@tachui/core 0.7.0-alpha1 → 0.7.1-alpha

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 (947) hide show
  1. package/README.md +195 -0
  2. package/dist/ScrollView-h-6wYMAm.js +515 -0
  3. package/dist/Spacer-BbteDQ9I.js +5337 -0
  4. package/dist/binding-CmdpowkI.js +2276 -0
  5. package/dist/bundles/minimal.d.ts +30 -4
  6. package/dist/bundles/minimal.d.ts.map +1 -1
  7. package/dist/common.js +825 -954
  8. package/dist/compiler/index.js +1386 -10
  9. package/dist/components/index.js +4166 -101
  10. package/dist/concatenated-component-DPcl2TEO.js +6779 -0
  11. package/dist/{runtime/context.js → context--zQFIImS.js} +65 -71
  12. package/dist/debug.js +0 -1
  13. package/dist/dom-bridge-Cx-s6Ihx.js +406 -0
  14. package/dist/effect-CytAc9em.js +66 -0
  15. package/dist/essential.js +825 -954
  16. package/dist/index-Nfi2SBQh.js +3268 -0
  17. package/dist/index.js +825 -954
  18. package/dist/minimal-prod.js +162 -191
  19. package/dist/minimal.js +183 -957
  20. package/dist/modifiers/responsive/index.d.ts +10 -9
  21. package/dist/modifiers/responsive/index.d.ts.map +1 -1
  22. package/dist/plugins/index.js +543 -32
  23. package/dist/reactive/index.js +490 -93
  24. package/dist/runtime/dom-bridge.js +12 -239
  25. package/dist/runtime/renderer.js +8 -388
  26. package/dist/scheduler-7SvC3a21.js +814 -0
  27. package/dist/validation/index.js +6614 -198
  28. package/dist/viewport/index.js +2002 -83
  29. package/package.json +3 -4
  30. package/dist/assets/Asset.cjs +0 -2
  31. package/dist/assets/Asset.cjs.map +0 -1
  32. package/dist/assets/Asset.js +0 -9
  33. package/dist/assets/Asset.js.map +0 -1
  34. package/dist/assets/AssetCollection.cjs +0 -2
  35. package/dist/assets/AssetCollection.cjs.map +0 -1
  36. package/dist/assets/AssetCollection.js +0 -44
  37. package/dist/assets/AssetCollection.js.map +0 -1
  38. package/dist/assets/ColorAsset.cjs +0 -2
  39. package/dist/assets/ColorAsset.cjs.map +0 -1
  40. package/dist/assets/ColorAsset.js +0 -114
  41. package/dist/assets/ColorAsset.js.map +0 -1
  42. package/dist/assets/FontAsset.cjs +0 -9
  43. package/dist/assets/FontAsset.cjs.map +0 -1
  44. package/dist/assets/FontAsset.js +0 -173
  45. package/dist/assets/FontAsset.js.map +0 -1
  46. package/dist/assets/ImageAsset.cjs +0 -2
  47. package/dist/assets/ImageAsset.cjs.map +0 -1
  48. package/dist/assets/ImageAsset.js +0 -39
  49. package/dist/assets/ImageAsset.js.map +0 -1
  50. package/dist/assets/index.cjs +0 -2
  51. package/dist/assets/index.cjs.map +0 -1
  52. package/dist/assets/index.js +0 -119
  53. package/dist/assets/index.js.map +0 -1
  54. package/dist/common.cjs +0 -2
  55. package/dist/common.cjs.map +0 -1
  56. package/dist/common.js.map +0 -1
  57. package/dist/compiler/advanced-parser.cjs +0 -5
  58. package/dist/compiler/advanced-parser.cjs.map +0 -1
  59. package/dist/compiler/advanced-parser.js +0 -440
  60. package/dist/compiler/advanced-parser.js.map +0 -1
  61. package/dist/compiler/codegen.cjs +0 -6
  62. package/dist/compiler/codegen.cjs.map +0 -1
  63. package/dist/compiler/codegen.js +0 -241
  64. package/dist/compiler/codegen.js.map +0 -1
  65. package/dist/compiler/enhanced-codegen.cjs +0 -6
  66. package/dist/compiler/enhanced-codegen.cjs.map +0 -1
  67. package/dist/compiler/enhanced-codegen.js +0 -347
  68. package/dist/compiler/enhanced-codegen.js.map +0 -1
  69. package/dist/compiler/index.cjs +0 -2
  70. package/dist/compiler/index.cjs.map +0 -1
  71. package/dist/compiler/index.js.map +0 -1
  72. package/dist/compiler/parser.cjs +0 -5
  73. package/dist/compiler/parser.cjs.map +0 -1
  74. package/dist/compiler/parser.js +0 -275
  75. package/dist/compiler/parser.js.map +0 -1
  76. package/dist/compiler/plugin.cjs +0 -33
  77. package/dist/compiler/plugin.cjs.map +0 -1
  78. package/dist/compiler/plugin.js +0 -103
  79. package/dist/compiler/plugin.js.map +0 -1
  80. package/dist/components/BasicInput.cjs +0 -2
  81. package/dist/components/BasicInput.cjs.map +0 -1
  82. package/dist/components/BasicInput.js +0 -182
  83. package/dist/components/BasicInput.js.map +0 -1
  84. package/dist/components/Button.cjs +0 -7
  85. package/dist/components/Button.cjs.map +0 -1
  86. package/dist/components/Button.js +0 -408
  87. package/dist/components/Button.js.map +0 -1
  88. package/dist/components/Divider.cjs +0 -2
  89. package/dist/components/Divider.cjs.map +0 -1
  90. package/dist/components/Divider.js +0 -187
  91. package/dist/components/Divider.js.map +0 -1
  92. package/dist/components/EnhancedLink.cjs +0 -2
  93. package/dist/components/EnhancedLink.cjs.map +0 -1
  94. package/dist/components/EnhancedLink.js +0 -345
  95. package/dist/components/EnhancedLink.js.map +0 -1
  96. package/dist/components/Form.cjs +0 -2
  97. package/dist/components/Form.cjs.map +0 -1
  98. package/dist/components/Form.js +0 -244
  99. package/dist/components/Form.js.map +0 -1
  100. package/dist/components/Grid.cjs +0 -2
  101. package/dist/components/Grid.cjs.map +0 -1
  102. package/dist/components/Grid.js +0 -1045
  103. package/dist/components/Grid.js.map +0 -1
  104. package/dist/components/GridResponsive.cjs +0 -2
  105. package/dist/components/GridResponsive.cjs.map +0 -1
  106. package/dist/components/GridResponsive.js +0 -382
  107. package/dist/components/GridResponsive.js.map +0 -1
  108. package/dist/components/Image.cjs +0 -2
  109. package/dist/components/Image.cjs.map +0 -1
  110. package/dist/components/Image.js +0 -212
  111. package/dist/components/Image.js.map +0 -1
  112. package/dist/components/List.cjs +0 -2
  113. package/dist/components/List.cjs.map +0 -1
  114. package/dist/components/List.js +0 -561
  115. package/dist/components/List.js.map +0 -1
  116. package/dist/components/Menu.cjs +0 -2
  117. package/dist/components/Menu.cjs.map +0 -1
  118. package/dist/components/Menu.js +0 -443
  119. package/dist/components/Menu.js.map +0 -1
  120. package/dist/components/Picker.cjs +0 -2
  121. package/dist/components/Picker.cjs.map +0 -1
  122. package/dist/components/Picker.js +0 -478
  123. package/dist/components/Picker.js.map +0 -1
  124. package/dist/components/ScrollView.cjs +0 -6
  125. package/dist/components/ScrollView.cjs.map +0 -1
  126. package/dist/components/ScrollView.js +0 -363
  127. package/dist/components/ScrollView.js.map +0 -1
  128. package/dist/components/Section.cjs +0 -2
  129. package/dist/components/Section.cjs.map +0 -1
  130. package/dist/components/Section.js +0 -323
  131. package/dist/components/Section.js.map +0 -1
  132. package/dist/components/Show.cjs +0 -2
  133. package/dist/components/Show.cjs.map +0 -1
  134. package/dist/components/Show.js +0 -112
  135. package/dist/components/Show.js.map +0 -1
  136. package/dist/components/Spacer.cjs +0 -2
  137. package/dist/components/Spacer.cjs.map +0 -1
  138. package/dist/components/Spacer.js +0 -53
  139. package/dist/components/Spacer.js.map +0 -1
  140. package/dist/components/Text.cjs +0 -2
  141. package/dist/components/Text.cjs.map +0 -1
  142. package/dist/components/Text.js +0 -193
  143. package/dist/components/Text.js.map +0 -1
  144. package/dist/components/Toggle.cjs +0 -2
  145. package/dist/components/Toggle.cjs.map +0 -1
  146. package/dist/components/Toggle.js +0 -477
  147. package/dist/components/Toggle.js.map +0 -1
  148. package/dist/components/index.cjs +0 -2
  149. package/dist/components/index.cjs.map +0 -1
  150. package/dist/components/index.js.map +0 -1
  151. package/dist/components/wrapper.cjs +0 -2
  152. package/dist/components/wrapper.cjs.map +0 -1
  153. package/dist/components/wrapper.js +0 -484
  154. package/dist/components/wrapper.js.map +0 -1
  155. package/dist/concatenation/concatenatable.cjs +0 -2
  156. package/dist/concatenation/concatenatable.cjs.map +0 -1
  157. package/dist/concatenation/concatenatable.js +0 -118
  158. package/dist/concatenation/concatenatable.js.map +0 -1
  159. package/dist/concatenation/concatenated-component.cjs +0 -2
  160. package/dist/concatenation/concatenated-component.cjs.map +0 -1
  161. package/dist/concatenation/concatenated-component.js +0 -276
  162. package/dist/concatenation/concatenated-component.js.map +0 -1
  163. package/dist/concatenation/text-optimizer.cjs +0 -2
  164. package/dist/concatenation/text-optimizer.cjs.map +0 -1
  165. package/dist/concatenation/text-optimizer.js +0 -236
  166. package/dist/concatenation/text-optimizer.js.map +0 -1
  167. package/dist/concatenation/types.cjs +0 -2
  168. package/dist/concatenation/types.cjs.map +0 -1
  169. package/dist/concatenation/types.js +0 -13
  170. package/dist/concatenation/types.js.map +0 -1
  171. package/dist/constants/frame-utils.cjs +0 -2
  172. package/dist/constants/frame-utils.cjs.map +0 -1
  173. package/dist/constants/frame-utils.js +0 -116
  174. package/dist/constants/frame-utils.js.map +0 -1
  175. package/dist/constants/layout.cjs +0 -2
  176. package/dist/constants/layout.cjs.map +0 -1
  177. package/dist/constants/layout.js +0 -46
  178. package/dist/constants/layout.js.map +0 -1
  179. package/dist/css-classes/component-base.cjs +0 -2
  180. package/dist/css-classes/component-base.cjs.map +0 -1
  181. package/dist/css-classes/component-base.js +0 -62
  182. package/dist/css-classes/component-base.js.map +0 -1
  183. package/dist/css-classes/css-class-manager.cjs +0 -2
  184. package/dist/css-classes/css-class-manager.cjs.map +0 -1
  185. package/dist/css-classes/css-class-manager.js +0 -209
  186. package/dist/css-classes/css-class-manager.js.map +0 -1
  187. package/dist/css-classes/dom-integration.cjs +0 -2
  188. package/dist/css-classes/dom-integration.cjs.map +0 -1
  189. package/dist/css-classes/dom-integration.js +0 -67
  190. package/dist/css-classes/dom-integration.js.map +0 -1
  191. package/dist/css-classes/enhanced-renderer.cjs +0 -2
  192. package/dist/css-classes/enhanced-renderer.cjs.map +0 -1
  193. package/dist/css-classes/enhanced-renderer.js +0 -73
  194. package/dist/css-classes/enhanced-renderer.js.map +0 -1
  195. package/dist/css-classes/utilities.cjs +0 -2
  196. package/dist/css-classes/utilities.cjs.map +0 -1
  197. package/dist/css-classes/utilities.js +0 -41
  198. package/dist/css-classes/utilities.js.map +0 -1
  199. package/dist/debug.cjs +0 -52
  200. package/dist/debug.cjs.map +0 -1
  201. package/dist/debug.js.map +0 -1
  202. package/dist/essential.cjs +0 -2
  203. package/dist/essential.cjs.map +0 -1
  204. package/dist/essential.js.map +0 -1
  205. package/dist/gradients/css-generator.cjs +0 -2
  206. package/dist/gradients/css-generator.cjs.map +0 -1
  207. package/dist/gradients/css-generator.js +0 -100
  208. package/dist/gradients/css-generator.js.map +0 -1
  209. package/dist/gradients/examples.cjs +0 -2
  210. package/dist/gradients/examples.cjs.map +0 -1
  211. package/dist/gradients/examples.js +0 -555
  212. package/dist/gradients/examples.js.map +0 -1
  213. package/dist/gradients/gradient-asset.cjs +0 -2
  214. package/dist/gradients/gradient-asset.cjs.map +0 -1
  215. package/dist/gradients/gradient-asset.js +0 -22
  216. package/dist/gradients/gradient-asset.js.map +0 -1
  217. package/dist/gradients/index.cjs +0 -2
  218. package/dist/gradients/index.cjs.map +0 -1
  219. package/dist/gradients/index.js +0 -78
  220. package/dist/gradients/index.js.map +0 -1
  221. package/dist/gradients/performance.cjs +0 -2
  222. package/dist/gradients/performance.cjs.map +0 -1
  223. package/dist/gradients/performance.js +0 -237
  224. package/dist/gradients/performance.js.map +0 -1
  225. package/dist/gradients/presets.cjs +0 -2
  226. package/dist/gradients/presets.cjs.map +0 -1
  227. package/dist/gradients/presets.js +0 -254
  228. package/dist/gradients/presets.js.map +0 -1
  229. package/dist/gradients/reactive.cjs +0 -2
  230. package/dist/gradients/reactive.cjs.map +0 -1
  231. package/dist/gradients/reactive.js +0 -239
  232. package/dist/gradients/reactive.js.map +0 -1
  233. package/dist/gradients/state-gradient-asset.cjs +0 -2
  234. package/dist/gradients/state-gradient-asset.cjs.map +0 -1
  235. package/dist/gradients/state-gradient-asset.js +0 -111
  236. package/dist/gradients/state-gradient-asset.js.map +0 -1
  237. package/dist/gradients/utils.cjs +0 -2
  238. package/dist/gradients/utils.cjs.map +0 -1
  239. package/dist/gradients/utils.js +0 -385
  240. package/dist/gradients/utils.js.map +0 -1
  241. package/dist/gradients/validation.cjs +0 -2
  242. package/dist/gradients/validation.cjs.map +0 -1
  243. package/dist/gradients/validation.js +0 -209
  244. package/dist/gradients/validation.js.map +0 -1
  245. package/dist/index.cjs +0 -2
  246. package/dist/index.cjs.map +0 -1
  247. package/dist/index.js.map +0 -1
  248. package/dist/index2.cjs +0 -2
  249. package/dist/index2.cjs.map +0 -1
  250. package/dist/index2.js +0 -293
  251. package/dist/index2.js.map +0 -1
  252. package/dist/lifecycle/hooks.cjs +0 -2
  253. package/dist/lifecycle/hooks.cjs.map +0 -1
  254. package/dist/lifecycle/hooks.js +0 -159
  255. package/dist/lifecycle/hooks.js.map +0 -1
  256. package/dist/minimal-prod.cjs +0 -2
  257. package/dist/minimal-prod.cjs.map +0 -1
  258. package/dist/minimal-prod.js.map +0 -1
  259. package/dist/minimal.cjs +0 -2
  260. package/dist/minimal.cjs.map +0 -1
  261. package/dist/minimal.js.map +0 -1
  262. package/dist/modifiers/as-html-validator.cjs +0 -2
  263. package/dist/modifiers/as-html-validator.cjs.map +0 -1
  264. package/dist/modifiers/as-html-validator.js +0 -47
  265. package/dist/modifiers/as-html-validator.js.map +0 -1
  266. package/dist/modifiers/as-html.cjs +0 -2
  267. package/dist/modifiers/as-html.cjs.map +0 -1
  268. package/dist/modifiers/as-html.js +0 -71
  269. package/dist/modifiers/as-html.js.map +0 -1
  270. package/dist/modifiers/attributes.cjs +0 -2
  271. package/dist/modifiers/attributes.cjs.map +0 -1
  272. package/dist/modifiers/attributes.js +0 -272
  273. package/dist/modifiers/attributes.js.map +0 -1
  274. package/dist/modifiers/backdrop.cjs +0 -2
  275. package/dist/modifiers/backdrop.cjs.map +0 -1
  276. package/dist/modifiers/backdrop.js +0 -109
  277. package/dist/modifiers/backdrop.js.map +0 -1
  278. package/dist/modifiers/background.cjs +0 -2
  279. package/dist/modifiers/background.cjs.map +0 -1
  280. package/dist/modifiers/background.js +0 -67
  281. package/dist/modifiers/background.js.map +0 -1
  282. package/dist/modifiers/base.cjs +0 -25
  283. package/dist/modifiers/base.cjs.map +0 -1
  284. package/dist/modifiers/base.js +0 -745
  285. package/dist/modifiers/base.js.map +0 -1
  286. package/dist/modifiers/basic-sanitizer.cjs +0 -2
  287. package/dist/modifiers/basic-sanitizer.cjs.map +0 -1
  288. package/dist/modifiers/basic-sanitizer.js +0 -162
  289. package/dist/modifiers/basic-sanitizer.js.map +0 -1
  290. package/dist/modifiers/border.cjs +0 -2
  291. package/dist/modifiers/border.cjs.map +0 -1
  292. package/dist/modifiers/border.js +0 -160
  293. package/dist/modifiers/border.js.map +0 -1
  294. package/dist/modifiers/builder.cjs +0 -2
  295. package/dist/modifiers/builder.cjs.map +0 -1
  296. package/dist/modifiers/builder.js +0 -930
  297. package/dist/modifiers/builder.js.map +0 -1
  298. package/dist/modifiers/core.cjs +0 -2
  299. package/dist/modifiers/core.cjs.map +0 -1
  300. package/dist/modifiers/core.js +0 -398
  301. package/dist/modifiers/core.js.map +0 -1
  302. package/dist/modifiers/css.cjs +0 -2
  303. package/dist/modifiers/css.cjs.map +0 -1
  304. package/dist/modifiers/css.js +0 -50
  305. package/dist/modifiers/css.js.map +0 -1
  306. package/dist/modifiers/effects.cjs +0 -2
  307. package/dist/modifiers/effects.cjs.map +0 -1
  308. package/dist/modifiers/effects.js +0 -178
  309. package/dist/modifiers/effects.js.map +0 -1
  310. package/dist/modifiers/elements.cjs +0 -2
  311. package/dist/modifiers/elements.cjs.map +0 -1
  312. package/dist/modifiers/elements.js +0 -216
  313. package/dist/modifiers/elements.js.map +0 -1
  314. package/dist/modifiers/filters.cjs +0 -2
  315. package/dist/modifiers/filters.cjs.map +0 -1
  316. package/dist/modifiers/filters.js +0 -223
  317. package/dist/modifiers/filters.js.map +0 -1
  318. package/dist/modifiers/flexbox.cjs +0 -2
  319. package/dist/modifiers/flexbox.cjs.map +0 -1
  320. package/dist/modifiers/flexbox.js +0 -56
  321. package/dist/modifiers/flexbox.js.map +0 -1
  322. package/dist/modifiers/font.cjs +0 -2
  323. package/dist/modifiers/font.cjs.map +0 -1
  324. package/dist/modifiers/font.js +0 -60
  325. package/dist/modifiers/font.js.map +0 -1
  326. package/dist/modifiers/grid.cjs +0 -2
  327. package/dist/modifiers/grid.cjs.map +0 -1
  328. package/dist/modifiers/grid.js +0 -92
  329. package/dist/modifiers/grid.js.map +0 -1
  330. package/dist/modifiers/margin.cjs +0 -2
  331. package/dist/modifiers/margin.cjs.map +0 -1
  332. package/dist/modifiers/margin.js +0 -65
  333. package/dist/modifiers/margin.js.map +0 -1
  334. package/dist/modifiers/padding.cjs +0 -2
  335. package/dist/modifiers/padding.cjs.map +0 -1
  336. package/dist/modifiers/padding.js +0 -109
  337. package/dist/modifiers/padding.js.map +0 -1
  338. package/dist/modifiers/registry.cjs +0 -2
  339. package/dist/modifiers/registry.cjs.map +0 -1
  340. package/dist/modifiers/registry.js +0 -163
  341. package/dist/modifiers/registry.js.map +0 -1
  342. package/dist/modifiers/responsive/advanced-utilities.cjs +0 -2
  343. package/dist/modifiers/responsive/advanced-utilities.cjs.map +0 -1
  344. package/dist/modifiers/responsive/advanced-utilities.js +0 -291
  345. package/dist/modifiers/responsive/advanced-utilities.js.map +0 -1
  346. package/dist/modifiers/responsive/breakpoints.cjs +0 -2
  347. package/dist/modifiers/responsive/breakpoints.cjs.map +0 -1
  348. package/dist/modifiers/responsive/breakpoints.js +0 -168
  349. package/dist/modifiers/responsive/breakpoints.js.map +0 -1
  350. package/dist/modifiers/responsive/css-generator.cjs +0 -5
  351. package/dist/modifiers/responsive/css-generator.cjs.map +0 -1
  352. package/dist/modifiers/responsive/css-generator.js +0 -261
  353. package/dist/modifiers/responsive/css-generator.js.map +0 -1
  354. package/dist/modifiers/responsive/dev-tools.cjs +0 -77
  355. package/dist/modifiers/responsive/dev-tools.cjs.map +0 -1
  356. package/dist/modifiers/responsive/dev-tools.js +0 -380
  357. package/dist/modifiers/responsive/dev-tools.js.map +0 -1
  358. package/dist/modifiers/responsive/layout-patterns.cjs +0 -2
  359. package/dist/modifiers/responsive/layout-patterns.cjs.map +0 -1
  360. package/dist/modifiers/responsive/layout-patterns.js +0 -254
  361. package/dist/modifiers/responsive/layout-patterns.js.map +0 -1
  362. package/dist/modifiers/responsive/performance.cjs +0 -3
  363. package/dist/modifiers/responsive/performance.cjs.map +0 -1
  364. package/dist/modifiers/responsive/performance.js +0 -212
  365. package/dist/modifiers/responsive/performance.js.map +0 -1
  366. package/dist/modifiers/responsive/responsive-builder.cjs +0 -2
  367. package/dist/modifiers/responsive/responsive-builder.cjs.map +0 -1
  368. package/dist/modifiers/responsive/responsive-builder.js +0 -272
  369. package/dist/modifiers/responsive/responsive-builder.js.map +0 -1
  370. package/dist/modifiers/responsive/responsive-modifier.cjs +0 -3
  371. package/dist/modifiers/responsive/responsive-modifier.cjs.map +0 -1
  372. package/dist/modifiers/responsive/responsive-modifier.js +0 -204
  373. package/dist/modifiers/responsive/responsive-modifier.js.map +0 -1
  374. package/dist/modifiers/responsive/types.cjs +0 -2
  375. package/dist/modifiers/responsive/types.cjs.map +0 -1
  376. package/dist/modifiers/responsive/types.js +0 -26
  377. package/dist/modifiers/responsive/types.js.map +0 -1
  378. package/dist/modifiers/responsive/utilities.cjs +0 -16
  379. package/dist/modifiers/responsive/utilities.cjs.map +0 -1
  380. package/dist/modifiers/responsive/utilities.js +0 -273
  381. package/dist/modifiers/responsive/utilities.js.map +0 -1
  382. package/dist/modifiers/scroll.cjs +0 -2
  383. package/dist/modifiers/scroll.cjs.map +0 -1
  384. package/dist/modifiers/scroll.js +0 -82
  385. package/dist/modifiers/scroll.js.map +0 -1
  386. package/dist/modifiers/shadows.cjs +0 -2
  387. package/dist/modifiers/shadows.cjs.map +0 -1
  388. package/dist/modifiers/shadows.js +0 -147
  389. package/dist/modifiers/shadows.js.map +0 -1
  390. package/dist/modifiers/size.cjs +0 -2
  391. package/dist/modifiers/size.cjs.map +0 -1
  392. package/dist/modifiers/size.js +0 -74
  393. package/dist/modifiers/size.js.map +0 -1
  394. package/dist/modifiers/text.cjs +0 -2
  395. package/dist/modifiers/text.cjs.map +0 -1
  396. package/dist/modifiers/text.js +0 -166
  397. package/dist/modifiers/text.js.map +0 -1
  398. package/dist/modifiers/transformations.cjs +0 -2
  399. package/dist/modifiers/transformations.cjs.map +0 -1
  400. package/dist/modifiers/transformations.js +0 -216
  401. package/dist/modifiers/transformations.js.map +0 -1
  402. package/dist/modifiers/transitions.cjs +0 -2
  403. package/dist/modifiers/transitions.cjs.map +0 -1
  404. package/dist/modifiers/transitions.js +0 -102
  405. package/dist/modifiers/transitions.js.map +0 -1
  406. package/dist/modifiers/types.cjs +0 -2
  407. package/dist/modifiers/types.cjs.map +0 -1
  408. package/dist/modifiers/types.js +0 -5
  409. package/dist/modifiers/types.js.map +0 -1
  410. package/dist/modifiers/typography.cjs +0 -2
  411. package/dist/modifiers/typography.cjs.map +0 -1
  412. package/dist/modifiers/typography.js +0 -76
  413. package/dist/modifiers/typography.js.map +0 -1
  414. package/dist/modifiers/utility.cjs +0 -2
  415. package/dist/modifiers/utility.cjs.map +0 -1
  416. package/dist/modifiers/utility.js +0 -71
  417. package/dist/modifiers/utility.js.map +0 -1
  418. package/dist/modifiers/utils.cjs +0 -2
  419. package/dist/modifiers/utils.cjs.map +0 -1
  420. package/dist/modifiers/utils.js +0 -250
  421. package/dist/modifiers/utils.js.map +0 -1
  422. package/dist/plugins/index.cjs +0 -2
  423. package/dist/plugins/index.cjs.map +0 -1
  424. package/dist/plugins/index.js.map +0 -1
  425. package/dist/plugins/legacy-adapter.cjs +0 -2
  426. package/dist/plugins/legacy-adapter.cjs.map +0 -1
  427. package/dist/plugins/legacy-adapter.js +0 -30
  428. package/dist/plugins/legacy-adapter.js.map +0 -1
  429. package/dist/plugins/simplified-component-registry.cjs +0 -2
  430. package/dist/plugins/simplified-component-registry.cjs.map +0 -1
  431. package/dist/plugins/simplified-component-registry.js +0 -71
  432. package/dist/plugins/simplified-component-registry.js.map +0 -1
  433. package/dist/plugins/simplified-error-handler.cjs +0 -2
  434. package/dist/plugins/simplified-error-handler.cjs.map +0 -1
  435. package/dist/plugins/simplified-error-handler.js +0 -154
  436. package/dist/plugins/simplified-error-handler.js.map +0 -1
  437. package/dist/plugins/simplified-lazy-loader.cjs +0 -2
  438. package/dist/plugins/simplified-lazy-loader.cjs.map +0 -1
  439. package/dist/plugins/simplified-lazy-loader.js +0 -129
  440. package/dist/plugins/simplified-lazy-loader.js.map +0 -1
  441. package/dist/plugins/simplified-plugin-manager.cjs +0 -2
  442. package/dist/plugins/simplified-plugin-manager.cjs.map +0 -1
  443. package/dist/plugins/simplified-plugin-manager.js +0 -51
  444. package/dist/plugins/simplified-plugin-manager.js.map +0 -1
  445. package/dist/plugins/simplified-tachui-instance.cjs +0 -2
  446. package/dist/plugins/simplified-tachui-instance.cjs.map +0 -1
  447. package/dist/plugins/simplified-tachui-instance.js +0 -88
  448. package/dist/plugins/simplified-tachui-instance.js.map +0 -1
  449. package/dist/plugins/simplified-types.cjs +0 -2
  450. package/dist/plugins/simplified-types.cjs.map +0 -1
  451. package/dist/plugins/simplified-types.js +0 -9
  452. package/dist/plugins/simplified-types.js.map +0 -1
  453. package/dist/plugins/simplified-utils.cjs +0 -2
  454. package/dist/plugins/simplified-utils.cjs.map +0 -1
  455. package/dist/plugins/simplified-utils.js +0 -40
  456. package/dist/plugins/simplified-utils.js.map +0 -1
  457. package/dist/reactive/cleanup.cjs +0 -2
  458. package/dist/reactive/cleanup.cjs.map +0 -1
  459. package/dist/reactive/cleanup.js +0 -62
  460. package/dist/reactive/cleanup.js.map +0 -1
  461. package/dist/reactive/computed.cjs +0 -2
  462. package/dist/reactive/computed.cjs.map +0 -1
  463. package/dist/reactive/computed.js +0 -121
  464. package/dist/reactive/computed.js.map +0 -1
  465. package/dist/reactive/context.cjs +0 -2
  466. package/dist/reactive/context.cjs.map +0 -1
  467. package/dist/reactive/context.js +0 -143
  468. package/dist/reactive/context.js.map +0 -1
  469. package/dist/reactive/effect.cjs +0 -2
  470. package/dist/reactive/effect.cjs.map +0 -1
  471. package/dist/reactive/effect.js +0 -67
  472. package/dist/reactive/effect.js.map +0 -1
  473. package/dist/reactive/enhanced-effect.cjs +0 -2
  474. package/dist/reactive/enhanced-effect.cjs.map +0 -1
  475. package/dist/reactive/enhanced-effect.js +0 -153
  476. package/dist/reactive/enhanced-effect.js.map +0 -1
  477. package/dist/reactive/enhanced-signal.cjs +0 -2
  478. package/dist/reactive/enhanced-signal.cjs.map +0 -1
  479. package/dist/reactive/enhanced-signal.js +0 -117
  480. package/dist/reactive/enhanced-signal.js.map +0 -1
  481. package/dist/reactive/equality.cjs +0 -2
  482. package/dist/reactive/equality.cjs.map +0 -1
  483. package/dist/reactive/equality.js +0 -66
  484. package/dist/reactive/equality.js.map +0 -1
  485. package/dist/reactive/index.cjs +0 -2
  486. package/dist/reactive/index.cjs.map +0 -1
  487. package/dist/reactive/index.js.map +0 -1
  488. package/dist/reactive/migration.cjs +0 -18
  489. package/dist/reactive/migration.cjs.map +0 -1
  490. package/dist/reactive/migration.js +0 -164
  491. package/dist/reactive/migration.js.map +0 -1
  492. package/dist/reactive/ownership.cjs +0 -2
  493. package/dist/reactive/ownership.cjs.map +0 -1
  494. package/dist/reactive/ownership.js +0 -34
  495. package/dist/reactive/ownership.js.map +0 -1
  496. package/dist/reactive/scheduler.cjs +0 -2
  497. package/dist/reactive/scheduler.cjs.map +0 -1
  498. package/dist/reactive/scheduler.js +0 -111
  499. package/dist/reactive/scheduler.js.map +0 -1
  500. package/dist/reactive/signal.cjs +0 -2
  501. package/dist/reactive/signal.cjs.map +0 -1
  502. package/dist/reactive/signal.js +0 -96
  503. package/dist/reactive/signal.js.map +0 -1
  504. package/dist/reactive/theme.cjs +0 -2
  505. package/dist/reactive/theme.cjs.map +0 -1
  506. package/dist/reactive/theme.js +0 -27
  507. package/dist/reactive/theme.js.map +0 -1
  508. package/dist/reactive/types.cjs +0 -2
  509. package/dist/reactive/types.cjs.map +0 -1
  510. package/dist/reactive/types.js +0 -5
  511. package/dist/reactive/types.js.map +0 -1
  512. package/dist/reactive/unified-scheduler.cjs +0 -2
  513. package/dist/reactive/unified-scheduler.cjs.map +0 -1
  514. package/dist/reactive/unified-scheduler.js +0 -219
  515. package/dist/reactive/unified-scheduler.js.map +0 -1
  516. package/dist/runtime/component-context.cjs +0 -2
  517. package/dist/runtime/component-context.cjs.map +0 -1
  518. package/dist/runtime/component-context.js +0 -177
  519. package/dist/runtime/component-context.js.map +0 -1
  520. package/dist/runtime/component.cjs +0 -2
  521. package/dist/runtime/component.cjs.map +0 -1
  522. package/dist/runtime/component.js +0 -238
  523. package/dist/runtime/component.js.map +0 -1
  524. package/dist/runtime/context.cjs +0 -2
  525. package/dist/runtime/context.cjs.map +0 -1
  526. package/dist/runtime/context.js.map +0 -1
  527. package/dist/runtime/dev-tools.cjs +0 -2
  528. package/dist/runtime/dev-tools.cjs.map +0 -1
  529. package/dist/runtime/dev-tools.js +0 -391
  530. package/dist/runtime/dev-tools.js.map +0 -1
  531. package/dist/runtime/development-warnings.cjs +0 -2
  532. package/dist/runtime/development-warnings.cjs.map +0 -1
  533. package/dist/runtime/development-warnings.js +0 -69
  534. package/dist/runtime/development-warnings.js.map +0 -1
  535. package/dist/runtime/dom-bridge.cjs +0 -2
  536. package/dist/runtime/dom-bridge.cjs.map +0 -1
  537. package/dist/runtime/dom-bridge.js.map +0 -1
  538. package/dist/runtime/element-override.cjs +0 -2
  539. package/dist/runtime/element-override.cjs.map +0 -1
  540. package/dist/runtime/element-override.js +0 -214
  541. package/dist/runtime/element-override.js.map +0 -1
  542. package/dist/runtime/error-boundary.cjs +0 -2
  543. package/dist/runtime/error-boundary.cjs.map +0 -1
  544. package/dist/runtime/error-boundary.js +0 -559
  545. package/dist/runtime/error-boundary.js.map +0 -1
  546. package/dist/runtime/error-recovery.cjs +0 -2
  547. package/dist/runtime/error-recovery.cjs.map +0 -1
  548. package/dist/runtime/error-recovery.js +0 -385
  549. package/dist/runtime/error-recovery.js.map +0 -1
  550. package/dist/runtime/error-reporting.cjs +0 -3
  551. package/dist/runtime/error-reporting.cjs.map +0 -1
  552. package/dist/runtime/error-reporting.js +0 -479
  553. package/dist/runtime/error-reporting.js.map +0 -1
  554. package/dist/runtime/error-utils.cjs +0 -3
  555. package/dist/runtime/error-utils.cjs.map +0 -1
  556. package/dist/runtime/error-utils.js +0 -352
  557. package/dist/runtime/error-utils.js.map +0 -1
  558. package/dist/runtime/lazy-component.cjs +0 -2
  559. package/dist/runtime/lazy-component.cjs.map +0 -1
  560. package/dist/runtime/lazy-component.js +0 -129
  561. package/dist/runtime/lazy-component.js.map +0 -1
  562. package/dist/runtime/lifecycle.cjs +0 -2
  563. package/dist/runtime/lifecycle.cjs.map +0 -1
  564. package/dist/runtime/lifecycle.js +0 -7
  565. package/dist/runtime/lifecycle.js.map +0 -1
  566. package/dist/runtime/mounting.cjs +0 -2
  567. package/dist/runtime/mounting.cjs.map +0 -1
  568. package/dist/runtime/mounting.js +0 -12
  569. package/dist/runtime/mounting.js.map +0 -1
  570. package/dist/runtime/optimization.cjs +0 -2
  571. package/dist/runtime/optimization.cjs.map +0 -1
  572. package/dist/runtime/optimization.js +0 -6
  573. package/dist/runtime/optimization.js.map +0 -1
  574. package/dist/runtime/performance.cjs +0 -2
  575. package/dist/runtime/performance.cjs.map +0 -1
  576. package/dist/runtime/performance.js +0 -399
  577. package/dist/runtime/performance.js.map +0 -1
  578. package/dist/runtime/props.cjs +0 -2
  579. package/dist/runtime/props.cjs.map +0 -1
  580. package/dist/runtime/props.js +0 -265
  581. package/dist/runtime/props.js.map +0 -1
  582. package/dist/runtime/renderer.cjs +0 -2
  583. package/dist/runtime/renderer.cjs.map +0 -1
  584. package/dist/runtime/renderer.js.map +0 -1
  585. package/dist/runtime/semantic-role-manager.cjs +0 -2
  586. package/dist/runtime/semantic-role-manager.cjs.map +0 -1
  587. package/dist/runtime/semantic-role-manager.js +0 -82
  588. package/dist/runtime/semantic-role-manager.js.map +0 -1
  589. package/dist/state/binding.cjs +0 -2
  590. package/dist/state/binding.cjs.map +0 -1
  591. package/dist/state/binding.js +0 -155
  592. package/dist/state/binding.js.map +0 -1
  593. package/dist/state/environment.cjs +0 -2
  594. package/dist/state/environment.cjs.map +0 -1
  595. package/dist/state/environment.js +0 -115
  596. package/dist/state/environment.js.map +0 -1
  597. package/dist/state/index.cjs +0 -2
  598. package/dist/state/index.cjs.map +0 -1
  599. package/dist/state/index.js +0 -63
  600. package/dist/state/index.js.map +0 -1
  601. package/dist/state/observed-object.cjs +0 -2
  602. package/dist/state/observed-object.cjs.map +0 -1
  603. package/dist/state/observed-object.js +0 -163
  604. package/dist/state/observed-object.js.map +0 -1
  605. package/dist/state/state-manager.cjs +0 -2
  606. package/dist/state/state-manager.cjs.map +0 -1
  607. package/dist/state/state-manager.js +0 -233
  608. package/dist/state/state-manager.js.map +0 -1
  609. package/dist/state/state.cjs +0 -2
  610. package/dist/state/state.cjs.map +0 -1
  611. package/dist/state/state.js +0 -159
  612. package/dist/state/state.js.map +0 -1
  613. package/dist/sui-compat.cjs +0 -2
  614. package/dist/sui-compat.cjs.map +0 -1
  615. package/dist/sui-compat.js +0 -88
  616. package/dist/sui-compat.js.map +0 -1
  617. package/dist/validation/advanced-debugging.cjs +0 -44
  618. package/dist/validation/advanced-debugging.cjs.map +0 -1
  619. package/dist/validation/advanced-debugging.js +0 -455
  620. package/dist/validation/advanced-debugging.js.map +0 -1
  621. package/dist/validation/build-time/detection.cjs +0 -2
  622. package/dist/validation/build-time/detection.cjs.map +0 -1
  623. package/dist/validation/build-time/detection.js +0 -199
  624. package/dist/validation/build-time/detection.js.map +0 -1
  625. package/dist/validation/build-time/index.cjs +0 -2
  626. package/dist/validation/build-time/index.cjs.map +0 -1
  627. package/dist/validation/build-time/index.js +0 -122
  628. package/dist/validation/build-time/index.js.map +0 -1
  629. package/dist/validation/build-time/plugins.cjs +0 -3
  630. package/dist/validation/build-time/plugins.cjs.map +0 -1
  631. package/dist/validation/build-time/plugins.js +0 -282
  632. package/dist/validation/build-time/plugins.js.map +0 -1
  633. package/dist/validation/build-time/rules.cjs +0 -2
  634. package/dist/validation/build-time/rules.cjs.map +0 -1
  635. package/dist/validation/build-time/rules.js +0 -576
  636. package/dist/validation/build-time/rules.js.map +0 -1
  637. package/dist/validation/build-time/transformer.cjs +0 -3
  638. package/dist/validation/build-time/transformer.cjs.map +0 -1
  639. package/dist/validation/build-time/transformer.js +0 -177
  640. package/dist/validation/build-time/transformer.js.map +0 -1
  641. package/dist/validation/comprehensive.cjs +0 -9
  642. package/dist/validation/comprehensive.cjs.map +0 -1
  643. package/dist/validation/comprehensive.js +0 -916
  644. package/dist/validation/comprehensive.js.map +0 -1
  645. package/dist/validation/debug-tools.cjs +0 -16
  646. package/dist/validation/debug-tools.cjs.map +0 -1
  647. package/dist/validation/debug-tools.js +0 -405
  648. package/dist/validation/debug-tools.js.map +0 -1
  649. package/dist/validation/developer-experience.cjs +0 -17
  650. package/dist/validation/developer-experience.cjs.map +0 -1
  651. package/dist/validation/developer-experience.js +0 -433
  652. package/dist/validation/developer-experience.js.map +0 -1
  653. package/dist/validation/documentation-integration.cjs +0 -7
  654. package/dist/validation/documentation-integration.cjs.map +0 -1
  655. package/dist/validation/documentation-integration.js +0 -440
  656. package/dist/validation/documentation-integration.js.map +0 -1
  657. package/dist/validation/enhanced-runtime.cjs +0 -6
  658. package/dist/validation/enhanced-runtime.cjs.map +0 -1
  659. package/dist/validation/enhanced-runtime.js +0 -465
  660. package/dist/validation/enhanced-runtime.js.map +0 -1
  661. package/dist/validation/error-reporting.cjs +0 -32
  662. package/dist/validation/error-reporting.cjs.map +0 -1
  663. package/dist/validation/error-reporting.js +0 -370
  664. package/dist/validation/error-reporting.js.map +0 -1
  665. package/dist/validation/ide-integration.cjs +0 -85
  666. package/dist/validation/ide-integration.cjs.map +0 -1
  667. package/dist/validation/ide-integration.js +0 -557
  668. package/dist/validation/ide-integration.js.map +0 -1
  669. package/dist/validation/index.cjs +0 -6
  670. package/dist/validation/index.cjs.map +0 -1
  671. package/dist/validation/index.js.map +0 -1
  672. package/dist/validation/lifecycle-validation.cjs +0 -2
  673. package/dist/validation/lifecycle-validation.cjs.map +0 -1
  674. package/dist/validation/lifecycle-validation.js +0 -314
  675. package/dist/validation/lifecycle-validation.js.map +0 -1
  676. package/dist/validation/performance-optimizer.cjs +0 -2
  677. package/dist/validation/performance-optimizer.cjs.map +0 -1
  678. package/dist/validation/performance-optimizer.js +0 -338
  679. package/dist/validation/performance-optimizer.js.map +0 -1
  680. package/dist/validation/plugin-registration.cjs +0 -2
  681. package/dist/validation/plugin-registration.cjs.map +0 -1
  682. package/dist/validation/plugin-registration.js +0 -126
  683. package/dist/validation/plugin-registration.js.map +0 -1
  684. package/dist/validation/production-bypass.cjs +0 -2
  685. package/dist/validation/production-bypass.cjs.map +0 -1
  686. package/dist/validation/production-bypass.js +0 -218
  687. package/dist/validation/production-bypass.js.map +0 -1
  688. package/dist/validation/simple.cjs +0 -9
  689. package/dist/validation/simple.cjs.map +0 -1
  690. package/dist/validation/simple.js +0 -146
  691. package/dist/validation/simple.js.map +0 -1
  692. package/dist/viewport/adapters/web-adapter.cjs +0 -70
  693. package/dist/viewport/adapters/web-adapter.cjs.map +0 -1
  694. package/dist/viewport/adapters/web-adapter.js +0 -823
  695. package/dist/viewport/adapters/web-adapter.js.map +0 -1
  696. package/dist/viewport/components.cjs +0 -2
  697. package/dist/viewport/components.cjs.map +0 -1
  698. package/dist/viewport/components.js +0 -298
  699. package/dist/viewport/components.js.map +0 -1
  700. package/dist/viewport/environment.cjs +0 -2
  701. package/dist/viewport/environment.cjs.map +0 -1
  702. package/dist/viewport/environment.js +0 -86
  703. package/dist/viewport/environment.js.map +0 -1
  704. package/dist/viewport/index.cjs +0 -2
  705. package/dist/viewport/index.cjs.map +0 -1
  706. package/dist/viewport/index.js.map +0 -1
  707. package/dist/viewport/platform-detection.cjs +0 -2
  708. package/dist/viewport/platform-detection.cjs.map +0 -1
  709. package/dist/viewport/platform-detection.js +0 -205
  710. package/dist/viewport/platform-detection.js.map +0 -1
  711. package/dist/viewport/types.cjs +0 -2
  712. package/dist/viewport/types.cjs.map +0 -1
  713. package/dist/viewport/types.js +0 -13
  714. package/dist/viewport/types.js.map +0 -1
  715. package/dist/viewport/viewport-manager.cjs +0 -2
  716. package/dist/viewport/viewport-manager.cjs.map +0 -1
  717. package/dist/viewport/viewport-manager.js +0 -524
  718. package/dist/viewport/viewport-manager.js.map +0 -1
  719. package/src/assets/Asset.ts +0 -11
  720. package/src/assets/AssetCollection.ts +0 -99
  721. package/src/assets/ColorAsset.ts +0 -210
  722. package/src/assets/FontAsset.ts +0 -380
  723. package/src/assets/ImageAsset.ts +0 -91
  724. package/src/assets/README.md +0 -190
  725. package/src/assets/index.ts +0 -175
  726. package/src/assets/test-assets.ts +0 -69
  727. package/src/assets/test-integration.ts +0 -46
  728. package/src/assets/test-simple.ts +0 -28
  729. package/src/assets/types.ts +0 -79
  730. package/src/bundles/common.ts +0 -30
  731. package/src/bundles/complete.ts +0 -29
  732. package/src/bundles/essential.ts +0 -26
  733. package/src/bundles/minimal.ts +0 -26
  734. package/src/bundles/production-minimal.ts +0 -67
  735. package/src/compiler/advanced-parser.ts +0 -871
  736. package/src/compiler/codegen.ts +0 -450
  737. package/src/compiler/enhanced-codegen.ts +0 -729
  738. package/src/compiler/index.ts +0 -25
  739. package/src/compiler/parser.ts +0 -461
  740. package/src/compiler/plugin.ts +0 -181
  741. package/src/compiler/types.ts +0 -177
  742. package/src/components/BasicInput.ts +0 -352
  743. package/src/components/Button.ts +0 -963
  744. package/src/components/Divider.ts +0 -341
  745. package/src/components/EnhancedLink.ts +0 -676
  746. package/src/components/Form.ts +0 -414
  747. package/src/components/Grid.ts +0 -2507
  748. package/src/components/GridResponsive.ts +0 -637
  749. package/src/components/Image.ts +0 -426
  750. package/src/components/List.ts +0 -1084
  751. package/src/components/Menu.ts +0 -807
  752. package/src/components/Picker.ts +0 -678
  753. package/src/components/ScrollView.ts +0 -725
  754. package/src/components/Section.ts +0 -472
  755. package/src/components/Show.ts +0 -205
  756. package/src/components/Spacer.ts +0 -93
  757. package/src/components/Text.ts +0 -447
  758. package/src/components/Toggle.ts +0 -700
  759. package/src/components/index.ts +0 -231
  760. package/src/components/wrapper.ts +0 -828
  761. package/src/concatenation/concatenatable.ts +0 -211
  762. package/src/concatenation/concatenated-component.ts +0 -471
  763. package/src/concatenation/index.ts +0 -41
  764. package/src/concatenation/styles.css +0 -120
  765. package/src/concatenation/text-optimizer.ts +0 -440
  766. package/src/concatenation/types.ts +0 -116
  767. package/src/constants/README.md +0 -339
  768. package/src/constants/__tests__/frame-utils.test.ts +0 -276
  769. package/src/constants/__tests__/layout.test.ts +0 -215
  770. package/src/constants/frame-utils.ts +0 -174
  771. package/src/constants/index.ts +0 -8
  772. package/src/constants/layout.ts +0 -120
  773. package/src/css-classes/component-base.ts +0 -117
  774. package/src/css-classes/css-class-manager.ts +0 -372
  775. package/src/css-classes/dom-integration.ts +0 -162
  776. package/src/css-classes/enhanced-renderer.ts +0 -166
  777. package/src/css-classes/index.ts +0 -45
  778. package/src/css-classes/types.ts +0 -73
  779. package/src/css-classes/utilities.ts +0 -175
  780. package/src/debug/index.ts +0 -267
  781. package/src/developer-experience/enhanced-errors.ts +0 -556
  782. package/src/developer-experience/enhanced-types.ts +0 -427
  783. package/src/developer-experience/index.ts +0 -220
  784. package/src/globals.d.ts +0 -43
  785. package/src/gradients/__tests__/angular-gradient.test.ts +0 -111
  786. package/src/gradients/__tests__/background-modifier.test.ts +0 -81
  787. package/src/gradients/__tests__/comprehensive-gradients.test.ts +0 -296
  788. package/src/gradients/__tests__/gradient-asset.test.ts +0 -144
  789. package/src/gradients/__tests__/linear-gradient.test.ts +0 -92
  790. package/src/gradients/__tests__/phase4-features.test.ts +0 -386
  791. package/src/gradients/__tests__/radial-gradient.test.ts +0 -110
  792. package/src/gradients/__tests__/repeating-gradients.test.ts +0 -125
  793. package/src/gradients/__tests__/state-background-modifier.test.ts +0 -340
  794. package/src/gradients/__tests__/state-gradient-asset.test.ts +0 -262
  795. package/src/gradients/__tests__/state-gradient-integration.test.ts +0 -277
  796. package/src/gradients/css-generator.ts +0 -158
  797. package/src/gradients/examples.ts +0 -632
  798. package/src/gradients/gradient-asset.ts +0 -30
  799. package/src/gradients/index.ts +0 -85
  800. package/src/gradients/performance.ts +0 -521
  801. package/src/gradients/presets.ts +0 -422
  802. package/src/gradients/reactive.ts +0 -470
  803. package/src/gradients/state-gradient-asset.ts +0 -179
  804. package/src/gradients/types.ts +0 -148
  805. package/src/gradients/utils.ts +0 -579
  806. package/src/gradients/validation.ts +0 -489
  807. package/src/index.ts +0 -168
  808. package/src/lifecycle/hooks.ts +0 -332
  809. package/src/modifiers/__tests__/as-html-integration.test.ts +0 -204
  810. package/src/modifiers/__tests__/as-html.test.ts +0 -437
  811. package/src/modifiers/__tests__/basic-sanitizer-security.test.ts +0 -294
  812. package/src/modifiers/__tests__/border.test.ts +0 -371
  813. package/src/modifiers/__tests__/margin-string-support.test.ts +0 -41
  814. package/src/modifiers/__tests__/padding-string-support.test.ts +0 -41
  815. package/src/modifiers/as-html-validator.ts +0 -68
  816. package/src/modifiers/as-html.ts +0 -216
  817. package/src/modifiers/attributes.ts +0 -574
  818. package/src/modifiers/backdrop.ts +0 -290
  819. package/src/modifiers/background.ts +0 -165
  820. package/src/modifiers/base.ts +0 -1815
  821. package/src/modifiers/basic-sanitizer.ts +0 -227
  822. package/src/modifiers/border.ts +0 -574
  823. package/src/modifiers/builder.ts +0 -1747
  824. package/src/modifiers/core.ts +0 -521
  825. package/src/modifiers/css.ts +0 -148
  826. package/src/modifiers/effects.ts +0 -412
  827. package/src/modifiers/elements.ts +0 -541
  828. package/src/modifiers/filters.ts +0 -501
  829. package/src/modifiers/flexbox.ts +0 -180
  830. package/src/modifiers/font.ts +0 -149
  831. package/src/modifiers/grid.ts +0 -238
  832. package/src/modifiers/index.ts +0 -481
  833. package/src/modifiers/margin.ts +0 -218
  834. package/src/modifiers/padding.ts +0 -318
  835. package/src/modifiers/registry.ts +0 -444
  836. package/src/modifiers/responsive/__tests__/advanced-media-queries.test.ts +0 -392
  837. package/src/modifiers/responsive/__tests__/advanced-utilities.test.ts +0 -368
  838. package/src/modifiers/responsive/__tests__/comprehensive-browser-tests.test.ts +0 -556
  839. package/src/modifiers/responsive/__tests__/layout-patterns.test.ts +0 -558
  840. package/src/modifiers/responsive/advanced-utilities.ts +0 -562
  841. package/src/modifiers/responsive/breakpoints.ts +0 -330
  842. package/src/modifiers/responsive/css-generator.ts +0 -432
  843. package/src/modifiers/responsive/dev-tools.ts +0 -650
  844. package/src/modifiers/responsive/index.ts +0 -119
  845. package/src/modifiers/responsive/layout-patterns.ts +0 -592
  846. package/src/modifiers/responsive/performance.ts +0 -385
  847. package/src/modifiers/responsive/responsive-builder.ts +0 -620
  848. package/src/modifiers/responsive/responsive-modifier.ts +0 -410
  849. package/src/modifiers/responsive/types.ts +0 -226
  850. package/src/modifiers/responsive/utilities.ts +0 -478
  851. package/src/modifiers/scroll.ts +0 -297
  852. package/src/modifiers/shadows.ts +0 -321
  853. package/src/modifiers/size.ts +0 -208
  854. package/src/modifiers/text.ts +0 -416
  855. package/src/modifiers/transformations.ts +0 -640
  856. package/src/modifiers/transitions.ts +0 -218
  857. package/src/modifiers/types.ts +0 -889
  858. package/src/modifiers/typography.ts +0 -341
  859. package/src/modifiers/utility.ts +0 -209
  860. package/src/modifiers/utils.ts +0 -413
  861. package/src/plugins/__tests__/simplified-plugin-system.test.ts +0 -190
  862. package/src/plugins/component-loader-registry.ts +0 -371
  863. package/src/plugins/index.ts +0 -61
  864. package/src/plugins/legacy-adapter.ts +0 -84
  865. package/src/plugins/simplified-component-registry.ts +0 -130
  866. package/src/plugins/simplified-error-handler.ts +0 -372
  867. package/src/plugins/simplified-index.ts +0 -61
  868. package/src/plugins/simplified-lazy-loader.ts +0 -242
  869. package/src/plugins/simplified-plugin-manager.ts +0 -93
  870. package/src/plugins/simplified-tachui-instance.ts +0 -142
  871. package/src/plugins/simplified-types.ts +0 -79
  872. package/src/plugins/simplified-utils.ts +0 -118
  873. package/src/reactive/cleanup.ts +0 -241
  874. package/src/reactive/computed.ts +0 -281
  875. package/src/reactive/context.ts +0 -287
  876. package/src/reactive/effect.ts +0 -194
  877. package/src/reactive/enhanced-effect.ts +0 -318
  878. package/src/reactive/enhanced-signal.ts +0 -227
  879. package/src/reactive/equality.ts +0 -188
  880. package/src/reactive/globals.d.ts +0 -5
  881. package/src/reactive/index.ts +0 -150
  882. package/src/reactive/migration.ts +0 -335
  883. package/src/reactive/ownership.ts +0 -182
  884. package/src/reactive/scheduler.ts +0 -300
  885. package/src/reactive/signal.ts +0 -201
  886. package/src/reactive/theme.ts +0 -49
  887. package/src/reactive/types.ts +0 -103
  888. package/src/reactive/unified-scheduler.ts +0 -357
  889. package/src/runtime/component-context.ts +0 -343
  890. package/src/runtime/component.ts +0 -499
  891. package/src/runtime/context.ts +0 -527
  892. package/src/runtime/dev-tools.ts +0 -752
  893. package/src/runtime/development-warnings.ts +0 -114
  894. package/src/runtime/dom-bridge.ts +0 -570
  895. package/src/runtime/element-override.ts +0 -282
  896. package/src/runtime/error-boundary.ts +0 -955
  897. package/src/runtime/error-recovery.ts +0 -638
  898. package/src/runtime/error-reporting.ts +0 -808
  899. package/src/runtime/error-utils.ts +0 -698
  900. package/src/runtime/index.ts +0 -202
  901. package/src/runtime/lazy-component.ts +0 -268
  902. package/src/runtime/lifecycle.ts +0 -10
  903. package/src/runtime/mounting.ts +0 -17
  904. package/src/runtime/optimization.ts +0 -13
  905. package/src/runtime/performance.ts +0 -693
  906. package/src/runtime/props.ts +0 -434
  907. package/src/runtime/refs.ts +0 -13
  908. package/src/runtime/renderer.ts +0 -674
  909. package/src/runtime/semantic-role-manager.ts +0 -140
  910. package/src/runtime/types.ts +0 -282
  911. package/src/state/binding.ts +0 -381
  912. package/src/state/environment-object.ts +0 -444
  913. package/src/state/environment.ts +0 -351
  914. package/src/state/index.ts +0 -179
  915. package/src/state/observed-object.ts +0 -405
  916. package/src/state/state-manager.ts +0 -366
  917. package/src/state/state.ts +0 -339
  918. package/src/state/types.ts +0 -192
  919. package/src/sui-compat.ts +0 -163
  920. package/src/validation/__tests__/phase-1d-integration.test.ts +0 -558
  921. package/src/validation/advanced-debugging.ts +0 -860
  922. package/src/validation/build-time/detection.ts +0 -373
  923. package/src/validation/build-time/index.ts +0 -222
  924. package/src/validation/build-time/plugins.ts +0 -515
  925. package/src/validation/build-time/rules.ts +0 -624
  926. package/src/validation/build-time/transformer.ts +0 -372
  927. package/src/validation/build-time/types.ts +0 -232
  928. package/src/validation/comprehensive.ts +0 -1272
  929. package/src/validation/debug-tools.ts +0 -724
  930. package/src/validation/developer-experience.ts +0 -712
  931. package/src/validation/documentation-integration.ts +0 -835
  932. package/src/validation/enhanced-runtime.ts +0 -765
  933. package/src/validation/error-reporting.ts +0 -587
  934. package/src/validation/ide-integration.ts +0 -845
  935. package/src/validation/index.ts +0 -353
  936. package/src/validation/lifecycle-validation.ts +0 -636
  937. package/src/validation/performance-optimizer.ts +0 -599
  938. package/src/validation/plugin-registration.ts +0 -249
  939. package/src/validation/production-bypass.ts +0 -466
  940. package/src/validation/simple.ts +0 -465
  941. package/src/viewport/adapters/web-adapter.ts +0 -1385
  942. package/src/viewport/components.ts +0 -505
  943. package/src/viewport/environment.ts +0 -173
  944. package/src/viewport/index.ts +0 -290
  945. package/src/viewport/platform-detection.ts +0 -431
  946. package/src/viewport/types.ts +0 -371
  947. package/src/viewport/viewport-manager.ts +0 -979
