mirror of
				https://github.com/rubickCenter/rubick
				synced 2025-10-26 22:51:25 +08:00 
			
		
		
		
	Merge pull request #47 from bijiwiki-community/dev-tcsnzh
使搜索框在存在输入内容时mousedown不会造成拖动
This commit is contained in:
		
							
								
								
									
										11
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,12 +1,21 @@ | ||||
| .DS_Store | ||||
|  | ||||
| dist/ | ||||
| dist/electron/* | ||||
| dist/web/* | ||||
|  | ||||
| build/* | ||||
| !build/icons/ | ||||
|  | ||||
| node_modules/ | ||||
|  | ||||
| npm-debug.log | ||||
| npm-debug.log.* | ||||
| .pnpm-debug.log | ||||
|  | ||||
| thumbs.db | ||||
| !.gitkeep | ||||
|  | ||||
| .idea | ||||
| dist/ | ||||
| .vscode | ||||
|  | ||||
|   | ||||
| @@ -1,5 +0,0 @@ | ||||
| { | ||||
|   "0 debug pnpm:scope": { | ||||
|     "selected": 1 | ||||
|   } | ||||
| } | ||||
| @@ -1,6 +1,6 @@ | ||||
| <template> | ||||
|   <div @mousedown="drag" > | ||||
|     <a-layout  id="components-layout"> | ||||
|   <div @mousedown="drag"> | ||||
|     <a-layout id="components-layout"> | ||||
|       <div v-if="!searchType" class="rubick-select"> | ||||
|         <div class="tag-container" v-if="selected"> | ||||
|           <a-tag | ||||
| @@ -16,23 +16,26 @@ | ||||
|         <a-input | ||||
|           id="search" | ||||
|           :placeholder=" | ||||
|           subPlaceHolder && selected && selected.key === 'plugin-container' | ||||
|             ? subPlaceHolder | ||||
|             : 'Hi, Rubick' | ||||
|         " | ||||
|             subPlaceHolder && selected && selected.key === 'plugin-container' | ||||
|               ? subPlaceHolder | ||||
|               : 'Hi, Rubick' | ||||
|           " | ||||
|           @mousedown.stop="dragWhenInput" | ||||
|           class="main-input" | ||||
|           @change="(e) => search({ value: e.target.value })" | ||||
|           @keydown.ctrl.86="shouldPaste" | ||||
|           :value="searchValue" | ||||
|           :maxLength="selected && selected.key !== 'plugin-container' ? 0 : 1000" | ||||
|           :maxLength=" | ||||
|             selected && selected.key !== 'plugin-container' ? 0 : 1000 | ||||
|           " | ||||
|           @keydown.down="(e) => changeCurrent(1)" | ||||
|           @keydown.up="() => changeCurrent(-1)" | ||||
|           @keypress.enter=" | ||||
|           (e) => targetSearch({ value: e.target.value, type: 'enter' }) | ||||
|         " | ||||
|             (e) => targetSearch({ value: e.target.value, type: 'enter' }) | ||||
|           " | ||||
|           @keypress.space=" | ||||
|           (e) => targetSearch({ value: e.target.value, type: 'space' }) | ||||
|         " | ||||
|             (e) => targetSearch({ value: e.target.value, type: 'space' }) | ||||
|           " | ||||
|         > | ||||
|           <div @click="goMenu" class="suffix-tool" slot="suffix"> | ||||
|             <a-icon | ||||
| @@ -42,12 +45,14 @@ | ||||
|             /> | ||||
|             <div v-if="selected && selected.icon" style="position: relative"> | ||||
|               <a-spin v-show="pluginLoading" class="loading"> | ||||
|                 <a-icon slot="indicator" type="loading" style="font-size: 42px" spin /> | ||||
|                 <a-icon | ||||
|                   slot="indicator" | ||||
|                   type="loading" | ||||
|                   style="font-size: 42px" | ||||
|                   spin | ||||
|                 /> | ||||
|               </a-spin> | ||||
|               <img | ||||
|                 class="icon-tool" | ||||
|                 :src="selected.icon" | ||||
|               /> | ||||
|               <img class="icon-tool" :src="selected.icon" /> | ||||
|             </div> | ||||
|             <div v-else class="rubick-logo"> | ||||
|               <img src="./assets/imgs/logo.png" /> | ||||
| @@ -87,19 +92,19 @@ | ||||
|             :placeholder="subPlaceHolder" | ||||
|             class="sub-input" | ||||
|             @change=" | ||||
|             (e) => | ||||
|               search({ | ||||
|                 value: e.target.value, | ||||
|                 searchType: pluginInfo.searchType, | ||||
|               }) | ||||
|           " | ||||
|               (e) => | ||||
|                 search({ | ||||
|                   value: e.target.value, | ||||
|                   searchType: pluginInfo.searchType, | ||||
|                 }) | ||||
|             " | ||||
|             :value="searchValue" | ||||
|             @keypress.enter=" | ||||
|             (e) => targetSearch({ value: e.target.value, type: 'enter' }) | ||||
|           " | ||||
|               (e) => targetSearch({ value: e.target.value, type: 'enter' }) | ||||
|             " | ||||
|             @keypress.space=" | ||||
|             (e) => targetSearch({ value: e.target.value, type: 'space' }) | ||||
|           " | ||||
|               (e) => targetSearch({ value: e.target.value, type: 'space' }) | ||||
|             " | ||||
|           ></a-input> | ||||
|         </div> | ||||
|  | ||||
| @@ -121,6 +126,7 @@ import { | ||||
|   searchKeyValues, | ||||
|   fileLists, | ||||
| } from "./assets/common/utils"; | ||||
| import { commonConst } from "../main/common/utils"; | ||||
| const opConfig = remote.getGlobal("opConfig"); | ||||
| const { Menu, MenuItem } = remote; | ||||
|  | ||||
| @@ -167,20 +173,21 @@ export default { | ||||
|         const feature = plugin.features; | ||||
|         feature.forEach((fe) => { | ||||
|           const cmd = searchKeyValues(fe.cmds, args)[0]; | ||||
|           const systemPlugin = fileLists.filter( | ||||
|             (plugin) => { | ||||
|               let has = false; | ||||
|               plugin.keyWords.some(keyWord => { | ||||
|                 if (keyWord.toLocaleUpperCase().indexOf(args.toLocaleUpperCase()) >= 0) { | ||||
|                   has = keyWord; | ||||
|                   plugin.name = keyWord; | ||||
|                   return true; | ||||
|                 } | ||||
|                 return false; | ||||
|               }); | ||||
|               return has; | ||||
|             } | ||||
|           )[0]; | ||||
|           const systemPlugin = fileLists.filter((plugin) => { | ||||
|             let has = false; | ||||
|             plugin.keyWords.some((keyWord) => { | ||||
|               if ( | ||||
|                 keyWord.toLocaleUpperCase().indexOf(args.toLocaleUpperCase()) >= | ||||
|                 0 | ||||
|               ) { | ||||
|                 has = keyWord; | ||||
|                 plugin.name = keyWord; | ||||
|                 return true; | ||||
|               } | ||||
|               return false; | ||||
|             }); | ||||
|             return has; | ||||
|           })[0]; | ||||
|           if (cmd) { | ||||
|             config = { | ||||
|               cmd: cmd, | ||||
| @@ -210,18 +217,56 @@ export default { | ||||
|     ...mapActions("main", ["onSearch", "showMainUI", "openPlugin"]), | ||||
|     ...mapMutations("main", ["commonUpdate"]), | ||||
|     shouldPaste(e) { | ||||
|       let filePath = ''; | ||||
|       if (process.platform === 'win32') { | ||||
|         const rawFilePath = clipboard.read('FileNameW'); | ||||
|         filePath = rawFilePath.replace(new RegExp(String.fromCharCode(0), 'g'), ''); | ||||
|         if (filePath.indexOf('plugin.json') >= 0) { | ||||
|       let filePath = ""; | ||||
|       if (commonConst.windows()) { | ||||
|         const rawFilePath = clipboard.read("FileNameW"); | ||||
|         filePath = rawFilePath.replace( | ||||
|           new RegExp(String.fromCharCode(0), "g"), | ||||
|           "" | ||||
|         ); | ||||
|         if (filePath.indexOf("plugin.json") >= 0) { | ||||
|           this.search({ | ||||
|             filePath, | ||||
|             disableDebounce: true, | ||||
|           }); | ||||
|         } | ||||
|       } else if (commonConst.linux()) { | ||||
|         const text = clipboard.readText("selection"); | ||||
|         // 在gnome的文件管理器中,复制文件的结果通常是 | ||||
|         // | ||||
|         // x-special/nautilus-clipboard | ||||
|         // copy | ||||
|         // file:///home/admin/dir/plugin.json | ||||
|         const splitLF = text.split(" "); | ||||
|         let pathUrl; | ||||
|         if ( | ||||
|           splitLF.length == 3 && | ||||
|           splitLF[0] === "x-special/nautilus-clipboard" && | ||||
|           splitLF[1] === "copy" && | ||||
|           (pathUrl = splitLF[2]).startsWith("file://") && | ||||
|           pathUrl.indexOf("plugin.json") >= 0 | ||||
|         ) { | ||||
|           filePath = pathUrl.slice(7); | ||||
|           this.search({ | ||||
|             filePath, | ||||
|             disableDebounce: true, | ||||
|           }); | ||||
|         } | ||||
|         // 其他的发行版、文件管理器尚未测试 | ||||
|       } | ||||
|     }, | ||||
|     /** | ||||
|      * @param {Object} v 搜索配置对象。 | ||||
|      * 若v.disableDebounce为true,则不会触发防抖动保护。 | ||||
|      * 该值的作用是让search()方法被多个监听器同时调用时,在某些情况下无视其他监听器的防抖动保护。 | ||||
|      * 其他属性 v.value、v.filePath 参见 src/renderer/store/modules/main.js的onSearch函数。 | ||||
|      */ | ||||
|     search(v) { | ||||
|       console.log("search was called , param v is :", v); | ||||
|       if (!v.disableDebounce) { | ||||
|         this.onSearch(v); | ||||
|         return; | ||||
|       } | ||||
|       if (!this.searchFn) { | ||||
|         this.searchFn = debounce(this.onSearch, 200); | ||||
|       } | ||||
| @@ -288,9 +333,13 @@ export default { | ||||
|       ipcRenderer.send("changeWindowSize-rubick", { | ||||
|         height: getWindowHeight([]), | ||||
|       }); | ||||
|       this.$router.push({ | ||||
|         path: "/home", | ||||
|       }); | ||||
|       if (this.$router.history.current.fullPath !== "/home") { | ||||
|         // 该if是为了避免跳转到相同路由而报错。 | ||||
|         // (之前在输入栏为空时按退格会疯狂报错) | ||||
|         this.$router.push({ | ||||
|           path: "/home", | ||||
|         }); | ||||
|       } | ||||
|     }, | ||||
|     newWindow() { | ||||
|       ipcRenderer.send("new-window", { | ||||
| @@ -340,8 +389,13 @@ export default { | ||||
|       this.changePath({ key: "market" }); | ||||
|     }, | ||||
|     drag() { | ||||
|       ipcRenderer.send('window-move'); | ||||
|     } | ||||
|       ipcRenderer.send("window-move"); | ||||
|     }, | ||||
|     dragWhenInput(e) { | ||||
|       if (this.searchValue == "") { | ||||
|         ipcRenderer.send("window-move"); | ||||
|       } | ||||
|     }, | ||||
|   }, | ||||
|   computed: { | ||||
|     ...mapState("main", [ | ||||
| @@ -479,7 +533,7 @@ export default { | ||||
|     cursor: pointer; | ||||
|   } | ||||
|   .loading { | ||||
|     position:absolute; | ||||
|     position: absolute; | ||||
|     top: 0; | ||||
|     left: 0; | ||||
|   } | ||||
|   | ||||
| @@ -2,14 +2,19 @@ | ||||
|   <div class="market"> | ||||
|     <a-carousel v-if="bannerList && !!bannerList.length" arrows> | ||||
|       <div | ||||
|           slot="prevArrow" | ||||
|           slot-scope="props" | ||||
|           class="custom-slick-arrow" | ||||
|           style="left: 10px;zIndex: 1" | ||||
|         slot="prevArrow" | ||||
|         slot-scope="props" | ||||
|         class="custom-slick-arrow" | ||||
|         style="left: 10px;zIndex: 1" | ||||
|       > | ||||
|         <a-icon type="left-circle" /> | ||||
|       </div> | ||||
|       <div slot="nextArrow" slot-scope="props" class="custom-slick-arrow" style="right: 10px"> | ||||
|       <div | ||||
|         slot="nextArrow" | ||||
|         slot-scope="props" | ||||
|         class="custom-slick-arrow" | ||||
|         style="right: 10px" | ||||
|       > | ||||
|         <a-icon type="right-circle" /> | ||||
|       </div> | ||||
|       <div v-for="banner in bannerList"> | ||||
| @@ -18,38 +23,49 @@ | ||||
|     </a-carousel> | ||||
|     <a-divider v-if="bannerList && !!bannerList.length"></a-divider> | ||||
|     <h2>插件</h2> | ||||
|     <a-list item-layout="horizontal" style="width: 100%" :grid="{ gutter: 16, column: 2 }" :data-source="pluginList"> | ||||
|     <a-list | ||||
|       item-layout="horizontal" | ||||
|       style="width: 100%" | ||||
|       :grid="{ gutter: 16, column: 2 }" | ||||
|       :data-source="pluginList" | ||||
|     > | ||||
|       <a-list-item slot="renderItem" slot-scope="item, index"> | ||||
|         <a-button v-if="showButton(item)" :loading="loading[index]" type="link" slot="actions" @click="download(index, item)"> | ||||
|           <a-icon v-show="!loading[index]" style="font-size: 20px;" type="cloud-download" /> | ||||
|         <a-button | ||||
|           v-if="showButton(item)" | ||||
|           :loading="loading[index]" | ||||
|           type="link" | ||||
|           slot="actions" | ||||
|           @click="download(index, item)" | ||||
|         > | ||||
|           <a-icon | ||||
|             v-show="!loading[index]" | ||||
|             style="font-size: 20px;" | ||||
|             type="cloud-download" | ||||
|           /> | ||||
|         </a-button> | ||||
|  | ||||
|  | ||||
|         <a-list-item-meta | ||||
|             @click="showPannel(item, index)" | ||||
|             :description="item.description" | ||||
|           @click="showPannel(item, index)" | ||||
|           :description="item.description" | ||||
|         > | ||||
|           <div slot="title">{{ item.pluginName }}</div> | ||||
|           <a-avatar | ||||
|               slot="avatar" | ||||
|               :src="item.logo" | ||||
|           /> | ||||
|           <a-avatar slot="avatar" :src="item.logo" /> | ||||
|         </a-list-item-meta> | ||||
|       </a-list-item> | ||||
|     </a-list> | ||||
|     <a-drawer | ||||
|       placement="right" | ||||
|       :visible="show" | ||||
|       @close="show=false" | ||||
|       @close="show = false" | ||||
|       width="100%" | ||||
|     > | ||||
|       <div class="plugin-market-desc" slot="title"> | ||||
|         <img width="80" :src="currentSelect.logo"/> | ||||
|         <img width="80" :src="currentSelect.logo" /> | ||||
|         <div class="desc"> | ||||
|           <h4>{{currentSelect.pluginName}}</h4> | ||||
|           <h4>{{ currentSelect.pluginName }}</h4> | ||||
|           <div class="info"> | ||||
|             <div class="actor"> | ||||
|               开发者:{{currentSelect.author}} | ||||
|               开发者:{{ currentSelect.author }} | ||||
|               <a-button | ||||
|                 v-if="showButton(currentSelect)" | ||||
|                 :loading="loading[currentSelect.index]" | ||||
| @@ -60,7 +76,7 @@ | ||||
|                 获取 | ||||
|               </a-button> | ||||
|             </div> | ||||
|             <div>{{currentSelect.description}}</div> | ||||
|             <div>{{ currentSelect.description }}</div> | ||||
|           </div> | ||||
|         </div> | ||||
|       </div> | ||||
| @@ -70,10 +86,10 @@ | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import api from '../../../assets/api'; | ||||
| import {mapActions, mapState} from 'vuex'; | ||||
| import api from "../../../assets/api"; | ||||
| import { mapActions, mapState } from "vuex"; | ||||
| import marked from "marked"; | ||||
| import {shell} from "electron"; | ||||
| import { shell } from "electron"; | ||||
| const rendererMD = new marked.Renderer(); | ||||
|  | ||||
| export default { | ||||
| @@ -83,8 +99,8 @@ export default { | ||||
|       loading: {}, | ||||
|       bannerList: [], | ||||
|       show: false, | ||||
|       currentSelect: {} | ||||
|     } | ||||
|       currentSelect: {}, | ||||
|     }; | ||||
|   }, | ||||
|   async created() { | ||||
|     const [result, bannerRes] = await Promise.all([ | ||||
| @@ -93,7 +109,7 @@ export default { | ||||
|     ]); | ||||
|     this.pluginList = result.result; | ||||
|     this.bannerList = bannerRes.result; | ||||
|     console.log(bannerRes) | ||||
|     console.log(bannerRes); | ||||
|   }, | ||||
|  | ||||
|   methods: { | ||||
| @@ -108,7 +124,9 @@ export default { | ||||
|       this.$set(this.loading, index, false); | ||||
|     }, | ||||
|     showButton(item) { | ||||
|       return !this.devPlugins.filter(plugin => (plugin.name === item.name && plugin.type === 'prod')).length; | ||||
|       return !this.devPlugins.filter( | ||||
|         (plugin) => plugin.name === item.name && plugin.type === "prod" | ||||
|       ).length; | ||||
|     }, | ||||
|     showPannel(item, index) { | ||||
|       this.show = true; | ||||
| @@ -117,13 +135,13 @@ export default { | ||||
|     }, | ||||
|     jumpTo(link) { | ||||
|       if (link) { | ||||
|         shell.openExternal(link) | ||||
|         shell.openExternal(link); | ||||
|       } | ||||
|     }, | ||||
|     ...mapActions('main', ['downloadPlugin']) | ||||
|     ...mapActions("main", ["downloadPlugin"]), | ||||
|   }, | ||||
|   computed: { | ||||
|     ...mapState('main', ['devPlugins']), | ||||
|     ...mapState("main", ["devPlugins"]), | ||||
|     readme() { | ||||
|       marked.setOptions({ | ||||
|         renderer: rendererMD, | ||||
| @@ -133,17 +151,16 @@ export default { | ||||
|         pedantic: false, | ||||
|         sanitize: false, | ||||
|         smartLists: true, | ||||
|         smartypants: false | ||||
|         smartypants: false, | ||||
|       }); | ||||
|       try { | ||||
|         return marked(this.currentSelect.detail); | ||||
|       } catch (e) { | ||||
|         return '暂无描述信息' | ||||
|         return "暂无描述信息"; | ||||
|       } | ||||
|  | ||||
|     } | ||||
|   } | ||||
| } | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style lang="less"> | ||||
| @@ -177,49 +194,48 @@ export default { | ||||
|     justify-content: space-between; | ||||
|   } | ||||
| } | ||||
|  .market { | ||||
|    height: calc(~'100vh - 110px'); | ||||
|    background: #fff; | ||||
|    padding: 20px; | ||||
|    box-sizing: border-box; | ||||
|    overflow: auto; | ||||
|    .ant-carousel .slick-slide { | ||||
|      text-align: center; | ||||
|      height: 235px; | ||||
|      line-height: 160px; | ||||
|      background: #364d79; | ||||
|      overflow: hidden; | ||||
|    } | ||||
| .market { | ||||
|   height: calc(~"100vh - 110px"); | ||||
|   background: #fff; | ||||
|   padding: 20px; | ||||
|   box-sizing: border-box; | ||||
|   overflow: auto; | ||||
|   .ant-carousel .slick-slide { | ||||
|     text-align: center; | ||||
|     height: 235px; | ||||
|     line-height: 160px; | ||||
|     background: #364d79; | ||||
|     overflow: hidden; | ||||
|   } | ||||
|  | ||||
|    .ant-carousel .custom-slick-arrow { | ||||
|      width: 25px; | ||||
|      height: 25px; | ||||
|      font-size: 25px; | ||||
|      color: #fff; | ||||
|      background-color: rgba(31, 45, 61, 0.11); | ||||
|      opacity: 0.3; | ||||
|    } | ||||
|    .ant-carousel .custom-slick-arrow:before { | ||||
|      display: none; | ||||
|    } | ||||
|    .ant-carousel .custom-slick-arrow:hover { | ||||
|      opacity: 0.5; | ||||
|    } | ||||
|  | ||||
|    .ant-carousel .slick-slide h3 { | ||||
|      color: #fff; | ||||
|    } | ||||
|    .ant-list-item { | ||||
|      display: flex !important; | ||||
|      align-items: center; | ||||
|      justify-content: space-between; | ||||
|    } | ||||
|    .ant-list-item-meta-description { | ||||
|      width: 200px; | ||||
|      overflow: hidden; | ||||
|      text-overflow:ellipsis; | ||||
|      white-space: nowrap; | ||||
|    } | ||||
|  } | ||||
|   .ant-carousel .custom-slick-arrow { | ||||
|     width: 25px; | ||||
|     height: 25px; | ||||
|     font-size: 25px; | ||||
|     color: #fff; | ||||
|     background-color: rgba(31, 45, 61, 0.11); | ||||
|     opacity: 0.3; | ||||
|   } | ||||
|   .ant-carousel .custom-slick-arrow:before { | ||||
|     display: none; | ||||
|   } | ||||
|   .ant-carousel .custom-slick-arrow:hover { | ||||
|     opacity: 0.5; | ||||
|   } | ||||
|  | ||||
|   .ant-carousel .slick-slide h3 { | ||||
|     color: #fff; | ||||
|   } | ||||
|   .ant-list-item { | ||||
|     display: flex !important; | ||||
|     align-items: center; | ||||
|     justify-content: space-between; | ||||
|   } | ||||
|   .ant-list-item-meta-description { | ||||
|     width: 200px; | ||||
|     overflow: hidden; | ||||
|     text-overflow: ellipsis; | ||||
|     white-space: nowrap; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| import { clipboard, ipcRenderer, remote } from 'electron'; | ||||
| import { v4 as uuidv4 } from 'uuid'; | ||||
| import { clipboard, ipcRenderer, remote } from "electron"; | ||||
| import { v4 as uuidv4 } from "uuid"; | ||||
| import { | ||||
|   getWindowHeight, | ||||
|   searchKeyValues, | ||||
| @@ -7,34 +7,34 @@ import { | ||||
|   mergePlugins, | ||||
|   find, | ||||
|   downloadZip, | ||||
|   fileLists | ||||
| } from '../../assets/common/utils'; | ||||
| import systemMethod from '../../assets/common/system'; | ||||
| import fs from 'fs'; | ||||
| import path from 'path'; | ||||
| import { execSync } from 'child_process'; | ||||
|   fileLists, | ||||
| } from "../../assets/common/utils"; | ||||
| import systemMethod from "../../assets/common/system"; | ||||
| import fs from "fs"; | ||||
| import path from "path"; | ||||
| import { execSync } from "child_process"; | ||||
|  | ||||
| const state = { | ||||
|   selected: null, | ||||
|   options: [], | ||||
|   showMain: false, | ||||
|   current: ['market'], | ||||
|   searchValue: '', | ||||
|   current: ["market"], | ||||
|   searchValue: "", | ||||
|   devPlugins: mergePlugins(sysFile.getUserPlugins() || []), | ||||
|   subPlaceHolder: '', | ||||
|   subPlaceHolder: "", | ||||
|   pluginLoading: true, | ||||
|   pluginInfo: (() => { | ||||
|     try { | ||||
|       return window.pluginInfo || {}; | ||||
|     } catch (e) {} | ||||
|   })() | ||||
|   })(), | ||||
| }; | ||||
|  | ||||
| const mutations = { | ||||
|   commonUpdate(state, payload) { | ||||
|     Object.keys(payload).forEach((key) => { | ||||
|       state[key] = payload[key]; | ||||
|       if (key === 'devPlugins') { | ||||
|       if (key === "devPlugins") { | ||||
|         sysFile.savePlugins(payload[key]); | ||||
|       } | ||||
|     }); | ||||
| @@ -43,11 +43,15 @@ const mutations = { | ||||
|     state.subPlaceHolder = payload; | ||||
|   }, | ||||
|   deleteDevPlugin(state, payload) { | ||||
|     state.devPlugins = state.devPlugins.filter((plugin) => plugin.name !== payload.name); | ||||
|     state.devPlugins = state.devPlugins.filter( | ||||
|       (plugin) => plugin.name !== payload.name | ||||
|     ); | ||||
|     sysFile.savePlugins(state.devPlugins); | ||||
|   }, | ||||
|   deleteProdPlugin(state, payload) { | ||||
|     state.devPlugins = state.devPlugins.filter((plugin) => plugin.id !== payload.id); | ||||
|     state.devPlugins = state.devPlugins.filter( | ||||
|       (plugin) => plugin.id !== payload.id | ||||
|     ); | ||||
|     sysFile.savePlugins(state.devPlugins); | ||||
|     // todo 删除 static 目录下的对应插件 | ||||
|   }, | ||||
| @@ -59,124 +63,136 @@ const mutations = { | ||||
|     }); | ||||
|     state.devPlugins = [...state.devPlugins]; | ||||
|     sysFile.savePlugins(state.devPlugins); | ||||
|   } | ||||
|   }, | ||||
| }; | ||||
|  | ||||
| const actions = { | ||||
|   showMainUI({ commit, state }, paylpad) { | ||||
|     ipcRenderer.send('changeWindowSize-rubick', { | ||||
|       height: getWindowHeight() | ||||
|     ipcRenderer.send("changeWindowSize-rubick", { | ||||
|       height: getWindowHeight(), | ||||
|     }); | ||||
|     setTimeout(() => { | ||||
|       commit('commonUpdate', { | ||||
|       commit("commonUpdate", { | ||||
|         showMain: true, | ||||
|         selected: { | ||||
|           key: 'market', | ||||
|           name: '插件中心' | ||||
|         } | ||||
|           key: "market", | ||||
|           name: "插件中心", | ||||
|         }, | ||||
|       }); | ||||
|     }, 50); | ||||
|   }, | ||||
|   reloadDevPlugin({ commit }, payload) { | ||||
|     const config = JSON.parse(fs.readFileSync(path.join(payload.sourceFile, '../plugin.json'), 'utf-8')); | ||||
|     const config = JSON.parse( | ||||
|       fs.readFileSync(path.join(payload.sourceFile, "../plugin.json"), "utf-8") | ||||
|     ); | ||||
|     const pluginConfig = { | ||||
|       ...config, | ||||
|       sourceFile: path.join(payload.sourceFile, `../${config.main}`) | ||||
|       sourceFile: path.join(payload.sourceFile, `../${config.main}`), | ||||
|     }; | ||||
|     const devPlugins = [...state.devPlugins]; | ||||
|     commit('commonUpdate', { | ||||
|     commit("commonUpdate", { | ||||
|       devPlugins: devPlugins.map((plugin) => { | ||||
|         if (plugin.name === payload.name) { | ||||
|           return { | ||||
|             ...plugin, | ||||
|             ...pluginConfig | ||||
|             ...pluginConfig, | ||||
|           }; | ||||
|         } | ||||
|         return plugin; | ||||
|       }) | ||||
|       }), | ||||
|     }); | ||||
|   }, | ||||
|   async onSearch({ commit }, paylpad) { | ||||
|     if (state.selected && state.selected.key !== 'plugin-container') { | ||||
|       commit('commonUpdate', { searchValue: '' }); | ||||
|   /** | ||||
|    * @param {Object} payload payload.filePath为配置文件的绝对路径。payload.value为搜索栏文字值。 | ||||
|    */ | ||||
|   async onSearch({ commit }, payload) { | ||||
|     if (state.selected && state.selected.key !== "plugin-container") { | ||||
|       commit("commonUpdate", { searchValue: "" }); | ||||
|       return; | ||||
|     } | ||||
|     const value = paylpad.value; | ||||
|     const value = payload.value; | ||||
|     // 在插件界面不触发其他功能 | ||||
|     if ((state.selected && state.selected.key === 'plugin-container') || paylpad.searchType === 'subWindow') { | ||||
|       commit('commonUpdate', { searchValue: value }); | ||||
|     if ( | ||||
|       (state.selected && state.selected.key === "plugin-container") || | ||||
|       payload.searchType === "subWindow" | ||||
|     ) { | ||||
|       commit("commonUpdate", { searchValue: value }); | ||||
|       return; | ||||
|     } | ||||
|     const fileUrl = paylpad.filePath || clipboard.read('public.file-url').replace('file://', ''); | ||||
|     commit('commonUpdate', { searchValue: value }); | ||||
|     const fileUrl = | ||||
|       payload.filePath || | ||||
|       clipboard.read("public.file-url").replace("file://", ""); | ||||
|     commit("commonUpdate", { searchValue: value }); | ||||
|     // 复制文件 | ||||
|     if (paylpad.filePath || (fileUrl && value === 'plugin.json')) { | ||||
|       const config = JSON.parse(fs.readFileSync(fileUrl, 'utf-8')); | ||||
|     if (payload.filePath || (fileUrl && value === "plugin.json")) { | ||||
|       const config = JSON.parse(fs.readFileSync(fileUrl, "utf-8")); | ||||
|  | ||||
|       const pluginConfig = { | ||||
|         ...config, | ||||
|         sourceFile: path.join(fileUrl, `../${config.main || 'index.html'}`), | ||||
|         sourceFile: path.join(fileUrl, `../${config.main || "index.html"}`), | ||||
|         id: uuidv4(), | ||||
|         type: 'dev', | ||||
|         icon: 'image://' + path.join(fileUrl, `../${config.logo}`), | ||||
|         type: "dev", | ||||
|         icon: "image://" + path.join(fileUrl, `../${config.logo}`), | ||||
|         subType: (() => { | ||||
|           if (config.main) { | ||||
|             return ''; | ||||
|             return ""; | ||||
|           } | ||||
|           return 'template'; | ||||
|         })() | ||||
|           return "template"; | ||||
|         })(), | ||||
|       }; | ||||
|       commit('commonUpdate', { | ||||
|       commit("commonUpdate", { | ||||
|         selected: { | ||||
|           key: 'plugin', | ||||
|           name: 'plugin.json' | ||||
|           key: "plugin", | ||||
|           name: "plugin.json", | ||||
|         }, | ||||
|         searchValue: '', | ||||
|         searchValue: "", | ||||
|         options: [ | ||||
|           { | ||||
|             name: '新建rubick开发插件', | ||||
|             value: 'new-plugin', | ||||
|             icon: 'https://static.91jkys.com/activity/img/b37ff555c748489f88f3adac15b76f18.png', | ||||
|             desc: '新建rubick开发插件', | ||||
|             name: "新建rubick开发插件", | ||||
|             value: "new-plugin", | ||||
|             icon: | ||||
|               "https://static.91jkys.com/activity/img/b37ff555c748489f88f3adac15b76f18.png", | ||||
|             desc: "新建rubick开发插件", | ||||
|             click: (router) => { | ||||
|               commit('commonUpdate', { | ||||
|               commit("commonUpdate", { | ||||
|                 showMain: true, | ||||
|                 devPlugins: [pluginConfig, ...state.devPlugins], | ||||
|                 selected: { | ||||
|                   key: 'plugin', | ||||
|                   name: '新建rubick开发插件' | ||||
|                   key: "plugin", | ||||
|                   name: "新建rubick开发插件", | ||||
|                 }, | ||||
|                 current: ['dev'] | ||||
|                 current: ["dev"], | ||||
|               }); | ||||
|               ipcRenderer.send('changeWindowSize-rubick', { | ||||
|                 height: getWindowHeight() | ||||
|               ipcRenderer.send("changeWindowSize-rubick", { | ||||
|                 height: getWindowHeight(), | ||||
|               }); | ||||
|               router.push('/home/dev'); | ||||
|             } | ||||
|               router.push("/home/dev"); | ||||
|             }, | ||||
|           }, | ||||
|           { | ||||
|             name: '复制路径', | ||||
|             desc: '复制路径', | ||||
|             value: 'copy-path', | ||||
|             icon: 'https://static.91jkys.com/activity/img/ac0d4df0247345b9a84c8cd7ea3dd696.png', | ||||
|             name: "复制路径", | ||||
|             desc: "复制路径", | ||||
|             value: "copy-path", | ||||
|             icon: | ||||
|               "https://static.91jkys.com/activity/img/ac0d4df0247345b9a84c8cd7ea3dd696.png", | ||||
|             click: () => { | ||||
|               clipboard.writeText(fileUrl); | ||||
|               commit('commonUpdate', { | ||||
|               commit("commonUpdate", { | ||||
|                 showMain: false, | ||||
|                 selected: null, | ||||
|                 options: [] | ||||
|                 options: [], | ||||
|               }); | ||||
|               ipcRenderer.send('changeWindowSize-rubick', { | ||||
|                 height: getWindowHeight([]) | ||||
|               ipcRenderer.send("changeWindowSize-rubick", { | ||||
|                 height: getWindowHeight([]), | ||||
|               }); | ||||
|               remote.Notification('Rubick 通知', { body: '复制成功' }); | ||||
|             } | ||||
|           } | ||||
|         ] | ||||
|               remote.Notification("Rubick 通知", { body: "复制成功" }); | ||||
|             }, | ||||
|           }, | ||||
|         ], | ||||
|       }); | ||||
|       // 调整窗口大小 | ||||
|       ipcRenderer.send('changeWindowSize-rubick', { | ||||
|         height: getWindowHeight(state.options) | ||||
|       ipcRenderer.send("changeWindowSize-rubick", { | ||||
|         height: getWindowHeight(state.options), | ||||
|       }); | ||||
|       return; | ||||
|     } | ||||
| @@ -187,7 +203,7 @@ const actions = { | ||||
|     if (value) { | ||||
|       state.devPlugins.forEach((plugin) => { | ||||
|         // dev 插件未开启 | ||||
|         if (plugin.type === 'dev' && !plugin.status) return; | ||||
|         if (plugin.type === "dev" && !plugin.status) return; | ||||
|         const feature = plugin.features; | ||||
|         feature.forEach((fe) => { | ||||
|           const cmds = searchKeyValues(fe.cmds, value); | ||||
| @@ -195,14 +211,19 @@ const actions = { | ||||
|             ...options, | ||||
|             ...cmds.map((cmd) => ({ | ||||
|               name: cmd, | ||||
|               value: 'plugin', | ||||
|               icon: plugin.sourceFile ? 'image://' + path.join(plugin.sourceFile, `../${plugin.logo}`) : plugin.logo, | ||||
|               value: "plugin", | ||||
|               icon: plugin.sourceFile | ||||
|                 ? "image://" + path.join(plugin.sourceFile, `../${plugin.logo}`) | ||||
|                 : plugin.logo, | ||||
|               desc: fe.explain, | ||||
|               type: plugin.type, | ||||
|               click: (router) => { | ||||
|                 actions.openPlugin({ commit }, { cmd, plugin, feature: fe, router }); | ||||
|               } | ||||
|             })) | ||||
|                 actions.openPlugin( | ||||
|                   { commit }, | ||||
|                   { cmd, plugin, feature: fe, router } | ||||
|                 ); | ||||
|               }, | ||||
|             })), | ||||
|           ]; | ||||
|         }); | ||||
|       }); | ||||
| @@ -215,8 +236,12 @@ const actions = { | ||||
|             if (!descMap.get(plugin)) { | ||||
|               descMap.set(plugin, true); | ||||
|               let has = false; | ||||
|               plugin.keyWords.some(keyWord => { | ||||
|                 if (keyWord.toLocaleUpperCase().indexOf(value.toLocaleUpperCase()) >= 0) { | ||||
|               plugin.keyWords.some((keyWord) => { | ||||
|                 if ( | ||||
|                   keyWord | ||||
|                     .toLocaleUpperCase() | ||||
|                     .indexOf(value.toLocaleUpperCase()) >= 0 | ||||
|                 ) { | ||||
|                   has = keyWord; | ||||
|                   plugin.name = keyWord; | ||||
|                   return true; | ||||
| @@ -233,17 +258,17 @@ const actions = { | ||||
|               actions.openPlugin({ commit }, { plugin }); | ||||
|             }; | ||||
|             return plugin; | ||||
|           }) | ||||
|           }), | ||||
|       ]; | ||||
|  | ||||
|       descMap = null; | ||||
|     } | ||||
|  | ||||
|     commit('commonUpdate', { | ||||
|       options | ||||
|     commit("commonUpdate", { | ||||
|       options, | ||||
|     }); | ||||
|     ipcRenderer.send('changeWindowSize-rubick', { | ||||
|       height: getWindowHeight(state.options) | ||||
|     ipcRenderer.send("changeWindowSize-rubick", { | ||||
|       height: getWindowHeight(state.options), | ||||
|     }); | ||||
|   }, | ||||
|   async downloadPlugin({ commit }, payload) { | ||||
| @@ -251,88 +276,90 @@ const actions = { | ||||
|     const fileUrl = find(distUrl); | ||||
|  | ||||
|     // 复制文件 | ||||
|     const config = JSON.parse(fs.readFileSync(`${fileUrl}/plugin.json`, 'utf-8')); | ||||
|     const config = JSON.parse( | ||||
|       fs.readFileSync(`${fileUrl}/plugin.json`, "utf-8") | ||||
|     ); | ||||
|     const pluginConfig = { | ||||
|       ...config, | ||||
|       id: uuidv4(), | ||||
|       sourceFile: `${fileUrl}/${config.main}`, | ||||
|       type: 'prod', | ||||
|       type: "prod", | ||||
|       icon: payload.logo, | ||||
|       subType: (() => { | ||||
|         if (config.main) { | ||||
|           return ''; | ||||
|           return ""; | ||||
|         } | ||||
|         return 'template'; | ||||
|       })() | ||||
|         return "template"; | ||||
|       })(), | ||||
|     }; | ||||
|     commit('commonUpdate', { | ||||
|       devPlugins: [pluginConfig, ...state.devPlugins] | ||||
|     commit("commonUpdate", { | ||||
|       devPlugins: [pluginConfig, ...state.devPlugins], | ||||
|     }); | ||||
|   }, | ||||
|   openPlugin({ commit }, { cmd, plugin, feature, router, payload }) { | ||||
|     if (plugin.type === 'app') { | ||||
|     if (plugin.type === "app") { | ||||
|       execSync(plugin.action); | ||||
|       commit('commonUpdate', { | ||||
|       commit("commonUpdate", { | ||||
|         selected: null, | ||||
|         showMain: false, | ||||
|         options: [], | ||||
|         searchValue: '' | ||||
|         searchValue: "", | ||||
|       }); | ||||
|       ipcRenderer.send('changeWindowSize-rubick', { | ||||
|         height: getWindowHeight([]) | ||||
|       ipcRenderer.send("changeWindowSize-rubick", { | ||||
|         height: getWindowHeight([]), | ||||
|       }); | ||||
|       return; | ||||
|     } | ||||
|     commit('commonUpdate', { | ||||
|     commit("commonUpdate", { | ||||
|       selected: { | ||||
|         key: 'plugin-container', | ||||
|         key: "plugin-container", | ||||
|         name: cmd.label ? cmd.label : cmd, | ||||
|         icon: 'image://' + path.join(plugin.sourceFile, `../${plugin.logo}`) | ||||
|         icon: "image://" + path.join(plugin.sourceFile, `../${plugin.logo}`), | ||||
|       }, | ||||
|       searchValue: '', | ||||
|       showMain: true | ||||
|       searchValue: "", | ||||
|       showMain: true, | ||||
|     }); | ||||
|     ipcRenderer.send('changeWindowSize-rubick', { | ||||
|       height: getWindowHeight() | ||||
|     ipcRenderer.send("changeWindowSize-rubick", { | ||||
|       height: getWindowHeight(), | ||||
|     }); | ||||
|     if (plugin.type === 'system') { | ||||
|     if (plugin.type === "system") { | ||||
|       systemMethod[plugin.tag][feature.code](); | ||||
|       commit('commonUpdate', { | ||||
|       commit("commonUpdate", { | ||||
|         selected: null, | ||||
|         showMain: false, | ||||
|         options: [] | ||||
|         options: [], | ||||
|       }); | ||||
|       ipcRenderer.send('changeWindowSize-rubick', { | ||||
|         height: getWindowHeight([]) | ||||
|       ipcRenderer.send("changeWindowSize-rubick", { | ||||
|         height: getWindowHeight([]), | ||||
|       }); | ||||
|       router.push({ | ||||
|         path: '/home' | ||||
|         path: "/home", | ||||
|       }); | ||||
|       return; | ||||
|     } | ||||
|     commit('commonUpdate', { | ||||
|     commit("commonUpdate", { | ||||
|       pluginInfo: { | ||||
|         cmd, | ||||
|         ...plugin, | ||||
|         detail: feature, | ||||
|         payload | ||||
|       } | ||||
|         payload, | ||||
|       }, | ||||
|     }); | ||||
|  | ||||
|     router.push({ | ||||
|       path: '/plugin', | ||||
|       path: "/plugin", | ||||
|       query: { | ||||
|         ...plugin, | ||||
|         _modify: Date.now(), | ||||
|         detail: JSON.stringify(feature) | ||||
|       } | ||||
|         detail: JSON.stringify(feature), | ||||
|       }, | ||||
|     }); | ||||
|   } | ||||
|   }, | ||||
| }; | ||||
|  | ||||
| export default { | ||||
|   namespaced: true, | ||||
|   state, | ||||
|   mutations, | ||||
|   actions | ||||
|   actions, | ||||
| }; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user