mirror of
https://github.com/jxxghp/MoviePilot-Frontend.git
synced 2026-05-11 10:00:08 +08:00
332 lines
8.6 KiB
Vue
332 lines
8.6 KiB
Vue
<script lang="ts" setup>
|
|
import type { PropType } from 'vue'
|
|
import { useToast } from 'vue-toast-notification'
|
|
import { useConfirm } from 'vuetify-use-dialog'
|
|
import { formatFileSize } from '@/@core/utils/formatters'
|
|
import api from '@/api'
|
|
import { doneNProgress, startNProgress } from '@/api/nprogress'
|
|
import type { Context, MediaInfo, TorrentInfo } from '@/api/types'
|
|
|
|
// 输入参数
|
|
const props = defineProps({
|
|
torrent: Object as PropType<Context>,
|
|
more: Array as PropType<Context[]>,
|
|
width: String,
|
|
height: String,
|
|
})
|
|
|
|
// 提示框
|
|
const $toast = useToast()
|
|
|
|
// 确认框
|
|
const createConfirm = useConfirm()
|
|
|
|
// 更多来源界面
|
|
const showMoreTorrents = ref(false)
|
|
|
|
// 种子信息
|
|
const torrent = ref(props.torrent?.torrent_info)
|
|
|
|
// 媒体信息
|
|
const media = ref(props.torrent?.media_info)
|
|
|
|
// 识别元数据
|
|
const meta = ref(props.torrent?.meta_info)
|
|
|
|
// 站点图标
|
|
const siteIcon = ref('')
|
|
|
|
// 存储是否已经下载过的记录
|
|
const downloaded = ref<String[]>([])
|
|
|
|
// 查询站点图标
|
|
async function getSiteIcon() {
|
|
try {
|
|
siteIcon.value = (await api.get(`site/icon/${torrent?.value?.site}`)).data.icon
|
|
}
|
|
catch (error) {
|
|
console.error(error)
|
|
}
|
|
}
|
|
|
|
// 询问并添加下载
|
|
async function handleAddDownload(_site: any = undefined,
|
|
_media: any = undefined,
|
|
_torrent: any = undefined) {
|
|
if (!_media || !_torrent || !_site) {
|
|
_site = torrent.value?.site_name
|
|
_media = media.value
|
|
_torrent = torrent.value
|
|
}
|
|
|
|
const isConfirmed = await createConfirm({
|
|
title: '确认',
|
|
content: `是否确认下载【${_site}】${_torrent?.title} ?`,
|
|
confirmationText: '确认',
|
|
cancellationText: '取消',
|
|
dialogProps: {
|
|
maxWidth: '50rem',
|
|
},
|
|
confirmationButtonProps: {
|
|
variant: 'tonal',
|
|
},
|
|
})
|
|
|
|
if (!isConfirmed)
|
|
return
|
|
|
|
addDownload(_media, _torrent)
|
|
}
|
|
|
|
// 添加下载
|
|
async function addDownload(_media: MediaInfo, _torrent: TorrentInfo) {
|
|
startNProgress()
|
|
try {
|
|
const result: { [key: string]: any } = await api.post('download/', {
|
|
media_in: _media,
|
|
torrent_in: _torrent,
|
|
})
|
|
|
|
if (result.success) {
|
|
// 添加下载成功
|
|
$toast.success(`${_torrent?.site_name} ${_torrent?.title} 添加下载成功!`)
|
|
downloaded.value.push(_torrent?.enclosure || '')
|
|
}
|
|
else {
|
|
// 添加下载失败
|
|
$toast.error(`${_torrent?.site_name} ${_torrent?.title} 添加下载失败!`)
|
|
}
|
|
}
|
|
catch (error) {
|
|
console.error(error)
|
|
}
|
|
doneNProgress()
|
|
}
|
|
|
|
// 打开种子详情页面
|
|
function openTorrentDetail() {
|
|
window.open(torrent.value?.page_url, '_blank')
|
|
}
|
|
|
|
// 下载种子文件
|
|
async function downloadTorrentFile() {
|
|
window.open(torrent.value?.enclosure, '_blank')
|
|
}
|
|
|
|
// 促销Chip类
|
|
function getVolumeFactorClass(downloadVolume: number, uploadVolume: number) {
|
|
if (downloadVolume === 0)
|
|
return 'text-white bg-lime-500'
|
|
else if (downloadVolume < 1)
|
|
return 'text-white bg-green-500'
|
|
else if (uploadVolume !== 1)
|
|
return 'text-white bg-sky-500'
|
|
else
|
|
return 'text-white bg-gray-500'
|
|
}
|
|
|
|
// 装载时查询站点图标
|
|
onMounted(() => {
|
|
getSiteIcon()
|
|
})
|
|
</script>
|
|
|
|
<template>
|
|
<VCard
|
|
:width="props.width"
|
|
:height="props.height"
|
|
:variant="downloaded.includes(torrent?.enclosure || '') ? 'outlined' : 'elevated'"
|
|
@click="handleAddDownload"
|
|
>
|
|
<template
|
|
v-if="!showMoreTorrents"
|
|
#image
|
|
>
|
|
<VAvatar
|
|
class="absolute right-2 bottom-2 rounded"
|
|
variant="flat"
|
|
rounded="0"
|
|
>
|
|
<VImg :src="siteIcon" />
|
|
</VAvatar>
|
|
</template>
|
|
<VCardItem class="py-1">
|
|
<VCardTitle class="break-words overflow-visible whitespace-break-spaces">
|
|
{{ media?.title }} {{ meta?.season_episode }}
|
|
<span class="text-green-700 ms-2 text-sm">↑{{ torrent?.seeders }}</span>
|
|
<span class="text-orange-700 ms-2 text-sm">↓{{ torrent?.peers }}</span>
|
|
</VCardTitle>
|
|
<template #append>
|
|
<div class="me-n3">
|
|
<IconBtn>
|
|
<VIcon
|
|
icon="mdi-dots-vertical"
|
|
/>
|
|
<VMenu
|
|
activator="parent"
|
|
close-on-content-click
|
|
>
|
|
<VList>
|
|
<VListItem
|
|
variant="plain"
|
|
@click="openTorrentDetail()"
|
|
>
|
|
<template #prepend>
|
|
<VIcon icon="mdi-information" />
|
|
</template>
|
|
<VListItemTitle>查看详情</VListItemTitle>
|
|
</VListItem>
|
|
<VListItem
|
|
v-if="props.torrent?.torrent_info?.enclosure?.startsWith('http')"
|
|
variant="plain"
|
|
@click="downloadTorrentFile()"
|
|
>
|
|
<template #prepend>
|
|
<VIcon icon="mdi-download" />
|
|
</template>
|
|
<VListItemTitle>下载种子文件</VListItemTitle>
|
|
</VListItem>
|
|
</VList>
|
|
</VMenu>
|
|
</IconBtn>
|
|
</div>
|
|
</template>
|
|
</VCardItem>
|
|
<VCardText class="text-subtitle-2">
|
|
{{ torrent?.title }}
|
|
</VCardText>
|
|
<VCardText>{{ torrent?.description }}</VCardText>
|
|
<VCardItem
|
|
v-if="torrent?.labels"
|
|
class="pb-3 pt-0 pe-12"
|
|
>
|
|
<VChip
|
|
v-if="torrent?.hit_and_run"
|
|
variant="elevated"
|
|
size="small"
|
|
class="me-1 mb-1 text-white bg-black"
|
|
>
|
|
H&R
|
|
</VChip>
|
|
<VChip
|
|
v-if="torrent?.freedate_diff"
|
|
variant="elevated"
|
|
color="secondary"
|
|
size="small"
|
|
class="me-1 mb-1"
|
|
>
|
|
{{ torrent?.freedate_diff }}
|
|
</VChip>
|
|
<VChip
|
|
v-for="(label, index) in torrent?.labels"
|
|
:key="index"
|
|
variant="elevated"
|
|
size="small"
|
|
color="primary"
|
|
class="me-1 mb-1"
|
|
>
|
|
{{ label }}
|
|
</VChip>
|
|
<VChip
|
|
v-if="meta?.edition"
|
|
variant="elevated"
|
|
size="small"
|
|
class="me-1 mb-1 text-white bg-red-500"
|
|
>
|
|
{{ meta?.edition }}
|
|
</VChip>
|
|
<VChip
|
|
v-if="meta?.resource_pix"
|
|
variant="elevated"
|
|
size="small"
|
|
class="me-1 mb-1 text-white bg-red-500"
|
|
>
|
|
{{ meta?.resource_pix }}
|
|
</VChip>
|
|
<VChip
|
|
v-if="meta?.video_encode"
|
|
variant="elevated"
|
|
size="small"
|
|
class="me-1 mb-1 text-white bg-orange-500"
|
|
>
|
|
{{ meta?.video_encode }}
|
|
</VChip>
|
|
<VChip
|
|
v-if="torrent?.size"
|
|
variant="elevated"
|
|
size="small"
|
|
class="me-1 mb-1 text-white bg-yellow-500"
|
|
>
|
|
{{ formatFileSize(torrent?.size) }}
|
|
</VChip>
|
|
<VChip
|
|
v-if="meta?.resource_team"
|
|
variant="elevated"
|
|
size="small"
|
|
class="me-1 mb-1 text-white bg-cyan-500"
|
|
>
|
|
{{ meta?.resource_team }}
|
|
</VChip>
|
|
<VChip
|
|
v-if="torrent?.downloadvolumefactor !== 1 || torrent?.uploadvolumefactor !== 1"
|
|
:class="
|
|
getVolumeFactorClass(torrent?.downloadvolumefactor, torrent?.uploadvolumefactor)
|
|
"
|
|
variant="elevated"
|
|
size="small"
|
|
class="me-1 mb-1"
|
|
>
|
|
{{ torrent?.volume_factor }}
|
|
</VChip>
|
|
</VCardItem>
|
|
<VCardActions>
|
|
<VBtn
|
|
v-if="props.more && props.more.length > 0"
|
|
@click.stop="showMoreTorrents = !showMoreTorrents"
|
|
>
|
|
<template #append>
|
|
<VIcon :icon="showMoreTorrents ? 'mdi-chevron-up' : 'mdi-chevron-down'" />
|
|
</template>
|
|
更多来源
|
|
</VBtn>
|
|
</VCardActions>
|
|
<VExpandTransition>
|
|
<div v-show="showMoreTorrents">
|
|
<VDivider />
|
|
<VChipGroup class="p-3" column>
|
|
<VChip
|
|
v-for="(item, index) in props.more"
|
|
:key="index"
|
|
@click.stop="
|
|
handleAddDownload(
|
|
item.torrent_info?.site_name,
|
|
item.media_info,
|
|
item.torrent_info,
|
|
)
|
|
"
|
|
>
|
|
<template #append>
|
|
<VBadge
|
|
color="primary"
|
|
:content="`↑${item.torrent_info?.seeders}`"
|
|
inline
|
|
size="small"
|
|
/>
|
|
<VBadge
|
|
v-if="
|
|
item.torrent_info?.downloadvolumefactor !== 1
|
|
|| item.torrent_info?.uploadvolumefactor !== 1
|
|
"
|
|
:content="item.torrent_info?.volume_factor"
|
|
inline
|
|
size="small"
|
|
/>
|
|
</template>
|
|
{{ item.torrent_info.site_name }}
|
|
</VChip>
|
|
</VChipGroup>
|
|
</div>
|
|
</VExpandTransition>
|
|
</VCard>
|
|
</template>
|