dl_uniapp/pages/mine/coupon/my-coupon.vue

626 lines
15 KiB
Vue
Raw Normal View History

2025-04-09 16:55:06 +08:00
<template>
<view class="container-box">
<navigation-bar-vue title="通告券" style="width: 100%;" background-color="#ffffff"
title-color="#000000"></navigation-bar-vue>
<view class="content">
<!-- 操作按钮 -->
<view class="dl-opt-box">
<view class="dl-menu-box" v-for="(item,index) in menus">
<view @click="itemClick(index,item)" class="dl-menu"
:class="index==menuIndex?'dl-menu click':'dl-menu'">{{item}}</view>
</view>
</view>
<view style="width: 100%;" v-if="0==menuIndex">
<view class="coupon-list-box">
2025-04-11 15:35:27 +08:00
<view class="top-text">剩余<text>{{ coupon }}</text></view>
2025-04-09 16:55:06 +08:00
<view :class="['coupon-item-box',index==couponIndex?'click':'']" v-for="(item,index) in dataList"
@click="chooseCoupon(index)">
<view class="left-dom">
<image src="@/static/mine/coupon/coupon.png" mode="aspectFit"></image>
<uni-icons type="closeempty" color="#FC1F3E" size="14"></uni-icons>
2025-04-11 15:35:27 +08:00
<view style="margin-left: 15rpx;">{{item.couponNum}}</view>
2025-04-09 16:55:06 +08:00
</view>
<view class="right-dom">
<text>¥</text>{{item.price}}
</view>
</view>
2025-04-24 18:33:21 +08:00
<!-- 购买 -->
<!-- #ifdef H5 -->
2025-04-11 15:35:27 +08:00
<view class="button-dom" @click="toOrder()">购买</view>
2025-04-24 18:33:21 +08:00
<!-- #endif -->
<!-- 调整h5 -->
<!-- #ifdef MP-WEIXIN -->
<view class="button-dom" @click="openVip()">购买</view>
<!-- #endif -->
2025-04-09 16:55:06 +08:00
</view>
<view class="item-field" style="align-items: center;">
<view class="my-suggest-dom" @click="viewRichText()">
<text>查看通告券购买协议</text>
</view>
</view>
</view>
<view style="width: 100%;" v-if="1==menuIndex">
<view class="buy-list-box">
<scroll-view style="height: 100%;" scroll-y="true" @scrolltolower="onReachBottomCus"
refresher-enabled @refresherrefresh="onRefresherrefresh" :refresher-triggered="isTriggered">
<view class="item-box" v-for="(item,index) in byList">
<view class="top-title-box">
<view class="order-no">订单编号{{item.orderNo}}</view>
2025-04-24 18:33:21 +08:00
<view :class="['order-status',item.isPay==1?'payed':'no-pay']">
{{item.isPay==1?'已支付':'未支付'}}
2025-04-09 16:55:06 +08:00
</view>
</view>
<view class="detail-item">
<view class="left-dom">通告券</view>
2025-04-11 15:35:27 +08:00
<view class="right-dom">*{{item.goodsNum}} </view>
2025-04-09 16:55:06 +08:00
</view>
<view class="detail-item" style="border-bottom:1rpx solid #F4F4F4;padding-bottom: 25rpx;">
<view class="left-dom">金额</view>
2025-04-11 15:35:27 +08:00
<view class="right-dom">{{item.goodsPrice}} </view>
2025-04-09 16:55:06 +08:00
</view>
<view class="bottom-item">
下单时间{{item.createTime}}
</view>
</view>
<view style="text-align: center" v-if="byList.length==0">
<image class="" src="@/static/images/nothing.png"></image>
</view>
</scroll-view>
</view>
</view>
</view>
</view>
</template>
<script>
import navigationBarVue from '@/components/navigation/navigationBar.vue';
2025-04-24 18:33:21 +08:00
import {
initCouponList
} from '@/api/business/base.js'
import {
saveOrder,
2025-04-24 18:44:45 +08:00
getOrderList,
prepayment
2025-04-24 18:33:21 +08:00
} from '@/api/business/member.js'
import {
toast
} from '@/utils/common.js'
import constant from '@/utils/constant';
import {
getJSONData
} from '@/utils/auth.js'
import {
getCodeUrl,
getWebAccessTokenAndOpenid,
gzhLogin
} from '@/api/wxApi'
import {
getToken
} from '@/utils/auth'
2025-04-09 16:55:06 +08:00
export default {
components: {
navigationBarVue
},
data() {
return {
globalConfig: getApp().globalData.config,
menus: ['通告券', '购买记录'],
menuIndex: 0,
2025-04-24 18:33:21 +08:00
coupon: 0,
2025-04-09 16:55:06 +08:00
//选中的通告券下标
couponIndex: 0,
queryParams: {
pageNum: 1,
2025-04-11 15:35:27 +08:00
pageSize: 10,
2025-04-24 18:33:21 +08:00
orderType: '02',
userId: null,
2025-04-09 16:55:06 +08:00
},
total: 0,
//下来刷新状态
isTriggered: false,
2025-04-11 15:35:27 +08:00
dataList: [],
2025-04-09 16:55:06 +08:00
//购买记录
2025-04-11 15:35:27 +08:00
byList: []
2025-04-09 16:55:06 +08:00
}
},
onLoad(option) {
2025-04-24 18:33:21 +08:00
this.menuIndex = option.index || 0
this.coupon = option.coupon || 0
this.initCoupon();
this.initOrder()
//获取url中的search
if (location.search) {
let search = location.search.slice(1);
let arr = search.split("&");
let result = {};
arr.forEach(function(item) {
let itemArr = item.split('=');
result[itemArr[0]] = itemArr[1];
})
if (result.code) {
let that = this
getWebAccessTokenAndOpenid(result.code).then(res => {
that.$store.dispatch('GzhLogin', res).then(() => {
this.initCoupon();
this.initOrder()
that.loginSuccess()
}).catch((e) => {
uni.showToast({
icon: 'error',
duration: 2000,
title: e
});
})
})
} else {
this.toLogin()
}
}
2025-04-09 16:55:06 +08:00
},
methods: {
2025-04-24 18:33:21 +08:00
openVip() {
// 在你想触发跳转的地方
wx.openOfficialAccountProfile({
username: 'tonggaokuaijie', // 此处填写公众号的微信号
success: res => {},
fail: res => {}
})
},
// 登录成功后,处理函数
loginSuccess(result) {
// 设置用户信息
this.$store.dispatch('GetInfo').then(res => {
})
},
toLogin() {
/*#ifdef APP-PLUS*/
// App端特有的逻辑
console.log('Running on App-Plus');
/*#endif*/
/*#ifdef H5*/
// 在浏览器端H5执行的逻辑
if (!getToken()) {
//未登录状态
getCodeUrl("01", "pages/mine/coupon/my-coupon").then(res => {
window.location.href = res.codeUrl;
})
}
/*#endif*/
/*#ifdef MP-WEIXIN*/
// 微信小程序端执行的逻辑
console.log('Running on WeChat Mini Program');
/*#endif*/
},
2025-04-09 16:55:06 +08:00
/**
* 菜单点击
* @param {Object} index
* @param {Object} item
*/
itemClick(index, item) {
this.menuIndex = index
},
2025-04-11 15:35:27 +08:00
2025-04-24 18:33:21 +08:00
/**查询卡券*/
initCoupon() {
if (getToken()) {
this.dataList = []
initCouponList().then(res => {
this.dataList = res.data
})
}
},
/**初始化订单数据*/
initOrder() {
if (getToken()) {
this.queryParams.userId = getJSONData(constant.userInfo).userId
getOrderList(this.queryParams).then(res => {
this.isTriggered = false
if (res.code == 200) {
if (this.queryParams.pageNum == 1) {
this.byList = res.data.records
} else {
this.byList = this.byList.concat(res.data.records)
}
this.total = res.data.total
}
})
}
},
/**生成订单*/
async toOrder() {
let data = {
userType: '01',
orderType: '02',
goodsId: this.dataList[this.couponIndex].id,
goodsNum: this.dataList[this.couponIndex].couponNum,
goodsPrice: this.dataList[this.couponIndex].price,
goodsCycle: '04'
}
2025-04-24 18:34:42 +08:00
let that = this
2025-04-24 18:33:21 +08:00
saveOrder(data).then(res => {
if (res.code == 200) {
//吊起支付
let payData = {
orderNo: res.data.orderNo
}
prepayment(payData).then(paymentData => {
that.wxpay(paymentData)
})
}
}).catch((e) => {
uni.showToast({
icon: 'error',
duration: 2000,
title: e
});
})
},
2025-04-11 15:35:27 +08:00
2025-04-09 16:55:06 +08:00
/**
* 选中的优惠券
* @param {Object} index
*/
chooseCoupon(index) {
this.couponIndex = index
},
viewRichText() {
this.$tab.navigateTo(
`/pages/common/richview/index?title=${this.globalConfig.appInfo.agreements[6].title}&code=${this.globalConfig.appInfo.agreements[6].code}`
)
},
2025-04-11 15:35:27 +08:00
2025-04-09 16:55:06 +08:00
/**
* 上滑加载数据
*/
onReachBottomCus() {
//判断 如果页码*页容量大于等于总条数,提示该页数据加载完毕
if (this.queryParams.pageNum * this.queryParams.pageSize >= this.total) {
toast("没有更多数据了")
return
}
//页码+1,调用获取数据的方法获取第二页数据
this.queryParams.pageNum++
2025-04-24 18:33:21 +08:00
this.initOrder()
2025-04-09 16:55:06 +08:00
},
/**
* 下拉刷新数据
*/
onRefresherrefresh() {
this.isTriggered = true
this.queryParams.pageNum = 1
this.total = 0
2025-04-24 18:33:21 +08:00
this.initOrder()
},
// 检测支付环境中的 WeixinJSBridge
wxpay(data) {
if (typeof WeixinJSBridge == "undefined") {
if (document.addEventListener) {
document.addEventListener('WeixinJSBridgeReady', onBridgeReady(data), false);
} else if (document.attachEvent) {
document.attachEvent('WeixinJSBridgeReady', onBridgeReady(data));
document.attachEvent('onWeixinJSBridgeReady', onBridgeReady(data));
}
} else {
this.onBridgeReady(data);
}
2025-04-09 16:55:06 +08:00
},
2025-04-24 18:33:21 +08:00
onBridgeReady(data) {
WeixinJSBridge.invoke(
'getBrandWCPayRequest', {
// 传入第一步后端接口返回的核心参数
"appId": data.appId, //公众号
"timeStamp": data.timeStamp, //时间戳
"nonceStr": data.nonceStr, //随机串
"package": data.packageVal, //prepay_id
"signType": data.signType, //微信签名方式RSA
"paySign": data.paySign //微信签名
},
function(res) {
// 支付成功
if (res.err_msg == "get_brand_wcpay_request:ok") {
// 使用以上方式判断前端返回,微信团队郑重提示:
//res.err_msg将在用户支付成功后返回ok但并不保证它绝对可靠。
}
// 支付过程中用户取消
if (res.err_msg == "get_brand_wcpay_request:cancel") {
}
// 支付失败
if (res.err_msg == "get_brand_wcpay_request:fail") {
}
/**
* 其它
* 1请检查预支付会话标识prepay_id是否已失效
* 2请求的appid与下单接口的appid是否一致
* */
if (res.err_msg == "调用支付JSAPI缺少参数total_fee") {
}
});
}
2025-04-09 16:55:06 +08:00
}
}
</script>
<style lang="scss">
.container-box {
padding-top: calc(90rpx + var(--status-bar-height));
border-top: 1rpx solid #F4F4F4;
background-color: white;
width: 100%;
color: #363636;
font-size: 30rpx;
height: 100%;
display: flex;
flex-direction: column;
align-items: self-start;
justify-content: center;
position: relative;
.content {
border-top: 1rpx solid #F4F4F4;
height: calc(100vh - var(--status-bar-height) - var(--window-bottom) - 95rpx);
overflow-y: scroll;
width: 100%;
background-color: #F2F2F2;
border-radius: 20rpx;
display: flex;
flex-direction: column;
align-items: self-start;
justify-content: start;
position: relative;
.dl-opt-box {
background-color: white;
width: 100%;
display: flex;
align-items: center;
justify-content: center;
.dl-menu-box {
color: #929292;
display: flex;
flex: 1;
align-items: center;
justify-content: center;
width: 100%;
padding-top: 20rpx;
.dl-menu {
width: 120rpx;
font-size: 30rpx;
margin: 0 20rpx;
padding-bottom: 15rpx;
text-align: center;
}
.click {
color: #FF434E;
font-weight: bold;
border-bottom: 2px solid #FF434E;
}
}
.seting {
font-size: 30rpx;
width: 180rpx;
display: flex;
align-items: center;
justify-content: center;
image {
width: 30rpx;
height: 30rpx;
margin-right: 10rpx;
}
}
}
.buy-list-box {
height: calc(100vh - var(--status-bar-height) - var(--window-bottom) - 174rpx);
width: 100%;
padding: 20rpx 30rpx 0 30rpx;
background-color: #F2F2F2;
border-radius: 20rpx;
display: flex;
flex-direction: column;
align-items: self-start;
justify-content: start;
position: relative;
.item-box {
margin-bottom: 20rpx;
background-color: white;
border-radius: 15rpx;
padding: 25rpx;
width: 100%;
display: flex;
flex-direction: column;
align-items: self-start;
justify-content: start;
.top-title-box {
padding-top: 10rpx;
padding-bottom: 20rpx;
margin-bottom: 15rpx;
width: 100%;
display: flex;
align-items: center;
justify-content: start;
border-bottom: 1rpx solid #F4F4F4;
.order-no {
flex: 1;
font-weight: bold;
display: flex;
align-items: center;
justify-content: start;
}
.order-status {
font-size: 27rpx;
padding: 5rpx 15rpx;
border-radius: 25rpx;
color: white;
}
.no-pay {
background-color: #929292;
}
.payed {
background-color: #FC1F3E;
}
}
.detail-item {
width: 100%;
padding: 10rpx 0;
display: flex;
align-items: center;
justify-content: start;
.left-dom {
display: flex;
align-items: center;
justify-content: start;
width: 200rpx;
}
.right-dom {
display: flex;
align-items: center;
justify-content: flex-end;
flex: 1;
}
}
.bottom-item {
padding-top: 15rpx;
font-size: 26rpx;
color: #929292;
}
}
}
.coupon-list-box {
margin-top: 20rpx;
background-color: white;
border-radius: 20rpx;
padding: 30rpx 20rpx;
margin-left: 30rpx;
margin-right: 30rpx;
width: calc(100% - 60rpx);
flex-direction: column;
display: flex;
align-items: self-start;
justify-content: center;
.top-text {
width: 100%;
display: flex;
align-items: center;
justify-content: center;
padding-bottom: 30rpx;
text {
color: #FB2B43;
padding: 0 10rpx;
}
}
.coupon-item-box {
width: 100%;
padding: 30rpx 40rpx 30rpx 20rpx;
display: flex;
align-items: center;
justify-content: center;
margin-bottom: 20rpx;
background-color: #FFE9EC;
border: 2rpx solid #FFE9EC;
border-radius: 15rpx;
color: #FC1F3E;
.left-dom {
flex: 1;
display: flex;
align-items: center;
justify-content: flex-start;
image {
width: 60rpx;
height: 60rpx;
margin-right: 15rpx;
}
}
.right-dom {
width: 200rpx;
display: flex;
align-items: baseline;
justify-content: flex-end;
font-weight: bold;
font-size: 36rpx;
text {
font-weight: normal;
margin-right: 8rpx;
font-size: 18rpx;
}
}
}
.click {
border: 2rpx solid #FC1F3E !important;
}
.button-dom {
margin-top: 30rpx;
width: 100%;
display: flex;
align-items: center;
justify-content: center;
padding: 20rpx 0;
background-image: linear-gradient(to right, #F9605A, #FB2B43);
color: white;
border-radius: 40rpx;
font-size: 33rpx;
}
}
.item-field {
color: #929292;
width: 100%;
display: flex;
align-items: self-start;
justify-content: center;
.my-suggest-dom {
margin: 0 30rpx;
display: flex;
align-items: center;
justify-content: center;
font-size: 24rpx;
margin-top: 20rpx;
}
}
}
}
</style>