termcast 1.3.19 → 1.3.24

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 (412) hide show
  1. package/dist/ai.d.ts +104 -0
  2. package/dist/ai.d.ts.map +1 -0
  3. package/dist/ai.js +135 -0
  4. package/dist/ai.js.map +1 -0
  5. package/dist/apis/browser-extension.d.ts +18 -0
  6. package/dist/apis/browser-extension.d.ts.map +1 -0
  7. package/dist/apis/browser-extension.js +14 -0
  8. package/dist/apis/browser-extension.js.map +1 -0
  9. package/dist/apis/localstorage.d.ts.map +1 -1
  10. package/dist/apis/localstorage.js +4 -7
  11. package/dist/apis/localstorage.js.map +1 -1
  12. package/dist/apis/oauth.d.ts.map +1 -1
  13. package/dist/apis/oauth.js +5 -1
  14. package/dist/apis/oauth.js.map +1 -1
  15. package/dist/apis/preferences.d.ts.map +1 -1
  16. package/dist/apis/preferences.js +38 -19
  17. package/dist/apis/preferences.js.map +1 -1
  18. package/dist/build.d.ts.map +1 -1
  19. package/dist/build.js +2 -1
  20. package/dist/build.js.map +1 -1
  21. package/dist/cache.d.ts +32 -0
  22. package/dist/cache.d.ts.map +1 -0
  23. package/dist/cache.js +205 -0
  24. package/dist/cache.js.map +1 -0
  25. package/dist/cli.d.ts.map +1 -1
  26. package/dist/cli.js +69 -33
  27. package/dist/cli.js.map +1 -1
  28. package/dist/clipboard.d.ts +36 -0
  29. package/dist/clipboard.d.ts.map +1 -0
  30. package/dist/clipboard.js +154 -0
  31. package/dist/clipboard.js.map +1 -0
  32. package/dist/compile.d.ts.map +1 -1
  33. package/dist/compile.js +24 -6
  34. package/dist/compile.js.map +1 -1
  35. package/dist/components/actions.d.ts.map +1 -1
  36. package/dist/components/actions.js +56 -30
  37. package/dist/components/actions.js.map +1 -1
  38. package/dist/components/detail.d.ts.map +1 -1
  39. package/dist/components/detail.js +4 -0
  40. package/dist/components/detail.js.map +1 -1
  41. package/dist/components/dropdown.d.ts.map +1 -1
  42. package/dist/components/dropdown.js +38 -15
  43. package/dist/components/dropdown.js.map +1 -1
  44. package/dist/components/extension-preferences.d.ts.map +1 -1
  45. package/dist/components/extension-preferences.js +40 -13
  46. package/dist/components/extension-preferences.js.map +1 -1
  47. package/dist/components/form/checkbox.d.ts.map +1 -1
  48. package/dist/components/form/checkbox.js +5 -3
  49. package/dist/components/form/checkbox.js.map +1 -1
  50. package/dist/components/form/date-picker.d.ts.map +1 -1
  51. package/dist/components/form/date-picker.js +5 -3
  52. package/dist/components/form/date-picker.js.map +1 -1
  53. package/dist/components/form/description.d.ts.map +1 -1
  54. package/dist/components/form/description.js +2 -2
  55. package/dist/components/form/description.js.map +1 -1
  56. package/dist/components/form/dropdown.d.ts.map +1 -1
  57. package/dist/components/form/dropdown.js +84 -80
  58. package/dist/components/form/dropdown.js.map +1 -1
  59. package/dist/components/form/file-autocomplete.d.ts +3 -6
  60. package/dist/components/form/file-autocomplete.d.ts.map +1 -1
  61. package/dist/components/form/file-autocomplete.js +61 -66
  62. package/dist/components/form/file-autocomplete.js.map +1 -1
  63. package/dist/components/form/file-picker.d.ts.map +1 -1
  64. package/dist/components/form/file-picker.js +33 -30
  65. package/dist/components/form/file-picker.js.map +1 -1
  66. package/dist/components/form/form-end.d.ts.map +1 -1
  67. package/dist/components/form/form-end.js +21 -1
  68. package/dist/components/form/form-end.js.map +1 -1
  69. package/dist/components/form/form-type-only.d.ts +174 -0
  70. package/dist/components/form/form-type-only.d.ts.map +1 -0
  71. package/dist/components/form/form-type-only.js +2 -0
  72. package/dist/components/form/form-type-only.js.map +1 -0
  73. package/dist/components/form/index.d.ts +3 -1
  74. package/dist/components/form/index.d.ts.map +1 -1
  75. package/dist/components/form/index.js +100 -28
  76. package/dist/components/form/index.js.map +1 -1
  77. package/dist/components/form/password-field.d.ts.map +1 -1
  78. package/dist/components/form/password-field.js +5 -3
  79. package/dist/components/form/password-field.js.map +1 -1
  80. package/dist/components/form/text-area.d.ts.map +1 -1
  81. package/dist/components/form/text-area.js +5 -3
  82. package/dist/components/form/text-area.js.map +1 -1
  83. package/dist/components/form/text-field.d.ts.map +1 -1
  84. package/dist/components/form/text-field.js +6 -4
  85. package/dist/components/form/text-field.js.map +1 -1
  86. package/dist/components/form/types.d.ts +5 -0
  87. package/dist/components/form/types.d.ts.map +1 -1
  88. package/dist/components/form/use-form-handling.d.ts +4 -0
  89. package/dist/components/form/use-form-handling.d.ts.map +1 -0
  90. package/dist/components/form/use-form-handling.js +37 -0
  91. package/dist/components/form/use-form-handling.js.map +1 -0
  92. package/dist/components/form/with-left-border.d.ts +2 -1
  93. package/dist/components/form/with-left-border.d.ts.map +1 -1
  94. package/dist/components/form/with-left-border.js +27 -3
  95. package/dist/components/form/with-left-border.js.map +1 -1
  96. package/dist/components/icon.d.ts +1 -0
  97. package/dist/components/icon.d.ts.map +1 -1
  98. package/dist/components/icon.js +24 -8
  99. package/dist/components/icon.js.map +1 -1
  100. package/dist/components/list.d.ts +2 -2
  101. package/dist/components/list.d.ts.map +1 -1
  102. package/dist/components/list.js +140 -62
  103. package/dist/components/list.js.map +1 -1
  104. package/dist/components/loading-bar.d.ts.map +1 -1
  105. package/dist/components/loading-bar.js +2 -2
  106. package/dist/components/loading-bar.js.map +1 -1
  107. package/dist/components/loading-text.d.ts +8 -0
  108. package/dist/components/loading-text.d.ts.map +1 -0
  109. package/dist/components/loading-text.js +58 -0
  110. package/dist/components/loading-text.js.map +1 -0
  111. package/dist/descendants.js +1 -1
  112. package/dist/descendants.js.map +1 -1
  113. package/dist/dev-ui.d.ts +7 -0
  114. package/dist/dev-ui.d.ts.map +1 -0
  115. package/dist/dev-ui.js +118 -0
  116. package/dist/dev-ui.js.map +1 -0
  117. package/dist/environment.d.ts +63 -0
  118. package/dist/environment.d.ts.map +1 -0
  119. package/dist/environment.js +189 -0
  120. package/dist/environment.js.map +1 -0
  121. package/dist/examples/datepicker.d.ts +2 -0
  122. package/dist/examples/datepicker.d.ts.map +1 -0
  123. package/dist/examples/datepicker.js +344 -0
  124. package/dist/examples/datepicker.js.map +1 -0
  125. package/dist/examples/file-autocomplete.vitest.d.ts +2 -0
  126. package/dist/examples/file-autocomplete.vitest.d.ts.map +1 -0
  127. package/dist/examples/file-autocomplete.vitest.js +223 -0
  128. package/dist/examples/file-autocomplete.vitest.js.map +1 -0
  129. package/dist/examples/form-basic-arrow-keys.vitest.d.ts +2 -0
  130. package/dist/examples/form-basic-arrow-keys.vitest.d.ts.map +1 -0
  131. package/dist/examples/form-basic-arrow-keys.vitest.js +46 -0
  132. package/dist/examples/form-basic-arrow-keys.vitest.js.map +1 -0
  133. package/dist/examples/form-basic.vitest.d.ts +2 -0
  134. package/dist/examples/form-basic.vitest.d.ts.map +1 -0
  135. package/dist/examples/form-basic.vitest.js +630 -0
  136. package/dist/examples/form-basic.vitest.js.map +1 -0
  137. package/dist/examples/form-dropdown-with-sections.d.ts +2 -0
  138. package/dist/examples/form-dropdown-with-sections.d.ts.map +1 -0
  139. package/dist/examples/form-dropdown-with-sections.js +13 -0
  140. package/dist/examples/form-dropdown-with-sections.js.map +1 -0
  141. package/dist/examples/form-dropdown-with-sections.vitest.d.ts +2 -0
  142. package/dist/examples/form-dropdown-with-sections.vitest.d.ts.map +1 -0
  143. package/dist/examples/form-dropdown-with-sections.vitest.js +75 -0
  144. package/dist/examples/form-dropdown-with-sections.vitest.js.map +1 -0
  145. package/dist/examples/form-dropdown.vitest.d.ts +2 -0
  146. package/dist/examples/form-dropdown.vitest.d.ts.map +1 -0
  147. package/dist/examples/form-dropdown.vitest.js +854 -0
  148. package/dist/examples/form-dropdown.vitest.js.map +1 -0
  149. package/dist/examples/form-multiselect-dropdown.d.ts +2 -0
  150. package/dist/examples/form-multiselect-dropdown.d.ts.map +1 -0
  151. package/dist/examples/form-multiselect-dropdown.js +13 -0
  152. package/dist/examples/form-multiselect-dropdown.js.map +1 -0
  153. package/dist/examples/form-scroll.d.ts.map +1 -1
  154. package/dist/examples/form-scroll.js +7 -1
  155. package/dist/examples/form-scroll.js.map +1 -1
  156. package/dist/examples/form-scroll.vitest.d.ts +2 -0
  157. package/dist/examples/form-scroll.vitest.d.ts.map +1 -0
  158. package/dist/examples/form-scroll.vitest.js +211 -0
  159. package/dist/examples/form-scroll.vitest.js.map +1 -0
  160. package/dist/examples/form-tagpicker.vitest.d.ts +2 -0
  161. package/dist/examples/form-tagpicker.vitest.d.ts.map +1 -0
  162. package/dist/examples/form-tagpicker.vitest.js +736 -0
  163. package/dist/examples/form-tagpicker.vitest.js.map +1 -0
  164. package/dist/examples/internal/descendants-filtering.js +1 -1
  165. package/dist/examples/internal/descendants-filtering.js.map +1 -1
  166. package/dist/examples/internal/descendants.js +1 -1
  167. package/dist/examples/internal/descendants.js.map +1 -1
  168. package/dist/examples/internal/nested-boxes.d.ts +2 -0
  169. package/dist/examples/internal/nested-boxes.d.ts.map +1 -0
  170. package/dist/examples/internal/nested-boxes.js +7 -0
  171. package/dist/examples/internal/nested-boxes.js.map +1 -0
  172. package/dist/examples/internal/rhf-custom-ref.js +2 -2
  173. package/dist/examples/internal/rhf-custom-ref.js.map +1 -1
  174. package/dist/examples/internal/scrollbox-demo.js +3 -22
  175. package/dist/examples/internal/scrollbox-demo.js.map +1 -1
  176. package/dist/examples/internal/scrollbox-descendants.d.ts +2 -0
  177. package/dist/examples/internal/scrollbox-descendants.d.ts.map +1 -0
  178. package/dist/examples/internal/scrollbox-descendants.js +83 -0
  179. package/dist/examples/internal/scrollbox-descendants.js.map +1 -0
  180. package/dist/examples/internal/scrollbox-with-descendants.js +4 -8
  181. package/dist/examples/internal/scrollbox-with-descendants.js.map +1 -1
  182. package/dist/examples/internal/simple-scrollbox.vitest.d.ts +2 -0
  183. package/dist/examples/internal/simple-scrollbox.vitest.d.ts.map +1 -0
  184. package/dist/examples/internal/simple-scrollbox.vitest.js +96 -0
  185. package/dist/examples/internal/simple-scrollbox.vitest.js.map +1 -0
  186. package/dist/examples/internal/unicode-square-repro.d.ts +2 -0
  187. package/dist/examples/internal/unicode-square-repro.d.ts.map +1 -0
  188. package/dist/examples/internal/unicode-square-repro.js +7 -0
  189. package/dist/examples/internal/unicode-square-repro.js.map +1 -0
  190. package/dist/examples/list-detail-metadata.d.ts +2 -0
  191. package/dist/examples/list-detail-metadata.d.ts.map +1 -0
  192. package/dist/examples/list-detail-metadata.js +8 -0
  193. package/dist/examples/list-detail-metadata.js.map +1 -0
  194. package/dist/examples/list-dropdown-default.vitest.d.ts +2 -0
  195. package/dist/examples/list-dropdown-default.vitest.d.ts.map +1 -0
  196. package/dist/examples/list-dropdown-default.vitest.js +234 -0
  197. package/dist/examples/list-dropdown-default.vitest.js.map +1 -0
  198. package/dist/examples/list-fetch-data.vitest.d.ts +2 -0
  199. package/dist/examples/list-fetch-data.vitest.d.ts.map +1 -0
  200. package/dist/examples/list-fetch-data.vitest.js +111 -0
  201. package/dist/examples/list-fetch-data.vitest.js.map +1 -0
  202. package/dist/examples/list-filter-navigation.d.ts +2 -0
  203. package/dist/examples/list-filter-navigation.d.ts.map +1 -0
  204. package/dist/examples/list-filter-navigation.js +8 -0
  205. package/dist/examples/list-filter-navigation.js.map +1 -0
  206. package/dist/examples/list-scrollbox.vitest.d.ts +2 -0
  207. package/dist/examples/list-scrollbox.vitest.d.ts.map +1 -0
  208. package/dist/examples/list-scrollbox.vitest.js +93 -0
  209. package/dist/examples/list-scrollbox.vitest.js.map +1 -0
  210. package/dist/examples/list-with-detail-long.d.ts +2 -0
  211. package/dist/examples/list-with-detail-long.d.ts.map +1 -0
  212. package/dist/examples/list-with-detail-long.js +53 -0
  213. package/dist/examples/list-with-detail-long.js.map +1 -0
  214. package/dist/examples/list-with-detail.vitest.d.ts +2 -0
  215. package/dist/examples/list-with-detail.vitest.d.ts.map +1 -0
  216. package/dist/examples/list-with-detail.vitest.js +434 -0
  217. package/dist/examples/list-with-detail.vitest.js.map +1 -0
  218. package/dist/examples/list-with-dropdown.vitest.d.ts +2 -0
  219. package/dist/examples/list-with-dropdown.vitest.d.ts.map +1 -0
  220. package/dist/examples/list-with-dropdown.vitest.js +337 -0
  221. package/dist/examples/list-with-dropdown.vitest.js.map +1 -0
  222. package/dist/examples/list-with-sections.js +5 -1
  223. package/dist/examples/list-with-sections.js.map +1 -1
  224. package/dist/examples/list-with-sections.vitest.d.ts +2 -0
  225. package/dist/examples/list-with-sections.vitest.d.ts.map +1 -0
  226. package/dist/examples/list-with-sections.vitest.js +601 -0
  227. package/dist/examples/list-with-sections.vitest.js.map +1 -0
  228. package/dist/examples/scrollbox-vertical-centering.d.ts +6 -0
  229. package/dist/examples/scrollbox-vertical-centering.d.ts.map +1 -0
  230. package/dist/examples/scrollbox-vertical-centering.js +17 -0
  231. package/dist/examples/scrollbox-vertical-centering.js.map +1 -0
  232. package/dist/examples/simple-file-picker.vitest.d.ts +2 -0
  233. package/dist/examples/simple-file-picker.vitest.d.ts.map +1 -0
  234. package/dist/examples/simple-file-picker.vitest.js +678 -0
  235. package/dist/examples/simple-file-picker.vitest.js.map +1 -0
  236. package/dist/examples/simple-grid.vitest.d.ts +2 -0
  237. package/dist/examples/simple-grid.vitest.d.ts.map +1 -0
  238. package/dist/examples/simple-grid.vitest.js +521 -0
  239. package/dist/examples/simple-grid.vitest.js.map +1 -0
  240. package/dist/examples/simple-navigation.js +10 -4
  241. package/dist/examples/simple-navigation.js.map +1 -1
  242. package/dist/examples/simple-navigation.vitest.d.ts +2 -0
  243. package/dist/examples/simple-navigation.vitest.d.ts.map +1 -0
  244. package/dist/examples/simple-navigation.vitest.js +718 -0
  245. package/dist/examples/simple-navigation.vitest.js.map +1 -0
  246. package/dist/examples/store.vitest.d.ts +2 -0
  247. package/dist/examples/store.vitest.d.ts.map +1 -0
  248. package/dist/examples/store.vitest.js +69 -0
  249. package/dist/examples/store.vitest.js.map +1 -0
  250. package/dist/extensions/dev.d.ts +4 -2
  251. package/dist/extensions/dev.d.ts.map +1 -1
  252. package/dist/extensions/dev.js +61 -10
  253. package/dist/extensions/dev.js.map +1 -1
  254. package/dist/extensions/dev.vitest.d.ts +2 -0
  255. package/dist/extensions/dev.vitest.d.ts.map +1 -0
  256. package/dist/extensions/dev.vitest.js +197 -0
  257. package/dist/extensions/dev.vitest.js.map +1 -0
  258. package/dist/extensions/home.d.ts.map +1 -1
  259. package/dist/extensions/home.js +3 -0
  260. package/dist/extensions/home.js.map +1 -1
  261. package/dist/home-command.d.ts +8 -0
  262. package/dist/home-command.d.ts.map +1 -0
  263. package/dist/home-command.js +181 -0
  264. package/dist/home-command.js.map +1 -0
  265. package/dist/hover-repro.d.ts +2 -0
  266. package/dist/hover-repro.d.ts.map +1 -0
  267. package/dist/hover-repro.js +20 -0
  268. package/dist/hover-repro.js.map +1 -0
  269. package/dist/index.d.ts +1 -0
  270. package/dist/index.d.ts.map +1 -1
  271. package/dist/index.js +2 -0
  272. package/dist/index.js.map +1 -1
  273. package/dist/internal/dialog.d.ts +1 -0
  274. package/dist/internal/dialog.d.ts.map +1 -1
  275. package/dist/internal/dialog.js +27 -18
  276. package/dist/internal/dialog.js.map +1 -1
  277. package/dist/internal/navigation.d.ts +9 -1
  278. package/dist/internal/navigation.d.ts.map +1 -1
  279. package/dist/internal/navigation.js +5 -5
  280. package/dist/internal/navigation.js.map +1 -1
  281. package/dist/internal/offscreen.d.ts +6 -0
  282. package/dist/internal/offscreen.d.ts.map +1 -0
  283. package/dist/internal/offscreen.js +10 -0
  284. package/dist/internal/offscreen.js.map +1 -0
  285. package/dist/internal/providers.d.ts.map +1 -1
  286. package/dist/internal/providers.js +2 -2
  287. package/dist/internal/providers.js.map +1 -1
  288. package/dist/internal/scrollbox.d.ts +1 -10
  289. package/dist/internal/scrollbox.d.ts.map +1 -1
  290. package/dist/internal/scrollbox.js +2 -1
  291. package/dist/internal/scrollbox.js.map +1 -1
  292. package/dist/localstorage.d.ts +13 -0
  293. package/dist/localstorage.d.ts.map +1 -0
  294. package/dist/localstorage.js +190 -0
  295. package/dist/localstorage.js.map +1 -0
  296. package/dist/oauth.d.ts +142 -0
  297. package/dist/oauth.d.ts.map +1 -0
  298. package/dist/oauth.js +551 -0
  299. package/dist/oauth.js.map +1 -0
  300. package/dist/preferences.d.ts +23 -0
  301. package/dist/preferences.d.ts.map +1 -0
  302. package/dist/preferences.js +105 -0
  303. package/dist/preferences.js.map +1 -0
  304. package/dist/state.d.ts +2 -0
  305. package/dist/state.d.ts.map +1 -1
  306. package/dist/state.js +3 -0
  307. package/dist/state.js.map +1 -1
  308. package/dist/store.d.ts +21 -0
  309. package/dist/store.d.ts.map +1 -0
  310. package/dist/store.js +84 -0
  311. package/dist/store.js.map +1 -0
  312. package/dist/swift-loader.d.ts +3 -0
  313. package/dist/swift-loader.d.ts.map +1 -0
  314. package/dist/swift-loader.js +193 -0
  315. package/dist/swift-loader.js.map +1 -0
  316. package/dist/swift-runtime.d.ts +2 -0
  317. package/dist/swift-runtime.d.ts.map +1 -0
  318. package/dist/swift-runtime.js +27 -0
  319. package/dist/swift-runtime.js.map +1 -0
  320. package/dist/toast.d.ts +44 -0
  321. package/dist/toast.d.ts.map +1 -0
  322. package/dist/toast.js +221 -0
  323. package/dist/toast.js.map +1 -0
  324. package/dist/utils/file-system.d.ts +9 -0
  325. package/dist/utils/file-system.d.ts.map +1 -1
  326. package/dist/utils/file-system.js +49 -0
  327. package/dist/utils/file-system.js.map +1 -1
  328. package/dist/utils/run-command.d.ts +25 -1
  329. package/dist/utils/run-command.d.ts.map +1 -1
  330. package/dist/utils/run-command.js +47 -4
  331. package/dist/utils/run-command.js.map +1 -1
  332. package/dist/window.d.ts +12 -0
  333. package/dist/window.d.ts.map +1 -0
  334. package/dist/window.js +48 -0
  335. package/dist/window.js.map +1 -0
  336. package/package.json +13 -11
  337. package/src/apis/browser-extension.tsx +29 -0
  338. package/src/apis/localstorage.test.ts +14 -6
  339. package/src/apis/localstorage.tsx +8 -5
  340. package/src/apis/oauth.tsx +5 -1
  341. package/src/apis/preferences.tsx +48 -22
  342. package/src/build.test.tsx +52 -0
  343. package/src/build.tsx +2 -1
  344. package/src/cli.tsx +80 -39
  345. package/src/compile.tsx +24 -6
  346. package/src/components/actions.tsx +94 -32
  347. package/src/components/detail.tsx +4 -0
  348. package/src/components/dropdown.tsx +47 -14
  349. package/src/components/extension-preferences.tsx +44 -16
  350. package/src/components/form/checkbox.tsx +12 -6
  351. package/src/components/form/date-picker.tsx +12 -6
  352. package/src/components/form/description.tsx +7 -2
  353. package/src/components/form/dropdown.tsx +131 -119
  354. package/src/components/form/file-autocomplete.tsx +90 -108
  355. package/src/components/form/file-picker.tsx +54 -43
  356. package/src/components/form/form-end.tsx +23 -2
  357. package/src/components/form/index.tsx +152 -34
  358. package/src/components/form/password-field.tsx +12 -6
  359. package/src/components/form/text-area.tsx +13 -6
  360. package/src/components/form/text-field.tsx +13 -6
  361. package/src/components/form/types.tsx +6 -0
  362. package/src/components/form/with-left-border.tsx +41 -8
  363. package/src/components/icon.tsx +27 -8
  364. package/src/components/list.tsx +193 -74
  365. package/src/components/loading-bar.tsx +3 -2
  366. package/src/components/loading-text.tsx +79 -0
  367. package/src/descendants.tsx +1 -0
  368. package/src/examples/file-autocomplete.vitest.tsx +130 -125
  369. package/src/examples/form-basic.vitest.tsx +376 -176
  370. package/src/examples/form-dropdown.vitest.tsx +126 -126
  371. package/src/examples/form-scroll.tsx +2 -0
  372. package/src/examples/form-scroll.vitest.tsx +58 -58
  373. package/src/examples/form-tagpicker.vitest.tsx +99 -99
  374. package/src/examples/internal/descendants-filtering.tsx +1 -0
  375. package/src/examples/internal/descendants.tsx +1 -0
  376. package/src/examples/internal/rhf-custom-ref.tsx +2 -0
  377. package/src/examples/internal/scrollbox-demo.tsx +3 -27
  378. package/src/examples/internal/scrollbox-with-descendants.tsx +4 -7
  379. package/src/examples/internal/simple-scrollbox.vitest.tsx +7 -5
  380. package/src/examples/list-detail-metadata.tsx +49 -0
  381. package/src/examples/list-detail-metadata.vitest.tsx +88 -0
  382. package/src/examples/list-dropdown-default.vitest.tsx +51 -51
  383. package/src/examples/list-fetch-data.vitest.tsx +4 -4
  384. package/src/examples/list-scrollbox.vitest.tsx +73 -14
  385. package/src/examples/list-with-detail-long.tsx +70 -0
  386. package/src/examples/list-with-detail.vitest.tsx +198 -92
  387. package/src/examples/list-with-dropdown.vitest.tsx +53 -53
  388. package/src/examples/list-with-sections.tsx +1 -0
  389. package/src/examples/list-with-sections.vitest.tsx +213 -89
  390. package/src/examples/list-with-toast.vitest.tsx +4 -4
  391. package/src/examples/simple-file-picker.vitest.tsx +61 -471
  392. package/src/examples/simple-grid.vitest.tsx +238 -233
  393. package/src/examples/simple-navigation.tsx +15 -7
  394. package/src/examples/simple-navigation.vitest.tsx +121 -210
  395. package/src/examples/store.vitest.tsx +1 -1
  396. package/src/examples/swift-extension.vitest.tsx +148 -0
  397. package/src/examples/synonyms.vitest.tsx +159 -0
  398. package/src/extensions/dev.tsx +74 -7
  399. package/src/extensions/dev.vitest.tsx +97 -31
  400. package/src/extensions/home.tsx +6 -0
  401. package/src/index.tsx +3 -0
  402. package/src/internal/dialog.tsx +43 -30
  403. package/src/internal/navigation.tsx +3 -1
  404. package/src/internal/offscreen.tsx +15 -0
  405. package/src/internal/providers.tsx +4 -2
  406. package/src/internal/scrollbox.tsx +4 -8
  407. package/src/keyboard.test.tsx +69 -0
  408. package/src/state.tsx +7 -0
  409. package/src/swift-loader.tsx +239 -0
  410. package/src/swift-runtime.tsx +36 -0
  411. package/src/utils/file-system.ts +61 -0
  412. package/src/utils/run-command.tsx +75 -6
