@fairyhunter13/opentui-core 0.1.112 → 0.1.114

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 (591) hide show
  1. package/dev/keypress-debug-renderer.ts +148 -0
  2. package/dev/keypress-debug.ts +43 -0
  3. package/dev/print-env-vars.ts +32 -0
  4. package/dev/test-tmux-graphics-334.sh +68 -0
  5. package/dev/thai-debug-test.ts +68 -0
  6. package/docs/development.md +144 -0
  7. package/package.json +63 -51
  8. package/scripts/build.ts +400 -0
  9. package/scripts/publish.ts +60 -0
  10. package/src/3d/SpriteResourceManager.ts +286 -0
  11. package/src/3d/SpriteUtils.ts +70 -0
  12. package/src/3d/TextureUtils.ts +196 -0
  13. package/src/3d/ThreeRenderable.ts +197 -0
  14. package/src/3d/WGPURenderer.ts +294 -0
  15. package/src/3d/animation/ExplodingSpriteEffect.ts +513 -0
  16. package/src/3d/animation/PhysicsExplodingSpriteEffect.ts +429 -0
  17. package/src/3d/animation/SpriteAnimator.ts +633 -0
  18. package/src/3d/animation/SpriteParticleGenerator.ts +435 -0
  19. package/src/3d/canvas.ts +464 -0
  20. package/src/3d/index.ts +12 -0
  21. package/src/3d/physics/PlanckPhysicsAdapter.ts +72 -0
  22. package/src/3d/physics/RapierPhysicsAdapter.ts +66 -0
  23. package/src/3d/physics/physics-interface.ts +31 -0
  24. package/src/3d/shaders/supersampling.wgsl +201 -0
  25. package/src/3d.ts +3 -0
  26. package/src/NativeSpanFeed.ts +300 -0
  27. package/src/Renderable.ts +1704 -0
  28. package/src/__snapshots__/buffer.test.ts.snap +28 -0
  29. package/src/animation/Timeline.test.ts +2709 -0
  30. package/src/animation/Timeline.ts +598 -0
  31. package/src/ansi.ts +18 -0
  32. package/src/benchmark/attenuation-benchmark.ts +81 -0
  33. package/src/benchmark/colormatrix-benchmark.ts +128 -0
  34. package/src/benchmark/gain-benchmark.ts +80 -0
  35. package/src/benchmark/latest-all-bench-run.json +707 -0
  36. package/src/benchmark/latest-async-bench-run.json +336 -0
  37. package/src/benchmark/latest-default-bench-run.json +657 -0
  38. package/src/benchmark/latest-large-bench-run.json +707 -0
  39. package/src/benchmark/latest-quick-bench-run.json +207 -0
  40. package/src/benchmark/markdown-benchmark.ts +1796 -0
  41. package/src/benchmark/native-span-feed-async-benchmark.ts +355 -0
  42. package/src/benchmark/native-span-feed-benchmark.md +56 -0
  43. package/src/benchmark/native-span-feed-benchmark.ts +596 -0
  44. package/src/benchmark/native-span-feed-compare.ts +280 -0
  45. package/src/benchmark/renderer-benchmark.ts +754 -0
  46. package/src/benchmark/text-table-benchmark.ts +948 -0
  47. package/src/buffer.test.ts +291 -0
  48. package/src/buffer.ts +554 -0
  49. package/src/console.test.ts +612 -0
  50. package/src/console.ts +1254 -0
  51. package/src/edit-buffer.test.ts +1769 -0
  52. package/src/edit-buffer.ts +411 -0
  53. package/src/editor-view.test.ts +1032 -0
  54. package/src/editor-view.ts +284 -0
  55. package/src/examples/ascii-font-selection-demo.ts +245 -0
  56. package/src/examples/assets/Water_2_M_Normal.jpg +0 -0
  57. package/src/examples/assets/concrete.png +0 -0
  58. package/src/examples/assets/crate.png +0 -0
  59. package/src/examples/assets/crate_emissive.png +0 -0
  60. package/src/examples/assets/forrest_background.png +0 -0
  61. package/src/examples/assets/hast-example.json +1018 -0
  62. package/src/examples/assets/heart.png +0 -0
  63. package/src/examples/assets/main_char_heavy_attack.png +0 -0
  64. package/src/examples/assets/main_char_idle.png +0 -0
  65. package/src/examples/assets/main_char_jump_end.png +0 -0
  66. package/src/examples/assets/main_char_jump_landing.png +0 -0
  67. package/src/examples/assets/main_char_jump_start.png +0 -0
  68. package/src/examples/assets/main_char_run_loop.png +0 -0
  69. package/src/examples/assets/roughness_map.jpg +0 -0
  70. package/src/examples/build.ts +115 -0
  71. package/src/examples/code-demo.ts +924 -0
  72. package/src/examples/console-demo.ts +358 -0
  73. package/src/examples/core-plugin-slots-demo.ts +759 -0
  74. package/src/examples/diff-demo.ts +701 -0
  75. package/src/examples/draggable-three-demo.ts +259 -0
  76. package/src/examples/editor-demo.ts +322 -0
  77. package/src/examples/extmarks-demo.ts +196 -0
  78. package/src/examples/focus-restore-demo.ts +310 -0
  79. package/src/examples/fonts.ts +245 -0
  80. package/src/examples/fractal-shader-demo.ts +268 -0
  81. package/src/examples/framebuffer-demo.ts +674 -0
  82. package/src/examples/full-unicode-demo.ts +241 -0
  83. package/src/examples/golden-star-demo.ts +933 -0
  84. package/src/examples/grayscale-buffer-demo.ts +249 -0
  85. package/src/examples/hast-syntax-highlighting-demo.ts +129 -0
  86. package/src/examples/index.ts +926 -0
  87. package/src/examples/input-demo.ts +377 -0
  88. package/src/examples/input-select-layout-demo.ts +425 -0
  89. package/src/examples/install.sh +143 -0
  90. package/src/examples/keypress-debug-demo.ts +452 -0
  91. package/src/examples/lib/HexList.ts +122 -0
  92. package/src/examples/lib/PaletteGrid.ts +125 -0
  93. package/src/examples/lib/standalone-keys.ts +25 -0
  94. package/src/examples/lib/tab-controller.ts +243 -0
  95. package/src/examples/lights-phong-demo.ts +290 -0
  96. package/src/examples/link-demo.ts +220 -0
  97. package/src/examples/live-state-demo.ts +480 -0
  98. package/src/examples/markdown-demo.ts +725 -0
  99. package/src/examples/mouse-interaction-demo.ts +428 -0
  100. package/src/examples/nested-zindex-demo.ts +357 -0
  101. package/src/examples/opacity-example.ts +235 -0
  102. package/src/examples/opentui-demo.ts +1057 -0
  103. package/src/examples/physx-planck-2d-demo.ts +623 -0
  104. package/src/examples/physx-rapier-2d-demo.ts +655 -0
  105. package/src/examples/relative-positioning-demo.ts +323 -0
  106. package/src/examples/scroll-example.ts +214 -0
  107. package/src/examples/scrollbox-mouse-test.ts +112 -0
  108. package/src/examples/scrollbox-overlay-hit-test.ts +206 -0
  109. package/src/examples/select-demo.ts +237 -0
  110. package/src/examples/shader-cube-demo.ts +1015 -0
  111. package/src/examples/simple-layout-example.ts +591 -0
  112. package/src/examples/slider-demo.ts +617 -0
  113. package/src/examples/split-mode-demo.ts +453 -0
  114. package/src/examples/sprite-animation-demo.ts +443 -0
  115. package/src/examples/sprite-particle-generator-demo.ts +486 -0
  116. package/src/examples/static-sprite-demo.ts +193 -0
  117. package/src/examples/sticky-scroll-example.ts +308 -0
  118. package/src/examples/styled-text-demo.ts +282 -0
  119. package/src/examples/tab-select-demo.ts +219 -0
  120. package/src/examples/terminal-title.ts +29 -0
  121. package/src/examples/terminal.ts +305 -0
  122. package/src/examples/text-node-demo.ts +416 -0
  123. package/src/examples/text-selection-demo.ts +377 -0
  124. package/src/examples/text-table-demo.ts +503 -0
  125. package/src/examples/text-truncation-demo.ts +481 -0
  126. package/src/examples/text-wrap.ts +757 -0
  127. package/src/examples/texture-loading-demo.ts +259 -0
  128. package/src/examples/timeline-example.ts +670 -0
  129. package/src/examples/transparency-demo.ts +400 -0
  130. package/src/examples/vnode-composition-demo.ts +404 -0
  131. package/src/examples/wide-grapheme-overlay-demo.ts +280 -0
  132. package/src/index.ts +24 -0
  133. package/src/lib/KeyHandler.integration.test.ts +292 -0
  134. package/src/lib/KeyHandler.stopPropagation.test.ts +289 -0
  135. package/src/lib/KeyHandler.test.ts +662 -0
  136. package/src/lib/KeyHandler.ts +222 -0
  137. package/src/lib/RGBA.test.ts +984 -0
  138. package/src/lib/RGBA.ts +204 -0
  139. package/src/lib/ascii.font.ts +330 -0
  140. package/src/lib/border.test.ts +83 -0
  141. package/src/lib/border.ts +170 -0
  142. package/src/lib/bunfs.test.ts +27 -0
  143. package/src/lib/bunfs.ts +18 -0
  144. package/src/lib/clipboard.test.ts +41 -0
  145. package/src/lib/clipboard.ts +47 -0
  146. package/src/lib/clock.ts +35 -0
  147. package/src/lib/data-paths.test.ts +133 -0
  148. package/src/lib/data-paths.ts +109 -0
  149. package/src/lib/debounce.ts +106 -0
  150. package/src/lib/detect-links.test.ts +98 -0
  151. package/src/lib/detect-links.ts +56 -0
  152. package/src/lib/env.test.ts +228 -0
  153. package/src/lib/env.ts +209 -0
  154. package/src/lib/extmarks-history.ts +51 -0
  155. package/src/lib/extmarks-multiwidth.test.ts +322 -0
  156. package/src/lib/extmarks.test.ts +3457 -0
  157. package/src/lib/extmarks.ts +843 -0
  158. package/src/lib/fonts/block.json +405 -0
  159. package/src/lib/fonts/grid.json +265 -0
  160. package/src/lib/fonts/huge.json +741 -0
  161. package/src/lib/fonts/pallet.json +314 -0
  162. package/src/lib/fonts/shade.json +591 -0
  163. package/src/lib/fonts/slick.json +321 -0
  164. package/src/lib/fonts/tiny.json +69 -0
  165. package/src/lib/hast-styled-text.ts +59 -0
  166. package/src/lib/index.ts +21 -0
  167. package/src/lib/keymapping.test.ts +317 -0
  168. package/src/lib/keymapping.ts +115 -0
  169. package/src/lib/objects-in-viewport.test.ts +787 -0
  170. package/src/lib/objects-in-viewport.ts +153 -0
  171. package/src/lib/output.capture.ts +58 -0
  172. package/src/lib/parse.keypress-kitty.protocol.test.ts +340 -0
  173. package/src/lib/parse.keypress-kitty.test.ts +663 -0
  174. package/src/lib/parse.keypress-kitty.ts +439 -0
  175. package/src/lib/parse.keypress.test.ts +1849 -0
  176. package/src/lib/parse.keypress.ts +397 -0
  177. package/src/lib/parse.mouse.test.ts +552 -0
  178. package/src/lib/parse.mouse.ts +232 -0
  179. package/src/lib/paste.ts +16 -0
  180. package/src/lib/queue.ts +65 -0
  181. package/src/lib/renderable.validations.test.ts +87 -0
  182. package/src/lib/renderable.validations.ts +83 -0
  183. package/src/lib/scroll-acceleration.ts +98 -0
  184. package/src/lib/selection.ts +240 -0
  185. package/src/lib/singleton.ts +28 -0
  186. package/src/lib/stdin-parser.test.ts +2290 -0
  187. package/src/lib/stdin-parser.ts +1810 -0
  188. package/src/lib/styled-text.ts +178 -0
  189. package/src/lib/terminal-capability-detection.test.ts +202 -0
  190. package/src/lib/terminal-capability-detection.ts +79 -0
  191. package/src/lib/terminal-palette.test.ts +878 -0
  192. package/src/lib/terminal-palette.ts +383 -0
  193. package/src/lib/tree-sitter/assets/README.md +118 -0
  194. package/src/lib/tree-sitter/assets/update.ts +334 -0
  195. package/src/lib/tree-sitter/assets.d.ts +9 -0
  196. package/src/lib/tree-sitter/cache.test.ts +273 -0
  197. package/src/lib/tree-sitter/client.test.ts +1165 -0
  198. package/src/lib/tree-sitter/client.ts +607 -0
  199. package/src/lib/tree-sitter/default-parsers.ts +86 -0
  200. package/src/lib/tree-sitter/download-utils.ts +148 -0
  201. package/src/lib/tree-sitter/index.ts +28 -0
  202. package/src/lib/tree-sitter/parser.worker.ts +1042 -0
  203. package/src/lib/tree-sitter/parsers-config.ts +81 -0
  204. package/src/lib/tree-sitter/resolve-ft.test.ts +55 -0
  205. package/src/lib/tree-sitter/resolve-ft.ts +189 -0
  206. package/src/lib/tree-sitter/types.ts +82 -0
  207. package/src/lib/tree-sitter-styled-text.test.ts +1253 -0
  208. package/src/lib/tree-sitter-styled-text.ts +306 -0
  209. package/src/lib/validate-dir-name.ts +55 -0
  210. package/src/lib/yoga.options.test.ts +628 -0
  211. package/src/lib/yoga.options.ts +346 -0
  212. package/src/plugins/core-slot.ts +579 -0
  213. package/src/plugins/registry.ts +402 -0
  214. package/src/plugins/types.ts +46 -0
  215. package/src/post/effects.ts +930 -0
  216. package/src/post/filters.ts +489 -0
  217. package/src/post/matrices.ts +288 -0
  218. package/src/renderables/ASCIIFont.ts +219 -0
  219. package/src/renderables/Box.test.ts +205 -0
  220. package/src/renderables/Box.ts +326 -0
  221. package/src/renderables/Code.test.ts +2062 -0
  222. package/src/renderables/Code.ts +357 -0
  223. package/src/renderables/Diff.regression.test.ts +226 -0
  224. package/src/renderables/Diff.test.ts +3101 -0
  225. package/src/renderables/Diff.ts +1211 -0
  226. package/src/renderables/EditBufferRenderable.test.ts +288 -0
  227. package/src/renderables/EditBufferRenderable.ts +1166 -0
  228. package/src/renderables/FrameBuffer.ts +47 -0
  229. package/src/renderables/Input.test.ts +1228 -0
  230. package/src/renderables/Input.ts +247 -0
  231. package/src/renderables/LineNumberRenderable.ts +724 -0
  232. package/src/renderables/Markdown.ts +1393 -0
  233. package/src/renderables/ScrollBar.ts +422 -0
  234. package/src/renderables/ScrollBox.ts +883 -0
  235. package/src/renderables/Select.test.ts +1033 -0
  236. package/src/renderables/Select.ts +524 -0
  237. package/src/renderables/Slider.test.ts +456 -0
  238. package/src/renderables/Slider.ts +342 -0
  239. package/src/renderables/TabSelect.test.ts +197 -0
  240. package/src/renderables/TabSelect.ts +455 -0
  241. package/src/renderables/Text.selection-buffer.test.ts +123 -0
  242. package/src/renderables/Text.test.ts +2660 -0
  243. package/src/renderables/Text.ts +147 -0
  244. package/src/renderables/TextBufferRenderable.ts +518 -0
  245. package/src/renderables/TextNode.test.ts +1058 -0
  246. package/src/renderables/TextNode.ts +325 -0
  247. package/src/renderables/TextTable.test.ts +1421 -0
  248. package/src/renderables/TextTable.ts +1344 -0
  249. package/src/renderables/Textarea.ts +430 -0
  250. package/src/renderables/TimeToFirstDraw.ts +89 -0
  251. package/src/renderables/__snapshots__/Code.test.ts.snap +13 -0
  252. package/src/renderables/__snapshots__/Diff.test.ts.snap +785 -0
  253. package/src/renderables/__snapshots__/Text.test.ts.snap +421 -0
  254. package/src/renderables/__snapshots__/TextTable.test.ts.snap +215 -0
  255. package/src/renderables/__tests__/LineNumberRenderable.scrollbox-simple.test.ts +144 -0
  256. package/src/renderables/__tests__/LineNumberRenderable.scrollbox.test.ts +816 -0
  257. package/src/renderables/__tests__/LineNumberRenderable.test.ts +1865 -0
  258. package/src/renderables/__tests__/LineNumberRenderable.wrapping.test.ts +85 -0
  259. package/src/renderables/__tests__/Markdown.code-colors.test.ts +242 -0
  260. package/src/renderables/__tests__/Markdown.test.ts +2518 -0
  261. package/src/renderables/__tests__/MultiRenderable.selection.test.ts +87 -0
  262. package/src/renderables/__tests__/Textarea.buffer.test.ts +682 -0
  263. package/src/renderables/__tests__/Textarea.destroyed-events.test.ts +675 -0
  264. package/src/renderables/__tests__/Textarea.editing.test.ts +2041 -0
  265. package/src/renderables/__tests__/Textarea.error-handling.test.ts +35 -0
  266. package/src/renderables/__tests__/Textarea.events.test.ts +738 -0
  267. package/src/renderables/__tests__/Textarea.highlights.test.ts +590 -0
  268. package/src/renderables/__tests__/Textarea.keybinding.test.ts +3149 -0
  269. package/src/renderables/__tests__/Textarea.paste.test.ts +357 -0
  270. package/src/renderables/__tests__/Textarea.rendering.test.ts +1866 -0
  271. package/src/renderables/__tests__/Textarea.scroll.test.ts +733 -0
  272. package/src/renderables/__tests__/Textarea.selection.test.ts +1590 -0
  273. package/src/renderables/__tests__/Textarea.stress.test.ts +670 -0
  274. package/src/renderables/__tests__/Textarea.undo-redo.test.ts +383 -0
  275. package/src/renderables/__tests__/Textarea.visual-lines.test.ts +310 -0
  276. package/src/renderables/__tests__/__snapshots__/LineNumberRenderable.code.test.ts.snap +221 -0
  277. package/src/renderables/__tests__/__snapshots__/LineNumberRenderable.scrollbox-simple.test.ts.snap +89 -0
  278. package/src/renderables/__tests__/__snapshots__/LineNumberRenderable.scrollbox.test.ts.snap +457 -0
  279. package/src/renderables/__tests__/__snapshots__/LineNumberRenderable.test.ts.snap +158 -0
  280. package/src/renderables/__tests__/__snapshots__/Textarea.rendering.test.ts.snap +387 -0
  281. package/src/renderables/__tests__/markdown-parser.test.ts +217 -0
  282. package/src/renderables/__tests__/renderable-test-utils.ts +60 -0
  283. package/src/renderables/composition/README.md +8 -0
  284. package/src/renderables/composition/VRenderable.ts +32 -0
  285. package/src/renderables/composition/constructs.ts +127 -0
  286. package/src/renderables/composition/vnode.ts +289 -0
  287. package/src/renderables/index.ts +23 -0
  288. package/src/renderables/markdown-parser.ts +66 -0
  289. package/src/renderer.ts +2681 -0
  290. package/src/runtime-plugin-support.ts +39 -0
  291. package/src/runtime-plugin.ts +615 -0
  292. package/src/syntax-style.test.ts +841 -0
  293. package/src/syntax-style.ts +257 -0
  294. package/src/testing/README.md +210 -0
  295. package/src/testing/capture-spans.test.ts +194 -0
  296. package/src/testing/integration.test.ts +276 -0
  297. package/src/testing/manual-clock.ts +117 -0
  298. package/src/testing/mock-keys.test.ts +1378 -0
  299. package/src/testing/mock-keys.ts +457 -0
  300. package/src/testing/mock-mouse.test.ts +218 -0
  301. package/src/testing/mock-mouse.ts +247 -0
  302. package/src/testing/mock-tree-sitter-client.ts +73 -0
  303. package/src/testing/spy.ts +13 -0
  304. package/src/testing/test-recorder.test.ts +415 -0
  305. package/src/testing/test-recorder.ts +145 -0
  306. package/src/testing/test-renderer.ts +132 -0
  307. package/src/testing.ts +7 -0
  308. package/src/tests/__snapshots__/absolute-positioning.snapshot.test.ts.snap +481 -0
  309. package/src/tests/__snapshots__/renderable.snapshot.test.ts.snap +19 -0
  310. package/src/tests/__snapshots__/scrollbox.test.ts.snap +29 -0
  311. package/src/tests/absolute-positioning.snapshot.test.ts +638 -0
  312. package/src/tests/allocator-stats.test.ts +38 -0
  313. package/src/tests/destroy-during-render.test.ts +200 -0
  314. package/src/tests/destroy-on-exit.fixture.ts +36 -0
  315. package/src/tests/destroy-on-exit.test.ts +41 -0
  316. package/src/tests/hover-cursor.test.ts +98 -0
  317. package/src/tests/native-span-feed-async.test.ts +173 -0
  318. package/src/tests/native-span-feed-close.test.ts +120 -0
  319. package/src/tests/native-span-feed-coverage.test.ts +227 -0
  320. package/src/tests/native-span-feed-edge-cases.test.ts +352 -0
  321. package/src/tests/native-span-feed-use-after-free.test.ts +45 -0
  322. package/src/tests/opacity.test.ts +123 -0
  323. package/src/tests/renderable.snapshot.test.ts +524 -0
  324. package/src/tests/renderable.test.ts +1281 -0
  325. package/src/tests/renderer.clock.test.ts +158 -0
  326. package/src/tests/renderer.console-startup.test.ts +185 -0
  327. package/src/tests/renderer.control.test.ts +425 -0
  328. package/src/tests/renderer.core-slot-binding.test.ts +952 -0
  329. package/src/tests/renderer.cursor.test.ts +26 -0
  330. package/src/tests/renderer.destroy-during-render.test.ts +147 -0
  331. package/src/tests/renderer.focus-restore.test.ts +257 -0
  332. package/src/tests/renderer.focus.test.ts +294 -0
  333. package/src/tests/renderer.idle.test.ts +219 -0
  334. package/src/tests/renderer.input.test.ts +2237 -0
  335. package/src/tests/renderer.kitty-flags.test.ts +195 -0
  336. package/src/tests/renderer.mouse.test.ts +1274 -0
  337. package/src/tests/renderer.palette.test.ts +629 -0
  338. package/src/tests/renderer.selection.test.ts +49 -0
  339. package/src/tests/renderer.slot-registry.test.ts +684 -0
  340. package/src/tests/renderer.useMouse.test.ts +47 -0
  341. package/src/tests/runtime-plugin-node-modules-cycle.fixture.ts +76 -0
  342. package/src/tests/runtime-plugin-node-modules-mjs.fixture.ts +43 -0
  343. package/src/tests/runtime-plugin-node-modules-no-bare-rewrite.fixture.ts +67 -0
  344. package/src/tests/runtime-plugin-node-modules-package-type-cache.fixture.ts +72 -0
  345. package/src/tests/runtime-plugin-node-modules-runtime-specifier.fixture.ts +44 -0
  346. package/src/tests/runtime-plugin-node-modules-scoped-package-bare-rewrite.fixture.ts +85 -0
  347. package/src/tests/runtime-plugin-path-alias.fixture.ts +43 -0
  348. package/src/tests/runtime-plugin-resolve-roots.fixture.ts +65 -0
  349. package/src/tests/runtime-plugin-support.fixture.ts +11 -0
  350. package/src/tests/runtime-plugin-support.test.ts +19 -0
  351. package/src/tests/runtime-plugin-windows-file-url.fixture.ts +30 -0
  352. package/src/tests/runtime-plugin.fixture.ts +40 -0
  353. package/src/tests/runtime-plugin.test.ts +354 -0
  354. package/src/tests/scrollbox-culling-bug.test.ts +114 -0
  355. package/src/tests/scrollbox-hitgrid-resize.test.ts +136 -0
  356. package/src/tests/scrollbox-hitgrid.test.ts +909 -0
  357. package/src/tests/scrollbox.test.ts +1530 -0
  358. package/src/tests/wrap-resize-perf.test.ts +276 -0
  359. package/src/tests/yoga-setters.test.ts +921 -0
  360. package/src/text-buffer-view.test.ts +705 -0
  361. package/src/text-buffer-view.ts +189 -0
  362. package/src/text-buffer.test.ts +347 -0
  363. package/src/text-buffer.ts +250 -0
  364. package/src/types.ts +161 -0
  365. package/src/utils.ts +88 -0
  366. package/src/zig/ansi.zig +268 -0
  367. package/src/zig/bench/README.md +50 -0
  368. package/src/zig/bench/buffer-draw-text-buffer_bench.zig +887 -0
  369. package/src/zig/bench/edit-buffer_bench.zig +476 -0
  370. package/src/zig/bench/native-span-feed_bench.zig +100 -0
  371. package/src/zig/bench/rope-markers_bench.zig +713 -0
  372. package/src/zig/bench/rope_bench.zig +514 -0
  373. package/src/zig/bench/styled-text_bench.zig +470 -0
  374. package/src/zig/bench/text-buffer-coords_bench.zig +362 -0
  375. package/src/zig/bench/text-buffer-view_bench.zig +459 -0
  376. package/src/zig/bench/text-chunk-graphemes_bench.zig +273 -0
  377. package/src/zig/bench/utf8_bench.zig +799 -0
  378. package/src/zig/bench-utils.zig +431 -0
  379. package/src/zig/bench.zig +217 -0
  380. package/src/zig/buffer-methods.zig +211 -0
  381. package/src/zig/buffer.zig +2281 -0
  382. package/src/zig/build.zig +289 -0
  383. package/src/zig/build.zig.zon +16 -0
  384. package/src/zig/edit-buffer.zig +825 -0
  385. package/src/zig/editor-view.zig +802 -0
  386. package/src/zig/event-bus.zig +13 -0
  387. package/src/zig/event-emitter.zig +65 -0
  388. package/src/zig/file-logger.zig +92 -0
  389. package/src/zig/grapheme.zig +599 -0
  390. package/src/zig/lib.zig +1854 -0
  391. package/src/zig/link.zig +333 -0
  392. package/src/zig/logger.zig +43 -0
  393. package/src/zig/mem-registry.zig +125 -0
  394. package/src/zig/native-span-feed-bench-lib.zig +7 -0
  395. package/src/zig/native-span-feed.zig +708 -0
  396. package/src/zig/renderer.zig +1393 -0
  397. package/src/zig/rope.zig +1220 -0
  398. package/src/zig/syntax-style.zig +161 -0
  399. package/src/zig/terminal.zig +987 -0
  400. package/src/zig/test.zig +72 -0
  401. package/src/zig/tests/README.md +18 -0
  402. package/src/zig/tests/buffer-methods_test.zig +1109 -0
  403. package/src/zig/tests/buffer_test.zig +2557 -0
  404. package/src/zig/tests/edit-buffer-history_test.zig +271 -0
  405. package/src/zig/tests/edit-buffer_test.zig +1689 -0
  406. package/src/zig/tests/editor-view_test.zig +3299 -0
  407. package/src/zig/tests/event-emitter_test.zig +249 -0
  408. package/src/zig/tests/grapheme_test.zig +1304 -0
  409. package/src/zig/tests/link_test.zig +190 -0
  410. package/src/zig/tests/mem-registry_test.zig +473 -0
  411. package/src/zig/tests/memory_leak_regression_test.zig +159 -0
  412. package/src/zig/tests/native-span-feed_test.zig +1264 -0
  413. package/src/zig/tests/renderer_test.zig +1017 -0
  414. package/src/zig/tests/rope-nested_test.zig +712 -0
  415. package/src/zig/tests/rope_fuzz_test.zig +238 -0
  416. package/src/zig/tests/rope_test.zig +2362 -0
  417. package/src/zig/tests/segment-merge.test.zig +148 -0
  418. package/src/zig/tests/syntax-style_test.zig +557 -0
  419. package/src/zig/tests/terminal_test.zig +754 -0
  420. package/src/zig/tests/text-buffer-drawing_test.zig +3237 -0
  421. package/src/zig/tests/text-buffer-highlights_test.zig +666 -0
  422. package/src/zig/tests/text-buffer-iterators_test.zig +776 -0
  423. package/src/zig/tests/text-buffer-segment_test.zig +320 -0
  424. package/src/zig/tests/text-buffer-selection_test.zig +1035 -0
  425. package/src/zig/tests/text-buffer-selection_viewport_test.zig +358 -0
  426. package/src/zig/tests/text-buffer-view_test.zig +3649 -0
  427. package/src/zig/tests/text-buffer_test.zig +2191 -0
  428. package/src/zig/tests/unicode-width-map.zon +3909 -0
  429. package/src/zig/tests/utf8_no_zwj_test.zig +260 -0
  430. package/src/zig/tests/utf8_test.zig +4057 -0
  431. package/src/zig/tests/utf8_wcwidth_cursor_test.zig +267 -0
  432. package/src/zig/tests/utf8_wcwidth_test.zig +357 -0
  433. package/src/zig/tests/word-wrap-editing_test.zig +498 -0
  434. package/src/zig/tests/wrap-cache-perf_test.zig +113 -0
  435. package/src/zig/text-buffer-iterators.zig +499 -0
  436. package/src/zig/text-buffer-segment.zig +404 -0
  437. package/src/zig/text-buffer-view.zig +1371 -0
  438. package/src/zig/text-buffer.zig +1180 -0
  439. package/src/zig/utf8.zig +1948 -0
  440. package/src/zig/utils.zig +9 -0
  441. package/src/zig-structs.ts +261 -0
  442. package/src/zig.ts +3884 -0
  443. package/tsconfig.build.json +24 -0
  444. package/tsconfig.json +27 -0
  445. package/3d/SpriteResourceManager.d.ts +0 -74
  446. package/3d/SpriteUtils.d.ts +0 -13
  447. package/3d/TextureUtils.d.ts +0 -24
  448. package/3d/ThreeRenderable.d.ts +0 -40
  449. package/3d/WGPURenderer.d.ts +0 -61
  450. package/3d/animation/ExplodingSpriteEffect.d.ts +0 -71
  451. package/3d/animation/PhysicsExplodingSpriteEffect.d.ts +0 -76
  452. package/3d/animation/SpriteAnimator.d.ts +0 -124
  453. package/3d/animation/SpriteParticleGenerator.d.ts +0 -62
  454. package/3d/canvas.d.ts +0 -44
  455. package/3d/index.d.ts +0 -12
  456. package/3d/physics/PlanckPhysicsAdapter.d.ts +0 -19
  457. package/3d/physics/RapierPhysicsAdapter.d.ts +0 -19
  458. package/3d/physics/physics-interface.d.ts +0 -27
  459. package/3d.d.ts +0 -2
  460. package/3d.js +0 -34041
  461. package/3d.js.map +0 -155
  462. package/LICENSE +0 -21
  463. package/NativeSpanFeed.d.ts +0 -41
  464. package/Renderable.d.ts +0 -334
  465. package/animation/Timeline.d.ts +0 -126
  466. package/ansi.d.ts +0 -13
  467. package/buffer.d.ts +0 -111
  468. package/console.d.ts +0 -144
  469. package/edit-buffer.d.ts +0 -98
  470. package/editor-view.d.ts +0 -73
  471. package/index-8fks7yv1.js +0 -411
  472. package/index-8fks7yv1.js.map +0 -10
  473. package/index-egy5e2rs.js +0 -12267
  474. package/index-egy5e2rs.js.map +0 -42
  475. package/index-tse8gzh0.js +0 -20614
  476. package/index-tse8gzh0.js.map +0 -67
  477. package/index.d.ts +0 -23
  478. package/index.js +0 -478
  479. package/index.js.map +0 -9
  480. package/lib/KeyHandler.d.ts +0 -61
  481. package/lib/RGBA.d.ts +0 -25
  482. package/lib/ascii.font.d.ts +0 -508
  483. package/lib/border.d.ts +0 -51
  484. package/lib/bunfs.d.ts +0 -7
  485. package/lib/clipboard.d.ts +0 -17
  486. package/lib/clock.d.ts +0 -15
  487. package/lib/data-paths.d.ts +0 -26
  488. package/lib/debounce.d.ts +0 -42
  489. package/lib/detect-links.d.ts +0 -6
  490. package/lib/env.d.ts +0 -42
  491. package/lib/extmarks-history.d.ts +0 -17
  492. package/lib/extmarks.d.ts +0 -89
  493. package/lib/hast-styled-text.d.ts +0 -17
  494. package/lib/index.d.ts +0 -21
  495. package/lib/keymapping.d.ts +0 -25
  496. package/lib/objects-in-viewport.d.ts +0 -24
  497. package/lib/output.capture.d.ts +0 -24
  498. package/lib/parse.keypress-kitty.d.ts +0 -2
  499. package/lib/parse.keypress.d.ts +0 -26
  500. package/lib/parse.mouse.d.ts +0 -30
  501. package/lib/paste.d.ts +0 -7
  502. package/lib/queue.d.ts +0 -15
  503. package/lib/renderable.validations.d.ts +0 -12
  504. package/lib/scroll-acceleration.d.ts +0 -43
  505. package/lib/selection.d.ts +0 -63
  506. package/lib/singleton.d.ts +0 -7
  507. package/lib/stdin-parser.d.ts +0 -87
  508. package/lib/styled-text.d.ts +0 -63
  509. package/lib/terminal-capability-detection.d.ts +0 -30
  510. package/lib/terminal-palette.d.ts +0 -50
  511. package/lib/tree-sitter/assets/update.d.ts +0 -11
  512. package/lib/tree-sitter/client.d.ts +0 -47
  513. package/lib/tree-sitter/default-parsers.d.ts +0 -2
  514. package/lib/tree-sitter/download-utils.d.ts +0 -21
  515. package/lib/tree-sitter/index.d.ts +0 -8
  516. package/lib/tree-sitter/parser.worker.d.ts +0 -1
  517. package/lib/tree-sitter/parsers-config.d.ts +0 -53
  518. package/lib/tree-sitter/resolve-ft.d.ts +0 -5
  519. package/lib/tree-sitter/types.d.ts +0 -82
  520. package/lib/tree-sitter-styled-text.d.ts +0 -14
  521. package/lib/validate-dir-name.d.ts +0 -1
  522. package/lib/yoga.options.d.ts +0 -32
  523. package/parser.worker.js +0 -899
  524. package/parser.worker.js.map +0 -12
  525. package/plugins/core-slot.d.ts +0 -72
  526. package/plugins/registry.d.ts +0 -42
  527. package/plugins/types.d.ts +0 -34
  528. package/post/effects.d.ts +0 -147
  529. package/post/filters.d.ts +0 -65
  530. package/post/matrices.d.ts +0 -20
  531. package/renderables/ASCIIFont.d.ts +0 -52
  532. package/renderables/Box.d.ts +0 -81
  533. package/renderables/Code.d.ts +0 -78
  534. package/renderables/Diff.d.ts +0 -142
  535. package/renderables/EditBufferRenderable.d.ts +0 -237
  536. package/renderables/FrameBuffer.d.ts +0 -16
  537. package/renderables/Input.d.ts +0 -67
  538. package/renderables/LineNumberRenderable.d.ts +0 -78
  539. package/renderables/Markdown.d.ts +0 -185
  540. package/renderables/ScrollBar.d.ts +0 -77
  541. package/renderables/ScrollBox.d.ts +0 -124
  542. package/renderables/Select.d.ts +0 -115
  543. package/renderables/Slider.d.ts +0 -47
  544. package/renderables/TabSelect.d.ts +0 -96
  545. package/renderables/Text.d.ts +0 -36
  546. package/renderables/TextBufferRenderable.d.ts +0 -105
  547. package/renderables/TextNode.d.ts +0 -91
  548. package/renderables/TextTable.d.ts +0 -140
  549. package/renderables/Textarea.d.ts +0 -63
  550. package/renderables/TimeToFirstDraw.d.ts +0 -24
  551. package/renderables/__tests__/renderable-test-utils.d.ts +0 -12
  552. package/renderables/composition/VRenderable.d.ts +0 -16
  553. package/renderables/composition/constructs.d.ts +0 -35
  554. package/renderables/composition/vnode.d.ts +0 -46
  555. package/renderables/index.d.ts +0 -23
  556. package/renderables/markdown-parser.d.ts +0 -10
  557. package/renderer.d.ts +0 -419
  558. package/runtime-plugin-support.d.ts +0 -3
  559. package/runtime-plugin-support.js +0 -29
  560. package/runtime-plugin-support.js.map +0 -10
  561. package/runtime-plugin.d.ts +0 -16
  562. package/runtime-plugin.js +0 -16
  563. package/runtime-plugin.js.map +0 -9
  564. package/syntax-style.d.ts +0 -54
  565. package/testing/manual-clock.d.ts +0 -17
  566. package/testing/mock-keys.d.ts +0 -81
  567. package/testing/mock-mouse.d.ts +0 -38
  568. package/testing/mock-tree-sitter-client.d.ts +0 -23
  569. package/testing/spy.d.ts +0 -7
  570. package/testing/test-recorder.d.ts +0 -61
  571. package/testing/test-renderer.d.ts +0 -23
  572. package/testing.d.ts +0 -6
  573. package/testing.js +0 -697
  574. package/testing.js.map +0 -15
  575. package/text-buffer-view.d.ts +0 -42
  576. package/text-buffer.d.ts +0 -67
  577. package/types.d.ts +0 -139
  578. package/utils.d.ts +0 -14
  579. package/zig-structs.d.ts +0 -155
  580. package/zig.d.ts +0 -353
  581. /package/{assets → src/lib/tree-sitter/assets}/javascript/highlights.scm +0 -0
  582. /package/{assets → src/lib/tree-sitter/assets}/javascript/tree-sitter-javascript.wasm +0 -0
  583. /package/{assets → src/lib/tree-sitter/assets}/markdown/highlights.scm +0 -0
  584. /package/{assets → src/lib/tree-sitter/assets}/markdown/injections.scm +0 -0
  585. /package/{assets → src/lib/tree-sitter/assets}/markdown/tree-sitter-markdown.wasm +0 -0
  586. /package/{assets → src/lib/tree-sitter/assets}/markdown_inline/highlights.scm +0 -0
  587. /package/{assets → src/lib/tree-sitter/assets}/markdown_inline/tree-sitter-markdown_inline.wasm +0 -0
  588. /package/{assets → src/lib/tree-sitter/assets}/typescript/highlights.scm +0 -0
  589. /package/{assets → src/lib/tree-sitter/assets}/typescript/tree-sitter-typescript.wasm +0 -0
  590. /package/{assets → src/lib/tree-sitter/assets}/zig/highlights.scm +0 -0
  591. /package/{assets → src/lib/tree-sitter/assets}/zig/tree-sitter-zig.wasm +0 -0
