1a1254f045
CI - 构建、测试和质量检查 / Rust 代码检查 (push) Has been cancelled
CI - 构建、测试和质量检查 / 单元测试 (push) Has been cancelled
CI - 构建、测试和质量检查 / 代码格式检查 (push) Has been cancelled
CI - 构建、测试和质量检查 / Clippy 代码质量检查 (push) Has been cancelled
CI - 构建、测试和质量检查 / 构建可执行文件 (claude_code_rs, macos-latest, x86_64-apple-darwin) (push) Has been cancelled
CI - 构建、测试和质量检查 / 构建可执行文件 (claude_code_rs, ubuntu-latest, x86_64-unknown-linux-gnu) (push) Has been cancelled
CI - 构建、测试和质量检查 / 构建可执行文件 (claude_code_rs.exe, windows-latest, x86_64-pc-windows-msvc) (push) Has been cancelled
- 添加 Rust GUI 桌面应用程序入口点 - 添加 TypeScript/JavaScript 项目基础结构文件 - 包含组件、工具、命令、服务和工具定义 - 添加配置文件如 .gitignore、.gitattributes 和 LICENSE - 包含图片资源和演示文件 - 为各种功能模块添加占位符和类型定义
59 lines
1.5 KiB
TypeScript
59 lines
1.5 KiB
TypeScript
import { createRequire } from 'module'
|
|
import { fileURLToPath } from 'url'
|
|
import { dirname, join } from 'path'
|
|
|
|
type UrlHandlerNapi = {
|
|
waitForUrlEvent(timeoutMs: number): string | null
|
|
}
|
|
|
|
let cachedModule: UrlHandlerNapi | null = null
|
|
|
|
function loadModule(): UrlHandlerNapi | null {
|
|
if (cachedModule) {
|
|
return cachedModule
|
|
}
|
|
|
|
// Only works on macOS
|
|
if (process.platform !== 'darwin') {
|
|
return null
|
|
}
|
|
|
|
try {
|
|
if (process.env.URL_HANDLER_NODE_PATH) {
|
|
// Bundled mode - use the env var path
|
|
// eslint-disable-next-line @typescript-eslint/no-require-imports
|
|
cachedModule = require(process.env.URL_HANDLER_NODE_PATH) as UrlHandlerNapi
|
|
} else {
|
|
// Dev mode - load from vendor directory
|
|
const modulePath = join(
|
|
dirname(fileURLToPath(import.meta.url)),
|
|
'..',
|
|
'url-handler',
|
|
`${process.arch}-darwin`,
|
|
'url-handler.node',
|
|
)
|
|
cachedModule = createRequire(import.meta.url)(modulePath) as UrlHandlerNapi
|
|
}
|
|
return cachedModule
|
|
} catch {
|
|
return null
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Wait for a macOS URL event (Apple Event kAEGetURL).
|
|
*
|
|
* Initializes NSApplication, registers for the URL event, and pumps
|
|
* the event loop for up to `timeoutMs` milliseconds.
|
|
*
|
|
* Returns the URL string if one was received, or null.
|
|
* Only functional on macOS — returns null on other platforms.
|
|
*/
|
|
export function waitForUrlEvent(timeoutMs: number): string | null {
|
|
const mod = loadModule()
|
|
if (!mod) {
|
|
return null
|
|
}
|
|
return mod.waitForUrlEvent(timeoutMs)
|
|
}
|