You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

103 lines
2.2 KiB

<template>
<view class="lottery_container">
<view class="grid_wrap">
<view class="lottery_wrap">
<ul class="lottery_grid">
<li v-for="(item, index) in prizeData" :class="{ active: current_index == index && index != 8 }"
:key="index" @click="luck_draw" :data-index="index">
<view :class="{in_line:index != 8 }" class="lottery-msg">
<image v-if="index != 8" class="grid_img" mode='aspectFit' :src="item.image" alt="" />
<text v-if="index !=8" class="name">
{{ index == 8 ? $t(`抽奖`) : item.name }}
</text>
<image v-else class="lottery-click" src="../../static/lottery-click.png" mode="">
</image>
</view>
</li>
</ul>
</view>
</view>
</view>
</template>
<script>
import LotteryDraw from './js/grids_lottery.js';
export default {
data() {
return {
current_index: -1,
lotteryBtn: true
};
},
props: {
prizeData: {
type: Array,
default: function() {
return []
}
},
lotteryNum: {
type: Number | String,
default: 0
}
},
onLoad() {
},
methods: {
luck_draw(event) {
if (Number(this.lotteryNum) <= 0) {
return this.$util.Tips({
title: this.$t(`剩余抽奖次数为0`)
});
} else if (this.lotteryBtn) {
this.lotteryBtn = false
} else {
return
}
let index = event.currentTarget.dataset.index;
let that = this;
if (index == 8) {
// 点击抽奖之后知道获奖位置,修改父组件中lottery_draw_param的值
this.$emit('get_winingIndex', function(res) {
let lottery_draw_param = res;
let win = new LotteryDraw({
domData: that.prizeData,
...lottery_draw_param
},
function(index, count) {
that.current_index = index;
if (lottery_draw_param.winingIndex == index && lottery_draw_param.totalCount ==
count) {
that.lotteryBtn = true
that.$emit('luck_draw_finish', that.prizeData[index])
}
}
);
});
}
}
}
};
</script>
<style scoped lang="scss">
@import './css/grids_lottery.css';
.lottery-msg {
width: 100%;
height: 100%;
padding: 0 4rpx;
.name {}
}
.lottery-click {
width: 100%;
height: 100%;
}
</style>