diff --git a/src/components/CommandRunResult.vue b/src/components/CommandRunResult.vue index ba549d8..1ceaf0d 100644 --- a/src/components/CommandRunResult.vue +++ b/src/components/CommandRunResult.vue @@ -241,6 +241,8 @@ export default { if (!!this.child) { quickcommand.kill(this.child.pid); } + quickcommand.closeWaitBtn?.(); + quickcommand.closeWaitBtn = () => {}; if (!!this.listener) { this.subInputValue = ""; utools.removeSubInput(); diff --git a/src/components/quickcommandUI/WaitButton.vue b/src/components/quickcommandUI/WaitButton.vue index 3e86f8c..80eede7 100644 --- a/src/components/quickcommandUI/WaitButton.vue +++ b/src/components/quickcommandUI/WaitButton.vue @@ -4,6 +4,7 @@ seamless position="right" @hide="onDialogHide" + style="z-index: 9999" > @@ -16,8 +17,10 @@ export default { props: { label: String, }, - mounted(){ - console.log(this); + mounted() { + quickcommand.closeWaitBtn = () => { + this.$refs?.dialog?.hide(); + }; }, emits: ["ok", "hide"], methods: { diff --git a/src/json/default_shellRunner.json b/src/json/default_shellRunner.json index 1c06af5..da2128c 100644 --- a/src/json/default_shellRunner.json +++ b/src/json/default_shellRunner.json @@ -1,15 +1,23 @@ { "program": "quickcommand", - "cmd": "const iconv = require('iconv-lite')\nconst child_process = require(\"child_process\")\nvar child = child_process.spawn(`{{subinput}}`, {shell: true, encoding: 'buffer'})\n\nchild.stdout.on('data', data => {\n var codec = utools.isWindows() ? 'cp936' : 'utf8'\n console.log(iconv.decode(data, codec))\n})\n\nchild.stderr.on('data', data => {\n var codec = utools.isWindows() ? 'cp936' : 'utf8'\n console.error(iconv.decode(data, codec))\n})", + "cmd": "const iconv = require('iconv-lite')\nconst child_process = require(\"child_process\")\nvar child = child_process.spawn(`{{subinput}}`, {shell: true, encoding: 'buffer'})\n\nchild.stdout.on('data', data => {\n var codec = utools.isWindows() ? 'cp936' : 'utf8'\n console.log(iconv.decode(data, codec))\n})\n\nchild.stderr.on('data', data => {\n var codec = utools.isWindows() ? 'cp936' : 'utf8'\n console.error(iconv.decode(data, codec))\n})\n\nquickcommand.showWaitButton(()=>{\n quickcommand.kill(child.pid)\n}, \"中止命令\")", "scptarg": "", "features": { "explain": "执行 shell 命令", - "platform": ["win32", "darwin", "linux"], + "platform": [ + "win32", + "darwin", + "linux" + ], "icon": "", "code": "default_shellRunner", - "cmds": ["sh"] + "cmds": [ + "sh" + ] }, "output": "text", "hasSubInput": true, - "tags": ["默认"] -} + "tags": [ + "默认" + ] +} \ No newline at end of file diff --git a/src/plugins/monaco/types/quickcommand.api.d.ts b/src/plugins/monaco/types/quickcommand.api.d.ts index 2902f12..e19b01e 100644 --- a/src/plugins/monaco/types/quickcommand.api.d.ts +++ b/src/plugins/monaco/types/quickcommand.api.d.ts @@ -157,8 +157,8 @@ interface quickcommandApi { * @param message 提示的内容 * @param title 提示的标题 */ - showConfirmBox(message?: string, title?: string): Promise; - + showConfirmBox(message?: string, title?: string): Promise; + /** * 显示等待用户操作的按钮,用户点击后执行相关操作 * @@ -172,6 +172,11 @@ interface quickcommandApi { */ showWaitButton(callback, label?: string): void; + /** + * 关掉现有等待操作按钮 + */ + closeWaitBtn(): void; + /** * 同步等待,会阻塞进程 * @param ms 等待的毫秒数 @@ -270,14 +275,18 @@ interface quickcommandApi { /** * 将 signal 发送给 pid 标识的进程 , 默认为关闭进程 - * + * * 不同于process.kill,会将该进程启用的所有子进程也杀死 - * + * * @param pid 进程 ID * @param signal 进程信号,默认为SIGTERM * @param callback 失败时的回调 */ - kill(pid: number, signal?: string | number, callback?: (error?: Error) => void): void; + kill( + pid: number, + signal?: string | number, + callback?: (error?: Error) => void + ): void; /** * windows 下运行 VBS 脚本并返回运行结果