mirror of
				https://github.com/rubickCenter/rubick
				synced 2025-10-26 14:42:43 +08:00 
			
		
		
		
	Compare commits
	
		
			27 Commits
		
	
	
		
			v4.2.4
			...
			7b55716742
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 7b55716742 | ||
|  | 5ca1ba1271 | ||
|  | 8c3186afef | ||
|  | de0e9ed8f2 | ||
|  | ef85084730 | ||
|  | b4b7c81b60 | ||
|  | 4b79cce2f4 | ||
|  | ae10dac5f7 | ||
|  | 1e0babe22d | ||
|  | 5ec18caa72 | ||
|  | b7d8932291 | ||
|  | 2307faf31a | ||
|  | 5608a147f7 | ||
|  | 132fb94289 | ||
|  | bb1a74b3b9 | ||
|  | bf9da854c7 | ||
|  | a2c5bcc90c | ||
|  | b9f4333c01 | ||
|  | bbeddb3fe6 | ||
|  | 4a2ca33e02 | ||
|  | 0578c7c7eb | ||
|  | ef34452a4f | ||
|  | 286d9da8d1 | ||
|  | 6b9d5182bf | ||
|  | 2053491782 | ||
|  | e128d01b81 | ||
|  | 472879f9b2 | 
							
								
								
									
										2
									
								
								.github/workflows/main.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/main.yml
									
									
									
									
										vendored
									
									
								
							| @@ -23,7 +23,7 @@ jobs: | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         os: [macos-11, windows-2019, ubuntu-latest] | ||||
