This commit is contained in:
parent
d7c6076353
commit
7f02ae77ee
|
@ -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,
|
||||||
|
@ -60,12 +70,25 @@
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
openBlindBox(val){
|
openBlindBox(val){
|
||||||
this.actionIndex=val;
|
this.actionIndex=val;
|
||||||
this.popShow=true;
|
if(val/2){
|
||||||
|
setTimeout(()=>{
|
||||||
|
this.blind=false;
|
||||||
|
this.popShow=true;
|
||||||
|
},800)
|
||||||
|
|
||||||
|
}else{
|
||||||
|
setTimeout(()=>{
|
||||||
|
this.popShow=true;
|
||||||
|
},800)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
},
|
},
|
||||||
init(){
|
init(){
|
||||||
},
|
},
|
||||||
closePop(){
|
closePop(){
|
||||||
|
this.popShow=false;
|
||||||
this.blindShow=false;
|
this.blindShow=false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -74,44 +97,40 @@
|
||||||
|
|
||||||
<style lang="less" scoped>
|
<style lang="less" scoped>
|
||||||
@keyframes bounce {
|
@keyframes bounce {
|
||||||
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% {
|
||||||
|
transform: scale3d(0.85, 1.05, 1);
|
||||||
40%,
|
}
|
||||||
43% {
|
|
||||||
animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
|
50% {
|
||||||
transform: translate3d(0, -15px, 0) scaleY(1.1);
|
transform: scale3d(1.10, 0.85, 1);
|
||||||
}
|
}
|
||||||
50% {
|
|
||||||
transform: scale3d(1.1, 1.1, 1.1);
|
65% {
|
||||||
}
|
transform: scale3d(0.95, 1.05, 1);
|
||||||
70% {
|
}
|
||||||
animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
|
|
||||||
transform: translate3d(0, -5px, 0) scaleY(1.05);
|
75% {
|
||||||
}
|
transform: scale3d(1.05, 0.95, 1);
|
||||||
|
}
|
||||||
80% {
|
|
||||||
transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
|
to {
|
||||||
transform: translate3d(0, 0, 0) scaleY(0.95);
|
transform: scale3d(1, 1, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
90% {
|
|
||||||
transform: translate3d(0, -4px, 0) scaleY(1.02);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.content {
|
.content {
|
||||||
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;
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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(){
|
||||||
this.gifShow=true;
|
await setSignIntegral().then(res=>{
|
||||||
setTimeout(()=>{
|
this.drawInfo.text = res.data.integral;
|
||||||
this.gifShow=false;
|
this.gifShow=true;
|
||||||
this.popShow=true;
|
setTimeout(()=>{
|
||||||
},1500)
|
this.gifShow=false;
|
||||||
|
this.popShow=true;
|
||||||
|
},1500)
|
||||||
|
}).catch(err=>{
|
||||||
|
this.close();
|
||||||
|
return this.$util.Tips({title:err})
|
||||||
|
});
|
||||||
|
|
||||||
},
|
},
|
||||||
close(){
|
close(){
|
||||||
this.$emit('closeTreasureBox')
|
this.$emit('closeTreasureBox')
|
||||||
|
|
|
@ -240,12 +240,6 @@
|
||||||
"navigationBarTitleText": "签到记录"
|
"navigationBarTitleText": "签到记录"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"path": "user_luckyDraw/index",
|
|
||||||
"style": {
|
|
||||||
"navigationBarTitleText": "幸运抽奖"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"path": "user_money/index",
|
"path": "user_money/index",
|
||||||
"style": {
|
"style": {
|
||||||
|
|
|
@ -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;
|
||||||
|
@ -167,20 +179,24 @@
|
||||||
goSign:function(e){
|
goSign:function(e){
|
||||||
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.treasureShow=true;
|
that.blindShow=true;
|
||||||
// that.active = true;
|
}else{
|
||||||
that.integral = res.data.integral;
|
that.treasureShow=true;
|
||||||
that.sign_index = (that.sign_index + 1) > that.signConfig.title.length ? 1 : that.sign_index + 1;
|
}
|
||||||
that.signCount = that.PrefixInteger(sum_sgin_day + 1, 4);
|
// setSignIntegral().then(res=>{
|
||||||
that.$set(that.userInfo,'is_sgin',true);
|
// // that.active = true;
|
||||||
that.$set(that.userInfo,'integral',that.$util.$h.Add(that.userInfo.integral, res.data.integral));
|
// that.integral = res.data.integral;
|
||||||
|
// that.sign_index = (that.sign_index + 1) > that.signConfig.title.length ? 1 : that.sign_index + 1;
|
||||||
|
// 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}
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 71 KiB |
Loading…
Reference in New Issue