Files
MoviePilot-Frontend/src/views/discover/ExtraSourceView.vue

65 lines
1.7 KiB
Vue

<script setup lang="ts">
import { DiscoverSource } from '@/api/types'
import MediaCardListView from '@/views/discover/MediaCardListView.vue'
import FormRender from '@/components/render/FormRender.vue'
import { cloneDeep, isNull } from 'lodash'
// 输入参数
const props = defineProps<{
source: DiscoverSource
}>()
// 默认输入参数
const default_params = cloneDeep(props.source.filter_params)
// 过滤参数
const filterParams = reactive(props.source.filter_params)
// 前一次的过滤参数
let previousParams = cloneDeep(props.source.filter_params)
// 当前Key
const currentKey = ref(0)
// 类型和过滤参数变化后重新刷新列表
watch(filterParams, newParams => {
// 检查每个值
for (const key in newParams) {
// 如果没有值但有默认值时,设置为默认值
if (!newParams[key] && default_params[key]) {
filterParams[key] = default_params[key]
}
// 检查依赖关系
const depends = props.source?.depends
if (depends) {
if (newParams[key] !== previousParams[key]) {
for (const dependKey in depends) {
if (key != dependKey && depends[dependKey] && depends[dependKey].includes(key)) {
filterParams[dependKey] = null
}
}
}
}
}
// 更新 previousParams
previousParams = cloneDeep(newParams)
// 刷新界面
currentKey.value++
})
</script>
<template>
<div class="px-3">
<FormRender v-for="(element, index) in source.filter_ui" :key="index" :config="element" :model="filterParams" />
</div>
<div>
<MediaCardListView :key="currentKey" :apipath="source.api_path" :params="filterParams" />
</div>
</template>
<style>
.v-chip--selected {
color: rgb(var(--v-theme-primary)) !important;
}
</style>