fix(frontend): 修复无限制订阅的显示问题

This commit is contained in:
shaw
2025-12-31 20:46:54 +08:00
parent 3fd9bd4a80
commit 2c35f0276f
5 changed files with 134 additions and 91 deletions

View File

@@ -69,94 +69,108 @@
</span> </span>
</div> </div>
<!-- Progress bars --> <!-- Progress bars or Unlimited badge -->
<div class="space-y-1.5"> <div class="space-y-1.5">
<div v-if="subscription.group?.daily_limit_usd" class="flex items-center gap-2"> <!-- Unlimited subscription badge -->
<span class="w-8 flex-shrink-0 text-[10px] text-gray-500">{{ <div
t('subscriptionProgress.daily') v-if="isUnlimited(subscription)"
}}</span> class="flex items-center gap-2 rounded-lg bg-gradient-to-r from-emerald-50 to-teal-50 px-2.5 py-1.5 dark:from-emerald-900/20 dark:to-teal-900/20"
<div class="h-1.5 min-w-0 flex-1 rounded-full bg-gray-200 dark:bg-dark-600"> >
<div <span class="text-lg text-emerald-600 dark:text-emerald-400"></span>
class="h-1.5 rounded-full transition-all" <span class="text-xs font-medium text-emerald-700 dark:text-emerald-300">
:class=" {{ t('subscriptionProgress.unlimited') }}
getProgressBarClass(
subscription.daily_usage_usd,
subscription.group?.daily_limit_usd
)
"
:style="{
width: getProgressWidth(
subscription.daily_usage_usd,
subscription.group?.daily_limit_usd
)
}"
></div>
</div>
<span class="w-24 flex-shrink-0 text-right text-[10px] text-gray-500">
{{
formatUsage(subscription.daily_usage_usd, subscription.group?.daily_limit_usd)
}}
</span> </span>
</div> </div>
<div v-if="subscription.group?.weekly_limit_usd" class="flex items-center gap-2"> <!-- Progress bars for limited subscriptions -->
<span class="w-8 flex-shrink-0 text-[10px] text-gray-500">{{ <template v-else>
t('subscriptionProgress.weekly') <div v-if="subscription.group?.daily_limit_usd" class="flex items-center gap-2">
}}</span> <span class="w-8 flex-shrink-0 text-[10px] text-gray-500">{{
<div class="h-1.5 min-w-0 flex-1 rounded-full bg-gray-200 dark:bg-dark-600"> t('subscriptionProgress.daily')
<div }}</span>
class="h-1.5 rounded-full transition-all" <div class="h-1.5 min-w-0 flex-1 rounded-full bg-gray-200 dark:bg-dark-600">
:class=" <div
getProgressBarClass( class="h-1.5 rounded-full transition-all"
subscription.weekly_usage_usd, :class="
subscription.group?.weekly_limit_usd getProgressBarClass(
) subscription.daily_usage_usd,
" subscription.group?.daily_limit_usd
:style="{ )
width: getProgressWidth( "
subscription.weekly_usage_usd, :style="{
subscription.group?.weekly_limit_usd width: getProgressWidth(
) subscription.daily_usage_usd,
}" subscription.group?.daily_limit_usd
></div> )
}"
></div>
</div>
<span class="w-24 flex-shrink-0 text-right text-[10px] text-gray-500">
{{
formatUsage(subscription.daily_usage_usd, subscription.group?.daily_limit_usd)
}}
</span>
</div> </div>
<span class="w-24 flex-shrink-0 text-right text-[10px] text-gray-500">
{{
formatUsage(subscription.weekly_usage_usd, subscription.group?.weekly_limit_usd)
}}
</span>
</div>
<div v-if="subscription.group?.monthly_limit_usd" class="flex items-center gap-2"> <div v-if="subscription.group?.weekly_limit_usd" class="flex items-center gap-2">
<span class="w-8 flex-shrink-0 text-[10px] text-gray-500">{{ <span class="w-8 flex-shrink-0 text-[10px] text-gray-500">{{
t('subscriptionProgress.monthly') t('subscriptionProgress.weekly')
}}</span> }}</span>
<div class="h-1.5 min-w-0 flex-1 rounded-full bg-gray-200 dark:bg-dark-600"> <div class="h-1.5 min-w-0 flex-1 rounded-full bg-gray-200 dark:bg-dark-600">
<div <div
class="h-1.5 rounded-full transition-all" class="h-1.5 rounded-full transition-all"
:class=" :class="
getProgressBarClass( getProgressBarClass(
subscription.monthly_usage_usd, subscription.weekly_usage_usd,
subscription.group?.monthly_limit_usd subscription.group?.weekly_limit_usd
) )
" "
:style="{ :style="{
width: getProgressWidth( width: getProgressWidth(
subscription.monthly_usage_usd, subscription.weekly_usage_usd,
subscription.group?.monthly_limit_usd subscription.group?.weekly_limit_usd
) )
}" }"
></div> ></div>
</div>
<span class="w-24 flex-shrink-0 text-right text-[10px] text-gray-500">
{{
formatUsage(subscription.weekly_usage_usd, subscription.group?.weekly_limit_usd)
}}
</span>
</div> </div>
<span class="w-24 flex-shrink-0 text-right text-[10px] text-gray-500">
{{ <div v-if="subscription.group?.monthly_limit_usd" class="flex items-center gap-2">
formatUsage( <span class="w-8 flex-shrink-0 text-[10px] text-gray-500">{{
subscription.monthly_usage_usd, t('subscriptionProgress.monthly')
subscription.group?.monthly_limit_usd }}</span>
) <div class="h-1.5 min-w-0 flex-1 rounded-full bg-gray-200 dark:bg-dark-600">
}} <div
</span> class="h-1.5 rounded-full transition-all"
</div> :class="
getProgressBarClass(
subscription.monthly_usage_usd,
subscription.group?.monthly_limit_usd
)
"
:style="{
width: getProgressWidth(
subscription.monthly_usage_usd,
subscription.group?.monthly_limit_usd
)
}"
></div>
</div>
<span class="w-24 flex-shrink-0 text-right text-[10px] text-gray-500">
{{
formatUsage(
subscription.monthly_usage_usd,
subscription.group?.monthly_limit_usd
)
}}
</span>
</div>
</template>
</div> </div>
</div> </div>
</div> </div>
@@ -215,7 +229,19 @@ function getMaxUsagePercentage(sub: UserSubscription): number {
return percentages.length > 0 ? Math.max(...percentages) : 0 return percentages.length > 0 ? Math.max(...percentages) : 0
} }
function isUnlimited(sub: UserSubscription): boolean {
return (
!sub.group?.daily_limit_usd &&
!sub.group?.weekly_limit_usd &&
!sub.group?.monthly_limit_usd
)
}
function getProgressDotClass(sub: UserSubscription): string { function getProgressDotClass(sub: UserSubscription): string {
// Unlimited subscriptions get a special color
if (isUnlimited(sub)) {
return 'bg-emerald-500'
}
const maxPercentage = getMaxUsagePercentage(sub) const maxPercentage = getMaxUsagePercentage(sub)
if (maxPercentage >= 90) return 'bg-red-500' if (maxPercentage >= 90) return 'bg-red-500'
if (maxPercentage >= 70) return 'bg-orange-500' if (maxPercentage >= 70) return 'bg-orange-500'

View File

@@ -749,6 +749,7 @@ export default {
weekly: 'Weekly', weekly: 'Weekly',
monthly: 'Monthly', monthly: 'Monthly',
noLimits: 'No limits configured', noLimits: 'No limits configured',
unlimited: 'Unlimited',
resetNow: 'Resetting soon', resetNow: 'Resetting soon',
windowNotActive: 'Window not active', windowNotActive: 'Window not active',
resetInMinutes: 'Resets in {minutes}m', resetInMinutes: 'Resets in {minutes}m',
@@ -1492,7 +1493,8 @@ export default {
expiresToday: 'Expires today', expiresToday: 'Expires today',
expiresTomorrow: 'Expires tomorrow', expiresTomorrow: 'Expires tomorrow',
viewAll: 'View all subscriptions', viewAll: 'View all subscriptions',
noSubscriptions: 'No active subscriptions' noSubscriptions: 'No active subscriptions',
unlimited: 'Unlimited'
}, },
// Version Badge // Version Badge
@@ -1535,6 +1537,7 @@ export default {
expires: 'Expires', expires: 'Expires',
noExpiration: 'No expiration', noExpiration: 'No expiration',
unlimited: 'Unlimited', unlimited: 'Unlimited',
unlimitedDesc: 'No usage limits on this subscription',
daily: 'Daily', daily: 'Daily',
weekly: 'Weekly', weekly: 'Weekly',
monthly: 'Monthly', monthly: 'Monthly',

View File

@@ -840,6 +840,7 @@ export default {
weekly: '每周', weekly: '每周',
monthly: '每月', monthly: '每月',
noLimits: '未配置限额', noLimits: '未配置限额',
unlimited: '无限制',
resetNow: '即将重置', resetNow: '即将重置',
windowNotActive: '窗口未激活', windowNotActive: '窗口未激活',
resetInMinutes: '{minutes} 分钟后重置', resetInMinutes: '{minutes} 分钟后重置',
@@ -1689,7 +1690,8 @@ export default {
expiresToday: '今天到期', expiresToday: '今天到期',
expiresTomorrow: '明天到期', expiresTomorrow: '明天到期',
viewAll: '查看全部订阅', viewAll: '查看全部订阅',
noSubscriptions: '暂无有效订阅' noSubscriptions: '暂无有效订阅',
unlimited: '无限制'
}, },
// Version Badge // Version Badge
@@ -1731,6 +1733,7 @@ export default {
expires: '到期时间', expires: '到期时间',
noExpiration: '无到期时间', noExpiration: '无到期时间',
unlimited: '无限制', unlimited: '无限制',
unlimitedDesc: '该订阅无用量限制',
daily: '每日', daily: '每日',
weekly: '每周', weekly: '每周',
monthly: '每月', monthly: '每月',

View File

@@ -202,16 +202,19 @@
</div> </div>
</div> </div>
<!-- No Limits --> <!-- No Limits - Unlimited badge -->
<div <div
v-if=" v-if="
!row.group?.daily_limit_usd && !row.group?.daily_limit_usd &&
!row.group?.weekly_limit_usd && !row.group?.weekly_limit_usd &&
!row.group?.monthly_limit_usd !row.group?.monthly_limit_usd
" "
class="text-xs text-gray-500" class="flex items-center gap-2 rounded-lg bg-gradient-to-r from-emerald-50 to-teal-50 px-3 py-2 dark:from-emerald-900/20 dark:to-teal-900/20"
> >
{{ t('admin.subscriptions.noLimits') }} <span class="text-lg text-emerald-600 dark:text-emerald-400">∞</span>
<span class="text-xs font-medium text-emerald-700 dark:text-emerald-300">
{{ t('admin.subscriptions.unlimited') }}
</span>
</div> </div>
</div> </div>
</template> </template>

View File

@@ -230,18 +230,26 @@
</p> </p>
</div> </div>
<!-- No limits configured --> <!-- No limits configured - Unlimited badge -->
<div <div
v-if=" v-if="
!subscription.group?.daily_limit_usd && !subscription.group?.daily_limit_usd &&
!subscription.group?.weekly_limit_usd && !subscription.group?.weekly_limit_usd &&
!subscription.group?.monthly_limit_usd !subscription.group?.monthly_limit_usd
" "
class="py-4 text-center" class="flex items-center justify-center rounded-xl bg-gradient-to-r from-emerald-50 to-teal-50 py-6 dark:from-emerald-900/20 dark:to-teal-900/20"
> >
<span class="text-sm text-gray-500 dark:text-dark-400">{{ <div class="flex items-center gap-3">
t('userSubscriptions.unlimited') <span class="text-4xl text-emerald-600 dark:text-emerald-400">∞</span>
}}</span> <div>
<p class="text-sm font-medium text-emerald-700 dark:text-emerald-300">
{{ t('userSubscriptions.unlimited') }}
</p>
<p class="text-xs text-emerald-600/70 dark:text-emerald-400/70">
{{ t('userSubscriptions.unlimitedDesc') }}
</p>
</div>
</div>
</div> </div>
</div> </div>
</div> </div>