@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,6 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});require("../reactive/cleanup.cjs");require("../reactive/unified-scheduler.cjs");const v=require("../reactive/effect.cjs"),a=require("../reactive/signal.cjs");require("../reactive/scheduler.cjs");require("../reactive/theme.cjs");require("../runtime/component.cjs");require("../runtime/context.cjs");require("../runtime/dev-tools.cjs");require("../runtime/dom-bridge.cjs");require("../runtime/error-boundary.cjs");require("../runtime/error-reporting.cjs");require("../runtime/performance.cjs");const m=require("../runtime/renderer.cjs");require("../runtime/element-override.cjs");require("../runtime/semantic-role-manager.cjs");require("../runtime/development-warnings.cjs");const T=require("./wrapper.cjs");var w=Object.defineProperty,b=(i,t,e)=>t in i?w(i,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[t]=e,l=(i,t,e)=>b(i,typeof t!="symbol"?t+"":t,e);class y{constructor(t){this.props=t,l(this,"type","component"),l(this,"id"),l(this,"mounted",!1),l(this,"cleanup",[]),l(this,"scrollElement",null),l(this,"contentOffsetSignal"),l(this,"setContentOffset"),l(this,"contentSizeSignal"),l(this,"setContentSize"),l(this,"setIsScrolling"),l(this,"pullToRefreshStateSignal"),l(this,"setPullToRefreshState"),l(this,"scrollEventThrottle"),l(this,"lastScrollTime",0),l(this,"scrollVelocity",{x:0,y:0}),l(this,"lastScrollOffset",{x:0,y:0}),l(this,"pullStartY",0),l(this,"isPulling",!1),l(this,"handleScroll",o=>{if(!this.scrollElement)return;const h=performance.now(),c=h-this.lastScrollTime;if(c<this.scrollEventThrottle)return;const u={x:this.scrollElement.scrollLeft,y:this.scrollElement.scrollTop};this.scrollVelocity=this.calculateVelocity(u,c),this.setContentOffset(u),this.setContentSize({width:this.scrollElement.scrollWidth,height:this.scrollElement.scrollHeight});const p=this.detectScrollEdges(),E={offset:u,velocity:this.scrollVelocity,contentSize:{width:this.scrollElement.scrollWidth,height:this.scrollElement.scrollHeight},containerSize:{width:this.scrollElement.clientWidth,height:this.scrollElement.clientHeight},edges:p};this.props.onScroll&&this.props.onScroll(E),p.top&&this.props.onReachTop&&this.props.onReachTop(),p.bottom&&this.props.onReachBottom&&this.props.onReachBottom(),p.left&&this.props.onReachLeft&&this.props.onReachLeft(),p.right&&this.props.onReachRight&&this.props.onReachRight(),this.lastScrollOffset=u,this.lastScrollTime=h}),l(this,"handleScrollStart",()=>{this.setIsScrolling(!0),this.props.onScrollBegin&&this.props.onScrollBegin()}),l(this,"handleScrollEnd",()=>{this.setIsScrolling(!1),this.props.onScrollEnd&&this.props.onScrollEnd()}),l(this,"handleTouchStart",o=>{this.props.refreshControl?.enabled&&(this.pullStartY=o.touches[0].clientY,this.isPulling=!1)}),l(this,"handleTouchMove",o=>{if(!this.props.refreshControl?.enabled||!this.scrollElement)return;const c=o.touches[0].clientY-this.pullStartY,u=this.props.refreshControl.threshold||80;this.scrollElement.scrollTop<=0&&c>0&&(this.isPulling=!0,c>u?this.setPullToRefreshState("ready"):this.setPullToRefreshState("pulling"))}),l(this,"handleTouchEnd",async()=>{if(!this.props.refreshControl?.enabled||!this.isPulling)return;if(this.pullToRefreshStateSignal()==="ready"){this.setPullToRefreshState("refreshing");try{await this.props.refreshControl.onRefresh()}catch(h){console.error("Pull to refresh error:",h)}finally{this.setPullToRefreshState("idle")}}else this.setPullToRefreshState("idle");this.isPulling=!1}),this.id=`scrollview-${Date.now()}-${Math.random().toString(36).substr(2,9)}`,this.scrollEventThrottle=t.scrollEventThrottle||16;const[e,s]=a.createSignal({x:0,y:0});this.contentOffsetSignal=e,this.setContentOffset=s;const[r,n]=a.createSignal({width:0,height:0});this.contentSizeSignal=r,this.setContentSize=n;const[,f]=a.createSignal(!1);this.setIsScrolling=f;const[g,d]=a.createSignal("idle");if(this.pullToRefreshStateSignal=g,this.setPullToRefreshState=d,t.contentOffset&&a.isSignal(t.contentOffset)){this.setContentOffset(t.contentOffset());const o=v.createEffect(()=>{t.contentOffset&&a.isSignal(t.contentOffset)&&this.setContentOffset(t.contentOffset())});this.cleanup.push(()=>o.dispose())}if(t.contentSize&&a.isSignal(t.contentSize)){this.setContentSize(t.contentSize());const o=v.createEffect(()=>{t.contentSize&&a.isSignal(t.contentSize)&&this.setContentSize(t.contentSize())});this.cleanup.push(()=>o.dispose())}}calculateVelocity(t,e){const s=t.x-this.lastScrollOffset.x,r=t.y-this.lastScrollOffset.y;return{x:e>0?s/e:0,y:e>0?r/e:0}}detectScrollEdges(){if(!this.scrollElement)return{top:!1,bottom:!1,left:!1,right:!1};const{scrollTop:t,scrollLeft:e,scrollHeight:s,scrollWidth:r,clientHeight:n,clientWidth:f}=this.scrollElement;return{top:t<=0,bottom:t+n>=s-1,left:e<=0,right:e+f>=r-1}}setupScrollHandlers(t){let e;const s=()=>{clearTimeout(e),this.handleScrollStart()},r=()=>{clearTimeout(e),e=setTimeout(()=>{this.handleScrollEnd()},150)},n=f=>{s(),this.handleScroll(f),r()};t.addEventListener("scroll",n,{passive:!0}),t.addEventListener("touchstart",this.handleTouchStart,{passive:!0}),t.addEventListener("touchmove",this.handleTouchMove,{passive:!1}),t.addEventListener("touchend",this.handleTouchEnd,{passive:!0}),this.cleanup.push(()=>{t.removeEventListener("scroll",n),t.removeEventListener("touchstart",this.handleTouchStart),t.removeEventListener("touchmove",this.handleTouchMove),t.removeEventListener("touchend",this.handleTouchEnd),clearTimeout(e)})}getOverflowStyles(t){switch(t){case"vertical":return{overflowX:"hidden",overflowY:"auto"};case"horizontal":return{overflowX:"auto",overflowY:"hidden"};case"both":return{overflow:"auto"};default:return{overflowX:"hidden",overflowY:"auto"}}}applyScrollViewStyles(t){const{showsScrollIndicator:e=!0,bounces:s=!0}=this.props;if(!e){t.style.scrollbarWidth="none",t.style.msOverflowStyle="none";const r=document.createElement("style");r.textContent=`
2
- #${t.id}::-webkit-scrollbar {
3
- display: none;
4
- }
5
- `,document.head.appendChild(r),this.cleanup.push(()=>{document.head.removeChild(r)})}s?t.style.webkitOverflowScrolling="touch":t.style.overscrollBehavior="none",t.style.scrollBehavior="smooth"}applyContentInsets(t){const{contentInset:e}=this.props;if(e){const{top:s=0,bottom:r=0,left:n=0,right:f=0}=e;t.style.padding=`${s}px ${f}px ${r}px ${n}px`}}createPullToRefreshIndicator(){if(!this.props.refreshControl?.enabled)return null;const t=this.pullToRefreshStateSignal(),e=this.props.refreshControl.tintColor||"#007AFF";let s="";switch(t){case"pulling":s="↓ Pull to refresh";break;case"ready":s="↑ Release to refresh";break;case"refreshing":s="⟳ Refreshing...";break;default:s=""}return s?{type:"component",id:`${this.id}-refresh`,mounted:!1,cleanup:[],props:{},render:()=>[m.h("div",{style:{position:"absolute",top:"-60px",left:"50%",transform:"translateX(-50%)",padding:"10px 20px",backgroundColor:"#f8f9fa",borderRadius:"20px",color:e,fontSize:"14px",fontWeight:"500",textAlign:"center",zIndex:1e3,transition:"all 0.3s ease",opacity:t==="idle"?0:1}},s)]}:null}scrollTo(t,e="smooth"){if(!this.scrollElement)return;const s={behavior:e};t.x!==void 0&&(s.left=t.x),t.y!==void 0&&(s.top=t.y),this.scrollElement.scrollTo(s)}scrollToTop(t="smooth"){this.scrollTo({x:0,y:0},t)}scrollToBottom(t="smooth"){this.scrollElement&&this.scrollTo({x:0,y:this.scrollElement.scrollHeight-this.scrollElement.clientHeight},t)}render(){const{children:t=[],scrollEnabled:e=!0}=this.props,s=m.h("div",{class:"tachui-scrollview-content",style:{minHeight:"100%",minWidth:"100%"}},...t.flatMap(o=>o.render())),r=this.createPullToRefreshIndicator(),n=[];if(r){const o=r.render(),h=Array.isArray(o)?o:[o];n.push(...h.filter(c=>c))}n.push(s);const{direction:f="vertical"}=this.props,g=this.getOverflowStyles(f),d=m.h("div",{id:this.id,class:"tachui-scrollview",style:{height:"100%",width:"100%",position:"relative",...g}},...n);if(d.element){const o=d.element;this.scrollElement=o,this.applyScrollViewStyles(o),this.setupScrollHandlers(o),s.element&&this.applyContentInsets(s.element);const h=()=>{const c=a.isSignal(e)?e():e;o.style.overflow=c?"auto":"hidden",o.style.pointerEvents=c?"auto":"none"};if(a.isSignal(e)){const c=v.createEffect(h);this.cleanup.push(()=>c.dispose())}else h()}return[d]}}function S(i={}){const t=new y(i);return T.withModifiers(t)}const C={withRefresh(i,t,e={}){return S({children:i,refreshControl:{enabled:!0,onRefresh:t,...e}})},horizontal(i,t={}){return S({...t,children:i,direction:"horizontal"})},paged(i,t={}){return S({...t,children:i,pagingEnabled:!0})}};exports.EnhancedScrollView=y;exports.ScrollView=S;exports.ScrollViewUtils=C;
6
- //# sourceMappingURL=ScrollView.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ScrollView.cjs","sources":["../../src/components/ScrollView.ts"],"sourcesContent":["/**\n * Enhanced ScrollView Component (Phase 5.5)\n *\n * SwiftUI-inspired ScrollView component with performance optimization,\n * smooth scrolling, pull-to-refresh, and advanced scroll handling.\n */\n\nimport type { ModifiableComponent, ModifierBuilder } from '../modifiers/types'\nimport { createEffect, createSignal, isSignal } from '../reactive'\nimport type { Signal } from '../reactive/types'\nimport { h } from '../runtime'\nimport type { ComponentInstance, ComponentProps } from '../runtime/types'\nimport { withModifiers } from './wrapper'\n\n/**\n * Scroll direction\n */\nexport type ScrollDirection = 'vertical' | 'horizontal' | 'both'\n\n/**\n * Scroll behavior for programmatic scrolling\n */\nexport type ScrollBehavior = 'auto' | 'smooth' | 'instant'\n\n/**\n * Content offset position\n */\nexport interface ContentOffset {\n x: number\n y: number\n}\n\n/**\n * Scroll edge detection\n */\nexport interface ScrollEdges {\n top: boolean\n bottom: boolean\n left: boolean\n right: boolean\n}\n\n/**\n * Pull-to-refresh state\n */\nexport type PullToRefreshState = 'idle' | 'pulling' | 'ready' | 'refreshing'\n\n/**\n * Scroll event information\n */\nexport interface ScrollEventInfo {\n offset: ContentOffset\n velocity: ContentOffset\n contentSize: { width: number; height: number }\n containerSize: { width: number; height: number }\n edges: ScrollEdges\n}\n\n/**\n * ScrollView component properties\n */\nexport interface ScrollViewProps extends ComponentProps {\n // Content\n children?: ComponentInstance[]\n\n // Scroll behavior\n direction?: ScrollDirection\n showsScrollIndicator?: boolean\n bounces?: boolean\n scrollEnabled?: boolean | Signal<boolean>\n\n // Content sizing\n contentOffset?: Signal<ContentOffset>\n contentSize?: Signal<{ width: number; height: number }>\n\n // Pull to refresh\n refreshControl?: {\n enabled: boolean\n onRefresh: () => Promise<void>\n refreshing?: Signal<boolean>\n threshold?: number\n tintColor?: string\n }\n\n // Scroll events\n onScroll?: (info: ScrollEventInfo) => void\n onScrollBegin?: () => void\n onScrollEnd?: () => void\n onReachTop?: () => void\n onReachBottom?: () => void\n onReachLeft?: () => void\n onReachRight?: () => void\n\n // Performance\n scrollEventThrottle?: number\n decelerationRate?: 'normal' | 'fast' | number\n\n // Content insets\n contentInset?: {\n top?: number\n bottom?: number\n left?: number\n right?: number\n }\n\n // Snap behavior\n pagingEnabled?: boolean\n snapToAlignment?: 'start' | 'center' | 'end'\n snapToInterval?: number\n\n // Keyboard behavior\n keyboardDismissMode?: 'none' | 'on-drag' | 'interactive'\n\n // Accessibility\n accessibilityLabel?: string\n accessibilityRole?: string\n}\n\n/**\n * Enhanced ScrollView component class\n */\nexport class EnhancedScrollView implements ComponentInstance<ScrollViewProps> {\n public readonly type = 'component' as const\n public readonly id: string\n public mounted = false\n public cleanup: (() => void)[] = []\n\n private scrollElement: HTMLElement | null = null\n public contentOffsetSignal: () => ContentOffset\n private setContentOffset: (offset: ContentOffset) => void\n public contentSizeSignal: () => { width: number; height: number }\n private setContentSize: (size: { width: number; height: number }) => void\n private setIsScrolling: (scrolling: boolean) => void\n private pullToRefreshStateSignal: () => PullToRefreshState\n private setPullToRefreshState: (state: PullToRefreshState) => void\n\n // Performance tracking\n private scrollEventThrottle: number\n private lastScrollTime = 0\n private scrollVelocity: ContentOffset = { x: 0, y: 0 }\n private lastScrollOffset: ContentOffset = { x: 0, y: 0 }\n\n // Pull to refresh tracking\n private pullStartY = 0\n private isPulling = false\n\n constructor(public props: ScrollViewProps) {\n this.id = `scrollview-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`\n this.scrollEventThrottle = props.scrollEventThrottle || 16 // 60fps default\n\n // Create reactive signals\n const [contentOffsetSignal, setContentOffset] = createSignal<ContentOffset>({ x: 0, y: 0 })\n this.contentOffsetSignal = contentOffsetSignal\n this.setContentOffset = setContentOffset\n\n const [contentSizeSignal, setContentSize] = createSignal({ width: 0, height: 0 })\n this.contentSizeSignal = contentSizeSignal\n this.setContentSize = setContentSize\n\n const [, setIsScrolling] = createSignal(false)\n this.setIsScrolling = setIsScrolling\n\n const [pullToRefreshStateSignal, setPullToRefreshState] =\n createSignal<PullToRefreshState>('idle')\n this.pullToRefreshStateSignal = pullToRefreshStateSignal\n this.setPullToRefreshState = setPullToRefreshState\n\n // Connect external content offset signal\n if (props.contentOffset && isSignal(props.contentOffset)) {\n // Set initial value\n this.setContentOffset(props.contentOffset())\n\n const effect = createEffect(() => {\n if (props.contentOffset && isSignal(props.contentOffset)) {\n this.setContentOffset(props.contentOffset())\n }\n })\n this.cleanup.push(() => effect.dispose())\n }\n\n // Connect external content size signal\n if (props.contentSize && isSignal(props.contentSize)) {\n // Set initial value\n this.setContentSize(props.contentSize())\n\n const effect = createEffect(() => {\n if (props.contentSize && isSignal(props.contentSize)) {\n this.setContentSize(props.contentSize())\n }\n })\n this.cleanup.push(() => effect.dispose())\n }\n }\n\n /**\n * Calculate scroll velocity\n */\n private calculateVelocity(currentOffset: ContentOffset, deltaTime: number): ContentOffset {\n const deltaX = currentOffset.x - this.lastScrollOffset.x\n const deltaY = currentOffset.y - this.lastScrollOffset.y\n\n return {\n x: deltaTime > 0 ? deltaX / deltaTime : 0,\n y: deltaTime > 0 ? deltaY / deltaTime : 0,\n }\n }\n\n /**\n * Detect scroll edges\n */\n private detectScrollEdges(): ScrollEdges {\n if (!this.scrollElement) {\n return { top: false, bottom: false, left: false, right: false }\n }\n\n const { scrollTop, scrollLeft, scrollHeight, scrollWidth, clientHeight, clientWidth } =\n this.scrollElement\n\n return {\n top: scrollTop <= 0,\n bottom: scrollTop + clientHeight >= scrollHeight - 1,\n left: scrollLeft <= 0,\n right: scrollLeft + clientWidth >= scrollWidth - 1,\n }\n }\n\n /**\n * Handle scroll events\n */\n private handleScroll = (_event: Event) => {\n if (!this.scrollElement) return\n\n const now = performance.now()\n const deltaTime = now - this.lastScrollTime\n\n // Throttle scroll events for performance\n if (deltaTime < this.scrollEventThrottle) return\n\n const currentOffset: ContentOffset = {\n x: this.scrollElement.scrollLeft,\n y: this.scrollElement.scrollTop,\n }\n\n // Calculate velocity\n this.scrollVelocity = this.calculateVelocity(currentOffset, deltaTime)\n\n // Update signals\n this.setContentOffset(currentOffset)\n this.setContentSize({\n width: this.scrollElement.scrollWidth,\n height: this.scrollElement.scrollHeight,\n })\n\n // Detect edges\n const edges = this.detectScrollEdges()\n\n // Create scroll event info\n const scrollInfo: ScrollEventInfo = {\n offset: currentOffset,\n velocity: this.scrollVelocity,\n contentSize: {\n width: this.scrollElement.scrollWidth,\n height: this.scrollElement.scrollHeight,\n },\n containerSize: {\n width: this.scrollElement.clientWidth,\n height: this.scrollElement.clientHeight,\n },\n edges,\n }\n\n // Call scroll callbacks\n if (this.props.onScroll) {\n this.props.onScroll(scrollInfo)\n }\n\n // Edge callbacks\n if (edges.top && this.props.onReachTop) this.props.onReachTop()\n if (edges.bottom && this.props.onReachBottom) this.props.onReachBottom()\n if (edges.left && this.props.onReachLeft) this.props.onReachLeft()\n if (edges.right && this.props.onReachRight) this.props.onReachRight()\n\n // Update tracking variables\n this.lastScrollOffset = currentOffset\n this.lastScrollTime = now\n }\n\n /**\n * Handle scroll start\n */\n private handleScrollStart = () => {\n this.setIsScrolling(true)\n if (this.props.onScrollBegin) {\n this.props.onScrollBegin()\n }\n }\n\n /**\n * Handle scroll end\n */\n private handleScrollEnd = () => {\n this.setIsScrolling(false)\n if (this.props.onScrollEnd) {\n this.props.onScrollEnd()\n }\n }\n\n /**\n * Handle touch start for pull to refresh\n */\n private handleTouchStart = (event: TouchEvent) => {\n if (!this.props.refreshControl?.enabled) return\n\n this.pullStartY = event.touches[0].clientY\n this.isPulling = false\n }\n\n /**\n * Handle touch move for pull to refresh\n */\n private handleTouchMove = (event: TouchEvent) => {\n if (!this.props.refreshControl?.enabled || !this.scrollElement) return\n\n const currentY = event.touches[0].clientY\n const deltaY = currentY - this.pullStartY\n const threshold = this.props.refreshControl.threshold || 80\n\n // Only trigger pull to refresh at the top\n if (this.scrollElement.scrollTop <= 0 && deltaY > 0) {\n this.isPulling = true\n\n if (deltaY > threshold) {\n this.setPullToRefreshState('ready')\n } else {\n this.setPullToRefreshState('pulling')\n }\n }\n }\n\n /**\n * Handle touch end for pull to refresh\n */\n private handleTouchEnd = async () => {\n if (!this.props.refreshControl?.enabled || !this.isPulling) return\n\n const state = this.pullToRefreshStateSignal()\n\n if (state === 'ready') {\n this.setPullToRefreshState('refreshing')\n\n try {\n await this.props.refreshControl.onRefresh()\n } catch (error) {\n console.error('Pull to refresh error:', error)\n } finally {\n this.setPullToRefreshState('idle')\n }\n } else {\n this.setPullToRefreshState('idle')\n }\n\n this.isPulling = false\n }\n\n /**\n * Set up scroll event handlers\n */\n private setupScrollHandlers(element: HTMLElement): void {\n let scrollTimer: NodeJS.Timeout\n\n const throttledScrollStart = () => {\n clearTimeout(scrollTimer)\n this.handleScrollStart()\n }\n\n const throttledScrollEnd = () => {\n clearTimeout(scrollTimer)\n scrollTimer = setTimeout(() => {\n this.handleScrollEnd()\n }, 150) // 150ms after scroll stops\n }\n\n const scrollHandler = (event: Event) => {\n throttledScrollStart()\n this.handleScroll(event)\n throttledScrollEnd()\n }\n\n element.addEventListener('scroll', scrollHandler, { passive: true })\n element.addEventListener('touchstart', this.handleTouchStart, { passive: true })\n element.addEventListener('touchmove', this.handleTouchMove, { passive: false })\n element.addEventListener('touchend', this.handleTouchEnd, { passive: true })\n\n this.cleanup.push(() => {\n element.removeEventListener('scroll', scrollHandler)\n element.removeEventListener('touchstart', this.handleTouchStart)\n element.removeEventListener('touchmove', this.handleTouchMove)\n element.removeEventListener('touchend', this.handleTouchEnd)\n clearTimeout(scrollTimer)\n })\n }\n\n /**\n * Get overflow styles based on direction\n */\n private getOverflowStyles(direction: ScrollDirection): Record<string, string> {\n switch (direction) {\n case 'vertical':\n return {\n overflowX: 'hidden',\n overflowY: 'auto',\n }\n case 'horizontal':\n return {\n overflowX: 'auto',\n overflowY: 'hidden',\n }\n case 'both':\n return {\n overflow: 'auto',\n }\n default:\n return {\n overflowX: 'hidden',\n overflowY: 'auto',\n }\n }\n }\n\n /**\n * Apply additional scroll view styling (position and overflow already set in initial render)\n */\n private applyScrollViewStyles(element: HTMLElement): void {\n const { showsScrollIndicator = true, bounces = true } = this.props\n\n // Scroll indicator visibility\n if (!showsScrollIndicator) {\n element.style.scrollbarWidth = 'none' // Firefox\n ;(element.style as any).msOverflowStyle = 'none' // IE/Edge\n\n // Webkit browsers\n const style = document.createElement('style')\n style.textContent = `\n #${element.id}::-webkit-scrollbar {\n display: none;\n }\n `\n document.head.appendChild(style)\n\n this.cleanup.push(() => {\n document.head.removeChild(style)\n })\n }\n\n // Bounce behavior (webkit-specific)\n if (bounces) {\n ;(element.style as any).webkitOverflowScrolling = 'touch'\n } else {\n element.style.overscrollBehavior = 'none'\n }\n\n // Smooth scrolling\n element.style.scrollBehavior = 'smooth'\n }\n\n /**\n * Apply content insets\n */\n private applyContentInsets(contentElement: HTMLElement): void {\n const { contentInset } = this.props\n\n if (contentInset) {\n const { top = 0, bottom = 0, left = 0, right = 0 } = contentInset\n contentElement.style.padding = `${top}px ${right}px ${bottom}px ${left}px`\n }\n }\n\n /**\n * Create pull to refresh indicator\n */\n private createPullToRefreshIndicator(): ComponentInstance | null {\n if (!this.props.refreshControl?.enabled) return null\n\n const state = this.pullToRefreshStateSignal()\n const tintColor = this.props.refreshControl.tintColor || '#007AFF'\n\n let content = ''\n switch (state) {\n case 'pulling':\n content = '↓ Pull to refresh'\n break\n case 'ready':\n content = '↑ Release to refresh'\n break\n case 'refreshing':\n content = '⟳ Refreshing...'\n break\n default:\n content = ''\n }\n\n if (!content) return null\n\n return {\n type: 'component',\n id: `${this.id}-refresh`,\n mounted: false,\n cleanup: [],\n props: {},\n render: () => [\n h(\n 'div',\n {\n style: {\n position: 'absolute',\n top: '-60px',\n left: '50%',\n transform: 'translateX(-50%)',\n padding: '10px 20px',\n backgroundColor: '#f8f9fa',\n borderRadius: '20px',\n color: tintColor,\n fontSize: '14px',\n fontWeight: '500',\n textAlign: 'center',\n zIndex: 1000,\n transition: 'all 0.3s ease',\n opacity: state === 'idle' ? 0 : 1,\n },\n },\n content\n ),\n ],\n }\n }\n\n /**\n * Scroll to specific position\n */\n public scrollTo(offset: Partial<ContentOffset>, behavior: ScrollBehavior = 'smooth'): void {\n if (!this.scrollElement) return\n\n const scrollOptions: ScrollToOptions = { behavior }\n if (offset.x !== undefined) scrollOptions.left = offset.x\n if (offset.y !== undefined) scrollOptions.top = offset.y\n\n this.scrollElement.scrollTo(scrollOptions)\n }\n\n /**\n * Scroll to top\n */\n public scrollToTop(behavior: ScrollBehavior = 'smooth'): void {\n this.scrollTo({ x: 0, y: 0 }, behavior)\n }\n\n /**\n * Scroll to bottom\n */\n public scrollToBottom(behavior: ScrollBehavior = 'smooth'): void {\n if (!this.scrollElement) return\n\n this.scrollTo(\n {\n x: 0,\n y: this.scrollElement.scrollHeight - this.scrollElement.clientHeight,\n },\n behavior\n )\n }\n\n /**\n * Render the scroll view component\n */\n render() {\n const { children = [], scrollEnabled = true } = this.props\n\n // Create content container\n const contentContainer = h(\n 'div',\n {\n class: 'tachui-scrollview-content',\n style: {\n minHeight: '100%',\n minWidth: '100%',\n },\n },\n ...children.flatMap((child) => child.render())\n )\n\n // Create pull to refresh indicator\n const refreshIndicator = this.createPullToRefreshIndicator()\n\n // Create scroll container children\n const scrollChildren: any[] = []\n\n // Add refresh indicator if present\n if (refreshIndicator) {\n const result = refreshIndicator.render()\n const arr = Array.isArray(result) ? result : [result]\n scrollChildren.push(...arr.filter((x: any) => x))\n }\n\n // Add content container\n scrollChildren.push(contentContainer)\n\n // Create scroll container with default overflow styles\n const { direction = 'vertical' } = this.props\n \n // Determine overflow styles based on direction\n const overflowStyles = this.getOverflowStyles(direction)\n \n const scrollContainer = h(\n 'div',\n {\n id: this.id,\n class: 'tachui-scrollview',\n style: {\n height: '100%',\n width: '100%',\n position: 'relative',\n ...overflowStyles,\n },\n },\n ...scrollChildren\n )\n\n // Apply styles and event handlers when element is created\n if (scrollContainer.element) {\n const element = scrollContainer.element as HTMLElement\n this.scrollElement = element\n\n this.applyScrollViewStyles(element)\n this.setupScrollHandlers(element)\n\n // Apply content insets to content container\n if (contentContainer.element) {\n this.applyContentInsets(contentContainer.element as HTMLElement)\n }\n\n // Handle scroll enabled state\n const updateScrollEnabled = () => {\n const enabled = isSignal(scrollEnabled) ? scrollEnabled() : scrollEnabled\n element.style.overflow = enabled ? 'auto' : 'hidden'\n element.style.pointerEvents = enabled ? 'auto' : 'none'\n }\n\n if (isSignal(scrollEnabled)) {\n const effect = createEffect(updateScrollEnabled)\n this.cleanup.push(() => effect.dispose())\n } else {\n updateScrollEnabled()\n }\n }\n\n return [scrollContainer]\n }\n}\n\n/**\n * Create enhanced ScrollView component with modifier support\n */\nexport function ScrollView(props: ScrollViewProps = {}): ModifiableComponent<ScrollViewProps> & {\n modifier: ModifierBuilder<ModifiableComponent<ScrollViewProps>>\n} {\n const component = new EnhancedScrollView(props)\n return withModifiers(component)\n}\n\n/**\n * ScrollView utility functions\n */\nexport const ScrollViewUtils = {\n /**\n * Create a scroll view with pull to refresh\n */\n withRefresh(\n children: ComponentInstance[],\n onRefresh: () => Promise<void>,\n options: Partial<ScrollViewProps['refreshControl']> = {}\n ): ModifiableComponent<ScrollViewProps> & {\n modifier: ModifierBuilder<ModifiableComponent<ScrollViewProps>>\n } {\n return ScrollView({\n children,\n refreshControl: {\n enabled: true,\n onRefresh,\n ...options,\n },\n })\n },\n\n /**\n * Create a horizontal scroll view\n */\n horizontal(\n children: ComponentInstance[],\n props: Omit<ScrollViewProps, 'children' | 'direction'> = {}\n ): ModifiableComponent<ScrollViewProps> & {\n modifier: ModifierBuilder<ModifiableComponent<ScrollViewProps>>\n } {\n return ScrollView({\n ...props,\n children,\n direction: 'horizontal',\n })\n },\n\n /**\n * Create a paged scroll view\n */\n paged(\n children: ComponentInstance[],\n props: Omit<ScrollViewProps, 'children' | 'pagingEnabled'> = {}\n ): ModifiableComponent<ScrollViewProps> & {\n modifier: ModifierBuilder<ModifiableComponent<ScrollViewProps>>\n } {\n return ScrollView({\n ...props,\n children,\n pagingEnabled: true,\n })\n },\n}\n"],"names":["EnhancedScrollView","props","__publicField","_event","now","deltaTime","currentOffset","edges","scrollInfo","event","deltaY","threshold","error","contentOffsetSignal","setContentOffset","createSignal","contentSizeSignal","setContentSize","setIsScrolling","pullToRefreshStateSignal","setPullToRefreshState","isSignal","effect","createEffect","deltaX","scrollTop","scrollLeft","scrollHeight","scrollWidth","clientHeight","clientWidth","element","scrollTimer","throttledScrollStart","throttledScrollEnd","scrollHandler","direction","showsScrollIndicator","bounces","style","contentElement","contentInset","top","bottom","left","right","state","tintColor","content","h","offset","behavior","scrollOptions","children","scrollEnabled","contentContainer","child","refreshIndicator","scrollChildren","result","arr","x","overflowStyles","scrollContainer","updateScrollEnabled","enabled","ScrollView","component","withModifiers","ScrollViewUtils","onRefresh","options"],"mappings":"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"}
@@ -1,363 +0,0 @@
1
- import "../reactive/cleanup.js";
2
- import "../reactive/unified-scheduler.js";
3
- import { createEffect as g } from "../reactive/effect.js";
4
- import { createSignal as S, isSignal as d } from "../reactive/signal.js";
5
- import "../reactive/scheduler.js";
6
- import "../reactive/theme.js";
7
- import "../runtime/component.js";
8
- import "../runtime/context.js";
9
- import "../runtime/dev-tools.js";
10
- import "../runtime/dom-bridge.js";
11
- import "../runtime/error-boundary.js";
12
- import "../runtime/error-reporting.js";
13
- import "../runtime/performance.js";
14
- import { h as v } from "../runtime/renderer.js";
15
- import "../runtime/element-override.js";
16
- import "../runtime/semantic-role-manager.js";
17
- import "../runtime/development-warnings.js";
18
- import { withModifiers as T } from "./wrapper.js";
19
- var w = Object.defineProperty, C = (i, t, e) => t in i ? w(i, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : i[t] = e, l = (i, t, e) => C(i, typeof t != "symbol" ? t + "" : t, e);
20
- class b {
21
- constructor(t) {
22
- this.props = t, l(this, "type", "component"), l(this, "id"), l(this, "mounted", !1), l(this, "cleanup", []), l(this, "scrollElement", null), l(this, "contentOffsetSignal"), l(this, "setContentOffset"), l(this, "contentSizeSignal"), l(this, "setContentSize"), l(this, "setIsScrolling"), l(this, "pullToRefreshStateSignal"), l(this, "setPullToRefreshState"), l(this, "scrollEventThrottle"), l(this, "lastScrollTime", 0), l(this, "scrollVelocity", { x: 0, y: 0 }), l(this, "lastScrollOffset", { x: 0, y: 0 }), l(this, "pullStartY", 0), l(this, "isPulling", !1), l(this, "handleScroll", (o) => {
23
- if (!this.scrollElement) return;
24
- const c = performance.now(), h = c - this.lastScrollTime;
25
- if (h < this.scrollEventThrottle) return;
26
- const f = {
27
- x: this.scrollElement.scrollLeft,
28
- y: this.scrollElement.scrollTop
29
- };
30
- this.scrollVelocity = this.calculateVelocity(f, h), this.setContentOffset(f), this.setContentSize({
31
- width: this.scrollElement.scrollWidth,
32
- height: this.scrollElement.scrollHeight
33
- });
34
- const u = this.detectScrollEdges(), E = {
35
- offset: f,
36
- velocity: this.scrollVelocity,
37
- contentSize: {
38
- width: this.scrollElement.scrollWidth,
39
- height: this.scrollElement.scrollHeight
40
- },
41
- containerSize: {
42
- width: this.scrollElement.clientWidth,
43
- height: this.scrollElement.clientHeight
44
- },
45
- edges: u
46
- };
47
- this.props.onScroll && this.props.onScroll(E), u.top && this.props.onReachTop && this.props.onReachTop(), u.bottom && this.props.onReachBottom && this.props.onReachBottom(), u.left && this.props.onReachLeft && this.props.onReachLeft(), u.right && this.props.onReachRight && this.props.onReachRight(), this.lastScrollOffset = f, this.lastScrollTime = c;
48
- }), l(this, "handleScrollStart", () => {
49
- this.setIsScrolling(!0), this.props.onScrollBegin && this.props.onScrollBegin();
50
- }), l(this, "handleScrollEnd", () => {
51
- this.setIsScrolling(!1), this.props.onScrollEnd && this.props.onScrollEnd();
52
- }), l(this, "handleTouchStart", (o) => {
53
- this.props.refreshControl?.enabled && (this.pullStartY = o.touches[0].clientY, this.isPulling = !1);
54
- }), l(this, "handleTouchMove", (o) => {
55
- if (!this.props.refreshControl?.enabled || !this.scrollElement) return;
56
- const h = o.touches[0].clientY - this.pullStartY, f = this.props.refreshControl.threshold || 80;
57
- this.scrollElement.scrollTop <= 0 && h > 0 && (this.isPulling = !0, h > f ? this.setPullToRefreshState("ready") : this.setPullToRefreshState("pulling"));
58
- }), l(this, "handleTouchEnd", async () => {
59
- if (!this.props.refreshControl?.enabled || !this.isPulling) return;
60
- if (this.pullToRefreshStateSignal() === "ready") {
61
- this.setPullToRefreshState("refreshing");
62
- try {
63
- await this.props.refreshControl.onRefresh();
64
- } catch (c) {
65
- console.error("Pull to refresh error:", c);
66
- } finally {
67
- this.setPullToRefreshState("idle");
68
- }
69
- } else
70
- this.setPullToRefreshState("idle");
71
- this.isPulling = !1;
72
- }), this.id = `scrollview-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`, this.scrollEventThrottle = t.scrollEventThrottle || 16;
73
- const [e, s] = S({ x: 0, y: 0 });
74
- this.contentOffsetSignal = e, this.setContentOffset = s;
75
- const [r, n] = S({ width: 0, height: 0 });
76
- this.contentSizeSignal = r, this.setContentSize = n;
77
- const [, a] = S(!1);
78
- this.setIsScrolling = a;
79
- const [m, p] = S("idle");
80
- if (this.pullToRefreshStateSignal = m, this.setPullToRefreshState = p, t.contentOffset && d(t.contentOffset)) {
81
- this.setContentOffset(t.contentOffset());
82
- const o = g(() => {
83
- t.contentOffset && d(t.contentOffset) && this.setContentOffset(t.contentOffset());
84
- });
85
- this.cleanup.push(() => o.dispose());
86
- }
87
- if (t.contentSize && d(t.contentSize)) {
88
- this.setContentSize(t.contentSize());
89
- const o = g(() => {
90
- t.contentSize && d(t.contentSize) && this.setContentSize(t.contentSize());
91
- });
92
- this.cleanup.push(() => o.dispose());
93
- }
94
- }
95
- /**
96
- * Calculate scroll velocity
97
- */
98
- calculateVelocity(t, e) {
99
- const s = t.x - this.lastScrollOffset.x, r = t.y - this.lastScrollOffset.y;
100
- return {
101
- x: e > 0 ? s / e : 0,
102
- y: e > 0 ? r / e : 0
103
- };
104
- }
105
- /**
106
- * Detect scroll edges
107
- */
108
- detectScrollEdges() {
109
- if (!this.scrollElement)
110
- return { top: !1, bottom: !1, left: !1, right: !1 };
111
- const { scrollTop: t, scrollLeft: e, scrollHeight: s, scrollWidth: r, clientHeight: n, clientWidth: a } = this.scrollElement;
112
- return {
113
- top: t <= 0,
114
- bottom: t + n >= s - 1,
115
- left: e <= 0,
116
- right: e + a >= r - 1
117
- };
118
- }
119
- /**
120
- * Set up scroll event handlers
121
- */
122
- setupScrollHandlers(t) {
123
- let e;
124
- const s = () => {
125
- clearTimeout(e), this.handleScrollStart();
126
- }, r = () => {
127
- clearTimeout(e), e = setTimeout(() => {
128
- this.handleScrollEnd();
129
- }, 150);
130
- }, n = (a) => {
131
- s(), this.handleScroll(a), r();
132
- };
133
- t.addEventListener("scroll", n, { passive: !0 }), t.addEventListener("touchstart", this.handleTouchStart, { passive: !0 }), t.addEventListener("touchmove", this.handleTouchMove, { passive: !1 }), t.addEventListener("touchend", this.handleTouchEnd, { passive: !0 }), this.cleanup.push(() => {
134
- t.removeEventListener("scroll", n), t.removeEventListener("touchstart", this.handleTouchStart), t.removeEventListener("touchmove", this.handleTouchMove), t.removeEventListener("touchend", this.handleTouchEnd), clearTimeout(e);
135
- });
136
- }
137
- /**
138
- * Get overflow styles based on direction
139
- */
140
- getOverflowStyles(t) {
141
- switch (t) {
142
- case "vertical":
143
- return {
144
- overflowX: "hidden",
145
- overflowY: "auto"
146
- };
147
- case "horizontal":
148
- return {
149
- overflowX: "auto",
150
- overflowY: "hidden"
151
- };
152
- case "both":
153
- return {
154
- overflow: "auto"
155
- };
156
- default:
157
- return {
158
- overflowX: "hidden",
159
- overflowY: "auto"
160
- };
161
- }
162
- }
163
- /**
164
- * Apply additional scroll view styling (position and overflow already set in initial render)
165
- */
166
- applyScrollViewStyles(t) {
167
- const { showsScrollIndicator: e = !0, bounces: s = !0 } = this.props;
168
- if (!e) {
169
- t.style.scrollbarWidth = "none", t.style.msOverflowStyle = "none";
170
- const r = document.createElement("style");
171
- r.textContent = `
172
- #${t.id}::-webkit-scrollbar {
173
- display: none;
174
- }
175
- `, document.head.appendChild(r), this.cleanup.push(() => {
176
- document.head.removeChild(r);
177
- });
178
- }
179
- s ? t.style.webkitOverflowScrolling = "touch" : t.style.overscrollBehavior = "none", t.style.scrollBehavior = "smooth";
180
- }
181
- /**
182
- * Apply content insets
183
- */
184
- applyContentInsets(t) {
185
- const { contentInset: e } = this.props;
186
- if (e) {
187
- const { top: s = 0, bottom: r = 0, left: n = 0, right: a = 0 } = e;
188
- t.style.padding = `${s}px ${a}px ${r}px ${n}px`;
189
- }
190
- }
191
- /**
192
- * Create pull to refresh indicator
193
- */
194
- createPullToRefreshIndicator() {
195
- if (!this.props.refreshControl?.enabled) return null;
196
- const t = this.pullToRefreshStateSignal(), e = this.props.refreshControl.tintColor || "#007AFF";
197
- let s = "";
198
- switch (t) {
199
- case "pulling":
200
- s = "↓ Pull to refresh";
201
- break;
202
- case "ready":
203
- s = "↑ Release to refresh";
204
- break;
205
- case "refreshing":
206
- s = "⟳ Refreshing...";
207
- break;
208
- default:
209
- s = "";
210
- }
211
- return s ? {
212
- type: "component",
213
- id: `${this.id}-refresh`,
214
- mounted: !1,
215
- cleanup: [],
216
- props: {},
217
- render: () => [
218
- v(
219
- "div",
220
- {
221
- style: {
222
- position: "absolute",
223
- top: "-60px",
224
- left: "50%",
225
- transform: "translateX(-50%)",
226
- padding: "10px 20px",
227
- backgroundColor: "#f8f9fa",
228
- borderRadius: "20px",
229
- color: e,
230
- fontSize: "14px",
231
- fontWeight: "500",
232
- textAlign: "center",
233
- zIndex: 1e3,
234
- transition: "all 0.3s ease",
235
- opacity: t === "idle" ? 0 : 1
236
- }
237
- },
238
- s
239
- )
240
- ]
241
- } : null;
242
- }
243
- /**
244
- * Scroll to specific position
245
- */
246
- scrollTo(t, e = "smooth") {
247
- if (!this.scrollElement) return;
248
- const s = { behavior: e };
249
- t.x !== void 0 && (s.left = t.x), t.y !== void 0 && (s.top = t.y), this.scrollElement.scrollTo(s);
250
- }
251
- /**
252
- * Scroll to top
253
- */
254
- scrollToTop(t = "smooth") {
255
- this.scrollTo({ x: 0, y: 0 }, t);
256
- }
257
- /**
258
- * Scroll to bottom
259
- */
260
- scrollToBottom(t = "smooth") {
261
- this.scrollElement && this.scrollTo(
262
- {
263
- x: 0,
264
- y: this.scrollElement.scrollHeight - this.scrollElement.clientHeight
265
- },
266
- t
267
- );
268
- }
269
- /**
270
- * Render the scroll view component
271
- */
272
- render() {
273
- const { children: t = [], scrollEnabled: e = !0 } = this.props, s = v(
274
- "div",
275
- {
276
- class: "tachui-scrollview-content",
277
- style: {
278
- minHeight: "100%",
279
- minWidth: "100%"
280
- }
281
- },
282
- ...t.flatMap((o) => o.render())
283
- ), r = this.createPullToRefreshIndicator(), n = [];
284
- if (r) {
285
- const o = r.render(), c = Array.isArray(o) ? o : [o];
286
- n.push(...c.filter((h) => h));
287
- }
288
- n.push(s);
289
- const { direction: a = "vertical" } = this.props, m = this.getOverflowStyles(a), p = v(
290
- "div",
291
- {
292
- id: this.id,
293
- class: "tachui-scrollview",
294
- style: {
295
- height: "100%",
296
- width: "100%",
297
- position: "relative",
298
- ...m
299
- }
300
- },
301
- ...n
302
- );
303
- if (p.element) {
304
- const o = p.element;
305
- this.scrollElement = o, this.applyScrollViewStyles(o), this.setupScrollHandlers(o), s.element && this.applyContentInsets(s.element);
306
- const c = () => {
307
- const h = d(e) ? e() : e;
308
- o.style.overflow = h ? "auto" : "hidden", o.style.pointerEvents = h ? "auto" : "none";
309
- };
310
- if (d(e)) {
311
- const h = g(c);
312
- this.cleanup.push(() => h.dispose());
313
- } else
314
- c();
315
- }
316
- return [p];
317
- }
318
- }
319
- function y(i = {}) {
320
- const t = new b(i);
321
- return T(t);
322
- }
323
- const k = {
324
- /**
325
- * Create a scroll view with pull to refresh
326
- */
327
- withRefresh(i, t, e = {}) {
328
- return y({
329
- children: i,
330
- refreshControl: {
331
- enabled: !0,
332
- onRefresh: t,
333
- ...e
334
- }
335
- });
336
- },
337
- /**
338
- * Create a horizontal scroll view
339
- */
340
- horizontal(i, t = {}) {
341
- return y({
342
- ...t,
343
- children: i,
344
- direction: "horizontal"
345
- });
346
- },
347
- /**
348
- * Create a paged scroll view
349
- */
350
- paged(i, t = {}) {
351
- return y({
352
- ...t,
353
- children: i,
354
- pagingEnabled: !0
355
- });
356
- }
357
- };
358
- export {
359
- b as EnhancedScrollView,
360
- y as ScrollView,
361
- k as ScrollViewUtils
362
- };
363
- //# sourceMappingURL=ScrollView.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ScrollView.js","sources":["../../src/components/ScrollView.ts"],"sourcesContent":["/**\n * Enhanced ScrollView Component (Phase 5.5)\n *\n * SwiftUI-inspired ScrollView component with performance optimization,\n * smooth scrolling, pull-to-refresh, and advanced scroll handling.\n */\n\nimport type { ModifiableComponent, ModifierBuilder } from '../modifiers/types'\nimport { createEffect, createSignal, isSignal } from '../reactive'\nimport type { Signal } from '../reactive/types'\nimport { h } from '../runtime'\nimport type { ComponentInstance, ComponentProps } from '../runtime/types'\nimport { withModifiers } from './wrapper'\n\n/**\n * Scroll direction\n */\nexport type ScrollDirection = 'vertical' | 'horizontal' | 'both'\n\n/**\n * Scroll behavior for programmatic scrolling\n */\nexport type ScrollBehavior = 'auto' | 'smooth' | 'instant'\n\n/**\n * Content offset position\n */\nexport interface ContentOffset {\n x: number\n y: number\n}\n\n/**\n * Scroll edge detection\n */\nexport interface ScrollEdges {\n top: boolean\n bottom: boolean\n left: boolean\n right: boolean\n}\n\n/**\n * Pull-to-refresh state\n */\nexport type PullToRefreshState = 'idle' | 'pulling' | 'ready' | 'refreshing'\n\n/**\n * Scroll event information\n */\nexport interface ScrollEventInfo {\n offset: ContentOffset\n velocity: ContentOffset\n contentSize: { width: number; height: number }\n containerSize: { width: number; height: number }\n edges: ScrollEdges\n}\n\n/**\n * ScrollView component properties\n */\nexport interface ScrollViewProps extends ComponentProps {\n // Content\n children?: ComponentInstance[]\n\n // Scroll behavior\n direction?: ScrollDirection\n showsScrollIndicator?: boolean\n bounces?: boolean\n scrollEnabled?: boolean | Signal<boolean>\n\n // Content sizing\n contentOffset?: Signal<ContentOffset>\n contentSize?: Signal<{ width: number; height: number }>\n\n // Pull to refresh\n refreshControl?: {\n enabled: boolean\n onRefresh: () => Promise<void>\n refreshing?: Signal<boolean>\n threshold?: number\n tintColor?: string\n }\n\n // Scroll events\n onScroll?: (info: ScrollEventInfo) => void\n onScrollBegin?: () => void\n onScrollEnd?: () => void\n onReachTop?: () => void\n onReachBottom?: () => void\n onReachLeft?: () => void\n onReachRight?: () => void\n\n // Performance\n scrollEventThrottle?: number\n decelerationRate?: 'normal' | 'fast' | number\n\n // Content insets\n contentInset?: {\n top?: number\n bottom?: number\n left?: number\n right?: number\n }\n\n // Snap behavior\n pagingEnabled?: boolean\n snapToAlignment?: 'start' | 'center' | 'end'\n snapToInterval?: number\n\n // Keyboard behavior\n keyboardDismissMode?: 'none' | 'on-drag' | 'interactive'\n\n // Accessibility\n accessibilityLabel?: string\n accessibilityRole?: string\n}\n\n/**\n * Enhanced ScrollView component class\n */\nexport class EnhancedScrollView implements ComponentInstance<ScrollViewProps> {\n public readonly type = 'component' as const\n public readonly id: string\n public mounted = false\n public cleanup: (() => void)[] = []\n\n private scrollElement: HTMLElement | null = null\n public contentOffsetSignal: () => ContentOffset\n private setContentOffset: (offset: ContentOffset) => void\n public contentSizeSignal: () => { width: number; height: number }\n private setContentSize: (size: { width: number; height: number }) => void\n private setIsScrolling: (scrolling: boolean) => void\n private pullToRefreshStateSignal: () => PullToRefreshState\n private setPullToRefreshState: (state: PullToRefreshState) => void\n\n // Performance tracking\n private scrollEventThrottle: number\n private lastScrollTime = 0\n private scrollVelocity: ContentOffset = { x: 0, y: 0 }\n private lastScrollOffset: ContentOffset = { x: 0, y: 0 }\n\n // Pull to refresh tracking\n private pullStartY = 0\n private isPulling = false\n\n constructor(public props: ScrollViewProps) {\n this.id = `scrollview-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`\n this.scrollEventThrottle = props.scrollEventThrottle || 16 // 60fps default\n\n // Create reactive signals\n const [contentOffsetSignal, setContentOffset] = createSignal<ContentOffset>({ x: 0, y: 0 })\n this.contentOffsetSignal = contentOffsetSignal\n this.setContentOffset = setContentOffset\n\n const [contentSizeSignal, setContentSize] = createSignal({ width: 0, height: 0 })\n this.contentSizeSignal = contentSizeSignal\n this.setContentSize = setContentSize\n\n const [, setIsScrolling] = createSignal(false)\n this.setIsScrolling = setIsScrolling\n\n const [pullToRefreshStateSignal, setPullToRefreshState] =\n createSignal<PullToRefreshState>('idle')\n this.pullToRefreshStateSignal = pullToRefreshStateSignal\n this.setPullToRefreshState = setPullToRefreshState\n\n // Connect external content offset signal\n if (props.contentOffset && isSignal(props.contentOffset)) {\n // Set initial value\n this.setContentOffset(props.contentOffset())\n\n const effect = createEffect(() => {\n if (props.contentOffset && isSignal(props.contentOffset)) {\n this.setContentOffset(props.contentOffset())\n }\n })\n this.cleanup.push(() => effect.dispose())\n }\n\n // Connect external content size signal\n if (props.contentSize && isSignal(props.contentSize)) {\n // Set initial value\n this.setContentSize(props.contentSize())\n\n const effect = createEffect(() => {\n if (props.contentSize && isSignal(props.contentSize)) {\n this.setContentSize(props.contentSize())\n }\n })\n this.cleanup.push(() => effect.dispose())\n }\n }\n\n /**\n * Calculate scroll velocity\n */\n private calculateVelocity(currentOffset: ContentOffset, deltaTime: number): ContentOffset {\n const deltaX = currentOffset.x - this.lastScrollOffset.x\n const deltaY = currentOffset.y - this.lastScrollOffset.y\n\n return {\n x: deltaTime > 0 ? deltaX / deltaTime : 0,\n y: deltaTime > 0 ? deltaY / deltaTime : 0,\n }\n }\n\n /**\n * Detect scroll edges\n */\n private detectScrollEdges(): ScrollEdges {\n if (!this.scrollElement) {\n return { top: false, bottom: false, left: false, right: false }\n }\n\n const { scrollTop, scrollLeft, scrollHeight, scrollWidth, clientHeight, clientWidth } =\n this.scrollElement\n\n return {\n top: scrollTop <= 0,\n bottom: scrollTop + clientHeight >= scrollHeight - 1,\n left: scrollLeft <= 0,\n right: scrollLeft + clientWidth >= scrollWidth - 1,\n }\n }\n\n /**\n * Handle scroll events\n */\n private handleScroll = (_event: Event) => {\n if (!this.scrollElement) return\n\n const now = performance.now()\n const deltaTime = now - this.lastScrollTime\n\n // Throttle scroll events for performance\n if (deltaTime < this.scrollEventThrottle) return\n\n const currentOffset: ContentOffset = {\n x: this.scrollElement.scrollLeft,\n y: this.scrollElement.scrollTop,\n }\n\n // Calculate velocity\n this.scrollVelocity = this.calculateVelocity(currentOffset, deltaTime)\n\n // Update signals\n this.setContentOffset(currentOffset)\n this.setContentSize({\n width: this.scrollElement.scrollWidth,\n height: this.scrollElement.scrollHeight,\n })\n\n // Detect edges\n const edges = this.detectScrollEdges()\n\n // Create scroll event info\n const scrollInfo: ScrollEventInfo = {\n offset: currentOffset,\n velocity: this.scrollVelocity,\n contentSize: {\n width: this.scrollElement.scrollWidth,\n height: this.scrollElement.scrollHeight,\n },\n containerSize: {\n width: this.scrollElement.clientWidth,\n height: this.scrollElement.clientHeight,\n },\n edges,\n }\n\n // Call scroll callbacks\n if (this.props.onScroll) {\n this.props.onScroll(scrollInfo)\n }\n\n // Edge callbacks\n if (edges.top && this.props.onReachTop) this.props.onReachTop()\n if (edges.bottom && this.props.onReachBottom) this.props.onReachBottom()\n if (edges.left && this.props.onReachLeft) this.props.onReachLeft()\n if (edges.right && this.props.onReachRight) this.props.onReachRight()\n\n // Update tracking variables\n this.lastScrollOffset = currentOffset\n this.lastScrollTime = now\n }\n\n /**\n * Handle scroll start\n */\n private handleScrollStart = () => {\n this.setIsScrolling(true)\n if (this.props.onScrollBegin) {\n this.props.onScrollBegin()\n }\n }\n\n /**\n * Handle scroll end\n */\n private handleScrollEnd = () => {\n this.setIsScrolling(false)\n if (this.props.onScrollEnd) {\n this.props.onScrollEnd()\n }\n }\n\n /**\n * Handle touch start for pull to refresh\n */\n private handleTouchStart = (event: TouchEvent) => {\n if (!this.props.refreshControl?.enabled) return\n\n this.pullStartY = event.touches[0].clientY\n this.isPulling = false\n }\n\n /**\n * Handle touch move for pull to refresh\n */\n private handleTouchMove = (event: TouchEvent) => {\n if (!this.props.refreshControl?.enabled || !this.scrollElement) return\n\n const currentY = event.touches[0].clientY\n const deltaY = currentY - this.pullStartY\n const threshold = this.props.refreshControl.threshold || 80\n\n // Only trigger pull to refresh at the top\n if (this.scrollElement.scrollTop <= 0 && deltaY > 0) {\n this.isPulling = true\n\n if (deltaY > threshold) {\n this.setPullToRefreshState('ready')\n } else {\n this.setPullToRefreshState('pulling')\n }\n }\n }\n\n /**\n * Handle touch end for pull to refresh\n */\n private handleTouchEnd = async () => {\n if (!this.props.refreshControl?.enabled || !this.isPulling) return\n\n const state = this.pullToRefreshStateSignal()\n\n if (state === 'ready') {\n this.setPullToRefreshState('refreshing')\n\n try {\n await this.props.refreshControl.onRefresh()\n } catch (error) {\n console.error('Pull to refresh error:', error)\n } finally {\n this.setPullToRefreshState('idle')\n }\n } else {\n this.setPullToRefreshState('idle')\n }\n\n this.isPulling = false\n }\n\n /**\n * Set up scroll event handlers\n */\n private setupScrollHandlers(element: HTMLElement): void {\n let scrollTimer: NodeJS.Timeout\n\n const throttledScrollStart = () => {\n clearTimeout(scrollTimer)\n this.handleScrollStart()\n }\n\n const throttledScrollEnd = () => {\n clearTimeout(scrollTimer)\n scrollTimer = setTimeout(() => {\n this.handleScrollEnd()\n }, 150) // 150ms after scroll stops\n }\n\n const scrollHandler = (event: Event) => {\n throttledScrollStart()\n this.handleScroll(event)\n throttledScrollEnd()\n }\n\n element.addEventListener('scroll', scrollHandler, { passive: true })\n element.addEventListener('touchstart', this.handleTouchStart, { passive: true })\n element.addEventListener('touchmove', this.handleTouchMove, { passive: false })\n element.addEventListener('touchend', this.handleTouchEnd, { passive: true })\n\n this.cleanup.push(() => {\n element.removeEventListener('scroll', scrollHandler)\n element.removeEventListener('touchstart', this.handleTouchStart)\n element.removeEventListener('touchmove', this.handleTouchMove)\n element.removeEventListener('touchend', this.handleTouchEnd)\n clearTimeout(scrollTimer)\n })\n }\n\n /**\n * Get overflow styles based on direction\n */\n private getOverflowStyles(direction: ScrollDirection): Record<string, string> {\n switch (direction) {\n case 'vertical':\n return {\n overflowX: 'hidden',\n overflowY: 'auto',\n }\n case 'horizontal':\n return {\n overflowX: 'auto',\n overflowY: 'hidden',\n }\n case 'both':\n return {\n overflow: 'auto',\n }\n default:\n return {\n overflowX: 'hidden',\n overflowY: 'auto',\n }\n }\n }\n\n /**\n * Apply additional scroll view styling (position and overflow already set in initial render)\n */\n private applyScrollViewStyles(element: HTMLElement): void {\n const { showsScrollIndicator = true, bounces = true } = this.props\n\n // Scroll indicator visibility\n if (!showsScrollIndicator) {\n element.style.scrollbarWidth = 'none' // Firefox\n ;(element.style as any).msOverflowStyle = 'none' // IE/Edge\n\n // Webkit browsers\n const style = document.createElement('style')\n style.textContent = `\n #${element.id}::-webkit-scrollbar {\n display: none;\n }\n `\n document.head.appendChild(style)\n\n this.cleanup.push(() => {\n document.head.removeChild(style)\n })\n }\n\n // Bounce behavior (webkit-specific)\n if (bounces) {\n ;(element.style as any).webkitOverflowScrolling = 'touch'\n } else {\n element.style.overscrollBehavior = 'none'\n }\n\n // Smooth scrolling\n element.style.scrollBehavior = 'smooth'\n }\n\n /**\n * Apply content insets\n */\n private applyContentInsets(contentElement: HTMLElement): void {\n const { contentInset } = this.props\n\n if (contentInset) {\n const { top = 0, bottom = 0, left = 0, right = 0 } = contentInset\n contentElement.style.padding = `${top}px ${right}px ${bottom}px ${left}px`\n }\n }\n\n /**\n * Create pull to refresh indicator\n */\n private createPullToRefreshIndicator(): ComponentInstance | null {\n if (!this.props.refreshControl?.enabled) return null\n\n const state = this.pullToRefreshStateSignal()\n const tintColor = this.props.refreshControl.tintColor || '#007AFF'\n\n let content = ''\n switch (state) {\n case 'pulling':\n content = '↓ Pull to refresh'\n break\n case 'ready':\n content = '↑ Release to refresh'\n break\n case 'refreshing':\n content = '⟳ Refreshing...'\n break\n default:\n content = ''\n }\n\n if (!content) return null\n\n return {\n type: 'component',\n id: `${this.id}-refresh`,\n mounted: false,\n cleanup: [],\n props: {},\n render: () => [\n h(\n 'div',\n {\n style: {\n position: 'absolute',\n top: '-60px',\n left: '50%',\n transform: 'translateX(-50%)',\n padding: '10px 20px',\n backgroundColor: '#f8f9fa',\n borderRadius: '20px',\n color: tintColor,\n fontSize: '14px',\n fontWeight: '500',\n textAlign: 'center',\n zIndex: 1000,\n transition: 'all 0.3s ease',\n opacity: state === 'idle' ? 0 : 1,\n },\n },\n content\n ),\n ],\n }\n }\n\n /**\n * Scroll to specific position\n */\n public scrollTo(offset: Partial<ContentOffset>, behavior: ScrollBehavior = 'smooth'): void {\n if (!this.scrollElement) return\n\n const scrollOptions: ScrollToOptions = { behavior }\n if (offset.x !== undefined) scrollOptions.left = offset.x\n if (offset.y !== undefined) scrollOptions.top = offset.y\n\n this.scrollElement.scrollTo(scrollOptions)\n }\n\n /**\n * Scroll to top\n */\n public scrollToTop(behavior: ScrollBehavior = 'smooth'): void {\n this.scrollTo({ x: 0, y: 0 }, behavior)\n }\n\n /**\n * Scroll to bottom\n */\n public scrollToBottom(behavior: ScrollBehavior = 'smooth'): void {\n if (!this.scrollElement) return\n\n this.scrollTo(\n {\n x: 0,\n y: this.scrollElement.scrollHeight - this.scrollElement.clientHeight,\n },\n behavior\n )\n }\n\n /**\n * Render the scroll view component\n */\n render() {\n const { children = [], scrollEnabled = true } = this.props\n\n // Create content container\n const contentContainer = h(\n 'div',\n {\n class: 'tachui-scrollview-content',\n style: {\n minHeight: '100%',\n minWidth: '100%',\n },\n },\n ...children.flatMap((child) => child.render())\n )\n\n // Create pull to refresh indicator\n const refreshIndicator = this.createPullToRefreshIndicator()\n\n // Create scroll container children\n const scrollChildren: any[] = []\n\n // Add refresh indicator if present\n if (refreshIndicator) {\n const result = refreshIndicator.render()\n const arr = Array.isArray(result) ? result : [result]\n scrollChildren.push(...arr.filter((x: any) => x))\n }\n\n // Add content container\n scrollChildren.push(contentContainer)\n\n // Create scroll container with default overflow styles\n const { direction = 'vertical' } = this.props\n \n // Determine overflow styles based on direction\n const overflowStyles = this.getOverflowStyles(direction)\n \n const scrollContainer = h(\n 'div',\n {\n id: this.id,\n class: 'tachui-scrollview',\n style: {\n height: '100%',\n width: '100%',\n position: 'relative',\n ...overflowStyles,\n },\n },\n ...scrollChildren\n )\n\n // Apply styles and event handlers when element is created\n if (scrollContainer.element) {\n const element = scrollContainer.element as HTMLElement\n this.scrollElement = element\n\n this.applyScrollViewStyles(element)\n this.setupScrollHandlers(element)\n\n // Apply content insets to content container\n if (contentContainer.element) {\n this.applyContentInsets(contentContainer.element as HTMLElement)\n }\n\n // Handle scroll enabled state\n const updateScrollEnabled = () => {\n const enabled = isSignal(scrollEnabled) ? scrollEnabled() : scrollEnabled\n element.style.overflow = enabled ? 'auto' : 'hidden'\n element.style.pointerEvents = enabled ? 'auto' : 'none'\n }\n\n if (isSignal(scrollEnabled)) {\n const effect = createEffect(updateScrollEnabled)\n this.cleanup.push(() => effect.dispose())\n } else {\n updateScrollEnabled()\n }\n }\n\n return [scrollContainer]\n }\n}\n\n/**\n * Create enhanced ScrollView component with modifier support\n */\nexport function ScrollView(props: ScrollViewProps = {}): ModifiableComponent<ScrollViewProps> & {\n modifier: ModifierBuilder<ModifiableComponent<ScrollViewProps>>\n} {\n const component = new EnhancedScrollView(props)\n return withModifiers(component)\n}\n\n/**\n * ScrollView utility functions\n */\nexport const ScrollViewUtils = {\n /**\n * Create a scroll view with pull to refresh\n */\n withRefresh(\n children: ComponentInstance[],\n onRefresh: () => Promise<void>,\n options: Partial<ScrollViewProps['refreshControl']> = {}\n ): ModifiableComponent<ScrollViewProps> & {\n modifier: ModifierBuilder<ModifiableComponent<ScrollViewProps>>\n } {\n return ScrollView({\n children,\n refreshControl: {\n enabled: true,\n onRefresh,\n ...options,\n },\n })\n },\n\n /**\n * Create a horizontal scroll view\n */\n horizontal(\n children: ComponentInstance[],\n props: Omit<ScrollViewProps, 'children' | 'direction'> = {}\n ): ModifiableComponent<ScrollViewProps> & {\n modifier: ModifierBuilder<ModifiableComponent<ScrollViewProps>>\n } {\n return ScrollView({\n ...props,\n children,\n direction: 'horizontal',\n })\n },\n\n /**\n * Create a paged scroll view\n */\n paged(\n children: ComponentInstance[],\n props: Omit<ScrollViewProps, 'children' | 'pagingEnabled'> = {}\n ): ModifiableComponent<ScrollViewProps> & {\n modifier: ModifierBuilder<ModifiableComponent<ScrollViewProps>>\n } {\n return ScrollView({\n ...props,\n children,\n pagingEnabled: true,\n })\n },\n}\n"],"names":["EnhancedScrollView","props","__publicField","_event","now","deltaTime","currentOffset","edges","scrollInfo","event","deltaY","threshold","error","contentOffsetSignal","setContentOffset","createSignal","contentSizeSignal","setContentSize","setIsScrolling","pullToRefreshStateSignal","setPullToRefreshState","isSignal","effect","createEffect","deltaX","scrollTop","scrollLeft","scrollHeight","scrollWidth","clientHeight","clientWidth","element","scrollTimer","throttledScrollStart","throttledScrollEnd","scrollHandler","direction","showsScrollIndicator","bounces","style","contentElement","contentInset","top","bottom","left","right","state","tintColor","content","h","offset","behavior","scrollOptions","children","scrollEnabled","contentContainer","child","refreshIndicator","scrollChildren","result","arr","x","overflowStyles","scrollContainer","updateScrollEnabled","enabled","ScrollView","component","withModifiers","ScrollViewUtils","onRefresh","options"],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});require("../reactive/cleanup.cjs");require("../reactive/unified-scheduler.cjs");const a=require("../reactive/signal.cjs");require("../reactive/scheduler.cjs");require("../reactive/theme.cjs");require("../runtime/component.cjs");require("../runtime/context.cjs");require("../runtime/dev-tools.cjs");require("../runtime/dom-bridge.cjs");require("../runtime/error-boundary.cjs");require("../runtime/error-reporting.cjs");require("../runtime/performance.cjs");const n=require("../runtime/renderer.cjs");require("../runtime/element-override.cjs");require("../runtime/semantic-role-manager.cjs");require("../runtime/development-warnings.cjs");const p=require("./wrapper.cjs");var d=Object.defineProperty,u=(t,e,r)=>e in t?d(t,e,{enumerable:!0,configurable:!0,writable:!0,value:r}):t[e]=r,s=(t,e,r)=>u(t,typeof e!="symbol"?e+"":e,r);class l{constructor(e){this.props=e,s(this,"type","component"),s(this,"id"),s(this,"mounted",!1),s(this,"cleanup",[]),s(this,"handleToggle",()=>{this.props.onToggle&&this.props.onToggle(!this.isCollapsed())}),this.id=`section-${Date.now()}-${Math.random().toString(36).substr(2,9)}`}resolveContent(e){return e?typeof e=="string"?e:typeof e=="function"||a.isSignal(e)?e():e:null}isCollapsed(){const{collapsed:e}=this.props;return typeof e=="boolean"?e:a.isSignal(e)?e():!1}renderComponentContent(e){const r=e.render();return Array.isArray(r)?r:[r]}getSectionStyles(){const{style:e="automatic"}=this.props,r={marginBottom:"20px"};switch(e){case"grouped":return{...r,backgroundColor:"#ffffff",border:"1px solid #e0e0e0",borderRadius:"12px",overflow:"hidden"};case"inset":return{...r,backgroundColor:"#f8f9fa",border:"1px solid #e9ecef",borderRadius:"8px",margin:"0 16px 20px 16px"};case"sidebar":return{...r,borderLeft:"3px solid #007AFF",paddingLeft:"16px",backgroundColor:"#f8f9fa",borderRadius:"0 8px 8px 0"};case"plain":return r;default:return{...r,backgroundColor:"#ffffff",border:"1px solid #f0f0f0",borderRadius:"8px"}}}getHeaderStyles(){const{style:e="automatic"}=this.props,r={fontSize:"16px",fontWeight:"600",color:"#1a1a1a",margin:"0 0 12px 0"};switch(e){case"grouped":case"inset":return{...r,padding:"12px 16px 0 16px",backgroundColor:"#f8f9fa",borderBottom:"1px solid #e9ecef"};case"sidebar":return{...r,fontSize:"14px",textTransform:"uppercase",letterSpacing:"0.5px",color:"#666",marginBottom:"8px"};default:return{...r,padding:"0 0 8px 0"}}}getContentStyles(){const{style:e="automatic",spacing:r=12}=this.props,o={display:"flex",flexDirection:"column",gap:`${r}px`};switch(e){case"grouped":case"inset":return{...o,padding:"16px"};case"sidebar":return{...o,padding:"8px 0"};default:return{...o,padding:"12px"}}}getFooterStyles(){const{style:e="automatic"}=this.props,r={fontSize:"14px",color:"#666",margin:"8px 0 0 0"};switch(e){case"grouped":case"inset":return{...r,padding:"0 16px 12px 16px",backgroundColor:"#f8f9fa",borderTop:"1px solid #e9ecef"};default:return{...r,padding:"0 0 4px 0"}}}renderHeader(){const e=this.resolveContent(this.props.header);if(!e)return null;const r=this.getHeaderStyles();if(this.props.collapsible){const o=this.isCollapsed()?"▶":"▼";return n.h("div",{style:{...r,cursor:"pointer",display:"flex",alignItems:"center",gap:"8px"},onClick:this.handleToggle},n.h("span",{style:{fontSize:"12px",color:"#666"}},n.text(o)),...typeof e=="string"?[n.text(e)]:this.renderComponentContent(e))}return n.h("div",{style:r},...typeof e=="string"?[n.text(e)]:this.renderComponentContent(e))}renderContent(){const{children:e=[]}=this.props;return this.props.collapsible&&this.isCollapsed()||e.length===0?null:n.h("div",{style:this.getContentStyles()},...e.flatMap(r=>{const o=r.render();return Array.isArray(o)?o:[o]}))}renderFooter(){const e=this.resolveContent(this.props.footer);return e?n.h("div",{style:this.getFooterStyles()},...typeof e=="string"?[n.text(e)]:this.renderComponentContent(e)):null}render(){const{accessibilityLabel:e,accessibilityRole:r="group"}=this.props;return n.h("div",{style:this.getSectionStyles(),"aria-label":e,role:r},...[this.renderHeader(),this.renderContent(),this.renderFooter()].filter(o=>o!==null))}}function i(t,e={}){console.warn("Section from @tachui/core is deprecated. Use FormSection from @tachui/forms for form contexts, or VStack for general layout grouping.");const r={...e,children:t},o=new l(r);return p.withModifiers(o)}function c(t,e,r={}){return i(e,{...r,header:t})}function f(t,e,r,o={}){return i(r,{...o,header:t,footer:e})}const h={Automatic(t,e={}){return i(t,{...e,style:"automatic"})},Grouped(t,e={}){return i(t,{...e,style:"grouped"})},Inset(t,e={}){return i(t,{...e,style:"inset"})},Sidebar(t,e={}){return i(t,{...e,style:"sidebar"})},Plain(t,e={}){return i(t,{...e,style:"plain"})},Collapsible(t,e,r=!1,o={}){return i(e,{...o,header:t,collapsible:!0,collapsed:r})}};exports.EnhancedSection=l;exports.Section=i;exports.SectionStyles=h;exports.SectionWithHeader=c;exports.SectionWithHeaderFooter=f;
2
- //# sourceMappingURL=Section.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Section.cjs","sources":["../../src/components/Section.ts"],"sourcesContent":["/**\n * Enhanced Section Component (Phase 6.4.2)\n *\n * @deprecated This component has been superseded by FormSection from @tachui/forms \n * for form contexts, which provides the same features with better semantic HTML.\n * For general layout grouping, use VStack or HStack with styling instead.\n *\n * Migration Guide:\n * - For forms: Replace with FormSection from @tachui/forms\n * - For general grouping: Use VStack with styling modifiers\n * - All props are compatible between Section and FormSection\n *\n * SwiftUI-inspired Section component for grouping form content\n * with headers, footers, and automatic styling.\n */\n\nimport type { ModifiableComponent, ModifierBuilder } from '../modifiers/types'\nimport { isSignal } from '../reactive'\nimport type { Signal } from '../reactive/types'\nimport { h, text } from '../runtime'\nimport type { ComponentInstance, ComponentProps, DOMNode } from '../runtime/types'\nimport { withModifiers } from './wrapper'\n\n/**\n * Section component properties\n */\nexport interface SectionProps extends ComponentProps {\n children?: ComponentInstance[]\n\n // Content\n header?: string | (() => string) | Signal<string> | ComponentInstance\n footer?: string | (() => string) | Signal<string> | ComponentInstance\n\n // Styling\n style?: 'automatic' | 'grouped' | 'inset' | 'plain' | 'sidebar'\n spacing?: number\n\n // Behavior\n collapsible?: boolean\n collapsed?: boolean | Signal<boolean>\n onToggle?: (collapsed: boolean) => void\n\n // Accessibility\n accessibilityLabel?: string\n accessibilityRole?: string\n}\n\n/**\n * Enhanced Section component class\n */\nexport class EnhancedSection implements ComponentInstance<SectionProps> {\n public readonly type = 'component' as const\n public readonly id: string\n public mounted = false\n public cleanup: (() => void)[] = []\n\n constructor(public props: SectionProps) {\n this.id = `section-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`\n }\n\n /**\n * Resolve dynamic content\n */\n private resolveContent(\n content: string | (() => string) | Signal<string> | ComponentInstance | undefined\n ): string | ComponentInstance | null {\n if (!content) return null\n\n if (typeof content === 'string') {\n return content\n } else if (typeof content === 'function') {\n return content()\n } else if (isSignal(content)) {\n return (content as () => string)()\n } else {\n return content as ComponentInstance\n }\n }\n\n /**\n * Check if section is collapsed\n */\n private isCollapsed(): boolean {\n const { collapsed } = this.props\n if (typeof collapsed === 'boolean') return collapsed\n if (isSignal(collapsed)) return (collapsed as () => boolean)()\n return false\n }\n\n /**\n * Handle toggle action\n */\n private handleToggle = () => {\n if (this.props.onToggle) {\n this.props.onToggle(!this.isCollapsed())\n }\n }\n\n /**\n * Helper to render component content safely\n */\n private renderComponentContent(content: ComponentInstance): DOMNode[] {\n const rendered = content.render()\n return Array.isArray(rendered) ? rendered : [rendered]\n }\n\n /**\n * Get section styles based on style prop\n */\n private getSectionStyles() {\n const { style = 'automatic' } = this.props\n\n const baseStyles = {\n marginBottom: '20px',\n }\n\n switch (style) {\n case 'grouped':\n return {\n ...baseStyles,\n backgroundColor: '#ffffff',\n border: '1px solid #e0e0e0',\n borderRadius: '12px',\n overflow: 'hidden' as const,\n }\n\n case 'inset':\n return {\n ...baseStyles,\n backgroundColor: '#f8f9fa',\n border: '1px solid #e9ecef',\n borderRadius: '8px',\n margin: '0 16px 20px 16px',\n }\n\n case 'sidebar':\n return {\n ...baseStyles,\n borderLeft: '3px solid #007AFF',\n paddingLeft: '16px',\n backgroundColor: '#f8f9fa',\n borderRadius: '0 8px 8px 0',\n }\n\n case 'plain':\n return baseStyles\n default:\n return {\n ...baseStyles,\n backgroundColor: '#ffffff',\n border: '1px solid #f0f0f0',\n borderRadius: '8px',\n }\n }\n }\n\n /**\n * Get header styles\n */\n private getHeaderStyles() {\n const { style = 'automatic' } = this.props\n\n const baseStyles = {\n fontSize: '16px',\n fontWeight: '600' as const,\n color: '#1a1a1a',\n margin: '0 0 12px 0',\n }\n\n switch (style) {\n case 'grouped':\n case 'inset':\n return {\n ...baseStyles,\n padding: '12px 16px 0 16px',\n backgroundColor: '#f8f9fa',\n borderBottom: '1px solid #e9ecef',\n }\n\n case 'sidebar':\n return {\n ...baseStyles,\n fontSize: '14px',\n textTransform: 'uppercase' as const,\n letterSpacing: '0.5px',\n color: '#666',\n marginBottom: '8px',\n }\n\n default:\n return {\n ...baseStyles,\n padding: '0 0 8px 0',\n }\n }\n }\n\n /**\n * Get content styles\n */\n private getContentStyles() {\n const { style = 'automatic', spacing = 12 } = this.props\n\n const baseStyles = {\n display: 'flex',\n flexDirection: 'column' as const,\n gap: `${spacing}px`,\n }\n\n switch (style) {\n case 'grouped':\n case 'inset':\n return {\n ...baseStyles,\n padding: '16px',\n }\n\n case 'sidebar':\n return {\n ...baseStyles,\n padding: '8px 0',\n }\n\n default:\n return {\n ...baseStyles,\n padding: '12px',\n }\n }\n }\n\n /**\n * Get footer styles\n */\n private getFooterStyles() {\n const { style = 'automatic' } = this.props\n\n const baseStyles = {\n fontSize: '14px',\n color: '#666',\n margin: '8px 0 0 0',\n }\n\n switch (style) {\n case 'grouped':\n case 'inset':\n return {\n ...baseStyles,\n padding: '0 16px 12px 16px',\n backgroundColor: '#f8f9fa',\n borderTop: '1px solid #e9ecef',\n }\n\n default:\n return {\n ...baseStyles,\n padding: '0 0 4px 0',\n }\n }\n }\n\n /**\n * Render header content\n */\n private renderHeader() {\n const headerContent = this.resolveContent(this.props.header)\n if (!headerContent) return null\n\n const headerStyles = this.getHeaderStyles()\n\n // Add collapse toggle if collapsible\n if (this.props.collapsible) {\n const toggleIcon = this.isCollapsed() ? '▶' : '▼'\n\n return h(\n 'div',\n {\n style: {\n ...headerStyles,\n cursor: 'pointer',\n display: 'flex',\n alignItems: 'center',\n gap: '8px',\n },\n onClick: this.handleToggle,\n },\n h(\n 'span',\n {\n style: {\n fontSize: '12px',\n color: '#666',\n },\n },\n text(toggleIcon)\n ),\n\n ...(typeof headerContent === 'string'\n ? [text(headerContent)]\n : this.renderComponentContent(headerContent as ComponentInstance))\n )\n }\n\n return h(\n 'div',\n { style: headerStyles },\n ...(typeof headerContent === 'string'\n ? [text(headerContent)]\n : this.renderComponentContent(headerContent as ComponentInstance))\n )\n }\n\n /**\n * Render content\n */\n private renderContent() {\n const { children = [] } = this.props\n\n // Don't render content if collapsed\n if (this.props.collapsible && this.isCollapsed()) {\n return null\n }\n\n if (children.length === 0) return null\n\n return h(\n 'div',\n {\n style: this.getContentStyles(),\n },\n ...children.flatMap((child) => {\n const rendered = child.render()\n return Array.isArray(rendered) ? rendered : [rendered]\n })\n )\n }\n\n /**\n * Render footer content\n */\n private renderFooter() {\n const footerContent = this.resolveContent(this.props.footer)\n if (!footerContent) return null\n\n return h(\n 'div',\n {\n style: this.getFooterStyles(),\n },\n ...(typeof footerContent === 'string'\n ? [text(footerContent)]\n : this.renderComponentContent(footerContent as ComponentInstance))\n )\n }\n\n render() {\n const { accessibilityLabel, accessibilityRole = 'group' } = this.props\n\n return h(\n 'div',\n {\n style: this.getSectionStyles(),\n 'aria-label': accessibilityLabel,\n role: accessibilityRole,\n },\n ...[this.renderHeader(), this.renderContent(), this.renderFooter()].filter(\n (item): item is DOMNode => item !== null\n )\n )\n }\n}\n\n/**\n * Section component function\n * @deprecated Use FormSection from @tachui/forms for form contexts, or VStack for general grouping\n */\nexport function Section(\n children: ComponentInstance[],\n props: Omit<SectionProps, 'children'> = {}\n): ModifiableComponent<SectionProps> & {\n modifier: ModifierBuilder<ModifiableComponent<SectionProps>>\n} {\n console.warn(\n 'Section from @tachui/core is deprecated. Use FormSection from @tachui/forms for form contexts, or VStack for general layout grouping.'\n )\n const sectionProps: SectionProps = { ...props, children }\n const component = new EnhancedSection(sectionProps)\n return withModifiers(component)\n}\n\n/**\n * Section with header\n * @deprecated Use FormSection from @tachui/forms\n */\nexport function SectionWithHeader(\n header: string | (() => string) | Signal<string> | ComponentInstance,\n children: ComponentInstance[],\n props: Omit<SectionProps, 'children' | 'header'> = {}\n) {\n return Section(children, { ...props, header })\n}\n\n/**\n * Section with header and footer\n * @deprecated Use FormSection from @tachui/forms\n */\nexport function SectionWithHeaderFooter(\n header: string | (() => string) | Signal<string> | ComponentInstance,\n footer: string | (() => string) | Signal<string> | ComponentInstance,\n children: ComponentInstance[],\n props: Omit<SectionProps, 'children' | 'header' | 'footer'> = {}\n) {\n return Section(children, { ...props, header, footer })\n}\n\n/**\n * Section style variants\n * @deprecated Use FormSection from @tachui/forms with style prop\n */\nexport const SectionStyles = {\n /**\n * Automatic section styling (default)\n */\n Automatic(children: ComponentInstance[], props: Omit<SectionProps, 'children' | 'style'> = {}) {\n return Section(children, { ...props, style: 'automatic' })\n },\n\n /**\n * Grouped section with container styling\n */\n Grouped(children: ComponentInstance[], props: Omit<SectionProps, 'children' | 'style'> = {}) {\n return Section(children, { ...props, style: 'grouped' })\n },\n\n /**\n * Inset section styling\n */\n Inset(children: ComponentInstance[], props: Omit<SectionProps, 'children' | 'style'> = {}) {\n return Section(children, { ...props, style: 'inset' })\n },\n\n /**\n * Sidebar-style section\n */\n Sidebar(children: ComponentInstance[], props: Omit<SectionProps, 'children' | 'style'> = {}) {\n return Section(children, { ...props, style: 'sidebar' })\n },\n\n /**\n * Plain section without styling\n */\n Plain(children: ComponentInstance[], props: Omit<SectionProps, 'children' | 'style'> = {}) {\n return Section(children, { ...props, style: 'plain' })\n },\n\n /**\n * Collapsible section\n */\n Collapsible(\n header: string | (() => string) | Signal<string> | ComponentInstance,\n children: ComponentInstance[],\n collapsed: boolean | Signal<boolean> = false,\n props: Omit<SectionProps, 'children' | 'header' | 'collapsible' | 'collapsed'> = {}\n ) {\n return Section(children, {\n ...props,\n header,\n collapsible: true,\n collapsed,\n })\n },\n}\n"],"names":["EnhancedSection","props","__publicField","content","isSignal","collapsed","rendered","style","baseStyles","spacing","headerContent","headerStyles","toggleIcon","h","text","children","child","footerContent","accessibilityLabel","accessibilityRole","item","Section","sectionProps","component","withModifiers","SectionWithHeader","header","SectionWithHeaderFooter","footer","SectionStyles"],"mappings":"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"}