@fairyhunter13/opentui-core 0.1.89 → 0.1.90

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 (570) 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 +141 -0
  7. package/docs/env-vars.md +140 -0
  8. package/docs/getting-started.md +353 -0
  9. package/docs/renderables-vs-constructs.md +159 -0
  10. package/docs/tree-sitter.md +311 -0
  11. package/package.json +61 -52
  12. package/scripts/build.ts +400 -0
  13. package/scripts/publish.ts +60 -0
  14. package/src/3d/SpriteResourceManager.ts +286 -0
  15. package/src/3d/SpriteUtils.ts +71 -0
  16. package/src/3d/TextureUtils.ts +196 -0
  17. package/src/3d/ThreeRenderable.ts +197 -0
  18. package/src/3d/WGPURenderer.ts +294 -0
  19. package/src/3d/animation/ExplodingSpriteEffect.ts +513 -0
  20. package/src/3d/animation/PhysicsExplodingSpriteEffect.ts +429 -0
  21. package/src/3d/animation/SpriteAnimator.ts +633 -0
  22. package/src/3d/animation/SpriteParticleGenerator.ts +435 -0
  23. package/src/3d/canvas.ts +464 -0
  24. package/src/3d/index.ts +12 -0
  25. package/src/3d/physics/PlanckPhysicsAdapter.ts +72 -0
  26. package/src/3d/physics/RapierPhysicsAdapter.ts +66 -0
  27. package/src/3d/physics/physics-interface.ts +31 -0
  28. package/src/3d/shaders/supersampling.wgsl +201 -0
  29. package/src/3d.ts +3 -0
  30. package/src/NativeSpanFeed.ts +300 -0
  31. package/src/Renderable.ts +1698 -0
  32. package/src/__snapshots__/buffer.test.ts.snap +28 -0
  33. package/src/animation/Timeline.test.ts +2709 -0
  34. package/src/animation/Timeline.ts +598 -0
  35. package/src/ansi.ts +18 -0
  36. package/src/benchmark/latest-all-bench-run.json +707 -0
  37. package/src/benchmark/latest-async-bench-run.json +336 -0
  38. package/src/benchmark/latest-default-bench-run.json +657 -0
  39. package/src/benchmark/latest-large-bench-run.json +707 -0
  40. package/src/benchmark/latest-quick-bench-run.json +207 -0
  41. package/src/benchmark/markdown-benchmark.ts +1804 -0
  42. package/src/benchmark/native-span-feed-async-benchmark.ts +355 -0
  43. package/src/benchmark/native-span-feed-benchmark.md +56 -0
  44. package/src/benchmark/native-span-feed-benchmark.ts +596 -0
  45. package/src/benchmark/native-span-feed-compare.ts +280 -0
  46. package/src/benchmark/renderer-benchmark.ts +754 -0
  47. package/src/benchmark/text-table-benchmark.ts +947 -0
  48. package/src/buffer.test.ts +291 -0
  49. package/src/buffer.ts +519 -0
  50. package/src/console.test.ts +612 -0
  51. package/src/console.ts +1255 -0
  52. package/src/edit-buffer.test.ts +1769 -0
  53. package/src/edit-buffer.ts +411 -0
  54. package/src/editor-view.test.ts +1032 -0
  55. package/src/editor-view.ts +284 -0
  56. package/src/examples/ascii-font-selection-demo.ts +245 -0
  57. package/src/examples/assets/Water_2_M_Normal.jpg +0 -0
  58. package/src/examples/assets/concrete.png +0 -0
  59. package/src/examples/assets/crate.png +0 -0
  60. package/src/examples/assets/crate_emissive.png +0 -0
  61. package/src/examples/assets/forrest_background.png +0 -0
  62. package/src/examples/assets/hast-example.json +1018 -0
  63. package/src/examples/assets/heart.png +0 -0
  64. package/src/examples/assets/main_char_heavy_attack.png +0 -0
  65. package/src/examples/assets/main_char_idle.png +0 -0
  66. package/src/examples/assets/main_char_jump_end.png +0 -0
  67. package/src/examples/assets/main_char_jump_landing.png +0 -0
  68. package/src/examples/assets/main_char_jump_start.png +0 -0
  69. package/src/examples/assets/main_char_run_loop.png +0 -0
  70. package/src/examples/assets/roughness_map.jpg +0 -0
  71. package/src/examples/build.ts +115 -0
  72. package/src/examples/code-demo.ts +584 -0
  73. package/src/examples/console-demo.ts +358 -0
  74. package/src/examples/core-plugin-slots-demo.ts +759 -0
  75. package/src/examples/diff-demo.ts +699 -0
  76. package/src/examples/draggable-three-demo.ts +259 -0
  77. package/src/examples/editor-demo.ts +322 -0
  78. package/src/examples/extmarks-demo.ts +204 -0
  79. package/src/examples/focus-restore-demo.ts +310 -0
  80. package/src/examples/fonts.ts +245 -0
  81. package/src/examples/fractal-shader-demo.ts +268 -0
  82. package/src/examples/framebuffer-demo.ts +674 -0
  83. package/src/examples/full-unicode-demo.ts +181 -0
  84. package/src/examples/golden-star-demo.ts +933 -0
  85. package/src/examples/grayscale-buffer-demo.ts +249 -0
  86. package/src/examples/hast-syntax-highlighting-demo.ts +129 -0
  87. package/src/examples/index.ts +925 -0
  88. package/src/examples/input-demo.ts +377 -0
  89. package/src/examples/input-select-layout-demo.ts +425 -0
  90. package/src/examples/install.sh +143 -0
  91. package/src/examples/keypress-debug-demo.ts +452 -0
  92. package/src/examples/lib/HexList.ts +122 -0
  93. package/src/examples/lib/PaletteGrid.ts +125 -0
  94. package/src/examples/lib/standalone-keys.ts +25 -0
  95. package/src/examples/lib/tab-controller.ts +243 -0
  96. package/src/examples/lights-phong-demo.ts +290 -0
  97. package/src/examples/link-demo.ts +220 -0
  98. package/src/examples/live-state-demo.ts +480 -0
  99. package/src/examples/markdown-demo.ts +620 -0
  100. package/src/examples/mouse-interaction-demo.ts +428 -0
  101. package/src/examples/nested-zindex-demo.ts +357 -0
  102. package/src/examples/opacity-example.ts +235 -0
  103. package/src/examples/opentui-demo.ts +1057 -0
  104. package/src/examples/physx-planck-2d-demo.ts +507 -0
  105. package/src/examples/physx-rapier-2d-demo.ts +526 -0
  106. package/src/examples/relative-positioning-demo.ts +323 -0
  107. package/src/examples/scroll-example.ts +214 -0
  108. package/src/examples/scrollbox-mouse-test.ts +112 -0
  109. package/src/examples/scrollbox-overlay-hit-test.ts +206 -0
  110. package/src/examples/select-demo.ts +237 -0
  111. package/src/examples/shader-cube-demo.ts +772 -0
  112. package/src/examples/simple-layout-example.ts +591 -0
  113. package/src/examples/slider-demo.ts +617 -0
  114. package/src/examples/split-mode-demo.ts +445 -0
  115. package/src/examples/sprite-animation-demo.ts +443 -0
  116. package/src/examples/sprite-particle-generator-demo.ts +486 -0
  117. package/src/examples/static-sprite-demo.ts +193 -0
  118. package/src/examples/sticky-scroll-example.ts +308 -0
  119. package/src/examples/styled-text-demo.ts +282 -0
  120. package/src/examples/tab-select-demo.ts +219 -0
  121. package/src/examples/terminal-title.ts +29 -0
  122. package/src/examples/terminal.ts +305 -0
  123. package/src/examples/text-node-demo.ts +416 -0
  124. package/src/examples/text-selection-demo.ts +377 -0
  125. package/src/examples/text-table-demo.ts +503 -0
  126. package/src/examples/text-truncation-demo.ts +481 -0
  127. package/src/examples/text-wrap.ts +757 -0
  128. package/src/examples/texture-loading-demo.ts +259 -0
  129. package/src/examples/timeline-example.ts +670 -0
  130. package/src/examples/transparency-demo.ts +241 -0
  131. package/src/examples/vnode-composition-demo.ts +404 -0
  132. package/src/index.ts +22 -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 +168 -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 +31 -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 +280 -0
  168. package/src/lib/keymapping.ts +87 -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 +1676 -0
  187. package/src/lib/stdin-parser.ts +1248 -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 +331 -0
  195. package/src/lib/tree-sitter/assets.d.ts +9 -0
  196. package/src/lib/tree-sitter/cache.test.ts +270 -0
  197. package/src/lib/tree-sitter/client.test.ts +1061 -0
  198. package/src/lib/tree-sitter/client.ts +615 -0
  199. package/src/lib/tree-sitter/default-parsers.ts +80 -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 +1001 -0
  203. package/src/lib/tree-sitter/parsers-config.ts +75 -0
  204. package/src/lib/tree-sitter/resolve-ft.ts +62 -0
  205. package/src/lib/tree-sitter/types.ts +81 -0
  206. package/src/lib/tree-sitter-styled-text.test.ts +1253 -0
  207. package/src/lib/tree-sitter-styled-text.ts +306 -0
  208. package/src/lib/validate-dir-name.ts +55 -0
  209. package/src/lib/yoga.options.test.ts +628 -0
  210. package/src/lib/yoga.options.ts +346 -0
  211. package/src/plugins/core-slot.ts +579 -0
  212. package/src/plugins/registry.ts +377 -0
  213. package/src/plugins/types.ts +46 -0
  214. package/src/post/filters.ts +888 -0
  215. package/src/renderables/ASCIIFont.ts +219 -0
  216. package/src/renderables/Box.test.ts +160 -0
  217. package/src/renderables/Box.ts +295 -0
  218. package/src/renderables/Code.test.ts +2062 -0
  219. package/src/renderables/Code.ts +357 -0
  220. package/src/renderables/Diff.regression.test.ts +226 -0
  221. package/src/renderables/Diff.test.ts +3027 -0
  222. package/src/renderables/Diff.ts +1209 -0
  223. package/src/renderables/EditBufferRenderable.ts +764 -0
  224. package/src/renderables/FrameBuffer.ts +47 -0
  225. package/src/renderables/Input.test.ts +1228 -0
  226. package/src/renderables/Input.ts +245 -0
  227. package/src/renderables/LineNumberRenderable.ts +675 -0
  228. package/src/renderables/Markdown.ts +1106 -0
  229. package/src/renderables/ScrollBar.ts +422 -0
  230. package/src/renderables/ScrollBox.ts +883 -0
  231. package/src/renderables/Select.test.ts +1010 -0
  232. package/src/renderables/Select.ts +523 -0
  233. package/src/renderables/Slider.test.ts +456 -0
  234. package/src/renderables/Slider.ts +347 -0
  235. package/src/renderables/TabSelect.test.ts +197 -0
  236. package/src/renderables/TabSelect.ts +455 -0
  237. package/src/renderables/Text.selection-buffer.test.ts +123 -0
  238. package/src/renderables/Text.test.ts +2660 -0
  239. package/src/renderables/Text.ts +147 -0
  240. package/src/renderables/TextBufferRenderable.ts +518 -0
  241. package/src/renderables/TextNode.test.ts +1058 -0
  242. package/src/renderables/TextNode.ts +325 -0
  243. package/src/renderables/TextTable.test.ts +1421 -0
  244. package/src/renderables/TextTable.ts +1344 -0
  245. package/src/renderables/Textarea.ts +732 -0
  246. package/src/renderables/TimeToFirstDraw.ts +89 -0
  247. package/src/renderables/__snapshots__/Code.test.ts.snap +13 -0
  248. package/src/renderables/__snapshots__/Diff.test.ts.snap +785 -0
  249. package/src/renderables/__snapshots__/Text.test.ts.snap +421 -0
  250. package/src/renderables/__snapshots__/TextTable.test.ts.snap +215 -0
  251. package/src/renderables/__tests__/LineNumberRenderable.scrollbox-simple.test.ts +144 -0
  252. package/src/renderables/__tests__/LineNumberRenderable.scrollbox.test.ts +816 -0
  253. package/src/renderables/__tests__/LineNumberRenderable.test.ts +1787 -0
  254. package/src/renderables/__tests__/LineNumberRenderable.wrapping.test.ts +85 -0
  255. package/src/renderables/__tests__/Markdown.test.ts +2287 -0
  256. package/src/renderables/__tests__/MultiRenderable.selection.test.ts +87 -0
  257. package/src/renderables/__tests__/Textarea.buffer.test.ts +682 -0
  258. package/src/renderables/__tests__/Textarea.destroyed-events.test.ts +675 -0
  259. package/src/renderables/__tests__/Textarea.editing.test.ts +2041 -0
  260. package/src/renderables/__tests__/Textarea.error-handling.test.ts +35 -0
  261. package/src/renderables/__tests__/Textarea.events.test.ts +738 -0
  262. package/src/renderables/__tests__/Textarea.highlights.test.ts +590 -0
  263. package/src/renderables/__tests__/Textarea.keybinding.test.ts +3149 -0
  264. package/src/renderables/__tests__/Textarea.paste.test.ts +357 -0
  265. package/src/renderables/__tests__/Textarea.rendering.test.ts +1864 -0
  266. package/src/renderables/__tests__/Textarea.scroll.test.ts +733 -0
  267. package/src/renderables/__tests__/Textarea.selection.test.ts +1590 -0
  268. package/src/renderables/__tests__/Textarea.stress.test.ts +670 -0
  269. package/src/renderables/__tests__/Textarea.undo-redo.test.ts +383 -0
  270. package/src/renderables/__tests__/Textarea.visual-lines.test.ts +310 -0
  271. package/src/renderables/__tests__/__snapshots__/LineNumberRenderable.code.test.ts.snap +221 -0
  272. package/src/renderables/__tests__/__snapshots__/LineNumberRenderable.scrollbox-simple.test.ts.snap +89 -0
  273. package/src/renderables/__tests__/__snapshots__/LineNumberRenderable.scrollbox.test.ts.snap +457 -0
  274. package/src/renderables/__tests__/__snapshots__/LineNumberRenderable.test.ts.snap +158 -0
  275. package/src/renderables/__tests__/__snapshots__/Textarea.rendering.test.ts.snap +387 -0
  276. package/src/renderables/__tests__/markdown-parser.test.ts +217 -0
  277. package/src/renderables/__tests__/renderable-test-utils.ts +60 -0
  278. package/src/renderables/composition/README.md +8 -0
  279. package/src/renderables/composition/VRenderable.ts +32 -0
  280. package/src/renderables/composition/constructs.ts +127 -0
  281. package/src/renderables/composition/vnode.ts +289 -0
  282. package/src/renderables/index.ts +22 -0
  283. package/src/renderables/markdown-parser.ts +66 -0
  284. package/src/renderer.ts +2363 -0
  285. package/src/runtime-plugin-support.ts +39 -0
  286. package/src/runtime-plugin.ts +144 -0
  287. package/src/syntax-style.test.ts +841 -0
  288. package/src/syntax-style.ts +264 -0
  289. package/src/testing/README.md +210 -0
  290. package/src/testing/capture-spans.test.ts +194 -0
  291. package/src/testing/integration.test.ts +276 -0
  292. package/src/testing/manual-clock.ts +106 -0
  293. package/src/testing/mock-keys.test.ts +1356 -0
  294. package/src/testing/mock-keys.ts +449 -0
  295. package/src/testing/mock-mouse.test.ts +218 -0
  296. package/src/testing/mock-mouse.ts +247 -0
  297. package/src/testing/mock-tree-sitter-client.ts +73 -0
  298. package/src/testing/spy.ts +13 -0
  299. package/src/testing/test-recorder.test.ts +415 -0
  300. package/src/testing/test-recorder.ts +145 -0
  301. package/src/testing/test-renderer.ts +116 -0
  302. package/src/testing.ts +7 -0
  303. package/src/tests/__snapshots__/absolute-positioning.snapshot.test.ts.snap +481 -0
  304. package/src/tests/__snapshots__/renderable.snapshot.test.ts.snap +19 -0
  305. package/src/tests/__snapshots__/scrollbox.test.ts.snap +29 -0
  306. package/src/tests/absolute-positioning.snapshot.test.ts +638 -0
  307. package/src/tests/allocator-stats.test.ts +38 -0
  308. package/src/tests/destroy-during-render.test.ts +200 -0
  309. package/src/tests/hover-cursor.test.ts +98 -0
  310. package/src/tests/native-span-feed-async.test.ts +173 -0
  311. package/src/tests/native-span-feed-close.test.ts +120 -0
  312. package/src/tests/native-span-feed-coverage.test.ts +227 -0
  313. package/src/tests/native-span-feed-edge-cases.test.ts +352 -0
  314. package/src/tests/native-span-feed-use-after-free.test.ts +45 -0
  315. package/src/tests/opacity.test.ts +123 -0
  316. package/src/tests/renderable.snapshot.test.ts +524 -0
  317. package/src/tests/renderable.test.ts +1281 -0
  318. package/src/tests/renderer.console-startup.test.ts +65 -0
  319. package/src/tests/renderer.control.test.ts +364 -0
  320. package/src/tests/renderer.core-slot-binding.test.ts +952 -0
  321. package/src/tests/renderer.cursor.test.ts +26 -0
  322. package/src/tests/renderer.destroy-during-render.test.ts +110 -0
  323. package/src/tests/renderer.focus-restore.test.ts +228 -0
  324. package/src/tests/renderer.focus.test.ts +251 -0
  325. package/src/tests/renderer.idle.test.ts +219 -0
  326. package/src/tests/renderer.input.test.ts +2145 -0
  327. package/src/tests/renderer.kitty-flags.test.ts +195 -0
  328. package/src/tests/renderer.mouse.test.ts +1269 -0
  329. package/src/tests/renderer.palette.test.ts +629 -0
  330. package/src/tests/renderer.selection.test.ts +49 -0
  331. package/src/tests/renderer.slot-registry.test.ts +649 -0
  332. package/src/tests/renderer.useMouse.test.ts +50 -0
  333. package/src/tests/runtime-plugin-support.fixture.ts +11 -0
  334. package/src/tests/runtime-plugin-support.test.ts +28 -0
  335. package/src/tests/runtime-plugin.fixture.ts +40 -0
  336. package/src/tests/runtime-plugin.test.ts +190 -0
  337. package/src/tests/scrollbox-culling-bug.test.ts +114 -0
  338. package/src/tests/scrollbox-hitgrid-resize.test.ts +136 -0
  339. package/src/tests/scrollbox-hitgrid.test.ts +909 -0
  340. package/src/tests/scrollbox.test.ts +1530 -0
  341. package/src/tests/wrap-resize-perf.test.ts +229 -0
  342. package/src/tests/yoga-setters.test.ts +921 -0
  343. package/src/text-buffer-view.test.ts +705 -0
  344. package/src/text-buffer-view.ts +189 -0
  345. package/src/text-buffer.test.ts +347 -0
  346. package/src/text-buffer.ts +250 -0
  347. package/src/types.ts +152 -0
  348. package/src/utils.ts +88 -0
  349. package/src/zig/ansi.zig +268 -0
  350. package/src/zig/bench/README.md +50 -0
  351. package/src/zig/bench/buffer-draw-text-buffer_bench.zig +887 -0
  352. package/src/zig/bench/edit-buffer_bench.zig +476 -0
  353. package/src/zig/bench/native-span-feed_bench.zig +100 -0
  354. package/src/zig/bench/rope-markers_bench.zig +713 -0
  355. package/src/zig/bench/rope_bench.zig +514 -0
  356. package/src/zig/bench/styled-text_bench.zig +470 -0
  357. package/src/zig/bench/text-buffer-coords_bench.zig +362 -0
  358. package/src/zig/bench/text-buffer-view_bench.zig +459 -0
  359. package/src/zig/bench/text-chunk-graphemes_bench.zig +273 -0
  360. package/src/zig/bench/utf8_bench.zig +799 -0
  361. package/src/zig/bench-utils.zig +431 -0
  362. package/src/zig/bench.zig +217 -0
  363. package/src/zig/buffer.zig +2223 -0
  364. package/src/zig/build.zig +289 -0
  365. package/src/zig/build.zig.zon +16 -0
  366. package/src/zig/edit-buffer.zig +825 -0
  367. package/src/zig/editor-view.zig +802 -0
  368. package/src/zig/event-bus.zig +13 -0
  369. package/src/zig/event-emitter.zig +65 -0
  370. package/src/zig/file-logger.zig +92 -0
  371. package/src/zig/grapheme.zig +599 -0
  372. package/src/zig/lib.zig +1834 -0
  373. package/src/zig/link.zig +333 -0
  374. package/src/zig/logger.zig +43 -0
  375. package/src/zig/mem-registry.zig +125 -0
  376. package/src/zig/native-span-feed-bench-lib.zig +7 -0
  377. package/src/zig/native-span-feed.zig +708 -0
  378. package/src/zig/renderer.zig +1386 -0
  379. package/src/zig/rope.zig +1220 -0
  380. package/src/zig/syntax-style.zig +161 -0
  381. package/src/zig/terminal.zig +975 -0
  382. package/src/zig/test.zig +70 -0
  383. package/src/zig/tests/README.md +18 -0
  384. package/src/zig/tests/buffer_test.zig +2526 -0
  385. package/src/zig/tests/edit-buffer-history_test.zig +271 -0
  386. package/src/zig/tests/edit-buffer_test.zig +1689 -0
  387. package/src/zig/tests/editor-view_test.zig +3299 -0
  388. package/src/zig/tests/event-emitter_test.zig +249 -0
  389. package/src/zig/tests/grapheme_test.zig +1304 -0
  390. package/src/zig/tests/link_test.zig +190 -0
  391. package/src/zig/tests/mem-registry_test.zig +473 -0
  392. package/src/zig/tests/memory_leak_regression_test.zig +159 -0
  393. package/src/zig/tests/native-span-feed_test.zig +1264 -0
  394. package/src/zig/tests/renderer_test.zig +1010 -0
  395. package/src/zig/tests/rope-nested_test.zig +712 -0
  396. package/src/zig/tests/rope_fuzz_test.zig +238 -0
  397. package/src/zig/tests/rope_test.zig +2362 -0
  398. package/src/zig/tests/segment-merge.test.zig +148 -0
  399. package/src/zig/tests/syntax-style_test.zig +557 -0
  400. package/src/zig/tests/terminal_test.zig +719 -0
  401. package/src/zig/tests/text-buffer-drawing_test.zig +3237 -0
  402. package/src/zig/tests/text-buffer-highlights_test.zig +666 -0
  403. package/src/zig/tests/text-buffer-iterators_test.zig +776 -0
  404. package/src/zig/tests/text-buffer-segment_test.zig +320 -0
  405. package/src/zig/tests/text-buffer-selection_test.zig +1035 -0
  406. package/src/zig/tests/text-buffer-selection_viewport_test.zig +358 -0
  407. package/src/zig/tests/text-buffer-view_test.zig +3649 -0
  408. package/src/zig/tests/text-buffer_test.zig +2191 -0
  409. package/src/zig/tests/unicode-width-map.zon +3909 -0
  410. package/src/zig/tests/utf8_no_zwj_test.zig +260 -0
  411. package/src/zig/tests/utf8_test.zig +4057 -0
  412. package/src/zig/tests/utf8_wcwidth_cursor_test.zig +267 -0
  413. package/src/zig/tests/utf8_wcwidth_test.zig +357 -0
  414. package/src/zig/tests/word-wrap-editing_test.zig +498 -0
  415. package/src/zig/tests/wrap-cache-perf_test.zig +113 -0
  416. package/src/zig/text-buffer-iterators.zig +499 -0
  417. package/src/zig/text-buffer-segment.zig +404 -0
  418. package/src/zig/text-buffer-view.zig +1371 -0
  419. package/src/zig/text-buffer.zig +1180 -0
  420. package/src/zig/utf8.zig +1948 -0
  421. package/src/zig/utils.zig +9 -0
  422. package/src/zig-structs.ts +261 -0
  423. package/src/zig.ts +3843 -0
  424. package/tsconfig.build.json +22 -0
  425. package/tsconfig.json +28 -0
  426. package/3d/SpriteResourceManager.d.ts +0 -74
  427. package/3d/SpriteUtils.d.ts +0 -13
  428. package/3d/TextureUtils.d.ts +0 -24
  429. package/3d/ThreeRenderable.d.ts +0 -40
  430. package/3d/WGPURenderer.d.ts +0 -61
  431. package/3d/animation/ExplodingSpriteEffect.d.ts +0 -71
  432. package/3d/animation/PhysicsExplodingSpriteEffect.d.ts +0 -76
  433. package/3d/animation/SpriteAnimator.d.ts +0 -124
  434. package/3d/animation/SpriteParticleGenerator.d.ts +0 -62
  435. package/3d/canvas.d.ts +0 -44
  436. package/3d/index.d.ts +0 -12
  437. package/3d/physics/PlanckPhysicsAdapter.d.ts +0 -19
  438. package/3d/physics/RapierPhysicsAdapter.d.ts +0 -19
  439. package/3d/physics/physics-interface.d.ts +0 -27
  440. package/3d.d.ts +0 -2
  441. package/3d.js +0 -34042
  442. package/3d.js.map +0 -155
  443. package/LICENSE +0 -21
  444. package/NativeSpanFeed.d.ts +0 -41
  445. package/Renderable.d.ts +0 -334
  446. package/animation/Timeline.d.ts +0 -126
  447. package/ansi.d.ts +0 -13
  448. package/buffer.d.ts +0 -107
  449. package/console.d.ts +0 -143
  450. package/edit-buffer.d.ts +0 -98
  451. package/editor-view.d.ts +0 -73
  452. package/index-e4hzc2j2.js +0 -113
  453. package/index-e4hzc2j2.js.map +0 -10
  454. package/index-nkrr8a4c.js +0 -18415
  455. package/index-nkrr8a4c.js.map +0 -64
  456. package/index-nyw5p3ep.js +0 -12619
  457. package/index-nyw5p3ep.js.map +0 -43
  458. package/index.d.ts +0 -21
  459. package/index.js +0 -430
  460. package/index.js.map +0 -9
  461. package/lib/KeyHandler.d.ts +0 -61
  462. package/lib/RGBA.d.ts +0 -25
  463. package/lib/ascii.font.d.ts +0 -508
  464. package/lib/border.d.ts +0 -49
  465. package/lib/bunfs.d.ts +0 -7
  466. package/lib/clipboard.d.ts +0 -17
  467. package/lib/clock.d.ts +0 -15
  468. package/lib/data-paths.d.ts +0 -26
  469. package/lib/debounce.d.ts +0 -42
  470. package/lib/detect-links.d.ts +0 -6
  471. package/lib/env.d.ts +0 -42
  472. package/lib/extmarks-history.d.ts +0 -17
  473. package/lib/extmarks.d.ts +0 -89
  474. package/lib/hast-styled-text.d.ts +0 -17
  475. package/lib/index.d.ts +0 -21
  476. package/lib/keymapping.d.ts +0 -25
  477. package/lib/objects-in-viewport.d.ts +0 -24
  478. package/lib/output.capture.d.ts +0 -24
  479. package/lib/parse.keypress-kitty.d.ts +0 -2
  480. package/lib/parse.keypress.d.ts +0 -26
  481. package/lib/parse.mouse.d.ts +0 -30
  482. package/lib/paste.d.ts +0 -7
  483. package/lib/queue.d.ts +0 -15
  484. package/lib/renderable.validations.d.ts +0 -12
  485. package/lib/scroll-acceleration.d.ts +0 -43
  486. package/lib/selection.d.ts +0 -63
  487. package/lib/singleton.d.ts +0 -7
  488. package/lib/stdin-parser.d.ts +0 -76
  489. package/lib/styled-text.d.ts +0 -63
  490. package/lib/terminal-capability-detection.d.ts +0 -30
  491. package/lib/terminal-palette.d.ts +0 -50
  492. package/lib/tree-sitter/assets/update.d.ts +0 -11
  493. package/lib/tree-sitter/client.d.ts +0 -47
  494. package/lib/tree-sitter/default-parsers.d.ts +0 -2
  495. package/lib/tree-sitter/download-utils.d.ts +0 -21
  496. package/lib/tree-sitter/index.d.ts +0 -8
  497. package/lib/tree-sitter/parser.worker.d.ts +0 -1
  498. package/lib/tree-sitter/parsers-config.d.ts +0 -38
  499. package/lib/tree-sitter/resolve-ft.d.ts +0 -2
  500. package/lib/tree-sitter/types.d.ts +0 -81
  501. package/lib/tree-sitter-styled-text.d.ts +0 -14
  502. package/lib/validate-dir-name.d.ts +0 -1
  503. package/lib/yoga.options.d.ts +0 -32
  504. package/parser.worker.js +0 -869
  505. package/parser.worker.js.map +0 -12
  506. package/plugins/core-slot.d.ts +0 -72
  507. package/plugins/registry.d.ts +0 -38
  508. package/plugins/types.d.ts +0 -34
  509. package/post/filters.d.ts +0 -105
  510. package/renderables/ASCIIFont.d.ts +0 -52
  511. package/renderables/Box.d.ts +0 -72
  512. package/renderables/Code.d.ts +0 -78
  513. package/renderables/Diff.d.ts +0 -142
  514. package/renderables/EditBufferRenderable.d.ts +0 -162
  515. package/renderables/FrameBuffer.d.ts +0 -16
  516. package/renderables/Input.d.ts +0 -67
  517. package/renderables/LineNumberRenderable.d.ts +0 -74
  518. package/renderables/Markdown.d.ts +0 -173
  519. package/renderables/ScrollBar.d.ts +0 -77
  520. package/renderables/ScrollBox.d.ts +0 -124
  521. package/renderables/Select.d.ts +0 -115
  522. package/renderables/Slider.d.ts +0 -44
  523. package/renderables/TabSelect.d.ts +0 -96
  524. package/renderables/Text.d.ts +0 -36
  525. package/renderables/TextBufferRenderable.d.ts +0 -105
  526. package/renderables/TextNode.d.ts +0 -91
  527. package/renderables/TextTable.d.ts +0 -140
  528. package/renderables/Textarea.d.ts +0 -114
  529. package/renderables/TimeToFirstDraw.d.ts +0 -24
  530. package/renderables/__tests__/renderable-test-utils.d.ts +0 -12
  531. package/renderables/composition/VRenderable.d.ts +0 -16
  532. package/renderables/composition/constructs.d.ts +0 -35
  533. package/renderables/composition/vnode.d.ts +0 -46
  534. package/renderables/index.d.ts +0 -22
  535. package/renderables/markdown-parser.d.ts +0 -10
  536. package/renderer.d.ts +0 -388
  537. package/runtime-plugin-support.d.ts +0 -3
  538. package/runtime-plugin-support.js +0 -29
  539. package/runtime-plugin-support.js.map +0 -10
  540. package/runtime-plugin.d.ts +0 -11
  541. package/runtime-plugin.js +0 -16
  542. package/runtime-plugin.js.map +0 -9
  543. package/syntax-style.d.ts +0 -54
  544. package/testing/manual-clock.d.ts +0 -16
  545. package/testing/mock-keys.d.ts +0 -81
  546. package/testing/mock-mouse.d.ts +0 -38
  547. package/testing/mock-tree-sitter-client.d.ts +0 -23
  548. package/testing/spy.d.ts +0 -7
  549. package/testing/test-recorder.d.ts +0 -61
  550. package/testing/test-renderer.d.ts +0 -23
  551. package/testing.d.ts +0 -6
  552. package/testing.js +0 -675
  553. package/testing.js.map +0 -15
  554. package/text-buffer-view.d.ts +0 -42
  555. package/text-buffer.d.ts +0 -67
  556. package/types.d.ts +0 -131
  557. package/utils.d.ts +0 -14
  558. package/zig-structs.d.ts +0 -155
  559. package/zig.d.ts +0 -351
  560. /package/{assets → src/lib/tree-sitter/assets}/javascript/highlights.scm +0 -0
  561. /package/{assets → src/lib/tree-sitter/assets}/javascript/tree-sitter-javascript.wasm +0 -0
  562. /package/{assets → src/lib/tree-sitter/assets}/markdown/highlights.scm +0 -0
  563. /package/{assets → src/lib/tree-sitter/assets}/markdown/injections.scm +0 -0
  564. /package/{assets → src/lib/tree-sitter/assets}/markdown/tree-sitter-markdown.wasm +0 -0
  565. /package/{assets → src/lib/tree-sitter/assets}/markdown_inline/highlights.scm +0 -0
  566. /package/{assets → src/lib/tree-sitter/assets}/markdown_inline/tree-sitter-markdown_inline.wasm +0 -0
  567. /package/{assets → src/lib/tree-sitter/assets}/typescript/highlights.scm +0 -0
  568. /package/{assets → src/lib/tree-sitter/assets}/typescript/tree-sitter-typescript.wasm +0 -0
  569. /package/{assets → src/lib/tree-sitter/assets}/zig/highlights.scm +0 -0
  570. /package/{assets → src/lib/tree-sitter/assets}/zig/tree-sitter-zig.wasm +0 -0
