@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 +0,0 @@
1
- {"version":3,"file":"advanced-utilities.js","sources":["../../../src/modifiers/responsive/advanced-utilities.ts"],"sourcesContent":["/**\n * Advanced Responsive Utilities\n * \n * Provides programmatic access to responsive behavior, advanced hooks,\n * and complex responsive logic utilities for sophisticated applications.\n */\n\nimport { createSignal, createComputed, createEffect, createMemo, Signal } from '../../reactive'\nimport { \n ResponsiveValue, \n BreakpointKey, \n BreakpointContext,\n isResponsiveValue \n} from './types'\nimport { \n getCurrentBreakpoint, \n getBreakpointIndex, \n createBreakpointContext,\n getCurrentBreakpointConfig \n} from './breakpoints'\n\n/**\n * Advanced breakpoint utilities with enhanced functionality\n */\nexport class AdvancedBreakpointUtils {\n /**\n * Create a responsive value resolver with custom logic\n */\n static createResponsiveResolver<T>(\n getValue: (breakpoint: BreakpointKey, context: BreakpointContext) => T,\n dependencies: Signal<any>[] = []\n ): Signal<T> {\n const currentBreakpoint = getCurrentBreakpoint()\n \n return createComputed(() => {\n // Include dependencies in computation\n dependencies.forEach(dep => dep())\n \n const breakpoint = currentBreakpoint()\n const context = createBreakpointContext()\n return getValue(breakpoint, context)\n })\n }\n \n /**\n * Create responsive value that interpolates between breakpoints\n */\n static createInterpolatedValue(\n values: Partial<Record<BreakpointKey, number>>,\n options: {\n smoothing?: 'linear' | 'ease' | 'ease-in' | 'ease-out'\n clamp?: boolean\n } = {}\n ): Signal<number> {\n const { smoothing = 'linear', clamp = true } = options\n \n return createComputed(() => {\n const context = createBreakpointContext()\n const width = context.width\n const breakpointConfig = getCurrentBreakpointConfig()\n \n // Convert breakpoint values to numeric widths\n const sortedPoints: Array<{ width: number; value: number }> = []\n \n for (const [bp, value] of Object.entries(values)) {\n if (value !== undefined) {\n const bpWidth = bp === 'base' ? 0 : parseInt(breakpointConfig[bp as BreakpointKey] || '0')\n sortedPoints.push({ width: bpWidth, value })\n }\n }\n \n sortedPoints.sort((a, b) => a.width - b.width)\n \n if (sortedPoints.length === 0) return 0\n if (sortedPoints.length === 1) return sortedPoints[0].value\n \n // Find interpolation points\n let lowerPoint = sortedPoints[0]\n let upperPoint = sortedPoints[sortedPoints.length - 1]\n \n for (let i = 0; i < sortedPoints.length - 1; i++) {\n if (width >= sortedPoints[i].width && width <= sortedPoints[i + 1].width) {\n lowerPoint = sortedPoints[i]\n upperPoint = sortedPoints[i + 1]\n break\n }\n }\n \n // Handle edge cases\n if (clamp) {\n if (width <= lowerPoint.width) return lowerPoint.value\n if (width >= upperPoint.width) return upperPoint.value\n }\n \n // Calculate interpolation factor\n const factor = (width - lowerPoint.width) / (upperPoint.width - lowerPoint.width)\n \n // Apply smoothing function\n let smoothedFactor = factor\n switch (smoothing) {\n case 'ease':\n smoothedFactor = 0.5 - 0.5 * Math.cos(factor * Math.PI)\n break\n case 'ease-in':\n smoothedFactor = factor * factor\n break\n case 'ease-out':\n smoothedFactor = 1 - (1 - factor) * (1 - factor)\n break\n case 'linear':\n default:\n smoothedFactor = factor\n break\n }\n \n // Interpolate value\n return lowerPoint.value + (upperPoint.value - lowerPoint.value) * smoothedFactor\n }) as Signal<number>\n }\n \n /**\n * Create conditional responsive behavior\n */\n static createConditionalResponsive<T>(\n condition: (context: BreakpointContext) => boolean,\n trueValue: ResponsiveValue<T>,\n falseValue: ResponsiveValue<T>\n ): Signal<T> {\n const currentBreakpoint = getCurrentBreakpoint()\n \n return createComputed(() => {\n const context = createBreakpointContext()\n const shouldUseTrue = condition(context)\n const activeValue = shouldUseTrue ? trueValue : falseValue\n \n return this.resolveResponsiveValue(activeValue, currentBreakpoint())\n })\n }\n \n /**\n * Resolve responsive value at specific breakpoint\n */\n private static resolveResponsiveValue<T>(\n value: ResponsiveValue<T>,\n breakpoint: BreakpointKey\n ): T {\n if (!isResponsiveValue(value)) {\n return value as T\n }\n \n const responsiveObj = value as Partial<Record<BreakpointKey, T>>\n const breakpointOrder: BreakpointKey[] = ['base', 'sm', 'md', 'lg', 'xl', '2xl']\n const currentIndex = breakpointOrder.indexOf(breakpoint)\n \n // Search backwards from current breakpoint\n for (let i = currentIndex; i >= 0; i--) {\n const bp = breakpointOrder[i]\n if (responsiveObj[bp] !== undefined) {\n return responsiveObj[bp]!\n }\n }\n \n // Fallback to any defined value\n for (const bp of breakpointOrder) {\n if (responsiveObj[bp] !== undefined) {\n return responsiveObj[bp]!\n }\n }\n \n throw new Error('No responsive value found')\n }\n}\n\n/**\n * Advanced responsive hooks for complex scenarios\n */\nexport class ResponsiveHooks {\n /**\n * Hook for responsive arrays (e.g., responsive grid columns data)\n */\n static useResponsiveArray<T>(\n arrays: Partial<Record<BreakpointKey, T[]>>\n ): Signal<T[]> {\n const currentBreakpoint = getCurrentBreakpoint()\n \n return createComputed(() => {\n const breakpoint = currentBreakpoint()\n return AdvancedBreakpointUtils['resolveResponsiveValue'](arrays, breakpoint) || []\n })\n }\n \n /**\n * Hook for responsive object selection\n */\n static useResponsiveObject<T extends Record<string, any>>(\n objects: Partial<Record<BreakpointKey, T>>\n ): Signal<T | null> {\n const currentBreakpoint = getCurrentBreakpoint()\n \n return createComputed(() => {\n const breakpoint = currentBreakpoint()\n try {\n return AdvancedBreakpointUtils['resolveResponsiveValue'](objects, breakpoint)\n } catch {\n return null\n }\n })\n }\n \n /**\n * Hook for responsive function selection and execution\n */\n static useResponsiveFunction<TArgs extends any[], TReturn>(\n functions: Partial<Record<BreakpointKey, (...args: TArgs) => TReturn>>\n ): Signal<((...args: TArgs) => TReturn) | null> {\n const currentBreakpoint = getCurrentBreakpoint()\n \n return createComputed(() => {\n const breakpoint = currentBreakpoint()\n try {\n return AdvancedBreakpointUtils['resolveResponsiveValue'](functions, breakpoint)\n } catch {\n return null\n }\n })\n }\n \n /**\n * Hook for responsive state management\n */\n static useResponsiveState<T>(\n initialValues: Partial<Record<BreakpointKey, T>>\n ): [Signal<T | undefined>, (value: T | Partial<Record<BreakpointKey, T>>) => void] {\n const [state, setState] = createSignal<Partial<Record<BreakpointKey, T>>>(initialValues)\n const currentBreakpoint = getCurrentBreakpoint()\n \n const currentValue = createComputed(() => {\n const stateObj = state()\n const breakpoint = currentBreakpoint()\n \n try {\n return AdvancedBreakpointUtils['resolveResponsiveValue'](stateObj, breakpoint)\n } catch {\n return undefined\n }\n })\n \n const setResponsiveState = (value: T | Partial<Record<BreakpointKey, T>>) => {\n if (isResponsiveValue(value)) {\n setState(value as Partial<Record<BreakpointKey, T>>)\n } else {\n setState({ [currentBreakpoint()]: value as T })\n }\n }\n \n return [currentValue, setResponsiveState]\n }\n \n /**\n * Hook for responsive computations with memoization\n */\n static useResponsiveComputation<T>(\n computation: (context: BreakpointContext) => T,\n dependencies: Signal<any>[] = []\n ): Signal<T> {\n return createMemo(() => {\n // Include dependencies\n dependencies.forEach(dep => dep())\n \n const context = createBreakpointContext()\n return computation(context)\n })\n }\n \n /**\n * Hook for responsive side effects\n */\n static useResponsiveEffect(\n effect: (context: BreakpointContext, prevContext?: BreakpointContext) => void | (() => void),\n dependencies: Signal<any>[] = []\n ): void {\n let cleanup: (() => void) | undefined\n let prevContext: BreakpointContext | undefined\n \n createEffect(() => {\n // Include dependencies\n dependencies.forEach(dep => dep())\n \n const context = createBreakpointContext()\n \n // Run cleanup from previous effect\n if (cleanup) {\n cleanup()\n cleanup = undefined\n }\n \n // Run the effect\n const result = effect(context, prevContext)\n \n if (typeof result === 'function') {\n cleanup = result\n }\n \n prevContext = context\n })\n }\n}\n\n/**\n * Responsive breakpoint targeting utilities\n */\nexport class ResponsiveTargeting {\n /**\n * Execute callback only on specific breakpoints\n */\n static onBreakpoints(\n breakpoints: BreakpointKey[],\n callback: (context: BreakpointContext) => void | (() => void)\n ): () => void {\n let cleanup: (() => void) | undefined\n \n createEffect(() => {\n const context = createBreakpointContext()\n \n if (breakpoints.includes(context.current)) {\n // Run cleanup from previous execution\n if (cleanup) {\n cleanup()\n cleanup = undefined\n }\n \n // Execute callback\n const result = callback(context)\n if (typeof result === 'function') {\n cleanup = result\n }\n }\n })\n \n return () => {\n if (cleanup) cleanup()\n }\n }\n \n /**\n * Execute callback when breakpoint changes\n */\n static onBreakpointChange(\n callback: (newBreakpoint: BreakpointKey, oldBreakpoint: BreakpointKey, context: BreakpointContext) => void\n ): () => void {\n let oldBreakpoint: BreakpointKey | undefined\n \n createEffect(() => {\n const context = createBreakpointContext()\n const newBreakpoint = context.current\n \n if (oldBreakpoint && oldBreakpoint !== newBreakpoint) {\n callback(newBreakpoint, oldBreakpoint, context)\n }\n \n oldBreakpoint = newBreakpoint\n })\n \n return () => {\n // No-op for now since createEffect doesn't return dispose function\n }\n }\n \n /**\n * Execute callback when entering/leaving specific breakpoint ranges\n */\n static onBreakpointRange(\n minBreakpoint: BreakpointKey,\n maxBreakpoint: BreakpointKey,\n callbacks: {\n onEnter?: (context: BreakpointContext) => void | (() => void)\n onLeave?: (context: BreakpointContext) => void\n onWithin?: (context: BreakpointContext) => void | (() => void)\n }\n ): () => void {\n let isWithinRange = false\n let withinCleanup: (() => void) | undefined\n let enterCleanup: (() => void) | undefined\n \n createEffect(() => {\n const context = createBreakpointContext()\n const currentIndex = getBreakpointIndex(context.current)\n const minIndex = getBreakpointIndex(minBreakpoint)\n const maxIndex = getBreakpointIndex(maxBreakpoint)\n \n const nowWithinRange = currentIndex >= minIndex && currentIndex <= maxIndex\n \n if (nowWithinRange && !isWithinRange) {\n // Entering range\n if (callbacks.onEnter) {\n const result = callbacks.onEnter(context)\n if (typeof result === 'function') {\n enterCleanup = result\n }\n }\n isWithinRange = true\n } else if (!nowWithinRange && isWithinRange) {\n // Leaving range\n if (enterCleanup) {\n enterCleanup()\n enterCleanup = undefined\n }\n if (withinCleanup) {\n withinCleanup()\n withinCleanup = undefined\n }\n if (callbacks.onLeave) {\n callbacks.onLeave(context)\n }\n isWithinRange = false\n }\n \n if (nowWithinRange && callbacks.onWithin) {\n // Within range\n if (withinCleanup) {\n withinCleanup()\n withinCleanup = undefined\n }\n \n const result = callbacks.onWithin(context)\n if (typeof result === 'function') {\n withinCleanup = result\n }\n }\n })\n \n return () => {\n if (enterCleanup) enterCleanup()\n if (withinCleanup) withinCleanup()\n }\n }\n}\n\n/**\n * Responsive data management utilities\n */\nexport class ResponsiveDataUtils {\n /**\n * Create responsive pagination\n */\n static createResponsivePagination<T>(\n data: T[],\n itemsPerPage: ResponsiveValue<number>\n ): {\n currentPage: Signal<number>\n totalPages: Signal<number>\n currentItems: Signal<T[]>\n setPage: (page: number) => void\n nextPage: () => void\n prevPage: () => void\n hasNext: Signal<boolean>\n hasPrev: Signal<boolean>\n } {\n const [currentPage, setCurrentPage] = createSignal(1)\n const currentBreakpoint = getCurrentBreakpoint()\n \n const itemsPerPageResolved = createComputed(() => {\n const breakpoint = currentBreakpoint()\n return AdvancedBreakpointUtils['resolveResponsiveValue'](itemsPerPage, breakpoint)\n }) as Signal<number>\n \n const totalPages = createComputed(() => {\n return Math.ceil(data.length / itemsPerPageResolved())\n }) as Signal<number>\n \n const currentItems = createComputed(() => {\n const itemsCount = itemsPerPageResolved()\n const page = currentPage()\n const startIndex = (page - 1) * itemsCount\n const endIndex = startIndex + itemsCount\n return data.slice(startIndex, endIndex)\n }) as Signal<T[]>\n \n const hasNext = createComputed(() => currentPage() < totalPages()) as Signal<boolean>\n const hasPrev = createComputed(() => currentPage() > 1) as Signal<boolean>\n \n const setPage = (page: number) => {\n const maxPage = totalPages()\n setCurrentPage(Math.max(1, Math.min(page, maxPage)))\n }\n \n const nextPage = () => {\n if (hasNext()) {\n setCurrentPage(currentPage() + 1)\n }\n }\n \n const prevPage = () => {\n if (hasPrev()) {\n setCurrentPage(currentPage() - 1)\n }\n }\n \n // Reset to page 1 when items per page changes\n createEffect(() => {\n itemsPerPageResolved() // Subscribe to changes\n setCurrentPage(1)\n })\n \n return {\n currentPage: currentPage as Signal<number>,\n totalPages,\n currentItems,\n setPage,\n nextPage,\n prevPage,\n hasNext,\n hasPrev\n }\n }\n \n /**\n * Create responsive filtering\n */\n static createResponsiveFilter<T>(\n data: T[],\n filters: Partial<Record<BreakpointKey, (item: T) => boolean>>\n ): Signal<T[]> {\n const currentBreakpoint = getCurrentBreakpoint()\n \n return createComputed(() => {\n const breakpoint = currentBreakpoint()\n const filter = AdvancedBreakpointUtils['resolveResponsiveValue'](filters, breakpoint)\n \n if (!filter) return data\n return data.filter(filter)\n }) as Signal<T[]>\n }\n \n /**\n * Create responsive sorting\n */\n static createResponsiveSort<T>(\n data: T[],\n sorters: Partial<Record<BreakpointKey, (a: T, b: T) => number>>\n ): Signal<T[]> {\n const currentBreakpoint = getCurrentBreakpoint()\n \n return createComputed(() => {\n const breakpoint = currentBreakpoint()\n const sorter = AdvancedBreakpointUtils['resolveResponsiveValue'](sorters, breakpoint)\n \n if (!sorter) return data\n return [...data].sort(sorter)\n }) as Signal<T[]>\n }\n}\n\n/**\n * Export all advanced utilities\n */\nexport const ResponsiveAdvanced = {\n Breakpoints: AdvancedBreakpointUtils,\n Hooks: ResponsiveHooks,\n Targeting: ResponsiveTargeting,\n Data: ResponsiveDataUtils\n}"],"names":["AdvancedBreakpointUtils","getValue","dependencies","currentBreakpoint","getCurrentBreakpoint","createComputed","dep","breakpoint","context","createBreakpointContext","values","options","smoothing","clamp","width","breakpointConfig","getCurrentBreakpointConfig","sortedPoints","bp","value","bpWidth","a","b","lowerPoint","upperPoint","i","factor","smoothedFactor","condition","trueValue","falseValue","activeValue","isResponsiveValue","responsiveObj","breakpointOrder","currentIndex","ResponsiveHooks","arrays","objects","functions","initialValues","state","setState","createSignal","stateObj","computation","createMemo","effect","cleanup","prevContext","createEffect","result","ResponsiveTargeting","breakpoints","callback","oldBreakpoint","newBreakpoint","minBreakpoint","maxBreakpoint","callbacks","isWithinRange","withinCleanup","enterCleanup","getBreakpointIndex","minIndex","maxIndex","nowWithinRange","ResponsiveDataUtils","data","itemsPerPage","currentPage","setCurrentPage","itemsPerPageResolved","totalPages","currentItems","itemsCount","startIndex","endIndex","hasNext","hasPrev","setPage","page","maxPage","nextPage","prevPage","filters","filter","sorters","sorter","ResponsiveAdvanced"],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const d=require("./types.cjs");require("../../reactive/cleanup.cjs");require("../../reactive/unified-scheduler.cjs");const m=require("../../reactive/signal.cjs");require("../../reactive/scheduler.cjs");require("../../reactive/theme.cjs");let a={...d.DEFAULT_BREAKPOINTS};const[k,w]=m.createSignal("base"),[h,B]=m.createSignal({width:0,height:0});function b(t){V(t),a={...d.DEFAULT_BREAKPOINTS,...t},s(),typeof window<"u"&&window.addEventListener("resize",s)}function v(){return{...a}}function y(){return k}function C(){return h}function $(){typeof window>"u"||(f(),s(),window.addEventListener("resize",()=>{f(),s()}),window.addEventListener("orientationchange",()=>{setTimeout(()=>{f(),s()},100)}))}function I(){const t=k(),n=h();return{current:t,width:n.width,height:n.height,isAbove:e=>x(t,e),isBelow:e=>g(t,e),isBetween:(e,i)=>x(t,e)&&g(t,i),matches:e=>window.matchMedia(e).matches}}function u(t){const n=a[t];return n.endsWith("px")?parseInt(n,10):n.endsWith("em")||n.endsWith("rem")?parseInt(n,10)*16:parseInt(n,10)||0}function r(t){return["base","sm","md","lg","xl","2xl"].indexOf(t)}function x(t,n){return r(t)>r(n)}function g(t,n){return r(t)<r(n)}function S(t){return t==="base"?"":`(min-width: ${a[t]})`}function E(t,n){const e=[];if(t!=="base"&&e.push(`(min-width: ${a[t]})`),n&&n!=="2xl"){const i=["sm","md","lg","xl","2xl"],o=i.indexOf(n);if(o>=0&&o<i.length-1){const c=i[o+1],p=`${u(c)-1}px`;e.push(`(max-width: ${p})`)}}return e.length>0?e.join(" and "):""}function l(){return["base","sm","md","lg","xl","2xl"]}function A(t){const n=l(),e=n.indexOf(t);return e>=0?n.slice(e+1):[]}function O(t){const n=l(),e=n.indexOf(t);return e>0?n.slice(0,e):[]}function s(){if(typeof window>"u")return;const t=window.innerWidth,n=l().reverse();for(const e of n)if(e==="base"||t>=u(e)){w(e);return}w("base")}function f(){typeof window<"u"&&B({width:window.innerWidth,height:window.innerHeight})}function V(t){for(const[e,i]of Object.entries(t)){if(!d.isValidBreakpointKey(e))throw new Error(`Invalid breakpoint key: "${e}". Valid keys are: base, sm, md, lg, xl, 2xl`);if(typeof i!="string")throw new Error(`Breakpoint value for "${e}" must be a string (e.g., "768px")`);if(!i.match(/^\d+(\.\d+)?(px|em|rem|%)$/))throw new Error(`Invalid breakpoint value for "${e}": "${i}". Must be a valid CSS length (e.g., "768px", "48em")`)}const n=Object.keys(t).filter(d.isValidBreakpointKey).sort((e,i)=>r(e)-r(i));for(let e=1;e<n.length;e++){const i=n[e-1],o=n[e],c=t[i],p=t[o];if(u(i)>=parseInt(p,10))throw new Error(`Breakpoint "${o}" (${p}) must be larger than "${i}" (${c})`)}}const T={tailwind:{sm:"640px",md:"768px",lg:"1024px",xl:"1280px","2xl":"1536px"},bootstrap:{sm:"576px",md:"768px",lg:"992px",xl:"1200px","2xl":"1400px"},material:{sm:"600px",md:"960px",lg:"1280px",xl:"1920px","2xl":"2560px"},mobileFocus:{sm:"480px",md:"768px",lg:"1024px",xl:"1200px","2xl":"1440px"}};exports.BreakpointPresets=T;exports.breakpointToPixels=u;exports.configureBreakpoints=b;exports.createBreakpointContext=I;exports.generateMediaQuery=S;exports.generateRangeMediaQuery=E;exports.getBreakpointIndex=r;exports.getBreakpointsAbove=A;exports.getBreakpointsBelow=O;exports.getCurrentBreakpoint=y;exports.getCurrentBreakpointConfig=v;exports.getSortedBreakpoints=l;exports.getViewportDimensions=C;exports.initializeResponsiveSystem=$;exports.isBreakpointAbove=x;exports.isBreakpointBelow=g;
2
- //# sourceMappingURL=breakpoints.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"breakpoints.cjs","sources":["../../../src/modifiers/responsive/breakpoints.ts"],"sourcesContent":["/**\n * Breakpoint Configuration System\n * \n * Manages responsive breakpoint configuration, validation, and utilities.\n * Supports both default Tailwind-inspired breakpoints and custom configurations.\n */\n\nimport { \n BreakpointKey, \n BreakpointConfig, \n DEFAULT_BREAKPOINTS,\n BreakpointContext,\n isValidBreakpointKey\n} from './types'\nimport { createSignal, Signal } from '../../reactive'\n\n/**\n * Global breakpoint configuration state\n */\nlet currentBreakpointConfig: Required<BreakpointConfig> = { ...DEFAULT_BREAKPOINTS }\n\n/**\n * Current active breakpoint signal\n */\nconst [currentBreakpoint, setCurrentBreakpoint] = createSignal<BreakpointKey>('base')\n\n/**\n * Current viewport dimensions signal\n */\nconst [viewportDimensions, setViewportDimensions] = createSignal({ width: 0, height: 0 })\n\n/**\n * Configure global breakpoints for the application\n */\nexport function configureBreakpoints(config: Partial<BreakpointConfig>): void {\n // Validate breakpoint configuration\n validateBreakpointConfig(config)\n \n // Update global configuration\n currentBreakpointConfig = {\n ...DEFAULT_BREAKPOINTS,\n ...config\n }\n \n // Re-evaluate current breakpoint\n updateCurrentBreakpoint()\n \n if (typeof window !== 'undefined') {\n // Update breakpoint on window resize\n window.addEventListener('resize', updateCurrentBreakpoint)\n }\n}\n\n/**\n * Get the current breakpoint configuration\n */\nexport function getCurrentBreakpointConfig(): Required<BreakpointConfig> {\n return { ...currentBreakpointConfig }\n}\n\n/**\n * Get the current active breakpoint\n */\nexport function getCurrentBreakpoint(): Signal<BreakpointKey> {\n return currentBreakpoint as Signal<BreakpointKey>\n}\n\n/**\n * Get current viewport dimensions\n */\nexport function getViewportDimensions(): Signal<{ width: number; height: number }> {\n return viewportDimensions as Signal<{ width: number; height: number }>\n}\n\n/**\n * Initialize the responsive system (should be called once on app startup)\n */\nexport function initializeResponsiveSystem(): void {\n if (typeof window === 'undefined') {\n return // Skip on server-side\n }\n \n // Set initial viewport dimensions\n updateViewportDimensions()\n updateCurrentBreakpoint()\n \n // Listen for window resize events\n window.addEventListener('resize', () => {\n updateViewportDimensions()\n updateCurrentBreakpoint()\n })\n \n // Listen for orientation changes\n window.addEventListener('orientationchange', () => {\n // Delay to ensure accurate dimensions after orientation change\n setTimeout(() => {\n updateViewportDimensions()\n updateCurrentBreakpoint()\n }, 100)\n })\n}\n\n/**\n * Create a breakpoint context for utilities\n */\nexport function createBreakpointContext(): BreakpointContext {\n const current = currentBreakpoint()\n const dimensions = viewportDimensions()\n \n return {\n current,\n width: dimensions.width,\n height: dimensions.height,\n isAbove: (breakpoint: BreakpointKey) => isBreakpointAbove(current, breakpoint),\n isBelow: (breakpoint: BreakpointKey) => isBreakpointBelow(current, breakpoint),\n isBetween: (min: BreakpointKey, max: BreakpointKey) => \n isBreakpointAbove(current, min) && isBreakpointBelow(current, max),\n matches: (query: string) => window.matchMedia(query).matches\n }\n}\n\n/**\n * Convert breakpoint value to numeric pixels for comparison\n */\nexport function breakpointToPixels(breakpoint: BreakpointKey): number {\n const value = currentBreakpointConfig[breakpoint]\n \n // Handle different CSS units\n if (value.endsWith('px')) {\n return parseInt(value, 10)\n } else if (value.endsWith('em')) {\n return parseInt(value, 10) * 16 // Assume 16px base font size\n } else if (value.endsWith('rem')) {\n return parseInt(value, 10) * 16 // Assume 16px base font size\n }\n \n // Fallback to direct number conversion\n return parseInt(value, 10) || 0\n}\n\n/**\n * Get breakpoint index for comparison (base = 0, sm = 1, etc.)\n */\nexport function getBreakpointIndex(breakpoint: BreakpointKey): number {\n const order: BreakpointKey[] = ['base', 'sm', 'md', 'lg', 'xl', '2xl']\n return order.indexOf(breakpoint)\n}\n\n/**\n * Check if breakpoint A is above breakpoint B\n */\nexport function isBreakpointAbove(a: BreakpointKey, b: BreakpointKey): boolean {\n return getBreakpointIndex(a) > getBreakpointIndex(b)\n}\n\n/**\n * Check if breakpoint A is below breakpoint B\n */\nexport function isBreakpointBelow(a: BreakpointKey, b: BreakpointKey): boolean {\n return getBreakpointIndex(a) < getBreakpointIndex(b)\n}\n\n/**\n * Generate CSS media query string for a breakpoint\n */\nexport function generateMediaQuery(breakpoint: BreakpointKey): string {\n if (breakpoint === 'base') {\n return '' // No media query for base (mobile-first)\n }\n \n const minWidth = currentBreakpointConfig[breakpoint]\n return `(min-width: ${minWidth})`\n}\n\n/**\n * Generate CSS media query for a range of breakpoints\n */\nexport function generateRangeMediaQuery(min: BreakpointKey, max?: BreakpointKey): string {\n const queries: string[] = []\n \n if (min !== 'base') {\n queries.push(`(min-width: ${currentBreakpointConfig[min]})`)\n }\n \n if (max && max !== '2xl') {\n const maxBreakpoints: BreakpointKey[] = ['sm', 'md', 'lg', 'xl', '2xl']\n const maxIndex = maxBreakpoints.indexOf(max)\n if (maxIndex >= 0 && maxIndex < maxBreakpoints.length - 1) {\n const nextBreakpoint = maxBreakpoints[maxIndex + 1]\n const maxWidth = `${breakpointToPixels(nextBreakpoint) - 1}px`\n queries.push(`(max-width: ${maxWidth})`)\n }\n }\n \n return queries.length > 0 ? queries.join(' and ') : ''\n}\n\n/**\n * Get all breakpoints sorted by size\n */\nexport function getSortedBreakpoints(): BreakpointKey[] {\n return ['base', 'sm', 'md', 'lg', 'xl', '2xl']\n}\n\n/**\n * Get breakpoints above a given breakpoint\n */\nexport function getBreakpointsAbove(breakpoint: BreakpointKey): BreakpointKey[] {\n const sorted = getSortedBreakpoints()\n const index = sorted.indexOf(breakpoint)\n return index >= 0 ? sorted.slice(index + 1) : []\n}\n\n/**\n * Get breakpoints below a given breakpoint\n */\nexport function getBreakpointsBelow(breakpoint: BreakpointKey): BreakpointKey[] {\n const sorted = getSortedBreakpoints()\n const index = sorted.indexOf(breakpoint)\n return index > 0 ? sorted.slice(0, index) : []\n}\n\n/**\n * Resolve current breakpoint based on viewport width\n */\nfunction updateCurrentBreakpoint(): void {\n if (typeof window === 'undefined') {\n return\n }\n \n const width = window.innerWidth\n const breakpoints = getSortedBreakpoints().reverse() // Start from largest\n \n for (const breakpoint of breakpoints) {\n if (breakpoint === 'base' || width >= breakpointToPixels(breakpoint)) {\n setCurrentBreakpoint(breakpoint)\n return\n }\n }\n \n setCurrentBreakpoint('base')\n}\n\n/**\n * Update viewport dimensions\n */\nfunction updateViewportDimensions(): void {\n if (typeof window !== 'undefined') {\n setViewportDimensions({\n width: window.innerWidth,\n height: window.innerHeight\n })\n }\n}\n\n/**\n * Validate breakpoint configuration\n */\nfunction validateBreakpointConfig(config: Partial<BreakpointConfig>): void {\n for (const [key, value] of Object.entries(config)) {\n if (!isValidBreakpointKey(key)) {\n throw new Error(`Invalid breakpoint key: \"${key}\". Valid keys are: base, sm, md, lg, xl, 2xl`)\n }\n \n if (typeof value !== 'string') {\n throw new Error(`Breakpoint value for \"${key}\" must be a string (e.g., \"768px\")`)\n }\n \n if (!value.match(/^\\d+(\\.\\d+)?(px|em|rem|%)$/)) {\n throw new Error(`Invalid breakpoint value for \"${key}\": \"${value}\". Must be a valid CSS length (e.g., \"768px\", \"48em\")`)\n }\n }\n \n // Validate that breakpoints are in ascending order\n const sortedKeys = Object.keys(config).filter(isValidBreakpointKey).sort((a, b) => {\n return getBreakpointIndex(a as BreakpointKey) - getBreakpointIndex(b as BreakpointKey)\n })\n \n for (let i = 1; i < sortedKeys.length; i++) {\n const prev = sortedKeys[i - 1] as BreakpointKey\n const current = sortedKeys[i] as BreakpointKey\n const prevValue = config[prev]!\n const currentValue = config[current]!\n \n if (breakpointToPixels(prev) >= parseInt(currentValue, 10)) {\n throw new Error(`Breakpoint \"${current}\" (${currentValue}) must be larger than \"${prev}\" (${prevValue})`)\n }\n }\n}\n\n/**\n * Create common breakpoint configurations\n */\nexport const BreakpointPresets = {\n // Tailwind CSS (default)\n tailwind: {\n sm: '640px',\n md: '768px',\n lg: '1024px',\n xl: '1280px',\n '2xl': '1536px'\n } as BreakpointConfig,\n \n // Bootstrap\n bootstrap: {\n sm: '576px',\n md: '768px',\n lg: '992px',\n xl: '1200px',\n '2xl': '1400px'\n } as BreakpointConfig,\n \n // Material Design\n material: {\n sm: '600px',\n md: '960px',\n lg: '1280px',\n xl: '1920px',\n '2xl': '2560px'\n } as BreakpointConfig,\n \n // Custom mobile-first\n mobileFocus: {\n sm: '480px',\n md: '768px',\n lg: '1024px',\n xl: '1200px',\n '2xl': '1440px'\n } as BreakpointConfig\n} as const"],"names":["currentBreakpointConfig","DEFAULT_BREAKPOINTS","currentBreakpoint","setCurrentBreakpoint","createSignal","viewportDimensions","setViewportDimensions","configureBreakpoints","config","validateBreakpointConfig","updateCurrentBreakpoint","getCurrentBreakpointConfig","getCurrentBreakpoint","getViewportDimensions","initializeResponsiveSystem","updateViewportDimensions","createBreakpointContext","current","dimensions","breakpoint","isBreakpointAbove","isBreakpointBelow","min","max","query","breakpointToPixels","value","getBreakpointIndex","a","b","generateMediaQuery","generateRangeMediaQuery","queries","maxBreakpoints","maxIndex","nextBreakpoint","maxWidth","getSortedBreakpoints","getBreakpointsAbove","sorted","index","getBreakpointsBelow","width","breakpoints","key","isValidBreakpointKey","sortedKeys","i","prev","prevValue","currentValue","BreakpointPresets"],"mappings":"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"}
@@ -1,168 +0,0 @@
1
- import { DEFAULT_BREAKPOINTS as h, isValidBreakpointKey as f } from "./types.js";
2
- import "../../reactive/cleanup.js";
3
- import "../../reactive/unified-scheduler.js";
4
- import { createSignal as g } from "../../reactive/signal.js";
5
- import "../../reactive/scheduler.js";
6
- import "../../reactive/theme.js";
7
- let a = { ...h };
8
- const [k, x] = g("base"), [B, b] = g({ width: 0, height: 0 });
9
- function O(t) {
10
- v(t), a = {
11
- ...h,
12
- ...t
13
- }, s(), typeof window < "u" && window.addEventListener("resize", s);
14
- }
15
- function V() {
16
- return { ...a };
17
- }
18
- function S() {
19
- return k;
20
- }
21
- function A() {
22
- return B;
23
- }
24
- function D() {
25
- typeof window > "u" || (u(), s(), window.addEventListener("resize", () => {
26
- u(), s();
27
- }), window.addEventListener("orientationchange", () => {
28
- setTimeout(() => {
29
- u(), s();
30
- }, 100);
31
- }));
32
- }
33
- function L() {
34
- const t = k(), n = B();
35
- return {
36
- current: t,
37
- width: n.width,
38
- height: n.height,
39
- isAbove: (e) => m(t, e),
40
- isBelow: (e) => w(t, e),
41
- isBetween: (e, i) => m(t, e) && w(t, i),
42
- matches: (e) => window.matchMedia(e).matches
43
- };
44
- }
45
- function c(t) {
46
- const n = a[t];
47
- return n.endsWith("px") ? parseInt(n, 10) : n.endsWith("em") || n.endsWith("rem") ? parseInt(n, 10) * 16 : parseInt(n, 10) || 0;
48
- }
49
- function o(t) {
50
- return ["base", "sm", "md", "lg", "xl", "2xl"].indexOf(t);
51
- }
52
- function m(t, n) {
53
- return o(t) > o(n);
54
- }
55
- function w(t, n) {
56
- return o(t) < o(n);
57
- }
58
- function M(t) {
59
- return t === "base" ? "" : `(min-width: ${a[t]})`;
60
- }
61
- function T(t, n) {
62
- const e = [];
63
- if (t !== "base" && e.push(`(min-width: ${a[t]})`), n && n !== "2xl") {
64
- const i = ["sm", "md", "lg", "xl", "2xl"], r = i.indexOf(n);
65
- if (r >= 0 && r < i.length - 1) {
66
- const p = i[r + 1], d = `${c(p) - 1}px`;
67
- e.push(`(max-width: ${d})`);
68
- }
69
- }
70
- return e.length > 0 ? e.join(" and ") : "";
71
- }
72
- function l() {
73
- return ["base", "sm", "md", "lg", "xl", "2xl"];
74
- }
75
- function j(t) {
76
- const n = l(), e = n.indexOf(t);
77
- return e >= 0 ? n.slice(e + 1) : [];
78
- }
79
- function z(t) {
80
- const n = l(), e = n.indexOf(t);
81
- return e > 0 ? n.slice(0, e) : [];
82
- }
83
- function s() {
84
- if (typeof window > "u")
85
- return;
86
- const t = window.innerWidth, n = l().reverse();
87
- for (const e of n)
88
- if (e === "base" || t >= c(e)) {
89
- x(e);
90
- return;
91
- }
92
- x("base");
93
- }
94
- function u() {
95
- typeof window < "u" && b({
96
- width: window.innerWidth,
97
- height: window.innerHeight
98
- });
99
- }
100
- function v(t) {
101
- for (const [e, i] of Object.entries(t)) {
102
- if (!f(e))
103
- throw new Error(`Invalid breakpoint key: "${e}". Valid keys are: base, sm, md, lg, xl, 2xl`);
104
- if (typeof i != "string")
105
- throw new Error(`Breakpoint value for "${e}" must be a string (e.g., "768px")`);
106
- if (!i.match(/^\d+(\.\d+)?(px|em|rem|%)$/))
107
- throw new Error(`Invalid breakpoint value for "${e}": "${i}". Must be a valid CSS length (e.g., "768px", "48em")`);
108
- }
109
- const n = Object.keys(t).filter(f).sort((e, i) => o(e) - o(i));
110
- for (let e = 1; e < n.length; e++) {
111
- const i = n[e - 1], r = n[e], p = t[i], d = t[r];
112
- if (c(i) >= parseInt(d, 10))
113
- throw new Error(`Breakpoint "${r}" (${d}) must be larger than "${i}" (${p})`);
114
- }
115
- }
116
- const K = {
117
- // Tailwind CSS (default)
118
- tailwind: {
119
- sm: "640px",
120
- md: "768px",
121
- lg: "1024px",
122
- xl: "1280px",
123
- "2xl": "1536px"
124
- },
125
- // Bootstrap
126
- bootstrap: {
127
- sm: "576px",
128
- md: "768px",
129
- lg: "992px",
130
- xl: "1200px",
131
- "2xl": "1400px"
132
- },
133
- // Material Design
134
- material: {
135
- sm: "600px",
136
- md: "960px",
137
- lg: "1280px",
138
- xl: "1920px",
139
- "2xl": "2560px"
140
- },
141
- // Custom mobile-first
142
- mobileFocus: {
143
- sm: "480px",
144
- md: "768px",
145
- lg: "1024px",
146
- xl: "1200px",
147
- "2xl": "1440px"
148
- }
149
- };
150
- export {
151
- K as BreakpointPresets,
152
- c as breakpointToPixels,
153
- O as configureBreakpoints,
154
- L as createBreakpointContext,
155
- M as generateMediaQuery,
156
- T as generateRangeMediaQuery,
157
- o as getBreakpointIndex,
158
- j as getBreakpointsAbove,
159
- z as getBreakpointsBelow,
160
- S as getCurrentBreakpoint,
161
- V as getCurrentBreakpointConfig,
162
- l as getSortedBreakpoints,
163
- A as getViewportDimensions,
164
- D as initializeResponsiveSystem,
165
- m as isBreakpointAbove,
166
- w as isBreakpointBelow
167
- };
168
- //# sourceMappingURL=breakpoints.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"breakpoints.js","sources":["../../../src/modifiers/responsive/breakpoints.ts"],"sourcesContent":["/**\n * Breakpoint Configuration System\n * \n * Manages responsive breakpoint configuration, validation, and utilities.\n * Supports both default Tailwind-inspired breakpoints and custom configurations.\n */\n\nimport { \n BreakpointKey, \n BreakpointConfig, \n DEFAULT_BREAKPOINTS,\n BreakpointContext,\n isValidBreakpointKey\n} from './types'\nimport { createSignal, Signal } from '../../reactive'\n\n/**\n * Global breakpoint configuration state\n */\nlet currentBreakpointConfig: Required<BreakpointConfig> = { ...DEFAULT_BREAKPOINTS }\n\n/**\n * Current active breakpoint signal\n */\nconst [currentBreakpoint, setCurrentBreakpoint] = createSignal<BreakpointKey>('base')\n\n/**\n * Current viewport dimensions signal\n */\nconst [viewportDimensions, setViewportDimensions] = createSignal({ width: 0, height: 0 })\n\n/**\n * Configure global breakpoints for the application\n */\nexport function configureBreakpoints(config: Partial<BreakpointConfig>): void {\n // Validate breakpoint configuration\n validateBreakpointConfig(config)\n \n // Update global configuration\n currentBreakpointConfig = {\n ...DEFAULT_BREAKPOINTS,\n ...config\n }\n \n // Re-evaluate current breakpoint\n updateCurrentBreakpoint()\n \n if (typeof window !== 'undefined') {\n // Update breakpoint on window resize\n window.addEventListener('resize', updateCurrentBreakpoint)\n }\n}\n\n/**\n * Get the current breakpoint configuration\n */\nexport function getCurrentBreakpointConfig(): Required<BreakpointConfig> {\n return { ...currentBreakpointConfig }\n}\n\n/**\n * Get the current active breakpoint\n */\nexport function getCurrentBreakpoint(): Signal<BreakpointKey> {\n return currentBreakpoint as Signal<BreakpointKey>\n}\n\n/**\n * Get current viewport dimensions\n */\nexport function getViewportDimensions(): Signal<{ width: number; height: number }> {\n return viewportDimensions as Signal<{ width: number; height: number }>\n}\n\n/**\n * Initialize the responsive system (should be called once on app startup)\n */\nexport function initializeResponsiveSystem(): void {\n if (typeof window === 'undefined') {\n return // Skip on server-side\n }\n \n // Set initial viewport dimensions\n updateViewportDimensions()\n updateCurrentBreakpoint()\n \n // Listen for window resize events\n window.addEventListener('resize', () => {\n updateViewportDimensions()\n updateCurrentBreakpoint()\n })\n \n // Listen for orientation changes\n window.addEventListener('orientationchange', () => {\n // Delay to ensure accurate dimensions after orientation change\n setTimeout(() => {\n updateViewportDimensions()\n updateCurrentBreakpoint()\n }, 100)\n })\n}\n\n/**\n * Create a breakpoint context for utilities\n */\nexport function createBreakpointContext(): BreakpointContext {\n const current = currentBreakpoint()\n const dimensions = viewportDimensions()\n \n return {\n current,\n width: dimensions.width,\n height: dimensions.height,\n isAbove: (breakpoint: BreakpointKey) => isBreakpointAbove(current, breakpoint),\n isBelow: (breakpoint: BreakpointKey) => isBreakpointBelow(current, breakpoint),\n isBetween: (min: BreakpointKey, max: BreakpointKey) => \n isBreakpointAbove(current, min) && isBreakpointBelow(current, max),\n matches: (query: string) => window.matchMedia(query).matches\n }\n}\n\n/**\n * Convert breakpoint value to numeric pixels for comparison\n */\nexport function breakpointToPixels(breakpoint: BreakpointKey): number {\n const value = currentBreakpointConfig[breakpoint]\n \n // Handle different CSS units\n if (value.endsWith('px')) {\n return parseInt(value, 10)\n } else if (value.endsWith('em')) {\n return parseInt(value, 10) * 16 // Assume 16px base font size\n } else if (value.endsWith('rem')) {\n return parseInt(value, 10) * 16 // Assume 16px base font size\n }\n \n // Fallback to direct number conversion\n return parseInt(value, 10) || 0\n}\n\n/**\n * Get breakpoint index for comparison (base = 0, sm = 1, etc.)\n */\nexport function getBreakpointIndex(breakpoint: BreakpointKey): number {\n const order: BreakpointKey[] = ['base', 'sm', 'md', 'lg', 'xl', '2xl']\n return order.indexOf(breakpoint)\n}\n\n/**\n * Check if breakpoint A is above breakpoint B\n */\nexport function isBreakpointAbove(a: BreakpointKey, b: BreakpointKey): boolean {\n return getBreakpointIndex(a) > getBreakpointIndex(b)\n}\n\n/**\n * Check if breakpoint A is below breakpoint B\n */\nexport function isBreakpointBelow(a: BreakpointKey, b: BreakpointKey): boolean {\n return getBreakpointIndex(a) < getBreakpointIndex(b)\n}\n\n/**\n * Generate CSS media query string for a breakpoint\n */\nexport function generateMediaQuery(breakpoint: BreakpointKey): string {\n if (breakpoint === 'base') {\n return '' // No media query for base (mobile-first)\n }\n \n const minWidth = currentBreakpointConfig[breakpoint]\n return `(min-width: ${minWidth})`\n}\n\n/**\n * Generate CSS media query for a range of breakpoints\n */\nexport function generateRangeMediaQuery(min: BreakpointKey, max?: BreakpointKey): string {\n const queries: string[] = []\n \n if (min !== 'base') {\n queries.push(`(min-width: ${currentBreakpointConfig[min]})`)\n }\n \n if (max && max !== '2xl') {\n const maxBreakpoints: BreakpointKey[] = ['sm', 'md', 'lg', 'xl', '2xl']\n const maxIndex = maxBreakpoints.indexOf(max)\n if (maxIndex >= 0 && maxIndex < maxBreakpoints.length - 1) {\n const nextBreakpoint = maxBreakpoints[maxIndex + 1]\n const maxWidth = `${breakpointToPixels(nextBreakpoint) - 1}px`\n queries.push(`(max-width: ${maxWidth})`)\n }\n }\n \n return queries.length > 0 ? queries.join(' and ') : ''\n}\n\n/**\n * Get all breakpoints sorted by size\n */\nexport function getSortedBreakpoints(): BreakpointKey[] {\n return ['base', 'sm', 'md', 'lg', 'xl', '2xl']\n}\n\n/**\n * Get breakpoints above a given breakpoint\n */\nexport function getBreakpointsAbove(breakpoint: BreakpointKey): BreakpointKey[] {\n const sorted = getSortedBreakpoints()\n const index = sorted.indexOf(breakpoint)\n return index >= 0 ? sorted.slice(index + 1) : []\n}\n\n/**\n * Get breakpoints below a given breakpoint\n */\nexport function getBreakpointsBelow(breakpoint: BreakpointKey): BreakpointKey[] {\n const sorted = getSortedBreakpoints()\n const index = sorted.indexOf(breakpoint)\n return index > 0 ? sorted.slice(0, index) : []\n}\n\n/**\n * Resolve current breakpoint based on viewport width\n */\nfunction updateCurrentBreakpoint(): void {\n if (typeof window === 'undefined') {\n return\n }\n \n const width = window.innerWidth\n const breakpoints = getSortedBreakpoints().reverse() // Start from largest\n \n for (const breakpoint of breakpoints) {\n if (breakpoint === 'base' || width >= breakpointToPixels(breakpoint)) {\n setCurrentBreakpoint(breakpoint)\n return\n }\n }\n \n setCurrentBreakpoint('base')\n}\n\n/**\n * Update viewport dimensions\n */\nfunction updateViewportDimensions(): void {\n if (typeof window !== 'undefined') {\n setViewportDimensions({\n width: window.innerWidth,\n height: window.innerHeight\n })\n }\n}\n\n/**\n * Validate breakpoint configuration\n */\nfunction validateBreakpointConfig(config: Partial<BreakpointConfig>): void {\n for (const [key, value] of Object.entries(config)) {\n if (!isValidBreakpointKey(key)) {\n throw new Error(`Invalid breakpoint key: \"${key}\". Valid keys are: base, sm, md, lg, xl, 2xl`)\n }\n \n if (typeof value !== 'string') {\n throw new Error(`Breakpoint value for \"${key}\" must be a string (e.g., \"768px\")`)\n }\n \n if (!value.match(/^\\d+(\\.\\d+)?(px|em|rem|%)$/)) {\n throw new Error(`Invalid breakpoint value for \"${key}\": \"${value}\". Must be a valid CSS length (e.g., \"768px\", \"48em\")`)\n }\n }\n \n // Validate that breakpoints are in ascending order\n const sortedKeys = Object.keys(config).filter(isValidBreakpointKey).sort((a, b) => {\n return getBreakpointIndex(a as BreakpointKey) - getBreakpointIndex(b as BreakpointKey)\n })\n \n for (let i = 1; i < sortedKeys.length; i++) {\n const prev = sortedKeys[i - 1] as BreakpointKey\n const current = sortedKeys[i] as BreakpointKey\n const prevValue = config[prev]!\n const currentValue = config[current]!\n \n if (breakpointToPixels(prev) >= parseInt(currentValue, 10)) {\n throw new Error(`Breakpoint \"${current}\" (${currentValue}) must be larger than \"${prev}\" (${prevValue})`)\n }\n }\n}\n\n/**\n * Create common breakpoint configurations\n */\nexport const BreakpointPresets = {\n // Tailwind CSS (default)\n tailwind: {\n sm: '640px',\n md: '768px',\n lg: '1024px',\n xl: '1280px',\n '2xl': '1536px'\n } as BreakpointConfig,\n \n // Bootstrap\n bootstrap: {\n sm: '576px',\n md: '768px',\n lg: '992px',\n xl: '1200px',\n '2xl': '1400px'\n } as BreakpointConfig,\n \n // Material Design\n material: {\n sm: '600px',\n md: '960px',\n lg: '1280px',\n xl: '1920px',\n '2xl': '2560px'\n } as BreakpointConfig,\n \n // Custom mobile-first\n mobileFocus: {\n sm: '480px',\n md: '768px',\n lg: '1024px',\n xl: '1200px',\n '2xl': '1440px'\n } as BreakpointConfig\n} as const"],"names":["currentBreakpointConfig","DEFAULT_BREAKPOINTS","currentBreakpoint","setCurrentBreakpoint","createSignal","viewportDimensions","setViewportDimensions","configureBreakpoints","config","validateBreakpointConfig","updateCurrentBreakpoint","getCurrentBreakpointConfig","getCurrentBreakpoint","getViewportDimensions","initializeResponsiveSystem","updateViewportDimensions","createBreakpointContext","current","dimensions","breakpoint","isBreakpointAbove","isBreakpointBelow","min","max","query","breakpointToPixels","value","getBreakpointIndex","a","b","generateMediaQuery","generateRangeMediaQuery","queries","maxBreakpoints","maxIndex","nextBreakpoint","maxWidth","getSortedBreakpoints","getBreakpointsAbove","sorted","index","getBreakpointsBelow","width","breakpoints","key","isValidBreakpointKey","sortedKeys","i","prev","prevValue","currentValue","BreakpointPresets"],"mappings":"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"}
@@ -1,5 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const y=require("./types.cjs"),h=require("./breakpoints.cjs");var m=Object.defineProperty,$=(l,e,t)=>e in l?m(l,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):l[e]=t,f=(l,e,t)=>$(l,typeof e!="symbol"?e+"":e,t);class g{constructor(e){f(this,"options"),this.options={generateMinified:!1,includeComments:!0,optimizeOutput:!0,mobileFirst:!0,...e}}generateResponsiveCSS(e){const t=[],s=[],r={};let o=!1;for(const[n,c]of Object.entries(e))if(y.isResponsiveValue(c)){o=!0;const i=this.generatePropertyMediaQueries(n,c);t.push(...i.mediaQueries),i.baseStyles&&Object.assign(r,i.baseStyles)}else r[this.toCSSPropertyName(n)]=this.formatCSSValue(n,c);return s.push(...this.generateCSSRules(t,r)),{cssRules:s,mediaQueries:t,fallbackStyles:r,hasResponsiveStyles:o}}generatePropertyMediaQueries(e,t){const s=[],r={},o=h.getSortedBreakpoints();for(const n of o){const c=t[n];if(c===void 0)continue;const i=this.toCSSPropertyName(e),u=this.formatCSSValue(e,c);if(n==="base")r[i]=u;else{const a=h.generateMediaQuery(n),d={[i]:u};s.push({breakpoint:n,query:a,styles:d,selector:this.options.selector})}}return{mediaQueries:s,baseStyles:Object.keys(r).length>0?r:void 0}}generateCSSRules(e,t){const s=[];if(Object.keys(t).length>0){const o=this.generateCSSRule(this.options.selector,t);s.push(o)}const r=this.groupQueriesByMediaQuery(e);for(const[o,n]of Object.entries(r)){if(o==="")continue;const c={};for(const u of n)Object.assign(c,u.styles);const i=this.generateMediaQueryRule(o,this.options.selector,c);s.push(i)}return s}groupQueriesByMediaQuery(e){const t={};for(const s of e)t[s.query]||(t[s.query]=[]),t[s.query].push(s);return t}generateCSSRule(e,t){const{generateMinified:s,includeComments:r}=this.options,o=s?"":" ",n=s?"":`
2
- `,c=s?"":" ";let i=`${e}${c}{${n}`;for(const[u,a]of Object.entries(t))i+=`${o}${u}:${c}${a};${n}`;return i+=`}${n}`,r&&!s&&(i=`/* Base styles (mobile-first) */${n}${i}`),i}generateMediaQueryRule(e,t,s){const{generateMinified:r,includeComments:o}=this.options,n=r?"":" ",c=r?"":" ",i=r?"":`
3
- `,u=r?"":" ";let a=`@media ${e}${u}{${i}`;a+=`${n}${t}${u}{${i}`;for(const[d,p]of Object.entries(s))a+=`${c}${d}:${u}${p};${i}`;return a+=`${n}}${i}`,a+=`}${i}`,o&&!r&&(a=`/* ${this.getBreakpointFromQuery(e)} styles */${i}${a}`),a}toCSSProperty(e){return e.replace(/[A-Z]/g,t=>`-${t.toLowerCase()}`)}formatCSSValue(e,t){if(t==null)return"inherit";if(typeof t=="number"){const s=["opacity","z-index","font-weight","line-height","flex-grow","flex-shrink","order","grid-column-start","grid-column-end","grid-row-start","grid-row-end"],r=this.toCSSProperty(e);if(s.includes(r))return this.addImportantIfNeeded(e,t.toString());if(["width","height","min-width","max-width","min-height","max-height","padding","margin","border-width","border-radius","top","right","bottom","left","font-size","letter-spacing","text-indent"].some(n=>r.includes(n)))return this.addImportantIfNeeded(e,`${t}px`)}return this.addImportantIfNeeded(e,t.toString())}addImportantIfNeeded(e,t){const s=["flexDirection","flex-direction","justifyContent","justify-content","alignItems","align-items","display"],r=this.toCSSProperty(e);return s.includes(e)||s.includes(r)?`${t} !important`:t}toCSSPropertyName(e){return this.toCSSProperty(e)}getBreakpointFromQuery(e){const t=h.getCurrentBreakpointConfig();for(const[s,r]of Object.entries(t))if(e.includes(r))return s;return"custom"}}function b(l,e,t,s){if(!y.isResponsiveValue(t)){const c=e.replace(/[A-Z]/g,u=>`-${u.toLowerCase()}`),i=typeof t=="number"?`${t}px`:t.toString();return[`${l} { ${c}: ${i}; }`]}const r=new g({selector:l,...s}),o={[e]:t};return r.generateResponsiveCSS(o).cssRules}function C(l,e,t){const{generateMinified:s=!1}=t||{},r=s?"":" ",o=s?"":`
4
- `,n=s?"":" ";let c=`@media ${e.query}${n}{${o}`;c+=`${r}${l}${n}{${o}`;for(const[i,u]of Object.entries(e.styles)){const a=i.replace(/[A-Z]/g,p=>`-${p.toLowerCase()}`),d=typeof u=="number"?`${u}px`:u.toString();c+=`${r}${r}${a}:${n}${d};${o}`}return c+=`${r}}${o}`,c+=`}${o}`,c}class S{static getStyleSheet(){if(this.styleSheet)return this.styleSheet;const e=document.createElement("style");return e.setAttribute("data-tachui-responsive","true"),document.head.appendChild(e),this.styleSheet=e.sheet,this.styleSheet}static injectCSS(e){if(typeof document>"u")return;const t=this.getStyleSheet();for(const s of e)if(!this.injectedRules.has(s))try{t.insertRule(s,t.cssRules.length),this.injectedRules.add(s)}catch(r){console.warn("Failed to inject CSS rule:",s,r)}}static clearCSS(){if(this.styleSheet){for(;this.styleSheet.cssRules.length>0;)this.styleSheet.deleteRule(0);this.injectedRules.clear()}}static hasRule(e){return this.injectedRules.has(e)}}f(S,"styleSheet",null);f(S,"injectedRules",new Set);exports.CSSInjector=S;exports.ResponsiveCSSGenerator=g;exports.generateCustomMediaQuery=C;exports.generateResponsiveProperty=b;
5
- //# sourceMappingURL=css-generator.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"css-generator.cjs","sources":["../../../src/modifiers/responsive/css-generator.ts"],"sourcesContent":["/**\n * Responsive CSS Generation Engine\n * \n * Generates optimized CSS media queries from responsive modifier configurations.\n * Supports mobile-first design patterns and advanced media query features.\n */\n\nimport {\n BreakpointKey,\n ResponsiveValue,\n ResponsiveStyleConfig,\n MediaQueryConfig,\n GeneratedMediaQuery,\n ResponsiveModifierResult,\n isResponsiveValue\n} from './types'\nimport {\n generateMediaQuery,\n getCurrentBreakpointConfig,\n getSortedBreakpoints\n} from './breakpoints'\n\n/**\n * CSS generation options\n */\nexport interface CSSGenerationOptions {\n selector: string // CSS selector for the element\n generateMinified?: boolean // Generate minified CSS\n includeComments?: boolean // Include helpful comments\n optimizeOutput?: boolean // Optimize and deduplicate CSS\n mobileFirst?: boolean // Use mobile-first approach (default: true)\n}\n\n/**\n * Main CSS generation class\n */\nexport class ResponsiveCSSGenerator {\n private options: Required<CSSGenerationOptions>\n \n constructor(options: CSSGenerationOptions) {\n this.options = {\n generateMinified: false,\n includeComments: true,\n optimizeOutput: true,\n mobileFirst: true,\n ...options\n }\n }\n \n /**\n * Generate complete responsive CSS from a style configuration\n */\n generateResponsiveCSS(config: ResponsiveStyleConfig): ResponsiveModifierResult {\n const mediaQueries: GeneratedMediaQuery[] = []\n const cssRules: string[] = []\n const fallbackStyles: Record<string, string | number> = {}\n let hasResponsiveStyles = false\n \n // Process each property in the configuration\n for (const [property, value] of Object.entries(config)) {\n if (isResponsiveValue(value)) {\n hasResponsiveStyles = true\n const result = this.generatePropertyMediaQueries(property, value)\n mediaQueries.push(...result.mediaQueries)\n \n // Add base styles to fallback\n if (result.baseStyles) {\n Object.assign(fallbackStyles, result.baseStyles)\n }\n } else {\n // Non-responsive property - add to fallback styles\n fallbackStyles[this.toCSSPropertyName(property)] = this.formatCSSValue(property, value)\n }\n }\n \n // Generate CSS rules from media queries\n cssRules.push(...this.generateCSSRules(mediaQueries, fallbackStyles))\n \n return {\n cssRules,\n mediaQueries,\n fallbackStyles,\n hasResponsiveStyles\n }\n }\n \n /**\n * Generate media queries for a single property\n */\n private generatePropertyMediaQueries(\n property: string, \n value: Partial<Record<BreakpointKey, any>>\n ): { mediaQueries: GeneratedMediaQuery[]; baseStyles?: Record<string, string | number> } {\n const mediaQueries: GeneratedMediaQuery[] = []\n const baseStyles: Record<string, string | number> = {}\n const sortedBreakpoints = getSortedBreakpoints()\n \n for (const breakpoint of sortedBreakpoints) {\n const breakpointValue = value[breakpoint]\n if (breakpointValue === undefined) continue\n \n const cssProperty = this.toCSSPropertyName(property)\n const cssValue = this.formatCSSValue(property, breakpointValue)\n \n if (breakpoint === 'base') {\n // Base styles (no media query needed for mobile-first)\n baseStyles[cssProperty] = cssValue\n } else {\n // Generate media query for this breakpoint\n const query = generateMediaQuery(breakpoint)\n const styles = { [cssProperty]: cssValue }\n \n mediaQueries.push({\n breakpoint,\n query,\n styles,\n selector: this.options.selector\n })\n }\n }\n \n return { mediaQueries, baseStyles: Object.keys(baseStyles).length > 0 ? baseStyles : undefined }\n }\n \n /**\n * Generate CSS rules from media queries and base styles\n */\n private generateCSSRules(\n mediaQueries: GeneratedMediaQuery[], \n baseStyles: Record<string, string | number>\n ): string[] {\n const rules: string[] = []\n \n // Generate base styles rule (mobile-first)\n if (Object.keys(baseStyles).length > 0) {\n const baseRule = this.generateCSSRule(this.options.selector, baseStyles)\n rules.push(baseRule)\n }\n \n // Generate media query rules\n const groupedQueries = this.groupQueriesByMediaQuery(mediaQueries)\n \n for (const [query, queryMediaQueries] of Object.entries(groupedQueries)) {\n if (query === '') continue // Skip empty queries (base styles)\n \n // Combine all styles for this media query\n const combinedStyles: Record<string, string | number> = {}\n for (const mq of queryMediaQueries) {\n Object.assign(combinedStyles, mq.styles)\n }\n \n const mediaRule = this.generateMediaQueryRule(query, this.options.selector, combinedStyles)\n rules.push(mediaRule)\n }\n \n return rules\n }\n \n /**\n * Group media queries by their query string for optimization\n */\n private groupQueriesByMediaQuery(mediaQueries: GeneratedMediaQuery[]): Record<string, GeneratedMediaQuery[]> {\n const grouped: Record<string, GeneratedMediaQuery[]> = {}\n \n for (const mq of mediaQueries) {\n if (!grouped[mq.query]) {\n grouped[mq.query] = []\n }\n grouped[mq.query].push(mq)\n }\n \n return grouped\n }\n \n /**\n * Generate a single CSS rule\n */\n private generateCSSRule(selector: string, styles: Record<string, string | number>): string {\n const { generateMinified, includeComments } = this.options\n const indent = generateMinified ? '' : ' '\n const newline = generateMinified ? '' : '\\n'\n const space = generateMinified ? '' : ' '\n \n let rule = `${selector}${space}{${newline}`\n \n for (const [property, value] of Object.entries(styles)) {\n rule += `${indent}${property}:${space}${value};${newline}`\n }\n \n rule += `}${newline}`\n \n if (includeComments && !generateMinified) {\n rule = `/* Base styles (mobile-first) */${newline}${rule}`\n }\n \n return rule\n }\n \n /**\n * Generate a CSS media query rule\n */\n private generateMediaQueryRule(\n query: string, \n selector: string, \n styles: Record<string, string | number>\n ): string {\n const { generateMinified, includeComments } = this.options\n const indent = generateMinified ? '' : ' '\n const doubleIndent = generateMinified ? '' : ' '\n const newline = generateMinified ? '' : '\\n'\n const space = generateMinified ? '' : ' '\n \n let rule = `@media ${query}${space}{${newline}`\n rule += `${indent}${selector}${space}{${newline}`\n \n for (const [property, value] of Object.entries(styles)) {\n rule += `${doubleIndent}${property}:${space}${value};${newline}`\n }\n \n rule += `${indent}}${newline}`\n rule += `}${newline}`\n \n if (includeComments && !generateMinified) {\n const breakpoint = this.getBreakpointFromQuery(query)\n rule = `/* ${breakpoint} styles */${newline}${rule}`\n }\n \n return rule\n }\n \n /**\n * Convert camelCase property to CSS kebab-case\n */\n private toCSSProperty(property: string): string {\n return property.replace(/[A-Z]/g, match => `-${match.toLowerCase()}`)\n }\n \n /**\n * Format CSS value with appropriate units and validation\n */\n private formatCSSValue(property: string, value: any): string {\n if (value === null || value === undefined) {\n return 'inherit'\n }\n \n // Handle numeric values that need units\n if (typeof value === 'number') {\n const unitlessProperties = [\n 'opacity', 'z-index', 'font-weight', 'line-height', \n 'flex-grow', 'flex-shrink', 'order', 'grid-column-start',\n 'grid-column-end', 'grid-row-start', 'grid-row-end'\n ]\n \n const cssProperty = this.toCSSProperty(property)\n if (unitlessProperties.includes(cssProperty)) {\n return this.addImportantIfNeeded(property, value.toString())\n }\n \n // Add px unit for dimension properties\n const dimensionProperties = [\n 'width', 'height', 'min-width', 'max-width', 'min-height', 'max-height',\n 'padding', 'margin', 'border-width', 'border-radius', 'top', 'right', \n 'bottom', 'left', 'font-size', 'letter-spacing', 'text-indent'\n ]\n \n if (dimensionProperties.some(prop => cssProperty.includes(prop))) {\n return this.addImportantIfNeeded(property, `${value}px`)\n }\n }\n \n return this.addImportantIfNeeded(property, value.toString())\n }\n\n /**\n * Add !important for properties that need to override base component styles\n */\n private addImportantIfNeeded(property: string, value: string): string {\n const conflictingProperties = [\n 'flexDirection', 'flex-direction',\n 'justifyContent', 'justify-content', \n 'alignItems', 'align-items',\n 'display'\n ]\n \n const cssProperty = this.toCSSProperty(property)\n if (conflictingProperties.includes(property) || conflictingProperties.includes(cssProperty)) {\n return `${value} !important`\n }\n \n return value\n }\n\n /**\n * Convert property name to appropriate CSS property (including custom properties)\n */\n private toCSSPropertyName(property: string): string {\n return this.toCSSProperty(property)\n }\n \n /**\n * Extract breakpoint name from media query for comments\n */\n private getBreakpointFromQuery(query: string): string {\n const breakpointConfig = getCurrentBreakpointConfig()\n \n for (const [breakpoint, value] of Object.entries(breakpointConfig)) {\n if (query.includes(value)) {\n return breakpoint\n }\n }\n \n return 'custom'\n }\n}\n\n/**\n * Utility function to generate responsive CSS for a single property\n */\nexport function generateResponsiveProperty(\n selector: string,\n property: string,\n value: ResponsiveValue<any>,\n options?: Partial<CSSGenerationOptions>\n): string[] {\n if (!isResponsiveValue(value)) {\n // Non-responsive value - return simple CSS rule\n const cssProperty = property.replace(/[A-Z]/g, match => `-${match.toLowerCase()}`)\n const cssValue = typeof value === 'number' ? `${value}px` : value.toString()\n return [`${selector} { ${cssProperty}: ${cssValue}; }`]\n }\n \n const generator = new ResponsiveCSSGenerator({ selector, ...options })\n const config = { [property]: value }\n const result = generator.generateResponsiveCSS(config)\n \n return result.cssRules\n}\n\n/**\n * Utility function to generate media query for custom conditions\n */\nexport function generateCustomMediaQuery(\n selector: string,\n mediaQueryConfig: MediaQueryConfig,\n options?: Partial<CSSGenerationOptions>\n): string {\n const { generateMinified = false } = options || {}\n const indent = generateMinified ? '' : ' '\n const newline = generateMinified ? '' : '\\n'\n const space = generateMinified ? '' : ' '\n \n let rule = `@media ${mediaQueryConfig.query}${space}{${newline}`\n rule += `${indent}${selector}${space}{${newline}`\n \n for (const [property, value] of Object.entries(mediaQueryConfig.styles)) {\n const cssProperty = property.replace(/[A-Z]/g, match => `-${match.toLowerCase()}`)\n const cssValue = typeof value === 'number' ? `${value}px` : value.toString()\n rule += `${indent}${indent}${cssProperty}:${space}${cssValue};${newline}`\n }\n \n rule += `${indent}}${newline}`\n rule += `}${newline}`\n \n return rule\n}\n\n/**\n * CSS injection utilities for runtime application\n */\nexport class CSSInjector {\n private static styleSheet: CSSStyleSheet | null = null\n private static injectedRules = new Set<string>()\n \n /**\n * Get or create the tachUI responsive stylesheet\n */\n private static getStyleSheet(): CSSStyleSheet {\n if (this.styleSheet) {\n return this.styleSheet\n }\n \n const style = document.createElement('style')\n style.setAttribute('data-tachui-responsive', 'true')\n document.head.appendChild(style)\n \n this.styleSheet = style.sheet as CSSStyleSheet\n return this.styleSheet\n }\n\n /**\n * Inject CSS rules into the document\n */\n static injectCSS(rules: string[]): void {\n if (typeof document === 'undefined') {\n return // Skip on server-side\n }\n \n const styleSheet = this.getStyleSheet()\n \n for (const rule of rules) {\n if (this.injectedRules.has(rule)) {\n continue // Skip duplicate rules\n }\n \n try {\n styleSheet.insertRule(rule, styleSheet.cssRules.length)\n this.injectedRules.add(rule)\n } catch (error) {\n console.warn('Failed to inject CSS rule:', rule, error)\n }\n }\n }\n \n /**\n * Clear all injected responsive CSS\n */\n static clearCSS(): void {\n if (this.styleSheet) {\n while (this.styleSheet.cssRules.length > 0) {\n this.styleSheet.deleteRule(0)\n }\n this.injectedRules.clear()\n }\n }\n \n /**\n * Check if a rule has been injected\n */\n static hasRule(rule: string): boolean {\n return this.injectedRules.has(rule)\n }\n}"],"names":["ResponsiveCSSGenerator","options","__publicField","config","mediaQueries","cssRules","fallbackStyles","hasResponsiveStyles","property","value","isResponsiveValue","result","baseStyles","sortedBreakpoints","getSortedBreakpoints","breakpoint","breakpointValue","cssProperty","cssValue","query","generateMediaQuery","styles","rules","baseRule","groupedQueries","queryMediaQueries","combinedStyles","mq","mediaRule","grouped","selector","generateMinified","includeComments","indent","newline","space","rule","doubleIndent","match","unitlessProperties","prop","conflictingProperties","breakpointConfig","getCurrentBreakpointConfig","generateResponsiveProperty","generator","generateCustomMediaQuery","mediaQueryConfig","CSSInjector","style","styleSheet","error"],"mappings":"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"}
@@ -1,261 +0,0 @@
1
- import { isResponsiveValue as h } from "./types.js";
2
- import { getSortedBreakpoints as y, generateMediaQuery as g, getCurrentBreakpointConfig as m } from "./breakpoints.js";
3
- var $ = Object.defineProperty, b = (a, e, t) => e in a ? $(a, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : a[e] = t, f = (a, e, t) => b(a, typeof e != "symbol" ? e + "" : e, t);
4
- class C {
5
- constructor(e) {
6
- f(this, "options"), this.options = {
7
- generateMinified: !1,
8
- includeComments: !0,
9
- optimizeOutput: !0,
10
- mobileFirst: !0,
11
- ...e
12
- };
13
- }
14
- /**
15
- * Generate complete responsive CSS from a style configuration
16
- */
17
- generateResponsiveCSS(e) {
18
- const t = [], s = [], r = {};
19
- let o = !1;
20
- for (const [n, c] of Object.entries(e))
21
- if (h(c)) {
22
- o = !0;
23
- const i = this.generatePropertyMediaQueries(n, c);
24
- t.push(...i.mediaQueries), i.baseStyles && Object.assign(r, i.baseStyles);
25
- } else
26
- r[this.toCSSPropertyName(n)] = this.formatCSSValue(n, c);
27
- return s.push(...this.generateCSSRules(t, r)), {
28
- cssRules: s,
29
- mediaQueries: t,
30
- fallbackStyles: r,
31
- hasResponsiveStyles: o
32
- };
33
- }
34
- /**
35
- * Generate media queries for a single property
36
- */
37
- generatePropertyMediaQueries(e, t) {
38
- const s = [], r = {}, o = y();
39
- for (const n of o) {
40
- const c = t[n];
41
- if (c === void 0) continue;
42
- const i = this.toCSSPropertyName(e), u = this.formatCSSValue(e, c);
43
- if (n === "base")
44
- r[i] = u;
45
- else {
46
- const l = g(n), d = { [i]: u };
47
- s.push({
48
- breakpoint: n,
49
- query: l,
50
- styles: d,
51
- selector: this.options.selector
52
- });
53
- }
54
- }
55
- return { mediaQueries: s, baseStyles: Object.keys(r).length > 0 ? r : void 0 };
56
- }
57
- /**
58
- * Generate CSS rules from media queries and base styles
59
- */
60
- generateCSSRules(e, t) {
61
- const s = [];
62
- if (Object.keys(t).length > 0) {
63
- const o = this.generateCSSRule(this.options.selector, t);
64
- s.push(o);
65
- }
66
- const r = this.groupQueriesByMediaQuery(e);
67
- for (const [o, n] of Object.entries(r)) {
68
- if (o === "") continue;
69
- const c = {};
70
- for (const u of n)
71
- Object.assign(c, u.styles);
72
- const i = this.generateMediaQueryRule(o, this.options.selector, c);
73
- s.push(i);
74
- }
75
- return s;
76
- }
77
- /**
78
- * Group media queries by their query string for optimization
79
- */
80
- groupQueriesByMediaQuery(e) {
81
- const t = {};
82
- for (const s of e)
83
- t[s.query] || (t[s.query] = []), t[s.query].push(s);
84
- return t;
85
- }
86
- /**
87
- * Generate a single CSS rule
88
- */
89
- generateCSSRule(e, t) {
90
- const { generateMinified: s, includeComments: r } = this.options, o = s ? "" : " ", n = s ? "" : `
91
- `, c = s ? "" : " ";
92
- let i = `${e}${c}{${n}`;
93
- for (const [u, l] of Object.entries(t))
94
- i += `${o}${u}:${c}${l};${n}`;
95
- return i += `}${n}`, r && !s && (i = `/* Base styles (mobile-first) */${n}${i}`), i;
96
- }
97
- /**
98
- * Generate a CSS media query rule
99
- */
100
- generateMediaQueryRule(e, t, s) {
101
- const { generateMinified: r, includeComments: o } = this.options, n = r ? "" : " ", c = r ? "" : " ", i = r ? "" : `
102
- `, u = r ? "" : " ";
103
- let l = `@media ${e}${u}{${i}`;
104
- l += `${n}${t}${u}{${i}`;
105
- for (const [d, p] of Object.entries(s))
106
- l += `${c}${d}:${u}${p};${i}`;
107
- return l += `${n}}${i}`, l += `}${i}`, o && !r && (l = `/* ${this.getBreakpointFromQuery(e)} styles */${i}${l}`), l;
108
- }
109
- /**
110
- * Convert camelCase property to CSS kebab-case
111
- */
112
- toCSSProperty(e) {
113
- return e.replace(/[A-Z]/g, (t) => `-${t.toLowerCase()}`);
114
- }
115
- /**
116
- * Format CSS value with appropriate units and validation
117
- */
118
- formatCSSValue(e, t) {
119
- if (t == null)
120
- return "inherit";
121
- if (typeof t == "number") {
122
- const s = [
123
- "opacity",
124
- "z-index",
125
- "font-weight",
126
- "line-height",
127
- "flex-grow",
128
- "flex-shrink",
129
- "order",
130
- "grid-column-start",
131
- "grid-column-end",
132
- "grid-row-start",
133
- "grid-row-end"
134
- ], r = this.toCSSProperty(e);
135
- if (s.includes(r))
136
- return this.addImportantIfNeeded(e, t.toString());
137
- if ([
138
- "width",
139
- "height",
140
- "min-width",
141
- "max-width",
142
- "min-height",
143
- "max-height",
144
- "padding",
145
- "margin",
146
- "border-width",
147
- "border-radius",
148
- "top",
149
- "right",
150
- "bottom",
151
- "left",
152
- "font-size",
153
- "letter-spacing",
154
- "text-indent"
155
- ].some((n) => r.includes(n)))
156
- return this.addImportantIfNeeded(e, `${t}px`);
157
- }
158
- return this.addImportantIfNeeded(e, t.toString());
159
- }
160
- /**
161
- * Add !important for properties that need to override base component styles
162
- */
163
- addImportantIfNeeded(e, t) {
164
- const s = [
165
- "flexDirection",
166
- "flex-direction",
167
- "justifyContent",
168
- "justify-content",
169
- "alignItems",
170
- "align-items",
171
- "display"
172
- ], r = this.toCSSProperty(e);
173
- return s.includes(e) || s.includes(r) ? `${t} !important` : t;
174
- }
175
- /**
176
- * Convert property name to appropriate CSS property (including custom properties)
177
- */
178
- toCSSPropertyName(e) {
179
- return this.toCSSProperty(e);
180
- }
181
- /**
182
- * Extract breakpoint name from media query for comments
183
- */
184
- getBreakpointFromQuery(e) {
185
- const t = m();
186
- for (const [s, r] of Object.entries(t))
187
- if (e.includes(r))
188
- return s;
189
- return "custom";
190
- }
191
- }
192
- function j(a, e, t, s) {
193
- if (!h(t)) {
194
- const c = e.replace(/[A-Z]/g, (u) => `-${u.toLowerCase()}`), i = typeof t == "number" ? `${t}px` : t.toString();
195
- return [`${a} { ${c}: ${i}; }`];
196
- }
197
- const r = new C({ selector: a, ...s }), o = { [e]: t };
198
- return r.generateResponsiveCSS(o).cssRules;
199
- }
200
- function w(a, e, t) {
201
- const { generateMinified: s = !1 } = t || {}, r = s ? "" : " ", o = s ? "" : `
202
- `, n = s ? "" : " ";
203
- let c = `@media ${e.query}${n}{${o}`;
204
- c += `${r}${a}${n}{${o}`;
205
- for (const [i, u] of Object.entries(e.styles)) {
206
- const l = i.replace(/[A-Z]/g, (p) => `-${p.toLowerCase()}`), d = typeof u == "number" ? `${u}px` : u.toString();
207
- c += `${r}${r}${l}:${n}${d};${o}`;
208
- }
209
- return c += `${r}}${o}`, c += `}${o}`, c;
210
- }
211
- class S {
212
- /**
213
- * Get or create the tachUI responsive stylesheet
214
- */
215
- static getStyleSheet() {
216
- if (this.styleSheet)
217
- return this.styleSheet;
218
- const e = document.createElement("style");
219
- return e.setAttribute("data-tachui-responsive", "true"), document.head.appendChild(e), this.styleSheet = e.sheet, this.styleSheet;
220
- }
221
- /**
222
- * Inject CSS rules into the document
223
- */
224
- static injectCSS(e) {
225
- if (typeof document > "u")
226
- return;
227
- const t = this.getStyleSheet();
228
- for (const s of e)
229
- if (!this.injectedRules.has(s))
230
- try {
231
- t.insertRule(s, t.cssRules.length), this.injectedRules.add(s);
232
- } catch (r) {
233
- console.warn("Failed to inject CSS rule:", s, r);
234
- }
235
- }
236
- /**
237
- * Clear all injected responsive CSS
238
- */
239
- static clearCSS() {
240
- if (this.styleSheet) {
241
- for (; this.styleSheet.cssRules.length > 0; )
242
- this.styleSheet.deleteRule(0);
243
- this.injectedRules.clear();
244
- }
245
- }
246
- /**
247
- * Check if a rule has been injected
248
- */
249
- static hasRule(e) {
250
- return this.injectedRules.has(e);
251
- }
252
- }
253
- f(S, "styleSheet", null);
254
- f(S, "injectedRules", /* @__PURE__ */ new Set());
255
- export {
256
- S as CSSInjector,
257
- C as ResponsiveCSSGenerator,
258
- w as generateCustomMediaQuery,
259
- j as generateResponsiveProperty
260
- };
261
- //# sourceMappingURL=css-generator.js.map