@@ -0,0 +1,725 @@
1
+ import {
2
+ CliRenderer,
3
+ CliRenderEvents,
4
+ createCliRenderer,
5
+ BoxRenderable,
6
+ TextRenderable,
7
+ type ParsedKey,
8
+ ScrollBoxRenderable,
9
+ } from "../index.js"
10
+ import { parseColor } from "../lib/RGBA.js"
11
+ import { getTreeSitterClient } from "../lib/tree-sitter/index.js"
12
+ import { MarkdownRenderable } from "../renderables/Markdown.js"
13
+ import { SyntaxStyle } from "../syntax-style.js"
14
+ import { setupCommonDemoKeys } from "./lib/standalone-keys.js"
15
+
16
+ // Rich markdown example showcasing various features
17
+ const markdownContent = `# OpenTUI Markdown Demo
18
+
19
+ Welcome to the **MarkdownRenderable** showcase! This demonstrates automatic table alignment and syntax highlighting.
20
+
21
+ ## Features
22
+
23
+ - Automatic **table column alignment** based on content width
24
+ - Proper handling of \`inline code\`, **bold**, and *italic* in tables
25
+ - Multiple syntax themes to choose from
26
+ - Conceal mode hides formatting markers
27
+
28
+ ## Comparison Table
29
+
30
+ | Feature | Status | Priority | Notes |
31
+ |---|---|---|---|
32
+ | Table alignment | **Done** | High | Uses \`marked\` parser |
33
+ | Conceal mode | *Working* | Medium | Hides \`**\`, \`\`\`, etc. |
34
+ | Theme switching | **Done** | Low | Multiple themes available |
35
+ | Unicode support | 日本語 | High | CJK characters |
36
+
37
+ ## Code Examples
38
+
39
+ Here's how to use it:
40
+
41
+ \`\`\`typescript
42
+ import { MarkdownRenderable } from "@fairyhunter13/opentui-core"
43
+
44
+ const md = new MarkdownRenderable(renderer, {
45
+ content: "# Hello World",
46
+ syntaxStyle: mySyntaxStyle,
47
+ fg: "#24292F",
48
+ bg: "#FFFFFF",
49
+ conceal: true, // Hide formatting markers
50
+ })
51
+ \`\`\`
52
+
53
+ And a JSON configuration example:
54
+
55
+ \`\`\`json
56
+ {
57
+ "name": "opentui-markdown-demo",
58
+ "theme": "github",
59
+ "features": ["table-alignment", "syntax-highlighting", "conceal-mode"],
60
+ "streaming": {
61
+ "enabled": true,
62
+ "speed": "slowest"
63
+ }
64
+ }
65
+ \`\`\`
66
+
67
+ Here's a TSX component example:
68
+
69
+ \`\`\`tsx
70
+ import React from "react"
71
+ import { useState } from "react"
72
+
73
+ interface Props {
74
+ title: string
75
+ count: number
76
+ }
77
+
78
+ export const Counter: React.FC<Props> = ({ title, count: initialCount }) => {
79
+ const [count, setCount] = useState(initialCount)
80
+
81
+ return (
82
+ <div className="counter">
83
+ <h1>{title}</h1>
84
+ <p>Count: {count}</p>
85
+ <button onClick={() => setCount(c => c + 1)}>
86
+ Increment
87
+ </button>
88
+ </div>
89
+ )
90
+ }
91
+ \`\`\`
92
+
93
+ ## Light Theme Fallback Checks
94
+
95
+ Press \`T\` until **GitHub Light**. These fences intentionally skip syntax
96
+ highlighting and should still inherit the theme text color.
97
+
98
+ Unlabeled fenced block:
99
+
100
+ \`\`\`
101
+ this fence has no language tag
102
+ it should stay readable in GitHub Light
103
+ \`\`\`
104
+
105
+ Unsupported parser fallback:
106
+
107
+ \`\`\`toml
108
+ title = "GitHub Light"
109
+ status = "fallback text should stay readable"
110
+ \`\`\`
111
+
112
+ ### API Reference
113
+
114
+ | Method | Parameters | Returns | Description |
115
+ |---|---|---|---|
116
+ | \`constructor\` | \`ctx, options\` | \`MarkdownRenderable\` | Create new instance |
117
+ | \`clearCache\` | none | \`void\` | Force re-render content |
118
+
119
+ ## Inline Formatting Examples
120
+
121
+ | Style | Syntax | Rendered |
122
+ |---|---|---|
123
+ | Bold | \`**text**\` | **bold text** |
124
+ | Italic | \`*text*\` | *italic text* |
125
+ | Code | \`code\` | \`inline code\` |
126
+ | Link | \`[text](url)\` | [OpenTUI](https://github.com) |
127
+
128
+ ## Mixed Content
129
+
130
+ > **Note**: This blockquote contains **bold** and \`code\` formatting.
131
+ > It should render correctly with proper styling.
132
+
133
+ ### Emoji Support
134
+
135
+ | Emoji | Name | Category |
136
+ |---|---|---|
137
+ | 🚀 | Rocket | Transport |
138
+ | 🎨 | Palette | Art |
139
+ | ⚡ | Lightning | Nature |
140
+ | 🔥 | Fire | Nature |
141
+
142
+ ---
143
+
144
+ ## Alignment Examples
145
+
146
+ | Left | Center | Right |
147
+ |:---|:---:|---:|
148
+ | L1 | C1 | R1 |
149
+ | Left aligned | Centered text | Right aligned |
150
+ | Short | Medium length | Longer content here |
151
+
152
+ ## Performance
153
+
154
+ The table alignment uses:
155
+ 1. AST-based parsing with \`marked\`
156
+ 2. Caching for repeated content
157
+ 3. Smart width calculation accounting for concealed chars
158
+
159
+ ---
160
+
161
+ *Press \`?\` for keybindings*
162
+ `
163
+
164
+ // Theme definitions
165
+ const themes = {
166
+ githubLight: {
167
+ name: "GitHub Light",
168
+ bg: "#FFFFFF",
169
+ styles: {
170
+ keyword: { fg: parseColor("#CF222E"), bold: true },
171
+ string: { fg: parseColor("#0A3069") },
172
+ comment: { fg: parseColor("#6E7781"), italic: true },
173
+ number: { fg: parseColor("#0550AE") },
174
+ function: { fg: parseColor("#8250DF") },
175
+ type: { fg: parseColor("#953800") },
176
+ operator: { fg: parseColor("#CF222E") },
177
+ variable: { fg: parseColor("#24292F") },
178
+ property: { fg: parseColor("#0550AE") },
179
+ "punctuation.bracket": { fg: parseColor("#24292F") },
180
+ "punctuation.delimiter": { fg: parseColor("#57606A") },
181
+ "markup.heading": { fg: parseColor("#0550AE"), bold: true },
182
+ "markup.heading.1": { fg: parseColor("#1A7F37"), bold: true, underline: true },
183
+ "markup.heading.2": { fg: parseColor("#0550AE"), bold: true },
184
+ "markup.heading.3": { fg: parseColor("#8250DF") },
185
+ "markup.bold": { fg: parseColor("#24292F"), bold: true },
186
+ "markup.strong": { fg: parseColor("#24292F"), bold: true },
187
+ "markup.italic": { fg: parseColor("#24292F"), italic: true },
188
+ "markup.list": { fg: parseColor("#CF222E") },
189
+ "markup.quote": { fg: parseColor("#6E7781"), italic: true },
190
+ "markup.raw": { fg: parseColor("#24292F"), bg: parseColor("#F6F8FA") },
191
+ "markup.raw.block": { fg: parseColor("#24292F"), bg: parseColor("#F6F8FA") },
192
+ "markup.raw.inline": { fg: parseColor("#24292F"), bg: parseColor("#F6F8FA") },
193
+ "markup.link": { fg: parseColor("#0969DA"), underline: true },
194
+ "markup.link.label": { fg: parseColor("#0A3069"), underline: true },
195
+ "markup.link.url": { fg: parseColor("#0969DA"), underline: true },
196
+ label: { fg: parseColor("#1A7F37") },
197
+ conceal: { fg: parseColor("#6E7781") },
198
+ "punctuation.special": { fg: parseColor("#57606A") },
199
+ default: { fg: parseColor("#24292F") },
200
+ },
201
+ },
202
+ github: {
203
+ name: "GitHub Dark",
204
+ bg: "#0D1117",
205
+ styles: {
206
+ keyword: { fg: parseColor("#FF7B72"), bold: true },
207
+ string: { fg: parseColor("#A5D6FF") },
208
+ comment: { fg: parseColor("#8B949E"), italic: true },
209
+ number: { fg: parseColor("#79C0FF") },
210
+ function: { fg: parseColor("#D2A8FF") },
211
+ type: { fg: parseColor("#FFA657") },
212
+ operator: { fg: parseColor("#FF7B72") },
213
+ variable: { fg: parseColor("#E6EDF3") },
214
+ property: { fg: parseColor("#79C0FF") },
215
+ "punctuation.bracket": { fg: parseColor("#F0F6FC") },
216
+ "punctuation.delimiter": { fg: parseColor("#C9D1D9") },
217
+ "markup.heading": { fg: parseColor("#58A6FF"), bold: true },
218
+ "markup.heading.1": { fg: parseColor("#00FF88"), bold: true, underline: true },
219
+ "markup.heading.2": { fg: parseColor("#00D7FF"), bold: true },
220
+ "markup.heading.3": { fg: parseColor("#FF69B4") },
221
+ "markup.bold": { fg: parseColor("#F0F6FC"), bold: true },
222
+ "markup.strong": { fg: parseColor("#F0F6FC"), bold: true },
223
+ "markup.italic": { fg: parseColor("#F0F6FC"), italic: true },
224
+ "markup.list": { fg: parseColor("#FF7B72") },
225
+ "markup.quote": { fg: parseColor("#8B949E"), italic: true },
226
+ "markup.raw": { fg: parseColor("#A5D6FF"), bg: parseColor("#161B22") },
227
+ "markup.raw.block": { fg: parseColor("#A5D6FF"), bg: parseColor("#161B22") },
228
+ "markup.raw.inline": { fg: parseColor("#A5D6FF"), bg: parseColor("#161B22") },
229
+ "markup.link": { fg: parseColor("#58A6FF"), underline: true },
230
+ "markup.link.label": { fg: parseColor("#A5D6FF"), underline: true },
231
+ "markup.link.url": { fg: parseColor("#58A6FF"), underline: true },
232
+ label: { fg: parseColor("#7EE787") },
233
+ conceal: { fg: parseColor("#6E7681") },
234
+ "punctuation.special": { fg: parseColor("#8B949E") },
235
+ default: { fg: parseColor("#E6EDF3") },
236
+ },
237
+ },
238
+ monokai: {
239
+ name: "Monokai",
240
+ bg: "#272822",
241
+ styles: {
242
+ keyword: { fg: parseColor("#F92672"), bold: true },
243
+ string: { fg: parseColor("#E6DB74") },
244
+ comment: { fg: parseColor("#75715E"), italic: true },
245
+ number: { fg: parseColor("#AE81FF") },
246
+ function: { fg: parseColor("#A6E22E") },
247
+ type: { fg: parseColor("#66D9EF"), italic: true },
248
+ operator: { fg: parseColor("#F92672") },
249
+ variable: { fg: parseColor("#F8F8F2") },
250
+ property: { fg: parseColor("#A6E22E") },
251
+ "punctuation.bracket": { fg: parseColor("#F8F8F2") },
252
+ "punctuation.delimiter": { fg: parseColor("#F8F8F2") },
253
+ "markup.heading": { fg: parseColor("#A6E22E"), bold: true },
254
+ "markup.heading.1": { fg: parseColor("#F92672"), bold: true, underline: true },
255
+ "markup.heading.2": { fg: parseColor("#66D9EF"), bold: true },
256
+ "markup.heading.3": { fg: parseColor("#E6DB74") },
257
+ "markup.bold": { fg: parseColor("#F8F8F2"), bold: true },
258
+ "markup.strong": { fg: parseColor("#F8F8F2"), bold: true },
259
+ "markup.italic": { fg: parseColor("#F8F8F2"), italic: true },
260
+ "markup.list": { fg: parseColor("#F92672") },
261
+ "markup.quote": { fg: parseColor("#75715E"), italic: true },
262
+ "markup.raw": { fg: parseColor("#E6DB74"), bg: parseColor("#3E3D32") },
263
+ "markup.raw.block": { fg: parseColor("#E6DB74"), bg: parseColor("#3E3D32") },
264
+ "markup.raw.inline": { fg: parseColor("#E6DB74"), bg: parseColor("#3E3D32") },
265
+ "markup.link": { fg: parseColor("#66D9EF"), underline: true },
266
+ "markup.link.label": { fg: parseColor("#E6DB74"), underline: true },
267
+ "markup.link.url": { fg: parseColor("#66D9EF"), underline: true },
268
+ label: { fg: parseColor("#A6E22E") },
269
+ conceal: { fg: parseColor("#75715E") },
270
+ "punctuation.special": { fg: parseColor("#75715E") },
271
+ default: { fg: parseColor("#F8F8F2") },
272
+ },
273
+ },
274
+ nord: {
275
+ name: "Nord",
276
+ bg: "#2E3440",
277
+ styles: {
278
+ keyword: { fg: parseColor("#81A1C1"), bold: true },
279
+ string: { fg: parseColor("#A3BE8C") },
280
+ comment: { fg: parseColor("#616E88"), italic: true },
281
+ number: { fg: parseColor("#B48EAD") },
282
+ function: { fg: parseColor("#88C0D0") },
283
+ type: { fg: parseColor("#8FBCBB") },
284
+ operator: { fg: parseColor("#81A1C1") },
285
+ variable: { fg: parseColor("#D8DEE9") },
286
+ property: { fg: parseColor("#88C0D0") },
287
+ "punctuation.bracket": { fg: parseColor("#ECEFF4") },
288
+ "punctuation.delimiter": { fg: parseColor("#D8DEE9") },
289
+ "markup.heading": { fg: parseColor("#88C0D0"), bold: true },
290
+ "markup.heading.1": { fg: parseColor("#8FBCBB"), bold: true, underline: true },
291
+ "markup.heading.2": { fg: parseColor("#81A1C1"), bold: true },
292
+ "markup.heading.3": { fg: parseColor("#B48EAD") },
293
+ "markup.bold": { fg: parseColor("#ECEFF4"), bold: true },
294
+ "markup.strong": { fg: parseColor("#ECEFF4"), bold: true },
295
+ "markup.italic": { fg: parseColor("#ECEFF4"), italic: true },
296
+ "markup.list": { fg: parseColor("#81A1C1") },
297
+ "markup.quote": { fg: parseColor("#616E88"), italic: true },
298
+ "markup.raw": { fg: parseColor("#A3BE8C"), bg: parseColor("#3B4252") },
299
+ "markup.raw.block": { fg: parseColor("#A3BE8C"), bg: parseColor("#3B4252") },
300
+ "markup.raw.inline": { fg: parseColor("#A3BE8C"), bg: parseColor("#3B4252") },
301
+ "markup.link": { fg: parseColor("#88C0D0"), underline: true },
302
+ "markup.link.label": { fg: parseColor("#A3BE8C"), underline: true },
303
+ "markup.link.url": { fg: parseColor("#88C0D0"), underline: true },
304
+ label: { fg: parseColor("#A3BE8C") },
305
+ conceal: { fg: parseColor("#4C566A") },
306
+ "punctuation.special": { fg: parseColor("#616E88") },
307
+ default: { fg: parseColor("#D8DEE9") },
308
+ },
309
+ },
310
+ }
311
+
312
+ type ThemeKey = keyof typeof themes
313
+ const themeKeys = ["github", "githubLight", "monokai", "nord"] as const satisfies readonly ThemeKey[]
314
+
315
+ let renderer: CliRenderer | null = null
316
+ let keyboardHandler: ((key: ParsedKey) => void) | null = null
317
+ let parentContainer: BoxRenderable | null = null
318
+ let markdownScrollBox: ScrollBoxRenderable | null = null
319
+ let markdownDisplay: MarkdownRenderable | null = null
320
+ let statusText: TextRenderable | null = null
321
+ let syntaxStyle: SyntaxStyle | null = null
322
+ let helpModal: BoxRenderable | null = null
323
+ let currentThemeIndex = 0
324
+ let concealEnabled = true
325
+ let showingHelp = false
326
+ let streamingMode = false
327
+ let streamingTimer: Timer | null = null
328
+ let streamPosition = 0
329
+ let endlessMode = false
330
+ let rendererDestroyHandler: (() => void) | null = null
331
+
332
+ // Streaming speed presets: [minDelay, maxDelay] in milliseconds
333
+ const streamSpeeds = [
334
+ { name: "Slowest", min: 200, max: 500 }, // 0: Default
335
+ { name: "Slower", min: 150, max: 350 }, // 1
336
+ { name: "Slow", min: 100, max: 250 }, // 2
337
+ { name: "Medium", min: 70, max: 150 }, // 3
338
+ { name: "Fast", min: 40, max: 100 }, // 4
339
+ { name: "Faster", min: 20, max: 60 }, // 5
340
+ { name: "Fastest", min: 10, max: 50 }, // 6
341
+ ]
342
+ let currentSpeedIndex = 0
343
+
344
+ const JSON_PARSER_WASM_URL =
345
+ "https://github.com/tree-sitter/tree-sitter-json/releases/download/v0.24.8/tree-sitter-json.wasm"
346
+ const JSON_HIGHLIGHTS_QUERY_URL =
347
+ "https://raw.githubusercontent.com/nvim-treesitter/nvim-treesitter/refs/heads/master/queries/json/highlights.scm"
348
+
349
+ let jsonParserRegistered = false
350
+
351
+ function registerJsonParserForDemo(): void {
352
+ if (jsonParserRegistered) return
353
+
354
+ getTreeSitterClient().addFiletypeParser({
355
+ filetype: "json",
356
+ wasm: JSON_PARSER_WASM_URL,
357
+ queries: {
358
+ highlights: [JSON_HIGHLIGHTS_QUERY_URL],
359
+ },
360
+ })
361
+
362
+ jsonParserRegistered = true
363
+ }
364
+
365
+ function getCurrentTheme() {
366
+ return themes[themeKeys[currentThemeIndex]]
367
+ }
368
+
369
+ function getThemeTextColor(theme: (typeof themes)[ThemeKey]) {
370
+ return theme.styles.default.fg
371
+ }
372
+
373
+ function getThemeMutedTextColor(theme: (typeof themes)[ThemeKey]) {
374
+ return theme.styles.conceal.fg ?? theme.styles.default.fg
375
+ }
376
+
377
+ function getCurrentSpeed() {
378
+ return streamSpeeds[currentSpeedIndex]
379
+ }
380
+
381
+ function stopStreaming() {
382
+ if (streamingTimer) {
383
+ clearTimeout(streamingTimer)
384
+ streamingTimer = null
385
+ }
386
+ streamingMode = false
387
+ streamPosition = 0
388
+ }
389
+
390
+ function startStreaming() {
391
+ stopStreaming()
392
+ streamingMode = true
393
+ streamPosition = 0
394
+
395
+ if (!markdownDisplay || !markdownScrollBox) return
396
+
397
+ // Reset to empty and enable streaming mode
398
+ markdownDisplay.streaming = true
399
+ markdownDisplay.content = ""
400
+
401
+ // Enable sticky scroll to bottom for streaming
402
+ markdownScrollBox.stickyScroll = true
403
+
404
+ markdownScrollBox.stickyStart = "bottom"
405
+
406
+ // Update status
407
+ if (statusText) {
408
+ const theme = getCurrentTheme()
409
+ const speed = getCurrentSpeed()
410
+ const mode = endlessMode ? "ENDLESS" : "NORMAL"
411
+ statusText.content = `Theme: ${theme.name} | Conceal: ${concealEnabled ? "ON" : "OFF"} | Streaming: IN PROGRESS (${speed.name}, ${mode}) | Press X to stop`
412
+ }
413
+
414
+ function streamNextChunk() {
415
+ if (!streamingMode || !markdownDisplay || markdownDisplay.isDestroyed) return
416
+
417
+ // Random chunk size between 1 and 50 characters
418
+ const chunkSize = Math.floor(Math.random() * 50) + 1
419
+
420
+ // Calculate which iteration we're on and position within that iteration
421
+ const positionInCurrentIteration = streamPosition % markdownContent.length
422
+ const nextPositionInIteration = Math.min(positionInCurrentIteration + chunkSize, markdownContent.length)
423
+
424
+ // Build content by repeating the markdown as many times as needed
425
+ const fullIterations = Math.floor(streamPosition / markdownContent.length)
426
+ const currentIterationContent = markdownContent.slice(0, nextPositionInIteration)
427
+
428
+ // Construct full content: (full iterations of content) + (partial current iteration)
429
+ let fullContent = markdownContent.repeat(fullIterations) + currentIterationContent
430
+
431
+ markdownDisplay.content = fullContent
432
+ streamPosition += chunkSize
433
+
434
+ // In endless mode, never stop. In normal mode, stop after first iteration
435
+ const shouldContinue = endlessMode || streamPosition < markdownContent.length
436
+
437
+ if (shouldContinue) {
438
+ // Random delay based on current speed setting
439
+ const speed = getCurrentSpeed()
440
+ const delayRange = speed.max - speed.min
441
+ const delay = Math.floor(Math.random() * delayRange) + speed.min
442
+ streamingTimer = setTimeout(streamNextChunk, delay)
443
+ } else {
444
+ // Normal mode - streaming complete
445
+ streamingMode = false
446
+ if (statusText) {
447
+ const theme = getCurrentTheme()
448
+ const speed = getCurrentSpeed()
449
+ statusText.content = `Theme: ${theme.name} | Conceal: ${concealEnabled ? "ON" : "OFF"} | Streaming: COMPLETE (${speed.name}) | Press S to restart`
450
+ }
451
+ }
452
+ }
453
+
454
+ streamNextChunk()
455
+ }
456
+
457
+ export async function run(rendererInstance: CliRenderer): Promise<void> {
458
+ renderer = rendererInstance
459
+ showingHelp = false
460
+
461
+ rendererDestroyHandler = () => {
462
+ stopStreaming()
463
+ markdownDisplay = null
464
+ markdownScrollBox = null
465
+ statusText = null
466
+ parentContainer = null
467
+ helpModal = null
468
+ }
469
+ rendererInstance.on(CliRenderEvents.DESTROY, rendererDestroyHandler)
470
+
471
+ renderer.start()
472
+ registerJsonParserForDemo()
473
+
474
+ const theme = getCurrentTheme()
475
+ renderer.setBackgroundColor(theme.bg)
476
+
477
+ parentContainer = new BoxRenderable(renderer, {
478
+ id: "parent-container",
479
+ zIndex: 10,
480
+ padding: 1,
481
+ })
482
+ renderer.root.add(parentContainer)
483
+
484
+ const titleBox = new BoxRenderable(renderer, {
485
+ id: "title-box",
486
+ height: 3,
487
+ borderStyle: "double",
488
+ borderColor: "#4ECDC4",
489
+ backgroundColor: theme.bg,
490
+ title: "Markdown Demo - Table Alignment + Syntax Highlighting",
491
+ titleAlignment: "center",
492
+ border: true,
493
+ })
494
+ parentContainer.add(titleBox)
495
+
496
+ const instructionsText = new TextRenderable(renderer, {
497
+ id: "instructions",
498
+ content: "ESC to return | Press ? for keybindings",
499
+ fg: "#888888",
500
+ })
501
+ titleBox.add(instructionsText)
502
+
503
+ // Create help modal (hidden by default)
504
+ helpModal = new BoxRenderable(renderer, {
505
+ id: "help-modal",
506
+ position: "absolute",
507
+ left: "50%",
508
+ top: "50%",
509
+ width: 60,
510
+ height: 20,
511
+ marginLeft: -30,
512
+ marginTop: -10,
513
+ border: true,
514
+ borderStyle: "double",
515
+ borderColor: "#4ECDC4",
516
+ backgroundColor: theme.bg,
517
+ title: "Keybindings",
518
+ titleAlignment: "center",
519
+ padding: 2,
520
+ zIndex: 100,
521
+ visible: false,
522
+ })
523
+
524
+ const helpContent = new TextRenderable(renderer, {
525
+ id: "help-content",
526
+ content: `Theme:
527
+ T : Cycle through themes
528
+
529
+ View Controls:
530
+ C : Toggle concealment (hide **, \`, etc.)
531
+
532
+ Streaming:
533
+ S : Start/restart streaming simulation
534
+ E : Toggle endless mode (repeats content forever)
535
+ X : Stop streaming (when in endless mode)
536
+ [ : Decrease speed (slower)
537
+ ] : Increase speed (faster)
538
+
539
+ Other:
540
+ ? : Toggle this help screen
541
+ ESC : Return to main menu`,
542
+ fg: "#E6EDF3",
543
+ })
544
+
545
+ helpModal.add(helpContent)
546
+ renderer.root.add(helpModal)
547
+
548
+ markdownScrollBox = new ScrollBoxRenderable(renderer, {
549
+ id: "markdown-scroll-box",
550
+ borderStyle: "single",
551
+
552
+ borderColor: "#6BCF7F",
553
+ backgroundColor: theme.bg,
554
+ title: `MarkdownRenderable - ${theme.name}`,
555
+ titleAlignment: "left",
556
+ border: true,
557
+ scrollY: true,
558
+ scrollX: false,
559
+ flexGrow: 1,
560
+ flexShrink: 1,
561
+ padding: 2,
562
+ })
563
+ markdownScrollBox.focus()
564
+ parentContainer.add(markdownScrollBox)
565
+
566
+ // Create syntax style from current theme
567
+ syntaxStyle = SyntaxStyle.fromStyles(theme.styles)
568
+
569
+ // Create markdown display using MarkdownRenderable
570
+ markdownDisplay = new MarkdownRenderable(renderer, {
571
+ id: "markdown-display",
572
+ content: markdownContent,
573
+ syntaxStyle,
574
+ fg: getThemeTextColor(theme),
575
+ bg: theme.bg,
576
+ conceal: concealEnabled,
577
+ width: "100%",
578
+ })
579
+
580
+ markdownScrollBox.add(markdownDisplay)
581
+
582
+ statusText = new TextRenderable(renderer, {
583
+ id: "status-display",
584
+ content: "",
585
+ fg: "#A5D6FF",
586
+ wrapMode: "word",
587
+ flexShrink: 0,
588
+ })
589
+ parentContainer.add(statusText)
590
+
591
+ const applyTheme = (theme: (typeof themes)[ThemeKey]) => {
592
+ rendererInstance.setBackgroundColor(theme.bg)
593
+ syntaxStyle = SyntaxStyle.fromStyles(theme.styles)
594
+
595
+ titleBox.backgroundColor = theme.bg
596
+ instructionsText.fg = getThemeMutedTextColor(theme)
597
+ helpContent.fg = getThemeTextColor(theme)
598
+
599
+ if (markdownDisplay) {
600
+ markdownDisplay.syntaxStyle = syntaxStyle
601
+ markdownDisplay.fg = getThemeTextColor(theme)
602
+ markdownDisplay.bg = theme.bg
603
+ }
604
+
605
+ if (markdownScrollBox) {
606
+ markdownScrollBox.title = `MarkdownRenderable - ${theme.name}`
607
+ markdownScrollBox.backgroundColor = theme.bg
608
+ }
609
+
610
+ if (helpModal) {
611
+ helpModal.backgroundColor = theme.bg
612
+ }
613
+
614
+ if (statusText) {
615
+ statusText.fg = getThemeTextColor(theme)
616
+ }
617
+ }
618
+
619
+ const updateStatusText = () => {
620
+ if (statusText) {
621
+ const theme = getCurrentTheme()
622
+ const speed = getCurrentSpeed()
623
+ const streamStatus = streamingMode ? "STREAMING" : "NORMAL"
624
+ const endlessStatus = endlessMode ? " [ENDLESS]" : ""
625
+ statusText.content = `Theme: ${theme.name} | Conceal: ${concealEnabled ? "ON" : "OFF"} | Mode: ${streamStatus}${endlessStatus} | Speed: ${speed.name} | Press T/C/S/E/[/]`
626
+ }
627
+ }
628
+
629
+ applyTheme(theme)
630
+ updateStatusText()
631
+
632
+ keyboardHandler = (key: ParsedKey) => {
633
+ // Handle help modal toggle
634
+ if (key.raw === "?" && helpModal) {
635
+ showingHelp = !showingHelp
636
+ helpModal.visible = showingHelp
637
+ return
638
+ }
639
+
640
+ // Don't process other keys when help is showing
641
+ if (showingHelp) return
642
+
643
+ if (key.name === "s" && !key.ctrl && !key.meta) {
644
+ // Start/restart streaming simulation
645
+ startStreaming()
646
+ } else if (key.name === "e" && !key.ctrl && !key.meta) {
647
+ // Toggle endless mode
648
+ endlessMode = !endlessMode
649
+ updateStatusText()
650
+ } else if (key.name === "x" && !key.ctrl && !key.meta) {
651
+ // Stop streaming (for endless mode)
652
+ stopStreaming()
653
+ if (markdownDisplay) {
654
+ markdownDisplay.streaming = false
655
+ }
656
+ updateStatusText()
657
+ } else if (key.raw === "[" && !key.ctrl && !key.meta) {
658
+ // Decrease streaming speed (slower)
659
+ if (currentSpeedIndex > 0) {
660
+ currentSpeedIndex--
661
+ updateStatusText()
662
+ }
663
+ } else if (key.raw === "]" && !key.ctrl && !key.meta) {
664
+ // Increase streaming speed (faster)
665
+ if (currentSpeedIndex < streamSpeeds.length - 1) {
666
+ currentSpeedIndex++
667
+ updateStatusText()
668
+ }
669
+ } else if (key.name === "t" && !key.ctrl && !key.meta) {
670
+ // Cycle through themes
671
+ currentThemeIndex = (currentThemeIndex + 1) % themeKeys.length
672
+ applyTheme(getCurrentTheme())
673
+
674
+ updateStatusText()
675
+ } else if (key.name === "c" && !key.ctrl && !key.meta) {
676
+ // Stop streaming when toggling conceal
677
+ stopStreaming()
678
+
679
+ concealEnabled = !concealEnabled
680
+ if (markdownDisplay) {
681
+ markdownDisplay.conceal = concealEnabled
682
+ markdownDisplay.streaming = false
683
+ markdownDisplay.content = markdownContent
684
+ }
685
+ updateStatusText()
686
+ }
687
+ }
688
+
689
+ rendererInstance.keyInput.on("keypress", keyboardHandler)
690
+ }
691
+
692
+ export function destroy(rendererInstance: CliRenderer): void {
693
+ stopStreaming()
694
+
695
+ if (rendererDestroyHandler) {
696
+ rendererInstance.off(CliRenderEvents.DESTROY, rendererDestroyHandler)
697
+ rendererDestroyHandler = null
698
+ }
699
+
700
+ if (keyboardHandler) {
701
+ rendererInstance.keyInput.off("keypress", keyboardHandler)
702
+ keyboardHandler = null
703
+ }
704
+
705
+ parentContainer?.destroy()
706
+ helpModal?.destroy()
707
+ parentContainer = null
708
+ markdownScrollBox = null
709
+ markdownDisplay = null
710
+ statusText = null
711
+ syntaxStyle = null
712
+ helpModal = null
713
+ showingHelp = false
714
+
715
+ renderer = null
716
+ }
717
+
718
+ if (import.meta.main) {
719
+ const renderer = await createCliRenderer({
720
+ exitOnCtrlC: true,
721
+ targetFps: 60,
722
+ })
723
+ run(renderer)
724
+ setupCommonDemoKeys(renderer)
725
+ }