mirror of
				https://github.com/fofolee/uTools-quickcommand.git
				synced 2025-10-25 04:51:31 +08:00 
			
		
		
		
	完成面板视图
This commit is contained in:
		| @@ -246,15 +246,6 @@ window.pluginInfo = () => { | |||||||
|     return JSON.parse(fs.readFileSync(path.join(__dirname, 'plugin.json'))) |     return JSON.parse(fs.readFileSync(path.join(__dirname, 'plugin.json'))) | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| let GetFilePath = (Path, File) => { |  | ||||||
|     if (utools.isDev()) { |  | ||||||
|         return path.join(__dirname, Path, File) |  | ||||||
|     } else { |  | ||||||
|         return path.join(__dirname.replace(/([a-zA-Z0-9\-]+\.asar)/, '$1.unpacked'), Path, File) |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| let getSleepCodeByShell = ms => { | let getSleepCodeByShell = ms => { | ||||||
|     var cmd, tempFilePath |     var cmd, tempFilePath | ||||||
|     if (utools.isWindows()) { |     if (utools.isWindows()) { | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								src/App.vue
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								src/App.vue
									
									
									
									
									
								
							| @@ -67,4 +67,14 @@ export default defineComponent({ | |||||||
|   --q-dark: #303133; |   --q-dark: #303133; | ||||||
|   --q-dark-page: #303133; |   --q-dark-page: #303133; | ||||||
| } | } | ||||||
|  | .commandLogo { | ||||||
|  |   cursor: pointer; | ||||||
|  |   transition: 0.2s; | ||||||
|  |   filter: drop-shadow(2px 1px 1px grey); | ||||||
|  | } | ||||||
|  | .commandLogo:hover { | ||||||
|  |   transition: 0.5s; | ||||||
|  |   transform: translateY(-5px); | ||||||
|  |   filter: drop-shadow(2px 1px 5px grey); | ||||||
|  | } | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -145,10 +145,22 @@ | |||||||
|       ref="editor" |       ref="editor" | ||||||
|       :style="{ |       :style="{ | ||||||
|         top: languageBarHeight + 'px', |         top: languageBarHeight + 'px', | ||||||
|         left: this.action.type === 'run' ? '0' : sideBarWidth + 'px', |         left: editorLeft, | ||||||
|         transition: '0.3s', |         transition: '0.3s', | ||||||
|       }" |       }" | ||||||
|     /> |     /> | ||||||
|  |     <div | ||||||
|  |       class="absolute-bottom flex justify-center content-center" | ||||||
|  |       :style="{ | ||||||
|  |         top: languageBarHeight + 'px', | ||||||
|  |         left: editorLeft, | ||||||
|  |         userSelect: 'none', | ||||||
|  |       }" | ||||||
|  |     > | ||||||
|  |       ctrl + s 保存 <br /> | ||||||
|  |       ctrl + b 运行 <br /> | ||||||
|  |       alt + z 自动换行 | ||||||
|  |     </div> | ||||||
|     <!-- 运行结果 --> |     <!-- 运行结果 --> | ||||||
|     <CommandRunResult :action="action" ref="result"></CommandRunResult> |     <CommandRunResult :action="action" ref="result"></CommandRunResult> | ||||||
|   </div> |   </div> | ||||||
| @@ -205,6 +217,9 @@ export default { | |||||||
|         "搜索结果" |         "搜索结果" | ||||||
|       ); |       ); | ||||||
|     }, |     }, | ||||||
|  |     editorLeft() { | ||||||
|  |       return this.action.type === "run" ? "0" : this.sideBarWidth + "px"; | ||||||
|  |     }, | ||||||
|   }, |   }, | ||||||
|   created() {}, |   created() {}, | ||||||
|   methods: { |   methods: { | ||||||
|   | |||||||
| @@ -234,6 +234,7 @@ | |||||||
|     </div> |     </div> | ||||||
|     <iconPicker |     <iconPicker | ||||||
|       @iconChanged="(dataUrl) => (currentCommand.features.icon = dataUrl)" |       @iconChanged="(dataUrl) => (currentCommand.features.icon = dataUrl)" | ||||||
|  |       position="left" | ||||||
|       ref="icon" |       ref="icon" | ||||||
|     /> |     /> | ||||||
|   </q-scroll-area> |   </q-scroll-area> | ||||||
| @@ -395,15 +396,3 @@ export default { | |||||||
|   }, |   }, | ||||||
| }; | }; | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style scoped> |  | ||||||
| .commandLogo { |  | ||||||
|   cursor: pointer; |  | ||||||
|   transition: 10s; |  | ||||||
|   filter: drop-shadow(2px 1px 1px grey); |  | ||||||
| } |  | ||||||
| .commandLogo:hover { |  | ||||||
|   transition: 10s; |  | ||||||
|   transform: rotate(1080deg); |  | ||||||
| } |  | ||||||
| </style> |  | ||||||
|   | |||||||
| @@ -144,7 +144,7 @@ | |||||||
|         </q-menu> |         </q-menu> | ||||||
|       </q-item> |       </q-item> | ||||||
|       <!-- 收藏 --> |       <!-- 收藏 --> | ||||||
|       <q-item v-if="isTagStared" clickable> |       <q-item v-if="isTagStared" clickable @click="unMarkTag"> | ||||||
|         <q-item-section side> |         <q-item-section side> | ||||||
|           <q-icon name="star_border" /> |           <q-icon name="star_border" /> | ||||||
|         </q-item-section> |         </q-item-section> | ||||||
| @@ -176,7 +176,7 @@ | |||||||
|     </q-dialog> |     </q-dialog> | ||||||
|     <!-- 面板视图弹窗 --> |     <!-- 面板视图弹窗 --> | ||||||
|     <q-dialog v-model="showPanelConf"> |     <q-dialog v-model="showPanelConf"> | ||||||
|       <PanelSetting :isTagStared="isTagStared" /> |       <PanelSetting :isTagStared="isTagStared" :currentTag="currentTag" /> | ||||||
|     </q-dialog> |     </q-dialog> | ||||||
|   </q-menu> |   </q-menu> | ||||||
| </template> | </template> | ||||||
| @@ -218,6 +218,7 @@ export default { | |||||||
|   }, |   }, | ||||||
|   props: { |   props: { | ||||||
|     isTagStared: Boolean, |     isTagStared: Boolean, | ||||||
|  |     currentTag: String, | ||||||
|   }, |   }, | ||||||
|   methods: { |   methods: { | ||||||
|     // 导入命令且定位 |     // 导入命令且定位 | ||||||
| @@ -257,6 +258,13 @@ export default { | |||||||
|       this.$profile.backgroundImg = reset ? null : this.selectFile.path; |       this.$profile.backgroundImg = reset ? null : this.selectFile.path; | ||||||
|       this.configurationPage.$forceUpdate(); |       this.configurationPage.$forceUpdate(); | ||||||
|     }, |     }, | ||||||
|  |     unMarkTag() { | ||||||
|  |       this.$utools.whole.removeFeature( | ||||||
|  |         `panel_${window.hexEncode(this.currentTag)}` | ||||||
|  |       ); | ||||||
|  |       _.pull(this.$root.$refs.view.activatedQuickPanels, this.currentTag); | ||||||
|  |       quickcommand.showMessageBox("取消收藏成功"); | ||||||
|  |     }, | ||||||
|   }, |   }, | ||||||
| }; | }; | ||||||
| </script> | </script> | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| <template> | <template> | ||||||
|   <div> |   <div> | ||||||
|     <q-dialog v-model="showIconPicker" class="q-gutter" position="left"> |     <q-dialog v-model="showIconPicker" class="q-gutter" :position="position"> | ||||||
|       <q-card> |       <q-card> | ||||||
|         <q-card-section class="text-h5 text-center">更改图标</q-card-section> |         <q-card-section class="text-h5 text-center">更改图标</q-card-section> | ||||||
|         <q-card-section> |         <q-card-section> | ||||||
| @@ -108,6 +108,9 @@ export default { | |||||||
|       dataUrl: null, |       dataUrl: null, | ||||||
|     }; |     }; | ||||||
|   }, |   }, | ||||||
|  |   props: { | ||||||
|  |     position: String, | ||||||
|  |   }, | ||||||
|   methods: { |   methods: { | ||||||
|     setIcon(dataUrl) { |     setIcon(dataUrl) { | ||||||
|       this.dataUrl = dataUrl; |       this.dataUrl = dataUrl; | ||||||
|   | |||||||
| @@ -1,26 +1,84 @@ | |||||||
| <template> | <template> | ||||||
|   <q-card> |   <q-card style="width: 400px"> | ||||||
|     <q-card-section> |     <q-card-section> | ||||||
|       <q-input dense label="名称" v-model="panelConf.name" /> |       <div class="row q-gutter-md"> | ||||||
|       <q-input dense label="说明" v-model="panelConf.description" /> |         <div class="col-auto justify-center content-center flex q-pa-md"> | ||||||
|  |           <q-avatar square class="commandLogo"> | ||||||
|  |             <q-img | ||||||
|  |               :src="features.icon" | ||||||
|  |               @click="$refs.icon.showIconPicker = true" | ||||||
|  |           /></q-avatar> | ||||||
|  |         </div> | ||||||
|  |         <div class="col"> | ||||||
|  |           <q-select | ||||||
|  |             hide-dropdown-icon | ||||||
|  |             label-color="primary" | ||||||
|  |             transition-show="jump-down" | ||||||
|  |             transition-hide="jump-up" | ||||||
|  |             v-model="features.cmds" | ||||||
|  |             max-values="3" | ||||||
|  |             type="text" | ||||||
|  |             placeholder="键入后回车" | ||||||
|  |             use-input | ||||||
|  |             use-chips | ||||||
|  |             multiple | ||||||
|  |             new-value-mode="add-unique" | ||||||
|  |             input-debounce="0" | ||||||
|  |             label="关键字" | ||||||
|  |             @blur="features.cmds.length || features.cmds.push(currentTag)" | ||||||
|  |           /> | ||||||
|  |           <q-input | ||||||
|  |             label-color="primary" | ||||||
|  |             v-model="features.explain" | ||||||
|  |             type="text" | ||||||
|  |             placeholder="请输入描述" | ||||||
|  |             label="描述" | ||||||
|  |             @blur="features.explain || (features.explain = ' ')" | ||||||
|  |           /> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|     </q-card-section> |     </q-card-section> | ||||||
|     <q-card-actions align="right"> |     <q-card-actions align="right"> | ||||||
|       <q-btn flat label="取消" color="grey" v-close-popup /> |       <q-btn flat label="取消" color="grey" v-close-popup /> | ||||||
|       <q-btn flat label="禁用" color="negative" v-close-popup /> |       <q-btn flat label="确定" color="primary" v-close-popup @click="markTag" /> | ||||||
|       <q-btn flat label="启用" color="primary" v-close-popup /> |  | ||||||
|     </q-card-actions> |     </q-card-actions> | ||||||
|  |     <IconPicker | ||||||
|  |       ref="icon" | ||||||
|  |       @iconChanged="(dataUrl) => (features.icon = dataUrl)" | ||||||
|  |       position="right" | ||||||
|  |     /> | ||||||
|   </q-card> |   </q-card> | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script> | <script> | ||||||
|  | import IconPicker from "components/IconPicker"; | ||||||
|  |  | ||||||
| export default { | export default { | ||||||
|  |   components: { IconPicker }, | ||||||
|   data() { |   data() { | ||||||
|     return { |     return { | ||||||
|       panelConf: { |       features: { | ||||||
|         name: "", |         explain: `进入${this.currentTag}的面板视图`, | ||||||
|         description: "", |         icon: "/logo.png", | ||||||
|  |         cmds: [this.currentTag], | ||||||
|  |         platform: ["win32", "darwin", "linux"], | ||||||
|  |         code: `panel_${window.hexEncode(this.currentTag)}`, | ||||||
|       }, |       }, | ||||||
|     }; |     }; | ||||||
|   }, |   }, | ||||||
|  |   props: { | ||||||
|  |     currentTag: String, | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     markTag() { | ||||||
|  |       this.$utools.whole.setFeature(_.cloneDeep(this.features)); | ||||||
|  |       this.$root.$refs.view.activatedQuickPanels.push(this.currentTag); | ||||||
|  |       quickcommand.showMessageBox( | ||||||
|  |         `主输入框输入『${this.features.cmds.join("、")}』即可直接进入『${ | ||||||
|  |           this.currentTag | ||||||
|  |         }』的面板视图` | ||||||
|  |       ); | ||||||
|  |     }, | ||||||
|  |   }, | ||||||
| }; | }; | ||||||
| </script> | </script> | ||||||
|   | |||||||
| @@ -164,6 +164,7 @@ | |||||||
|               ><q-spinner-bars color="primary" size="1.5em" /> |               ><q-spinner-bars color="primary" size="1.5em" /> | ||||||
|               <ConfigurationMenu |               <ConfigurationMenu | ||||||
|                 :isTagStared="activatedQuickPanels.includes(currentTag)" |                 :isTagStared="activatedQuickPanels.includes(currentTag)" | ||||||
|  |                 :currentTag="currentTag" | ||||||
|               ></ConfigurationMenu> |               ></ConfigurationMenu> | ||||||
|             </q-btn> |             </q-btn> | ||||||
|           </q-btn-group> |           </q-btn-group> | ||||||
| @@ -313,6 +314,10 @@ export default { | |||||||
|       // 所有的快捷命令 |       // 所有的快捷命令 | ||||||
|       this.allQuickCommands = this.getAllQuickCommands(); |       this.allQuickCommands = this.getAllQuickCommands(); | ||||||
|       this.importDefaultCommands(); |       this.importDefaultCommands(); | ||||||
|  |       if (this.$route.params.tags) { | ||||||
|  |         this.currentTag = window.hexDecode(this.$route.params.tags); | ||||||
|  |         this.commandCardStyle = "mini"; | ||||||
|  |       } | ||||||
|     }, |     }, | ||||||
|     importDefaultCommands() { |     importDefaultCommands() { | ||||||
|       for (var code of Object.keys(defaultCommands)) { |       for (var code of Object.keys(defaultCommands)) { | ||||||
| @@ -327,7 +332,7 @@ export default { | |||||||
|       let quickpanels = []; |       let quickpanels = []; | ||||||
|       features.forEach((x) => |       features.forEach((x) => | ||||||
|         x.code.slice(0, 6) == "panel_" |         x.code.slice(0, 6) == "panel_" | ||||||
|           ? quickpanels.push(hexDecode(x.code.slice(6))) |           ? quickpanels.push(window.hexDecode(x.code.slice(6))) | ||||||
|           : currentFts.push(x) |           : currentFts.push(x) | ||||||
|       ); |       ); | ||||||
|       return { |       return { | ||||||
|   | |||||||
| @@ -2,43 +2,43 @@ const routes = [{ | |||||||
|         path: '/configuration', |         path: '/configuration', | ||||||
|         name: 'configuration', |         name: 'configuration', | ||||||
|         component: () => |         component: () => | ||||||
|             import('pages/ConfigurationPage.vue') |             import ('pages/ConfigurationPage.vue') | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|         path: '/code', |         path: '/code', | ||||||
|         name: 'code', |         name: 'code', | ||||||
|         component: () => |         component: () => | ||||||
|             import('pages/RunCodePage.vue') |             import ('pages/RunCodePage.vue') | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|         path: '/newcommand', |         path: '/newcommand', | ||||||
|         component: () => |         component: () => | ||||||
|             import('pages/NewCommand.vue') |             import ('pages/NewCommand.vue') | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|         path: '/:type(default|files|img|key|regex|window|professional)_:uid(\\w+)', |         path: '/:type(default|files|img|key|regex|window|professional)_:uid(\\w+)', | ||||||
|         name: 'command', |         name: 'command', | ||||||
|         component: () => |         component: () => | ||||||
|             import('pages/CommandPage.vue') |             import ('pages/CommandPage.vue') | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|         path: '/panel_:tags(\\w+)', |         path: '/panel_:tags(\\w+)', | ||||||
|         name: 'panel', |         name: 'panel', | ||||||
|         component: () => |         component: () => | ||||||
|             import('pages/ConfigurationPage.vue') |             import ('pages/ConfigurationPage.vue') | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|         path: '/needupdate', |         path: '/needupdate', | ||||||
|         name: 'needupdate', |         name: 'needupdate', | ||||||
|         props: true, |         props: true, | ||||||
|         component: () => |         component: () => | ||||||
|             import('pages/updateWarningPage.vue') |             import ('pages/updateWarningPage.vue') | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|         path: '/loading', |         path: '/loading', | ||||||
|         name: 'loading', |         name: 'loading', | ||||||
|         component: () => |         component: () => | ||||||
|             import('pages/LoadingPage.vue') |             import ('pages/LoadingPage.vue') | ||||||
|     } |     } | ||||||
|  |  | ||||||
| ] | ] | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user