288 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			288 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|     <div class="side">
 | |
|       <div v-show="loadComplete" class="load_complete">
 | |
|         <el-scrollbar max-height="80vh">
 | |
|           <div v-if="currentTasks.length === 0">
 | |
|             {{emptyText}}
 | |
|           </div>
 | |
|           <div v-for="gallery in currentTasks" :style="{'height': '20vh', 'background': isDark() ? '': 'FloralWhite', 'border-radius': '1%',
 | |
|           'margin-bottom': '10px'}"
 | |
|                @click="viewInfo(gallery)" id="gallery">
 | |
|             <el-image :src="gallery.thumb_link"
 | |
|                     style="height: 20vh; width: 35vw; float:left"
 | |
|                   fit="contain"
 | |
|                   loading="lazy"
 | |
|             ></el-image>
 | |
|             <div style="font: bold 16px semi-condensed;">
 | |
|               {{adjustGalleryName(gallery.name, 95)}}<br>
 | |
|               页数:{{gallery.pages}}<br>
 | |
|               语言:{{gallery.language}}
 | |
|               <span v-if="gallery.status !== '下载完成'">
 | |
|                 下载进度: {{gallery.progress}}
 | |
|               </span>
 | |
|             </div>
 | |
|           </div>
 | |
|         </el-scrollbar>
 | |
|         <el-col>
 | |
|           <el-row>
 | |
|             <el-button @click="store.state.isShowHistory = true">三</el-button>
 | |
|             <el-select style="width: 22vw" v-model="type">
 | |
|               <el-option value="link" label="链接"/>
 | |
|               <el-option value="keyword" label="关键字"/>
 | |
|             </el-select>
 | |
|             <el-input style="width: 60vw" v-model="param" placeholder="搜索">
 | |
|               <template #append>
 | |
|                 <el-button @click="queryLocalTask">搜索</el-button>
 | |
|               </template>
 | |
|             </el-input>
 | |
|           </el-row>
 | |
|         </el-col>
 | |
| 
 | |
|         <el-row class="pageChanger">
 | |
|           <el-col>
 | |
|           <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: 165px">
 | |
|             <template #prefix>
 | |
|               排序
 | |
|             </template>
 | |
|             <el-option value="name" label="名字"/>
 | |
|             <el-option value="shortName" label="简洁名字"/>
 | |
|             <el-option value="createTime" label="任务创建时间"/>
 | |
|           </el-select>
 | |
|           <el-select v-model="galleryNameType" @change="changeGalleryNameType">
 | |
|             <template #prefix>
 | |
|               显示
 | |
|             </template>
 | |
|             <el-option value="name" label="名字"/>
 | |
|             <el-option value="shortName" label="简洁名字"/>
 | |
|           </el-select>
 | |
|           </el-col>
 | |
|           <el-col>
 | |
|             <el-button @click="toMin">{{min}}</el-button>
 | |
|             <el-button @click="previous">-</el-button>
 | |
|             <el-input v-model="targetPage"
 | |
|                       @change="changePage"
 | |
|                       v-show="isEditingPage"
 | |
|                       @blur="reverseEditMode"
 | |
|                       class="page"
 | |
|                       ref="inputNode"></el-input>
 | |
|             <span @click="reverseEditMode" v-show="!isEditingPage" class="page">{{page}}</span>
 | |
|             <el-button @click="next">+</el-button>
 | |
|             <el-button @click="toMax">{{max}}</el-button>
 | |
|           </el-col>
 | |
|         </el-row>
 | |
|       </div>
 | |
|     </div>
 | |
| 
 | |
|   <el-dialog v-model="isViewing" width="100%" top="0" style="padding: 0">
 | |
|     <div style="height: 20vh; font: bold 16px semi-expanded">
 | |
|         <el-image :src="currentGallery.thumb_link"
 | |
|                   style="float: left; width: 40vw; height: 20vh" fit="contain"/>
 | |
|       {{adjustGalleryName(currentGallery.name, 150)}}
 | |
|     </div>
 | |
