@@ -1158,3 +1158,25 @@ update | |||||
update | update | ||||
- ‘7天’,‘30天’文字 改成 ‘前7天’,‘前30天’, | - ‘7天’,‘30天’文字 改成 ‘前7天’,‘前30天’, | ||||
## v1.0.125 | |||||
`2024.5.27` | |||||
update | |||||
- 增加 周报详情不显示对比条件 | |||||
## v1.0.126 | |||||
`2024.6.18` | |||||
fix | |||||
- 修复 心理首页页面显示空白的问题 | |||||
## v1.0.127 | |||||
`2024.6.21` | |||||
update | |||||
- 增加 app打开充值h5跳转到话费查询页面 | |||||
- 增加 app点击订购套餐提示 |
@@ -8,7 +8,7 @@ | |||||
import store from "@/store"; | import store from "@/store"; | ||||
// 情绪模型 | // 情绪模型 | ||||
const appTypeList = ['1']; | const appTypeList = ['1']; | ||||
export const VERSION_MODEL = '1.0.124F'; //版本号 | |||||
export const VERSION_MODEL = '1.0.127F'; //版本号 | |||||
export const IMAGE_URL = { | export const IMAGE_URL = { | ||||
production: 'http://zfb.ssjlai.com/web/', | production: 'http://zfb.ssjlai.com/web/', | ||||
test: 'http://zfb.ssjlai.com/web/', | test: 'http://zfb.ssjlai.com/web/', | ||||
@@ -7,19 +7,14 @@ | |||||
--> | --> | ||||
<template> | <template> | ||||
<div class="card-info-container" v-show="isShowPage"> | <div class="card-info-container" v-show="isShowPage"> | ||||
<van-nav-bar title="话费查询" | |||||
:left-arrow="false" | |||||
:border="true"> | |||||
<van-nav-bar title="话费查询" :left-arrow="false" :border="true"> | |||||
</van-nav-bar> | </van-nav-bar> | ||||
<div class="check-container"> | <div class="check-container"> | ||||
<!-- header --> | <!-- header --> | ||||
<div class="header"> | <div class="header"> | ||||
<!-- banner --> | <!-- banner --> | ||||
<div class="banner"> | <div class="banner"> | ||||
<van-image | |||||
:src="logo" | |||||
round | |||||
> | |||||
<van-image :src="logo" round> | |||||
</van-image> | </van-image> | ||||
<div class="right-message"> | <div class="right-message"> | ||||
<p>{{ setMeal.msisdn }}</p> | <p>{{ setMeal.msisdn }}</p> | ||||
@@ -28,7 +23,15 @@ | |||||
<p class="padding-left">ICCID:{{ setMeal.iccid || '--' }}</p> | <p class="padding-left">ICCID:{{ setMeal.iccid || '--' }}</p> | ||||
<p class="padding-left">语音通话接听免费,免漫游费。禁止手机使用</p> | <p class="padding-left">语音通话接听免费,免漫游费。禁止手机使用</p> | ||||
<div class="action"> | <div class="action"> | ||||
<div class="action-item"><p>{{ setMeal.realname || '--' }}</p></div> <span> | </span> <div class="action-item"><p>{{ setMeal.cardState || '--' }}</p></div> <span> | </span> <div class="btn"><p @click="onRefresh">刷新</p></div> | |||||
<div class="action-item"> | |||||
<p>{{ setMeal.realname || '--' }}</p> | |||||
</div> <span> | </span> | |||||
<div class="action-item"> | |||||
<p>{{ setMeal.cardState || '--' }}</p> | |||||
</div> <span> | </span> | |||||
<div class="btn"> | |||||
<p @click="onRefresh">刷新</p> | |||||
</div> | |||||
</div> | </div> | ||||
</div> | </div> | ||||
<!-- 套餐详情 --> | <!-- 套餐详情 --> | ||||
@@ -53,11 +56,13 @@ | |||||
<!-- 套餐操作 --> | <!-- 套餐操作 --> | ||||
<div class="card-details-menu"> | <div class="card-details-menu"> | ||||
<div class="meal-item" @click="onMealBuy"> | <div class="meal-item" @click="onMealBuy"> | ||||
<img src="" alt=""/> | |||||
<img src="" | |||||
alt="" /> | |||||
<p>套餐订购</p> | <p>套餐订购</p> | ||||
</div> | </div> | ||||
<div class="meal-item" @click="onRecordCheck"> | <div class="meal-item" @click="onRecordCheck"> | ||||
<img src="" alt=""/> | |||||
<img src="" | |||||
alt="" /> | |||||
<p>订购记录</p> | <p>订购记录</p> | ||||
</div> | </div> | ||||
</div> | </div> | ||||
@@ -76,325 +81,380 @@ import { isNotNull } from "@/utils/index"; | |||||
import APICore from "@/api/core"; | import APICore from "@/api/core"; | ||||
import AppId from "@/config/appId"; | import AppId from "@/config/appId"; | ||||
export default { | export default { | ||||
name:'cardInfo', | |||||
inject: ["reload"], | |||||
data(){ | |||||
return { | |||||
//套餐信息 | |||||
setMeal: { | |||||
expireTime: '', //套餐过期时间 | |||||
residueVoiceData: '', //剩余语音 | |||||
availableData: '', //流量套餐 | |||||
residueFlow: '', //剩余流量 | |||||
iccid: this.$route.query.iccid, //iccid | |||||
cardState: '', //卡激活状态 | |||||
realname: '', //是否已实名 1是 0 否 | |||||
msisdn: '', //msisdn | |||||
isUnicom: null, //是否是联通 | |||||
}, | |||||
isShowMenu: this.$route.query.isShowMenu, | |||||
params: {}, | |||||
isShowPage: false, //是否显示整个页面 | |||||
code: '', //微信授权code | |||||
} | |||||
}, | |||||
computed: { | |||||
// 顶部图标 | |||||
logo(){ | |||||
if(this.setMeal.isUnicom !== null) { | |||||
return this.setMeal.isUnicom ? require('@/assets/img/unicom.png') : require('@/assets/img/yidong_logo.png') | |||||
} else { | |||||
return null | |||||
} | |||||
} | |||||
}, | |||||
created() { | |||||
this.getAuth(); | |||||
this.getToken(); | |||||
this.getParams(); | |||||
this.getCardInfo(); | |||||
}, | |||||
methods: { | |||||
// 获取core token | |||||
getAuth() { | |||||
let manufactorId = "5bf13062-a41e-4d00-ba14-1101aad12650"; | |||||
APICore.getAuth({ manufactorId: manufactorId }).then(res => { | |||||
this.$store.commit("gatewayToken", res.data.data); | |||||
}); | |||||
}, | |||||
// 获取token | |||||
getToken() { | |||||
let manufacturerNo = '9f166b07-ff83-4991-84dc-ca6ad4a6b95b'; | |||||
return new Promise((resolve) => { | |||||
APIPay.getToken(manufacturerNo).then(res => { | |||||
let data = res.data; | |||||
if(data.code === 20000) { | |||||
this.$store.commit("token", data.token); | |||||
resolve(true); | |||||
} | |||||
}); | |||||
}) | |||||
name: 'cardInfo', | |||||
inject: ["reload"], | |||||
data() { | |||||
return { | |||||
//套餐信息 | |||||
setMeal: { | |||||
expireTime: '', //套餐过期时间 | |||||
residueVoiceData: '', //剩余语音 | |||||
availableData: '', //流量套餐 | |||||
residueFlow: '', //剩余流量 | |||||
iccid: this.$route.query.iccid, //iccid | |||||
cardState: '', //卡激活状态 | |||||
realname: '', //是否已实名 1是 0 否 | |||||
msisdn: '', //msisdn | |||||
isUnicom: null, //是否是联通 | |||||
}, | |||||
isShowMenu: this.$route.query.isShowMenu, | |||||
params: {}, | |||||
isShowPage: false, //是否显示整个页面 | |||||
code: '', //微信授权code | |||||
} | |||||
}, | }, | ||||
// 获取url传过来的参数 | |||||
getParams() { | |||||
let params = this.$route.query; | |||||
if (params) { | |||||
this.params = {...params}; | |||||
let url = window.location.href.split("?code=")[1]; | |||||
if ( isNotNull(url) || window.location.href.indexOf("code") > -1) { | |||||
let timeStamp = new Date().getTime(); | |||||
let code = url.split("&")[0]; | |||||
this.code = code; | |||||
if (isNotNull(code)) { | |||||
this.isShowPage = true; | |||||
if(!params.isHasCode) { | |||||
this.getOpenId(code); | |||||
} | |||||
} else { | |||||
this.$dialog({ | |||||
message: '系统繁忙,请重新进入' | |||||
}) | |||||
} | |||||
computed: { | |||||
// 顶部图标 | |||||
logo() { | |||||
if (this.setMeal.isUnicom !== null) { | |||||
return this.setMeal.isUnicom ? require('@/assets/img/unicom.png') : require('@/assets/img/yidong_logo.png') | |||||
} else { | } else { | ||||
this.getWxCode(); | |||||
return null | |||||
} | } | ||||
}, | |||||
isWeChat() { | |||||
const ua = window.navigator.userAgent.toLowerCase(); | |||||
return /micromessenger/.test(ua); | |||||
} | } | ||||
}, | }, | ||||
getWxCode() { | |||||
let params = this.params; | |||||
let commonUrl = process.env.VUE_APP_BASE_API; | |||||
let redUrl = encodeURIComponent(`${commonUrl}/h5-frontendweb/#/cardInfo?imei=${params.imei}&iccid=${params.iccid}`); | |||||
let url = `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${AppId}&redirect_uri=${redUrl}&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect`; | |||||
window.location.href = url; | |||||
async mounted() { | |||||
await this.getAuth(); | |||||
await this.getToken(); | |||||
await this.getParams(); | |||||
await this.getCardInfo(); | |||||
}, | }, | ||||
// 根据code获取openId | |||||
getOpenId(code) { | |||||
let openId = this.$store.getters.openId; | |||||
APIPay.getOpenId(code).then( async res => { | |||||
let data= res.data; | |||||
if(data.code === 20000) { | |||||
this.$store.commit("openId", data.data.openId); | |||||
}else if (data.state === false) { | |||||
console.log("token过期"); | |||||
let hasToken = await this.getToken(); | |||||
if(hasToken) { | |||||
this.getOpenId(this.code); | |||||
} else { | |||||
this.$dialog({ | |||||
message: '系统繁忙,请重新进入' | |||||
}) | |||||
methods: { | |||||
// 获取core token | |||||
getAuth() { | |||||
let manufactorId = "5bf13062-a41e-4d00-ba14-1101aad12650"; | |||||
return new Promise((resolve) => { | |||||
APICore.getAuth({ manufactorId: manufactorId }).then(res => { | |||||
this.$store.commit("gatewayToken", res.data.data); | |||||
}); | |||||
resolve(true) | |||||
}) | |||||
}, | |||||
// 获取token | |||||
getToken() { | |||||
let manufacturerNo = '9f166b07-ff83-4991-84dc-ca6ad4a6b95b'; | |||||
return new Promise((resolve) => { | |||||
APIPay.getToken(manufacturerNo).then(res => { | |||||
let data = res.data; | |||||
if (data.code === 20000) { | |||||
this.$store.commit("token", data.token); | |||||
} | |||||
}); | |||||
resolve(true); | |||||
}) | |||||
}, | |||||
// 获取url传过来的参数 | |||||
getParams() { | |||||
let params = this.$route.query; | |||||
return new Promise(resolve => { | |||||
if (params) { | |||||
this.params = { ...params }; | |||||
let url = window.location.href.split("?code=")[1]; | |||||
if (isNotNull(url) && window.location.href.indexOf("code") > -1 && this.isWeChat) { | |||||
let timeStamp = new Date().getTime(); | |||||
let code = url.split("&")[0]; | |||||
this.code = code; | |||||
if (isNotNull(code)) { | |||||
this.isShowPage = true; | |||||
if (!params.isHasCode) { | |||||
this.getOpenId(code); | |||||
} | |||||
} else { | |||||
this.$dialog({ | |||||
message: '系统繁忙,请重新进入' | |||||
}) | |||||
} | |||||
} else { | |||||
if (this.isWeChat) { | |||||
this.getWxCode(); | |||||
} else { | |||||
this.isShowPage = true; | |||||
} | |||||
} | |||||
} | } | ||||
} | |||||
}) | |||||
}, | |||||
//获取小台风物联网卡信息 | |||||
getCardInfo() { | |||||
if( !this.isShowPage ) {return} | |||||
this.$toast.loading({ message: '查询中...' }); | |||||
let reqBody = { | |||||
imei: this.$route.query.imei, | |||||
iccid: this.$route.query.iccid || '' | |||||
} | |||||
APIWx.GetCardInfo(reqBody) | |||||
.then(res => { | |||||
resolve(true); | |||||
}) | |||||
}, | |||||
getWxCode() { | |||||
let params = this.params; | |||||
let commonUrl = process.env.NODE_ENV === "production" ? process.env.VUE_APP_BASE_API : 'https://id.gdssjl.com'; | |||||
let redUrl = encodeURIComponent(`${commonUrl}/h5-frontendweb/#/cardInfo?imei=${params.imei}&iccid=${params.iccid}`); | |||||
let url = `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${AppId}&redirect_uri=${redUrl}&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect`; | |||||
window.location.href = url; | |||||
}, | |||||
// 根据code获取openId | |||||
getOpenId(code) { | |||||
let openId = this.$store.getters.openId; | |||||
APIPay.getOpenId(code).then(async res => { | |||||
let data = res.data; | let data = res.data; | ||||
if (data.stateCode === 1 ) { | |||||
let item = data.data; | |||||
this.setMeal.expireTime = item.expireTime == '' ? "": this.$dayjs(item.expireTime).format("YYYY-MM-DD"); | |||||
this.setMeal.residueVoiceData = item.availableVoiceData; | |||||
this.setMeal.residueFlow = item.availableData; | |||||
this.setMeal.cardState = item.cardState; | |||||
this.setMeal.realname = Number(item.realname) === 1 ? '已实名' : '未实名'; | |||||
this.setMeal.msisdn = item.msisdn; | |||||
// 截取msisdn 前三位, 148 是移动,其它都是联通 | |||||
this.setMeal.isUnicom = item.msisdn.slice(0,3) === '148' ? false : true; | |||||
this.$toast.success({ | |||||
message: "查询成功", | |||||
duration: 1500 | |||||
}); | |||||
if (data.code === 20000) { | |||||
this.$store.commit("openId", data.data.openId); | |||||
} else if (data.state === false) { | |||||
console.log("token过期"); | |||||
let hasToken = await this.getToken(); | |||||
if (hasToken) { | |||||
/* this.getOpenId(this.code); */ | |||||
this.getWxCode(); | |||||
} else { | |||||
this.$dialog({ | |||||
message: '系统繁忙,请重新进入' | |||||
}) | |||||
} | |||||
} else { | |||||
this.getWxCode(); | |||||
} | } | ||||
}) | }) | ||||
.catch(error => { | |||||
console.log("接口报错了", error); | |||||
}).finally(() => { | |||||
this.$toast.clear(); | |||||
}, | |||||
//获取小台风物联网卡信息 | |||||
getCardInfo() { | |||||
if (!this.isShowPage) { return } | |||||
return new Promise((resolve) => { | |||||
this.$toast.loading({ message: '查询中...' }); | |||||
let reqBody = { | |||||
imei: this.$route.query.imei, | |||||
iccid: this.$route.query.iccid || '' | |||||
} | |||||
APIWx.GetCardInfo(reqBody) | |||||
.then(res => { | |||||
let data = res.data; | |||||
if (data.stateCode === 1) { | |||||
let item = data.data; | |||||
this.setMeal.expireTime = item.expireTime == '' ? "" : this.$dayjs(item.expireTime).format("YYYY-MM-DD"); | |||||
this.setMeal.residueVoiceData = item.availableVoiceData; | |||||
this.setMeal.residueFlow = item.availableData; | |||||
this.setMeal.cardState = item.cardState; | |||||
this.setMeal.realname = Number(item.realname) === 1 ? '已实名' : '未实名'; | |||||
this.setMeal.msisdn = item.msisdn; | |||||
// 截取msisdn 前三位, 148 是移动,其它都是联通 | |||||
this.setMeal.isUnicom = item.msisdn.slice(0, 3) === '148' ? false : true; | |||||
this.$toast.success({ | |||||
message: "查询成功", | |||||
duration: 1500 | |||||
}); | |||||
} else { | |||||
this.$toast.success({ | |||||
message: `${data.message}`, | |||||
duration: 1500 | |||||
}); | |||||
} | |||||
}) | |||||
.catch(error => { | |||||
console.log("接口报错了", error); | |||||
}).finally(() => { | |||||
setTimeout(() => { | |||||
this.$toast.clear(); | |||||
}, 1500); | |||||
}) | |||||
resolve(true) | |||||
}) | |||||
}, | |||||
// 返回 | |||||
onNavBack() { | |||||
/* this.$router.push({ name: 'device'}); */ | |||||
}, | |||||
// onRefresh 刷新 | |||||
onRefresh() { | |||||
this.reload(); | |||||
}, | |||||
// 购买套餐 | |||||
onMealBuy() { | |||||
this.$router.replace({ | |||||
name: 'packageBuy', | |||||
query: { imei: this.$route.query.imei, iccid: this.$route.query.iccid, isShowMenu: this.isShowMenu } | |||||
}) | }) | ||||
}, | |||||
// 返回 | |||||
onNavBack() { | |||||
/* this.$router.push({ name: 'device'}); */ | |||||
}, | |||||
// onRefresh 刷新 | |||||
onRefresh() { | |||||
this.reload(); | |||||
}, | |||||
// 购买套餐 | |||||
onMealBuy() { | |||||
this.$router.replace({ | |||||
name: 'packageBuy', | |||||
query: { imei: this.$route.query.imei, iccid: this.$route.query.iccid, isShowMenu: this.isShowMenu} | |||||
}) | |||||
}, | |||||
// 订购记录 | |||||
onRecordCheck () { | |||||
this.$router.replace({ | |||||
name: 'buyRecord', | |||||
query: { imei: this.$route.query.imei, iccid: this.$route.query.iccid, isShowMenu: this.isShowMenu} | |||||
}) | |||||
} | |||||
}, | |||||
// 订购记录 | |||||
onRecordCheck() { | |||||
this.$router.replace({ | |||||
name: 'buyRecord', | |||||
query: { imei: this.$route.query.imei, iccid: this.$route.query.iccid, isShowMenu: this.isShowMenu } | |||||
}) | |||||
} | |||||
} | |||||
} | |||||
} | } | ||||
</script> | </script> | ||||
<style scoped lang="scss"> | <style scoped lang="scss"> | ||||
.card-info-container { | |||||
max-height: 100vh; | |||||
width: 100%; | |||||
position: relative; | |||||
background-color: #fff; | |||||
p { | |||||
font-size: 16px; | |||||
color: #9B9B9B; | |||||
} | |||||
.check-container { | |||||
height: calc(100vh - 88px); | |||||
padding: 8px 10px; | |||||
.card-info-container { | |||||
max-height: 100vh; | |||||
width: 100%; | |||||
position: relative; | |||||
background-color: #fff; | |||||
p { | |||||
font-size: 16px; | |||||
color: #9B9B9B; | |||||
} | |||||
.check-container { | |||||
height: calc(100vh - 88px); | |||||
padding: 8px 10px; | |||||
display: flex; | |||||
justify-content: flex-start; | |||||
align-items: center; | |||||
flex-direction: column; | |||||
.header { | |||||
height: 200px; | |||||
width: 100%; | |||||
display: flex; | display: flex; | ||||
justify-content: flex-start; | |||||
align-items: center; | |||||
justify-content: space-around; | |||||
flex-direction: column; | flex-direction: column; | ||||
.header { | |||||
height: 200px; | |||||
width: 100%; | |||||
align-items: flex-start; | |||||
border: 1px solid #fff; | |||||
box-shadow: rgba(60, 64, 67, 0.3) 0px 1px 2px 0px, rgba(60, 64, 67, 0.15) 0px 2px 6px 2px; | |||||
.padding-left { | |||||
padding-left: 10px; | |||||
} | |||||
.banner { | |||||
height: 75px; | |||||
margin: 10px 0; | |||||
padding-left: 5px; | |||||
display: flex; | display: flex; | ||||
justify-content: space-around; | |||||
flex-direction: column; | |||||
align-items: flex-start; | |||||
border: 1px solid #fff; | |||||
box-shadow: rgba(60, 64, 67, 0.3) 0px 1px 2px 0px, rgba(60, 64, 67, 0.15) 0px 2px 6px 2px; | |||||
.padding-left { | |||||
padding-left: 10px; | |||||
} | |||||
.banner { | |||||
justify-content: flex-start; | |||||
align-items: center; | |||||
.van-image { | |||||
height: 75px; | height: 75px; | ||||
margin: 10px 0; | |||||
padding-left: 5px; | |||||
display: flex; | |||||
justify-content: flex-start; | |||||
align-items: center; | |||||
.van-image { | |||||
height: 75px; | |||||
width: 75px; | |||||
border: 5px solid #E0EEFF; | |||||
} | |||||
.right-message { | |||||
text-align: center; | |||||
margin-left: 10px; | |||||
p { | |||||
font-size: 18px; | |||||
color: #64A9FF; | |||||
} | |||||
} | |||||
width: 75px; | |||||
border: 5px solid #E0EEFF; | |||||
} | } | ||||
.action { | |||||
height: 35px; | |||||
.right-message { | |||||
text-align: center; | text-align: center; | ||||
padding-left: 10px; | |||||
width: 100%; | |||||
display: flex; | |||||
justify-content: flex-start; | |||||
align-items: center; | |||||
margin-left: 10px; | |||||
p { | p { | ||||
font-size: 16px; | |||||
font-size: 18px; | |||||
color: #64A9FF; | color: #64A9FF; | ||||
} | } | ||||
span { | |||||
display: block; | |||||
color: #9B9B9B; | |||||
font-size: 16px; | |||||
padding: 0 8px; | |||||
} | |||||
.btn { | |||||
height: 25px; | |||||
width: 75px; | |||||
line-height: 25px; | |||||
text-align: center; | |||||
background-color: #64A9FF; | |||||
border-radius: 10px; | |||||
p { | |||||
color: #fff; | |||||
} | |||||
} | |||||
} | } | ||||
} | } | ||||
.card-details { | |||||
height: 75px; | |||||
.action { | |||||
height: 35px; | |||||
text-align: center; | |||||
padding-left: 10px; | |||||
width: 100%; | width: 100%; | ||||
display: flex; | display: flex; | ||||
justify-content: space-between; | |||||
justify-content: flex-start; | |||||
align-items: center; | align-items: center; | ||||
margin-top: 20px; | |||||
border: 1px solid #fff; | |||||
box-shadow: rgba(60, 64, 67, 0.3) 0px 1px 2px 0px, rgba(60, 64, 67, 0.15) 0px 2px 6px 2px; | |||||
.set-meal { | |||||
flex: 1; | |||||
height: 50px; | |||||
display: flex; | |||||
justify-content: center; | |||||
align-items: center; | |||||
flex-direction: column; | |||||
p { | |||||
font-size: 16px; | |||||
color: #64A9FF; | |||||
} | |||||
span { | |||||
display: block; | |||||
color: #9B9B9B; | |||||
font-size: 16px; | |||||
padding: 0 8px; | |||||
} | |||||
.btn { | |||||
height: 25px; | |||||
width: 75px; | |||||
line-height: 25px; | |||||
text-align: center; | |||||
background-color: #64A9FF; | |||||
border-radius: 10px; | |||||
p { | p { | ||||
font-size: 16px; | |||||
padding: 5px 0; | |||||
} | |||||
.font-orange { | |||||
color: orange; | |||||
color: #fff; | |||||
} | } | ||||
} | } | ||||
.set-meal:nth-of-type(2) { | |||||
border-left: 1px solid #DDDDDD; | |||||
border-right: 1px solid #DDDDDD; | |||||
} | |||||
} | } | ||||
.card-details-menu { | |||||
height: 75px; | |||||
width: 100%; | |||||
} | |||||
.card-details { | |||||
height: 75px; | |||||
width: 100%; | |||||
display: flex; | |||||
justify-content: space-between; | |||||
align-items: center; | |||||
margin-top: 20px; | |||||
border: 1px solid #fff; | |||||
box-shadow: rgba(60, 64, 67, 0.3) 0px 1px 2px 0px, rgba(60, 64, 67, 0.15) 0px 2px 6px 2px; | |||||
.set-meal { | |||||
flex: 1; | |||||
height: 50px; | |||||
display: flex; | display: flex; | ||||
justify-content: flex-start; | |||||
justify-content: center; | |||||
align-items: center; | align-items: center; | ||||
margin-top: 20px; | |||||
border: 1px solid #fff; | |||||
box-shadow: rgba(60, 64, 67, 0.3) 0px 1px 2px 0px, rgba(60, 64, 67, 0.15) 0px 2px 6px 2px; | |||||
.meal-item { | |||||
flex: 1; | |||||
display: flex; | |||||
justify-content: center; | |||||
align-items: center; | |||||
flex-direction: column; | |||||
padding-left: 10px; | |||||
img { | |||||
height: 45px; | |||||
width: 40px | |||||
} | |||||
p { | |||||
font-size: 14px; | |||||
padding: 5px 0; | |||||
} | |||||
flex-direction: column; | |||||
p { | |||||
font-size: 16px; | |||||
padding: 5px 0; | |||||
} | |||||
.font-orange { | |||||
color: orange; | |||||
} | } | ||||
} | } | ||||
.tips-container { | |||||
width: 100%; | |||||
.set-meal:nth-of-type(2) { | |||||
border-left: 1px solid #DDDDDD; | |||||
border-right: 1px solid #DDDDDD; | |||||
} | |||||
} | |||||
.card-details-menu { | |||||
height: 75px; | |||||
width: 100%; | |||||
display: flex; | |||||
justify-content: flex-start; | |||||
align-items: center; | |||||
margin-top: 20px; | |||||
border: 1px solid #fff; | |||||
box-shadow: rgba(60, 64, 67, 0.3) 0px 1px 2px 0px, rgba(60, 64, 67, 0.15) 0px 2px 6px 2px; | |||||
.meal-item { | |||||
flex: 1; | |||||
display: flex; | display: flex; | ||||
justify-content: flex-start; | |||||
align-items: flex-start; | |||||
justify-content: center; | |||||
align-items: center; | |||||
flex-direction: column; | flex-direction: column; | ||||
padding-left: 10px; | |||||
img { | |||||
height: 45px; | |||||
width: 40px | |||||
} | |||||
p { | p { | ||||
margin: 10px; | |||||
color: red; | |||||
font-size: 14px; | |||||
padding: 5px 0; | |||||
} | } | ||||
} | } | ||||
} | } | ||||
.tips-container { | |||||
width: 100%; | |||||
display: flex; | |||||
justify-content: flex-start; | |||||
align-items: flex-start; | |||||
flex-direction: column; | |||||
p { | |||||
margin: 10px; | |||||
color: red; | |||||
} | |||||
} | |||||
} | } | ||||
} | |||||
</style> | </style> |
@@ -202,8 +202,13 @@ export default { | |||||
/* imgUrl = require(`@/assets/img/psychological/${name}_${level}.png`); */ | /* imgUrl = require(`@/assets/img/psychological/${name}_${level}.png`); */ | ||||
let numLevel = Number(level); | let numLevel = Number(level); | ||||
console.log(`@/assets/img/psychological/${name}_${numLevel}.png`); | console.log(`@/assets/img/psychological/${name}_${numLevel}.png`); | ||||
imgUrl = require(`@/assets/img/psychological/${name}_${numLevel + 1 | |||||
}.png`); | |||||
if (numLevel < 0) { | |||||
imgUrl = require(`@/assets/img/psychological/${name}_1.png`); | |||||
} else { | |||||
imgUrl = require(`@/assets/img/psychological/${name}_${numLevel + 1}.png`); | |||||
} | |||||
/* switch(level) { | /* switch(level) { | ||||
case '0': | case '0': | ||||
imgUrl = require(`@/assets/img/psychological/${name}_${numLevel + 1}.png`); | imgUrl = require(`@/assets/img/psychological/${name}_${numLevel + 1}.png`); | ||||
@@ -63,7 +63,7 @@ | |||||
}}</label> | }}</label> | ||||
</div> | </div> | ||||
<div class="status"> | |||||
<div class="status" v-if="isShowCompare"> | |||||
<img :src="calcImg(item.percentage, item.lastPercentage)" alt="" /> | <img :src="calcImg(item.percentage, item.lastPercentage)" alt="" /> | ||||
<span :style="{ | <span :style="{ | ||||
color: | color: | ||||
@@ -126,8 +126,8 @@ | |||||
item.days | item.days | ||||
}}</span> | }}</span> | ||||
<span class="day-text">天</span> | <span class="day-text">天</span> | ||||
<img :src="calcWeekImg(item.days, item.lastDay)" alt="" /> | |||||
<span class="day-text status">{{ | |||||
<img :src="calcWeekImg(item.days, item.lastDay)" alt="" v-if="isShowCompare" /> | |||||
<span class="day-text status" v-if="isShowCompare">{{ | |||||
calcWeekImg(item.days, item.lastDay, true) | calcWeekImg(item.days, item.lastDay, true) | ||||
}}</span> | }}</span> | ||||
</p> | </p> | ||||
@@ -249,7 +249,7 @@ export default { | |||||
weekResult: {}, | weekResult: {}, | ||||
upImg: require("@/assets/img/psychological/up.png"), | upImg: require("@/assets/img/psychological/up.png"), | ||||
downImg: require("@/assets/img/psychological/down.png"), | downImg: require("@/assets/img/psychological/down.png"), | ||||
isShowCompare: null, //是否显示周对比 | |||||
}; | }; | ||||
}, | }, | ||||
created() { | created() { | ||||
@@ -694,6 +694,7 @@ export default { | |||||
this.weekResult.Summary = this.$replaceAll(data.Summary, '抑郁', '忧郁') | this.weekResult.Summary = this.$replaceAll(data.Summary, '抑郁', '忧郁') | ||||
this.weekResult.Advice = this.$replaceAll(data.Advice, '抑郁', '忧郁') | this.weekResult.Advice = this.$replaceAll(data.Advice, '抑郁', '忧郁') | ||||
this.emoName = this.calcTitle(data.Type); | this.emoName = this.calcTitle(data.Type); | ||||
this.isShowCompare = data.LastweekData; | |||||
} | } | ||||
let None = { | let None = { | ||||
count: data.None, | count: data.None, | ||||
@@ -14,28 +14,17 @@ | |||||
</van-nav-bar> | </van-nav-bar> | ||||
<!-- 套餐内容 --> | <!-- 套餐内容 --> | ||||
<div class="package-container"> | <div class="package-container"> | ||||
<van-tabs | |||||
type="line" | |||||
v-model="active" | |||||
color="#1890ff" | |||||
background="#fafafa" | |||||
swipeable | |||||
line-width="20%" | |||||
line-height="4px" | |||||
> | |||||
<van-tabs type="line" v-model="active" color="#1890ff" background="#fafafa" swipeable line-width="20%" | |||||
line-height="4px"> | |||||
<van-tab title="加油包"> | <van-tab title="加油包"> | ||||
<div class="refuel-package" v-if="refuelPackageList.length > 0"> | <div class="refuel-package" v-if="refuelPackageList.length > 0"> | ||||
<div | |||||
class="refuel-item" | |||||
v-for="(item, index) in refuelPackageList" | |||||
:key="index" | |||||
> | |||||
<div class="refuel-item" v-for="(item, index) in refuelPackageList" :key="index"> | |||||
<div class="title"> | <div class="title"> | ||||
<p>{{item.packagesName}}</p> | |||||
<p>{{ item.packagesName }}</p> | |||||
</div> | </div> | ||||
<div class="bottom"> | <div class="bottom"> | ||||
<span> | <span> | ||||
{{item.packagesPrice}} | |||||
{{ item.packagesPrice }} | |||||
<span class="price-span">元</span> | <span class="price-span">元</span> | ||||
</span> | </span> | ||||
<div class="btn-button" @click="onBuyRefuel(item)"> | <div class="btn-button" @click="onBuyRefuel(item)"> | ||||
@@ -51,11 +40,7 @@ | |||||
</van-tab> | </van-tab> | ||||
<van-tab title="基础套餐"> | <van-tab title="基础套餐"> | ||||
<div class="base-package" v-if="basePackageList.length > 0"> | <div class="base-package" v-if="basePackageList.length > 0"> | ||||
<div | |||||
class="base-item" | |||||
v-for="(item, index) in basePackageList" | |||||
:key="index" | |||||
> | |||||
<div class="base-item" v-for="(item, index) in basePackageList" :key="index"> | |||||
<div class="base-item-content"> | <div class="base-item-content"> | ||||
<!-- <div class="title"> | <!-- <div class="title"> | ||||
<p>{{item.packagesName}}</p> | <p>{{item.packagesName}}</p> | ||||
@@ -65,24 +50,20 @@ | |||||
</div> | </div> | ||||
<div class="details"> | <div class="details"> | ||||
<p> | <p> | ||||
<span | |||||
class="orange large" | |||||
>¥{{(item.packagesPrice/(item.packageIssue === 0 ? 1: item.packageIssue)).toFixed(0)}}</span>元/月, | |||||
<span class="orange large">¥{{ (item.packagesPrice / (item.packageIssue === 0 ? | |||||
1 : | |||||
item.packageIssue)).toFixed(0) }}</span>元/月, | |||||
</p> | </p> | ||||
<p class="total"> | <p class="total"> | ||||
<span>合计</span> | <span>合计</span> | ||||
<span class="orange price">{{item.packagesPrice}}元</span> | |||||
<span class="orange price">{{ item.packagesPrice }}元</span> | |||||
</p> | </p> | ||||
</div> | </div> | ||||
<div class="radios-con"> | <div class="radios-con"> | ||||
<div class="pay-type"> | <div class="pay-type"> | ||||
<p>支付方式:</p> | <p>支付方式:</p> | ||||
</div> | </div> | ||||
<van-radio-group | |||||
v-model="radio" | |||||
direction="horizontal" | |||||
@change="onRaidoChange" | |||||
> | |||||
<van-radio-group v-model="radio" direction="horizontal" @change="onRaidoChange"> | |||||
<van-radio name="1"> | <van-radio name="1"> | ||||
<template #default> | <template #default> | ||||
<div class="radio-con"> | <div class="radio-con"> | ||||
@@ -134,38 +115,38 @@ import AppId from "@/config/appId"; | |||||
import { APIPay } from "@/api/pay"; | import { APIPay } from "@/api/pay"; | ||||
let wx = require("weixin-js-sdk"); // TODO 再封装,可拦截错误提示等操作 | let wx = require("weixin-js-sdk"); // TODO 再封装,可拦截错误提示等操作 | ||||
export default { | export default { | ||||
name:'', | |||||
data(){ | |||||
return { | |||||
basePackageList: [], //基础套餐 | |||||
refuelPackageList: [], //加油包 | |||||
outTradeNo: "", //订单号 | |||||
price: "", //价格, | |||||
isShowNoData: false, //是否显示无套餐内容, 默认false | |||||
radio: '1', //支付方式单选按钮默认值 | |||||
payProductId: null, //套餐id | |||||
packageIssue: null, //套餐分期 | |||||
payType: '1', //支付方式 1 微信, 2 支付宝,支付宝又分为花呗和全额支付,全额支付分期数传0 或者1 ,花呗则传 3 6 12 | |||||
active: 0, //tabs默认选择的下标 | |||||
} | |||||
}, | |||||
methods: { | |||||
onNavBack() { | |||||
this.$router.replace({ | |||||
name: "cardInfo", | |||||
query: { imei: this.$route.query.imei, iccid: this.$route.query.iccid, isShowMenu: true, isHasCode: true} | |||||
}); | |||||
}, | |||||
// 获取core token | |||||
getAuth() { | |||||
let manufactorId = "5bf13062-a41e-4d00-ba14-1101aad12650"; | |||||
APICore.getAuth({ manufactorId: manufactorId }).then(res => { | |||||
this.$store.commit("gatewayToken", res.data.data); | |||||
}); | |||||
name: '', | |||||
data() { | |||||
return { | |||||
basePackageList: [], //基础套餐 | |||||
refuelPackageList: [], //加油包 | |||||
outTradeNo: "", //订单号 | |||||
price: "", //价格, | |||||
isShowNoData: false, //是否显示无套餐内容, 默认false | |||||
radio: '1', //支付方式单选按钮默认值 | |||||
payProductId: null, //套餐id | |||||
packageIssue: null, //套餐分期 | |||||
payType: '1', //支付方式 1 微信, 2 支付宝,支付宝又分为花呗和全额支付,全额支付分期数传0 或者1 ,花呗则传 3 6 12 | |||||
active: 0, //tabs默认选择的下标 | |||||
} | |||||
}, | }, | ||||
// 获取微信授权 | |||||
getWxAutograph(){ | |||||
let that = this; | |||||
methods: { | |||||
onNavBack() { | |||||
this.$router.replace({ | |||||
name: "cardInfo", | |||||
query: { imei: this.$route.query.imei, iccid: this.$route.query.iccid, isShowMenu: true, isHasCode: true } | |||||
}); | |||||
}, | |||||
// 获取core token | |||||
getAuth() { | |||||
let manufactorId = "5bf13062-a41e-4d00-ba14-1101aad12650"; | |||||
APICore.getAuth({ manufactorId: manufactorId }).then(res => { | |||||
this.$store.commit("gatewayToken", res.data.data); | |||||
}); | |||||
}, | |||||
// 获取微信授权 | |||||
getWxAutograph() { | |||||
let that = this; | |||||
return new Promise((resolve, reject) => { | return new Promise((resolve, reject) => { | ||||
APIWx.createJSSDK({ | APIWx.createJSSDK({ | ||||
sUrl: window.location.href.split("#")[0], | sUrl: window.location.href.split("#")[0], | ||||
@@ -192,10 +173,10 @@ export default { | |||||
console.log(err); | console.log(err); | ||||
}); | }); | ||||
}); | }); | ||||
}, | |||||
// 获取套餐列表数据 | |||||
getDevicePayPackage() { | |||||
this.$toast.loading({ | |||||
}, | |||||
// 获取套餐列表数据 | |||||
getDevicePayPackage() { | |||||
this.$toast.loading({ | |||||
message: "加载中", | message: "加载中", | ||||
duration: 1500 | duration: 1500 | ||||
}); | }); | ||||
@@ -211,7 +192,7 @@ export default { | |||||
} else if (res.data.code === 0 && res.data.data === null) { | } else if (res.data.code === 0 && res.data.data === null) { | ||||
this.isShowNoData = true; | this.isShowNoData = true; | ||||
} else { | } else { | ||||
if(res.data.data === null) { | |||||
if (res.data.data === null) { | |||||
this.isShowNoData = false; | this.isShowNoData = false; | ||||
} else { | } else { | ||||
let data = res.data.data.packagesList; | let data = res.data.data.packagesList; | ||||
@@ -242,19 +223,32 @@ export default { | |||||
this.$toast.clear(); | this.$toast.clear(); | ||||
}, 1500); | }, 1500); | ||||
}); | }); | ||||
}, | |||||
// 购买加油包 | |||||
onBuyRefuel(data){ | |||||
console.log("加油包", data); | |||||
this.price = data.packagesPrice; | |||||
this.wxPay(data,1); | |||||
}, | |||||
// 购买基础套餐 | |||||
onBuyBase(data) { | |||||
console.log("基础包", data); | |||||
this.price = data.packagesPrice; | |||||
let payTypeToPackAgeId = data.payTypeList; | |||||
if (this.payType == '2') { | |||||
}, | |||||
// 购买加油包 | |||||
onBuyRefuel(data) { | |||||
console.log("加油包", data); | |||||
if (!this.isWeChat) { | |||||
return this.$dialog.confirm({ | |||||
message: '请用微信客户端打开此页。', | |||||
showCancelButton: false, | |||||
}) | |||||
} | |||||
this.price = data.packagesPrice; | |||||
this.wxPay(data, 1); | |||||
}, | |||||
// 购买基础套餐 | |||||
onBuyBase(data) { | |||||
console.log("基础包", data); | |||||
console.log("isWeChat", this.isWeChat); | |||||
if (!this.isWeChat) { | |||||
return this.$dialog.confirm({ | |||||
message: '请用微信客户端打开此页。', | |||||
showCancelButton: false, | |||||
}) | |||||
} | |||||
this.price = data.packagesPrice; | |||||
let payTypeToPackAgeId = data.payTypeList; | |||||
if (this.payType == '2') { | |||||
// 全额 | // 全额 | ||||
this.payProductId = payTypeToPackAgeId.filter(item => { | this.payProductId = payTypeToPackAgeId.filter(item => { | ||||
return item.payType == '2' | return item.payType == '2' | ||||
@@ -279,7 +273,7 @@ export default { | |||||
})[0].productId; | })[0].productId; | ||||
this.packageIssue = 0; | this.packageIssue = 0; | ||||
console.log("this.payProductId3", this.payProductId); | console.log("this.payProductId3", this.payProductId); | ||||
if(openId === null || openId === 'null') { | |||||
if (openId === null || openId === 'null') { | |||||
this.$dialog.confirm({ | this.$dialog.confirm({ | ||||
message: '获取OpenId失败,请您重新进入', | message: '获取OpenId失败,请您重新进入', | ||||
showCancelButton: false, | showCancelButton: false, | ||||
@@ -288,56 +282,56 @@ export default { | |||||
this.wxPay(data); | this.wxPay(data); | ||||
} | } | ||||
} | } | ||||
}, | |||||
// 支付类型切换 | |||||
onRaidoChange(value) { | |||||
console.log("选择的支付类型是", value); | |||||
this.payType = value; | |||||
}, | |||||
// 微信支付 | |||||
wxPay(data, packageType) { | |||||
let that = this; | |||||
const orderData = data; | |||||
console.log("orderData", orderData); | |||||
let reqBody = { | |||||
openId: this.$store.getters.openId, //openId | |||||
imei: that.$route.query.imei, //imei | |||||
iccid: that.$route.query.iccid, | |||||
productId: orderData.payTypeList[0].productId, //套餐id | |||||
packageName: | |||||
orderData.productModel + "," + orderData.packagesName, //套餐名字 | |||||
packagePayType: '1', //支付类型, 默认微信 | |||||
pkId: data.packagesCardId, | |||||
packageIssue: orderData.packageIssue, //分期 | |||||
packagePrice: orderData.packagesPrice * 100 | |||||
}; | |||||
}, | |||||
// 支付类型切换 | |||||
onRaidoChange(value) { | |||||
console.log("选择的支付类型是", value); | |||||
this.payType = value; | |||||
}, | |||||
// 微信支付 | |||||
wxPay(data, packageType) { | |||||
let that = this; | |||||
const orderData = data; | |||||
console.log("orderData", orderData); | |||||
let reqBody = { | |||||
openId: this.$store.getters.openId, //openId | |||||
imei: that.$route.query.imei, //imei | |||||
iccid: that.$route.query.iccid, | |||||
productId: orderData.payTypeList[0].productId, //套餐id | |||||
packageName: | |||||
orderData.productModel + "," + orderData.packagesName, //套餐名字 | |||||
packagePayType: '1', //支付类型, 默认微信 | |||||
pkId: data.packagesCardId, | |||||
packageIssue: orderData.packageIssue, //分期 | |||||
packagePrice: orderData.packagesPrice * 100 | |||||
}; | |||||
// 1.获取微信预下单Id | // 1.获取微信预下单Id | ||||
APICore.payLiveBaseDevice(reqBody) | |||||
.then(res => { | |||||
if (res.data.code === 104 || res.data.code === 106) { | |||||
this.getAuth(); | |||||
setTimeout(() => { | |||||
this.wxPay(orderData); | |||||
}, 1000); | |||||
} else if ( res.data.code !== 0){ | |||||
return this.$dialog.confirm({ | |||||
message: `请反馈给一线人员,\n${res.data.message},或者请您重新进入`, | |||||
showCancelButton: false | |||||
}) | |||||
} | |||||
let wxData = res.data.data; | |||||
let outTradeNo = wxData.out_trade_no; | |||||
that.outTradeNo = wxData.out_trade_no; | |||||
//this.checkWxPayResult(outTradeNo); | |||||
//this.closeTime(); | |||||
// 调起微信支付收银台 | |||||
this.onWxPay(wxData,packageType); | |||||
}) | |||||
.catch(error => { | |||||
console.log("error", error); | |||||
}) | |||||
}, | |||||
onWxPay(data,packageType) { | |||||
APICore.payLiveBaseDevice(reqBody) | |||||
.then(res => { | |||||
if (res.data.code === 104 || res.data.code === 106) { | |||||
this.getAuth(); | |||||
setTimeout(() => { | |||||
this.wxPay(orderData); | |||||
}, 1000); | |||||
} else if (res.data.code !== 0) { | |||||
return this.$dialog.confirm({ | |||||
message: `请反馈给一线人员,\n${res.data.message},或者请您重新进入`, | |||||
showCancelButton: false | |||||
}) | |||||
} | |||||
let wxData = res.data.data; | |||||
let outTradeNo = wxData.out_trade_no; | |||||
that.outTradeNo = wxData.out_trade_no; | |||||
//this.checkWxPayResult(outTradeNo); | |||||
//this.closeTime(); | |||||
// 调起微信支付收银台 | |||||
this.onWxPay(wxData, packageType); | |||||
}) | |||||
.catch(error => { | |||||
console.log("error", error); | |||||
}) | |||||
}, | |||||
onWxPay(data, packageType) { | |||||
let that = this; | let that = this; | ||||
function onBridgeReady() { | function onBridgeReady() { | ||||
WeixinJSBridge.invoke( | WeixinJSBridge.invoke( | ||||
@@ -350,13 +344,13 @@ export default { | |||||
signType: data.signType, //微信签名方式: | signType: data.signType, //微信签名方式: | ||||
paySign: data.paySign //微信签名 | paySign: data.paySign //微信签名 | ||||
}, | }, | ||||
function(res) { | |||||
function (res) { | |||||
if (res.err_msg == "get_brand_wcpay_request:ok") { | if (res.err_msg == "get_brand_wcpay_request:ok") { | ||||
// 使用以上方式判断前端返回,微信团队郑重提示: | // 使用以上方式判断前端返回,微信团队郑重提示: | ||||
//res.err_msg将在用户支付成功后返回ok,但并不保证它绝对可靠。 | //res.err_msg将在用户支付成功后返回ok,但并不保证它绝对可靠。 | ||||
if(packageType === 1) { | |||||
// 加油包不用跳转,直接提示支付成功 | |||||
// 2023.06.09 修改充值成功提示如下: | |||||
if (packageType === 1) { | |||||
// 加油包不用跳转,直接提示支付成功 | |||||
// 2023.06.09 修改充值成功提示如下: | |||||
that.$toast.success({ | that.$toast.success({ | ||||
message: '充值成功,请重启设备后,恢复正常使用。' | message: '充值成功,请重启设备后,恢复正常使用。' | ||||
}); | }); | ||||
@@ -375,7 +369,7 @@ export default { | |||||
}); | }); | ||||
} | } | ||||
} else { | } else { | ||||
let cancelMessage = packageType === 1 ? '立即订购': '套餐订购' | |||||
let cancelMessage = packageType === 1 ? '立即订购' : '套餐订购' | |||||
that.$dialog.confirm({ | that.$dialog.confirm({ | ||||
message: `请点击“${cancelMessage}”支付`, | message: `请点击“${cancelMessage}”支付`, | ||||
showCancelButton: false | showCancelButton: false | ||||
@@ -402,8 +396,8 @@ export default { | |||||
onBridgeReady(); | onBridgeReady(); | ||||
} | } | ||||
}, | }, | ||||
// 跳转到支付宝花呗外部链接 | |||||
aliPay(data) { | |||||
// 跳转到支付宝花呗外部链接 | |||||
aliPay(data) { | |||||
console.log("选择了支付宝::", data); | console.log("选择了支付宝::", data); | ||||
this.$toast.loading({ | this.$toast.loading({ | ||||
message: "加载中" | message: "加载中" | ||||
@@ -462,12 +456,19 @@ export default { | |||||
.finally(() => { | .finally(() => { | ||||
this.$toast.clear(); | this.$toast.clear(); | ||||
}); | }); | ||||
}, | |||||
}, | |||||
computed: { | |||||
isWeChat() { | |||||
const ua = window.navigator.userAgent.toLowerCase(); | |||||
return /micromessenger/.test(ua); | |||||
} | |||||
}, | |||||
created() { | |||||
// 套餐列表 | |||||
this.getDevicePayPackage(); | |||||
}, | }, | ||||
}, | |||||
created() { | |||||
// 套餐列表 | |||||
this.getDevicePayPackage(); | |||||
}, | |||||
} | } | ||||
</script> | </script> | ||||
<style lang="scss"> | <style lang="scss"> | ||||
@@ -475,21 +476,26 @@ export default { | |||||
.van-tabs { | .van-tabs { | ||||
min-height: 100vh; | min-height: 100vh; | ||||
background: #fafafa; | background: #fafafa; | ||||
&.blue { | &.blue { | ||||
background: #1890ff !important; | background: #1890ff !important; | ||||
} | } | ||||
.van-tabs__wrap { | .van-tabs__wrap { | ||||
height: 50px; | height: 50px; | ||||
width: 100%; | width: 100%; | ||||
.van-tabs__nav { | .van-tabs__nav { | ||||
.van-tab { | .van-tab { | ||||
@include center(); | @include center(); | ||||
padding: 0; | padding: 0; | ||||
span { | span { | ||||
color: #333333; | color: #333333; | ||||
font-size: 16px; | font-size: 16px; | ||||
padding: 4px; | padding: 4px; | ||||
} | } | ||||
&.van-tab--active { | &.van-tab--active { | ||||
span { | span { | ||||
color: #1890ff; | color: #1890ff; | ||||
@@ -507,13 +513,16 @@ export default { | |||||
.package-buy-container { | .package-buy-container { | ||||
height: 100vh; | height: 100vh; | ||||
overflow: hidden; | overflow: hidden; | ||||
.package-container { | .package-container { | ||||
height: calc(100vh - 88px); | height: calc(100vh - 88px); | ||||
background: #fafafa; | background: #fafafa; | ||||
.refuel-package { | .refuel-package { | ||||
height: calc(100vh - 88px); | height: calc(100vh - 88px); | ||||
padding: 10px 20px; | padding: 10px 20px; | ||||
overflow: scroll; | overflow: scroll; | ||||
.refuel-item { | .refuel-item { | ||||
padding: 10px; | padding: 10px; | ||||
margin-bottom: 20px; | margin-bottom: 20px; | ||||
@@ -525,41 +534,50 @@ export default { | |||||
border-left: 3px solid #1890ff; | border-left: 3px solid #1890ff; | ||||
box-shadow: rgba(60, 64, 67, 0.3) 0px 1px 2px 0px, | box-shadow: rgba(60, 64, 67, 0.3) 0px 1px 2px 0px, | ||||
rgba(60, 64, 67, 0.15) 0px 2px 6px 2px; | rgba(60, 64, 67, 0.15) 0px 2px 6px 2px; | ||||
p, | p, | ||||
span { | span { | ||||
font-size: 16px; | font-size: 16px; | ||||
} | } | ||||
.title { | .title { | ||||
text-align: left; | text-align: left; | ||||
padding-top: 10px; | padding-top: 10px; | ||||
font-weight: 500; | font-weight: 500; | ||||
} | } | ||||
.tips { | .tips { | ||||
margin-top: 10px; | margin-top: 10px; | ||||
p { | p { | ||||
font-size: 14px; | font-size: 14px; | ||||
} | } | ||||
} | } | ||||
.bottom { | .bottom { | ||||
padding-top: 20px; | padding-top: 20px; | ||||
display: flex; | display: flex; | ||||
justify-content: space-between; | justify-content: space-between; | ||||
align-items: center; | align-items: center; | ||||
span { | span { | ||||
font-size: 20px; | font-size: 20px; | ||||
color: #fca842; | color: #fca842; | ||||
font-weight: bold; | font-weight: bold; | ||||
.price-span { | .price-span { | ||||
margin-left: 5px; | margin-left: 5px; | ||||
font-size: 14px; | font-size: 14px; | ||||
} | } | ||||
} | } | ||||
.btn-button { | .btn-button { | ||||
height: 35px; | height: 35px; | ||||
width: 100px; | width: 100px; | ||||
@include center(); | @include center(); | ||||
background-color: #fca842; | background-color: #fca842; | ||||
border-radius: 17px; | border-radius: 17px; | ||||
p { | p { | ||||
font-size: 14px; | font-size: 14px; | ||||
color: #fff; | color: #fff; | ||||
@@ -568,6 +586,7 @@ export default { | |||||
} | } | ||||
} | } | ||||
} | } | ||||
.base-package { | .base-package { | ||||
height: calc(100vh - 88px); | height: calc(100vh - 88px); | ||||
position: relative; | position: relative; | ||||
@@ -579,39 +598,48 @@ export default { | |||||
rgba(14, 30, 37, 0.32) 0 2px 16px 0; | rgba(14, 30, 37, 0.32) 0 2px 16px 0; | ||||
padding: 15px 10px; | padding: 15px 10px; | ||||
background-color: #fff; | background-color: #fff; | ||||
/* border-radius: 5px; */ | /* border-radius: 5px; */ | ||||
.title { | .title { | ||||
display: flex; | display: flex; | ||||
justify-content: flex-start; | justify-content: flex-start; | ||||
p { | p { | ||||
font-size: 16px; | font-size: 16px; | ||||
font-weight: bold; | font-weight: bold; | ||||
} | } | ||||
} | } | ||||
.details { | .details { | ||||
display: flex; | display: flex; | ||||
justify-content: flex-start; | justify-content: flex-start; | ||||
align-items: center; | align-items: center; | ||||
p { | p { | ||||
height: 40px; | height: 40px; | ||||
@include center(); | @include center(); | ||||
font-size: 14px; | font-size: 14px; | ||||
padding: 5px 0 5px 10px; | padding: 5px 0 5px 10px; | ||||
} | } | ||||
.total { | .total { | ||||
font-size: 16px; | font-size: 16px; | ||||
padding: 0; | padding: 0; | ||||
} | } | ||||
.orange { | .orange { | ||||
color: orange; | color: orange; | ||||
} | } | ||||
.large { | .large { | ||||
font-size: 26px; | font-size: 26px; | ||||
margin: 0 2px; | margin: 0 2px; | ||||
} | } | ||||
.price { | .price { | ||||
font-size: 16px; | font-size: 16px; | ||||
} | } | ||||
/* .buy-btn { | /* .buy-btn { | ||||
height: 30px; | height: 30px; | ||||
width: 100px; | width: 100px; | ||||
@@ -627,18 +655,22 @@ export default { | |||||
} | } | ||||
} */ | } */ | ||||
} | } | ||||
.remark { | .remark { | ||||
display: flex; | display: flex; | ||||
justify-content: flex-start; | justify-content: flex-start; | ||||
p { | p { | ||||
font-size: 14px; | font-size: 14px; | ||||
padding: 5px 10px; | padding: 5px 10px; | ||||
/* font-weight: bold; */ | /* font-weight: bold; */ | ||||
} | } | ||||
} | } | ||||
.package-buy { | .package-buy { | ||||
@include center(); | @include center(); | ||||
padding: 5px 8px; | padding: 5px 8px; | ||||
.buy-btn { | .buy-btn { | ||||
height: 40px; | height: 40px; | ||||
width: 200px; | width: 200px; | ||||
@@ -648,6 +680,7 @@ export default { | |||||
align-items: center; | align-items: center; | ||||
background: orange; | background: orange; | ||||
border-radius: 20px; | border-radius: 20px; | ||||
p { | p { | ||||
font-size: 16px; | font-size: 16px; | ||||
padding: 0; | padding: 0; | ||||
@@ -655,12 +688,14 @@ export default { | |||||
} | } | ||||
} | } | ||||
} | } | ||||
.radios-con { | .radios-con { | ||||
/* padding: 20px 10px; */ | /* padding: 20px 10px; */ | ||||
/* @include center(); */ | /* @include center(); */ | ||||
/* align-items: center; */ | /* align-items: center; */ | ||||
padding: 10px 0 10px 10px; | padding: 10px 0 10px 10px; | ||||
font-size: 14px; | font-size: 14px; | ||||
/* box-shadow: rgba(14, 30, 37, 0.12) 0 3px 5px 0, | /* box-shadow: rgba(14, 30, 37, 0.12) 0 3px 5px 0, | ||||
rgba(14, 30, 37, 0.32) 0 2px 16px 0; */ | rgba(14, 30, 37, 0.32) 0 2px 16px 0; */ | ||||
img { | img { | ||||
@@ -668,8 +703,10 @@ export default { | |||||
width: 20px; | width: 20px; | ||||
margin: 2px; | margin: 2px; | ||||
} | } | ||||
.pay-type { | .pay-type { | ||||
text-align: left; | text-align: left; | ||||
p { | p { | ||||
font-size: 14px; | font-size: 14px; | ||||
padding: 0 0 10px 0; | padding: 0 0 10px 0; | ||||
@@ -679,10 +716,12 @@ export default { | |||||
.radio-con { | .radio-con { | ||||
@include center(); | @include center(); | ||||
} | } | ||||
.van-cell-text { | .van-cell-text { | ||||
display: flex; | display: flex; | ||||
justify-content: flex-start; | justify-content: flex-start; | ||||
align-items: center; | align-items: center; | ||||
span { | span { | ||||
font-size: 14px; | font-size: 14px; | ||||
padding: 0 5px; | padding: 0 5px; | ||||
@@ -690,14 +729,17 @@ export default { | |||||
} | } | ||||
} | } | ||||
} | } | ||||
.content { | .content { | ||||
font-size: 14px; | font-size: 14px; | ||||
} | } | ||||
} | } | ||||
.data-null { | .data-null { | ||||
height: calc(100vh - 88px); | height: calc(100vh - 88px); | ||||
@include center(); | @include center(); | ||||
flex-direction: column; | flex-direction: column; | ||||
span { | span { | ||||
font-size: 14px; | font-size: 14px; | ||||
} | } | ||||
@@ -31,6 +31,12 @@ export default { | |||||
created() { | created() { | ||||
this.getAuth(); | this.getAuth(); | ||||
}, | }, | ||||
computed: { | |||||
isWeChat() { | |||||
const ua = window.navigator.userAgent.toLowerCase(); | |||||
return /micromessenger/.test(ua); | |||||
} | |||||
}, | |||||
mounted() { | mounted() { | ||||
this.getParams(); | this.getParams(); | ||||
}, | }, | ||||
@@ -42,27 +48,27 @@ export default { | |||||
// 4.如果有基础套餐但未充值,跳转套餐充值页面 | // 4.如果有基础套餐但未充值,跳转套餐充值页面 | ||||
getDevicePayPackage() { | getDevicePayPackage() { | ||||
APICore.devicePayPackage(this.params.imei) | APICore.devicePayPackage(this.params.imei) | ||||
.then(res => { | |||||
let data = res.data; | |||||
if (data.code === 106 || data.code === 104) { | |||||
this.getAuth(); | |||||
setTimeout(() => { | |||||
this.getDevicePayPackage(); | |||||
}, 1500); | |||||
} else { | |||||
// 筛选是否存在基础套餐, producModelId = 1 是基础套餐, 2 是加油包 | |||||
this.isHasBasePackage = data.data.packagesList.some(res => { | |||||
return res.producModelId === 1; | |||||
}); | |||||
} | |||||
}).catch(() => {}) | |||||
.then(res => { | |||||
let data = res.data; | |||||
if (data.code === 106 || data.code === 104) { | |||||
this.getAuth(); | |||||
setTimeout(() => { | |||||
this.getDevicePayPackage(); | |||||
}, 1500); | |||||
} else { | |||||
// 筛选是否存在基础套餐, producModelId = 1 是基础套餐, 2 是加油包 | |||||
this.isHasBasePackage = data.data.packagesList.some(res => { | |||||
return res.producModelId === 1; | |||||
}); | |||||
} | |||||
}).catch(() => { }) | |||||
}, | }, | ||||
checkImei() { | checkImei() { | ||||
let reqBody = { | let reqBody = { | ||||
imei: this.params.imei, | imei: this.params.imei, | ||||
iccid: this.params.iccid || '' | iccid: this.params.iccid || '' | ||||
}; | }; | ||||
APIWx.CheckImei(reqBody).then(res =>{ | |||||
APIWx.CheckImei(reqBody).then(res => { | |||||
this.isRecharge = res.data.isRecharge; | this.isRecharge = res.data.isRecharge; | ||||
this.currentIotTitle = res.data.title; | this.currentIotTitle = res.data.title; | ||||
this.getWxCode(); | this.getWxCode(); | ||||
@@ -82,19 +88,19 @@ export default { | |||||
let url = window.location.href.split("?code=")[1]; | let url = window.location.href.split("?code=")[1]; | ||||
console.log("获取授权code的url", url); | console.log("获取授权code的url", url); | ||||
this.getWxCode(); | this.getWxCode(); | ||||
/* if ( | |||||
isNotNull(url) || | |||||
window.location.href.indexOf("code") > -1 | |||||
) { | |||||
let timeStamp = new Date().getTime(); | |||||
let code = url.split("&")[0]; | |||||
console.log("code", code); | |||||
if (isNotNull(code)) { | |||||
this.getWxCode(); | |||||
} | |||||
} else { | |||||
this.getWxCode(); | |||||
} */ | |||||
/* if ( | |||||
isNotNull(url) || | |||||
window.location.href.indexOf("code") > -1 | |||||
) { | |||||
let timeStamp = new Date().getTime(); | |||||
let code = url.split("&")[0]; | |||||
console.log("code", code); | |||||
if (isNotNull(code)) { | |||||
this.getWxCode(); | |||||
} | |||||
} else { | |||||
this.getWxCode(); | |||||
} */ | |||||
} else { | } else { | ||||
this.getWxCode(); | this.getWxCode(); | ||||
console.log("当前浏览器内核并非支付宝或者微信"); | console.log("当前浏览器内核并非支付宝或者微信"); | ||||
@@ -107,15 +113,15 @@ export default { | |||||
this.$store.commit("gatewayToken", res.data.data); | this.$store.commit("gatewayToken", res.data.data); | ||||
}); | }); | ||||
}, | }, | ||||
// 获取token | |||||
// 获取token | |||||
getToken() { | getToken() { | ||||
let manufacturerNo = '9f166b07-ff83-4991-84dc-ca6ad4a6b95b'; | let manufacturerNo = '9f166b07-ff83-4991-84dc-ca6ad4a6b95b'; | ||||
APIPay.getToken(manufacturerNo).then(res => { | APIPay.getToken(manufacturerNo).then(res => { | ||||
console.log("token的数据", res.data) | console.log("token的数据", res.data) | ||||
let data = res.data; | let data = res.data; | ||||
if(data.code === 20000) { | |||||
if (data.code === 20000) { | |||||
this.$store.commit("token", data.token); | this.$store.commit("token", data.token); | ||||
console.log("token的数据", localStorage.getItem('token')) | |||||
console.log("token的数据", localStorage.getItem('token')) | |||||
} | } | ||||
}) | }) | ||||
}, | }, | ||||
@@ -123,8 +129,8 @@ export default { | |||||
getOpenId(code) { | getOpenId(code) { | ||||
//let code = this.$store.getters.wxAuthCode; | //let code = this.$store.getters.wxAuthCode; | ||||
APIPay.getOpenId(code).then(res => { | APIPay.getOpenId(code).then(res => { | ||||
let data= res.data; | |||||
if(data.code === 20000) { | |||||
let data = res.data; | |||||
if (data.code === 20000) { | |||||
this.$store.commit("openId", data.data.openId); | this.$store.commit("openId", data.data.openId); | ||||
} | } | ||||
}) | }) | ||||
@@ -132,38 +138,47 @@ export default { | |||||
// 获取微信code | // 获取微信code | ||||
getWxCode() { | getWxCode() { | ||||
let params = this.params; | let params = this.params; | ||||
let commonUrl = process.env.VUE_APP_BASE_API; | |||||
let commonUrl = process.env.NODE_ENV === "production" ? process.env.VUE_APP_BASE_API : 'https://id.gdssjl.com'; | |||||
let isWhiteTitle = this.whiteTitleList.includes(this.currentIotTitle) > 0; | let isWhiteTitle = this.whiteTitleList.includes(this.currentIotTitle) > 0; | ||||
let cardInfoBaseUrl = encodeURIComponent(`${commonUrl}/h5-frontendweb/#/cardInfo?imei=${params.imei}&iccid=${params.iccid}`); | let cardInfoBaseUrl = encodeURIComponent(`${commonUrl}/h5-frontendweb/#/cardInfo?imei=${params.imei}&iccid=${params.iccid}`); | ||||
let toupBaseUrl = encodeURIComponent(`${commonUrl}/h5-frontendweb/#/${params.routerName}?imei=${params.imei}&iccid=${params.iccid}`); | let toupBaseUrl = encodeURIComponent(`${commonUrl}/h5-frontendweb/#/${params.routerName}?imei=${params.imei}&iccid=${params.iccid}`); | ||||
if(this.isHasBasePackage) { | |||||
// 有套餐 | |||||
if(this.isRecharge) { | |||||
// 已支付,跳转话费查询页面 | |||||
console.log("有套餐跳转话费查询页面"); | |||||
let wxRedUrl = `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${AppId}&redirect_uri=${cardInfoBaseUrl}&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect`; | |||||
window.location.href = wxRedUrl; | |||||
} else if (!this.isRecharge) { | |||||
// 未支付, 跳转套餐充值页面 | |||||
console.log("跳转套餐充值页面"); | |||||
let wxRedUrl = `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${AppId}&redirect_uri=${toupBaseUrl}&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect`; | |||||
window.location.href = wxRedUrl; | |||||
} | |||||
} else { | |||||
// 无套餐 | |||||
if(isWhiteTitle) { | |||||
// 是零川或者小台风,跳转话费查询页面 | |||||
let wxRedUrl = `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${AppId}&redirect_uri=${cardInfoBaseUrl}&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect`; | |||||
window.location.href = wxRedUrl; | |||||
console.log("无套餐跳转话费查询页面"); | |||||
if (this.isWeChat) { | |||||
if (this.isHasBasePackage) { | |||||
// 有套餐 | |||||
if (this.isRecharge) { | |||||
// 已支付,跳转话费查询页面 | |||||
console.log("有套餐跳转话费查询页面"); | |||||
let wxRedUrl = `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${AppId}&redirect_uri=${cardInfoBaseUrl}&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect`; | |||||
window.location.href = wxRedUrl; | |||||
} else if (!this.isRecharge) { | |||||
// 未支付, 跳转套餐充值页面 | |||||
console.log("跳转套餐充值页面"); | |||||
let wxRedUrl = `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${AppId}&redirect_uri=${cardInfoBaseUrl}&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect`; | |||||
window.location.href = wxRedUrl; | |||||
} | |||||
} else { | } else { | ||||
// 跳转错误页面; | |||||
this.$router.replace({ | |||||
name: 'iotcardError' | |||||
}) | |||||
console.log("跳转错误页面"); | |||||
// 无套餐 | |||||
if (isWhiteTitle) { | |||||
// 是零川或者小台风,跳转话费查询页面 | |||||
let wxRedUrl = `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${AppId}&redirect_uri=${cardInfoBaseUrl}&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect`; | |||||
window.location.href = wxRedUrl; | |||||
console.log("无套餐跳转话费查询页面"); | |||||
} else { | |||||
// 跳转错误页面; | |||||
this.$router.replace({ | |||||
name: 'iotcardError' | |||||
}) | |||||
console.log("跳转错误页面"); | |||||
} | |||||
} | } | ||||
} else { | |||||
this.$router.replace({ | |||||
name: "cardInfo", | |||||
query: { imei: this.params.imei, iccid: this.params.iccid, isShowMenu: true, isHasCode: true } | |||||
}); | |||||
} | } | ||||
// 2023.09.20 废弃 | // 2023.09.20 废弃 | ||||
/* if(this.isRecharge) { | /* if(this.isRecharge) { | ||||
let redUrl = encodeURIComponent(`${commonUrl}/h5-frontendweb/#/cardInfo?imei=${params.imei}&iccid=${params.iccid}`); | let redUrl = encodeURIComponent(`${commonUrl}/h5-frontendweb/#/cardInfo?imei=${params.imei}&iccid=${params.iccid}`); | ||||
@@ -180,9 +195,9 @@ export default { | |||||
getParams() { | getParams() { | ||||
let params = this.$route.query; | let params = this.$route.query; | ||||
if (params) { | if (params) { | ||||
this.params = {...params}; | |||||
this.params = { ...params }; | |||||
this.$store.commit("appId", AppId); | this.$store.commit("appId", AppId); | ||||
if(params.reqUrl) { | |||||
if (params.reqUrl) { | |||||
const reqUrl = encodeURI(params.reqUrl); | const reqUrl = encodeURI(params.reqUrl); | ||||
window.location.href = reqUrl; | window.location.href = reqUrl; | ||||
} else { | } else { | ||||
@@ -195,5 +210,4 @@ export default { | |||||
}; | }; | ||||
</script> | </script> | ||||
<style scoped lang="scss"> | |||||
</style> | |||||
<style scoped lang="scss"></style> |
@@ -9,7 +9,7 @@ | |||||
<div class="package-list-container"> | <div class="package-list-container"> | ||||
<van-nav-bar :left-arrow="false" :border="true"> | <van-nav-bar :left-arrow="false" :border="true"> | ||||
<template #title> | <template #title> | ||||
<h5 style="font-size: 16px">{{topupTitle}}</h5> | |||||
<h5 style="font-size: 16px">{{ topupTitle }}</h5> | |||||
</template> | </template> | ||||
</van-nav-bar> | </van-nav-bar> | ||||
<!-- 灰色线条 --> | <!-- 灰色线条 --> | ||||
@@ -22,12 +22,7 @@ | |||||
<p>暂无相关套餐数据,请您联系管理员~</p> | <p>暂无相关套餐数据,请您联系管理员~</p> | ||||
</div> | </div> | ||||
<!-- 套餐订购 --> | <!-- 套餐订购 --> | ||||
<div | |||||
class="package-order-container" | |||||
v-for="(item, index) in packageOrderList" | |||||
:key="index" | |||||
> | |||||
<div class="package-order-container" v-for="(item, index) in packageOrderList" :key="index"> | |||||
<!-- 推荐 --> | <!-- 推荐 --> | ||||
<div class="recom" v-show="false"> | <div class="recom" v-show="false"> | ||||
<div class="shape"></div> | <div class="shape"></div> | ||||
@@ -38,7 +33,8 @@ | |||||
<!-- 套餐内容 --> | <!-- 套餐内容 --> | ||||
<div class="order-content"> | <div class="order-content"> | ||||
<div class="title"> | <div class="title"> | ||||
<p>{{item.packageName}}<!-- :{{(item.packagesPrice/item.packageIssue).toFixed(0)}}元/月 --></p> | |||||
<p>{{ item.packageName }}<!-- :{{(item.packagesPrice/item.packageIssue).toFixed(0)}}元/月 --> | |||||
</p> | |||||
</div> | </div> | ||||
<div class="remark"> | <div class="remark"> | ||||
<p>每月200分钟通话时长,1G流量</p> | <p>每月200分钟通话时长,1G流量</p> | ||||
@@ -46,10 +42,11 @@ | |||||
<div class="details"> | <div class="details"> | ||||
<p> | <p> | ||||
<span class="orange large">¥{{(item.packagesPrice/(item.packageIssue === 0 ? 1: item.packageIssue)).toFixed(0)}}</span>元/月, | |||||
<span class="orange large">¥{{ (item.packagesPrice / (item.packageIssue === 0 ? 1 : | |||||
item.packageIssue)).toFixed(0)}}</span>元/月, | |||||
</p> | </p> | ||||
<p class="total"> | <p class="total"> | ||||
<span>合计</span><span class="orange price">{{item.packagesPrice}}元</span> | |||||
<span>合计</span><span class="orange price">{{ item.packagesPrice }}元</span> | |||||
</p> | </p> | ||||
</div> | </div> | ||||
<!-- <div class="package-buy"> | <!-- <div class="package-buy"> | ||||
@@ -61,12 +58,12 @@ | |||||
<div class="pay-type"> | <div class="pay-type"> | ||||
<p>支付方式:</p> | <p>支付方式:</p> | ||||
</div> | </div> | ||||
<van-radio-group v-model="radio" direction="horizontal" @change="onRaidoChange"> | |||||
<van-radio-group v-model="radio" direction="horizontal" @change="onRaidoChange"> | |||||
<van-radio name="1"> | <van-radio name="1"> | ||||
<template #default> | <template #default> | ||||
<div class="radio-con"> | <div class="radio-con"> | ||||
<span>微信</span> | <span>微信</span> | ||||
<img src="../../assets/wx-pay.png"/> | |||||
<img src="../../assets/wx-pay.png" /> | |||||
</div> | </div> | ||||
</template> | </template> | ||||
</van-radio> | </van-radio> | ||||
@@ -74,7 +71,7 @@ | |||||
<template #default> | <template #default> | ||||
<div class="radio-con"> | <div class="radio-con"> | ||||
<span>支付宝</span> | <span>支付宝</span> | ||||
<img src="../../assets/alipay.png"/> | |||||
<img src="../../assets/alipay.png" /> | |||||
</div> | </div> | ||||
</template> | </template> | ||||
</van-radio> | </van-radio> | ||||
@@ -82,7 +79,7 @@ | |||||
<template #default> | <template #default> | ||||
<div class="radio-con"> | <div class="radio-con"> | ||||
<span>12期花呗</span> | <span>12期花呗</span> | ||||
<img src="../../assets/antpay.png"/> | |||||
<img src="../../assets/antpay.png" /> | |||||
</div> | </div> | ||||
</template> | </template> | ||||
</van-radio> | </van-radio> | ||||
@@ -144,6 +141,13 @@ export default { | |||||
code: '' | code: '' | ||||
}; | }; | ||||
}, | }, | ||||
computed: { | |||||
isWeChat() { | |||||
const ua = window.navigator.userAgent.toLowerCase(); | |||||
return /micromessenger/.test(ua); | |||||
} | |||||
}, | |||||
created() { | created() { | ||||
this.getAuth(); | this.getAuth(); | ||||
this.getToken(); | this.getToken(); | ||||
@@ -158,8 +162,8 @@ export default { | |||||
// 根据code获取openId | // 根据code获取openId | ||||
getOpenId(code) { | getOpenId(code) { | ||||
APIPay.getOpenId(code).then(res => { | APIPay.getOpenId(code).then(res => { | ||||
let data= res.data; | |||||
if(data.code === 20000) { | |||||
let data = res.data; | |||||
if (data.code === 20000) { | |||||
this.openId = data.data.openId; | this.openId = data.data.openId; | ||||
this.$store.commit("openId", data.data.openId); | this.$store.commit("openId", data.data.openId); | ||||
} else if (data.state === false) { | } else if (data.state === false) { | ||||
@@ -169,7 +173,7 @@ export default { | |||||
} | } | ||||
}) | }) | ||||
}, | }, | ||||
// 获取b端接口的token | |||||
// 获取b端接口的token | |||||
getAuth() { | getAuth() { | ||||
let manufactorId = "5bf13062-a41e-4d00-ba14-1101aad12650"; | let manufactorId = "5bf13062-a41e-4d00-ba14-1101aad12650"; | ||||
APICore.getAuth({ manufactorId: manufactorId }).then(res => { | APICore.getAuth({ manufactorId: manufactorId }).then(res => { | ||||
@@ -182,16 +186,16 @@ export default { | |||||
APIPay.getToken(manufacturerNo).then(res => { | APIPay.getToken(manufacturerNo).then(res => { | ||||
console.log("token的数据", res.data) | console.log("token的数据", res.data) | ||||
let data = res.data; | let data = res.data; | ||||
if(data.code === 20000) { | |||||
if (data.code === 20000) { | |||||
this.$store.commit("token", data.token); | this.$store.commit("token", data.token); | ||||
console.log("token的数据", localStorage.getItem('token')) | |||||
console.log("token的数据", localStorage.getItem('token')) | |||||
} | } | ||||
}) | }) | ||||
}, | }, | ||||
getCode() { | getCode() { | ||||
let url = window.location.href.split("?code=")[1]; | let url = window.location.href.split("?code=")[1]; | ||||
console.log("url", url); | console.log("url", url); | ||||
if (isNotNull(url) ||window.location.href.indexOf("code") > -1) { | |||||
if (isNotNull(url) || window.location.href.indexOf("code") > -1) { | |||||
let code = url.split("&")[0]; | let code = url.split("&")[0]; | ||||
this.code = code; | this.code = code; | ||||
if (isNotNull(code)) { | if (isNotNull(code)) { | ||||
@@ -209,7 +213,7 @@ export default { | |||||
let params = this.$route.query; | let params = this.$route.query; | ||||
console.log("params", params); | console.log("params", params); | ||||
if (params) { | if (params) { | ||||
this.params = {...params}; | |||||
this.params = { ...params }; | |||||
} | } | ||||
}, | }, | ||||
// 获取基本套餐信息 | // 获取基本套餐信息 | ||||
@@ -230,7 +234,7 @@ export default { | |||||
} else if (res.data.code === 0 && res.data.data === null) { | } else if (res.data.code === 0 && res.data.data === null) { | ||||
this.isShowNoData = true; | this.isShowNoData = true; | ||||
} else { | } else { | ||||
if(res.data.data === null) { | |||||
if (res.data.data === null) { | |||||
this.isShowNoData = false; | this.isShowNoData = false; | ||||
} else { | } else { | ||||
let data = res.data.data.packagesList; | let data = res.data.data.packagesList; | ||||
@@ -271,7 +275,7 @@ export default { | |||||
APIWx.createJSSDK({ | APIWx.createJSSDK({ | ||||
sUrl: window.location.href.split("#")[0], | sUrl: window.location.href.split("#")[0], | ||||
userId: '', | userId: '', | ||||
appId: this.params.appId || AppId | |||||
appId: this.params.appId || AppId | |||||
}) | }) | ||||
.then(res => { | .then(res => { | ||||
let item = res.data.data; | let item = res.data.data; | ||||
@@ -300,6 +304,12 @@ export default { | |||||
// 遍历数据找到属于三种支付方式对应的套餐id, 1 微信 2 支付宝全额 3 支付宝分期 | // 遍历数据找到属于三种支付方式对应的套餐id, 1 微信 2 支付宝全额 3 支付宝分期 | ||||
let payTypeToPackAgeId = data.payTypeList; | let payTypeToPackAgeId = data.payTypeList; | ||||
console.log("购买的套餐数据data", payTypeToPackAgeId); | console.log("购买的套餐数据data", payTypeToPackAgeId); | ||||
if (!this.isWeChat) { | |||||
return this.$dialog.confirm({ | |||||
message: '请用微信客户端打开此页。', | |||||
showCancelButton: false, | |||||
}) | |||||
} | |||||
// 需要区分是要用微信支付还是支付宝花呗支付 | // 需要区分是要用微信支付还是支付宝花呗支付 | ||||
if (this.payType === '2') { | if (this.payType === '2') { | ||||
// 全额 | // 全额 | ||||
@@ -326,7 +336,7 @@ export default { | |||||
})[0].productId; | })[0].productId; | ||||
this.packageIssue = 0; | this.packageIssue = 0; | ||||
console.log("this.payProductId3", this.payProductId); | console.log("this.payProductId3", this.payProductId); | ||||
if(openId === null || openId === 'null') { | |||||
if (openId === null || openId === 'null') { | |||||
this.$dialog.confirm({ | this.$dialog.confirm({ | ||||
message: '获取OpenId失败,请您重新进入', | message: '获取OpenId失败,请您重新进入', | ||||
showCancelButton: false, | showCancelButton: false, | ||||
@@ -367,7 +377,7 @@ export default { | |||||
message: `${res.data.message}`, | message: `${res.data.message}`, | ||||
showCancelButton: false | showCancelButton: false | ||||
}) | }) | ||||
} else if ( res.data.code !== 0){ | |||||
} else if (res.data.code !== 0) { | |||||
return this.$dialog.confirm({ | return this.$dialog.confirm({ | ||||
message: `请反馈给一线人员,\n${res.data.message}`, | message: `请反馈给一线人员,\n${res.data.message}`, | ||||
showCancelButton: false | showCancelButton: false | ||||
@@ -453,7 +463,7 @@ export default { | |||||
signType: data.signType, //微信签名方式: | signType: data.signType, //微信签名方式: | ||||
paySign: data.paySign //微信签名 | paySign: data.paySign //微信签名 | ||||
}, | }, | ||||
function(res) { | |||||
function (res) { | |||||
if (res.err_msg == "get_brand_wcpay_request:ok") { | if (res.err_msg == "get_brand_wcpay_request:ok") { | ||||
// 使用以上方式判断前端返回,微信团队郑重提示: | // 使用以上方式判断前端返回,微信团队郑重提示: | ||||
//res.err_msg将在用户支付成功后返回ok,但并不保证它绝对可靠。 | //res.err_msg将在用户支付成功后返回ok,但并不保证它绝对可靠。 | ||||
@@ -575,6 +585,7 @@ export default { | |||||
.package-list-container { | .package-list-container { | ||||
background-color: white; | background-color: white; | ||||
height: 100vh; | height: 100vh; | ||||
.topup-container { | .topup-container { | ||||
position: relative; | position: relative; | ||||
/* margin: 20px; */ | /* margin: 20px; */ | ||||
@@ -585,14 +596,17 @@ export default { | |||||
background-color: white; | background-color: white; | ||||
overflow: scroll; | overflow: scroll; | ||||
height: calc(100vh - 88px); | height: calc(100vh - 88px); | ||||
.main { | .main { | ||||
display: flex; | display: flex; | ||||
justify-content: center; | justify-content: center; | ||||
align-items: center; | align-items: center; | ||||
flex-direction: column; | flex-direction: column; | ||||
.tips { | .tips { | ||||
padding: 10px; | padding: 10px; | ||||
} | } | ||||
.noData_container { | .noData_container { | ||||
margin: 100px auto 0; | margin: 100px auto 0; | ||||
height: 120px; | height: 120px; | ||||
@@ -603,15 +617,19 @@ export default { | |||||
align-items: flex-end; | align-items: flex-end; | ||||
font-size: 16px; | font-size: 16px; | ||||
color: #999; | color: #999; | ||||
p { | p { | ||||
font-size: 16px; | font-size: 16px; | ||||
} | } | ||||
/* @include colorAndFont(#999, 28); */ | /* @include colorAndFont(#999, 28); */ | ||||
} | } | ||||
p { | p { | ||||
padding: 10px; | padding: 10px; | ||||
font-size: 16px; | font-size: 16px; | ||||
} | } | ||||
.cancel-button { | .cancel-button { | ||||
width: 30vw; | width: 30vw; | ||||
border-radius: 5px; | border-radius: 5px; | ||||
@@ -623,6 +641,7 @@ export default { | |||||
align-items: center; | align-items: center; | ||||
font-size: 16px; | font-size: 16px; | ||||
} | } | ||||
.package-order-container { | .package-order-container { | ||||
position: relative; | position: relative; | ||||
margin: 10px 0; | margin: 10px 0; | ||||
@@ -630,6 +649,7 @@ export default { | |||||
z-index: 999; | z-index: 999; | ||||
box-shadow: rgba(14, 30, 37, 0.12) 0 3px 5px 0, | box-shadow: rgba(14, 30, 37, 0.12) 0 3px 5px 0, | ||||
rgba(14, 30, 37, 0.32) 0 2px 16px 0; | rgba(14, 30, 37, 0.32) 0 2px 16px 0; | ||||
.recom { | .recom { | ||||
position: absolute; | position: absolute; | ||||
top: -7px; | top: -7px; | ||||
@@ -640,11 +660,13 @@ export default { | |||||
transform: rotate(-45deg); | transform: rotate(-45deg); | ||||
text-align: center; | text-align: center; | ||||
z-index: 9999; | z-index: 9999; | ||||
p { | p { | ||||
padding: 0; | padding: 0; | ||||
color: white; | color: white; | ||||
font-size: 14px; | font-size: 14px; | ||||
} | } | ||||
.shape { | .shape { | ||||
position: absolute; | position: absolute; | ||||
top: -1px; | top: -1px; | ||||
@@ -653,6 +675,7 @@ export default { | |||||
border-width: 0 21px 21px; | border-width: 0 21px 21px; | ||||
border-color: transparent transparent white; | border-color: transparent transparent white; | ||||
} | } | ||||
.square { | .square { | ||||
height: 15px; | height: 15px; | ||||
width: 35px; | width: 35px; | ||||
@@ -663,40 +686,50 @@ export default { | |||||
font-size: 14px; | font-size: 14px; | ||||
} | } | ||||
} | } | ||||
.order-content { | .order-content { | ||||
padding: 15px 10px; | padding: 15px 10px; | ||||
.title { | .title { | ||||
display: flex; | display: flex; | ||||
justify-content: flex-start; | justify-content: flex-start; | ||||
p { | p { | ||||
font-size: 16px; | font-size: 16px; | ||||
font-weight: bold; | font-weight: bold; | ||||
} | } | ||||
} | } | ||||
.details { | .details { | ||||
display: flex; | display: flex; | ||||
justify-content: flex-start; | justify-content: flex-start; | ||||
align-items: center; | align-items: center; | ||||
p { | p { | ||||
height: 40px; | height: 40px; | ||||
@include center(); | @include center(); | ||||
font-size: 14px; | font-size: 14px; | ||||
padding: 5px 0 5px 10px; | padding: 5px 0 5px 10px; | ||||
} | } | ||||
.total { | .total { | ||||
font-size: 16px; | font-size: 16px; | ||||
padding: 0; | padding: 0; | ||||
} | } | ||||
.orange { | .orange { | ||||
color: orange; | color: orange; | ||||
} | } | ||||
.large { | .large { | ||||
font-size: 26px; | font-size: 26px; | ||||
margin: 0 2px; | margin: 0 2px; | ||||
} | } | ||||
.price { | .price { | ||||
font-size: 16px; | font-size: 16px; | ||||
} | } | ||||
/* .buy-btn { | /* .buy-btn { | ||||
height: 30px; | height: 30px; | ||||
width: 100px; | width: 100px; | ||||
@@ -712,41 +745,48 @@ export default { | |||||
} | } | ||||
} */ | } */ | ||||
} | } | ||||
.remark { | .remark { | ||||
display: flex; | display: flex; | ||||
justify-content: flex-start; | justify-content: flex-start; | ||||
p { | p { | ||||
font-size: 14px; | font-size: 14px; | ||||
padding: 5px 10px; | |||||
padding: 5px 10px; | |||||
/* font-weight: bold; */ | /* font-weight: bold; */ | ||||
} | } | ||||
} | } | ||||
.package-buy { | .package-buy { | ||||
@include center(); | @include center(); | ||||
padding: 5px 8px; | padding: 5px 8px; | ||||
@include center(); | @include center(); | ||||
.buy-btn { | |||||
height: 40px; | |||||
width: 200px; | |||||
padding: 0 5px; | |||||
display: flex; | |||||
justify-content: center; | |||||
align-items: center; | |||||
background: orange; | |||||
border-radius: 20px; | |||||
p { | |||||
font-size: 16px; | |||||
padding: 0; | |||||
color: white; | |||||
} | |||||
.buy-btn { | |||||
height: 40px; | |||||
width: 200px; | |||||
padding: 0 5px; | |||||
display: flex; | |||||
justify-content: center; | |||||
align-items: center; | |||||
background: orange; | |||||
border-radius: 20px; | |||||
p { | |||||
font-size: 16px; | |||||
padding: 0; | |||||
color: white; | |||||
} | } | ||||
} | } | ||||
} | |||||
.radios-con { | .radios-con { | ||||
/* padding: 20px 10px; */ | /* padding: 20px 10px; */ | ||||
/* @include center(); */ | /* @include center(); */ | ||||
/* align-items: center; */ | /* align-items: center; */ | ||||
padding: 10px 0 10px 10px; | padding: 10px 0 10px 10px; | ||||
font-size: 14px; | font-size: 14px; | ||||
/* box-shadow: rgba(14, 30, 37, 0.12) 0 3px 5px 0, | /* box-shadow: rgba(14, 30, 37, 0.12) 0 3px 5px 0, | ||||
rgba(14, 30, 37, 0.32) 0 2px 16px 0; */ | rgba(14, 30, 37, 0.32) 0 2px 16px 0; */ | ||||
img { | img { | ||||
@@ -754,8 +794,10 @@ export default { | |||||
width: 20px; | width: 20px; | ||||
margin: 2px; | margin: 2px; | ||||
} | } | ||||
.pay-type { | .pay-type { | ||||
text-align: left; | text-align: left; | ||||
p { | p { | ||||
font-size: 14px; | font-size: 14px; | ||||
padding: 0 0 10px 0; | padding: 0 0 10px 0; | ||||
@@ -765,10 +807,12 @@ export default { | |||||
.radio-con { | .radio-con { | ||||
@include center(); | @include center(); | ||||
} | } | ||||
.van-cell-text { | .van-cell-text { | ||||
display: flex; | display: flex; | ||||
justify-content: flex-start; | justify-content: flex-start; | ||||
align-items: center; | align-items: center; | ||||
span { | span { | ||||
font-size: 14px; | font-size: 14px; | ||||
padding: 0 5px; | padding: 0 5px; | ||||
@@ -776,18 +820,21 @@ export default { | |||||
} | } | ||||
} | } | ||||
} | } | ||||
.content { | .content { | ||||
font-size: 14px; | font-size: 14px; | ||||
} | } | ||||
} | } | ||||
} | } | ||||
} | } | ||||
.gray-line { | .gray-line { | ||||
height: 10px; | height: 10px; | ||||
width: 100%; | width: 100%; | ||||
background: #f2f4f5; | background: #f2f4f5; | ||||
} | } | ||||
.order-description { | .order-description { | ||||
height: 60px; | height: 60px; | ||||
display: flex; | display: flex; | ||||
@@ -795,15 +842,18 @@ export default { | |||||
align-items: flex-start; | align-items: flex-start; | ||||
flex-direction: column; | flex-direction: column; | ||||
padding: 5px 0 10px 10px; | padding: 5px 0 10px 10px; | ||||
h5 { | h5 { | ||||
font-size: 14px; | font-size: 14px; | ||||
padding: 10px 0 0 0; | padding: 10px 0 0 0; | ||||
} | } | ||||
} | } | ||||
.pay-radios { | .pay-radios { | ||||
position: relative; | position: relative; | ||||
top: 0; | top: 0; | ||||
width: 100%; | width: 100%; | ||||
/* background-color: red; */ | /* background-color: red; */ | ||||
/* padding: 0 15px; */ | /* padding: 0 15px; */ | ||||
.radios-con { | .radios-con { | ||||
@@ -812,15 +862,18 @@ export default { | |||||
align-items: center; | align-items: center; | ||||
font-size: 18px; | font-size: 18px; | ||||
box-shadow: rgba(14, 30, 37, 0.12) 0 3px 5px 0, | box-shadow: rgba(14, 30, 37, 0.12) 0 3px 5px 0, | ||||
rgba(14, 30, 37, 0.32) 0 2px 16px 0; | |||||
rgba(14, 30, 37, 0.32) 0 2px 16px 0; | |||||
img { | img { | ||||
height: 35px; | height: 35px; | ||||
width: auto; | width: auto; | ||||
} | } | ||||
.van-cell-text { | .van-cell-text { | ||||
display: flex; | display: flex; | ||||
justify-content: flex-start; | justify-content: flex-start; | ||||
align-items: center; | align-items: center; | ||||
span { | span { | ||||
padding: 0 5px; | padding: 0 5px; | ||||
} | } | ||||