chad-code 1.3.1 → 1.3.2

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 (337) hide show
  1. package/README.md +55 -6
  2. package/package.json +36 -98
  3. package/AGENTS.md +0 -27
  4. package/Dockerfile +0 -18
  5. package/README.npm.md +0 -64
  6. package/bunfig.toml +0 -7
  7. package/eslint.config.js +0 -29
  8. package/parsers-config.ts +0 -253
  9. package/script/build.ts +0 -167
  10. package/script/publish-registries.ts +0 -187
  11. package/script/publish.ts +0 -93
  12. package/script/schema.ts +0 -47
  13. package/src/acp/README.md +0 -164
  14. package/src/acp/agent.ts +0 -1086
  15. package/src/acp/session.ts +0 -101
  16. package/src/acp/types.ts +0 -22
  17. package/src/agent/agent.ts +0 -253
  18. package/src/agent/generate.txt +0 -75
  19. package/src/agent/prompt/compaction.txt +0 -12
  20. package/src/agent/prompt/explore.txt +0 -18
  21. package/src/agent/prompt/summary.txt +0 -11
  22. package/src/agent/prompt/title.txt +0 -36
  23. package/src/auth/index.ts +0 -70
  24. package/src/bun/index.ts +0 -130
  25. package/src/bus/bus-event.ts +0 -43
  26. package/src/bus/global.ts +0 -10
  27. package/src/bus/index.ts +0 -105
  28. package/src/cli/bootstrap.ts +0 -17
  29. package/src/cli/cmd/acp.ts +0 -69
  30. package/src/cli/cmd/agent.ts +0 -257
  31. package/src/cli/cmd/auth.ts +0 -132
  32. package/src/cli/cmd/cmd.ts +0 -7
  33. package/src/cli/cmd/debug/agent.ts +0 -28
  34. package/src/cli/cmd/debug/config.ts +0 -15
  35. package/src/cli/cmd/debug/file.ts +0 -91
  36. package/src/cli/cmd/debug/index.ts +0 -45
  37. package/src/cli/cmd/debug/lsp.ts +0 -48
  38. package/src/cli/cmd/debug/ripgrep.ts +0 -83
  39. package/src/cli/cmd/debug/scrap.ts +0 -15
  40. package/src/cli/cmd/debug/skill.ts +0 -15
  41. package/src/cli/cmd/debug/snapshot.ts +0 -48
  42. package/src/cli/cmd/export.ts +0 -88
  43. package/src/cli/cmd/generate.ts +0 -38
  44. package/src/cli/cmd/github.ts +0 -32
  45. package/src/cli/cmd/import.ts +0 -98
  46. package/src/cli/cmd/mcp.ts +0 -670
  47. package/src/cli/cmd/models.ts +0 -42
  48. package/src/cli/cmd/pr.ts +0 -112
  49. package/src/cli/cmd/run.ts +0 -374
  50. package/src/cli/cmd/serve.ts +0 -16
  51. package/src/cli/cmd/session.ts +0 -135
  52. package/src/cli/cmd/stats.ts +0 -402
  53. package/src/cli/cmd/tui/app.tsx +0 -705
  54. package/src/cli/cmd/tui/attach.ts +0 -32
  55. package/src/cli/cmd/tui/component/border.tsx +0 -21
  56. package/src/cli/cmd/tui/component/dialog-agent.tsx +0 -31
  57. package/src/cli/cmd/tui/component/dialog-command.tsx +0 -124
  58. package/src/cli/cmd/tui/component/dialog-mcp.tsx +0 -86
  59. package/src/cli/cmd/tui/component/dialog-model.tsx +0 -232
  60. package/src/cli/cmd/tui/component/dialog-provider.tsx +0 -228
  61. package/src/cli/cmd/tui/component/dialog-session-list.tsx +0 -115
  62. package/src/cli/cmd/tui/component/dialog-session-rename.tsx +0 -31
  63. package/src/cli/cmd/tui/component/dialog-stash.tsx +0 -86
  64. package/src/cli/cmd/tui/component/dialog-status.tsx +0 -162
  65. package/src/cli/cmd/tui/component/dialog-tag.tsx +0 -44
  66. package/src/cli/cmd/tui/component/dialog-theme-list.tsx +0 -50
  67. package/src/cli/cmd/tui/component/did-you-know.tsx +0 -85
  68. package/src/cli/cmd/tui/component/logo.tsx +0 -43
  69. package/src/cli/cmd/tui/component/prompt/autocomplete.tsx +0 -654
  70. package/src/cli/cmd/tui/component/prompt/history.tsx +0 -108
  71. package/src/cli/cmd/tui/component/prompt/index.tsx +0 -1078
  72. package/src/cli/cmd/tui/component/prompt/stash.tsx +0 -101
  73. package/src/cli/cmd/tui/component/textarea-keybindings.ts +0 -73
  74. package/src/cli/cmd/tui/component/tips.ts +0 -92
  75. package/src/cli/cmd/tui/component/todo-item.tsx +0 -32
  76. package/src/cli/cmd/tui/context/args.tsx +0 -14
  77. package/src/cli/cmd/tui/context/directory.ts +0 -13
  78. package/src/cli/cmd/tui/context/exit.tsx +0 -23
  79. package/src/cli/cmd/tui/context/helper.tsx +0 -25
  80. package/src/cli/cmd/tui/context/keybind.tsx +0 -101
  81. package/src/cli/cmd/tui/context/kv.tsx +0 -49
  82. package/src/cli/cmd/tui/context/local.tsx +0 -392
  83. package/src/cli/cmd/tui/context/prompt.tsx +0 -18
  84. package/src/cli/cmd/tui/context/route.tsx +0 -46
  85. package/src/cli/cmd/tui/context/sdk.tsx +0 -75
  86. package/src/cli/cmd/tui/context/sync.tsx +0 -384
  87. package/src/cli/cmd/tui/context/theme/aura.json +0 -69
  88. package/src/cli/cmd/tui/context/theme/ayu.json +0 -80
  89. package/src/cli/cmd/tui/context/theme/catppuccin-frappe.json +0 -233
  90. package/src/cli/cmd/tui/context/theme/catppuccin-macchiato.json +0 -233
  91. package/src/cli/cmd/tui/context/theme/catppuccin.json +0 -112
  92. package/src/cli/cmd/tui/context/theme/chad.json +0 -245
  93. package/src/cli/cmd/tui/context/theme/cobalt2.json +0 -228
  94. package/src/cli/cmd/tui/context/theme/cursor.json +0 -249
  95. package/src/cli/cmd/tui/context/theme/dracula.json +0 -219
  96. package/src/cli/cmd/tui/context/theme/everforest.json +0 -241
  97. package/src/cli/cmd/tui/context/theme/flexoki.json +0 -237
  98. package/src/cli/cmd/tui/context/theme/github.json +0 -233
  99. package/src/cli/cmd/tui/context/theme/gruvbox.json +0 -95
  100. package/src/cli/cmd/tui/context/theme/kanagawa.json +0 -77
  101. package/src/cli/cmd/tui/context/theme/lucent-orng.json +0 -227
  102. package/src/cli/cmd/tui/context/theme/material.json +0 -235
  103. package/src/cli/cmd/tui/context/theme/matrix.json +0 -77
  104. package/src/cli/cmd/tui/context/theme/mercury.json +0 -252
  105. package/src/cli/cmd/tui/context/theme/monokai.json +0 -221
  106. package/src/cli/cmd/tui/context/theme/nightowl.json +0 -221
  107. package/src/cli/cmd/tui/context/theme/nord.json +0 -223
  108. package/src/cli/cmd/tui/context/theme/one-dark.json +0 -84
  109. package/src/cli/cmd/tui/context/theme/orng.json +0 -245
  110. package/src/cli/cmd/tui/context/theme/osaka-jade.json +0 -93
  111. package/src/cli/cmd/tui/context/theme/palenight.json +0 -222
  112. package/src/cli/cmd/tui/context/theme/rosepine.json +0 -234
  113. package/src/cli/cmd/tui/context/theme/solarized.json +0 -223
  114. package/src/cli/cmd/tui/context/theme/synthwave84.json +0 -226
  115. package/src/cli/cmd/tui/context/theme/tokyonight.json +0 -243
  116. package/src/cli/cmd/tui/context/theme/vercel.json +0 -245
  117. package/src/cli/cmd/tui/context/theme/vesper.json +0 -218
  118. package/src/cli/cmd/tui/context/theme/zenburn.json +0 -223
  119. package/src/cli/cmd/tui/context/theme.tsx +0 -1137
  120. package/src/cli/cmd/tui/event.ts +0 -46
  121. package/src/cli/cmd/tui/routes/home.tsx +0 -138
  122. package/src/cli/cmd/tui/routes/session/dialog-fork-from-timeline.tsx +0 -64
  123. package/src/cli/cmd/tui/routes/session/dialog-message.tsx +0 -109
  124. package/src/cli/cmd/tui/routes/session/dialog-subagent.tsx +0 -26
  125. package/src/cli/cmd/tui/routes/session/dialog-timeline.tsx +0 -47
  126. package/src/cli/cmd/tui/routes/session/footer.tsx +0 -88
  127. package/src/cli/cmd/tui/routes/session/header.tsx +0 -125
  128. package/src/cli/cmd/tui/routes/session/index.tsx +0 -1814
  129. package/src/cli/cmd/tui/routes/session/permission.tsx +0 -416
  130. package/src/cli/cmd/tui/routes/session/sidebar.tsx +0 -318
  131. package/src/cli/cmd/tui/spawn.ts +0 -48
  132. package/src/cli/cmd/tui/thread.ts +0 -111
  133. package/src/cli/cmd/tui/ui/dialog-alert.tsx +0 -57
  134. package/src/cli/cmd/tui/ui/dialog-confirm.tsx +0 -83
  135. package/src/cli/cmd/tui/ui/dialog-export-options.tsx +0 -204
  136. package/src/cli/cmd/tui/ui/dialog-help.tsx +0 -38
  137. package/src/cli/cmd/tui/ui/dialog-prompt.tsx +0 -77
  138. package/src/cli/cmd/tui/ui/dialog-select.tsx +0 -345
  139. package/src/cli/cmd/tui/ui/dialog.tsx +0 -171
  140. package/src/cli/cmd/tui/ui/link.tsx +0 -28
  141. package/src/cli/cmd/tui/ui/spinner.ts +0 -368
  142. package/src/cli/cmd/tui/ui/toast.tsx +0 -100
  143. package/src/cli/cmd/tui/util/clipboard.ts +0 -127
  144. package/src/cli/cmd/tui/util/editor.ts +0 -32
  145. package/src/cli/cmd/tui/util/signal.ts +0 -7
  146. package/src/cli/cmd/tui/util/terminal.ts +0 -114
  147. package/src/cli/cmd/tui/util/transcript.ts +0 -98
  148. package/src/cli/cmd/tui/worker.ts +0 -68
  149. package/src/cli/cmd/uninstall.ts +0 -344
  150. package/src/cli/cmd/upgrade.ts +0 -67
  151. package/src/cli/cmd/web.ts +0 -73
  152. package/src/cli/error.ts +0 -56
  153. package/src/cli/network.ts +0 -53
  154. package/src/cli/ui.ts +0 -87
  155. package/src/cli/upgrade.ts +0 -25
  156. package/src/command/index.ts +0 -131
  157. package/src/command/template/initialize.txt +0 -10
  158. package/src/command/template/review.txt +0 -97
  159. package/src/config/config.ts +0 -1124
  160. package/src/config/markdown.ts +0 -41
  161. package/src/env/index.ts +0 -26
  162. package/src/file/ignore.ts +0 -83
  163. package/src/file/index.ts +0 -411
  164. package/src/file/ripgrep.ts +0 -402
  165. package/src/file/time.ts +0 -64
  166. package/src/file/watcher.ts +0 -117
  167. package/src/flag/flag.ts +0 -52
  168. package/src/format/formatter.ts +0 -359
  169. package/src/format/index.ts +0 -137
  170. package/src/global/index.ts +0 -55
  171. package/src/id/id.ts +0 -73
  172. package/src/ide/index.ts +0 -77
  173. package/src/index.ts +0 -159
  174. package/src/installation/index.ts +0 -198
  175. package/src/lsp/client.ts +0 -252
  176. package/src/lsp/index.ts +0 -485
  177. package/src/lsp/language.ts +0 -119
  178. package/src/lsp/server.ts +0 -2023
  179. package/src/mcp/auth.ts +0 -135
  180. package/src/mcp/index.ts +0 -874
  181. package/src/mcp/oauth-callback.ts +0 -200
  182. package/src/mcp/oauth-provider.ts +0 -154
  183. package/src/patch/index.ts +0 -622
  184. package/src/permission/arity.ts +0 -163
  185. package/src/permission/index.ts +0 -210
  186. package/src/permission/next.ts +0 -268
  187. package/src/plugin/index.ts +0 -106
  188. package/src/project/bootstrap.ts +0 -31
  189. package/src/project/instance.ts +0 -78
  190. package/src/project/project.ts +0 -263
  191. package/src/project/state.ts +0 -65
  192. package/src/project/vcs.ts +0 -76
  193. package/src/provider/auth.ts +0 -143
  194. package/src/provider/models-macro.ts +0 -4
  195. package/src/provider/models.ts +0 -77
  196. package/src/provider/provider.ts +0 -516
  197. package/src/provider/transform.ts +0 -114
  198. package/src/pty/index.ts +0 -212
  199. package/src/server/error.ts +0 -36
  200. package/src/server/mdns.ts +0 -57
  201. package/src/server/project.ts +0 -79
  202. package/src/server/server.ts +0 -2866
  203. package/src/server/tui.ts +0 -71
  204. package/src/session/compaction.ts +0 -225
  205. package/src/session/index.ts +0 -469
  206. package/src/session/llm.ts +0 -213
  207. package/src/session/message-v2.ts +0 -742
  208. package/src/session/message.ts +0 -189
  209. package/src/session/processor.ts +0 -402
  210. package/src/session/prompt/anthropic-20250930.txt +0 -166
  211. package/src/session/prompt/anthropic.txt +0 -105
  212. package/src/session/prompt/anthropic_spoof.txt +0 -1
  213. package/src/session/prompt/beast.txt +0 -147
  214. package/src/session/prompt/build-switch.txt +0 -5
  215. package/src/session/prompt/codex.txt +0 -318
  216. package/src/session/prompt/copilot-gpt-5.txt +0 -143
  217. package/src/session/prompt/gemini.txt +0 -155
  218. package/src/session/prompt/max-steps.txt +0 -16
  219. package/src/session/prompt/plan-reminder-anthropic.txt +0 -67
  220. package/src/session/prompt/plan.txt +0 -26
  221. package/src/session/prompt/qwen.txt +0 -109
  222. package/src/session/prompt.ts +0 -1621
  223. package/src/session/retry.ts +0 -90
  224. package/src/session/revert.ts +0 -108
  225. package/src/session/status.ts +0 -76
  226. package/src/session/summary.ts +0 -194
  227. package/src/session/system.ts +0 -108
  228. package/src/session/todo.ts +0 -37
  229. package/src/share/share-next.ts +0 -194
  230. package/src/share/share.ts +0 -23
  231. package/src/shell/shell.ts +0 -67
  232. package/src/skill/index.ts +0 -1
  233. package/src/skill/skill.ts +0 -124
  234. package/src/snapshot/index.ts +0 -197
  235. package/src/storage/storage.ts +0 -226
  236. package/src/tool/bash.ts +0 -262
  237. package/src/tool/bash.txt +0 -116
  238. package/src/tool/batch.ts +0 -175
  239. package/src/tool/batch.txt +0 -24
  240. package/src/tool/codesearch.ts +0 -132
  241. package/src/tool/codesearch.txt +0 -12
  242. package/src/tool/edit.ts +0 -655
  243. package/src/tool/edit.txt +0 -10
  244. package/src/tool/glob.ts +0 -75
  245. package/src/tool/glob.txt +0 -6
  246. package/src/tool/grep.ts +0 -132
  247. package/src/tool/grep.txt +0 -8
  248. package/src/tool/invalid.ts +0 -17
  249. package/src/tool/ls.ts +0 -119
  250. package/src/tool/ls.txt +0 -1
  251. package/src/tool/lsp.ts +0 -94
  252. package/src/tool/lsp.txt +0 -19
  253. package/src/tool/multiedit.ts +0 -46
  254. package/src/tool/multiedit.txt +0 -41
  255. package/src/tool/patch.ts +0 -210
  256. package/src/tool/patch.txt +0 -1
  257. package/src/tool/read.ts +0 -191
  258. package/src/tool/read.txt +0 -12
  259. package/src/tool/registry.ts +0 -137
  260. package/src/tool/skill.ts +0 -77
  261. package/src/tool/task.ts +0 -167
  262. package/src/tool/task.txt +0 -60
  263. package/src/tool/todo.ts +0 -53
  264. package/src/tool/todoread.txt +0 -14
  265. package/src/tool/todowrite.txt +0 -167
  266. package/src/tool/tool.ts +0 -73
  267. package/src/tool/webfetch.ts +0 -182
  268. package/src/tool/webfetch.txt +0 -13
  269. package/src/tool/websearch.ts +0 -144
  270. package/src/tool/websearch.txt +0 -11
  271. package/src/tool/write.ts +0 -84
  272. package/src/tool/write.txt +0 -8
  273. package/src/util/archive.ts +0 -16
  274. package/src/util/color.ts +0 -19
  275. package/src/util/context.ts +0 -25
  276. package/src/util/defer.ts +0 -12
  277. package/src/util/eventloop.ts +0 -20
  278. package/src/util/filesystem.ts +0 -83
  279. package/src/util/fn.ts +0 -11
  280. package/src/util/iife.ts +0 -3
  281. package/src/util/keybind.ts +0 -102
  282. package/src/util/lazy.ts +0 -18
  283. package/src/util/locale.ts +0 -81
  284. package/src/util/lock.ts +0 -98
  285. package/src/util/log.ts +0 -180
  286. package/src/util/queue.ts +0 -32
  287. package/src/util/rpc.ts +0 -42
  288. package/src/util/scrap.ts +0 -10
  289. package/src/util/signal.ts +0 -12
  290. package/src/util/timeout.ts +0 -14
  291. package/src/util/token.ts +0 -7
  292. package/src/util/wildcard.ts +0 -54
  293. package/src/worktree/index.ts +0 -217
  294. package/sst-env.d.ts +0 -9
  295. package/test/agent/agent.test.ts +0 -448
  296. package/test/bun.test.ts +0 -53
  297. package/test/cli/github-action.test.ts +0 -129
  298. package/test/cli/github-remote.test.ts +0 -80
  299. package/test/cli/tui/transcript.test.ts +0 -297
  300. package/test/config/agent-color.test.ts +0 -66
  301. package/test/config/config.test.ts +0 -870
  302. package/test/config/markdown.test.ts +0 -89
  303. package/test/file/ignore.test.ts +0 -10
  304. package/test/file/path-traversal.test.ts +0 -115
  305. package/test/fixture/fixture.ts +0 -45
  306. package/test/fixture/lsp/fake-lsp-server.js +0 -77
  307. package/test/ide/ide.test.ts +0 -82
  308. package/test/keybind.test.ts +0 -421
  309. package/test/lsp/client.test.ts +0 -95
  310. package/test/mcp/headers.test.ts +0 -153
  311. package/test/patch/patch.test.ts +0 -348
  312. package/test/permission/arity.test.ts +0 -33
  313. package/test/permission/next.test.ts +0 -652
  314. package/test/preload.ts +0 -63
  315. package/test/project/project.test.ts +0 -120
  316. package/test/provider/amazon-bedrock.test.ts +0 -236
  317. package/test/provider/provider.test.ts +0 -2127
  318. package/test/provider/transform.test.ts +0 -980
  319. package/test/server/session-select.test.ts +0 -78
  320. package/test/session/compaction.test.ts +0 -251
  321. package/test/session/message-v2.test.ts +0 -570
  322. package/test/session/retry.test.ts +0 -131
  323. package/test/session/revert-compact.test.ts +0 -285
  324. package/test/session/session.test.ts +0 -71
  325. package/test/skill/skill.test.ts +0 -185
  326. package/test/snapshot/snapshot.test.ts +0 -939
  327. package/test/tool/__snapshots__/tool.test.ts.snap +0 -9
  328. package/test/tool/bash.test.ts +0 -232
  329. package/test/tool/grep.test.ts +0 -109
  330. package/test/tool/patch.test.ts +0 -261
  331. package/test/tool/read.test.ts +0 -167
  332. package/test/util/iife.test.ts +0 -36
  333. package/test/util/lazy.test.ts +0 -50
  334. package/test/util/timeout.test.ts +0 -21
  335. package/test/util/wildcard.test.ts +0 -55
  336. package/tsconfig.json +0 -16
  337. /package/{script/postinstall.mjs → postinstall.mjs} +0 -0
