@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,404 @@
1
+ import { createCliRenderer, MouseEvent, type CliRenderer } from "../renderer.js"
2
+ import {
3
+ Box,
4
+ Text,
5
+ Generic,
6
+ type VNode,
7
+ instantiate,
8
+ delegate,
9
+ Input,
10
+ BoxRenderable,
11
+ type BoxOptions,
12
+ vstyles,
13
+ } from "../renderables/index.js"
14
+ import type { RenderContext } from "../types.js"
15
+ import type { OptimizedBuffer } from "../buffer.js"
16
+ import { setupCommonDemoKeys } from "./lib/standalone-keys.js"
17
+ import { RGBA, parseColor } from "../lib/index.js"
18
+ import type { Renderable } from "../Renderable.js"
19
+ import { TextAttributes } from "../types.js"
20
+
21
+ const textColor = parseColor("#FFFFFF")
22
+ const globalbgColor = parseColor("#333333")
23
+ const transparent = parseColor("transparent")
24
+
25
+ const { bold, italic, underline, dim, boldItalic, boldUnderline, italicUnderline, color, bgColor, styled } = vstyles
26
+
27
+ // This is NOT react and not reactive, it's just a declarative way to compose renderables
28
+ // and mount them into a parent container.
29
+ function MyRenderable(props: any, children: VNode[] = []) {
30
+ const mouseHandler = (event: MouseEvent) => {
31
+ console.log("mouseHandler", event.type)
32
+ }
33
+
34
+ return Box({ id: "inner" }, [
35
+ Box(
36
+ {
37
+ border: true,
38
+ borderStyle: "double",
39
+ padding: 1,
40
+ onMouseDown: mouseHandler,
41
+ flexDirection: "row",
42
+ },
43
+ children,
44
+ ),
45
+ ])
46
+ }
47
+
48
+ function Button(
49
+ props: {
50
+ title: string
51
+ onClick: () => void
52
+ borderColor?: string | RGBA
53
+ },
54
+ children: VNode[] = [],
55
+ ) {
56
+ return Box(
57
+ {
58
+ id: "button",
59
+ border: true,
60
+ onMouseDown: props.onClick,
61
+ borderColor: props.borderColor,
62
+ },
63
+ Text({ content: props.title, selectable: false }),
64
+ ...children,
65
+ )
66
+ }
67
+
68
+ // Custom Rendering Functional Construct
69
+ function VNodeButton(
70
+ props: {
71
+ title: string
72
+ onClick: () => void
73
+ borderColor?: RGBA
74
+ },
75
+ children: VNode[] = [],
76
+ ) {
77
+ return Generic(
78
+ {
79
+ render: (buffer, deltaTime, renderable) => demoRenderFn(props, buffer, deltaTime, renderable),
80
+ maxWidth: props.title.length + 4,
81
+ margin: 1,
82
+ },
83
+ Box(
84
+ {
85
+ id: "button",
86
+ height: 3,
87
+ onMouseDown: props.onClick,
88
+ },
89
+ children,
90
+ ),
91
+ )
92
+ }
93
+
94
+ // Custom Rendering - Class Method Example
95
+ class MyRoot {
96
+ width: number
97
+
98
+ constructor(private readonly props: { title: string; borderColor?: RGBA }) {
99
+ this.width = Math.max(props.title.length + 4, 12)
100
+ Object.assign(this, props)
101
+ }
102
+
103
+ render(buffer: OptimizedBuffer, deltaTime: number, renderable: Renderable) {
104
+ demoRenderFn(this.props, buffer, deltaTime, renderable)
105
+ }
106
+ }
107
+
108
+ function ButtonWithClassRender(
109
+ props: { title: string; onClick: () => void; borderColor?: RGBA; marginLeft?: number },
110
+ children: VNode[] = [],
111
+ ) {
112
+ return Generic(
113
+ new MyRoot(props),
114
+ Box(
115
+ {
116
+ id: "button",
117
+ height: 3,
118
+ onMouseDown: props.onClick,
119
+ },
120
+ ...children,
121
+ ),
122
+ )
123
+ }
124
+
125
+ // Host Override Example
126
+ function MyDelegateToVNodeRenderable(props: any, children: VNode[] = []) {
127
+ return delegate(
128
+ {
129
+ add: `${props.id}_box3`,
130
+ remove: `${props.id}_box3`,
131
+ },
132
+ Box({ id: `${props.id}_outer3`, border: true, borderColor: "blue" }, [
133
+ Box({ id: `${props.id}_inner3`, border: true, borderColor: "magenta" }, [
134
+ Box({ id: `${props.id}_box3`, flexDirection: "row", border: true, padding: 1 }, children),
135
+ ]),
136
+ ]),
137
+ )
138
+ }
139
+
140
+ function MyDelegateToRenderableComponent(renderer: RenderContext, props: any, children: VNode[] = []) {
141
+ return delegate(
142
+ {
143
+ add: "__box4",
144
+ remove: "__box4",
145
+ },
146
+ instantiate(
147
+ renderer,
148
+ Box({ id: "__outer4", border: true, borderColor: "blue" }, [
149
+ Box({ id: "__inner4", border: true, borderColor: "magenta" }, [
150
+ Box({ id: "__box4", flexDirection: "row", border: true, padding: 1 }, children),
151
+ ]),
152
+ ]),
153
+ ),
154
+ )
155
+ }
156
+
157
+ function MyInstancedRenderable(renderer: RenderContext, props: any, children: VNode[] = []) {
158
+ return instantiate(renderer, MyDelegateToVNodeRenderable(props, children))
159
+ }
160
+
161
+ function LabeledInput(props: { id: string; label: string; placeholder: string }) {
162
+ return delegate(
163
+ {
164
+ focus: `${props.id}-input`,
165
+ },
166
+ Box(
167
+ { flexDirection: "row", id: `${props.id}-labeled-outer` },
168
+ Text({ content: props.label + " " }),
169
+ Input({
170
+ id: `${props.id}-input`,
171
+ placeholder: props.placeholder,
172
+ width: 20,
173
+ backgroundColor: "white",
174
+ textColor: "black",
175
+ cursorColor: "blue",
176
+ focusedBackgroundColor: "orange",
177
+ }),
178
+ ),
179
+ )
180
+ }
181
+
182
+ function BaseBox(props: BoxOptions, children: VNode[] = []) {
183
+ return Box(
184
+ {
185
+ id: "base-box",
186
+ border: true,
187
+ borderColor: "blue",
188
+ backgroundColor: "orange",
189
+ ...props,
190
+ renderAfter(buffer: OptimizedBuffer, deltaTime: number) {
191
+ buffer.drawText("Hello", this.x + 1, this.y + 1, RGBA.fromInts(255, 255, 255, 255))
192
+ props.renderAfter?.call(this, buffer, deltaTime)
193
+ },
194
+ },
195
+ children,
196
+ )
197
+ }
198
+
199
+ function ExtendedBaseBox(props: BoxOptions, children: VNode[] = []) {
200
+ return BaseBox(
201
+ {
202
+ id: "extended-base-box",
203
+ ...props,
204
+ renderAfter(buffer: OptimizedBuffer, deltaTime: number) {
205
+ buffer.drawText("Extended", this.x + 1, this.y + 2, RGBA.fromInts(255, 255, 255, 255))
206
+ },
207
+ },
208
+ children,
209
+ )
210
+ }
211
+
212
+ export function run(renderer: CliRenderer) {
213
+ renderer.start()
214
+ const mainGroup = new BoxRenderable(renderer, {
215
+ id: "main-group",
216
+ })
217
+ renderer.root.add(mainGroup)
218
+
219
+ // BaseBox example
220
+ mainGroup.add(ExtendedBaseBox({ width: 20, height: 10, position: "absolute", left: 55, top: 10, zIndex: 1000 }))
221
+
222
+ // Proxied VNode example
223
+ const tree = MyRenderable({ id: "demo-root" }, [
224
+ Box({ id: "child-1", width: 20, height: 3, border: true, marginBottom: 1 }, [Text({ content: "Hello" })]),
225
+ Box({ id: "child-2", width: 24, height: 3, border: true }, [Text({ content: "VNode world" })]),
226
+ ])
227
+ tree.backgroundColor = RGBA.fromInts(0, 155, 155, 100)
228
+
229
+ mainGroup.add(tree)
230
+
231
+ const input = LabeledInput({ id: "labeled-input", label: "Label:", placeholder: "Enter your text..." })
232
+ input.focus()
233
+ mainGroup.add(input)
234
+
235
+ //
236
+ // VNode delegated version
237
+ const instance1 = MyDelegateToVNodeRenderable({ id: "delegated-demo-root" }, [
238
+ Box({ id: "child-1", width: 20, height: 3, border: true, marginBottom: 1 }, [
239
+ Text({ content: "Hello delegated 1" }),
240
+ ]),
241
+ Box({ id: "child-2", width: 24, height: 3, border: true }, [Text({ content: "VNode world delegated 1" })]),
242
+ ])
243
+ instance1.backgroundColor = RGBA.fromInts(155, 0, 155, 100)
244
+
245
+ mainGroup.add(instance1)
246
+
247
+ //
248
+ // Instaced Delegated version
249
+ const instance = MyInstancedRenderable(renderer, { id: "demo-root" }, [
250
+ Box({ id: "child-1", width: 20, height: 3, border: true, marginBottom: 1 }, [Text({ content: "Hello 2" })]),
251
+ Box({ id: "child-2", width: 24, height: 3, border: true }, [Text({ content: "VNode world 2" })]),
252
+ ])
253
+
254
+ mainGroup.add(instance)
255
+
256
+ // Delegated to __box3, would otherwise end up in the top-level group!
257
+ instance.add(Box({ id: "child-3", width: 24, height: 3, border: true }, [Text({ content: "VNode world 3" })]))
258
+ instance.add(Button({ title: "Click me", onClick: () => console.log("clicked"), borderColor: "red" }))
259
+
260
+ //
261
+ // Renderable delegated version
262
+ const renderableInstance = MyDelegateToRenderableComponent(renderer, { id: "demo-root" }, [
263
+ Box({ id: "child-1", width: 20, height: 3, border: true, marginBottom: 1 }, [Text({ content: "Hello 4" })]),
264
+ Box({ id: "child-2", width: 24, height: 3, border: true }, [Text({ content: "VNode world 4" })]),
265
+ ])
266
+ mainGroup.add(renderableInstance)
267
+
268
+ // Delegated to __box4, would otherwise end up in the top-level group!
269
+ renderableInstance.add(Button({ title: "Click me too!", onClick: () => console.log("clicked"), borderColor: "red" }))
270
+
271
+ //
272
+ // Add animated VNode button
273
+ mainGroup.add(
274
+ VNodeButton({
275
+ title: "Animated VNode",
276
+ onClick: () => console.log("vnode 1 clicked"),
277
+ borderColor: RGBA.fromInts(0, 0, 255, 255),
278
+ }),
279
+ )
280
+ mainGroup.add(
281
+ VNodeButton({
282
+ title: "Same VNode, different props",
283
+ onClick: () => console.log("vnode 2 clicked"),
284
+ borderColor: RGBA.fromInts(255, 0, 255, 255),
285
+ }),
286
+ )
287
+
288
+ //
289
+ // Add button with class render function
290
+ mainGroup.add(
291
+ ButtonWithClassRender({
292
+ marginLeft: 1,
293
+ title: "ClassRender",
294
+ onClick: () => console.log("clicked"),
295
+ borderColor: RGBA.fromInts(0, 0, 255, 255),
296
+ }),
297
+ )
298
+
299
+ mainGroup.add(
300
+ Box({ flexDirection: "column", marginTop: 2 }, [
301
+ // Basic styles
302
+ Text({}, bold("Bold Text")),
303
+ Text({}, italic("Italic Text")),
304
+ Text({}, underline("Underlined Text")),
305
+ Text({}, dim("Dim Text")),
306
+
307
+ // Combined styles
308
+ Text({}, boldItalic("Bold and Italic")),
309
+ Text({}, boldUnderline("Bold and Underlined")),
310
+ Text({}, italicUnderline("Italic and Underlined")),
311
+
312
+ // Colors
313
+ Text({}, color("#ff6b6b", "Red Text")),
314
+ Text({}, bgColor("#4ecdc4", "Text with Background")),
315
+
316
+ // Custom styling
317
+ Text({}, styled(TextAttributes.BOLD | TextAttributes.UNDERLINE, "Custom Styled")),
318
+
319
+ // Stacked styles
320
+ Text({}, bold(underline("hello"), " world")),
321
+ Text({}, color("#ff6b6b", bold("Bold Red"), " normal")),
322
+ Text({}, italic(color("#4ecdc4", "Green Italic"), " normal again")),
323
+ ]),
324
+ )
325
+ }
326
+
327
+ export function destroy(renderer: CliRenderer) {
328
+ renderer.root.getRenderable("main-group")?.destroyRecursively()
329
+ renderer.requestRender()
330
+ }
331
+
332
+ if (import.meta.main) {
333
+ const renderer = await createCliRenderer({
334
+ exitOnCtrlC: true,
335
+ })
336
+
337
+ run(renderer)
338
+ setupCommonDemoKeys(renderer)
339
+ renderer.start()
340
+ }
341
+
342
+ function demoRenderFn(
343
+ props: { title: string; borderColor?: RGBA },
344
+ buffer: OptimizedBuffer,
345
+ deltaTime: number,
346
+ renderable: Renderable,
347
+ ) {
348
+ const x = renderable.x
349
+ const y = renderable.y
350
+ const width = renderable.width
351
+ const height = renderable.height
352
+
353
+ const borderColor = props.borderColor ?? RGBA.fromInts(255, 255, 0, 255)
354
+
355
+ // Draw a simple animated button with pulsing border
356
+ const timeInSeconds = Date.now() / 1000
357
+ const pulse = Math.sin(timeInSeconds * 4) * 0.5 + 0.5 // Fast pulsing, 0-1 oscillation
358
+
359
+ const pulsingBorderColor = RGBA.fromValues(
360
+ borderColor.r * (0.1 + pulse * 0.9),
361
+ borderColor.g * (0.1 + pulse * 0.9),
362
+ borderColor.b * (0.1 + pulse * 0.9),
363
+ borderColor.a,
364
+ )
365
+
366
+ const bgPulse = Math.sin(timeInSeconds * 2 + Math.PI / 2) * 0.4 + 0.6 // Different frequency and phase
367
+ const pulsingBgColor = RGBA.fromValues(
368
+ globalbgColor.r * bgPulse,
369
+ globalbgColor.g * bgPulse,
370
+ globalbgColor.b * bgPulse,
371
+ globalbgColor.a,
372
+ )
373
+
374
+ for (let row = 0; row < height; row++) {
375
+ for (let col = 0; col < width; col++) {
376
+ const isTop = row === 0
377
+ const isBottom = row === height - 1
378
+ const isLeft = col === 0
379
+ const isRight = col === width - 1
380
+ const isBorder = isTop || isBottom || isLeft || isRight
381
+
382
+ if (isBorder) {
383
+ buffer.setCell(x + col, y + row, "█", pulsingBorderColor, pulsingBgColor)
384
+ } else {
385
+ buffer.setCell(x + col, y + row, " ", textColor, pulsingBgColor)
386
+ }
387
+ }
388
+ }
389
+
390
+ const titlePulse = Math.sin(timeInSeconds * 6) * 0.5 + 0.5 // Even faster text pulse
391
+ const textScale = 0.3 + titlePulse * 0.7
392
+ const pulsingTextColor = RGBA.fromValues(
393
+ textColor.r * textScale,
394
+ textColor.g * textScale,
395
+ textColor.b * textScale,
396
+ textColor.a,
397
+ )
398
+
399
+ const titleX = x + Math.floor((width - props.title.length) / 2)
400
+ const titleY = y + Math.floor(height / 2)
401
+ if (titleY >= y && titleY < y + height) {
402
+ buffer.drawText(props.title, titleX, titleY, pulsingTextColor, transparent)
403
+ }
404
+ }
@@ -0,0 +1,280 @@
1
+ import {
2
+ createCliRenderer,
3
+ FrameBufferRenderable,
4
+ RGBA,
5
+ TextRenderable,
6
+ BoxRenderable,
7
+ OptimizedBuffer,
8
+ t,
9
+ bold,
10
+ underline,
11
+ fg,
12
+ type MouseEvent,
13
+ type KeyEvent,
14
+ } from "../index.js"
15
+ import type { CliRenderer, RenderContext } from "../index.js"
16
+ import { setupCommonDemoKeys } from "./lib/standalone-keys.js"
17
+
18
+ const GRAPHEME_LINES: string[] = [
19
+ "東京都 北京市 서울시 大阪府 名古屋 横浜市 上海市",
20
+ "👨‍👩‍👧‍👦 👩🏽‍💻 🏳️‍🌈 🇺🇸 🇩🇪 🇯🇵 🇮🇳 家族 絵文字 🎉🎊🎈",
21
+ "こんにちは世界 你好世界 안녕하세요 สวัสดี مرحبا",
22
+ "漢字テスト 中文测试 한국어 日本語 繁體中文 简体中文",
23
+ "🚀 Full-width: ABCDEF Half: abcdef ½ ⅞ ⅓",
24
+ "混合テキスト mixed text with 漢字 and emoji 🎯",
25
+ ]
26
+
27
+ const HEADER_HEIGHT = 2
28
+
29
+ let nextZIndex = 101
30
+ let draggableBoxes: DraggableBox[] = []
31
+ let scrimVisible = false
32
+ let scrim: BoxRenderable | null = null
33
+ let headerDisplay: TextRenderable | null = null
34
+
35
+ class DraggableBox extends BoxRenderable {
36
+ private isDragging = false
37
+ private dragOffsetX = 0
38
+ private dragOffsetY = 0
39
+ private alphaPercentage: number
40
+
41
+ constructor(
42
+ ctx: RenderContext,
43
+ id: string,
44
+ x: number,
45
+ y: number,
46
+ width: number,
47
+ height: number,
48
+ bg: RGBA,
49
+ zIndex: number,
50
+ ) {
51
+ super(ctx, {
52
+ id,
53
+ width,
54
+ height,
55
+ zIndex,
56
+ backgroundColor: bg,
57
+ position: "absolute",
58
+ left: x,
59
+ top: y,
60
+ })
61
+ this.alphaPercentage = Math.round(bg.a * 100)
62
+ }
63
+
64
+ protected renderSelf(buffer: OptimizedBuffer): void {
65
+ super.renderSelf(buffer)
66
+
67
+ const alphaText = `${this.alphaPercentage}%`
68
+ const centerX = this.x + Math.floor(this.width / 2 - alphaText.length / 2)
69
+ const centerY = this.y + Math.floor(this.height / 2)
70
+
71
+ buffer.drawText(alphaText, centerX, centerY, RGBA.fromInts(255, 255, 255, 220))
72
+ }
73
+
74
+ protected onMouseEvent(event: MouseEvent): void {
75
+ switch (event.type) {
76
+ case "down":
77
+ this.isDragging = true
78
+ this.dragOffsetX = event.x - this.x
79
+ this.dragOffsetY = event.y - this.y
80
+ this.zIndex = nextZIndex++
81
+ event.stopPropagation()
82
+ break
83
+
84
+ case "drag-end":
85
+ if (this.isDragging) {
86
+ this.isDragging = false
87
+ event.stopPropagation()
88
+ }
89
+ break
90
+
91
+ case "drag":
92
+ if (this.isDragging) {
93
+ const newX = event.x - this.dragOffsetX
94
+ const newY = event.y - this.dragOffsetY
95
+
96
+ this.x = Math.max(0, Math.min(newX, this._ctx.width - this.width))
97
+ this.y = Math.max(0, Math.min(newY, this._ctx.height - this.height))
98
+
99
+ event.stopPropagation()
100
+ }
101
+ break
102
+ }
103
+ }
104
+ }
105
+
106
+ class GraphemeBackground extends FrameBufferRenderable {
107
+ constructor(ctx: RenderContext, id: string, width: number, height: number) {
108
+ super(ctx, {
109
+ id,
110
+ width,
111
+ height,
112
+ position: "absolute",
113
+ left: 0,
114
+ top: HEADER_HEIGHT,
115
+ respectAlpha: false,
116
+ })
117
+
118
+ this.fillGraphemes(width, height)
119
+ }
120
+
121
+ private fillGraphemes(width: number, height: number) {
122
+ const fgColor = RGBA.fromInts(220, 220, 220, 255)
123
+ const bgColor = RGBA.fromInts(10, 14, 20, 255)
124
+ this.frameBuffer.clear(bgColor)
125
+ for (let y = 0; y < height; y++) {
126
+ const line = GRAPHEME_LINES[y % GRAPHEME_LINES.length]
127
+ this.frameBuffer.drawText(line, 2, y, fgColor, bgColor)
128
+ }
129
+ }
130
+ }
131
+
132
+ function toggleScrim(renderer: CliRenderer) {
133
+ scrimVisible = !scrimVisible
134
+ if (scrim) scrim.visible = scrimVisible
135
+ updateHeader()
136
+ renderer.requestRender()
137
+ }
138
+
139
+ function updateHeader() {
140
+ if (!headerDisplay) return
141
+ const dimLabel = scrimVisible ? "D: hide scrim" : "D: show scrim"
142
+ headerDisplay.content = t`${bold(fg("#00D4AA")("Wide Grapheme Overlay"))} ${fg("#A8A8B2")(`| ${dimLabel} | Drag boxes over CJK/emoji | Ctrl+C: quit`)}`
143
+ }
144
+
145
+ export function run(renderer: CliRenderer): void {
146
+ renderer.start()
147
+ renderer.setBackgroundColor("#0A0E14")
148
+
149
+ const root = new BoxRenderable(renderer, { id: "wg-overlay-root" })
150
+ renderer.root.add(root)
151
+
152
+ // Header row
153
+ headerDisplay = new TextRenderable(renderer, {
154
+ id: "wg-header",
155
+ height: HEADER_HEIGHT,
156
+ position: "absolute",
157
+ left: 2,
158
+ top: 0,
159
+ zIndex: 200,
160
+ selectable: false,
161
+ })
162
+ updateHeader()
163
+ root.add(headerDisplay)
164
+
165
+ // Background filled with repeating wide grapheme lines, below the header
166
+ const bgHeight = renderer.terminalHeight - HEADER_HEIGHT
167
+ const background = new GraphemeBackground(renderer, "wg-background", renderer.terminalWidth, bgHeight)
168
+ root.add(background)
169
+
170
+ // Full-screen dimming scrim (same as opencode dialog backdrop: RGBA(0,0,0,150))
171
+ scrim = new BoxRenderable(renderer, {
172
+ id: "wg-scrim",
173
+ position: "absolute",
174
+ left: 0,
175
+ top: HEADER_HEIGHT,
176
+ width: renderer.terminalWidth,
177
+ height: bgHeight,
178
+ backgroundColor: RGBA.fromInts(0, 0, 0, 150),
179
+ zIndex: 50,
180
+ })
181
+ scrim.visible = false
182
+ root.add(scrim)
183
+
184
+ // Draggable boxes at various alpha levels
185
+ const box1 = new DraggableBox(
186
+ renderer,
187
+ "wg-box-50",
188
+ 4,
189
+ HEADER_HEIGHT + 1,
190
+ 25,
191
+ 8,
192
+ RGBA.fromValues(64 / 255, 176 / 255, 255 / 255, 128 / 255),
193
+ 100,
194
+ )
195
+ root.add(box1)
196
+ draggableBoxes.push(box1)
197
+
198
+ const box2 = new DraggableBox(
199
+ renderer,
200
+ "wg-box-75",
201
+ 20,
202
+ HEADER_HEIGHT + 5,
203
+ 25,
204
+ 8,
205
+ RGBA.fromValues(255 / 255, 107 / 255, 129 / 255, 192 / 255),
206
+ 100,
207
+ )
208
+ root.add(box2)
209
+ draggableBoxes.push(box2)
210
+
211
+ const box3 = new DraggableBox(
212
+ renderer,
213
+ "wg-box-25",
214
+ 40,
215
+ HEADER_HEIGHT + 3,
216
+ 25,
217
+ 8,
218
+ RGBA.fromValues(139 / 255, 69 / 255, 193 / 255, 64 / 255),
219
+ 100,
220
+ )
221
+ root.add(box3)
222
+ draggableBoxes.push(box3)
223
+
224
+ const box4 = new DraggableBox(
225
+ renderer,
226
+ "wg-box-opaque",
227
+ 60,
228
+ HEADER_HEIGHT + 7,
229
+ 25,
230
+ 8,
231
+ RGBA.fromValues(30 / 255, 30 / 255, 42 / 255, 1.0),
232
+ 100,
233
+ )
234
+ root.add(box4)
235
+ draggableBoxes.push(box4)
236
+
237
+ renderer.keyInput.on("keypress", (key: KeyEvent) => {
238
+ if (key.name === "d") {
239
+ key.preventDefault()
240
+ toggleScrim(renderer)
241
+ }
242
+ })
243
+
244
+ renderer.on("resize", (width: number, height: number) => {
245
+ const h = height - HEADER_HEIGHT
246
+ background.width = width
247
+ background.height = h
248
+ if (scrim) {
249
+ scrim.width = width
250
+ scrim.height = h
251
+ }
252
+ renderer.requestRender()
253
+ })
254
+ }
255
+
256
+ export function destroy(renderer: CliRenderer): void {
257
+ renderer.clearFrameCallbacks()
258
+
259
+ for (const box of draggableBoxes) {
260
+ renderer.root.remove(box.id)
261
+ }
262
+ draggableBoxes = []
263
+ nextZIndex = 101
264
+ scrimVisible = false
265
+ scrim = null
266
+ headerDisplay = null
267
+
268
+ renderer.root.remove("wg-overlay-root")
269
+ renderer.setCursorPosition(0, 0, false)
270
+ }
271
+
272
+ if (import.meta.main) {
273
+ const renderer = await createCliRenderer({
274
+ exitOnCtrlC: true,
275
+ })
276
+
277
+ run(renderer)
278
+ setupCommonDemoKeys(renderer)
279
+ renderer.start()
280
+ }
package/src/index.ts ADDED
@@ -0,0 +1,24 @@
1
+ // Core exports without 3D dependencies
2
+ export * from "./Renderable.js"
3
+ export * from "./types.js"
4
+ export * from "./utils.js"
5
+ export * from "./buffer.js"
6
+ export * from "./text-buffer.js"
7
+ export * from "./text-buffer-view.js"
8
+ export * from "./edit-buffer.js"
9
+ export * from "./editor-view.js"
10
+ export * from "./syntax-style.js"
11
+ export * from "./post/effects.js"
12
+ export * from "./post/filters.js"
13
+ export * from "./post/matrices.js"
14
+ export * from "./animation/Timeline.js"
15
+ export * from "./lib/index.js"
16
+ export * from "./renderer.js"
17
+ export * from "./plugins/types.js"
18
+ export * from "./plugins/registry.js"
19
+ export * from "./plugins/core-slot.js"
20
+ export * from "./NativeSpanFeed.js"
21
+ export * from "./renderables/index.js"
22
+ export * from "./zig.js"
23
+ export * from "./console.js"
24
+ export * as Yoga from "yoga-layout"