@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,1385 +0,0 @@
1
- /**
2
- * Web Viewport Adapter
3
- *
4
- * Handles viewport management for web browsers using modals, portals, and popup windows.
5
- * Provides fallback strategies for different browser capabilities.
6
- */
7
-
8
- import { createSignal } from '../../reactive'
9
- import type { Signal } from '../../reactive/types'
10
- import type { ComponentInstance } from '../../runtime/types'
11
- import { mountComponentTree } from '../../runtime/dom-bridge'
12
- import { detectViewportEnvironment, type PlatformDetectionConfig } from '../platform-detection'
13
- import {
14
- ViewportAdapter,
15
- type ViewportEnvironment,
16
- type ViewportInstance,
17
- type ViewportState,
18
- type ViewportType,
19
- type WindowConfig,
20
- } from '../types'
21
-
22
- /**
23
- * Web-specific viewport adapter
24
- */
25
- export class WebViewportAdapter extends ViewportAdapter {
26
- readonly environment: ViewportEnvironment
27
- private portals = new Map<string, WebPortalInstance>()
28
- private modals = new Map<string, WebModalInstance>()
29
- private popups = new Map<string, WebPopupInstance>()
30
- private portalContainer: HTMLElement | null = null
31
- private broadcastChannel: BroadcastChannel | null = null
32
-
33
- constructor(config: PlatformDetectionConfig = {}) {
34
- super()
35
- this.environment = detectViewportEnvironment(config)
36
- this.initializePortalContainer()
37
- }
38
-
39
- /**
40
- * Check if we can create a window with given config
41
- */
42
- canCreateWindow(config: WindowConfig): boolean {
43
- // Always can create modals and portals
44
- if (!config.preferNativeWindow) {
45
- return true
46
- }
47
-
48
- // Check if we can create popup windows
49
- try {
50
- return this.environment.capabilities.multiWindow
51
- } catch {
52
- return false
53
- }
54
- }
55
-
56
- /**
57
- * Create a viewport instance
58
- */
59
- createWindow(config: WindowConfig): ViewportInstance {
60
- const windowType = this.determineWindowType(config)
61
-
62
- switch (windowType) {
63
- case 'window':
64
- return this.createPopupWindow(config)
65
-
66
- case 'modal':
67
- return this.createModal(config)
68
-
69
- case 'portal':
70
- return this.createPortal(config)
71
-
72
- default:
73
- return this.createModal(config)
74
- }
75
- }
76
-
77
- /**
78
- * Destroy a window
79
- */
80
- async destroyWindow(windowId: string): Promise<void> {
81
- // Try each type
82
- const portal = this.portals.get(windowId)
83
- if (portal) {
84
- portal.dispose()
85
- this.portals.delete(windowId)
86
- return
87
- }
88
-
89
- const modal = this.modals.get(windowId)
90
- if (modal) {
91
- modal.dispose()
92
- this.modals.delete(windowId)
93
- return
94
- }
95
-
96
- const popup = this.popups.get(windowId)
97
- if (popup) {
98
- popup.dispose()
99
- this.popups.delete(windowId)
100
- return
101
- }
102
- }
103
-
104
- /**
105
- * Set up cross-window communication
106
- */
107
- setupCrossWindowCommunication(): void {
108
- if ('BroadcastChannel' in window) {
109
- // Use BroadcastChannel for same-origin communication
110
- this.broadcastChannel = new BroadcastChannel('tachui-viewport')
111
-
112
- this.broadcastChannel.addEventListener('message', (event: MessageEvent) => {
113
- this.handleCrossWindowMessage(event.data)
114
- })
115
- } else {
116
- // Fallback to localStorage events
117
- const handleStorage = (event: StorageEvent) => {
118
- if (event.key === 'tachui-viewport-message') {
119
- try {
120
- const message = JSON.parse(event.newValue || '{}')
121
- this.handleCrossWindowMessage(message)
122
- } catch {
123
- // Ignore malformed messages
124
- }
125
- }
126
- }
127
- if (typeof window !== 'undefined') {
128
- ;(window as any).addEventListener('storage', handleStorage)
129
- }
130
- }
131
- }
132
-
133
- /**
134
- * Broadcast message to other windows
135
- */
136
- broadcastMessage(message: any, _excludeWindow?: string): void {
137
- const messageData = {
138
- ...message,
139
- timestamp: Date.now(),
140
- source: window.location.href,
141
- }
142
-
143
- if (this.broadcastChannel) {
144
- this.broadcastChannel.postMessage(messageData)
145
- } else {
146
- // Fallback to localStorage
147
- localStorage.setItem('tachui-viewport-message', JSON.stringify(messageData))
148
- // Clear after a moment to avoid storage bloat
149
- setTimeout(() => {
150
- localStorage.removeItem('tachui-viewport-message')
151
- }, 100)
152
- }
153
- }
154
-
155
- /**
156
- * Optimize for web platform
157
- */
158
- optimizeForPlatform(): void {
159
- // Set up CSS custom properties for theming
160
- document.documentElement.style.setProperty('--tachui-modal-backdrop-blur', '8px')
161
- document.documentElement.style.setProperty('--tachui-modal-animation-duration', '200ms')
162
- document.documentElement.style.setProperty('--tachui-modal-z-index', '1000')
163
-
164
- // Set up global styles for modals if needed
165
- this.injectGlobalStyles()
166
- }
167
-
168
- /**
169
- * Create popup window (native browser window)
170
- */
171
- private createPopupWindow(config: WindowConfig): WebPopupInstance {
172
- const popup = new WebPopupInstance(config)
173
- this.popups.set(config.id, popup)
174
- return popup
175
- }
176
-
177
- /**
178
- * Create modal overlay
179
- */
180
- protected createModal(config: WindowConfig): WebModalInstance {
181
- const modal = new WebModalInstance(config)
182
- this.modals.set(config.id, modal)
183
- return modal
184
- }
185
-
186
- /**
187
- * Create portal
188
- */
189
- protected createPortal(config: WindowConfig): WebPortalInstance {
190
- const portal = new WebPortalInstance(config, this.portalContainer!)
191
- this.portals.set(config.id, portal)
192
- return portal
193
- }
194
-
195
- /**
196
- * Determine optimal window type
197
- */
198
- private determineWindowType(config: WindowConfig): ViewportType {
199
- if (config.preferNativeWindow && this.environment.capabilities.multiWindow) {
200
- return 'window'
201
- }
202
-
203
- if (config.modal !== false) {
204
- return 'modal'
205
- }
206
-
207
- return 'portal'
208
- }
209
-
210
- /**
211
- * Initialize portal container
212
- */
213
- private initializePortalContainer(): void {
214
- // For single-page apps, try to use the existing app container first
215
- let container = document.getElementById('app')
216
-
217
- if (container) {
218
- this.portalContainer = container
219
- return
220
- }
221
-
222
- // Fallback to creating a separate portal container
223
- container = document.getElementById('tachui-portals')
224
-
225
- if (!container) {
226
- container = document.createElement('div')
227
- container.id = 'tachui-portals'
228
- container.style.position = 'relative'
229
- container.style.zIndex = '999'
230
- document.body.appendChild(container)
231
- }
232
-
233
- this.portalContainer = container
234
- }
235
-
236
- /**
237
- * Handle cross-window messages
238
- */
239
- private handleCrossWindowMessage(message: any): void {
240
- // Forward to all viewport instances
241
- this.portals.forEach((portal) => portal.receiveMessage(message))
242
- this.modals.forEach((modal) => modal.receiveMessage(message))
243
- this.popups.forEach((popup) => popup.receiveMessage(message))
244
- }
245
-
246
- /**
247
- * Inject global CSS styles
248
- */
249
- private injectGlobalStyles(): void {
250
- const styleId = 'tachui-viewport-styles'
251
-
252
- if (document.getElementById(styleId)) {
253
- return // Already injected
254
- }
255
-
256
- const style = document.createElement('style')
257
- style.id = styleId
258
- style.textContent = `
259
- .tachui-modal-backdrop {
260
- position: fixed;
261
- top: 0;
262
- left: 0;
263
- right: 0;
264
- bottom: 0;
265
- background: rgba(0, 0, 0, 0.5);
266
- backdrop-filter: blur(var(--tachui-modal-backdrop-blur, 8px));
267
- z-index: var(--tachui-modal-z-index, 1000);
268
- display: flex;
269
- align-items: center;
270
- justify-content: center;
271
- animation: tachui-fade-in var(--tachui-modal-animation-duration, 200ms) ease-out;
272
- }
273
-
274
- .tachui-modal-content {
275
- background: white;
276
- border-radius: 8px;
277
- box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
278
- max-width: 90vw;
279
- max-height: 90vh;
280
- overflow: auto;
281
- animation: tachui-scale-in var(--tachui-modal-animation-duration, 200ms) ease-out;
282
- }
283
-
284
- .tachui-portal {
285
- position: relative;
286
- }
287
-
288
- @keyframes tachui-fade-in {
289
- from {
290
- opacity: 0;
291
- }
292
- to {
293
- opacity: 1;
294
- }
295
- }
296
-
297
- @keyframes tachui-scale-in {
298
- from {
299
- opacity: 0;
300
- transform: scale(0.95);
301
- }
302
- to {
303
- opacity: 1;
304
- transform: scale(1);
305
- }
306
- }
307
-
308
- @media (prefers-reduced-motion: reduce) {
309
- .tachui-modal-backdrop,
310
- .tachui-modal-content {
311
- animation: none;
312
- }
313
- }
314
- `
315
-
316
- document.head.appendChild(style)
317
- }
318
- }
319
-
320
- /**
321
- * Web popup window instance (using window.open)
322
- */
323
- class WebPopupInstance implements ViewportInstance {
324
- readonly id: string
325
- readonly type: ViewportType = 'window'
326
- readonly config: WindowConfig
327
- state: Signal<ViewportState>
328
-
329
- private nativeWindow: Window | null = null
330
- private messageHandlers = new Set<(message: any) => void>()
331
- private eventHandlers = new Map<string, Set<() => void>>()
332
- private setState: (
333
- value: ViewportState | ((prev: ViewportState) => ViewportState)
334
- ) => ViewportState
335
-
336
- constructor(config: WindowConfig) {
337
- this.id = config.id
338
- this.config = config
339
-
340
- const [state, setState] = createSignal<ViewportState>({
341
- id: config.id,
342
- title: config.title || config.id,
343
- isVisible: false,
344
- isMinimized: false,
345
- isMaximized: false,
346
- isFullscreen: false,
347
- isFocused: false,
348
- bounds: {
349
- x: config.x || 100,
350
- y: config.y || 100,
351
- width: config.width || 800,
352
- height: config.height || 600,
353
- },
354
- // Phase 2: Enhanced state properties
355
- isPooled: false,
356
- lastUsed: Date.now(),
357
- groupId: undefined,
358
- tabIndex: undefined,
359
- parentWindowId: undefined,
360
- })
361
-
362
- this.state = state as Signal<ViewportState>
363
- this.setState = setState
364
- }
365
-
366
- render(_component: ComponentInstance): void {
367
- // For popup windows, we need to render the component in the popup's document
368
- if (!this.nativeWindow) return
369
-
370
- // This would need integration with TachUI's rendering system
371
- // For now, just set basic content
372
- this.nativeWindow.document.title = this.config.title || this.config.id
373
- }
374
-
375
- async show(): Promise<void> {
376
- if (this.nativeWindow && !this.nativeWindow.closed) {
377
- this.nativeWindow.focus()
378
- return
379
- }
380
-
381
- const features = this.buildWindowFeatures()
382
- this.nativeWindow = window.open('', this.config.id, features)
383
-
384
- if (!this.nativeWindow) {
385
- throw new Error('Failed to open popup window (likely blocked by popup blocker)')
386
- }
387
-
388
- this.setupPopupEventHandlers()
389
-
390
- // Update state
391
- this.setState((prevState) => ({
392
- ...prevState,
393
- isVisible: true,
394
- isFocused: true,
395
- }))
396
- }
397
-
398
- async hide(): Promise<void> {
399
- if (this.nativeWindow && !this.nativeWindow.closed) {
400
- this.nativeWindow.blur()
401
- }
402
- }
403
-
404
- async focus(): Promise<void> {
405
- if (this.nativeWindow && !this.nativeWindow.closed) {
406
- this.nativeWindow.focus()
407
- }
408
- }
409
-
410
- async minimize(): Promise<void> {
411
- // Not supported in web popups
412
- }
413
-
414
- async maximize(): Promise<void> {
415
- // Not supported in web popups
416
- }
417
-
418
- async restore(): Promise<void> {
419
- // Not supported in web popups
420
- }
421
-
422
- async close(): Promise<void> {
423
- if (this.nativeWindow && !this.nativeWindow.closed) {
424
- this.nativeWindow.close()
425
- }
426
- this.dispose()
427
- }
428
-
429
- dispose(): void {
430
- this.messageHandlers.clear()
431
- this.eventHandlers.clear()
432
- this.nativeWindow = null
433
- }
434
-
435
- postMessage(message: any): void {
436
- if (this.nativeWindow && !this.nativeWindow.closed) {
437
- this.nativeWindow.postMessage(message, '*')
438
- }
439
- }
440
-
441
- onMessage(handler: (message: any) => void): () => void {
442
- this.messageHandlers.add(handler)
443
- return () => this.messageHandlers.delete(handler)
444
- }
445
-
446
- receiveMessage(message: any): void {
447
- this.messageHandlers.forEach((handler) => handler(message))
448
- }
449
-
450
- onShow(handler: () => void): () => void {
451
- return this.addEventListener('show', handler)
452
- }
453
-
454
- onHide(handler: () => void): () => void {
455
- return this.addEventListener('hide', handler)
456
- }
457
-
458
- onFocus(handler: () => void): () => void {
459
- return this.addEventListener('focus', handler)
460
- }
461
-
462
- onBlur(handler: () => void): () => void {
463
- return this.addEventListener('blur', handler)
464
- }
465
-
466
- onResize(_handler: (bounds: ViewportState['bounds']) => void): () => void {
467
- // Web popups don't provide reliable resize events
468
- return () => {}
469
- }
470
-
471
- onClose(handler: () => void): () => void {
472
- return this.addEventListener('close', handler)
473
- }
474
-
475
- private addEventListener(event: string, handler: () => void): () => void {
476
- if (!this.eventHandlers.has(event)) {
477
- this.eventHandlers.set(event, new Set())
478
- }
479
-
480
- this.eventHandlers.get(event)!.add(handler)
481
-
482
- return () => {
483
- this.eventHandlers.get(event)?.delete(handler)
484
- }
485
- }
486
-
487
- private emit(event: string): void {
488
- const handlers = this.eventHandlers.get(event)
489
- if (handlers) {
490
- handlers.forEach((handler) => handler())
491
- }
492
- }
493
-
494
- private buildWindowFeatures(): string {
495
- const features = []
496
-
497
- if (this.config.width) features.push(`width=${this.config.width}`)
498
- if (this.config.height) features.push(`height=${this.config.height}`)
499
- if (this.config.x) features.push(`left=${this.config.x}`)
500
- if (this.config.y) features.push(`top=${this.config.y}`)
501
-
502
- features.push(`resizable=${this.config.resizable !== false ? 'yes' : 'no'}`)
503
- features.push('scrollbars=yes')
504
- features.push('status=no')
505
- features.push('toolbar=no')
506
- features.push('menubar=no')
507
- features.push('location=no')
508
-
509
- return features.join(',')
510
- }
511
-
512
- private setupPopupEventHandlers(): void {
513
- if (!this.nativeWindow) return
514
-
515
- // Check if window is closed
516
- const checkClosed = () => {
517
- if (this.nativeWindow?.closed) {
518
- this.emit('close')
519
- return
520
- }
521
- setTimeout(checkClosed, 1000)
522
- }
523
- checkClosed()
524
-
525
- // Listen for messages
526
- window.addEventListener('message', (event) => {
527
- if (event.source === this.nativeWindow) {
528
- this.messageHandlers.forEach((handler) => handler(event.data))
529
- }
530
- })
531
- }
532
-
533
- // ==================== Phase 2: Enhanced Methods ====================
534
-
535
- /**
536
- * Window pooling and reuse
537
- */
538
- async prepareForReuse(): Promise<void> {
539
- // Clear current content and reset state for reuse
540
- if (this.nativeWindow && !this.nativeWindow.closed) {
541
- this.nativeWindow.document.body.innerHTML = ''
542
- this.nativeWindow.document.title = ''
543
- }
544
- this.messageHandlers.clear()
545
- }
546
-
547
- isReusable(): boolean {
548
- return this.nativeWindow != null && !this.nativeWindow.closed
549
- }
550
-
551
- markAsUsed(): void {
552
- this.setState((prev) => ({
553
- ...prev,
554
- lastUsed: Date.now(),
555
- }))
556
- }
557
-
558
- async returnToPool(): Promise<void> {
559
- await this.hide()
560
- this.setState((prev) => ({
561
- ...prev,
562
- isPooled: true,
563
- lastUsed: Date.now(),
564
- }))
565
- }
566
-
567
- /**
568
- * State synchronization (limited in popup windows due to cross-origin restrictions)
569
- */
570
- syncState<T>(_key: string, _value: T): void {
571
- // Store locally for this window
572
- if (!this.nativeWindow || this.nativeWindow.closed) return
573
-
574
- try {
575
- // Try to sync via postMessage (may fail due to CORS)
576
- this.nativeWindow.postMessage({ type: 'sync_state', key: _key, value: _value }, '*')
577
- } catch (error) {
578
- console.warn('Failed to sync state to popup window:', error)
579
- }
580
- }
581
-
582
- getSharedState<T>(_key: string): T | undefined {
583
- // Cannot access shared state from popup due to security restrictions
584
- return undefined
585
- }
586
-
587
- onSharedStateChange<T>(_key: string, _callback: (value: T) => void): () => void {
588
- // Limited implementation due to popup security restrictions
589
- return () => {} // No-op unsubscribe
590
- }
591
-
592
- /**
593
- * Tab grouping (not supported for popup windows)
594
- */
595
- async attachToTab(_tabContainer: ViewportInstance): Promise<void> {
596
- throw new Error('Tab grouping not supported for popup windows')
597
- }
598
-
599
- async detachFromTab(): Promise<ViewportInstance> {
600
- return this // Already detached
601
- }
602
-
603
- getTabContainer(): ViewportInstance | null {
604
- return null
605
- }
606
-
607
- getTabIndex(): number {
608
- return this.state().tabIndex || 0
609
- }
610
-
611
- setTabIndex(index: number): void {
612
- this.setState((prev) => ({
613
- ...prev,
614
- tabIndex: index,
615
- }))
616
- }
617
-
618
- /**
619
- * Parent-child relationships (limited for popup windows)
620
- */
621
- setParentWindow(parent: ViewportInstance): void {
622
- this.setState((prev) => ({
623
- ...prev,
624
- parentWindowId: parent.id,
625
- }))
626
- }
627
-
628
- getParentWindow(): ViewportInstance | null {
629
- // Cannot access parent window reference due to security
630
- return null
631
- }
632
-
633
- getChildWindows(): ViewportInstance[] {
634
- // Cannot track child windows from popup
635
- return []
636
- }
637
-
638
- addChildWindow(_child: ViewportInstance): void {
639
- // Not supported for popup windows
640
- }
641
-
642
- removeChildWindow(_childId: string): void {
643
- // Not supported for popup windows
644
- }
645
- }
646
-
647
- /**
648
- * Web modal instance (overlay on current page)
649
- */
650
- class WebModalInstance implements ViewportInstance {
651
- readonly id: string
652
- readonly type: ViewportType = 'modal'
653
- readonly config: WindowConfig
654
- state: Signal<ViewportState>
655
-
656
- private backdropElement: HTMLElement | null = null
657
- private contentElement: HTMLElement | null = null
658
- private messageHandlers = new Set<(message: any) => void>()
659
- private eventHandlers = new Map<string, Set<() => void>>()
660
- private setState: (
661
- value: ViewportState | ((prev: ViewportState) => ViewportState)
662
- ) => ViewportState
663
-
664
- constructor(config: WindowConfig) {
665
- this.id = config.id
666
- this.config = config
667
-
668
- const [state, setState] = createSignal<ViewportState>({
669
- id: config.id,
670
- title: config.title || config.id,
671
- isVisible: false,
672
- isMinimized: false,
673
- isMaximized: false,
674
- isFullscreen: false,
675
- isFocused: false,
676
- bounds: {
677
- x: 0,
678
- y: 0,
679
- width: config.width || 600,
680
- height: config.height || 400,
681
- },
682
- zIndex: 1000,
683
- // Phase 2: Enhanced state properties
684
- isPooled: false,
685
- lastUsed: Date.now(),
686
- groupId: undefined,
687
- tabIndex: undefined,
688
- parentWindowId: undefined,
689
- })
690
-
691
- this.state = state as Signal<ViewportState>
692
- this.setState = setState
693
- this.createElement()
694
- }
695
-
696
- render(_component: ComponentInstance): void {
697
- if (!this.contentElement) return
698
-
699
- // This would integrate with TachUI's renderer
700
- // For now, just set basic content
701
- this.contentElement.innerHTML = `<div>Modal: ${this.config.title}</div>`
702
- }
703
-
704
- async show(): Promise<void> {
705
- if (!this.backdropElement) return
706
-
707
- document.body.appendChild(this.backdropElement)
708
-
709
- // Update state
710
- this.setState((prevState) => ({
711
- ...prevState,
712
- isVisible: true,
713
- isFocused: true,
714
- }))
715
-
716
- this.emit('show')
717
- }
718
-
719
- async hide(): Promise<void> {
720
- if (this.backdropElement?.parentNode) {
721
- this.backdropElement.parentNode.removeChild(this.backdropElement)
722
- }
723
-
724
- // Update state
725
- this.setState((prevState) => ({
726
- ...prevState,
727
- isVisible: false,
728
- isFocused: false,
729
- }))
730
-
731
- this.emit('hide')
732
- }
733
-
734
- async focus(): Promise<void> {
735
- if (this.contentElement) {
736
- this.contentElement.focus()
737
- }
738
- this.emit('focus')
739
- }
740
-
741
- async minimize(): Promise<void> {
742
- await this.hide()
743
- }
744
-
745
- async maximize(): Promise<void> {
746
- // Could implement fullscreen modal
747
- }
748
-
749
- async restore(): Promise<void> {
750
- await this.show()
751
- }
752
-
753
- async close(): Promise<void> {
754
- await this.hide()
755
- this.emit('close')
756
- this.dispose()
757
- }
758
-
759
- dispose(): void {
760
- if (this.backdropElement?.parentNode) {
761
- this.backdropElement.parentNode.removeChild(this.backdropElement)
762
- }
763
- this.messageHandlers.clear()
764
- this.eventHandlers.clear()
765
- }
766
-
767
- postMessage(_message: any): void {
768
- // Broadcast to other modals/windows
769
- }
770
-
771
- onMessage(handler: (message: any) => void): () => void {
772
- this.messageHandlers.add(handler)
773
- return () => this.messageHandlers.delete(handler)
774
- }
775
-
776
- receiveMessage(message: any): void {
777
- this.messageHandlers.forEach((handler) => handler(message))
778
- }
779
-
780
- onShow(handler: () => void): () => void {
781
- return this.addEventListener('show', handler)
782
- }
783
- onHide(handler: () => void): () => void {
784
- return this.addEventListener('hide', handler)
785
- }
786
- onFocus(handler: () => void): () => void {
787
- return this.addEventListener('focus', handler)
788
- }
789
- onBlur(handler: () => void): () => void {
790
- return this.addEventListener('blur', handler)
791
- }
792
- onResize(_handler: (bounds: ViewportState['bounds']) => void): () => void {
793
- return () => {}
794
- }
795
- onClose(handler: () => void): () => void {
796
- return this.addEventListener('close', handler)
797
- }
798
-
799
- private addEventListener(event: string, handler: () => void): () => void {
800
- if (!this.eventHandlers.has(event)) {
801
- this.eventHandlers.set(event, new Set())
802
- }
803
-
804
- this.eventHandlers.get(event)!.add(handler)
805
-
806
- return () => {
807
- this.eventHandlers.get(event)?.delete(handler)
808
- }
809
- }
810
-
811
- private emit(event: string): void {
812
- const handlers = this.eventHandlers.get(event)
813
- if (handlers) {
814
- handlers.forEach((handler) => handler())
815
- }
816
- }
817
-
818
- private createElement(): void {
819
- // Create backdrop
820
- this.backdropElement = document.createElement('div')
821
- this.backdropElement.className = 'tachui-modal-backdrop'
822
-
823
- // Create content container
824
- this.contentElement = document.createElement('div')
825
- this.contentElement.className = 'tachui-modal-content'
826
- this.contentElement.style.width = `${this.config.width || 600}px`
827
- this.contentElement.style.height = `${this.config.height || 400}px`
828
-
829
- this.backdropElement.appendChild(this.contentElement)
830
-
831
- // Handle backdrop clicks
832
- this.backdropElement.addEventListener('click', (e) => {
833
- if (e.target === this.backdropElement && this.config.backdropDismiss !== false) {
834
- this.close()
835
- }
836
- })
837
-
838
- // Handle escape key
839
- document.addEventListener('keydown', (e) => {
840
- if (e.key === 'Escape' && this.config.escapeKeyDismiss !== false) {
841
- this.close()
842
- }
843
- })
844
- }
845
-
846
- // ==================== Phase 2: Enhanced Methods ====================
847
-
848
- private sharedState = new Map<string, any>()
849
- private stateChangeCallbacks = new Map<string, Set<(value: any) => void>>()
850
- private childWindows = new Map<string, ViewportInstance>()
851
- private parentWindow: ViewportInstance | null = null
852
- private tabContainer: ViewportInstance | null = null
853
-
854
- /**
855
- * Window pooling and reuse
856
- */
857
- async prepareForReuse(): Promise<void> {
858
- // Clear current content and reset for reuse
859
- if (this.contentElement) {
860
- this.contentElement.innerHTML = ''
861
- }
862
- this.messageHandlers.clear()
863
- this.sharedState.clear()
864
- this.stateChangeCallbacks.clear()
865
- }
866
-
867
- isReusable(): boolean {
868
- return this.backdropElement != null && this.contentElement != null
869
- }
870
-
871
- markAsUsed(): void {
872
- this.setState((prev) => ({
873
- ...prev,
874
- lastUsed: Date.now(),
875
- }))
876
- }
877
-
878
- async returnToPool(): Promise<void> {
879
- await this.hide()
880
- this.setState((prev) => ({
881
- ...prev,
882
- isPooled: true,
883
- lastUsed: Date.now(),
884
- }))
885
- }
886
-
887
- /**
888
- * State synchronization (full support for modals)
889
- */
890
- syncState<T>(key: string, value: T): void {
891
- this.sharedState.set(key, value)
892
-
893
- // Notify local callbacks
894
- const callbacks = this.stateChangeCallbacks.get(key)
895
- if (callbacks) {
896
- callbacks.forEach((callback) => callback(value))
897
- }
898
-
899
- // Sync to child windows
900
- this.childWindows.forEach((child) => {
901
- child.syncState(key, value)
902
- })
903
- }
904
-
905
- getSharedState<T>(key: string): T | undefined {
906
- return this.sharedState.get(key)
907
- }
908
-
909
- onSharedStateChange<T>(key: string, callback: (value: T) => void): () => void {
910
- if (!this.stateChangeCallbacks.has(key)) {
911
- this.stateChangeCallbacks.set(key, new Set())
912
- }
913
-
914
- this.stateChangeCallbacks.get(key)!.add(callback)
915
-
916
- return () => {
917
- this.stateChangeCallbacks.get(key)?.delete(callback)
918
- }
919
- }
920
-
921
- /**
922
- * Tab grouping (web modal tab simulation)
923
- */
924
- async attachToTab(tabContainer: ViewportInstance): Promise<void> {
925
- this.tabContainer = tabContainer
926
- // For web modals, we can simulate tabs by adding tab headers
927
- this.createTabInterface()
928
- }
929
-
930
- async detachFromTab(): Promise<ViewportInstance> {
931
- this.tabContainer = null
932
- this.removeTabInterface()
933
- return this
934
- }
935
-
936
- getTabContainer(): ViewportInstance | null {
937
- return this.tabContainer
938
- }
939
-
940
- getTabIndex(): number {
941
- return this.state().tabIndex || 0
942
- }
943
-
944
- setTabIndex(index: number): void {
945
- this.setState((prev) => ({
946
- ...prev,
947
- tabIndex: index,
948
- }))
949
- }
950
-
951
- /**
952
- * Parent-child relationships (full support for modals)
953
- */
954
- setParentWindow(parent: ViewportInstance): void {
955
- this.parentWindow = parent
956
- this.setState((prev) => ({
957
- ...prev,
958
- parentWindowId: parent.id,
959
- }))
960
- }
961
-
962
- getParentWindow(): ViewportInstance | null {
963
- return this.parentWindow
964
- }
965
-
966
- getChildWindows(): ViewportInstance[] {
967
- return Array.from(this.childWindows.values())
968
- }
969
-
970
- addChildWindow(child: ViewportInstance): void {
971
- this.childWindows.set(child.id, child)
972
- child.setParentWindow(this)
973
- }
974
-
975
- removeChildWindow(childId: string): void {
976
- this.childWindows.delete(childId)
977
- }
978
-
979
- /**
980
- * Tab interface helpers
981
- */
982
- private createTabInterface(): void {
983
- if (!this.contentElement || !this.tabContainer) return
984
-
985
- // Create tab header
986
- const tabHeader = document.createElement('div')
987
- tabHeader.className = 'tachui-modal-tab-header'
988
- tabHeader.style.cssText = `
989
- display: flex;
990
- border-bottom: 1px solid #e0e0e0;
991
- background: #f5f5f5;
992
- min-height: 40px;
993
- `
994
-
995
- // Insert tab header
996
- this.contentElement.insertBefore(tabHeader, this.contentElement.firstChild)
997
- }
998
-
999
- private removeTabInterface(): void {
1000
- if (!this.contentElement) return
1001
-
1002
- const tabHeader = this.contentElement.querySelector('.tachui-modal-tab-header')
1003
- if (tabHeader) {
1004
- tabHeader.remove()
1005
- }
1006
- }
1007
- }
1008
-
1009
- /**
1010
- * Web portal instance (renders in portal container)
1011
- */
1012
- class WebPortalInstance implements ViewportInstance {
1013
- readonly id: string
1014
- readonly type: ViewportType = 'portal'
1015
- readonly config: WindowConfig
1016
- state: Signal<ViewportState>
1017
-
1018
- private portalElement: HTMLElement | null = null
1019
- private messageHandlers = new Set<(message: any) => void>()
1020
- private eventHandlers = new Map<string, Set<() => void>>()
1021
- private cleanupFunction: (() => void) | null = null
1022
- private setState: (
1023
- value: ViewportState | ((prev: ViewportState) => ViewportState)
1024
- ) => ViewportState
1025
-
1026
- constructor(
1027
- config: WindowConfig,
1028
- private container: HTMLElement
1029
- ) {
1030
- this.id = config.id
1031
- this.config = config
1032
-
1033
- const [state, setState] = createSignal<ViewportState>({
1034
- id: config.id,
1035
- title: config.title || config.id,
1036
- isVisible: false,
1037
- isMinimized: false,
1038
- isMaximized: false,
1039
- isFullscreen: false,
1040
- isFocused: false,
1041
- bounds: {
1042
- x: config.x || 0,
1043
- y: config.y || 0,
1044
- width: config.width || 400,
1045
- height: config.height || 300,
1046
- },
1047
- // Phase 2: Enhanced state properties
1048
- isPooled: false,
1049
- lastUsed: Date.now(),
1050
- groupId: undefined,
1051
- tabIndex: undefined,
1052
- parentWindowId: undefined,
1053
- })
1054
-
1055
- this.state = state as Signal<ViewportState>
1056
- this.setState = setState
1057
- this.createElement()
1058
- }
1059
-
1060
- render(component: ComponentInstance): void {
1061
- if (!this.portalElement) {
1062
- return
1063
- }
1064
-
1065
- // Clear existing content
1066
- this.portalElement.innerHTML = ''
1067
-
1068
- try {
1069
- // Use enhanced DOM bridge mounting to ensure lifecycle hooks are called
1070
- const cleanup = mountComponentTree(component, this.portalElement)
1071
-
1072
- // Store cleanup function for later disposal
1073
- this.cleanupFunction = cleanup
1074
- } catch (error) {
1075
- console.error('Error during mountComponentTree:', error)
1076
- }
1077
- }
1078
-
1079
- async show(): Promise<void> {
1080
- if (!this.portalElement) {
1081
- return
1082
- }
1083
-
1084
- // For single-page apps, replace the loading content instead of appending
1085
- if (this.container.id === 'app') {
1086
- this.container.innerHTML = ''
1087
- }
1088
-
1089
- this.container.appendChild(this.portalElement)
1090
- this.portalElement.style.display = 'block'
1091
-
1092
- this.setState((prevState) => ({
1093
- ...prevState,
1094
- isVisible: true,
1095
- }))
1096
-
1097
- this.emit('show')
1098
- }
1099
-
1100
- async hide(): Promise<void> {
1101
- if (this.portalElement) {
1102
- this.portalElement.style.display = 'none'
1103
- }
1104
-
1105
- this.setState((prevState) => ({
1106
- ...prevState,
1107
- isVisible: false,
1108
- }))
1109
-
1110
- this.emit('hide')
1111
- }
1112
-
1113
- async focus(): Promise<void> {
1114
- this.emit('focus')
1115
- }
1116
- async minimize(): Promise<void> {
1117
- await this.hide()
1118
- }
1119
- async maximize(): Promise<void> {}
1120
- async restore(): Promise<void> {
1121
- await this.show()
1122
- }
1123
-
1124
- async close(): Promise<void> {
1125
- if (this.portalElement?.parentNode) {
1126
- this.portalElement.parentNode.removeChild(this.portalElement)
1127
- }
1128
- this.emit('close')
1129
- this.dispose()
1130
- }
1131
-
1132
- dispose(): void {
1133
- // Call component cleanup function first
1134
- if (this.cleanupFunction) {
1135
- this.cleanupFunction()
1136
- this.cleanupFunction = null
1137
- }
1138
-
1139
- if (this.portalElement?.parentNode) {
1140
- this.portalElement.parentNode.removeChild(this.portalElement)
1141
- }
1142
- this.messageHandlers.clear()
1143
- this.eventHandlers.clear()
1144
- }
1145
-
1146
- postMessage(_message: any): void {}
1147
- onMessage(handler: (message: any) => void): () => void {
1148
- this.messageHandlers.add(handler)
1149
- return () => this.messageHandlers.delete(handler)
1150
- }
1151
-
1152
- receiveMessage(message: any): void {
1153
- this.messageHandlers.forEach((handler) => handler(message))
1154
- }
1155
-
1156
- onShow(handler: () => void): () => void {
1157
- return this.addEventListener('show', handler)
1158
- }
1159
- onHide(handler: () => void): () => void {
1160
- return this.addEventListener('hide', handler)
1161
- }
1162
- onFocus(handler: () => void): () => void {
1163
- return this.addEventListener('focus', handler)
1164
- }
1165
- onBlur(handler: () => void): () => void {
1166
- return this.addEventListener('blur', handler)
1167
- }
1168
- onResize(_handler: (bounds: ViewportState['bounds']) => void): () => void {
1169
- return () => {}
1170
- }
1171
- onClose(handler: () => void): () => void {
1172
- return this.addEventListener('close', handler)
1173
- }
1174
-
1175
- private addEventListener(event: string, handler: () => void): () => void {
1176
- if (!this.eventHandlers.has(event)) {
1177
- this.eventHandlers.set(event, new Set())
1178
- }
1179
-
1180
- this.eventHandlers.get(event)!.add(handler)
1181
-
1182
- return () => {
1183
- this.eventHandlers.get(event)?.delete(handler)
1184
- }
1185
- }
1186
-
1187
- private emit(event: string): void {
1188
- const handlers = this.eventHandlers.get(event)
1189
- if (handlers) {
1190
- handlers.forEach((handler) => handler())
1191
- }
1192
- }
1193
-
1194
- private createElement(): void {
1195
- this.portalElement = document.createElement('div')
1196
- this.portalElement.className = 'tachui-portal'
1197
-
1198
- // For single-page apps using the #app container, render transparently
1199
- if (this.container && this.container.id === 'app') {
1200
- // No positioning, background, or borders - just a transparent container
1201
- this.portalElement.style.position = 'static'
1202
- this.portalElement.style.width = '100%'
1203
- this.portalElement.style.height = 'auto'
1204
- this.portalElement.style.background = 'transparent'
1205
- this.portalElement.style.border = 'none'
1206
- this.portalElement.style.display = 'block'
1207
- } else {
1208
- // Traditional portal with positioning and styling
1209
- this.portalElement.style.position = 'absolute'
1210
- this.portalElement.style.left = `${this.config.x || 0}px`
1211
- this.portalElement.style.top = `${this.config.y || 0}px`
1212
- this.portalElement.style.width = `${this.config.width || 400}px`
1213
- this.portalElement.style.height = `${this.config.height || 300}px`
1214
- this.portalElement.style.background = 'white'
1215
- this.portalElement.style.border = '1px solid #ccc'
1216
- this.portalElement.style.borderRadius = '8px'
1217
- this.portalElement.style.boxShadow = '0 4px 12px rgba(0, 0, 0, 0.15)'
1218
- this.portalElement.style.display = 'none'
1219
- }
1220
- }
1221
-
1222
- // ==================== Phase 2: Enhanced Methods ====================
1223
-
1224
- private sharedState = new Map<string, any>()
1225
- private stateChangeCallbacks = new Map<string, Set<(value: any) => void>>()
1226
- private childWindows = new Map<string, ViewportInstance>()
1227
- private parentWindow: ViewportInstance | null = null
1228
- private tabContainer: ViewportInstance | null = null
1229
-
1230
- /**
1231
- * Window pooling and reuse (excellent for portals)
1232
- */
1233
- async prepareForReuse(): Promise<void> {
1234
- // Clear current content and reset for reuse
1235
- if (this.portalElement) {
1236
- this.portalElement.innerHTML = ''
1237
- }
1238
- this.messageHandlers.clear()
1239
- this.sharedState.clear()
1240
- this.stateChangeCallbacks.clear()
1241
- }
1242
-
1243
- isReusable(): boolean {
1244
- return this.portalElement != null
1245
- }
1246
-
1247
- markAsUsed(): void {
1248
- this.setState((prev) => ({
1249
- ...prev,
1250
- lastUsed: Date.now(),
1251
- }))
1252
- }
1253
-
1254
- async returnToPool(): Promise<void> {
1255
- await this.hide()
1256
- this.setState((prev) => ({
1257
- ...prev,
1258
- isPooled: true,
1259
- lastUsed: Date.now(),
1260
- }))
1261
- }
1262
-
1263
- /**
1264
- * State synchronization (full support for portals)
1265
- */
1266
- syncState<T>(key: string, value: T): void {
1267
- this.sharedState.set(key, value)
1268
-
1269
- // Notify local callbacks
1270
- const callbacks = this.stateChangeCallbacks.get(key)
1271
- if (callbacks) {
1272
- callbacks.forEach((callback) => callback(value))
1273
- }
1274
-
1275
- // Sync to child windows
1276
- this.childWindows.forEach((child) => {
1277
- child.syncState(key, value)
1278
- })
1279
- }
1280
-
1281
- getSharedState<T>(key: string): T | undefined {
1282
- return this.sharedState.get(key)
1283
- }
1284
-
1285
- onSharedStateChange<T>(key: string, callback: (value: T) => void): () => void {
1286
- if (!this.stateChangeCallbacks.has(key)) {
1287
- this.stateChangeCallbacks.set(key, new Set())
1288
- }
1289
-
1290
- this.stateChangeCallbacks.get(key)!.add(callback)
1291
-
1292
- return () => {
1293
- this.stateChangeCallbacks.get(key)?.delete(callback)
1294
- }
1295
- }
1296
-
1297
- /**
1298
- * Tab grouping (portal-based tab simulation)
1299
- */
1300
- async attachToTab(tabContainer: ViewportInstance): Promise<void> {
1301
- this.tabContainer = tabContainer
1302
- // Create visual tab interface for portals
1303
- this.createPortalTabInterface()
1304
- }
1305
-
1306
- async detachFromTab(): Promise<ViewportInstance> {
1307
- this.tabContainer = null
1308
- this.removePortalTabInterface()
1309
- return this
1310
- }
1311
-
1312
- getTabContainer(): ViewportInstance | null {
1313
- return this.tabContainer
1314
- }
1315
-
1316
- getTabIndex(): number {
1317
- return this.state().tabIndex || 0
1318
- }
1319
-
1320
- setTabIndex(index: number): void {
1321
- this.setState((prev) => ({
1322
- ...prev,
1323
- tabIndex: index,
1324
- }))
1325
- }
1326
-
1327
- /**
1328
- * Parent-child relationships (full support for portals)
1329
- */
1330
- setParentWindow(parent: ViewportInstance): void {
1331
- this.parentWindow = parent
1332
- this.setState((prev) => ({
1333
- ...prev,
1334
- parentWindowId: parent.id,
1335
- }))
1336
- }
1337
-
1338
- getParentWindow(): ViewportInstance | null {
1339
- return this.parentWindow
1340
- }
1341
-
1342
- getChildWindows(): ViewportInstance[] {
1343
- return Array.from(this.childWindows.values())
1344
- }
1345
-
1346
- addChildWindow(child: ViewportInstance): void {
1347
- this.childWindows.set(child.id, child)
1348
- child.setParentWindow(this)
1349
- }
1350
-
1351
- removeChildWindow(childId: string): void {
1352
- this.childWindows.delete(childId)
1353
- }
1354
-
1355
- /**
1356
- * Portal tab interface helpers
1357
- */
1358
- private createPortalTabInterface(): void {
1359
- if (!this.portalElement || !this.tabContainer) return
1360
-
1361
- // Create tab header for portals
1362
- const tabHeader = document.createElement('div')
1363
- tabHeader.className = 'tachui-portal-tab-header'
1364
- tabHeader.style.cssText = `
1365
- display: flex;
1366
- background: #f8f9fa;
1367
- border-bottom: 1px solid #dee2e6;
1368
- min-height: 36px;
1369
- padding: 0 8px;
1370
- align-items: center;
1371
- `
1372
-
1373
- // Insert tab header
1374
- this.portalElement.insertBefore(tabHeader, this.portalElement.firstChild)
1375
- }
1376
-
1377
- private removePortalTabInterface(): void {
1378
- if (!this.portalElement) return
1379
-
1380
- const tabHeader = this.portalElement.querySelector('.tachui-portal-tab-header')
1381
- if (tabHeader) {
1382
- tabHeader.remove()
1383
- }
1384
- }
1385
- }