@@ -0,0 +1,344 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "@opentui/react/jsx-runtime";
2
+ import { render, useKeyboard } from '@opentui/react'; // renderer & hooks per docs
3
+ import { useMemo, useState, useRef } from 'react';
4
+ const MONTHS = [
5
+ 'January',
6
+ 'February',
7
+ 'March',
8
+ 'April',
9
+ 'May',
10
+ 'June',
11
+ 'July',
12
+ 'August',
13
+ 'September',
14
+ 'October',
15
+ 'November',
16
+ 'December',
17
+ ];
18
+ function daysInMonth(y, m) {
19
+ return new Date(y, m + 1, 0).getDate();
20
+ }
21
+ function startOfMonth(d) {
22
+ return new Date(d.getFullYear(), d.getMonth(), 1);
23
+ }
24
+ function sameDay(a, b) {
25
+ return (a.getFullYear() === b.getFullYear() &&
26
+ a.getMonth() === b.getMonth() &&
27
+ a.getDate() === b.getDate());
28
+ }
29
+ function addDays(d, delta) {
30
+ const nd = new Date(d);
31
+ nd.setDate(nd.getDate() + delta);
32
+ return nd;
33
+ }
34
+ function clampDay(y, m, day) {
35
+ return Math.min(day, daysInMonth(y, m));
36
+ }
37
+ function generateSixWeekGrid(viewDate, weekStartsOnMonday = true) {
38
+ // Strategy: 7x6 grid, include prev/next month days to fill 42 cells
39
+ const first = startOfMonth(viewDate);
40
+ const firstWeekday = first.getDay(); // 0=Sun..6=Sat
41
+ // For Monday start: Mon=0, Tue=1, ..., Sun=6
42
+ const offset = weekStartsOnMonday ? (firstWeekday + 6) % 7 : firstWeekday;
43
+ const grid = [];
44
+ const start = addDays(first, -offset);
45
+ for (let w = 0; w < 6; w++) {
46
+ const row = [];
47
+ for (let i = 0; i < 7; i++)
48
+ row.push(addDays(start, w * 7 + i));
49
+ grid.push(row);
50
+ }
51
+ return grid;
52
+ }
53
+ // ----- Component -----
54
+ function DatePicker({ enableColors = true, initialValue, onChange }) {
55
+ const today = useMemo(() => new Date(), []);
56
+ const [focus, setFocus] = useState('grid'); // can be "year" | "month" | "grid"
57
+ const [selected, setSelected] = useState(initialValue || new Date()); // focused day
58
+ const [visible, setVisible] = useState(startOfMonth(initialValue || new Date())); // month being shown
59
+ const [searchQuery, setSearchQuery] = useState(''); // for type-to-search
60
+ const searchTimeoutRef = useRef(null);
61
+ // Recompute 7x6 grid for the visible month (Monday start)
62
+ const weeks = useMemo(() => generateSixWeekGrid(visible, true), [visible]);
63
+ // Keep visible month synced when selected day moves across months
64
+ function ensureVisibleFor(date) {
65
+ const m = new Date(date.getFullYear(), date.getMonth(), 1);
66
+ const keyA = visible.getFullYear() * 12 + visible.getMonth();
67
+ const keyB = m.getFullYear() * 12 + m.getMonth();
68
+ if (keyA !== keyB)
69
+ setVisible(m);
70
+ }
71
+ function changeMonth(delta) {
72
+ const y = visible.getFullYear();
73
+ const m = visible.getMonth() + delta;
74
+ const newY = y + Math.floor(m / 12);
75
+ const newM = ((m % 12) + 12) % 12;
76
+ const day = clampDay(newY, newM, selected.getDate());
77
+ const newSel = new Date(newY, newM, day);
78
+ setVisible(new Date(newY, newM, 1));
79
+ setSelected(newSel);
80
+ }
81
+ function changeYear(delta) {
82
+ const y = visible.getFullYear() + delta;
83
+ const m = visible.getMonth();
84
+ const day = clampDay(y, m, selected.getDate());
85
+ const newSel = new Date(y, m, day);
86
+ setVisible(new Date(y, m, 1));
87
+ setSelected(newSel);
88
+ }
89
+ // Generate years list for search
90
+ const years = useMemo(() => {
91
+ const yearList = [];
92
+ for (let y = 1800; y <= 2200; y++) {
93
+ yearList.push(y);
94
+ }
95
+ return yearList;
96
+ }, []);
97
+ // Search functionality
98
+ function searchYear(query) {
99
+ const matches = years.filter((y) => y.toString().startsWith(query));
100
+ if (matches.length > 0) {
101
+ const newY = matches[0];
102
+ const m = visible.getMonth();
103
+ const day = clampDay(newY, m, selected.getDate());
104
+ const newSel = new Date(newY, m, day);
105
+ setVisible(new Date(newY, m, 1));
106
+ setSelected(newSel);
107
+ }
108
+ }
109
+ function searchMonth(query) {
110
+ // Search by month name or number
111
+ const lowerQuery = query.toLowerCase();
112
+ let monthIndex = -1;
113
+ // Try to match month name
114
+ for (let i = 0; i < MONTHS.length; i++) {
115
+ if (MONTHS[i].toLowerCase().startsWith(lowerQuery)) {
116
+ monthIndex = i;
117
+ break;
118
+ }
119
+ }
120
+ // Try to match month number
121
+ if (monthIndex === -1) {
122
+ const num = parseInt(query);
123
+ if (!isNaN(num) && num >= 1 && num <= 12) {
124
+ monthIndex = num - 1;
125
+ }
126
+ }
127
+ if (monthIndex !== -1) {
128
+ const y = visible.getFullYear();
129
+ const day = clampDay(y, monthIndex, selected.getDate());
130
+ const newSel = new Date(y, monthIndex, day);
131
+ setVisible(new Date(y, monthIndex, 1));
132
+ setSelected(newSel);
133
+ }
134
+ }
135
+ function searchDay(query) {
136
+ const day = parseInt(query);
137
+ if (!isNaN(day) && day >= 1 && day <= 31) {
138
+ const y = visible.getFullYear();
139
+ const m = visible.getMonth();
140
+ const clampedDay = clampDay(y, m, day);
141
+ const newSel = new Date(y, m, clampedDay);
142
+ setSelected(newSel);
143
+ }
144
+ }
145
+ // Keyboard interactions
146
+ useKeyboard((key) => {
147
+ // Handle type-to-search
148
+ if (key.name.length === 1 && /[0-9a-zA-Z]/.test(key.name)) {
149
+ const newQuery = searchQuery + key.name;
150
+ setSearchQuery(newQuery);
151
+ // Clear previous timeout
152
+ if (searchTimeoutRef.current) {
153
+ clearTimeout(searchTimeoutRef.current);
154
+ }
155
+ // Perform search based on current focus
156
+ if (focus === 'year') {
157
+ searchYear(newQuery);
158
+ }
159
+ else if (focus === 'month') {
160
+ searchMonth(newQuery);
161
+ }
162
+ else if (focus === 'grid') {
163
+ searchDay(newQuery);
164
+ }
165
+ // Reset search query after 1 second
166
+ searchTimeoutRef.current = setTimeout(() => {
167
+ setSearchQuery('');
168
+ }, 1000);
169
+ return;
170
+ }
171
+ switch (key.name) {
172
+ case 'left':
173
+ if (focus === 'grid') {
174
+ const next = addDays(selected, -1);
175
+ setSelected(next);
176
+ ensureVisibleFor(next);
177
+ }
178
+ else if (focus === 'month') {
179
+ changeMonth(-1);
180
+ }
181
+ else if (focus === 'year') {
182
+ changeYear(-1);
183
+ }
184
+ break;
185
+ case 'right':
186
+ if (focus === 'grid') {
187
+ const next = addDays(selected, +1);
188
+ setSelected(next);
189
+ ensureVisibleFor(next);
190
+ }
191
+ else if (focus === 'month') {
192
+ changeMonth(+1);
193
+ }
194
+ else if (focus === 'year') {
195
+ changeYear(+1);
196
+ }
197
+ break;
198
+ case 'up':
199
+ if (focus === 'grid') {
200
+ // Check if we're in the first row of the month
201
+ const firstDayOfMonth = new Date(selected.getFullYear(), selected.getMonth(), 1);
202
+ const daysDiff = selected.getDate() - 1;
203
+ if (daysDiff < 7) {
204
+ // Move focus to month
205
+ setFocus('month');
206
+ }
207
+ else {
208
+ const next = addDays(selected, -7);
209
+ setSelected(next);
210
+ ensureVisibleFor(next);
211
+ }
212
+ }
213
+ else if (focus === 'month') {
214
+ // Move focus to year
215
+ setFocus('year');
216
+ }
217
+ else if (focus === 'year') {
218
+ // Stay on year
219
+ }
220
+ break;
221
+ case 'down':
222
+ if (focus === 'grid') {
223
+ const next = addDays(selected, +7);
224
+ setSelected(next);
225
+ ensureVisibleFor(next);
226
+ }
227
+ else if (focus === 'year') {
228
+ // Move focus to month
229
+ setFocus('month');
230
+ }
231
+ else if (focus === 'month') {
232
+ // Move focus to grid
233
+ setFocus('grid');
234
+ }
235
+ break;
236
+ case 'tab':
237
+ if (key.shift) {
238
+ // Shift+Tab: Move focus up (grid -> month -> year)
239
+ setFocus((f) => f === 'grid'
240
+ ? 'month'
241
+ : f === 'month'
242
+ ? 'year'
243
+ : 'year');
244
+ }
245
+ else {
246
+ // Tab: Move focus down (year -> month -> grid)
247
+ setFocus((f) => f === 'year'
248
+ ? 'month'
249
+ : f === 'month'
250
+ ? 'grid'
251
+ : 'grid');
252
+ }
253
+ break;
254
+ case 'return': // Enter key
255
+ if (focus === 'grid' && onChange) {
256
+ onChange(selected);
257
+ }
258
+ break;
259
+ default:
260
+ break;
261
+ }
262
+ });
263
+ const y = visible.getFullYear();
264
+ const m = visible.getMonth();
265
+ const headerWidth = 21; // Match form.md width (7 cols * 3 width)
266
+ const cellStyle = {
267
+ width: 3,
268
+ height: 1,
269
+ alignItems: 'center',
270
+ justifyContent: 'center',
271
+ };
272
+ // Only show days from current month
273
+ const filteredWeeks = weeks.map((row) => row.map((d) => (d.getMonth() === m ? d : null)));
274
+ // Week starts Monday: Mo Tu We Th Fr Sa Su
275
+ const weekdayHeaders = ['Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa', 'Su'];
276
+ return (_jsxs("box", { style: {
277
+ flexDirection: 'column',
278
+ alignItems: 'center',
279
+ padding: 1,
280
+ }, children: [_jsx("box", { style: {
281
+ width: headerWidth,
282
+ height: 1,
283
+ backgroundColor: enableColors && focus === 'year'
284
+ ? '#1e40af'
285
+ : undefined,
286
+ marginBottom: 0,
287
+ }, onMouseDown: () => setFocus('year'), children: _jsxs("box", { style: {
288
+ flexDirection: 'row',
289
+ justifyContent: 'space-between',
290
+ alignItems: 'center',
291
+ width: headerWidth,
292
+ }, children: [_jsx("text", { fg: focus === 'year' ? '#FFFFFF' : '#666666', children: "\u2190" }), _jsx("text", { fg: focus === 'year' ? '#FFFFFF' : '#666666', children: String(y) }), _jsx("text", { fg: focus === 'year' ? '#FFFFFF' : '#666666', children: "\u2192" })] }) }), _jsx("box", { style: {
293
+ width: headerWidth,
294
+ height: 1,
295
+ backgroundColor: enableColors && focus === 'month'
296
+ ? '#1e40af'
297
+ : undefined,
298
+ marginBottom: 1,
299
+ }, onMouseDown: () => setFocus('month'), children: _jsxs("box", { style: {
300
+ flexDirection: 'row',
301
+ justifyContent: 'space-between',
302
+ alignItems: 'center',
303
+ width: headerWidth,
304
+ }, children: [_jsx("text", { fg: focus === 'month' ? '#FFFFFF' : '#666666', children: "\u2190" }), _jsx("text", { fg: focus === 'month' ? '#FFFFFF' : '#666666', children: MONTHS[m] }), _jsx("text", { fg: focus === 'month' ? '#FFFFFF' : '#666666', children: "\u2192" })] }) }), _jsx("box", { style: {
305
+ flexDirection: 'row',
306
+ width: headerWidth,
307
+ justifyContent: 'space-between',
308
+ marginBottom: 0,
309
+ }, children: weekdayHeaders.map((wd, idx) => (_jsx("box", { style: cellStyle, children: _jsx("text", { fg: enableColors && (idx === 5 || idx === 6)
310
+ ? '#dc2626'
311
+ : '#4b5563', children: wd }) }, wd))) }), _jsx("box", { style: { flexDirection: 'column' }, children: filteredWeeks.map((row, i) => {
312
+ // Skip empty rows
313
+ if (row.every((d) => d === null))
314
+ return null;
315
+ return (_jsx("box", { style: { flexDirection: 'row' }, children: row.map((d, j) => {
316
+ if (d === null) {
317
+ return (_jsx("box", { style: cellStyle, children: _jsx("text", { children: " " }) }, `${i}-${j}`));
318
+ }
319
+ const isSel = sameDay(d, selected);
320
+ const isToday = sameDay(d, today);
321
+ return (_jsx("box", { style: {
322
+ ...cellStyle,
323
+ backgroundColor: enableColors &&
324
+ isSel &&
325
+ focus === 'grid'
326
+ ? '#2563eb'
327
+ : undefined,
328
+ }, onMouseDown: () => {
329
+ setSelected(d);
330
+ setFocus('grid');
331
+ ensureVisibleFor(d);
332
+ }, children: _jsx("text", { fg: isSel && focus === 'grid'
333
+ ? '#FFFFFF'
334
+ : isToday && enableColors
335
+ ? '#3b82f6'
336
+ : enableColors &&
337
+ (j === 5 || j === 6)
338
+ ? '#dc2626'
339
+ : '#111827', children: String(d.getDate()).padStart(2, ' ') }) }, `${i}-${j}`));
340
+ }) }, i));
341
+ }) })] }));
342
+ }
343
+ render(_jsx("box", { style: { paddingTop: 6 }, children: _jsx(DatePicker, { enableColors: true, initialValue: new Date(2028, 7, 15), onChange: (date) => console.log('Selected date:', date) }) }));
344
+ //# sourceMappingURL=datepicker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"datepicker.js","sourceRoot":"","sources":["../../src/examples/datepicker.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=file-autocomplete.vitest.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file-autocomplete.vitest.d.ts","sourceRoot":"","sources":["../../src/examples/file-autocomplete.vitest.tsx"],"names":[],"mappings":""}
@@ -0,0 +1,223 @@
1
+ import { test, expect, afterEach, beforeEach } from 'vitest';
2
+ import { launchTerminal } from 'tuistory/src';
3
+ let session;
4
+ beforeEach(async () => {
5
+ session = await launchTerminal({
6
+ command: 'bun',
7
+ args: ['src/examples/simple-file-picker.tsx'],
8
+ cols: 70,
9
+ rows: 30,
10
+ });
11
+ });
12
+ afterEach(() => {
13
+ session?.close();
14
+ });
15
+ test('autocomplete shows on ./ input with proper background', async () => {
16
+ await session.text({
17
+ waitFor: (text) => text.includes('Select Files') && text.includes('Select Folder'),
18
+ });
19
+ await session.press('tab');
20
+ await session.press('tab');
21
+ await session.type('./');
22
+ const snapshot = await session.text({
23
+ waitFor: (text) => text.includes('📁'),
24
+ });
25
+ expect(snapshot).toMatchInlineSnapshot(`
26
+ "
27
+
28
+
29
+
30
+
31
+ ◇ Your Name
32
+ │ John Doe
33
+ │ ┌────────────────────────────────────────────────────────────┐
34
+ ◇ │ 📁 dist │
35
+ │ │ 📁 fixtures │
36
+ │ │ 📁 node_modules │
37
+ │ │ 📁 src │
38
+ │ │ ↑↓ navigate ⏎ open folder ⇥ select folder esc close │
39
+ ◆ └────────────────────────────────────────────────────────────┘
40
+ ┃ ./
41
+
42
+ ┃ Choose a folder for output
43
+
44
+ ◇ Select Single File
45
+ │ Enter file path...
46
+
47
+ │ Choose exactly one file
48
+
49
+
50
+
51
+
52
+
53
+
54
+ ctrl ↵ submit ↑↓ navigate ^k actions"
55
+ `);
56
+ }, 10000);
57
+ test('autocomplete dropdown covers background content', async () => {
58
+ await session.text({
59
+ waitFor: (text) => text.includes('Select Files'),
60
+ });
61
+ await session.press('tab');
62
+ await session.press('tab');
63
+ await session.type('src/');
64
+ const snapshot = await session.text({
65
+ waitFor: (text) => text.includes('📁 apis'),
66
+ });
67
+ expect(snapshot).toMatchInlineSnapshot(`
68
+ "
69
+
70
+
71
+ ┌────────────────────────────────────────────────────────────┐
72
+ │ 📁 apis │
73
+ ◇ │ 📁 components │
74
+ │ │ 📁 examples │
75
+ │ │ 📁 extensions │
76
+ ◇ │ 📁 hooks │
77
+ │ │ 📁 internal │
78
+ │ │ 📁 store-api │
79
+ │ │ 📁 utils │
80
+ │ │ ↑↓ navigate ⏎ open folder ⇥ select folder esc close │
81
+ ◆ └────────────────────────────────────────────────────────────┘
82
+ ┃ src/
83
+
84
+ ┃ Choose a folder for output
85
+
86
+ ◇ Select Single File
87
+ │ Enter file path...
88
+
89
+ │ Choose exactly one file
90
+
91
+
92
+
93
+
94
+
95
+
96
+ ctrl ↵ submit ↑↓ navigate ^k actions"
97
+ `);
98
+ }, 10000);
99
+ test('autocomplete navigation with down/up keys', async () => {
100
+ await session.text({
101
+ waitFor: (text) => text.includes('Select Files'),
102
+ });
103
+ await session.press('tab');
104
+ await session.press('tab');
105
+ await session.type('src/');
106
+ await session.text({
107
+ waitFor: (text) => text.includes('📁 apis'),
108
+ });
109
+ await session.press('down');
110
+ await session.press('down');
111
+ const afterDown = await session.text({});
112
+ expect(afterDown).toMatchInlineSnapshot(`
113
+ "
114
+
115
+
116
+ ┌────────────────────────────────────────────────────────────┐
117
+ │ 📁 apis │
118
+ ◇ │ 📁 components │
119
+ │ │ 📁 examples │
120
+ │ │ 📁 extensions │
121
+ ◇ │ 📁 hooks │
122
+ │ │ 📁 internal │
123
+ │ │ 📁 store-api │
124
+ │ │ 📁 utils │
125
+ │ │ ↑↓ navigate ⏎ open folder ⇥ select folder esc close │
126
+ ◆ └────────────────────────────────────────────────────────────┘
127
+ ┃ src/
128
+
129
+ ┃ Choose a folder for output
130
+
131
+ ◇ Select Single File
132
+ │ Enter file path...
133
+
134
+ │ Choose exactly one file
135
+
136
+
137
+
138
+
139
+
140
+
141
+ ctrl ↵ submit ↑↓ navigate ^k actions"
142
+ `);
143
+ await session.press('up');
144
+ const afterUp = await session.text({});
145
+ expect(afterUp).toMatchInlineSnapshot(`
146
+ "
147
+
148
+
149
+ ┌────────────────────────────────────────────────────────────┐
150
+ │ 📁 apis │
151
+ ◇ │ 📁 components │
152
+ │ │ 📁 examples │
153
+ │ │ 📁 extensions │
154
+ ◇ │ 📁 hooks │
155
+ │ │ 📁 internal │
156
+ │ │ 📁 store-api │
157
+ │ │ 📁 utils │
158
+ │ │ ↑↓ navigate ⏎ open folder ⇥ select folder esc close │
159
+ ◆ └────────────────────────────────────────────────────────────┘
160
+ ┃ src/
161
+
162
+ ┃ Choose a folder for output
163
+
164
+ ◇ Select Single File
165
+ │ Enter file path...
166
+
167
+ │ Choose exactly one file
168
+
169
+
170
+
171
+
172
+
173
+
174
+ ctrl ↵ submit ↑↓ navigate ^k actions"
175
+ `);
176
+ }, 10000);
177
+ test('escape closes autocomplete', async () => {
178
+ await session.text({
179
+ waitFor: (text) => text.includes('Select Files'),
180
+ });
181
+ await session.press('tab');
182
+ await session.press('tab');
183
+ await session.type('./');
184
+ await session.text({
185
+ waitFor: (text) => text.includes('📁'),
186
+ });
187
+ await session.press('esc');
188
+ const afterEsc = await session.text({
189
+ waitFor: (text) => !text.includes('📁'),
190
+ });
191
+ expect(afterEsc).toMatchInlineSnapshot(`
192
+ "
193
+
194
+
195
+
196
+
197
+ ◇ Your Name
198
+ │ John Doe
199
+
200
+ ◇ Select Files
201
+ │ Enter file path...
202
+
203
+ │ Choose one or more files to upload
204
+
205
+ ◆ Select Folder
206
+ ┃ ./
207
+
208
+ ┃ Choose a folder for output
209
+
210
+ ◇ Select Single File
211
+ │ Enter file path...
212
+
213
+ │ Choose exactly one file
214
+
215
+
216
+
217
+
218
+
219
+
220
+ ctrl ↵ submit ↑↓ navigate ^k actions"
221
+ `);
222
+ }, 10000);
223
+ //# sourceMappingURL=file-autocomplete.vitest.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file-autocomplete.vitest.js","sourceRoot":"","sources":["../../src/examples/file-autocomplete.vitest.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=form-basic-arrow-keys.vitest.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"form-basic-arrow-keys.vitest.d.ts","sourceRoot":"","sources":["../../src/examples/form-basic-arrow-keys.vitest.tsx"],"names":[],"mappings":""}
@@ -0,0 +1,46 @@
1
+ // node-pty does not work in bun, so we use vitest to run this test
2
+ import { test, expect, afterEach, beforeEach } from 'vitest';
3
+ import { NodeTuiDriver } from '@termcast/cli/src/e2e-node';
4
+ let driver;
5
+ beforeEach(() => {
6
+ driver = new NodeTuiDriver('bun', ['src/examples/form-basic.tsx'], {
7
+ cols: 70,
8
+ rows: 50,
9
+ });
10
+ });
11
+ afterEach(() => {
12
+ driver?.dispose();
13
+ });
14
+ test('form navigation with arrow keys and ctrl+k', async () => {
15
+ await driver.text({
16
+ waitFor: (text) => {
17
+ // wait for form to show up
18
+ return /Form Component Demo/i.test(text);
19
+ },
20
+ });
21
+ // Type in username field
22
+ await driver.keys.type('user1');
23
+ // Navigate down with arrow key instead of tab
24
+ await driver.keys.down();
25
+ await driver.keys.type('pass123');
26
+ const afterDownArrowSnapshot = await driver.text();
27
+ expect(afterDownArrowSnapshot).toMatchInlineSnapshot();
28
+ // Navigate up with arrow key
29
+ await driver.keys.up();
30
+ const afterUpArrowSnapshot = await driver.text();
31
+ expect(afterUpArrowSnapshot).toMatchInlineSnapshot();
32
+ // Test Ctrl+K to show actions
33
+ await driver.keys.ctrlK();
34
+ const actionsOpenSnapshot = await driver.text();
35
+ expect(actionsOpenSnapshot).toMatchInlineSnapshot();
36
+ // Select the submit action
37
+ await driver.keys.enter();
38
+ const afterSubmitWithCtrlKSnapshot = await driver.text({
39
+ waitFor: (text) => {
40
+ // wait for toast to show
41
+ return /Form Submitted/i.test(text);
42
+ },
43
+ });
44
+ expect(afterSubmitWithCtrlKSnapshot).toMatchInlineSnapshot();
45
+ }, 10000);
46
+ //# sourceMappingURL=form-basic-arrow-keys.vitest.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"form-basic-arrow-keys.vitest.js","sourceRoot":"","sources":["../../src/examples/form-basic-arrow-keys.vitest.tsx"],"names":[],"mappings":"AAAA,mEAAmE;AACnE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAA;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AAE1D,IAAI,MAAqB,CAAA;AAEzB,UAAU,CAAC,GAAG,EAAE;IACZ,MAAM,GAAG,IAAI,aAAa,CAAC,KAAK,EAAE,CAAC,6BAA6B,CAAC,EAAE;QAC/D,IAAI,EAAE,EAAE;QACR,IAAI,EAAE,EAAE;KACX,CAAC,CAAA;AACN,CAAC,CAAC,CAAA;AAEF,SAAS,CAAC,GAAG,EAAE;IACX,MAAM,EAAE,OAAO,EAAE,CAAA;AACrB,CAAC,CAAC,CAAA;AAEF,IAAI,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;IAC1D,MAAM,MAAM,CAAC,IAAI,CAAC;QACd,OAAO,EAAE,CAAC,IAAI,EAAE,EAAE;YACd,2BAA2B;YAC3B,OAAO,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAC5C,CAAC;KACJ,CAAC,CAAA;IAEF,yBAAyB;IACzB,MAAM,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;IAE/B,8CAA8C;IAC9C,MAAM,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,CAAA;IACxB,MAAM,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;IAEjC,MAAM,sBAAsB,GAAG,MAAM,MAAM,CAAC,IAAI,EAAE,CAAA;IAClD,MAAM,CAAC,sBAAsB,CAAC,CAAC,qBAAqB,EAAE,CAAA;IAEtD,6BAA6B;IAC7B,MAAM,MAAM,CAAC,IAAI,CAAC,EAAE,EAAE,CAAA;IAEtB,MAAM,oBAAoB,GAAG,MAAM,MAAM,CAAC,IAAI,EAAE,CAAA;IAChD,MAAM,CAAC,oBAAoB,CAAC,CAAC,qBAAqB,EAAE,CAAA;IAEpD,8BAA8B;IAC9B,MAAM,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,CAAA;IAEzB,MAAM,mBAAmB,GAAG,MAAM,MAAM,CAAC,IAAI,EAAE,CAAA;IAC/C,MAAM,CAAC,mBAAmB,CAAC,CAAC,qBAAqB,EAAE,CAAA;IAEnD,2BAA2B;IAC3B,MAAM,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,CAAA;IAEzB,MAAM,4BAA4B,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC;QACnD,OAAO,EAAE,CAAC,IAAI,EAAE,EAAE;YACd,yBAAyB;YACzB,OAAO,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACvC,CAAC;KACJ,CAAC,CAAA;IACF,MAAM,CAAC,4BAA4B,CAAC,CAAC,qBAAqB,EAAE,CAAA;AAChE,CAAC,EAAE,KAAK,CAAC,CAAA"}