This commit is contained in:
PQZ 2025-04-11 15:35:27 +08:00
parent b9c79d06a6
commit e5793326d8
6 changed files with 126 additions and 79 deletions

View File

@ -34,3 +34,12 @@ export function rightList(params) {
params:params
})
}
//------------------通告券相关-----------------------
//查询基础通告券
export function initCouponList() {
return request({
url: '/base/coupon/uniCouponList',
method: 'get'
})
}

View File

@ -34,14 +34,6 @@ export function toApply(data) {
}
//------------------开通会员-----------------------
export function saveOrder(data) {
return request({
url: '/member/order/uniSaveOrder',
method: 'post',
data: data
})
}
//------------------名片-----------------------
// 查询当前登录用户的名片
export function getUserBusiCard() {
@ -129,4 +121,20 @@ export function selectMemberRights() {
url: '/member/card/selectMemberRights',
method: 'get'
})
}
//------------------订单相关-----------------------
export function getOrderList(params) {
return request({
url: '/member/order/list',
method: 'get',
params: params
})
}
export function saveOrder(data) {
return request({
url: '/member/order/uniSaveOrder',
method: 'post',
data: data
})
}

View File

@ -67,19 +67,10 @@
<script>
import navigationBarVue from '@/components/navigation/navigationBar.vue';
import {
formatNumberWithUnits
} from '@/utils/common.js'
import {
getUserBusiCard,
removeBusiCard
} from '@/api/business/member.js'
import {
getSignCard
} from '@/api/business/signCard.js'
import {
hasRights
} from '@/utils/common.js'
import {formatNumberWithUnits} from '@/utils/common.js'
import {getUserBusiCard, removeBusiCard} from '@/api/business/member.js'
import {getSignCard} from '@/api/business/signCard.js'
import {hasRights} from '@/utils/common.js'
import rightsCode from '@/utils/rightsCode.js'
export default {
components: {

View File

@ -16,7 +16,7 @@
</view>
<view class="bottom-content">
<view class="top-text">剩余<text>0</text></view>
<view class="top-text">剩余<text>{{ coupon }}</text></view>
<view class="button-dom" @click="goMyCoupon(0)">去获取</view>
</view>
@ -45,8 +45,12 @@
data() {
return {
globalConfig: getApp().globalData.config,
coupon:0
}
},
onLoad(options){
this.coupon = options.coupon
},
methods: {
viewRichText() {
this.$tab.navigateTo(
@ -55,7 +59,7 @@
},
goMyCoupon(index) {
this.$tab.navigateTo(
`/pages/mine/coupon/my-coupon?index=${index}`
`/pages/mine/coupon/my-coupon?index=${index}&coupon=`+this.coupon
)
}
}

View File

@ -12,19 +12,19 @@
</view>
<view style="width: 100%;" v-if="0==menuIndex">
<view class="coupon-list-box">
<view class="top-text">剩余<text>0</text></view>
<view class="top-text">剩余<text>{{ coupon }}</text></view>
<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>
<view style="margin-left: 15rpx;">{{item.num}}</view>
<view style="margin-left: 15rpx;">{{item.couponNum}}</view>
</view>
<view class="right-dom">
<text>¥</text>{{item.price}}
</view>
</view>
<view class="button-dom" @click="buyFun()">购买</view>
<view class="button-dom" @click="toOrder()">购买</view>
</view>
<view class="item-field" style="align-items: center;">
<view class="my-suggest-dom" @click="viewRichText()">
@ -39,16 +39,16 @@
<view class="item-box" v-for="(item,index) in byList">
<view class="top-title-box">
<view class="order-no">订单编号{{item.orderNo}}</view>
<view :class="['order-status',item.ifPay?'payed':'no-pay']">{{item.ifPay?'已支付':'未支付'}}
<view :class="['order-status',item.isPay==1?'payed':'no-pay']">{{item.isPay==1?'已支付':'未支付'}}
</view>
</view>
<view class="detail-item">
<view class="left-dom">通告券</view>
<view class="right-dom">*{{item.num}} </view>
<view class="right-dom">*{{item.goodsNum}} </view>
</view>
<view class="detail-item" style="border-bottom:1rpx solid #F4F4F4;padding-bottom: 25rpx;">
<view class="left-dom">金额</view>
<view class="right-dom">{{item.price}} </view>
<view class="right-dom">{{item.goodsPrice}} </view>
</view>
<view class="bottom-item">
下单时间{{item.createTime}}
@ -66,10 +66,11 @@
<script>
import navigationBarVue from '@/components/navigation/navigationBar.vue';
import {
toast,
hasRights
} from '@/utils/common.js'
import {initCouponList} from '@/api/business/base.js'
import {saveOrder,getOrderList} from '@/api/business/member.js'
import {toast} from '@/utils/common.js'
import constant from '@/utils/constant';
import {getJSONData} from '@/utils/auth.js'
export default {
components: {
navigationBarVue
@ -79,48 +80,28 @@
globalConfig: getApp().globalData.config,
menus: ['通告券', '购买记录'],
menuIndex: 0,
coupon:0,
//
couponIndex: 0,
queryParams: {
pageNum: 1,
pageSize: 10
pageSize: 10,
orderType:'02',
userId:null,
},
total: 0,
//
isTriggered: false,
dataList: [{
id: "3",
num: 5,
price: 20
}, {
id: "2",
num: 10,
price: 40
}, {
id: "1",
num: 20,
price: 80
}],
dataList: [],
//
byList: [{
id: "1",
orderNo: "111",
num: 20,
price: 80,
ifPay: true,
createTime: "2024-02-03 12:23:00"
}, {
id: "2",
orderNo: "111",
num: 10,
price: 40,
ifPay: false,
createTime: "2024-02-03 12:23:00"
}]
byList: []
}
},
onLoad(option) {
this.menuIndex = option.index
this.coupon = option.coupon
this.initCoupon();
this.initOrder()
},
methods: {
/**
@ -132,6 +113,59 @@
this.menuIndex = index
},
/**查询卡券*/
initCoupon(){
this.dataList = []
initCouponList().then(res=>{
this.dataList = res.data
})
},
/**初始化订单数据*/
initOrder(){
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.data.total
}
})
},
/**生成订单*/
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'
}
saveOrder(data).then(res => {
if (res.code == 200) {
uni.showToast({
icon: 'success',
duration: 2000,
title: '保存成功'
});
uni.navigateBack()
}
}).catch((e) => {
uni.showToast({
icon: 'error',
duration: 2000,
title: e
});
})
},
/**
* 选中的优惠券
* @param {Object} index
@ -139,14 +173,15 @@
chooseCoupon(index) {
this.couponIndex = index
},
buyFun() {
},
viewRichText() {
this.$tab.navigateTo(
`/pages/common/richview/index?title=${this.globalConfig.appInfo.agreements[6].title}&code=${this.globalConfig.appInfo.agreements[6].code}`
)
},
/**
* 上滑加载数据
*/
@ -158,6 +193,7 @@
}
//+1,
this.queryParams.pageNum++
this.initOrder()
},
/**
* 下拉刷新数据
@ -166,6 +202,7 @@
this.isTriggered = true
this.queryParams.pageNum = 1
this.total = 0
this.initOrder()
},
}
}

View File

@ -77,14 +77,14 @@
<!-- 发布通告 -->
<view class="public-notice-box" v-if="'01'==localUserType">
<view class="left-box">
<view style="margin-bottom: 20rpx;">发布通告额度剩余3条</view>
<progress style="width: 90%;" border-radius="5" percent="40" activeColor="#FC1F3E"
backgroundColor="#DEDEDE" stroke-width="8" />
</view>
<view class="right-box">
获取更多
<uni-icons type="right" color="#623109" size="12"></uni-icons>
<view style="margin-bottom: 20rpx;">发布通告额度剩余{{userInfo.coupon}}</view>
<!-- <progress style="width: 90%;" border-radius="5" percent="40" activeColor="#FC1F3E"-->
<!-- backgroundColor="#DEDEDE" stroke-width="8" />-->
</view>
<!-- <view class="right-box">-->
<!-- 获取更多-->
<!-- <uni-icons type="right" color="#623109" size="12"></uni-icons>-->
<!-- </view>-->
</view>
</view>
<!-- 个人信息和其他信息 -->
@ -170,12 +170,7 @@
import tabBarVue from '@/components/tabbar/tabBar.vue'
import storage from '@/utils/storage'
import constant from '@/utils/constant';
import {
changeUserType,
getUserType,
formatNumberWithUnits,
calculateTimeDifference
} from '@/utils/common.js'
import {changeUserType} from '@/utils/common.js'
import config from '@/config'
import {
getJSONData,
@ -205,7 +200,9 @@
globalConfig: getApp().globalData.config,
//
ifHasCard: false,
userInfo: {},
userInfo: {
coupon:0
},
imageUrl: config.baseUrl,
//
wechat_img: constant.wechat_img,
@ -243,6 +240,7 @@
this.userInfo.tfansNum = res.data.tfansNum.toString()
this.userInfo.pointsBalance = res.data.pointsBalance.toString()
this.userInfo.report = res.data.report.toString()
this.userInfo.coupon = res.data.coupon.toString()
this.userInfo.avatar = this.imageUrl + res.data.avatar
})
},
@ -280,7 +278,7 @@
this.$tab.navigateTo('/pages/mine/auth/auth-choose')
},
goCoupon() {
this.$tab.navigateTo('/pages/mine/coupon/coupon-list')
this.$tab.navigateTo('/pages/mine/coupon/coupon-list?userId='+this.userInfo.userId + '&coupon='+this.userInfo.coupon)
},
goHistory() {
this.$tab.navigateTo('/pages/mine/history/history')