flexium 0.9.1 → 0.10.4

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 (142) hide show
  1. package/README.md +14 -0
  2. package/dist/{DrawText-CJikXQjL.d.cts → DrawText-ccZrs3Xs.d.cts} +1 -1
  3. package/dist/{DrawText-Bvzl40Vi.d.ts → DrawText-ngwNNh8O.d.ts} +1 -1
  4. package/dist/advanced.d.cts +1 -1
  5. package/dist/advanced.d.ts +1 -1
  6. package/dist/advanced.js +1 -1
  7. package/dist/advanced.js.map +1 -1
  8. package/dist/advanced.mjs +1 -1
  9. package/dist/advanced.mjs.map +1 -1
  10. package/dist/canvas.d.cts +4 -4
  11. package/dist/canvas.d.ts +4 -4
  12. package/dist/canvas.js +1 -1
  13. package/dist/canvas.mjs +1 -1
  14. package/dist/chunk-3AWR7IKE.js +2 -0
  15. package/dist/chunk-3AWR7IKE.js.map +1 -0
  16. package/dist/chunk-3BQXIHYI.mjs +3 -0
  17. package/dist/chunk-3BQXIHYI.mjs.map +1 -0
  18. package/dist/chunk-5236IK5I.js +2 -0
  19. package/dist/chunk-5236IK5I.js.map +1 -0
  20. package/dist/{chunk-JHJHIMWD.js → chunk-63AW5ZOC.js} +2 -2
  21. package/dist/{chunk-JHJHIMWD.js.map → chunk-63AW5ZOC.js.map} +1 -1
  22. package/dist/chunk-6K44QCMT.mjs +3 -0
  23. package/dist/chunk-6K44QCMT.mjs.map +1 -0
  24. package/dist/chunk-7Q4UE442.mjs +2 -0
  25. package/dist/chunk-7Q4UE442.mjs.map +1 -0
  26. package/dist/chunk-AJT35P3Z.js +3 -0
  27. package/dist/chunk-AJT35P3Z.js.map +1 -0
  28. package/dist/chunk-AYQMU7XC.js +3 -0
  29. package/dist/chunk-AYQMU7XC.js.map +1 -0
  30. package/dist/chunk-B7VP6HBY.mjs +2 -0
  31. package/dist/chunk-B7VP6HBY.mjs.map +1 -0
  32. package/dist/{chunk-R5CS7UZG.mjs → chunk-BYHIHYRR.mjs} +2 -2
  33. package/dist/{chunk-R5CS7UZG.mjs.map → chunk-BYHIHYRR.mjs.map} +1 -1
  34. package/dist/chunk-HLPVL6EK.mjs +2 -0
  35. package/dist/{chunk-RUXAK74B.mjs.map → chunk-HLPVL6EK.mjs.map} +1 -1
  36. package/dist/{chunk-HDCPA76O.mjs → chunk-KJPIJNFH.mjs} +2 -2
  37. package/dist/chunk-KJPIJNFH.mjs.map +1 -0
  38. package/dist/chunk-PVPY55Z7.mjs +2 -0
  39. package/dist/{chunk-TRIEKNVZ.mjs.map → chunk-PVPY55Z7.mjs.map} +1 -1
  40. package/dist/chunk-Q7WT5IIF.mjs +3 -0
  41. package/dist/chunk-Q7WT5IIF.mjs.map +1 -0
  42. package/dist/chunk-S3EDPCYT.js +3 -0
  43. package/dist/chunk-S3EDPCYT.js.map +1 -0
  44. package/dist/{chunk-L4C5UBOX.js → chunk-WOHSSPKD.js} +2 -2
  45. package/dist/chunk-WOHSSPKD.js.map +1 -0
  46. package/dist/{chunk-DFG62GKW.js → chunk-WXEHDEIH.js} +2 -2
  47. package/dist/{chunk-DFG62GKW.js.map → chunk-WXEHDEIH.js.map} +1 -1
  48. package/dist/{chunk-3P6DMEGB.js → chunk-YDZ37ZZ4.js} +2 -2
  49. package/dist/{chunk-3P6DMEGB.js.map → chunk-YDZ37ZZ4.js.map} +1 -1
  50. package/dist/{components-D4WeooPi.d.ts → components-B7KQ8C-i.d.ts} +2 -2
  51. package/dist/{components-DZy2r6m5.d.cts → components-CxnAnbpI.d.cts} +2 -2
  52. package/dist/core.d.cts +48 -136
  53. package/dist/core.d.ts +48 -136
  54. package/dist/core.js +1 -1
  55. package/dist/core.mjs +1 -1
  56. package/dist/dom.d.cts +2 -2
  57. package/dist/dom.d.ts +2 -2
  58. package/dist/dom.js +1 -1
  59. package/dist/dom.js.map +1 -1
  60. package/dist/dom.mjs +1 -1
  61. package/dist/dom.mjs.map +1 -1
  62. package/dist/{effect-BlnnM1t5.d.cts → effect-14CxUU8r.d.cts} +8 -4
  63. package/dist/{effect-BlnnM1t5.d.ts → effect-14CxUU8r.d.ts} +8 -4
  64. package/dist/effect-3LUCHSAZ.mjs +2 -0
  65. package/dist/effect-3LUCHSAZ.mjs.map +1 -0
  66. package/dist/effect-K45UU3N4.js +2 -0
  67. package/dist/effect-K45UU3N4.js.map +1 -0
  68. package/dist/index.d.cts +1 -1
  69. package/dist/index.d.ts +1 -1
  70. package/dist/index.js +1 -1
  71. package/dist/index.js.map +1 -1
  72. package/dist/index.mjs +1 -1
  73. package/dist/index.mjs.map +1 -1
  74. package/dist/interactive.d.cts +15 -10
  75. package/dist/interactive.d.ts +15 -10
  76. package/dist/interactive.js +1 -1
  77. package/dist/interactive.js.map +1 -1
  78. package/dist/interactive.mjs +1 -1
  79. package/dist/interactive.mjs.map +1 -1
  80. package/dist/metafile-cjs.json +1 -1
  81. package/dist/metafile-esm.json +1 -1
  82. package/dist/{portal-C3ESJhlv.d.ts → portal-CVqrpmHd.d.ts} +2 -2
  83. package/dist/{portal-CAEbiMUZ.d.cts → portal-NLlE-fNZ.d.cts} +2 -2
  84. package/dist/primitives/layout.js +1 -1
  85. package/dist/primitives/layout.mjs +1 -1
  86. package/dist/primitives/motion.js +1 -1
  87. package/dist/primitives/motion.mjs +1 -1
  88. package/dist/primitives/ui.d.cts +3 -3
  89. package/dist/primitives/ui.d.ts +3 -3
  90. package/dist/primitives/ui.js +1 -1
  91. package/dist/primitives/ui.js.map +1 -1
  92. package/dist/primitives/ui.mjs +1 -1
  93. package/dist/primitives/ui.mjs.map +1 -1
  94. package/dist/primitives.d.cts +4 -4
  95. package/dist/primitives.d.ts +4 -4
  96. package/dist/primitives.js +1 -1
  97. package/dist/primitives.js.map +1 -1
  98. package/dist/primitives.mjs +1 -1
  99. package/dist/primitives.mjs.map +1 -1
  100. package/dist/router.d.cts +3 -3
  101. package/dist/router.d.ts +3 -3
  102. package/dist/router.js +1 -1
  103. package/dist/router.mjs +1 -1
  104. package/dist/server.js +1 -1
  105. package/dist/server.js.map +1 -1
  106. package/dist/server.mjs +1 -1
  107. package/dist/server.mjs.map +1 -1
  108. package/dist/signal-2QUI7H7B.js +2 -0
  109. package/dist/{signal-3YZHUCLL.js.map → signal-2QUI7H7B.js.map} +1 -1
  110. package/dist/signal-C6936A3J.d.cts +175 -0
  111. package/dist/signal-C6936A3J.d.ts +175 -0
  112. package/dist/signal-L3ZWGOVT.mjs +2 -0
  113. package/dist/{signal-F2HEYB6F.mjs.map → signal-L3ZWGOVT.mjs.map} +1 -1
  114. package/dist/test-exports.d.cts +6 -6
  115. package/dist/test-exports.d.ts +6 -6
  116. package/dist/test-exports.js +1 -1
  117. package/dist/test-exports.mjs +1 -1
  118. package/package.json +2 -1
  119. package/dist/chunk-2ZHUQBNI.mjs +0 -2
  120. package/dist/chunk-2ZHUQBNI.mjs.map +0 -1
  121. package/dist/chunk-HDCPA76O.mjs.map +0 -1
  122. package/dist/chunk-J4CK5NRW.mjs +0 -3
  123. package/dist/chunk-J4CK5NRW.mjs.map +0 -1
  124. package/dist/chunk-JEDCNAAI.mjs +0 -3
  125. package/dist/chunk-JEDCNAAI.mjs.map +0 -1
  126. package/dist/chunk-L4C5UBOX.js.map +0 -1
  127. package/dist/chunk-M4ANLZ6P.js +0 -3
  128. package/dist/chunk-M4ANLZ6P.js.map +0 -1
  129. package/dist/chunk-RDA77IE6.js +0 -2
  130. package/dist/chunk-RDA77IE6.js.map +0 -1
  131. package/dist/chunk-RUXAK74B.mjs +0 -2
  132. package/dist/chunk-TRIEKNVZ.mjs +0 -2
  133. package/dist/chunk-VIVO4FHN.js +0 -3
  134. package/dist/chunk-VIVO4FHN.js.map +0 -1
  135. package/dist/chunk-XLE6SMWX.mjs +0 -3
  136. package/dist/chunk-XLE6SMWX.mjs.map +0 -1
  137. package/dist/chunk-YGMMJWAA.js +0 -3
  138. package/dist/chunk-YGMMJWAA.js.map +0 -1
  139. package/dist/signal-3YZHUCLL.js +0 -2
  140. package/dist/signal-Dxh9PsKr.d.cts +0 -69
  141. package/dist/signal-Dxh9PsKr.d.ts +0 -69
  142. package/dist/signal-F2HEYB6F.mjs +0 -2
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkQ7IWDVJ4_js=require('./chunk-Q7IWDVJ4.js'),chunkYGMMJWAA_js=require('./chunk-YGMMJWAA.js');function m(e){let t={},i=[];return e.x!==void 0&&i.push(`translateX(${e.x}px)`),e.y!==void 0&&i.push(`translateY(${e.y}px)`),e.scale!==void 0?i.push(`scale(${e.scale})`):(e.scaleX!==void 0&&i.push(`scaleX(${e.scaleX})`),e.scaleY!==void 0&&i.push(`scaleY(${e.scaleY})`)),e.rotate!==void 0&&i.push(`rotate(${e.rotate}deg)`),i.length>0&&(t.transform=i.join(" ")),e.opacity!==void 0&&(t.opacity=e.opacity.toString()),e.width!==void 0&&(t.width=typeof e.width=="number"?`${e.width}px`:e.width),e.height!==void 0&&(t.height=typeof e.height=="number"?`${e.height}px`:e.height),t}function L(e){let t=e.tension??170,i=e.friction??26,o=e.mass??1,r=t,n=i,s=o,l=Math.sqrt(r/s),c=n/(2*Math.sqrt(r*s)),u=4.6/(c*l)*1e3;return c<1?{duration:u,easing:"cubic-bezier(0.34, 1.56, 0.64, 1)"}:{duration:u,easing:"cubic-bezier(0.22, 1, 0.36, 1)"}}var d=null,x=null;function A(){if(d===null)if(typeof window<"u"&&window.matchMedia){let e=window.matchMedia("(prefers-reduced-motion: reduce)");d=e.matches;let t=i=>{d=i.matches;};e.addEventListener("change",t),x=()=>{e.removeEventListener("change",t),d=null,x=null;};}else d=false;return d}function O(){x&&x();}var f=class{constructor(t){this.animation=null;this.resizeObserver=null;this.previousSize=null;this.element=t;}animate(t){let{initial:i,animate:o,duration:r=300,spring:n,easing:s="ease-out",delay:l=0}=t;if(!o)return;if(this.cancel(),A()){let a=m(o);Object.assign(this.element.style,{transform:a.transform||"",opacity:a.opacity||"",width:a.width||"",height:a.height||""}),t.onAnimationStart&&t.onAnimationStart(),t.onAnimationComplete&&t.onAnimationComplete();return}if(i){let a=m(i);Object.assign(this.element.style,{transform:a.transform||"",opacity:a.opacity||"",width:a.width||"",height:a.height||""});}let c=i?m(i):{},u=m(o),h=r,g=s;if(n){let a=L(n);h=a.duration,g=a.easing;}this.animation=this.element.animate([c,u],{duration:h,easing:g,delay:l,fill:"forwards"}),t.onAnimationStart&&t.onAnimationStart(),this.animation.onfinish=()=>{t.onAnimationComplete&&t.onAnimationComplete();};}async animateExit(t,i=300,o="ease-in"){if(this.cancel(),A()){let n=m(t);Object.assign(this.element.style,{transform:n.transform||"",opacity:n.opacity||"",width:n.width||"",height:n.height||""});return}let r=m(t);this.animation=this.element.animate([{},r],{duration:i,easing:o,fill:"forwards"}),await this.animation.finished;}enableLayoutAnimation(t=300,i="ease-out"){let o=this.element.getBoundingClientRect();this.previousSize={width:o.width,height:o.height},this.resizeObserver=new ResizeObserver(r=>{for(let n of r){if(!this.previousSize){this.previousSize={width:n.contentRect.width,height:n.contentRect.height};return}let s=n.contentRect.width,l=n.contentRect.height;(s!==this.previousSize.width||l!==this.previousSize.height)&&(this.cancel(),this.animation=this.element.animate([{width:`${this.previousSize.width}px`,height:`${this.previousSize.height}px`},{width:`${s}px`,height:`${l}px`}],{duration:t,easing:i,fill:"forwards"}),this.previousSize={width:s,height:l});}}),this.resizeObserver.observe(this.element);}disableLayoutAnimation(){this.resizeObserver&&(this.resizeObserver.disconnect(),this.resizeObserver=null,this.previousSize=null);}cancel(){this.animation&&(this.animation.cancel(),this.animation=null);}dispose(){this.cancel(),this.disableLayoutAnimation();}};function R(e){switch(e){case "fade":return {enter:{opacity:0},enterTo:{opacity:1},exit:{opacity:0}};case "slide-up":return {enter:{opacity:0,y:20},enterTo:{opacity:1,y:0},exit:{opacity:0,y:-20}};case "slide-down":return {enter:{opacity:0,y:-20},enterTo:{opacity:1,y:0},exit:{opacity:0,y:20}};case "slide-left":return {enter:{opacity:0,x:20},enterTo:{opacity:1,x:0},exit:{opacity:0,x:-20}};case "slide-right":return {enter:{opacity:0,x:-20},enterTo:{opacity:1,x:0},exit:{opacity:0,x:20}};case "scale":return {enter:{scale:.9},enterTo:{scale:1},exit:{scale:.9}};case "scale-fade":return {enter:{opacity:0,scale:.95},enterTo:{opacity:1,scale:1},exit:{opacity:0,scale:.95}};default:return {enter:{},enterTo:{},exit:{}}}}var y=null;function $(e){let{preset:t,enter:i,enterTo:o,exit:r,enterTiming:n={duration:300,easing:"ease-out"},exitTiming:s={duration:200,easing:"ease-in"},onEnterStart:l,onEnterComplete:c,onExitStart:u,onExitComplete:h,children:g}=e,a=t?R(t):null,P=i??a?.enter??{},C=o??a?.enterTo??{},S=r??a?.exit??{},b=null,p=null,M=y?.registerChild()??0,z=y?.staggerDelay??0,E=M*z;return chunkYGMMJWAA_js.m(async()=>{b&&p&&(u?.(),await p.animateExit(S,s.duration,s.easing),h?.());}),chunkQ7IWDVJ4_js.a("div",{style:{display:"contents"},ref:T=>{T&&(b=T,p=new f(T),queueMicrotask(()=>{p&&(l?.(),p.animate({initial:P,animate:C,duration:n.duration,easing:n.easing,delay:(n.delay??0)+E,onAnimationComplete:c}));}));}},g)}function G(e){let{stagger:t=50,children:i}=e,o=0,r={registerChild:()=>o++,staggerDelay:t};return ()=>{o=0;let n=y;y=r;try{return i}finally{y=n;}}}var D={fade:{preset:"fade"},slideUp:{preset:"slide-up"},slideDown:{preset:"slide-down"},slideLeft:{preset:"slide-left"},slideRight:{preset:"slide-right"},scale:{preset:"scale"},scaleFade:{preset:"scale-fade"},modal:{enter:{opacity:0,scale:.95,y:-10},enterTo:{opacity:1,scale:1,y:0},exit:{opacity:0,scale:.95,y:10},enterTiming:{duration:200,easing:"cubic-bezier(0.16, 1, 0.3, 1)"},exitTiming:{duration:150,easing:"ease-in"}},dropdown:{enter:{opacity:0,y:-8,scale:.95},enterTo:{opacity:1,y:0,scale:1},exit:{opacity:0,y:-8,scale:.95},enterTiming:{duration:150,easing:"ease-out"},exitTiming:{duration:100,easing:"ease-in"}},tooltip:{enter:{opacity:0,scale:.9},enterTo:{opacity:1,scale:1},exit:{opacity:0,scale:.9},enterTiming:{duration:100,easing:"ease-out"},exitTiming:{duration:75,easing:"ease-in"}},notification:{enter:{opacity:0,x:100},enterTo:{opacity:1,x:0},exit:{opacity:0,x:100},enterTiming:{duration:300,easing:"cubic-bezier(0.16, 1, 0.3, 1)"},exitTiming:{duration:200,easing:"ease-in"}},page:{enter:{opacity:0},enterTo:{opacity:1},exit:{opacity:0},enterTiming:{duration:200,easing:"ease-out"},exitTiming:{duration:150,easing:"ease-in"}}};exports.a=O;exports.b=f;exports.c=$;exports.d=G;exports.e=D;//# sourceMappingURL=chunk-JHJHIMWD.js.map
2
- //# sourceMappingURL=chunk-JHJHIMWD.js.map
1
+ 'use strict';var chunkQ7IWDVJ4_js=require('./chunk-Q7IWDVJ4.js'),chunk5236IK5I_js=require('./chunk-5236IK5I.js');function m(e){let t={},i=[];return e.x!==void 0&&i.push(`translateX(${e.x}px)`),e.y!==void 0&&i.push(`translateY(${e.y}px)`),e.scale!==void 0?i.push(`scale(${e.scale})`):(e.scaleX!==void 0&&i.push(`scaleX(${e.scaleX})`),e.scaleY!==void 0&&i.push(`scaleY(${e.scaleY})`)),e.rotate!==void 0&&i.push(`rotate(${e.rotate}deg)`),i.length>0&&(t.transform=i.join(" ")),e.opacity!==void 0&&(t.opacity=e.opacity.toString()),e.width!==void 0&&(t.width=typeof e.width=="number"?`${e.width}px`:e.width),e.height!==void 0&&(t.height=typeof e.height=="number"?`${e.height}px`:e.height),t}function L(e){let t=e.tension??170,i=e.friction??26,o=e.mass??1,r=t,n=i,s=o,l=Math.sqrt(r/s),c=n/(2*Math.sqrt(r*s)),u=4.6/(c*l)*1e3;return c<1?{duration:u,easing:"cubic-bezier(0.34, 1.56, 0.64, 1)"}:{duration:u,easing:"cubic-bezier(0.22, 1, 0.36, 1)"}}var d=null,x=null;function A(){if(d===null)if(typeof window<"u"&&window.matchMedia){let e=window.matchMedia("(prefers-reduced-motion: reduce)");d=e.matches;let t=i=>{d=i.matches;};e.addEventListener("change",t),x=()=>{e.removeEventListener("change",t),d=null,x=null;};}else d=false;return d}function O(){x&&x();}var f=class{constructor(t){this.animation=null;this.resizeObserver=null;this.previousSize=null;this.element=t;}animate(t){let{initial:i,animate:o,duration:r=300,spring:n,easing:s="ease-out",delay:l=0}=t;if(!o)return;if(this.cancel(),A()){let a=m(o);Object.assign(this.element.style,{transform:a.transform||"",opacity:a.opacity||"",width:a.width||"",height:a.height||""}),t.onAnimationStart&&t.onAnimationStart(),t.onAnimationComplete&&t.onAnimationComplete();return}if(i){let a=m(i);Object.assign(this.element.style,{transform:a.transform||"",opacity:a.opacity||"",width:a.width||"",height:a.height||""});}let c=i?m(i):{},u=m(o),h=r,g=s;if(n){let a=L(n);h=a.duration,g=a.easing;}this.animation=this.element.animate([c,u],{duration:h,easing:g,delay:l,fill:"forwards"}),t.onAnimationStart&&t.onAnimationStart(),this.animation.onfinish=()=>{t.onAnimationComplete&&t.onAnimationComplete();};}async animateExit(t,i=300,o="ease-in"){if(this.cancel(),A()){let n=m(t);Object.assign(this.element.style,{transform:n.transform||"",opacity:n.opacity||"",width:n.width||"",height:n.height||""});return}let r=m(t);this.animation=this.element.animate([{},r],{duration:i,easing:o,fill:"forwards"}),await this.animation.finished;}enableLayoutAnimation(t=300,i="ease-out"){let o=this.element.getBoundingClientRect();this.previousSize={width:o.width,height:o.height},this.resizeObserver=new ResizeObserver(r=>{for(let n of r){if(!this.previousSize){this.previousSize={width:n.contentRect.width,height:n.contentRect.height};return}let s=n.contentRect.width,l=n.contentRect.height;(s!==this.previousSize.width||l!==this.previousSize.height)&&(this.cancel(),this.animation=this.element.animate([{width:`${this.previousSize.width}px`,height:`${this.previousSize.height}px`},{width:`${s}px`,height:`${l}px`}],{duration:t,easing:i,fill:"forwards"}),this.previousSize={width:s,height:l});}}),this.resizeObserver.observe(this.element);}disableLayoutAnimation(){this.resizeObserver&&(this.resizeObserver.disconnect(),this.resizeObserver=null,this.previousSize=null);}cancel(){this.animation&&(this.animation.cancel(),this.animation=null);}dispose(){this.cancel(),this.disableLayoutAnimation();}};function R(e){switch(e){case "fade":return {enter:{opacity:0},enterTo:{opacity:1},exit:{opacity:0}};case "slide-up":return {enter:{opacity:0,y:20},enterTo:{opacity:1,y:0},exit:{opacity:0,y:-20}};case "slide-down":return {enter:{opacity:0,y:-20},enterTo:{opacity:1,y:0},exit:{opacity:0,y:20}};case "slide-left":return {enter:{opacity:0,x:20},enterTo:{opacity:1,x:0},exit:{opacity:0,x:-20}};case "slide-right":return {enter:{opacity:0,x:-20},enterTo:{opacity:1,x:0},exit:{opacity:0,x:20}};case "scale":return {enter:{scale:.9},enterTo:{scale:1},exit:{scale:.9}};case "scale-fade":return {enter:{opacity:0,scale:.95},enterTo:{opacity:1,scale:1},exit:{opacity:0,scale:.95}};default:return {enter:{},enterTo:{},exit:{}}}}var y=null;function $(e){let{preset:t,enter:i,enterTo:o,exit:r,enterTiming:n={duration:300,easing:"ease-out"},exitTiming:s={duration:200,easing:"ease-in"},onEnterStart:l,onEnterComplete:c,onExitStart:u,onExitComplete:h,children:g}=e,a=t?R(t):null,P=i??a?.enter??{},C=o??a?.enterTo??{},S=r??a?.exit??{},b=null,p=null,M=y?.registerChild()??0,z=y?.staggerDelay??0,E=M*z;return chunk5236IK5I_js.g(async()=>{b&&p&&(u?.(),await p.animateExit(S,s.duration,s.easing),h?.());}),chunkQ7IWDVJ4_js.a("div",{style:{display:"contents"},ref:T=>{T&&(b=T,p=new f(T),queueMicrotask(()=>{p&&(l?.(),p.animate({initial:P,animate:C,duration:n.duration,easing:n.easing,delay:(n.delay??0)+E,onAnimationComplete:c}));}));}},g)}function G(e){let{stagger:t=50,children:i}=e,o=0,r={registerChild:()=>o++,staggerDelay:t};return ()=>{o=0;let n=y;y=r;try{return i}finally{y=n;}}}var D={fade:{preset:"fade"},slideUp:{preset:"slide-up"},slideDown:{preset:"slide-down"},slideLeft:{preset:"slide-left"},slideRight:{preset:"slide-right"},scale:{preset:"scale"},scaleFade:{preset:"scale-fade"},modal:{enter:{opacity:0,scale:.95,y:-10},enterTo:{opacity:1,scale:1,y:0},exit:{opacity:0,scale:.95,y:10},enterTiming:{duration:200,easing:"cubic-bezier(0.16, 1, 0.3, 1)"},exitTiming:{duration:150,easing:"ease-in"}},dropdown:{enter:{opacity:0,y:-8,scale:.95},enterTo:{opacity:1,y:0,scale:1},exit:{opacity:0,y:-8,scale:.95},enterTiming:{duration:150,easing:"ease-out"},exitTiming:{duration:100,easing:"ease-in"}},tooltip:{enter:{opacity:0,scale:.9},enterTo:{opacity:1,scale:1},exit:{opacity:0,scale:.9},enterTiming:{duration:100,easing:"ease-out"},exitTiming:{duration:75,easing:"ease-in"}},notification:{enter:{opacity:0,x:100},enterTo:{opacity:1,x:0},exit:{opacity:0,x:100},enterTiming:{duration:300,easing:"cubic-bezier(0.16, 1, 0.3, 1)"},exitTiming:{duration:200,easing:"ease-in"}},page:{enter:{opacity:0},enterTo:{opacity:1},exit:{opacity:0},enterTiming:{duration:200,easing:"ease-out"},exitTiming:{duration:150,easing:"ease-in"}}};exports.a=O;exports.b=f;exports.c=$;exports.d=G;exports.e=D;//# sourceMappingURL=chunk-63AW5ZOC.js.map
2
+ //# sourceMappingURL=chunk-63AW5ZOC.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/primitives/motion/Motion.ts","../src/primitives/motion/Transition.ts"],"names":["propsToKeyframe","props","keyframe","transforms","springToTiming","spring","tension","friction","mass","k","c","m","naturalFreq","dampingRatio","duration","prefersReducedMotion","mediaQueryCleanup","checkReducedMotion","mediaQuery","handler","e","cleanupMotionState","MotionController","element","initial","animate","easing","delay","finalKeyframe","initialKeyframe","from","to","animDuration","animEasing","timing","exitProps","rect","entries","entry","newWidth","newHeight","getPresetKeyframes","preset","currentTransitionGroup","Transition","customEnter","customEnterTo","customExit","enterTiming","exitTiming","onEnterStart","onEnterComplete","onExitStart","onExitComplete","children","presetFrames","enter","enterTo","exit","controller","staggerIndex","staggerDelay","additionalDelay","onCleanup","f","el","TransitionGroup","stagger","childIndex","context","previousGroup","transitions"],"mappings":"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","file":"chunk-JHJHIMWD.js","sourcesContent":["/**\n * Motion Component - Declarative animations using Web Animations API\n *\n * Provides smooth, performant animations without JavaScript RAF\n * Supports transforms, opacity, spring physics, and layout animations\n */\n\n/**\n * Animation properties that can be animated\n */\nexport interface AnimatableProps {\n x?: number\n y?: number\n scale?: number\n scaleX?: number\n scaleY?: number\n rotate?: number // in degrees\n opacity?: number\n width?: number | string\n height?: number | string\n}\n\n/**\n * Spring physics configuration\n */\nexport interface SpringConfig {\n tension?: number // Default: 170\n friction?: number // Default: 26\n mass?: number // Default: 1\n}\n\n/**\n * Motion component props\n */\nexport interface MotionProps {\n element?: HTMLElement | null\n initial?: AnimatableProps\n animate?: AnimatableProps\n exit?: AnimatableProps\n duration?: number // in milliseconds\n spring?: SpringConfig\n easing?: string // CSS easing function\n delay?: number\n onAnimationStart?: () => void\n onAnimationComplete?: () => void\n}\n\n/**\n * Convert animatable props to Web Animations API keyframe\n */\nfunction propsToKeyframe(props: AnimatableProps): Keyframe {\n const keyframe: Keyframe = {}\n\n const transforms: string[] = []\n\n if (props.x !== undefined) {\n transforms.push(`translateX(${props.x}px)`)\n }\n\n if (props.y !== undefined) {\n transforms.push(`translateY(${props.y}px)`)\n }\n\n if (props.scale !== undefined) {\n transforms.push(`scale(${props.scale})`)\n } else {\n if (props.scaleX !== undefined) {\n transforms.push(`scaleX(${props.scaleX})`)\n }\n if (props.scaleY !== undefined) {\n transforms.push(`scaleY(${props.scaleY})`)\n }\n }\n\n if (props.rotate !== undefined) {\n transforms.push(`rotate(${props.rotate}deg)`)\n }\n\n if (transforms.length > 0) {\n keyframe.transform = transforms.join(' ')\n }\n\n if (props.opacity !== undefined) {\n keyframe.opacity = props.opacity.toString()\n }\n\n if (props.width !== undefined) {\n keyframe.width =\n typeof props.width === 'number' ? `${props.width}px` : props.width\n }\n\n if (props.height !== undefined) {\n keyframe.height =\n typeof props.height === 'number' ? `${props.height}px` : props.height\n }\n\n return keyframe\n}\n\n/**\n * Calculate spring-based duration and easing\n * Based on spring physics formula\n */\nfunction springToTiming(spring: SpringConfig): {\n duration: number\n easing: string\n} {\n const tension = spring.tension ?? 170\n const friction = spring.friction ?? 26\n const mass = spring.mass ?? 1\n\n // Calculate damping ratio and natural frequency\n const k = tension\n const c = friction\n const m = mass\n\n const naturalFreq = Math.sqrt(k / m)\n const dampingRatio = c / (2 * Math.sqrt(k * m))\n\n // Calculate duration (time to settle within 1% of final value)\n const duration = (4.6 / (dampingRatio * naturalFreq)) * 1000\n\n // Create spring easing curve\n // For underdamped (bouncy) springs\n if (dampingRatio < 1) {\n // Use cubic-bezier that approximates spring behavior\n // Values tuned for natural spring feel\n const easing = `cubic-bezier(0.34, 1.56, 0.64, 1)`\n return { duration, easing }\n }\n\n // For critically damped or overdamped springs\n const easing = `cubic-bezier(0.22, 1, 0.36, 1)`\n return { duration, easing }\n}\n\n/**\n * Check if user prefers reduced motion\n * Cached at module level for performance\n */\nlet prefersReducedMotion: boolean | null = null\nlet mediaQueryCleanup: (() => void) | null = null\n\nfunction checkReducedMotion(): boolean {\n if (prefersReducedMotion === null) {\n if (typeof window !== 'undefined' && window.matchMedia) {\n const mediaQuery = window.matchMedia('(prefers-reduced-motion: reduce)')\n prefersReducedMotion = mediaQuery.matches\n // Listen for changes with proper cleanup support\n const handler = (e: MediaQueryListEvent) => {\n prefersReducedMotion = e.matches\n }\n mediaQuery.addEventListener('change', handler)\n mediaQueryCleanup = () => {\n mediaQuery.removeEventListener('change', handler)\n prefersReducedMotion = null\n mediaQueryCleanup = null\n }\n } else {\n prefersReducedMotion = false\n }\n }\n return prefersReducedMotion\n}\n\n/**\n * Cleanup motion module state (useful for testing and SSR)\n */\nexport function cleanupMotionState(): void {\n if (mediaQueryCleanup) {\n mediaQueryCleanup()\n }\n}\n\n/**\n * Motion controller class\n * Manages animations for a single element using Web Animations API\n * Respects prefers-reduced-motion accessibility setting\n */\nexport class MotionController {\n private element: HTMLElement\n private animation: Animation | null = null\n private resizeObserver: ResizeObserver | null = null\n private previousSize: { width: number; height: number } | null = null\n\n constructor(element: HTMLElement) {\n this.element = element\n }\n\n /**\n * Animate from initial to animate props\n * Respects prefers-reduced-motion: applies end state instantly if enabled\n */\n animate(props: MotionProps): void {\n const {\n initial,\n animate,\n duration = 300,\n spring,\n easing = 'ease-out',\n delay = 0,\n } = props\n\n if (!animate) return\n\n // Cancel any running animation\n this.cancel()\n\n // Respect prefers-reduced-motion: skip animation and apply final state instantly\n if (checkReducedMotion()) {\n const finalKeyframe = propsToKeyframe(animate)\n Object.assign(this.element.style, {\n transform: finalKeyframe.transform || '',\n opacity: finalKeyframe.opacity || '',\n width: finalKeyframe.width || '',\n height: finalKeyframe.height || '',\n })\n if (props.onAnimationStart) props.onAnimationStart()\n if (props.onAnimationComplete) props.onAnimationComplete()\n return\n }\n\n // Apply initial state immediately if provided\n if (initial) {\n const initialKeyframe = propsToKeyframe(initial)\n Object.assign(this.element.style, {\n transform: initialKeyframe.transform || '',\n opacity: initialKeyframe.opacity || '',\n width: initialKeyframe.width || '',\n height: initialKeyframe.height || '',\n })\n }\n\n // Create keyframes\n const from = initial ? propsToKeyframe(initial) : {}\n const to = propsToKeyframe(animate)\n\n // Calculate timing\n let animDuration = duration\n let animEasing = easing\n\n if (spring) {\n const timing = springToTiming(spring)\n animDuration = timing.duration\n animEasing = timing.easing\n }\n\n // Create animation\n this.animation = this.element.animate([from, to], {\n duration: animDuration,\n easing: animEasing,\n delay,\n fill: 'forwards',\n })\n\n // Handle callbacks\n if (props.onAnimationStart) {\n props.onAnimationStart()\n }\n\n this.animation.onfinish = () => {\n if (props.onAnimationComplete) {\n props.onAnimationComplete()\n }\n }\n }\n\n /**\n * Animate exit (used when element is being removed)\n * Respects prefers-reduced-motion: applies end state instantly if enabled\n */\n async animateExit(\n exitProps: AnimatableProps,\n duration = 300,\n easing = 'ease-in'\n ): Promise<void> {\n this.cancel()\n\n // Respect prefers-reduced-motion: skip animation\n if (checkReducedMotion()) {\n const finalKeyframe = propsToKeyframe(exitProps)\n Object.assign(this.element.style, {\n transform: finalKeyframe.transform || '',\n opacity: finalKeyframe.opacity || '',\n width: finalKeyframe.width || '',\n height: finalKeyframe.height || '',\n })\n return\n }\n\n const to = propsToKeyframe(exitProps)\n\n this.animation = this.element.animate([{}, to], {\n duration,\n easing,\n fill: 'forwards',\n })\n\n await this.animation.finished\n }\n\n /**\n * Enable layout animations (animate size changes automatically)\n */\n enableLayoutAnimation(duration = 300, easing = 'ease-out'): void {\n // Store initial size\n const rect = this.element.getBoundingClientRect()\n this.previousSize = { width: rect.width, height: rect.height }\n\n // Watch for size changes\n this.resizeObserver = new ResizeObserver((entries) => {\n for (const entry of entries) {\n if (!this.previousSize) {\n this.previousSize = {\n width: entry.contentRect.width,\n height: entry.contentRect.height,\n }\n return\n }\n\n const newWidth = entry.contentRect.width\n const newHeight = entry.contentRect.height\n\n // Only animate if size actually changed\n if (\n newWidth !== this.previousSize.width ||\n newHeight !== this.previousSize.height\n ) {\n // Animate from previous size to new size\n this.cancel()\n\n this.animation = this.element.animate(\n [\n {\n width: `${this.previousSize.width}px`,\n height: `${this.previousSize.height}px`,\n },\n {\n width: `${newWidth}px`,\n height: `${newHeight}px`,\n },\n ],\n {\n duration,\n easing,\n fill: 'forwards',\n }\n )\n\n this.previousSize = { width: newWidth, height: newHeight }\n }\n }\n })\n\n this.resizeObserver.observe(this.element)\n }\n\n /**\n * Disable layout animations\n */\n disableLayoutAnimation(): void {\n if (this.resizeObserver) {\n this.resizeObserver.disconnect()\n this.resizeObserver = null\n this.previousSize = null\n }\n }\n\n /**\n * Cancel current animation\n */\n cancel(): void {\n if (this.animation) {\n this.animation.cancel()\n this.animation = null\n }\n }\n\n /**\n * Cleanup all animations and observers\n */\n dispose(): void {\n this.cancel()\n this.disableLayoutAnimation()\n }\n}\n\n\n","/**\n * Transition Component - Coordinated Enter/Exit Animations\n *\n * Provides declarative transitions for elements entering and leaving the DOM.\n * Works seamlessly with For and conditional rendering (ternary, &&).\n */\n\nimport { onCleanup } from '../../core/signal'\nimport type { AnimatableProps, MotionController } from './Motion'\nimport { MotionController as MC } from './Motion'\nimport { f } from '../../renderers/dom/f'\n\n/**\n * Preset animation types\n */\nexport type TransitionPreset =\n | 'fade'\n | 'slide-up'\n | 'slide-down'\n | 'slide-left'\n | 'slide-right'\n | 'scale'\n | 'scale-fade'\n\n/**\n * Transition timing configuration\n */\nexport interface TransitionTiming {\n duration?: number\n delay?: number\n easing?: string\n}\n\n/**\n * Transition component props\n */\nexport interface TransitionProps {\n /** Use a preset animation */\n preset?: TransitionPreset\n /** Custom enter animation (from state) */\n enter?: AnimatableProps\n /** Custom enter animation (to state) */\n enterTo?: AnimatableProps\n /** Custom exit animation (to state) */\n exit?: AnimatableProps\n /** Enter timing */\n enterTiming?: TransitionTiming\n /** Exit timing */\n exitTiming?: TransitionTiming\n /** Callback when enter animation starts */\n onEnterStart?: () => void\n /** Callback when enter animation completes */\n onEnterComplete?: () => void\n /** Callback when exit animation starts */\n onExitStart?: () => void\n /** Callback when exit animation completes */\n onExitComplete?: () => void\n /** Children to animate */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n children: any\n}\n\n/**\n * Get animation keyframes for a preset\n */\nfunction getPresetKeyframes(preset: TransitionPreset): {\n enter: AnimatableProps\n enterTo: AnimatableProps\n exit: AnimatableProps\n} {\n switch (preset) {\n case 'fade':\n return {\n enter: { opacity: 0 },\n enterTo: { opacity: 1 },\n exit: { opacity: 0 },\n }\n case 'slide-up':\n return {\n enter: { opacity: 0, y: 20 },\n enterTo: { opacity: 1, y: 0 },\n exit: { opacity: 0, y: -20 },\n }\n case 'slide-down':\n return {\n enter: { opacity: 0, y: -20 },\n enterTo: { opacity: 1, y: 0 },\n exit: { opacity: 0, y: 20 },\n }\n case 'slide-left':\n return {\n enter: { opacity: 0, x: 20 },\n enterTo: { opacity: 1, x: 0 },\n exit: { opacity: 0, x: -20 },\n }\n case 'slide-right':\n return {\n enter: { opacity: 0, x: -20 },\n enterTo: { opacity: 1, x: 0 },\n exit: { opacity: 0, x: 20 },\n }\n case 'scale':\n return {\n enter: { scale: 0.9 },\n enterTo: { scale: 1 },\n exit: { scale: 0.9 },\n }\n case 'scale-fade':\n return {\n enter: { opacity: 0, scale: 0.95 },\n enterTo: { opacity: 1, scale: 1 },\n exit: { opacity: 0, scale: 0.95 },\n }\n default:\n return {\n enter: {},\n enterTo: {},\n exit: {},\n }\n }\n}\n\n/**\n * TransitionGroup context for staggered animations\n */\ninterface TransitionGroupContext {\n registerChild: () => number\n staggerDelay: number\n}\n\nlet currentTransitionGroup: TransitionGroupContext | null = null\n\n/**\n * Transition component for animated enter/exit\n *\n * @example\n * {() => visible() && (\n * <Transition preset=\"fade\">\n * <div>Content appears with fade</div>\n * </Transition>\n * )}\n *\n * @example\n * <Transition\n * enter={{ opacity: 0, y: 50 }}\n * enterTo={{ opacity: 1, y: 0 }}\n * exit={{ opacity: 0, y: -50 }}\n * enterTiming={{ duration: 300, easing: 'ease-out' }}\n * exitTiming={{ duration: 200, easing: 'ease-in' }}\n * >\n * <div>Custom animated content</div>\n * </Transition>\n */\nexport function Transition(props: TransitionProps) {\n const {\n preset,\n enter: customEnter,\n enterTo: customEnterTo,\n exit: customExit,\n enterTiming = { duration: 300, easing: 'ease-out' },\n exitTiming = { duration: 200, easing: 'ease-in' },\n onEnterStart,\n onEnterComplete,\n onExitStart,\n onExitComplete,\n children,\n } = props\n\n // Get keyframes from preset or custom props\n const presetFrames = preset ? getPresetKeyframes(preset) : null\n const enter = customEnter ?? presetFrames?.enter ?? {}\n const enterTo = customEnterTo ?? presetFrames?.enterTo ?? {}\n const exit = customExit ?? presetFrames?.exit ?? {}\n\n // Track the mounted element and controller\n let element: HTMLElement | null = null\n let controller: MotionController | null = null\n\n // Get stagger delay from group if present\n const staggerIndex = currentTransitionGroup?.registerChild() ?? 0\n const staggerDelay = currentTransitionGroup?.staggerDelay ?? 0\n const additionalDelay = staggerIndex * staggerDelay\n\n // Setup cleanup for exit animation\n onCleanup(async () => {\n if (element && controller) {\n onExitStart?.()\n\n await controller.animateExit(exit, exitTiming.duration, exitTiming.easing)\n\n onExitComplete?.()\n }\n })\n\n // Return wrapper div with ref to capture element\n return f(\n 'div',\n {\n style: { display: 'contents' },\n ref: (el: HTMLElement | null) => {\n if (!el) return\n\n element = el\n controller = new MC(el)\n\n // Schedule enter animation after DOM update\n queueMicrotask(() => {\n if (controller) {\n onEnterStart?.()\n\n controller.animate({\n initial: enter,\n animate: enterTo,\n duration: enterTiming.duration,\n easing: enterTiming.easing,\n delay: (enterTiming.delay ?? 0) + additionalDelay,\n onAnimationComplete: onEnterComplete,\n })\n }\n })\n },\n },\n children\n )\n}\n\n/**\n * TransitionGroup props\n */\nexport interface TransitionGroupProps {\n /** Delay between each child animation (stagger effect) */\n stagger?: number\n /** Children (should contain Transition components) */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n children: any\n}\n\n/**\n * TransitionGroup component for staggered animations\n *\n * @example\n * <TransitionGroup stagger={50}>\n * <For each={items}>\n * {(item) => (\n * <Transition preset=\"slide-up\">\n * <div>{item.name}</div>\n * </Transition>\n * )}\n * </For>\n * </TransitionGroup>\n */\nexport function TransitionGroup(props: TransitionGroupProps) {\n const { stagger = 50, children } = props\n\n let childIndex = 0\n\n const context: TransitionGroupContext = {\n registerChild: () => childIndex++,\n staggerDelay: stagger,\n }\n\n return () => {\n // Reset child index for each render\n childIndex = 0\n\n // Set context for child Transitions\n const previousGroup = currentTransitionGroup\n currentTransitionGroup = context\n\n try {\n return children\n } finally {\n currentTransitionGroup = previousGroup\n }\n }\n}\n\n/**\n * Preset transition configurations\n */\nexport const transitions = {\n fade: { preset: 'fade' },\n slideUp: { preset: 'slide-up' },\n slideDown: { preset: 'slide-down' },\n slideLeft: { preset: 'slide-left' },\n slideRight: { preset: 'slide-right' },\n scale: { preset: 'scale' },\n scaleFade: { preset: 'scale-fade' },\n\n // Common UI patterns\n modal: {\n enter: { opacity: 0, scale: 0.95, y: -10 },\n enterTo: { opacity: 1, scale: 1, y: 0 },\n exit: { opacity: 0, scale: 0.95, y: 10 },\n enterTiming: { duration: 200, easing: 'cubic-bezier(0.16, 1, 0.3, 1)' },\n exitTiming: { duration: 150, easing: 'ease-in' },\n },\n\n dropdown: {\n enter: { opacity: 0, y: -8, scale: 0.95 },\n enterTo: { opacity: 1, y: 0, scale: 1 },\n exit: { opacity: 0, y: -8, scale: 0.95 },\n enterTiming: { duration: 150, easing: 'ease-out' },\n exitTiming: { duration: 100, easing: 'ease-in' },\n },\n\n tooltip: {\n enter: { opacity: 0, scale: 0.9 },\n enterTo: { opacity: 1, scale: 1 },\n exit: { opacity: 0, scale: 0.9 },\n enterTiming: { duration: 100, easing: 'ease-out' },\n exitTiming: { duration: 75, easing: 'ease-in' },\n },\n\n notification: {\n enter: { opacity: 0, x: 100 },\n enterTo: { opacity: 1, x: 0 },\n exit: { opacity: 0, x: 100 },\n enterTiming: { duration: 300, easing: 'cubic-bezier(0.16, 1, 0.3, 1)' },\n exitTiming: { duration: 200, easing: 'ease-in' },\n },\n\n page: {\n enter: { opacity: 0 },\n enterTo: { opacity: 1 },\n exit: { opacity: 0 },\n enterTiming: { duration: 200, easing: 'ease-out' },\n exitTiming: { duration: 150, easing: 'ease-in' },\n },\n} satisfies Record<string, Omit<TransitionProps, 'children'>>\n"]}
1
+ {"version":3,"sources":["../src/primitives/motion/Motion.ts","../src/primitives/motion/Transition.ts"],"names":["propsToKeyframe","props","keyframe","transforms","springToTiming","spring","tension","friction","mass","k","c","m","naturalFreq","dampingRatio","duration","prefersReducedMotion","mediaQueryCleanup","checkReducedMotion","mediaQuery","handler","e","cleanupMotionState","MotionController","element","initial","animate","easing","delay","finalKeyframe","initialKeyframe","from","to","animDuration","animEasing","timing","exitProps","rect","entries","entry","newWidth","newHeight","getPresetKeyframes","preset","currentTransitionGroup","Transition","customEnter","customEnterTo","customExit","enterTiming","exitTiming","onEnterStart","onEnterComplete","onExitStart","onExitComplete","children","presetFrames","enter","enterTo","exit","controller","staggerIndex","staggerDelay","additionalDelay","onCleanup","f","el","TransitionGroup","stagger","childIndex","context","previousGroup","transitions"],"mappings":"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","file":"chunk-63AW5ZOC.js","sourcesContent":["/**\n * Motion Component - Declarative animations using Web Animations API\n *\n * Provides smooth, performant animations without JavaScript RAF\n * Supports transforms, opacity, spring physics, and layout animations\n */\n\n/**\n * Animation properties that can be animated\n */\nexport interface AnimatableProps {\n x?: number\n y?: number\n scale?: number\n scaleX?: number\n scaleY?: number\n rotate?: number // in degrees\n opacity?: number\n width?: number | string\n height?: number | string\n}\n\n/**\n * Spring physics configuration\n */\nexport interface SpringConfig {\n tension?: number // Default: 170\n friction?: number // Default: 26\n mass?: number // Default: 1\n}\n\n/**\n * Motion component props\n */\nexport interface MotionProps {\n element?: HTMLElement | null\n initial?: AnimatableProps\n animate?: AnimatableProps\n exit?: AnimatableProps\n duration?: number // in milliseconds\n spring?: SpringConfig\n easing?: string // CSS easing function\n delay?: number\n onAnimationStart?: () => void\n onAnimationComplete?: () => void\n}\n\n/**\n * Convert animatable props to Web Animations API keyframe\n */\nfunction propsToKeyframe(props: AnimatableProps): Keyframe {\n const keyframe: Keyframe = {}\n\n const transforms: string[] = []\n\n if (props.x !== undefined) {\n transforms.push(`translateX(${props.x}px)`)\n }\n\n if (props.y !== undefined) {\n transforms.push(`translateY(${props.y}px)`)\n }\n\n if (props.scale !== undefined) {\n transforms.push(`scale(${props.scale})`)\n } else {\n if (props.scaleX !== undefined) {\n transforms.push(`scaleX(${props.scaleX})`)\n }\n if (props.scaleY !== undefined) {\n transforms.push(`scaleY(${props.scaleY})`)\n }\n }\n\n if (props.rotate !== undefined) {\n transforms.push(`rotate(${props.rotate}deg)`)\n }\n\n if (transforms.length > 0) {\n keyframe.transform = transforms.join(' ')\n }\n\n if (props.opacity !== undefined) {\n keyframe.opacity = props.opacity.toString()\n }\n\n if (props.width !== undefined) {\n keyframe.width =\n typeof props.width === 'number' ? `${props.width}px` : props.width\n }\n\n if (props.height !== undefined) {\n keyframe.height =\n typeof props.height === 'number' ? `${props.height}px` : props.height\n }\n\n return keyframe\n}\n\n/**\n * Calculate spring-based duration and easing\n * Based on spring physics formula\n */\nfunction springToTiming(spring: SpringConfig): {\n duration: number\n easing: string\n} {\n const tension = spring.tension ?? 170\n const friction = spring.friction ?? 26\n const mass = spring.mass ?? 1\n\n // Calculate damping ratio and natural frequency\n const k = tension\n const c = friction\n const m = mass\n\n const naturalFreq = Math.sqrt(k / m)\n const dampingRatio = c / (2 * Math.sqrt(k * m))\n\n // Calculate duration (time to settle within 1% of final value)\n const duration = (4.6 / (dampingRatio * naturalFreq)) * 1000\n\n // Create spring easing curve\n // For underdamped (bouncy) springs\n if (dampingRatio < 1) {\n // Use cubic-bezier that approximates spring behavior\n // Values tuned for natural spring feel\n const easing = `cubic-bezier(0.34, 1.56, 0.64, 1)`\n return { duration, easing }\n }\n\n // For critically damped or overdamped springs\n const easing = `cubic-bezier(0.22, 1, 0.36, 1)`\n return { duration, easing }\n}\n\n/**\n * Check if user prefers reduced motion\n * Cached at module level for performance\n */\nlet prefersReducedMotion: boolean | null = null\nlet mediaQueryCleanup: (() => void) | null = null\n\nfunction checkReducedMotion(): boolean {\n if (prefersReducedMotion === null) {\n if (typeof window !== 'undefined' && window.matchMedia) {\n const mediaQuery = window.matchMedia('(prefers-reduced-motion: reduce)')\n prefersReducedMotion = mediaQuery.matches\n // Listen for changes with proper cleanup support\n const handler = (e: MediaQueryListEvent) => {\n prefersReducedMotion = e.matches\n }\n mediaQuery.addEventListener('change', handler)\n mediaQueryCleanup = () => {\n mediaQuery.removeEventListener('change', handler)\n prefersReducedMotion = null\n mediaQueryCleanup = null\n }\n } else {\n prefersReducedMotion = false\n }\n }\n return prefersReducedMotion\n}\n\n/**\n * Cleanup motion module state (useful for testing and SSR)\n */\nexport function cleanupMotionState(): void {\n if (mediaQueryCleanup) {\n mediaQueryCleanup()\n }\n}\n\n/**\n * Motion controller class\n * Manages animations for a single element using Web Animations API\n * Respects prefers-reduced-motion accessibility setting\n */\nexport class MotionController {\n private element: HTMLElement\n private animation: Animation | null = null\n private resizeObserver: ResizeObserver | null = null\n private previousSize: { width: number; height: number } | null = null\n\n constructor(element: HTMLElement) {\n this.element = element\n }\n\n /**\n * Animate from initial to animate props\n * Respects prefers-reduced-motion: applies end state instantly if enabled\n */\n animate(props: MotionProps): void {\n const {\n initial,\n animate,\n duration = 300,\n spring,\n easing = 'ease-out',\n delay = 0,\n } = props\n\n if (!animate) return\n\n // Cancel any running animation\n this.cancel()\n\n // Respect prefers-reduced-motion: skip animation and apply final state instantly\n if (checkReducedMotion()) {\n const finalKeyframe = propsToKeyframe(animate)\n Object.assign(this.element.style, {\n transform: finalKeyframe.transform || '',\n opacity: finalKeyframe.opacity || '',\n width: finalKeyframe.width || '',\n height: finalKeyframe.height || '',\n })\n if (props.onAnimationStart) props.onAnimationStart()\n if (props.onAnimationComplete) props.onAnimationComplete()\n return\n }\n\n // Apply initial state immediately if provided\n if (initial) {\n const initialKeyframe = propsToKeyframe(initial)\n Object.assign(this.element.style, {\n transform: initialKeyframe.transform || '',\n opacity: initialKeyframe.opacity || '',\n width: initialKeyframe.width || '',\n height: initialKeyframe.height || '',\n })\n }\n\n // Create keyframes\n const from = initial ? propsToKeyframe(initial) : {}\n const to = propsToKeyframe(animate)\n\n // Calculate timing\n let animDuration = duration\n let animEasing = easing\n\n if (spring) {\n const timing = springToTiming(spring)\n animDuration = timing.duration\n animEasing = timing.easing\n }\n\n // Create animation\n this.animation = this.element.animate([from, to], {\n duration: animDuration,\n easing: animEasing,\n delay,\n fill: 'forwards',\n })\n\n // Handle callbacks\n if (props.onAnimationStart) {\n props.onAnimationStart()\n }\n\n this.animation.onfinish = () => {\n if (props.onAnimationComplete) {\n props.onAnimationComplete()\n }\n }\n }\n\n /**\n * Animate exit (used when element is being removed)\n * Respects prefers-reduced-motion: applies end state instantly if enabled\n */\n async animateExit(\n exitProps: AnimatableProps,\n duration = 300,\n easing = 'ease-in'\n ): Promise<void> {\n this.cancel()\n\n // Respect prefers-reduced-motion: skip animation\n if (checkReducedMotion()) {\n const finalKeyframe = propsToKeyframe(exitProps)\n Object.assign(this.element.style, {\n transform: finalKeyframe.transform || '',\n opacity: finalKeyframe.opacity || '',\n width: finalKeyframe.width || '',\n height: finalKeyframe.height || '',\n })\n return\n }\n\n const to = propsToKeyframe(exitProps)\n\n this.animation = this.element.animate([{}, to], {\n duration,\n easing,\n fill: 'forwards',\n })\n\n await this.animation.finished\n }\n\n /**\n * Enable layout animations (animate size changes automatically)\n */\n enableLayoutAnimation(duration = 300, easing = 'ease-out'): void {\n // Store initial size\n const rect = this.element.getBoundingClientRect()\n this.previousSize = { width: rect.width, height: rect.height }\n\n // Watch for size changes\n this.resizeObserver = new ResizeObserver((entries) => {\n for (const entry of entries) {\n if (!this.previousSize) {\n this.previousSize = {\n width: entry.contentRect.width,\n height: entry.contentRect.height,\n }\n return\n }\n\n const newWidth = entry.contentRect.width\n const newHeight = entry.contentRect.height\n\n // Only animate if size actually changed\n if (\n newWidth !== this.previousSize.width ||\n newHeight !== this.previousSize.height\n ) {\n // Animate from previous size to new size\n this.cancel()\n\n this.animation = this.element.animate(\n [\n {\n width: `${this.previousSize.width}px`,\n height: `${this.previousSize.height}px`,\n },\n {\n width: `${newWidth}px`,\n height: `${newHeight}px`,\n },\n ],\n {\n duration,\n easing,\n fill: 'forwards',\n }\n )\n\n this.previousSize = { width: newWidth, height: newHeight }\n }\n }\n })\n\n this.resizeObserver.observe(this.element)\n }\n\n /**\n * Disable layout animations\n */\n disableLayoutAnimation(): void {\n if (this.resizeObserver) {\n this.resizeObserver.disconnect()\n this.resizeObserver = null\n this.previousSize = null\n }\n }\n\n /**\n * Cancel current animation\n */\n cancel(): void {\n if (this.animation) {\n this.animation.cancel()\n this.animation = null\n }\n }\n\n /**\n * Cleanup all animations and observers\n */\n dispose(): void {\n this.cancel()\n this.disableLayoutAnimation()\n }\n}\n\n\n","/**\n * Transition Component - Coordinated Enter/Exit Animations\n *\n * Provides declarative transitions for elements entering and leaving the DOM.\n * Works seamlessly with For and conditional rendering (ternary, &&).\n */\n\nimport { onCleanup } from '../../core/signal'\nimport type { AnimatableProps, MotionController } from './Motion'\nimport { MotionController as MC } from './Motion'\nimport { f } from '../../renderers/dom/f'\n\n/**\n * Preset animation types\n */\nexport type TransitionPreset =\n | 'fade'\n | 'slide-up'\n | 'slide-down'\n | 'slide-left'\n | 'slide-right'\n | 'scale'\n | 'scale-fade'\n\n/**\n * Transition timing configuration\n */\nexport interface TransitionTiming {\n duration?: number\n delay?: number\n easing?: string\n}\n\n/**\n * Transition component props\n */\nexport interface TransitionProps {\n /** Use a preset animation */\n preset?: TransitionPreset\n /** Custom enter animation (from state) */\n enter?: AnimatableProps\n /** Custom enter animation (to state) */\n enterTo?: AnimatableProps\n /** Custom exit animation (to state) */\n exit?: AnimatableProps\n /** Enter timing */\n enterTiming?: TransitionTiming\n /** Exit timing */\n exitTiming?: TransitionTiming\n /** Callback when enter animation starts */\n onEnterStart?: () => void\n /** Callback when enter animation completes */\n onEnterComplete?: () => void\n /** Callback when exit animation starts */\n onExitStart?: () => void\n /** Callback when exit animation completes */\n onExitComplete?: () => void\n /** Children to animate */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n children: any\n}\n\n/**\n * Get animation keyframes for a preset\n */\nfunction getPresetKeyframes(preset: TransitionPreset): {\n enter: AnimatableProps\n enterTo: AnimatableProps\n exit: AnimatableProps\n} {\n switch (preset) {\n case 'fade':\n return {\n enter: { opacity: 0 },\n enterTo: { opacity: 1 },\n exit: { opacity: 0 },\n }\n case 'slide-up':\n return {\n enter: { opacity: 0, y: 20 },\n enterTo: { opacity: 1, y: 0 },\n exit: { opacity: 0, y: -20 },\n }\n case 'slide-down':\n return {\n enter: { opacity: 0, y: -20 },\n enterTo: { opacity: 1, y: 0 },\n exit: { opacity: 0, y: 20 },\n }\n case 'slide-left':\n return {\n enter: { opacity: 0, x: 20 },\n enterTo: { opacity: 1, x: 0 },\n exit: { opacity: 0, x: -20 },\n }\n case 'slide-right':\n return {\n enter: { opacity: 0, x: -20 },\n enterTo: { opacity: 1, x: 0 },\n exit: { opacity: 0, x: 20 },\n }\n case 'scale':\n return {\n enter: { scale: 0.9 },\n enterTo: { scale: 1 },\n exit: { scale: 0.9 },\n }\n case 'scale-fade':\n return {\n enter: { opacity: 0, scale: 0.95 },\n enterTo: { opacity: 1, scale: 1 },\n exit: { opacity: 0, scale: 0.95 },\n }\n default:\n return {\n enter: {},\n enterTo: {},\n exit: {},\n }\n }\n}\n\n/**\n * TransitionGroup context for staggered animations\n */\ninterface TransitionGroupContext {\n registerChild: () => number\n staggerDelay: number\n}\n\nlet currentTransitionGroup: TransitionGroupContext | null = null\n\n/**\n * Transition component for animated enter/exit\n *\n * @example\n * {() => visible() && (\n * <Transition preset=\"fade\">\n * <div>Content appears with fade</div>\n * </Transition>\n * )}\n *\n * @example\n * <Transition\n * enter={{ opacity: 0, y: 50 }}\n * enterTo={{ opacity: 1, y: 0 }}\n * exit={{ opacity: 0, y: -50 }}\n * enterTiming={{ duration: 300, easing: 'ease-out' }}\n * exitTiming={{ duration: 200, easing: 'ease-in' }}\n * >\n * <div>Custom animated content</div>\n * </Transition>\n */\nexport function Transition(props: TransitionProps) {\n const {\n preset,\n enter: customEnter,\n enterTo: customEnterTo,\n exit: customExit,\n enterTiming = { duration: 300, easing: 'ease-out' },\n exitTiming = { duration: 200, easing: 'ease-in' },\n onEnterStart,\n onEnterComplete,\n onExitStart,\n onExitComplete,\n children,\n } = props\n\n // Get keyframes from preset or custom props\n const presetFrames = preset ? getPresetKeyframes(preset) : null\n const enter = customEnter ?? presetFrames?.enter ?? {}\n const enterTo = customEnterTo ?? presetFrames?.enterTo ?? {}\n const exit = customExit ?? presetFrames?.exit ?? {}\n\n // Track the mounted element and controller\n let element: HTMLElement | null = null\n let controller: MotionController | null = null\n\n // Get stagger delay from group if present\n const staggerIndex = currentTransitionGroup?.registerChild() ?? 0\n const staggerDelay = currentTransitionGroup?.staggerDelay ?? 0\n const additionalDelay = staggerIndex * staggerDelay\n\n // Setup cleanup for exit animation\n onCleanup(async () => {\n if (element && controller) {\n onExitStart?.()\n\n await controller.animateExit(exit, exitTiming.duration, exitTiming.easing)\n\n onExitComplete?.()\n }\n })\n\n // Return wrapper div with ref to capture element\n return f(\n 'div',\n {\n style: { display: 'contents' },\n ref: (el: HTMLElement | null) => {\n if (!el) return\n\n element = el\n controller = new MC(el)\n\n // Schedule enter animation after DOM update\n queueMicrotask(() => {\n if (controller) {\n onEnterStart?.()\n\n controller.animate({\n initial: enter,\n animate: enterTo,\n duration: enterTiming.duration,\n easing: enterTiming.easing,\n delay: (enterTiming.delay ?? 0) + additionalDelay,\n onAnimationComplete: onEnterComplete,\n })\n }\n })\n },\n },\n children\n )\n}\n\n/**\n * TransitionGroup props\n */\nexport interface TransitionGroupProps {\n /** Delay between each child animation (stagger effect) */\n stagger?: number\n /** Children (should contain Transition components) */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n children: any\n}\n\n/**\n * TransitionGroup component for staggered animations\n *\n * @example\n * <TransitionGroup stagger={50}>\n * <For each={items}>\n * {(item) => (\n * <Transition preset=\"slide-up\">\n * <div>{item.name}</div>\n * </Transition>\n * )}\n * </For>\n * </TransitionGroup>\n */\nexport function TransitionGroup(props: TransitionGroupProps) {\n const { stagger = 50, children } = props\n\n let childIndex = 0\n\n const context: TransitionGroupContext = {\n registerChild: () => childIndex++,\n staggerDelay: stagger,\n }\n\n return () => {\n // Reset child index for each render\n childIndex = 0\n\n // Set context for child Transitions\n const previousGroup = currentTransitionGroup\n currentTransitionGroup = context\n\n try {\n return children\n } finally {\n currentTransitionGroup = previousGroup\n }\n }\n}\n\n/**\n * Preset transition configurations\n */\nexport const transitions = {\n fade: { preset: 'fade' },\n slideUp: { preset: 'slide-up' },\n slideDown: { preset: 'slide-down' },\n slideLeft: { preset: 'slide-left' },\n slideRight: { preset: 'slide-right' },\n scale: { preset: 'scale' },\n scaleFade: { preset: 'scale-fade' },\n\n // Common UI patterns\n modal: {\n enter: { opacity: 0, scale: 0.95, y: -10 },\n enterTo: { opacity: 1, scale: 1, y: 0 },\n exit: { opacity: 0, scale: 0.95, y: 10 },\n enterTiming: { duration: 200, easing: 'cubic-bezier(0.16, 1, 0.3, 1)' },\n exitTiming: { duration: 150, easing: 'ease-in' },\n },\n\n dropdown: {\n enter: { opacity: 0, y: -8, scale: 0.95 },\n enterTo: { opacity: 1, y: 0, scale: 1 },\n exit: { opacity: 0, y: -8, scale: 0.95 },\n enterTiming: { duration: 150, easing: 'ease-out' },\n exitTiming: { duration: 100, easing: 'ease-in' },\n },\n\n tooltip: {\n enter: { opacity: 0, scale: 0.9 },\n enterTo: { opacity: 1, scale: 1 },\n exit: { opacity: 0, scale: 0.9 },\n enterTiming: { duration: 100, easing: 'ease-out' },\n exitTiming: { duration: 75, easing: 'ease-in' },\n },\n\n notification: {\n enter: { opacity: 0, x: 100 },\n enterTo: { opacity: 1, x: 0 },\n exit: { opacity: 0, x: 100 },\n enterTiming: { duration: 300, easing: 'cubic-bezier(0.16, 1, 0.3, 1)' },\n exitTiming: { duration: 200, easing: 'ease-in' },\n },\n\n page: {\n enter: { opacity: 0 },\n enterTo: { opacity: 1 },\n exit: { opacity: 0 },\n enterTiming: { duration: 200, easing: 'ease-out' },\n exitTiming: { duration: 150, easing: 'ease-in' },\n },\n} satisfies Record<string, Omit<TransitionProps, 'children'>>\n"]}
@@ -0,0 +1,3 @@
1
+ import {c as c$2}from'./chunk-HLPVL6EK.mjs';import {d,e,b as b$2,c as c$1,a as a$1}from'./chunk-7Q4UE442.mjs';import {c}from'./chunk-WVEJT7HD.mjs';import {f,g,d as d$1}from'./chunk-B7VP6HBY.mjs';import {k,b as b$1,a,i}from'./chunk-Q7WT5IIF.mjs';var Ne=new Set,xe=new Set(["focus","blur","mouseenter","mouseleave","load","unload","scroll"]),X=new WeakMap;function we(e){let t=e.type.toLowerCase(),n=!xe.has(t),o=e.composedPath?.()||[],r=e.target;if(o.length===0&&r)for(;r;)o.push(r),r=r.parentNode;for(let i of o){let s=i;if(s===document||!s)break;let p=X.get(s);if(p?.has(t)){let l=p.get(t);if(l){try{l(e);}catch(d){b$1(a.EVENT_HANDLER_FAILED,{eventType:t},d);}if(e.cancelBubble)return}}if(!n)break}}function Re(e){if(!(typeof document>"u")&&!Ne.has(e)){let t=xe.has(e);document.addEventListener(e,we,{capture:t}),Ne.add(e);}}var re={on(e,t,n){let o=t.toLowerCase(),r=X.get(e);r||(r=new Map,X.set(e,r)),r.set(o,n),Re(o);},off(e,t){let n=t.toLowerCase(),o=X.get(e);o&&o.delete(n);}};var Z={width:{cssProp:"width",transform:"px"},height:{cssProp:"height",transform:"px"},flexDirection:{cssProp:"flexDirection",transform:"none"},justifyContent:{cssProp:"justifyContent",transform:"none"},alignItems:{cssProp:"alignItems",transform:"none"},alignSelf:{cssProp:"alignSelf",transform:"none"},flexWrap:{cssProp:"flexWrap",transform:"none"},flex:{cssProp:"flex",transform:"string"},gap:{cssProp:"gap",transform:"px"},justify:{cssProp:"justifyContent",transform:"none"},align:{cssProp:"alignItems",transform:"none"},bg:{cssProp:"backgroundColor",transform:"none"},color:{cssProp:"color",transform:"none"},borderRadius:{cssProp:"borderRadius",transform:"px"},borderWidth:{cssProp:"borderWidth",transform:"px",sideEffect:(e,t)=>{t!==void 0&&e.borderStyle!=="solid"&&(e.borderStyle="solid");}},borderColor:{cssProp:"borderColor",transform:"none"},opacity:{cssProp:"opacity",transform:"string"},fontSize:{cssProp:"fontSize",transform:"px"},fontWeight:{cssProp:"fontWeight",transform:"string"},fontFamily:{cssProp:"fontFamily",transform:"none"},lineHeight:{cssProp:"lineHeight",transform:"string"},textAlign:{cssProp:"textAlign",transform:"none"},padding:{cssProp:"padding",transform:"px"},paddingTop:{cssProp:"paddingTop",transform:"px"},paddingRight:{cssProp:"paddingRight",transform:"px"},paddingBottom:{cssProp:"paddingBottom",transform:"px"},paddingLeft:{cssProp:"paddingLeft",transform:"px"},margin:{cssProp:"margin",transform:"px"},marginTop:{cssProp:"marginTop",transform:"px"},marginRight:{cssProp:"marginRight",transform:"px"},marginBottom:{cssProp:"marginBottom",transform:"px"},marginLeft:{cssProp:"marginLeft",transform:"px"}},Ce={Row:"div",Column:"div",Stack:"div",Text:"span",Button:"button",Input:"input",Container:"div"},q={onPress:"click",onHover:"mouseenter",onChange:"input",onFocus:"focus",onBlur:"blur"},be=new Set(["children","key","ref","className","style","width","height","padding","paddingTop","paddingRight","paddingBottom","paddingLeft","margin","marginTop","marginRight","marginBottom","marginLeft","gap","flex","flexDirection","flexWrap","justifyContent","alignItems","alignSelf","align","justify","bg","color","borderRadius","borderWidth","borderColor","opacity","fontSize","fontWeight","fontFamily","lineHeight","textAlign"]),_e="http://www.w3.org/2000/svg",Fe=new Set(["svg","path","circle","rect","line","polyline","polygon","ellipse","g","text","tspan","defs","use","symbol","marker","linearGradient","radialGradient","stop","clipPath","pattern","mask","filter"]),Me={viewBox:"viewBox",preserveAspectRatio:"preserveAspectRatio",strokeWidth:"stroke-width",strokeLinecap:"stroke-linecap",strokeLinejoin:"stroke-linejoin",strokeDasharray:"stroke-dasharray",strokeDashoffset:"stroke-dashoffset",fillOpacity:"fill-opacity",strokeOpacity:"stroke-opacity",stopColor:"stop-color",stopOpacity:"stop-opacity",clipPath:"clip-path",markerEnd:"marker-end",markerStart:"marker-start",markerMid:"marker-mid"};function Pe(e){return typeof e=="number"?`${e}px`:e}var ve=new Map;function Se(e){let t=ve.get(e);return t===void 0&&(t=e.replace(/[A-Z]/g,n=>`-${n.toLowerCase()}`),ve.set(e,t)),t}function De(e){return e.replace(/&/g,"&amp;").replace(/"/g,"&quot;").replace(/'/g,"&#39;").replace(/</g,"&lt;").replace(/>/g,"&gt;")}function Ie(e,t){if(e!=null)switch(t){case "px":return Pe(e);case "string":return String(e);case "none":default:return e}}function He(e,t,n){let o=e.style,r=t.style,i=n.style;if(r!==i){if(r&&typeof r=="object")for(let d in r)(!i||!(d in i))&&o.setProperty(Se(d),"");if(i&&typeof i=="object")for(let d in i){let f=i[d];(!r||r[d]!==f)&&o.setProperty(Se(d),f);}}let s=e.getAttribute("data-flexium-type");(n.flexDirection||n.justifyContent||n.alignItems||n.flexWrap||n.gap!==void 0||n.justify||n.align||s==="Row"||s==="Column"||s==="Stack")&&(o.display!=="flex"&&(o.display="flex"),s==="Row"&&o.flexDirection!=="row"&&(o.flexDirection="row"),s==="Column"&&o.flexDirection!=="column"&&(o.flexDirection="column"));let l=o;for(let d in t)if(d in Z&&!(d in n)){let f=Z[d],m=f.cssProp,a=l[m];a!==void 0&&a!==""&&(l[m]=""),f.sideEffect&&f.sideEffect(o,void 0);}for(let d in n)if(d in Z){let f=t[d],m=n[d];if(f===m)continue;let a=Z[d],c=Ie(m,a.transform),u=a.cssProp,N=l[u];c===void 0?N!==void 0&&N!==""&&(l[u]=""):N!==c&&(l[u]=c),a.sideEffect&&a.sideEffect(o,c);}}function Ee(e){if(typeof e=="string")return e;if(Array.isArray(e)){let t="";for(let n=0;n<e.length;n++){let o=e[n];if(!o)continue;let r=typeof o=="string"?o:Ee(o);r&&(t=t?`${t} ${r}`:r);}return t}if(typeof e=="object"&&e!==null){let t="";for(let n in e)e[n]&&(t=t?`${t} ${n}`:n);return t}return ""}var ie=class{createNode(t,n){let o=Ce[t]??t,r;return Fe.has(o)?r=document.createElementNS(_e,o):r=document.createElement(o),Ce[t]&&r.setAttribute("data-flexium-type",t),this.updateNode(r,{},n),r}updateNode(t,n,o){if(o.className!==n.className){let i=Ee(o.className);t instanceof SVGElement?t.setAttribute("class",i):t.className=i;}He(t,n,o);for(let i in n)if(!(i in o)){if(typeof i=="symbol")continue;if(i.startsWith("on")){let s=q[i]||i.slice(2).toLowerCase();this.removeEventListener(t,s,n[i]);}else be.has(i)||t.removeAttribute(i);}let r=Reflect.ownKeys(o);for(let i of r){if(typeof i=="symbol")continue;let s=i,p=o[s],l=n[s];if(p!==l){if(s.startsWith("on")){let d=q[s]||s.slice(2).toLowerCase();l&&this.removeEventListener(t,d,l),p&&this.addEventListener(t,d,p);}else if(!be.has(s))if(p==null||p===false)t.removeAttribute(s);else if(p===true)t.setAttribute(s,"");else {let d=Me[s]||s;t.setAttribute(d,De(String(p)));}}}}appendChild(t,n){t.appendChild(n);}insertBefore(t,n,o){t.insertBefore(n,o);}nextSibling(t){return t.nextSibling}removeChild(t,n){t.removeChild(n);}createTextNode(t){return document.createTextNode(t)}updateTextNode(t,n){t.textContent=n;}addEventListener(t,n,o){let r=q[n]||n;re.on(t,r,o);}removeEventListener(t,n,o){let r=q[n]||n;re.off(t,r);}},C=new ie;var se=Symbol("flexium.list");function de(e){return e!==null&&typeof e=="object"&&se in e&&e[se]===true}function Oe(e,t){return typeof e=="number"?e:e.mode==="fixed"?e.itemHeight:e.estimatedItemHeight}function Be(e,t,n,o,r){let i=o*n;if(o===0)return {startIndex:0,endIndex:-1,totalHeight:0};let s=Math.floor(e/n),p=Math.ceil(t/n),l=s+p;return {startIndex:Math.max(0,s-r),endIndex:Math.min(o-1,l+r),totalHeight:i}}function ce(e,t,n,o){return e.virtual?$e(e,t,n,o):Ve(e,t,n,o)}function Ve(e,t,n,o){let{each:r,renderItem:i,getKey:s,class:p,style:l}=e,d=document.createElement("div");d.setAttribute("role","list"),p&&(d.className=p),l&&Object.entries(l).forEach(([c,u])=>{d.style[c]=typeof u=="number"?`${u}px`:u;}),t.appendChild(d);let f=new Map,m=(c,u)=>s?s(c,u):u,a=k(()=>{let c=r()||[],u=new Set;c.forEach((N,h)=>{let x=m(N,h);if(u.add(x),!f.has(x)){let L=new d$1(h),y=i(N,()=>L.get()),g=n(y);g&&g instanceof HTMLElement&&(g.setAttribute("role","listitem"),d.appendChild(g),f.set(x,{node:g,dispose:()=>{try{o(g);}catch{}}}));}});for(let[N,h]of f)u.has(N)||(h.dispose(),h.node.parentNode===d&&d.removeChild(h.node),f.delete(N));});return ()=>{a();for(let c of f.values())c.dispose();f.clear(),d.parentNode===t&&t.removeChild(d);}}function $e(e,t,n,o){let{each:r,renderItem:i,height:s,width:p,itemSize:l,overscan:d,getKey:f,onScroll:m,onVisibleRangeChange:a}=e;if(!s||!l)return console.warn("List: height and itemSize are required when virtual is true"),()=>{};let c=document.createElement("div");c.style.height=typeof s=="number"?`${s}px`:s,c.style.width=p?typeof p=="number"?`${p}px`:p:"100%",c.style.overflow="auto",c.style.position="relative",c.setAttribute("role","list"),c.setAttribute("tabindex","0");let u=document.createElement("div");u.style.position="relative",u.style.width="100%";let N=new d$1(0),h=new Map,x=-1,L=-1,y=()=>{N.set(c.scrollTop),m?.(c.scrollTop);};c.addEventListener("scroll",y,{passive:true});let g=(w,M)=>f?f(w,M):M,E=k(()=>{let w=r()||[],M=N.get(),j=c.clientHeight||parseFloat(String(s)),P=Oe(l),{startIndex:K,endIndex:z,totalHeight:ke}=Be(M,j,P,w.length,d);u.style.height=`${ke}px`,c.setAttribute("aria-rowcount",String(w.length)),(K!==x||z!==L)&&(a?.(K,z),x=K,L=z);let fe=new Set;for(let v=K;v<=z&&v<w.length;v++){let R=w[v],O=g(R,v);fe.add(O);let I=h.get(O),te=h.get(O)?.state;if(te?te.set(R):te=new d$1(R),I){I.indexSig.peek()!==v&&I.indexSig.set(v);let B=I.node;B.style.transform=`translateY(${v*P}px)`,B.setAttribute("aria-rowindex",String(v+1));}else {let B=new d$1(v),Ae=i(R,()=>B.get()),T=n(Ae);T&&T instanceof HTMLElement&&(T.style.position="absolute",T.style.top="0",T.style.left="0",T.style.right="0",T.style.transform=`translateY(${v*P}px)`,T.style.height=`${P}px`,T.style.boxSizing="border-box",T.setAttribute("role","listitem"),T.setAttribute("aria-rowindex",String(v+1)),u.appendChild(T),I={item:R,key:O,node:T,indexSig:B,dispose:()=>{try{o(T);}catch{}}},h.set(O,I));}}for(let[v,R]of h)fe.has(v)||(R.dispose(),R.node.parentNode===u&&u.removeChild(R.node),h.delete(v));});return ()=>{E(),c.removeEventListener("scroll",y);for(let w of h.values())w.dispose();h.clear(),c.parentNode===t&&t.removeChild(c);}}var Te=new WeakMap;function A(e){return Te.get(e)}function D(e,t){Te.set(e,t);}var G;(s=>{let e=[],t=[];function o(){if(e.length>0){let p=e.pop();return p.clear(),p}return new Map}s.getMap=o;function r(){if(t.length>0){let p=t.pop();return p.clear(),p}return new Set}s.getSet=r;function i(p,l){e.length<10&&e.push(p),t.length<10&&t.push(l);}s.release=i;})(G||(G={}));function Y(e,t,n,o){let r=t&&t.length>0,i=n&&n.length>0;if(!r&&!i)return;if(!i){for(let a of t){let c=a&&A(a);c&&(S(c),C.removeChild(e,c));}return}if(!r){let a=document.createDocumentFragment();for(let c of n){let u=b(c,void 0);u&&(D(c,u),a.appendChild(u));}o?e.insertBefore(a,o):e.appendChild(a);return}let s=t.length,p=n.length,l=5;if(s<=l&&p<=l){let a=0,c=0,u=e.firstChild;for(;a<s||c<p;){if(c>=p){for(;a<s;){let y=t[a++],g=y&&A(y);g&&(S(g),C.removeChild(e,g));}break}if(a>=s){let y=document.createDocumentFragment();for(;c<p;){let g=n[c++],E=b(g,void 0);E&&(D(g,E),y.appendChild(E));}o?e.insertBefore(y,o):e.appendChild(y);break}let N=t[a],h=n[c],x=N.key??`__idx_${a}_${N.type}`,L=h.key??`__idx_${c}_${h.type}`;if(x===L&&N.type===h.type)le(N,h),u=u?.nextSibling||null,a++,c++;else {let y=false;for(let g=a+1;g<s;g++){let E=t[g];if((E.key??`__idx_${g}_${E.type}`)===L&&E.type===h.type){for(let M=a;M<g;M++){let j=t[M],P=j&&A(j);P&&(S(P),C.removeChild(e,P));}le(E,h),a=g+1,c++,y=true;break}}if(!y){let g=b(h,void 0);g&&(D(h,g),e.insertBefore(g,u)),c++;}}}return}let d=G.getMap(),f=G.getSet();for(let a=0;a<s;a++){let c=t[a],u=c.key??`__idx_${a}_${c.type}`;d.set(u,c);}let m=e.firstChild;for(let a=0;a<n.length;a++){let c=n[a],u=c.key??`__idx_${a}_${c.type}`;f.add(u);let N=d.get(u),h=m;if(!N||N.type!==c.type){let x=b(c,void 0);x&&(D(c,x),e.insertBefore(x,h));}else {le(N,c);let x=A(c);x&&(m!==x?e.insertBefore(x,h):m=m?.nextSibling||null);}}for(let[a,c]of d){let u=A(c);!f.has(a)&&u&&(S(u),u.parentNode===e&&C.removeChild(e,u));}G.release(d,f);}function le(e,t){let n=A(e);if(!n||(D(t,n),typeof t.type!="string"))return;C.updateNode(n,e.props,t.props);let o=e.children||[],r=t.children||[];if(!(o.length===0&&r.length===0)){if(r.length===1&&(typeof r[0]=="string"||typeof r[0]=="number")&&n.firstChild?.nodeType===Node.TEXT_NODE&&n.childNodes.length===1){let i=String(r[0]);String(o[0])!==i&&C.updateTextNode(n.firstChild,i);return}Y(n,o,r,null);}}var W=new WeakMap,J=new Set,ae=false;function ee(e){J.add(e),ae||(ae=true,requestAnimationFrame(()=>{Ge();}));}function Ge(){if(ae=false,J.size===0)return;let e=Array.from(J);J.clear();for(let t=0;t<e.length;t++)e[t]();}function H(e,t){let n=W.get(e);n||(n=new Set,W.set(e,n)),n.add(t);}function b(e$1,t){if(e$1==null||typeof e$1=="boolean")return null;if(de(e$1)){let n=t||document.createDocumentFragment(),o=ce(e$1,n,i=>b(i),S),r=document.createTextNode("");return H(r,o),t?n.firstChild:n}if(d(e$1)){let n=e(e$1);if(n){let o=document.createTextNode(""),r=t||document.createDocumentFragment();C.appendChild(r,o);let i=o,s=k(()=>{let p=n.get(),l=o.parentNode;if(l)if((typeof p=="string"||typeof p=="number")&&i&&i.nodeType===Node.TEXT_NODE&&i!==o){let d=i,f=String(p);ee(()=>{C.updateTextNode(d,f);});}else {let d=b(p);if(d)if(i&&i!==o)if(i.parentNode===l)if(i.nodeType===Node.TEXT_NODE&&d.nodeType===Node.TEXT_NODE){let f=i,m=d.textContent||"";ee(()=>{C.updateTextNode(f,m);});}else l.replaceChild(d,i),i=d;else l.insertBefore(d,o.nextSibling),i=d;else l.insertBefore(d,o.nextSibling),i=d;else {if(i&&i!==o&&i.parentNode===l)try{l.removeChild(i);}catch(f){b$1(a.DOM_CLEANUP_FAILED,{operation:"removeChild"},f);}i=o;}}});return H(o,s),t?o:r}}if(f(e$1)||typeof e$1=="function"){let n=document.createTextNode(""),o=t||document.createDocumentFragment();C.appendChild(o,n);let r=[],i=null,s=[],p=k(()=>{let l=f(e$1)?e$1.get():e$1(),d=n.parentNode;if(d){if(Array.isArray(l)){let f=l.filter(m=>m!=null);if(s.length>0){let m=n.nextSibling;Y(d,s,f,m);}else {for(let a$1 of r)if(S(a$1),a$1.parentNode===d)try{d.removeChild(a$1);}catch(c){b$1(a.DOM_CLEANUP_FAILED,{operation:"removeChild"},c);}r=[];let m=document.createDocumentFragment();for(let a of f){let c=b(a,m);c&&typeof a=="object"&&D(a,c);}r=Array.from(m.childNodes),d.insertBefore(m,n.nextSibling);}s=f,i=l;return}if(s.length>0){for(let f of s){let m=A(f);if(m&&m.parentNode===d){S(m);try{d.removeChild(m);}catch(a$1){b$1(a.DOM_CLEANUP_FAILED,{operation:"removeChild"},a$1);}}}s=[];}if(l!==i){for(let f of r)if(S(f),f.parentNode===d)try{d.removeChild(f);}catch(m){b$1(a.DOM_CLEANUP_FAILED,{operation:"removeChild"},m);}if(r=[],typeof l=="string"||typeof l=="number"){let f=C.createTextNode(String(l));d.insertBefore(f,n.nextSibling),r=[f];}else {let f=b(l);f&&(f.nodeType===Node.DOCUMENT_FRAGMENT_NODE?(r=Array.from(f.childNodes),d.insertBefore(f,n.nextSibling)):(d.insertBefore(f,n.nextSibling),r=[f]));}i=l;}}});return H(n,p),t?n:o}if(Array.isArray(e$1)){let n=document.createDocumentFragment();for(let o of e$1)b(o,n);return t&&C.appendChild(t,n),n}if(typeof e$1=="string"||typeof e$1=="number"){let n=C.createTextNode(String(e$1));return t&&C.appendChild(t,n),n}if(c(e$1)){if(typeof e$1.type=="function"){let i$1=e$1.type,s=document.createTextNode(""),p=t||document.createDocumentFragment();C.appendChild(p,s);let l=[],d=[],f=b$2(),m=k(()=>{c$1(f),i(a$2=>{g(a$2);let c$1=i$1._contextId;c$1&&c$2(c$1,e$1.props.value);let u;try{a$1(f);let y=e$1.children!==void 0?{...e$1.props,children:e$1.children}:e$1.props;u=i$1(y);}finally{a$1(null);}if(Array.isArray(u)&&u.every(y=>c(y)&&y.type!=="fragment")){let y=s.parentNode;if(y){let g=u;Y(y,d,g,s.nextSibling),d=g,l=g.map(E=>A(E)).filter(E=>E!=null);return}}let x=s.parentNode;if(x){for(let y of l)if(S(y),y.parentNode===x)try{x.removeChild(y);}catch(g){b$1(a.DOM_CLEANUP_FAILED,{operation:"removeChild"},g);}}l=[],d=[];let L=document.createDocumentFragment();b(u,L),x&&(l=Array.from(L.childNodes),x.insertBefore(L,s.nextSibling));});});return H(s,m),t?s:p}if(e$1.type==="fragment"){let i=document.createDocumentFragment();for(let s of e$1.children)b(s,i);return t&&C.appendChild(t,i),i}let n=C.createNode(e$1.type,e$1.props),o=We(n,e$1.props);o.length>0&&W.set(n,new Set(o));for(let i of e$1.children)b(i,n);t&&C.appendChild(t,n);let r=e$1.props.ref;return r&&(typeof r=="function"?(r(n),H(n,()=>{r(null);})):typeof r=="object"&&"current"in r&&(r.current=n,H(n,()=>{r.current=null;}))),n}return null}var Q=Symbol("uninitialized");function We(e,t){let n=[],o=[];for(let r in t){if(r.startsWith("on"))continue;let i=t[r];(f(i)||typeof i=="function")&&o.push([r,i]);}for(let[r,i]of o)if(f(i)){let s=Q,p=k(()=>{let l=i.get();if(l!==s){let d=s===Q?void 0:s;ee(()=>{C.updateNode(e,{[r]:d},{[r]:l});}),s=l;}});n.push(p);}else {let s=Q,p=k(()=>{try{let l=i();if(l!==s){let d=s===Q?void 0:s;ee(()=>{C.updateNode(e,{[r]:d},{[r]:l});}),s=l;}}catch(l){b$1(a.DOM_CLEANUP_FAILED,{operation:"updateNode",prop:r},l);}});n.push(p);}return n}function S(e){let t=W.get(e);if(t&&(t.forEach(n=>n()),W.delete(e)),e.childNodes&&e.childNodes.length>0){let n=Array.from(e.childNodes);for(let o of n)S(o);}}function Le(e){let t=null,n=null,o=null;return {render(r){let i=o===r;!i&&n&&(S(n),e.childNodes.length===1?e.removeChild(n):e.innerHTML="",n=null),t&&(t(),t=null),t=k(()=>{!i&&e.firstChild&&(e.childNodes.length===1?e.removeChild(e.firstChild):e.innerHTML=""),n=b(r,e),o=r;});},unmount(){t&&(t(),t=null),S(e),e.childNodes.length===1?e.removeChild(e.firstChild):e.innerHTML="",n=null,o=null;}}}function xt(e,t){return t.innerHTML="",b(e,t)}function Ct(e){return Le(e)}function Et(e){if(typeof document>"u")return null;let t=e.mount||document.body,n=document.createComment("portal"),o=null;return o=b(e.children,t),g(()=>{o&&(S(o),o.parentNode===t&&t.removeChild(o));}),n}
2
+ export{ie as a,C as b,se as c,de as d,b as e,Le as f,xt as g,Ct as h,Et as i};//# sourceMappingURL=chunk-6K44QCMT.mjs.map
3
+ //# sourceMappingURL=chunk-6K44QCMT.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/renderers/dom/events.ts","../src/renderers/dom/index.ts","../src/primitives/List/List.ts","../src/renderers/dom/node-map.ts","../src/renderers/dom/reconcile.ts","../src/renderers/dom/reactive.ts","../src/renderers/dom/render.ts","../src/renderers/dom/portal.ts"],"names":["globalListeners","NON_BUBBLING_EVENTS","nodeHandlers","dispatchEvent","event","eventType","bubbles","path","current","node","targetNode","handlers","handler","error","logError","ErrorCodes","ensureGlobalListener","eventName","capture","eventDelegator","lowerEvent","STYLE_PROPS_CONFIG","style","value","ELEMENT_MAPPING","EVENT_MAPPING","SKIP_PROPS","SVG_NAMESPACE","SVG_TAGS","SVG_ATTR_MAP","px","kebabCache","toKebabCase","str","result","letter","escapeAttrValue","transformValue","transform","updateStyles","element","oldProps","newProps","oldStyle","newStyle","key","val","type","styleRecord","propName","config","cssProp","currentValue","oldValue","newValue","transformedValue","normalizeClass","i","item","normalized","k","DOMRenderer","props","tagName","className","keys","strKey","newVal","oldVal","attrName","parent","child","beforeChild","text","domEvent","_handler","domRenderer","LIST_MARKER","isListComponent","getItemHeight","_index","calculateVisibleRangeFixed","scrollTop","viewportHeight","itemHeight","totalItems","overscan","totalHeight","start","visibleCount","end","mountListComponent","comp","mountFn","cleanupFn","mountVirtualList","mountSimpleList","each","renderItem","getKey","container","cache","getItemKey","index","disposeEffect","effect","list","currentKeys","indexSig","SignalNode","vnode","entry","height","width","itemSize","onScroll","onVisibleRangeChange","innerContainer","scrollTopSig","prevStartIndex","prevEndIndex","handleScroll","currentScrollTop","startIndex","endIndex","visibleKeys","rowState","fnodeToNode","getNode","fnode","setNode","ReconciliationPool","mapPool","setPool","getMap","map","getSet","set","release","reconcileArrays","oldFNodes","newFNodes","nextSibling","hasOld","hasNew","cleanupReactive","fragment","newFNode","mountReactive","oldLen","newLen","SMALL_LIST_THRESHOLD","oldIdx","newIdx","currentChild","oldFNode","oldKey","newKey","patchNode","found","searchIdx","searchFNode","removeIdx","removeFNode","keyToOldFNode","seen","refNode","oldChildren","newChildren","newText","REACTIVE_BINDINGS","domUpdateQueue","isDOMUpdateScheduled","scheduleDOMUpdate","task","flushDOMUpdates","queue","registerReactiveBinding","dispose","bindings","listDispose","childNode","marker","isStateValue","sig","getStateSignal","startNode","currentNode","currentContainer","textNode","textValue","newNode","textContent","e","isSignal","currentNodes","currentFNode","currentFNodeList","c","childFNode","isFNode","component","componentInstance","createComponentInstance","resetHookIndex","root","disposeRoot","onCleanup","contextId","pushProvider","setCurrentComponent","componentProps","fn","n","currentParent","domNode","disposeProps","setupReactiveProps","ref","UNINITIALIZED","disposers","reactiveProps","prevValue","oldPropValue","children","createReactiveRoot","rootDispose","currentRootNode","isSameNode","render","createRoot","Portal","placeholder","portalContent"],"mappings":"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","file":"chunk-6K44QCMT.mjs","sourcesContent":["import type { EventHandler } from '../../core/renderer'\nimport { logError, ErrorCodes } from '../../core/errors'\n\n// Map of event names to global listener status\nconst globalListeners = new Set<string>()\n\n// Events that do not bubble and must be captured\nconst NON_BUBBLING_EVENTS = new Set([\n 'focus',\n 'blur',\n 'mouseenter',\n 'mouseleave',\n 'load',\n 'unload',\n 'scroll',\n])\n\n// WeakMap to store event handlers for each node\n// Key: DOM Node, Value: Map<EventName, Handler>\nconst nodeHandlers = new WeakMap<Node, Map<string, EventHandler>>()\n\n/**\n * Global event dispatcher that handles delegation\n */\nfunction dispatchEvent(event: Event) {\n\n const eventType = event.type.toLowerCase()\n const bubbles = !NON_BUBBLING_EVENTS.has(eventType)\n\n // Use composedPath if available (handles Shadow DOM and is faster)\n // Fallback to parentNode traversal for older browsers\n const path = event.composedPath?.() || []\n let current: Node | null = event.target as Node\n\n if (path.length === 0 && current) {\n // Build path manually if composedPath not available\n while (current) {\n path.push(current)\n current = current.parentNode\n }\n }\n\n for (const node of path) {\n const targetNode = node as Node\n // Stop at document or if we hit the end\n if (targetNode === document || !targetNode) break\n\n const handlers = nodeHandlers.get(targetNode)\n if (handlers?.has(eventType)) {\n const handler = handlers.get(eventType)\n if (handler) {\n try {\n handler(event)\n } catch (error) {\n logError(ErrorCodes.EVENT_HANDLER_FAILED, { eventType }, error)\n }\n if (event.cancelBubble) return\n }\n }\n\n if (!bubbles) break\n }\n}\n\n/**\n * Register a global event listener for delegation\n */\nfunction ensureGlobalListener(eventName: string) {\n // SSR guard\n if (typeof document === 'undefined') return\n\n if (!globalListeners.has(eventName)) {\n const capture = NON_BUBBLING_EVENTS.has(eventName)\n document.addEventListener(eventName, dispatchEvent, { capture })\n globalListeners.add(eventName)\n }\n}\n\n/**\n * Clear all global event listeners (useful for SSR cleanup and testing)\n */\nexport function clearGlobalListeners(): void {\n // SSR guard\n if (typeof document === 'undefined') return\n\n for (const eventName of globalListeners) {\n const capture = NON_BUBBLING_EVENTS.has(eventName)\n document.removeEventListener(eventName, dispatchEvent, { capture })\n }\n globalListeners.clear()\n}\n\n/**\n * Event Delegation System\n */\nexport const eventDelegator = {\n /**\n * Attach an event handler to a node (virtual attachment)\n */\n on(node: Node, eventName: string, handler: EventHandler) {\n // normalize event name (e.g., 'click' -> 'click')\n const lowerEvent = eventName.toLowerCase()\n\n let handlers = nodeHandlers.get(node)\n if (!handlers) {\n handlers = new Map()\n nodeHandlers.set(node, handlers)\n }\n\n handlers.set(lowerEvent, handler)\n ensureGlobalListener(lowerEvent)\n },\n\n /**\n * Detach an event handler from a node\n */\n off(node: Node, eventName: string) {\n const lowerEvent = eventName.toLowerCase()\n const handlers = nodeHandlers.get(node)\n if (handlers) {\n handlers.delete(lowerEvent)\n }\n },\n}\n","import type { Renderer, EventHandler } from '../../core/renderer'\nimport { eventDelegator } from './events'\n\n/**\n * Style property configuration for data-driven updates\n */\ninterface StylePropConfig {\n /** CSS property name to set */\n cssProp: string\n /** Transform function (e.g., px for pixel values) */\n transform?: 'px' | 'string' | 'none'\n /** Additional side effect when setting this property */\n sideEffect?: (style: CSSStyleDeclaration, value: string | undefined) => void\n}\n\n/**\n * Data-driven style property mappings\n * Maps Flexium props to CSS properties with optional transformations\n */\nconst STYLE_PROPS_CONFIG: Record<string, StylePropConfig> = {\n // Layout\n width: { cssProp: 'width', transform: 'px' },\n height: { cssProp: 'height', transform: 'px' },\n\n // Flex properties\n flexDirection: { cssProp: 'flexDirection', transform: 'none' },\n justifyContent: { cssProp: 'justifyContent', transform: 'none' },\n alignItems: { cssProp: 'alignItems', transform: 'none' },\n alignSelf: { cssProp: 'alignSelf', transform: 'none' },\n flexWrap: { cssProp: 'flexWrap', transform: 'none' },\n flex: { cssProp: 'flex', transform: 'string' },\n gap: { cssProp: 'gap', transform: 'px' },\n\n // Shorthands\n justify: { cssProp: 'justifyContent', transform: 'none' },\n align: { cssProp: 'alignItems', transform: 'none' },\n\n // Visual\n bg: { cssProp: 'backgroundColor', transform: 'none' },\n color: { cssProp: 'color', transform: 'none' },\n borderRadius: { cssProp: 'borderRadius', transform: 'px' },\n borderWidth: {\n cssProp: 'borderWidth',\n transform: 'px',\n sideEffect: (style, value) => {\n if (value !== undefined && style.borderStyle !== 'solid') {\n style.borderStyle = 'solid'\n }\n },\n },\n borderColor: { cssProp: 'borderColor', transform: 'none' },\n opacity: { cssProp: 'opacity', transform: 'string' },\n\n // Typography\n fontSize: { cssProp: 'fontSize', transform: 'px' },\n fontWeight: { cssProp: 'fontWeight', transform: 'string' },\n fontFamily: { cssProp: 'fontFamily', transform: 'none' },\n lineHeight: { cssProp: 'lineHeight', transform: 'string' },\n textAlign: { cssProp: 'textAlign', transform: 'none' },\n\n // Padding\n padding: { cssProp: 'padding', transform: 'px' },\n paddingTop: { cssProp: 'paddingTop', transform: 'px' },\n paddingRight: { cssProp: 'paddingRight', transform: 'px' },\n paddingBottom: { cssProp: 'paddingBottom', transform: 'px' },\n paddingLeft: { cssProp: 'paddingLeft', transform: 'px' },\n\n // Margin\n margin: { cssProp: 'margin', transform: 'px' },\n marginTop: { cssProp: 'marginTop', transform: 'px' },\n marginRight: { cssProp: 'marginRight', transform: 'px' },\n marginBottom: { cssProp: 'marginBottom', transform: 'px' },\n marginLeft: { cssProp: 'marginLeft', transform: 'px' },\n}\n\n/**\n * Component type to HTML element mapping\n */\nconst ELEMENT_MAPPING: Record<string, string> = {\n Row: 'div',\n Column: 'div',\n Stack: 'div',\n Text: 'span',\n Button: 'button',\n Input: 'input',\n Container: 'div',\n}\n\n/**\n * Event name mapping (platform-agnostic to DOM)\n */\nconst EVENT_MAPPING: Record<string, string> = {\n onPress: 'click',\n onHover: 'mouseenter',\n onChange: 'input',\n onFocus: 'focus',\n onBlur: 'blur',\n}\n\n/**\n * Props that should not be set as DOM attributes\n */\nconst SKIP_PROPS = new Set([\n 'children',\n 'key',\n 'ref',\n 'className',\n 'style',\n // Layout props (handled via style)\n 'width',\n 'height',\n 'padding',\n 'paddingTop',\n 'paddingRight',\n 'paddingBottom',\n 'paddingLeft',\n 'margin',\n 'marginTop',\n 'marginRight',\n 'marginBottom',\n 'marginLeft',\n 'gap',\n 'flex',\n 'flexDirection',\n 'flexWrap',\n 'justifyContent',\n 'alignItems',\n 'alignSelf',\n // Shorthand flexbox props\n 'align',\n 'justify',\n // Visual props (handled via style)\n 'bg',\n 'color',\n 'borderRadius',\n 'borderWidth',\n 'borderColor',\n 'opacity',\n // Typography props\n 'fontSize',\n 'fontWeight',\n 'fontFamily',\n 'lineHeight',\n 'textAlign',\n])\n\n/**\n * SVG Namespace URI\n */\nconst SVG_NAMESPACE = 'http://www.w3.org/2000/svg'\n\n/**\n * Common SVG tags that require namespace\n */\nconst SVG_TAGS = new Set([\n 'svg',\n 'path',\n 'circle',\n 'rect',\n 'line',\n 'polyline',\n 'polygon',\n 'ellipse',\n 'g',\n 'text',\n 'tspan',\n 'defs',\n 'use',\n 'symbol',\n 'marker',\n 'linearGradient',\n 'radialGradient',\n 'stop',\n 'clipPath',\n 'pattern',\n 'mask',\n 'filter',\n])\n\n/**\n * SVG Attribute Case Mapping\n * React-like camelCase to SVG case-sensitive attributes\n */\nconst SVG_ATTR_MAP: Record<string, string> = {\n viewBox: 'viewBox',\n preserveAspectRatio: 'preserveAspectRatio',\n strokeWidth: 'stroke-width',\n strokeLinecap: 'stroke-linecap',\n strokeLinejoin: 'stroke-linejoin',\n strokeDasharray: 'stroke-dasharray',\n strokeDashoffset: 'stroke-dashoffset',\n fillOpacity: 'fill-opacity',\n strokeOpacity: 'stroke-opacity',\n stopColor: 'stop-color',\n stopOpacity: 'stop-opacity',\n clipPath: 'clip-path',\n markerEnd: 'marker-end',\n markerStart: 'marker-start',\n markerMid: 'marker-mid',\n}\n\n/**\n * Convert pixel value to CSS string\n */\nfunction px(value: number | string): string {\n return typeof value === 'number' ? `${value}px` : value\n}\n\n/**\n * Cache for camelCase to kebab-case conversions\n * Avoids repeated regex operations for common CSS properties\n */\nconst kebabCache = new Map<string, string>()\n\n/**\n * Convert camelCase to kebab-case for CSS property names\n * Uses memoization for performance\n */\nfunction toKebabCase(str: string): string {\n let result = kebabCache.get(str)\n if (result === undefined) {\n result = str.replace(/[A-Z]/g, (letter) => `-${letter.toLowerCase()}`)\n kebabCache.set(str, result)\n }\n return result\n}\n\n/**\n * Escape special characters in HTML attribute values to prevent XSS\n * @param value - Attribute value to escape\n * @returns Escaped value safe for HTML attributes\n */\nexport function escapeAttrValue(value: string): string {\n return value\n .replace(/&/g, '&amp;')\n .replace(/\"/g, '&quot;')\n .replace(/'/g, '&#39;')\n .replace(/</g, '&lt;')\n .replace(/>/g, '&gt;')\n}\n\n/**\n * Transform a value based on the config type\n */\nfunction transformValue(\n value: unknown,\n transform: StylePropConfig['transform']\n): string | undefined {\n if (value === undefined || value === null) return undefined\n switch (transform) {\n case 'px':\n return px(value as number | string)\n case 'string':\n return String(value)\n case 'none':\n default:\n return value as string\n }\n}\n\n/**\n * Apply style props to DOM element efficiently\n */\nfunction updateStyles(\n element: HTMLElement | SVGElement,\n oldProps: Record<string, unknown>,\n newProps: Record<string, unknown>\n): void {\n const style = element.style\n\n // 1. Handle 'style' object prop\n const oldStyle = oldProps.style as Record<string, string> | undefined\n const newStyle = newProps.style as Record<string, string> | undefined\n\n if (oldStyle !== newStyle) {\n if (oldStyle && typeof oldStyle === 'object') {\n for (const key in oldStyle) {\n if (!newStyle || !(key in newStyle)) {\n // Convert camelCase to kebab-case for CSS property names\n style.setProperty(toKebabCase(key), '')\n }\n }\n }\n if (newStyle && typeof newStyle === 'object') {\n for (const key in newStyle) {\n const val = newStyle[key]\n if (!oldStyle || oldStyle[key] !== val) {\n // Convert camelCase to kebab-case for CSS property names\n style.setProperty(toKebabCase(key), val)\n }\n }\n }\n }\n\n // 2. Flexbox setup (display: flex)\n const type = element.getAttribute('data-flexium-type')\n const needsFlex =\n newProps.flexDirection ||\n newProps.justifyContent ||\n newProps.alignItems ||\n newProps.flexWrap ||\n newProps.gap !== undefined ||\n newProps.justify ||\n newProps.align ||\n type === 'Row' ||\n type === 'Column' ||\n type === 'Stack'\n\n if (needsFlex) {\n if (style.display !== 'flex') style.display = 'flex'\n if (type === 'Row' && style.flexDirection !== 'row')\n style.flexDirection = 'row'\n if (type === 'Column' && style.flexDirection !== 'column')\n style.flexDirection = 'column'\n }\n\n // 3. Handle Flexium specific style props - only check props that exist\n // Optimized: iterate directly without creating intermediate Set\n\n // Performance: Cache style access and avoid unnecessary checks\n const styleRecord = style as unknown as Record<string, string>\n\n // Check oldProps for removed style props\n for (const propName in oldProps) {\n if (propName in STYLE_PROPS_CONFIG && !(propName in newProps)) {\n const config = STYLE_PROPS_CONFIG[propName]\n const cssProp = config.cssProp as string\n\n // Performance: Only clear if actually set (avoid unnecessary DOM writes)\n const currentValue = styleRecord[cssProp]\n if (currentValue !== undefined && currentValue !== '') {\n styleRecord[cssProp] = ''\n }\n\n // Apply any side effects\n if (config.sideEffect) {\n config.sideEffect(style, undefined)\n }\n }\n }\n\n // Check newProps for added/updated style props\n for (const propName in newProps) {\n if (propName in STYLE_PROPS_CONFIG) {\n const oldValue = oldProps[propName]\n const newValue = newProps[propName]\n\n // Performance: Skip if value hasn't changed\n if (oldValue === newValue) continue\n\n const config = STYLE_PROPS_CONFIG[propName]\n const transformedValue = transformValue(newValue, config.transform)\n const cssProp = config.cssProp as string\n\n // Performance: Cache current value and only update if different\n const currentValue = styleRecord[cssProp]\n\n // Update the style property\n if (transformedValue === undefined) {\n // Only clear if actually set\n if (currentValue !== undefined && currentValue !== '') {\n styleRecord[cssProp] = ''\n }\n } else {\n // Only update if value actually changed\n if (currentValue !== transformedValue) {\n styleRecord[cssProp] = transformedValue\n }\n }\n\n // Apply any side effects\n if (config.sideEffect) {\n config.sideEffect(style, transformedValue)\n }\n }\n }\n}\n\n/**\n * Normalize className prop (supports string, array, object)\n * Optimized single-pass implementation without recursion overhead\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction normalizeClass(value: any): string {\n if (typeof value === 'string') return value\n if (Array.isArray(value)) {\n // Single-pass iteration without intermediate arrays\n let result = ''\n for (let i = 0; i < value.length; i++) {\n const item = value[i]\n if (!item) continue\n const normalized = typeof item === 'string' ? item : normalizeClass(item)\n if (normalized) {\n result = result ? `${result} ${normalized}` : normalized\n }\n }\n return result\n }\n if (typeof value === 'object' && value !== null) {\n // Single-pass iteration without intermediate arrays\n let result = ''\n for (const k in value) {\n if (value[k]) {\n result = result ? `${result} ${k}` : k\n }\n }\n return result\n }\n return ''\n}\n\n/**\n * DOM Renderer implementation\n */\nexport class DOMRenderer implements Renderer {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n createNode(type: string, props: Record<string, any>): HTMLElement | SVGElement {\n // Map component type to HTML element\n const tagName = ELEMENT_MAPPING[type] ?? type\n\n let element: HTMLElement | SVGElement\n\n if (SVG_TAGS.has(tagName)) {\n element = document.createElementNS(SVG_NAMESPACE, tagName) as SVGElement\n } else {\n element = document.createElement(tagName)\n }\n\n // Store original type for reference\n if (ELEMENT_MAPPING[type]) {\n element.setAttribute('data-flexium-type', type)\n }\n\n // Apply all props (treat oldProps as empty)\n this.updateNode(element, {}, props)\n\n return element\n }\n\n updateNode(\n node: HTMLElement | SVGElement,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n oldProps: Record<string, any>,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n newProps: Record<string, any>\n ): void {\n // 1. Handle className\n if (newProps.className !== oldProps.className) {\n const className = normalizeClass(newProps.className)\n if (node instanceof SVGElement) {\n node.setAttribute('class', className)\n } else {\n node.className = className\n }\n }\n\n // 2. Update Styles (Efficiently)\n updateStyles(node, oldProps, newProps)\n\n // 3. Handle Events & Attributes\n // We iterate over merged keys to handle additions, updates, and removals in one pass if possible\n // But separating old and new is easier for now.\n\n // Remove deleted props\n for (const key in oldProps) {\n if (!(key in newProps)) {\n // Ignore Symbols\n if (typeof key === 'symbol') continue\n\n if (key.startsWith('on')) {\n const eventName = EVENT_MAPPING[key] || key.slice(2).toLowerCase()\n this.removeEventListener(node, eventName, oldProps[key])\n } else if (!SKIP_PROPS.has(key)) {\n node.removeAttribute(key)\n }\n }\n }\n\n // Add/Update new props\n const keys = Reflect.ownKeys(newProps) // Get string and symbol keys\n for (const key of keys) {\n // Ignore Symbols (Synapse keys)\n if (typeof key === 'symbol') continue\n\n // Cast key to string for accessing record\n const strKey = key\n const newVal = newProps[strKey]\n const oldVal = oldProps[strKey]\n\n if (newVal === oldVal) continue\n\n if (strKey.startsWith('on')) {\n const eventName = EVENT_MAPPING[strKey] || strKey.slice(2).toLowerCase()\n if (oldVal) this.removeEventListener(node, eventName, oldVal)\n if (newVal) this.addEventListener(node, eventName, newVal)\n } else if (!SKIP_PROPS.has(strKey)) {\n if (newVal === null || newVal === undefined || newVal === false) {\n node.removeAttribute(strKey)\n } else if (newVal === true) {\n node.setAttribute(strKey, '')\n } else {\n // Handle SVG attributes\n const attrName = SVG_ATTR_MAP[strKey] || strKey\n\n // Escape attribute value to prevent XSS attacks\n node.setAttribute(attrName, escapeAttrValue(String(newVal)))\n }\n }\n }\n }\n\n appendChild(parent: Node, child: Node): void {\n parent.appendChild(child)\n }\n\n insertBefore(parent: Node, child: Node, beforeChild: Node | null): void {\n parent.insertBefore(child, beforeChild)\n }\n\n nextSibling(node: Node): Node | null {\n return node.nextSibling\n }\n\n removeChild(parent: Node, child: Node): void {\n // No need to manually cleanup listeners if using WeakMap in delegator\n // The nodeHandlers WeakMap will automatically release entries when node is garbage collected\n parent.removeChild(child)\n }\n\n createTextNode(text: string): Text {\n return document.createTextNode(text)\n }\n\n updateTextNode(node: Text, text: string): void {\n node.textContent = text\n }\n\n addEventListener(node: Node, event: string, handler: EventHandler): void {\n // Use Event Delegation\n // Map to DOM event name\n const domEvent = EVENT_MAPPING[event] || event\n eventDelegator.on(node, domEvent, handler)\n }\n\n removeEventListener(node: Node, event: string, _handler: EventHandler): void {\n // Use Event Delegation\n // Map to DOM event name\n const domEvent = EVENT_MAPPING[event] || event\n eventDelegator.off(node, domEvent)\n }\n}\n\n/**\n * Default DOM renderer instance\n */\nexport const domRenderer = new DOMRenderer()\n","import { SignalNode } from '../../core/signal'\nimport { effect } from '../../core/effect'\nimport type { FNode } from '../../core/renderer'\nimport type {\n ListProps,\n ListComponent,\n ListCacheEntry,\n SizeConfig,\n} from './types'\n// import { SignalNode, effect } from '../../core/signal' -- Already imported at top\n\n/** Marker symbol for List components */\nexport const LIST_MARKER = Symbol('flexium.list')\n\n/**\n * Check if a value is a ListComponent\n */\nexport function isListComponent<T>(\n value: unknown\n): value is ListComponent<T> {\n return (\n value !== null &&\n typeof value === 'object' &&\n LIST_MARKER in value &&\n (value as Record<symbol, unknown>)[LIST_MARKER] === true\n )\n}\n\n\n/**\n * List - Render lists with optional virtualization\n *\n * By default, renders all items. Set `virtual` to true for large lists\n * to only render visible items.\n *\n * @example\n * ```tsx\n * // Simple list (renders all items)\n * <List each={items}>\n * {(item, index) => <div>{item.name}</div>}\n * </List>\n *\n * // Virtual list (for large datasets)\n * <List\n * each={items}\n * virtual\n * height={400}\n * itemSize={50}\n * >\n * {(item, index) => <div>{index()}: {item.name}</div>}\n * </List>\n * ```\n */\nexport function List<T>(props: ListProps<T>): ListComponent<T> {\n const {\n each,\n children,\n virtual = false,\n height,\n width,\n itemSize,\n overscan = 3,\n getKey,\n onScroll,\n onVisibleRangeChange,\n class: className,\n style,\n } = props\n\n const component: ListComponent<T> = {\n [LIST_MARKER]: true,\n each,\n renderItem: children,\n virtual,\n height,\n width,\n itemSize,\n overscan,\n getKey,\n onScroll,\n onVisibleRangeChange,\n class: className,\n style,\n }\n\n return component\n}\n\n/**\n * Get item height based on configuration\n */\nfunction getItemHeight(config: number | SizeConfig, _index: number): number {\n if (typeof config === 'number') {\n return config\n }\n if (config.mode === 'fixed') {\n return config.itemHeight\n }\n // Variable mode - use estimated height\n return config.estimatedItemHeight\n}\n\n/**\n * Calculate visible range for fixed-height items\n */\nfunction calculateVisibleRangeFixed(\n scrollTop: number,\n viewportHeight: number,\n itemHeight: number,\n totalItems: number,\n overscan: number\n): { startIndex: number; endIndex: number; totalHeight: number } {\n const totalHeight = totalItems * itemHeight\n\n if (totalItems === 0) {\n return { startIndex: 0, endIndex: -1, totalHeight: 0 }\n }\n\n const start = Math.floor(scrollTop / itemHeight)\n const visibleCount = Math.ceil(viewportHeight / itemHeight)\n const end = start + visibleCount\n\n return {\n startIndex: Math.max(0, start - overscan),\n endIndex: Math.min(totalItems - 1, end + overscan),\n totalHeight,\n }\n}\n\n/**\n * Mount a List component to the DOM with efficient rendering.\n *\n * Handles both simple and virtual lists:\n * - Simple lists render all items immediately with key-based caching\n * - Virtual lists only render visible items for optimal performance with large datasets\n *\n * @internal Used by the reactive renderer\n * @param comp - The ListComponent to mount\n * @param parent - Parent DOM node to mount into\n * @param mountFn - Function to mount an FNode to the DOM\n * @param cleanupFn - Function to cleanup a DOM node and its bindings\n * @returns Dispose function to cleanup all list items and effects\n *\n * @example\n * ```tsx\n * // This is called automatically by mountReactive when it encounters a List:\n * <List each={items} virtual height={400} itemSize={50}>\n * {(item, index) => <Row>{index()}: {item.name}</Row>}\n * </List>\n * ```\n */\nexport function mountListComponent<T>(\n comp: ListComponent<T>,\n parent: Node,\n mountFn: (vnode: FNode) => Node | null,\n cleanupFn: (node: Node) => void\n): () => void {\n if (comp.virtual) {\n return mountVirtualList(comp, parent, mountFn, cleanupFn)\n } else {\n return mountSimpleList(comp, parent, mountFn, cleanupFn)\n }\n}\n\n/**\n * Mount a simple (non-virtual) list\n */\nfunction mountSimpleList<T>(\n comp: ListComponent<T>,\n parent: Node,\n mountFn: (vnode: FNode) => Node | null,\n cleanupFn: (node: Node) => void\n): () => void {\n const { each, renderItem, getKey, class: className, style } = comp\n\n // Create container\n const container = document.createElement('div')\n container.setAttribute('role', 'list')\n if (className) container.className = className\n if (style) {\n Object.entries(style).forEach(([key, value]) => {\n ; (container.style as unknown as Record<string, string>)[key] =\n typeof value === 'number' ? `${value}px` : value\n })\n }\n\n parent.appendChild(container)\n\n // Cache for rendered items\n const cache = new Map<string | number, { node: Node; dispose: () => void }>()\n\n // Get key for item\n const getItemKey = (item: T, index: number): string | number => {\n if (getKey) {\n return getKey(item, index)\n }\n return index\n }\n\n // Render effect\n const disposeEffect = effect(() => {\n const list = each() || []\n const currentKeys = new Set<string | number>()\n\n // Render items\n list.forEach((item, index) => {\n const key = getItemKey(item, index)\n currentKeys.add(key)\n\n if (!cache.has(key)) {\n const indexSig = new SignalNode(index)\n const vnode = renderItem(item, () => indexSig.get())\n const node = mountFn(vnode)\n\n if (node && node instanceof HTMLElement) {\n node.setAttribute('role', 'listitem')\n container.appendChild(node)\n\n cache.set(key, {\n node,\n dispose: () => {\n try {\n cleanupFn(node)\n } catch {\n // Ignore cleanup errors\n }\n },\n })\n }\n }\n })\n\n // Remove items no longer in list\n for (const [key, entry] of cache) {\n if (!currentKeys.has(key)) {\n entry.dispose()\n if (entry.node.parentNode === container) {\n container.removeChild(entry.node)\n }\n cache.delete(key)\n }\n }\n })\n\n // Cleanup\n return () => {\n disposeEffect()\n for (const entry of cache.values()) {\n entry.dispose()\n }\n cache.clear()\n if (container.parentNode === parent) {\n parent.removeChild(container)\n }\n }\n}\n\n/**\n * Mount a virtual (windowed) list\n */\nfunction mountVirtualList<T>(\n comp: ListComponent<T>,\n parent: Node,\n mountFn: (node: FNode) => Node | null,\n cleanupFn: (node: Node) => void\n): () => void {\n const {\n each,\n renderItem,\n height,\n width,\n itemSize,\n overscan,\n getKey,\n onScroll,\n onVisibleRangeChange,\n } = comp\n\n if (!height || !itemSize) {\n console.warn('List: height and itemSize are required when virtual is true')\n return () => { }\n }\n\n // Create container structure\n const container = document.createElement('div')\n container.style.height = typeof height === 'number' ? `${height}px` : height\n container.style.width = width\n ? typeof width === 'number'\n ? `${width}px`\n : width\n : '100%'\n container.style.overflow = 'auto'\n container.style.position = 'relative'\n\n // Accessibility attributes\n container.setAttribute('role', 'list')\n container.setAttribute('tabindex', '0')\n\n const innerContainer = document.createElement('div')\n innerContainer.style.position = 'relative'\n innerContainer.style.width = '100%'\n // Reactive state\n const scrollTopSig = new SignalNode(0)\n const cache = new Map<string | number, ListCacheEntry<T>>()\n\n // Track previous visible range\n let prevStartIndex = -1\n let prevEndIndex = -1\n\n const handleScroll = () => {\n scrollTopSig.set(container.scrollTop)\n onScroll?.(container.scrollTop)\n }\n\n container.addEventListener('scroll', handleScroll, { passive: true })\n\n // Get key for item\n const getItemKey = (item: T, index: number): string | number => {\n if (getKey) {\n return getKey(item, index)\n }\n return index\n }\n\n // Main render effect\n const disposeEffect = effect(() => {\n const list = each() || []\n const currentScrollTop = scrollTopSig.get()\n const viewportHeight = container.clientHeight || parseFloat(String(height))\n const itemHeight = getItemHeight(itemSize, 0)\n\n // Calculate visible range\n const { startIndex, endIndex, totalHeight } = calculateVisibleRangeFixed(\n currentScrollTop,\n viewportHeight,\n itemHeight,\n list.length,\n overscan\n )\n\n // Update spacer height\n innerContainer.style.height = `${totalHeight}px`\n\n // Update ARIA attributes\n container.setAttribute('aria-rowcount', String(list.length))\n\n // Notify visible range change\n if (startIndex !== prevStartIndex || endIndex !== prevEndIndex) {\n onVisibleRangeChange?.(startIndex, endIndex)\n prevStartIndex = startIndex\n prevEndIndex = endIndex\n }\n\n // Track which keys are currently visible\n const visibleKeys = new Set<string | number>()\n\n // Render visible items\n for (let i = startIndex; i <= endIndex && i < list.length; i++) {\n const item = list[i]\n const key = getItemKey(item, i)\n visibleKeys.add(key)\n\n let entry = cache.get(key)\n\n // Use cache or create new row state\n let rowState = cache.get(key)?.state\n if (!rowState) {\n rowState = new SignalNode(item)\n } else {\n rowState.set(item)\n }\n\n if (!entry) {\n // Create new item\n const indexSig = new SignalNode(i)\n const vnode = renderItem(item, () => indexSig.get())\n const node = mountFn(vnode)\n\n if (node && node instanceof HTMLElement) {\n // Position the item\n node.style.position = 'absolute'\n node.style.top = '0'\n node.style.left = '0'\n node.style.right = '0'\n node.style.transform = `translateY(${i * itemHeight}px)`\n node.style.height = `${itemHeight}px`\n node.style.boxSizing = 'border-box'\n node.setAttribute('role', 'listitem')\n node.setAttribute('aria-rowindex', String(i + 1))\n\n innerContainer.appendChild(node)\n\n entry = {\n item,\n key,\n node,\n indexSig,\n dispose: () => {\n try {\n cleanupFn(node)\n } catch {\n // Ignore cleanup errors\n }\n },\n }\n cache.set(key, entry)\n }\n } else {\n // Update existing item position\n if (entry.indexSig.peek() !== i) {\n entry.indexSig.set(i)\n }\n const node = entry.node as HTMLElement\n node.style.transform = `translateY(${i * itemHeight}px)`\n node.setAttribute('aria-rowindex', String(i + 1))\n }\n }\n\n // Remove items no longer visible\n for (const [key, entry] of cache) {\n if (!visibleKeys.has(key)) {\n entry.dispose()\n if (entry.node.parentNode === innerContainer) {\n innerContainer.removeChild(entry.node)\n }\n cache.delete(key)\n }\n }\n })\n\n // Cleanup function\n return () => {\n disposeEffect()\n container.removeEventListener('scroll', handleScroll)\n\n for (const entry of cache.values()) {\n entry.dispose()\n }\n cache.clear()\n\n if (container.parentNode === parent) {\n parent.removeChild(container)\n }\n }\n}\n\nexport default List\n","/**\n * FNode to DOM Node mapping using WeakMap\n *\n * This replaces the _node property on FNode with a clean separation.\n * WeakMap ensures nodes are garbage collected when FNodes are no longer referenced.\n */\n\nimport type { FNode } from '../../core/renderer'\n\nconst fnodeToNode = new WeakMap<FNode, Node>()\n\n/**\n * Get the DOM node associated with an FNode\n */\nexport function getNode(fnode: FNode): Node | undefined {\n return fnodeToNode.get(fnode)\n}\n\n/**\n * Set the DOM node associated with an FNode\n */\nexport function setNode(fnode: FNode, node: Node): void {\n fnodeToNode.set(fnode, node)\n}\n\n/**\n * Check if an FNode has an associated DOM node\n */\nexport function hasNode(fnode: FNode): boolean {\n return fnodeToNode.has(fnode)\n}\n\n/**\n * Remove the DOM node association from an FNode\n */\nexport function deleteNode(fnode: FNode): boolean {\n return fnodeToNode.delete(fnode)\n}\n","import { FNode } from '../../core/renderer'\nimport { domRenderer } from './index'\nimport { mountReactive, cleanupReactive } from './reactive'\nimport { getNode, setNode } from './node-map'\n\n/**\n * Object pool for Map/Set used in reconciliation to reduce GC pressure\n * Performance: Reuse Map and Set instances instead of creating new ones\n */\nnamespace ReconciliationPool {\n const mapPool: Map<string | number | undefined, FNode>[] = []\n const setPool: Set<string | number | undefined>[] = []\n const MAX_POOL_SIZE = 10\n\n export function getMap(): Map<string | number | undefined, FNode> {\n if (mapPool.length > 0) {\n const map = mapPool.pop()!\n map.clear()\n return map\n }\n return new Map()\n }\n\n export function getSet(): Set<string | number | undefined> {\n if (setPool.length > 0) {\n const set = setPool.pop()!\n set.clear()\n return set\n }\n return new Set()\n }\n\n export function release(\n map: Map<string | number | undefined, FNode>,\n set: Set<string | number | undefined>\n ): void {\n if (mapPool.length < MAX_POOL_SIZE) {\n mapPool.push(map)\n }\n if (setPool.length < MAX_POOL_SIZE) {\n setPool.push(set)\n }\n }\n}\n\n/**\n * Reconcile two arrays of FNodes using hybrid key-based approach.\n * Simple Map lookup + position check for optimal DOM operations.\n *\n * @param parent The parent DOM node\n * @param oldFNodes The array of old FNodes (with attached DOM nodes)\n * @param newFNodes The array of new FNodes\n * @param nextSibling The node to insert before (for the end of the list)\n */\nexport function reconcileArrays(\n parent: Node,\n oldFNodes: FNode[],\n newFNodes: FNode[],\n nextSibling: Node | null\n): void {\n const hasOld = oldFNodes && oldFNodes.length > 0\n const hasNew = newFNodes && newFNodes.length > 0\n\n // Fast path: both empty\n if (!hasOld && !hasNew) return\n\n // Fast path: remove all\n if (!hasNew) {\n for (const fnode of oldFNodes) {\n const node = fnode && getNode(fnode)\n if (node) {\n cleanupReactive(node)\n domRenderer.removeChild(parent, node)\n }\n }\n return\n }\n\n // Fast path: add all\n if (!hasOld) {\n const fragment = document.createDocumentFragment()\n for (const newFNode of newFNodes) {\n const node = mountReactive(newFNode, undefined)\n if (node) {\n setNode(newFNode, node)\n fragment.appendChild(node)\n }\n }\n if (nextSibling) {\n parent.insertBefore(fragment, nextSibling)\n } else {\n parent.appendChild(fragment)\n }\n return\n }\n\n // Performance: Fast path for small lists (5 or fewer items) - avoid Map/Set overhead\n const oldLen = oldFNodes.length\n const newLen = newFNodes.length\n const SMALL_LIST_THRESHOLD = 5\n\n if (oldLen <= SMALL_LIST_THRESHOLD && newLen <= SMALL_LIST_THRESHOLD) {\n // Simple linear reconciliation for small lists\n let oldIdx = 0\n let newIdx = 0\n let currentChild = parent.firstChild\n\n while (oldIdx < oldLen || newIdx < newLen) {\n if (newIdx >= newLen) {\n // Remove remaining old nodes\n while (oldIdx < oldLen) {\n const oldFNode = oldFNodes[oldIdx++]\n const node = oldFNode && getNode(oldFNode)\n if (node) {\n cleanupReactive(node)\n domRenderer.removeChild(parent, node)\n }\n }\n break\n }\n\n if (oldIdx >= oldLen) {\n // Add remaining new nodes\n const fragment = document.createDocumentFragment()\n while (newIdx < newLen) {\n const newFNode = newFNodes[newIdx++]\n const node = mountReactive(newFNode, undefined)\n if (node) {\n setNode(newFNode, node)\n fragment.appendChild(node)\n }\n }\n if (nextSibling) {\n parent.insertBefore(fragment, nextSibling)\n } else {\n parent.appendChild(fragment)\n }\n break\n }\n\n const oldFNode = oldFNodes[oldIdx]\n const newFNode = newFNodes[newIdx]\n const oldKey = oldFNode.key ?? `__idx_${oldIdx}_${oldFNode.type}`\n const newKey = newFNode.key ?? `__idx_${newIdx}_${newFNode.type}`\n\n if (oldKey === newKey && oldFNode.type === newFNode.type) {\n // Same node: patch and advance both\n patchNode(oldFNode, newFNode)\n currentChild = currentChild?.nextSibling || null\n oldIdx++\n newIdx++\n } else {\n // Different: check if we can find matching old node\n let found = false\n for (let searchIdx = oldIdx + 1; searchIdx < oldLen; searchIdx++) {\n const searchFNode = oldFNodes[searchIdx]\n const searchKey = searchFNode.key ?? `__idx_${searchIdx}_${searchFNode.type}`\n if (searchKey === newKey && searchFNode.type === newFNode.type) {\n // Found match: remove nodes between oldIdx and searchIdx, then patch\n for (let removeIdx = oldIdx; removeIdx < searchIdx; removeIdx++) {\n const removeFNode = oldFNodes[removeIdx]\n const node = removeFNode && getNode(removeFNode)\n if (node) {\n cleanupReactive(node)\n domRenderer.removeChild(parent, node)\n }\n }\n patchNode(searchFNode, newFNode)\n oldIdx = searchIdx + 1\n newIdx++\n found = true\n break\n }\n }\n if (!found) {\n // No match: insert new node\n const node = mountReactive(newFNode, undefined)\n if (node) {\n setNode(newFNode, node)\n parent.insertBefore(node, currentChild)\n }\n newIdx++\n }\n }\n }\n return\n }\n\n // Performance: Reuse Map/Set from pool to reduce GC pressure\n const keyToOldFNode = ReconciliationPool.getMap()\n const seen = ReconciliationPool.getSet()\n\n // Build key-to-node mapping\n for (let i = 0; i < oldLen; i++) {\n const fnode = oldFNodes[i]\n // Use key if available, otherwise use index with type prefix for uniqueness\n const key = fnode.key ?? `__idx_${i}_${fnode.type}`\n keyToOldFNode.set(key, fnode)\n }\n\n // Forward pass: process new nodes\n let currentChild = parent.firstChild\n\n for (let i = 0; i < newFNodes.length; i++) {\n const newFNode = newFNodes[i]\n const key = newFNode.key ?? `__idx_${i}_${newFNode.type}`\n seen.add(key)\n\n const oldFNode = keyToOldFNode.get(key)\n\n // Determine the reference node for insertion\n // If currentChild is valid, insert before it. Otherwise append (refNode is null).\n const refNode = currentChild\n\n if (!oldFNode || oldFNode.type !== newFNode.type) {\n // New node or type changed: create and insert\n const node = mountReactive(newFNode, undefined)\n if (node) {\n setNode(newFNode, node)\n parent.insertBefore(node, refNode)\n // We inserted a new node before currentChild, so currentChild is still the next one to process\n }\n // If type changed, old node will be removed in cleanup pass\n } else {\n // Existing node: patch and maybe move\n patchNode(oldFNode, newFNode)\n\n const node = getNode(newFNode)\n if (node) {\n if (currentChild !== node) {\n // Position wrong: move to correct position (before currentChild)\n parent.insertBefore(node, refNode)\n // We moved the node here. currentChild is still the next one to process.\n } else {\n // Position correct: match!\n // Advance pointer since we consumed this node\n currentChild = currentChild?.nextSibling || null\n }\n }\n }\n }\n\n // Cleanup pass: remove nodes not in new list\n for (const [key, fnode] of keyToOldFNode) {\n const node = getNode(fnode)\n if (!seen.has(key) && node) {\n cleanupReactive(node)\n // Check if node is still attached before removing\n if (node.parentNode === parent) {\n domRenderer.removeChild(parent, node)\n }\n }\n }\n\n // Performance: Return Map/Set to pool for reuse\n ReconciliationPool.release(keyToOldFNode, seen)\n}\n\n/**\n * Patch an existing FNode with new props and children\n */\nfunction patchNode(oldFNode: FNode, newFNode: FNode) {\n const node = getNode(oldFNode) as HTMLElement\n if (!node) return\n\n // Transfer DOM reference\n setNode(newFNode, node)\n\n // Only patch element nodes (not components)\n if (typeof newFNode.type !== 'string') return\n\n // Update props\n domRenderer.updateNode(node, oldFNode.props, newFNode.props)\n\n // Update children\n const oldChildren = oldFNode.children || []\n const newChildren = newFNode.children || []\n\n if (oldChildren.length === 0 && newChildren.length === 0) return\n\n // Fast path: single text/number child\n if (\n newChildren.length === 1 &&\n (typeof newChildren[0] === 'string' || typeof newChildren[0] === 'number') &&\n node.firstChild?.nodeType === Node.TEXT_NODE &&\n node.childNodes.length === 1\n ) {\n const newText = String(newChildren[0])\n const oldText = String(oldChildren[0])\n if (oldText !== newText) {\n domRenderer.updateTextNode(node.firstChild as Text, newText)\n }\n return\n }\n\n // Recursive reconciliation for nested children\n reconcileArrays(\n node,\n oldChildren as FNode[],\n newChildren as FNode[],\n null\n )\n}\n","/**\n * Reactive DOM Rendering\n *\n * Integrates the signal system with the DOM renderer to enable fine-grained\n * reactive updates. Only the specific DOM nodes that depend on changed signals\n * will be updated, without re-rendering the entire component tree.\n */\n\nimport type { FNode } from '../../core/renderer'\nimport { isSignal, onCleanup } from '../../core/signal'\nimport { effect } from '../../core/effect'\nimport { root } from '../../core/owner'\nimport type { SignalNode, ComputedNode } from '../../core/signal'\nimport { domRenderer } from './index'\nimport { isFNode } from './f'\nimport {\n pushProvider,\n} from '../../core/context'\nimport { reconcileArrays } from './reconcile'\nimport {\n isStateValue,\n getStateSignal,\n setCurrentComponent,\n createComponentInstance,\n resetHookIndex,\n} from '../../core/state'\nimport {\n isListComponent,\n mountListComponent,\n ListComponent,\n} from '../../primitives/List'\nimport { logError, ErrorCodes } from '../../core/errors'\nimport { setNode, getNode } from './node-map'\n\nconst REACTIVE_BINDINGS = new WeakMap<Node, Set<() => void>>()\n\n/**\n * DOM Update Batching System\n * Batches DOM updates using requestAnimationFrame to improve performance\n * when multiple signals update simultaneously.\n */\ntype DOMUpdateTask = () => void\n\nconst domUpdateQueue = new Set<DOMUpdateTask>()\nlet isDOMUpdateScheduled = false\n\n/**\n * Schedule a DOM update to be batched\n */\nfunction scheduleDOMUpdate(task: DOMUpdateTask): void {\n domUpdateQueue.add(task)\n if (!isDOMUpdateScheduled) {\n isDOMUpdateScheduled = true\n // Use requestAnimationFrame to batch DOM updates with browser rendering cycle\n requestAnimationFrame(() => {\n flushDOMUpdates()\n })\n }\n}\n\n/**\n * Flush all pending DOM updates\n */\nfunction flushDOMUpdates(): void {\n isDOMUpdateScheduled = false\n if (domUpdateQueue.size === 0) return\n\n // Performance: Convert Set to array for faster iteration\n const queue = Array.from(domUpdateQueue)\n domUpdateQueue.clear()\n\n // Execute all DOM updates\n for (let i = 0; i < queue.length; i++) {\n queue[i]()\n }\n}\n\n/**\n * Register a dispose function for a node's reactive bindings.\n * Ensures the bindings set exists and adds the dispose function to it.\n */\nfunction registerReactiveBinding(node: Node, dispose: () => void): void {\n let bindings = REACTIVE_BINDINGS.get(node)\n if (!bindings) {\n bindings = new Set()\n REACTIVE_BINDINGS.set(node, bindings)\n }\n bindings.add(dispose)\n}\n\n/**\n * Mount a virtual node reactively to the DOM.\n *\n * This is the core rendering function that handles all node types:\n * - FNodes (both built-in elements and function components)\n * - Strings and numbers (text nodes)\n * - Signals and computed values (reactive children)\n * - StateValues from the state() API\n * - ListComponents\n * - Arrays and fragments\n *\n * Reactive values are automatically tracked and DOM updates occur\n * only when the specific values change (fine-grained reactivity).\n *\n * @param vnode - The virtual node to mount\n * @param container - Optional parent node to append to\n * @returns The created DOM node, or null for empty/boolean values\n *\n * @example\n * ```tsx\n * // Mount a simple element\n * const node = mountReactive(<div>Hello</div>, document.body)\n *\n * // Mount a reactive signal\n * const count = signal(0)\n * mountReactive(() => <span>{count.value}</span>, container)\n * ```\n */\nexport function mountReactive(\n node:\n | FNode\n | string\n | number\n | boolean\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n | SignalNode<any>\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n | ComputedNode<any>\n | null\n | undefined\n | Function\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n | any[]\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n | ListComponent<any>,\n container?: Node\n): Node | null {\n // Handle null/undefined/boolean (falsy JSX values)\n if (node === null || node === undefined || typeof node === 'boolean') {\n return null\n }\n\n // Handle List component\n if (isListComponent(node)) {\n const parent = container || document.createDocumentFragment()\n\n const listDispose = mountListComponent(\n node,\n parent,\n (childNode) => mountReactive(childNode),\n cleanupReactive\n )\n\n // Create a marker for cleanup tracking\n const marker = document.createTextNode('')\n registerReactiveBinding(marker, listDispose)\n\n return container ? parent.firstChild : parent\n }\n\n // Handle StateValue (from state() API)\n if (isStateValue(node)) {\n const sig = getStateSignal(node)\n if (sig) {\n const startNode = document.createTextNode('')\n const parent = container || document.createDocumentFragment()\n domRenderer.appendChild(parent, startNode)\n\n let currentNode: Node | null = startNode\n\n const dispose = effect(() => {\n const value = sig.get()\n const currentContainer = startNode.parentNode\n if (!currentContainer) return\n\n if (\n (typeof value === 'string' || typeof value === 'number') &&\n currentNode &&\n currentNode.nodeType === Node.TEXT_NODE &&\n currentNode !== startNode\n ) {\n // Performance: Batch simple text node updates\n const textNode = currentNode as Text\n const textValue = String(value)\n scheduleDOMUpdate(() => {\n domRenderer.updateTextNode(textNode, textValue)\n })\n } else {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const newNode = mountReactive(value as any)\n if (newNode) {\n if (currentNode && currentNode !== startNode) {\n if (currentNode.parentNode === currentContainer) {\n // Optimize: if both old and new are text nodes, just update content\n if (\n currentNode.nodeType === Node.TEXT_NODE &&\n newNode.nodeType === Node.TEXT_NODE\n ) {\n // Performance: Batch text node updates\n const textNode = currentNode as Text\n const textContent = newNode.textContent || ''\n scheduleDOMUpdate(() => {\n domRenderer.updateTextNode(textNode, textContent)\n })\n // Don't update currentNode reference since we reused it\n } else {\n currentContainer.replaceChild(newNode, currentNode)\n currentNode = newNode\n }\n } else {\n currentContainer.insertBefore(newNode, startNode.nextSibling)\n currentNode = newNode\n }\n } else {\n currentContainer.insertBefore(newNode, startNode.nextSibling)\n currentNode = newNode\n }\n } else {\n if (\n currentNode &&\n currentNode !== startNode &&\n currentNode.parentNode === currentContainer\n ) {\n try {\n currentContainer.removeChild(currentNode)\n } catch (e) {\n logError(ErrorCodes.DOM_CLEANUP_FAILED, { operation: 'removeChild' }, e)\n }\n }\n currentNode = startNode\n }\n }\n })\n\n registerReactiveBinding(startNode, dispose)\n\n return container ? startNode : parent\n }\n }\n\n // Handle signals and functions (reactive children)\n if (isSignal(node) || typeof node === 'function') {\n const startNode = document.createTextNode('')\n const parent = container || document.createDocumentFragment()\n domRenderer.appendChild(parent, startNode)\n\n let currentNodes: Node[] = []\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let currentFNode: any = null\n let currentFNodeList: FNode[] = []\n\n const dispose = effect(() => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const value = isSignal(node) ? (node as SignalNode<any>).get() : (node as () => unknown)()\n const currentContainer = startNode.parentNode\n\n // Safety check: if node is detached, we can't update siblings\n if (!currentContainer) return\n\n if (Array.isArray(value)) {\n const newFNodes = value.filter((c) => c != null)\n if (currentFNodeList.length > 0) {\n const nextSibling = startNode.nextSibling\n // Note: reconcileArrays expects parent, oldFNodes, newFNodes, nextSibling\n reconcileArrays(\n currentContainer,\n currentFNodeList,\n newFNodes,\n nextSibling\n )\n } else {\n // Clean up old nodes first\n for (const childNode of currentNodes) {\n cleanupReactive(childNode)\n if (childNode.parentNode === currentContainer) {\n try {\n currentContainer.removeChild(childNode)\n } catch (e) {\n logError(ErrorCodes.DOM_CLEANUP_FAILED, { operation: 'removeChild' }, e)\n }\n }\n }\n currentNodes = []\n\n const fragment = document.createDocumentFragment()\n for (const child of newFNodes) {\n const childNode = mountReactive(child, fragment)\n if (childNode && typeof child === 'object') {\n setNode(child, childNode)\n }\n }\n currentNodes = Array.from(fragment.childNodes)\n currentContainer.insertBefore(fragment, startNode.nextSibling)\n }\n currentFNodeList = newFNodes\n currentFNode = value\n return\n }\n\n if (currentFNodeList.length > 0) {\n for (const childFNode of currentFNodeList) {\n const childNode = getNode(childFNode)\n if (childNode && childNode.parentNode === currentContainer) {\n cleanupReactive(childNode)\n try {\n currentContainer.removeChild(childNode)\n } catch (e) {\n logError(ErrorCodes.DOM_CLEANUP_FAILED, { operation: 'removeChild' }, e)\n }\n }\n }\n currentFNodeList = []\n }\n\n if (value !== currentFNode) {\n // Clean up old nodes first\n for (const childNode of currentNodes) {\n cleanupReactive(childNode)\n if (childNode.parentNode === currentContainer) {\n try {\n currentContainer.removeChild(childNode)\n } catch (e) {\n logError(ErrorCodes.DOM_CLEANUP_FAILED, { operation: 'removeChild' }, e)\n }\n }\n }\n currentNodes = []\n\n if (\n (typeof value === 'string' || typeof value === 'number')\n ) {\n const textNode = domRenderer.createTextNode(String(value))\n currentContainer.insertBefore(textNode, startNode.nextSibling)\n currentNodes = [textNode]\n } else {\n const newNode = mountReactive(value)\n if (newNode) {\n // If newNode is a fragment, track all children\n if (newNode.nodeType === Node.DOCUMENT_FRAGMENT_NODE) {\n currentNodes = Array.from(newNode.childNodes)\n currentContainer.insertBefore(newNode, startNode.nextSibling)\n } else {\n currentContainer.insertBefore(newNode, startNode.nextSibling)\n currentNodes = [newNode]\n }\n }\n }\n currentFNode = value\n }\n })\n\n registerReactiveBinding(startNode, dispose)\n\n return container ? startNode : parent\n }\n\n if (Array.isArray(node)) {\n const fragment = document.createDocumentFragment()\n for (const child of node) {\n mountReactive(child, fragment)\n }\n if (container) {\n domRenderer.appendChild(container, fragment)\n }\n return fragment\n }\n\n // Handle text nodes\n if (typeof node === 'string' || typeof node === 'number') {\n const textNode = domRenderer.createTextNode(String(node))\n if (container) domRenderer.appendChild(container, textNode)\n return textNode\n }\n\n // Handle FNodes\n if (isFNode(node)) {\n // Handle function components\n if (typeof node.type === 'function') {\n const component = node.type\n const startNode = document.createTextNode('')\n const parent = container || document.createDocumentFragment()\n domRenderer.appendChild(parent, startNode)\n\n let currentNodes: Node[] = []\n let currentFNodeList: FNode[] = []\n\n // Create component instance for hook tracking\n const componentInstance = createComponentInstance()\n\n const dispose = effect(() => {\n try {\n // Reset hook index for each render\n resetHookIndex(componentInstance)\n\n // Use root() to track any effects created inside the component\n // These will be automatically cleaned up when disposeRoot is called\n // Use root() to track any effects created inside the component\n // These will be automatically cleaned up when disposeRoot is called\n root((disposeRoot) => {\n // Register disposeRoot to cleanup component's internal effects\n onCleanup(disposeRoot)\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const contextId = (component as any)._contextId\n if (contextId) {\n pushProvider(contextId, node.props.value)\n }\n\n let result\n try {\n // Set current component for hook tracking\n setCurrentComponent(componentInstance)\n // Performance: Avoid object spread when children is undefined (reuse props object)\n const componentProps = node.children !== undefined\n ? { ...node.props, children: node.children }\n : node.props\n result = component(componentProps)\n } finally {\n // Clear current component\n setCurrentComponent(null)\n }\n\n // Attempt Reconciliation for Arrays (e.g. items.map)\n // This enables efficient list updates without full re-render\n const isArray = Array.isArray(result)\n // Check if it's a list of FNodes (elements) that we can reconcile\n // We skip reconciliation for primitives or fragments to be safe for now\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const canReconcile = isArray && (result as unknown as any[]).every(item =>\n isFNode(item) && item.type !== 'fragment'\n )\n\n if (canReconcile) {\n const parent = startNode.parentNode\n if (parent) {\n // Normalize result to FNode[] (already checked, but for type safety)\n const newFNodes = result as unknown as FNode[]\n\n // Use reconcileArrays to diff/patch the DOM\n reconcileArrays(\n parent,\n currentFNodeList,\n newFNodes,\n startNode.nextSibling\n )\n\n // Update state for next render\n currentFNodeList = newFNodes\n // Update currentNodes so we know what to remove if we switch to fallback\n currentNodes = newFNodes.map(fn => getNode(fn)).filter(n => n != null) as Node[]\n return\n }\n }\n\n // Fallback: Standard Mount (Destroy & Recreate)\n // Clean up old nodes first\n const currentParent = startNode.parentNode\n if (currentParent) {\n // If we were using reconciliation, currentFNodeList handles the nodes\n // If not, currentNodes handles them.\n // We iterate currentNodes to be safe.\n for (const childNode of currentNodes) {\n cleanupReactive(childNode)\n // Only remove if still attached (reconcileArrays might have moved them)\n if (childNode.parentNode === currentParent) {\n try {\n currentParent.removeChild(childNode)\n } catch (e) {\n logError(ErrorCodes.DOM_CLEANUP_FAILED, { operation: 'removeChild' }, e)\n }\n }\n }\n }\n currentNodes = []\n currentFNodeList = []\n\n const fragment = document.createDocumentFragment()\n mountReactive(result, fragment)\n\n if (currentParent) {\n currentNodes = Array.from(fragment.childNodes)\n currentParent.insertBefore(fragment, startNode.nextSibling)\n }\n })\n } finally {\n // No popProvider needed with Owner-based context\n }\n })\n\n registerReactiveBinding(startNode, dispose)\n\n return container ? startNode : parent\n }\n\n // Handle fragments\n if (node.type === 'fragment') {\n const fragment = document.createDocumentFragment()\n for (const child of node.children) {\n mountReactive(child, fragment)\n }\n if (container) {\n domRenderer.appendChild(container, fragment)\n }\n return fragment\n }\n\n // Handle built-in elements\n const domNode = domRenderer.createNode(node.type, node.props)\n const disposeProps = setupReactiveProps(domNode, node.props)\n if (disposeProps.length > 0) {\n REACTIVE_BINDINGS.set(domNode, new Set(disposeProps))\n }\n\n for (const child of node.children) {\n mountReactive(child, domNode)\n }\n\n if (container) {\n domRenderer.appendChild(container, domNode)\n }\n\n // Handle ref (callback or object with .current)\n const ref = node.props.ref\n if (ref) {\n if (typeof ref === 'function') {\n // Callback ref\n ref(domNode)\n registerReactiveBinding(domNode, () => {\n ref(null)\n })\n } else if (typeof ref === 'object' && 'current' in ref) {\n // Object ref (like useRef)\n ref.current = domNode\n registerReactiveBinding(domNode, () => {\n ref.current = null\n })\n }\n }\n\n return domNode\n }\n\n return null\n}\n\n// Sentinel value to detect first run\nconst UNINITIALIZED = Symbol('uninitialized')\n\nfunction setupReactiveProps(\n node: HTMLElement | SVGElement,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n props: Record<string, any>\n): (() => void)[] {\n const disposers: (() => void)[] = []\n\n // Performance: Filter reactive props in a single pass\n // Only process props that are signals or functions (reactive props)\n // Skip event handlers (they are handled separately in updateNode)\n const reactiveProps: Array<[string, unknown]> = []\n for (const key in props) {\n // Skip event handlers (they are handled separately in updateNode)\n if (key.startsWith('on')) continue\n\n const value = props[key]\n // Only collect reactive props (signals or functions)\n if (isSignal(value) || typeof value === 'function') {\n reactiveProps.push([key, value])\n }\n }\n\n // Process only reactive props (reduces iterations)\n for (const [key, value] of reactiveProps) {\n if (isSignal(value)) {\n // Track previous value to avoid unnecessary DOM updates\n // Use sentinel for first run to ensure initial value is set\n let prevValue: unknown = UNINITIALIZED\n const dispose = effect(() => {\n const newValue = value.get()\n // Only update DOM if value actually changed (always update on first run)\n if (newValue !== prevValue) {\n // Performance: Batch DOM node updates\n const oldPropValue = prevValue === UNINITIALIZED ? undefined : prevValue\n scheduleDOMUpdate(() => {\n domRenderer.updateNode(\n node,\n { [key]: oldPropValue },\n { [key]: newValue }\n )\n })\n prevValue = newValue\n }\n })\n disposers.push(dispose)\n } else {\n // value is a function (already checked in filter above)\n // Track previous value to avoid unnecessary DOM updates\n // Use sentinel for first run to ensure initial value is set\n let prevValue: unknown = UNINITIALIZED\n const dispose = effect(() => {\n try {\n // TypeScript: value is guaranteed to be a function here (checked in filter above)\n const newValue = (value as () => unknown)()\n // Only update DOM if value actually changed (always update on first run)\n if (newValue !== prevValue) {\n // Performance: Batch DOM node updates\n const oldPropValue = prevValue === UNINITIALIZED ? undefined : prevValue\n scheduleDOMUpdate(() => {\n domRenderer.updateNode(\n node,\n { [key]: oldPropValue },\n { [key]: newValue }\n )\n })\n prevValue = newValue\n }\n } catch (e) {\n logError(ErrorCodes.DOM_CLEANUP_FAILED, { operation: 'updateNode', prop: key }, e)\n }\n })\n disposers.push(dispose)\n }\n }\n return disposers\n}\n\nexport function cleanupReactive(node: Node): void {\n const bindings = REACTIVE_BINDINGS.get(node)\n if (bindings) {\n bindings.forEach((dispose) => dispose())\n REACTIVE_BINDINGS.delete(node)\n }\n if (node.childNodes && node.childNodes.length > 0) {\n const children = Array.from(node.childNodes)\n for (const child of children) {\n cleanupReactive(child)\n }\n }\n}\n\nexport function createReactiveRoot(container: HTMLElement) {\n let rootDispose: (() => void) | null = null\n let currentRootNode: Node | null = null\n let currentFNode: FNode | null = null\n\n return {\n render(node: FNode) {\n // Performance: If rendering the same node, skip cleanup (optimization for re-renders)\n const isSameNode = currentFNode === node\n\n if (!isSameNode && currentRootNode) {\n cleanupReactive(currentRootNode)\n // Performance: Use removeChild instead of innerHTML when possible (faster)\n // Only use innerHTML if container has many children\n if (container.childNodes.length === 1) {\n container.removeChild(currentRootNode)\n } else {\n container.innerHTML = ''\n }\n currentRootNode = null\n }\n\n if (rootDispose) {\n rootDispose()\n rootDispose = null\n }\n\n rootDispose = effect(() => {\n // Performance: Only clear if we have existing content and it's different\n if (!isSameNode && container.firstChild) {\n // Performance: Use removeChild for single child, innerHTML for multiple\n if (container.childNodes.length === 1) {\n container.removeChild(container.firstChild!)\n } else {\n container.innerHTML = ''\n }\n }\n currentRootNode = mountReactive(node, container)\n currentFNode = node\n })\n },\n unmount() {\n if (rootDispose) {\n rootDispose()\n rootDispose = null\n }\n cleanupReactive(container)\n // Performance: Use removeChild when possible\n if (container.childNodes.length === 1) {\n container.removeChild(container.firstChild!)\n } else {\n container.innerHTML = ''\n }\n currentRootNode = null\n currentFNode = null\n },\n }\n}\n\n/**\n * Create a reactive text node that updates when the getter returns a new value\n */\nexport function reactiveText(getText: () => string): Text {\n const textNode = document.createTextNode('')\n const dispose = effect(() => {\n const text = getText()\n // Performance: Batch text node updates\n scheduleDOMUpdate(() => {\n domRenderer.updateTextNode(textNode, text)\n })\n })\n registerReactiveBinding(textNode, dispose)\n return textNode\n}\n","/**\n * DOM Render Function\n *\n * This module provides the main render function for mounting components to the DOM.\n * It includes simple reconciliation logic for mounting and unmounting components.\n *\n * Note: This module uses reactive rendering internally via mountReactive.\n * For root-level rendering with cleanup support, use createReactiveRoot.\n */\n\nimport type { FNode, FNodeChild } from '../../core/renderer'\nimport { domRenderer } from './index'\nimport { isFNode } from './f'\nimport { mountReactive, createReactiveRoot } from './reactive'\n\n/**\n * Internal node data stored on DOM nodes\n */\ninterface NodeData {\n vnode: FNode | null\n props: Record<string, unknown>\n}\n\nconst NODE_DATA = new WeakMap<Node, NodeData>()\n\n/**\n * Render a component to a DOM container with automatic reactivity\n *\n * This function uses reactive rendering by default, which means:\n * - Signals passed as children automatically update the DOM\n * - Signals in props automatically update element properties\n * - Component functions automatically re-render when signals change\n *\n * @param vnode - Flexium node to render\n * @returns The rendered DOM node\n *\n * @example\n * const count = signal(0);\n * render(f('div', {}, [count]), document.body);\n * // The div will automatically update when count changes\n */\n/**\n * Mounts a Flexium node to a container\n * @param node - Flexium node to render\n * @param container - DOM element to mount to\n */\nexport function render(\n node: FNode | string | number | null | undefined | Function,\n container: HTMLElement\n): Node | null {\n // Clear container\n container.innerHTML = ''\n return mountReactive(node, container)\n}\n\n/**\n * Internal function to mount a node\n */\nfunction mountNode(node: FNodeChild | Function): Node | null {\n // Handle primitives\n if (node === null || node === undefined || typeof node === 'boolean') {\n return null\n }\n\n // Handle arrays (fragments)\n if (Array.isArray(node)) {\n const fragment = document.createDocumentFragment()\n for (const child of node) {\n const childNode = mountNode(child)\n if (childNode) {\n domRenderer.appendChild(fragment, childNode)\n }\n }\n return fragment\n }\n\n // Handle functions (signals or components returning functions)\n if (typeof node === 'function') {\n return mountNode(node())\n }\n\n // Handle strings/numbers\n if (typeof node === 'string' || typeof node === 'number') {\n return domRenderer.createTextNode(String(node))\n }\n\n // Handle FNodes\n if (isFNode(node)) {\n // Handle function components\n if (typeof node.type === 'function') {\n const component = node.type\n const result = component({ ...node.props, children: node.children })\n return mountNode(result)\n }\n\n // Handle fragments\n if (node.type === 'fragment') {\n const fragment = document.createDocumentFragment()\n for (const child of node.children) {\n const childNode = mountNode(child)\n if (childNode) {\n domRenderer.appendChild(fragment, childNode)\n }\n }\n return fragment\n }\n\n // Handle DOM elements\n const domNode = domRenderer.createNode(node.type, node.props)\n\n // Handle children\n for (const child of node.children) {\n const childNode = mountNode(child)\n if (childNode) {\n domRenderer.appendChild(domNode, childNode)\n }\n }\n\n return domNode\n }\n\n return null\n}\n\n/**\n * Unmount a DOM node and clean up\n */\nfunction unmount(node: Node): void {\n // Clean up children first\n const childNodes = Array.from(node.childNodes)\n for (const child of childNodes) {\n unmount(child)\n }\n\n // Remove from parent\n if (node.parentNode) {\n node.parentNode.removeChild(node)\n }\n\n // Clean up stored data\n NODE_DATA.delete(node)\n}\n\n/**\n * Update an existing DOM node with a new flexium node\n * (Simple implementation - will be enhanced with proper reconciliation later)\n */\nexport function update(\n node: HTMLElement,\n oldVNode: FNode,\n newVNode: FNode\n): void {\n // If types don't match, replace the node\n if (oldVNode.type !== newVNode.type) {\n const newNode = mountNode(newVNode)\n if (newNode && node.parentNode) {\n node.parentNode.replaceChild(newNode, node)\n }\n unmount(node)\n return\n }\n\n // Update props\n domRenderer.updateNode(node, oldVNode.props, newVNode.props)\n\n // Update stored data\n NODE_DATA.set(node, {\n vnode: newVNode,\n props: newVNode.props,\n })\n\n // Update children (simple approach for now)\n const oldChildren = oldVNode.children\n const newChildren = newVNode.children\n\n // Simple reconciliation: update/add/remove based on index\n const maxLength = Math.max(oldChildren.length, newChildren.length)\n\n for (let i = 0; i < maxLength; i++) {\n const oldChild = oldChildren[i]\n const newChild = newChildren[i]\n const childNode = node.childNodes[i]\n\n if (!newChild) {\n // Remove old child\n if (childNode) {\n unmount(childNode)\n }\n } else if (!oldChild) {\n // Add new child\n const newChildNode = mountNode(newChild)\n if (newChildNode) {\n domRenderer.appendChild(node, newChildNode)\n }\n } else if (typeof oldChild === 'string' || typeof oldChild === 'number') {\n // Update text node\n if (typeof newChild === 'string' || typeof newChild === 'number') {\n if (oldChild !== newChild && childNode) {\n domRenderer.updateTextNode(childNode as Text, String(newChild))\n }\n } else {\n // Replace text with element\n const newChildNode = mountNode(newChild)\n if (newChildNode && childNode) {\n node.replaceChild(newChildNode, childNode)\n unmount(childNode)\n }\n }\n } else if (isFNode(oldChild)) {\n if (typeof newChild === 'string' || typeof newChild === 'number') {\n // Replace element with text\n const newChildNode = mountNode(newChild)\n if (newChildNode && childNode) {\n node.replaceChild(newChildNode, childNode)\n unmount(childNode)\n }\n } else if (isFNode(newChild)) {\n // Update element\n if (childNode instanceof HTMLElement) {\n update(childNode, oldChild, newChild)\n }\n }\n }\n }\n}\n\n/**\n * Create a root for rendering with automatic reactivity\n *\n * This creates a root that supports fine-grained reactive updates.\n * Signals are automatically tracked and only the affected DOM nodes are updated.\n *\n * @param container - DOM element to render into\n * @returns Root object with render and unmount methods\n *\n * @example\n * const root = createRoot(document.body);\n * const count = signal(0);\n * root.render(f('div', {}, [count]));\n * // Later: count.value++ will automatically update the DOM\n */\nexport function createRoot(container: HTMLElement) {\n // Use reactive root for automatic signal tracking\n return createReactiveRoot(container)\n}\n\n","import { mountReactive, cleanupReactive } from './reactive'\nimport { onCleanup } from '../../core/signal'\n\ninterface PortalProps {\n mount?: HTMLElement\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n children: any\n}\n\n/**\n * <Portal> component renders its children into a different part of the DOM.\n * Useful for modals, tooltips, etc.\n *\n * @example\n * <Portal mount={document.body}>\n * <div class=\"modal\">...</div>\n * </Portal>\n */\nexport function Portal(props: PortalProps) {\n // SSR guard: return null placeholder on server\n if (typeof document === 'undefined') {\n return null\n }\n\n const container = props.mount || document.body\n\n // Placeholder to keep position in the VDOM tree\n const placeholder = document.createComment('portal')\n\n // We use a fragment to hold portal content references\n let portalContent: Node | null = null\n\n // Mount children to the target container\n // This runs synchronously when Portal component is executed (inside effect)\n portalContent = mountReactive(props.children, container)\n\n // Cleanup when Portal is unmounted\n onCleanup(() => {\n if (portalContent) {\n cleanupReactive(portalContent)\n if (portalContent.parentNode === container) {\n container.removeChild(portalContent)\n }\n }\n })\n\n return placeholder\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {h as h$1,e,d as d$1}from'./chunk-B7VP6HBY.mjs';var S=Symbol.for("flexium.stateSignal"),O=new WeakMap,F=new WeakMap,A=new WeakMap;function l(t,e,n){let s=O.get(t);s||(s=new Map,O.set(t,s));let o=s.get(e);if(!o){let a=n!==void 0?n:Reflect.get(t,e);o=new d$1(a),s.set(e,o);}return o}var Q={get(t,e){let n=A.get(t);if(e===S)return n;let s=F.get(n);if(s&&V(s),e==="peek")return n.peek.bind(n);let o=typeof n.peek=="function"&&typeof n.get=="function",a;if(o||l(n,"value"),a=n.get(),e===Symbol.toPrimitive||e==="valueOf")return ()=>a;if(e===Symbol.iterator)return l(a,"length").get(),l(a,"iterate").get(),a[Symbol.iterator].bind(a);if(a!==null&&typeof a=="object"){let c=Reflect.get(a,e);return typeof c=="function"?Array.isArray(a)&&["push","pop","shift","unshift","splice","sort","reverse"].includes(e)?function(...p){let x=c.apply(a,p);return a===n.get()&&l(n,"value").set(a),l(a,"length").set(a.length),a===n.get()&&l(n,"value").get(),x}:Array.isArray(a)?c.bind(a):a[e].bind(a):(l(a,e,c).get(),c!==null&&typeof c=="object"?H(c):c)}let u=a[e];return typeof u=="function"?u.bind(a):u},set(t,e,n){let o=A.get(t).get();if(o!==null&&typeof o=="object"){let a=Reflect.set(o,e,n);return l(o,e).set(n),a}return false},has(t,e){let n=A.get(t);if(e===S)return true;let s=n.get();return s===null?false:typeof s=="object"?Reflect.has(s,e):false},ownKeys(t){let n=A.get(t).get();return n===null||typeof n!="object"?Reflect.ownKeys(t):(Array.isArray(n)&&l(n,"length").get(),l(n,"iterate").get(),Reflect.ownKeys(n))},getOwnPropertyDescriptor(t,e){let n=A.get(t);if(e===S)return {configurable:true,enumerable:false,value:n};let s=n.get();if(s===null||typeof s!="object")return;let o=Reflect.getOwnPropertyDescriptor(s,e);return o&&(o.configurable=true),o}},U={get(t,e,n){if(e===S)return t;let s=Reflect.get(t,e,n);return l(t,e,s).get(),s!==null&&typeof s=="object"?H(s):s},set(t,e,n,s){let o=Reflect.set(t,e,n,s);return o&&l(t,e).set(n),o},has(t,e){return e===S?true:Reflect.has(t,e)}},z=new WeakMap;function H(t){let e=z.get(t);return e||(e=new Proxy(t,U),z.set(t,e)),e}var D=new WeakMap;function N(t){let e=D.get(t);if(e)return e;let n=()=>t.get();return A.set(n,t),e=new Proxy(n,Q),D.set(t,e),e}var T=null;function te(t){T=t;}function ne(){return {id:Symbol("component"),hookIndex:0,hooks:[]}}function se(t){t.hookIndex=0;}var g=new Map,h=new Map,y=new Map,m={enabled:true,maxIdleTime:300*1e3,checkInterval:60*1e3,minAccessCount:0},d=null;(typeof window<"u"||typeof globalThis<"u")&&setTimeout(()=>{m.enabled&&!d&&(d=setInterval(L,m.checkInterval),d&&typeof d=="object"&&"unref"in d&&typeof d.unref=="function"&&d.unref());},0);var X=1e4,j=false,B=new WeakMap;function v(t){if(typeof t=="string")return t;let e=B.get(t);if(e!==void 0)return e;try{let n=JSON.stringify(t);return B.set(t,n),n}catch{return String(t)}}function E(t,e){e&&(h.has(e)||h.set(e,new Set),h.get(e).add(t));}function _(t,e){if(!e)return;let n=h.get(e);n&&(n.delete(t),n.size===0&&h.delete(e));}function V(t,e,n){let s=Date.now(),o=y.get(t);o?(o.lastAccessed=s,o.accessCount++,o.referenceCount++,e&&o.namespace!==e&&(o.namespace&&_(t,o.namespace),o.namespace=e,E(t,e))):(y.set(t,{key:t,namespace:e,createdAt:s,lastAccessed:s,accessCount:1,referenceCount:1,signalRef:n&&typeof WeakRef<"u"?new WeakRef(n):void 0}),E(t,e));}function L(){if(!m.enabled)return;let t=Date.now(),e=[];for(let[n,s]of y.entries()){if(s.signalRef&&typeof WeakRef<"u"&&!s.signalRef.deref()){e.push(n);continue}t-s.lastAccessed>m.maxIdleTime&&s.referenceCount===0&&s.accessCount>=m.minAccessCount&&e.push(n);}for(let n of e)f.delete(n);e.length>0&&typeof process<"u"&&process.env?.NODE_ENV!=="production"&&console.log(`[Flexium] Auto-cleaned ${e.length} idle states`);}function K(t){return (typeof t=="object"||typeof t=="function")&&t!==null&&S in t}function oe(t){return K(t)?t[S]:null}function ae(t,e){return K(t)?t.peek()===e:false}function re(t){return K(t)?!!t.peek():false}function Y(t,e$1){if(T&&!e$1?.key){let r=T,i=r.hookIndex++;if(i<r.hooks.length)return r.hooks[i];let w=T;T=null;let I=f(t,e$1);return T=w,r.hooks.push(I),I}let n=e$1?.key,s=n?v(n):void 0,o=Array.isArray(n)&&n.length>0?String(n[0]):void 0,a=e$1?.params;if(s&&g.has(s)){let r=g.get(s);V(s,o,r.box);let i=[r.proxy];return r.setter&&i.push(r.setter),r.refetch&&i.push(r.refetch),r.status&&i.push(r.status),r.error&&i.push(r.error),i}let u,c,p,x,C;if(typeof t=="function"){let r=t,i=a!==void 0?()=>r(a):r,w;try{w=i();}catch{}if(r.constructor.name==="AsyncFunction"||w instanceof Promise){let[b,G]=h$1(i,async J=>J);u={get:()=>b.value,peek:()=>b.peek()},p=G.refetch;let $=new e(()=>b.loading?"loading":b.error?"error":b.state==="unresolved"?"idle":"success");x=N($);let q=new e(()=>b.error);C=N(q);}else u=new e(i);}else {let r=new d$1(t);u=r,c=i=>{typeof i=="function"?r.set(i(r.peek())):r.set(i);};}let M=N(u),k=[M];return c&&k.push(c),p&&(k.splice(1,0,p),x&&k.push(x),C&&k.push(C)),s&&(g.set(s,{box:u,proxy:M,setter:c,refetch:p,status:x,error:C,createdAt:Date.now(),lastAccessed:Date.now(),accessCount:1,referenceCount:1,key:s,namespace:o}),F.set(u,s),V(s,o,u),typeof process<"u"&&process.env?.NODE_ENV!=="production"&&!j&&g.size>=X&&(j=true,console.warn(`[Flexium] Registry size warning: ${g.size}`))),k}var f=Y;f.delete=function(t){let e=v(t),n=y.get(e);return n?.namespace&&_(e,n.namespace),y.delete(e),g.delete(e)};f.clear=function(){g.clear(),h.clear(),y.clear(),j=false;};f.has=function(t){return g.has(v(t))};f.clearByPrefix=function(t){let e=v(t),n=0,s=[];for(let[o]of y.entries()){if(o===e){s.push(o);continue}if(e.endsWith("]")){let a=e.slice(0,-1);o.startsWith(a)&&o.length>a.length&&o[a.length]===","&&s.push(o);}else o.startsWith(e)&&s.push(o);}for(let o of s)f.delete(o)&&n++;return n};f.getStats=function(){let t={};for(let[n,s]of h.entries())t[n]=s.size;let e=0;for(let n of y.values())e+=n.accessCount;return {total:g.size,byNamespace:t,topNamespaces:Object.entries(t).map(([n,s])=>({namespace:n,count:s})).sort((n,s)=>s.count-n.count).slice(0,10),averageAccessCount:y.size?e/y.size:0}};f.getNamespaceStats=function(t){let e=v(t),n=Array.isArray(t)&&t.length>0?String(t[0]):e,s=[],o=0;for(let[a,u]of y.entries()){let c=false;if(a===e)c=true;else if(e.endsWith("]")){let p=e.slice(0,-1);a.startsWith(p)&&a.length>p.length&&a[p.length]===","&&(c=true);}else a.startsWith(e)&&(c=true);c&&(s.push({key:a,accessCount:u.accessCount,createdAt:u.createdAt}),o+=u.accessCount);}return {namespace:n,count:s.length,totalAccessCount:o,averageAccessCount:s.length?o/s.length:0,states:s}};Object.defineProperty(f,"size",{get:()=>g.size,enumerable:true});f.enableAutoCleanup=t=>{Object.assign(m,t,{enabled:true}),d&&clearInterval(d),d=setInterval(L,m.checkInterval);};f.disableAutoCleanup=()=>{m.enabled=false,d&&clearInterval(d);};Object.defineProperty(f,"isAutoCleanupEnabled",{get:()=>m.enabled,enumerable:true});function ce(t){return {current:t}}export{te as a,ne as b,se as c,K as d,oe as e,ae as f,re as g,f as h,ce as i};//# sourceMappingURL=chunk-7Q4UE442.mjs.map
2
+ //# sourceMappingURL=chunk-7Q4UE442.mjs.map