|     <div style="font: bold 20px semi-expanded">
 | |
|       页数:{{currentGallery.pages}}                 <br>
 | |
|       语言:{{currentGallery.language}}              <br>
 | |
|       下载时间:{{currentGallery.createTimeDisplay}}  <br>
 | |
|       大小:{{currentGallery.fileSize}}              <br>
 | |
|       分辨率:{{currentGallery.resolution}}          <br>
 | |
|       链接:<a :href="currentGallery.link">link</a>  <br>
 | |
|       下载链接:<a :href="currentGallery.download">link</a><br>
 | |
|       <span v-show="isLion">
 | |
|         downloader:{{currentGallery.downloader}}
 | |
|       </span>
 | |
|       <span v-if="currentGallery.download === undefined">
 | |
|         下载进度: {{currentGallery.progress}}
 | |
|       </span>
 | |
|     </div>
 | |
|     <template #footer>
 | |
|       <el-button @click="downloadTask(currentGallery.download)" :disabled="currentGallery.status !== '下载完成'" size="large">下载</el-button>
 | |
|       <el-button @click="deleteGallery(currentGallery.gid)" :disabled="currentGallery.status !== '下载完成'" size="large">删除</el-button>
 | |
|       <el-button @click="changeGalleryCollect(currentGallery.gid, currentGallery.isCollect)" :disabled="currentGallery.status !== '下载完成'"
 | |
|                  size="large">{{currentGallery.isCollect ? '取消收藏' : '收藏'}}</el-button>
 | |
|       <el-button @click="readOnlineGallery(currentGallery)" size="large">在线看</el-button>
 | |
|     </template>
 | |
|   </el-dialog>
 | |
| 
 | |
|   <OnlineReader/>
 | |
| </template>
 | |
| 
 | |
| <script setup>
 | |
| import store from "../store";
 | |
| import {computed, ref} from "vue";
 | |
| import axios from "axios";
 | |
| import {ElMessage} from "element-plus";
 | |
| import OnlineReader from "./OnlineReader.vue";
 | |
| 
 | |
| //输入
 | |
| let inputNode = ref(null)
 | |
| //是否正在编辑页数
 | |
| let isEditingPage = ref(false)
 | |
| //是否查看详情
 | |
| let isViewing = ref(false)
 | |
| 
 | |
| let category = ref("myDownload")            //myDownload myCollect total
 | |
| let galleryNameType = ref("shortName")      // shortName name
 | |
| let sortType = ref("shortName")             // shortName name createTime
 | |
| let targetPage = ref(1)                     // 当前页数
 | |
| 
 | |
| //查询相关
 | |
| let type = ref("keyword")
 | |
| let param = ref("")
 | |
| 
 | |
| let loadComplete = computed(() => {
 | |
|   return store.state.loadComplete
 | |
| })
 | |
| 
 | |
| let currentTasks = computed(() => {
 | |
|   return store.getters.currentTasks ? store.getters.currentTasks: null
 | |
| })
 | |
| 
 | |
| let min = computed(() => {
 | |
|   return store.getters.min
 | |
| })
 | |
| let max = computed(() => {
 | |
|   if(targetPage.value > store.getters.max)
 | |
|     store.commit("_changePage", store.getters.max)
 | |
|   return store.getters.max
 | |
| })
 | |
| let page = computed(() => {
 | |
|   targetPage.value = store.state.page
 | |
|   return store.state.page
 | |
| })
 | |
| let isLion = computed(() => {
 | |
|   return store.state.userId === 3
 | |
| })
 | |
| 
 | |
| let emptyText = computed(() => {
 | |
|   let action = category.value === 'myDownload' ? '下载': '收藏'
 | |
|   return '您未' + action + '本子'
 | |
| })
 | |
| 
 | |
| //查看详情
 | |
| let currentGallery = ref({name:"name"})
 | |
| 
 | |
| //翻页
 | |
