From dce4c05fa9168ca78029142b06363c910cedd06c Mon Sep 17 00:00:00 2001 From: Filip <34747899+neriousy@users.noreply.github.com> Date: Tue, 10 Feb 2026 22:10:58 +0100 Subject: fix(desktop): open apps with executables on Windows (#13022) --- packages/desktop/src/bindings.ts | 1 + packages/desktop/src/index.tsx | 7 ++++++- 2 files changed, 7 insertions(+), 1 deletion(-) (limited to 'packages/desktop/src') diff --git a/packages/desktop/src/bindings.ts b/packages/desktop/src/bindings.ts index 2db1a624c..c7bcaba9c 100644 --- a/packages/desktop/src/bindings.ts +++ b/packages/desktop/src/bindings.ts @@ -14,6 +14,7 @@ export const commands = { setDisplayBackend: (backend: LinuxDisplayBackend) => __TAURI_INVOKE("set_display_backend", { backend }), parseMarkdownCommand: (markdown: string) => __TAURI_INVOKE("parse_markdown_command", { markdown }), checkAppExists: (appName: string) => __TAURI_INVOKE("check_app_exists", { appName }), + resolveAppPath: (appName: string) => __TAURI_INVOKE("resolve_app_path", { appName }), }; /** Events */ diff --git a/packages/desktop/src/index.tsx b/packages/desktop/src/index.tsx index 25e9f825c..0e2fcb7fe 100644 --- a/packages/desktop/src/index.tsx +++ b/packages/desktop/src/index.tsx @@ -98,7 +98,12 @@ const createPlatform = (password: Accessor): Platform => ({ void shellOpen(url).catch(() => undefined) }, - openPath(path: string, app?: string) { + async openPath(path: string, app?: string) { + const os = ostype() + if (os === "windows" && app) { + const resolvedApp = await commands.resolveAppPath(app) + return openerOpenPath(path, resolvedApp || app) + } return openerOpenPath(path, app) }, -- cgit v1.2.3