@@ -1,1084 +0,0 @@
1
- /**
2
- * Enhanced List Components (Phase 5.5)
3
- *
4
- * SwiftUI-inspired List components with virtual scrolling, ForEach patterns,
5
- * and high-performance rendering for large datasets.
6
- */
7
-
8
- import type { ModifiableComponent, ModifierBuilder } from '../modifiers/types'
9
- import { createEffect, createRoot, createSignal, isComputed, isSignal } from '../reactive'
10
- import type { Signal } from '../reactive/types'
11
- import { h } from '../runtime'
12
- import type { ComponentInstance, ComponentProps, ComponentRef, DOMNode } from '../runtime/types'
13
- import { DOMRenderer } from '../runtime/renderer'
14
- import { ScrollView, type ScrollViewProps } from './ScrollView'
15
- import { withModifiers } from './wrapper'
16
-
17
- /**
18
- * List item selection mode
19
- */
20
- export type SelectionMode = 'none' | 'single' | 'multiple'
21
-
22
- /**
23
- * List style
24
- */
25
- export type ListStyle = 'plain' | 'grouped' | 'inset' | 'sidebar'
26
-
27
- /**
28
- * List item swipe action
29
- */
30
- export interface SwipeAction {
31
- id: string
32
- title: string
33
- backgroundColor?: string
34
- foregroundColor?: string
35
- icon?: string
36
- destructive?: boolean
37
- onTap: () => void
38
- }
39
-
40
- /**
41
- * List section header/footer
42
- */
43
- export interface ListSection<T = any> {
44
- id: string
45
- header?: string | ComponentInstance
46
- footer?: string | ComponentInstance
47
- items: T[]
48
- }
49
-
50
- /**
51
- * Virtual scrolling configuration
52
- */
53
- export interface VirtualScrollConfig {
54
- enabled: boolean
55
- itemHeight?: number | ((index: number, item: any) => number)
56
- estimatedItemHeight?: number
57
- overscan?: number
58
- threshold?: number
59
- }
60
-
61
- /**
62
- * List component properties
63
- */
64
- export interface ListProps<T = any> extends Omit<ScrollViewProps, 'children'> {
65
- // Data
66
- data?: T[] | Signal<T[]>
67
- sections?: ListSection<T>[] | Signal<ListSection<T>[]>
68
-
69
- // Rendering
70
- renderItem: (item: T, index: number) => ComponentInstance
71
- renderSectionHeader?: (section: ListSection<T>, index: number) => ComponentInstance
72
- renderSectionFooter?: (section: ListSection<T>, index: number) => ComponentInstance
73
-
74
- // Appearance
75
- style?: ListStyle
76
- separator?: boolean | ComponentInstance
77
-
78
- // Selection
79
- selectionMode?: SelectionMode
80
- selectedItems?: Signal<Set<string | number>>
81
- onSelectionChange?: (selectedItems: Set<string | number>) => void
82
-
83
- // Item actions
84
- leadingSwipeActions?: (item: T, index: number) => SwipeAction[]
85
- trailingSwipeActions?: (item: T, index: number) => SwipeAction[]
86
- onItemTap?: (item: T, index: number) => void
87
- onItemLongPress?: (item: T, index: number) => void
88
-
89
- // Virtual scrolling
90
- virtualScrolling?: VirtualScrollConfig
91
-
92
- // Performance
93
- getItemId?: (item: T, index: number) => string | number
94
-
95
- // Empty state
96
- emptyState?: ComponentInstance
97
-
98
- // Loading
99
- isLoading?: boolean | Signal<boolean>
100
- loadingIndicator?: ComponentInstance
101
-
102
- // Pull to refresh (inherited from ScrollView)
103
- onRefresh?: () => Promise<void>
104
-
105
- // Infinite scroll
106
- onLoadMore?: () => Promise<void>
107
- hasMore?: boolean | Signal<boolean>
108
- }
109
-
110
- /**
111
- * ForEach component properties
112
- */
113
- export interface ForEachProps<T = any> {
114
- data: T[] | Signal<T[]>
115
- children: (item: T, index: number) => ComponentInstance | ComponentInstance[]
116
- getItemId?: (item: T, index: number) => string | number
117
- key?: string | number
118
- ref?: ComponentRef
119
- }
120
-
121
- /**
122
- * ForEach component internal props that satisfy ComponentProps
123
- */
124
- interface ForEachInternalProps<T = any> extends ComponentProps {
125
- data: T[] | Signal<T[]>
126
- renderItem: (item: T, index: number) => ComponentInstance | ComponentInstance[]
127
- getItemId?: (item: T, index: number) => string | number
128
- }
129
-
130
- /**
131
- * Virtual scroll item info
132
- */
133
- interface VirtualScrollItem {
134
- index: number
135
- height: number
136
- offset: number
137
- item: any
138
- }
139
-
140
- /**
141
- * Enhanced List component class
142
- */
143
- export class EnhancedList<T = any> implements ComponentInstance<ListProps<T>> {
144
- public readonly type = 'component' as const
145
- public readonly id: string
146
- public mounted = false
147
- public cleanup: (() => void)[] = []
148
-
149
- private dataSignal: () => T[]
150
- private setData: (data: T[]) => void
151
- private sectionsSignal: () => ListSection<T>[]
152
- private setSections: (sections: ListSection<T>[]) => void
153
- private selectedItemsSignal: () => Set<string | number>
154
- private setSelectedItems: (items: Set<string | number>) => void
155
- private isLoadingSignal: () => boolean
156
- private setIsLoading: (loading: boolean) => void
157
-
158
- // Virtual scrolling state
159
- private virtualItems: VirtualScrollItem[] = []
160
- private visibleStartIndex = 0
161
- private visibleEndIndex = 0
162
- private scrollOffset = 0
163
- private containerHeight = 0
164
- private totalHeight = 0
165
-
166
- constructor(public props: ListProps<T>) {
167
- this.id = `list-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`
168
-
169
- // Create reactive signals
170
- const [dataSignal, setData] = createSignal<T[]>(this.resolveData())
171
- this.dataSignal = dataSignal
172
- this.setData = setData
173
-
174
- const [sectionsSignal, setSections] = createSignal<ListSection<T>[]>(this.resolveSections())
175
- this.sectionsSignal = sectionsSignal
176
- this.setSections = setSections
177
-
178
- const initialSelection = new Set<string | number>()
179
- const [selectedItemsSignal, setSelectedItems] = createSignal(initialSelection)
180
- this.selectedItemsSignal = selectedItemsSignal
181
- this.setSelectedItems = setSelectedItems
182
-
183
- const [isLoadingSignal, setIsLoading] = createSignal(this.resolveIsLoading())
184
- this.isLoadingSignal = isLoadingSignal
185
- this.setIsLoading = setIsLoading
186
-
187
- // Set up reactive data updates
188
- this.setupReactiveUpdates()
189
-
190
- // Initialize virtual scrolling if enabled
191
- if (props.virtualScrolling?.enabled) {
192
- this.initializeVirtualScrolling()
193
- }
194
- }
195
-
196
- /**
197
- * Helper to flatten render results
198
- */
199
- private flattenRenderResult(result: any): any[] {
200
- return Array.isArray(result) ? result : [result]
201
- }
202
-
203
- /**
204
- * Resolve data from various input types
205
- */
206
- private resolveData(): T[] {
207
- const { data } = this.props
208
-
209
- if (Array.isArray(data)) {
210
- return data
211
- } else if (isSignal(data)) {
212
- return data()
213
- } else {
214
- return []
215
- }
216
- }
217
-
218
- /**
219
- * Resolve sections from various input types
220
- */
221
- private resolveSections(): ListSection<T>[] {
222
- const { sections } = this.props
223
-
224
- if (Array.isArray(sections)) {
225
- return sections
226
- } else if (isSignal(sections)) {
227
- return sections()
228
- } else {
229
- return []
230
- }
231
- }
232
-
233
- /**
234
- * Resolve loading state
235
- */
236
- private resolveIsLoading(): boolean {
237
- const { isLoading } = this.props
238
-
239
- if (typeof isLoading === 'boolean') {
240
- return isLoading
241
- } else if (isSignal(isLoading)) {
242
- return isLoading()
243
- } else {
244
- return false
245
- }
246
- }
247
-
248
- /**
249
- * Set up reactive updates for data and state
250
- */
251
- private setupReactiveUpdates(): void {
252
- // Data updates
253
- if (isSignal(this.props.data)) {
254
- const effect = createEffect(() => {
255
- this.setData(this.resolveData())
256
- this.updateVirtualScrolling()
257
- })
258
- this.cleanup.push(() => effect.dispose())
259
- }
260
-
261
- // Sections updates
262
- if (isSignal(this.props.sections)) {
263
- const effect = createEffect(() => {
264
- this.setSections(this.resolveSections())
265
- this.updateVirtualScrolling()
266
- })
267
- this.cleanup.push(() => effect.dispose())
268
- }
269
-
270
- // Loading state updates
271
- if (isSignal(this.props.isLoading)) {
272
- const effect = createEffect(() => {
273
- this.setIsLoading(this.resolveIsLoading())
274
- })
275
- this.cleanup.push(() => effect.dispose())
276
- }
277
-
278
- // Selection updates
279
- if (this.props.selectedItems) {
280
- const effect = createEffect(() => {
281
- if (this.props.selectedItems) {
282
- this.setSelectedItems(this.props.selectedItems())
283
- }
284
- })
285
- this.cleanup.push(() => effect.dispose())
286
- }
287
- }
288
-
289
- /**
290
- * Initialize virtual scrolling calculations
291
- */
292
- private initializeVirtualScrolling(): void {
293
- const data = this.dataSignal()
294
- const config = this.props.virtualScrolling!
295
- const estimatedHeight = config.estimatedItemHeight || 50
296
-
297
- this.virtualItems = data.map((item, index) => ({
298
- index,
299
- height: estimatedHeight,
300
- offset: index * estimatedHeight,
301
- item,
302
- }))
303
-
304
- this.totalHeight = data.length * estimatedHeight
305
- }
306
-
307
- /**
308
- * Update virtual scrolling calculations
309
- */
310
- private updateVirtualScrolling(): void {
311
- if (!this.props.virtualScrolling?.enabled) return
312
-
313
- this.initializeVirtualScrolling()
314
- this.calculateVisibleRange()
315
- }
316
-
317
- /**
318
- * Calculate visible item range for virtual scrolling
319
- */
320
- private calculateVisibleRange(): void {
321
- if (!this.props.virtualScrolling?.enabled) return
322
-
323
- const config = this.props.virtualScrolling
324
- const overscan = config.overscan || 5
325
- const threshold = config.threshold || 0
326
-
327
- // Find first visible item
328
- let startIndex = 0
329
- for (let i = 0; i < this.virtualItems.length; i++) {
330
- if (
331
- this.virtualItems[i].offset + this.virtualItems[i].height >
332
- this.scrollOffset - threshold
333
- ) {
334
- startIndex = Math.max(0, i - overscan)
335
- break
336
- }
337
- }
338
-
339
- // Find last visible item
340
- let endIndex = this.virtualItems.length - 1
341
- for (let i = startIndex; i < this.virtualItems.length; i++) {
342
- if (this.virtualItems[i].offset > this.scrollOffset + this.containerHeight + threshold) {
343
- endIndex = Math.min(this.virtualItems.length - 1, i + overscan)
344
- break
345
- }
346
- }
347
-
348
- this.visibleStartIndex = startIndex
349
- this.visibleEndIndex = endIndex
350
- }
351
-
352
- /**
353
- * Handle item selection
354
- */
355
- private handleItemSelection(item: T, index: number): void {
356
- const { selectionMode, getItemId, onSelectionChange } = this.props
357
-
358
- if (selectionMode === 'none') return
359
-
360
- const itemId = getItemId ? getItemId(item, index) : index
361
- const currentSelection = new Set(this.selectedItemsSignal())
362
-
363
- if (selectionMode === 'single') {
364
- currentSelection.clear()
365
- currentSelection.add(itemId)
366
- } else if (selectionMode === 'multiple') {
367
- if (currentSelection.has(itemId)) {
368
- currentSelection.delete(itemId)
369
- } else {
370
- currentSelection.add(itemId)
371
- }
372
- }
373
-
374
- this.setSelectedItems(currentSelection)
375
-
376
- if (onSelectionChange) {
377
- onSelectionChange(currentSelection)
378
- }
379
- }
380
-
381
- /**
382
- * Create list item component
383
- */
384
- private createListItem(item: T, index: number, isSelected: boolean): ComponentInstance {
385
- const { renderItem, style, onItemTap, onItemLongPress } = this.props
386
-
387
- const itemContent = renderItem(item, index)
388
-
389
- // Wrap in interactive container
390
- return {
391
- type: 'component',
392
- id: `${this.id}-item-${index}`,
393
- mounted: false,
394
- cleanup: [],
395
- props: {},
396
- render: () => {
397
- const itemElement = h(
398
- 'div',
399
- {
400
- class: `tachui-list-item tachui-list-item-${style || 'plain'}`,
401
- style: {
402
- display: 'flex',
403
- flexDirection: 'column',
404
- position: 'relative',
405
- backgroundColor: isSelected ? '#e6f3ff' : 'transparent',
406
- transition: 'background-color 0.2s ease',
407
- cursor: onItemTap ? 'pointer' : 'default',
408
- },
409
- },
410
- ...this.flattenRenderResult(itemContent.render())
411
- )
412
-
413
- // Add event handlers
414
- if (itemElement.element) {
415
- const element = itemElement.element as HTMLElement
416
-
417
- if (onItemTap) {
418
- element.addEventListener('click', () => onItemTap(item, index))
419
- }
420
-
421
- if (onItemLongPress) {
422
- let longPressTimer: NodeJS.Timeout
423
-
424
- const startLongPress = () => {
425
- longPressTimer = setTimeout(() => onItemLongPress(item, index), 500)
426
- }
427
-
428
- const cancelLongPress = () => {
429
- clearTimeout(longPressTimer)
430
- }
431
-
432
- element.addEventListener('mousedown', startLongPress)
433
- element.addEventListener('mouseup', cancelLongPress)
434
- element.addEventListener('mouseleave', cancelLongPress)
435
- element.addEventListener('touchstart', startLongPress)
436
- element.addEventListener('touchend', cancelLongPress)
437
- }
438
-
439
- // Selection handling
440
- if (this.props.selectionMode !== 'none') {
441
- element.addEventListener('click', (e) => {
442
- if (e.metaKey || e.ctrlKey || this.props.selectionMode === 'multiple') {
443
- e.preventDefault()
444
- this.handleItemSelection(item, index)
445
- }
446
- })
447
- }
448
- }
449
-
450
- return [itemElement]
451
- },
452
- }
453
- }
454
-
455
- /**
456
- * Create list separator
457
- */
458
- private createSeparator(): ComponentInstance | null {
459
- const { separator } = this.props
460
-
461
- if (!separator) return null
462
-
463
- if (typeof separator === 'object' && 'render' in separator) {
464
- return separator
465
- }
466
-
467
- return {
468
- type: 'component',
469
- id: `${this.id}-separator`,
470
- mounted: false,
471
- cleanup: [],
472
- props: {},
473
- render: () => [
474
- h('div', {
475
- class: 'tachui-list-separator',
476
- style: {
477
- height: '1px',
478
- backgroundColor: '#e0e0e0',
479
- margin: '0 16px',
480
- },
481
- }),
482
- ],
483
- }
484
- }
485
-
486
- /**
487
- * Create section header
488
- */
489
- private createSectionHeader(section: ListSection<T>, index: number): ComponentInstance | null {
490
- if (!section.header) return null
491
-
492
- if (typeof section.header === 'string') {
493
- return {
494
- type: 'component',
495
- id: `${this.id}-section-header-${index}`,
496
- mounted: false,
497
- cleanup: [],
498
- props: {},
499
- render: () => [
500
- h(
501
- 'div',
502
- {
503
- class: 'tachui-list-section-header',
504
- style: {
505
- padding: '8px 16px',
506
- backgroundColor: '#f8f9fa',
507
- fontWeight: '600',
508
- fontSize: '14px',
509
- color: '#666',
510
- textTransform: 'uppercase',
511
- letterSpacing: '0.5px',
512
- },
513
- },
514
- section.header as string
515
- ),
516
- ],
517
- }
518
- }
519
-
520
- return this.props.renderSectionHeader
521
- ? this.props.renderSectionHeader(section, index)
522
- : (section.header as ComponentInstance)
523
- }
524
-
525
- /**
526
- * Create section footer
527
- */
528
- private createSectionFooter(section: ListSection<T>, index: number): ComponentInstance | null {
529
- if (!section.footer) return null
530
-
531
- if (typeof section.footer === 'string') {
532
- return {
533
- type: 'component',
534
- id: `${this.id}-section-footer-${index}`,
535
- mounted: false,
536
- cleanup: [],
537
- props: {},
538
- render: () => [
539
- h(
540
- 'div',
541
- {
542
- class: 'tachui-list-section-footer',
543
- style: {
544
- padding: '8px 16px',
545
- fontSize: '12px',
546
- color: '#999',
547
- },
548
- },
549
- section.footer as string
550
- ),
551
- ],
552
- }
553
- }
554
-
555
- return this.props.renderSectionFooter
556
- ? this.props.renderSectionFooter(section, index)
557
- : (section.footer as ComponentInstance)
558
- }
559
-
560
- /**
561
- * Create empty state component
562
- */
563
- private createEmptyState(): ComponentInstance | null {
564
- const { emptyState } = this.props
565
-
566
- if (!emptyState) {
567
- return {
568
- type: 'component',
569
- id: `${this.id}-empty`,
570
- mounted: false,
571
- cleanup: [],
572
- props: {},
573
- render: () => [
574
- h(
575
- 'div',
576
- {
577
- class: 'tachui-list-empty',
578
- style: {
579
- display: 'flex',
580
- flexDirection: 'column',
581
- alignItems: 'center',
582
- justifyContent: 'center',
583
- padding: '40px 20px',
584
- color: '#999',
585
- fontSize: '16px',
586
- },
587
- },
588
- 'No items to display'
589
- ),
590
- ],
591
- }
592
- }
593
-
594
- return emptyState
595
- }
596
-
597
- /**
598
- * Create loading indicator
599
- */
600
- private createLoadingIndicator(): ComponentInstance | null {
601
- const { loadingIndicator } = this.props
602
-
603
- if (!loadingIndicator) {
604
- return {
605
- type: 'component',
606
- id: `${this.id}-loading`,
607
- mounted: false,
608
- cleanup: [],
609
- props: {},
610
- render: () => [
611
- h(
612
- 'div',
613
- {
614
- class: 'tachui-list-loading',
615
- style: {
616
- display: 'flex',
617
- alignItems: 'center',
618
- justifyContent: 'center',
619
- padding: '20px',
620
- color: '#999',
621
- },
622
- },
623
- 'Loading...'
624
- ),
625
- ],
626
- }
627
- }
628
-
629
- return loadingIndicator
630
- }
631
-
632
- /**
633
- * Render virtual scrolling content
634
- */
635
- private renderVirtualContent(): ComponentInstance[] {
636
- if (!this.props.virtualScrolling?.enabled) {
637
- return this.renderRegularContent()
638
- }
639
-
640
- const data = this.dataSignal()
641
- const selectedItems = this.selectedItemsSignal()
642
- const separator = this.createSeparator()
643
-
644
- const visibleItems: ComponentInstance[] = []
645
-
646
- // Add spacer for items before visible range
647
- if (this.visibleStartIndex > 0) {
648
- const spacerHeight = this.virtualItems[this.visibleStartIndex]?.offset || 0
649
- visibleItems.push({
650
- type: 'component',
651
- id: `${this.id}-spacer-top`,
652
- mounted: false,
653
- cleanup: [],
654
- props: {},
655
- render: () => [
656
- h('div', {
657
- style: { height: `${spacerHeight}px` },
658
- }),
659
- ],
660
- })
661
- }
662
-
663
- // Render visible items
664
- for (let i = this.visibleStartIndex; i <= this.visibleEndIndex && i < data.length; i++) {
665
- const item = data[i]
666
- const itemId = this.props.getItemId ? this.props.getItemId(item, i) : i
667
- const isSelected = selectedItems.has(itemId)
668
-
669
- visibleItems.push(this.createListItem(item, i, isSelected))
670
-
671
- if (separator && i < data.length - 1) {
672
- visibleItems.push(separator)
673
- }
674
- }
675
-
676
- // Add spacer for items after visible range
677
- if (this.visibleEndIndex < data.length - 1) {
678
- const remainingHeight =
679
- this.totalHeight - (this.virtualItems[this.visibleEndIndex + 1]?.offset || 0)
680
- visibleItems.push({
681
- type: 'component',
682
- id: `${this.id}-spacer-bottom`,
683
- mounted: false,
684
- cleanup: [],
685
- props: {},
686
- render: () => [
687
- h('div', {
688
- style: { height: `${remainingHeight}px` },
689
- }),
690
- ],
691
- })
692
- }
693
-
694
- return visibleItems
695
- }
696
-
697
- /**
698
- * Render regular (non-virtual) content
699
- */
700
- private renderRegularContent(): ComponentInstance[] {
701
- const data = this.dataSignal()
702
- const sections = this.sectionsSignal()
703
- const selectedItems = this.selectedItemsSignal()
704
- const separator = this.createSeparator()
705
-
706
- const content: ComponentInstance[] = []
707
-
708
- // Render sections if available
709
- if (sections.length > 0) {
710
- sections.forEach((section, sectionIndex) => {
711
- // Section header
712
- const header = this.createSectionHeader(section, sectionIndex)
713
- if (header) content.push(header)
714
-
715
- // Section items
716
- section.items.forEach((item, itemIndex) => {
717
- const globalIndex = sectionIndex * 1000 + itemIndex // Simple global index
718
- const itemId = this.props.getItemId
719
- ? this.props.getItemId(item, globalIndex)
720
- : globalIndex
721
- const isSelected = selectedItems.has(itemId)
722
-
723
- content.push(this.createListItem(item, globalIndex, isSelected))
724
-
725
- if (separator && itemIndex < section.items.length - 1) {
726
- content.push(separator)
727
- }
728
- })
729
-
730
- // Section footer
731
- const footer = this.createSectionFooter(section, sectionIndex)
732
- if (footer) content.push(footer)
733
- })
734
- } else {
735
- // Render flat data
736
- data.forEach((item, index) => {
737
- const itemId = this.props.getItemId ? this.props.getItemId(item, index) : index
738
- const isSelected = selectedItems.has(itemId)
739
-
740
- content.push(this.createListItem(item, index, isSelected))
741
-
742
- if (separator && index < data.length - 1) {
743
- content.push(separator)
744
- }
745
- })
746
- }
747
-
748
- return content
749
- }
750
-
751
- /**
752
- * Handle scroll events for virtual scrolling and infinite scroll
753
- */
754
- private handleListScroll = (scrollInfo: any) => {
755
- this.scrollOffset = scrollInfo.offset.y
756
- this.containerHeight = scrollInfo.containerSize.height
757
-
758
- // Update virtual scrolling
759
- if (this.props.virtualScrolling?.enabled) {
760
- this.calculateVisibleRange()
761
- }
762
-
763
- // Handle infinite scroll
764
- if (this.props.onLoadMore && scrollInfo.edges.bottom) {
765
- const hasMore = isSignal(this.props.hasMore) ? this.props.hasMore() : this.props.hasMore
766
- if (hasMore && !this.isLoadingSignal()) {
767
- this.setIsLoading(true)
768
- this.props.onLoadMore().finally(() => {
769
- this.setIsLoading(false)
770
- })
771
- }
772
- }
773
-
774
- // Forward to parent scroll handler
775
- if (this.props.onScroll) {
776
- this.props.onScroll(scrollInfo)
777
- }
778
- }
779
-
780
- /**
781
- * Render the list component
782
- */
783
- render() {
784
- const data = this.dataSignal()
785
- const isLoading = this.isLoadingSignal()
786
-
787
- // Show loading indicator if loading and no data
788
- if (isLoading && data.length === 0) {
789
- const loadingIndicator = this.createLoadingIndicator()
790
- return loadingIndicator ? loadingIndicator.render() : []
791
- }
792
-
793
- // Show empty state if no data
794
- if (data.length === 0 && !isLoading) {
795
- const emptyState = this.createEmptyState()
796
- return emptyState ? emptyState.render() : []
797
- }
798
-
799
- // Render list content
800
- const content = this.props.virtualScrolling?.enabled
801
- ? this.renderVirtualContent()
802
- : this.renderRegularContent()
803
-
804
- // Add loading indicator at bottom if loading more
805
- if (isLoading && data.length > 0) {
806
- const loadingIndicator = this.createLoadingIndicator()
807
- if (loadingIndicator) {
808
- content.push(loadingIndicator)
809
- }
810
- }
811
-
812
- // Create scroll view props
813
- const scrollViewProps: ScrollViewProps = {
814
- ...this.props,
815
- children: content,
816
- onScroll: this.handleListScroll,
817
- }
818
-
819
- // Create scroll view
820
- const scrollView = new (ScrollView as any)(scrollViewProps)
821
- return scrollView.render()
822
- }
823
- }
824
-
825
- /**
826
- * ForEach component implementation with self-contained reactivity
827
- */
828
- export class ForEach<T = any> implements ComponentInstance<ForEachInternalProps<T>> {
829
- public readonly type = 'component' as const
830
- public readonly id: string
831
- public mounted = false
832
- public cleanup: (() => void)[] = []
833
- public props: ForEachInternalProps<T>
834
-
835
- private dataSignal: () => T[]
836
-
837
- constructor(props: ForEachProps<T>) {
838
- // Convert to internal props format
839
- this.props = {
840
- ...props,
841
- renderItem: props.children,
842
- children: undefined, // ComponentProps children
843
- } as ForEachInternalProps<T>
844
- this.id = `foreach-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`
845
-
846
- // Set up reactive data
847
- this.dataSignal = isSignal(props.data) ? props.data : () => props.data as T[]
848
- }
849
-
850
- /**
851
- * Helper to flatten render results
852
- */
853
- private flattenRenderResult(result: any): any[] {
854
- return Array.isArray(result) ? result : [result]
855
- }
856
-
857
- /**
858
- * Render children for current data
859
- */
860
- private renderChildren(): DOMNode[] {
861
- const data = this.dataSignal()
862
-
863
- return data.flatMap((item, index) => {
864
- const children = this.props.renderItem(item, index)
865
- const childArray = Array.isArray(children) ? children : [children]
866
- return childArray.flatMap((child) => this.flattenRenderResult(child.render()))
867
- })
868
- }
869
-
870
- /**
871
- * Render ForEach with reactive container pattern like Show component
872
- */
873
- render(): DOMNode[] {
874
- // Check if data source is reactive
875
- const isReactive = isSignal(this.props.data) || isComputed(this.props.data)
876
-
877
- if (!isReactive) {
878
- // Static data - simple render
879
- return this.renderChildren()
880
- }
881
-
882
- // Reactive data - create reactive container
883
- const containerNode: DOMNode = {
884
- type: 'element',
885
- tag: 'div',
886
- props: {
887
- style: { display: 'contents' } // Make container invisible
888
- },
889
- children: [],
890
- dispose: undefined,
891
- }
892
-
893
- // Create reactive effect that updates the container
894
- const cleanup = createRoot(() => {
895
- const effect = createEffect(() => {
896
- const newChildren = this.renderChildren()
897
- containerNode.children = newChildren
898
-
899
- // Update DOM if already rendered
900
- if (containerNode.element && containerNode.element instanceof HTMLElement) {
901
- this.updateContainerDOM(containerNode.element, newChildren)
902
- }
903
- })
904
-
905
- return () => effect.dispose()
906
- })
907
-
908
- containerNode.dispose = cleanup
909
-
910
- // Initialize with current children
911
- const initialChildren = this.renderChildren()
912
- containerNode.children = initialChildren
913
-
914
- return [containerNode]
915
- }
916
-
917
- /**
918
- * Update the container DOM element with new children using TachUI's renderer
919
- */
920
- private updateContainerDOM(container: HTMLElement, children: DOMNode[]): void {
921
- // Clear existing content
922
- container.innerHTML = ''
923
-
924
- // Use TachUI's renderer to properly handle modifiers and reactivity
925
- const renderer = new DOMRenderer()
926
-
927
- // Render new content using TachUI's renderer which handles modifiers
928
- children.forEach(child => {
929
- try {
930
- const element = renderer.render(child)
931
- if (element) {
932
- container.appendChild(element)
933
- }
934
- } catch (error) {
935
- console.error('Error rendering ForEach component child:', error)
936
- }
937
- })
938
- }
939
-
940
- /**
941
- * Cleanup resources
942
- */
943
- dispose(): void {
944
- this.cleanup.forEach(fn => {
945
- try {
946
- fn()
947
- } catch (error) {
948
- console.error('ForEach component cleanup error:', error)
949
- }
950
- })
951
- this.cleanup = []
952
- }
953
- }
954
-
955
- /**
956
- * Create enhanced List component with modifier support
957
- */
958
- export function List<T = any>(
959
- props: ListProps<T>
960
- ): ModifiableComponent<ListProps<T>> & {
961
- modifier: ModifierBuilder<ModifiableComponent<ListProps<T>>>
962
- } {
963
- const component = new EnhancedList(props)
964
- return withModifiers(component)
965
- }
966
-
967
- /**
968
- * Create ForEach component
969
- */
970
- export function ForEachComponent<T = any>(
971
- props: ForEachProps<T>
972
- ): ComponentInstance<ForEachInternalProps<T>> {
973
- return new ForEach(props)
974
- }
975
-
976
- /**
977
- * For component alias (SolidJS-style compatibility)
978
- *
979
- * @example
980
- * ```typescript
981
- * For({
982
- * each: items,
983
- * children: (item, index) => Text(item.name)
984
- * })
985
- * ```
986
- */
987
- export interface ForProps<T = any> {
988
- each: T[] | Signal<T[]>
989
- children: (item: T, index: number) => ComponentInstance | ComponentInstance[]
990
- fallback?: ComponentInstance
991
- key?: string | number
992
- ref?: ComponentRef
993
- }
994
-
995
- export function For<T = any>(props: ForProps<T>): ComponentInstance<ForEachInternalProps<T>> {
996
- // Convert SolidJS-style props to TachUI ForEach props
997
- const forEachProps: ForEachProps<T> = {
998
- data: props.each,
999
- children: props.children,
1000
- key: props.key,
1001
- ref: props.ref,
1002
- }
1003
-
1004
- return new ForEach(forEachProps)
1005
- }
1006
-
1007
- /**
1008
- * List utility functions
1009
- */
1010
- export const ListUtils = {
1011
- /**
1012
- * Create a simple list from array
1013
- */
1014
- simple<T>(
1015
- data: T[] | Signal<T[]>,
1016
- renderItem: (item: T, index: number) => ComponentInstance,
1017
- props: Omit<ListProps<T>, 'data' | 'renderItem'> = {}
1018
- ): ModifiableComponent<ListProps<T>> & {
1019
- modifier: ModifierBuilder<ModifiableComponent<ListProps<T>>>
1020
- } {
1021
- return List({
1022
- ...props,
1023
- data,
1024
- renderItem,
1025
- })
1026
- },
1027
-
1028
- /**
1029
- * Create a sectioned list
1030
- */
1031
- sectioned<T>(
1032
- sections: ListSection<T>[] | Signal<ListSection<T>[]>,
1033
- renderItem: (item: T, index: number) => ComponentInstance,
1034
- props: Omit<ListProps<T>, 'sections' | 'renderItem'> = {}
1035
- ): ModifiableComponent<ListProps<T>> & {
1036
- modifier: ModifierBuilder<ModifiableComponent<ListProps<T>>>
1037
- } {
1038
- return List({
1039
- ...props,
1040
- sections,
1041
- renderItem,
1042
- })
1043
- },
1044
-
1045
- /**
1046
- * Create a virtual scrolling list for large datasets
1047
- */
1048
- virtual<T>(
1049
- data: T[] | Signal<T[]>,
1050
- renderItem: (item: T, index: number) => ComponentInstance,
1051
- virtualConfig: VirtualScrollConfig,
1052
- props: Omit<ListProps<T>, 'data' | 'renderItem' | 'virtualScrolling'> = {}
1053
- ): ModifiableComponent<ListProps<T>> & {
1054
- modifier: ModifierBuilder<ModifiableComponent<ListProps<T>>>
1055
- } {
1056
- return List({
1057
- ...props,
1058
- data,
1059
- renderItem,
1060
- virtualScrolling: virtualConfig,
1061
- })
1062
- },
1063
-
1064
- /**
1065
- * Create an infinite scrolling list
1066
- */
1067
- infinite<T>(
1068
- data: T[] | Signal<T[]>,
1069
- renderItem: (item: T, index: number) => ComponentInstance,
1070
- onLoadMore: () => Promise<void>,
1071
- hasMore: boolean | Signal<boolean>,
1072
- props: Omit<ListProps<T>, 'data' | 'renderItem' | 'onLoadMore' | 'hasMore'> = {}
1073
- ): ModifiableComponent<ListProps<T>> & {
1074
- modifier: ModifierBuilder<ModifiableComponent<ListProps<T>>>
1075
- } {
1076
- return List({
1077
- ...props,
1078
- data,
1079
- renderItem,
1080
- onLoadMore,
1081
- hasMore,
1082
- })
1083
- },
1084
- }