@@ -1,171 +0,0 @@
1
- import { useKeyboard, useRenderer, useTerminalDimensions } from "@opentui/solid"
2
- import { batch, createContext, Show, useContext, type JSX, type ParentProps } from "solid-js"
3
- import { useTheme } from "@tui/context/theme"
4
- import { Renderable, RGBA } from "@opentui/core"
5
- import { createStore } from "solid-js/store"
6
- import { Clipboard } from "@tui/util/clipboard"
7
- import { useToast } from "./toast"
8
-
9
- export function Dialog(
10
- props: ParentProps<{
11
- size?: "medium" | "large"
12
- onClose: () => void
13
- }>,
14
- ) {
15
- const dimensions = useTerminalDimensions()
16
- const { theme } = useTheme()
17
- const renderer = useRenderer()
18
-
19
- return (
20
- <box
21
- onMouseUp={async () => {
22
- if (renderer.getSelection()) return
23
- props.onClose?.()
24
- }}
25
- width={dimensions().width}
26
- height={dimensions().height}
27
- alignItems="center"
28
- position="absolute"
29
- paddingTop={dimensions().height / 4}
30
- left={0}
31
- top={0}
32
- backgroundColor={RGBA.fromInts(0, 0, 0, 150)}
33
- >
34
- <box
35
- onMouseUp={async (e) => {
36
- if (renderer.getSelection()) return
37
- e.stopPropagation()
38
- }}
39
- width={props.size === "large" ? 80 : 60}
40
- maxWidth={dimensions().width - 2}
41
- backgroundColor={theme.backgroundPanel}
42
- paddingTop={1}
43
- >
44
- {props.children}
45
- </box>
46
- </box>
47
- )
48
- }
49
-
50
- function init() {
51
- const [store, setStore] = createStore({
52
- stack: [] as {
53
- element: JSX.Element
54
- onClose?: () => void
55
- }[],
56
- size: "medium" as "medium" | "large",
57
- })
58
-
59
- useKeyboard((evt) => {
60
- if (evt.name === "escape" && store.stack.length > 0) {
61
- const current = store.stack.at(-1)!
62
- current.onClose?.()
63
- setStore("stack", store.stack.slice(0, -1))
64
- evt.preventDefault()
65
- refocus()
66
- }
67
- })
68
-
69
- const renderer = useRenderer()
70
- let focus: Renderable | null
71
- function refocus() {
72
- setTimeout(() => {
73
- if (!focus) return
74
- if (focus.isDestroyed) return
75
- function find(item: Renderable) {
76
- for (const child of item.getChildren()) {
77
- if (child === focus) return true
78
- if (find(child)) return true
79
- }
80
- return false
81
- }
82
- const found = find(renderer.root)
83
- if (!found) return
84
- focus.focus()
85
- }, 1)
86
- }
87
-
88
- return {
89
- clear() {
90
- for (const item of store.stack) {
91
- if (item.onClose) item.onClose()
92
- }
93
- batch(() => {
94
- setStore("size", "medium")
95
- setStore("stack", [])
96
- })
97
- refocus()
98
- },
99
- replace(input: any, onClose?: () => void) {
100
- if (store.stack.length === 0) {
101
- focus = renderer.currentFocusedRenderable
102
- focus?.blur()
103
- }
104
- for (const item of store.stack) {
105
- if (item.onClose) item.onClose()
106
- }
107
- setStore("size", "medium")
108
- setStore("stack", [
109
- {
110
- element: input,
111
- onClose,
112
- },
113
- ])
114
- },
115
- get stack() {
116
- return store.stack
117
- },
118
- get size() {
119
- return store.size
120
- },
121
- setSize(size: "medium" | "large") {
122
- setStore("size", size)
123
- },
124
- }
125
- }
126
-
127
- export type DialogContext = ReturnType<typeof init>
128
-
129
- const ctx = createContext<DialogContext>()
130
-
131
- export function DialogProvider(props: ParentProps) {
132
- const value = init()
133
- const renderer = useRenderer()
134
- const toast = useToast()
135
- return (
136
- <ctx.Provider value={value}>
137
- {props.children}
138
- <box
139
- position="absolute"
140
- onMouseUp={async () => {
141
- const text = renderer.getSelection()?.getSelectedText()
142
- if (text && text.length > 0) {
143
- const base64 = Buffer.from(text).toString("base64")
144
- const osc52 = `\x1b]52;c;${base64}\x07`
145
- const finalOsc52 = process.env["TMUX"] ? `\x1bPtmux;\x1b${osc52}\x1b\\` : osc52
146
- /* @ts-expect-error */
147
- renderer.writeOut(finalOsc52)
148
- await Clipboard.copy(text)
149
- .then(() => toast.show({ message: "Copied to clipboard", variant: "info" }))
150
- .catch(toast.error)
151
- renderer.clearSelection()
152
- }
153
- }}
154
- >
155
- <Show when={value.stack.length}>
156
- <Dialog onClose={() => value.clear()} size={value.size}>
157
- {value.stack.at(-1)!.element}
158
- </Dialog>
159
- </Show>
160
- </box>
161
- </ctx.Provider>
162
- )
163
- }
164
-
165
- export function useDialog() {
166
- const value = useContext(ctx)
167
- if (!value) {
168
- throw new Error("useDialog must be used within a DialogProvider")
169
- }
170
- return value
171
- }
@@ -1,28 +0,0 @@
1
- import type { JSX } from "solid-js"
2
- import type { RGBA } from "@opentui/core"
3
- import open from "open"
4
-
5
- export interface LinkProps {
6
- href: string
7
- children?: JSX.Element | string
8
- fg?: RGBA
9
- }
10
-
11
- /**
12
- * Link component that renders clickable hyperlinks.
13
- * Clicking anywhere on the link text opens the URL in the default browser.
14
- */
15
- export function Link(props: LinkProps) {
16
- const displayText = props.children ?? props.href
17
-
18
- return (
19
- <text
20
- fg={props.fg}
21
- onMouseUp={() => {
22
- open(props.href).catch(() => {})
23
- }}
24
- >
25
- {displayText}
26
- </text>
27
- )
28
- }
@@ -1,368 +0,0 @@
1
- import type { ColorInput } from "@opentui/core"
2
- import { RGBA } from "@opentui/core"
3
- import type { ColorGenerator } from "opentui-spinner"
4
-
5
- interface AdvancedGradientOptions {
6
- colors: ColorInput[]
7
- trailLength: number
8
- defaultColor?: ColorInput
9
- direction?: "forward" | "backward" | "bidirectional"
10
- holdFrames?: { start?: number; end?: number }
11
- enableFading?: boolean
12
- minAlpha?: number
13
- }
14
-
15
- interface ScannerState {
16
- activePosition: number
17
- isHolding: boolean
18
- holdProgress: number
19
- holdTotal: number
20
- movementProgress: number
21
- movementTotal: number
22
- isMovingForward: boolean
23
- }
24
-
25
- function getScannerState(
26
- frameIndex: number,
27
- totalChars: number,
28
- options: Pick<AdvancedGradientOptions, "direction" | "holdFrames">,
29
- ): ScannerState {
30
- const { direction = "forward", holdFrames = {} } = options
31
-
32
- if (direction === "bidirectional") {
33
- const forwardFrames = totalChars
34
- const holdEndFrames = holdFrames.end ?? 0
35
- const backwardFrames = totalChars - 1
36
-
37
- if (frameIndex < forwardFrames) {
38
- // Moving forward
39
- return {
40
- activePosition: frameIndex,
41
- isHolding: false,
42
- holdProgress: 0,
43
- holdTotal: 0,
44
- movementProgress: frameIndex,
45
- movementTotal: forwardFrames,
46
- isMovingForward: true,
47
- }
48
- } else if (frameIndex < forwardFrames + holdEndFrames) {
49
- // Holding at end
50
- return {
51
- activePosition: totalChars - 1,
52
- isHolding: true,
53
- holdProgress: frameIndex - forwardFrames,
54
- holdTotal: holdEndFrames,
55
- movementProgress: 0,
56
- movementTotal: 0,
57
- isMovingForward: true,
58
- }
59
- } else if (frameIndex < forwardFrames + holdEndFrames + backwardFrames) {
60
- // Moving backward
61
- const backwardIndex = frameIndex - forwardFrames - holdEndFrames
62
- return {
63
- activePosition: totalChars - 2 - backwardIndex,
64
- isHolding: false,
65
- holdProgress: 0,
66
- holdTotal: 0,
67
- movementProgress: backwardIndex,
68
- movementTotal: backwardFrames,
69
- isMovingForward: false,
70
- }
71
- } else {
72
- // Holding at start
73
- return {
74
- activePosition: 0,
75
- isHolding: true,
76
- holdProgress: frameIndex - forwardFrames - holdEndFrames - backwardFrames,
77
- holdTotal: holdFrames.start ?? 0,
78
- movementProgress: 0,
79
- movementTotal: 0,
80
- isMovingForward: false,
81
- }
82
- }
83
- } else if (direction === "backward") {
84
- return {
85
- activePosition: totalChars - 1 - (frameIndex % totalChars),
86
- isHolding: false,
87
- holdProgress: 0,
88
- holdTotal: 0,
89
- movementProgress: frameIndex % totalChars,
90
- movementTotal: totalChars,
91
- isMovingForward: false,
92
- }
93
- } else {
94
- return {
95
- activePosition: frameIndex % totalChars,
96
- isHolding: false,
97
- holdProgress: 0,
98
- holdTotal: 0,
99
- movementProgress: frameIndex % totalChars,
100
- movementTotal: totalChars,
101
- isMovingForward: true,
102
- }
103
- }
104
- }
105
-
106
- function calculateColorIndex(
107
- frameIndex: number,
108
- charIndex: number,
109
- totalChars: number,
110
- options: Pick<AdvancedGradientOptions, "direction" | "holdFrames" | "trailLength">,
111
- state?: ScannerState,
112
- ): number {
113
- const { trailLength } = options
114
- const { activePosition, isHolding, holdProgress, isMovingForward } =
115
- state ?? getScannerState(frameIndex, totalChars, options)
116
-
117
- // Calculate directional distance (positive means trailing behind)
118
- const directionalDistance = isMovingForward
119
- ? activePosition - charIndex // For forward: trail is to the left (lower indices)
120
- : charIndex - activePosition // For backward: trail is to the right (higher indices)
121
-
122
- // Handle hold frame fading: keep the lead bright, fade the trail
123
- if (isHolding) {
124
- // Shift the color index by how long we've been holding
125
- return directionalDistance + holdProgress
126
- }
127
-
128
- // Normal movement - show gradient trail only behind the movement direction
129
- if (directionalDistance > 0 && directionalDistance < trailLength) {
130
- return directionalDistance
131
- }
132
-
133
- // At the active position, show the brightest color
134
- if (directionalDistance === 0) {
135
- return 0
136
- }
137
-
138
- return -1
139
- }
140
-
141
- function createKnightRiderTrail(options: AdvancedGradientOptions): ColorGenerator {
142
- const { colors, defaultColor, enableFading = true, minAlpha = 0 } = options
143
-
144
- // Use the provided defaultColor if it's an RGBA instance, otherwise convert/default
145
- // We use RGBA.fromHex for the fallback to ensure we have an RGBA object.
146
- // Note: If defaultColor is a string, we convert it once here.
147
- const defaultRgba = defaultColor instanceof RGBA ? defaultColor : RGBA.fromHex((defaultColor as string) || "#000000")
148
-
149
- // Store the base alpha from the inactive factor
150
- const baseInactiveAlpha = defaultRgba.a
151
-
152
- let cachedFrameIndex = -1
153
- let cachedState: ScannerState | null = null
154
-
155
- return (frameIndex: number, charIndex: number, _totalFrames: number, totalChars: number) => {
156
- if (frameIndex !== cachedFrameIndex) {
157
- cachedFrameIndex = frameIndex
158
- cachedState = getScannerState(frameIndex, totalChars, options)
159
- }
160
-
161
- const state = cachedState!
162
-
163
- const index = calculateColorIndex(frameIndex, charIndex, totalChars, options, state)
164
-
165
- // Calculate global fade for inactive dots during hold or movement
166
- const { isHolding, holdProgress, holdTotal, movementProgress, movementTotal } = state
167
-
168
- let fadeFactor = 1.0
169
- if (enableFading) {
170
- if (isHolding && holdTotal > 0) {
171
- // Fade out linearly to minAlpha
172
- const progress = Math.min(holdProgress / holdTotal, 1)
173
- fadeFactor = Math.max(minAlpha, 1 - progress * (1 - minAlpha))
174
- } else if (!isHolding && movementTotal > 0) {
175
- // Fade in linearly from minAlpha during movement
176
- const progress = Math.min(movementProgress / Math.max(1, movementTotal - 1), 1)
177
- fadeFactor = minAlpha + progress * (1 - minAlpha)
178
- }
179
- }
180
-
181
- // Combine base inactive alpha with the fade factor
182
- // This ensures inactiveFactor is respected while still allowing fading animation
183
- defaultRgba.a = baseInactiveAlpha * fadeFactor
184
-
185
- if (index === -1) {
186
- return defaultRgba
187
- }
188
-
189
- return colors[index] ?? defaultRgba
190
- }
191
- }
192
-
193
- /**
194
- * Derives a gradient of tail colors from a single bright color using alpha falloff
195
- * @param brightColor The brightest color (center/head of the scanner)
196
- * @param steps Number of gradient steps (default: 6)
197
- * @returns Array of RGBA colors with alpha-based trail fade (background-independent)
198
- */
199
- export function deriveTrailColors(brightColor: ColorInput, steps: number = 6): RGBA[] {
200
- const baseRgba = brightColor instanceof RGBA ? brightColor : RGBA.fromHex(brightColor as string)
201
-
202
- const colors: RGBA[] = []
203
-
204
- for (let i = 0; i < steps; i++) {
205
- // Alpha-based falloff with optional bloom effect
206
- let alpha: number
207
- let brightnessFactor: number
208
-
209
- if (i === 0) {
210
- // Lead position: full brightness and opacity
211
- alpha = 1.0
212
- brightnessFactor = 1.0
213
- } else if (i === 1) {
214
- // Slight bloom/glare effect: brighten color but reduce opacity slightly
215
- alpha = 0.9
216
- brightnessFactor = 1.15
217
- } else {
218
- // Exponential alpha decay for natural-looking trail fade
219
- alpha = Math.pow(0.65, i - 1)
220
- brightnessFactor = 1.0
221
- }
222
-
223
- const r = Math.min(1.0, baseRgba.r * brightnessFactor)
224
- const g = Math.min(1.0, baseRgba.g * brightnessFactor)
225
- const b = Math.min(1.0, baseRgba.b * brightnessFactor)
226
-
227
- colors.push(RGBA.fromValues(r, g, b, alpha))
228
- }
229
-
230
- return colors
231
- }
232
-
233
- /**
234
- * Derives the inactive/default color from a bright color using alpha
235
- * @param brightColor The brightest color (center/head of the scanner)
236
- * @param factor Alpha factor for inactive color (default: 0.2, range: 0-1)
237
- * @returns The same color with reduced alpha for background-independent dimming
238
- */
239
- export function deriveInactiveColor(brightColor: ColorInput, factor: number = 0.2): RGBA {
240
- const baseRgba = brightColor instanceof RGBA ? brightColor : RGBA.fromHex(brightColor as string)
241
-
242
- // Use the full color brightness but adjust alpha for background-independent dimming
243
- return RGBA.fromValues(baseRgba.r, baseRgba.g, baseRgba.b, factor)
244
- }
245
-
246
- export type KnightRiderStyle = "blocks" | "diamonds"
247
-
248
- export interface KnightRiderOptions {
249
- width?: number
250
- style?: KnightRiderStyle
251
- holdStart?: number
252
- holdEnd?: number
253
- colors?: ColorInput[]
254
- /** Single color to derive trail from (alternative to providing colors array) */
255
- color?: ColorInput
256
- /** Number of trail steps when using single color (default: 6) */
257
- trailSteps?: number
258
- defaultColor?: ColorInput
259
- /** Alpha factor for inactive color when using single color (default: 0.2, range: 0-1) */
260
- inactiveFactor?: number
261
- /** Enable fading of inactive dots during hold and movement (default: true) */
262
- enableFading?: boolean
263
- /** Minimum alpha value when fading (default: 0, range: 0-1) */
264
- minAlpha?: number
265
- }
266
-
267
- /**
268
- * Creates frame strings for a Knight Rider style scanner animation
269
- * @param options Configuration options for the Knight Rider effect
270
- * @returns Array of frame strings
271
- */
272
- export function createFrames(options: KnightRiderOptions = {}): string[] {
273
- const width = options.width ?? 8
274
- const style = options.style ?? "diamonds"
275
- const holdStart = options.holdStart ?? 30
276
- const holdEnd = options.holdEnd ?? 9
277
-
278
- const colors =
279
- options.colors ??
280
- (options.color
281
- ? deriveTrailColors(options.color, options.trailSteps)
282
- : [
283
- RGBA.fromHex("#ff0000"), // Brightest Red (Center)
284
- RGBA.fromHex("#ff5555"), // Glare/Bloom
285
- RGBA.fromHex("#dd0000"), // Trail 1
286
- RGBA.fromHex("#aa0000"), // Trail 2
287
- RGBA.fromHex("#770000"), // Trail 3
288
- RGBA.fromHex("#440000"), // Trail 4
289
- ])
290
-
291
- const defaultColor =
292
- options.defaultColor ??
293
- (options.color ? deriveInactiveColor(options.color, options.inactiveFactor) : RGBA.fromHex("#330000"))
294
-
295
- const trailOptions = {
296
- colors,
297
- trailLength: colors.length,
298
- defaultColor,
299
- direction: "bidirectional" as const,
300
- holdFrames: { start: holdStart, end: holdEnd },
301
- enableFading: options.enableFading,
302
- minAlpha: options.minAlpha,
303
- }
304
-
305
- // Bidirectional cycle: Forward (width) + Hold End + Backward (width-1) + Hold Start
306
- const totalFrames = width + holdEnd + (width - 1) + holdStart
307
-
308
- // Generate dynamic frames where inactive pixels are dots and active ones are blocks
309
- const frames = Array.from({ length: totalFrames }, (_, frameIndex) => {
310
- return Array.from({ length: width }, (_, charIndex) => {
311
- const index = calculateColorIndex(frameIndex, charIndex, width, trailOptions)
312
-
313
- if (style === "diamonds") {
314
- const shapes = ["⬥", "◆", "⬩", "⬪"]
315
- if (index >= 0 && index < trailOptions.colors.length) {
316
- return shapes[Math.min(index, shapes.length - 1)]
317
- }
318
- return "·"
319
- }
320
-
321
- // Default to blocks
322
- // It's active if we have a valid color index that is within our colors array
323
- const isActive = index >= 0 && index < trailOptions.colors.length
324
- return isActive ? "■" : "⬝"
325
- }).join("")
326
- })
327
-
328
- return frames
329
- }
330
-
331
- /**
332
- * Creates a color generator function for Knight Rider style scanner animation
333
- * @param options Configuration options for the Knight Rider effect
334
- * @returns ColorGenerator function
335
- */
336
- export function createColors(options: KnightRiderOptions = {}): ColorGenerator {
337
- const holdStart = options.holdStart ?? 30
338
- const holdEnd = options.holdEnd ?? 9
339
-
340
- const colors =
341
- options.colors ??
342
- (options.color
343
- ? deriveTrailColors(options.color, options.trailSteps)
344
- : [
345
- RGBA.fromHex("#ff0000"), // Brightest Red (Center)
346
- RGBA.fromHex("#ff5555"), // Glare/Bloom
347
- RGBA.fromHex("#dd0000"), // Trail 1
348
- RGBA.fromHex("#aa0000"), // Trail 2
349
- RGBA.fromHex("#770000"), // Trail 3
350
- RGBA.fromHex("#440000"), // Trail 4
351
- ])
352
-
353
- const defaultColor =
354
- options.defaultColor ??
355
- (options.color ? deriveInactiveColor(options.color, options.inactiveFactor) : RGBA.fromHex("#330000"))
356
-
357
- const trailOptions = {
358
- colors,
359
- trailLength: colors.length,
360
- defaultColor,
361
- direction: "bidirectional" as const,
362
- holdFrames: { start: holdStart, end: holdEnd },
363
- enableFading: options.enableFading,
364
- minAlpha: options.minAlpha,
365
- }
366
-
367
- return createKnightRiderTrail(trailOptions)
368
- }
@@ -1,100 +0,0 @@
1
- import { createContext, useContext, type ParentProps, Show } from "solid-js"
2
- import { createStore } from "solid-js/store"
3
- import { useTheme } from "@tui/context/theme"
4
- import { useTerminalDimensions } from "@opentui/solid"
5
- import { SplitBorder } from "../component/border"
6
- import { TextAttributes } from "@opentui/core"
7
- import z from "zod"
8
- import { TuiEvent } from "../event"
9
-
10
- export type ToastOptions = z.infer<typeof TuiEvent.ToastShow.properties>
11
-
12
- export function Toast() {
13
- const toast = useToast()
14
- const { theme } = useTheme()
15
- const dimensions = useTerminalDimensions()
16
-
17
- return (
18
- <Show when={toast.currentToast}>
19
- {(current) => (
20
- <box
21
- position="absolute"
22
- justifyContent="center"
23
- alignItems="flex-start"
24
- top={2}
25
- right={2}
26
- maxWidth={Math.min(60, dimensions().width - 6)}
27
- paddingLeft={2}
28
- paddingRight={2}
29
- paddingTop={1}
30
- paddingBottom={1}
31
- backgroundColor={theme.backgroundPanel}
32
- borderColor={theme[current().variant]}
33
- border={["left", "right"]}
34
- customBorderChars={SplitBorder.customBorderChars}
35
- >
36
- <Show when={current().title}>
37
- <text attributes={TextAttributes.BOLD} marginBottom={1} fg={theme.text}>
38
- {current().title}
39
- </text>
40
- </Show>
41
- <text fg={theme.text} wrapMode="word" width="100%">
42
- {current().message}
43
- </text>
44
- </box>
45
- )}
46
- </Show>
47
- )
48
- }
49
-
50
- function init() {
51
- const [store, setStore] = createStore({
52
- currentToast: null as ToastOptions | null,
53
- })
54
-
55
- let timeoutHandle: NodeJS.Timeout | null = null
56
-
57
- const toast = {
58
- show(options: ToastOptions) {
59
- const parsedOptions = TuiEvent.ToastShow.properties.parse(options)
60
- const { duration, ...currentToast } = parsedOptions
61
- setStore("currentToast", currentToast)
62
- if (timeoutHandle) clearTimeout(timeoutHandle)
63
- timeoutHandle = setTimeout(() => {
64
- setStore("currentToast", null)
65
- }, duration).unref()
66
- },
67
- error: (err: any) => {
68
- if (err instanceof Error)
69
- return toast.show({
70
- variant: "error",
71
- message: err.message,
72
- })
73
- toast.show({
74
- variant: "error",
75
- message: "An unknown error has occurred",
76
- })
77
- },
78
- get currentToast(): ToastOptions | null {
79
- return store.currentToast
80
- },
81
- }
82
- return toast
83
- }
84
-
85
- export type ToastContext = ReturnType<typeof init>
86
-
87
- const ctx = createContext<ToastContext>()
88
-
89
- export function ToastProvider(props: ParentProps) {
90
- const value = init()
91
- return <ctx.Provider value={value}>{props.children}</ctx.Provider>
92
- }
93
-
94
- export function useToast() {
95
- const value = useContext(ctx)
96
- if (!value) {
97
- throw new Error("useToast must be used within a ToastProvider")
98
- }
99
- return value
100
- }