@effect-tui/react 0.1.3 → 0.1.5

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 (442) hide show
  1. package/dist/jsx-runtime.d.ts +13 -0
  2. package/dist/jsx-runtime.d.ts.map +1 -1
  3. package/dist/jsx-runtime.js.map +1 -1
  4. package/dist/src/codeblock.d.ts.map +1 -1
  5. package/dist/src/codeblock.js.map +1 -1
  6. package/dist/src/components/Divider.d.ts +18 -0
  7. package/dist/src/components/Divider.d.ts.map +1 -0
  8. package/dist/src/components/Divider.js +17 -0
  9. package/dist/src/components/Divider.js.map +1 -0
  10. package/dist/src/components/Markdown.d.ts +66 -0
  11. package/dist/src/components/Markdown.d.ts.map +1 -0
  12. package/dist/src/components/Markdown.js +226 -0
  13. package/dist/src/components/Markdown.js.map +1 -0
  14. package/dist/src/components/MultilineTextInput.d.ts +65 -0
  15. package/dist/src/components/MultilineTextInput.d.ts.map +1 -0
  16. package/dist/src/components/MultilineTextInput.js +607 -0
  17. package/dist/src/components/MultilineTextInput.js.map +1 -0
  18. package/dist/src/components/Overlay.d.ts +46 -0
  19. package/dist/src/components/Overlay.d.ts.map +1 -0
  20. package/dist/src/components/Overlay.js +11 -0
  21. package/dist/src/components/Overlay.js.map +1 -0
  22. package/dist/src/components/Static.d.ts +44 -0
  23. package/dist/src/components/Static.d.ts.map +1 -0
  24. package/dist/src/components/Static.js +53 -0
  25. package/dist/src/components/Static.js.map +1 -0
  26. package/dist/src/components/TextInput.d.ts +55 -0
  27. package/dist/src/components/TextInput.d.ts.map +1 -0
  28. package/dist/src/components/TextInput.js +277 -0
  29. package/dist/src/components/TextInput.js.map +1 -0
  30. package/dist/src/components/index.d.ts +7 -0
  31. package/dist/src/components/index.d.ts.map +1 -0
  32. package/dist/src/components/index.js +7 -0
  33. package/dist/src/components/index.js.map +1 -0
  34. package/dist/src/components/text-editing.d.ts +62 -0
  35. package/dist/src/components/text-editing.d.ts.map +1 -0
  36. package/dist/src/components/text-editing.js +385 -0
  37. package/dist/src/components/text-editing.js.map +1 -0
  38. package/dist/src/console/ConsoleCapture.d.ts +36 -0
  39. package/dist/src/console/ConsoleCapture.d.ts.map +1 -0
  40. package/dist/src/console/ConsoleCapture.js +210 -0
  41. package/dist/src/console/ConsoleCapture.js.map +1 -0
  42. package/dist/src/console/ConsolePopover.d.ts +18 -0
  43. package/dist/src/console/ConsolePopover.d.ts.map +1 -0
  44. package/dist/src/console/ConsolePopover.js +324 -0
  45. package/dist/src/console/ConsolePopover.js.map +1 -0
  46. package/dist/src/console/clipboard.d.ts +10 -0
  47. package/dist/src/console/clipboard.d.ts.map +1 -0
  48. package/dist/src/console/clipboard.js +74 -0
  49. package/dist/src/console/clipboard.js.map +1 -0
  50. package/dist/src/console/index.d.ts +5 -0
  51. package/dist/src/console/index.d.ts.map +1 -0
  52. package/dist/src/console/index.js +33 -0
  53. package/dist/src/console/index.js.map +1 -0
  54. package/dist/src/console/useConsole.d.ts +44 -0
  55. package/dist/src/console/useConsole.d.ts.map +1 -0
  56. package/dist/src/console/useConsole.js +91 -0
  57. package/dist/src/console/useConsole.js.map +1 -0
  58. package/dist/src/debug/DebugOverlay.d.ts +49 -0
  59. package/dist/src/debug/DebugOverlay.d.ts.map +1 -0
  60. package/dist/src/debug/DebugOverlay.js +438 -0
  61. package/dist/src/debug/DebugOverlay.js.map +1 -0
  62. package/dist/src/debug/DiagnosticsPanel.d.ts.map +1 -1
  63. package/dist/src/debug/DiagnosticsPanel.js.map +1 -1
  64. package/dist/src/dev/Toast.d.ts +19 -0
  65. package/dist/src/dev/Toast.d.ts.map +1 -0
  66. package/dist/src/dev/Toast.js +72 -0
  67. package/dist/src/dev/Toast.js.map +1 -0
  68. package/dist/src/dev/index.d.ts +2 -0
  69. package/dist/src/dev/index.d.ts.map +1 -0
  70. package/dist/src/dev/index.js +3 -0
  71. package/dist/src/dev/index.js.map +1 -0
  72. package/dist/src/dev.d.ts +114 -0
  73. package/dist/src/dev.d.ts.map +1 -0
  74. package/dist/src/dev.js +373 -0
  75. package/dist/src/dev.js.map +1 -0
  76. package/dist/src/highlight.d.ts +3 -3
  77. package/dist/src/highlight.d.ts.map +1 -1
  78. package/dist/src/highlight.js.map +1 -1
  79. package/dist/src/hmr-plugin.d.ts +2 -0
  80. package/dist/src/hmr-plugin.d.ts.map +1 -0
  81. package/dist/src/hmr-plugin.js +53 -0
  82. package/dist/src/hmr-plugin.js.map +1 -0
  83. package/dist/src/hooks/index.d.ts +4 -0
  84. package/dist/src/hooks/index.d.ts.map +1 -1
  85. package/dist/src/hooks/index.js +2 -0
  86. package/dist/src/hooks/index.js.map +1 -1
  87. package/dist/src/hooks/use-keyboard.d.ts +11 -0
  88. package/dist/src/hooks/use-keyboard.d.ts.map +1 -1
  89. package/dist/src/hooks/use-keyboard.js +22 -4
  90. package/dist/src/hooks/use-keyboard.js.map +1 -1
  91. package/dist/src/hooks/use-mouse.d.ts +24 -0
  92. package/dist/src/hooks/use-mouse.d.ts.map +1 -0
  93. package/dist/src/hooks/use-mouse.js +41 -0
  94. package/dist/src/hooks/use-mouse.js.map +1 -0
  95. package/dist/src/hooks/use-paste.d.ts +11 -0
  96. package/dist/src/hooks/use-paste.d.ts.map +1 -1
  97. package/dist/src/hooks/use-paste.js +17 -3
  98. package/dist/src/hooks/use-paste.js.map +1 -1
  99. package/dist/src/hooks/use-scroll.d.ts +79 -0
  100. package/dist/src/hooks/use-scroll.d.ts.map +1 -0
  101. package/dist/src/hooks/use-scroll.js +239 -0
  102. package/dist/src/hooks/use-scroll.js.map +1 -0
  103. package/dist/src/hooks/useFrameStats.js.map +1 -1
  104. package/dist/src/hosts/base.d.ts +62 -1
  105. package/dist/src/hosts/base.d.ts.map +1 -1
  106. package/dist/src/hosts/base.js +118 -5
  107. package/dist/src/hosts/base.js.map +1 -1
  108. package/dist/src/hosts/box.d.ts +7 -7
  109. package/dist/src/hosts/box.d.ts.map +1 -1
  110. package/dist/src/hosts/box.js +30 -23
  111. package/dist/src/hosts/box.js.map +1 -1
  112. package/dist/src/hosts/canvas.d.ts +16 -8
  113. package/dist/src/hosts/canvas.d.ts.map +1 -1
  114. package/dist/src/hosts/canvas.js +27 -22
  115. package/dist/src/hosts/canvas.js.map +1 -1
  116. package/dist/src/hosts/codeblock.d.ts +7 -7
  117. package/dist/src/hosts/codeblock.d.ts.map +1 -1
  118. package/dist/src/hosts/codeblock.js +11 -20
  119. package/dist/src/hosts/codeblock.js.map +1 -1
  120. package/dist/src/hosts/flex-container.d.ts +45 -0
  121. package/dist/src/hosts/flex-container.d.ts.map +1 -0
  122. package/dist/src/hosts/flex-container.js +90 -0
  123. package/dist/src/hosts/flex-container.js.map +1 -0
  124. package/dist/src/hosts/hstack.d.ts +6 -11
  125. package/dist/src/hosts/hstack.d.ts.map +1 -1
  126. package/dist/src/hosts/hstack.js +6 -41
  127. package/dist/src/hosts/hstack.js.map +1 -1
  128. package/dist/src/hosts/index.d.ts +4 -0
  129. package/dist/src/hosts/index.d.ts.map +1 -1
  130. package/dist/src/hosts/index.js +10 -0
  131. package/dist/src/hosts/index.js.map +1 -1
  132. package/dist/src/hosts/overlay-item.d.ts +32 -0
  133. package/dist/src/hosts/overlay-item.d.ts.map +1 -0
  134. package/dist/src/hosts/overlay-item.js +54 -0
  135. package/dist/src/hosts/overlay-item.js.map +1 -0
  136. package/dist/src/hosts/overlay.d.ts +30 -0
  137. package/dist/src/hosts/overlay.d.ts.map +1 -0
  138. package/dist/src/hosts/overlay.js +105 -0
  139. package/dist/src/hosts/overlay.js.map +1 -0
  140. package/dist/src/hosts/scroll.d.ts +56 -0
  141. package/dist/src/hosts/scroll.d.ts.map +1 -0
  142. package/dist/src/hosts/scroll.js +204 -0
  143. package/dist/src/hosts/scroll.js.map +1 -0
  144. package/dist/src/hosts/single-child.d.ts +16 -0
  145. package/dist/src/hosts/single-child.d.ts.map +1 -0
  146. package/dist/src/hosts/single-child.js +45 -0
  147. package/dist/src/hosts/single-child.js.map +1 -0
  148. package/dist/src/hosts/spacer.d.ts.map +1 -1
  149. package/dist/src/hosts/spacer.js +7 -3
  150. package/dist/src/hosts/spacer.js.map +1 -1
  151. package/dist/src/hosts/text.d.ts +9 -6
  152. package/dist/src/hosts/text.d.ts.map +1 -1
  153. package/dist/src/hosts/text.js +49 -22
  154. package/dist/src/hosts/text.js.map +1 -1
  155. package/dist/src/hosts/vstack.d.ts +6 -11
  156. package/dist/src/hosts/vstack.d.ts.map +1 -1
  157. package/dist/src/hosts/vstack.js +6 -41
  158. package/dist/src/hosts/vstack.js.map +1 -1
  159. package/dist/src/hosts/zstack.d.ts.map +1 -1
  160. package/dist/src/hosts/zstack.js +16 -5
  161. package/dist/src/hosts/zstack.js.map +1 -1
  162. package/dist/src/index.d.ts +9 -2
  163. package/dist/src/index.d.ts.map +1 -1
  164. package/dist/src/index.js +10 -2
  165. package/dist/src/index.js.map +1 -1
  166. package/dist/src/inline/index.d.ts.map +1 -1
  167. package/dist/src/inline/index.js.map +1 -1
  168. package/dist/src/motion/color-motion-value.d.ts.map +1 -1
  169. package/dist/src/motion/color-motion-value.js.map +1 -1
  170. package/dist/src/motion/color.d.ts +1 -29
  171. package/dist/src/motion/color.d.ts.map +1 -1
  172. package/dist/src/motion/color.js +2 -170
  173. package/dist/src/motion/color.js.map +1 -1
  174. package/dist/src/motion/color.test.js.map +1 -1
  175. package/dist/src/motion/event-emitter.d.ts.map +1 -1
  176. package/dist/src/motion/event-emitter.js.map +1 -1
  177. package/dist/src/motion/frame.js.map +1 -1
  178. package/dist/src/motion/hooks.d.ts.map +1 -1
  179. package/dist/src/motion/hooks.js +8 -3
  180. package/dist/src/motion/hooks.js.map +1 -1
  181. package/dist/src/motion/index.d.ts.map +1 -1
  182. package/dist/src/motion/index.js.map +1 -1
  183. package/dist/src/motion/motion-value.d.ts.map +1 -1
  184. package/dist/src/motion/motion-value.js.map +1 -1
  185. package/dist/src/motion/motion-value.test.js.map +1 -1
  186. package/dist/src/motion/spring-math.d.ts +6 -1
  187. package/dist/src/motion/spring-math.d.ts.map +1 -1
  188. package/dist/src/motion/spring-math.js +6 -1
  189. package/dist/src/motion/spring-math.js.map +1 -1
  190. package/dist/src/motion/types.d.ts.map +1 -1
  191. package/dist/src/motion/types.js.map +1 -1
  192. package/dist/src/profiler.js.map +1 -1
  193. package/dist/src/reconciler/host-config.d.ts +5 -5
  194. package/dist/src/reconciler/host-config.d.ts.map +1 -1
  195. package/dist/src/reconciler/host-config.js +43 -51
  196. package/dist/src/reconciler/host-config.js.map +1 -1
  197. package/dist/src/reconciler/noop-methods.d.ts +29 -0
  198. package/dist/src/reconciler/noop-methods.d.ts.map +1 -0
  199. package/dist/src/reconciler/noop-methods.js +43 -0
  200. package/dist/src/reconciler/noop-methods.js.map +1 -0
  201. package/dist/src/reconciler/types.d.ts +68 -14
  202. package/dist/src/reconciler/types.d.ts.map +1 -1
  203. package/dist/src/remote/Procedures.d.ts +22 -0
  204. package/dist/src/remote/Procedures.d.ts.map +1 -0
  205. package/dist/src/remote/Procedures.js +42 -0
  206. package/dist/src/remote/Procedures.js.map +1 -0
  207. package/dist/src/remote/Router.d.ts +20 -0
  208. package/dist/src/remote/Router.d.ts.map +1 -0
  209. package/dist/src/remote/Router.js +26 -0
  210. package/dist/src/remote/Router.js.map +1 -0
  211. package/dist/src/remote/Server.d.ts +6 -0
  212. package/dist/src/remote/Server.d.ts.map +1 -0
  213. package/dist/src/remote/Server.js +53 -0
  214. package/dist/src/remote/Server.js.map +1 -0
  215. package/dist/src/remote/index.d.ts +18 -0
  216. package/dist/src/remote/index.d.ts.map +1 -0
  217. package/dist/src/remote/index.js +74 -0
  218. package/dist/src/remote/index.js.map +1 -0
  219. package/dist/src/renderer/core/FrameBuilder.d.ts +18 -0
  220. package/dist/src/renderer/core/FrameBuilder.d.ts.map +1 -0
  221. package/dist/src/renderer/core/FrameBuilder.js +38 -0
  222. package/dist/src/renderer/core/FrameBuilder.js.map +1 -0
  223. package/dist/src/renderer/core/RendererState.d.ts +41 -0
  224. package/dist/src/renderer/core/RendererState.d.ts.map +1 -0
  225. package/dist/src/renderer/core/RendererState.js +70 -0
  226. package/dist/src/renderer/core/RendererState.js.map +1 -0
  227. package/dist/src/renderer/core/index.d.ts +3 -0
  228. package/dist/src/renderer/core/index.d.ts.map +1 -0
  229. package/dist/src/renderer/core/index.js +3 -0
  230. package/dist/src/renderer/core/index.js.map +1 -0
  231. package/dist/src/renderer/input/InputProcessor.d.ts +25 -0
  232. package/dist/src/renderer/input/InputProcessor.d.ts.map +1 -0
  233. package/dist/src/renderer/input/InputProcessor.js +81 -0
  234. package/dist/src/renderer/input/InputProcessor.js.map +1 -0
  235. package/dist/src/renderer/input/index.d.ts +2 -0
  236. package/dist/src/renderer/input/index.d.ts.map +1 -0
  237. package/dist/src/renderer/input/index.js +2 -0
  238. package/dist/src/renderer/input/index.js.map +1 -0
  239. package/dist/src/renderer/lifecycle/EventBus.d.ts +41 -0
  240. package/dist/src/renderer/lifecycle/EventBus.d.ts.map +1 -0
  241. package/dist/src/renderer/lifecycle/EventBus.js +78 -0
  242. package/dist/src/renderer/lifecycle/EventBus.js.map +1 -0
  243. package/dist/src/renderer/lifecycle/ResizeManager.d.ts +34 -0
  244. package/dist/src/renderer/lifecycle/ResizeManager.d.ts.map +1 -0
  245. package/dist/src/renderer/lifecycle/ResizeManager.js +47 -0
  246. package/dist/src/renderer/lifecycle/ResizeManager.js.map +1 -0
  247. package/dist/src/renderer/lifecycle/TerminalSetup.d.ts +36 -0
  248. package/dist/src/renderer/lifecycle/TerminalSetup.d.ts.map +1 -0
  249. package/dist/src/renderer/lifecycle/TerminalSetup.js +82 -0
  250. package/dist/src/renderer/lifecycle/TerminalSetup.js.map +1 -0
  251. package/dist/src/renderer/lifecycle/index.d.ts +4 -0
  252. package/dist/src/renderer/lifecycle/index.d.ts.map +1 -0
  253. package/dist/src/renderer/lifecycle/index.js +4 -0
  254. package/dist/src/renderer/lifecycle/index.js.map +1 -0
  255. package/dist/src/renderer/modes/FullscreenRenderer.d.ts +12 -0
  256. package/dist/src/renderer/modes/FullscreenRenderer.d.ts.map +1 -0
  257. package/dist/src/renderer/modes/FullscreenRenderer.js +52 -0
  258. package/dist/src/renderer/modes/FullscreenRenderer.js.map +1 -0
  259. package/dist/src/renderer/modes/InlineRenderer.d.ts +25 -0
  260. package/dist/src/renderer/modes/InlineRenderer.d.ts.map +1 -0
  261. package/dist/src/renderer/modes/InlineRenderer.js +161 -0
  262. package/dist/src/renderer/modes/InlineRenderer.js.map +1 -0
  263. package/dist/src/renderer/modes/RendererMode.d.ts +42 -0
  264. package/dist/src/renderer/modes/RendererMode.d.ts.map +1 -0
  265. package/dist/src/renderer/modes/RendererMode.js +2 -0
  266. package/dist/src/renderer/modes/RendererMode.js.map +1 -0
  267. package/dist/src/renderer/modes/StaticContentRenderer.d.ts +25 -0
  268. package/dist/src/renderer/modes/StaticContentRenderer.d.ts.map +1 -0
  269. package/dist/src/renderer/modes/StaticContentRenderer.js +47 -0
  270. package/dist/src/renderer/modes/StaticContentRenderer.js.map +1 -0
  271. package/dist/src/renderer/modes/index.d.ts +5 -0
  272. package/dist/src/renderer/modes/index.d.ts.map +1 -0
  273. package/dist/src/renderer/modes/index.js +4 -0
  274. package/dist/src/renderer/modes/index.js.map +1 -0
  275. package/dist/src/renderer-context.d.ts +9 -0
  276. package/dist/src/renderer-context.d.ts.map +1 -0
  277. package/dist/src/renderer-context.js +22 -0
  278. package/dist/src/renderer-context.js.map +1 -0
  279. package/dist/src/renderer-types.d.ts +103 -0
  280. package/dist/src/renderer-types.d.ts.map +1 -0
  281. package/dist/src/renderer-types.js +2 -0
  282. package/dist/src/renderer-types.js.map +1 -0
  283. package/dist/src/renderer.d.ts +4 -86
  284. package/dist/src/renderer.d.ts.map +1 -1
  285. package/dist/src/renderer.js +214 -384
  286. package/dist/src/renderer.js.map +1 -1
  287. package/dist/src/test/index.d.ts.map +1 -1
  288. package/dist/src/test/index.js.map +1 -1
  289. package/dist/src/test/mock-streams.d.ts.map +1 -1
  290. package/dist/src/test/mock-streams.js.map +1 -1
  291. package/dist/src/test/render-tui.d.ts.map +1 -1
  292. package/dist/src/test/render-tui.js +2 -5
  293. package/dist/src/test/render-tui.js.map +1 -1
  294. package/dist/src/trace/SpanTree.d.ts.map +1 -1
  295. package/dist/src/trace/SpanTree.js +21 -11
  296. package/dist/src/trace/SpanTree.js.map +1 -1
  297. package/dist/src/trace/format-value.d.ts +15 -0
  298. package/dist/src/trace/format-value.d.ts.map +1 -0
  299. package/dist/src/trace/format-value.js +77 -0
  300. package/dist/src/trace/format-value.js.map +1 -0
  301. package/dist/src/trace/index.d.ts.map +1 -1
  302. package/dist/src/trace/index.js.map +1 -1
  303. package/dist/src/trace/location.js +1 -1
  304. package/dist/src/trace/location.js.map +1 -1
  305. package/dist/src/trace/span-processor.d.ts.map +1 -1
  306. package/dist/src/trace/span-processor.js.map +1 -1
  307. package/dist/src/trace/span-state.d.ts +19 -2
  308. package/dist/src/trace/span-state.d.ts.map +1 -1
  309. package/dist/src/trace/span-state.js +62 -31
  310. package/dist/src/trace/span-state.js.map +1 -1
  311. package/dist/src/trace/tui-logger.js.map +1 -1
  312. package/dist/src/utils/border.d.ts +1 -1
  313. package/dist/src/utils/border.d.ts.map +1 -1
  314. package/dist/src/utils/border.js +6 -0
  315. package/dist/src/utils/border.js.map +1 -1
  316. package/dist/src/utils/flex-layout.d.ts +2 -1
  317. package/dist/src/utils/flex-layout.d.ts.map +1 -1
  318. package/dist/src/utils/flex-layout.js +22 -33
  319. package/dist/src/utils/flex-layout.js.map +1 -1
  320. package/dist/src/utils/index.d.ts +1 -1
  321. package/dist/src/utils/index.d.ts.map +1 -1
  322. package/dist/src/utils/index.js +1 -1
  323. package/dist/src/utils/index.js.map +1 -1
  324. package/dist/src/utils/padding.d.ts.map +1 -1
  325. package/dist/src/utils/padding.js.map +1 -1
  326. package/dist/src/utils/styles.d.ts +20 -1
  327. package/dist/src/utils/styles.d.ts.map +1 -1
  328. package/dist/src/utils/styles.js +36 -1
  329. package/dist/src/utils/styles.js.map +1 -1
  330. package/dist/src/visualize/index.d.ts +8 -19
  331. package/dist/src/visualize/index.d.ts.map +1 -1
  332. package/dist/src/visualize/index.js +11 -25
  333. package/dist/src/visualize/index.js.map +1 -1
  334. package/dist/tsconfig.tsbuildinfo +1 -1
  335. package/jsx-dev-runtime.ts +5 -0
  336. package/jsx-runtime.ts +54 -0
  337. package/package.json +124 -92
  338. package/src/codeblock.tsx +34 -34
  339. package/src/components/Divider.tsx +23 -0
  340. package/src/components/Markdown.tsx +380 -0
  341. package/src/components/MultilineTextInput.tsx +749 -0
  342. package/src/components/Overlay.tsx +56 -0
  343. package/src/components/Static.tsx +68 -0
  344. package/src/components/TextInput.tsx +356 -0
  345. package/src/components/index.ts +6 -0
  346. package/src/components/text-editing.ts +464 -0
  347. package/src/console/ConsoleCapture.ts +272 -0
  348. package/src/console/ConsolePopover.tsx +487 -0
  349. package/src/console/clipboard.ts +81 -0
  350. package/src/console/index.ts +42 -0
  351. package/src/console/useConsole.ts +129 -0
  352. package/src/debug/DebugOverlay.ts +557 -0
  353. package/src/debug/DiagnosticsPanel.tsx +27 -27
  354. package/src/dev/Toast.tsx +117 -0
  355. package/src/dev/index.ts +2 -0
  356. package/src/dev.tsx +489 -0
  357. package/src/highlight.ts +46 -46
  358. package/src/hmr-plugin.ts +61 -0
  359. package/src/hooks/index.ts +4 -0
  360. package/src/hooks/use-keyboard.ts +44 -24
  361. package/src/hooks/use-mouse.ts +51 -0
  362. package/src/hooks/use-paste.ts +21 -6
  363. package/src/hooks/use-scroll.ts +386 -0
  364. package/src/hooks/useFrameStats.ts +17 -17
  365. package/src/hosts/base.ts +180 -59
  366. package/src/hosts/box.ts +117 -94
  367. package/src/hosts/canvas.ts +170 -141
  368. package/src/hosts/codeblock.ts +117 -133
  369. package/src/hosts/flex-container.ts +124 -0
  370. package/src/hosts/hstack.ts +11 -59
  371. package/src/hosts/index.ts +24 -14
  372. package/src/hosts/overlay-item.ts +72 -0
  373. package/src/hosts/overlay.ts +125 -0
  374. package/src/hosts/scroll.ts +255 -0
  375. package/src/hosts/single-child.ts +52 -0
  376. package/src/hosts/spacer.ts +30 -26
  377. package/src/hosts/text.ts +198 -164
  378. package/src/hosts/vstack.ts +11 -59
  379. package/src/hosts/zstack.ts +79 -67
  380. package/src/index.ts +44 -19
  381. package/src/inline/index.tsx +123 -123
  382. package/src/motion/color-motion-value.ts +67 -67
  383. package/src/motion/color.test.ts +107 -107
  384. package/src/motion/color.ts +9 -190
  385. package/src/motion/event-emitter.ts +20 -20
  386. package/src/motion/frame.ts +35 -35
  387. package/src/motion/hooks.ts +144 -139
  388. package/src/motion/index.ts +10 -10
  389. package/src/motion/motion-value.test.ts +207 -207
  390. package/src/motion/motion-value.ts +112 -112
  391. package/src/motion/spring-math.ts +88 -83
  392. package/src/motion/types.ts +25 -25
  393. package/src/profiler.ts +50 -50
  394. package/src/reconciler/host-config.ts +152 -174
  395. package/src/reconciler/noop-methods.ts +55 -0
  396. package/src/reconciler/types.ts +112 -46
  397. package/src/remote/Procedures.ts +52 -0
  398. package/src/remote/Router.ts +58 -0
  399. package/src/remote/Server.ts +76 -0
  400. package/src/remote/index.ts +90 -0
  401. package/src/renderer/core/FrameBuilder.ts +49 -0
  402. package/src/renderer/core/RendererState.ts +80 -0
  403. package/src/renderer/core/index.ts +2 -0
  404. package/src/renderer/input/InputProcessor.ts +94 -0
  405. package/src/renderer/input/index.ts +1 -0
  406. package/src/renderer/lifecycle/EventBus.ts +90 -0
  407. package/src/renderer/lifecycle/ResizeManager.ts +65 -0
  408. package/src/renderer/lifecycle/TerminalSetup.ts +105 -0
  409. package/src/renderer/lifecycle/index.ts +3 -0
  410. package/src/renderer/modes/FullscreenRenderer.ts +53 -0
  411. package/src/renderer/modes/InlineRenderer.ts +186 -0
  412. package/src/renderer/modes/RendererMode.ts +46 -0
  413. package/src/renderer/modes/StaticContentRenderer.ts +56 -0
  414. package/src/renderer/modes/index.ts +4 -0
  415. package/src/renderer-context.ts +27 -0
  416. package/src/renderer-types.ts +109 -0
  417. package/src/renderer.ts +392 -642
  418. package/src/test/index.ts +5 -5
  419. package/src/test/mock-streams.ts +115 -115
  420. package/src/test/render-tui.ts +84 -87
  421. package/src/utils/border.ts +79 -73
  422. package/src/utils/flex-layout.ts +80 -93
  423. package/src/utils/index.ts +1 -1
  424. package/src/utils/padding.ts +27 -27
  425. package/src/utils/styles.ts +50 -7
  426. package/src/visualize/index.tsx +225 -240
  427. package/dist/src/output.d.ts +0 -47
  428. package/dist/src/output.d.ts.map +0 -1
  429. package/dist/src/output.js +0 -125
  430. package/dist/src/output.js.map +0 -1
  431. package/dist/src/terminal.d.ts +0 -37
  432. package/dist/src/terminal.d.ts.map +0 -1
  433. package/dist/src/terminal.js +0 -65
  434. package/dist/src/terminal.js.map +0 -1
  435. package/src/output.ts +0 -156
  436. package/src/terminal.ts +0 -67
  437. package/src/trace/SpanTree.tsx +0 -195
  438. package/src/trace/index.tsx +0 -205
  439. package/src/trace/location.ts +0 -90
  440. package/src/trace/span-processor.ts +0 -65
  441. package/src/trace/span-state.ts +0 -286
  442. package/src/trace/tui-logger.ts +0 -72
