| 
									
										
										
										
											2024-09-27 17:14:48 +08:00
										 |  |  | <template> | 
					
						
							|  |  |  |   <view class="container"> | 
					
						
							|  |  |  |     <v-navigation-bar title-color="#333" background-color="#fff" title="活动列表"> | 
					
						
							|  |  |  |     </v-navigation-bar> | 
					
						
							|  |  |  |     <view class="body"> | 
					
						
							| 
									
										
										
										
											2024-09-27 20:08:04 +08:00
										 |  |  |         <uni-card :title="item.name"  v-for="item in activeList"> | 
					
						
							|  |  |  |           <text class="uni-body">{{ item.remark }}</text> | 
					
						
							|  |  |  |           <view slot="actions" class="card-actions"> | 
					
						
							|  |  |  |             <picker v-if="item.type=='kkyl'" @change="bindPickerChange" :value="index" :range="array"> | 
					
						
							| 
									
										
										
										
											2024-09-27 20:37:19 +08:00
										 |  |  |               <button type="primary">参加</button> | 
					
						
							| 
									
										
										
										
											2024-09-27 20:08:04 +08:00
										 |  |  |             </picker> | 
					
						
							| 
									
										
										
										
											2024-09-27 20:37:19 +08:00
										 |  |  |             <view v-if="item.type=='zcyl'"> | 
					
						
							| 
									
										
										
										
											2024-09-27 20:08:04 +08:00
										 |  |  |               <button @click="joinAct(item)" v-if="item.isJoin!='1'" type="primary">参加</button> | 
					
						
							|  |  |  |               <button @click="joinAct(item)" v-if="item.isJoin=='1'" disabled type="primary">参加</button> | 
					
						
							|  |  |  |             </view> | 
					
						
							| 
									
										
										
										
											2024-09-27 20:37:19 +08:00
										 |  |  |             <view v-if="item.type=='czyl'"> | 
					
						
							|  |  |  |               <button @click="joinCzylActPrex(item)" type="primary">参加</button> | 
					
						
							|  |  |  |             </view> | 
					
						
							| 
									
										
										
										
											2024-09-27 17:14:48 +08:00
										 |  |  |           </view> | 
					
						
							| 
									
										
										
										
											2024-09-27 20:08:04 +08:00
										 |  |  |         </uni-card> | 
					
						
							| 
									
										
										
										
											2024-09-27 17:14:48 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-27 20:37:19 +08:00
										 |  |  |     </view> | 
					
						
							|  |  |  |     <view> | 
					
						
							|  |  |  |       <!-- 输入框示例 --> | 
					
						
							|  |  |  |       <uni-popup ref="inputDialog" type="dialog"> | 
					
						
							|  |  |  |         <uni-popup-dialog ref="inputClose"  mode="input" title="充值" value="" | 
					
						
							|  |  |  |                           placeholder="请输入充值金额" @confirm="dialogInputConfirm"></uni-popup-dialog> | 
					
						
							|  |  |  |       </uni-popup> | 
					
						
							| 
									
										
										
										
											2024-09-27 17:14:48 +08:00
										 |  |  |     </view> | 
					
						
							|  |  |  |   </view> | 
					
						
							| 
									
										
										
										
											2024-09-27 20:37:19 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-27 17:14:48 +08:00
										 |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  | import VNavigationBar from '@/components/VNavigationBar.vue' | 
					
						
							|  |  |  | import request from "@/utils/request"; | 
					
						
							| 
									
										
										
										
											2024-09-27 17:57:20 +08:00
										 |  |  | import {getUserInfoRequest} from "@/utils/common.js"; | 
					
						
							|  |  |  | import {getToken,setUserInfo} from '@/utils/auth.js' | 
					
						
							| 
									
										
										
										
											2024-09-27 17:14:48 +08:00
										 |  |  | export default { | 
					
						
							|  |  |  |   components: { | 
					
						
							|  |  |  |     VNavigationBar, | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   data() { | 
					
						
							|  |  |  |     return { | 
					
						
							| 
									
										
										
										
											2024-09-27 20:48:40 +08:00
										 |  |  |       //可以点击
 | 
					
						
							|  |  |  |       canClick:true, | 
					
						
							| 
									
										
										
										
											2024-09-27 20:08:04 +08:00
										 |  |  |       value:"", | 
					
						
							|  |  |  |       index:0, | 
					
						
							|  |  |  |       array:[], | 
					
						
							|  |  |  |       couponList:[], | 
					
						
							|  |  |  |       orderInfo:{}, | 
					
						
							| 
									
										
										
										
											2024-09-27 17:14:48 +08:00
										 |  |  |       customInfo: {}, | 
					
						
							|  |  |  |       activeList: [], | 
					
						
							| 
									
										
										
										
											2024-09-27 20:08:04 +08:00
										 |  |  |       //开卡有礼活动id
 | 
					
						
							|  |  |  |       kkylActId:"", | 
					
						
							| 
									
										
										
										
											2024-09-27 20:37:19 +08:00
										 |  |  |       //充值有礼活动id
 | 
					
						
							|  |  |  |       czylActId:"", | 
					
						
							|  |  |  |       //充值金额
 | 
					
						
							|  |  |  |       topUpAmount:0.0, | 
					
						
							| 
									
										
										
										
											2024-09-27 17:14:48 +08:00
										 |  |  |       tabList: [{ | 
					
						
							|  |  |  |         value: 0, | 
					
						
							|  |  |  |         title: '礼包券' | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |           value: 1, | 
					
						
							|  |  |  |           title: '卡包' | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       ], | 
					
						
							|  |  |  |       activeKey: 0 | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   onShow(data) { | 
					
						
							| 
									
										
										
										
											2024-09-27 17:57:20 +08:00
										 |  |  |     if(!getToken()){ | 
					
						
							|  |  |  |       uni.reLaunch({ | 
					
						
							|  |  |  |         url: '/pages/login/login' | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     }else{ | 
					
						
							|  |  |  |       console.log("已登录") | 
					
						
							|  |  |  |       this.getUserInfos() | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-09-27 17:14:48 +08:00
										 |  |  |   }, | 
					
						
							|  |  |  |   onLoad(data) { | 
					
						
							|  |  |  |     this.getActive() | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   methods: { | 
					
						
							| 
									
										
										
										
											2024-09-27 20:37:19 +08:00
										 |  |  |     isNumber(value) { | 
					
						
							|  |  |  |       return /^\d+(\.\d+)?$/.test(value); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     dialogInputConfirm(val) { | 
					
						
							|  |  |  |       if(this.isNumber(val)){ | 
					
						
							|  |  |  |         console.log(val) | 
					
						
							|  |  |  |         this.topUpAmount = val | 
					
						
							|  |  |  |         //充值下单
 | 
					
						
							|  |  |  |         this.joinCzylAct() | 
					
						
							|  |  |  |         // 关闭窗口后,恢复默认内容
 | 
					
						
							|  |  |  |         this.$refs.inputDialog.close() | 
					
						
							|  |  |  |       }else{ | 
					
						
							|  |  |  |         uni.showToast({ | 
					
						
							|  |  |  |           title: '请输入数字!', | 
					
						
							|  |  |  |           icon: 'none' | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-09-27 20:08:04 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     bindPickerChange(e){ | 
					
						
							|  |  |  |       this.index = e.detail.value | 
					
						
							|  |  |  |       console.log("index",this.index) | 
					
						
							|  |  |  |       this.joinKkylAct() | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-09-27 17:57:20 +08:00
										 |  |  |     //获取当前登录用户信息
 | 
					
						
							|  |  |  |     async getUserInfos() { | 
					
						
							| 
									
										
										
										
											2024-09-27 20:08:04 +08:00
										 |  |  |       await getUserInfoRequest() | 
					
						
							|  |  |  |       await this.getActive() | 
					
						
							| 
									
										
										
										
											2024-09-27 17:57:20 +08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-09-27 17:14:48 +08:00
										 |  |  |     //查询营销活动列表
 | 
					
						
							|  |  |  |     async getActive() { | 
					
						
							| 
									
										
										
										
											2024-09-27 20:08:04 +08:00
										 |  |  |       this.customInfo = JSON.parse(uni.getStorageSync('customerInfo')) | 
					
						
							| 
									
										
										
										
											2024-09-27 17:14:48 +08:00
										 |  |  |       const data = { | 
					
						
							| 
									
										
										
										
											2024-09-27 20:08:04 +08:00
										 |  |  |         cusId: this.customInfo.id | 
					
						
							| 
									
										
										
										
											2024-09-27 17:14:48 +08:00
										 |  |  |       } | 
					
						
							|  |  |  |       await request({ | 
					
						
							|  |  |  |         url: '/userClient/customer/activeList', | 
					
						
							|  |  |  |         method: 'get', | 
					
						
							|  |  |  |         params:data | 
					
						
							|  |  |  |       }).then((res) => { | 
					
						
							|  |  |  |         this.activeList = res.data | 
					
						
							| 
									
										
										
										
											2024-09-27 20:08:04 +08:00
										 |  |  |         for(var i = 0; i < this.activeList.length; i++) { | 
					
						
							|  |  |  |           if(this.activeList[i].type=="kkyl"){ | 
					
						
							|  |  |  |             this.kkylActId = this.activeList[i].id | 
					
						
							|  |  |  |              request({ | 
					
						
							|  |  |  |               url: "/userClient/customer/getActive", | 
					
						
							|  |  |  |               method: "get", | 
					
						
							|  |  |  |               params:{id:this.activeList[i].id} | 
					
						
							|  |  |  |             }).then((res) => { | 
					
						
							|  |  |  |               if(res.data.hasOwnProperty("couponList")&&res.data.couponList.length>0){ | 
					
						
							|  |  |  |                 this.couponList = res.data.couponList | 
					
						
							|  |  |  |                 for(var i = 0; i < res.data.couponList.length; i++) { | 
					
						
							|  |  |  |                   var coupon = res.data.couponList[i] | 
					
						
							|  |  |  |                   this.array.push(coupon.name+"("+coupon.amount+")") | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 this.$forceUpdate() | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |             }) | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-09-27 17:14:48 +08:00
										 |  |  |       }) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-27 20:08:04 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2024-09-27 20:37:19 +08:00
										 |  |  |      * 参加注册活动 | 
					
						
							| 
									
										
										
										
											2024-09-27 20:08:04 +08:00
										 |  |  |      * @param item | 
					
						
							|  |  |  |      * @returns {Promise<void>} | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-09-27 20:37:19 +08:00
										 |  |  |     async joinAct(item) { | 
					
						
							| 
									
										
										
										
											2024-09-27 20:48:40 +08:00
										 |  |  |       if(this.canClick){ | 
					
						
							|  |  |  |         this.canClick = false | 
					
						
							|  |  |  |         let dataObj = {} | 
					
						
							|  |  |  |         dataObj.cusId = this.customInfo.id | 
					
						
							|  |  |  |         dataObj.activeId = item.id | 
					
						
							|  |  |  |         await request({ | 
					
						
							|  |  |  |           url: "/userClient/customer/attendActive", | 
					
						
							|  |  |  |           method: "POST", | 
					
						
							|  |  |  |           data: dataObj | 
					
						
							|  |  |  |         }).then((res) => { | 
					
						
							|  |  |  |           this.getActive() | 
					
						
							|  |  |  |           this.canClick = true | 
					
						
							|  |  |  |           console.log(res); | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-09-27 20:08:04 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * 参加开卡有礼活动 | 
					
						
							|  |  |  |      * @returns {Promise<void>} | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     async joinKkylAct(){ | 
					
						
							|  |  |  |       let dataObj = {} | 
					
						
							|  |  |  |       dataObj.cusId = this.customInfo.id | 
					
						
							|  |  |  |       dataObj.activeId = this.kkylActId | 
					
						
							|  |  |  |       dataObj.accountType='01' | 
					
						
							|  |  |  |       dataObj.selectCoupon=[this.couponList[this.index]] | 
					
						
							|  |  |  |       await request({ | 
					
						
							|  |  |  |         url: "/userClient/customer/attendActive", | 
					
						
							|  |  |  |         method: "POST", | 
					
						
							|  |  |  |         data:dataObj | 
					
						
							|  |  |  |       }).then((res) => { | 
					
						
							|  |  |  |         console.log(res); | 
					
						
							| 
									
										
										
										
											2024-09-27 20:37:19 +08:00
										 |  |  |         //拿到开卡有礼订单 TODO  对接支付
 | 
					
						
							|  |  |  |         this.orderInfo = res.data | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * 充值有礼前置方法 | 
					
						
							|  |  |  |      * @returns {Promise<void>} | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     async joinCzylActPrex(item){ | 
					
						
							|  |  |  |       this.$refs.inputDialog.open() | 
					
						
							|  |  |  |       this.czylActId = item.id | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * 充值有礼 | 
					
						
							|  |  |  |      * @returns {Promise<void>} | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     async joinCzylAct(){ | 
					
						
							|  |  |  |       let dataObj = {} | 
					
						
							|  |  |  |       dataObj.cusId = this.customInfo.id | 
					
						
							|  |  |  |       dataObj.activeId = this.czylActId | 
					
						
							|  |  |  |       dataObj.accountType='01' | 
					
						
							|  |  |  |       dataObj.topUpAmount=this.topUpAmount | 
					
						
							|  |  |  |       await request({ | 
					
						
							|  |  |  |         url: "/userClient/customer/attendActive", | 
					
						
							|  |  |  |         method: "POST", | 
					
						
							|  |  |  |         data:dataObj | 
					
						
							|  |  |  |       }).then((res) => { | 
					
						
							|  |  |  |         console.log(res); | 
					
						
							|  |  |  |         //拿到充值有礼订单 TODO  对接支付
 | 
					
						
							| 
									
										
										
										
											2024-09-27 20:08:04 +08:00
										 |  |  |         this.orderInfo = res.data | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-09-27 17:14:48 +08:00
										 |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style lang="less" scoped> | 
					
						
							|  |  |  | .container { | 
					
						
							|  |  |  |   height: 100%; | 
					
						
							|  |  |  |   background-color: #F0F1F5; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  |   flex-direction: column; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .body { | 
					
						
							|  |  |  |     flex: 1; | 
					
						
							|  |  |  |     height: 0; | 
					
						
							|  |  |  |     box-sizing: border-box; | 
					
						
							|  |  |  |     padding: 30 rpx 0; | 
					
						
							|  |  |  |     margin: 0 32 rpx; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     flex-direction: column; | 
					
						
							|  |  |  |     row-gap: 20 rpx; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     overflow: auto; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-27 17:57:20 +08:00
										 |  |  | </style> |