mirror of
https://github.com/Megghy/vtsuru.live.git
synced 2025-12-10 20:36:55 +08:00
feat: 更新依赖和移除不必要的文件, 更新歌单管理列表在小屏幕上的显示效果, 修复自定义配置文件加载
- 在 package.json 中移除不再使用的依赖项,并更新部分依赖版本 - 删除多个不再使用的组件和文件,包括 CheckInTemplateHelper.vue、CommonConfigItems.vue、GlobalSettingsConfig.vue 等 - 更新 bun.lockb 文件以反映依赖变更
This commit is contained in:
@@ -1,201 +0,0 @@
|
||||
<script setup lang="ts">
|
||||
import { GetSelfAccount, useAccount } from '@/api/account'
|
||||
import { QueryGetAPI } from '@/api/query'
|
||||
import { BILI_API_URL } from '@/data/constants'
|
||||
import {
|
||||
NAlert,
|
||||
NButton,
|
||||
NCard,
|
||||
NCountdown,
|
||||
NInput,
|
||||
NInputGroup,
|
||||
NInputNumber,
|
||||
NSpace,
|
||||
NSpin,
|
||||
NText,
|
||||
useMessage,
|
||||
} from 'naive-ui'
|
||||
import { onMounted, ref } from 'vue'
|
||||
|
||||
const message = useMessage()
|
||||
|
||||
const accountInfo = useAccount()
|
||||
const isStart = ref(false)
|
||||
const timeLeft = ref(0)
|
||||
const timeOut = ref(false)
|
||||
|
||||
const uId = ref()
|
||||
const roomId = ref()
|
||||
const timer = ref()
|
||||
|
||||
function onStartVerify() {
|
||||
QueryGetAPI(BILI_API_URL + 'verify', {
|
||||
uId: uId.value,
|
||||
}).then((data) => {
|
||||
if (data.code == 200) {
|
||||
message.info('已开始认证流程, 请前往直播间发送认证码')
|
||||
checkStatus()
|
||||
isStart.value = true
|
||||
timer.value = setInterval(checkStatus, 2500)
|
||||
}
|
||||
})
|
||||
}
|
||||
async function checkStatus() {
|
||||
const data = await QueryGetAPI<{
|
||||
uId: number
|
||||
roomId: number
|
||||
endTime: number
|
||||
}>(BILI_API_URL + 'status')
|
||||
if (data.code == 200) {
|
||||
//正在进行认证
|
||||
roomId.value ??= data.data.roomId
|
||||
timeLeft.value = data.data.endTime
|
||||
return true
|
||||
} else if (data.code == 201) {
|
||||
clearInterval(timer.value)
|
||||
message.success('认证成功')
|
||||
setTimeout(() => {
|
||||
GetSelfAccount()
|
||||
}, 1)
|
||||
return true
|
||||
} else if (data.code == 400 && isStart.value) {
|
||||
timeOut.value = true
|
||||
clearInterval(timer.value)
|
||||
message.error('认证超时')
|
||||
return false
|
||||
}
|
||||
return false
|
||||
}
|
||||
function copyCode() {
|
||||
if (navigator.clipboard) {
|
||||
navigator.clipboard.writeText(accountInfo.value?.biliVerifyCode ?? '')
|
||||
message.success('已复制认证码到剪切板')
|
||||
} else {
|
||||
message.warning('当前环境不支持自动复制, 请手动选择并复制')
|
||||
}
|
||||
}
|
||||
|
||||
onMounted(async () => {
|
||||
if (accountInfo.value && !accountInfo.value.isBiliVerified) {
|
||||
if (await checkStatus()) {
|
||||
isStart.value = true
|
||||
timer.value = setInterval(checkStatus, 5000)
|
||||
}
|
||||
}
|
||||
})
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<NAlert
|
||||
v-if="accountInfo?.isBiliVerified"
|
||||
type="success"
|
||||
>
|
||||
你已通过验证
|
||||
</NAlert>
|
||||
<NAlert v-else-if="!accountInfo">
|
||||
尚未登录
|
||||
</NAlert>
|
||||
<NCard
|
||||
v-else
|
||||
embedded
|
||||
>
|
||||
<template #header>
|
||||
Bilibili 身份验证
|
||||
</template>
|
||||
<template v-if="isStart">
|
||||
<NSpace
|
||||
vertical
|
||||
justify="center"
|
||||
align="center"
|
||||
>
|
||||
<template v-if="!timeOut">
|
||||
<NSpin />
|
||||
<span> 剩余 <NCountdown :duration="timeLeft - Date.now()" /> </span>
|
||||
</template>
|
||||
<NAlert
|
||||
v-else
|
||||
type="error"
|
||||
>
|
||||
认证超时
|
||||
<NButton
|
||||
type="info"
|
||||
@click="
|
||||
() => {
|
||||
isStart = false
|
||||
timeOut = false
|
||||
}
|
||||
"
|
||||
>
|
||||
重新开始
|
||||
</NButton>
|
||||
</NAlert>
|
||||
<NInputGroup>
|
||||
<NInput
|
||||
v-model:value="accountInfo.biliVerifyCode"
|
||||
:allow-input="() => false"
|
||||
/>
|
||||
<NButton @click="copyCode">
|
||||
复制认证码
|
||||
</NButton>
|
||||
</NInputGroup>
|
||||
<NButton
|
||||
v-if="roomId"
|
||||
type="primary"
|
||||
tag="a"
|
||||
:href="'https://live.bilibili.com/' + roomId"
|
||||
target="_blank"
|
||||
>
|
||||
前往直播间
|
||||
</NButton>
|
||||
</NSpace>
|
||||
</template>
|
||||
<template v-else>
|
||||
<NSpace
|
||||
vertical
|
||||
justify="center"
|
||||
align="center"
|
||||
>
|
||||
<NAlert type="info">
|
||||
<NText>
|
||||
请在点击
|
||||
<NText
|
||||
type="primary"
|
||||
strong
|
||||
>
|
||||
开始认证
|
||||
</NText>
|
||||
后2分钟之内使用
|
||||
<NText
|
||||
strong
|
||||
type="primary"
|
||||
>
|
||||
需要认证的账户
|
||||
</NText>
|
||||
在自己的直播间内发送
|
||||
<NButton
|
||||
type="info"
|
||||
text
|
||||
@click="copyCode"
|
||||
>
|
||||
{{ accountInfo?.biliVerifyCode }}
|
||||
</NButton>
|
||||
</NText>
|
||||
</NAlert>
|
||||
<NInputNumber
|
||||
v-model:value="uId"
|
||||
size="small"
|
||||
placeholder="输入用户UId"
|
||||
:min="1"
|
||||
:show-button="false"
|
||||
/>
|
||||
<NButton
|
||||
size="large"
|
||||
type="primary"
|
||||
@click="onStartVerify"
|
||||
>
|
||||
开始认证
|
||||
</NButton>
|
||||
</NSpace>
|
||||
</template>
|
||||
</NCard>
|
||||
</template>
|
||||
@@ -1,24 +0,0 @@
|
||||
<script setup lang="ts">
|
||||
import { useAccount } from '@/api/account'
|
||||
import { useDanmakuClient } from '@/store/useDanmakuClient'
|
||||
import { NAlert } from 'naive-ui'
|
||||
import OpenLottery from '../open_live/OpenLottery.vue'
|
||||
|
||||
const accountInfo = useAccount()
|
||||
const client = await useDanmakuClient().initOpenlive()
|
||||
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<NAlert
|
||||
v-if="accountInfo?.isBiliVerified != true"
|
||||
type="info"
|
||||
>
|
||||
尚未进行Bilibili认证
|
||||
</NAlert>
|
||||
<OpenLottery
|
||||
v-else
|
||||
:room-info="client.authInfo!"
|
||||
:code="accountInfo?.biliAuthCode"
|
||||
/>
|
||||
</template>
|
||||
@@ -1,24 +0,0 @@
|
||||
<script setup lang="ts">
|
||||
import { useAccount } from '@/api/account'
|
||||
import { useDanmakuClient } from '@/store/useDanmakuClient'
|
||||
import { NAlert } from 'naive-ui'
|
||||
import MusicRequest from '../open_live/MusicRequest.vue'
|
||||
|
||||
const accountInfo = useAccount()
|
||||
const client = await useDanmakuClient().initOpenlive()
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<NAlert
|
||||
v-if="accountInfo?.isBiliVerified != true"
|
||||
type="info"
|
||||
>
|
||||
尚未进行Bilibili认证
|
||||
</NAlert>
|
||||
<MusicRequest
|
||||
v-else
|
||||
:client="client"
|
||||
:room-info="client.authInfo!"
|
||||
:code="accountInfo?.biliAuthCode"
|
||||
/>
|
||||
</template>
|
||||
@@ -1,30 +0,0 @@
|
||||
<script setup lang="ts">
|
||||
import { computed, onMounted, ref } from 'vue'
|
||||
|
||||
// 组件属性定义
|
||||
const props = defineProps<{
|
||||
// 可以根据需要添加属性
|
||||
}>()
|
||||
|
||||
// 事件定义
|
||||
const emit = defineEmits<{
|
||||
// 可以根据需要添加事件
|
||||
}>()
|
||||
|
||||
// 组件挂载时的初始化
|
||||
onMounted(() => {
|
||||
// 初始化逻辑
|
||||
})
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<div class="point-sub-item-manage">
|
||||
<!-- 组件内容 -->
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<style scoped>
|
||||
.point-sub-item-manage {
|
||||
width: 100%;
|
||||
}
|
||||
</style>
|
||||
Reference in New Issue
Block a user