174 lines
4.4 KiB
Vue
174 lines
4.4 KiB
Vue
<template>
|
|
<su-popup
|
|
:show="state.show"
|
|
type="bottom"
|
|
round="10"
|
|
:isMaskClick="false"
|
|
:backgroundImage="sheep.$url.static('/static/img/shop/commission/become-agent.png')"
|
|
@close="show = false"
|
|
backgroundColor="var(--ui-BG-Main)"
|
|
>
|
|
<view class="model-box ss-flex ss-row-center">
|
|
<view class="content">
|
|
<scroll-view
|
|
class="scroll-box"
|
|
scroll-y="true"
|
|
:scroll-with-animation="true"
|
|
:show-scrollbar="false"
|
|
>
|
|
<view v-if="errorData.type === 'goods'">
|
|
<view class="item-box ss-m-b-20" v-for="item in errorData.value" :key="item.id">
|
|
<s-goods-item :title="item.title" :img="item.image" :price="item.price[0]" priceColor="#E1212B" @tap="sheep.$router.go('/pages/goods/index', { id: item.id })">
|
|
<template #groupon>
|
|
<view class="item-box-subtitle">{{ item.subtitle }}</view>
|
|
</template>
|
|
</s-goods-item>
|
|
</view>
|
|
</view>
|
|
|
|
<s-goods-item
|
|
title="累计消费满"
|
|
price=""
|
|
:img="sheep.$url.static('/static/img/shop/commission/consume.png')"
|
|
v-else-if="errorData.type === 'consume'"
|
|
>
|
|
<template #groupon>
|
|
<view class="ss-flex">
|
|
<view class="progress-box ss-flex">
|
|
<view
|
|
class="progerss-active"
|
|
:style="{
|
|
width: state.percent < 10 ? '10%' : state.percent + '%',
|
|
}"
|
|
></view>
|
|
</view>
|
|
<view class="progress-title ss-m-l-10">{{ errorData.value }}元</view>
|
|
</view>
|
|
<view class="progress-title ss-m-t-20">{{ userInfo.total_consume }}元</view>
|
|
</template>
|
|
</s-goods-item>
|
|
</scroll-view>
|
|
<view class="content-des" v-if="errorData.type === 'goods'"
|
|
>* 购买指定商品即可成为分销商</view
|
|
>
|
|
<view class="content-des" v-else-if="errorData.type === 'consume'"
|
|
>* 满足累计消费即可成为分销商</view
|
|
>
|
|
</view>
|
|
<button class="ss-reset-button go-btn ui-BG-Main-Gradient" @tap="sheep.$router.back()">
|
|
返回
|
|
</button>
|
|
</view>
|
|
</su-popup>
|
|
</template>
|
|
<script setup>
|
|
import sheep from '@/sheep';
|
|
import { computed, reactive, watch } from 'vue';
|
|
import { onLoad } from '@dcloudio/uni-app';
|
|
|
|
const props = defineProps({
|
|
error: {
|
|
type: Number,
|
|
default: 0,
|
|
},
|
|
errorData: {
|
|
type: Object,
|
|
default() {},
|
|
},
|
|
});
|
|
|
|
const userInfo = computed(() => sheep.$store('user').userInfo);
|
|
|
|
const state = reactive({
|
|
percent: computed(() => {
|
|
if (props.errorData.type !== 'consume') {
|
|
return 0;
|
|
}
|
|
let percent = (userInfo.value.total_consume / props.errorData.value) * 100;
|
|
return parseInt(percent);
|
|
}),
|
|
show: false,
|
|
money: '',
|
|
});
|
|
|
|
watch(
|
|
() => props.error,
|
|
(error) => {
|
|
if (error == 100) {
|
|
state.show = true;
|
|
}
|
|
},
|
|
);
|
|
</script>
|
|
<style lang="scss" scoped>
|
|
:deep() {
|
|
.ss-goods-item-warp {
|
|
background-color: #f8f8f8 !important;
|
|
}
|
|
}
|
|
|
|
.progress-title {
|
|
font-size: 20rpx;
|
|
font-weight: 500;
|
|
color: #666666;
|
|
}
|
|
|
|
.progress-box {
|
|
flex: 1;
|
|
height: 18rpx;
|
|
background: #e7e7e7;
|
|
border-radius: 9rpx;
|
|
}
|
|
|
|
.progerss-active {
|
|
height: 24rpx;
|
|
background: linear-gradient(90deg, #ff6000 0%, #fe832a 100%);
|
|
border-radius: 12rpx;
|
|
}
|
|
|
|
.model-box {
|
|
padding: 140rpx 40rpx 60rpx 40rpx;
|
|
height: 916rpx;
|
|
box-sizing: border-box;
|
|
position: relative;
|
|
|
|
.content {
|
|
height: 720rpx;
|
|
width: 612rpx;
|
|
padding-top: 30rpx;
|
|
// background-color: #fff;
|
|
box-sizing: border-box;
|
|
|
|
.content-des {
|
|
margin-top: 20rpx;
|
|
font-size: 24rpx;
|
|
font-weight: 500;
|
|
color: #999999;
|
|
text-align: center;
|
|
}
|
|
}
|
|
|
|
.scroll-box {
|
|
height: 620rpx;
|
|
}
|
|
.item-box-subtitle {
|
|
font-size: 24rpx;
|
|
font-weight: 500;
|
|
color: #999999;
|
|
line-height: normal;
|
|
}
|
|
|
|
.go-btn {
|
|
width: 600rpx;
|
|
height: 70rpx;
|
|
position: absolute;
|
|
left: 50%;
|
|
transform: translateX(-50%);
|
|
bottom: 120rpx;
|
|
border-radius: 35rpx;
|
|
font-size: 28rpx;
|
|
font-weight: 500;
|
|
}
|
|
}
|
|
</style>
|