| function next() {
 | |
|   if(targetPage.value < max.value) {
 | |
|     targetPage.value++
 | |
|     store.commit("_changePage", targetPage.value)
 | |
|   }
 | |
| }
 | |
| function previous() {
 | |
|   if(targetPage.value > min.value) {
 | |
|     targetPage.value--
 | |
|     store.commit("_changePage", targetPage.value)
 | |
|   }
 | |
| }
 | |
| function toMax() {
 | |
|   store.commit("_changePage", max.value)
 | |
|   targetPage.value = max.value
 | |
| }
 | |
| function toMin(){
 | |
|   store.commit("_changePage", min.value)
 | |
|   targetPage.value = min.value
 | |
| }
 | |
| function changePage(){
 | |
|   if(targetPage.value >= min.value && targetPage.value <= max.value)
 | |
|     store.commit("_changePage", targetPage.value)
 | |
| }
 | |
| function reverseEditMode(){
 | |
|   isEditingPage.value = !isEditingPage.value
 | |
|   if(isEditingPage)
 | |
|     inputNode.value.focus()
 | |
|   targetPage.value = page.value
 | |
| }
 | |
| 
 | |
| //改变展示类型
 | |
| function changeCategory(){
 | |
|   store.commit("_setCategory", category.value)
 | |
| }
 | |
| function changeGalleryNameType(){
 | |
|   store.commit("_setShowNameType", galleryNameType.value)
 | |
| }
 | |
| function changeSortType(){
 | |
|   store.commit("_setSortType", sortType.value)
 | |
| }
 | |
| 
 | |
| //收藏
 | |
| function changeGalleryCollect(gid, isCollect){
 | |
|   if(isCollect)
 | |
|     store.dispatch("disCollectGallery", gid)
 | |
|   else
 | |
|     store.dispatch("collectGallery", gid)
 | |
| }
 | |
| function queryLocalTask(){
 | |
|   switch (type.value){
 | |
|     case "link":
 | |
|       store.commit("_searchLocalByLink", param.value)
 | |
|       break
 | |
|     case "keyword":
 | |
|       store.commit("_searchLocalByKeyword", param.value)
 | |
|       break
 | |
|   }
 | |
| }
 | |
| 
 | |
| //下载,删除,在线看
 | |
| function downloadTask(link){
 | |
|   window.open(link)
 | |
| }
 | |
| function deleteGallery(gid){
 | |
|   store.dispatch("deleteGallery", gid).then(() => {
 | |
|     isViewing.value = false
 | |
|   })
 | |
| }
 | |
| function readOnlineGallery(gallery){
 | |
|   store.dispatch("readOnlineGallery", gallery)
 | |
| }
 | |
| function viewInfo(gallery){
 | |
|   currentGallery.value = gallery
 | |
|   isViewing.value = true;
 | |
| }
 | |
| 
 | |
| function adjustGalleryName(name, length) {
 | |
|   let truncated = '';
 | |
|   let bytesCount = 0;
 | |
| 
 | |
|   for (const char of name) {
 | |
|     const charCode = char.charCodeAt(0);
 | |
|     const byteLength = charCode < 0x80 ? 1 : charCode < 0x800 ? 2 : 3;
 | |
| 
 | |
|     if (bytesCount + byteLength <= length) {
 | |
|       truncated += char;
 | |
|       bytesCount += byteLength;
 | |
|     } else {
 | |
|       truncated += "..."
 | |
|       break;
 | |
|     }
 | |
|   }
 | |
|   return truncated;
 | |
| }
 | |
| 
 | |
| function isDark(){
 | |
|   return document.querySelector('html').classList.contains('dark')
 | |
| }
 | |
| </script>
 | |
| 
 | |
| <style scoped>
 | |
|   span{
 | |
|     display: block;
 | |
|   }
 | |
|   .pageChanger{
 | |
|     text-align: center;
 | |
|   }
 | |
|   .el-select{
 | |
|     width: 135px;
 | |
|   }
 | |
|   .page{
 | |
|     display: inline-block;
 | |
|     width: 50px;
 | |
|   }
 | |
| </style> | 
