cerebras-cli 1.0.1 → 1.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (314) hide show
  1. package/README.md +3 -5
  2. package/cerebras-cli-1.0.0.tgz +0 -0
  3. package/package.json +7 -88
  4. package/AGENTS.md +0 -27
  5. package/Dockerfile +0 -10
  6. package/bunfig.toml +0 -4
  7. package/parsers-config.ts +0 -239
  8. package/script/build.ts +0 -151
  9. package/script/postinstall.mjs +0 -122
  10. package/script/publish.ts +0 -256
  11. package/script/schema.ts +0 -47
  12. package/src/acp/README.md +0 -164
  13. package/src/acp/agent.ts +0 -812
  14. package/src/acp/session.ts +0 -70
  15. package/src/acp/types.ts +0 -22
  16. package/src/agent/agent.ts +0 -310
  17. package/src/agent/generate.txt +0 -75
  18. package/src/auth/index.ts +0 -70
  19. package/src/bun/index.ts +0 -152
  20. package/src/bus/global.ts +0 -10
  21. package/src/bus/index.ts +0 -142
  22. package/src/cli/bootstrap.ts +0 -17
  23. package/src/cli/cmd/acp.ts +0 -88
  24. package/src/cli/cmd/agent.ts +0 -165
  25. package/src/cli/cmd/auth.ts +0 -369
  26. package/src/cli/cmd/cmd.ts +0 -7
  27. package/src/cli/cmd/debug/config.ts +0 -15
  28. package/src/cli/cmd/debug/file.ts +0 -91
  29. package/src/cli/cmd/debug/index.ts +0 -41
  30. package/src/cli/cmd/debug/lsp.ts +0 -47
  31. package/src/cli/cmd/debug/ripgrep.ts +0 -83
  32. package/src/cli/cmd/debug/scrap.ts +0 -15
  33. package/src/cli/cmd/debug/snapshot.ts +0 -48
  34. package/src/cli/cmd/export.ts +0 -88
  35. package/src/cli/cmd/generate.ts +0 -38
  36. package/src/cli/cmd/github.ts +0 -1200
  37. package/src/cli/cmd/import.ts +0 -98
  38. package/src/cli/cmd/mcp.ts +0 -400
  39. package/src/cli/cmd/models.ts +0 -77
  40. package/src/cli/cmd/pr.ts +0 -112
  41. package/src/cli/cmd/run.ts +0 -342
  42. package/src/cli/cmd/serve.ts +0 -31
  43. package/src/cli/cmd/session.ts +0 -106
  44. package/src/cli/cmd/stats.ts +0 -298
  45. package/src/cli/cmd/tui/app.tsx +0 -732
  46. package/src/cli/cmd/tui/attach.ts +0 -25
  47. package/src/cli/cmd/tui/component/border.tsx +0 -21
  48. package/src/cli/cmd/tui/component/dialog-agent.tsx +0 -31
  49. package/src/cli/cmd/tui/component/dialog-command.tsx +0 -124
  50. package/src/cli/cmd/tui/component/dialog-feedback.tsx +0 -160
  51. package/src/cli/cmd/tui/component/dialog-mcp.tsx +0 -86
  52. package/src/cli/cmd/tui/component/dialog-model.tsx +0 -223
  53. package/src/cli/cmd/tui/component/dialog-notification.tsx +0 -78
  54. package/src/cli/cmd/tui/component/dialog-provider.tsx +0 -222
  55. package/src/cli/cmd/tui/component/dialog-session-list.tsx +0 -97
  56. package/src/cli/cmd/tui/component/dialog-session-rename.tsx +0 -31
  57. package/src/cli/cmd/tui/component/dialog-status.tsx +0 -114
  58. package/src/cli/cmd/tui/component/dialog-tag.tsx +0 -44
  59. package/src/cli/cmd/tui/component/dialog-theme-list.tsx +0 -50
  60. package/src/cli/cmd/tui/component/logo.tsx +0 -37
  61. package/src/cli/cmd/tui/component/notification-banner.tsx +0 -58
  62. package/src/cli/cmd/tui/component/prompt/autocomplete.tsx +0 -530
  63. package/src/cli/cmd/tui/component/prompt/history.tsx +0 -107
  64. package/src/cli/cmd/tui/component/prompt/index.tsx +0 -931
  65. package/src/cli/cmd/tui/context/args.tsx +0 -14
  66. package/src/cli/cmd/tui/context/directory.ts +0 -12
  67. package/src/cli/cmd/tui/context/exit.tsx +0 -23
  68. package/src/cli/cmd/tui/context/helper.tsx +0 -25
  69. package/src/cli/cmd/tui/context/keybind.tsx +0 -111
  70. package/src/cli/cmd/tui/context/kv.tsx +0 -49
  71. package/src/cli/cmd/tui/context/local.tsx +0 -339
  72. package/src/cli/cmd/tui/context/prompt.tsx +0 -18
  73. package/src/cli/cmd/tui/context/route.tsx +0 -45
  74. package/src/cli/cmd/tui/context/sdk.tsx +0 -75
  75. package/src/cli/cmd/tui/context/sync.tsx +0 -374
  76. package/src/cli/cmd/tui/context/theme/aura.json +0 -69
  77. package/src/cli/cmd/tui/context/theme/ayu.json +0 -80
  78. package/src/cli/cmd/tui/context/theme/catppuccin-macchiato.json +0 -233
  79. package/src/cli/cmd/tui/context/theme/catppuccin.json +0 -112
  80. package/src/cli/cmd/tui/context/theme/cobalt2.json +0 -228
  81. package/src/cli/cmd/tui/context/theme/dracula.json +0 -219
  82. package/src/cli/cmd/tui/context/theme/everforest.json +0 -241
  83. package/src/cli/cmd/tui/context/theme/flexoki.json +0 -237
  84. package/src/cli/cmd/tui/context/theme/github.json +0 -233
  85. package/src/cli/cmd/tui/context/theme/gruvbox.json +0 -95
  86. package/src/cli/cmd/tui/context/theme/kanagawa.json +0 -77
  87. package/src/cli/cmd/tui/context/theme/material.json +0 -235
  88. package/src/cli/cmd/tui/context/theme/matrix.json +0 -77
  89. package/src/cli/cmd/tui/context/theme/mercury.json +0 -252
  90. package/src/cli/cmd/tui/context/theme/monokai.json +0 -221
  91. package/src/cli/cmd/tui/context/theme/nightowl.json +0 -221
  92. package/src/cli/cmd/tui/context/theme/nord.json +0 -223
  93. package/src/cli/cmd/tui/context/theme/one-dark.json +0 -84
  94. package/src/cli/cmd/tui/context/theme/orng.json +0 -245
  95. package/src/cli/cmd/tui/context/theme/palenight.json +0 -222
  96. package/src/cli/cmd/tui/context/theme/rosepine.json +0 -234
  97. package/src/cli/cmd/tui/context/theme/solarized.json +0 -223
  98. package/src/cli/cmd/tui/context/theme/synthwave84.json +0 -226
  99. package/src/cli/cmd/tui/context/theme/tokyonight.json +0 -243
  100. package/src/cli/cmd/tui/context/theme/vercel.json +0 -245
  101. package/src/cli/cmd/tui/context/theme/vesper.json +0 -218
  102. package/src/cli/cmd/tui/context/theme/zenburn.json +0 -223
  103. package/src/cli/cmd/tui/context/theme.tsx +0 -1077
  104. package/src/cli/cmd/tui/event.ts +0 -39
  105. package/src/cli/cmd/tui/routes/home.tsx +0 -104
  106. package/src/cli/cmd/tui/routes/session/dialog-message.tsx +0 -93
  107. package/src/cli/cmd/tui/routes/session/dialog-timeline.tsx +0 -37
  108. package/src/cli/cmd/tui/routes/session/footer.tsx +0 -76
  109. package/src/cli/cmd/tui/routes/session/header.tsx +0 -183
  110. package/src/cli/cmd/tui/routes/session/index.tsx +0 -1703
  111. package/src/cli/cmd/tui/routes/session/sidebar.tsx +0 -586
  112. package/src/cli/cmd/tui/spawn.ts +0 -60
  113. package/src/cli/cmd/tui/thread.ts +0 -120
  114. package/src/cli/cmd/tui/ui/dialog-alert.tsx +0 -55
  115. package/src/cli/cmd/tui/ui/dialog-confirm.tsx +0 -81
  116. package/src/cli/cmd/tui/ui/dialog-help.tsx +0 -36
  117. package/src/cli/cmd/tui/ui/dialog-prompt.tsx +0 -75
  118. package/src/cli/cmd/tui/ui/dialog-select.tsx +0 -317
  119. package/src/cli/cmd/tui/ui/dialog.tsx +0 -170
  120. package/src/cli/cmd/tui/ui/spinner.ts +0 -368
  121. package/src/cli/cmd/tui/ui/toast.tsx +0 -100
  122. package/src/cli/cmd/tui/util/clipboard.ts +0 -127
  123. package/src/cli/cmd/tui/util/editor.ts +0 -32
  124. package/src/cli/cmd/tui/util/terminal.ts +0 -114
  125. package/src/cli/cmd/tui/worker.ts +0 -63
  126. package/src/cli/cmd/uninstall.ts +0 -344
  127. package/src/cli/cmd/upgrade.ts +0 -67
  128. package/src/cli/cmd/web.ts +0 -84
  129. package/src/cli/error.ts +0 -55
  130. package/src/cli/ui.ts +0 -84
  131. package/src/cli/upgrade.ts +0 -25
  132. package/src/command/index.ts +0 -79
  133. package/src/command/template/initialize.txt +0 -10
  134. package/src/command/template/review.txt +0 -73
  135. package/src/config/config.ts +0 -886
  136. package/src/config/markdown.ts +0 -41
  137. package/src/env/index.ts +0 -26
  138. package/src/file/fzf.ts +0 -124
  139. package/src/file/ignore.ts +0 -83
  140. package/src/file/index.ts +0 -326
  141. package/src/file/ripgrep.ts +0 -391
  142. package/src/file/time.ts +0 -38
  143. package/src/file/watcher.ts +0 -89
  144. package/src/flag/flag.ts +0 -28
  145. package/src/format/formatter.ts +0 -277
  146. package/src/format/index.ts +0 -137
  147. package/src/global/index.ts +0 -52
  148. package/src/id/id.ts +0 -73
  149. package/src/ide/index.ts +0 -75
  150. package/src/index.ts +0 -158
  151. package/src/installation/index.ts +0 -194
  152. package/src/lsp/client.ts +0 -215
  153. package/src/lsp/index.ts +0 -370
  154. package/src/lsp/language.ts +0 -111
  155. package/src/lsp/server.ts +0 -1327
  156. package/src/mcp/auth.ts +0 -82
  157. package/src/mcp/index.ts +0 -576
  158. package/src/mcp/oauth-callback.ts +0 -203
  159. package/src/mcp/oauth-provider.ts +0 -132
  160. package/src/notification/index.ts +0 -101
  161. package/src/patch/index.ts +0 -622
  162. package/src/permission/index.ts +0 -198
  163. package/src/plugin/index.ts +0 -95
  164. package/src/project/bootstrap.ts +0 -31
  165. package/src/project/instance.ts +0 -68
  166. package/src/project/project.ts +0 -133
  167. package/src/project/state.ts +0 -65
  168. package/src/project/vcs.ts +0 -77
  169. package/src/provider/auth.ts +0 -143
  170. package/src/provider/models-macro.ts +0 -11
  171. package/src/provider/models.ts +0 -93
  172. package/src/provider/provider.ts +0 -996
  173. package/src/provider/sdk/openai-compatible/src/README.md +0 -5
  174. package/src/provider/sdk/openai-compatible/src/index.ts +0 -2
  175. package/src/provider/sdk/openai-compatible/src/openai-compatible-provider.ts +0 -100
  176. package/src/provider/sdk/openai-compatible/src/responses/convert-to-openai-responses-input.ts +0 -303
  177. package/src/provider/sdk/openai-compatible/src/responses/map-openai-responses-finish-reason.ts +0 -27
  178. package/src/provider/sdk/openai-compatible/src/responses/openai-config.ts +0 -18
  179. package/src/provider/sdk/openai-compatible/src/responses/openai-error.ts +0 -22
  180. package/src/provider/sdk/openai-compatible/src/responses/openai-responses-api-types.ts +0 -207
  181. package/src/provider/sdk/openai-compatible/src/responses/openai-responses-language-model.ts +0 -1713
  182. package/src/provider/sdk/openai-compatible/src/responses/openai-responses-prepare-tools.ts +0 -177
  183. package/src/provider/sdk/openai-compatible/src/responses/openai-responses-settings.ts +0 -1
  184. package/src/provider/sdk/openai-compatible/src/responses/tool/code-interpreter.ts +0 -88
  185. package/src/provider/sdk/openai-compatible/src/responses/tool/file-search.ts +0 -128
  186. package/src/provider/sdk/openai-compatible/src/responses/tool/image-generation.ts +0 -115
  187. package/src/provider/sdk/openai-compatible/src/responses/tool/local-shell.ts +0 -65
  188. package/src/provider/sdk/openai-compatible/src/responses/tool/web-search-preview.ts +0 -104
  189. package/src/provider/sdk/openai-compatible/src/responses/tool/web-search.ts +0 -103
  190. package/src/provider/transform.ts +0 -406
  191. package/src/pty/index.ts +0 -226
  192. package/src/ratelimit/index.ts +0 -185
  193. package/src/server/error.ts +0 -36
  194. package/src/server/project.ts +0 -50
  195. package/src/server/server.ts +0 -2463
  196. package/src/server/tui.ts +0 -71
  197. package/src/session/compaction.ts +0 -257
  198. package/src/session/index.ts +0 -470
  199. package/src/session/message-v2.ts +0 -641
  200. package/src/session/message.ts +0 -189
  201. package/src/session/processor.ts +0 -443
  202. package/src/session/prompt/anthropic-20250930.txt +0 -166
  203. package/src/session/prompt/anthropic.txt +0 -105
  204. package/src/session/prompt/anthropic_spoof.txt +0 -1
  205. package/src/session/prompt/beast.txt +0 -147
  206. package/src/session/prompt/build-switch.txt +0 -5
  207. package/src/session/prompt/codex.txt +0 -318
  208. package/src/session/prompt/compaction.txt +0 -12
  209. package/src/session/prompt/copilot-gpt-5.txt +0 -143
  210. package/src/session/prompt/gemini.txt +0 -155
  211. package/src/session/prompt/max-steps.txt +0 -16
  212. package/src/session/prompt/plan-reminder-anthropic.txt +0 -67
  213. package/src/session/prompt/plan.txt +0 -26
  214. package/src/session/prompt/polaris.txt +0 -107
  215. package/src/session/prompt/qwen.txt +0 -109
  216. package/src/session/prompt/summarize.txt +0 -4
  217. package/src/session/prompt/title.txt +0 -36
  218. package/src/session/prompt.ts +0 -1541
  219. package/src/session/retry.ts +0 -82
  220. package/src/session/revert.ts +0 -108
  221. package/src/session/status.ts +0 -75
  222. package/src/session/summary.ts +0 -203
  223. package/src/session/system.ts +0 -148
  224. package/src/session/todo.ts +0 -36
  225. package/src/share/share-next.ts +0 -195
  226. package/src/share/share.ts +0 -87
  227. package/src/snapshot/index.ts +0 -197
  228. package/src/storage/storage.ts +0 -226
  229. package/src/telemetry/index.ts +0 -232
  230. package/src/tool/bash.ts +0 -365
  231. package/src/tool/bash.txt +0 -128
  232. package/src/tool/batch.ts +0 -173
  233. package/src/tool/batch.txt +0 -28
  234. package/src/tool/codesearch.ts +0 -138
  235. package/src/tool/codesearch.txt +0 -12
  236. package/src/tool/edit.ts +0 -674
  237. package/src/tool/edit.txt +0 -10
  238. package/src/tool/glob.ts +0 -65
  239. package/src/tool/glob.txt +0 -6
  240. package/src/tool/grep.ts +0 -120
  241. package/src/tool/grep.txt +0 -8
  242. package/src/tool/invalid.ts +0 -17
  243. package/src/tool/ls.ts +0 -110
  244. package/src/tool/ls.txt +0 -1
  245. package/src/tool/lsp-diagnostics.ts +0 -26
  246. package/src/tool/lsp-diagnostics.txt +0 -1
  247. package/src/tool/lsp-hover.ts +0 -31
  248. package/src/tool/lsp-hover.txt +0 -1
  249. package/src/tool/multiedit.ts +0 -46
  250. package/src/tool/multiedit.txt +0 -41
  251. package/src/tool/patch.ts +0 -233
  252. package/src/tool/patch.txt +0 -1
  253. package/src/tool/read.ts +0 -217
  254. package/src/tool/read.txt +0 -12
  255. package/src/tool/registry.ts +0 -148
  256. package/src/tool/task.ts +0 -135
  257. package/src/tool/task.txt +0 -60
  258. package/src/tool/todo.ts +0 -39
  259. package/src/tool/todoread.txt +0 -14
  260. package/src/tool/todowrite.txt +0 -167
  261. package/src/tool/tool.ts +0 -66
  262. package/src/tool/webfetch.ts +0 -187
  263. package/src/tool/webfetch.txt +0 -14
  264. package/src/tool/websearch.ts +0 -150
  265. package/src/tool/websearch.txt +0 -11
  266. package/src/tool/write.ts +0 -99
  267. package/src/tool/write.txt +0 -8
  268. package/src/types/shims.d.ts +0 -3
  269. package/src/util/color.ts +0 -19
  270. package/src/util/context.ts +0 -25
  271. package/src/util/defer.ts +0 -12
  272. package/src/util/eventloop.ts +0 -20
  273. package/src/util/filesystem.ts +0 -69
  274. package/src/util/fn.ts +0 -11
  275. package/src/util/iife.ts +0 -3
  276. package/src/util/keybind.ts +0 -79
  277. package/src/util/lazy.ts +0 -11
  278. package/src/util/locale.ts +0 -81
  279. package/src/util/lock.ts +0 -98
  280. package/src/util/log.ts +0 -177
  281. package/src/util/queue.ts +0 -32
  282. package/src/util/rpc.ts +0 -42
  283. package/src/util/scrap.ts +0 -10
  284. package/src/util/signal.ts +0 -12
  285. package/src/util/timeout.ts +0 -14
  286. package/src/util/token.ts +0 -7
  287. package/src/util/wildcard.ts +0 -54
  288. package/sst-env.d.ts +0 -9
  289. package/test/bun.test.ts +0 -53
  290. package/test/config/agent-color.test.ts +0 -66
  291. package/test/config/config.test.ts +0 -503
  292. package/test/config/markdown.test.ts +0 -89
  293. package/test/file/ignore.test.ts +0 -10
  294. package/test/fixture/fixture.ts +0 -28
  295. package/test/fixture/lsp/fake-lsp-server.js +0 -77
  296. package/test/ide/ide.test.ts +0 -82
  297. package/test/keybind.test.ts +0 -317
  298. package/test/lsp/client.test.ts +0 -95
  299. package/test/patch/patch.test.ts +0 -348
  300. package/test/preload.ts +0 -38
  301. package/test/project/project.test.ts +0 -42
  302. package/test/provider/provider.test.ts +0 -1809
  303. package/test/provider/transform.test.ts +0 -305
  304. package/test/session/retry.test.ts +0 -61
  305. package/test/session/session.test.ts +0 -71
  306. package/test/snapshot/snapshot.test.ts +0 -939
  307. package/test/tool/__snapshots__/tool.test.ts.snap +0 -9
  308. package/test/tool/bash.test.ts +0 -55
  309. package/test/tool/patch.test.ts +0 -259
  310. package/test/util/iife.test.ts +0 -36
  311. package/test/util/lazy.test.ts +0 -50
  312. package/test/util/timeout.test.ts +0 -21
  313. package/test/util/wildcard.test.ts +0 -55
  314. package/tsconfig.json +0 -17
