This commit is contained in:
yangtao 2024-04-10 14:26:10 +08:00
parent d7c6076353
commit 7f02ae77ee
5 changed files with 119 additions and 80 deletions

View File

@ -6,7 +6,7 @@
</view> </view>
<view class="lucky-draw"> <view class="lucky-draw">
<view class="title"> <view class="title">
恭喜你获得 {{wheel}} 次盲盒抽奖机会
</view> </view>
<view class="blind-box"> <view class="blind-box">
<image src="@/static/images/mh-item.png" @click="openBlindBox(index)" :class="actionIndex==index?'action':''" class="box-item" v-for="(item,index) in 6"> <image src="@/static/images/mh-item.png" @click="openBlindBox(index)" :class="actionIndex==index?'action':''" class="box-item" v-for="(item,index) in 6">
@ -17,12 +17,21 @@
</view> </view>
<view class="coupon_popups" v-if="popShow"> <view class="coupon_popups" v-if="popShow">
<view class="bg2"></view> <view class="bg2"></view>
<view class="con" > <view class="con" v-if="blind">
<view class="content"> <view class="content">
<image :src="drawInfo.img" mode=""></image> <image :src="drawInfo.img" mode=""></image>
<view class="text-black">恭喜您获得</view> <view class="text-black">恭喜您获得</view>
<view class="text-red">{{drawInfo.text}}</view> <view class="text-red">{{drawInfo.text}}</view>
<view class="btn" @click="popShow = false">开心收下</view> <view class="btn" @click="closePop()">开心收下</view>
</view>
</view>
<view class="con" v-else>
<view class="content">
<image src="@/static/images/notBlind.png" style="width: 80px;height: 80px;" mode=""></image>
<view class="text-black">很遗憾,差一点就中奖了</view>
<view class="text-red">期待您下次再来</view>
<view class="btn" @click="closePop()">我知道了</view>
</view> </view>
</view> </view>
@ -38,9 +47,10 @@
data() { data() {
return { return {
wheel:0, wheel:0,
actionIndex:'', actionIndex:-1,
popShow:false, popShow:false,
blindShow:true, blindShow:true,
blind:true,
defaultConfig: { defaultConfig: {
gutter: '5px', gutter: '5px',
speed: 60, speed: 60,
@ -61,11 +71,24 @@
methods: { methods: {
openBlindBox(val){ openBlindBox(val){
this.actionIndex=val; this.actionIndex=val;
if(val/2){
setTimeout(()=>{
this.blind=false;
this.popShow=true; this.popShow=true;
},800)
}else{
setTimeout(()=>{
this.popShow=true;
},800)
}
}, },
init(){ init(){
}, },
closePop(){ closePop(){
this.popShow=false;
this.blindShow=false; this.blindShow=false;
} }
} }
@ -77,33 +100,29 @@
from { from {
transform: scale3d(1, 1, 1); transform: scale3d(1, 1, 1);
} }
20%,
53%, 30% {
to { transform: scale3d(1.05, 0.85, 1);
animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
transform: translate3d(0, 0, 0) scale3d(1, 1, 1);
} }
40%, 40% {
43% { transform: scale3d(0.85, 1.05, 1);
animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
transform: translate3d(0, -15px, 0) scaleY(1.1);
} }
50% { 50% {
transform: scale3d(1.1, 1.1, 1.1); transform: scale3d(1.10, 0.85, 1);
}
70% {
animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
transform: translate3d(0, -5px, 0) scaleY(1.05);
} }
80% { 65% {
transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); transform: scale3d(0.95, 1.05, 1);
transform: translate3d(0, 0, 0) scaleY(0.95);
} }
90% { 75% {
transform: translate3d(0, -4px, 0) scaleY(1.02); transform: scale3d(1.05, 0.95, 1);
}
to {
transform: scale3d(1, 1, 1);
} }
} }
@ -111,7 +130,7 @@
width: 100%; width: 100%;
height: 100vh; height: 100vh;
position: fixed; position: fixed;
background-color: rgba(0,0,0,.5); background-color: rgba(0,0,0,.9);
z-index: 10000; z-index: 10000;
top: 0; top: 0;
display: flex; display: flex;
@ -121,7 +140,7 @@
z-index: 999; z-index: 999;
position: fixed; position: fixed;
left: 0; left: 0;
top: 0; top: 120rpx;
width: 100%; width: 100%;
height: 100%; height: 100%;
text-align: center; text-align: center;
@ -177,8 +196,7 @@
line-height: 68rpx; line-height: 68rpx;
padding: 4rpx 0; padding: 4rpx 0;
border-radius: 60rpx; border-radius: 60rpx;
background: linear-gradient(136deg, #D753FC 0%, #FC276C 53%, #FC3E8F 100%); background: linear-gradient(136deg, #FFDF6A 0%, #EF521F 100%);
} }
} }
@ -222,7 +240,7 @@
} }
} }
.top{ .top{
height: 330rpx; height:180rpx;
} }
.lucky-draw{ .lucky-draw{
display: flex; display: flex;
@ -233,7 +251,7 @@
position: relative; position: relative;
bottom: 20rpx; bottom: 20rpx;
width:80%; width:80%;
height: 50rpx; height: 120rpx;
font-family: PingFang SC; font-family: PingFang SC;
font-weight: 400; font-weight: 400;
font-size: 32rpx; font-size: 32rpx;
@ -241,7 +259,8 @@
margin: 20rpx 0; margin: 20rpx 0;
line-height: 54rpx; line-height: 54rpx;
text-align: center; text-align: center;
background: url('@/static/images/font-bg.png') no-repeat 100%; background: url('@/static/images/mh-title.png') no-repeat;
background-size: 100% 100%;
background-position: center; background-position: center;
} }
.blind-box{ .blind-box{
@ -261,8 +280,12 @@
height: auto; height: auto;
} }
.action{ .action{
animation:bounce 2s 1; background: url('@/static/images/mh-item-bg.png');
background-repeat: no-repeat;
background-size: 100% 100%;
animation:bounce .8s 1;
animation-direction: normal; animation-direction: normal;
} }
} }

