542 lines
12 KiB
Vue
542 lines
12 KiB
Vue
<template>
|
|
<!-- 道具商城页面 -->
|
|
<view class="view-page">
|
|
<view v-if="!errorPage">
|
|
<!-- 自定义选项卡 -->
|
|
<NavigationTabs :tabs-data="tabs" :default-active="currentIndex" @tab-change="handleTabChange" />
|
|
<view class="swiper-view">
|
|
</view>
|
|
<scroll-view scroll-y="true" class="list-view">
|
|
<view class="flex-container" v-if="listData && listData.length">
|
|
<!-- 循环生成子元素 -->
|
|
<view v-for="(item,index) in listData" @click="openPopup(item)" :key="index" class="flex-item decorate-box">
|
|
<view class="decorate-content">
|
|
<view class="decorate-image">
|
|
<img :src="item.base_image" alt="" />
|
|
</view>
|
|
<view class="decorate-title w-fill color-3 font-28">
|
|
{{item.title}}
|
|
</view>
|
|
<view class="decorate-price color-3 w-fill">
|
|
<img class="icon-goin" src="@/static/image/goin.png" alt="" /> {{item.price}}
|
|
</view>
|
|
<view class="decorate-tag" v-if="[6,7,8].includes(item.type)">
|
|
<span v-if="item.type === 6">个人靓号</span>
|
|
<span v-if="item.type === 7">房间靓号</span>
|
|
<span v-if="item.type === 8">公会靓号</span>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<!-- <uni-grid :column="3" :showBorder="false" :square="false">
|
|
<uni-grid-item class="decorate-box" @click="openPopup(item)" >
|
|
|
|
</uni-grid-item>
|
|
</uni-grid> -->
|
|
<view class="color-9" v-else style="text-align: center;font-size: 24rpx;">
|
|
暂无数据
|
|
</view>
|
|
</scroll-view>
|
|
<uni-popup ref="popup" borderRadius="32rpx 32rpx 0 0" type="bottom" background-color="#fff">
|
|
<view class="popup-view" v-if="decorateDetail">
|
|
<view class="decorate-image">
|
|
<img :src="decorateDetail.base_image" alt="" />
|
|
</view>
|
|
<view class="decorate-title w-fill color-3 font-28">
|
|
{{decorateDetail.title}}
|
|
</view>
|
|
<view class="decorate-info">
|
|
<view class="info-line">
|
|
<view class="line-lable">
|
|
商品名称
|
|
</view>
|
|
<view class="">
|
|
{{decorateDetail.title}}
|
|
</view>
|
|
</view>
|
|
<view class="info-line">
|
|
<view class="line-lable">
|
|
商品价格
|
|
</view>
|
|
<view class="flex-line">
|
|
{{payData.price}} <img class="icon-goin ml-6" src="@/static/image/goin.png"
|
|
alt="" />
|
|
</view>
|
|
</view>
|
|
<template v-if="decorateDetail.decorate && decorateDetail.decorate.price_list">
|
|
<view class="info-line">
|
|
<view class="line-lable">
|
|
有效期至
|
|
</view>
|
|
<view class="">
|
|
{{payData.end_time}}
|
|
</view>
|
|
|
|
</view>
|
|
<view style="padding: 18rpx 0;">
|
|
<view class="line-lable" style="text-align: left;">
|
|
购买时长
|
|
</view>
|
|
</view>
|
|
<view class="info-line setmenut" style="justify-content: flex-start">
|
|
<view :class="currentMenuIndex === menuIndex ? 'active-menubox' : 'menubox'"
|
|
v-for="(menu,menuIndex) in decorateDetail.decorate.price_list"
|
|
@click="changePayData(menu,menuIndex)">
|
|
<view>
|
|
{{menu.day}}天
|
|
</view>
|
|
<view class="sale" v-if="menu.discount">
|
|
7折优惠
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</template>
|
|
</view>
|
|
<view class="flex-line user-account font-28">
|
|
<view class="">
|
|
<img class="icon-goin ml-6" src="@/static/image/goin.png" alt="" />
|
|
</view>
|
|
<view class="color-6 ml-20">
|
|
{{decorateDetail.user_info.user_coin}}
|
|
</view>
|
|
<view class="chongzhi-text ml-20" @click="RechargeCoin">
|
|
去充值
|
|
</view>
|
|
</view>
|
|
<view class="button-footer">
|
|
<view class="pay-button" @click="toPay">
|
|
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</uni-popup>
|
|
</view>
|
|
<view v-else>
|
|
<!-- 请求出错啦 -->
|
|
</view>
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
import http from '@/until/http.js';
|
|
import NavigationTabs from '@/component/tab.vue'
|
|
export default {
|
|
components: {
|
|
NavigationTabs
|
|
},
|
|
data() {
|
|
return {
|
|
errorPage: true,
|
|
tabs: [],
|
|
listData: [],
|
|
currentIndex: 0,
|
|
indicatorLeft: 5,
|
|
decorateDetail: null,
|
|
currentMenuIndex: 0,
|
|
payData: null
|
|
}
|
|
},
|
|
onLoad(options) {
|
|
this.errorPage = true
|
|
const {
|
|
id
|
|
} = options
|
|
uni.setStorageSync('token', id)
|
|
if (uni.getStorageSync('token')) this.gettabs()
|
|
},
|
|
methods: {
|
|
async gettabs() {
|
|
http.get('/api/Decorate/get_type_list', {
|
|
token: uni.getStorageSync('token') ?? '',
|
|
have_hot: 0
|
|
}).then(response => {
|
|
const {
|
|
data,
|
|
code
|
|
} = response
|
|
// let list = []
|
|
if (code) {
|
|
// console.log(data)
|
|
this.tabs = data.map(ele => {
|
|
return {
|
|
type: ele.id,
|
|
value: ele.name
|
|
}
|
|
})
|
|
// Object.keys(data).forEach(ele => {
|
|
// // console.log(ele)
|
|
// const item = {
|
|
// type: +ele,
|
|
// value: data[ele]
|
|
// }
|
|
// list.push(item)
|
|
// })
|
|
// console.log(list)
|
|
}
|
|
// this.tabs = list
|
|
this.errorPage = false
|
|
this.$nextTick(() => {
|
|
this.getDecorate(this.tabs[0].type)
|
|
})
|
|
}).catch(error => {
|
|
this.tabs = []
|
|
this.errorPage = true
|
|
});
|
|
},
|
|
async getDecorate(type) {
|
|
// let listData = []
|
|
http.get('/api/Decorate/get_decorate_list', {
|
|
token: uni.getStorageSync('token') ?? '',
|
|
type
|
|
}).then(response => {
|
|
// console.log(response.data)
|
|
// for (let i = 1; i <= 40; i++) {
|
|
// listData.push(...response.data)
|
|
// }
|
|
// this.listData =listData
|
|
// console.log(listData)
|
|
const {
|
|
data,
|
|
code
|
|
} = response
|
|
this.listData = code ? data : []
|
|
|
|
}).catch(error => {
|
|
this.tabs = []
|
|
this.errorPage = true
|
|
});
|
|
},
|
|
async getDecorateDetail(id, detail) {
|
|
http.get('/api/Decorate/get_decorate_detail', {
|
|
token: uni.getStorageSync('token') ?? '',
|
|
did: id
|
|
}).then(response => {
|
|
const {
|
|
data,
|
|
code
|
|
} = response
|
|
this.decorateDetail = code ? {
|
|
...detail,
|
|
...data
|
|
} : null
|
|
this.currentMenuIndex = 0
|
|
console.log(this.decorateDetail)
|
|
this.payData = this.decorateDetail.decorate.price_list[this.currentMenuIndex]
|
|
this.$refs.popup.open('bottom')
|
|
}).catch(error => {});
|
|
},
|
|
changePayData(data, index) {
|
|
this.payData = data
|
|
this.currentMenuIndex = index
|
|
},
|
|
handleTabChange({
|
|
index,
|
|
tab
|
|
}) {
|
|
this.currentIndex = index;
|
|
console.log(index, tab)
|
|
const {
|
|
type
|
|
} = tab
|
|
this.getDecorate(type)
|
|
},
|
|
// 打开弹框
|
|
openPopup(data) {
|
|
this.getDecorateDetail(data.did, data)
|
|
},
|
|
closePopup() {
|
|
this.decorateDetail = null
|
|
this.currentMenuIndex = 0
|
|
this.payData = null
|
|
this.$refs.popup.close()
|
|
},
|
|
// 去支付
|
|
toPay() {
|
|
// console.log(this.payData,this.decorateDetail)
|
|
if (this.payData.price > this.decorateDetail.user_info.user_coin) {
|
|
// 余额不足
|
|
uni.showToast({
|
|
title: '余额不足,请先充值',
|
|
icon: 'none',
|
|
mask: true,
|
|
duration: 500
|
|
});
|
|
return
|
|
}
|
|
// 余额足 调购买装扮接口
|
|
this.payDecorate()
|
|
},
|
|
payDecorate() {
|
|
uni.showLoading({
|
|
mask: true
|
|
})
|
|
http.post('/api/Decorate/pay_decorate', {
|
|
token: uni.getStorageSync('token') ?? '',
|
|
did: this.decorateDetail.did,
|
|
day: this.payData.day
|
|
}).then(response => {
|
|
uni.showToast({
|
|
title: '购买成功',
|
|
icon: 'success',
|
|
mask: true,
|
|
duration: 1000
|
|
});
|
|
uni.hideLoading()
|
|
this.closePopup()
|
|
}).catch(error => {});
|
|
},
|
|
// 点击去充值
|
|
RechargeCoin() {
|
|
const platform = uni.getSystemInfoSync().platform;
|
|
// console.log(platform, '打印设备参数')
|
|
if (platform === 'ios') {
|
|
console.log('调用iOS原生方法')
|
|
// 通过 messageHandlers 调用 iOS 原生方法
|
|
window.webkit.messageHandlers.nativeHandler.postMessage({
|
|
'action': 'Recharge'
|
|
});
|
|
} else if (platform === 'android') {
|
|
console.log('调用Android原生方法')
|
|
// 调用 Android 原生方法
|
|
window.Android.Recharge();
|
|
|
|
}
|
|
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
<style lang="scss" scoped>
|
|
.view-page {
|
|
padding: 0 32rpx;
|
|
min-height: 100vh;
|
|
background: #00000000;
|
|
|
|
.decorate-box {
|
|
margin: 0 auto;
|
|
|
|
.decorate-content {
|
|
width: 95%;
|
|
background: #EFF2F8;
|
|
border-radius: 20rpx;
|
|
position: relative;
|
|
text-align: center;
|
|
display: inline-flex;
|
|
flex-wrap: wrap;
|
|
align-items: center;
|
|
justify-content: center;
|
|
align-content: center;
|
|
margin-bottom: 14rpx;
|
|
padding: 12rpx 0;
|
|
|
|
.decorate-image {
|
|
// width: 120rpx;
|
|
height: 120rpx;
|
|
margin: 12rpx 0;
|
|
width: 100%;
|
|
// background-color: #5B5B5B;
|
|
display: inline-flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
|
|
img {
|
|
width: 120rpx;
|
|
}
|
|
}
|
|
|
|
.decorate-price {
|
|
.icon-goin {
|
|
width: 24rpx;
|
|
height: 24rpx;
|
|
}
|
|
}
|
|
|
|
.decorate-tag {
|
|
position: absolute;
|
|
right: 0;
|
|
top: 0;
|
|
font-size: 20rpx;
|
|
padding: 8rpx 10rpx;
|
|
background-image: url('@/static/image/lhbg.png');
|
|
background-repeat: no-repeat;
|
|
background-size: 100% 100%;
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
.decorate-image {
|
|
width: 120rpx;
|
|
height: 120rpx;
|
|
margin: 12rpx 0;
|
|
// background-color: #5B5B5B;
|
|
}
|
|
|
|
.swiper-view {
|
|
width: 686rpx;
|
|
height: 200rpx;
|
|
border-radius: 14rpx 14rpx 14rpx 14rpx;
|
|
background-image: url('@/static/image/swiper.png');
|
|
background-repeat: no-repeat;
|
|
background-size: 100% 100%;
|
|
margin-bottom: 32rpx;
|
|
}
|
|
|
|
// background-color: bisque;
|
|
.list-view {
|
|
width: calc(100vw - 64rpx);
|
|
height: calc(100vh - 200rpx - 32rpx - 100rpx);
|
|
}
|
|
|
|
.popup-view {
|
|
height: 60vh;
|
|
padding: 32rpx;
|
|
width: calc(100vw - 64rpx);
|
|
display: inline-flex;
|
|
flex-wrap: wrap;
|
|
flex-direction: row;
|
|
align-content: flex-start;
|
|
align-items: center;
|
|
justify-content: center;
|
|
text-align: center;
|
|
|
|
.decorate-title {
|
|
font-size: 28rpx;
|
|
}
|
|
|
|
.decorate-info {
|
|
width: calc(100vw - 64rpx);
|
|
margin-top: 48rpx;
|
|
color: #333333;
|
|
|
|
.info-line {
|
|
width: 100%;
|
|
display: inline-flex;
|
|
align-content: flex-start;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
text-align: center;
|
|
padding: 18rpx 0;
|
|
|
|
.icon-goin {
|
|
width: 28rpx;
|
|
height: 28rpx;
|
|
margin-top: 6rpx;
|
|
}
|
|
}
|
|
|
|
.setmenut {
|
|
|
|
.menubox,
|
|
.active-menubox {
|
|
width: 152rpx;
|
|
height: 124rpx;
|
|
// padding: 26rpx 38rpx;
|
|
// line-height: 94rpx;
|
|
display: inline-flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
border-radius: 12rpx 12rpx 12rpx 12rpx;
|
|
border: 2rpx solid #F1F2F3;
|
|
position: relative;
|
|
margin-right: 20rpx;
|
|
}
|
|
|
|
.active-menubox {
|
|
border: 0;
|
|
background-image: url('@/static/image/menuBg.png');
|
|
background-repeat: no-repeat;
|
|
background-size: 100% 100%;
|
|
color: #0DFFB9;
|
|
|
|
}
|
|
|
|
.sale {
|
|
position: absolute;
|
|
top: 0;
|
|
right: 0;
|
|
font-size: 20rpx;
|
|
color: #fff;
|
|
padding: 0 8rpx;
|
|
background-image: url('@/static/image/sale.png');
|
|
background-repeat: no-repeat;
|
|
background-size: 100% 100%;
|
|
}
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
.user-account {
|
|
width: 100%;
|
|
display: inline-flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
margin: 30rpx 0;
|
|
|
|
.icon-goin {
|
|
width: 24rpx;
|
|
height: 24rpx;
|
|
}
|
|
|
|
.chongzhi-text {
|
|
font-family: Source Han Sans CN, Source Han Sans CN;
|
|
font-weight: 400;
|
|
font-size: 28rpx;
|
|
color: #0DFFB9;
|
|
}
|
|
}
|
|
|
|
.button-footer {
|
|
width: 100%;
|
|
display: inline-flex;
|
|
align-items: center;
|
|
justify-content: space-around;
|
|
|
|
.give-button {
|
|
width: 190rpx;
|
|
height: 84rpx;
|
|
background-image: url('@/static/image/propMall/give.png');
|
|
background-repeat: no-repeat;
|
|
background-size: 100% 100%;
|
|
}
|
|
|
|
.pay-button {
|
|
|
|
width: 376rpx;
|
|
height: 84rpx;
|
|
background-image: url('@/static/image/propMall/pay.png');
|
|
background-repeat: no-repeat;
|
|
background-size: 100% 100%;
|
|
}
|
|
}
|
|
}
|
|
|
|
.flex-container {
|
|
display: flex;
|
|
/* 启用 Flex 布局 */
|
|
flex-wrap: wrap;
|
|
/* 允许换行 */
|
|
}
|
|
|
|
.flex-item {
|
|
flex: 0 0 calc(33% - 10px);
|
|
/* 基础宽度25% 减去间隔 */
|
|
margin: 5px;
|
|
/* 元素间距 */
|
|
box-sizing: border-box;
|
|
/* 包含内边距和边框 */
|
|
border-radius: 14rpx;
|
|
/* 样式美化(可选) */
|
|
background-color: #fff;
|
|
// padding: 20rpx;
|
|
text-align: center;
|
|
|
|
.image {
|
|
width: 120rpx;
|
|
height: 120rpx;
|
|
}
|
|
}
|
|
}
|
|
</style> |