@@ -1,78 +0,0 @@
1
- import { TextAttributes } from "@opentui/core"
2
- import { useTheme } from "../context/theme"
3
- import { useKeyboard, useTerminalDimensions } from "@opentui/solid"
4
- import { createSignal, onMount } from "solid-js"
5
- import type { Notification } from "@/notification"
6
-
7
- export function FullscreenNotification(props: { notification: Notification; onClose: () => void }) {
8
- const { theme } = useTheme()
9
- const dimensions = useTerminalDimensions()
10
- const [ready, setReady] = createSignal(false)
11
-
12
- // Wait a moment before accepting key presses to avoid immediate dismiss
13
- onMount(() => {
14
- setTimeout(() => setReady(true), 500)
15
- })
16
-
17
- useKeyboard((evt) => {
18
- // Any key dismisses (after ready)
19
- if (ready()) {
20
- evt.preventDefault?.()
21
- evt.stopPropagation?.()
22
- // Small delay to prevent key from reaching prompt
23
- setReady(false)
24
- setTimeout(() => props.onClose(), 50)
25
- }
26
- })
27
-
28
- const bgColor = () => {
29
- switch (props.notification.type) {
30
- case "critical":
31
- return theme.error
32
- case "warning":
33
- return theme.warning
34
- default:
35
- return theme.primary
36
- }
37
- }
38
-
39
- const icon = () => {
40
- switch (props.notification.type) {
41
- case "critical":
42
- return "⚠"
43
- case "warning":
44
- return "⚡"
45
- default:
46
- return "✦"
47
- }
48
- }
49
-
50
- return (
51
- <box
52
- position="absolute"
53
- top={0}
54
- left={0}
55
- width={dimensions().width}
56
- height={dimensions().height}
57
- backgroundColor={bgColor()}
58
- justifyContent="center"
59
- alignItems="center"
60
- flexDirection="column"
61
- gap={2}
62
- >
63
- <text attributes={TextAttributes.BOLD} fg={theme.backgroundPanel} style={{ fontSize: 2 }}>
64
- {icon()} {props.notification.title}
65
- </text>
66
- <box maxWidth={Math.min(80, dimensions().width - 10)} paddingLeft={2} paddingRight={2}>
67
- <text fg={theme.backgroundPanel} wrapMode="word" textAlign="center">
68
- {props.notification.message}
69
- </text>
70
- </box>
71
- <box marginTop={2}>
72
- <text fg={theme.backgroundPanel} attributes={TextAttributes.DIM}>
73
- press any key to continue
74
- </text>
75
- </box>
76
- </box>
77
- )
78
- }
@@ -1,222 +0,0 @@
1
- import { createMemo, createSignal, onMount, Show } from "solid-js"
2
- import { useSync } from "@tui/context/sync"
3
- import { map, pipe, sortBy } from "remeda"
4
- import { DialogSelect } from "@tui/ui/dialog-select"
5
- import { useDialog } from "@tui/ui/dialog"
6
- import { useSDK } from "../context/sdk"
7
- import { DialogPrompt } from "../ui/dialog-prompt"
8
- import { useTheme } from "../context/theme"
9
- import { TextAttributes } from "@opentui/core"
10
- import type { ProviderAuthAuthorization } from "@opencode-ai/sdk/v2"
11
- import { DialogModel } from "./dialog-model"
12
-
13
- const PROVIDER_PRIORITY: Record<string, number> = {
14
- opencode: 0,
15
- anthropic: 1,
16
- "github-copilot": 2,
17
- openai: 3,
18
- google: 4,
19
- openrouter: 5,
20
- }
21
-
22
- export function createDialogProviderOptions() {
23
- const sync = useSync()
24
- const dialog = useDialog()
25
- const sdk = useSDK()
26
- const options = createMemo(() => {
27
- return pipe(
28
- sync.data.provider_next.all,
29
- sortBy((x) => PROVIDER_PRIORITY[x.id] ?? 99),
30
- map((provider) => ({
31
- title: provider.name,
32
- value: provider.id,
33
- description: {
34
- opencode: "(Recommended)",
35
- anthropic: "(Claude Max or API key)",
36
- }[provider.id],
37
- category: provider.id in PROVIDER_PRIORITY ? "Popular" : "Other",
38
- async onSelect() {
39
- const methods = sync.data.provider_auth[provider.id] ?? [
40
- {
41
- type: "api",
42
- label: "API key",
43
- },
44
- ]
45
- let index: number | null = 0
46
- if (methods.length > 1) {
47
- index = await new Promise<number | null>((resolve) => {
48
- dialog.replace(
49
- () => (
50
- <DialogSelect
51
- title="Select auth method"
52
- options={methods.map((x, index) => ({
53
- title: x.label,
54
- value: index,
55
- }))}
56
- onSelect={(option) => resolve(option.value)}
57
- />
58
- ),
59
- () => resolve(null),
60
- )
61
- })
62
- }
63
- if (index == null) return
64
- const method = methods[index]
65
- if (method.type === "oauth") {
66
- const result = await sdk.client.provider.oauth.authorize({
67
- providerID: provider.id,
68
- method: index,
69
- })
70
- if (result.data?.method === "code") {
71
- dialog.replace(() => (
72
- <CodeMethod providerID={provider.id} title={method.label} index={index} authorization={result.data!} />
73
- ))
74
- }
75
- if (result.data?.method === "auto") {
76
- dialog.replace(() => (
77
- <AutoMethod providerID={provider.id} title={method.label} index={index} authorization={result.data!} />
78
- ))
79
- }
80
- }
81
- if (method.type === "api") {
82
- return dialog.replace(() => <ApiMethod providerID={provider.id} title={method.label} />)
83
- }
84
- },
85
- })),
86
- )
87
- })
88
- return options
89
- }
90
-
91
- export function DialogProvider() {
92
- const options = createDialogProviderOptions()
93
- return <DialogSelect title="Connect a provider" options={options()} />
94
- }
95
-
96
- interface AutoMethodProps {
97
- index: number
98
- providerID: string
99
- title: string
100
- authorization: ProviderAuthAuthorization
101
- }
102
- function AutoMethod(props: AutoMethodProps) {
103
- const { theme } = useTheme()
104
- const sdk = useSDK()
105
- const dialog = useDialog()
106
- const sync = useSync()
107
-
108
- onMount(async () => {
109
- const result = await sdk.client.provider.oauth.callback({
110
- providerID: props.providerID,
111
- method: props.index,
112
- })
113
- if (result.error) {
114
- dialog.clear()
115
- return
116
- }
117
- await sdk.client.instance.dispose()
118
- await sync.bootstrap()
119
- dialog.replace(() => <DialogModel providerID={props.providerID} />)
120
- })
121
-
122
- return (
123
- <box paddingLeft={2} paddingRight={2} gap={1} paddingBottom={1}>
124
- <box flexDirection="row" justifyContent="space-between">
125
- <text attributes={TextAttributes.BOLD}>{props.title}</text>
126
- <text fg={theme.textMuted}>esc</text>
127
- </box>
128
- <box gap={1}>
129
- <text fg={theme.primary}>{props.authorization.url}</text>
130
- <text fg={theme.textMuted}>{props.authorization.instructions}</text>
131
- </box>
132
- <text fg={theme.textMuted}>Waiting for authorization...</text>
133
- </box>
134
- )
135
- }
136
-
137
- interface CodeMethodProps {
138
- index: number
139
- title: string
140
- providerID: string
141
- authorization: ProviderAuthAuthorization
142
- }
143
- function CodeMethod(props: CodeMethodProps) {
144
- const { theme } = useTheme()
145
- const sdk = useSDK()
146
- const sync = useSync()
147
- const dialog = useDialog()
148
- const [error, setError] = createSignal(false)
149
-
150
- return (
151
- <DialogPrompt
152
- title={props.title}
153
- placeholder="Authorization code"
154
- onConfirm={async (value) => {
155
- const { error } = await sdk.client.provider.oauth.callback({
156
- providerID: props.providerID,
157
- method: props.index,
158
- code: value,
159
- })
160
- if (!error) {
161
- await sdk.client.instance.dispose()
162
- await sync.bootstrap()
163
- dialog.replace(() => <DialogModel providerID={props.providerID} />)
164
- return
165
- }
166
- setError(true)
167
- }}
168
- description={() => (
169
- <box gap={1}>
170
- <text fg={theme.textMuted}>{props.authorization.instructions}</text>
171
- <text fg={theme.primary}>{props.authorization.url}</text>
172
- <Show when={error()}>
173
- <text fg={theme.error}>Invalid code</text>
174
- </Show>
175
- </box>
176
- )}
177
- />
178
- )
179
- }
180
-
181
- interface ApiMethodProps {
182
- providerID: string
183
- title: string
184
- }
185
- function ApiMethod(props: ApiMethodProps) {
186
- const dialog = useDialog()
187
- const sdk = useSDK()
188
- const sync = useSync()
189
- const { theme } = useTheme()
190
-
191
- return (
192
- <DialogPrompt
193
- title={props.title}
194
- placeholder="API key"
195
- description={
196
- props.providerID === "opencode" ? (
197
- <box gap={1}>
198
- <text fg={theme.textMuted}>
199
- OpenCode Zen gives you access to all the best coding models at the cheapest prices with a single API key.
200
- </text>
201
- <text>
202
- Go to <span style={{ fg: theme.primary }}>https://opencode.ai/zen</span> to get a key
203
- </text>
204
- </box>
205
- ) : undefined
206
- }
207
- onConfirm={async (value) => {
208
- if (!value) return
209
- sdk.client.auth.set({
210
- providerID: props.providerID,
211
- auth: {
212
- type: "api",
213
- key: value,
214
- },
215
- })
216
- await sdk.client.instance.dispose()
217
- await sync.bootstrap()
218
- dialog.replace(() => <DialogModel providerID={props.providerID} />)
219
- }}
220
- />
221
- )
222
- }
@@ -1,97 +0,0 @@
1
- import { useDialog } from "@tui/ui/dialog"
2
- import { DialogSelect } from "@tui/ui/dialog-select"
3
- import { useRoute } from "@tui/context/route"
4
- import { useSync } from "@tui/context/sync"
5
- import { createEffect, createMemo, createSignal, onMount } from "solid-js"
6
- import { Locale } from "@/util/locale"
7
- import { Keybind } from "@/util/keybind"
8
- import { useTheme } from "../context/theme"
9
- import { useSDK } from "../context/sdk"
10
- import { DialogSessionRename } from "./dialog-session-rename"
11
-
12
- export function DialogSessionList() {
13
- const dialog = useDialog()
14
- const sync = useSync()
15
- const { theme } = useTheme()
16
- const route = useRoute()
17
- const sdk = useSDK()
18
-
19
- const [toDelete, setToDelete] = createSignal<string>()
20
-
21
- const deleteKeybind = "ctrl+d"
22
-
23
- const currentSessionID = createMemo(() => (route.data.type === "session" ? route.data.sessionID : undefined))
24
-
25
- const options = createMemo(() => {
26
- const today = new Date().toDateString()
27
- return sync.data.session
28
- .filter((x) => x.parentID === undefined)
29
- .toSorted((a, b) => b.time.updated - a.time.updated)
30
- .map((x) => {
31
- const date = new Date(x.time.updated)
32
- let category = date.toDateString()
33
- if (category === today) {
34
- category = "Today"
35
- }
36
- const isDeleting = toDelete() === x.id
37
- return {
38
- title: isDeleting ? `Press ${deleteKeybind} again to confirm` : x.title,
39
- bg: isDeleting ? theme.error : undefined,
40
- value: x.id,
41
- category,
42
- footer: Locale.time(x.time.updated),
43
- }
44
- })
45
- .slice(0, 150)
46
- })
47
-
48
- createEffect(() => {
49
- console.log("session count", sync.data.session.length)
50
- })
51
-
52
- onMount(() => {
53
- dialog.setSize("large")
54
- })
55
-
56
- return (
57
- <DialogSelect
58
- title="Sessions"
59
- options={options()}
60
- current={currentSessionID()}
61
- onMove={() => {
62
- setToDelete(undefined)
63
- }}
64
- onSelect={(option) => {
65
- route.navigate({
66
- type: "session",
67
- sessionID: option.value,
68
- })
69
- dialog.clear()
70
- }}
71
- keybind={[
72
- {
73
- keybind: Keybind.parse(deleteKeybind)[0],
74
- title: "delete",
75
- onTrigger: async (option) => {
76
- if (toDelete() === option.value) {
77
- sdk.client.session.delete({
78
- sessionID: option.value,
79
- })
80
- setToDelete(undefined)
81
- // dialog.clear()
82
- return
83
- }
84
- setToDelete(option.value)
85
- },
86
- },
87
- {
88
- keybind: Keybind.parse("ctrl+r")[0],
89
- title: "rename",
90
- onTrigger: async (option) => {
91
- dialog.replace(() => <DialogSessionRename session={option.value} />)
92
- },
93
- },
94
- ]}
95
- />
96
- )
97
- }
@@ -1,31 +0,0 @@
1
- import { DialogPrompt } from "@tui/ui/dialog-prompt"
2
- import { useDialog } from "@tui/ui/dialog"
3
- import { useSync } from "@tui/context/sync"
4
- import { createMemo } from "solid-js"
5
- import { useSDK } from "../context/sdk"
6
-
7
- interface DialogSessionRenameProps {
8
- session: string
9
- }
10
-
11
- export function DialogSessionRename(props: DialogSessionRenameProps) {
12
- const dialog = useDialog()
13
- const sync = useSync()
14
- const sdk = useSDK()
15
- const session = createMemo(() => sync.session.get(props.session))
16
-
17
- return (
18
- <DialogPrompt
19
- title="Rename Session"
20
- value={session()?.title}
21
- onConfirm={(value) => {
22
- sdk.client.session.update({
23
- sessionID: props.session,
24
- title: value,
25
- })
26
- dialog.clear()
27
- }}
28
- onCancel={() => dialog.clear()}
29
- />
30
- )
31
- }
@@ -1,114 +0,0 @@
1
- import { TextAttributes } from "@opentui/core"
2
- import { useTheme } from "../context/theme"
3
- import { useSync } from "@tui/context/sync"
4
- import { For, Match, Switch, Show, createMemo } from "solid-js"
5
-
6
- export type DialogStatusProps = {}
7
-
8
- export function DialogStatus() {
9
- const sync = useSync()
10
- const { theme } = useTheme()
11
-
12
- const enabledFormatters = createMemo(() => sync.data.formatter.filter((f) => f.enabled))
13
-
14
- return (
15
- <box paddingLeft={2} paddingRight={2} gap={1} paddingBottom={1}>
16
- <box flexDirection="row" justifyContent="space-between">
17
- <text fg={theme.text} attributes={TextAttributes.BOLD}>
18
- Status
19
- </text>
20
- <text fg={theme.textMuted}>esc</text>
21
- </box>
22
- <Show when={Object.keys(sync.data.mcp).length > 0} fallback={<text>No MCP Servers</text>}>
23
- <box>
24
- <text fg={theme.text}>{Object.keys(sync.data.mcp).length} MCP Servers</text>
25
- <For each={Object.entries(sync.data.mcp)}>
26
- {([key, item]) => (
27
- <box flexDirection="row" gap={1}>
28
- <text
29
- flexShrink={0}
30
- style={{
31
- fg: (
32
- {
33
- connected: theme.success,
34
- failed: theme.error,
35
- disabled: theme.textMuted,
36
- needs_auth: theme.warning,
37
- needs_client_registration: theme.error,
38
- } as Record<string, typeof theme.success>
39
- )[item.status],
40
- }}
41
- >
42
-
43
- </text>
44
- <text fg={theme.text} wrapMode="word">
45
- <b>{key}</b>{" "}
46
- <span style={{ fg: theme.textMuted }}>
47
- <Switch fallback={item.status}>
48
- <Match when={item.status === "connected"}>Connected</Match>
49
- <Match when={item.status === "failed" && item}>{(val) => val().error}</Match>
50
- <Match when={item.status === "disabled"}>Disabled in configuration</Match>
51
- <Match when={(item.status as string) === "needs_auth"}>
52
- Needs authentication (run: opencode mcp auth {key})
53
- </Match>
54
- <Match when={(item.status as string) === "needs_client_registration" && item}>
55
- {(val) => (val() as { error: string }).error}
56
- </Match>
57
- </Switch>
58
- </span>
59
- </text>
60
- </box>
61
- )}
62
- </For>
63
- </box>
64
- </Show>
65
- {sync.data.lsp.length > 0 && (
66
- <box>
67
- <text fg={theme.text}>{sync.data.lsp.length} LSP Servers</text>
68
- <For each={sync.data.lsp}>
69
- {(item) => (
70
- <box flexDirection="row" gap={1}>
71
- <text
72
- flexShrink={0}
73
- style={{
74
- fg: {
75
- connected: theme.success,
76
- error: theme.error,
77
- }[item.status],
78
- }}
79
- >
80
-
81
- </text>
82
- <text fg={theme.text} wrapMode="word">
83
- <b>{item.id}</b> <span style={{ fg: theme.textMuted }}>{item.root}</span>
84
- </text>
85
- </box>
86
- )}
87
- </For>
88
- </box>
89
- )}
90
- <Show when={enabledFormatters().length > 0} fallback={<text fg={theme.text}>No Formatters</text>}>
91
- <box>
92
- <text fg={theme.text}>{enabledFormatters().length} Formatters</text>
93
- <For each={enabledFormatters()}>
94
- {(item) => (
95
- <box flexDirection="row" gap={1}>
96
- <text
97
- flexShrink={0}
98
- style={{
99
- fg: theme.success,
100
- }}
101
- >
102
-
103
- </text>
104
- <text wrapMode="word" fg={theme.text}>
105
- <b>{item.name}</b>
106
- </text>
107
- </box>
108
- )}
109
- </For>
110
- </box>
111
- </Show>
112
- </box>
113
- )
114
- }
@@ -1,44 +0,0 @@
1
- import { createMemo, createResource } from "solid-js"
2
- import { DialogSelect } from "@tui/ui/dialog-select"
3
- import { useDialog } from "@tui/ui/dialog"
4
- import { useSDK } from "@tui/context/sdk"
5
- import { createStore } from "solid-js/store"
6
-
7
- export function DialogTag(props: { onSelect?: (value: string) => void }) {
8
- const sdk = useSDK()
9
- const dialog = useDialog()
10
-
11
- const [store] = createStore({
12
- filter: "",
13
- })
14
-
15
- const [files] = createResource(
16
- () => [store.filter],
17
- async () => {
18
- const result = await sdk.client.find.files({
19
- query: store.filter,
20
- })
21
- if (result.error) return []
22
- const sliced = (result.data ?? []).slice(0, 5)
23
- return sliced
24
- },
25
- )
26
-
27
- const options = createMemo(() =>
28
- (files() ?? []).map((file) => ({
29
- value: file,
30
- title: file,
31
- })),
32
- )
33
-
34
- return (
35
- <DialogSelect
36
- title="Autocomplete"
37
- options={options()}
38
- onSelect={(option) => {
39
- props.onSelect?.(option.value)
40
- dialog.clear()
41
- }}
42
- />
43
- )
44
- }
@@ -1,50 +0,0 @@
1
- import { DialogSelect, type DialogSelectRef } from "../ui/dialog-select"
2
- import { useTheme } from "../context/theme"
3
- import { useDialog } from "../ui/dialog"
4
- import { onCleanup, onMount } from "solid-js"
5
-
6
- export function DialogThemeList() {
7
- const theme = useTheme()
8
- const options = Object.keys(theme.all())
9
- .sort((a, b) => a.localeCompare(b, undefined, { sensitivity: "base" }))
10
- .map((value) => ({
11
- title: value,
12
- value: value,
13
- }))
14
- const dialog = useDialog()
15
- let confirmed = false
16
- let ref: DialogSelectRef<string>
17
- const initial = theme.selected
18
-
19
- onCleanup(() => {
20
- if (!confirmed) theme.set(initial)
21
- })
22
-
23
- return (
24
- <DialogSelect
25
- title="Themes"
26
- options={options}
27
- current={initial}
28
- onMove={(opt) => {
29
- theme.set(opt.value)
30
- }}
31
- onSelect={(opt) => {
32
- theme.set(opt.value)
33
- confirmed = true
34
- dialog.clear()
35
- }}
36
- ref={(r) => {
37
- ref = r
38
- }}
39
- onFilter={(query) => {
40
- if (query.length === 0) {
41
- theme.set(initial)
42
- return
43
- }
44
-
45
- const first = ref.filtered[0]
46
- if (first) theme.set(first.value)
47
- }}
48
- />
49
- )
50
- }
@@ -1,37 +0,0 @@
1
- import { TextAttributes } from "@opentui/core"
2
- import { For } from "solid-js"
3
- import { useTheme } from "@tui/context/theme"
4
-
5
- // "Cerebras" in block characters
6
- const LOGO_LINE1 = [
7
- `█▀▀▀ █▀▀▀ █▀▀█ █▀▀▀ █▀▀▄ █▀▀█ █▀▀█ █▀▀▀`,
8
- `█░░░ █▀▀▀ █▀▀▄ █▀▀▀ █▀▀▄ █▀▀▄ █▀▀█ ▀▀▀█`,
9
- `▀▀▀▀ ▀▀▀▀ ▀ ▀ ▀▀▀▀ ▀▀▀ ▀ ▀ ▀ ▀ ▀▀▀▀`,
10
- ]
11
-
12
- // "Code CLI" in block characters (spaced to align with CEREBRAS)
13
- const LOGO_LINE2 = [
14
- `█▀▀▀ █▀▀█ █▀▀▄ █▀▀▀ █▀▀▀ █░░ ▀█▀`,
15
- `█░░░ █░░█ █░░█ █▀▀▀ █░░░ █░░ ░█░`,
16
- `▀▀▀▀ ▀▀▀▀ ▀▀▀ ▀▀▀▀ ▀▀▀▀ ▀▀▀ ▀▀▀`,
17
- ]
18
-
19
- export function Logo() {
20
- const { theme } = useTheme()
21
- return (
22
- <box>
23
- <For each={LOGO_LINE1}>
24
- {(line) => (
25
- <text fg={theme.text} attributes={TextAttributes.BOLD}>
26
- {line}
27
- </text>
28
- )}
29
- </For>
30
- <For each={LOGO_LINE2}>
31
- {(line) => (
32
- <text fg={theme.textMuted}>{line}</text>
33
- )}
34
- </For>
35
- </box>
36
- )
37
- }