@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,46 +0,0 @@
1
- const t = Symbol.for("tachui.infinity"), f = {
2
- infinity: t
3
- };
4
- function o(i) {
5
- return i === t;
6
- }
7
- function s(i) {
8
- if (i !== void 0)
9
- return i === t ? "100%" : typeof i == "number" ? `${i}px` : i;
10
- }
11
- function a() {
12
- return {
13
- flexGrow: "1",
14
- flexShrink: "1",
15
- flexBasis: "0%"
16
- };
17
- }
18
- function x(i) {
19
- const r = i.width === t || i.maxWidth === t, e = i.height === t || i.maxHeight === t, n = {};
20
- return r && Object.assign(n, {
21
- flexGrow: "1 !important",
22
- flexShrink: "1 !important",
23
- flexBasis: "0% !important",
24
- alignSelf: "stretch !important"
25
- // Override parent's align-items constraint
26
- }), e && Object.assign(n, {
27
- flexGrow: "1 !important",
28
- flexShrink: "1 !important",
29
- flexBasis: "0% !important",
30
- alignSelf: "stretch !important"
31
- // Override parent's align-items constraint
32
- }), {
33
- expandWidth: r,
34
- expandHeight: e,
35
- cssProps: n
36
- };
37
- }
38
- export {
39
- f as SUI,
40
- s as dimensionToCSS,
41
- t as infinity,
42
- a as infinityToFlexCSS,
43
- o as isInfinity,
44
- x as shouldExpandForInfinity
45
- };
46
- //# sourceMappingURL=layout.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"layout.js","sources":["../../src/constants/layout.ts"],"sourcesContent":["/**\n * TachUI Layout Constants\n *\n * Provides SwiftUI-style constants for layout and sizing operations.\n * Enables familiar APIs like `.frame(maxWidth: infinity)` for responsive layouts.\n */\n\n/**\n * Infinity constant representing unlimited space availability\n * Equivalent to SwiftUI's .infinity for frame dimensions\n */\nexport const infinity = Symbol.for('tachui.infinity')\n\n/**\n * Type definition for the infinity constant\n */\nexport type InfinityValue = typeof infinity\n\n/**\n * Dimension type that accepts numbers, strings, or infinity\n * Used throughout the modifier system for size-related properties\n */\nexport type Dimension = number | string | InfinityValue\n\n/**\n * SUI-compatible export object (SUI = SwiftUI-inspired)\n * Allows usage like: import { SUI } from '@tachui/core'; SUI.infinity\n */\nexport const SUI = {\n infinity: infinity\n} as const\n\n/**\n * Helper function to check if a value is the infinity constant\n */\nexport function isInfinity(value: any): value is InfinityValue {\n return value === infinity\n}\n\n/**\n * Convert a Dimension value to appropriate CSS value\n * \n * @param value - The dimension value to convert\n * @returns CSS-compatible string or undefined\n */\nexport function dimensionToCSS(value: Dimension | undefined): string | undefined {\n if (value === undefined) {\n return undefined\n }\n \n if (value === infinity) {\n return '100%'\n }\n \n if (typeof value === 'number') {\n return `${value}px`\n }\n \n // String values are passed through as-is (allows for custom units)\n return value\n}\n\n/**\n * Convert infinity to flexbox properties for proper expansion\n * Used when width/height is set to infinity to ensure proper flex behavior\n */\nexport function infinityToFlexCSS(): Record<string, string> {\n return {\n flexGrow: '1',\n flexShrink: '1',\n flexBasis: '0%'\n }\n}\n\n/**\n * Helper to determine if a frame constraint should expand to fill\n * Takes precedence of constraints into account\n */\nexport function shouldExpandForInfinity(options: {\n width?: Dimension\n height?: Dimension\n maxWidth?: Dimension\n maxHeight?: Dimension\n minWidth?: Dimension\n minHeight?: Dimension\n}): { \n expandWidth: boolean\n expandHeight: boolean \n cssProps: Record<string, string>\n} {\n const expandWidth = options.width === infinity || options.maxWidth === infinity\n const expandHeight = options.height === infinity || options.maxHeight === infinity\n \n const cssProps: Record<string, string> = {}\n \n // Apply flex properties for infinity dimensions\n if (expandWidth) {\n Object.assign(cssProps, {\n flexGrow: '1 !important',\n flexShrink: '1 !important', \n flexBasis: '0% !important',\n alignSelf: 'stretch !important' // Override parent's align-items constraint\n })\n }\n \n if (expandHeight) {\n Object.assign(cssProps, {\n flexGrow: '1 !important',\n flexShrink: '1 !important',\n flexBasis: '0% !important',\n alignSelf: 'stretch !important' // Override parent's align-items constraint\n })\n }\n \n return {\n expandWidth,\n expandHeight,\n cssProps\n }\n}"],"names":["infinity","SUI","isInfinity","value","dimensionToCSS","infinityToFlexCSS","shouldExpandForInfinity","options","expandWidth","expandHeight","cssProps"],"mappings":"AAWO,MAAMA,IAAW,OAAO,IAAI,iBAAiB,GAiBvCC,IAAM;AAAA,EACjB,UAAAD;AACF;AAKO,SAASE,EAAWC,GAAoC;AAC7D,SAAOA,MAAUH;AACnB;AAQO,SAASI,EAAeD,GAAkD;AAC/E,MAAIA,MAAU;AAId,WAAIA,MAAUH,IACL,SAGL,OAAOG,KAAU,WACZ,GAAGA,CAAK,OAIVA;AACT;AAMO,SAASE,IAA4C;AAC1D,SAAO;AAAA,IACL,UAAU;AAAA,IACV,YAAY;AAAA,IACZ,WAAW;AAAA,EAAA;AAEf;AAMO,SAASC,EAAwBC,GAWtC;AACA,QAAMC,IAAcD,EAAQ,UAAUP,KAAYO,EAAQ,aAAaP,GACjES,IAAeF,EAAQ,WAAWP,KAAYO,EAAQ,cAAcP,GAEpEU,IAAmC,CAAA;AAGzC,SAAIF,KACF,OAAO,OAAOE,GAAU;AAAA,IACtB,UAAU;AAAA,IACV,YAAY;AAAA,IACZ,WAAW;AAAA,IACX,WAAW;AAAA;AAAA,EAAA,CACZ,GAGCD,KACF,OAAO,OAAOC,GAAU;AAAA,IACtB,UAAU;AAAA,IACV,YAAY;AAAA,IACZ,WAAW;AAAA,IACX,WAAW;AAAA;AAAA,EAAA,CACZ,GAGI;AAAA,IACL,aAAAF;AAAA,IACA,cAAAC;AAAA,IACA,UAAAC;AAAA,EAAA;AAEJ;"}
@@ -1,2 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});require("../reactive/cleanup.cjs");const a=require("../reactive/computed.cjs");require("../reactive/unified-scheduler.cjs");const i=require("../reactive/signal.cjs");require("../reactive/scheduler.cjs");require("../reactive/theme.cjs");const o=require("./css-class-manager.cjs");var l=Object.defineProperty,C=(r,s,e)=>s in r?l(r,s,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[s]=e,u=(r,s,e)=>C(r,s+"",e);class g{constructor(){u(this,"cssClassManager",o.cssClassManager)}processComponentClasses(s,e=[]){if(!s.css)return e;const n=this.cssClassManager.processClasses(s.css);return this.cssClassManager.combineClasses(e,n)}createClassString(s,e=[]){return s.css&&(i.isSignal(s.css)||a.isComputed(s.css))?a.createComputed(()=>this.processComponentClasses(s,e).join(" ")):this.processComponentClasses(s,e).join(" ")}createClassArray(s,e=[]){return s.css&&i.isSignal(s.css)?a.createComputed(()=>this.processComponentClasses(s,e)):this.processComponentClasses(s,e)}validateCSSClasses(s){if(process.env.NODE_ENV!=="development"||!s.css)return;const e=s.css;if(typeof e=="string"||Array.isArray(e)||i.isSignal(e)||console.warn("[tachUI] css must be a string, array of strings, or signal. Got:",typeof e),Array.isArray(e)){const t=e.filter(c=>typeof c!="string");t.length>0&&console.warn("[tachUI] All items in css array must be strings. Invalid items:",t)}}getClassDebugInfo(s,e=[]){const n=s.css?this.cssClassManager.processClasses(s.css):[],t=this.processComponentClasses(s,e);return{base:e,user:n,processed:t,final:t.join(" ")}}}exports.ComponentWithCSSClasses=g;
2
- //# sourceMappingURL=component-base.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"component-base.cjs","sources":["../../src/css-classes/component-base.ts"],"sourcesContent":["/**\n * CSS Classes Enhancement - Component Base\n * \n * Base class for components that support CSS class integration.\n * Provides utilities for processing and applying CSS classes.\n */\n\nimport { createComputed, isSignal, isComputed } from '../reactive'\nimport type { Signal } from '../reactive/types'\nimport { cssClassManager } from './css-class-manager'\nimport type { CSSClassesProps } from './types'\n\n/**\n * Base class for components with CSS class support\n */\nexport abstract class ComponentWithCSSClasses {\n protected cssClassManager = cssClassManager\n\n /**\n * Process CSS classes from props and integrate with component classes\n */\n protected processComponentClasses(\n props: CSSClassesProps, \n baseClasses: string[] = []\n ): string[] {\n if (!props.css) {\n return baseClasses\n }\n\n const userClasses = this.cssClassManager.processClasses(props.css)\n return this.cssClassManager.combineClasses(baseClasses, userClasses)\n }\n\n /**\n * Create class string for DOM nodes - handles both static and reactive classes\n */\n protected createClassString(\n props: CSSClassesProps,\n baseClasses: string[] = []\n ): Signal<string> | string {\n // If css is reactive, create reactive class string\n if (props.css && (isSignal(props.css) || isComputed(props.css))) {\n return createComputed(() => {\n const processedClasses = this.processComponentClasses(props, baseClasses)\n return processedClasses.join(' ')\n })\n }\n\n // Static class processing\n const processedClasses = this.processComponentClasses(props, baseClasses)\n return processedClasses.join(' ')\n }\n\n /**\n * Create class array for components that need array format\n */\n protected createClassArray(\n props: CSSClassesProps,\n baseClasses: string[] = []\n ): Signal<string[]> | string[] {\n // If css is reactive, create reactive class array\n if (props.css && isSignal(props.css)) {\n return createComputed(() => {\n return this.processComponentClasses(props, baseClasses)\n })\n }\n\n // Static class processing\n return this.processComponentClasses(props, baseClasses)\n }\n\n /**\n * Validate CSS classes for development warnings\n */\n protected validateCSSClasses(props: CSSClassesProps): void {\n if (process.env.NODE_ENV !== 'development' || !props.css) {\n return\n }\n\n // Validate that css is the right type\n const classes = props.css\n const isValidType = typeof classes === 'string' || \n Array.isArray(classes) || \n isSignal(classes)\n\n if (!isValidType) {\n console.warn('[tachUI] css must be a string, array of strings, or signal. Got:', typeof classes)\n }\n\n // Validate array contents if it's an array\n if (Array.isArray(classes)) {\n const invalidItems = classes.filter(item => typeof item !== 'string')\n if (invalidItems.length > 0) {\n console.warn('[tachUI] All items in css array must be strings. Invalid items:', invalidItems)\n }\n }\n }\n\n /**\n * Get debug information about processed classes\n */\n protected getClassDebugInfo(\n props: CSSClassesProps,\n baseClasses: string[] = []\n ): { base: string[], user: string[], processed: string[], final: string } {\n const userClasses = props.css ? \n this.cssClassManager.processClasses(props.css) : []\n const processedClasses = this.processComponentClasses(props, baseClasses)\n \n return {\n base: baseClasses,\n user: userClasses,\n processed: processedClasses,\n final: processedClasses.join(' ')\n }\n }\n}"],"names":["ComponentWithCSSClasses","__publicField","cssClassManager","props","baseClasses","userClasses","isSignal","isComputed","createComputed","classes","invalidItems","item","processedClasses"],"mappings":"8eAeO,MAAeA,CAAwB,CAAvC,aAAA,CACLC,EAAA,KAAU,kBAAkBC,iBAAA,CAAA,CAKlB,wBACRC,EACAC,EAAwB,GACd,CACV,GAAI,CAACD,EAAM,IACT,OAAOC,EAGT,MAAMC,EAAc,KAAK,gBAAgB,eAAeF,EAAM,GAAG,EACjE,OAAO,KAAK,gBAAgB,eAAeC,EAAaC,CAAW,CACrE,CAKU,kBACRF,EACAC,EAAwB,GACC,CAEzB,OAAID,EAAM,MAAQG,EAAAA,SAASH,EAAM,GAAG,GAAKI,aAAWJ,EAAM,GAAG,GACpDK,EAAAA,eAAe,IACK,KAAK,wBAAwBL,EAAOC,CAAW,EAChD,KAAK,GAAG,CACjC,EAIsB,KAAK,wBAAwBD,EAAOC,CAAW,EAChD,KAAK,GAAG,CAClC,CAKU,iBACRD,EACAC,EAAwB,GACK,CAE7B,OAAID,EAAM,KAAOG,EAAAA,SAASH,EAAM,GAAG,EAC1BK,EAAAA,eAAe,IACb,KAAK,wBAAwBL,EAAOC,CAAW,CACvD,EAII,KAAK,wBAAwBD,EAAOC,CAAW,CACxD,CAKU,mBAAmBD,EAA8B,CACzD,GAAI,QAAQ,IAAI,WAAa,eAAiB,CAACA,EAAM,IACnD,OAIF,MAAMM,EAAUN,EAAM,IAUtB,GAToB,OAAOM,GAAY,UACpB,MAAM,QAAQA,CAAO,GACrBH,EAAAA,SAASG,CAAO,GAGjC,QAAQ,KAAK,mEAAoE,OAAOA,CAAO,EAI7F,MAAM,QAAQA,CAAO,EAAG,CAC1B,MAAMC,EAAeD,EAAQ,OAAOE,GAAQ,OAAOA,GAAS,QAAQ,EAChED,EAAa,OAAS,GACxB,QAAQ,KAAK,kEAAmEA,CAAY,CAEhG,CACF,CAKU,kBACRP,EACAC,EAAwB,GACgD,CACxE,MAAMC,EAAcF,EAAM,IACxB,KAAK,gBAAgB,eAAeA,EAAM,GAAG,EAAI,CAAA,EAC7CS,EAAmB,KAAK,wBAAwBT,EAAOC,CAAW,EAExE,MAAO,CACL,KAAMA,EACN,KAAMC,EACN,UAAWO,EACX,MAAOA,EAAiB,KAAK,GAAG,CAAA,CAEpC,CACF"}
@@ -1,62 +0,0 @@
1
- import "../reactive/cleanup.js";
2
- import { isComputed as c, createComputed as o } from "../reactive/computed.js";
3
- import "../reactive/unified-scheduler.js";
4
- import { isSignal as a } from "../reactive/signal.js";
5
- import "../reactive/scheduler.js";
6
- import "../reactive/theme.js";
7
- import { cssClassManager as l } from "./css-class-manager.js";
8
- var C = Object.defineProperty, m = (r, s, e) => s in r ? C(r, s, { enumerable: !0, configurable: !0, writable: !0, value: e }) : r[s] = e, u = (r, s, e) => m(r, s + "", e);
9
- class _ {
10
- constructor() {
11
- u(this, "cssClassManager", l);
12
- }
13
- /**
14
- * Process CSS classes from props and integrate with component classes
15
- */
16
- processComponentClasses(s, e = []) {
17
- if (!s.css)
18
- return e;
19
- const n = this.cssClassManager.processClasses(s.css);
20
- return this.cssClassManager.combineClasses(e, n);
21
- }
22
- /**
23
- * Create class string for DOM nodes - handles both static and reactive classes
24
- */
25
- createClassString(s, e = []) {
26
- return s.css && (a(s.css) || c(s.css)) ? o(() => this.processComponentClasses(s, e).join(" ")) : this.processComponentClasses(s, e).join(" ");
27
- }
28
- /**
29
- * Create class array for components that need array format
30
- */
31
- createClassArray(s, e = []) {
32
- return s.css && a(s.css) ? o(() => this.processComponentClasses(s, e)) : this.processComponentClasses(s, e);
33
- }
34
- /**
35
- * Validate CSS classes for development warnings
36
- */
37
- validateCSSClasses(s) {
38
- if (process.env.NODE_ENV !== "development" || !s.css)
39
- return;
40
- const e = s.css;
41
- if (typeof e == "string" || Array.isArray(e) || a(e) || console.warn("[tachUI] css must be a string, array of strings, or signal. Got:", typeof e), Array.isArray(e)) {
42
- const t = e.filter((i) => typeof i != "string");
43
- t.length > 0 && console.warn("[tachUI] All items in css array must be strings. Invalid items:", t);
44
- }
45
- }
46
- /**
47
- * Get debug information about processed classes
48
- */
49
- getClassDebugInfo(s, e = []) {
50
- const n = s.css ? this.cssClassManager.processClasses(s.css) : [], t = this.processComponentClasses(s, e);
51
- return {
52
- base: e,
53
- user: n,
54
- processed: t,
55
- final: t.join(" ")
56
- };
57
- }
58
- }
59
- export {
60
- _ as ComponentWithCSSClasses
61
- };
62
- //# sourceMappingURL=component-base.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"component-base.js","sources":["../../src/css-classes/component-base.ts"],"sourcesContent":["/**\n * CSS Classes Enhancement - Component Base\n * \n * Base class for components that support CSS class integration.\n * Provides utilities for processing and applying CSS classes.\n */\n\nimport { createComputed, isSignal, isComputed } from '../reactive'\nimport type { Signal } from '../reactive/types'\nimport { cssClassManager } from './css-class-manager'\nimport type { CSSClassesProps } from './types'\n\n/**\n * Base class for components with CSS class support\n */\nexport abstract class ComponentWithCSSClasses {\n protected cssClassManager = cssClassManager\n\n /**\n * Process CSS classes from props and integrate with component classes\n */\n protected processComponentClasses(\n props: CSSClassesProps, \n baseClasses: string[] = []\n ): string[] {\n if (!props.css) {\n return baseClasses\n }\n\n const userClasses = this.cssClassManager.processClasses(props.css)\n return this.cssClassManager.combineClasses(baseClasses, userClasses)\n }\n\n /**\n * Create class string for DOM nodes - handles both static and reactive classes\n */\n protected createClassString(\n props: CSSClassesProps,\n baseClasses: string[] = []\n ): Signal<string> | string {\n // If css is reactive, create reactive class string\n if (props.css && (isSignal(props.css) || isComputed(props.css))) {\n return createComputed(() => {\n const processedClasses = this.processComponentClasses(props, baseClasses)\n return processedClasses.join(' ')\n })\n }\n\n // Static class processing\n const processedClasses = this.processComponentClasses(props, baseClasses)\n return processedClasses.join(' ')\n }\n\n /**\n * Create class array for components that need array format\n */\n protected createClassArray(\n props: CSSClassesProps,\n baseClasses: string[] = []\n ): Signal<string[]> | string[] {\n // If css is reactive, create reactive class array\n if (props.css && isSignal(props.css)) {\n return createComputed(() => {\n return this.processComponentClasses(props, baseClasses)\n })\n }\n\n // Static class processing\n return this.processComponentClasses(props, baseClasses)\n }\n\n /**\n * Validate CSS classes for development warnings\n */\n protected validateCSSClasses(props: CSSClassesProps): void {\n if (process.env.NODE_ENV !== 'development' || !props.css) {\n return\n }\n\n // Validate that css is the right type\n const classes = props.css\n const isValidType = typeof classes === 'string' || \n Array.isArray(classes) || \n isSignal(classes)\n\n if (!isValidType) {\n console.warn('[tachUI] css must be a string, array of strings, or signal. Got:', typeof classes)\n }\n\n // Validate array contents if it's an array\n if (Array.isArray(classes)) {\n const invalidItems = classes.filter(item => typeof item !== 'string')\n if (invalidItems.length > 0) {\n console.warn('[tachUI] All items in css array must be strings. Invalid items:', invalidItems)\n }\n }\n }\n\n /**\n * Get debug information about processed classes\n */\n protected getClassDebugInfo(\n props: CSSClassesProps,\n baseClasses: string[] = []\n ): { base: string[], user: string[], processed: string[], final: string } {\n const userClasses = props.css ? \n this.cssClassManager.processClasses(props.css) : []\n const processedClasses = this.processComponentClasses(props, baseClasses)\n \n return {\n base: baseClasses,\n user: userClasses,\n processed: processedClasses,\n final: processedClasses.join(' ')\n }\n }\n}"],"names":["ComponentWithCSSClasses","__publicField","cssClassManager","props","baseClasses","userClasses","isSignal","isComputed","createComputed","classes","invalidItems","item","processedClasses"],"mappings":";;;;;;;;AAeO,MAAeA,EAAwB;AAAA,EAAvC,cAAA;AACL,IAAAC,EAAA,MAAU,mBAAkBC,CAAA;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA,EAKlB,wBACRC,GACAC,IAAwB,IACd;AACV,QAAI,CAACD,EAAM;AACT,aAAOC;AAGT,UAAMC,IAAc,KAAK,gBAAgB,eAAeF,EAAM,GAAG;AACjE,WAAO,KAAK,gBAAgB,eAAeC,GAAaC,CAAW;AAAA,EACrE;AAAA;AAAA;AAAA;AAAA,EAKU,kBACRF,GACAC,IAAwB,IACC;AAEzB,WAAID,EAAM,QAAQG,EAASH,EAAM,GAAG,KAAKI,EAAWJ,EAAM,GAAG,KACpDK,EAAe,MACK,KAAK,wBAAwBL,GAAOC,CAAW,EAChD,KAAK,GAAG,CACjC,IAIsB,KAAK,wBAAwBD,GAAOC,CAAW,EAChD,KAAK,GAAG;AAAA,EAClC;AAAA;AAAA;AAAA;AAAA,EAKU,iBACRD,GACAC,IAAwB,IACK;AAE7B,WAAID,EAAM,OAAOG,EAASH,EAAM,GAAG,IAC1BK,EAAe,MACb,KAAK,wBAAwBL,GAAOC,CAAW,CACvD,IAII,KAAK,wBAAwBD,GAAOC,CAAW;AAAA,EACxD;AAAA;AAAA;AAAA;AAAA,EAKU,mBAAmBD,GAA8B;AACzD,QAAI,QAAQ,IAAI,aAAa,iBAAiB,CAACA,EAAM;AACnD;AAIF,UAAMM,IAAUN,EAAM;AAUtB,QAToB,OAAOM,KAAY,YACpB,MAAM,QAAQA,CAAO,KACrBH,EAASG,CAAO,KAGjC,QAAQ,KAAK,oEAAoE,OAAOA,CAAO,GAI7F,MAAM,QAAQA,CAAO,GAAG;AAC1B,YAAMC,IAAeD,EAAQ,OAAO,CAAAE,MAAQ,OAAOA,KAAS,QAAQ;AACpE,MAAID,EAAa,SAAS,KACxB,QAAQ,KAAK,mEAAmEA,CAAY;AAAA,IAEhG;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKU,kBACRP,GACAC,IAAwB,IACgD;AACxE,UAAMC,IAAcF,EAAM,MACxB,KAAK,gBAAgB,eAAeA,EAAM,GAAG,IAAI,CAAA,GAC7CS,IAAmB,KAAK,wBAAwBT,GAAOC,CAAW;AAExE,WAAO;AAAA,MACL,MAAMA;AAAA,MACN,MAAMC;AAAA,MACN,WAAWO;AAAA,MACX,OAAOA,EAAiB,KAAK,GAAG;AAAA,IAAA;AAAA,EAEpC;AACF;"}
@@ -1,2 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});require("../reactive/cleanup.cjs");const f=require("../reactive/computed.cjs");require("../reactive/unified-scheduler.cjs");const C=require("../reactive/signal.cjs");require("../reactive/scheduler.cjs");require("../reactive/theme.cjs");var g=Object.defineProperty,u=(r,e,s)=>e in r?g(r,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):r[e]=s,c=(r,e,s)=>u(r,typeof e!="symbol"?e+"":e,s);const d={sanitizeClassNames:!0,sanitizationRules:{allowNumbers:!0,allowUnderscores:!0,customReplacements:{}},enableCaching:!0,maxCacheSize:1e3,warnDuplicateClasses:process.env.NODE_ENV==="development",warnInvalidClasses:process.env.NODE_ENV==="development"};class h{constructor(e={}){c(this,"config"),c(this,"classCache"),c(this,"processingCache"),this.config={...d,...e};const s=(()=>{try{return typeof Map<"u"&&typeof Map=="function"}catch{return!1}})();this.classCache=s?new Map:{},this.processingCache=s?new Map:{}}cacheHas(e,s){try{return e instanceof Map?e.has(s):s in e}catch{return s in e}}cacheGet(e,s){try{return e instanceof Map?e.get(s):e[s]}catch{return e[s]}}cacheSet(e,s,t){try{e instanceof Map?e.set(s,t):e[s]=t}catch{e[s]=t}}cacheDelete(e,s){try{e instanceof Map?e.delete(s):delete e[s]}catch{delete e[s]}}cacheClear(e){try{e instanceof Map?e.clear():Object.keys(e).forEach(s=>delete e[s])}catch{Object.keys(e).forEach(t=>delete e[t])}}cacheSize(e){try{return e instanceof Map?e.size:Object.keys(e).length}catch{return Object.keys(e).length}}cacheKeys(e){try{return e instanceof Map?e.keys():Object.keys(e)}catch{return Object.keys(e)}}processClasses(e){if(!e)return[];if(C.isSignal(e)||f.isComputed(e)){const a=e();return this.processClasses(a)}const s=this.getCacheKey(e);if(this.config.enableCaching&&this.cacheHas(this.classCache,s))return this.cacheGet(this.classCache,s);let t=[];if(typeof e=="string")t=e.trim().split(/\s+/).filter(Boolean);else if(Array.isArray(e))t=e.flatMap(a=>{if(a==null||a==="")return[];const n=(typeof a=="string"?a:String(a)).trim();return typeof a!="string"&&n?[n]:n.split(/\s+/)}).filter(Boolean);else{const a=String(e).trim();t=a?[a]:[]}const i=this.processClassArray(t);return this.config.enableCaching&&this.setCachedClasses(s,i),i}processClassArray(e){let s=e;return this.config.sanitizeClassNames&&(s=s.map(t=>this.sanitizeClassName(t))),s=this.deduplicateClasses(s),this.config.warnDuplicateClasses&&e.length!==s.length&&console.warn("[tachUI] Duplicate CSS classes detected and removed:",e.filter((t,i)=>e.indexOf(t)!==i)),s}sanitizeClassName(e){if(!e||typeof e!="string")return"";const s=this.config.sanitizationRules;let t=e.trim();t.includes(" ")&&(t=t.replace(/\s+/g,"-"),this.config.warnInvalidClasses&&console.warn(`[tachUI] CSS class names cannot contain spaces. Converted "${e}" to "${t}"`)),Object.entries(s.customReplacements||{}).forEach(([a,o])=>{t=t.replace(new RegExp(a,"g"),o)});let i="a-zA-Z\\-\\.";return s.allowNumbers&&(i+="0-9"),s.allowUnderscores&&(i+="_"),i+=":\\[\\]/%",t=t.replace(new RegExp(`[^${i}]`,"g"),"-"),/^[0-9]/.test(t)&&(t="cls-"+t),t=t.replace(/---+/g,"--"),this.config.warnInvalidClasses&&t!==e.trim()&&console.warn(`[tachUI] CSS class "${e}" sanitized to "${t}"`),t}deduplicateClasses(e){return[...new Set(e.filter(Boolean))]}combineClasses(e,s){const t=this.processClasses(s),i=[...e,...t];return this.deduplicateClasses(i)}updateConfig(e){this.config={...this.config,...e},this.clearCaches()}getConfig(){return{...this.config}}clearCaches(){this.cacheClear(this.classCache),this.cacheClear(this.processingCache)}getCacheStats(){return{size:this.cacheSize(this.classCache),maxSize:this.config.maxCacheSize,hitRate:0}}getCacheKey(e){return Array.isArray(e)?e.join("|"):e}setCachedClasses(e,s){if(this.cacheSize(this.classCache)>=this.config.maxCacheSize){const t=this.cacheKeys(this.classCache),i=Array.isArray(t)?t[0]:t.next().value;i!==void 0&&this.cacheDelete(this.classCache,i)}this.cacheSet(this.classCache,e,s)}}const l=new h;function p(r){l.updateConfig(r)}function S(){return l.getConfig()}exports.CSSClassManager=h;exports.configureCSSClasses=p;exports.cssClassManager=l;exports.getCSSClassConfig=S;
2
- //# sourceMappingURL=css-class-manager.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"css-class-manager.cjs","sources":["../../src/css-classes/css-class-manager.ts"],"sourcesContent":["/**\n * CSS Classes Enhancement - Class Manager\n *\n * Core CSS class processing system that handles sanitization,\n * deduplication, and integration with tachUI components.\n */\n\nimport { isSignal, isComputed } from '../reactive'\nimport type { Signal } from '../reactive/types'\nimport type {\n CSSClassProcessor,\n CSSClassConfig,\n ClassProcessingResult\n} from './types'\n\n/**\n * Default configuration for CSS class processing\n */\nconst DEFAULT_CONFIG: CSSClassConfig = {\n sanitizeClassNames: true,\n sanitizationRules: {\n allowNumbers: true,\n allowUnderscores: true,\n customReplacements: {}\n },\n enableCaching: true,\n maxCacheSize: 1000,\n warnDuplicateClasses: process.env.NODE_ENV === 'development',\n warnInvalidClasses: process.env.NODE_ENV === 'development'\n}\n\n/**\n * CSS Class Manager - Core processing system\n */\nexport class CSSClassManager implements CSSClassProcessor {\n private config: CSSClassConfig\n private classCache: Map<string, string[]> | { [key: string]: string[] }\n private processingCache: Map<string, ClassProcessingResult> | { [key: string]: ClassProcessingResult }\n\n constructor(config: Partial<CSSClassConfig> = {}) {\n this.config = { ...DEFAULT_CONFIG, ...config }\n\n // Initialize caches with Map if available, otherwise use plain objects\n // Use safe check for Map availability to handle all edge cases\n const mapAvailable = (() => {\n try {\n return typeof Map !== 'undefined' && typeof Map === 'function'\n } catch (_e) {\n return false\n }\n })()\n\n this.classCache = mapAvailable ? new Map() : {}\n this.processingCache = mapAvailable ? new Map() : {}\n }\n\n /**\n * Cache helper methods to work with both Map and plain object fallbacks\n */\n private cacheHas(cache: Map<string, any> | { [key: string]: any }, key: string): boolean {\n try {\n return cache instanceof Map ? cache.has(key) : key in cache\n } catch (_e) {\n // Fallback if Map check fails\n return key in cache\n }\n }\n\n private cacheGet<T>(cache: Map<string, T> | { [key: string]: T }, key: string): T | undefined {\n try {\n return cache instanceof Map ? cache.get(key) : cache[key]\n } catch (_e) {\n return (cache as { [key: string]: T })[key]\n }\n }\n\n private cacheSet<T>(cache: Map<string, T> | { [key: string]: T }, key: string, value: T): void {\n try {\n if (cache instanceof Map) {\n cache.set(key, value)\n } else {\n cache[key] = value\n }\n } catch (_e) {\n ;(cache as { [key: string]: T })[key] = value\n }\n }\n\n private cacheDelete<T>(cache: Map<string, T> | { [key: string]: T }, key: string): void {\n try {\n if (cache instanceof Map) {\n cache.delete(key)\n } else {\n delete cache[key]\n }\n } catch (_e) {\n delete (cache as { [key: string]: T })[key]\n }\n }\n\n private cacheClear<T>(cache: Map<string, T> | { [key: string]: T }): void {\n try {\n if (cache instanceof Map) {\n cache.clear()\n } else {\n Object.keys(cache).forEach(key => delete cache[key])\n }\n } catch (_e) {\n Object.keys(cache as { [key: string]: T }).forEach(key => delete (cache as { [key: string]: T })[key])\n }\n }\n\n private cacheSize<T>(cache: Map<string, T> | { [key: string]: T }): number {\n try {\n return cache instanceof Map ? cache.size : Object.keys(cache).length\n } catch (_e) {\n return Object.keys(cache).length\n }\n }\n\n private cacheKeys<T>(cache: Map<string, T> | { [key: string]: T }): IterableIterator<string> | string[] {\n try {\n return cache instanceof Map ? cache.keys() : Object.keys(cache)\n } catch (_e) {\n return Object.keys(cache)\n }\n }\n\n /**\n * Process CSS classes from various input formats\n */\n processClasses(input: string | string[] | Signal<string | string[]>): string[] {\n if (!input) return []\n\n // Handle reactive signals and computed values - no caching for dynamic values\n if (isSignal(input) || isComputed(input)) {\n const resolved = input()\n return this.processClasses(resolved)\n }\n\n // Check cache for static inputs\n const cacheKey = this.getCacheKey(input)\n if (this.config.enableCaching && this.cacheHas(this.classCache, cacheKey)) {\n return this.cacheGet(this.classCache, cacheKey)!\n }\n\n let classes: string[] = []\n\n // Handle string input - split on whitespace\n if (typeof input === 'string') {\n classes = input.trim().split(/\\s+/).filter(Boolean)\n }\n // Handle array input - flatten and filter, convert non-strings to strings\n else if (Array.isArray(input)) {\n classes = input\n .flatMap(cls => {\n if (cls === null || cls === undefined || cls === '') {\n return [] // Skip null, undefined, and empty strings\n }\n // Convert non-strings to strings\n const stringified = typeof cls === 'string' ? cls : String(cls)\n const trimmed = stringified.trim()\n\n // For non-string values that have been stringified, treat as single class name\n // to preserve object representations like \"[object Object]\"\n if (typeof cls !== 'string' && trimmed) {\n return [trimmed]\n }\n\n // For strings, split on whitespace as normal\n return trimmed.split(/\\s+/)\n })\n .filter(Boolean)\n }\n // Handle other types by converting to string (for edge case testing)\n // Treat the entire stringified value as a single class name to preserve object representations\n else {\n const stringified = String(input).trim()\n classes = stringified ? [stringified] : []\n }\n\n // Process classes through sanitization and deduplication\n const processed = this.processClassArray(classes)\n\n // Cache the result if caching is enabled\n if (this.config.enableCaching) {\n this.setCachedClasses(cacheKey, processed)\n }\n\n return processed\n }\n\n /**\n * Process an array of class names\n */\n private processClassArray(classes: string[]): string[] {\n let processed = classes\n\n // Sanitize class names if enabled\n if (this.config.sanitizeClassNames) {\n processed = processed.map(cls => this.sanitizeClassName(cls))\n }\n\n // Remove duplicates while preserving order\n processed = this.deduplicateClasses(processed)\n\n // Development warnings\n if (this.config.warnDuplicateClasses && classes.length !== processed.length) {\n console.warn('[tachUI] Duplicate CSS classes detected and removed:',\n classes.filter((cls, i) => classes.indexOf(cls) !== i))\n }\n\n return processed\n }\n\n /**\n * Sanitize class name to be valid CSS identifier\n */\n sanitizeClassName(className: string): string {\n if (!className || typeof className !== 'string') return ''\n\n const rules = this.config.sanitizationRules!\n let sanitized = className.trim()\n\n // Handle spaces in class names\n // CSS class names cannot contain spaces - convert them to hyphens to create valid single class names\n if (sanitized.includes(' ')) {\n sanitized = sanitized.replace(/\\s+/g, '-')\n if (this.config.warnInvalidClasses) {\n console.warn(`[tachUI] CSS class names cannot contain spaces. Converted \"${className}\" to \"${sanitized}\"`)\n }\n }\n\n // Apply custom replacements first\n Object.entries(rules.customReplacements || {}).forEach(([from, to]) => {\n sanitized = sanitized.replace(new RegExp(from, 'g'), to)\n })\n\n // Build character allowlist - be more permissive for modern CSS frameworks\n let allowedChars = 'a-zA-Z\\\\-\\\\.' // Basic CSS characters\n if (rules.allowNumbers) allowedChars += '0-9'\n if (rules.allowUnderscores) allowedChars += '_'\n\n // Allow modern CSS framework characters (Tailwind, CSS modules, etc.)\n // : for pseudo-classes (hover:bg-blue-500)\n // [ ] for arbitrary values ([10px])\n // / for opacity modifiers (bg-black/50)\n // % for percentages\n allowedChars += ':\\\\[\\\\]/%'\n\n // Only replace characters that are truly invalid in CSS class names\n // Keep most characters as-is since modern CSS frameworks use many special chars\n sanitized = sanitized.replace(new RegExp(`[^${allowedChars}]`, 'g'), '-')\n\n // Ensure doesn't start with number (invalid CSS)\n if (/^[0-9]/.test(sanitized)) {\n sanitized = 'cls-' + sanitized\n }\n\n // Collapse excessive hyphens (3 or more) but preserve CSS custom property prefixes (--)\n sanitized = sanitized.replace(/---+/g, '--')\n\n // Keep leading/trailing hyphens - they are valid in CSS class names\n // Only remove if they result from excessive collapsing (e.g., \"---\" became \"--\" then \"-\" at edges)\n\n // Keep original case - many frameworks use camelCase and mixed case\n // Do not convert to lowercase to preserve modern CSS framework conventions\n\n // Warn about invalid classes in development\n if (this.config.warnInvalidClasses && sanitized !== className.trim()) {\n console.warn(`[tachUI] CSS class \"${className}\" sanitized to \"${sanitized}\"`)\n }\n\n return sanitized\n }\n\n /**\n * Deduplicate classes while preserving first occurrence order\n */\n deduplicateClasses(classes: string[]): string[] {\n return [...new Set(classes.filter(Boolean))]\n }\n\n /**\n * Combine tachUI classes with user-provided CSS classes\n * User classes come AFTER tachUI classes for proper CSS cascade\n */\n combineClasses(tachuiClasses: string[], userClasses: string[]): string[] {\n const processedUserClasses = this.processClasses(userClasses)\n const combined = [...tachuiClasses, ...processedUserClasses]\n return this.deduplicateClasses(combined)\n }\n\n /**\n * Update configuration\n */\n updateConfig(config: Partial<CSSClassConfig>): void {\n this.config = { ...this.config, ...config }\n\n // Clear caches when config changes\n this.clearCaches()\n }\n\n /**\n * Get current configuration\n */\n getConfig(): CSSClassConfig {\n return { ...this.config }\n }\n\n /**\n * Clear all caches\n */\n clearCaches(): void {\n this.cacheClear(this.classCache)\n this.cacheClear(this.processingCache)\n }\n\n /**\n * Get cache statistics for debugging\n */\n getCacheStats(): { size: number; maxSize: number; hitRate: number } {\n return {\n size: this.cacheSize(this.classCache),\n maxSize: this.config.maxCacheSize,\n hitRate: 0 // TODO: Implement hit rate tracking if needed\n }\n }\n\n /**\n * Generate cache key for input\n */\n private getCacheKey(input: string | string[]): string {\n return Array.isArray(input) ? input.join('|') : input\n }\n\n /**\n * Set cached classes with LRU eviction\n */\n private setCachedClasses(key: string, classes: string[]): void {\n // Implement LRU cache eviction\n if (this.cacheSize(this.classCache) >= this.config.maxCacheSize) {\n const keys = this.cacheKeys(this.classCache)\n // const firstKey = keys instanceof Array ? keys[0] : keys.next().value\n const firstKey = Array.isArray(keys) ? keys[0] : keys.next().value\n if (firstKey !== undefined) {\n this.cacheDelete(this.classCache, firstKey)\n }\n }\n\n this.cacheSet(this.classCache, key, classes)\n }\n}\n\n/**\n * Global CSS class manager instance\n */\nexport const cssClassManager = new CSSClassManager()\n\n/**\n * Configure global CSS class processing\n */\nexport function configureCSSClasses(config: Partial<CSSClassConfig>): void {\n cssClassManager.updateConfig(config)\n}\n\n/**\n * Get current CSS class configuration\n */\nexport function getCSSClassConfig(): CSSClassConfig {\n return cssClassManager.getConfig()\n}\n"],"names":["DEFAULT_CONFIG","CSSClassManager","config","__publicField","mapAvailable","cache","key","value","input","isSignal","isComputed","resolved","cacheKey","classes","cls","trimmed","stringified","processed","className","rules","sanitized","from","to","allowedChars","tachuiClasses","userClasses","processedUserClasses","combined","keys","firstKey","cssClassManager","configureCSSClasses","getCSSClassConfig"],"mappings":"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"}
@@ -1,209 +0,0 @@
1
- import "../reactive/cleanup.js";
2
- import { isComputed as h } from "../reactive/computed.js";
3
- import "../reactive/unified-scheduler.js";
4
- import { isSignal as f } from "../reactive/signal.js";
5
- import "../reactive/scheduler.js";
6
- import "../reactive/theme.js";
7
- var C = Object.defineProperty, g = (r, e, s) => e in r ? C(r, e, { enumerable: !0, configurable: !0, writable: !0, value: s }) : r[e] = s, c = (r, e, s) => g(r, typeof e != "symbol" ? e + "" : e, s);
8
- const p = {
9
- sanitizeClassNames: !0,
10
- sanitizationRules: {
11
- allowNumbers: !0,
12
- allowUnderscores: !0,
13
- customReplacements: {}
14
- },
15
- enableCaching: !0,
16
- maxCacheSize: 1e3,
17
- warnDuplicateClasses: process.env.NODE_ENV === "development",
18
- warnInvalidClasses: process.env.NODE_ENV === "development"
19
- };
20
- class d {
21
- constructor(e = {}) {
22
- c(this, "config"), c(this, "classCache"), c(this, "processingCache"), this.config = { ...p, ...e };
23
- const s = (() => {
24
- try {
25
- return typeof Map < "u" && typeof Map == "function";
26
- } catch {
27
- return !1;
28
- }
29
- })();
30
- this.classCache = s ? /* @__PURE__ */ new Map() : {}, this.processingCache = s ? /* @__PURE__ */ new Map() : {};
31
- }
32
- /**
33
- * Cache helper methods to work with both Map and plain object fallbacks
34
- */
35
- cacheHas(e, s) {
36
- try {
37
- return e instanceof Map ? e.has(s) : s in e;
38
- } catch {
39
- return s in e;
40
- }
41
- }
42
- cacheGet(e, s) {
43
- try {
44
- return e instanceof Map ? e.get(s) : e[s];
45
- } catch {
46
- return e[s];
47
- }
48
- }
49
- cacheSet(e, s, t) {
50
- try {
51
- e instanceof Map ? e.set(s, t) : e[s] = t;
52
- } catch {
53
- e[s] = t;
54
- }
55
- }
56
- cacheDelete(e, s) {
57
- try {
58
- e instanceof Map ? e.delete(s) : delete e[s];
59
- } catch {
60
- delete e[s];
61
- }
62
- }
63
- cacheClear(e) {
64
- try {
65
- e instanceof Map ? e.clear() : Object.keys(e).forEach((s) => delete e[s]);
66
- } catch {
67
- Object.keys(e).forEach((t) => delete e[t]);
68
- }
69
- }
70
- cacheSize(e) {
71
- try {
72
- return e instanceof Map ? e.size : Object.keys(e).length;
73
- } catch {
74
- return Object.keys(e).length;
75
- }
76
- }
77
- cacheKeys(e) {
78
- try {
79
- return e instanceof Map ? e.keys() : Object.keys(e);
80
- } catch {
81
- return Object.keys(e);
82
- }
83
- }
84
- /**
85
- * Process CSS classes from various input formats
86
- */
87
- processClasses(e) {
88
- if (!e) return [];
89
- if (f(e) || h(e)) {
90
- const a = e();
91
- return this.processClasses(a);
92
- }
93
- const s = this.getCacheKey(e);
94
- if (this.config.enableCaching && this.cacheHas(this.classCache, s))
95
- return this.cacheGet(this.classCache, s);
96
- let t = [];
97
- if (typeof e == "string")
98
- t = e.trim().split(/\s+/).filter(Boolean);
99
- else if (Array.isArray(e))
100
- t = e.flatMap((a) => {
101
- if (a == null || a === "")
102
- return [];
103
- const n = (typeof a == "string" ? a : String(a)).trim();
104
- return typeof a != "string" && n ? [n] : n.split(/\s+/);
105
- }).filter(Boolean);
106
- else {
107
- const a = String(e).trim();
108
- t = a ? [a] : [];
109
- }
110
- const i = this.processClassArray(t);
111
- return this.config.enableCaching && this.setCachedClasses(s, i), i;
112
- }
113
- /**
114
- * Process an array of class names
115
- */
116
- processClassArray(e) {
117
- let s = e;
118
- return this.config.sanitizeClassNames && (s = s.map((t) => this.sanitizeClassName(t))), s = this.deduplicateClasses(s), this.config.warnDuplicateClasses && e.length !== s.length && console.warn(
119
- "[tachUI] Duplicate CSS classes detected and removed:",
120
- e.filter((t, i) => e.indexOf(t) !== i)
121
- ), s;
122
- }
123
- /**
124
- * Sanitize class name to be valid CSS identifier
125
- */
126
- sanitizeClassName(e) {
127
- if (!e || typeof e != "string") return "";
128
- const s = this.config.sanitizationRules;
129
- let t = e.trim();
130
- t.includes(" ") && (t = t.replace(/\s+/g, "-"), this.config.warnInvalidClasses && console.warn(`[tachUI] CSS class names cannot contain spaces. Converted "${e}" to "${t}"`)), Object.entries(s.customReplacements || {}).forEach(([a, o]) => {
131
- t = t.replace(new RegExp(a, "g"), o);
132
- });
133
- let i = "a-zA-Z\\-\\.";
134
- return s.allowNumbers && (i += "0-9"), s.allowUnderscores && (i += "_"), i += ":\\[\\]/%", t = t.replace(new RegExp(`[^${i}]`, "g"), "-"), /^[0-9]/.test(t) && (t = "cls-" + t), t = t.replace(/---+/g, "--"), this.config.warnInvalidClasses && t !== e.trim() && console.warn(`[tachUI] CSS class "${e}" sanitized to "${t}"`), t;
135
- }
136
- /**
137
- * Deduplicate classes while preserving first occurrence order
138
- */
139
- deduplicateClasses(e) {
140
- return [...new Set(e.filter(Boolean))];
141
- }
142
- /**
143
- * Combine tachUI classes with user-provided CSS classes
144
- * User classes come AFTER tachUI classes for proper CSS cascade
145
- */
146
- combineClasses(e, s) {
147
- const t = this.processClasses(s), i = [...e, ...t];
148
- return this.deduplicateClasses(i);
149
- }
150
- /**
151
- * Update configuration
152
- */
153
- updateConfig(e) {
154
- this.config = { ...this.config, ...e }, this.clearCaches();
155
- }
156
- /**
157
- * Get current configuration
158
- */
159
- getConfig() {
160
- return { ...this.config };
161
- }
162
- /**
163
- * Clear all caches
164
- */
165
- clearCaches() {
166
- this.cacheClear(this.classCache), this.cacheClear(this.processingCache);
167
- }
168
- /**
169
- * Get cache statistics for debugging
170
- */
171
- getCacheStats() {
172
- return {
173
- size: this.cacheSize(this.classCache),
174
- maxSize: this.config.maxCacheSize,
175
- hitRate: 0
176
- // TODO: Implement hit rate tracking if needed
177
- };
178
- }
179
- /**
180
- * Generate cache key for input
181
- */
182
- getCacheKey(e) {
183
- return Array.isArray(e) ? e.join("|") : e;
184
- }
185
- /**
186
- * Set cached classes with LRU eviction
187
- */
188
- setCachedClasses(e, s) {
189
- if (this.cacheSize(this.classCache) >= this.config.maxCacheSize) {
190
- const t = this.cacheKeys(this.classCache), i = Array.isArray(t) ? t[0] : t.next().value;
191
- i !== void 0 && this.cacheDelete(this.classCache, i);
192
- }
193
- this.cacheSet(this.classCache, e, s);
194
- }
195
- }
196
- const l = new d();
197
- function z(r) {
198
- l.updateConfig(r);
199
- }
200
- function _() {
201
- return l.getConfig();
202
- }
203
- export {
204
- d as CSSClassManager,
205
- z as configureCSSClasses,
206
- l as cssClassManager,
207
- _ as getCSSClassConfig
208
- };
209
- //# sourceMappingURL=css-class-manager.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"css-class-manager.js","sources":["../../src/css-classes/css-class-manager.ts"],"sourcesContent":["/**\n * CSS Classes Enhancement - Class Manager\n *\n * Core CSS class processing system that handles sanitization,\n * deduplication, and integration with tachUI components.\n */\n\nimport { isSignal, isComputed } from '../reactive'\nimport type { Signal } from '../reactive/types'\nimport type {\n CSSClassProcessor,\n CSSClassConfig,\n ClassProcessingResult\n} from './types'\n\n/**\n * Default configuration for CSS class processing\n */\nconst DEFAULT_CONFIG: CSSClassConfig = {\n sanitizeClassNames: true,\n sanitizationRules: {\n allowNumbers: true,\n allowUnderscores: true,\n customReplacements: {}\n },\n enableCaching: true,\n maxCacheSize: 1000,\n warnDuplicateClasses: process.env.NODE_ENV === 'development',\n warnInvalidClasses: process.env.NODE_ENV === 'development'\n}\n\n/**\n * CSS Class Manager - Core processing system\n */\nexport class CSSClassManager implements CSSClassProcessor {\n private config: CSSClassConfig\n private classCache: Map<string, string[]> | { [key: string]: string[] }\n private processingCache: Map<string, ClassProcessingResult> | { [key: string]: ClassProcessingResult }\n\n constructor(config: Partial<CSSClassConfig> = {}) {\n this.config = { ...DEFAULT_CONFIG, ...config }\n\n // Initialize caches with Map if available, otherwise use plain objects\n // Use safe check for Map availability to handle all edge cases\n const mapAvailable = (() => {\n try {\n return typeof Map !== 'undefined' && typeof Map === 'function'\n } catch (_e) {\n return false\n }\n })()\n\n this.classCache = mapAvailable ? new Map() : {}\n this.processingCache = mapAvailable ? new Map() : {}\n }\n\n /**\n * Cache helper methods to work with both Map and plain object fallbacks\n */\n private cacheHas(cache: Map<string, any> | { [key: string]: any }, key: string): boolean {\n try {\n return cache instanceof Map ? cache.has(key) : key in cache\n } catch (_e) {\n // Fallback if Map check fails\n return key in cache\n }\n }\n\n private cacheGet<T>(cache: Map<string, T> | { [key: string]: T }, key: string): T | undefined {\n try {\n return cache instanceof Map ? cache.get(key) : cache[key]\n } catch (_e) {\n return (cache as { [key: string]: T })[key]\n }\n }\n\n private cacheSet<T>(cache: Map<string, T> | { [key: string]: T }, key: string, value: T): void {\n try {\n if (cache instanceof Map) {\n cache.set(key, value)\n } else {\n cache[key] = value\n }\n } catch (_e) {\n ;(cache as { [key: string]: T })[key] = value\n }\n }\n\n private cacheDelete<T>(cache: Map<string, T> | { [key: string]: T }, key: string): void {\n try {\n if (cache instanceof Map) {\n cache.delete(key)\n } else {\n delete cache[key]\n }\n } catch (_e) {\n delete (cache as { [key: string]: T })[key]\n }\n }\n\n private cacheClear<T>(cache: Map<string, T> | { [key: string]: T }): void {\n try {\n if (cache instanceof Map) {\n cache.clear()\n } else {\n Object.keys(cache).forEach(key => delete cache[key])\n }\n } catch (_e) {\n Object.keys(cache as { [key: string]: T }).forEach(key => delete (cache as { [key: string]: T })[key])\n }\n }\n\n private cacheSize<T>(cache: Map<string, T> | { [key: string]: T }): number {\n try {\n return cache instanceof Map ? cache.size : Object.keys(cache).length\n } catch (_e) {\n return Object.keys(cache).length\n }\n }\n\n private cacheKeys<T>(cache: Map<string, T> | { [key: string]: T }): IterableIterator<string> | string[] {\n try {\n return cache instanceof Map ? cache.keys() : Object.keys(cache)\n } catch (_e) {\n return Object.keys(cache)\n }\n }\n\n /**\n * Process CSS classes from various input formats\n */\n processClasses(input: string | string[] | Signal<string | string[]>): string[] {\n if (!input) return []\n\n // Handle reactive signals and computed values - no caching for dynamic values\n if (isSignal(input) || isComputed(input)) {\n const resolved = input()\n return this.processClasses(resolved)\n }\n\n // Check cache for static inputs\n const cacheKey = this.getCacheKey(input)\n if (this.config.enableCaching && this.cacheHas(this.classCache, cacheKey)) {\n return this.cacheGet(this.classCache, cacheKey)!\n }\n\n let classes: string[] = []\n\n // Handle string input - split on whitespace\n if (typeof input === 'string') {\n classes = input.trim().split(/\\s+/).filter(Boolean)\n }\n // Handle array input - flatten and filter, convert non-strings to strings\n else if (Array.isArray(input)) {\n classes = input\n .flatMap(cls => {\n if (cls === null || cls === undefined || cls === '') {\n return [] // Skip null, undefined, and empty strings\n }\n // Convert non-strings to strings\n const stringified = typeof cls === 'string' ? cls : String(cls)\n const trimmed = stringified.trim()\n\n // For non-string values that have been stringified, treat as single class name\n // to preserve object representations like \"[object Object]\"\n if (typeof cls !== 'string' && trimmed) {\n return [trimmed]\n }\n\n // For strings, split on whitespace as normal\n return trimmed.split(/\\s+/)\n })\n .filter(Boolean)\n }\n // Handle other types by converting to string (for edge case testing)\n // Treat the entire stringified value as a single class name to preserve object representations\n else {\n const stringified = String(input).trim()\n classes = stringified ? [stringified] : []\n }\n\n // Process classes through sanitization and deduplication\n const processed = this.processClassArray(classes)\n\n // Cache the result if caching is enabled\n if (this.config.enableCaching) {\n this.setCachedClasses(cacheKey, processed)\n }\n\n return processed\n }\n\n /**\n * Process an array of class names\n */\n private processClassArray(classes: string[]): string[] {\n let processed = classes\n\n // Sanitize class names if enabled\n if (this.config.sanitizeClassNames) {\n processed = processed.map(cls => this.sanitizeClassName(cls))\n }\n\n // Remove duplicates while preserving order\n processed = this.deduplicateClasses(processed)\n\n // Development warnings\n if (this.config.warnDuplicateClasses && classes.length !== processed.length) {\n console.warn('[tachUI] Duplicate CSS classes detected and removed:',\n classes.filter((cls, i) => classes.indexOf(cls) !== i))\n }\n\n return processed\n }\n\n /**\n * Sanitize class name to be valid CSS identifier\n */\n sanitizeClassName(className: string): string {\n if (!className || typeof className !== 'string') return ''\n\n const rules = this.config.sanitizationRules!\n let sanitized = className.trim()\n\n // Handle spaces in class names\n // CSS class names cannot contain spaces - convert them to hyphens to create valid single class names\n if (sanitized.includes(' ')) {\n sanitized = sanitized.replace(/\\s+/g, '-')\n if (this.config.warnInvalidClasses) {\n console.warn(`[tachUI] CSS class names cannot contain spaces. Converted \"${className}\" to \"${sanitized}\"`)\n }\n }\n\n // Apply custom replacements first\n Object.entries(rules.customReplacements || {}).forEach(([from, to]) => {\n sanitized = sanitized.replace(new RegExp(from, 'g'), to)\n })\n\n // Build character allowlist - be more permissive for modern CSS frameworks\n let allowedChars = 'a-zA-Z\\\\-\\\\.' // Basic CSS characters\n if (rules.allowNumbers) allowedChars += '0-9'\n if (rules.allowUnderscores) allowedChars += '_'\n\n // Allow modern CSS framework characters (Tailwind, CSS modules, etc.)\n // : for pseudo-classes (hover:bg-blue-500)\n // [ ] for arbitrary values ([10px])\n // / for opacity modifiers (bg-black/50)\n // % for percentages\n allowedChars += ':\\\\[\\\\]/%'\n\n // Only replace characters that are truly invalid in CSS class names\n // Keep most characters as-is since modern CSS frameworks use many special chars\n sanitized = sanitized.replace(new RegExp(`[^${allowedChars}]`, 'g'), '-')\n\n // Ensure doesn't start with number (invalid CSS)\n if (/^[0-9]/.test(sanitized)) {\n sanitized = 'cls-' + sanitized\n }\n\n // Collapse excessive hyphens (3 or more) but preserve CSS custom property prefixes (--)\n sanitized = sanitized.replace(/---+/g, '--')\n\n // Keep leading/trailing hyphens - they are valid in CSS class names\n // Only remove if they result from excessive collapsing (e.g., \"---\" became \"--\" then \"-\" at edges)\n\n // Keep original case - many frameworks use camelCase and mixed case\n // Do not convert to lowercase to preserve modern CSS framework conventions\n\n // Warn about invalid classes in development\n if (this.config.warnInvalidClasses && sanitized !== className.trim()) {\n console.warn(`[tachUI] CSS class \"${className}\" sanitized to \"${sanitized}\"`)\n }\n\n return sanitized\n }\n\n /**\n * Deduplicate classes while preserving first occurrence order\n */\n deduplicateClasses(classes: string[]): string[] {\n return [...new Set(classes.filter(Boolean))]\n }\n\n /**\n * Combine tachUI classes with user-provided CSS classes\n * User classes come AFTER tachUI classes for proper CSS cascade\n */\n combineClasses(tachuiClasses: string[], userClasses: string[]): string[] {\n const processedUserClasses = this.processClasses(userClasses)\n const combined = [...tachuiClasses, ...processedUserClasses]\n return this.deduplicateClasses(combined)\n }\n\n /**\n * Update configuration\n */\n updateConfig(config: Partial<CSSClassConfig>): void {\n this.config = { ...this.config, ...config }\n\n // Clear caches when config changes\n this.clearCaches()\n }\n\n /**\n * Get current configuration\n */\n getConfig(): CSSClassConfig {\n return { ...this.config }\n }\n\n /**\n * Clear all caches\n */\n clearCaches(): void {\n this.cacheClear(this.classCache)\n this.cacheClear(this.processingCache)\n }\n\n /**\n * Get cache statistics for debugging\n */\n getCacheStats(): { size: number; maxSize: number; hitRate: number } {\n return {\n size: this.cacheSize(this.classCache),\n maxSize: this.config.maxCacheSize,\n hitRate: 0 // TODO: Implement hit rate tracking if needed\n }\n }\n\n /**\n * Generate cache key for input\n */\n private getCacheKey(input: string | string[]): string {\n return Array.isArray(input) ? input.join('|') : input\n }\n\n /**\n * Set cached classes with LRU eviction\n */\n private setCachedClasses(key: string, classes: string[]): void {\n // Implement LRU cache eviction\n if (this.cacheSize(this.classCache) >= this.config.maxCacheSize) {\n const keys = this.cacheKeys(this.classCache)\n // const firstKey = keys instanceof Array ? keys[0] : keys.next().value\n const firstKey = Array.isArray(keys) ? keys[0] : keys.next().value\n if (firstKey !== undefined) {\n this.cacheDelete(this.classCache, firstKey)\n }\n }\n\n this.cacheSet(this.classCache, key, classes)\n }\n}\n\n/**\n * Global CSS class manager instance\n */\nexport const cssClassManager = new CSSClassManager()\n\n/**\n * Configure global CSS class processing\n */\nexport function configureCSSClasses(config: Partial<CSSClassConfig>): void {\n cssClassManager.updateConfig(config)\n}\n\n/**\n * Get current CSS class configuration\n */\nexport function getCSSClassConfig(): CSSClassConfig {\n return cssClassManager.getConfig()\n}\n"],"names":["DEFAULT_CONFIG","CSSClassManager","config","__publicField","mapAvailable","cache","key","value","input","isSignal","isComputed","resolved","cacheKey","classes","cls","trimmed","stringified","processed","className","rules","sanitized","from","to","allowedChars","tachuiClasses","userClasses","processedUserClasses","combined","keys","firstKey","cssClassManager","configureCSSClasses","getCSSClassConfig"],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});class i{applyCSSClasses(e,s){if(!s)return;const t=(Array.isArray(s)?s:[s]).filter(Boolean);t.length>0&&(e.className=t.join(" "))}applyReactiveCSSClasses(e,s){const a=require("../reactive").createEffect;return a(()=>{const r=s();e.className=r})}updateCSSClasses(e,s){this.applyCSSClasses(e,s)}removeCSSClasses(e,s){if(!s)return;const a=Array.isArray(s)?s:[s],r=e.className.split(" ").filter(l=>!a.includes(l));e.className=r.join(" ")}mergeCSSClasses(e,s){if(!s)return;const a=Array.isArray(s)?s:[s],r=[...e.className?e.className.split(" "):[],...a.filter(Boolean)],l=[...new Set(r)];e.className=l.join(" ")}}const o=new i;function n(c,e={},s=[],a){const r={...{type:"element",tag:c,props:e,children:s}};return a&&(Array.isArray(a)?r.cssClasses=a:r.reactiveClasses=a),r}function C(c){return{static:c.cssClasses||[],reactive:c.reactiveClasses}}exports.DOMCSSClassApplicator=i;exports.createDOMNodeWithClasses=n;exports.domCSSClassApplicator=o;exports.extractCSSClasses=C;
2
- //# sourceMappingURL=dom-integration.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dom-integration.cjs","sources":["../../src/css-classes/dom-integration.ts"],"sourcesContent":["/**\n * CSS Classes Enhancement - DOM Integration\n * \n * Enhanced DOM node types and utilities for CSS class integration\n */\n\nimport type { Signal } from '../reactive/types'\nimport type { DOMNode } from '../runtime/types'\n\n/**\n * Enhanced DOM node with CSS class support\n */\nexport interface DOMNodeWithClasses extends DOMNode {\n cssClasses?: string[]\n reactiveClasses?: Signal<string>\n}\n\n/**\n * CSS class application utilities for DOM elements\n */\nexport interface CSSClassDOMApplicator {\n /**\n * Apply CSS classes to a DOM element\n */\n applyCSSClasses(element: Element, classes: string[] | string): void\n \n /**\n * Apply reactive CSS classes to a DOM element\n */\n applyReactiveCSSClasses(element: Element, classSignal: Signal<string>): (() => void)\n \n /**\n * Update CSS classes on an existing element\n */\n updateCSSClasses(element: Element, newClasses: string[] | string): void\n \n /**\n * Remove CSS classes from an element\n */\n removeCSSClasses(element: Element, classes: string[] | string): void\n}\n\n/**\n * DOM CSS class applicator implementation\n */\nexport class DOMCSSClassApplicator implements CSSClassDOMApplicator {\n /**\n * Apply CSS classes to a DOM element\n */\n applyCSSClasses(element: Element, classes: string[] | string): void {\n if (!classes) return\n \n const classArray = Array.isArray(classes) ? classes : [classes]\n const validClasses = classArray.filter(Boolean)\n \n if (validClasses.length > 0) {\n element.className = validClasses.join(' ')\n }\n }\n\n /**\n * Apply reactive CSS classes to a DOM element\n */\n applyReactiveCSSClasses(element: Element, classSignal: Signal<string>): (() => void) {\n // Import createEffect dynamically to avoid circular dependencies\n const createEffect = require('../reactive').createEffect\n \n // Create effect to update classes when signal changes\n const dispose = createEffect(() => {\n const classString = classSignal()\n element.className = classString\n })\n \n return dispose\n }\n\n /**\n * Update CSS classes on an existing element\n */\n updateCSSClasses(element: Element, newClasses: string[] | string): void {\n this.applyCSSClasses(element, newClasses)\n }\n\n /**\n * Remove CSS classes from an element\n */\n removeCSSClasses(element: Element, classes: string[] | string): void {\n if (!classes) return\n \n const classArray = Array.isArray(classes) ? classes : [classes]\n const currentClasses = element.className.split(' ')\n const filteredClasses = currentClasses.filter(cls => !classArray.includes(cls))\n \n element.className = filteredClasses.join(' ')\n }\n\n /**\n * Merge CSS classes with existing classes on an element\n */\n mergeCSSClasses(element: Element, newClasses: string[] | string): void {\n if (!newClasses) return\n \n const classArray = Array.isArray(newClasses) ? newClasses : [newClasses]\n const currentClasses = element.className ? element.className.split(' ') : []\n const mergedClasses = [...currentClasses, ...classArray.filter(Boolean)]\n \n // Deduplicate classes\n const uniqueClasses = [...new Set(mergedClasses)]\n element.className = uniqueClasses.join(' ')\n }\n}\n\n/**\n * Global DOM CSS class applicator instance\n */\nexport const domCSSClassApplicator = new DOMCSSClassApplicator()\n\n/**\n * Helper function to create DOM nodes with CSS classes\n */\nexport function createDOMNodeWithClasses(\n tag: string,\n props: Record<string, any> = {},\n children: DOMNode[] = [],\n cssClasses?: string[] | Signal<string>\n): DOMNodeWithClasses {\n const baseNode: DOMNode = {\n type: 'element',\n tag,\n props,\n children\n }\n\n const enhancedNode: DOMNodeWithClasses = {\n ...baseNode\n }\n\n // Add CSS class support\n if (cssClasses) {\n if (Array.isArray(cssClasses)) {\n enhancedNode.cssClasses = cssClasses\n } else {\n // Assume it's a signal\n enhancedNode.reactiveClasses = cssClasses as Signal<string>\n }\n }\n\n return enhancedNode\n}\n\n/**\n * Utility to extract CSS classes from a DOMNodeWithClasses\n */\nexport function extractCSSClasses(node: DOMNodeWithClasses): {\n static: string[]\n reactive: Signal<string> | undefined\n} {\n return {\n static: node.cssClasses || [],\n reactive: node.reactiveClasses\n }\n}"],"names":["DOMCSSClassApplicator","element","classes","validClasses","classSignal","createEffect","classString","newClasses","classArray","filteredClasses","cls","mergedClasses","uniqueClasses","domCSSClassApplicator","createDOMNodeWithClasses","tag","props","children","cssClasses","enhancedNode","extractCSSClasses","node"],"mappings":"gFA6CO,MAAMA,CAAuD,CAIlE,gBAAgBC,EAAkBC,EAAkC,CAClE,GAAI,CAACA,EAAS,OAGd,MAAMC,GADa,MAAM,QAAQD,CAAO,EAAIA,EAAU,CAACA,CAAO,GAC9B,OAAO,OAAO,EAE1CC,EAAa,OAAS,IACxBF,EAAQ,UAAYE,EAAa,KAAK,GAAG,EAE7C,CAKA,wBAAwBF,EAAkBG,EAA2C,CAEnF,MAAMC,EAAe,QAAQ,aAAa,EAAE,aAQ5C,OALgBA,EAAa,IAAM,CACjC,MAAMC,EAAcF,EAAA,EACpBH,EAAQ,UAAYK,CACtB,CAAC,CAGH,CAKA,iBAAiBL,EAAkBM,EAAqC,CACtE,KAAK,gBAAgBN,EAASM,CAAU,CAC1C,CAKA,iBAAiBN,EAAkBC,EAAkC,CACnE,GAAI,CAACA,EAAS,OAEd,MAAMM,EAAa,MAAM,QAAQN,CAAO,EAAIA,EAAU,CAACA,CAAO,EAExDO,EADiBR,EAAQ,UAAU,MAAM,GAAG,EACX,OAAOS,GAAO,CAACF,EAAW,SAASE,CAAG,CAAC,EAE9ET,EAAQ,UAAYQ,EAAgB,KAAK,GAAG,CAC9C,CAKA,gBAAgBR,EAAkBM,EAAqC,CACrE,GAAI,CAACA,EAAY,OAEjB,MAAMC,EAAa,MAAM,QAAQD,CAAU,EAAIA,EAAa,CAACA,CAAU,EAEjEI,EAAgB,CAAC,GADAV,EAAQ,UAAYA,EAAQ,UAAU,MAAM,GAAG,EAAI,CAAA,EAChC,GAAGO,EAAW,OAAO,OAAO,CAAC,EAGjEI,EAAgB,CAAC,GAAG,IAAI,IAAID,CAAa,CAAC,EAChDV,EAAQ,UAAYW,EAAc,KAAK,GAAG,CAC5C,CACF,CAKO,MAAMC,EAAwB,IAAIb,EAKlC,SAASc,EACdC,EACAC,EAA6B,CAAA,EAC7BC,EAAsB,CAAA,EACtBC,EACoB,CAQpB,MAAMC,EAAmC,CACvC,GARwB,CACxB,KAAM,UACN,IAAAJ,EACA,MAAAC,EACA,SAAAC,CAAA,CAIG,EAIL,OAAIC,IACE,MAAM,QAAQA,CAAU,EAC1BC,EAAa,WAAaD,EAG1BC,EAAa,gBAAkBD,GAI5BC,CACT,CAKO,SAASC,EAAkBC,EAGhC,CACA,MAAO,CACL,OAAQA,EAAK,YAAc,CAAA,EAC3B,SAAUA,EAAK,eAAA,CAEnB"}
@@ -1,67 +0,0 @@
1
- class i {
2
- /**
3
- * Apply CSS classes to a DOM element
4
- */
5
- applyCSSClasses(e, s) {
6
- if (!s) return;
7
- const t = (Array.isArray(s) ? s : [s]).filter(Boolean);
8
- t.length > 0 && (e.className = t.join(" "));
9
- }
10
- /**
11
- * Apply reactive CSS classes to a DOM element
12
- */
13
- applyReactiveCSSClasses(e, s) {
14
- const r = require("../reactive").createEffect;
15
- return r(() => {
16
- const a = s();
17
- e.className = a;
18
- });
19
- }
20
- /**
21
- * Update CSS classes on an existing element
22
- */
23
- updateCSSClasses(e, s) {
24
- this.applyCSSClasses(e, s);
25
- }
26
- /**
27
- * Remove CSS classes from an element
28
- */
29
- removeCSSClasses(e, s) {
30
- if (!s) return;
31
- const r = Array.isArray(s) ? s : [s], a = e.className.split(" ").filter((l) => !r.includes(l));
32
- e.className = a.join(" ");
33
- }
34
- /**
35
- * Merge CSS classes with existing classes on an element
36
- */
37
- mergeCSSClasses(e, s) {
38
- if (!s) return;
39
- const r = Array.isArray(s) ? s : [s], a = [...e.className ? e.className.split(" ") : [], ...r.filter(Boolean)], l = [...new Set(a)];
40
- e.className = l.join(" ");
41
- }
42
- }
43
- const n = new i();
44
- function o(c, e = {}, s = [], r) {
45
- const a = {
46
- ...{
47
- type: "element",
48
- tag: c,
49
- props: e,
50
- children: s
51
- }
52
- };
53
- return r && (Array.isArray(r) ? a.cssClasses = r : a.reactiveClasses = r), a;
54
- }
55
- function C(c) {
56
- return {
57
- static: c.cssClasses || [],
58
- reactive: c.reactiveClasses
59
- };
60
- }
61
- export {
62
- i as DOMCSSClassApplicator,
63
- o as createDOMNodeWithClasses,
64
- n as domCSSClassApplicator,
65
- C as extractCSSClasses
66
- };
67
- //# sourceMappingURL=dom-integration.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dom-integration.js","sources":["../../src/css-classes/dom-integration.ts"],"sourcesContent":["/**\n * CSS Classes Enhancement - DOM Integration\n * \n * Enhanced DOM node types and utilities for CSS class integration\n */\n\nimport type { Signal } from '../reactive/types'\nimport type { DOMNode } from '../runtime/types'\n\n/**\n * Enhanced DOM node with CSS class support\n */\nexport interface DOMNodeWithClasses extends DOMNode {\n cssClasses?: string[]\n reactiveClasses?: Signal<string>\n}\n\n/**\n * CSS class application utilities for DOM elements\n */\nexport interface CSSClassDOMApplicator {\n /**\n * Apply CSS classes to a DOM element\n */\n applyCSSClasses(element: Element, classes: string[] | string): void\n \n /**\n * Apply reactive CSS classes to a DOM element\n */\n applyReactiveCSSClasses(element: Element, classSignal: Signal<string>): (() => void)\n \n /**\n * Update CSS classes on an existing element\n */\n updateCSSClasses(element: Element, newClasses: string[] | string): void\n \n /**\n * Remove CSS classes from an element\n */\n removeCSSClasses(element: Element, classes: string[] | string): void\n}\n\n/**\n * DOM CSS class applicator implementation\n */\nexport class DOMCSSClassApplicator implements CSSClassDOMApplicator {\n /**\n * Apply CSS classes to a DOM element\n */\n applyCSSClasses(element: Element, classes: string[] | string): void {\n if (!classes) return\n \n const classArray = Array.isArray(classes) ? classes : [classes]\n const validClasses = classArray.filter(Boolean)\n \n if (validClasses.length > 0) {\n element.className = validClasses.join(' ')\n }\n }\n\n /**\n * Apply reactive CSS classes to a DOM element\n */\n applyReactiveCSSClasses(element: Element, classSignal: Signal<string>): (() => void) {\n // Import createEffect dynamically to avoid circular dependencies\n const createEffect = require('../reactive').createEffect\n \n // Create effect to update classes when signal changes\n const dispose = createEffect(() => {\n const classString = classSignal()\n element.className = classString\n })\n \n return dispose\n }\n\n /**\n * Update CSS classes on an existing element\n */\n updateCSSClasses(element: Element, newClasses: string[] | string): void {\n this.applyCSSClasses(element, newClasses)\n }\n\n /**\n * Remove CSS classes from an element\n */\n removeCSSClasses(element: Element, classes: string[] | string): void {\n if (!classes) return\n \n const classArray = Array.isArray(classes) ? classes : [classes]\n const currentClasses = element.className.split(' ')\n const filteredClasses = currentClasses.filter(cls => !classArray.includes(cls))\n \n element.className = filteredClasses.join(' ')\n }\n\n /**\n * Merge CSS classes with existing classes on an element\n */\n mergeCSSClasses(element: Element, newClasses: string[] | string): void {\n if (!newClasses) return\n \n const classArray = Array.isArray(newClasses) ? newClasses : [newClasses]\n const currentClasses = element.className ? element.className.split(' ') : []\n const mergedClasses = [...currentClasses, ...classArray.filter(Boolean)]\n \n // Deduplicate classes\n const uniqueClasses = [...new Set(mergedClasses)]\n element.className = uniqueClasses.join(' ')\n }\n}\n\n/**\n * Global DOM CSS class applicator instance\n */\nexport const domCSSClassApplicator = new DOMCSSClassApplicator()\n\n/**\n * Helper function to create DOM nodes with CSS classes\n */\nexport function createDOMNodeWithClasses(\n tag: string,\n props: Record<string, any> = {},\n children: DOMNode[] = [],\n cssClasses?: string[] | Signal<string>\n): DOMNodeWithClasses {\n const baseNode: DOMNode = {\n type: 'element',\n tag,\n props,\n children\n }\n\n const enhancedNode: DOMNodeWithClasses = {\n ...baseNode\n }\n\n // Add CSS class support\n if (cssClasses) {\n if (Array.isArray(cssClasses)) {\n enhancedNode.cssClasses = cssClasses\n } else {\n // Assume it's a signal\n enhancedNode.reactiveClasses = cssClasses as Signal<string>\n }\n }\n\n return enhancedNode\n}\n\n/**\n * Utility to extract CSS classes from a DOMNodeWithClasses\n */\nexport function extractCSSClasses(node: DOMNodeWithClasses): {\n static: string[]\n reactive: Signal<string> | undefined\n} {\n return {\n static: node.cssClasses || [],\n reactive: node.reactiveClasses\n }\n}"],"names":["DOMCSSClassApplicator","element","classes","validClasses","classSignal","createEffect","classString","newClasses","classArray","filteredClasses","cls","mergedClasses","uniqueClasses","domCSSClassApplicator","createDOMNodeWithClasses","tag","props","children","cssClasses","enhancedNode","extractCSSClasses","node"],"mappings":"AA6CO,MAAMA,EAAuD;AAAA;AAAA;AAAA;AAAA,EAIlE,gBAAgBC,GAAkBC,GAAkC;AAClE,QAAI,CAACA,EAAS;AAGd,UAAMC,KADa,MAAM,QAAQD,CAAO,IAAIA,IAAU,CAACA,CAAO,GAC9B,OAAO,OAAO;AAE9C,IAAIC,EAAa,SAAS,MACxBF,EAAQ,YAAYE,EAAa,KAAK,GAAG;AAAA,EAE7C;AAAA;AAAA;AAAA;AAAA,EAKA,wBAAwBF,GAAkBG,GAA2C;AAEnF,UAAMC,IAAe,QAAQ,aAAa,EAAE;AAQ5C,WALgBA,EAAa,MAAM;AACjC,YAAMC,IAAcF,EAAA;AACpB,MAAAH,EAAQ,YAAYK;AAAA,IACtB,CAAC;AAAA,EAGH;AAAA;AAAA;AAAA;AAAA,EAKA,iBAAiBL,GAAkBM,GAAqC;AACtE,SAAK,gBAAgBN,GAASM,CAAU;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA,EAKA,iBAAiBN,GAAkBC,GAAkC;AACnE,QAAI,CAACA,EAAS;AAEd,UAAMM,IAAa,MAAM,QAAQN,CAAO,IAAIA,IAAU,CAACA,CAAO,GAExDO,IADiBR,EAAQ,UAAU,MAAM,GAAG,EACX,OAAO,CAAAS,MAAO,CAACF,EAAW,SAASE,CAAG,CAAC;AAE9E,IAAAT,EAAQ,YAAYQ,EAAgB,KAAK,GAAG;AAAA,EAC9C;AAAA;AAAA;AAAA;AAAA,EAKA,gBAAgBR,GAAkBM,GAAqC;AACrE,QAAI,CAACA,EAAY;AAEjB,UAAMC,IAAa,MAAM,QAAQD,CAAU,IAAIA,IAAa,CAACA,CAAU,GAEjEI,IAAgB,CAAC,GADAV,EAAQ,YAAYA,EAAQ,UAAU,MAAM,GAAG,IAAI,CAAA,GAChC,GAAGO,EAAW,OAAO,OAAO,CAAC,GAGjEI,IAAgB,CAAC,GAAG,IAAI,IAAID,CAAa,CAAC;AAChD,IAAAV,EAAQ,YAAYW,EAAc,KAAK,GAAG;AAAA,EAC5C;AACF;AAKO,MAAMC,IAAwB,IAAIb,EAAA;AAKlC,SAASc,EACdC,GACAC,IAA6B,CAAA,GAC7BC,IAAsB,CAAA,GACtBC,GACoB;AAQpB,QAAMC,IAAmC;AAAA,IACvC,GARwB;AAAA,MACxB,MAAM;AAAA,MACN,KAAAJ;AAAA,MACA,OAAAC;AAAA,MACA,UAAAC;AAAA,IAAA;AAAA,EAIG;AAIL,SAAIC,MACE,MAAM,QAAQA,CAAU,IAC1BC,EAAa,aAAaD,IAG1BC,EAAa,kBAAkBD,IAI5BC;AACT;AAKO,SAASC,EAAkBC,GAGhC;AACA,SAAO;AAAA,IACL,QAAQA,EAAK,cAAc,CAAA;AAAA,IAC3B,UAAUA,EAAK;AAAA,EAAA;AAEnB;"}
@@ -1,2 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});require("../reactive/cleanup.cjs");require("../reactive/unified-scheduler.cjs");const r=require("../reactive/effect.cjs"),n=require("../reactive/signal.cjs");require("../reactive/scheduler.cjs");require("../reactive/theme.cjs");const l={applyCSSClasses(e,s){if(s.cssClasses&&s.cssClasses.length>0){const t=s.cssClasses.join(" ");e.className=t}if(s.reactiveClasses&&n.isSignal(s.reactiveClasses)){const t=s.reactiveClasses();e.className=t,r.createEffect(()=>{const a=s.reactiveClasses();e.className=a})}},processElementClasses(e,s){let t=[];if(s.props?.className){const a=typeof s.props.className=="string"?s.props.className.split(" ").filter(Boolean):[];t.push(...a)}if(s.cssClasses&&t.push(...s.cssClasses),t.length>0){const a=[...new Set(t)];e.className=a.join(" ")}s.reactiveClasses&&n.isSignal(s.reactiveClasses)&&r.createEffect(()=>{const a=s.reactiveClasses();if(t.length>0){const i=t.join(" ");e.className=`${i} ${a}`.trim()}else e.className=a})}};function C(e){const s=e.createElement.bind(e),t=a=>{const i=s(a),c=a;return(c.cssClasses||c.reactiveClasses)&&l.processElementClasses(i,c),i};return e.createElement=t,Object.assign(e,l)}function o(e,s={},t=[],a){const i={type:"element",tag:e,props:s,children:t};return a&&(Array.isArray(a)?i.cssClasses=a:i.reactiveClasses=a),i}function S(e){const s=e;return!!(s.cssClasses||s.reactiveClasses)}exports.createCSSClassDOMNode=o;exports.cssClassRendererMixin=l;exports.enhanceRendererWithCSSClasses=C;exports.hasCSSClassSupport=S;
2
- //# sourceMappingURL=enhanced-renderer.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"enhanced-renderer.cjs","sources":["../../src/css-classes/enhanced-renderer.ts"],"sourcesContent":["/**\n * CSS Classes Enhancement - Enhanced Renderer\n * \n * Enhanced DOM renderer that supports CSS class integration\n * while maintaining compatibility with existing functionality.\n */\n\nimport { createEffect, isSignal } from '../reactive'\nimport type { Signal } from '../reactive/types'\nimport type { DOMNode } from '../runtime/types'\nimport type { DOMNodeWithClasses } from './dom-integration'\n\n/**\n * Enhanced renderer mixin for CSS class support\n * This can be mixed into the existing DirectDOMRenderer\n */\nexport interface CSSClassRendererMixin {\n /**\n * Apply CSS classes to an element during creation\n */\n applyCSSClasses(element: Element, node: DOMNodeWithClasses): void\n\n /**\n * Process className prop and CSS classes together\n */\n processElementClasses(element: Element, node: DOMNodeWithClasses): void\n}\n\n/**\n * CSS class renderer mixin implementation\n */\nexport const cssClassRendererMixin: CSSClassRendererMixin = {\n /**\n * Apply CSS classes to an element during creation\n */\n applyCSSClasses(element: Element, node: DOMNodeWithClasses): void {\n // Handle static CSS classes\n if (node.cssClasses && node.cssClasses.length > 0) {\n const classString = node.cssClasses.join(' ')\n element.className = classString\n }\n\n // Handle reactive CSS classes\n if (node.reactiveClasses) {\n if (isSignal(node.reactiveClasses)) {\n // Set initial value\n const initialClasses = node.reactiveClasses()\n element.className = initialClasses\n\n // Create reactive effect for updates\n createEffect(() => {\n const classString = node.reactiveClasses!()\n element.className = classString\n })\n }\n }\n },\n\n /**\n * Process className prop and CSS classes together\n */\n processElementClasses(element: Element, node: DOMNodeWithClasses): void {\n let finalClasses: string[] = []\n\n // Start with existing className prop if it exists\n if (node.props?.className) {\n const existingClasses = typeof node.props.className === 'string' \n ? node.props.className.split(' ').filter(Boolean)\n : []\n finalClasses.push(...existingClasses)\n }\n\n // Add CSS classes from cssClasses property\n if (node.cssClasses) {\n finalClasses.push(...node.cssClasses)\n }\n\n // Deduplicate and apply classes\n if (finalClasses.length > 0) {\n const uniqueClasses = [...new Set(finalClasses)]\n element.className = uniqueClasses.join(' ')\n }\n\n // Handle reactive classes separately (they override static classes)\n if (node.reactiveClasses && isSignal(node.reactiveClasses)) {\n createEffect(() => {\n const reactiveClassString = node.reactiveClasses!()\n \n // Combine with static classes if needed\n if (finalClasses.length > 0) {\n const staticClassString = finalClasses.join(' ')\n element.className = `${staticClassString} ${reactiveClassString}`.trim()\n } else {\n element.className = reactiveClassString\n }\n })\n }\n }\n}\n\n/**\n * Function to enhance any renderer with CSS class support\n */\nexport function enhanceRendererWithCSSClasses<T extends { createElement: (node: DOMNode) => Element }>(\n renderer: T\n): T & CSSClassRendererMixin {\n // Store original createElement method\n const originalCreateElement = renderer.createElement.bind(renderer)\n\n // Enhanced createElement that supports CSS classes\n const enhancedCreateElement = (node: DOMNode): Element => {\n // Call original createElement to create the element\n const element = originalCreateElement(node)\n\n // Check if this is a CSS-enhanced node\n const cssNode = node as DOMNodeWithClasses\n \n // Apply CSS classes if present\n if (cssNode.cssClasses || cssNode.reactiveClasses) {\n cssClassRendererMixin.processElementClasses(element, cssNode)\n }\n\n return element\n }\n\n // Replace createElement with enhanced version\n ;(renderer as any).createElement = enhancedCreateElement\n\n // Mix in CSS class methods\n return Object.assign(renderer, cssClassRendererMixin)\n}\n\n/**\n * Utility function to create a CSS class-aware DOM node\n */\nexport function createCSSClassDOMNode(\n tag: string,\n props: Record<string, any> = {},\n children: DOMNode[] = [],\n cssClasses?: string[] | Signal<string>\n): DOMNodeWithClasses {\n const node: DOMNodeWithClasses = {\n type: 'element',\n tag,\n props,\n children\n }\n\n if (cssClasses) {\n if (Array.isArray(cssClasses)) {\n node.cssClasses = cssClasses\n } else {\n node.reactiveClasses = cssClasses\n }\n }\n\n return node\n}\n\n/**\n * Helper to check if a DOMNode has CSS class support\n */\nexport function hasCSSClassSupport(node: DOMNode): node is DOMNodeWithClasses {\n const cssNode = node as DOMNodeWithClasses\n return !!(cssNode.cssClasses || cssNode.reactiveClasses)\n}"],"names":["cssClassRendererMixin","element","node","classString","isSignal","initialClasses","createEffect","finalClasses","existingClasses","uniqueClasses","reactiveClassString","staticClassString","enhanceRendererWithCSSClasses","renderer","originalCreateElement","enhancedCreateElement","cssNode","createCSSClassDOMNode","tag","props","children","cssClasses","hasCSSClassSupport"],"mappings":"oTA+BO,MAAMA,EAA+C,CAI1D,gBAAgBC,EAAkBC,EAAgC,CAEhE,GAAIA,EAAK,YAAcA,EAAK,WAAW,OAAS,EAAG,CACjD,MAAMC,EAAcD,EAAK,WAAW,KAAK,GAAG,EAC5CD,EAAQ,UAAYE,CACtB,CAGA,GAAID,EAAK,iBACHE,EAAAA,SAASF,EAAK,eAAe,EAAG,CAElC,MAAMG,EAAiBH,EAAK,gBAAA,EAC5BD,EAAQ,UAAYI,EAGpBC,EAAAA,aAAa,IAAM,CACjB,MAAMH,EAAcD,EAAK,gBAAA,EACzBD,EAAQ,UAAYE,CACtB,CAAC,CACH,CAEJ,EAKA,sBAAsBF,EAAkBC,EAAgC,CACtE,IAAIK,EAAyB,CAAA,EAG7B,GAAIL,EAAK,OAAO,UAAW,CACzB,MAAMM,EAAkB,OAAON,EAAK,MAAM,WAAc,SACpDA,EAAK,MAAM,UAAU,MAAM,GAAG,EAAE,OAAO,OAAO,EAC9C,CAAA,EACJK,EAAa,KAAK,GAAGC,CAAe,CACtC,CAQA,GALIN,EAAK,YACPK,EAAa,KAAK,GAAGL,EAAK,UAAU,EAIlCK,EAAa,OAAS,EAAG,CAC3B,MAAME,EAAgB,CAAC,GAAG,IAAI,IAAIF,CAAY,CAAC,EAC/CN,EAAQ,UAAYQ,EAAc,KAAK,GAAG,CAC5C,CAGIP,EAAK,iBAAmBE,EAAAA,SAASF,EAAK,eAAe,GACvDI,EAAAA,aAAa,IAAM,CACjB,MAAMI,EAAsBR,EAAK,gBAAA,EAGjC,GAAIK,EAAa,OAAS,EAAG,CAC3B,MAAMI,EAAoBJ,EAAa,KAAK,GAAG,EAC/CN,EAAQ,UAAY,GAAGU,CAAiB,IAAID,CAAmB,GAAG,KAAA,CACpE,MACET,EAAQ,UAAYS,CAExB,CAAC,CAEL,CACF,EAKO,SAASE,EACdC,EAC2B,CAE3B,MAAMC,EAAwBD,EAAS,cAAc,KAAKA,CAAQ,EAG5DE,EAAyBb,GAA2B,CAExD,MAAMD,EAAUa,EAAsBZ,CAAI,EAGpCc,EAAUd,EAGhB,OAAIc,EAAQ,YAAcA,EAAQ,kBAChChB,EAAsB,sBAAsBC,EAASe,CAAO,EAGvDf,CACT,EAGE,OAAAY,EAAiB,cAAgBE,EAG5B,OAAO,OAAOF,EAAUb,CAAqB,CACtD,CAKO,SAASiB,EACdC,EACAC,EAA6B,CAAA,EAC7BC,EAAsB,CAAA,EACtBC,EACoB,CACpB,MAAMnB,EAA2B,CAC/B,KAAM,UACN,IAAAgB,EACA,MAAAC,EACA,SAAAC,CAAA,EAGF,OAAIC,IACE,MAAM,QAAQA,CAAU,EAC1BnB,EAAK,WAAamB,EAElBnB,EAAK,gBAAkBmB,GAIpBnB,CACT,CAKO,SAASoB,EAAmBpB,EAA2C,CAC5E,MAAMc,EAAUd,EAChB,MAAO,CAAC,EAAEc,EAAQ,YAAcA,EAAQ,gBAC1C"}