@@ -0,0 +1,380 @@
1
+ import { Colors, type ColorValue } from "@effect-tui/core"
2
+ import { CodeBlock } from "../codeblock.js"
3
+ import type { BundledLanguage, BundledTheme } from "shiki"
4
+
5
+ export interface MarkdownTheme {
6
+ /** Header colors by level (h1, h2, h3+) */
7
+ h1?: ColorValue
8
+ h2?: ColorValue
9
+ h3?: ColorValue
10
+ /** Bold text color */
11
+ bold?: ColorValue
12
+ /** Italic text color */
13
+ italic?: ColorValue
14
+ /** Inline code color */
15
+ code?: ColorValue
16
+ /** Inline code background */
17
+ codeBg?: ColorValue
18
+ /** Link text color */
19
+ link?: ColorValue
20
+ /** Link URL color */
21
+ linkUrl?: ColorValue
22
+ /** Blockquote text color */
23
+ quote?: ColorValue
24
+ /** Blockquote border color */
25
+ quoteBorder?: ColorValue
26
+ /** List bullet/number color */
27
+ listMarker?: ColorValue
28
+ /** Normal text color */
29
+ text?: ColorValue
30
+ }
31
+
32
+ const defaultTheme: Required<MarkdownTheme> = {
33
+ h1: Colors.brightCyan,
34
+ h2: Colors.cyan,
35
+ h3: Colors.brightBlue,
36
+ bold: Colors.brightWhite,
37
+ italic: Colors.brightYellow,
38
+ code: Colors.brightGreen,
39
+ codeBg: Colors.gray(2),
40
+ link: Colors.brightBlue,
41
+ linkUrl: Colors.gray(10),
42
+ quote: Colors.gray(14),
43
+ quoteBorder: Colors.gray(8),
44
+ listMarker: Colors.gray(12),
45
+ text: Colors.gray(18),
46
+ }
47
+
48
+ export interface MarkdownProps {
49
+ /** Markdown content to render */
50
+ content: string
51
+ /** Custom theme overrides */
52
+ theme?: MarkdownTheme
53
+ /** Code block theme for syntax highlighting */
54
+ codeTheme?: BundledTheme
55
+ /** Maximum width for text wrapping (default: no wrap) */
56
+ maxWidth?: number
57
+ }
58
+
59
+ // Parsed markdown elements
60
+ type MdElement =
61
+ | { type: "h1" | "h2" | "h3"; text: string }
62
+ | { type: "paragraph"; spans: MdSpan[] }
63
+ | { type: "code"; language: string; code: string }
64
+ | { type: "blockquote"; spans: MdSpan[] }
65
+ | { type: "ul"; items: MdSpan[][] }
66
+ | { type: "ol"; items: MdSpan[][]; start: number }
67
+ | { type: "hr" }
68
+ | { type: "blank" }
69
+
70
+ type MdSpan =
71
+ | { type: "text"; text: string }
72
+ | { type: "bold"; text: string }
73
+ | { type: "italic"; text: string }
74
+ | { type: "code"; text: string }
75
+ | { type: "link"; text: string; url: string }
76
+
77
+ /**
78
+ * Parse inline markdown formatting (bold, italic, code, links)
79
+ */
80
+ function parseInline(text: string): MdSpan[] {
81
+ const spans: MdSpan[] = []
82
+ let remaining = text
83
+
84
+ while (remaining.length > 0) {
85
+ // Bold: **text** or __text__
86
+ let match = remaining.match(/^\*\*(.+?)\*\*|^__(.+?)__/)
87
+ if (match) {
88
+ spans.push({ type: "bold", text: match[1] || match[2] })
89
+ remaining = remaining.slice(match[0].length)
90
+ continue
91
+ }
92
+
93
+ // Italic: *text* or _text_ (but not inside words for _)
94
+ match = remaining.match(/^\*([^*]+?)\*|^_([^_]+?)_/)
95
+ if (match) {
96
+ spans.push({ type: "italic", text: match[1] || match[2] })
97
+ remaining = remaining.slice(match[0].length)
98
+ continue
99
+ }
100
+
101
+ // Inline code: `code`
102
+ match = remaining.match(/^`([^`]+?)`/)
103
+ if (match) {
104
+ spans.push({ type: "code", text: match[1] })
105
+ remaining = remaining.slice(match[0].length)
106
+ continue
107
+ }
108
+
109
+ // Link: [text](url)
110
+ match = remaining.match(/^\[([^\]]+)\]\(([^)]+)\)/)
111
+ if (match) {
112
+ spans.push({ type: "link", text: match[1], url: match[2] })
113
+ remaining = remaining.slice(match[0].length)
114
+ continue
115
+ }
116
+
117
+ // Plain text until next special character
118
+ match = remaining.match(/^[^*_`\[]+/)
119
+ if (match) {
120
+ spans.push({ type: "text", text: match[0] })
121
+ remaining = remaining.slice(match[0].length)
122
+ continue
123
+ }
124
+
125
+ // Single special character that didn't match a pattern
126
+ spans.push({ type: "text", text: remaining[0] })
127
+ remaining = remaining.slice(1)
128
+ }
129
+
130
+ return spans
131
+ }
132
+
133
+ /**
134
+ * Parse markdown content into elements
135
+ */
136
+ function parseMarkdown(content: string): MdElement[] {
137
+ const lines = content.split("\n")
138
+ const elements: MdElement[] = []
139
+ let i = 0
140
+
141
+ while (i < lines.length) {
142
+ const line = lines[i]
143
+
144
+ // Blank line
145
+ if (line.trim() === "") {
146
+ elements.push({ type: "blank" })
147
+ i++
148
+ continue
149
+ }
150
+
151
+ // Horizontal rule
152
+ if (/^[-*_]{3,}\s*$/.test(line)) {
153
+ elements.push({ type: "hr" })
154
+ i++
155
+ continue
156
+ }
157
+
158
+ // Headers
159
+ const headerMatch = line.match(/^(#{1,6})\s+(.+)$/)
160
+ if (headerMatch) {
161
+ const level = Math.min(headerMatch[1].length, 3)
162
+ const type = level === 1 ? "h1" : level === 2 ? "h2" : "h3"
163
+ elements.push({ type, text: headerMatch[2] })
164
+ i++
165
+ continue
166
+ }
167
+
168
+ // Fenced code block
169
+ const codeMatch = line.match(/^```(\w*)/)
170
+ if (codeMatch) {
171
+ const language = codeMatch[1] || "text"
172
+ const codeLines: string[] = []
173
+ i++
174
+ while (i < lines.length && !lines[i].startsWith("```")) {
175
+ codeLines.push(lines[i])
176
+ i++
177
+ }
178
+ elements.push({ type: "code", language, code: codeLines.join("\n") })
179
+ i++ // skip closing ```
180
+ continue
181
+ }
182
+
183
+ // Blockquote
184
+ if (line.startsWith(">")) {
185
+ const quoteText = line.replace(/^>\s?/, "")
186
+ elements.push({ type: "blockquote", spans: parseInline(quoteText) })
187
+ i++
188
+ continue
189
+ }
190
+
191
+ // Unordered list
192
+ const ulMatch = line.match(/^[-*+]\s+(.+)$/)
193
+ if (ulMatch) {
194
+ const items: MdSpan[][] = []
195
+ while (i < lines.length) {
196
+ const itemMatch = lines[i].match(/^[-*+]\s+(.+)$/)
197
+ if (!itemMatch) break
198
+ items.push(parseInline(itemMatch[1]))
199
+ i++
200
+ }
201
+ elements.push({ type: "ul", items })
202
+ continue
203
+ }
204
+
205
+ // Ordered list
206
+ const olMatch = line.match(/^(\d+)\.\s+(.+)$/)
207
+ if (olMatch) {
208
+ const start = parseInt(olMatch[1], 10)
209
+ const items: MdSpan[][] = []
210
+ while (i < lines.length) {
211
+ const itemMatch = lines[i].match(/^\d+\.\s+(.+)$/)
212
+ if (!itemMatch) break
213
+ items.push(parseInline(itemMatch[1]))
214
+ i++
215
+ }
216
+ elements.push({ type: "ol", items, start })
217
+ continue
218
+ }
219
+
220
+ // Regular paragraph
221
+ elements.push({ type: "paragraph", spans: parseInline(line) })
222
+ i++
223
+ }
224
+
225
+ return elements
226
+ }
227
+
228
+ /**
229
+ * Render inline spans as text elements
230
+ */
231
+ function renderSpans(spans: MdSpan[], theme: Required<MarkdownTheme>) {
232
+ return spans.map((span, i) => {
233
+ switch (span.type) {
234
+ case "text":
235
+ return (
236
+ <text key={i} fg={theme.text}>
237
+ {span.text}
238
+ </text>
239
+ )
240
+ case "bold":
241
+ return (
242
+ <text key={i} fg={theme.bold} bold>
243
+ {span.text}
244
+ </text>
245
+ )
246
+ case "italic":
247
+ return (
248
+ <text key={i} fg={theme.italic} italic>
249
+ {span.text}
250
+ </text>
251
+ )
252
+ case "code":
253
+ return (
254
+ <text key={i} fg={theme.code} bg={theme.codeBg}>
255
+ {span.text}
256
+ </text>
257
+ )
258
+ case "link":
259
+ return (
260
+ <hstack key={i}>
261
+ <text fg={theme.link}>{span.text}</text>
262
+ <text fg={theme.linkUrl}>{" ("}</text>
263
+ <text fg={theme.linkUrl}>{span.url}</text>
264
+ <text fg={theme.linkUrl}>{")"}</text>
265
+ </hstack>
266
+ )
267
+ }
268
+ })
269
+ }
270
+
271
+ /**
272
+ * A markdown renderer component for terminal UIs.
273
+ *
274
+ * Supports:
275
+ * - Headers (# ## ###)
276
+ * - Bold (**text**) and italic (*text*)
277
+ * - Inline code (`code`) and fenced code blocks
278
+ * - Links [text](url)
279
+ * - Blockquotes (> text)
280
+ * - Unordered lists (- item)
281
+ * - Ordered lists (1. item)
282
+ * - Horizontal rules (---)
283
+ *
284
+ * @example
285
+ * ```tsx
286
+ * <Markdown content={`
287
+ * # Hello World
288
+ *
289
+ * This is **bold** and *italic* text.
290
+ *
291
+ * \`\`\`typescript
292
+ * const x = 42
293
+ * \`\`\`
294
+ * `} />
295
+ * ```
296
+ */
297
+ export function Markdown({ content, theme: themeOverrides, codeTheme = "nord" }: MarkdownProps) {
298
+ const theme = { ...defaultTheme, ...themeOverrides }
299
+ const elements = parseMarkdown(content)
300
+
301
+ return (
302
+ <vstack>
303
+ {elements.map((el, i) => {
304
+ switch (el.type) {
305
+ case "h1":
306
+ return (
307
+ <text key={i} fg={theme.h1} bold>
308
+ {"# "}
309
+ {el.text}
310
+ </text>
311
+ )
312
+ case "h2":
313
+ return (
314
+ <text key={i} fg={theme.h2} bold>
315
+ {"## "}
316
+ {el.text}
317
+ </text>
318
+ )
319
+ case "h3":
320
+ return (
321
+ <text key={i} fg={theme.h3} bold>
322
+ {"### "}
323
+ {el.text}
324
+ </text>
325
+ )
326
+ case "paragraph":
327
+ return <hstack key={i}>{renderSpans(el.spans, theme)}</hstack>
328
+ case "code":
329
+ return (
330
+ <CodeBlock
331
+ key={i}
332
+ code={el.code}
333
+ language={el.language as BundledLanguage}
334
+ theme={codeTheme}
335
+ lineNumbers={false}
336
+ padding={1}
337
+ />
338
+ )
339
+ case "blockquote":
340
+ return (
341
+ <hstack key={i}>
342
+ <text fg={theme.quoteBorder}>{"│ "}</text>
343
+ {renderSpans(el.spans, theme)}
344
+ </hstack>
345
+ )
346
+ case "ul":
347
+ return (
348
+ <vstack key={i}>
349
+ {el.items.map((item, j) => (
350
+ <hstack key={j}>
351
+ <text fg={theme.listMarker}>{" • "}</text>
352
+ {renderSpans(item, theme)}
353
+ </hstack>
354
+ ))}
355
+ </vstack>
356
+ )
357
+ case "ol":
358
+ return (
359
+ <vstack key={i}>
360
+ {el.items.map((item, j) => (
361
+ <hstack key={j}>
362
+ <text fg={theme.listMarker}>{` ${el.start + j}. `}</text>
363
+ {renderSpans(item, theme)}
364
+ </hstack>
365
+ ))}
366
+ </vstack>
367
+ )
368
+ case "hr":
369
+ return (
370
+ <text key={i} fg={theme.quoteBorder}>
371
+ {"────────────────────────────────"}
372
+ </text>
373
+ )
374
+ case "blank":
375
+ return <text key={i}> </text>
376
+ }
377
+ })}
378
+ </vstack>
379
+ )
380
+ }