fix(settings): AccountSettingSite bug

- 拆分 CC 与 站点刷新,解决CC保存时,站点刷新也会被提交保存的问题。
This commit is contained in:
Aqr-K
2024-10-31 18:05:15 +08:00
parent 6bc420d57f
commit 6a4a218152

View File

@@ -1,6 +1,10 @@
<script lang="ts" setup>
import { useToast } from 'vue-toast-notification'
import api from '@/api'
import debounce from 'lodash/debounce'
// 防抖时间
const debounceTime = 500
// 提示框
const $toast = useToast()
@@ -16,16 +20,20 @@ const resetSitesDisabled = ref(false)
const isPasswordVisible = ref(false)
// CookieCloud设置项
const siteSetting = ref({
COOKIECLOUD_HOST: '',
COOKIECLOUD_KEY: '',
COOKIECLOUD_PASSWORD: '',
COOKIECLOUD_INTERVAL: 0,
USER_AGENT: '',
COOKIECLOUD_ENABLE_LOCAL: false,
COOKIECLOUD_BLACKLIST: '',
SITEDATA_REFRESH_INTERVAL: 0,
// 站点设置默认值
const siteSetting = ref<any>({
CookieCloud: {
COOKIECLOUD_HOST: '',
COOKIECLOUD_KEY: '',
COOKIECLOUD_PASSWORD: '',
COOKIECLOUD_INTERVAL: 0,
USER_AGENT: '',
COOKIECLOUD_ENABLE_LOCAL: false,
COOKIECLOUD_BLACKLIST: '',
},
Site:{
SITEDATA_REFRESH_INTERVAL: 0,
}
})
// 同步间隔下拉框
@@ -50,7 +58,7 @@ const SiteDataRefreshIntervalItems = [
]
// 重置站点
async function resetSites() {
const resetSites = debounce(async () => {
try {
resetSitesDisabled.value = true
resetSitesText.value = '正在重置...'
@@ -64,32 +72,24 @@ async function resetSites() {
} catch (error) {
console.log(error)
}
}
}, debounceTime)
// 加载站点设置
async function loadSiteSettings() {
try {
const result: { [key: string]: any } = await api.get('system/env')
if (result.success) {
const {
COOKIECLOUD_HOST,
COOKIECLOUD_KEY,
COOKIECLOUD_PASSWORD,
COOKIECLOUD_INTERVAL,
USER_AGENT,
COOKIECLOUD_ENABLE_LOCAL,
COOKIECLOUD_BLACKLIST,
SITEDATA_REFRESH_INTERVAL,
} = result.data
siteSetting.value = {
COOKIECLOUD_HOST,
COOKIECLOUD_KEY,
COOKIECLOUD_PASSWORD,
COOKIECLOUD_INTERVAL,
USER_AGENT,
COOKIECLOUD_ENABLE_LOCAL,
COOKIECLOUD_BLACKLIST,
SITEDATA_REFRESH_INTERVAL,
// 将API返回的值赋值给SystemSettings
for (const sectionKey of Object.keys(siteSetting.value) as Array<keyof typeof siteSetting.value>) {
Object.keys(siteSetting.value[sectionKey]).forEach((key: string) => {
let v: any
if (result.data.hasOwnProperty(key)) {
v = result.data[key]
// 空字符串转为null避免空字符串导致前端显示问题
if (v === '') { v = null }
(siteSetting.value[sectionKey] as any)[key] = v
}
})
}
}
} catch (error) {
@@ -97,17 +97,19 @@ async function loadSiteSettings() {
}
}
// 调用API保存CookieCloud设置
async function saveSiteSetting() {
// 调用API保存设置
const saveSiteSetting = debounce(async (value: { [key: string]: any }) => {
console.log(`正在保存设置:${JSON.stringify(value)}`)
try {
const result: { [key: string]: any } = await api.post('system/env', siteSetting.value)
if (result.success) $toast.success('保存站点设置成功')
else $toast.error('保存站点设置失败!')
const result: { [key: string]: any } = await api.post('system/env', value)
if (result.success) {
$toast.success('保存设置成功')
}
} catch (error) {
console.log(error)
$toast.error('保存设置失败!')
}
}
}, debounceTime)
// 加载数据
onMounted(() => {
@@ -128,7 +130,7 @@ onMounted(() => {
<VRow>
<VCol cols="12" md="6">
<VCheckbox
v-model="siteSetting.COOKIECLOUD_ENABLE_LOCAL"
v-model="siteSetting.CookieCloud.COOKIECLOUD_ENABLE_LOCAL"
label="启用本地CookieCloud服务器"
hint="使用内建CookieCloud服务同步站点数据服务地址为http://localhost:3000/cookiecloud"
persistent-hint
@@ -138,17 +140,17 @@ onMounted(() => {
<VRow>
<VCol cols="12" md="6">
<VTextField
v-model="siteSetting.COOKIECLOUD_HOST"
v-model="siteSetting.CookieCloud.COOKIECLOUD_HOST"
label="服务地址"
placeholder="https://movie-pilot.org/cookiecloud"
:disabled="!!siteSetting.COOKIECLOUD_ENABLE_LOCAL"
:disabled="siteSetting.CookieCloud.COOKIECLOUD_ENABLE_LOCAL"
hint="远端CookieCloud服务地址格式https://movie-pilot.org/cookiecloud"
persistent-hint
/>
</VCol>
<VCol cols="12" md="6">
<VTextField
v-model="siteSetting.COOKIECLOUD_KEY"
v-model="siteSetting.CookieCloud.COOKIECLOUD_KEY"
label="用户KEY"
hint="CookieCloud浏览器插件生成的用户KEY"
persistent-hint
@@ -156,7 +158,7 @@ onMounted(() => {
</VCol>
<VCol cols="12" md="6">
<VTextField
v-model="siteSetting.COOKIECLOUD_PASSWORD"
v-model="siteSetting.CookieCloud.COOKIECLOUD_PASSWORD"
:type="isPasswordVisible ? 'text' : 'password'"
:append-inner-icon="isPasswordVisible ? 'mdi-eye-off-outline' : 'mdi-eye-outline'"
@click:append-inner="isPasswordVisible = !isPasswordVisible"
@@ -167,7 +169,7 @@ onMounted(() => {
</VCol>
<VCol cols="12" md="6">
<VSelect
v-model="siteSetting.COOKIECLOUD_INTERVAL"
v-model="siteSetting.CookieCloud.COOKIECLOUD_INTERVAL"
label="自动同步间隔"
:items="CookieCloudIntervalItems"
hint="从CookieCloud服务器自动同步站点Cookie到MoviePilot的时间间隔"
@@ -176,7 +178,7 @@ onMounted(() => {
</VCol>
<VCol cols="12" md="6">
<VTextField
v-model="siteSetting.COOKIECLOUD_BLACKLIST"
v-model="siteSetting.CookieCloud.COOKIECLOUD_BLACKLIST"
label="同步域名黑名单"
placeholder="多个域名,分割"
hint="CookieCloud同步域名黑名单多个域名,分割"
@@ -185,7 +187,7 @@ onMounted(() => {
</VCol>
<VCol cols="12" md="6">
<VTextField
v-model="siteSetting.USER_AGENT"
v-model="siteSetting.CookieCloud.USER_AGENT"
label="浏览器User-Agent"
hint="CookieCloud插件所在的浏览器的User-Agent"
persistent-hint
@@ -195,7 +197,11 @@ onMounted(() => {
</VForm>
</VCardText>
<VCardText>
<VBtn type="submit" @click="saveSiteSetting"> 保存 </VBtn>
<VForm @submit.prevent="() => {}">
<div class="d-flex flex-wrap gap-4 mt-4">
<VBtn type="submit" @click="saveSiteSetting(siteSetting.CookieCloud)"> 保存 </VBtn>
</div>
</VForm>
</VCardText>
</VCard>
</VCol>
@@ -207,7 +213,7 @@ onMounted(() => {
<VRow>
<VCol cols="12" md="6">
<VSelect
v-model="siteSetting.SITEDATA_REFRESH_INTERVAL"
v-model="siteSetting.Site.SITEDATA_REFRESH_INTERVAL"
label="站点数据刷新间隔"
:items="SiteDataRefreshIntervalItems"
hint="刷新站点用户上传下载等数据的时间间隔"
@@ -218,7 +224,11 @@ onMounted(() => {
</VForm>
</VCardText>
<VCardText>
<VBtn type="submit" @click="saveSiteSetting"> 保存 </VBtn>
<VForm @submit.prevent="() => {}">
<div class="d-flex flex-wrap gap-4 mt-4">
<VBtn type="submit" @click="saveSiteSetting(siteSetting.Site)"> 保存 </VBtn>
</div>
</VForm>
</VCardText>
</VCard>
</VCol>