Files
tydata-webview-v2/src/views/AgentVipApply.vue

908 lines
42 KiB
Vue
Raw Normal View History

2025-09-27 17:41:14 +08:00
<template>
<div class="agent-VIP-apply w-full min-h-screen bg-gradient-to-b from-amber-50 via-amber-100 to-amber-50 pb-24">
<!-- 装饰元素 -->
<div
2025-10-24 17:08:42 +08:00
class="absolute top-0 right-0 w-32 h-32 bg-gradient-to-br from-amber-300 to-amber-500 rounded-bl-full opacity-20">
</div>
2025-09-27 17:41:14 +08:00
<div
2025-10-24 17:08:42 +08:00
class="absolute top-40 left-0 w-16 h-16 bg-gradient-to-tr from-amber-400 to-amber-600 rounded-tr-full opacity-20">
</div>
2025-09-27 17:41:14 +08:00
<div
2025-10-24 17:08:42 +08:00
class="absolute bottom-60 right-0 w-24 h-24 bg-gradient-to-bl from-amber-300 to-amber-500 rounded-tl-full opacity-20">
</div>
2025-09-27 17:41:14 +08:00
<!-- 顶部标题区域 -->
<div class="header relative pt-8 px-4 pb-6 text-center">
<div
2025-10-24 17:08:42 +08:00
class="animate-pulse absolute -top-2 left-1/2 -translate-x-1/2 w-24 h-1 bg-gradient-to-r from-amber-300 via-amber-500 to-amber-300 rounded-full">
</div>
2025-09-27 17:41:14 +08:00
<h1 class="text-3xl font-bold text-amber-800 mb-1">
{{ isVipOrSvip ? '代理会员续费' : 'VIP代理申请' }}
</h1>
<p class="text-sm text-amber-700 mt-2 max-w-xs mx-auto">
<template v-if="isVipOrSvip">
您的会员有效期至 {{ formatExpiryTime(ExpiryTime) }}续费后有效期至
{{ renewalExpiryTime }}
</template>
<template v-else>
平台为疯狂推广者定制的赚买计划助您收益<span class="text-red-500 font-bold">翻倍增升</span>
</template>
</p>
<!-- 装饰性金币图标 -->
<div class="absolute top-6 left-4 transform -rotate-12">
<div
2025-10-24 17:08:42 +08:00
class="w-8 h-8 bg-gradient-to-br from-yellow-300 to-yellow-500 rounded-full flex items-center justify-center shadow-lg">
2025-09-27 17:41:14 +08:00
<span class="text-white font-bold text-xs">¥</span>
</div>
</div>
<div class="absolute top-10 right-6 transform rotate-12">
<div
2025-10-24 17:08:42 +08:00
class="w-6 h-6 bg-gradient-to-br from-yellow-400 to-yellow-600 rounded-full flex items-center justify-center shadow-lg">
2025-09-27 17:41:14 +08:00
<span class="text-white font-bold text-xs">¥</span>
</div>
</div>
</div>
<!-- 选择代理类型 -->
<div class="card-container px-4 mb-8">
<div class="bg-white rounded-xl shadow-lg overflow-hidden border border-amber-100 transform transition-all">
<h2
2025-10-24 17:08:42 +08:00
class="bg-gradient-to-r from-amber-500 to-amber-600 text-white py-3 px-4 text-center font-bold relative overflow-hidden">
2025-09-27 17:41:14 +08:00
<span class="relative z-10">选择代理类型</span>
<div class="absolute inset-0 bg-amber-500 opacity-30">
<div
2025-10-24 17:08:42 +08:00
class="absolute top-0 left-0 w-full h-full bg-gradient-to-r from-transparent via-white to-transparent opacity-20 transform -skew-x-30 translate-x-full animate-shimmer">
</div>
2025-09-27 17:41:14 +08:00
</div>
</h2>
<div class="flex p-6 gap-4">
<div
class="flex-1 border-2 rounded-lg p-4 text-center cursor-pointer transition-all duration-300 relative transform hover:-translate-y-1"
:class="[
selectedType === 'vip'
? 'border-amber-500 bg-amber-50 shadow-md'
: 'border-gray-200 hover:border-amber-300',
2025-10-24 17:08:42 +08:00
]" @click="selectType('vip')">
2025-09-27 17:41:14 +08:00
<div class="text-xl font-bold text-amber-700">VIP代理</div>
<div class="text-amber-600 font-bold mt-1 text-lg">{{ vipConfig.price }}{{ vipConfig.priceUnit }}</div>
<div class="mt-2 text-gray-600 text-sm">标准VIP权益</div>
2025-10-24 17:08:42 +08:00
<div v-if="selectedType === 'vip'"
class="absolute -top-2 -right-2 w-6 h-6 bg-gradient-to-br from-amber-500 to-amber-600 rounded-full flex items-center justify-center shadow-md">
2025-09-27 17:41:14 +08:00
<van-icon name="success" color="#fff" size="14" />
</div>
</div>
<div
class="flex-1 border-2 rounded-lg p-4 text-center cursor-pointer transition-all duration-300 relative transform hover:-translate-y-1"
:class="[
selectedType === 'svip'
? 'border-amber-500 bg-amber-50 shadow-md'
: 'border-gray-200 hover:border-amber-300',
2025-10-24 17:08:42 +08:00
]" @click="selectType('svip')">
2025-09-27 17:41:14 +08:00
<div class="text-xl font-bold text-amber-700">SVIP代理</div>
<div class="text-amber-600 font-bold mt-1 text-lg">{{ vipConfig.svipPrice }}{{ vipConfig.priceUnit }}</div>
<div class="mt-2 text-gray-600 text-sm">超级VIP权益</div>
2025-10-24 17:08:42 +08:00
<div v-if="selectedType === 'svip'"
class="absolute -top-2 -right-2 w-6 h-6 bg-gradient-to-br from-amber-500 to-amber-600 rounded-full flex items-center justify-center shadow-md">
2025-09-27 17:41:14 +08:00
<van-icon name="success" color="#fff" size="14" />
</div>
</div>
</div>
</div>
</div>
<!-- 六大超值权益 -->
<div class="card-container px-4 mb-8">
<div class="bg-white rounded-xl shadow-lg overflow-hidden border border-amber-100">
<h2
2025-10-24 17:08:42 +08:00
class="bg-gradient-to-r from-amber-500 to-amber-600 text-white py-3 px-4 text-center font-bold relative overflow-hidden">
2025-09-27 17:41:14 +08:00
<span class="relative z-10">六大超值权益</span>
<div class="absolute inset-0 bg-amber-500 opacity-30">
<div
2025-10-24 17:08:42 +08:00
class="absolute top-0 left-0 w-full h-full bg-gradient-to-r from-transparent via-white to-transparent opacity-20 transform -skew-x-30 translate-x-full animate-shimmer">
</div>
2025-09-27 17:41:14 +08:00
</div>
</h2>
<div class="grid grid-cols-2 gap-4 p-4">
<!-- 权益1 -->
<div
2025-10-24 17:08:42 +08:00
class="bg-gradient-to-br from-amber-50 to-amber-100 rounded-lg p-3 border border-amber-200 transition-all duration-300 hover:shadow-md hover:border-amber-300">
2025-09-27 17:41:14 +08:00
<div class="text-amber-800 font-bold mb-2 flex items-center">
<span
2025-10-24 17:08:42 +08:00
class="w-6 h-6 bg-gradient-to-br from-amber-500 to-amber-600 rounded-full flex items-center justify-center text-white text-xs mr-2">1</span>
2025-09-27 17:41:14 +08:00
下级贡献收益
</div>
<p class="text-sm text-gray-600">
下级完全收益您来定涨多少赚多少一单最高收益<span class="text-red-500 font-bold">10</span>
</p>
</div>
<!-- 权益2 -->
<div
2025-10-24 17:08:42 +08:00
class="bg-gradient-to-br from-amber-50 to-amber-100 rounded-lg p-3 border border-amber-200 transition-all duration-300 hover:shadow-md hover:border-amber-300">
2025-09-27 17:41:14 +08:00
<div class="text-amber-800 font-bold mb-2 flex items-center">
<span
2025-10-24 17:08:42 +08:00
class="w-6 h-6 bg-gradient-to-br from-amber-500 to-amber-600 rounded-full flex items-center justify-center text-white text-xs mr-2">2</span>
2025-09-27 17:41:14 +08:00
下级提现收益
</div>
<p class="text-sm text-gray-600">
下级定价标准由您定超过标准部分收益更丰厚一单最高多赚<span class="text-red-500 font-bold">10</span>
</p>
</div>
<!-- 权益3 -->
<div
2025-10-24 17:08:42 +08:00
class="bg-gradient-to-br from-amber-50 to-amber-100 rounded-lg p-3 border border-amber-200 transition-all duration-300 hover:shadow-md hover:border-amber-300">
2025-09-27 17:41:14 +08:00
<div class="text-amber-800 font-bold mb-2 flex items-center">
<span
2025-10-24 17:08:42 +08:00
class="w-6 h-6 bg-gradient-to-br from-amber-500 to-amber-600 rounded-full flex items-center justify-center text-white text-xs mr-2">3</span>
2025-09-27 17:41:14 +08:00
转换高额奖励
</div>
<p class="text-sm text-gray-600">
下级成为VIPSVIP高额奖励立马发放<span class="text-red-500 font-bold">399</span>
</p>
</div>
<!-- 权益4 -->
<div
2025-10-24 17:08:42 +08:00
class="bg-gradient-to-br from-amber-50 to-amber-100 rounded-lg p-3 border border-amber-200 transition-all duration-300 hover:shadow-md hover:border-amber-300">
2025-09-27 17:41:14 +08:00
<div class="text-amber-800 font-bold mb-2 flex items-center">
<span
2025-10-24 17:08:42 +08:00
class="w-6 h-6 bg-gradient-to-br from-amber-500 to-amber-600 rounded-full flex items-center justify-center text-white text-xs mr-2">4</span>
2025-09-27 17:41:14 +08:00
下级提现奖励
</div>
<p class="text-sm text-gray-600">下级成为SVIP每次提现都奖励1%坐享被动收入</p>
</div>
<!-- 权益5 -->
<div
2025-10-24 17:08:42 +08:00
class="bg-gradient-to-br from-amber-50 to-amber-100 rounded-lg p-3 border border-amber-200 transition-all duration-300 hover:shadow-md hover:border-amber-300">
2025-09-27 17:41:14 +08:00
<div class="text-amber-800 font-bold mb-2 flex items-center">
<span
2025-10-24 17:08:42 +08:00
class="w-6 h-6 bg-gradient-to-br from-amber-500 to-amber-600 rounded-full flex items-center justify-center text-white text-xs mr-2">5</span>
2025-09-27 17:41:14 +08:00
月度现金奖励
</div>
<p class="text-sm text-gray-600">
下级每月活跃达100名额外奖励<span class="text-red-500 font-bold">50</span>新增15名活跃下级再得<span
2025-10-24 17:08:42 +08:00
class="text-red-500 font-bold">50</span>
2025-09-27 17:41:14 +08:00
</p>
</div>
<!-- 权益6 -->
<div
2025-10-24 17:08:42 +08:00
class="bg-gradient-to-br from-amber-50 to-amber-100 rounded-lg p-3 border border-amber-200 transition-all duration-300 hover:shadow-md hover:border-amber-300">
2025-09-27 17:41:14 +08:00
<div class="text-amber-800 font-bold mb-2 flex items-center">
<span
2025-10-24 17:08:42 +08:00
class="w-6 h-6 bg-gradient-to-br from-amber-500 to-amber-600 rounded-full flex items-center justify-center text-white text-xs mr-2">6</span>
2025-09-27 17:41:14 +08:00
平台专项扶持
</div>
<p class="text-sm text-gray-600">一对一专属客服服务为合作伙伴提供全方位成长赋能</p>
</div>
</div>
</div>
</div>
<!-- 权益对比表 -->
<div class="card-container px-4 mb-8" v-if="selectedType">
<div class="bg-white rounded-xl shadow-lg overflow-hidden border border-amber-100">
<h2
2025-10-24 17:08:42 +08:00
class="bg-gradient-to-r from-amber-500 to-amber-600 text-white py-3 px-4 text-center font-bold relative overflow-hidden">
2025-09-27 17:41:14 +08:00
<span class="relative z-10">{{ selectedType === 'vip' ? 'VIP' : 'SVIP' }}代理权益对比</span>
<div class="absolute inset-0 bg-amber-500 opacity-30">
<div
2025-10-24 17:08:42 +08:00
class="absolute top-0 left-0 w-full h-full bg-gradient-to-r from-transparent via-white to-transparent opacity-20 transform -skew-x-30 translate-x-full animate-shimmer">
</div>
2025-09-27 17:41:14 +08:00
</div>
</h2>
<div class="p-4 overflow-x-auto">
<table class="w-full border-collapse">
<thead>
<tr class="bg-gradient-to-r from-amber-100 to-amber-200">
<th class="border border-amber-200 p-2 text-left text-amber-800">权益项目</th>
<th class="border border-amber-200 p-2 text-center text-amber-800">普通代理</th>
2025-10-24 17:08:42 +08:00
<th class="border border-amber-200 p-2 text-center text-amber-800"
:class="{ 'bg-amber-200': selectedType === 'vip' }">
2025-09-27 17:41:14 +08:00
VIP代理
</th>
2025-10-24 17:08:42 +08:00
<th class="border border-amber-200 p-2 text-center text-amber-800"
:class="{ 'bg-amber-200': selectedType === 'svip' }">
2025-09-27 17:41:14 +08:00
SVIP代理
</th>
</tr>
</thead>
<tbody>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">会员权益</td>
<td class="border border-amber-200 p-2 text-center">普通代理<br />免费</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center font-bold" :class="{
'text-amber-700 bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.price }}{{ vipConfig.priceUnit }}
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center font-bold" :class="{
'text-amber-700 bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.svipPrice }}{{ vipConfig.priceUnit }}
</td>
</tr>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">下级贡献收益</td>
<td class="border border-amber-200 p-2 text-center">1/</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.vipCommission }}/
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.svipCommission }}/
</td>
</tr>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">自定义设置下级成本</td>
<td class="border border-amber-200 p-2 text-center"></td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
</td>
</tr>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">下级价格浮动收益</td>
<td class="border border-amber-200 p-2 text-center"></td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
最高{{ vipConfig.vipFloatingRate }}%
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
最高{{ vipConfig.svipFloatingRate }}%
</td>
</tr>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">下级提现奖励</td>
<td class="border border-amber-200 p-2 text-center"></td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.withdrawRatio }}%
</td>
</tr>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">下级活跃奖励</td>
<td class="border border-amber-200 p-2 text-center"></td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.monthlyRewardForTeam }}/
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.monthlyRewardForTeam }}/
</td>
</tr>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">新增活跃奖励</td>
<td class="border border-amber-200 p-2 text-center"></td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.monthlyRewardForNewTeam }}/
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.monthlyRewardForNewTeam }}/
</td>
</tr>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">下级转化奖励</td>
<td class="border border-amber-200 p-2 text-center"></td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.vipConversionBonus }}*10
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.svipConversionBonus }}*10
</td>
</tr>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">提现次数额度</td>
<td class="border border-amber-200 p-2 text-center">800/</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.vipWithdrawalLimit }}/
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.svipWithdrawalLimit }}/
</td>
</tr>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">提现次数</td>
<td class="border border-amber-200 p-2 text-center">1/</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
1/
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-bold bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
2/
</td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
<!-- 收益预估 -->
<div class="card-container px-4 mb-8" v-if="selectedType">
<div class="bg-white rounded-xl shadow-lg overflow-hidden border border-amber-100">
<h2
2025-10-24 17:08:42 +08:00
class="bg-gradient-to-r from-amber-500 to-amber-600 text-white py-3 px-4 text-center font-bold relative overflow-hidden">
2025-09-27 17:41:14 +08:00
<span class="relative z-10">收益预估对比</span>
<div class="absolute inset-0 bg-amber-500 opacity-30">
<div
2025-10-24 17:08:42 +08:00
class="absolute top-0 left-0 w-full h-full bg-gradient-to-r from-transparent via-white to-transparent opacity-20 transform -skew-x-30 translate-x-full animate-shimmer">
</div>
2025-09-27 17:41:14 +08:00
</div>
</h2>
<div class="p-4">
<!-- 顶部收益概览 -->
<div class="mb-6 rounded-lg overflow-hidden border border-amber-200">
<div class="bg-gradient-to-r from-amber-100 to-amber-200 py-2 px-4 text-center font-bold text-amber-800">
VIP与SVIP代理收益对比
</div>
<div class="grid grid-cols-2 divide-x divide-amber-200">
<div class="p-4 text-center" :class="{ 'bg-amber-50': selectedType === 'vip' }">
<div class="text-sm text-gray-600 mb-1">VIP月预计收益</div>
<div class="text-amber-600 font-bold text-xl">{{ revenueData.vipMonthly }}</div>
<div class="text-xs text-gray-500 mt-1">年收益{{ revenueData.vipYearly }}</div>
</div>
<div class="p-4 text-center" :class="{ 'bg-amber-50': selectedType === 'svip' }">
<div class="text-sm text-gray-600 mb-1">SVIP月预计收益</div>
<div class="text-red-500 font-bold text-xl">{{ revenueData.svipMonthly }}</div>
<div class="text-xs text-gray-500 mt-1">年收益{{ revenueData.svipYearly }}</div>
</div>
</div>
<div class="bg-gradient-to-r from-red-50 to-red-100 py-2 px-4 text-center text-red-600 font-medium">
选择SVIP相比VIP月增收益<span class="font-bold">{{ revenueData.monthlyDifference }}</span>
</div>
</div>
<!-- 详细收益表格 -->
<div class="overflow-x-auto">
<table class="w-full border-collapse">
<thead>
<tr class="bg-gradient-to-r from-amber-100 to-amber-200">
<th class="border border-amber-200 p-2 text-left text-amber-800">收益来源</th>
2025-10-24 17:08:42 +08:00
<th class="border border-amber-200 p-2 text-center text-amber-800 w-1/3"
:class="{ 'bg-amber-200': selectedType === 'vip' }">
2025-09-27 17:41:14 +08:00
VIP代理
</th>
2025-10-24 17:08:42 +08:00
<th class="border border-amber-200 p-2 text-center text-amber-800 w-1/3"
:class="{ 'bg-amber-200': selectedType === 'svip' }">
2025-09-27 17:41:14 +08:00
SVIP代理
</th>
</tr>
</thead>
<tbody>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">推广收益()</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-medium bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
300×50=15,000
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-medium bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
300×50=15,000
</td>
</tr>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">下级贡献收益()</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-medium bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
300×{{ vipConfig.vipCommission }}=360
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-medium bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
300×{{ vipConfig.svipCommission }}=450
</td>
</tr>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">下级价格浮动收益()</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-medium bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
100×100×{{ vipConfig.vipFloatingRate }}%=500
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-medium bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
200×100×{{ vipConfig.svipFloatingRate }}%=2,000
</td>
</tr>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">下级提现奖励()</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-medium bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
-
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-medium bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
{{ revenueData.withdrawReward }}
</td>
</tr>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">下级活跃奖励()</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-medium bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.monthlyRewardForTeam }}
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-medium bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.monthlyRewardForTeam }}
</td>
</tr>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">新增活跃奖励()</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-medium bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.monthlyRewardForNewTeam }}
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-medium bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.monthlyRewardForNewTeam }}
</td>
</tr>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">下级转化奖励()</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-medium bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.vipConversionBonus }}×2=598
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-medium bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
{{ vipConfig.svipConversionBonus }}×2=798
</td>
</tr>
<tr class="hover:bg-amber-50 transition-colors">
<td class="border border-amber-200 p-2 font-medium">额外业务收益()</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-medium bg-amber-50': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
约3,000
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-2 text-center" :class="{
'text-amber-700 font-medium bg-amber-50': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
约6,000
</td>
</tr>
<tr class="bg-gradient-to-r from-amber-50 to-amber-100 font-bold">
<td class="border border-amber-200 p-3">月计收益</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-3 text-center text-amber-700" :class="{
'bg-amber-50 border-amber-300': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
{{ revenueData.vipMonthly }}
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-3 text-center text-red-500" :class="{
'bg-amber-50 border-amber-300': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
{{ revenueData.svipMonthly }}
</td>
</tr>
<tr class="bg-gradient-to-r from-amber-50 to-amber-100 font-bold">
<td class="border border-amber-200 p-3">年计收益</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-3 text-center text-amber-700" :class="{
'bg-amber-50 border-amber-300': selectedType === 'vip',
}">
2025-09-27 17:41:14 +08:00
{{ revenueData.vipYearly }}
</td>
2025-10-24 17:08:42 +08:00
<td class="border border-amber-200 p-3 text-center text-red-500" :class="{
'bg-amber-50 border-amber-300': selectedType === 'svip',
}">
2025-09-27 17:41:14 +08:00
{{ revenueData.svipYearly }}
</td>
</tr>
</tbody>
</table>
</div>
<!-- 投资回报率 -->
<div class="mt-6 p-4 bg-gradient-to-r from-amber-50 to-amber-100 rounded-lg border border-amber-200">
<div class="text-center mb-3 font-bold text-amber-800">投资收益分析</div>
<div class="grid grid-cols-1 gap-4">
<div class="p-3 bg-white rounded-lg shadow-sm">
<div class="flex items-center justify-between">
<div class="flex-1 border-r border-amber-100 pr-3">
<div class="text-amber-700 font-medium text-center mb-1">VIP方案</div>
<div class="text-center">
<div class="text-amber-600 text-sm">投资{{ vipConfig.price }}</div>
<div class="text-gray-600 text-sm">月收益{{ revenueData.vipMonthly }}</div>
</div>
</div>
<div class="flex-1 pl-3">
<div class="text-red-500 font-medium text-center mb-1">SVIP方案</div>
<div class="text-center">
<div class="text-red-500 text-sm">投资{{ vipConfig.svipPrice }}</div>
<div class="text-gray-600 text-sm">月收益{{ revenueData.svipMonthly }}</div>
</div>
</div>
</div>
</div>
<!-- 升级收益对比 -->
<div class="p-3 bg-gradient-to-r from-red-50 to-amber-50 rounded-lg shadow-sm">
<div class="text-center font-medium text-red-700 mb-2">SVIP升级优势分析</div>
<div class="flex items-center justify-center gap-3">
<div class="text-center">
<div class="text-sm text-gray-600">额外投资</div>
<div class="text-red-600 font-bold">{{ revenueData.priceDifference }}</div>
</div>
<div
2025-10-24 17:08:42 +08:00
class="bg-red-500 flex-shrink-0 text-white rounded-full w-6 h-6 flex items-center justify-center">
2025-09-27 17:41:14 +08:00
<div class="transform -translate-y-px"></div>
</div>
<div class="text-center">
<div class="text-sm text-gray-600">每月额外收益</div>
<div class="text-red-600 font-bold">{{ revenueData.monthlyDifference }}</div>
</div>
<div
2025-10-24 17:08:42 +08:00
class="bg-red-500 flex-shrink-0 text-white rounded-full w-6 h-6 flex items-center justify-center">
2025-09-27 17:41:14 +08:00
<span class="transform -translate-y-px"></span>
</div>
<div class="text-center">
<div class="text-sm text-gray-600">投资回收时间</div>
<div class="text-red-600 font-bold">{{ revenueData.recoverDays }}</div>
</div>
</div>
<div class="text-center text-red-500 font-medium mt-3">
2025-10-24 17:08:42 +08:00
额外投资{{ revenueData.priceDifference }}<span class="text-red-600 font-bold">年多赚{{
revenueData.yearlyDifference }}</span>
2025-09-27 17:41:14 +08:00
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<!-- 申请按钮固定在底部 -->
<div
2025-10-24 17:08:42 +08:00
class="fixed bottom-0 left-0 right-0 px-4 py-3 bg-gradient-to-t from-amber-100 to-transparent backdrop-blur-sm z-30">
2025-09-27 17:41:14 +08:00
<div class="flex flex-col gap-2">
<button :class="buttonClass" @click="applyVip" :disabled="!canPerformAction">
<span class="relative z-10">{{ buttonText }}</span>
<div
2025-10-24 17:08:42 +08:00
class="absolute top-0 left-0 w-full h-full bg-gradient-to-r from-transparent via-white to-transparent opacity-20 transform -skew-x-30 translate-x-full animate-shimmer">
</div>
2025-09-27 17:41:14 +08:00
</button>
<button
class="w-full py-3 rounded-lg font-medium text-amber-700 border border-amber-400 bg-white shadow-md active:bg-amber-50 transform transition-transform active:scale-98"
2025-10-24 17:08:42 +08:00
@click="contactService">
2025-09-27 17:41:14 +08:00
<div class="flex items-center justify-center">
<van-icon name="service-o" class="mr-1" />
<span>联系客服咨询</span>
</div>
</button>
<!-- 最终解释权声明 -->
<div class="text-center text-xs text-gray-400 py-1">最终解释权归海南省学宇思网络科技有限公司所有</div>
</div>
</div>
</div>
<Payment v-model="showPayment" :data="payData" :id="payID" type="agent_vip" @close="showPayment = false" />
</template>
<script setup>
import { ref, onMounted, reactive, computed } from 'vue'
import { showToast } from 'vant'
import { useAgentStore } from '@/stores/agentStore'
import { storeToRefs } from 'pinia'
// 获取代理状态
const agentStore = useAgentStore()
const { level, ExpiryTime } = storeToRefs(agentStore)
// 计算是否已经是VIP或SVIP
const isVipOrSvip = computed(() => ['VIP', 'SVIP'].includes(level.value))
const isVip = computed(() => level.value === 'VIP')
const isSvip = computed(() => level.value === 'SVIP')
// 计算续费后的到期时间
const renewalExpiryTime = computed(() => {
if (!ExpiryTime.value) return '未知'
// 从格式化字符串中提取日期部分
const dateStr = ExpiryTime.value.split(' ')[0] // 假设格式是 "YYYY-MM-DD HH:MM:SS"
const [year, month, day] = dateStr.split('-').map(num => parseInt(num))
// 创建日期对象并加一年
const expiryDate = new Date(year, month - 1, day) // 月份从0开始所以要-1
expiryDate.setFullYear(expiryDate.getFullYear() + 1)
// 返回格式化的日期字符串
return `${expiryDate.getFullYear()}-${String(expiryDate.getMonth() + 1).padStart(2, '0')}-${String(expiryDate.getDate()).padStart(2, '0')}`
})
// 按钮文字 - 根据当前状态显示不同文案
const buttonText = computed(() => {
if (!isVipOrSvip.value) return '立即开通' // 非会员状态
if (selectedType.value === 'vip') {
if (isVip.value) return '续费VIP代理' // VIP续费VIP
return '降级不可用' // SVIP不能降级到VIP
} else {
if (isSvip.value) return '续费SVIP代理' // SVIP续费SVIP
return '升级SVIP代理' // VIP升级SVIP
}
})
// 是否可以操作按钮
const canPerformAction = computed(() => {
// 非会员可以开通任何会员
if (!isVipOrSvip.value) return true
// VIP不能降级到普通会员
if (isVip.value && selectedType.value === '') return false
// SVIP不能降级到VIP
if (isSvip.value && selectedType.value === 'vip') return false
return true
})
// 计算按钮类名
const buttonClass = computed(() => {
const baseClass =
'w-full py-4 rounded-lg font-bold text-lg shadow-lg transform transition-transform active:scale-98 relative overflow-hidden'
if (!canPerformAction.value) {
return `${baseClass} bg-gray-400 text-white cursor-not-allowed`
}
if (isVip.value && selectedType.value === 'svip') {
return `${baseClass} bg-gradient-to-r from-purple-500 to-indigo-600 text-white`
}
return `${baseClass} bg-gradient-to-r from-amber-500 to-amber-600 active:from-amber-600 active:to-amber-700 text-white`
})
// VIP价格配置
2025-10-24 17:08:42 +08:00
const vipConfig = reactive({})
2025-09-27 17:41:14 +08:00
// 计算得出的收益数据
const revenueData = computed(() => {
const baseOrders = 300 // 基础订单数
const pricePerOrder = 50 // 每单价格
const baseRevenue = baseOrders * pricePerOrder // 基础推广收益
const vipCommissionRevenue = baseOrders * vipConfig.vipCommission // VIP下级贡献收益
const svipCommissionRevenue = baseOrders * vipConfig.svipCommission // SVIP下级贡献收益
const vipFloatingRevenue = 100 * 100 * (vipConfig.vipFloatingRate / 100) // VIP浮动收益
const svipFloatingRevenue = 200 * 100 * (vipConfig.svipFloatingRate / 100) // SVIP浮动收益
const vipConversionRevenue = vipConfig.vipConversionBonus * 2 // VIP转化奖励
const svipConversionRevenue = vipConfig.svipConversionBonus * 2 // SVIP转化奖励
const vipExtraRevenue = 3000 // VIP额外收益估计
const svipExtraRevenue = 6000 // SVIP额外收益估计
// 平级提现奖励(只有SVIP才有)
const withdrawReward = 20000 * (vipConfig.withdrawRatio / 100)
// 计算月总收益
const vipMonthlyTotal =
baseRevenue +
vipCommissionRevenue +
vipFloatingRevenue +
vipConfig.monthlyRewardForTeam +
vipConfig.monthlyRewardForNewTeam +
vipConversionRevenue +
vipExtraRevenue
const svipMonthlyTotal =
baseRevenue +
svipCommissionRevenue +
svipFloatingRevenue +
withdrawReward +
vipConfig.monthlyRewardForTeam +
vipConfig.monthlyRewardForNewTeam +
svipConversionRevenue +
svipExtraRevenue
// 计算VIP和SVIP之间的差额
const monthlyDifference = svipMonthlyTotal - vipMonthlyTotal
const priceDifference = vipConfig.svipPrice - vipConfig.price
return {
vipMonthly: Math.round(vipMonthlyTotal),
svipMonthly: Math.round(svipMonthlyTotal),
vipYearly: Math.round(vipMonthlyTotal * 12),
svipYearly: Math.round(svipMonthlyTotal * 12),
monthlyDifference: Math.round(monthlyDifference),
yearlyDifference: Math.round(monthlyDifference * 12),
vipRate: Math.round(vipMonthlyTotal / vipConfig.price),
svipRate: Math.round(svipMonthlyTotal / vipConfig.svipPrice),
priceDifference,
recoverDays: Math.ceil(priceDifference / (monthlyDifference / 30)),
withdrawReward,
}
})
2025-10-24 17:08:42 +08:00
// 加载价格配置
2025-09-27 17:41:14 +08:00
onMounted(async () => {
document.documentElement.style.scrollBehavior = 'smooth'
2025-10-24 17:08:42 +08:00
// 从API获取会员配置信息
2025-09-27 17:41:14 +08:00
try {
2025-10-24 17:08:42 +08:00
const { data, error } = await useApiFetch('/agent/membership/info').get().json()
if (data.value && !error.value && data.value.code === 200) {
const configData = data.value.data
// 更新VIP配置
if (configData.vip_config) {
const vipData = configData.vip_config
vipConfig.price = vipData.price
vipConfig.vipCommission = vipData.report_commission // 直接显示,就是几元/单
vipConfig.vipFloatingRate = vipData.price_ratio * 100 // 转换为百分比
vipConfig.monthlyRewardForTeam = vipData.lower_activity_reward
vipConfig.monthlyRewardForNewTeam = vipData.new_activity_reward
vipConfig.vipConversionBonus = vipData.lower_convert_vip_reward
vipConfig.vipWithdrawalLimit = vipData.exemption_amount
}
// 更新SVIP配置
if (configData.svip_config) {
const svipData = configData.svip_config
vipConfig.svipPrice = svipData.price
vipConfig.svipCommission = svipData.report_commission // 直接显示,就是几元/单
vipConfig.svipFloatingRate = svipData.price_ratio * 100 // 转换为百分比
vipConfig.withdrawRatio = svipData.lower_withdraw_reward_ratio * 100 // 转换为百分比
vipConfig.monthlyRewardForTeam = svipData.lower_activity_reward
vipConfig.monthlyRewardForNewTeam = svipData.new_activity_reward
vipConfig.svipConversionBonus = svipData.lower_convert_svip_reward
vipConfig.svipWithdrawalLimit = svipData.exemption_amount
}
console.log('会员配置信息加载成功', configData)
} else {
console.error('获取会员配置信息失败', data.value?.msg || '未知错误')
}
2025-09-27 17:41:14 +08:00
} catch (error) {
2025-10-24 17:08:42 +08:00
console.error('加载会员配置信息失败', error)
2025-09-27 17:41:14 +08:00
}
})
const selectedType = ref('vip') // 默认选择VIP
const showPayment = ref(false)
const payData = ref({
product_name: `${selectedType.value.toUpperCase()}代理`,
sell_price: vipConfig.price,
})
const payID = ref('')
// 选择代理类型
function selectType(type) {
selectedType.value = type
// 更新payData中的价格和产品名称
payData.value = {
product_name: `${type === 'vip' ? 'VIP' : 'SVIP'}代理`,
sell_price: type === 'vip' ? vipConfig.price : vipConfig.svipPrice,
}
}
// 申请VIP或SVIP
async function applyVip() {
// 如果是VIP想升级到SVIP提示联系客服
if (isVip.value && selectedType.value === 'svip') {
contactService()
return
}
// 如果是SVIP要降级到VIP提示不能降级
if (isSvip.value && selectedType.value === 'vip') {
showToast('SVIP会员不能降级到VIP会员')
return
}
const { data, error } = await useApiFetch('/agent/membership/activate')
.post({
type: selectedType.value.toUpperCase(),
})
.json()
if (data.value && !error.value) {
if (data.value.code === 200) {
if (data.value.data.id) {
payID.value = data.value.data.id
showPayment.value = true
}
}
}
}
// 联系客服
function contactService() {
// 跳转到客服页面
2025-10-24 14:39:32 +08:00
window.location.href = 'https://work.weixin.qq.com/kfid/kfc8a32720024833f57'
2025-09-27 17:41:14 +08:00
}
function formatExpiryTime(expiryTimeStr) {
if (!expiryTimeStr) return '未知'
// 从格式化字符串中提取日期部分
return expiryTimeStr.split(' ')[0] // 假设格式是 "YYYY-MM-DD HH:MM:SS"
}
</script>
<style scoped>
.agent-VIP-apply {
font-family:
system-ui,
-apple-system,
BlinkMacSystemFont,
'Segoe UI',
Roboto,
sans-serif;
}
@keyframes shimmer {
0% {
transform: translateX(-100%) skewX(-30deg);
}
100% {
transform: translateX(200%) skewX(-30deg);
}
}
.animate-shimmer {
animation: shimmer 3s infinite;
}
.active\:scale-98:active {
transform: scale(0.98);
}
</style>