|         os: [macos-latest, windows-2019, ubuntu-latest] | ||||
|  | ||||
|     # create steps | ||||
|     steps: | ||||
|   | ||||
| @@ -109,6 +109,8 @@ Those who are interested in this project or want to exchange and learn can scan | ||||
|  | ||||
|  | ||||
|  | ||||
| <a href="https://hellogithub.com/repository/0a3e2484b44e481e9dcf1850e45193cd" target="_blank"><img src="https://api.hellogithub.com/v1/widgets/recommend.svg?rid=0a3e2484b44e481e9dcf1850e45193cd&claim_uid=vXGwjpmYNsBex0C" alt="Featured|HelloGitHub" style="width: 250px; height: 54px;" width="250" height="54" /></a> | ||||
|  | ||||
| ## Contribute | ||||
| This project exists thanks to all the people who contribute. [[Contribute](https://github.com/rubickCenter/rubick/graphs/contributors)]. <a href="https://github.com/rubickCenter/rubick/graphs/contributors"><img src="https://opencollective.com/rubick/contributors.svg?width=890&button=false" /></a> | ||||
|  | ||||
|   | ||||
| @@ -90,6 +90,9 @@ | ||||
|  | ||||
| [Rubick Plugin CLI](https://github.com/rubickCenter/rubick-plugin-cli) | ||||
|  | ||||
| ## 局限性 | ||||
| npm包最终大小不宜超过100MB,所以插件包大小也不宜超过此大小,建议20MB以内,如果包体积过大,预期会导致推送npm仓库失败 | ||||
|  | ||||
| ## 赞助 | ||||
| ### 1. 加入知识星球 | ||||
| 我们在知识星球积累了大量的关于 rubick 的知识和常见问题,您可以付费加入我们的知识星球来一起讨论。我们将随时解答! | ||||
|   | ||||
| @@ -8,37 +8,37 @@ | ||||
|       > | ||||
|         <a-menu-item key="finder"> | ||||
|           <template #icon> | ||||
|             <StarOutlined style="font-size: 18px;" /> | ||||
|             <StarOutlined style="font-size: 16px" /> | ||||
|           </template> | ||||
|           {{ $t('feature.market.explore') }} | ||||
|         </a-menu-item> | ||||
|         <a-menu-item key="worker"> | ||||
|           <template #icon> | ||||
|             <SendOutlined style="transform: rotate(-45deg); font-size: 18px;" /> | ||||
|             <SendOutlined style="transform: rotate(-45deg); font-size: 16px" /> | ||||
|           </template> | ||||
|           {{ $t('feature.market.efficiency') }} | ||||
|         </a-menu-item> | ||||
|         <a-menu-item key="tools"> | ||||
|           <template #icon> | ||||
|             <SearchOutlined style="font-size: 18px;" /> | ||||
|             <SearchOutlined style="font-size: 16px" /> | ||||
|           </template> | ||||
|           {{ $t('feature.market.searchTool') }} | ||||
|         </a-menu-item> | ||||
|         <a-menu-item key="image"> | ||||
|           <template #icon> | ||||
|             <FileImageOutlined style="font-size: 18px;" /> | ||||
|             <FileImageOutlined style="font-size: 16px" /> | ||||
|           </template> | ||||
|           {{ $t('feature.market.imageTool') }} | ||||
|         </a-menu-item> | ||||
|         <a-menu-item key="devPlugin"> | ||||
|           <template #icon> | ||||
|             <CodeOutlined style="font-size: 18px;" /> | ||||
|             <CodeOutlined style="font-size: 16px" /> | ||||
|           </template> | ||||
|           {{ $t('feature.market.developTool') }} | ||||
|         </a-menu-item> | ||||
|         <a-menu-item key="system"> | ||||
|           <template #icon> | ||||
|             <DatabaseOutlined style="font-size: 18px;" /> | ||||
|             <DatabaseOutlined style="font-size: 16px" /> | ||||
|           </template> | ||||
|           {{ $t('feature.market.systemTool') }} | ||||
|         </a-menu-item> | ||||
| @@ -72,7 +72,21 @@ | ||||
|         </a-sub-menu> | ||||
|       </a-menu> | ||||
|     </div> | ||||
|     <div :class="['finder', 'result', 'devPlugin', 'image', 'tools', 'worker', 'system'].includes(active[0]) ? 'container' : 'more'"> | ||||
|     <div | ||||
|       :class=" | ||||
|         [ | ||||
|           'finder', | ||||
|           'result', | ||||
|           'devPlugin', | ||||
|           'image', | ||||
|           'tools', | ||||
|           'worker', | ||||
|           'system', | ||||
|         ].includes(active[0]) | ||||
|           ? 'container' | ||||
|           : 'more' | ||||
|       " | ||||
|     > | ||||
|       <keep-alive> | ||||
|         <router-view /> | ||||
|       </keep-alive> | ||||
| @@ -103,14 +117,14 @@ const active = computed(() => store.state.active); | ||||
| const { perf } = localConfig.getConfig(); | ||||
|  | ||||
| const changeMenu = (key: any) => { | ||||
|   store.commit('commonUpdate', {active: [key]}) | ||||
|   store.commit('commonUpdate', { active: [key] }); | ||||
|   router.push(key); | ||||
| }; | ||||
|  | ||||
| window.rubick.onPluginEnter(({ code }: { code: string }) => { | ||||
|   code = code === '已安装插件' ? 'installed' : code; | ||||
|   changeMenu(code); | ||||
|   store.commit('commonUpdate', {active: [code]}) | ||||
|   store.commit('commonUpdate', { active: [code] }); | ||||
| }); | ||||
|  | ||||
| window.rubick.setSubInput((e: any) => { | ||||
| @@ -129,7 +143,7 @@ window.rubick.setSubInput((e: any) => { | ||||
|       store.commit('setSearchValue', e.text); | ||||
|       router.push('result'); | ||||
|     } else { | ||||
|       store.commit('commonUpdate', {active: ['finder']}) | ||||
|       store.commit('commonUpdate', { active: ['finder'] }); | ||||
|       router.push('finder'); | ||||
|     } | ||||
|   } | ||||
| @@ -144,13 +158,16 @@ init(); | ||||
|     background: var(--color-body-bg2) !important; | ||||
|     height: 100%; | ||||
|     border-right: none; | ||||
|     .ant-menu-item, .ant-menu-submenu, .ant-menu-submenu-arrow { | ||||
|     .ant-menu-item, | ||||
|     .ant-menu-submenu, | ||||
|     .ant-menu-submenu-arrow { | ||||
|       color: var(--color-text-content); | ||||
|       &:active { | ||||
|         background: none; | ||||
|       } | ||||
|     } | ||||
|     .ant-menu-item-selected, .ant-menu-submenu-selected { | ||||
|     .ant-menu-item-selected, | ||||
|     .ant-menu-submenu-selected { | ||||
|       background-color: var(--color-list-hover); | ||||
|       color: var(--ant-primary-color); | ||||
|       .ant-menu-submenu-arrow { | ||||
| @@ -203,9 +220,12 @@ init(); | ||||
|     background: var(--color-body-bg2); | ||||
|   } | ||||
|   .left-menu { | ||||
|     padding: 24px 16px; | ||||
|     padding: 16px; | ||||
|     position: relative; | ||||
|     height: 100vh; | ||||
|     :deep(.ant-menu) { | ||||
|       width: 100%; | ||||
|     } | ||||
|     :deep(.ant-menu-item) { | ||||
|       padding-left: 12px !important; | ||||
|       display: flex; | ||||
| @@ -219,7 +239,14 @@ init(); | ||||
|     } | ||||
|     :deep(.user-info) { | ||||
|       position: absolute; | ||||
|       bottom: 32px; | ||||
|       bottom: 16px; | ||||
|       width: calc(100% - 32px); | ||||
|       .ant-menu-submenu-title { | ||||
|         padding: 0 32px 0 8px; | ||||
|         .ant-menu-title-content { | ||||
|           margin-left: 8px; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|     :deep(.ant-avatar) { | ||||
|       background: transparent; | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| import axios from 'axios'; | ||||
|  | ||||
| let baseURL = 'https://gitcode.net/rubickcenter/rubick-database/-/raw/master'; | ||||
| let baseURL = 'https://gitee.com/monkeyWang/rubickdatabase/raw/master'; | ||||
| let access_token = ''; | ||||
|  | ||||
| try { | ||||
| @@ -14,7 +14,7 @@ try { | ||||
| const instance = axios.create({ | ||||
|   timeout: 4000, | ||||
|   baseURL: | ||||
|     baseURL || 'https://gitcode.net/rubickcenter/rubick-database/-/raw/master', | ||||
|     baseURL || 'https://gitee.com/monkeyWang/rubickdatabase/raw/master', | ||||
| }); | ||||
|  | ||||
| export default { | ||||
| @@ -23,9 +23,10 @@ export default { | ||||
|     if (access_token) { | ||||
|       targetPath = `${encodeURIComponent( | ||||
|         targetPath | ||||
|       )}/raw?access_token=${access_token}&ref=master`; | ||||
|       )}?access_token=${access_token}&ref=master`; | ||||
|     } | ||||
|     const res = await instance.get(targetPath); | ||||
|     console.log('total plugsin', res); | ||||
|     return res.data; | ||||
|   }, | ||||
|  | ||||
| @@ -34,7 +35,7 @@ export default { | ||||
|     if (access_token) { | ||||
|       targetPath = `${encodeURIComponent( | ||||
|         targetPath | ||||
|       )}/raw?access_token=${access_token}&ref=master`; | ||||
|       )}?access_token=${access_token}&ref=master`; | ||||
|     } | ||||
|     const res = await instance.get(targetPath); | ||||
|     return res.data; | ||||
| @@ -45,7 +46,7 @@ export default { | ||||
|     if (access_token) { | ||||
|       targetPath = `${encodeURIComponent( | ||||
|         targetPath | ||||
|       )}/raw?access_token=${access_token}&ref=master`; | ||||
|       )}?access_token=${access_token}&ref=master`; | ||||
|     } | ||||
|     const res = await instance.get(targetPath); | ||||
|     return res.data; | ||||
| @@ -55,7 +56,7 @@ export default { | ||||
|     if (access_token) { | ||||
|       targetPath = `${encodeURIComponent( | ||||
|         targetPath | ||||
|       )}/raw?access_token=${access_token}&ref=master`; | ||||
|       )}?access_token=${access_token}&ref=master`; | ||||
|     } | ||||
|     const res = await instance.get(targetPath); | ||||
|     return res.data; | ||||
| @@ -71,7 +72,7 @@ export default { | ||||
|     if (access_token) { | ||||
|       targetPath = `${encodeURIComponent( | ||||
|         targetPath | ||||
|       )}/raw?access_token=${access_token}&ref=master`; | ||||
|       )}?access_token=${access_token}&ref=master`; | ||||
|     } | ||||
|     const res = await instance.get(targetPath); | ||||
|     return res.data; | ||||
| @@ -81,7 +82,7 @@ export default { | ||||
|     if (access_token) { | ||||
|       targetPath = `${encodeURIComponent( | ||||
|         targetPath | ||||
|       )}/raw?access_token=${access_token}&ref=master`; | ||||
|       )}?access_token=${access_token}&ref=master`; | ||||
|     } | ||||
|     const res = await instance.get(targetPath); | ||||
|     return res.data; | ||||
| @@ -91,7 +92,7 @@ export default { | ||||
|     if (access_token) { | ||||
|       targetPath = `${encodeURIComponent( | ||||
|         targetPath | ||||
|       )}/raw?access_token=${access_token}&ref=master`; | ||||
|       )}?access_token=${access_token}&ref=master`; | ||||
|     } | ||||
|     const res = await instance.get(targetPath); | ||||
|     return res.data; | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "rubick", | ||||
|   "version": "4.2.4", | ||||
|   "version": "4.3.0", | ||||
|   "author": "muwoo <2424880409@qq.com>", | ||||
|   "private": true, | ||||
|   "scripts": { | ||||
|   | ||||
| @@ -7,11 +7,10 @@ import path from 'path'; | ||||
| import got from 'got'; | ||||
| import fixPath from 'fix-path'; | ||||
|  | ||||
| import spawn from 'cross-spawn'; | ||||
| import { ipcRenderer } from 'electron'; | ||||
| import axios from 'axios'; | ||||
|  | ||||
| import npm from 'npm'; | ||||
|  | ||||
| fixPath(); | ||||
|  | ||||
| /** | ||||
| @@ -42,7 +41,7 @@ class AdapterHandler { | ||||
|     } | ||||
|     this.baseDir = options.baseDir; | ||||
|  | ||||
|     let register = options.registry || 'https://registry.npmmirror.com/'; | ||||
|     let register = options.registry || 'https://registry.npm.taobao.org'; | ||||
|  | ||||
|     try { | ||||
|       const dbdata = ipcRenderer.sendSync('msg-trigger', { | ||||
| @@ -61,7 +60,7 @@ class AdapterHandler { | ||||
|     const packageJSON = JSON.parse( | ||||
|       fs.readFileSync(`${this.baseDir}/package.json`, 'utf-8') | ||||
|     ); | ||||
|     const registryUrl = `${this.registry}${name}`; | ||||
|     const registryUrl = `https://registry.npm.taobao.org/${name}`; | ||||
|  | ||||
|     // 从npm源中获取依赖包的最新版本 | ||||
|     try { | ||||
| @@ -158,32 +157,43 @@ class AdapterHandler { | ||||
|    */ | ||||
|   private async execCommand(cmd: string, modules: string[]): Promise<string> { | ||||
|     return new Promise((resolve: any, reject: any) => { | ||||
|       const module = | ||||
|       let args: string[] = [cmd].concat( | ||||
|         cmd !== 'uninstall' && cmd !== 'link' | ||||
|           ? modules.map((m) => `${m}@latest`) | ||||
|           : modules; | ||||
|       const config: any = { | ||||
|         prefix: this.baseDir, | ||||
|         save: true, | ||||
|         cache: path.join(this.baseDir, 'cache'), | ||||
|       }; | ||||
|           : modules | ||||
|       ); | ||||
|       if (cmd !== 'link') { | ||||
|         config.registry = this.registry; | ||||
|         args = args | ||||
|           .concat('--color=always') | ||||
|           .concat('--save') | ||||
|           .concat(`--registry=${this.registry}`); | ||||
|       } | ||||
|       npm.load(config, function (err) { | ||||
|         npm.commands[cmd](module, function (er, data) { | ||||
|           if (!err) { | ||||
|             console.log(data); | ||||
|             resolve({ code: -1, data }); | ||||
|           } else { | ||||
|             reject({ code: -1, data: err }); | ||||
|           } | ||||
|         }); | ||||
|  | ||||
|         npm.on('log', function (message) { | ||||
|           // log installation progress | ||||
|           console.log(message); | ||||
|         }); | ||||
|       const npm = spawn('npm', args, { | ||||
|         cwd: this.baseDir, | ||||
|       }); | ||||
|  | ||||
|       console.log(args); | ||||
|  | ||||
|       let output = ''; | ||||
|       npm.stdout | ||||
|         .on('data', (data: string) => { | ||||
|           output += data; // 获取输出日志 | ||||
|         }) | ||||
|         .pipe(process.stdout); | ||||
|  | ||||
|       npm.stderr | ||||
|         .on('data', (data: string) => { | ||||
|           output += data; // 获取报错日志 | ||||
|         }) | ||||
|         .pipe(process.stderr); | ||||
|  | ||||
|       npm.on('close', (code: number) => { | ||||
|         if (!code) { | ||||
|           resolve({ code: 0, data: output }); // 如果没有报错就输出正常日志 | ||||
|         } else { | ||||
|           reject({ code: code, data: output }); // 如果报错就输出报错日志 | ||||
|         } | ||||
|       }); | ||||
|     }); | ||||
|   } | ||||
|   | ||||
| @@ -25,7 +25,7 @@ export default () => { | ||||
|       height: WINDOW_HEIGHT, | ||||
|       minHeight: WINDOW_MIN_HEIGHT, | ||||
|       useContentSize: true, | ||||
|       resizable: false, | ||||
|       resizable: true, | ||||
|       width: WINDOW_WIDTH, | ||||
|       frame: false, | ||||
|       title: '拉比克', | ||||
|   | ||||
| @@ -175,31 +175,29 @@ export default () => { | ||||
|  | ||||
|   const removeView = (window: BrowserWindow) => { | ||||
|     if (!view) return; | ||||
|     window.removeBrowserView(view); | ||||
|     if (!view.inDetach) { | ||||
|       window.setBrowserView(null); | ||||
|       view.webContents?.destroy(); | ||||
|     } | ||||
|  | ||||
|     // window.setSize(800, 60); | ||||
|     executeHooks('PluginOut', null); | ||||
|     window.webContents?.executeJavaScript(`window.initRubick()`); | ||||
|     view = undefined; | ||||
|     setTimeout(() => { | ||||
|       window.removeBrowserView(view); | ||||
|       if (!view.inDetach) { | ||||
|         window.setBrowserView(null); | ||||
|         view.webContents?.destroy(); | ||||
|       } | ||||
|       window.webContents?.executeJavaScript(`window.initRubick()`); | ||||
|       view = undefined; | ||||
|     }, 0); | ||||
|   }; | ||||
|  | ||||
|   const getView = () => view; | ||||
|  | ||||
|   const executeHooks = (hook, data) => { | ||||
|     setTimeout(() => { | ||||
|       if (!view) return; | ||||
|       const evalJs = `if(window.rubick && window.rubick.hooks && typeof window.rubick.hooks.on${hook} === 'function' ) { | ||||
|     if (!view) return; | ||||
|     const evalJs = `if(window.rubick && window.rubick.hooks && typeof window.rubick.hooks.on${hook} === 'function' ) { | ||||
|           try { | ||||
|             window.rubick.hooks.on${hook}(${data ? JSON.stringify(data) : ''}); | ||||
|           } catch(e) {} | ||||
|         } | ||||
|       `; | ||||
|       view.webContents?.executeJavaScript(evalJs); | ||||
|     }, 300); | ||||
|     view.webContents?.executeJavaScript(evalJs); | ||||
|   }; | ||||
|  | ||||
|   return { | ||||
|   | ||||
| @@ -128,8 +128,8 @@ class API extends DBInstance { | ||||
|   } | ||||
|  | ||||
|   public removePlugin(e, window) { | ||||
|     this.currentPlugin = null; | ||||
|     runnerInstance.removeView(window); | ||||
|     this.currentPlugin = null; | ||||
|   } | ||||
|  | ||||
|   public openPluginDevTools() { | ||||
| @@ -211,11 +211,10 @@ class API extends DBInstance { | ||||
|     if (!Notification.isSupported()) return; | ||||
|     'string' != typeof body && (body = String(body)); | ||||
|     const plugin = this.currentPlugin; | ||||
|     if (!plugin) return; | ||||
|     const notify = new Notification({ | ||||
|       title: plugin.pluginName, | ||||
|       title: plugin ? plugin.pluginName : null, | ||||
|       body, | ||||
|       icon: plugin.logo, | ||||
|       icon: plugin ? plugin.logo : null, | ||||
|     }); | ||||
|     notify.show(); | ||||
|   } | ||||
|   | ||||
| @@ -1,8 +1,5 @@ | ||||
| <template> | ||||
|   <div | ||||
|     id="components-layout" | ||||
|     @mousedown="onMouseDown" | ||||
|   > | ||||
|   <div id="components-layout" @mousedown="onMouseDown"> | ||||
|     <Search | ||||
|       :currentPlugin="currentPlugin" | ||||
|       @changeCurrent="changeIndex" | ||||
| @@ -94,7 +91,9 @@ watch( | ||||
|     window.rubick.setExpendHeight( | ||||
|       getWindowHeight( | ||||
|         options.value, | ||||
|         (pluginLoading.value || !config.value.perf.common.history) ? [] : pluginHistory.value | ||||
|         pluginLoading.value || !config.value.perf.common.history | ||||
|           ? [] | ||||
|           : pluginHistory.value | ||||
|       ) | ||||
|     ); | ||||
|   }, | ||||
| @@ -104,26 +103,15 @@ watch( | ||||
| ); | ||||
|  | ||||
| const changeIndex = (index) => { | ||||
|   if (!options.value.length) { | ||||
|     if (!pluginHistory.value.length) return; | ||||
|     if ( | ||||
|       currentSelect.value + index > pluginHistory.value.length - 1 || | ||||
|       currentSelect.value + index < 0 | ||||
|     ) { | ||||
|       currentSelect.value = 0; | ||||
|       return; | ||||
|     } | ||||
|     currentSelect.value = currentSelect.value + index; | ||||
|     return; | ||||
|   } | ||||
|   if ( | ||||
|     currentSelect.value + index > options.value.length - 1 || | ||||
|     currentSelect.value + index < 0 | ||||
|   ) { | ||||
|   const len = options.value.length || pluginHistory.value.length; | ||||
|   if (!len) return; | ||||
|   if (currentSelect.value + index > len - 1) { | ||||
|     currentSelect.value = 0; | ||||
|     return; | ||||
|   } else if (currentSelect.value + index < 0) { | ||||
|     currentSelect.value = len - 1; | ||||
|   } else { | ||||
|     currentSelect.value = currentSelect.value + index; | ||||
|   } | ||||
|   currentSelect.value = currentSelect.value + index; | ||||
| }; | ||||
|  | ||||
| const openMenu = (ext) => { | ||||
| @@ -161,7 +149,9 @@ const choosePlugin = (plugin) => { | ||||
|     }); | ||||
|     if (hasRemove) { | ||||
|       const result = window.rubick.db.get(PLUGIN_HISTORY) || {}; | ||||
|       const history = result.data.filter(item => item.originName !== currentChoose.originName); | ||||
|       const history = result.data.filter( | ||||
|         (item) => item.originName !== currentChoose.originName | ||||
|       ); | ||||
|       setPluginHistory(history); | ||||
|       return message.warning('插件已被卸载!'); | ||||
|     } | ||||
|   | ||||
| @@ -25,6 +25,8 @@ | ||||
|       ref="mainInput" | ||||
|       class="main-input" | ||||
|       @input="(e) => changeValue(e)" | ||||
|       @keydown.left="(e) => keydownEvent(e, 'left')" | ||||
|       @keydown.right="(e) => keydownEvent(e, 'right')" | ||||
|       @keydown.down="(e) => keydownEvent(e, 'down')" | ||||
|       @keydown.tab="(e) => keydownEvent(e, 'down')" | ||||
|       @keydown.up="(e) => keydownEvent(e, 'up')" | ||||
| @@ -41,10 +43,7 @@ | ||||
|     > | ||||
|       <template #suffix> | ||||
|         <div class="suffix-tool"> | ||||
|           <MoreOutlined | ||||
|             @click="showSeparate()" | ||||
|             class="icon-more" | ||||
|           /> | ||||
|           <MoreOutlined @click="showSeparate()" class="icon-more" /> | ||||
|         </div> | ||||
|       </template> | ||||
|     </a-input> | ||||
| @@ -120,6 +119,12 @@ const keydownEvent = (e, key: string) => { | ||||
|     case 'down': | ||||
|       emit('changeCurrent', 1); | ||||
|       break; | ||||
|     case 'left': | ||||
|       emit('changeCurrent', -1); | ||||
|       break; | ||||
|     case 'right': | ||||
|       emit('changeCurrent', 1); | ||||
|       break; | ||||
|     case 'enter': | ||||
|       if (runPluginDisable) return; | ||||
|       emit('choosePlugin'); | ||||
|   | ||||
| @@ -8,7 +8,7 @@ import useFocus from './clipboardWatch'; | ||||
|  | ||||
| function formatReg(regStr) { | ||||
|   const flags = regStr.replace(/.*\/([gimy]*)$/, '$1'); | ||||
|   const pattern = flags.replace(new RegExp('^/(.*?)/' + flags + '$'), '$1'); | ||||
|   const pattern = regStr.replace(new RegExp('^/(.*?)/' + flags + '$'), '$1'); | ||||
|   return new RegExp(pattern, flags); | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user