flexium 0.10.4 → 0.10.7

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 (150) hide show
  1. package/README.md +5 -5
  2. package/dist/{DrawText-ngwNNh8O.d.ts → DrawText-CVAKQ5wZ.d.cts} +42 -42
  3. package/dist/{DrawText-ccZrs3Xs.d.cts → DrawText-Dlh1L1Ar.d.ts} +42 -42
  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 +5 -6
  11. package/dist/canvas.d.ts +5 -6
  12. package/dist/canvas.js +1 -1
  13. package/dist/canvas.mjs +1 -1
  14. package/dist/chunk-5ICRQIS2.js +3 -0
  15. package/dist/chunk-5ICRQIS2.js.map +1 -0
  16. package/dist/chunk-5K55ASOD.mjs +3 -0
  17. package/dist/chunk-5K55ASOD.mjs.map +1 -0
  18. package/dist/chunk-AZEHBSBG.js +3 -0
  19. package/dist/chunk-AZEHBSBG.js.map +1 -0
  20. package/dist/chunk-BBNYMXE7.mjs +2 -0
  21. package/dist/chunk-BBNYMXE7.mjs.map +1 -0
  22. package/dist/{chunk-WXEHDEIH.js → chunk-DZ7L3SHV.js} +2 -2
  23. package/dist/{chunk-WXEHDEIH.js.map → chunk-DZ7L3SHV.js.map} +1 -1
  24. package/dist/chunk-ECYYIQEX.mjs +3 -0
  25. package/dist/chunk-ECYYIQEX.mjs.map +1 -0
  26. package/dist/chunk-FDMJHFN7.mjs +2 -0
  27. package/dist/chunk-FDMJHFN7.mjs.map +1 -0
  28. package/dist/chunk-GKJQEOP7.mjs +2 -0
  29. package/dist/{chunk-PVPY55Z7.mjs.map → chunk-GKJQEOP7.mjs.map} +1 -1
  30. package/dist/chunk-GYDP6MFV.js +3 -0
  31. package/dist/chunk-GYDP6MFV.js.map +1 -0
  32. package/dist/chunk-HB5VPQTB.mjs +2 -0
  33. package/dist/chunk-HB5VPQTB.mjs.map +1 -0
  34. package/dist/chunk-OPAAGNBO.mjs +2 -0
  35. package/dist/{chunk-HLPVL6EK.mjs.map → chunk-OPAAGNBO.mjs.map} +1 -1
  36. package/dist/chunk-QPCIDSMM.js +2 -0
  37. package/dist/chunk-QPCIDSMM.js.map +1 -0
  38. package/dist/chunk-QZIX4FXS.mjs +2 -0
  39. package/dist/chunk-QZIX4FXS.mjs.map +1 -0
  40. package/dist/{chunk-63AW5ZOC.js → chunk-RMN5IPS5.js} +2 -2
  41. package/dist/{chunk-63AW5ZOC.js.map → chunk-RMN5IPS5.js.map} +1 -1
  42. package/dist/chunk-WWEWRI6S.js +2 -0
  43. package/dist/chunk-WWEWRI6S.js.map +1 -0
  44. package/dist/chunk-XJHWMHKF.js +2 -0
  45. package/dist/chunk-XJHWMHKF.js.map +1 -0
  46. package/dist/chunk-Y6KKAHLS.mjs +3 -0
  47. package/dist/chunk-Y6KKAHLS.mjs.map +1 -0
  48. package/dist/chunk-YPVRQKMW.js +2 -0
  49. package/dist/chunk-YPVRQKMW.js.map +1 -0
  50. package/dist/{components-CxnAnbpI.d.cts → components-BMbqsbMY.d.cts} +5 -5
  51. package/dist/{components-B7KQ8C-i.d.ts → components-C83mBQXW.d.ts} +5 -5
  52. package/dist/{effect-14CxUU8r.d.ts → core-CxHP8991.d.cts} +9 -1
  53. package/dist/{effect-14CxUU8r.d.cts → core-D0ggvjX3.d.ts} +9 -1
  54. package/dist/core.d.cts +2 -80
  55. package/dist/core.d.ts +2 -80
  56. package/dist/core.js +1 -1
  57. package/dist/core.mjs +1 -1
  58. package/dist/dom.d.cts +2 -2
  59. package/dist/dom.d.ts +2 -2
  60. package/dist/dom.js +1 -1
  61. package/dist/dom.js.map +1 -1
  62. package/dist/dom.mjs +1 -1
  63. package/dist/dom.mjs.map +1 -1
  64. package/dist/effect-554ONNZR.js +2 -0
  65. package/dist/{effect-K45UU3N4.js.map → effect-554ONNZR.js.map} +1 -1
  66. package/dist/effect-T2GVIS3T.mjs +2 -0
  67. package/dist/{effect-3LUCHSAZ.mjs.map → effect-T2GVIS3T.mjs.map} +1 -1
  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 +5 -5
  75. package/dist/interactive.d.ts +5 -5
  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-NLlE-fNZ.d.cts → portal-BK_0Z0hE.d.cts} +2 -2
  83. package/dist/{portal-CVqrpmHd.d.ts → portal-CbguxtuQ.d.ts} +2 -2
  84. package/dist/primitives/motion.js +1 -1
  85. package/dist/primitives/motion.mjs +1 -1
  86. package/dist/primitives/ui.d.cts +3 -3
  87. package/dist/primitives/ui.d.ts +3 -3
  88. package/dist/primitives/ui.js +1 -1
  89. package/dist/primitives/ui.js.map +1 -1
  90. package/dist/primitives/ui.mjs +1 -1
  91. package/dist/primitives/ui.mjs.map +1 -1
  92. package/dist/primitives.d.cts +4 -5
  93. package/dist/primitives.d.ts +4 -5
  94. package/dist/primitives.js +1 -1
  95. package/dist/primitives.js.map +1 -1
  96. package/dist/primitives.mjs +1 -1
  97. package/dist/primitives.mjs.map +1 -1
  98. package/dist/router.d.cts +3 -3
  99. package/dist/router.d.ts +3 -3
  100. package/dist/router.js +1 -1
  101. package/dist/router.mjs +1 -1
  102. package/dist/server.js +1 -1
  103. package/dist/server.js.map +1 -1
  104. package/dist/server.mjs +1 -1
  105. package/dist/server.mjs.map +1 -1
  106. package/dist/state-DitsMyev.d.cts +96 -0
  107. package/dist/state-DitsMyev.d.ts +96 -0
  108. package/dist/state-RYKSC35A.mjs +2 -0
  109. package/dist/state-RYKSC35A.mjs.map +1 -0
  110. package/dist/state-XUXPMCFJ.js +2 -0
  111. package/dist/state-XUXPMCFJ.js.map +1 -0
  112. package/dist/test-exports.d.cts +37 -7
  113. package/dist/test-exports.d.ts +37 -7
  114. package/dist/test-exports.js +1 -1
  115. package/dist/test-exports.mjs +1 -1
  116. package/package.json +1 -1
  117. package/dist/chunk-3AWR7IKE.js +0 -2
  118. package/dist/chunk-3AWR7IKE.js.map +0 -1
  119. package/dist/chunk-3BQXIHYI.mjs +0 -3
  120. package/dist/chunk-3BQXIHYI.mjs.map +0 -1
  121. package/dist/chunk-5236IK5I.js +0 -2
  122. package/dist/chunk-5236IK5I.js.map +0 -1
  123. package/dist/chunk-6K44QCMT.mjs +0 -3
  124. package/dist/chunk-6K44QCMT.mjs.map +0 -1
  125. package/dist/chunk-7Q4UE442.mjs +0 -2
  126. package/dist/chunk-7Q4UE442.mjs.map +0 -1
  127. package/dist/chunk-AJT35P3Z.js +0 -3
  128. package/dist/chunk-AJT35P3Z.js.map +0 -1
  129. package/dist/chunk-AYQMU7XC.js +0 -3
  130. package/dist/chunk-AYQMU7XC.js.map +0 -1
  131. package/dist/chunk-B7VP6HBY.mjs +0 -2
  132. package/dist/chunk-B7VP6HBY.mjs.map +0 -1
  133. package/dist/chunk-HLPVL6EK.mjs +0 -2
  134. package/dist/chunk-KJPIJNFH.mjs +0 -2
  135. package/dist/chunk-KJPIJNFH.mjs.map +0 -1
  136. package/dist/chunk-PVPY55Z7.mjs +0 -2
  137. package/dist/chunk-Q7WT5IIF.mjs +0 -3
  138. package/dist/chunk-Q7WT5IIF.mjs.map +0 -1
  139. package/dist/chunk-S3EDPCYT.js +0 -3
  140. package/dist/chunk-S3EDPCYT.js.map +0 -1
  141. package/dist/chunk-WOHSSPKD.js +0 -2
  142. package/dist/chunk-WOHSSPKD.js.map +0 -1
  143. package/dist/effect-3LUCHSAZ.mjs +0 -2
  144. package/dist/effect-K45UU3N4.js +0 -2
  145. package/dist/signal-2QUI7H7B.js +0 -2
  146. package/dist/signal-2QUI7H7B.js.map +0 -1
  147. package/dist/signal-C6936A3J.d.cts +0 -175
  148. package/dist/signal-C6936A3J.d.ts +0 -175
  149. package/dist/signal-L3ZWGOVT.mjs +0 -2
  150. package/dist/signal-L3ZWGOVT.mjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/core/context.ts"],"names":["createContext","defaultValue","id","Provider","props","context","ctx","owner","getOwner","value","pushProvider"],"mappings":"qCASO,SAASA,CAAAA,CAAiBC,CAAAA,CAA6B,CAC5D,IAAMC,EAAK,MAAA,CAAO,SAAS,CAAA,CAErBC,CAAAA,CAAYC,GACTA,CAAAA,CAAM,QAAA,CAEX,OAACD,CAAAA,CAA+C,WAAaD,CAAAA,CAE1D,CACL,EAAA,CAAAA,CAAAA,CACA,SAAAC,CAAAA,CACA,YAAA,CAAAF,CACF,CACF,CAUO,SAASI,CAAAA,CAAWC,CAAAA,CAAoB,CAC7C,IAAMC,CAAAA,CAAQC,CAAAA,EAAS,CACvB,GAAID,GAASA,CAAAA,CAAM,OAAA,CAAS,CAC1B,IAAME,EAAQF,CAAAA,CAAM,OAAA,CAAQD,CAAAA,CAAI,EAAE,EAClC,GAAIG,CAAAA,GAAU,MAAA,CACZ,OAAOA,CAEX,CACA,OAAOH,CAAAA,CAAI,YACb,CAQO,SAASI,CAAAA,CAAaR,CAAAA,CAAYO,CAAAA,CAAsB,CAC7D,IAAMF,CAAAA,CAAQC,CAAAA,EAAS,CACnBD,IACGA,CAAAA,CAAM,OAAA,GACTA,CAAAA,CAAM,OAAA,CAAU,EAAC,CAAA,CAEnBA,CAAAA,CAAM,OAAA,CAAQL,CAAE,EAAIO,CAAAA,EAExB","file":"chunk-HLPVL6EK.mjs","sourcesContent":["import type { FNodeChild } from './renderer'\nimport { getOwner, setOwner } from './owner'\n\nexport interface Context<T> {\n id: symbol\n Provider: (props: { value: T; children: FNodeChild }) => FNodeChild\n defaultValue: T\n}\n\nexport function createContext<T>(defaultValue: T): Context<T> {\n const id = Symbol('context')\n\n const Provider = (props: { value: T; children: FNodeChild }): FNodeChild => {\n return props.children\n }\n ; (Provider as unknown as { _contextId: symbol })._contextId = id\n\n return {\n id,\n Provider,\n defaultValue,\n }\n}\n\n/**\n * Get the current value from a context.\n *\n * @example\n * ```tsx\n * const theme = context(ThemeContext)\n * ```\n */\nexport function context<T>(ctx: Context<T>): T {\n const owner = getOwner()\n if (owner && owner.context) {\n const value = owner.context[ctx.id]\n if (value !== undefined) {\n return value as T\n }\n }\n return ctx.defaultValue\n}\n\n/**\n * Push a value onto the context stack for a given context ID.\n * @internal Used by the renderer during component mounting.\n * @param id - The context symbol identifier\n * @param value - The value to push onto the context stack\n */\nexport function pushProvider(id: symbol, value: unknown): void {\n const owner = getOwner()\n if (owner) {\n if (!owner.context) {\n owner.context = {}\n }\n owner.context[id] = value\n }\n}\n\n/**\n * Pop a value from the context stack for a given context ID.\n * @internal No-op in Owner-based context system (handled by scope)\n */\nexport function popProvider(_id: symbol): void {\n // No-op: Context scoping is handled by the Owner prototype chain\n}\n\n/**\n * Capture the current context state\n * Returns an opaque handle to the current owner scope.\n */\nexport function captureContext(): unknown {\n return getOwner()\n}\n\n/**\n * Run a function with the captured context restored\n */\nexport function runWithContext<T>(\n snapshot: unknown,\n fn: () => T\n): T {\n const prev = getOwner()\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setOwner(snapshot as any)\n try {\n return fn()\n } finally {\n setOwner(prev)\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/core/context.ts"],"names":["createContext","defaultValue","id","Provider","props","context","ctx","owner","getOwner","value","pushProvider"],"mappings":"qCASO,SAASA,CAAAA,CAAiBC,CAAAA,CAA6B,CAC5D,IAAMC,EAAK,MAAA,CAAO,SAAS,CAAA,CAErBC,CAAAA,CAAYC,GACTA,CAAAA,CAAM,QAAA,CAEX,OAACD,CAAAA,CAA+C,WAAaD,CAAAA,CAE1D,CACL,EAAA,CAAAA,CAAAA,CACA,SAAAC,CAAAA,CACA,YAAA,CAAAF,CACF,CACF,CAUO,SAASI,CAAAA,CAAWC,CAAAA,CAAoB,CAC7C,IAAMC,CAAAA,CAAQC,CAAAA,EAAS,CACvB,GAAID,GAASA,CAAAA,CAAM,OAAA,CAAS,CAC1B,IAAME,EAAQF,CAAAA,CAAM,OAAA,CAAQD,CAAAA,CAAI,EAAE,EAClC,GAAIG,CAAAA,GAAU,MAAA,CACZ,OAAOA,CAEX,CACA,OAAOH,CAAAA,CAAI,YACb,CAQO,SAASI,CAAAA,CAAaR,CAAAA,CAAYO,CAAAA,CAAsB,CAC7D,IAAMF,CAAAA,CAAQC,CAAAA,EAAS,CACnBD,IACGA,CAAAA,CAAM,OAAA,GACTA,CAAAA,CAAM,OAAA,CAAU,EAAC,CAAA,CAEnBA,CAAAA,CAAM,OAAA,CAAQL,CAAE,EAAIO,CAAAA,EAExB","file":"chunk-OPAAGNBO.mjs","sourcesContent":["import type { FNodeChild } from './renderer'\nimport { getOwner, setOwner } from './owner'\n\nexport interface Context<T> {\n id: symbol\n Provider: (props: { value: T; children: FNodeChild }) => FNodeChild\n defaultValue: T\n}\n\nexport function createContext<T>(defaultValue: T): Context<T> {\n const id = Symbol('context')\n\n const Provider = (props: { value: T; children: FNodeChild }): FNodeChild => {\n return props.children\n }\n ; (Provider as unknown as { _contextId: symbol })._contextId = id\n\n return {\n id,\n Provider,\n defaultValue,\n }\n}\n\n/**\n * Get the current value from a context.\n *\n * @example\n * ```tsx\n * const theme = context(ThemeContext)\n * ```\n */\nexport function context<T>(ctx: Context<T>): T {\n const owner = getOwner()\n if (owner && owner.context) {\n const value = owner.context[ctx.id]\n if (value !== undefined) {\n return value as T\n }\n }\n return ctx.defaultValue\n}\n\n/**\n * Push a value onto the context stack for a given context ID.\n * @internal Used by the renderer during component mounting.\n * @param id - The context symbol identifier\n * @param value - The value to push onto the context stack\n */\nexport function pushProvider(id: symbol, value: unknown): void {\n const owner = getOwner()\n if (owner) {\n if (!owner.context) {\n owner.context = {}\n }\n owner.context[id] = value\n }\n}\n\n/**\n * Pop a value from the context stack for a given context ID.\n * @internal No-op in Owner-based context system (handled by scope)\n */\nexport function popProvider(_id: symbol): void {\n // No-op: Context scoping is handled by the Owner prototype chain\n}\n\n/**\n * Capture the current context state\n * Returns an opaque handle to the current owner scope.\n */\nexport function captureContext(): unknown {\n return getOwner()\n}\n\n/**\n * Run a function with the captured context restored\n */\nexport function runWithContext<T>(\n snapshot: unknown,\n fn: () => T\n): T {\n const prev = getOwner()\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setOwner(snapshot as any)\n try {\n return fn()\n } finally {\n setOwner(prev)\n }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ 'use strict';var chunkXJHWMHKF_js=require('./chunk-XJHWMHKF.js');function x(i){if(!i)return {};let e={};i.display&&(e.display=i.display),i.flex!==void 0&&(e.flex=i.flex),i.flexDirection&&(e.flexDirection=i.flexDirection),i.flexWrap&&(e.flexWrap=i.flexWrap),i.justifyContent&&(e.justifyContent=i.justifyContent),i.alignItems&&(e.alignItems=i.alignItems),i.alignSelf&&(e.alignSelf=i.alignSelf),i.gap!==void 0&&(e.gap=`${i.gap}px`),i.padding!==void 0&&(e.padding=`${i.padding}px`),i.paddingTop!==void 0&&(e.paddingTop=`${i.paddingTop}px`),i.paddingRight!==void 0&&(e.paddingRight=`${i.paddingRight}px`),i.paddingBottom!==void 0&&(e.paddingBottom=`${i.paddingBottom}px`),i.paddingLeft!==void 0&&(e.paddingLeft=`${i.paddingLeft}px`),i.paddingHorizontal!==void 0&&(e.paddingLeft=`${i.paddingHorizontal}px`,e.paddingRight=`${i.paddingHorizontal}px`),i.paddingVertical!==void 0&&(e.paddingTop=`${i.paddingVertical}px`,e.paddingBottom=`${i.paddingVertical}px`),i.margin!==void 0&&(e.margin=`${i.margin}px`),i.marginTop!==void 0&&(e.marginTop=`${i.marginTop}px`),i.marginRight!==void 0&&(e.marginRight=`${i.marginRight}px`),i.marginBottom!==void 0&&(e.marginBottom=`${i.marginBottom}px`),i.marginLeft!==void 0&&(e.marginLeft=`${i.marginLeft}px`),i.marginHorizontal!==void 0&&(e.marginLeft=`${i.marginHorizontal}px`,e.marginRight=`${i.marginHorizontal}px`),i.marginVertical!==void 0&&(e.marginTop=`${i.marginVertical}px`,e.marginBottom=`${i.marginVertical}px`),i.width!==void 0&&(e.width=typeof i.width=="number"?`${i.width}px`:i.width),i.height!==void 0&&(e.height=typeof i.height=="number"?`${i.height}px`:i.height),i.minWidth!==void 0&&(e.minWidth=`${i.minWidth}px`),i.maxWidth!==void 0&&(e.maxWidth=`${i.maxWidth}px`),i.minHeight!==void 0&&(e.minHeight=`${i.minHeight}px`),i.maxHeight!==void 0&&(e.maxHeight=`${i.maxHeight}px`),i.backgroundColor&&(e.backgroundColor=i.backgroundColor),i.borderRadius!==void 0&&(e.borderRadius=`${i.borderRadius}px`),i.borderTopLeftRadius!==void 0&&(e.borderTopLeftRadius=`${i.borderTopLeftRadius}px`),i.borderTopRightRadius!==void 0&&(e.borderTopRightRadius=`${i.borderTopRightRadius}px`),i.borderBottomLeftRadius!==void 0&&(e.borderBottomLeftRadius=`${i.borderBottomLeftRadius}px`),i.borderBottomRightRadius!==void 0&&(e.borderBottomRightRadius=`${i.borderBottomRightRadius}px`),i.opacity!==void 0&&(e.opacity=i.opacity),i.borderWidth!==void 0&&(e.borderWidth=`${i.borderWidth}px`),i.borderColor&&(e.borderColor=i.borderColor),i.borderTopWidth!==void 0&&(e.borderTopWidth=`${i.borderTopWidth}px`),i.borderRightWidth!==void 0&&(e.borderRightWidth=`${i.borderRightWidth}px`),i.borderBottomWidth!==void 0&&(e.borderBottomWidth=`${i.borderBottomWidth}px`),i.borderLeftWidth!==void 0&&(e.borderLeftWidth=`${i.borderLeftWidth}px`),i.position&&(e.position=i.position),i.top!==void 0&&(e.top=`${i.top}px`),i.right!==void 0&&(e.right=`${i.right}px`),i.bottom!==void 0&&(e.bottom=`${i.bottom}px`),i.left!==void 0&&(e.left=`${i.left}px`),i.zIndex!==void 0&&(e.zIndex=i.zIndex),i.transform&&(e.transform=i.transform);let t=i;return t.color&&(e.color=t.color),t.fontSize!==void 0&&(e.fontSize=`${t.fontSize}px`),t.fontWeight&&(e.fontWeight=t.fontWeight),t.fontFamily&&(e.fontFamily=t.fontFamily),t.fontStyle&&(e.fontStyle=t.fontStyle),t.textAlign&&(e.textAlign=t.textAlign),t.textDecoration&&(e.textDecoration=t.textDecoration),t.lineHeight!==void 0&&(e.lineHeight=`${t.lineHeight}px`),t.letterSpacing!==void 0&&(e.letterSpacing=`${t.letterSpacing}px`),e}function k(i){return chunkXJHWMHKF_js.g(i)}function n(i){return k(i)?i():i!==null&&typeof i=="object"&&"value"in i&&"peek"in i?i.value:i}function b(i,e,t,r){if(!e)return;let a=Array.isArray(e)?e:[e];for(let o of a)if(!(!o||!o.type))switch(o.type){case "canvas-rect":D(i,o.props);break;case "canvas-circle":S(i,o.props);break;case "canvas-path":W(i,o.props);break;case "canvas-text":C(i,o.props);break;case "canvas-line":T(i,o.props);break;case "canvas-arc":v(i,o.props);break}}function D(i,e){let t=n(e.x),r=n(e.y),a=n(e.width),o=n(e.height),d=n(e.fill),f=n(e.stroke),p=n(e.strokeWidth),c=n(e.opacity);i.save(),c!==void 0&&(i.globalAlpha=c),d&&(i.fillStyle=d,i.fillRect(t,r,a,o)),f&&(i.strokeStyle=f,i.lineWidth=p||1,i.strokeRect(t,r,a,o)),i.restore();}function S(i,e){let t=n(e.x),r=n(e.y),a=n(e.radius),o=n(e.fill),d=n(e.stroke),f=n(e.strokeWidth),p=n(e.opacity);i.save(),p!==void 0&&(i.globalAlpha=p),i.beginPath(),i.arc(t,r,a,0,2*Math.PI),o&&(i.fillStyle=o,i.fill()),d&&(i.strokeStyle=d,i.lineWidth=f||1,i.stroke()),i.restore();}function W(i,e){let t=n(e.d),r=n(e.fill),a=n(e.stroke),o=n(e.strokeWidth),d=n(e.opacity);i.save(),d!==void 0&&(i.globalAlpha=d);let f=new Path2D(t);r&&(i.fillStyle=r,i.fill(f)),a&&(i.strokeStyle=a,i.lineWidth=o||1,i.stroke(f)),i.restore();}function C(i,e){let t=n(e.x),r=n(e.y),a=n(e.text),o=n(e.fill),d=n(e.fontSize)||12,f=n(e.fontFamily)||"sans-serif",p=n(e.fontWeight)||"normal",c=n(e.textAlign)||"left",m=n(e.textBaseline)||"alphabetic";i.save(),i.font=`${p} ${d}px ${f}`,i.textAlign=c,i.textBaseline=m,o&&(i.fillStyle=o,i.fillText(a,t,r)),i.restore();}function T(i,e){let t=n(e.x1),r=n(e.y1),a=n(e.x2),o=n(e.y2),d=n(e.stroke)||"black",f=n(e.strokeWidth)||1,p=n(e.opacity);i.save(),p!==void 0&&(i.globalAlpha=p),i.beginPath(),i.moveTo(t,r),i.lineTo(a,o),i.strokeStyle=d,i.lineWidth=f,i.stroke(),i.restore();}function v(i,e){let t=n(e.x),r=n(e.y),a=n(e.radius),o=n(e.startAngle),d=n(e.endAngle),f=n(e.counterclockwise)||false,p=n(e.fill),c=n(e.stroke),m=n(e.strokeWidth),h=n(e.opacity);i.save(),h!==void 0&&(i.globalAlpha=h),i.beginPath(),i.arc(t,r,a,o,d,f),p&&(i.fillStyle=p,i.fill()),c&&(i.strokeStyle=c,i.lineWidth=m||1,i.stroke()),i.restore();}function N(i){let{width:e,height:t,children:r,style:a,id:o,...d}=i;return {type:"canvas",props:{...d,id:o,width:e,height:t,style:x(a),ref:f=>{if(!f||typeof requestAnimationFrame>"u")return;let p=f.getContext("2d");p&&Promise.all([import('./effect-554ONNZR.js').then(c=>({effect:c.effect,onCleanup:c.onCleanup})),import('./state-XUXPMCFJ.js').then(c=>({isSignal:c.isSignal}))]).then(([{effect:c,onCleanup:m},{isSignal:h}])=>{let g,R=()=>{g!==void 0&&cancelAnimationFrame(g),g=requestAnimationFrame(()=>{p.clearRect(0,0,e,t),b(p,r),g=void 0;});};c(()=>{let w=Array.isArray(r)?r:[r];for(let u of w)if(u&&u.props)for(let $ in u.props){let s=u.props[$];h(s)&&s();}R(),m(()=>{g!==void 0&&(cancelAnimationFrame(g),g=void 0);});});}).catch(c=>{console.error("[Flexium Canvas] Failed to load signal module:",c);});}},children:[]}}function V(i){return {type:"canvas-rect",props:i,children:[]}}function j(i){return {type:"canvas-circle",props:i,children:[]}}function M(i){return {type:"canvas-arc",props:i,children:[]}}function E(i){return {type:"canvas-line",props:i,children:[]}}function J(i){return {type:"canvas-path",props:i,children:[]}}function O(i){return {type:"canvas-text",props:i,children:[]}}exports.a=x;exports.b=n;exports.c=b;exports.d=N;exports.e=V;exports.f=j;exports.g=M;exports.h=E;exports.i=J;exports.j=O;//# sourceMappingURL=chunk-QPCIDSMM.js.map
2
+ //# sourceMappingURL=chunk-QPCIDSMM.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/primitives/utils.ts","../src/primitives/canvas/utils.ts","../src/primitives/canvas/renderer.ts","../src/primitives/canvas/Canvas.ts","../src/primitives/canvas/DrawRect.ts","../src/primitives/canvas/DrawCircle.ts","../src/primitives/canvas/DrawArc.ts","../src/primitives/canvas/DrawLine.ts","../src/primitives/canvas/DrawPath.ts","../src/primitives/canvas/DrawText.ts"],"names":["normalizeStyle","style","css","textStyle","isSignal","value","unwrapSignal","renderCanvasChildren","ctx","children","_width","_height","childArray","child","renderRect","renderCircle","renderPath","renderText","renderLine","renderArc","props","x","y","width","height","fill","stroke","strokeWidth","opacity","radius","d","path","text","fontSize","fontFamily","fontWeight","textAlign","textBaseline","x1","y1","x2","y2","startAngle","endAngle","counterclockwise","Canvas","id","rest","canvas","m","effect","onCleanup","rafId","scheduleRender","key","err","DrawRect","DrawCircle","DrawArc","DrawLine","DrawPath","DrawText"],"mappings":"iEASO,SAASA,EACdC,CAAAA,CAEqB,CACrB,GAAI,CAACA,CAAAA,CAAO,OAAO,EAAC,CAGpB,IAAMC,CAAAA,CAA2B,EAAC,CAG9BD,CAAAA,CAAM,UAASC,CAAAA,CAAI,OAAA,CAAUD,EAAM,OAAA,CAAA,CACnCA,CAAAA,CAAM,IAAA,GAAS,MAAA,GAAWC,EAAI,IAAA,CAAOD,CAAAA,CAAM,MAC3CA,CAAAA,CAAM,aAAA,GAAeC,EAAI,aAAA,CAAgBD,CAAAA,CAAM,aAAA,CAAA,CAC/CA,CAAAA,CAAM,WAAUC,CAAAA,CAAI,QAAA,CAAWD,EAAM,QAAA,CAAA,CACrCA,CAAAA,CAAM,iBAAgBC,CAAAA,CAAI,cAAA,CAAiBD,CAAAA,CAAM,cAAA,CAAA,CACjDA,EAAM,UAAA,GAAYC,CAAAA,CAAI,WAAaD,CAAAA,CAAM,UAAA,CAAA,CACzCA,EAAM,SAAA,GAAWC,CAAAA,CAAI,SAAA,CAAYD,CAAAA,CAAM,WACvCA,CAAAA,CAAM,GAAA,GAAQ,SAAWC,CAAAA,CAAI,GAAA,CAAM,GAAGD,CAAAA,CAAM,GAAG,CAAA,EAAA,CAAA,CAAA,CAG/CA,CAAAA,CAAM,UAAY,MAAA,GAAWC,CAAAA,CAAI,QAAU,CAAA,EAAGD,CAAAA,CAAM,OAAO,CAAA,EAAA,CAAA,CAAA,CAC3DA,CAAAA,CAAM,aAAe,MAAA,GAAWC,CAAAA,CAAI,WAAa,CAAA,EAAGD,CAAAA,CAAM,UAAU,CAAA,EAAA,CAAA,CAAA,CACpEA,CAAAA,CAAM,eAAiB,MAAA,GACzBC,CAAAA,CAAI,YAAA,CAAe,CAAA,EAAGD,EAAM,YAAY,CAAA,EAAA,CAAA,CAAA,CACtCA,EAAM,aAAA,GAAkB,MAAA,GAC1BC,EAAI,aAAA,CAAgB,CAAA,EAAGD,CAAAA,CAAM,aAAa,MACxCA,CAAAA,CAAM,WAAA,GAAgB,SACxBC,CAAAA,CAAI,WAAA,CAAc,GAAGD,CAAAA,CAAM,WAAW,CAAA,EAAA,CAAA,CAAA,CACpCA,CAAAA,CAAM,oBAAsB,MAAA,GAC9BC,CAAAA,CAAI,YAAc,CAAA,EAAGD,CAAAA,CAAM,iBAAiB,CAAA,EAAA,CAAA,CAC5CC,CAAAA,CAAI,YAAA,CAAe,CAAA,EAAGD,EAAM,iBAAiB,CAAA,EAAA,CAAA,CAAA,CAE3CA,EAAM,eAAA,GAAoB,MAAA,GAC5BC,EAAI,UAAA,CAAa,CAAA,EAAGD,CAAAA,CAAM,eAAe,KACzCC,CAAAA,CAAI,aAAA,CAAgB,GAAGD,CAAAA,CAAM,eAAe,MAI1CA,CAAAA,CAAM,MAAA,GAAW,MAAA,GAAWC,CAAAA,CAAI,OAAS,CAAA,EAAGD,CAAAA,CAAM,MAAM,CAAA,EAAA,CAAA,CAAA,CACxDA,CAAAA,CAAM,YAAc,MAAA,GAAWC,CAAAA,CAAI,SAAA,CAAY,CAAA,EAAGD,EAAM,SAAS,CAAA,EAAA,CAAA,CAAA,CACjEA,EAAM,WAAA,GAAgB,MAAA,GACxBC,EAAI,WAAA,CAAc,CAAA,EAAGD,EAAM,WAAW,CAAA,EAAA,CAAA,CAAA,CACpCA,EAAM,YAAA,GAAiB,MAAA,GACzBC,EAAI,YAAA,CAAe,CAAA,EAAGD,EAAM,YAAY,CAAA,EAAA,CAAA,CAAA,CACtCA,CAAAA,CAAM,UAAA,GAAe,SAAWC,CAAAA,CAAI,UAAA,CAAa,GAAGD,CAAAA,CAAM,UAAU,MACpEA,CAAAA,CAAM,gBAAA,GAAqB,MAAA,GAC7BC,CAAAA,CAAI,WAAa,CAAA,EAAGD,CAAAA,CAAM,gBAAgB,CAAA,EAAA,CAAA,CAC1CC,CAAAA,CAAI,YAAc,CAAA,EAAGD,CAAAA,CAAM,gBAAgB,CAAA,EAAA,CAAA,CAAA,CAEzCA,EAAM,cAAA,GAAmB,MAAA,GAC3BC,EAAI,SAAA,CAAY,CAAA,EAAGD,EAAM,cAAc,CAAA,EAAA,CAAA,CACvCC,CAAAA,CAAI,YAAA,CAAe,GAAGD,CAAAA,CAAM,cAAc,MAIxCA,CAAAA,CAAM,KAAA,GAAU,SAClBC,CAAAA,CAAI,KAAA,CACF,OAAOD,CAAAA,CAAM,OAAU,QAAA,CAAW,CAAA,EAAGA,EAAM,KAAK,CAAA,EAAA,CAAA,CAAOA,EAAM,KAAA,CAAA,CAC7DA,CAAAA,CAAM,MAAA,GAAW,MAAA,GACnBC,EAAI,MAAA,CACF,OAAOD,EAAM,MAAA,EAAW,QAAA,CAAW,GAAGA,CAAAA,CAAM,MAAM,CAAA,EAAA,CAAA,CAAOA,CAAAA,CAAM,QAC/DA,CAAAA,CAAM,QAAA,GAAa,SAAWC,CAAAA,CAAI,QAAA,CAAW,GAAGD,CAAAA,CAAM,QAAQ,MAC9DA,CAAAA,CAAM,QAAA,GAAa,SAAWC,CAAAA,CAAI,QAAA,CAAW,GAAGD,CAAAA,CAAM,QAAQ,MAC9DA,CAAAA,CAAM,SAAA,GAAc,MAAA,GAAWC,CAAAA,CAAI,UAAY,CAAA,EAAGD,CAAAA,CAAM,SAAS,CAAA,EAAA,CAAA,CAAA,CACjEA,CAAAA,CAAM,YAAc,MAAA,GAAWC,CAAAA,CAAI,SAAA,CAAY,CAAA,EAAGD,EAAM,SAAS,CAAA,EAAA,CAAA,CAAA,CAGjEA,EAAM,eAAA,GAAiBC,CAAAA,CAAI,gBAAkBD,CAAAA,CAAM,eAAA,CAAA,CACnDA,CAAAA,CAAM,YAAA,GAAiB,SACzBC,CAAAA,CAAI,YAAA,CAAe,GAAGD,CAAAA,CAAM,YAAY,MACtCA,CAAAA,CAAM,mBAAA,GAAwB,MAAA,GAChCC,CAAAA,CAAI,oBAAsB,CAAA,EAAGD,CAAAA,CAAM,mBAAmB,CAAA,EAAA,CAAA,CAAA,CACpDA,CAAAA,CAAM,uBAAyB,MAAA,GACjCC,CAAAA,CAAI,oBAAA,CAAuB,CAAA,EAAGD,EAAM,oBAAoB,CAAA,EAAA,CAAA,CAAA,CACtDA,EAAM,sBAAA,GAA2B,MAAA,GACnCC,EAAI,sBAAA,CAAyB,CAAA,EAAGD,CAAAA,CAAM,sBAAsB,MAC1DA,CAAAA,CAAM,uBAAA,GAA4B,SACpCC,CAAAA,CAAI,uBAAA,CAA0B,GAAGD,CAAAA,CAAM,uBAAuB,CAAA,EAAA,CAAA,CAAA,CAC5DA,CAAAA,CAAM,UAAY,MAAA,GAAWC,CAAAA,CAAI,QAAUD,CAAAA,CAAM,OAAA,CAAA,CAGjDA,EAAM,WAAA,GAAgB,MAAA,GACxBC,EAAI,WAAA,CAAc,CAAA,EAAGD,EAAM,WAAW,CAAA,EAAA,CAAA,CAAA,CACpCA,EAAM,WAAA,GAAaC,CAAAA,CAAI,YAAcD,CAAAA,CAAM,WAAA,CAAA,CAC3CA,CAAAA,CAAM,cAAA,GAAmB,SAC3BC,CAAAA,CAAI,cAAA,CAAiB,GAAGD,CAAAA,CAAM,cAAc,MAC1CA,CAAAA,CAAM,gBAAA,GAAqB,MAAA,GAC7BC,CAAAA,CAAI,iBAAmB,CAAA,EAAGD,CAAAA,CAAM,gBAAgB,CAAA,EAAA,CAAA,CAAA,CAC9CA,CAAAA,CAAM,oBAAsB,MAAA,GAC9BC,CAAAA,CAAI,iBAAA,CAAoB,CAAA,EAAGD,EAAM,iBAAiB,CAAA,EAAA,CAAA,CAAA,CAChDA,EAAM,eAAA,GAAoB,MAAA,GAC5BC,EAAI,eAAA,CAAkB,CAAA,EAAGD,CAAAA,CAAM,eAAe,MAG5CA,CAAAA,CAAM,QAAA,GAAUC,EAAI,QAAA,CAAWD,CAAAA,CAAM,UACrCA,CAAAA,CAAM,GAAA,GAAQ,MAAA,GAAWC,CAAAA,CAAI,IAAM,CAAA,EAAGD,CAAAA,CAAM,GAAG,CAAA,EAAA,CAAA,CAAA,CAC/CA,CAAAA,CAAM,QAAU,MAAA,GAAWC,CAAAA,CAAI,KAAA,CAAQ,CAAA,EAAGD,EAAM,KAAK,CAAA,EAAA,CAAA,CAAA,CACrDA,EAAM,MAAA,GAAW,MAAA,GAAWC,EAAI,MAAA,CAAS,CAAA,EAAGD,CAAAA,CAAM,MAAM,MACxDA,CAAAA,CAAM,IAAA,GAAS,SAAWC,CAAAA,CAAI,IAAA,CAAO,GAAGD,CAAAA,CAAM,IAAI,MAClDA,CAAAA,CAAM,MAAA,GAAW,SAAWC,CAAAA,CAAI,MAAA,CAASD,EAAM,MAAA,CAAA,CAG/CA,CAAAA,CAAM,YAAWC,CAAAA,CAAI,SAAA,CAAYD,CAAAA,CAAM,SAAA,CAAA,CAG3C,IAAME,CAAAA,CAAYF,CAAAA,CAClB,OAAIE,CAAAA,CAAU,KAAA,GAAOD,EAAI,KAAA,CAAQC,CAAAA,CAAU,KAAA,CAAA,CACvCA,CAAAA,CAAU,WAAa,MAAA,GAAWD,CAAAA,CAAI,SAAW,CAAA,EAAGC,CAAAA,CAAU,QAAQ,CAAA,EAAA,CAAA,CAAA,CACtEA,CAAAA,CAAU,UAAA,GAAYD,CAAAA,CAAI,WAAaC,CAAAA,CAAU,UAAA,CAAA,CACjDA,EAAU,UAAA,GAAYD,CAAAA,CAAI,WAAaC,CAAAA,CAAU,UAAA,CAAA,CACjDA,CAAAA,CAAU,SAAA,GAAWD,EAAI,SAAA,CAAYC,CAAAA,CAAU,WAC/CA,CAAAA,CAAU,SAAA,GAAWD,EAAI,SAAA,CAAYC,CAAAA,CAAU,SAAA,CAAA,CAC/CA,CAAAA,CAAU,iBAAgBD,CAAAA,CAAI,cAAA,CAAiBC,EAAU,cAAA,CAAA,CACzDA,CAAAA,CAAU,aAAe,MAAA,GAC3BD,CAAAA,CAAI,UAAA,CAAa,CAAA,EAAGC,EAAU,UAAU,CAAA,EAAA,CAAA,CAAA,CACtCA,EAAU,aAAA,GAAkB,MAAA,GAC9BD,EAAI,aAAA,CAAgB,CAAA,EAAGC,CAAAA,CAAU,aAAa,MAEzCD,CACT,CCtHO,SAASE,CAAAA,CAAYC,CAAAA,CAAkD,CAG5E,OAAOD,kBAAAA,CAAaC,CAAK,CAC3B,CAKO,SAASC,CAAAA,CAAgBD,CAAAA,CAA6B,CAE3D,OAAID,CAAAA,CAASC,CAAK,CAAA,CACRA,CAAAA,EAAwB,CAKhCA,CAAAA,GAAU,MACV,OAAOA,CAAAA,EAAU,UACjB,OAAA,GAAWA,CAAAA,EACX,SAAUA,CAAAA,CAEFA,CAAAA,CAAc,KAAA,CAEjBA,CACT,CClBO,SAASE,CAAAA,CACdC,EAEAC,CAAAA,CACAC,CAAAA,CACAC,EACM,CACN,GAAI,CAACF,CAAAA,CAAU,OAEf,IAAMG,CAAAA,CAAa,MAAM,OAAA,CAAQH,CAAQ,EAAIA,CAAAA,CAAW,CAACA,CAAQ,CAAA,CAEjE,QAAWI,CAAAA,IAASD,CAAAA,CAClB,GAAI,EAAA,CAACC,CAAAA,EAAS,CAACA,CAAAA,CAAM,IAAA,CAAA,CAErB,OAAQA,CAAAA,CAAM,MACZ,KAAK,cACHC,CAAAA,CAAWN,CAAAA,CAAKK,EAAM,KAAK,CAAA,CAC3B,MACF,KAAK,gBACHE,CAAAA,CAAaP,CAAAA,CAAKK,EAAM,KAAK,CAAA,CAC7B,MACF,KAAK,aAAA,CACHG,CAAAA,CAAWR,CAAAA,CAAKK,EAAM,KAAK,CAAA,CAC3B,MACF,KAAK,aAAA,CACHI,EAAWT,CAAAA,CAAKK,CAAAA,CAAM,KAAK,CAAA,CAC3B,MACF,KAAK,aAAA,CACHK,CAAAA,CAAWV,EAAKK,CAAAA,CAAM,KAAK,EAC3B,MACF,KAAK,YAAA,CACHM,CAAAA,CAAUX,EAAKK,CAAAA,CAAM,KAAK,EAC1B,KACJ,CAEJ,CAKA,SAASC,CAAAA,CAAWN,CAAAA,CAA+BY,CAAAA,CAA4B,CAC7E,IAAMC,CAAAA,CAAIf,EAAac,CAAAA,CAAM,CAAC,EACxBE,CAAAA,CAAIhB,CAAAA,CAAac,CAAAA,CAAM,CAAC,EACxBG,CAAAA,CAAQjB,CAAAA,CAAac,EAAM,KAAK,CAAA,CAChCI,EAASlB,CAAAA,CAAac,CAAAA,CAAM,MAAM,CAAA,CAClCK,CAAAA,CAAOnB,EAAac,CAAAA,CAAM,IAAI,EAC9BM,CAAAA,CAASpB,CAAAA,CAAac,EAAM,MAAM,CAAA,CAClCO,CAAAA,CAAcrB,CAAAA,CAAac,EAAM,WAAW,CAAA,CAC5CQ,EAAUtB,CAAAA,CAAac,CAAAA,CAAM,OAAO,CAAA,CAE1CZ,CAAAA,CAAI,IAAA,EAAK,CAELoB,IAAY,MAAA,GACdpB,CAAAA,CAAI,YAAcoB,CAAAA,CAAAA,CAGhBH,CAAAA,GACFjB,EAAI,SAAA,CAAYiB,CAAAA,CAChBjB,CAAAA,CAAI,QAAA,CAASa,EAAGC,CAAAA,CAAGC,CAAAA,CAAOC,CAAM,CAAA,CAAA,CAG9BE,CAAAA,GACFlB,EAAI,WAAA,CAAckB,CAAAA,CAClBlB,EAAI,SAAA,CAAYmB,CAAAA,EAAe,EAC/BnB,CAAAA,CAAI,UAAA,CAAWa,EAAGC,CAAAA,CAAGC,CAAAA,CAAOC,CAAM,CAAA,CAAA,CAGpChB,CAAAA,CAAI,OAAA,GACN,CAKA,SAASO,CAAAA,CACPP,EACAY,CAAAA,CACM,CACN,IAAMC,CAAAA,CAAIf,CAAAA,CAAac,CAAAA,CAAM,CAAC,EACxBE,CAAAA,CAAIhB,CAAAA,CAAac,EAAM,CAAC,CAAA,CACxBS,EAASvB,CAAAA,CAAac,CAAAA,CAAM,MAAM,CAAA,CAClCK,EAAOnB,CAAAA,CAAac,CAAAA,CAAM,IAAI,CAAA,CAC9BM,CAAAA,CAASpB,EAAac,CAAAA,CAAM,MAAM,CAAA,CAClCO,CAAAA,CAAcrB,EAAac,CAAAA,CAAM,WAAW,EAC5CQ,CAAAA,CAAUtB,CAAAA,CAAac,EAAM,OAAO,CAAA,CAE1CZ,CAAAA,CAAI,IAAA,GAEAoB,CAAAA,GAAY,MAAA,GACdpB,EAAI,WAAA,CAAcoB,CAAAA,CAAAA,CAGpBpB,EAAI,SAAA,EAAU,CACdA,CAAAA,CAAI,GAAA,CAAIa,EAAGC,CAAAA,CAAGO,CAAAA,CAAQ,EAAG,CAAA,CAAI,IAAA,CAAK,EAAE,CAAA,CAEhCJ,CAAAA,GACFjB,CAAAA,CAAI,SAAA,CAAYiB,EAChBjB,CAAAA,CAAI,IAAA,IAGFkB,CAAAA,GACFlB,CAAAA,CAAI,YAAckB,CAAAA,CAClBlB,CAAAA,CAAI,UAAYmB,CAAAA,EAAe,CAAA,CAC/BnB,EAAI,MAAA,EAAO,CAAA,CAGbA,EAAI,OAAA,GACN,CAKA,SAASQ,CAAAA,CAAWR,CAAAA,CAA+BY,CAAAA,CAA4B,CAC7E,IAAMU,CAAAA,CAAIxB,EAAac,CAAAA,CAAM,CAAC,EACxBK,CAAAA,CAAOnB,CAAAA,CAAac,CAAAA,CAAM,IAAI,EAC9BM,CAAAA,CAASpB,CAAAA,CAAac,EAAM,MAAM,CAAA,CAClCO,EAAcrB,CAAAA,CAAac,CAAAA,CAAM,WAAW,CAAA,CAC5CQ,EAAUtB,CAAAA,CAAac,CAAAA,CAAM,OAAO,CAAA,CAE1CZ,CAAAA,CAAI,MAAK,CAELoB,CAAAA,GAAY,MAAA,GACdpB,CAAAA,CAAI,YAAcoB,CAAAA,CAAAA,CAIpB,IAAMG,EAAO,IAAI,MAAA,CAAOD,CAAC,CAAA,CAErBL,CAAAA,GACFjB,CAAAA,CAAI,SAAA,CAAYiB,EAChBjB,CAAAA,CAAI,IAAA,CAAKuB,CAAI,CAAA,CAAA,CAGXL,CAAAA,GACFlB,EAAI,WAAA,CAAckB,CAAAA,CAClBlB,CAAAA,CAAI,SAAA,CAAYmB,GAAe,CAAA,CAC/BnB,CAAAA,CAAI,OAAOuB,CAAI,CAAA,CAAA,CAGjBvB,EAAI,OAAA,GACN,CAKA,SAASS,EAAWT,CAAAA,CAA+BY,CAAAA,CAA4B,CAC7E,IAAMC,CAAAA,CAAIf,EAAac,CAAAA,CAAM,CAAC,EACxBE,CAAAA,CAAIhB,CAAAA,CAAac,EAAM,CAAC,CAAA,CACxBY,EAAO1B,CAAAA,CAAac,CAAAA,CAAM,IAAI,CAAA,CAC9BK,CAAAA,CAAOnB,CAAAA,CAAac,CAAAA,CAAM,IAAI,CAAA,CAC9Ba,CAAAA,CAAW3B,EAAac,CAAAA,CAAM,QAAQ,GAAK,EAAA,CAC3Cc,CAAAA,CAAa5B,CAAAA,CAAac,CAAAA,CAAM,UAAU,CAAA,EAAK,YAAA,CAC/Ce,EAAa7B,CAAAA,CAAac,CAAAA,CAAM,UAAU,CAAA,EAAK,QAAA,CAC/CgB,CAAAA,CAAY9B,CAAAA,CAAac,EAAM,SAAS,CAAA,EAAK,OAC7CiB,CAAAA,CAAe/B,CAAAA,CAAac,EAAM,YAAY,CAAA,EAAK,YAAA,CAEzDZ,CAAAA,CAAI,MAAK,CAETA,CAAAA,CAAI,KAAO,CAAA,EAAG2B,CAAU,IAAIF,CAAQ,CAAA,GAAA,EAAMC,CAAU,CAAA,CAAA,CACpD1B,EAAI,SAAA,CAAY4B,CAAAA,CAChB5B,EAAI,YAAA,CAAe6B,CAAAA,CAEfZ,IACFjB,CAAAA,CAAI,SAAA,CAAYiB,CAAAA,CAChBjB,CAAAA,CAAI,SAASwB,CAAAA,CAAMX,CAAAA,CAAGC,CAAC,CAAA,CAAA,CAGzBd,CAAAA,CAAI,UACN,CAKA,SAASU,CAAAA,CAAWV,EAA+BY,CAAAA,CAA4B,CAC7E,IAAMkB,CAAAA,CAAKhC,CAAAA,CAAac,EAAM,EAAE,CAAA,CAC1BmB,EAAKjC,CAAAA,CAAac,CAAAA,CAAM,EAAE,CAAA,CAC1BoB,CAAAA,CAAKlC,EAAac,CAAAA,CAAM,EAAE,EAC1BqB,CAAAA,CAAKnC,CAAAA,CAAac,CAAAA,CAAM,EAAE,EAC1BM,CAAAA,CAASpB,CAAAA,CAAac,EAAM,MAAM,CAAA,EAAK,QACvCO,CAAAA,CAAcrB,CAAAA,CAAac,CAAAA,CAAM,WAAW,GAAK,CAAA,CACjDQ,CAAAA,CAAUtB,EAAac,CAAAA,CAAM,OAAO,EAE1CZ,CAAAA,CAAI,IAAA,EAAK,CAELoB,CAAAA,GAAY,SACdpB,CAAAA,CAAI,WAAA,CAAcoB,GAGpBpB,CAAAA,CAAI,SAAA,GACJA,CAAAA,CAAI,MAAA,CAAO8B,EAAIC,CAAE,CAAA,CACjB/B,EAAI,MAAA,CAAOgC,CAAAA,CAAIC,CAAE,CAAA,CAEjBjC,CAAAA,CAAI,YAAckB,CAAAA,CAClBlB,CAAAA,CAAI,SAAA,CAAYmB,CAAAA,CAChBnB,EAAI,MAAA,EAAO,CAEXA,EAAI,OAAA,GACN,CAKA,SAASW,CAAAA,CAAUX,CAAAA,CAA+BY,CAAAA,CAA2B,CAC3E,IAAMC,CAAAA,CAAIf,EAAac,CAAAA,CAAM,CAAC,EACxBE,CAAAA,CAAIhB,CAAAA,CAAac,CAAAA,CAAM,CAAC,EACxBS,CAAAA,CAASvB,CAAAA,CAAac,EAAM,MAAM,CAAA,CAClCsB,EAAapC,CAAAA,CAAac,CAAAA,CAAM,UAAU,CAAA,CAC1CuB,CAAAA,CAAWrC,EAAac,CAAAA,CAAM,QAAQ,EACtCwB,CAAAA,CAAmBtC,CAAAA,CAAac,EAAM,gBAAgB,CAAA,EAAK,KAAA,CAC3DK,CAAAA,CAAOnB,EAAac,CAAAA,CAAM,IAAI,EAC9BM,CAAAA,CAASpB,CAAAA,CAAac,EAAM,MAAM,CAAA,CAClCO,CAAAA,CAAcrB,CAAAA,CAAac,EAAM,WAAW,CAAA,CAC5CQ,EAAUtB,CAAAA,CAAac,CAAAA,CAAM,OAAO,CAAA,CAE1CZ,CAAAA,CAAI,IAAA,EAAK,CAELoB,IAAY,MAAA,GACdpB,CAAAA,CAAI,YAAcoB,CAAAA,CAAAA,CAGpBpB,CAAAA,CAAI,WAAU,CACdA,CAAAA,CAAI,GAAA,CAAIa,CAAAA,CAAGC,EAAGO,CAAAA,CAAQa,CAAAA,CAAYC,EAAUC,CAAgB,CAAA,CAExDnB,IACFjB,CAAAA,CAAI,SAAA,CAAYiB,CAAAA,CAChBjB,CAAAA,CAAI,MAAK,CAAA,CAGPkB,CAAAA,GACFlB,EAAI,WAAA,CAAckB,CAAAA,CAClBlB,EAAI,SAAA,CAAYmB,CAAAA,EAAe,CAAA,CAC/BnB,CAAAA,CAAI,QAAO,CAAA,CAGbA,CAAAA,CAAI,UACN,CCtOO,SAASqC,CAAAA,CAAOzB,CAAAA,CAA2B,CAChD,GAAM,CAAE,KAAA,CAAAG,CAAAA,CAAO,OAAAC,CAAAA,CAAQ,QAAA,CAAAf,EAAU,KAAA,CAAAR,CAAAA,CAAO,GAAA6C,CAAAA,CAAI,GAAGC,CAAK,CAAA,CAAI3B,CAAAA,CAExD,OAAO,CACL,IAAA,CAAM,SACN,KAAA,CAAO,CACL,GAAG2B,CAAAA,CACH,GAAAD,CAAAA,CACA,KAAA,CAAAvB,EACA,MAAA,CAAAC,CAAAA,CACA,MAAOxB,CAAAA,CAAeC,CAAK,CAAA,CAE3B,GAAA,CAAM+C,GAAqC,CAIzC,GAHI,CAACA,CAAAA,EAGD,OAAO,sBAA0B,GAAA,CAAa,OAElD,IAAMxC,CAAAA,CAAMwC,EAAO,UAAA,CAAW,IAAI,EAC7BxC,CAAAA,EAIL,OAAA,CAAQ,IAAI,CACV,OAAO,sBAAmB,CAAA,CAAE,KAAKyC,CAAAA,GAAM,CAAE,OAAQA,CAAAA,CAAE,MAAA,CAAQ,UAAWA,CAAAA,CAAE,SAAU,CAAA,CAAE,CAAA,CACpF,OAAO,qBAAkB,CAAA,CAAE,KAAKA,CAAAA,GAAM,CAAE,SAAUA,CAAAA,CAAE,QAAS,CAAA,CAAE,CACjE,CAAC,CAAA,CACE,IAAA,CAAK,CAAC,CAAC,CAAE,OAAAC,CAAAA,CAAQ,SAAA,CAAAC,CAAU,CAAA,CAAG,CAAE,QAAA,CAAA/C,CAAS,CAAC,CAAA,GAAM,CAC/C,IAAIgD,CAAAA,CAEEC,CAAAA,CAAiB,IAAM,CACvBD,CAAAA,GAAU,QACZ,oBAAA,CAAqBA,CAAK,EAG5BA,CAAAA,CAAQ,qBAAA,CAAsB,IAAM,CAElC5C,CAAAA,CAAI,SAAA,CAAU,CAAA,CAAG,EAAGe,CAAAA,CAAOC,CAAM,EAGjCjB,CAAAA,CAAqBC,CAAAA,CAAKC,CAAuB,CAAA,CAEjD2C,CAAAA,CAAQ,OACV,CAAC,EACH,EAEAF,CAAAA,CAAO,IAAM,CAGX,IAAMtC,CAAAA,CAAa,KAAA,CAAM,OAAA,CAAQH,CAAQ,CAAA,CAAIA,CAAAA,CAAW,CAACA,CAAQ,CAAA,CACjE,QAAWI,CAAAA,IAASD,CAAAA,CAClB,GAAIC,CAAAA,EAASA,EAAM,KAAA,CAEjB,IAAA,IAAWyC,KAAOzC,CAAAA,CAAM,KAAA,CAAO,CAC7B,IAAMR,CAAAA,CAAQQ,CAAAA,CAAM,KAAA,CAAMyC,CAAG,CAAA,CAEzBlD,CAAAA,CAASC,CAAK,CAAA,EACVA,CAAAA,GAEV,CAKJgD,CAAAA,EAAe,CAGfF,CAAAA,CAAU,IAAM,CACVC,CAAAA,GAAU,SACZ,oBAAA,CAAqBA,CAAK,EAC1BA,CAAAA,CAAQ,MAAA,EAEZ,CAAC,EACH,CAAC,EACH,CAAC,EACA,KAAA,CAAOG,CAAAA,EAAQ,CACd,OAAA,CAAQ,KAAA,CAAM,iDAAkDA,CAAG,EACrE,CAAC,EACL,CACF,EACA,QAAA,CAAU,EACZ,CACF,CC3FO,SAASC,CAAAA,CAASpC,EAA6B,CACpD,OAAO,CACL,IAAA,CAAM,aAAA,CACN,MAAAA,CAAAA,CACA,QAAA,CAAU,EACZ,CACF,CCNO,SAASqC,EAAWrC,CAAAA,CAA+B,CACxD,OAAO,CACL,IAAA,CAAM,eAAA,CACN,KAAA,CAAAA,EACA,QAAA,CAAU,EACZ,CACF,CCNO,SAASsC,CAAAA,CAAQtC,CAAAA,CAA4B,CAClD,OAAO,CACL,KAAM,YAAA,CACN,KAAA,CAAAA,EACA,QAAA,CAAU,EACZ,CACF,CCNO,SAASuC,CAAAA,CAASvC,EAA6B,CACpD,OAAO,CACL,IAAA,CAAM,aAAA,CACN,MAAAA,CAAAA,CACA,QAAA,CAAU,EACZ,CACF,CCNO,SAASwC,EAASxC,CAAAA,CAA6B,CACpD,OAAO,CACL,IAAA,CAAM,aAAA,CACN,KAAA,CAAAA,EACA,QAAA,CAAU,EACZ,CACF,CCNO,SAASyC,CAAAA,CAASzC,CAAAA,CAA6B,CACpD,OAAO,CACL,KAAM,aAAA,CACN,KAAA,CAAAA,EACA,QAAA,CAAU,EACZ,CACF","file":"chunk-QPCIDSMM.js","sourcesContent":["/**\n * Primitive utilities\n */\n\nimport type { CommonStyle, TextStyle } from './types'\n\n/**\n * Normalize CommonStyle to CSS properties\n */\nexport function normalizeStyle(\n style?: CommonStyle | TextStyle\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): Record<string, any> {\n if (!style) return {}\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const css: Record<string, any> = {}\n\n // Layout\n if (style.display) css.display = style.display\n if (style.flex !== undefined) css.flex = style.flex\n if (style.flexDirection) css.flexDirection = style.flexDirection\n if (style.flexWrap) css.flexWrap = style.flexWrap\n if (style.justifyContent) css.justifyContent = style.justifyContent\n if (style.alignItems) css.alignItems = style.alignItems\n if (style.alignSelf) css.alignSelf = style.alignSelf\n if (style.gap !== undefined) css.gap = `${style.gap}px`\n\n // Spacing - padding\n if (style.padding !== undefined) css.padding = `${style.padding}px`\n if (style.paddingTop !== undefined) css.paddingTop = `${style.paddingTop}px`\n if (style.paddingRight !== undefined)\n css.paddingRight = `${style.paddingRight}px`\n if (style.paddingBottom !== undefined)\n css.paddingBottom = `${style.paddingBottom}px`\n if (style.paddingLeft !== undefined)\n css.paddingLeft = `${style.paddingLeft}px`\n if (style.paddingHorizontal !== undefined) {\n css.paddingLeft = `${style.paddingHorizontal}px`\n css.paddingRight = `${style.paddingHorizontal}px`\n }\n if (style.paddingVertical !== undefined) {\n css.paddingTop = `${style.paddingVertical}px`\n css.paddingBottom = `${style.paddingVertical}px`\n }\n\n // Spacing - margin\n if (style.margin !== undefined) css.margin = `${style.margin}px`\n if (style.marginTop !== undefined) css.marginTop = `${style.marginTop}px`\n if (style.marginRight !== undefined)\n css.marginRight = `${style.marginRight}px`\n if (style.marginBottom !== undefined)\n css.marginBottom = `${style.marginBottom}px`\n if (style.marginLeft !== undefined) css.marginLeft = `${style.marginLeft}px`\n if (style.marginHorizontal !== undefined) {\n css.marginLeft = `${style.marginHorizontal}px`\n css.marginRight = `${style.marginHorizontal}px`\n }\n if (style.marginVertical !== undefined) {\n css.marginTop = `${style.marginVertical}px`\n css.marginBottom = `${style.marginVertical}px`\n }\n\n // Sizing\n if (style.width !== undefined)\n css.width =\n typeof style.width === 'number' ? `${style.width}px` : style.width\n if (style.height !== undefined)\n css.height =\n typeof style.height === 'number' ? `${style.height}px` : style.height\n if (style.minWidth !== undefined) css.minWidth = `${style.minWidth}px`\n if (style.maxWidth !== undefined) css.maxWidth = `${style.maxWidth}px`\n if (style.minHeight !== undefined) css.minHeight = `${style.minHeight}px`\n if (style.maxHeight !== undefined) css.maxHeight = `${style.maxHeight}px`\n\n // Visual\n if (style.backgroundColor) css.backgroundColor = style.backgroundColor\n if (style.borderRadius !== undefined)\n css.borderRadius = `${style.borderRadius}px`\n if (style.borderTopLeftRadius !== undefined)\n css.borderTopLeftRadius = `${style.borderTopLeftRadius}px`\n if (style.borderTopRightRadius !== undefined)\n css.borderTopRightRadius = `${style.borderTopRightRadius}px`\n if (style.borderBottomLeftRadius !== undefined)\n css.borderBottomLeftRadius = `${style.borderBottomLeftRadius}px`\n if (style.borderBottomRightRadius !== undefined)\n css.borderBottomRightRadius = `${style.borderBottomRightRadius}px`\n if (style.opacity !== undefined) css.opacity = style.opacity\n\n // Border\n if (style.borderWidth !== undefined)\n css.borderWidth = `${style.borderWidth}px`\n if (style.borderColor) css.borderColor = style.borderColor\n if (style.borderTopWidth !== undefined)\n css.borderTopWidth = `${style.borderTopWidth}px`\n if (style.borderRightWidth !== undefined)\n css.borderRightWidth = `${style.borderRightWidth}px`\n if (style.borderBottomWidth !== undefined)\n css.borderBottomWidth = `${style.borderBottomWidth}px`\n if (style.borderLeftWidth !== undefined)\n css.borderLeftWidth = `${style.borderLeftWidth}px`\n\n // Position\n if (style.position) css.position = style.position\n if (style.top !== undefined) css.top = `${style.top}px`\n if (style.right !== undefined) css.right = `${style.right}px`\n if (style.bottom !== undefined) css.bottom = `${style.bottom}px`\n if (style.left !== undefined) css.left = `${style.left}px`\n if (style.zIndex !== undefined) css.zIndex = style.zIndex\n\n // Transform\n if (style.transform) css.transform = style.transform\n\n // Text-specific (if TextStyle)\n const textStyle = style as TextStyle\n if (textStyle.color) css.color = textStyle.color\n if (textStyle.fontSize !== undefined) css.fontSize = `${textStyle.fontSize}px`\n if (textStyle.fontWeight) css.fontWeight = textStyle.fontWeight\n if (textStyle.fontFamily) css.fontFamily = textStyle.fontFamily\n if (textStyle.fontStyle) css.fontStyle = textStyle.fontStyle\n if (textStyle.textAlign) css.textAlign = textStyle.textAlign\n if (textStyle.textDecoration) css.textDecoration = textStyle.textDecoration\n if (textStyle.lineHeight !== undefined)\n css.lineHeight = `${textStyle.lineHeight}px`\n if (textStyle.letterSpacing !== undefined)\n css.letterSpacing = `${textStyle.letterSpacing}px`\n\n return css\n}\n","/**\n * Canvas utilities\n */\n\nimport { isSignal as coreIsSignal } from '../../core/state'\nimport type { StateValue } from '../../core/state'\n\n/**\n * Check if a value is a Signal\n */\nexport function isSignal<T>(value: T | StateValue<T>): value is StateValue<T> {\n // Use core isSignal which checks for SIGNAL_MARKER symbol\n // Signals are functions with properties, not plain objects\n return coreIsSignal(value)\n}\n\n/**\n * Unwrap a value that might be a Signal\n */\nexport function unwrapSignal<T>(value: T | StateValue<T>): T {\n // Check for real signals first (have STATE_SIGNAL)\n if (isSignal(value)) {\n return (value as StateValue<T>)()\n }\n // Handle signal-like objects (for testing) - duck typing\n // Check if it's an object with a 'value' property\n if (\n value !== null &&\n typeof value === 'object' &&\n 'value' in value &&\n 'peek' in value\n ) {\n return (value as any).value\n }\n return value\n}\n","/**\n * Canvas renderer - renders canvas primitives to canvas context\n */\n\nimport type {\n DrawRectProps,\n DrawCircleProps,\n DrawPathProps,\n DrawTextProps,\n DrawLineProps,\n DrawArcProps,\n} from '../types'\nimport { unwrapSignal } from './utils'\n\n/**\n * Render canvas children to context\n */\nexport function renderCanvasChildren(\n ctx: CanvasRenderingContext2D,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n children: any,\n _width: number,\n _height: number\n): void {\n if (!children) return\n\n const childArray = Array.isArray(children) ? children : [children]\n\n for (const child of childArray) {\n if (!child || !child.type) continue\n\n switch (child.type) {\n case 'canvas-rect':\n renderRect(ctx, child.props)\n break\n case 'canvas-circle':\n renderCircle(ctx, child.props)\n break\n case 'canvas-path':\n renderPath(ctx, child.props)\n break\n case 'canvas-text':\n renderText(ctx, child.props)\n break\n case 'canvas-line':\n renderLine(ctx, child.props)\n break\n case 'canvas-arc':\n renderArc(ctx, child.props)\n break\n }\n }\n}\n\n/**\n * Render rectangle\n */\nfunction renderRect(ctx: CanvasRenderingContext2D, props: DrawRectProps): void {\n const x = unwrapSignal(props.x)\n const y = unwrapSignal(props.y)\n const width = unwrapSignal(props.width)\n const height = unwrapSignal(props.height)\n const fill = unwrapSignal(props.fill)\n const stroke = unwrapSignal(props.stroke)\n const strokeWidth = unwrapSignal(props.strokeWidth)\n const opacity = unwrapSignal(props.opacity)\n\n ctx.save()\n\n if (opacity !== undefined) {\n ctx.globalAlpha = opacity\n }\n\n if (fill) {\n ctx.fillStyle = fill\n ctx.fillRect(x, y, width, height)\n }\n\n if (stroke) {\n ctx.strokeStyle = stroke\n ctx.lineWidth = strokeWidth || 1\n ctx.strokeRect(x, y, width, height)\n }\n\n ctx.restore()\n}\n\n/**\n * Render circle\n */\nfunction renderCircle(\n ctx: CanvasRenderingContext2D,\n props: DrawCircleProps\n): void {\n const x = unwrapSignal(props.x)\n const y = unwrapSignal(props.y)\n const radius = unwrapSignal(props.radius)\n const fill = unwrapSignal(props.fill)\n const stroke = unwrapSignal(props.stroke)\n const strokeWidth = unwrapSignal(props.strokeWidth)\n const opacity = unwrapSignal(props.opacity)\n\n ctx.save()\n\n if (opacity !== undefined) {\n ctx.globalAlpha = opacity\n }\n\n ctx.beginPath()\n ctx.arc(x, y, radius, 0, 2 * Math.PI)\n\n if (fill) {\n ctx.fillStyle = fill\n ctx.fill()\n }\n\n if (stroke) {\n ctx.strokeStyle = stroke\n ctx.lineWidth = strokeWidth || 1\n ctx.stroke()\n }\n\n ctx.restore()\n}\n\n/**\n * Render path\n */\nfunction renderPath(ctx: CanvasRenderingContext2D, props: DrawPathProps): void {\n const d = unwrapSignal(props.d)\n const fill = unwrapSignal(props.fill)\n const stroke = unwrapSignal(props.stroke)\n const strokeWidth = unwrapSignal(props.strokeWidth)\n const opacity = unwrapSignal(props.opacity)\n\n ctx.save()\n\n if (opacity !== undefined) {\n ctx.globalAlpha = opacity\n }\n\n // Parse SVG path (simplified - only supports basic commands)\n const path = new Path2D(d)\n\n if (fill) {\n ctx.fillStyle = fill\n ctx.fill(path)\n }\n\n if (stroke) {\n ctx.strokeStyle = stroke\n ctx.lineWidth = strokeWidth || 1\n ctx.stroke(path)\n }\n\n ctx.restore()\n}\n\n/**\n * Render text\n */\nfunction renderText(ctx: CanvasRenderingContext2D, props: DrawTextProps): void {\n const x = unwrapSignal(props.x)\n const y = unwrapSignal(props.y)\n const text = unwrapSignal(props.text)\n const fill = unwrapSignal(props.fill)\n const fontSize = unwrapSignal(props.fontSize) || 12\n const fontFamily = unwrapSignal(props.fontFamily) || 'sans-serif'\n const fontWeight = unwrapSignal(props.fontWeight) || 'normal'\n const textAlign = unwrapSignal(props.textAlign) || 'left'\n const textBaseline = unwrapSignal(props.textBaseline) || 'alphabetic'\n\n ctx.save()\n\n ctx.font = `${fontWeight} ${fontSize}px ${fontFamily}`\n ctx.textAlign = textAlign\n ctx.textBaseline = textBaseline\n\n if (fill) {\n ctx.fillStyle = fill\n ctx.fillText(text, x, y)\n }\n\n ctx.restore()\n}\n\n/**\n * Render line\n */\nfunction renderLine(ctx: CanvasRenderingContext2D, props: DrawLineProps): void {\n const x1 = unwrapSignal(props.x1)\n const y1 = unwrapSignal(props.y1)\n const x2 = unwrapSignal(props.x2)\n const y2 = unwrapSignal(props.y2)\n const stroke = unwrapSignal(props.stroke) || 'black'\n const strokeWidth = unwrapSignal(props.strokeWidth) || 1\n const opacity = unwrapSignal(props.opacity)\n\n ctx.save()\n\n if (opacity !== undefined) {\n ctx.globalAlpha = opacity\n }\n\n ctx.beginPath()\n ctx.moveTo(x1, y1)\n ctx.lineTo(x2, y2)\n\n ctx.strokeStyle = stroke\n ctx.lineWidth = strokeWidth\n ctx.stroke()\n\n ctx.restore()\n}\n\n/**\n * Render arc\n */\nfunction renderArc(ctx: CanvasRenderingContext2D, props: DrawArcProps): void {\n const x = unwrapSignal(props.x)\n const y = unwrapSignal(props.y)\n const radius = unwrapSignal(props.radius)\n const startAngle = unwrapSignal(props.startAngle)\n const endAngle = unwrapSignal(props.endAngle)\n const counterclockwise = unwrapSignal(props.counterclockwise) || false\n const fill = unwrapSignal(props.fill)\n const stroke = unwrapSignal(props.stroke)\n const strokeWidth = unwrapSignal(props.strokeWidth)\n const opacity = unwrapSignal(props.opacity)\n\n ctx.save()\n\n if (opacity !== undefined) {\n ctx.globalAlpha = opacity\n }\n\n ctx.beginPath()\n ctx.arc(x, y, radius, startAngle, endAngle, counterclockwise)\n\n if (fill) {\n ctx.fillStyle = fill\n ctx.fill()\n }\n\n if (stroke) {\n ctx.strokeStyle = stroke\n ctx.lineWidth = strokeWidth || 1\n ctx.stroke()\n }\n\n ctx.restore()\n}\n","/**\n * Canvas - Declarative canvas container with JSX drawing\n *\n * Supports Signal-based reactive rendering\n *\n * @example\n * ```tsx\n * const x = signal(50)\n *\n * <Canvas width={300} height={200}>\n * <Rect x={x} y={50} width={100} height={50} fill=\"blue\" />\n * <Circle x={150} y={100} radius={30} fill=\"red\" />\n * </Canvas>\n * ```\n */\n\nimport type { FNode } from '../../types'\nimport type { CanvasProps } from '../types'\nimport { normalizeStyle } from '../utils'\nimport { renderCanvasChildren } from './renderer'\n\nexport function Canvas(props: CanvasProps): FNode {\n const { width, height, children, style, id, ...rest } = props\n\n return {\n type: 'canvas',\n props: {\n ...rest,\n id,\n width,\n height,\n style: normalizeStyle(style),\n // Attach canvas renderer when element is mounted\n ref: (canvas: HTMLCanvasElement | null) => {\n if (!canvas) return\n\n // SSR guard: skip canvas rendering on server\n if (typeof requestAnimationFrame === 'undefined') return\n\n const ctx = canvas.getContext('2d')\n if (!ctx) return\n\n // Check if effect is available before trying to import\n // Import effect and onCleanup dynamically to avoid circular deps\n Promise.all([\n import('../../core/effect').then(m => ({ effect: m.effect, onCleanup: m.onCleanup })),\n import('../../core/state').then(m => ({ isSignal: m.isSignal }))\n ])\n .then(([{ effect, onCleanup }, { isSignal }]) => {\n let rafId: number | undefined\n\n const scheduleRender = () => {\n if (rafId !== undefined) {\n cancelAnimationFrame(rafId)\n }\n\n rafId = requestAnimationFrame(() => {\n // Clear canvas\n ctx.clearRect(0, 0, width, height)\n\n // Render all children\n renderCanvasChildren(ctx, children, width, height)\n\n rafId = undefined\n })\n }\n\n effect(() => {\n // To track signal dependencies, we need to access them in the effect\n // Walk through children and touch any signals to track dependencies\n const childArray = Array.isArray(children) ? children : [children]\n for (const child of childArray) {\n if (child && child.props) {\n // Touch each prop to track signal dependencies\n for (const key in child.props) {\n const value = child.props[key]\n // If it's a signal, access its value to track it\n if (isSignal(value)) {\n void (value as any)() // Touch the signal to track dependency\n }\n }\n }\n }\n\n // Now schedule the actual render\n scheduleRender()\n\n // Cleanup RAF when effect is disposed\n onCleanup(() => {\n if (rafId !== undefined) {\n cancelAnimationFrame(rafId)\n rafId = undefined\n }\n })\n })\n })\n .catch((err) => {\n console.error('[Flexium Canvas] Failed to load signal module:', err)\n })\n },\n },\n children: [],\n }\n}\n","/**\n * DrawRect - Canvas rectangle primitive\n *\n * @example\n * ```tsx\n * <DrawRect x={10} y={10} width={100} height={50} fill=\"blue\" />\n * ```\n */\n\nimport type { FNode } from '../../types'\nimport type { DrawRectProps } from '../types'\n\nexport function DrawRect(props: DrawRectProps): FNode {\n return {\n type: 'canvas-rect',\n props,\n children: [],\n }\n}\n","/**\n * DrawCircle - Canvas circle primitive\n *\n * @example\n * ```tsx\n * <DrawCircle x={100} y={100} radius={50} fill=\"red\" />\n * ```\n */\n\nimport type { FNode } from '../../types'\nimport type { DrawCircleProps } from '../types'\n\nexport function DrawCircle(props: DrawCircleProps): FNode {\n return {\n type: 'canvas-circle',\n props,\n children: [],\n }\n}\n","/**\n * DrawArc - Canvas arc primitive\n *\n * @example\n * ```tsx\n * <DrawArc x={100} y={100} radius={50} startAngle={0} endAngle={Math.PI} fill=\"green\" />\n * ```\n */\n\nimport type { FNode } from '../../types'\nimport type { DrawArcProps } from '../types'\n\nexport function DrawArc(props: DrawArcProps): FNode {\n return {\n type: 'canvas-arc',\n props,\n children: [],\n }\n}\n","/**\n * DrawLine - Canvas line primitive\n *\n * @example\n * ```tsx\n * <DrawLine x1={10} y1={10} x2={100} y2={100} stroke=\"black\" strokeWidth={2} />\n * ```\n */\n\nimport type { FNode } from '../../types'\nimport type { DrawLineProps } from '../types'\n\nexport function DrawLine(props: DrawLineProps): FNode {\n return {\n type: 'canvas-line',\n props,\n children: [],\n }\n}\n","/**\n * DrawPath - Canvas path primitive\n *\n * @example\n * ```tsx\n * <DrawPath d=\"M 10 10 L 100 100\" stroke=\"black\" strokeWidth={2} />\n * ```\n */\n\nimport type { FNode } from '../../types'\nimport type { DrawPathProps } from '../types'\n\nexport function DrawPath(props: DrawPathProps): FNode {\n return {\n type: 'canvas-path',\n props,\n children: [],\n }\n}\n","/**\n * DrawText - Canvas text primitive\n *\n * @example\n * ```tsx\n * <DrawText x={50} y={50} text=\"Hello Canvas\" fontSize={20} fill=\"black\" />\n * ```\n */\n\nimport type { FNode } from '../../types'\nimport type { DrawTextProps } from '../types'\n\nexport function DrawText(props: DrawTextProps): FNode {\n return {\n type: 'canvas-text',\n props,\n children: [],\n }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import {g}from'./chunk-BBNYMXE7.mjs';function x(i){if(!i)return {};let e={};i.display&&(e.display=i.display),i.flex!==void 0&&(e.flex=i.flex),i.flexDirection&&(e.flexDirection=i.flexDirection),i.flexWrap&&(e.flexWrap=i.flexWrap),i.justifyContent&&(e.justifyContent=i.justifyContent),i.alignItems&&(e.alignItems=i.alignItems),i.alignSelf&&(e.alignSelf=i.alignSelf),i.gap!==void 0&&(e.gap=`${i.gap}px`),i.padding!==void 0&&(e.padding=`${i.padding}px`),i.paddingTop!==void 0&&(e.paddingTop=`${i.paddingTop}px`),i.paddingRight!==void 0&&(e.paddingRight=`${i.paddingRight}px`),i.paddingBottom!==void 0&&(e.paddingBottom=`${i.paddingBottom}px`),i.paddingLeft!==void 0&&(e.paddingLeft=`${i.paddingLeft}px`),i.paddingHorizontal!==void 0&&(e.paddingLeft=`${i.paddingHorizontal}px`,e.paddingRight=`${i.paddingHorizontal}px`),i.paddingVertical!==void 0&&(e.paddingTop=`${i.paddingVertical}px`,e.paddingBottom=`${i.paddingVertical}px`),i.margin!==void 0&&(e.margin=`${i.margin}px`),i.marginTop!==void 0&&(e.marginTop=`${i.marginTop}px`),i.marginRight!==void 0&&(e.marginRight=`${i.marginRight}px`),i.marginBottom!==void 0&&(e.marginBottom=`${i.marginBottom}px`),i.marginLeft!==void 0&&(e.marginLeft=`${i.marginLeft}px`),i.marginHorizontal!==void 0&&(e.marginLeft=`${i.marginHorizontal}px`,e.marginRight=`${i.marginHorizontal}px`),i.marginVertical!==void 0&&(e.marginTop=`${i.marginVertical}px`,e.marginBottom=`${i.marginVertical}px`),i.width!==void 0&&(e.width=typeof i.width=="number"?`${i.width}px`:i.width),i.height!==void 0&&(e.height=typeof i.height=="number"?`${i.height}px`:i.height),i.minWidth!==void 0&&(e.minWidth=`${i.minWidth}px`),i.maxWidth!==void 0&&(e.maxWidth=`${i.maxWidth}px`),i.minHeight!==void 0&&(e.minHeight=`${i.minHeight}px`),i.maxHeight!==void 0&&(e.maxHeight=`${i.maxHeight}px`),i.backgroundColor&&(e.backgroundColor=i.backgroundColor),i.borderRadius!==void 0&&(e.borderRadius=`${i.borderRadius}px`),i.borderTopLeftRadius!==void 0&&(e.borderTopLeftRadius=`${i.borderTopLeftRadius}px`),i.borderTopRightRadius!==void 0&&(e.borderTopRightRadius=`${i.borderTopRightRadius}px`),i.borderBottomLeftRadius!==void 0&&(e.borderBottomLeftRadius=`${i.borderBottomLeftRadius}px`),i.borderBottomRightRadius!==void 0&&(e.borderBottomRightRadius=`${i.borderBottomRightRadius}px`),i.opacity!==void 0&&(e.opacity=i.opacity),i.borderWidth!==void 0&&(e.borderWidth=`${i.borderWidth}px`),i.borderColor&&(e.borderColor=i.borderColor),i.borderTopWidth!==void 0&&(e.borderTopWidth=`${i.borderTopWidth}px`),i.borderRightWidth!==void 0&&(e.borderRightWidth=`${i.borderRightWidth}px`),i.borderBottomWidth!==void 0&&(e.borderBottomWidth=`${i.borderBottomWidth}px`),i.borderLeftWidth!==void 0&&(e.borderLeftWidth=`${i.borderLeftWidth}px`),i.position&&(e.position=i.position),i.top!==void 0&&(e.top=`${i.top}px`),i.right!==void 0&&(e.right=`${i.right}px`),i.bottom!==void 0&&(e.bottom=`${i.bottom}px`),i.left!==void 0&&(e.left=`${i.left}px`),i.zIndex!==void 0&&(e.zIndex=i.zIndex),i.transform&&(e.transform=i.transform);let t=i;return t.color&&(e.color=t.color),t.fontSize!==void 0&&(e.fontSize=`${t.fontSize}px`),t.fontWeight&&(e.fontWeight=t.fontWeight),t.fontFamily&&(e.fontFamily=t.fontFamily),t.fontStyle&&(e.fontStyle=t.fontStyle),t.textAlign&&(e.textAlign=t.textAlign),t.textDecoration&&(e.textDecoration=t.textDecoration),t.lineHeight!==void 0&&(e.lineHeight=`${t.lineHeight}px`),t.letterSpacing!==void 0&&(e.letterSpacing=`${t.letterSpacing}px`),e}function k(i){return g(i)}function n(i){return k(i)?i():i!==null&&typeof i=="object"&&"value"in i&&"peek"in i?i.value:i}function b(i,e,t,r){if(!e)return;let a=Array.isArray(e)?e:[e];for(let o of a)if(!(!o||!o.type))switch(o.type){case "canvas-rect":D(i,o.props);break;case "canvas-circle":S(i,o.props);break;case "canvas-path":W(i,o.props);break;case "canvas-text":C(i,o.props);break;case "canvas-line":T(i,o.props);break;case "canvas-arc":v(i,o.props);break}}function D(i,e){let t=n(e.x),r=n(e.y),a=n(e.width),o=n(e.height),d=n(e.fill),f=n(e.stroke),p=n(e.strokeWidth),c=n(e.opacity);i.save(),c!==void 0&&(i.globalAlpha=c),d&&(i.fillStyle=d,i.fillRect(t,r,a,o)),f&&(i.strokeStyle=f,i.lineWidth=p||1,i.strokeRect(t,r,a,o)),i.restore();}function S(i,e){let t=n(e.x),r=n(e.y),a=n(e.radius),o=n(e.fill),d=n(e.stroke),f=n(e.strokeWidth),p=n(e.opacity);i.save(),p!==void 0&&(i.globalAlpha=p),i.beginPath(),i.arc(t,r,a,0,2*Math.PI),o&&(i.fillStyle=o,i.fill()),d&&(i.strokeStyle=d,i.lineWidth=f||1,i.stroke()),i.restore();}function W(i,e){let t=n(e.d),r=n(e.fill),a=n(e.stroke),o=n(e.strokeWidth),d=n(e.opacity);i.save(),d!==void 0&&(i.globalAlpha=d);let f=new Path2D(t);r&&(i.fillStyle=r,i.fill(f)),a&&(i.strokeStyle=a,i.lineWidth=o||1,i.stroke(f)),i.restore();}function C(i,e){let t=n(e.x),r=n(e.y),a=n(e.text),o=n(e.fill),d=n(e.fontSize)||12,f=n(e.fontFamily)||"sans-serif",p=n(e.fontWeight)||"normal",c=n(e.textAlign)||"left",m=n(e.textBaseline)||"alphabetic";i.save(),i.font=`${p} ${d}px ${f}`,i.textAlign=c,i.textBaseline=m,o&&(i.fillStyle=o,i.fillText(a,t,r)),i.restore();}function T(i,e){let t=n(e.x1),r=n(e.y1),a=n(e.x2),o=n(e.y2),d=n(e.stroke)||"black",f=n(e.strokeWidth)||1,p=n(e.opacity);i.save(),p!==void 0&&(i.globalAlpha=p),i.beginPath(),i.moveTo(t,r),i.lineTo(a,o),i.strokeStyle=d,i.lineWidth=f,i.stroke(),i.restore();}function v(i,e){let t=n(e.x),r=n(e.y),a=n(e.radius),o=n(e.startAngle),d=n(e.endAngle),f=n(e.counterclockwise)||false,p=n(e.fill),c=n(e.stroke),m=n(e.strokeWidth),h=n(e.opacity);i.save(),h!==void 0&&(i.globalAlpha=h),i.beginPath(),i.arc(t,r,a,o,d,f),p&&(i.fillStyle=p,i.fill()),c&&(i.strokeStyle=c,i.lineWidth=m||1,i.stroke()),i.restore();}function N(i){let{width:e,height:t,children:r,style:a,id:o,...d}=i;return {type:"canvas",props:{...d,id:o,width:e,height:t,style:x(a),ref:f=>{if(!f||typeof requestAnimationFrame>"u")return;let p=f.getContext("2d");p&&Promise.all([import('./effect-T2GVIS3T.mjs').then(c=>({effect:c.effect,onCleanup:c.onCleanup})),import('./state-RYKSC35A.mjs').then(c=>({isSignal:c.isSignal}))]).then(([{effect:c,onCleanup:m},{isSignal:h}])=>{let g,R=()=>{g!==void 0&&cancelAnimationFrame(g),g=requestAnimationFrame(()=>{p.clearRect(0,0,e,t),b(p,r),g=void 0;});};c(()=>{let w=Array.isArray(r)?r:[r];for(let u of w)if(u&&u.props)for(let $ in u.props){let s=u.props[$];h(s)&&s();}R(),m(()=>{g!==void 0&&(cancelAnimationFrame(g),g=void 0);});});}).catch(c=>{console.error("[Flexium Canvas] Failed to load signal module:",c);});}},children:[]}}function V(i){return {type:"canvas-rect",props:i,children:[]}}function j(i){return {type:"canvas-circle",props:i,children:[]}}function M(i){return {type:"canvas-arc",props:i,children:[]}}function E(i){return {type:"canvas-line",props:i,children:[]}}function J(i){return {type:"canvas-path",props:i,children:[]}}function O(i){return {type:"canvas-text",props:i,children:[]}}export{x as a,n as b,b as c,N as d,V as e,j as f,M as g,E as h,J as i,O as j};//# sourceMappingURL=chunk-QZIX4FXS.mjs.map
2
+ //# sourceMappingURL=chunk-QZIX4FXS.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/primitives/utils.ts","../src/primitives/canvas/utils.ts","../src/primitives/canvas/renderer.ts","../src/primitives/canvas/Canvas.ts","../src/primitives/canvas/DrawRect.ts","../src/primitives/canvas/DrawCircle.ts","../src/primitives/canvas/DrawArc.ts","../src/primitives/canvas/DrawLine.ts","../src/primitives/canvas/DrawPath.ts","../src/primitives/canvas/DrawText.ts"],"names":["normalizeStyle","style","css","textStyle","isSignal","value","unwrapSignal","renderCanvasChildren","ctx","children","_width","_height","childArray","child","renderRect","renderCircle","renderPath","renderText","renderLine","renderArc","props","x","y","width","height","fill","stroke","strokeWidth","opacity","radius","d","path","text","fontSize","fontFamily","fontWeight","textAlign","textBaseline","x1","y1","x2","y2","startAngle","endAngle","counterclockwise","Canvas","id","rest","canvas","m","effect","onCleanup","rafId","scheduleRender","key","err","DrawRect","DrawCircle","DrawArc","DrawLine","DrawPath","DrawText"],"mappings":"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","file":"chunk-QZIX4FXS.mjs","sourcesContent":["/**\n * Primitive utilities\n */\n\nimport type { CommonStyle, TextStyle } from './types'\n\n/**\n * Normalize CommonStyle to CSS properties\n */\nexport function normalizeStyle(\n style?: CommonStyle | TextStyle\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): Record<string, any> {\n if (!style) return {}\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const css: Record<string, any> = {}\n\n // Layout\n if (style.display) css.display = style.display\n if (style.flex !== undefined) css.flex = style.flex\n if (style.flexDirection) css.flexDirection = style.flexDirection\n if (style.flexWrap) css.flexWrap = style.flexWrap\n if (style.justifyContent) css.justifyContent = style.justifyContent\n if (style.alignItems) css.alignItems = style.alignItems\n if (style.alignSelf) css.alignSelf = style.alignSelf\n if (style.gap !== undefined) css.gap = `${style.gap}px`\n\n // Spacing - padding\n if (style.padding !== undefined) css.padding = `${style.padding}px`\n if (style.paddingTop !== undefined) css.paddingTop = `${style.paddingTop}px`\n if (style.paddingRight !== undefined)\n css.paddingRight = `${style.paddingRight}px`\n if (style.paddingBottom !== undefined)\n css.paddingBottom = `${style.paddingBottom}px`\n if (style.paddingLeft !== undefined)\n css.paddingLeft = `${style.paddingLeft}px`\n if (style.paddingHorizontal !== undefined) {\n css.paddingLeft = `${style.paddingHorizontal}px`\n css.paddingRight = `${style.paddingHorizontal}px`\n }\n if (style.paddingVertical !== undefined) {\n css.paddingTop = `${style.paddingVertical}px`\n css.paddingBottom = `${style.paddingVertical}px`\n }\n\n // Spacing - margin\n if (style.margin !== undefined) css.margin = `${style.margin}px`\n if (style.marginTop !== undefined) css.marginTop = `${style.marginTop}px`\n if (style.marginRight !== undefined)\n css.marginRight = `${style.marginRight}px`\n if (style.marginBottom !== undefined)\n css.marginBottom = `${style.marginBottom}px`\n if (style.marginLeft !== undefined) css.marginLeft = `${style.marginLeft}px`\n if (style.marginHorizontal !== undefined) {\n css.marginLeft = `${style.marginHorizontal}px`\n css.marginRight = `${style.marginHorizontal}px`\n }\n if (style.marginVertical !== undefined) {\n css.marginTop = `${style.marginVertical}px`\n css.marginBottom = `${style.marginVertical}px`\n }\n\n // Sizing\n if (style.width !== undefined)\n css.width =\n typeof style.width === 'number' ? `${style.width}px` : style.width\n if (style.height !== undefined)\n css.height =\n typeof style.height === 'number' ? `${style.height}px` : style.height\n if (style.minWidth !== undefined) css.minWidth = `${style.minWidth}px`\n if (style.maxWidth !== undefined) css.maxWidth = `${style.maxWidth}px`\n if (style.minHeight !== undefined) css.minHeight = `${style.minHeight}px`\n if (style.maxHeight !== undefined) css.maxHeight = `${style.maxHeight}px`\n\n // Visual\n if (style.backgroundColor) css.backgroundColor = style.backgroundColor\n if (style.borderRadius !== undefined)\n css.borderRadius = `${style.borderRadius}px`\n if (style.borderTopLeftRadius !== undefined)\n css.borderTopLeftRadius = `${style.borderTopLeftRadius}px`\n if (style.borderTopRightRadius !== undefined)\n css.borderTopRightRadius = `${style.borderTopRightRadius}px`\n if (style.borderBottomLeftRadius !== undefined)\n css.borderBottomLeftRadius = `${style.borderBottomLeftRadius}px`\n if (style.borderBottomRightRadius !== undefined)\n css.borderBottomRightRadius = `${style.borderBottomRightRadius}px`\n if (style.opacity !== undefined) css.opacity = style.opacity\n\n // Border\n if (style.borderWidth !== undefined)\n css.borderWidth = `${style.borderWidth}px`\n if (style.borderColor) css.borderColor = style.borderColor\n if (style.borderTopWidth !== undefined)\n css.borderTopWidth = `${style.borderTopWidth}px`\n if (style.borderRightWidth !== undefined)\n css.borderRightWidth = `${style.borderRightWidth}px`\n if (style.borderBottomWidth !== undefined)\n css.borderBottomWidth = `${style.borderBottomWidth}px`\n if (style.borderLeftWidth !== undefined)\n css.borderLeftWidth = `${style.borderLeftWidth}px`\n\n // Position\n if (style.position) css.position = style.position\n if (style.top !== undefined) css.top = `${style.top}px`\n if (style.right !== undefined) css.right = `${style.right}px`\n if (style.bottom !== undefined) css.bottom = `${style.bottom}px`\n if (style.left !== undefined) css.left = `${style.left}px`\n if (style.zIndex !== undefined) css.zIndex = style.zIndex\n\n // Transform\n if (style.transform) css.transform = style.transform\n\n // Text-specific (if TextStyle)\n const textStyle = style as TextStyle\n if (textStyle.color) css.color = textStyle.color\n if (textStyle.fontSize !== undefined) css.fontSize = `${textStyle.fontSize}px`\n if (textStyle.fontWeight) css.fontWeight = textStyle.fontWeight\n if (textStyle.fontFamily) css.fontFamily = textStyle.fontFamily\n if (textStyle.fontStyle) css.fontStyle = textStyle.fontStyle\n if (textStyle.textAlign) css.textAlign = textStyle.textAlign\n if (textStyle.textDecoration) css.textDecoration = textStyle.textDecoration\n if (textStyle.lineHeight !== undefined)\n css.lineHeight = `${textStyle.lineHeight}px`\n if (textStyle.letterSpacing !== undefined)\n css.letterSpacing = `${textStyle.letterSpacing}px`\n\n return css\n}\n","/**\n * Canvas utilities\n */\n\nimport { isSignal as coreIsSignal } from '../../core/state'\nimport type { StateValue } from '../../core/state'\n\n/**\n * Check if a value is a Signal\n */\nexport function isSignal<T>(value: T | StateValue<T>): value is StateValue<T> {\n // Use core isSignal which checks for SIGNAL_MARKER symbol\n // Signals are functions with properties, not plain objects\n return coreIsSignal(value)\n}\n\n/**\n * Unwrap a value that might be a Signal\n */\nexport function unwrapSignal<T>(value: T | StateValue<T>): T {\n // Check for real signals first (have STATE_SIGNAL)\n if (isSignal(value)) {\n return (value as StateValue<T>)()\n }\n // Handle signal-like objects (for testing) - duck typing\n // Check if it's an object with a 'value' property\n if (\n value !== null &&\n typeof value === 'object' &&\n 'value' in value &&\n 'peek' in value\n ) {\n return (value as any).value\n }\n return value\n}\n","/**\n * Canvas renderer - renders canvas primitives to canvas context\n */\n\nimport type {\n DrawRectProps,\n DrawCircleProps,\n DrawPathProps,\n DrawTextProps,\n DrawLineProps,\n DrawArcProps,\n} from '../types'\nimport { unwrapSignal } from './utils'\n\n/**\n * Render canvas children to context\n */\nexport function renderCanvasChildren(\n ctx: CanvasRenderingContext2D,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n children: any,\n _width: number,\n _height: number\n): void {\n if (!children) return\n\n const childArray = Array.isArray(children) ? children : [children]\n\n for (const child of childArray) {\n if (!child || !child.type) continue\n\n switch (child.type) {\n case 'canvas-rect':\n renderRect(ctx, child.props)\n break\n case 'canvas-circle':\n renderCircle(ctx, child.props)\n break\n case 'canvas-path':\n renderPath(ctx, child.props)\n break\n case 'canvas-text':\n renderText(ctx, child.props)\n break\n case 'canvas-line':\n renderLine(ctx, child.props)\n break\n case 'canvas-arc':\n renderArc(ctx, child.props)\n break\n }\n }\n}\n\n/**\n * Render rectangle\n */\nfunction renderRect(ctx: CanvasRenderingContext2D, props: DrawRectProps): void {\n const x = unwrapSignal(props.x)\n const y = unwrapSignal(props.y)\n const width = unwrapSignal(props.width)\n const height = unwrapSignal(props.height)\n const fill = unwrapSignal(props.fill)\n const stroke = unwrapSignal(props.stroke)\n const strokeWidth = unwrapSignal(props.strokeWidth)\n const opacity = unwrapSignal(props.opacity)\n\n ctx.save()\n\n if (opacity !== undefined) {\n ctx.globalAlpha = opacity\n }\n\n if (fill) {\n ctx.fillStyle = fill\n ctx.fillRect(x, y, width, height)\n }\n\n if (stroke) {\n ctx.strokeStyle = stroke\n ctx.lineWidth = strokeWidth || 1\n ctx.strokeRect(x, y, width, height)\n }\n\n ctx.restore()\n}\n\n/**\n * Render circle\n */\nfunction renderCircle(\n ctx: CanvasRenderingContext2D,\n props: DrawCircleProps\n): void {\n const x = unwrapSignal(props.x)\n const y = unwrapSignal(props.y)\n const radius = unwrapSignal(props.radius)\n const fill = unwrapSignal(props.fill)\n const stroke = unwrapSignal(props.stroke)\n const strokeWidth = unwrapSignal(props.strokeWidth)\n const opacity = unwrapSignal(props.opacity)\n\n ctx.save()\n\n if (opacity !== undefined) {\n ctx.globalAlpha = opacity\n }\n\n ctx.beginPath()\n ctx.arc(x, y, radius, 0, 2 * Math.PI)\n\n if (fill) {\n ctx.fillStyle = fill\n ctx.fill()\n }\n\n if (stroke) {\n ctx.strokeStyle = stroke\n ctx.lineWidth = strokeWidth || 1\n ctx.stroke()\n }\n\n ctx.restore()\n}\n\n/**\n * Render path\n */\nfunction renderPath(ctx: CanvasRenderingContext2D, props: DrawPathProps): void {\n const d = unwrapSignal(props.d)\n const fill = unwrapSignal(props.fill)\n const stroke = unwrapSignal(props.stroke)\n const strokeWidth = unwrapSignal(props.strokeWidth)\n const opacity = unwrapSignal(props.opacity)\n\n ctx.save()\n\n if (opacity !== undefined) {\n ctx.globalAlpha = opacity\n }\n\n // Parse SVG path (simplified - only supports basic commands)\n const path = new Path2D(d)\n\n if (fill) {\n ctx.fillStyle = fill\n ctx.fill(path)\n }\n\n if (stroke) {\n ctx.strokeStyle = stroke\n ctx.lineWidth = strokeWidth || 1\n ctx.stroke(path)\n }\n\n ctx.restore()\n}\n\n/**\n * Render text\n */\nfunction renderText(ctx: CanvasRenderingContext2D, props: DrawTextProps): void {\n const x = unwrapSignal(props.x)\n const y = unwrapSignal(props.y)\n const text = unwrapSignal(props.text)\n const fill = unwrapSignal(props.fill)\n const fontSize = unwrapSignal(props.fontSize) || 12\n const fontFamily = unwrapSignal(props.fontFamily) || 'sans-serif'\n const fontWeight = unwrapSignal(props.fontWeight) || 'normal'\n const textAlign = unwrapSignal(props.textAlign) || 'left'\n const textBaseline = unwrapSignal(props.textBaseline) || 'alphabetic'\n\n ctx.save()\n\n ctx.font = `${fontWeight} ${fontSize}px ${fontFamily}`\n ctx.textAlign = textAlign\n ctx.textBaseline = textBaseline\n\n if (fill) {\n ctx.fillStyle = fill\n ctx.fillText(text, x, y)\n }\n\n ctx.restore()\n}\n\n/**\n * Render line\n */\nfunction renderLine(ctx: CanvasRenderingContext2D, props: DrawLineProps): void {\n const x1 = unwrapSignal(props.x1)\n const y1 = unwrapSignal(props.y1)\n const x2 = unwrapSignal(props.x2)\n const y2 = unwrapSignal(props.y2)\n const stroke = unwrapSignal(props.stroke) || 'black'\n const strokeWidth = unwrapSignal(props.strokeWidth) || 1\n const opacity = unwrapSignal(props.opacity)\n\n ctx.save()\n\n if (opacity !== undefined) {\n ctx.globalAlpha = opacity\n }\n\n ctx.beginPath()\n ctx.moveTo(x1, y1)\n ctx.lineTo(x2, y2)\n\n ctx.strokeStyle = stroke\n ctx.lineWidth = strokeWidth\n ctx.stroke()\n\n ctx.restore()\n}\n\n/**\n * Render arc\n */\nfunction renderArc(ctx: CanvasRenderingContext2D, props: DrawArcProps): void {\n const x = unwrapSignal(props.x)\n const y = unwrapSignal(props.y)\n const radius = unwrapSignal(props.radius)\n const startAngle = unwrapSignal(props.startAngle)\n const endAngle = unwrapSignal(props.endAngle)\n const counterclockwise = unwrapSignal(props.counterclockwise) || false\n const fill = unwrapSignal(props.fill)\n const stroke = unwrapSignal(props.stroke)\n const strokeWidth = unwrapSignal(props.strokeWidth)\n const opacity = unwrapSignal(props.opacity)\n\n ctx.save()\n\n if (opacity !== undefined) {\n ctx.globalAlpha = opacity\n }\n\n ctx.beginPath()\n ctx.arc(x, y, radius, startAngle, endAngle, counterclockwise)\n\n if (fill) {\n ctx.fillStyle = fill\n ctx.fill()\n }\n\n if (stroke) {\n ctx.strokeStyle = stroke\n ctx.lineWidth = strokeWidth || 1\n ctx.stroke()\n }\n\n ctx.restore()\n}\n","/**\n * Canvas - Declarative canvas container with JSX drawing\n *\n * Supports Signal-based reactive rendering\n *\n * @example\n * ```tsx\n * const x = signal(50)\n *\n * <Canvas width={300} height={200}>\n * <Rect x={x} y={50} width={100} height={50} fill=\"blue\" />\n * <Circle x={150} y={100} radius={30} fill=\"red\" />\n * </Canvas>\n * ```\n */\n\nimport type { FNode } from '../../types'\nimport type { CanvasProps } from '../types'\nimport { normalizeStyle } from '../utils'\nimport { renderCanvasChildren } from './renderer'\n\nexport function Canvas(props: CanvasProps): FNode {\n const { width, height, children, style, id, ...rest } = props\n\n return {\n type: 'canvas',\n props: {\n ...rest,\n id,\n width,\n height,\n style: normalizeStyle(style),\n // Attach canvas renderer when element is mounted\n ref: (canvas: HTMLCanvasElement | null) => {\n if (!canvas) return\n\n // SSR guard: skip canvas rendering on server\n if (typeof requestAnimationFrame === 'undefined') return\n\n const ctx = canvas.getContext('2d')\n if (!ctx) return\n\n // Check if effect is available before trying to import\n // Import effect and onCleanup dynamically to avoid circular deps\n Promise.all([\n import('../../core/effect').then(m => ({ effect: m.effect, onCleanup: m.onCleanup })),\n import('../../core/state').then(m => ({ isSignal: m.isSignal }))\n ])\n .then(([{ effect, onCleanup }, { isSignal }]) => {\n let rafId: number | undefined\n\n const scheduleRender = () => {\n if (rafId !== undefined) {\n cancelAnimationFrame(rafId)\n }\n\n rafId = requestAnimationFrame(() => {\n // Clear canvas\n ctx.clearRect(0, 0, width, height)\n\n // Render all children\n renderCanvasChildren(ctx, children, width, height)\n\n rafId = undefined\n })\n }\n\n effect(() => {\n // To track signal dependencies, we need to access them in the effect\n // Walk through children and touch any signals to track dependencies\n const childArray = Array.isArray(children) ? children : [children]\n for (const child of childArray) {\n if (child && child.props) {\n // Touch each prop to track signal dependencies\n for (const key in child.props) {\n const value = child.props[key]\n // If it's a signal, access its value to track it\n if (isSignal(value)) {\n void (value as any)() // Touch the signal to track dependency\n }\n }\n }\n }\n\n // Now schedule the actual render\n scheduleRender()\n\n // Cleanup RAF when effect is disposed\n onCleanup(() => {\n if (rafId !== undefined) {\n cancelAnimationFrame(rafId)\n rafId = undefined\n }\n })\n })\n })\n .catch((err) => {\n console.error('[Flexium Canvas] Failed to load signal module:', err)\n })\n },\n },\n children: [],\n }\n}\n","/**\n * DrawRect - Canvas rectangle primitive\n *\n * @example\n * ```tsx\n * <DrawRect x={10} y={10} width={100} height={50} fill=\"blue\" />\n * ```\n */\n\nimport type { FNode } from '../../types'\nimport type { DrawRectProps } from '../types'\n\nexport function DrawRect(props: DrawRectProps): FNode {\n return {\n type: 'canvas-rect',\n props,\n children: [],\n }\n}\n","/**\n * DrawCircle - Canvas circle primitive\n *\n * @example\n * ```tsx\n * <DrawCircle x={100} y={100} radius={50} fill=\"red\" />\n * ```\n */\n\nimport type { FNode } from '../../types'\nimport type { DrawCircleProps } from '../types'\n\nexport function DrawCircle(props: DrawCircleProps): FNode {\n return {\n type: 'canvas-circle',\n props,\n children: [],\n }\n}\n","/**\n * DrawArc - Canvas arc primitive\n *\n * @example\n * ```tsx\n * <DrawArc x={100} y={100} radius={50} startAngle={0} endAngle={Math.PI} fill=\"green\" />\n * ```\n */\n\nimport type { FNode } from '../../types'\nimport type { DrawArcProps } from '../types'\n\nexport function DrawArc(props: DrawArcProps): FNode {\n return {\n type: 'canvas-arc',\n props,\n children: [],\n }\n}\n","/**\n * DrawLine - Canvas line primitive\n *\n * @example\n * ```tsx\n * <DrawLine x1={10} y1={10} x2={100} y2={100} stroke=\"black\" strokeWidth={2} />\n * ```\n */\n\nimport type { FNode } from '../../types'\nimport type { DrawLineProps } from '../types'\n\nexport function DrawLine(props: DrawLineProps): FNode {\n return {\n type: 'canvas-line',\n props,\n children: [],\n }\n}\n","/**\n * DrawPath - Canvas path primitive\n *\n * @example\n * ```tsx\n * <DrawPath d=\"M 10 10 L 100 100\" stroke=\"black\" strokeWidth={2} />\n * ```\n */\n\nimport type { FNode } from '../../types'\nimport type { DrawPathProps } from '../types'\n\nexport function DrawPath(props: DrawPathProps): FNode {\n return {\n type: 'canvas-path',\n props,\n children: [],\n }\n}\n","/**\n * DrawText - Canvas text primitive\n *\n * @example\n * ```tsx\n * <DrawText x={50} y={50} text=\"Hello Canvas\" fontSize={20} fill=\"black\" />\n * ```\n */\n\nimport type { FNode } from '../../types'\nimport type { DrawTextProps } from '../types'\n\nexport function DrawText(props: DrawTextProps): FNode {\n return {\n type: 'canvas-text',\n props,\n children: [],\n }\n}\n"]}
@@ -1,2 +1,2 @@
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
+ 'use strict';var chunkQ7IWDVJ4_js=require('./chunk-Q7IWDVJ4.js'),chunkWWEWRI6S_js=require('./chunk-WWEWRI6S.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 chunkWWEWRI6S_js.d(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-RMN5IPS5.js.map
2
+ //# sourceMappingURL=chunk-RMN5IPS5.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-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"]}
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-RMN5IPS5.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/effect'\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,2 @@
1
+ 'use strict';var chunkGYDP6MFV_js=require('./chunk-GYDP6MFV.js');var c;(i=>{let o=[],t=0;function s(e,d){if(t>0){let r=o[--t];return r.dep=e,r.sub=d,r.prevSub=void 0,r.nextSub=void 0,r.prevDep=void 0,r.nextDep=void 0,r}return {dep:e,sub:d,prevSub:void 0,nextSub:void 0,prevDep:void 0,nextDep:void 0}}i.alloc=s;function n(e){e.dep=void 0,e.sub=void 0,e.prevSub=void 0,e.nextSub=void 0,e.prevDep=void 0,e.nextDep=void 0,t<1e4&&(o[t++]=e);}i.free=n;})(c||(c={}));exports.a=void 0;(s=>{function o(n,i){let e=c.alloc(n,i),d=i.depsHead;e.nextDep=d,d&&(d.prevDep=e),i.depsHead=e;let r=n.subsHead;e.nextSub=r,r&&(r.prevSub=e),n.subsHead=e;}s.connect=o;function t(n){let i=n.depsHead;for(;i;){let e=i.dep,d=i.nextDep,r=i.prevSub,f=i.nextSub;r?r.nextSub=f:e.subsHead=f,f&&(f.prevSub=r),c.free(i),i=d;}n.depsHead=void 0;}s.disconnectDependencies=t;})(exports.a||(exports.a={}));var g;(n=>{function o(i,e){return (i.flags&e)!==0}n.has=o;function t(i,e){i.flags|=e;}n.add=t;function s(i,e){i.flags&=~e;}n.remove=s;})(g||(g={}));var x=class{constructor(t,s){this.fn=t;this.onError=s;this.cleanups=[];this.flags=0;this.nodeType=3;this.owner=null;this.owner=chunkGYDP6MFV_js.g();}execute(){if((this.flags&1)!==0){this.flags|=2;return}this.flags|=1;try{this.run();}finally{this.flags&=-2,(this.flags&2)!==0&&(this.flags&=-3,queueMicrotask(()=>this.execute()));}}run(){if(this.cleanups.length>0){for(let n=this.cleanups.length-1;n>=0;n--)this.cleanups[n]();this.cleanups=[];}exports.a.disconnectDependencies(this);let t=chunkGYDP6MFV_js.d(),s=chunkGYDP6MFV_js.g();chunkGYDP6MFV_js.e(this),chunkGYDP6MFV_js.h(this.owner);try{let n=this.fn();typeof n=="function"&&this.cleanups.push(n);}catch(n){this.onError?this.onError(n):chunkGYDP6MFV_js.b(chunkGYDP6MFV_js.a.EFFECT_EXECUTION_FAILED,void 0,n);}finally{chunkGYDP6MFV_js.e(t),chunkGYDP6MFV_js.h(s);}}dispose(){if(this.cleanups.length>0){for(let t=this.cleanups.length-1;t>=0;t--)this.cleanups[t]();this.cleanups=[];}exports.a.disconnectDependencies(this);}};function O(o,t){let s=new x(o,t?.onError);s.execute();let n=()=>s.dispose(),i=chunkGYDP6MFV_js.g();return i&&i.cleanups.push(n),n}function k(o){let t=chunkGYDP6MFV_js.d();t&&t.nodeType===3?t.cleanups.push(o):chunkGYDP6MFV_js.c(chunkGYDP6MFV_js.a.CLEANUP_OUTSIDE_EFFECT);}exports.b=x;exports.c=O;exports.d=k;//# sourceMappingURL=chunk-WWEWRI6S.js.map
2
+ //# sourceMappingURL=chunk-WWEWRI6S.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/core/graph.ts","../src/core/effect.ts"],"names":["LinkPool","pool","size","alloc","dep","sub","link","free","Graph","connect","depsHead","subsHead","disconnectDependencies","nextDep","prevSub","nextSub","Flags","has","obj","flag","add","remove","EffectNode","fn","onError","getOwner","i","prevEffect","getActiveEffect","prevOwner","setActiveEffect","setOwner","result","error","logError","ErrorCodes","effect","options","node","dispose","owner","onCleanup","activeEffect","logWarning"],"mappings":"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","file":"chunk-WWEWRI6S.js","sourcesContent":["/**\n * Graph.ts\n *\n * Core Graph Data Structures & Algorithms\n * Implements the \"Hardcore\" Doubly Linked List for dependency tracking.\n *\n * This module is purely internal and has NO dependencies on other core modules\n * to avoid circular references.\n */\n\n// ==================================================================================\n// 1. Data Structures\n// ==================================================================================\n\n/**\n * Flags for subscriber state (Optimization: Bitmasking)\n */\nexport const enum SubscriberFlags {\n Running = 1 << 0,\n Notified = 1 << 1,\n Dirty = 1 << 2,\n Stale = 1 << 3,\n Tracking = 1 << 4,\n}\n\n/**\n * Node type identifiers for fast type checking (Performance: Avoid instanceof)\n */\nexport const enum NodeType {\n Signal = 1,\n Computed = 2,\n Effect = 3,\n Resource = 4,\n}\n\n/**\n * Link node connecting a Subscriber (Effect/Computed) to a Dependency (Signal/Computed).\n *\n * ASCII Visualization of the Doubly Linked Graph:\n *\n * [Signal A] <==> [Link 1] <==> [Effect B]\n * ^\n * | (Prev/Next Sub on Signal A)\n * v\n * [Link 2] <==> [Effect C]\n *\n * Each Link serves as a node in TWO lists simultaneously:\n * 1. The Subscriber's list of dependencies (prevDep/nextDep)\n * 2. The Dependency's list of subscribers (prevSub/nextSub)\n */\nexport interface Link {\n dep: IObservable | undefined\n sub: ISubscriber | undefined\n\n // Pointers for Dependency's subscriber list\n prevSub: Link | undefined\n nextSub: Link | undefined\n\n // Pointers for Subscriber's dependency list\n prevDep: Link | undefined\n nextDep: Link | undefined\n}\n\n/**\n * Base interface for subscriber nodes (Effect, Computed)\n */\nexport interface ISubscriber {\n execute(): void\n depsHead: Link | undefined // Head of dependencies list\n flags: SubscriberFlags\n nodeType: NodeType // Fast type checking (Performance optimization)\n}\n\n/**\n * Base interface for observable nodes (Signal, Computed)\n */\nexport interface IObservable {\n subsHead: Link | undefined // Head of subscribers list\n version: number // For epoch-based check\n notify(): void\n nodeType: NodeType // Fast type checking (Performance optimization)\n}\n\n// ==================================================================================\n// 2. Object Pool (Memory Optimization)\n// ==================================================================================\n\n/**\n * Pool for Link objects to eliminate GC pressure.\n */\nexport namespace LinkPool {\n const pool: Link[] = []\n let size = 0\n\n export function alloc(dep: IObservable, sub: ISubscriber): Link {\n if (size > 0) {\n const link = pool[--size]\n link.dep = dep\n link.sub = sub\n link.prevSub = undefined\n link.nextSub = undefined\n link.prevDep = undefined\n link.nextDep = undefined\n return link\n }\n return {\n dep,\n sub,\n prevSub: undefined,\n nextSub: undefined,\n prevDep: undefined,\n nextDep: undefined,\n }\n }\n\n export function free(link: Link): void {\n link.dep = undefined\n link.sub = undefined\n // Clearing pointers is optional for safety but good for debugging leaks\n link.prevSub = undefined\n link.nextSub = undefined\n link.prevDep = undefined\n link.nextDep = undefined\n\n if (size < 10000) { // Safety cap\n pool[size++] = link\n }\n }\n}\n\n// ==================================================================================\n// 3. Graph Operations\n// ==================================================================================\n\n/**\n * Internal Graph operations to manage the \"Hardcore\" Linked List structure.\n * Encapsulates raw pointer arithmetic for readability.\n */\nexport namespace Graph {\n /**\n * Connects a dependency (Signal) to a subscriber (Effect/Computed).\n * Allocates a Link from the pool and stitches it into both lists.\n */\n export function connect(dep: IObservable, sub: ISubscriber): void {\n const link = LinkPool.alloc(dep, sub)\n\n // Add to Subscriber's dependency list (prepend)\n // Performance: Cache depsHead to avoid repeated property access\n const depsHead = sub.depsHead\n link.nextDep = depsHead\n if (depsHead) {\n depsHead.prevDep = link\n }\n sub.depsHead = link\n\n // Add to Dependency's subscriber list (prepend)\n // Performance: Cache subsHead to avoid repeated property access\n const subsHead = dep.subsHead\n link.nextSub = subsHead\n if (subsHead) {\n subsHead.prevSub = link\n }\n dep.subsHead = link\n }\n\n /**\n * Fully disconnects a subscriber from all its dependencies.\n * Walks the 'depsHead' list and unlinks each one.\n */\n export function disconnectDependencies(sub: ISubscriber): void {\n let link = sub.depsHead\n while (link) {\n const dep = link.dep!\n // Performance: Cache nextDep and pointers before modifying link\n const nextDep = link.nextDep\n const prevSub = link.prevSub\n const nextSub = link.nextSub\n\n // Remove link from dependency's subscriber list\n // This is a standard doubly-linked list removal\n // Performance: Branch prediction - middle nodes are more common\n if (prevSub) {\n prevSub.nextSub = nextSub\n } else {\n dep.subsHead = nextSub\n }\n if (nextSub) {\n nextSub.prevSub = prevSub\n }\n\n LinkPool.free(link)\n link = nextDep\n }\n sub.depsHead = undefined\n }\n}\n\n/**\n * Flag helpers for readability\n */\nexport namespace Flags {\n export function has(obj: { flags: number }, flag: SubscriberFlags): boolean {\n return (obj.flags & flag) !== 0\n }\n\n export function add(obj: { flags: number }, flag: SubscriberFlags): void {\n obj.flags |= flag\n }\n\n export function remove(obj: { flags: number }, flag: SubscriberFlags): void {\n obj.flags &= ~flag\n }\n}\n","import { ErrorCodes, logError, logWarning } from './errors'\nimport {\n Graph,\n\n type Link,\n type ISubscriber,\n SubscriberFlags,\n NodeType\n} from './graph'\nimport {\n Owner,\n getOwner,\n setOwner,\n getActiveEffect,\n setActiveEffect\n} from './owner'\n\nexport class EffectNode implements ISubscriber {\n depsHead: Link | undefined\n cleanups: (() => void)[] = []\n flags = 0 // detached by default, will set flags during execution\n nodeType = NodeType.Effect\n\n private owner: Owner | null = null\n\n constructor(\n public fn: () => void | (() => void),\n public onError?: (error: Error) => void\n ) {\n this.owner = getOwner()\n }\n\n execute(): void {\n // Performance: Inline bit operations for better performance\n if ((this.flags & SubscriberFlags.Running) !== 0) {\n this.flags |= SubscriberFlags.Notified\n return\n }\n\n this.flags |= SubscriberFlags.Running\n\n try {\n this.run()\n } finally {\n // Performance: Inline bit operations\n this.flags &= ~SubscriberFlags.Running\n if ((this.flags & SubscriberFlags.Notified) !== 0) {\n this.flags &= ~SubscriberFlags.Notified\n // Schedule microtask to avoid stack overflow and infinite sync loops\n queueMicrotask(() => this.execute())\n }\n }\n }\n\n private run(): void {\n // Performance: Fast path when no cleanups\n if (this.cleanups.length > 0) {\n // Performance: Run cleanups in reverse order (most recent first)\n // This ensures proper dependency cleanup order and matches React's behavior\n for (let i = this.cleanups.length - 1; i >= 0; i--) {\n this.cleanups[i]()\n }\n this.cleanups = []\n }\n\n // Clean up previous dependencies via Graph helper\n Graph.disconnectDependencies(this)\n\n const prevEffect = getActiveEffect()\n const prevOwner = getOwner()\n setActiveEffect(this)\n setOwner(this.owner)\n\n try {\n const result = this.fn()\n if (typeof result === 'function') {\n this.cleanups.push(result)\n }\n } catch (error) {\n if (this.onError) {\n this.onError(error as Error)\n } else {\n logError(ErrorCodes.EFFECT_EXECUTION_FAILED, undefined, error)\n }\n } finally {\n setActiveEffect(prevEffect)\n setOwner(prevOwner)\n }\n }\n\n dispose(): void {\n // Performance: Run cleanups in reverse order (most recent first)\n // This ensures proper dependency cleanup order\n if (this.cleanups.length > 0) {\n for (let i = this.cleanups.length - 1; i >= 0; i--) {\n this.cleanups[i]()\n }\n this.cleanups = []\n }\n Graph.disconnectDependencies(this)\n }\n}\n\n/**\n * Creates a side effect that runs when dependencies change\n *\n * @param fn - Effect function, can return a cleanup function\n * @param options - Optional error handler\n * @returns Dispose function to stop the effect\n *\n * @example\n * ```ts\n * const [count, setCount] = state(0);\n * \n * effect(() => {\n * console.log(count());\n * });\n * \n * setCount(1); // logs: 1\n * ```\n */\nexport function effect(\n fn: () => void | (() => void),\n options?: { onError?: (error: Error) => void; name?: string }\n): () => void {\n // DevTools hooks integration would go here if needed\n // For now we rely on the devtools hooks in signal.ts or need to export them properly\n // This implementation is sufficient for core logic\n\n const node = new EffectNode(fn, options?.onError)\n node.execute()\n const dispose = () => node.dispose()\n\n const owner = getOwner()\n if (owner) {\n owner.cleanups.push(dispose)\n }\n\n return dispose\n}\n\n/**\n * Registers a cleanup function that runs before the current effect re-runs or is disposed\n *\n * @param fn - Cleanup function\n */\nexport function onCleanup(fn: () => void): void {\n const activeEffect = getActiveEffect()\n // Performance: Use nodeType instead of instanceof\n if (activeEffect && activeEffect.nodeType === NodeType.Effect) {\n (activeEffect as EffectNode).cleanups.push(fn)\n } else {\n logWarning(ErrorCodes.CLEANUP_OUTSIDE_EFFECT)\n }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ 'use strict';var chunkYPVRQKMW_js=require('./chunk-YPVRQKMW.js'),chunkWWEWRI6S_js=require('./chunk-WWEWRI6S.js'),chunkGYDP6MFV_js=require('./chunk-GYDP6MFV.js');function U(e){return e&&(typeof e=="object"||typeof e=="function")?g in e:false}function X(e){return typeof e=="function"?(e()):U(e)?e():e}function Y(e,t){let[a,n]=d(void 0),[r,o]=d(void 0),[u,s]=d(false),[l,y]=d("unresolved"),p=null,x=async(c,P=false)=>{P?(y("refreshing"),s(true)):(y("pending"),s(true)),o(void 0);let C=t(c,{value:a.peek(),refetching:P});p=C;try{let T=await C;p===C&&(n(T),y("ready"),s(!1));}catch(T){p===C&&(o(T),y("errored"),s(false));}};chunkWWEWRI6S_js.c(()=>{let c=X(e);x(c,false);});let v=function(){return a()};return Object.defineProperties(v,{value:{get:()=>a(),enumerable:true,configurable:true},loading:{get:()=>u(),enumerable:true,configurable:true},error:{get:()=>r(),enumerable:true,configurable:true},state:{get:()=>l(),enumerable:true,configurable:true},latest:{get:()=>a.peek(),enumerable:true,configurable:true},peek:{value:()=>a.peek(),enumerable:false,configurable:true},[g]:{value:v,enumerable:false,configurable:false}}),[v,{mutate:c=>n(c),refetch:()=>{let c=X(e);x(c,true);}}]}var m=new Map,w=new Map,b=new Map,h={enabled:true,maxIdleTime:300*1e3,checkInterval:60*1e3,minAccessCount:0},k=null;function M(){return k}function _(e){k=e;}(typeof window<"u"||typeof globalThis<"u")&&setTimeout(()=>{h.enabled&&!k&&(k=setInterval(E,h.checkInterval),k&&typeof k=="object"&&"unref"in k&&typeof k.unref=="function"&&k.unref());},0);var ge=1e4,te=false,Z=new WeakMap;function R(e){if(typeof e=="string")return e;let t=Z.get(e);if(t!==void 0)return t;try{let a=JSON.stringify(e);return Z.set(e,a),a}catch{return String(e)}}function ee(e,t){t&&(w.has(t)||w.set(t,new Set),w.get(t).add(e));}function N(e,t){if(!t)return;let a=w.get(t);a&&(a.delete(e),a.size===0&&w.delete(t));}function I(e,t,a){let n=Date.now(),r=b.get(e);r?(r.lastAccessed=n,r.accessCount++,r.referenceCount++,t&&r.namespace!==t&&(r.namespace&&N(e,r.namespace),r.namespace=t,ee(e,t))):(b.set(e,{key:e,namespace:t,createdAt:n,lastAccessed:n,accessCount:1,referenceCount:1,signalRef:a&&typeof WeakRef<"u"?new WeakRef(a):void 0}),ee(e,t));}var H=null;function ne(e){H=e;}function E(){if(!h.enabled||!H)return;let e=Date.now(),t=[];for(let[a,n]of b.entries()){if(n.signalRef&&typeof WeakRef<"u"&&!n.signalRef.deref()){t.push(a);continue}e-n.lastAccessed>h.maxIdleTime&&n.referenceCount===0&&n.accessCount>=h.minAccessCount&&t.push(a);}for(let a of t)H(a);t.length>0&&typeof process<"u"&&process.env?.NODE_ENV!=="production"&&console.log(`[Flexium] Auto-cleaned ${t.length} idle states`);}function ae(){return te}function W(e){te=e;}function re(){return ge}var z=0,f=new WeakMap,oe=new WeakMap,be=new WeakMap;function S(e,t,a){let n=oe.get(e);n||(n=new Map,oe.set(e,n));let r=n.get(t);if(!r){let o=a!==void 0?a:Reflect.get(e,t);r=O(o),n.set(t,r);}return r}function O(e,t,a){let n={_value:e,subsHead:void 0,depsHead:void 0,version:0,nodeType:t?2:1,computeFn:t,flags:t?12:0,lastCleanEpoch:0,key:a},r=function(){let s=f.get(r),l=chunkGYDP6MFV_js.d();return l&&l!==r&&chunkWWEWRI6S_js.a.connect(r,l),s.computeFn?A(s,r):s._value},o=r;return f.set(o,n),a&&be.set(o,a),Object.defineProperty(o,"subsHead",{get:()=>f.get(o).subsHead,set:s=>{f.get(o).subsHead=s;},enumerable:false,configurable:true}),Object.defineProperty(o,"depsHead",{get:()=>f.get(o).depsHead,set:s=>{f.get(o).depsHead=s;},enumerable:false,configurable:true}),Object.defineProperty(o,"version",{get:()=>f.get(o).version,enumerable:false,configurable:true}),Object.defineProperty(o,"nodeType",{get:()=>f.get(o).nodeType,enumerable:false,configurable:true}),Object.defineProperty(o,"flags",{get:()=>f.get(o).flags||0,set:s=>{f.get(o).flags=s;},enumerable:false,configurable:true}),o.peek=()=>{let s=f.get(o);return s.computeFn?A(s,o,true):s._value},t||(o.set=s=>{let l=f.get(o),y=l._value,p=typeof s=="function"?s(y):s;l._value!==p&&(l._value=p,l.version=++z,K(l));}),o.execute=()=>{let s=f.get(o);s.computeFn&&(s.flags=(s.flags||0)|4|8,K(s));},o.notify=()=>{let s=f.get(o);K(s);},new Proxy(o,Se)}function A(e,t,a=false){if(!e.computeFn)return e._value;let n=e.flags||0,r=n&12;if(!a&&r===0)return e._value;if((n&4)===0&&(n&8)!==0&&!me(e))return e.flags=n&-9,e._value;e.flags=n&-13,chunkWWEWRI6S_js.a.disconnectDependencies(t);let o=chunkGYDP6MFV_js.d();chunkGYDP6MFV_js.e(t);try{let u=e.computeFn();e._value!==u&&(e._value=u,e.version=++z),e.lastCleanEpoch=z;}finally{chunkGYDP6MFV_js.e(o);}return e._value}function me(e){if(!e.depsHead)return true;let t=e.depsHead;for(;t;){let a=t.dep;if(a.version>(e.lastCleanEpoch||0))return true;if(a.nodeType===2){let n=f.get(a);if(((n.flags||0)&12)!==0){let o=a.version;if(A(n,a,true),a.version!==o&&a.version>(e.lastCleanEpoch||0))return true}}t=t.nextDep;}return false}function K(e){if(chunkYPVRQKMW_js.d()===0){if(e.subsHead){let t=false,a=e.subsHead;for(;a;){let n=a.sub;n.nodeType===2?n.execute&&n.execute():(chunkYPVRQKMW_js.b(n),t||(t=true,chunkYPVRQKMW_js.a())),a=a.nextSub;}}}else {let t=e.subsHead;for(;t;)t.sub&&chunkYPVRQKMW_js.c(t.sub),t=t.nextSub;}}var Se={get(e,t){let a=f.get(e);if(t===g)return e;if(a.key&&I(a.key),t==="peek")return e.peek;if(t==="set"&&!a.computeFn)return e.set;let n=a.computeFn?A(a,e):a._value,r=chunkGYDP6MFV_js.d();if(r&&r!==e&&chunkWWEWRI6S_js.a.connect(e,r),t===Symbol.toPrimitive||t==="valueOf")return ()=>n;if(t===Symbol.iterator&&Array.isArray(n))return S(n,"length")(),S(n,"iterate")(),n[Symbol.iterator].bind(n);if(t==="prototype"||t==="name"||t==="caller"||t==="arguments"){if(typeof n=="function")return n[t];if(n===null||typeof n!="object")return}if(n!==null&&typeof n=="object"){let u=Reflect.get(n,t);return typeof u=="function"?Array.isArray(n)&&["push","pop","shift","unshift","splice","sort","reverse"].includes(t)?function(...l){let y=u.apply(n,l),p=f.get(e),x=p.computeFn?A(p,e):p._value;return n===x&&(S(n,"length").set(n.length),S(n,"iterate")()),y}:Array.isArray(n)?u.bind(n):n[t].bind(n):(S(n,t,u)(),u!==null&&typeof u=="object"?ie(u):u)}let o=n[t];return typeof o=="function"?o.bind(n):o},set(e,t,a){let n=f.get(e);if(n.computeFn)throw new Error("Cannot set computed signal");let r=n._value;if(r!==null&&typeof r=="object"){let o=Reflect.set(r,t,a);return o&&S(r,t).set(a),o}return false},has(e,t){if(t===g)return true;let a=f.get(e),n=a.computeFn?A(a,e):a._value;return n===null?false:typeof n=="object"?Reflect.has(n,t):false},ownKeys(e){let t=f.get(e),a=t.computeFn?A(t,e):t._value;if(a===null||typeof a!="object")return [];Array.isArray(a)&&S(a,"length")(),S(a,"iterate")();let n=Reflect.ownKeys(a),r=Reflect.ownKeys(e),o=["prototype","name","length"],u=[...n];for(let s of o)r.includes(s)&&!u.includes(s)&&Reflect.getOwnPropertyDescriptor(e,s)&&u.push(s);return u},getPrototypeOf(e){let t=f.get(e),a=t.computeFn?A(t,e):t._value;return a!==null&&typeof a=="object"?Reflect.getPrototypeOf(a):Object.prototype},getOwnPropertyDescriptor(e,t){if(t===g)return {configurable:true,enumerable:false,value:e};let a=f.get(e),n=a.computeFn?A(a,e):a._value;if(t==="prototype"||t==="name"||t==="caller"||t==="arguments"){if(t==="prototype"){let o=Reflect.getOwnPropertyDescriptor(e,t);return o||void 0}if(n!==null&&typeof n=="object"){let o=Reflect.getOwnPropertyDescriptor(n,t);if(o)return {...o,configurable:true,enumerable:true}}if(typeof n=="function"){let o=Reflect.getOwnPropertyDescriptor(n,t);if(o)return {...o,configurable:true,enumerable:true}}return}if(n===null||typeof n!="object")return;let r=Reflect.getOwnPropertyDescriptor(n,t);if(r)return {...r,configurable:true,enumerable:true}}},ve={get(e,t,a){if(t===g)return e;let n=Reflect.get(e,t,a);return S(e,t,n)(),n!==null&&typeof n=="object"?ie(n):n},set(e,t,a,n){let r=Reflect.set(e,t,a,n);return r&&S(e,t).set(a),r},has(e,t){return t===g?true:Reflect.has(e,t)}},se=new WeakMap;function ie(e){let t=se.get(e);return t||(t=new Proxy(e,ve),se.set(e,t)),t}var ue=new WeakMap;function ce(e,t){if(typeof e=="object"&&e!==null){let a=ue.get(e);return a||(a=O(e,void 0,t),ue.set(e,a),a)}return O(e,void 0,t)}function j(e,t){return O(void 0,e,t)}function le(e){return (typeof e=="object"||typeof e=="function")&&e!==null&&g in e?e[g]:null}var fe=null;function L(e){fe=e;}function de(){return fe}function Fe(){return {id:Symbol("component"),hookIndex:0,hooks:[]}}function He(e){e.hookIndex=0;}var g=Symbol.for("flexium.stateSignal");function B(e){return (typeof e=="object"||typeof e=="function")&&e!==null&&g in e}function Ke(e){return B(e)}function ze(e){return le(e)}function Le(e,t){return B(e)?e.peek()===t:false}function Be(e){return B(e)?!!e.peek():false}function Te(e,t){let a=de();if(a&&!t?.key){let i=a,c=i.hookIndex++;if(c<i.hooks.length)return i.hooks[c];let P=a;L(null);let C=d(e,t);return L(P),i.hooks.push(C),C}let n=t?.key,r=n?R(n):void 0,o=Array.isArray(n)&&n.length>0?String(n[0]):void 0,u=t?.params;if(r&&m.has(r)){let i=m.get(r);I(r,o,i.proxy);let c=[i.proxy];return i.setter&&c.push(i.setter),i.refetch&&c.push(i.refetch),i.status&&c.push(i.status),i.error&&c.push(i.error),c}let s,l,y,p,x;if(typeof e=="function"){let i=e,c=u!==void 0?()=>i(u):i,P;try{P=c();}catch{}if(i.constructor.name==="AsyncFunction"||P instanceof Promise){let[T,pe]=Y(c,async ye=>ye);y=pe.refetch,s=j(()=>T(),r),p=j(()=>T.loading?"loading":T.error?"error":T.state==="unresolved"?"idle":"success",r),x=j(()=>T.error,r);}else s=j(c,r);}else s=ce(e,r),l=i=>{let c=s[g];typeof i=="function"?c.set(i(c.peek())):c.set(i);};let v=[s];return l&&v.push(l),y&&(v.splice(1,0,y),p&&v.push(p),x&&v.push(x)),r&&(m.set(r,{proxy:s,setter:l,refetch:y,status:p,error:x,createdAt:Date.now(),lastAccessed:Date.now(),accessCount:1,referenceCount:1,key:r,namespace:o}),I(r,o,s),typeof process<"u"&&process.env?.NODE_ENV!=="production"&&!ae()&&m.size>=re()&&(W(true),console.warn(`[Flexium] Registry size warning: ${m.size}`))),v}var d=Te;d.delete=function(e){let t=R(e),a=b.get(t);return a?.namespace&&N(t,a.namespace),b.delete(t),m.delete(t)};d.clear=function(){m.clear(),w.clear(),b.clear(),W(false);};d.has=function(e){return m.has(R(e))};d.clearByPrefix=function(e){let t=R(e),a=0,n=[];for(let[r]of b.entries()){if(r===t){n.push(r);continue}if(t.endsWith("]")){let o=t.slice(0,-1);r.startsWith(o)&&r.length>o.length&&r[o.length]===","&&n.push(r);}else r.startsWith(t)&&n.push(r);}for(let r of n)d.delete(r)&&a++;return a};d.getStats=function(){let e={};for(let[a,n]of w.entries())e[a]=n.size;let t=0;for(let a of b.values())t+=a.accessCount;return {total:m.size,byNamespace:e,topNamespaces:Object.entries(e).map(([a,n])=>({namespace:a,count:n})).sort((a,n)=>n.count-a.count).slice(0,10),averageAccessCount:b.size?t/b.size:0}};d.getNamespaceStats=function(e){let t=R(e),a=Array.isArray(e)&&e.length>0?String(e[0]):t,n=[],r=0;for(let[o,u]of b.entries()){let s=false;if(o===t)s=true;else if(t.endsWith("]")){let l=t.slice(0,-1);o.startsWith(l)&&o.length>l.length&&o[l.length]===","&&(s=true);}else o.startsWith(t)&&(s=true);s&&(n.push({key:o,accessCount:u.accessCount,createdAt:u.createdAt}),r+=u.accessCount);}return {namespace:a,count:n.length,totalAccessCount:r,averageAccessCount:n.length?r/n.length:0,states:n}};Object.defineProperty(d,"size",{get:()=>m.size,enumerable:true});d.enableAutoCleanup=e=>{Object.assign(h,e,{enabled:true});let t=M();t&&clearInterval(t);let a=setInterval(E,h.checkInterval);_(a);};d.disableAutoCleanup=()=>{h.enabled=false;let e=M();e&&clearInterval(e),_(null);};Object.defineProperty(d,"isAutoCleanupEnabled",{get:()=>h.enabled,enumerable:true});ne(e=>d.delete(e));function Ge(e){return {current:e}}exports.a=Y;exports.b=L;exports.c=Fe;exports.d=He;exports.e=g;exports.f=B;exports.g=Ke;exports.h=ze;exports.i=Le;exports.j=Be;exports.k=d;exports.l=Ge;//# sourceMappingURL=chunk-XJHWMHKF.js.map
2
+ //# sourceMappingURL=chunk-XJHWMHKF.js.map