mirror of
https://github.com/Wei-Shaw/claude-relay-service.git
synced 2026-01-22 16:43:35 +00:00
feat: 添加 Opus 限流状态显示
- 在账户列表中显示 Opus 限流状态徽章 - 显示限流剩余时间(天/小时) - 后端 API 添加 opusRateLimitedAt 和 opusRateLimitEndAt 字段 - 优化徽章样式,防止文字溢出
This commit is contained in:
@@ -606,9 +606,19 @@
|
||||
>({{ formatRateLimitTime(account.rateLimitStatus.minutesRemaining) }})</span
|
||||
>
|
||||
</span>
|
||||
<span
|
||||
v-if="isOpusRateLimited(account)"
|
||||
class="inline-flex items-center whitespace-nowrap rounded-full bg-orange-100 px-3 py-1 text-xs font-semibold text-orange-800 dark:bg-orange-900/30 dark:text-orange-300"
|
||||
>
|
||||
<i class="fas fa-gem mr-1 flex-shrink-0" />
|
||||
<span class="flex-shrink-0">Opus限流</span>
|
||||
<span v-if="account.opusRateLimitEndAt" class="ml-1 flex-shrink-0">
|
||||
({{ formatOpusLimitEndTime(account.opusRateLimitEndAt) }})
|
||||
</span>
|
||||
</span>
|
||||
<span
|
||||
v-if="account.schedulable === false"
|
||||
class="inline-flex items-center rounded-full bg-gray-100 px-3 py-1 text-xs font-semibold text-gray-700"
|
||||
class="inline-flex items-center rounded-full bg-gray-100 px-3 py-1 text-xs font-semibold text-gray-700 dark:bg-gray-700 dark:text-gray-300"
|
||||
>
|
||||
<i class="fas fa-pause-circle mr-1" />
|
||||
不可调度
|
||||
@@ -2491,6 +2501,54 @@ const formatRateLimitTime = (minutes) => {
|
||||
}
|
||||
}
|
||||
|
||||
// 检查账户是否处于 Opus 限流状态
|
||||
const isOpusRateLimited = (account) => {
|
||||
if (!account.opusRateLimitEndAt) {
|
||||
return false
|
||||
}
|
||||
const endTime = new Date(account.opusRateLimitEndAt)
|
||||
const now = new Date()
|
||||
return endTime > now
|
||||
}
|
||||
|
||||
// 格式化 Opus 限流结束时间
|
||||
const formatOpusLimitEndTime = (endTimeStr) => {
|
||||
if (!endTimeStr) return ''
|
||||
|
||||
const endTime = new Date(endTimeStr)
|
||||
const now = new Date()
|
||||
|
||||
// 如果已经过期,返回"已解除"
|
||||
if (endTime <= now) {
|
||||
return '已解除'
|
||||
}
|
||||
|
||||
// 计算剩余时间(毫秒)
|
||||
const remainingMs = endTime - now
|
||||
const remainingMinutes = Math.floor(remainingMs / (1000 * 60))
|
||||
|
||||
// 计算天数、小时和分钟
|
||||
const days = Math.floor(remainingMinutes / 1440)
|
||||
const remainingAfterDays = remainingMinutes % 1440
|
||||
const hours = Math.floor(remainingAfterDays / 60)
|
||||
const mins = remainingAfterDays % 60
|
||||
|
||||
// 格式化显示
|
||||
const parts = []
|
||||
if (days > 0) {
|
||||
parts.push(`${days}天`)
|
||||
}
|
||||
if (hours > 0) {
|
||||
parts.push(`${hours}小时`)
|
||||
}
|
||||
if (mins > 0 && days === 0) {
|
||||
// 只有在天数为0时才显示分钟
|
||||
parts.push(`${mins}分钟`)
|
||||
}
|
||||
|
||||
return parts.join('')
|
||||
}
|
||||
|
||||
// 打开创建账户模态框
|
||||
const openCreateAccountModal = () => {
|
||||
newAccountPlatform.value = null // 重置选择的平台
|
||||
|
||||
Reference in New Issue
Block a user