Files
Serendipity 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
feat: 添加初始项目结构和基础文件
- 添加 Rust GUI 桌面应用程序入口点
- 添加 TypeScript/JavaScript 项目基础结构文件
- 包含组件、工具、命令、服务和工具定义
- 添加配置文件如 .gitignore、.gitattributes 和 LICENSE
- 包含图片资源和演示文件
- 为各种功能模块添加占位符和类型定义
2026-04-20 16:58:22 +08:00

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)
}