@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,1747 +0,0 @@
1
- /**
2
- * Modifier Builder Implementation
3
- *
4
- * Provides a fluent API for chaining modifiers on components,
5
- * similar to SwiftUI's modifier system.
6
- */
7
-
8
- import type { Signal } from '../reactive/types'
9
- import type { ComponentInstance, ComponentProps } from '../runtime/types'
10
- import type { StatefulBackgroundValue } from '../gradients/types'
11
- import type { ColorValue, TextShadowConfig } from './types'
12
- import type { FontAsset } from '../assets/FontAsset'
13
- import {
14
- AnimationModifier,
15
- AppearanceModifier,
16
- InteractionModifier,
17
- LayoutModifier,
18
- LifecycleModifier,
19
- ResizableModifier,
20
- } from './base'
21
- import { BackgroundModifier } from './background'
22
- import type { BorderStyle } from './border'
23
- import { borderBottom, borderLeft, borderRight, borderTop } from './border'
24
- import { css, cssProperty, cssVariable } from './css'
25
- import { alignItems, flexDirection, flexGrow, flexShrink, flexWrap, gap, justifyContent } from './flexbox'
26
- import { margin, marginBottom, marginHorizontal, marginLeft, marginRight, marginTop, marginVertical } from './margin'
27
- import {
28
- padding,
29
- paddingBottom,
30
- paddingHorizontal,
31
- paddingLeading,
32
- paddingLeft,
33
- paddingRight,
34
- paddingTop,
35
- paddingTrailing,
36
- paddingVertical,
37
- } from './padding'
38
- // Import new multi-property modifiers
39
- import { height, maxHeight, maxWidth, minHeight, minWidth, size, width } from './size'
40
- import type {
41
- AnimationModifierProps,
42
- AppearanceModifierProps,
43
- LayoutModifierProps,
44
- ModifiableComponent,
45
- Modifier,
46
- ModifierBuilder,
47
- } from './types'
48
- import type { ResponsiveModifierBuilder, ResponsiveBreakpointBuilder } from './responsive/responsive-builder'
49
- import { ResponsiveModifierBuilderImpl } from './responsive/responsive-builder'
50
- import type { ResponsiveStyleConfig } from './responsive/types'
51
- import { createResponsiveModifier } from './responsive/responsive-modifier'
52
- import { createModifiableComponent } from './registry'
53
- import type {
54
- FontStyle,
55
- FontVariant,
56
- FontWeight,
57
- TextAlign,
58
- TextDecoration,
59
- TextTransform,
60
- } from './typography'
61
- import {
62
- letterSpacing,
63
- lineHeight,
64
- overflow,
65
- textAlign,
66
- textDecoration,
67
- textOverflow,
68
- textTransform,
69
- typography,
70
- whiteSpace,
71
- } from './typography'
72
- import { cursor, display, overflowX, overflowY, position, zIndex } from './utility'
73
- import {
74
- IdModifier,
75
- DataModifier,
76
- AriaModifier,
77
- TabIndexModifier
78
- } from './attributes'
79
- import {
80
- LineClampModifier,
81
- WordBreakModifier,
82
- OverflowWrapModifier,
83
- HyphensModifier,
84
- BackgroundClipModifier
85
- } from './text'
86
- import {
87
- BackdropFilterModifier
88
- } from './backdrop'
89
- import {
90
- before as beforeModifier,
91
- after as afterModifier
92
- } from './elements'
93
- import {
94
- FilterModifier,
95
- filter,
96
- saturate,
97
- // grayscale, // Unused - commented out to fix type-check
98
- sepia,
99
- hueRotate,
100
- invert,
101
- vintagePhoto,
102
- blackAndWhite,
103
- vibrant,
104
- warmTone,
105
- coolTone,
106
- faded,
107
- highKey,
108
- lowKey,
109
- softFocus,
110
- highContrastMode,
111
- subtleBlur,
112
- darkModeInvert
113
- } from './filters'
114
- import {
115
- textShadow,
116
- shadow as shadowModifier,
117
- shadows as shadowsModifier,
118
- shadowPreset
119
- } from './shadows'
120
- import {
121
- scale,
122
- rotate,
123
- translate,
124
- perspective
125
- // transform // Unused - commented out to fix type-check
126
- } from './transformations'
127
- import {
128
- // cursor as cursorModifier, // Unused - commented out to fix type-check
129
- hover as hoverModifier,
130
- hoverEffect,
131
- hoverWithTransition,
132
- conditionalHover,
133
- interactiveCursor,
134
- draggableCursor,
135
- textCursor,
136
- disabledCursor,
137
- loadingCursor,
138
- helpCursor,
139
- zoomCursor,
140
- buttonHover,
141
- cardHover,
142
- linkHover,
143
- imageHover
144
- } from './effects'
145
- import {
146
- transition as transitionModifier,
147
- transitions,
148
- fadeTransition,
149
- transformTransition,
150
- colorTransition,
151
- layoutTransition,
152
- buttonTransition,
153
- cardTransition,
154
- modalTransition,
155
- smoothTransition,
156
- quickTransition,
157
- slowTransition
158
- } from './transitions'
159
- import {
160
- scroll as scrollModifier,
161
- scrollBehavior,
162
- overscrollBehavior,
163
- overscrollBehaviorX,
164
- overscrollBehaviorY,
165
- scrollMargin,
166
- scrollPadding,
167
- scrollSnap
168
- } from './scroll'
169
- import { asHTML } from './as-html'
170
- import type { AsHTMLOptions } from './as-html'
171
-
172
- /**
173
- * Concrete modifier builder implementation
174
- */
175
- export class ModifierBuilderImpl<T extends ComponentInstance = ComponentInstance>
176
- implements ModifierBuilder<T>
177
- {
178
- private modifiers: Modifier[] = []
179
-
180
- constructor(private component: T) {}
181
-
182
- // Layout modifiers
183
- frame(width?: number | string, height?: number | string): ModifierBuilder<T>
184
- frame(options: LayoutModifierProps['frame']): ModifierBuilder<T>
185
- frame(
186
- widthOrOptions?: number | string | LayoutModifierProps['frame'],
187
- height?: number | string
188
- ): ModifierBuilder<T> {
189
- let frameProps: LayoutModifierProps['frame']
190
-
191
- if (typeof widthOrOptions === 'object') {
192
- frameProps = widthOrOptions
193
- } else {
194
- frameProps = {}
195
- if (widthOrOptions !== undefined) frameProps.width = widthOrOptions
196
- if (height !== undefined) frameProps.height = height
197
- }
198
-
199
- this.modifiers.push(new LayoutModifier({ frame: frameProps }))
200
- return this
201
- }
202
-
203
- // Padding is now handled by the new padding modifiers below
204
-
205
- margin(value: number | string): ModifierBuilder<T>
206
- margin(options: LayoutModifierProps['margin']): ModifierBuilder<T>
207
- margin(valueOrOptions: number | string | LayoutModifierProps['margin']): ModifierBuilder<T> {
208
- if (typeof valueOrOptions === 'number' || typeof valueOrOptions === 'string') {
209
- this.modifiers.push(margin(valueOrOptions))
210
- } else {
211
- // Handle both LayoutModifierProps margin format and direct MarginOptions format
212
- const marginOptions = valueOrOptions as any
213
-
214
- // Check if it's using vertical/horizontal pattern
215
- if (marginOptions.vertical !== undefined || marginOptions.horizontal !== undefined) {
216
- this.modifiers.push(margin({
217
- vertical: marginOptions.vertical,
218
- horizontal: marginOptions.horizontal
219
- }))
220
- } else if (marginOptions.top !== undefined || marginOptions.right !== undefined ||
221
- marginOptions.bottom !== undefined || marginOptions.left !== undefined) {
222
- // Handle individual sides
223
- this.modifiers.push(margin({
224
- top: marginOptions.top,
225
- right: marginOptions.right,
226
- bottom: marginOptions.bottom,
227
- left: marginOptions.left
228
- }))
229
- }
230
- }
231
- return this
232
- }
233
-
234
- layoutPriority(priority: number | Signal<number>): ModifierBuilder<T> {
235
- this.modifiers.push(new LayoutModifier({ layoutPriority: priority }))
236
- return this
237
- }
238
-
239
- // New multi-property modifiers
240
- size(options: {
241
- width?: number | string
242
- height?: number | string
243
- minWidth?: number | string
244
- maxWidth?: number | string
245
- minHeight?: number | string
246
- maxHeight?: number | string
247
- }): ModifierBuilder<T> {
248
- this.modifiers.push(size(options))
249
- return this
250
- }
251
-
252
- width(value: number | string): ModifierBuilder<T> {
253
- this.modifiers.push(width(value))
254
- return this
255
- }
256
-
257
- height(value: number | string): ModifierBuilder<T> {
258
- this.modifiers.push(height(value))
259
- return this
260
- }
261
-
262
- maxWidth(value: number | string): ModifierBuilder<T> {
263
- this.modifiers.push(maxWidth(value))
264
- return this
265
- }
266
-
267
- minWidth(value: number | string): ModifierBuilder<T> {
268
- this.modifiers.push(minWidth(value))
269
- return this
270
- }
271
-
272
- maxHeight(value: number | string): ModifierBuilder<T> {
273
- this.modifiers.push(maxHeight(value))
274
- return this
275
- }
276
-
277
- minHeight(value: number | string): ModifierBuilder<T> {
278
- this.modifiers.push(minHeight(value))
279
- return this
280
- }
281
-
282
- marginTop(value: number): ModifierBuilder<T> {
283
- this.modifiers.push(marginTop(value))
284
- return this
285
- }
286
-
287
- marginBottom(value: number): ModifierBuilder<T> {
288
- this.modifiers.push(marginBottom(value))
289
- return this
290
- }
291
-
292
- marginHorizontal(value: number): ModifierBuilder<T> {
293
- this.modifiers.push(marginHorizontal(value))
294
- return this
295
- }
296
-
297
- marginVertical(value: number): ModifierBuilder<T> {
298
- this.modifiers.push(marginVertical(value))
299
- return this
300
- }
301
-
302
- marginLeft(value: number): ModifierBuilder<T> {
303
- this.modifiers.push(marginLeft(value))
304
- return this
305
- }
306
-
307
- marginRight(value: number): ModifierBuilder<T> {
308
- this.modifiers.push(marginRight(value))
309
- return this
310
- }
311
-
312
- // Padding modifiers
313
- padding(value: number): ModifierBuilder<T>
314
- padding(options: any): ModifierBuilder<T>
315
- padding(valueOrOptions: number | any): ModifierBuilder<T> {
316
- if (typeof valueOrOptions === 'number') {
317
- this.modifiers.push(padding(valueOrOptions))
318
- } else {
319
- this.modifiers.push(padding(valueOrOptions as any))
320
- }
321
- return this
322
- }
323
-
324
- paddingTop(value: number): ModifierBuilder<T> {
325
- this.modifiers.push(paddingTop(value))
326
- return this
327
- }
328
-
329
- paddingBottom(value: number): ModifierBuilder<T> {
330
- this.modifiers.push(paddingBottom(value))
331
- return this
332
- }
333
-
334
- paddingLeft(value: number): ModifierBuilder<T> {
335
- this.modifiers.push(paddingLeft(value))
336
- return this
337
- }
338
-
339
- paddingRight(value: number): ModifierBuilder<T> {
340
- this.modifiers.push(paddingRight(value))
341
- return this
342
- }
343
-
344
- paddingLeading(value: number): ModifierBuilder<T> {
345
- this.modifiers.push(paddingLeading(value))
346
- return this
347
- }
348
-
349
- paddingTrailing(value: number): ModifierBuilder<T> {
350
- this.modifiers.push(paddingTrailing(value))
351
- return this
352
- }
353
-
354
- paddingHorizontal(value: number): ModifierBuilder<T> {
355
- this.modifiers.push(paddingHorizontal(value))
356
- return this
357
- }
358
-
359
- paddingVertical(value: number): ModifierBuilder<T> {
360
- this.modifiers.push(paddingVertical(value))
361
- return this
362
- }
363
-
364
- // Typography modifiers
365
- typography(options: {
366
- size?: number | string
367
- weight?: FontWeight
368
- family?: string
369
- lineHeight?: number | string
370
- letterSpacing?: number | string
371
- align?: TextAlign
372
- transform?: TextTransform
373
- decoration?: TextDecoration
374
- variant?: FontVariant
375
- style?: FontStyle
376
- color?: string
377
- }): ModifierBuilder<T> {
378
- this.modifiers.push(typography(options))
379
- return this
380
- }
381
-
382
- textAlign(value: 'left' | 'center' | 'right' | 'justify' | 'start' | 'end'): ModifierBuilder<T> {
383
- this.modifiers.push(textAlign(value))
384
- return this
385
- }
386
-
387
- textTransform(value: 'none' | 'uppercase' | 'lowercase' | 'capitalize'): ModifierBuilder<T> {
388
- this.modifiers.push(textTransform(value))
389
- return this
390
- }
391
-
392
- letterSpacing(value: number | string): ModifierBuilder<T> {
393
- this.modifiers.push(letterSpacing(value))
394
- return this
395
- }
396
-
397
- lineHeight(value: number | string): ModifierBuilder<T> {
398
- this.modifiers.push(lineHeight(value))
399
- return this
400
- }
401
-
402
- textOverflow(value: 'clip' | 'ellipsis' | 'fade' | string): ModifierBuilder<T> {
403
- this.modifiers.push(textOverflow(value))
404
- return this
405
- }
406
-
407
- whiteSpace(
408
- value: 'normal' | 'nowrap' | 'pre' | 'pre-wrap' | 'pre-line' | 'break-spaces'
409
- ): ModifierBuilder<T> {
410
- this.modifiers.push(whiteSpace(value))
411
- return this
412
- }
413
-
414
- overflow(value: 'visible' | 'hidden' | 'scroll' | 'auto'): ModifierBuilder<T> {
415
- this.modifiers.push(overflow(value))
416
- return this
417
- }
418
-
419
- // Border modifiers
420
- borderTop(
421
- width: number | Signal<number>,
422
- color: string | Signal<string>,
423
- style?: BorderStyle
424
- ): ModifierBuilder<T> {
425
- this.modifiers.push(borderTop(width, color, style))
426
- return this
427
- }
428
-
429
- borderRight(
430
- width: number | Signal<number>,
431
- color: string | Signal<string>,
432
- style?: BorderStyle
433
- ): ModifierBuilder<T> {
434
- this.modifiers.push(borderRight(width, color, style))
435
- return this
436
- }
437
-
438
- borderBottom(
439
- width: number | Signal<number>,
440
- color: string | Signal<string>,
441
- style?: BorderStyle
442
- ): ModifierBuilder<T> {
443
- this.modifiers.push(borderBottom(width, color, style))
444
- return this
445
- }
446
-
447
- borderLeft(
448
- width: number | Signal<number>,
449
- color: string | Signal<string>,
450
- style?: BorderStyle
451
- ): ModifierBuilder<T> {
452
- this.modifiers.push(borderLeft(width, color, style))
453
- return this
454
- }
455
-
456
- // Flexbox modifiers
457
-
458
- flexGrow(value: number): ModifierBuilder<T> {
459
- this.modifiers.push(flexGrow(value))
460
- return this
461
- }
462
-
463
- flexShrink(value: number): ModifierBuilder<T> {
464
- this.modifiers.push(flexShrink(value))
465
- return this
466
- }
467
-
468
- justifyContent(
469
- value: 'flex-start' | 'flex-end' | 'center' | 'space-between' | 'space-around' | 'space-evenly'
470
- ): ModifierBuilder<T> {
471
- this.modifiers.push(justifyContent(value))
472
- return this
473
- }
474
-
475
- alignItems(
476
- value: 'flex-start' | 'flex-end' | 'center' | 'stretch' | 'baseline'
477
- ): ModifierBuilder<T> {
478
- this.modifiers.push(alignItems(value))
479
- return this
480
- }
481
-
482
- gap(value: number | string): ModifierBuilder<T> {
483
- this.modifiers.push(gap(value))
484
- return this
485
- }
486
-
487
- flexDirection(value: 'row' | 'row-reverse' | 'column' | 'column-reverse'): ModifierBuilder<T> {
488
- this.modifiers.push(flexDirection(value))
489
- return this
490
- }
491
-
492
- flexWrap(value: 'nowrap' | 'wrap' | 'wrap-reverse'): ModifierBuilder<T> {
493
- this.modifiers.push(flexWrap(value))
494
- return this
495
- }
496
-
497
- // Utility modifiers
498
- cursor(
499
- value:
500
- | 'auto'
501
- | 'default'
502
- | 'pointer'
503
- | 'text'
504
- | 'wait'
505
- | 'help'
506
- | 'not-allowed'
507
- | 'grab'
508
- | 'grabbing'
509
- ): ModifierBuilder<T> {
510
- this.modifiers.push(cursor(value))
511
- return this
512
- }
513
-
514
- overflowY(value: 'visible' | 'hidden' | 'scroll' | 'auto'): ModifierBuilder<T> {
515
- this.modifiers.push(overflowY(value))
516
- return this
517
- }
518
-
519
- overflowX(value: 'visible' | 'hidden' | 'scroll' | 'auto'): ModifierBuilder<T> {
520
- this.modifiers.push(overflowX(value))
521
- return this
522
- }
523
-
524
- position(value: 'static' | 'relative' | 'absolute' | 'fixed' | 'sticky'): ModifierBuilder<T> {
525
- this.modifiers.push(position(value))
526
- return this
527
- }
528
-
529
- zIndex(value: number): ModifierBuilder<T> {
530
- this.modifiers.push(zIndex(value))
531
- return this
532
- }
533
-
534
- display(
535
- value: 'block' | 'inline' | 'inline-block' | 'flex' | 'inline-flex' | 'grid' | 'none'
536
- ): ModifierBuilder<T> {
537
- this.modifiers.push(display(value))
538
- return this
539
- }
540
-
541
- // Raw CSS modifiers
542
- css(properties: { [property: string]: string | number | undefined }): ModifierBuilder<T> {
543
- this.modifiers.push(css(properties))
544
- return this
545
- }
546
-
547
- cssProperty(property: string, value: string | number): ModifierBuilder<T> {
548
- this.modifiers.push(cssProperty(property, value))
549
- return this
550
- }
551
-
552
- cssVariable(name: string, value: string | number): ModifierBuilder<T> {
553
- this.modifiers.push(cssVariable(name, value))
554
- return this
555
- }
556
-
557
- textCase(value: 'none' | 'uppercase' | 'lowercase' | 'capitalize'): ModifierBuilder<T> {
558
- this.modifiers.push(textTransform(value))
559
- return this
560
- }
561
-
562
- textDecoration(value: 'none' | 'underline' | 'overline' | 'line-through'): ModifierBuilder<T> {
563
- this.modifiers.push(textDecoration(value))
564
- return this
565
- }
566
-
567
- // Phase 1 SwiftUI modifiers
568
- offset(x: number | Signal<number>, y?: number | Signal<number>): ModifierBuilder<T> {
569
- this.modifiers.push(
570
- new LayoutModifier({
571
- offset: {
572
- x: typeof x === 'number' ? x : x,
573
- y: typeof y === 'number' ? (y ?? 0) : (y ?? 0),
574
- },
575
- })
576
- )
577
- return this
578
- }
579
-
580
- clipped(): ModifierBuilder<T> {
581
- this.modifiers.push(new AppearanceModifier({ clipped: true }))
582
- return this
583
- }
584
-
585
- rotationEffect(
586
- angle: number | Signal<number>,
587
- anchor:
588
- | 'center'
589
- | 'top'
590
- | 'topLeading'
591
- | 'topTrailing'
592
- | 'bottom'
593
- | 'bottomLeading'
594
- | 'bottomTrailing'
595
- | 'leading'
596
- | 'trailing' = 'center'
597
- ): ModifierBuilder<T> {
598
- this.modifiers.push(
599
- new AnimationModifier({
600
- rotationEffect: {
601
- angle: typeof angle === 'number' ? angle : angle,
602
- anchor,
603
- },
604
- })
605
- )
606
- return this
607
- }
608
-
609
- // Phase 2 SwiftUI modifiers
610
- aspectRatio(
611
- ratio?: number | Signal<number>,
612
- contentMode: 'fit' | 'fill' = 'fit'
613
- ): ModifierBuilder<T> {
614
- this.modifiers.push(
615
- new LayoutModifier({
616
- aspectRatio: {
617
- ratio: typeof ratio === 'number' ? ratio : ratio,
618
- contentMode,
619
- },
620
- })
621
- )
622
- return this
623
- }
624
-
625
- fixedSize(horizontal: boolean = true, vertical: boolean = true): ModifierBuilder<T> {
626
- this.modifiers.push(
627
- new LayoutModifier({
628
- fixedSize: {
629
- horizontal,
630
- vertical,
631
- },
632
- })
633
- )
634
- return this
635
- }
636
-
637
- clipShape(
638
- shape: 'circle' | 'ellipse' | 'rect' | 'polygon',
639
- parameters?: Record<string, any>
640
- ): ModifierBuilder<T> {
641
- this.modifiers.push(
642
- new AppearanceModifier({
643
- clipShape: {
644
- shape,
645
- parameters: parameters || {},
646
- },
647
- })
648
- )
649
- return this
650
- }
651
-
652
- overlay(
653
- content: any,
654
- alignment:
655
- | 'center'
656
- | 'top'
657
- | 'bottom'
658
- | 'leading'
659
- | 'trailing'
660
- | 'topLeading'
661
- | 'topTrailing'
662
- | 'bottomLeading'
663
- | 'bottomTrailing' = 'center'
664
- ): ModifierBuilder<T> {
665
- this.modifiers.push(
666
- new AnimationModifier({
667
- overlay: {
668
- content,
669
- alignment,
670
- },
671
- })
672
- )
673
- return this
674
- }
675
-
676
- // Phase 3 SwiftUI modifiers - Critical Transform Modifiers
677
- scaleEffect(
678
- x: number | Signal<number>,
679
- y?: number | Signal<number>,
680
- anchor:
681
- | 'center'
682
- | 'top'
683
- | 'topLeading'
684
- | 'topTrailing'
685
- | 'bottom'
686
- | 'bottomLeading'
687
- | 'bottomTrailing'
688
- | 'leading'
689
- | 'trailing' = 'center'
690
- ): ModifierBuilder<T> {
691
- this.modifiers.push(
692
- new LayoutModifier({
693
- scaleEffect: {
694
- x,
695
- y,
696
- anchor,
697
- },
698
- })
699
- )
700
- return this
701
- }
702
-
703
- absolutePosition(x: number | Signal<number>, y: number | Signal<number>): ModifierBuilder<T> {
704
- this.modifiers.push(
705
- new LayoutModifier({
706
- position: {
707
- x,
708
- y,
709
- },
710
- })
711
- )
712
- return this
713
- }
714
-
715
- // Appearance modifiers
716
- foregroundColor(color: ColorValue): ModifierBuilder<T> {
717
- this.modifiers.push(new AppearanceModifier({ foregroundColor: color }))
718
- return this
719
- }
720
-
721
- backgroundColor(color: ColorValue): ModifierBuilder<T> {
722
- this.modifiers.push(new AppearanceModifier({ backgroundColor: color }))
723
- return this
724
- }
725
-
726
- background(value: StatefulBackgroundValue | Signal<string>): ModifierBuilder<T> {
727
- this.modifiers.push(new BackgroundModifier({ background: value as StatefulBackgroundValue }))
728
- return this
729
- }
730
-
731
- font(options: AppearanceModifierProps['font']): ModifierBuilder<T>
732
- font(size: number | string): ModifierBuilder<T>
733
- font(sizeOrOptions: number | string | AppearanceModifierProps['font']): ModifierBuilder<T> {
734
- let fontProps: AppearanceModifierProps['font']
735
-
736
- if (typeof sizeOrOptions === 'object') {
737
- fontProps = sizeOrOptions
738
- } else {
739
- fontProps = sizeOrOptions !== undefined ? { size: sizeOrOptions } : {}
740
- }
741
-
742
- this.modifiers.push(new AppearanceModifier({ font: fontProps }))
743
- return this
744
- }
745
-
746
- fontWeight(weight: NonNullable<AppearanceModifierProps['font']>['weight']): ModifierBuilder<T> {
747
- this.modifiers.push(new AppearanceModifier({ font: { weight } }))
748
- return this
749
- }
750
-
751
- fontSize(size: number | string | Signal<number> | Signal<string>): ModifierBuilder<T> {
752
- this.modifiers.push(new AppearanceModifier({ font: { size } }))
753
- return this
754
- }
755
-
756
- fontFamily(family: string | FontAsset | Signal<string | FontAsset>): ModifierBuilder<T> {
757
- this.modifiers.push(new AppearanceModifier({ font: { family } }))
758
- return this
759
- }
760
-
761
- opacity(value: number | Signal<number>): ModifierBuilder<T> {
762
- this.modifiers.push(new AppearanceModifier({ opacity: value }))
763
- return this
764
- }
765
-
766
- cornerRadius(radius: number | Signal<number>): ModifierBuilder<T> {
767
- this.modifiers.push(new AppearanceModifier({ cornerRadius: radius }))
768
- return this
769
- }
770
-
771
- border(width: number | Signal<number>, color?: ColorValue): ModifierBuilder<T>
772
- border(options: AppearanceModifierProps['border']): ModifierBuilder<T>
773
- border(
774
- widthOrOptions: number | Signal<number> | AppearanceModifierProps['border'],
775
- color?: ColorValue
776
- ): ModifierBuilder<T> {
777
- let borderProps: AppearanceModifierProps['border']
778
-
779
- if (typeof widthOrOptions === 'object') {
780
- borderProps = widthOrOptions
781
- } else {
782
- borderProps = {
783
- style: 'solid',
784
- ...(widthOrOptions !== undefined && { width: widthOrOptions }),
785
- ...(color !== undefined && { color }),
786
- }
787
- }
788
-
789
- this.modifiers.push(new AppearanceModifier({ border: borderProps }))
790
- return this
791
- }
792
-
793
- borderWidth(width: number | Signal<number>): ModifierBuilder<T> {
794
- this.modifiers.push(new AppearanceModifier({ border: { width } }))
795
- return this
796
- }
797
-
798
- shadow(options: AppearanceModifierProps['shadow']): ModifierBuilder<T>
799
- shadow(config: { x: number; y: number; blur: number; color: string; spread?: number; inset?: boolean }): ModifierBuilder<T>
800
- shadow(optionsOrConfig: AppearanceModifierProps['shadow'] | { x: number; y: number; blur: number; color: string; spread?: number; inset?: boolean }): ModifierBuilder<T> {
801
- // Check if it's the new ShadowConfig format (has x, y, blur properties)
802
- if (optionsOrConfig && typeof optionsOrConfig === 'object' && 'x' in optionsOrConfig && 'y' in optionsOrConfig && 'blur' in optionsOrConfig) {
803
- this.modifiers.push(shadowModifier(optionsOrConfig as any))
804
- } else {
805
- // Use the old AppearanceModifier format
806
- this.modifiers.push(new AppearanceModifier({ shadow: optionsOrConfig as AppearanceModifierProps['shadow'] }))
807
- }
808
- return this
809
- }
810
-
811
- textShadow(config: TextShadowConfig): ModifierBuilder<T> {
812
- this.modifiers.push(textShadow(config))
813
- return this
814
- }
815
-
816
- // Additional shadow methods
817
- shadows(configs: Array<{ x: number; y: number; blur: number; color: string; spread?: number; inset?: boolean }>): ModifierBuilder<T> {
818
- this.modifiers.push(shadowsModifier(configs))
819
- return this
820
- }
821
-
822
- shadowPreset(presetName: string): ModifierBuilder<T> {
823
- this.modifiers.push(shadowPreset(presetName))
824
- return this
825
- }
826
-
827
- // Visual Effects Modifiers (Phase 2 - Epic: Butternut)
828
- blur(radius: number | Signal<number>): ModifierBuilder<T> {
829
- this.modifiers.push(new AppearanceModifier({ blur: radius }))
830
- return this
831
- }
832
-
833
- brightness(amount: number | Signal<number>): ModifierBuilder<T> {
834
- this.modifiers.push(new AppearanceModifier({ brightness: amount }))
835
- return this
836
- }
837
-
838
- contrast(amount: number | Signal<number>): ModifierBuilder<T> {
839
- this.modifiers.push(new AppearanceModifier({ contrast: amount }))
840
- return this
841
- }
842
-
843
- saturation(amount: number | Signal<number>): ModifierBuilder<T> {
844
- this.modifiers.push(new AppearanceModifier({ saturation: amount }))
845
- return this
846
- }
847
-
848
- hueRotation(angle: number | Signal<number>): ModifierBuilder<T> {
849
- this.modifiers.push(new AppearanceModifier({ hueRotation: angle }))
850
- return this
851
- }
852
-
853
- grayscale(amount: number | Signal<number>): ModifierBuilder<T> {
854
- this.modifiers.push(new AppearanceModifier({ grayscale: amount }))
855
- return this
856
- }
857
-
858
- colorInvert(amount: number | Signal<number> = 1.0): ModifierBuilder<T> {
859
- this.modifiers.push(new AppearanceModifier({ colorInvert: amount }))
860
- return this
861
- }
862
-
863
- dropShadow(shadow: string): ModifierBuilder<T> {
864
- this.modifiers.push(new FilterModifier({ filter: { dropShadow: shadow } }))
865
- return this
866
- }
867
-
868
- // Additional filter methods
869
- filter(config: { blur?: number; brightness?: number; contrast?: number; saturate?: number; [key: string]: any } | string): ModifierBuilder<T> {
870
- this.modifiers.push(filter(config))
871
- return this
872
- }
873
-
874
- saturate(value: number): ModifierBuilder<T> {
875
- this.modifiers.push(saturate(value))
876
- return this
877
- }
878
-
879
- sepia(value: number): ModifierBuilder<T> {
880
- this.modifiers.push(sepia(value))
881
- return this
882
- }
883
-
884
- hueRotate(angle: string): ModifierBuilder<T> {
885
- this.modifiers.push(hueRotate(angle))
886
- return this
887
- }
888
-
889
- invert(value: number): ModifierBuilder<T> {
890
- this.modifiers.push(invert(value))
891
- return this
892
- }
893
-
894
- // Filter presets
895
- vintagePhoto(sepiaAmount?: number, contrastAmount?: number): ModifierBuilder<T> {
896
- this.modifiers.push(vintagePhoto(sepiaAmount, contrastAmount))
897
- return this
898
- }
899
-
900
- blackAndWhite(contrastAmount?: number): ModifierBuilder<T> {
901
- this.modifiers.push(blackAndWhite(contrastAmount))
902
- return this
903
- }
904
-
905
- vibrant(saturationAmount?: number, contrastAmount?: number): ModifierBuilder<T> {
906
- this.modifiers.push(vibrant(saturationAmount, contrastAmount))
907
- return this
908
- }
909
-
910
- warmTone(hueShift?: string): ModifierBuilder<T> {
911
- this.modifiers.push(warmTone(hueShift))
912
- return this
913
- }
914
-
915
- coolTone(hueShift?: string): ModifierBuilder<T> {
916
- this.modifiers.push(coolTone(hueShift))
917
- return this
918
- }
919
-
920
- faded(contrastAmount?: number, saturationAmount?: number): ModifierBuilder<T> {
921
- this.modifiers.push(faded(contrastAmount, saturationAmount))
922
- return this
923
- }
924
-
925
- highKey(brightnessAmount?: number, contrastAmount?: number): ModifierBuilder<T> {
926
- this.modifiers.push(highKey(brightnessAmount, contrastAmount))
927
- return this
928
- }
929
-
930
- lowKey(brightnessAmount?: number, contrastAmount?: number): ModifierBuilder<T> {
931
- this.modifiers.push(lowKey(brightnessAmount, contrastAmount))
932
- return this
933
- }
934
-
935
- softFocus(blurAmount?: number): ModifierBuilder<T> {
936
- this.modifiers.push(softFocus(blurAmount))
937
- return this
938
- }
939
-
940
- highContrastMode(): ModifierBuilder<T> {
941
- this.modifiers.push(highContrastMode())
942
- return this
943
- }
944
-
945
- subtleBlur(): ModifierBuilder<T> {
946
- this.modifiers.push(subtleBlur())
947
- return this
948
- }
949
-
950
- darkModeInvert(): ModifierBuilder<T> {
951
- this.modifiers.push(darkModeInvert())
952
- return this
953
- }
954
-
955
- // Transform modifiers
956
- scale(value: number | { x?: number; y?: number }): ModifierBuilder<T> {
957
- this.modifiers.push(scale(value))
958
- return this
959
- }
960
-
961
- rotate(angle: string): ModifierBuilder<T> {
962
- this.modifiers.push(rotate(angle))
963
- return this
964
- }
965
-
966
- translate(offset: { x?: number | string; y?: number | string }): ModifierBuilder<T> {
967
- this.modifiers.push(translate(offset))
968
- return this
969
- }
970
-
971
- perspective(value: number): ModifierBuilder<T> {
972
- this.modifiers.push(perspective(value))
973
- return this
974
- }
975
-
976
- // Hover and cursor effect modifiers
977
- hover(styles: any, transition?: string | number): ModifierBuilder<T> {
978
- this.modifiers.push(hoverModifier(styles, transition))
979
- return this
980
- }
981
-
982
- hoverEffect(effect: 'automatic' | 'highlight' | 'lift' | 'scale', isEnabled?: boolean): ModifierBuilder<T> {
983
- this.modifiers.push(hoverEffect(effect, isEnabled))
984
- return this
985
- }
986
-
987
- hoverWithTransition(styles: any, duration: number = 200): ModifierBuilder<T> {
988
- this.modifiers.push(hoverWithTransition(styles, duration))
989
- return this
990
- }
991
-
992
- conditionalHover(effect: 'automatic' | 'highlight' | 'lift' | 'scale', isEnabled: boolean): ModifierBuilder<T> {
993
- this.modifiers.push(conditionalHover(effect, isEnabled))
994
- return this
995
- }
996
-
997
- // Cursor preset methods
998
- interactiveCursor(): ModifierBuilder<T> {
999
- this.modifiers.push(interactiveCursor())
1000
- return this
1001
- }
1002
-
1003
- draggableCursor(): ModifierBuilder<T> {
1004
- this.modifiers.push(draggableCursor())
1005
- return this
1006
- }
1007
-
1008
- textCursor(): ModifierBuilder<T> {
1009
- this.modifiers.push(textCursor())
1010
- return this
1011
- }
1012
-
1013
- disabledCursor(): ModifierBuilder<T> {
1014
- this.modifiers.push(disabledCursor())
1015
- return this
1016
- }
1017
-
1018
- loadingCursor(): ModifierBuilder<T> {
1019
- this.modifiers.push(loadingCursor())
1020
- return this
1021
- }
1022
-
1023
- helpCursor(): ModifierBuilder<T> {
1024
- this.modifiers.push(helpCursor())
1025
- return this
1026
- }
1027
-
1028
- zoomCursor(mode: 'in' | 'out' = 'in'): ModifierBuilder<T> {
1029
- this.modifiers.push(zoomCursor(mode))
1030
- return this
1031
- }
1032
-
1033
- // Hover effect presets
1034
- buttonHover(): ModifierBuilder<T> {
1035
- this.modifiers.push(buttonHover())
1036
- return this
1037
- }
1038
-
1039
- cardHover(): ModifierBuilder<T> {
1040
- this.modifiers.push(cardHover())
1041
- return this
1042
- }
1043
-
1044
- linkHover(): ModifierBuilder<T> {
1045
- this.modifiers.push(linkHover())
1046
- return this
1047
- }
1048
-
1049
- imageHover(): ModifierBuilder<T> {
1050
- this.modifiers.push(imageHover())
1051
- return this
1052
- }
1053
-
1054
- // Transition modifiers
1055
- transition(
1056
- property: string = 'all',
1057
- duration: number = 300,
1058
- easing: string = 'ease',
1059
- delay: number = 0
1060
- ): ModifierBuilder<T> {
1061
- this.modifiers.push(transitionModifier(property, duration, easing, delay))
1062
- return this
1063
- }
1064
-
1065
- transitions(config: any): ModifierBuilder<T> {
1066
- this.modifiers.push(transitions(config))
1067
- return this
1068
- }
1069
-
1070
- // Transition presets
1071
- fadeTransition(duration: number = 200): ModifierBuilder<T> {
1072
- this.modifiers.push(fadeTransition(duration))
1073
- return this
1074
- }
1075
-
1076
- transformTransition(duration: number = 300): ModifierBuilder<T> {
1077
- this.modifiers.push(transformTransition(duration))
1078
- return this
1079
- }
1080
-
1081
- colorTransition(duration: number = 150): ModifierBuilder<T> {
1082
- this.modifiers.push(colorTransition(duration))
1083
- return this
1084
- }
1085
-
1086
- layoutTransition(duration: number = 250): ModifierBuilder<T> {
1087
- this.modifiers.push(layoutTransition(duration))
1088
- return this
1089
- }
1090
-
1091
- buttonTransition(): ModifierBuilder<T> {
1092
- this.modifiers.push(buttonTransition())
1093
- return this
1094
- }
1095
-
1096
- cardTransition(): ModifierBuilder<T> {
1097
- this.modifiers.push(cardTransition())
1098
- return this
1099
- }
1100
-
1101
- modalTransition(): ModifierBuilder<T> {
1102
- this.modifiers.push(modalTransition())
1103
- return this
1104
- }
1105
-
1106
- smoothTransition(duration: number = 300): ModifierBuilder<T> {
1107
- this.modifiers.push(smoothTransition(duration))
1108
- return this
1109
- }
1110
-
1111
- quickTransition(duration: number = 150): ModifierBuilder<T> {
1112
- this.modifiers.push(quickTransition(duration))
1113
- return this
1114
- }
1115
-
1116
- slowTransition(duration: number = 500): ModifierBuilder<T> {
1117
- this.modifiers.push(slowTransition(duration))
1118
- return this
1119
- }
1120
-
1121
- // Scroll modifiers
1122
- scroll(config: any): ModifierBuilder<T> {
1123
- this.modifiers.push(scrollModifier(config))
1124
- return this
1125
- }
1126
-
1127
- scrollBehavior(value: 'auto' | 'smooth'): ModifierBuilder<T> {
1128
- this.modifiers.push(scrollBehavior(value))
1129
- return this
1130
- }
1131
-
1132
- overscrollBehavior(value: 'auto' | 'contain' | 'none'): ModifierBuilder<T> {
1133
- this.modifiers.push(overscrollBehavior(value))
1134
- return this
1135
- }
1136
-
1137
- overscrollBehaviorX(value: 'auto' | 'contain' | 'none'): ModifierBuilder<T> {
1138
- this.modifiers.push(overscrollBehaviorX(value))
1139
- return this
1140
- }
1141
-
1142
- overscrollBehaviorY(value: 'auto' | 'contain' | 'none'): ModifierBuilder<T> {
1143
- this.modifiers.push(overscrollBehaviorY(value))
1144
- return this
1145
- }
1146
-
1147
- scrollMargin(margin: number | string | { top?: number | string, right?: number | string, bottom?: number | string, left?: number | string }): ModifierBuilder<T> {
1148
- this.modifiers.push(scrollMargin(margin))
1149
- return this
1150
- }
1151
-
1152
- scrollPadding(padding: number | string | { top?: number | string, right?: number | string, bottom?: number | string, left?: number | string }): ModifierBuilder<T> {
1153
- this.modifiers.push(scrollPadding(padding))
1154
- return this
1155
- }
1156
-
1157
- scrollSnap(
1158
- type: 'none' | 'x mandatory' | 'y mandatory' | 'x proximity' | 'y proximity' | 'both mandatory' | 'both proximity',
1159
- align?: 'start' | 'end' | 'center',
1160
- stop?: 'normal' | 'always'
1161
- ): ModifierBuilder<T> {
1162
- this.modifiers.push(scrollSnap(type, align, stop))
1163
- return this
1164
- }
1165
-
1166
- // Interaction modifiers
1167
- onTap(handler: (event: MouseEvent) => void): ModifierBuilder<T> {
1168
- this.modifiers.push(new InteractionModifier({ onTap: handler }))
1169
- return this
1170
- }
1171
-
1172
- onHover(handler: (isHovered: boolean) => void): ModifierBuilder<T> {
1173
- this.modifiers.push(new InteractionModifier({ onHover: handler }))
1174
- return this
1175
- }
1176
-
1177
- onMouseEnter(handler: (event: MouseEvent) => void): ModifierBuilder<T> {
1178
- this.modifiers.push(new InteractionModifier({ onMouseEnter: handler }))
1179
- return this
1180
- }
1181
-
1182
- onMouseLeave(handler: (event: MouseEvent) => void): ModifierBuilder<T> {
1183
- this.modifiers.push(new InteractionModifier({ onMouseLeave: handler }))
1184
- return this
1185
- }
1186
-
1187
- onMouseDown(handler: (event: MouseEvent) => void): ModifierBuilder<T> {
1188
- this.modifiers.push(new InteractionModifier({ onMouseDown: handler }))
1189
- return this
1190
- }
1191
-
1192
- onMouseUp(handler: (event: MouseEvent) => void): ModifierBuilder<T> {
1193
- this.modifiers.push(new InteractionModifier({ onMouseUp: handler }))
1194
- return this
1195
- }
1196
-
1197
- onDragStart(handler: (event: DragEvent) => void): ModifierBuilder<T> {
1198
- this.modifiers.push(new InteractionModifier({ onDragStart: handler }))
1199
- return this
1200
- }
1201
-
1202
- onDragOver(handler: (event: DragEvent) => void): ModifierBuilder<T> {
1203
- this.modifiers.push(new InteractionModifier({ onDragOver: handler }))
1204
- return this
1205
- }
1206
-
1207
- onDragLeave(handler: (event: DragEvent) => void): ModifierBuilder<T> {
1208
- this.modifiers.push(new InteractionModifier({ onDragLeave: handler }))
1209
- return this
1210
- }
1211
-
1212
- onDrop(handler: (event: DragEvent) => void): ModifierBuilder<T> {
1213
- this.modifiers.push(new InteractionModifier({ onDrop: handler }))
1214
- return this
1215
- }
1216
-
1217
- // Additional mouse events
1218
- onDoubleClick(handler: (event: MouseEvent) => void): ModifierBuilder<T> {
1219
- this.modifiers.push(new InteractionModifier({ onDoubleClick: handler }))
1220
- return this
1221
- }
1222
-
1223
- onContextMenu(handler: (event: MouseEvent) => void): ModifierBuilder<T> {
1224
- this.modifiers.push(new InteractionModifier({ onContextMenu: handler }))
1225
- return this
1226
- }
1227
-
1228
- // Focus events
1229
- onFocus(handler: (isFocused: boolean) => void): ModifierBuilder<T> {
1230
- this.modifiers.push(new InteractionModifier({ onFocus: handler }))
1231
- return this
1232
- }
1233
-
1234
- onBlur(handler: (isFocused: boolean) => void): ModifierBuilder<T> {
1235
- this.modifiers.push(new InteractionModifier({ onBlur: handler }))
1236
- return this
1237
- }
1238
-
1239
- // Keyboard events
1240
- onKeyPress(handler: (event: KeyboardEvent) => void): ModifierBuilder<T> {
1241
- this.modifiers.push(new InteractionModifier({ onKeyPress: handler }))
1242
- return this
1243
- }
1244
-
1245
- onKeyDown(handler: (event: KeyboardEvent) => void): ModifierBuilder<T> {
1246
- this.modifiers.push(new InteractionModifier({ onKeyDown: handler }))
1247
- return this
1248
- }
1249
-
1250
- onKeyUp(handler: (event: KeyboardEvent) => void): ModifierBuilder<T> {
1251
- this.modifiers.push(new InteractionModifier({ onKeyUp: handler }))
1252
- return this
1253
- }
1254
-
1255
- // Scroll and wheel events
1256
- onScroll(handler: (event: Event) => void): ModifierBuilder<T> {
1257
- this.modifiers.push(new InteractionModifier({ onScroll: handler }))
1258
- return this
1259
- }
1260
-
1261
- onWheel(handler: (event: WheelEvent) => void): ModifierBuilder<T> {
1262
- this.modifiers.push(new InteractionModifier({ onWheel: handler }))
1263
- return this
1264
- }
1265
-
1266
- // Input events
1267
- onInput(handler: (event: InputEvent) => void): ModifierBuilder<T> {
1268
- this.modifiers.push(new InteractionModifier({ onInput: handler }))
1269
- return this
1270
- }
1271
-
1272
- onChange(handler: (value: any, event?: Event) => void): ModifierBuilder<T> {
1273
- this.modifiers.push(new InteractionModifier({ onChange: handler }))
1274
- return this
1275
- }
1276
-
1277
- // Clipboard events
1278
- onCopy(handler: (event: ClipboardEvent) => void): ModifierBuilder<T> {
1279
- this.modifiers.push(new InteractionModifier({ onCopy: handler }))
1280
- return this
1281
- }
1282
-
1283
- onCut(handler: (event: ClipboardEvent) => void): ModifierBuilder<T> {
1284
- this.modifiers.push(new InteractionModifier({ onCut: handler }))
1285
- return this
1286
- }
1287
-
1288
- onPaste(handler: (event: ClipboardEvent) => void): ModifierBuilder<T> {
1289
- this.modifiers.push(new InteractionModifier({ onPaste: handler }))
1290
- return this
1291
- }
1292
-
1293
- // Selection events
1294
- onSelect(handler: (event: Event) => void): ModifierBuilder<T> {
1295
- this.modifiers.push(new InteractionModifier({ onSelect: handler }))
1296
- return this
1297
- }
1298
-
1299
- // HTML and ARIA Attributes
1300
- id(value: string): ModifierBuilder<T> {
1301
- this.modifiers.push(new IdModifier({ id: value }))
1302
- return this
1303
- }
1304
-
1305
- data(attributes: { [key: string]: string | number | boolean }): ModifierBuilder<T> {
1306
- this.modifiers.push(new DataModifier({ data: attributes }))
1307
- return this
1308
- }
1309
-
1310
- aria(attributes: { [key: string]: string | number | boolean | undefined }): ModifierBuilder<T> {
1311
- this.modifiers.push(new AriaModifier({ aria: attributes }))
1312
- return this
1313
- }
1314
-
1315
-
1316
- tabIndex(value: number): ModifierBuilder<T> {
1317
- this.modifiers.push(new TabIndexModifier({ tabIndex: value }))
1318
- return this
1319
- }
1320
-
1321
- // Text Modifiers
1322
- lineClamp(lines: number): ModifierBuilder<T> {
1323
- this.modifiers.push(new LineClampModifier({ lines }))
1324
- return this
1325
- }
1326
-
1327
- wordBreak(value: 'normal' | 'break-all' | 'keep-all' | 'break-word'): ModifierBuilder<T> {
1328
- this.modifiers.push(new WordBreakModifier({ wordBreak: value }))
1329
- return this
1330
- }
1331
-
1332
- overflowWrap(value: 'normal' | 'break-word' | 'anywhere'): ModifierBuilder<T> {
1333
- this.modifiers.push(new OverflowWrapModifier({ overflowWrap: value }))
1334
- return this
1335
- }
1336
-
1337
- hyphens(value: 'none' | 'manual' | 'auto'): ModifierBuilder<T> {
1338
- this.modifiers.push(new HyphensModifier({ hyphens: value }))
1339
- return this
1340
- }
1341
-
1342
- // Gradient Text Modifier
1343
- gradientText(gradient: string): ModifierBuilder<T> {
1344
- this.modifiers.push(new BackgroundClipModifier({
1345
- backgroundImage: gradient,
1346
- backgroundClip: 'text',
1347
- color: 'transparent',
1348
- webkitBackgroundClip: 'text',
1349
- webkitTextFillColor: 'transparent'
1350
- }))
1351
- return this
1352
- }
1353
-
1354
- // Backdrop Filter Modifiers (Unified Implementation)
1355
- backdropFilter(config: { blur?: number; brightness?: number; contrast?: number; saturate?: number; [key: string]: any }, fallbackColor?: ColorValue): ModifierBuilder<T>
1356
- backdropFilter(cssValue: string, fallbackColor?: ColorValue): ModifierBuilder<T>
1357
- backdropFilter(value: { blur?: number; brightness?: number; contrast?: number; saturate?: number; [key: string]: any } | string, fallbackColor?: ColorValue): ModifierBuilder<T> {
1358
- this.modifiers.push(new BackdropFilterModifier({
1359
- backdropFilter: value,
1360
- ...(fallbackColor && { fallbackColor })
1361
- }))
1362
- return this
1363
- }
1364
-
1365
- glassmorphism(intensity: 'subtle' | 'light' | 'medium' | 'heavy' = 'medium', customFallback?: ColorValue): ModifierBuilder<T> {
1366
- const presets = {
1367
- subtle: { config: { blur: 3, saturate: 1.05, brightness: 1.05 }, fallbackColor: 'rgba(255, 255, 255, 0.05)' },
1368
- light: { config: { blur: 8, saturate: 1.15, brightness: 1.1 }, fallbackColor: 'rgba(255, 255, 255, 0.1)' },
1369
- medium: { config: { blur: 16, saturate: 1.3, brightness: 1.15 }, fallbackColor: 'rgba(255, 255, 255, 0.15)' },
1370
- heavy: { config: { blur: 24, saturate: 1.5, brightness: 1.2 }, fallbackColor: 'rgba(255, 255, 255, 0.2)' }
1371
- }
1372
- const preset = presets[intensity]
1373
- this.modifiers.push(new BackdropFilterModifier({
1374
- backdropFilter: preset.config,
1375
- fallbackColor: customFallback || preset.fallbackColor
1376
- }))
1377
- return this
1378
- }
1379
-
1380
- before(styles: { content: string; color?: string; [key: string]: any }): ModifierBuilder<T> {
1381
- this.modifiers.push(beforeModifier(styles))
1382
- return this
1383
- }
1384
-
1385
- after(styles: { content: string; color?: string; [key: string]: any }): ModifierBuilder<T> {
1386
- this.modifiers.push(afterModifier(styles))
1387
- return this
1388
- }
1389
-
1390
- disabled(isDisabled: boolean | Signal<boolean> = true): ModifierBuilder<T> {
1391
- this.modifiers.push(new InteractionModifier({ disabled: isDisabled }))
1392
- return this
1393
- }
1394
-
1395
- draggable(isDraggable: boolean = true): ModifierBuilder<T> {
1396
- this.modifiers.push(new InteractionModifier({ draggable: isDraggable }))
1397
- return this
1398
- }
1399
-
1400
- setAttribute(name: string, value: string): ModifierBuilder<T> {
1401
- // Create a custom modifier for setting arbitrary attributes
1402
- this.modifiers.push({
1403
- type: 'attribute',
1404
- priority: 50,
1405
- properties: { name, value },
1406
- apply: (_node, context) => {
1407
- if (context.element) {
1408
- context.element.setAttribute(name, value)
1409
- }
1410
- return undefined
1411
- },
1412
- })
1413
- return this
1414
- }
1415
-
1416
- accessibilityLabel(label: string): ModifierBuilder<T> {
1417
- this.modifiers.push(new InteractionModifier({ accessibilityLabel: label }))
1418
- return this
1419
- }
1420
-
1421
- // Phase 4 Advanced Gesture Modifiers (Epic: Butternut)
1422
-
1423
- onLongPressGesture(options: {
1424
- minimumDuration?: number
1425
- maximumDistance?: number
1426
- perform: () => void
1427
- onPressingChanged?: (isPressing: boolean) => void
1428
- }): ModifierBuilder<T> {
1429
- this.modifiers.push(new InteractionModifier({ onLongPressGesture: options }))
1430
- return this
1431
- }
1432
-
1433
- keyboardShortcut(
1434
- key: string,
1435
- modifiers: ('cmd' | 'ctrl' | 'shift' | 'alt' | 'meta')[],
1436
- action: () => void
1437
- ): ModifierBuilder<T> {
1438
- this.modifiers.push(new InteractionModifier({
1439
- keyboardShortcut: { key, modifiers, action }
1440
- }))
1441
- return this
1442
- }
1443
-
1444
- focused(binding: boolean | Signal<boolean>): ModifierBuilder<T> {
1445
- this.modifiers.push(new InteractionModifier({ focused: binding }))
1446
- return this
1447
- }
1448
-
1449
- focusable(
1450
- isFocusable: boolean = true,
1451
- interactions?: ('activate' | 'edit')[]
1452
- ): ModifierBuilder<T> {
1453
- this.modifiers.push(new InteractionModifier({
1454
- focusable: { isFocusable, interactions }
1455
- }))
1456
- return this
1457
- }
1458
-
1459
- onContinuousHover(
1460
- coordinateSpace: 'local' | 'global',
1461
- perform: (location: { x: number; y: number } | null) => void
1462
- ): ModifierBuilder<T> {
1463
- this.modifiers.push(new InteractionModifier({
1464
- onContinuousHover: { coordinateSpace, perform }
1465
- }))
1466
- return this
1467
- }
1468
-
1469
- highPriorityGesture(
1470
- gesture: any,
1471
- including?: ('all' | 'subviews' | 'none')[]
1472
- ): ModifierBuilder<T> {
1473
- this.modifiers.push(new InteractionModifier({
1474
- highPriorityGesture: { gesture, including }
1475
- }))
1476
- return this
1477
- }
1478
-
1479
- simultaneousGesture(
1480
- gesture: any,
1481
- including?: ('all' | 'subviews' | 'none')[]
1482
- ): ModifierBuilder<T> {
1483
- this.modifiers.push(new InteractionModifier({
1484
- simultaneousGesture: { gesture, including }
1485
- }))
1486
- return this
1487
- }
1488
-
1489
- allowsHitTesting(enabled: boolean): ModifierBuilder<T> {
1490
- this.modifiers.push(new InteractionModifier({ allowsHitTesting: enabled }))
1491
- return this
1492
- }
1493
-
1494
- // Animation modifiers
1495
- transform(value: string | Signal<string>): ModifierBuilder<T> {
1496
- this.modifiers.push(new AnimationModifier({ transform: value }))
1497
- return this
1498
- }
1499
-
1500
- animation(options: AnimationModifierProps['animation']): ModifierBuilder<T> {
1501
- this.modifiers.push(new AnimationModifier({ animation: options }))
1502
- return this
1503
- }
1504
-
1505
- // Lifecycle modifiers
1506
- onAppear(handler: () => void): ModifierBuilder<T> {
1507
- this.modifiers.push(new LifecycleModifier({ onAppear: handler }))
1508
- return this
1509
- }
1510
-
1511
- onDisappear(handler: () => void): ModifierBuilder<T> {
1512
- this.modifiers.push(new LifecycleModifier({ onDisappear: handler }))
1513
- return this
1514
- }
1515
-
1516
- task(
1517
- operation: () => Promise<void> | void,
1518
- options?: { id?: string; priority?: 'background' | 'userInitiated' | 'utility' | 'default' }
1519
- ): ModifierBuilder<T> {
1520
- this.modifiers.push(
1521
- new LifecycleModifier({
1522
- task: {
1523
- operation,
1524
- id: options?.id,
1525
- priority: options?.priority || 'default',
1526
- },
1527
- })
1528
- )
1529
- return this
1530
- }
1531
-
1532
- refreshable(
1533
- onRefresh: () => Promise<void>,
1534
- isRefreshing?: boolean | Signal<boolean>
1535
- ): ModifierBuilder<T> {
1536
- this.modifiers.push(
1537
- new LifecycleModifier({
1538
- refreshable: {
1539
- onRefresh,
1540
- isRefreshing,
1541
- },
1542
- })
1543
- )
1544
- return this
1545
- }
1546
-
1547
- // Custom modifier application
1548
- modifier(modifier: Modifier): ModifierBuilder<T> {
1549
- this.modifiers.push(modifier)
1550
- return this
1551
- }
1552
-
1553
- // Resizable modifier for images
1554
- resizable(): ModifierBuilder<T> {
1555
- this.modifiers.push(new ResizableModifier({}))
1556
- return this
1557
- }
1558
-
1559
- // Responsive Design Methods
1560
-
1561
- /**
1562
- * Add modifier to internal list (used by responsive builder)
1563
- */
1564
- addModifier(modifier: Modifier): void {
1565
- this.modifiers.push(modifier)
1566
-
1567
- // If the component is modifiable, automatically update its modifiers array
1568
- if ('modifiers' in this.component && Array.isArray((this.component as any).modifiers)) {
1569
- const modifiableComponent = this.component as any
1570
- modifiableComponent.modifiers = [...modifiableComponent.modifiers, modifier]
1571
- }
1572
- }
1573
-
1574
- /**
1575
- * Get responsive builder interface for this builder
1576
- */
1577
- responsive(): ResponsiveModifierBuilder<T>
1578
-
1579
- /**
1580
- * Apply responsive styles with configuration object
1581
- */
1582
- responsive(config: ResponsiveStyleConfig): ModifierBuilder<T>
1583
-
1584
- responsive(config?: ResponsiveStyleConfig): ResponsiveModifierBuilder<T> | ModifierBuilder<T> {
1585
- if (config) {
1586
- // Apply the responsive modifier directly and return this builder
1587
- const modifier = createResponsiveModifier(config)
1588
- this.modifiers.push(modifier)
1589
- return this
1590
- } else {
1591
- // Return responsive builder for chaining
1592
- return new ResponsiveModifierBuilderImpl(this)
1593
- }
1594
- }
1595
-
1596
- // Responsive Breakpoint Shorthand Properties
1597
- get base(): ResponsiveBreakpointBuilder<T> {
1598
- return new ResponsiveModifierBuilderImpl(this).base
1599
- }
1600
-
1601
- get sm(): ResponsiveBreakpointBuilder<T> {
1602
- return new ResponsiveModifierBuilderImpl(this).sm
1603
- }
1604
-
1605
- get md(): ResponsiveBreakpointBuilder<T> {
1606
- return new ResponsiveModifierBuilderImpl(this).md
1607
- }
1608
-
1609
- get lg(): ResponsiveBreakpointBuilder<T> {
1610
- return new ResponsiveModifierBuilderImpl(this).lg
1611
- }
1612
-
1613
- get xl(): ResponsiveBreakpointBuilder<T> {
1614
- return new ResponsiveModifierBuilderImpl(this).xl
1615
- }
1616
-
1617
- get '2xl'(): ResponsiveBreakpointBuilder<T> {
1618
- return new ResponsiveModifierBuilderImpl(this)['2xl']
1619
- }
1620
-
1621
- // HTML Content Rendering (Text components only)
1622
- asHTML(options?: AsHTMLOptions): ModifierBuilder<T> {
1623
- const modifier = asHTML(options)
1624
- this.modifiers.push(modifier)
1625
- return this
1626
- }
1627
-
1628
- // Build the final component with all modifiers applied
1629
- build(): T {
1630
- // Check if this component is already modifiable (from withModifiers)
1631
- if ('modifiers' in this.component) {
1632
- // Update the existing modifiable component with new modifiers
1633
- const existingModifiable = this.component as ModifiableComponent
1634
-
1635
- // Only add modifiers that aren't already in the component's modifiers array
1636
- // This prevents duplicates when addModifier has already added them
1637
- const newModifiers = this.modifiers.filter(builderModifier =>
1638
- !existingModifiable.modifiers.some(existingModifier =>
1639
- existingModifier === builderModifier // Reference equality check
1640
- )
1641
- )
1642
-
1643
- existingModifiable.modifiers = [...existingModifiable.modifiers, ...newModifiers]
1644
- return this.component as T
1645
- } else {
1646
- // Create a new modifiable component with the accumulated modifiers using the proper factory
1647
- const modifiableComponent = createModifiableComponent(this.component as any, this.modifiers)
1648
- return modifiableComponent as unknown as T
1649
- }
1650
- }
1651
- }
1652
-
1653
- /**
1654
- * Create a modifier builder for a component
1655
- */
1656
- export function createModifierBuilder<T extends ComponentInstance>(
1657
- component: T
1658
- ): ModifierBuilder<T> {
1659
- return new ModifierBuilderImpl(component)
1660
- }
1661
-
1662
- /**
1663
- * Apply modifiers to a component instance
1664
- */
1665
- export function applyModifiers<T extends ComponentInstance>(
1666
- component: T,
1667
- modifiers: Modifier[]
1668
- ): ModifiableComponent<ComponentProps> {
1669
- return {
1670
- ...component,
1671
- modifiers,
1672
- modifierBuilder: createModifierBuilder(component) as any,
1673
- }
1674
- }
1675
-
1676
- /**
1677
- * Utility functions for common modifier patterns
1678
- */
1679
- export const modifierUtils = {
1680
- /**
1681
- * Create a padding modifier with all sides
1682
- */
1683
- paddingAll(value: number): Modifier {
1684
- return new LayoutModifier({ padding: value })
1685
- },
1686
-
1687
- /**
1688
- * Create a padding modifier with horizontal/vertical values
1689
- */
1690
- paddingSymmetric(horizontal?: number, vertical?: number): Modifier {
1691
- return new LayoutModifier({
1692
- padding: {
1693
- left: horizontal,
1694
- right: horizontal,
1695
- top: vertical,
1696
- bottom: vertical,
1697
- },
1698
- })
1699
- },
1700
-
1701
- /**
1702
- * Create a margin modifier with all sides
1703
- */
1704
- marginAll(value: number): Modifier {
1705
- return new LayoutModifier({ margin: value })
1706
- },
1707
-
1708
- /**
1709
- * Create a font modifier with common presets
1710
- */
1711
- fontPreset(preset: 'title' | 'heading' | 'body' | 'caption'): Modifier {
1712
- const presets = {
1713
- title: { size: 32, weight: 'bold' as const },
1714
- heading: { size: 24, weight: '600' as const },
1715
- body: { size: 16, weight: 'normal' as const },
1716
- caption: { size: 12, weight: 'normal' as const },
1717
- }
1718
-
1719
- return new AppearanceModifier({ font: presets[preset] })
1720
- },
1721
-
1722
- /**
1723
- * Create a shadow modifier with common presets
1724
- */
1725
- shadowPreset(preset: 'small' | 'medium' | 'large'): Modifier {
1726
- const presets = {
1727
- small: { x: 0, y: 1, radius: 3, color: 'rgba(0,0,0,0.12)' },
1728
- medium: { x: 0, y: 4, radius: 6, color: 'rgba(0,0,0,0.15)' },
1729
- large: { x: 0, y: 10, radius: 25, color: 'rgba(0,0,0,0.15)' },
1730
- }
1731
-
1732
- return new AppearanceModifier({ shadow: presets[preset] })
1733
- },
1734
-
1735
- /**
1736
- * Create a transition modifier with common presets
1737
- */
1738
- transitionPreset(preset: 'fast' | 'normal' | 'slow'): Modifier {
1739
- const presets = {
1740
- fast: { duration: 150, easing: 'ease-out' },
1741
- normal: { duration: 300, easing: 'ease' },
1742
- slow: { duration: 500, easing: 'ease-in-out' },
1743
- }
1744
-
1745
- return new AnimationModifier({ transition: presets[preset] })
1746
- },
1747
- }