View File

@ -20,23 +20,22 @@
<view class="content"> <view class="content">
<image :src="drawInfo.img" mode=""></image> <image :src="drawInfo.img" mode=""></image>
<view class="text-black">恭喜您获得</view> <view class="text-black">恭喜您获得</view>
<view class="text-red">{{drawInfo.text}}</view> <view class="text-red">{{drawInfo.text}}积分</view>
<view class="btn" @click="confirm">开心收下</view> <view class="btn" @click="confirm">开心收下</view>
</view> </view>
<view class='iconfont icon-guanbi3' @click="popShow = false"></view> <view class='iconfont icon-guanbi3' @click="popShow = false"></view>
</view> </view>
</view> </view>
<blind-box v-if="blindShow"></blind-box>
</view> </view>
</template> </template>
<script> <script>
import {getWhellNumber,getWhellConfig,getWhellAction,getWhellList} from '@/api/user.js'
import LuckyWheel from 'uni-luck-draw/lucky-wheel'; import {getWhellNumber,getWhellConfig,getWhellAction,getWhellList,setSignIntegral} from '@/api/user.js';
import blindBox from '@/components/blindBox/blindBox.vue'; import blindBox from '@/components/blindBox/blindBox.vue';
export default { export default {
components: { components: {
LuckyWheel,
blindBox blindBox
}, },
data() { data() {
@ -44,7 +43,7 @@
wheel:0, wheel:0,
popShow:false, popShow:false,
gifShow:false, gifShow:false,
blindShow:false, integral:'',
list:[], list:[],
drawInfo:{ drawInfo:{
img:'', img:'',
@ -58,14 +57,21 @@
methods: { methods: {
confirm(){ confirm(){
this.popShow = false; this.popShow = false;
this.blindShow=true; this.close();
}, },
openBox(){ async openBox(){
await setSignIntegral().then(res=>{
this.drawInfo.text = res.data.integral;
this.gifShow=true; this.gifShow=true;
setTimeout(()=>{ setTimeout(()=>{
this.gifShow=false; this.gifShow=false;
this.popShow=true; this.popShow=true;
},1500) },1500)
}).catch(err=>{
this.close();
return this.$util.Tips({title:err})
});
}, },
close(){ close(){
this.$emit('closeTreasureBox') this.$emit('closeTreasureBox')

View File

@ -240,12 +240,6 @@
"navigationBarTitleText": "签到记录" "navigationBarTitleText": "签到记录"
} }
}, },
{
"path": "user_luckyDraw/index",
"style": {
"navigationBarTitleText": "幸运抽奖"
}
},
{ {
"path": "user_money/index", "path": "user_money/index",
"style": { "style": {

View File

@ -52,6 +52,7 @@
</view> </view>
</view> </view>
<treasureBox v-if="treasureShow" @closeTreasureBox="closeBox"></treasureBox> <treasureBox v-if="treasureShow" @closeTreasureBox="closeBox"></treasureBox>
<blindBox v-if="blindShow"></blindBox>
<view class='signTip acea-row row-center-wrapper' :class='active==true?"on":""'> <view class='signTip acea-row row-center-wrapper' :class='active==true?"on":""'>
<view class='signTipLight loadingpic'></view> <view class='signTipLight loadingpic'></view>
<view class='signTipCon' :style="'background-image: url('+domain+'/static/diy/signSuccess'+keyColor+'.png)'"> <view class='signTipCon' :style="'background-image: url('+domain+'/static/diy/signSuccess'+keyColor+'.png)'">
@ -72,8 +73,9 @@
import { HTTP_REQUEST_URL } from '@/config/app'; import { HTTP_REQUEST_URL } from '@/config/app';
import { toLogin } from '@/libs/login.js'; import { toLogin } from '@/libs/login.js';
import treasureBox from '@/components/treasureBox/index.vue'; import treasureBox from '@/components/treasureBox/index.vue';
import blindBox from '@/components/blindBox/blindBox.vue';
export default { export default {
components: {treasureBox}, components: {treasureBox,blindBox},
data() { data() {
return { return {
domain: HTTP_REQUEST_URL, domain: HTTP_REQUEST_URL,
@ -89,6 +91,7 @@
is_sign: false, // is_sign: false, //
disabled: false, disabled: false,
treasureShow:false, treasureShow:false,
blindShow:false,
}; };
}, },
computed: mapGetters(['isLogin','viewColor','keyColor']), computed: mapGetters(['isLogin','viewColor','keyColor']),
@ -100,6 +103,14 @@
toLogin() toLogin()
} }
}, },
onShow() {
if(this.isLogin){
this.getUserInfo();
this.getSignList();
}else{
toLogin()
}
},
methods: { methods: {
closeBox(){ closeBox(){
this.treasureShow=false; this.treasureShow=false;
@ -120,10 +131,11 @@
getUserInfo:function(){ getUserInfo:function(){
let that=this; let that=this;
getSignUser().then(res=>{ getSignUser().then(res=>{
res.data.sign_num=6;
res.data.integral = parseInt(res.data.integral); res.data.integral = parseInt(res.data.integral);
let sum_sgin_day = res.data.count; let sum_sgin_day = res.data.count;
that.$set(that,'signConfig',res.data.title); that.$set(that,'signConfig',res.data.title);
// that.$set(that,'is_sign',res.data.is_sign); that.$set(that,'is_sign',res.data.is_sign);
that.$set(that,'userInfo',res.data.userInfo); that.$set(that,'userInfo',res.data.userInfo);
that.signCount = that.PrefixInteger(sum_sgin_day, 4); that.signCount = that.PrefixInteger(sum_sgin_day, 4);
that.sign_index = res.data.sign_num; that.sign_index = res.data.sign_num;
@ -168,19 +180,23 @@
let that = this, sum_sgin_day = that.signConfig.sign_num; let that = this, sum_sgin_day = that.signConfig.sign_num;
if (that.userInfo.is_day_sgin) return this.$util.Tips({title:'您今日已签到!'}); if (that.userInfo.is_day_sgin) return this.$util.Tips({title:'您今日已签到!'});
that.disabled = true; that.disabled = true;
setSignIntegral().then(res=>{ if(!that.userInfo.is_day_sgin&&that.sign_index==6){
that.blindShow=true;
}else{
that.treasureShow=true; that.treasureShow=true;
// that.active = true; }
that.integral = res.data.integral; // setSignIntegral().then(res=>{
that.sign_index = (that.sign_index + 1) > that.signConfig.title.length ? 1 : that.sign_index + 1; // // that.active = true;
that.signCount = that.PrefixInteger(sum_sgin_day + 1, 4); // that.integral = res.data.integral;
that.$set(that.userInfo,'is_sgin',true); // that.sign_index = (that.sign_index + 1) > that.signConfig.title.length ? 1 : that.sign_index + 1;
that.$set(that.userInfo,'integral',that.$util.$h.Add(that.userInfo.integral, res.data.integral)); // that.signCount = that.PrefixInteger(sum_sgin_day + 1, 4);
// that.$set(that.userInfo,'is_sgin',true);
// that.$set(that.userInfo,'integral',that.$util.$h.Add(that.userInfo.integral, res.data.integral));
}).catch(err=>{ // }).catch(err=>{
that.disabled = false; // that.disabled = false;
return this.$util.Tips({title:err}) // return this.$util.Tips({title:err})
}); // });
}, },
/** /**
* 关闭签到提示 * 关闭签到提示
@ -211,7 +227,7 @@
.sign .wrapper .list .item .num{font-size:30rpx;color:#999;} .sign .wrapper .list .item .num{font-size:30rpx;color:#999;}
.sign .wrapper .list .item .venus.venusSelect+.num{color:#ff9000;} .sign .wrapper .list .item .venus.venusSelect+.num{color:#ff9000;}
.sign .wrapper .list .item .venus{background-image:url('');background-repeat:no-repeat;background-size:100% 100%;width:56rpx;height:56rpx;margin:10rpx auto;} .sign .wrapper .list .item .venus{background-image:url('');background-repeat:no-repeat;background-size:100% 100%;width:56rpx;height:56rpx;margin:10rpx auto;}
.sign .wrapper .list .item .venus.reward{background-image:url('');width:75rpx;height:56rpx;} .sign .wrapper .list .item .venus.reward{background-image:url('https://plus.hwms.shop/uploads/def/20240409/4f4ded3abbffea25b83b3aed8a1846b3.png');width:56rpx;height:56rpx;}
.sign .wrapper .list .item .venus.venusSelect{background-image:url('');} .sign .wrapper .list .item .venus.venusSelect{background-image:url('');}
.sign .wrapper .but{width:400rpx;height:76rpx;font-size:30rpx;line-height:76rpx;color:#fff;border-radius:50rpx;text-align:center;margin:0 auto;background-color: var(--view-theme);} .sign .wrapper .but{width:400rpx;height:76rpx;font-size:30rpx;line-height:76rpx;color:#fff;border-radius:50rpx;text-align:center;margin:0 auto;background-color: var(--view-theme);}
.sign .wrapper .but.disabled{pointer-events: none} .sign .wrapper .but.disabled{pointer-events: none}

BIN
static/images/notBlind.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 71 KiB