| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- import { createSimpleContext } from "@opencode-ai/ui/context"
- import { AsyncStorage, SyncStorage } from "@solid-primitives/storage"
- import type { Accessor } from "solid-js"
- export type Platform = {
- /** Platform discriminator */
- platform: "web" | "desktop"
- /** Desktop OS (Tauri only) */
- os?: "macos" | "windows" | "linux"
- /** App version */
- version?: string
- /** Open a URL in the default browser */
- openLink(url: string): void
- /** Open a local path in a local app (desktop only) */
- openPath?(path: string, app?: string): Promise<void>
- /** Restart the app */
- restart(): Promise<void>
- /** Navigate back in history */
- back(): void
- /** Navigate forward in history */
- forward(): void
- /** Send a system notification (optional deep link) */
- notify(title: string, description?: string, href?: string): Promise<void>
- /** Open directory picker dialog (native on Tauri, server-backed on web) */
- openDirectoryPickerDialog?(opts?: { title?: string; multiple?: boolean }): Promise<string | string[] | null>
- /** Open native file picker dialog (Tauri only) */
- openFilePickerDialog?(opts?: { title?: string; multiple?: boolean }): Promise<string | string[] | null>
- /** Save file picker dialog (Tauri only) */
- saveFilePickerDialog?(opts?: { title?: string; defaultPath?: string }): Promise<string | null>
- /** Storage mechanism, defaults to localStorage */
- storage?: (name?: string) => SyncStorage | AsyncStorage
- /** Check for updates (Tauri only) */
- checkUpdate?(): Promise<{ updateAvailable: boolean; version?: string }>
- /** Install updates (Tauri only) */
- update?(): Promise<void>
- /** Fetch override */
- fetch?: typeof fetch
- /** Get the configured default server URL (platform-specific) */
- getDefaultServerUrl?(): Promise<string | null> | string | null
- /** Set the default server URL to use on app startup (platform-specific) */
- setDefaultServerUrl?(url: string | null): Promise<void> | void
- /** Parse markdown to HTML using native parser (desktop only, returns unprocessed code blocks) */
- parseMarkdown?(markdown: string): Promise<string>
- /** Webview zoom level (desktop only) */
- webviewZoom?: Accessor<number>
- /** Check if an editor app exists (desktop only) */
- checkAppExists?(appName: string): Promise<boolean>
- /** Read image from clipboard (desktop only) */
- readClipboardImage?(): Promise<File | null>
- }
- export const { use: usePlatform, provider: PlatformProvider } = createSimpleContext({
- name: "Platform",
- init: (props: { value: Platform }) => {
- return props.value
- },
- })
|