mirror of
https://github.com/jxxghp/MoviePilot-Frontend.git
synced 2026-05-11 10:00:08 +08:00
148 lines
4.0 KiB
Vue
148 lines
4.0 KiB
Vue
<script lang="ts" setup>
|
|
import api from '@/api'
|
|
import { useI18n } from 'vue-i18n'
|
|
import { useDisplay } from 'vuetify'
|
|
|
|
// 显示器宽度
|
|
const display = useDisplay()
|
|
|
|
// 多语言支持
|
|
const { t } = useI18n()
|
|
|
|
// 定义输入
|
|
const props = defineProps({
|
|
conf: {
|
|
type: Object as PropType<{ [key: string]: any }>,
|
|
required: true,
|
|
},
|
|
})
|
|
|
|
// 定义事件
|
|
const emit = defineEmits(['done', 'close'])
|
|
|
|
// 完成
|
|
async function handleDone() {
|
|
await savaAlistConfig()
|
|
emit('done')
|
|
}
|
|
|
|
// 重置配置
|
|
async function handleReset() {
|
|
try {
|
|
const result: { [key: string]: any } = await api.get('/storage/reset/alist')
|
|
if (result.success) {
|
|
// 重置成功
|
|
handleDone()
|
|
}
|
|
} catch (e) {
|
|
console.error(e)
|
|
}
|
|
}
|
|
|
|
// 登录类型
|
|
let loginType = ref('username')
|
|
if (props.conf.token) {
|
|
loginType = ref('token')
|
|
} else if (props.conf.username) {
|
|
loginType = ref('username')
|
|
} else {
|
|
loginType = ref('guest')
|
|
}
|
|
|
|
// 数据源
|
|
const sourceItems = [
|
|
{
|
|
'title': t('dialog.alistConfig.loginTypeOptions.username'),
|
|
'value': 'username',
|
|
},
|
|
{ 'title': t('dialog.alistConfig.loginTypeOptions.token'), 'value': 'token' },
|
|
{ 'title': t('dialog.alistConfig.loginTypeOptions.guest'), 'value': 'guest' },
|
|
]
|
|
|
|
// 保存alist设置
|
|
async function savaAlistConfig() {
|
|
try {
|
|
await api.post(`storage/save/alist`, props.conf)
|
|
} catch (e) {
|
|
console.error(e)
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<template>
|
|
<VDialog width="50rem" scrollable :fullscreen="!display.mdAndUp.value">
|
|
<VCard>
|
|
<VDialogCloseBtn @click="emit('close')" />
|
|
<VCardItem>
|
|
<template #prepend>
|
|
<VIcon icon="mdi-cog-outline" class="me-2" />
|
|
</template>
|
|
<VCardTitle>
|
|
{{ t('dialog.alistConfig.title') }}
|
|
</VCardTitle>
|
|
</VCardItem>
|
|
<VDivider />
|
|
<VCardText>
|
|
<VRow>
|
|
<VCol cols="12">
|
|
<VTextField
|
|
v-model="props.conf.url"
|
|
:hint="t('dialog.alistConfig.serverUrl')"
|
|
:label="t('dialog.alistConfig.serverUrl')"
|
|
persistent-hint
|
|
prepend-inner-icon="mdi-server"
|
|
/>
|
|
</VCol>
|
|
<VCol cols="12" md="4">
|
|
<VSelect
|
|
v-model="loginType"
|
|
:items="sourceItems"
|
|
:label="t('dialog.alistConfig.loginType')"
|
|
:hint="t('dialog.alistConfig.loginType')"
|
|
persistent-hint
|
|
prepend-inner-icon="mdi-login"
|
|
/>
|
|
</VCol>
|
|
<VCol cols="12" md="4" v-if="loginType == 'username'">
|
|
<VTextField
|
|
v-model="props.conf.username"
|
|
:hint="t('dialog.alistConfig.username')"
|
|
:label="t('dialog.alistConfig.username')"
|
|
persistent-hint
|
|
prepend-inner-icon="mdi-account"
|
|
/>
|
|
</VCol>
|
|
<VCol cols="12" md="4" v-if="loginType == 'username'">
|
|
<VTextField
|
|
type="password"
|
|
v-model="props.conf.password"
|
|
:hint="t('dialog.alistConfig.password')"
|
|
:label="t('dialog.alistConfig.password')"
|
|
persistent-hint
|
|
prepend-inner-icon="mdi-lock"
|
|
/>
|
|
</VCol>
|
|
<VCol cols="12" md="8" v-if="loginType == 'token'">
|
|
<VTextField
|
|
v-model="props.conf.token"
|
|
:hint="t('dialog.alistConfig.loginTypeOptions.token')"
|
|
:label="t('dialog.alistConfig.loginTypeOptions.token')"
|
|
persistent-hint
|
|
prepend-inner-icon="mdi-key"
|
|
/>
|
|
</VCol>
|
|
</VRow>
|
|
</VCardText>
|
|
<VCardActions>
|
|
<VBtn color="error" @click="handleReset" prepend-icon="mdi-restore" class="px-5 me-3">
|
|
{{ t('dialog.alistConfig.reset') }}
|
|
</VBtn>
|
|
<VSpacer />
|
|
<VBtn @click="handleDone" prepend-icon="mdi-check" class="px-5 me-3">
|
|
{{ t('dialog.alistConfig.complete') }}
|
|
</VBtn>
|
|
</VCardActions>
|
|
</VCard>
|
|
</VDialog>
|
|
</template>
|