@@ -0,0 +1,259 @@
1
+ #!/usr/bin/env bun
2
+
3
+ import {
4
+ CliRenderer,
5
+ createCliRenderer,
6
+ RGBA,
7
+ BoxRenderable,
8
+ TextRenderable,
9
+ type KeyEvent,
10
+ type MouseEvent,
11
+ } from "../index.js"
12
+ import { setupCommonDemoKeys } from "./lib/standalone-keys.js"
13
+ import {
14
+ Scene as ThreeScene,
15
+ Mesh as ThreeMesh,
16
+ PerspectiveCamera,
17
+ Color,
18
+ DirectionalLight,
19
+ AmbientLight,
20
+ BoxGeometry,
21
+ MeshPhongMaterial,
22
+ Vector3,
23
+ } from "three"
24
+ import { ThreeRenderable } from "../3d.js"
25
+
26
+ let nextZIndex = 200
27
+ let keyListener: ((key: KeyEvent) => void) | null = null
28
+ let resizeListener: ((width: number, height: number) => void) | null = null
29
+ let parentContainer: BoxRenderable | null = null
30
+ let draggableCube: DraggableThreeRenderable | null = null
31
+
32
+ const HEADER_HEIGHT = 4
33
+
34
+ class DraggableThreeRenderable extends ThreeRenderable {
35
+ private isDragging = false
36
+ private dragOffsetX = 0
37
+ private dragOffsetY = 0
38
+ private dragBoundsTop: number
39
+
40
+ constructor(ctx: CliRenderer, dragBoundsTop: number, options: ConstructorParameters<typeof ThreeRenderable>[1]) {
41
+ super(ctx, options)
42
+ this.dragBoundsTop = dragBoundsTop
43
+ }
44
+
45
+ public setDragBoundsTop(top: number): void {
46
+ this.dragBoundsTop = top
47
+ }
48
+
49
+ protected onMouseEvent(event: MouseEvent): void {
50
+ switch (event.type) {
51
+ case "down":
52
+ this.isDragging = true
53
+ this.dragOffsetX = event.x - this.x
54
+ this.dragOffsetY = event.y - this.y
55
+ this.zIndex = nextZIndex++
56
+ event.stopPropagation()
57
+ break
58
+ case "drag":
59
+ if (!this.isDragging) return
60
+ this.updateDragPosition(event.x, event.y)
61
+ event.stopPropagation()
62
+ break
63
+ case "drag-end":
64
+ if (this.isDragging) {
65
+ this.isDragging = false
66
+ event.stopPropagation()
67
+ }
68
+ break
69
+ }
70
+ }
71
+
72
+ private updateDragPosition(pointerX: number, pointerY: number): void {
73
+ const newX = pointerX - this.dragOffsetX
74
+ const newY = pointerY - this.dragOffsetY
75
+ const maxX = this._ctx.width - this.width
76
+ const maxY = this._ctx.height - this.height
77
+
78
+ this.x = Math.max(0, Math.min(newX, maxX))
79
+ this.y = Math.max(this.dragBoundsTop, Math.min(newY, maxY))
80
+ }
81
+ }
82
+
83
+ function getRenderSize(width: number, height: number): { width: number; height: number } {
84
+ return {
85
+ width: Math.max(24, Math.min(64, Math.floor(width * 0.55))),
86
+ height: Math.max(12, Math.min(28, Math.floor(height * 0.55))),
87
+ }
88
+ }
89
+
90
+ export function run(renderer: CliRenderer): void {
91
+ renderer.start()
92
+ renderer.setBackgroundColor("#0A0E14")
93
+
94
+ const width = renderer.terminalWidth
95
+ const height = renderer.terminalHeight
96
+ const size = getRenderSize(width, height)
97
+
98
+ parentContainer = new BoxRenderable(renderer, {
99
+ id: "draggable-three-container",
100
+ zIndex: 10,
101
+ })
102
+ renderer.root.add(parentContainer)
103
+
104
+ const titleText = new TextRenderable(renderer, {
105
+ id: "draggable-three-title",
106
+ content: "Draggable ThreeRenderable - rotating cube (drag with mouse)",
107
+ position: "absolute",
108
+ left: 2,
109
+ top: 1,
110
+ fg: "#E2E8F0",
111
+ zIndex: 20,
112
+ })
113
+ parentContainer.add(titleText)
114
+
115
+ const instructionsText = new TextRenderable(renderer, {
116
+ id: "draggable-three-instructions",
117
+ content: "Space: toggle rotation | P: screenshot | Esc: return",
118
+ position: "absolute",
119
+ left: 2,
120
+ top: 2,
121
+ fg: "#94A3B8",
122
+ zIndex: 20,
123
+ })
124
+ parentContainer.add(instructionsText)
125
+
126
+ const controlsText = new TextRenderable(renderer, {
127
+ id: "draggable-three-controls",
128
+ content: "Drag the cube to see transparency and live rendering",
129
+ position: "absolute",
130
+ left: 2,
131
+ top: height - 2,
132
+ fg: "#CBD5F5",
133
+ zIndex: 20,
134
+ })
135
+ parentContainer.add(controlsText)
136
+
137
+ const sceneRoot = new ThreeScene()
138
+
139
+ const ambientLight = new AmbientLight(new Color(0.35, 0.35, 0.35), 1.0)
140
+ sceneRoot.add(ambientLight)
141
+
142
+ const keyLight = new DirectionalLight(new Color(1.0, 0.95, 0.9), 1.2)
143
+ keyLight.position.set(2.5, 2.0, 3.0)
144
+ sceneRoot.add(keyLight)
145
+
146
+ const fillLight = new DirectionalLight(new Color(0.5, 0.7, 1.0), 0.6)
147
+ fillLight.position.set(-2.0, -1.5, 2.5)
148
+ sceneRoot.add(fillLight)
149
+
150
+ const cubeGeometry = new BoxGeometry(1.0, 1.0, 1.0)
151
+ const cubeMaterial = new MeshPhongMaterial({
152
+ color: new Color(0.25, 0.8, 1.0),
153
+ shininess: 80,
154
+ specular: new Color(0.9, 0.9, 1.0),
155
+ })
156
+ const cubeMesh = new ThreeMesh(cubeGeometry, cubeMaterial)
157
+ cubeMesh.name = "cube"
158
+ sceneRoot.add(cubeMesh)
159
+
160
+ const cameraNode = new PerspectiveCamera(45, 1, 0.1, 100)
161
+ cameraNode.position.set(0, 0, 3)
162
+ cameraNode.name = "main_camera"
163
+
164
+ const startX = Math.max(2, Math.floor((width - size.width) / 2))
165
+ const startY = Math.max(HEADER_HEIGHT, Math.floor((height - size.height) / 2))
166
+
167
+ draggableCube = new DraggableThreeRenderable(renderer, HEADER_HEIGHT, {
168
+ id: "draggable-three",
169
+ width: size.width,
170
+ height: size.height,
171
+ position: "absolute",
172
+ left: startX,
173
+ top: startY,
174
+ zIndex: 50,
175
+ scene: sceneRoot,
176
+ camera: cameraNode,
177
+ renderer: {
178
+ focalLength: 8,
179
+ alpha: true,
180
+ backgroundColor: RGBA.fromValues(0, 0, 0, 0),
181
+ },
182
+ })
183
+ renderer.root.add(draggableCube)
184
+
185
+ const rotationSpeed = new Vector3(0.6, 0.4, 0.2)
186
+ let rotationEnabled = true
187
+
188
+ renderer.setFrameCallback(async (deltaMs) => {
189
+ const deltaTime = deltaMs / 1000
190
+ if (!rotationEnabled) return
191
+ cubeMesh.rotation.x += rotationSpeed.x * deltaTime
192
+ cubeMesh.rotation.y += rotationSpeed.y * deltaTime
193
+ cubeMesh.rotation.z += rotationSpeed.z * deltaTime
194
+ })
195
+
196
+ resizeListener = (newWidth: number, newHeight: number) => {
197
+ controlsText.y = newHeight - 2
198
+
199
+ if (!draggableCube) return
200
+
201
+ const nextSize = getRenderSize(newWidth, newHeight)
202
+ draggableCube.width = nextSize.width
203
+ draggableCube.height = nextSize.height
204
+ draggableCube.setDragBoundsTop(HEADER_HEIGHT)
205
+
206
+ const maxX = newWidth - draggableCube.width
207
+ const maxY = newHeight - draggableCube.height
208
+ draggableCube.x = Math.max(0, Math.min(draggableCube.x, maxX))
209
+ draggableCube.y = Math.max(HEADER_HEIGHT, Math.min(draggableCube.y, maxY))
210
+ }
211
+
212
+ renderer.on("resize", resizeListener)
213
+
214
+ keyListener = (key: KeyEvent) => {
215
+ if (key.name === "p" && draggableCube) {
216
+ draggableCube.renderer.saveToFile(`screenshot-${Date.now()}.png`)
217
+ }
218
+
219
+ if (key.name === "space") {
220
+ rotationEnabled = !rotationEnabled
221
+ }
222
+ }
223
+
224
+ renderer.keyInput.on("keypress", keyListener)
225
+ }
226
+
227
+ export function destroy(renderer: CliRenderer): void {
228
+ renderer.clearFrameCallbacks()
229
+
230
+ if (resizeListener) {
231
+ renderer.off("resize", resizeListener)
232
+ resizeListener = null
233
+ }
234
+
235
+ if (keyListener) {
236
+ renderer.keyInput.off("keypress", keyListener)
237
+ keyListener = null
238
+ }
239
+
240
+ if (draggableCube) {
241
+ draggableCube.destroy()
242
+ draggableCube = null
243
+ }
244
+
245
+ if (parentContainer) {
246
+ renderer.root.remove("draggable-three-container")
247
+ parentContainer = null
248
+ }
249
+ }
250
+
251
+ if (import.meta.main) {
252
+ const renderer = await createCliRenderer({
253
+ exitOnCtrlC: true,
254
+ targetFps: 60,
255
+ })
256
+
257
+ run(renderer)
258
+ setupCommonDemoKeys(renderer)
259
+ }
@@ -0,0 +1,322 @@
1
+ import {
2
+ CliRenderer,
3
+ createCliRenderer,
4
+ TextareaRenderable,
5
+ BoxRenderable,
6
+ TextRenderable,
7
+ LineNumberRenderable,
8
+ KeyEvent,
9
+ t,
10
+ bold,
11
+ cyan,
12
+ fg,
13
+ } from "../index.js"
14
+ import { setupCommonDemoKeys } from "./lib/standalone-keys.js"
15
+
16
+ const initialContent = `Welcome to the TextareaRenderable Demo!
17
+
18
+ This is an interactive text editor powered by EditBuffer and EditorView.
19
+
20
+ \tThis is a tab
21
+ \t\t\tMultiple tabs
22
+
23
+ Emojis:
24
+ 👩🏽‍💻 👨‍👩‍👧‍👦 🏳️‍🌈 🇺🇸 🇩🇪 🇯🇵 🇮🇳
25
+
26
+ NAVIGATION:
27
+ • Arrow keys to move cursor
28
+ • Ctrl+A/Ctrl+E for line start/end
29
+ • Home/End for buffer start/end
30
+ • Ctrl+F/Ctrl+B to move right/left (Emacs-style)
31
+ • Alt+F/Alt+B for word forward/backward
32
+ • Alt+Left/Alt+Right for word forward/backward
33
+ • Ctrl+Left/Ctrl+Right for word forward/backward
34
+ • Alt+A/Alt+E for visual line start/end
35
+
36
+ SELECTION:
37
+ • Shift+Arrow keys to select
38
+ • Ctrl+Shift+A/E to select to line start/end
39
+ • Shift+Home/End to select to buffer start/end
40
+ • Alt+Shift+F/B to select word forward/backward
41
+ • Alt+Shift+Left/Right to select word forward/backward
42
+ • Alt+Shift+A/E to select to visual line start/end
43
+
44
+ EDITING:
45
+ • Type any text to insert
46
+ • Backspace/Delete to remove text
47
+ • Enter to create new lines
48
+ • Ctrl+Shift+D to delete current line
49
+ • Ctrl+D to delete character forward
50
+ • Ctrl+K to delete to line end
51
+ • Ctrl+U to delete to line start
52
+ • Alt+D to delete word forward
53
+ • Alt+Backspace or Ctrl+W to delete word backward
54
+ • Ctrl+Delete or Alt+Delete to delete word forward
55
+
56
+ UNDO/REDO:
57
+ • Ctrl+- to undo or Cmd+Z (Mac)
58
+ • Ctrl+. to redo or Cmd+Shift+Z (Mac)
59
+
60
+ VIEW:
61
+ • Shift+W to toggle wrap mode (word/char/none)
62
+ • Shift+L to toggle line numbers
63
+ • Shift+H to toggle diff highlights (colors + +/- signs)
64
+ • Shift+D to toggle diagnostics (error/warning/info emojis)
65
+ • Ctrl+] to increase scroll speed
66
+ • Ctrl+[ to decrease scroll speed
67
+
68
+ FEATURES:
69
+ ✓ Grapheme-aware cursor movement
70
+ ✓ Unicode (emoji 🌟 and CJK 世界, 你好世界, 中文, 한글)
71
+ ✓ Incremental editing
72
+ ✓ Text wrapping and viewport management
73
+ ✓ Undo/redo support
74
+ ✓ Word-based navigation and deletion
75
+ ✓ Text selection with shift keys
76
+
77
+ Press ESC to return to main menu`
78
+
79
+ let renderer: CliRenderer | null = null
80
+ let parentContainer: BoxRenderable | null = null
81
+ let editor: TextareaRenderable | null = null
82
+ let editorWithLines: LineNumberRenderable | null = null
83
+ let statusText: TextRenderable | null = null
84
+ let highlightsEnabled: boolean = false
85
+ let diagnosticsEnabled: boolean = false
86
+
87
+ export async function run(rendererInstance: CliRenderer): Promise<void> {
88
+ renderer = rendererInstance
89
+ renderer.setBackgroundColor("#0D1117")
90
+
91
+ parentContainer = new BoxRenderable(renderer, {
92
+ id: "parent-container",
93
+ zIndex: 10,
94
+ padding: 1,
95
+ })
96
+ renderer.root.add(parentContainer)
97
+
98
+ const editorBox = new BoxRenderable(renderer, {
99
+ id: "editor-box",
100
+ borderStyle: "single",
101
+ borderColor: "#6BCF7F",
102
+ backgroundColor: "#0D1117",
103
+ title: "Interactive Editor (TextareaRenderable)",
104
+ titleAlignment: "left",
105
+ border: true,
106
+ })
107
+ parentContainer.add(editorBox)
108
+
109
+ // Create interactive editor
110
+ editor = new TextareaRenderable(renderer, {
111
+ id: "editor",
112
+ initialValue: initialContent,
113
+ textColor: "#F0F6FC",
114
+ selectionBg: "#264F78",
115
+ selectionFg: "#FFFFFF",
116
+ wrapMode: "word",
117
+ showCursor: true,
118
+ cursorColor: "#4ECDC4",
119
+ placeholder: t`${fg("#333333")("Enter")} ${cyan(bold("text"))} ${fg("#333333")("here...")}`,
120
+ tabIndicator: "→",
121
+ tabIndicatorColor: "#30363D",
122
+ })
123
+
124
+ editorWithLines = new LineNumberRenderable(renderer, {
125
+ id: "editor-lines",
126
+ target: editor,
127
+ minWidth: 3,
128
+ paddingRight: 1,
129
+ fg: "#6b7280", // Dimmed gray for line numbers
130
+ bg: "#161b22", // Slightly darker than editor background for distinction
131
+ width: "100%",
132
+ height: "100%",
133
+ })
134
+
135
+ editorBox.add(editorWithLines)
136
+
137
+ statusText = new TextRenderable(renderer, {
138
+ id: "status",
139
+ content: "",
140
+ fg: "#A5D6FF",
141
+ height: 1,
142
+ })
143
+ parentContainer.add(statusText)
144
+
145
+ editor.focus()
146
+
147
+ rendererInstance.setFrameCallback(async () => {
148
+ if (statusText && editor && !editor.isDestroyed) {
149
+ try {
150
+ const cursor = editor.logicalCursor
151
+ const wrap = editor.wrapMode !== "none" ? "ON" : "OFF"
152
+ const highlights = highlightsEnabled ? "ON" : "OFF"
153
+ const diagnostics = diagnosticsEnabled ? "ON" : "OFF"
154
+ const scrollSpeed = editor.scrollSpeed
155
+ statusText.content = `Line ${cursor.row + 1}, Col ${cursor.col + 1} | Wrap: ${wrap} | Diff: ${highlights} | Diag: ${diagnostics} | Scroll: ${scrollSpeed} lines/s`
156
+ } catch (error) {
157
+ // Ignore errors during shutdown
158
+ }
159
+ }
160
+ })
161
+
162
+ rendererInstance.keyInput.on("keypress", (key: KeyEvent) => {
163
+ if (key.shift && key.name === "l") {
164
+ key.preventDefault()
165
+ if (editorWithLines && !editorWithLines.isDestroyed) {
166
+ editorWithLines.showLineNumbers = !editorWithLines.showLineNumbers
167
+ }
168
+ }
169
+ if (key.shift && key.name === "w") {
170
+ key.preventDefault()
171
+ if (editor && !editor.isDestroyed) {
172
+ const currentMode = editor.wrapMode
173
+ const nextMode = currentMode === "word" ? "char" : currentMode === "char" ? "none" : "word"
174
+ editor.wrapMode = nextMode
175
+ }
176
+ }
177
+ if (key.shift && key.name === "h") {
178
+ key.preventDefault()
179
+ if (editorWithLines && !editorWithLines.isDestroyed) {
180
+ highlightsEnabled = !highlightsEnabled
181
+ if (highlightsEnabled) {
182
+ // Add modern diff-style line colors and +/- signs throughout the document
183
+ editorWithLines.setLineColor(2, "#1a4d1a") // Line 3: Added (fresh green)
184
+ editorWithLines.setLineSign(2, { after: " +", afterColor: "#22c55e" })
185
+
186
+ editorWithLines.setLineColor(5, "#4d1a1a") // Line 6: Removed (vibrant red)
187
+ editorWithLines.setLineSign(5, { after: " -", afterColor: "#ef4444" })
188
+
189
+ editorWithLines.setLineColor(8, "#1a4d1a") // Line 9: Added (fresh green)
190
+ editorWithLines.setLineSign(8, { after: " +", afterColor: "#22c55e" })
191
+
192
+ editorWithLines.setLineColor(11, "#4d1a1a") // Line 12: Removed (vibrant red)
193
+ editorWithLines.setLineSign(11, { after: " -", afterColor: "#ef4444" })
194
+
195
+ editorWithLines.setLineColor(14, "#1a4d1a") // Line 15: Added (fresh green)
196
+ editorWithLines.setLineSign(14, { after: " +", afterColor: "#22c55e" })
197
+
198
+ editorWithLines.setLineColor(17, "#4d1a1a") // Line 18: Removed (vibrant red)
199
+ editorWithLines.setLineSign(17, { after: " -", afterColor: "#ef4444" })
200
+
201
+ editorWithLines.setLineColor(20, "#1a4d1a") // Line 21: Added (fresh green)
202
+ editorWithLines.setLineSign(20, { after: " +", afterColor: "#22c55e" })
203
+
204
+ editorWithLines.setLineColor(23, "#4d1a1a") // Line 24: Removed (vibrant red)
205
+ editorWithLines.setLineSign(23, { after: " -", afterColor: "#ef4444" })
206
+
207
+ editorWithLines.setLineColor(27, "#1a4d1a") // Line 28: Added (fresh green)
208
+ editorWithLines.setLineSign(27, { after: " +", afterColor: "#22c55e" })
209
+
210
+ editorWithLines.setLineColor(30, "#4d1a1a") // Line 31: Removed (vibrant red)
211
+ editorWithLines.setLineSign(30, { after: " -", afterColor: "#ef4444" })
212
+
213
+ editorWithLines.setLineColor(34, "#1a4d1a") // Line 35: Added (fresh green)
214
+ editorWithLines.setLineSign(34, { after: " +", afterColor: "#22c55e" })
215
+
216
+ editorWithLines.setLineColor(38, "#4d1a1a") // Line 39: Removed (vibrant red)
217
+ editorWithLines.setLineSign(38, { after: " -", afterColor: "#ef4444" })
218
+
219
+ editorWithLines.setLineColor(42, "#1a4d1a") // Line 43: Added (fresh green)
220
+ editorWithLines.setLineSign(42, { after: " +", afterColor: "#22c55e" })
221
+
222
+ editorWithLines.setLineColor(46, "#4d1a1a") // Line 47: Removed (vibrant red)
223
+ editorWithLines.setLineSign(46, { after: " -", afterColor: "#ef4444" })
224
+
225
+ editorWithLines.setLineColor(50, "#1a4d1a") // Line 51: Added (fresh green)
226
+ editorWithLines.setLineSign(50, { after: " +", afterColor: "#22c55e" })
227
+
228
+ editorWithLines.setLineColor(54, "#4d1a1a") // Line 55: Removed (vibrant red)
229
+ editorWithLines.setLineSign(54, { after: " -", afterColor: "#ef4444" })
230
+
231
+ editorWithLines.setLineColor(58, "#1a4d1a") // Line 59: Added (fresh green)
232
+ editorWithLines.setLineSign(58, { after: " +", afterColor: "#22c55e" })
233
+ } else {
234
+ editorWithLines.clearAllLineColors()
235
+ // Clear only the after signs (keep diagnostics if enabled)
236
+ const currentSigns = editorWithLines.getLineSigns()
237
+ for (const [line, sign] of currentSigns) {
238
+ if (sign.after) {
239
+ if (sign.before) {
240
+ // Keep the before sign, remove only after
241
+ editorWithLines.setLineSign(line, { before: sign.before, beforeColor: sign.beforeColor })
242
+ } else {
243
+ // No before sign, remove entirely
244
+ editorWithLines.clearLineSign(line)
245
+ }
246
+ }
247
+ }
248
+ }
249
+ }
250
+ }
251
+ if (key.shift && key.name === "d") {
252
+ key.preventDefault()
253
+ if (editorWithLines && !editorWithLines.isDestroyed) {
254
+ diagnosticsEnabled = !diagnosticsEnabled
255
+ if (diagnosticsEnabled) {
256
+ // Add diagnostic signs (errors, warnings, info) on some lines
257
+ editorWithLines.setLineSign(0, { before: "❌", beforeColor: "#ef4444" }) // Line 1: Error
258
+ editorWithLines.setLineSign(4, { before: "⚠️", beforeColor: "#f59e0b" }) // Line 5: Warning
259
+ editorWithLines.setLineSign(10, { before: "💡", beforeColor: "#3b82f6" }) // Line 11: Info
260
+ editorWithLines.setLineSign(25, { before: "❌", beforeColor: "#ef4444" }) // Line 26: Error
261
+ editorWithLines.setLineSign(40, { before: "⚠️", beforeColor: "#f59e0b" }) // Line 41: Warning
262
+ editorWithLines.setLineSign(52, { before: "💡", beforeColor: "#3b82f6" }) // Line 53: Info
263
+ } else {
264
+ // Clear only the before signs (keep diff signs if enabled)
265
+ const currentSigns = editorWithLines.getLineSigns()
266
+ for (const [line, sign] of currentSigns) {
267
+ if (sign.before) {
268
+ if (sign.after) {
269
+ // Keep the after sign, remove only before
270
+ editorWithLines.setLineSign(line, { after: sign.after, afterColor: sign.afterColor })
271
+ } else {
272
+ // No after sign, remove entirely
273
+ editorWithLines.clearLineSign(line)
274
+ }
275
+ }
276
+ }
277
+ }
278
+ }
279
+ }
280
+ if (key.ctrl && (key.name === "pageup" || key.name === "pagedown")) {
281
+ key.preventDefault()
282
+ if (editor && !editor.isDestroyed) {
283
+ if (key.name === "pageup") {
284
+ editor.editBuffer.setCursor(0, 0)
285
+ } else {
286
+ editor.gotoBufferEnd()
287
+ }
288
+ }
289
+ }
290
+ if (key.ctrl && key.name === "]") {
291
+ key.preventDefault()
292
+ if (editor && !editor.isDestroyed) {
293
+ editor.scrollSpeed = Math.min(100, editor.scrollSpeed + 4)
294
+ }
295
+ }
296
+ if (key.ctrl && key.name === "[") {
297
+ key.preventDefault()
298
+ if (editor && !editor.isDestroyed) {
299
+ editor.scrollSpeed = Math.max(4, editor.scrollSpeed - 4)
300
+ }
301
+ }
302
+ })
303
+ }
304
+
305
+ export function destroy(rendererInstance: CliRenderer): void {
306
+ rendererInstance.clearFrameCallbacks()
307
+ parentContainer?.destroy()
308
+ parentContainer = null
309
+ editorWithLines = null
310
+ editor = null
311
+ statusText = null
312
+ renderer = null
313
+ }
314
+
315
+ if (import.meta.main) {
316
+ const renderer = await createCliRenderer({
317
+ exitOnCtrlC: true,
318
+ targetFps: 60,
319
+ })
320
+ run(renderer)
321
+ setupCommonDemoKeys(renderer)
322
+ }