精简代码,抽取公共代码为函数,修复bug(同步更新)

This commit is contained in:
chuzhongzai 2023-02-27 22:52:38 +08:00
parent 0e59b1aa43
commit 73d902253e
3 changed files with 184 additions and 156 deletions

View File

@ -208,7 +208,7 @@ function queryLocalTask(){
} }
function resetLocalQuery(){ function resetLocalQuery(){
store.commit("_searchLocalByKeyword", "") store.commit("_searchLocalByKeyword", "")
store.commit("_searchLocalByTaf", ['']) store.commit("_searchLocalByTag", [''])
param.value = "" param.value = ""
} }

View File

@ -2,7 +2,7 @@
<div class="side" style="width: 100%"> <div class="side" style="width: 100%">
<span v-show="loadComplete">{{showType === 'gallery' || showType === 'collect' ? '本子' : '视频'}}历史</span> <span v-show="loadComplete">{{showType === 'gallery' || showType === 'collect' ? '本子' : '视频'}}历史</span>
<div v-show="loadComplete" class="load_complete"> <div v-show="loadComplete" class="load_complete">
<el-table :data="galleryTasks" v-show="isShowGalleryHistory"> <el-table :data="currentTasks" v-show="showType === 'gallery'" :empty-text="emptyText" :row-key="gallery=>gallery.gid">
<el-table-column type="expand"> <el-table-column type="expand">
<template #default="props"> <template #default="props">
@ -28,7 +28,7 @@
<el-table-column label="名字" width="300vw"> <el-table-column label="名字" width="300vw">
<template #default="scoped"> <template #default="scoped">
<span @mouseover="showThumbnail(scoped.row)"> <span @mouseover="showThumbnail(scoped.row)">
{{showNameType === 'shortName' ? scoped.row.shortName: scoped.row.name}} {{galleryNameType === 'shortName' ? scoped.row.shortName: scoped.row.name}}
</span> </span>
</template> </template>
</el-table-column> </el-table-column>
@ -49,7 +49,7 @@
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<el-table :data="videoTasks" v-show="isShowVideoHistory"> <el-table :data="currentTasks" v-show="showType === 'video'" :empty-text="emptyText" :row-key="video=>video.id">
<el-table-column type="expand"> <el-table-column type="expand">
<template #default="props"> <template #default="props">
名字:{{props.row.name}} <br> 名字:{{props.row.name}} <br>
@ -94,17 +94,30 @@
<el-row class="pageChanger"> <el-row class="pageChanger">
<el-col> <el-col>
筛选:<el-select v-model="showType" @change="changeShowType" class="el-select"> <el-select v-model="showType" @change="changeShowType" class="el-select" style="width: 75px">
<el-option value="gallery" label="本子"/> <el-option value="gallery" label="本子"/>
<el-option value="video" label="视频"/> <el-option value="video" label="视频"/>
<el-option value="collect" label="收藏"/>
</el-select> </el-select>
排列顺序:<el-select v-model="sortType" @change="changeSortType"> <el-select v-model="category" @change="changeCategory">
<template #prefix>
分类
</template>
<el-option value="myCollect" label="我的收藏"/>
<el-option value="myDownload" label="我的下载"/>
<el-option value="total" label="全部"/>
</el-select>
<el-select v-model="sortType" @change="changeSortType" style="width: 170px">
<template #prefix>
排序
</template>
<el-option value="name" label="名字"/> <el-option value="name" label="名字"/>
<el-option value="shortName" label="简洁名字"/> <el-option value="shortName" label="简洁名字" v-show="showType === 'gallery'"/>
<el-option value="createTime" label="任务创建时间"/> <el-option value="createTime" label="任务创建时间"/>
</el-select> </el-select>
显示:<el-select v-model="showNameType" @change="changeShowNameType"> <el-select v-model="galleryNameType" @change="changeGalleryNameType" v-show="showType === 'gallery'">
<template #prefix>
显示
</template>
<el-option value="name" label="名字"/> <el-option value="name" label="名字"/>
<el-option value="shortName" label="简洁名字"/> <el-option value="shortName" label="简洁名字"/>
</el-select> </el-select>
@ -141,8 +154,8 @@
</el-footer> </el-footer>
</el-dialog> </el-dialog>
<el-dialog v-model="isOnlineReading" title="在线预览" @close="closeOnlineReader" width="90%" style="margin-top: 0; margin-bottom: 0; padding: 0"> <el-dialog v-model="isOnlineReading" title="在线预览" @close="closeOnlineReading" width="90%" style="margin-top: 0; margin-bottom: 0; padding: 0">
<el-scrollbar height="84vh"> <el-scrollbar height="84vh" ref="onlineReadingScrollbar">
<el-image v-for="(link, index) in currentLinks" :src="link" :style="{'width': imageWidth, 'padding-right': imagePadding, 'background-color': 'ghostwhite'}" <el-image v-for="(link, index) in currentLinks" :src="link" :style="{'width': imageWidth, 'padding-right': imagePadding, 'background-color': 'ghostwhite'}"
:preview-src-list="currentLinks" :initial-index="index" loading="lazy"/> :preview-src-list="currentLinks" :initial-index="index" loading="lazy"/>
</el-scrollbar> </el-scrollbar>
@ -180,11 +193,14 @@ let tempTag = ref("")
let tempGid = ref("") let tempGid = ref("")
let tempId = ref("") let tempId = ref("")
let showNameType = ref("shortName") // shortName name let category = ref("myDownload") //myDownload myCollect total
let galleryNameType = ref("shortName") // shortName name
let showType = ref("gallery") // gallery video collect let showType = ref("gallery") // gallery video collect
let sortType = ref("shortName") // shortName name createTime let sortType = ref("shortName") // shortName name createTime
let targetPage = ref(1) // let targetPage = ref(1) //
let onlineReadingScrollbar = ref(null)
// //
let debounceTimer = 0 let debounceTimer = 0
// //
@ -192,18 +208,8 @@ let loadComplete = computed(() => {
return store.state.loadComplete return store.state.loadComplete
}) })
let galleryTasks = computed(() => { let currentTasks = computed(() => {
return store.getters.galleryTasks ? store.getters.galleryTasks: null return store.getters.currentTasks ? store.getters.currentTasks: null
})
let videoTasks = computed(() => {
return store.getters.videoTasks ? store.getters.videoTasks: null
})
let isShowVideoHistory = computed(() => {
return store.state.showType === "video"
})
let isShowGalleryHistory = computed(() => {
return store.state.showType === "gallery" || store.state.showType === "collect"
}) })
let isOnlineReading = computed(() => { let isOnlineReading = computed(() => {
return store.state.isOnlineReading return store.state.isOnlineReading
@ -225,6 +231,12 @@ let isLion = computed(() => {
return store.state.userId === 3 return store.state.userId === 3
}) })
let emptyText = computed(() => {
let type = showType.value === 'gallery' ? '本子': '视频'
let action = category.value === 'myDownload' ? '下载': '收藏'
return '您未' + action + type
})
//线 //线
let currentLinks = computed(() => { let currentLinks = computed(() => {
return store.state.currentLinks return store.state.currentLinks
@ -270,24 +282,19 @@ function reverseEditMode(){
} }
// //
function changeCategory(){
store.commit("_setCategory", category.value)
}
function changeShowType(){ function changeShowType(){
if(showType.value === 'video')
sortType.value = 'name'
store.commit("_setShowType", showType.value) store.commit("_setShowType", showType.value)
} }
function changeShowNameType(){ function changeGalleryNameType(){
store.commit("_setShowNameType", showNameType.value) store.commit("_setShowNameType", galleryNameType.value)
if(showNameType.value !== sortType.value){
store.commit("_setSortType", showNameType.value)
sortType.value = showNameType.value
}
} }
function changeSortType(){ function changeSortType(){
store.commit("_setSortType", sortType.value) store.commit("_setSortType", sortType.value)
if(sortType.value !== showNameType.value && sortType.value !== "createTime") {
store.commit("_setShowNameType", sortType.value)
showNameType.value = sortType.value
}
} }
//,, //,,
@ -314,7 +321,7 @@ function editVideoTag(id, tag){
isEditingTag.value = true isEditingTag.value = true
} }
function submitGalleryTag(){ function submitGalleryTag(){
store.dispatch("updateTag", {gid:tempGid.value, tag:tempTag.value}) store.dispatch("updateGalleryTag", {gid:tempGid.value, tag:tempTag.value})
tempTag.value = '' tempTag.value = ''
tempGid.value = '' tempGid.value = ''
isEditingTag.value = false isEditingTag.value = false
@ -342,8 +349,9 @@ function deleteVideo(id){
function onlineGalleryReader(gid){ function onlineGalleryReader(gid){
store.dispatch("queryOnlineLinks", gid) store.dispatch("queryOnlineLinks", gid)
} }
function closeOnlineReader(){ function closeOnlineReading(){
store.state.isOnlineReading = false store.state.isOnlineReading = false
onlineReadingScrollbar.value.setScrollTop(0)
} }
function shareGallery(data){ function shareGallery(data){
const {gid, shortName} = data const {gid, shortName} = data
@ -401,7 +409,7 @@ function showThumbnail(gallery){
margin-top: 5vh; margin-top: 5vh;
} }
.el-select{ .el-select{
width: 125px; width: 135px;
} }
.page{ .page{
display: inline-block; display: inline-block;

View File

@ -178,7 +178,7 @@ const actions = {
//初始化 //初始化
context.dispatch("loadMaskDomain").then() context.dispatch("loadMaskDomain").then()
context.dispatch("loadWeekUsedAmount").then() context.dispatch("loadWeekUsedAmount").then()
context.dispatch("updateGalleryTasks", "all").then() context.dispatch("updateGalleryTasks", "all").then(() => confirmCurrentTask(context.state))
context.dispatch("updateVideoTasks", "all").then() context.dispatch("updateVideoTasks", "all").then()
//获取图片合适长度 //获取图片合适长度
@ -430,7 +430,7 @@ const mutations = {
} }
//处理是否下载 //处理是否下载
if(task.downloader === state.username) if(task.downloader === state.userId)
state.downloadGallery.push(task) state.downloadGallery.push(task)
state.totalGalleryTask.push(task) state.totalGalleryTask.push(task)
@ -526,7 +526,7 @@ const mutations = {
} }
//处理是否下载 //处理是否下载
if(task.downloader === state.username) if(task.downloader === state.userId)
state.downloadVideo.push(task) state.downloadVideo.push(task)
state.totalVideoTask.push(task) state.totalVideoTask.push(task)
@ -576,17 +576,13 @@ const mutations = {
localStorage.removeItem("auth") localStorage.removeItem("auth")
}, },
_searchLocalByLink(state, link){ _searchLocalByLink(state, link){
let tasks let tasks = state.currentTasks
let i = 0 let i = 0
let gid = null let gid = null
let name = null let name = null
if(state.showType === "gallery") { if(state.showType === "gallery")
tasks = state.totalGalleryTask
gid = link.split("/")[4] gid = link.split("/")[4]
}
else
tasks = state.totalVideoTask
if(gid === null) if(gid === null)
for (i = 0; i < tasks.length; i++) { for (i = 0; i < tasks.length; i++) {
@ -612,17 +608,15 @@ const mutations = {
state.searchTask.splice(0) state.searchTask.splice(0)
if(keyword.trim() !== '') { if(keyword.trim() !== '') {
state.page = 1 state.page = 1
let tasks let tasks = state.currentTasks
if (state.showType === "video")
tasks = state.totalVideoTask
else
tasks = state.totalGalleryTask
tasks.forEach((task) => { tasks.forEach((task) => {
if (task.name.includes(keyword)) if (task.name.includes(keyword))
state.searchTask.push(task) state.searchTask.push(task)
}) })
if (state.searchTask.length === 0) if (state.searchTask.length === 0)
ElMessage("未找到该关键字的任务") ElMessage("未找到该关键字的任务")
else
state.currentTasks = state.searchTask
} }
}, },
_searchLocalByTag(state, tags) { _searchLocalByTag(state, tags) {
@ -631,10 +625,11 @@ const mutations = {
let tagAmount = tags.length let tagAmount = tags.length
let hitAmount let hitAmount
let tasks = state.totalGalleryTask let tasks = state.currentTasks
if (tags[0].trim() !== '') { if (tags[0].trim() !== '') {
tasks.forEach((task) => { tasks.forEach((task) => {
if('tag' in task) {
hitAmount = 0 hitAmount = 0
tags.forEach((tag) => { tags.forEach((tag) => {
if (task.tag.includes(tag)) if (task.tag.includes(tag))
@ -642,25 +637,22 @@ const mutations = {
}) })
if (hitAmount === tagAmount) if (hitAmount === tagAmount)
state.searchTask.push(task) state.searchTask.push(task)
}
}) })
if (state.searchTask.length === 0) if (state.searchTask.length === 0)
ElMessage("未找到符合这些tag的任务") ElMessage("未找到符合这些tag的任务")
else
state.currentTasks = state.searchTask
} }
}, },
_deleteGallery(state, gid){ _deleteGallery(state, gid){
for(let i=0; i<state.totalGalleryTask.length; i++) let tasks = [state.totalGalleryTask, state.downloadGallery, state.collectGallery]
if(state.totalGalleryTask[i].gid === gid){ deleteTask(tasks, 'gid', gid)
state.totalGalleryTask.splice(i, 1)
break
}
}, },
_deleteVideo(state, id){ _deleteVideo(state, id){
for(let i=0; i<state.totalVideoTask.length; i++) let tasks = [state.totalVideoTask, state.downloadVideo, state.collectVideo]
if(state.totalGalleryTask[i].id === id){ deleteTask(tasks, 'id', id)
state.totalVideoTask.splice(i, 1)
break
}
}, },
_setChosenGallery(state,data){ _setChosenGallery(state,data){
if(data.gallery === false) { if(data.gallery === false) {
@ -685,33 +677,21 @@ const mutations = {
} }
state.chosenVideo = data.video state.chosenVideo = data.video
}, },
_setCategory(state, category){
state.category = category
confirmCurrentTask(state)
},
_setShowType(state, showType){ _setShowType(state, showType){
state.showType = showType state.showType = showType
confirmCurrentTask(state)
if(showType === 'video' && state.sortType === "shortName") {
state.sortType = 'name'
sortTasks(state)
}
}, },
_setSortType(state, sortType){ _setSortType(state, sortType){
state.sortType = sortType state.sortType = sortType
switch (sortType) { sortTasks(state)
case "name":
state.totalGalleryTask = state.totalGalleryTask.sort((before, after) => {
return before.name > after.name ? 1: -1
})
state.totalVideoTask = state.totalVideoTask.sort((before, after) => {
return before.name > after.name ? 1: -1
})
break
case "shortName":
state.totalGalleryTask = state.totalGalleryTask.sort((before, after) => {
return before.shortName > after.shortName ? 1: -1
})
break
case "createTime":
state.totalGalleryTask = state.totalGalleryTask.sort((before, after) => {
return before.createTime - after.createTime
})
state.totalVideoTask = state.totalVideoTask.sort((before, after) => {
return before.createTime - after.createTime
})
}
}, },
_setShowNameType(state, type){ _setShowNameType(state, type){
if(type === "shortName") if(type === "shortName")
@ -784,53 +764,32 @@ const state = {
isInclude: false, //是否搜索到任务 isInclude: false, //是否搜索到任务
searchTask: [], //搜索到的任务 searchTask: [], //搜索到的任务
showType:'gallery', //展示类型 showType:'gallery', //展示类型
category: 'myDownload', //分类
sortType:'shortName', //排序类型 sortType:'shortName', //排序类型
currentTasks: [], //当前任务
weekUsed: {}, //每周用量 weekUsed: {}, //每周用量
maskDomain: [] //伪装域名 maskDomain: [] //伪装域名
} }
const getters = { const getters = {
galleryTasks(state){ currentTasks(state){
if(state.showType === 'collect') return state.currentTasks.slice((state.page-1)*state.length, state.page*state.length)
return state.collectGallery.slice((state.page-1)*state.length, state.page*state.length)
if(state.searchTask.length !== 0)
return state.searchTask.slice((state.page-1)*state.length, state.page*state.length)
if(state.totalGalleryTask.length !== 0)
return state.totalGalleryTask.slice((state.page-1)*state.length, state.page*state.length)
return null
},
videoTasks(state){
if(state.searchTask.length !== 0)
return state.searchTask.slice((state.page-1)*state.length, state.page*state.length)
if(state.totalVideoTask.length !== 0)
return state.totalVideoTask.slice((state.page-1)*state.length, state.page*state.length)
return null
}, },
min(){ min(){
return 1 return 1
}, },
max(state){ max(state){
let max = 0 let max = 0
let tasks let tasks = state.currentTasks
if(state.showType === 'collect')
tasks = state.collectGallery
else if(state.searchTask.length !== 0)
tasks = state.searchTask
else if(state.showType === "gallery")
tasks = state.totalGalleryTask
else if(state.showType === "video")
tasks = state.totalVideoTask
if(!tasks) if(!tasks)
return 1 return 1
max = Math.floor(tasks.length/state.length) max = Math.floor(tasks.length/state.length)
if(tasks.length % state.length !== 0) if(tasks.length % state.length !== 0 || max === 0)
max += 1 max += 1
if(max === 0)
return 1
return max return max
} }
} }
@ -875,3 +834,64 @@ function getShortname(name){
return name return name
} }
} }
function confirmCurrentTask(state){
if(state.showType === "gallery")
switch (state.category){
case 'myDownload':
state.currentTasks = state.downloadGallery
break
case 'myCollect':
state.currentTasks = state.collectGallery
break
case 'total':
state.currentTasks = state.totalGalleryTask
break
}
else
switch (state.category){
case 'myDownload':
state.currentTasks = state.downloadVideo
break
case 'myCollect':
state.currentTasks = state.collectGallery
break
case 'total':
state.currentTasks = state.totalVideoTask
break
}
}
function sortTasks(state){
switch (state.sortType) {
case "name":
state.currentTasks = state.currentTasks.sort((before, after) => {
return before.name > after.name ? 1: -1
})
state.currentTasks = state.currentTasks.sort((before, after) => {
return before.name > after.name ? 1: -1
})
break
case "shortName":
state.currentTasks = state.currentTasks.sort((before, after) => {
return before.shortName > after.shortName ? 1: -1
})
break
case "createTime":
state.currentTasks = state.currentTasks.sort((before, after) => {
return before.createTime - after.createTime
})
state.currentTasks = state.currentTasks.sort((before, after) => {
return before.createTime - after.createTime
})
}
}
function deleteTask(tasks, key, value){
for(let j=0; j < tasks.length; j++)
for(let i=0; i<tasks[j].length; i++)
if(tasks[j][i][key] === value){
tasks[j].splice(i, 1)
break
}
}