flexium 0.8.15 → 0.9.0
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.
- package/dist/{DrawText-CeXBL8Ev.d.ts → DrawText-Bvzl40Vi.d.ts} +1 -1
- package/dist/{DrawText-JB58mpQT.d.cts → DrawText-CJikXQjL.d.cts} +1 -1
- package/dist/advanced.d.cts +3 -1
- package/dist/advanced.d.ts +3 -1
- package/dist/advanced.js +1 -1
- package/dist/advanced.mjs +1 -1
- package/dist/advanced.mjs.map +1 -1
- package/dist/canvas.d.cts +5 -3
- package/dist/canvas.d.ts +5 -3
- package/dist/canvas.js +1 -1
- package/dist/canvas.mjs +1 -1
- package/dist/chunk-6RV7ARJT.mjs +3 -0
- package/dist/chunk-6RV7ARJT.mjs.map +1 -0
- package/dist/{chunk-CNY6FPKJ.js → chunk-CBO2X74Q.js} +2 -2
- package/dist/{chunk-CZYIK6FD.mjs.map → chunk-CBO2X74Q.js.map} +1 -1
- package/dist/chunk-GFL4VRAO.mjs +3 -0
- package/dist/chunk-GFL4VRAO.mjs.map +1 -0
- package/dist/{chunk-MLZTCKTH.mjs → chunk-GQKN4NPW.mjs} +2 -2
- package/dist/{chunk-MLZTCKTH.mjs.map → chunk-GQKN4NPW.mjs.map} +1 -1
- package/dist/{chunk-CZYIK6FD.mjs → chunk-JDTJFAXO.mjs} +2 -2
- package/dist/chunk-JDTJFAXO.mjs.map +1 -0
- package/dist/{chunk-ZNPYN2TZ.mjs → chunk-LXXN76HJ.mjs} +2 -2
- package/dist/{chunk-ZNPYN2TZ.mjs.map → chunk-LXXN76HJ.mjs.map} +1 -1
- package/dist/chunk-MKE3KA43.js +3 -0
- package/dist/chunk-MKE3KA43.js.map +1 -0
- package/dist/{chunk-DOGIWSDA.js → chunk-PDOEMOWN.js} +2 -2
- package/dist/{chunk-DOGIWSDA.js.map → chunk-PDOEMOWN.js.map} +1 -1
- package/dist/{chunk-GDBJ322I.js → chunk-RIVNKTUR.js} +2 -2
- package/dist/{chunk-GDBJ322I.js.map → chunk-RIVNKTUR.js.map} +1 -1
- package/dist/chunk-TQLZ7UZX.js +2 -0
- package/dist/chunk-TQLZ7UZX.js.map +1 -0
- package/dist/chunk-WEYAKKNF.js +3 -0
- package/dist/chunk-WEYAKKNF.js.map +1 -0
- package/dist/chunk-WO6NQ3KR.mjs +3 -0
- package/dist/chunk-WO6NQ3KR.mjs.map +1 -0
- package/dist/chunk-Y4DUMNIW.mjs +2 -0
- package/dist/chunk-Y4DUMNIW.mjs.map +1 -0
- package/dist/chunk-ZG3LULLU.js +3 -0
- package/dist/chunk-ZG3LULLU.js.map +1 -0
- package/dist/components-D4WeooPi.d.ts +126 -0
- package/dist/components-DZy2r6m5.d.cts +126 -0
- package/dist/core.d.cts +159 -15
- package/dist/core.d.ts +159 -15
- package/dist/core.js +1 -1
- package/dist/core.mjs +1 -1
- package/dist/dom.d.cts +2 -3
- package/dist/dom.d.ts +2 -3
- package/dist/dom.js +1 -1
- package/dist/dom.js.map +1 -1
- package/dist/dom.mjs +1 -1
- package/dist/dom.mjs.map +1 -1
- package/dist/effect-BlnnM1t5.d.cts +20 -0
- package/dist/effect-BlnnM1t5.d.ts +20 -0
- package/dist/index.d.cts +2 -2
- package/dist/index.d.ts +2 -2
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +1 -1
- package/dist/index.mjs.map +1 -1
- package/dist/interactive.d.cts +1 -1
- package/dist/interactive.d.ts +1 -1
- package/dist/interactive.js +1 -1
- package/dist/interactive.mjs +1 -1
- package/dist/interactive.mjs.map +1 -1
- package/dist/metafile-cjs.json +1 -1
- package/dist/metafile-esm.json +1 -1
- package/dist/owner-Ce7KCWzi.d.cts +34 -0
- package/dist/owner-Ce7KCWzi.d.ts +34 -0
- package/dist/{portal-DBwz7gD0.d.ts → portal-C3ESJhlv.d.ts} +1 -1
- package/dist/{portal-BpcIlK9y.d.cts → portal-CAEbiMUZ.d.cts} +1 -1
- package/dist/primitives/motion.js +1 -1
- package/dist/primitives/motion.mjs +1 -1
- package/dist/primitives/ui.d.cts +1 -1
- package/dist/primitives/ui.d.ts +1 -1
- package/dist/primitives/ui.js +1 -1
- package/dist/primitives/ui.mjs +1 -1
- package/dist/primitives/ui.mjs.map +1 -1
- package/dist/primitives.d.cts +6 -4
- package/dist/primitives.d.ts +6 -4
- package/dist/primitives.js +1 -1
- package/dist/primitives.mjs +1 -1
- package/dist/router.d.cts +11 -120
- package/dist/router.d.ts +11 -120
- package/dist/router.js +1 -1
- package/dist/router.mjs +1 -1
- package/dist/scheduler-Z4QqUDjF.d.cts +25 -0
- package/dist/scheduler-Z4QqUDjF.d.ts +25 -0
- package/dist/server.js +1 -1
- package/dist/server.mjs +1 -1
- package/dist/signal-AXKUQJVA.js +2 -0
- package/dist/{signal-XZXQ4VYQ.js.map → signal-AXKUQJVA.js.map} +1 -1
- package/dist/signal-Dxh9PsKr.d.cts +69 -0
- package/dist/signal-Dxh9PsKr.d.ts +69 -0
- package/dist/signal-HM2LG5YL.mjs +2 -0
- package/dist/{signal-PWBIM6JV.mjs.map → signal-HM2LG5YL.mjs.map} +1 -1
- package/dist/test-exports.d.cts +29 -8
- package/dist/test-exports.d.ts +29 -8
- package/dist/test-exports.js +1 -1
- package/dist/test-exports.mjs +1 -1
- package/package.json +1 -1
- package/dist/chunk-2MVKTSFR.mjs +0 -3
- package/dist/chunk-2MVKTSFR.mjs.map +0 -1
- package/dist/chunk-2U4DW375.mjs +0 -2
- package/dist/chunk-2U4DW375.mjs.map +0 -1
- package/dist/chunk-5S3ZQ2LB.mjs +0 -3
- package/dist/chunk-5S3ZQ2LB.mjs.map +0 -1
- package/dist/chunk-CNY6FPKJ.js.map +0 -1
- package/dist/chunk-EX2GURH5.mjs +0 -3
- package/dist/chunk-EX2GURH5.mjs.map +0 -1
- package/dist/chunk-I7UCVARB.js +0 -2
- package/dist/chunk-I7UCVARB.js.map +0 -1
- package/dist/chunk-REETNY2Z.js +0 -3
- package/dist/chunk-REETNY2Z.js.map +0 -1
- package/dist/chunk-ROYFUJN5.js +0 -3
- package/dist/chunk-ROYFUJN5.js.map +0 -1
- package/dist/chunk-V4K6WOXN.js +0 -3
- package/dist/chunk-V4K6WOXN.js.map +0 -1
- package/dist/signal-PWBIM6JV.mjs +0 -2
- package/dist/signal-XZXQ4VYQ.js +0 -2
- package/dist/signal-mNtlF8-v.d.cts +0 -158
- package/dist/signal-mNtlF8-v.d.ts +0 -158
- package/dist/state-kK9sQh9s.d.cts +0 -73
- package/dist/state-kK9sQh9s.d.ts +0 -73
|
@@ -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-MLZTCKTH.mjs","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":"0EAkDA,SAASA,EAAgBC,CAAAA,CAAkC,CACzD,IAAMC,CAAAA,CAAqB,EAAC,CAEtBC,CAAAA,CAAuB,EAAC,CAE9B,OAAIF,CAAAA,CAAM,CAAA,GAAM,MAAA,EACdE,CAAAA,CAAW,KAAK,CAAA,WAAA,EAAcF,CAAAA,CAAM,CAAC,CAAA,GAAA,CAAK,EAGxCA,CAAAA,CAAM,CAAA,GAAM,MAAA,EACdE,CAAAA,CAAW,KAAK,CAAA,WAAA,EAAcF,CAAAA,CAAM,CAAC,CAAA,GAAA,CAAK,EAGxCA,CAAAA,CAAM,KAAA,GAAU,OAClBE,CAAAA,CAAW,IAAA,CAAK,SAASF,CAAAA,CAAM,KAAK,CAAA,CAAA,CAAG,CAAA,EAEnCA,EAAM,MAAA,GAAW,MAAA,EACnBE,CAAAA,CAAW,IAAA,CAAK,UAAUF,CAAAA,CAAM,MAAM,CAAA,CAAA,CAAG,CAAA,CAEvCA,EAAM,MAAA,GAAW,MAAA,EACnBE,CAAAA,CAAW,IAAA,CAAK,UAAUF,CAAAA,CAAM,MAAM,CAAA,CAAA,CAAG,CAAA,CAAA,CAIzCA,EAAM,MAAA,GAAW,MAAA,EACnBE,CAAAA,CAAW,IAAA,CAAK,UAAUF,CAAAA,CAAM,MAAM,CAAA,IAAA,CAAM,CAAA,CAG1CE,EAAW,MAAA,CAAS,CAAA,GACtBD,EAAS,SAAA,CAAYC,CAAAA,CAAW,KAAK,GAAG,CAAA,CAAA,CAGtCF,CAAAA,CAAM,OAAA,GAAY,SACpBC,CAAAA,CAAS,OAAA,CAAUD,CAAAA,CAAM,OAAA,CAAQ,UAAS,CAAA,CAGxCA,CAAAA,CAAM,KAAA,GAAU,MAAA,GAClBC,EAAS,KAAA,CACP,OAAOD,CAAAA,CAAM,KAAA,EAAU,SAAW,CAAA,EAAGA,CAAAA,CAAM,KAAK,CAAA,EAAA,CAAA,CAAOA,EAAM,KAAA,CAAA,CAG7DA,CAAAA,CAAM,MAAA,GAAW,MAAA,GACnBC,EAAS,MAAA,CACP,OAAOD,CAAAA,CAAM,MAAA,EAAW,SAAW,CAAA,EAAGA,CAAAA,CAAM,MAAM,CAAA,EAAA,CAAA,CAAOA,CAAAA,CAAM,QAG5DC,CACT,CAMA,SAASE,CAAAA,CAAeC,EAGtB,CACA,IAAMC,CAAAA,CAAUD,CAAAA,CAAO,SAAW,GAAA,CAC5BE,CAAAA,CAAWF,CAAAA,CAAO,QAAA,EAAY,GAC9BG,CAAAA,CAAOH,CAAAA,CAAO,IAAA,EAAQ,CAAA,CAGtBI,EAAIH,CAAAA,CACJI,CAAAA,CAAIH,CAAAA,CACJI,CAAAA,CAAIH,EAEJI,CAAAA,CAAc,IAAA,CAAK,IAAA,CAAKH,CAAAA,CAAIE,CAAC,CAAA,CAC7BE,CAAAA,CAAeH,CAAAA,EAAK,CAAA,CAAI,KAAK,IAAA,CAAKD,CAAAA,CAAIE,CAAC,CAAA,CAAA,CAGvCG,CAAAA,CAAY,KAAOD,CAAAA,CAAeD,CAAAA,CAAAA,CAAgB,GAAA,CAIxD,OAAIC,EAAe,CAAA,CAIV,CAAE,QAAA,CAAAC,CAAAA,CAAU,OADJ,mCACW,CAAA,CAKrB,CAAE,QAAA,CAAAA,EAAU,MAAA,CADJ,gCACW,CAC5B,CAMA,IAAIC,CAAAA,CAAuC,IAAA,CACvCC,CAAAA,CAAyC,IAAA,CAE7C,SAASC,CAAAA,EAA8B,CACrC,GAAIF,CAAAA,GAAyB,KAC3B,GAAI,OAAO,MAAA,CAAW,GAAA,EAAe,OAAO,UAAA,CAAY,CACtD,IAAMG,CAAAA,CAAa,MAAA,CAAO,WAAW,kCAAkC,CAAA,CACvEH,CAAAA,CAAuBG,CAAAA,CAAW,QAElC,IAAMC,CAAAA,CAAWC,CAAAA,EAA2B,CAC1CL,EAAuBK,CAAAA,CAAE,QAC3B,CAAA,CACAF,CAAAA,CAAW,iBAAiB,QAAA,CAAUC,CAAO,CAAA,CAC7CH,CAAAA,CAAoB,IAAM,CACxBE,CAAAA,CAAW,mBAAA,CAAoB,QAAA,CAAUC,CAAO,CAAA,CAChDJ,CAAAA,CAAuB,IAAA,CACvBC,CAAAA,CAAoB,KACtB,EACF,CAAA,KACED,CAAAA,CAAuB,KAAA,CAG3B,OAAOA,CACT,CAKO,SAASM,CAAAA,EAA2B,CACrCL,GACFA,CAAAA,GAEJ,CAOO,IAAMM,EAAN,KAAuB,CAM5B,WAAA,CAAYC,CAAAA,CAAsB,CAJlC,IAAA,CAAQ,SAAA,CAA8B,IAAA,CACtC,IAAA,CAAQ,eAAwC,IAAA,CAChD,IAAA,CAAQ,YAAA,CAAyD,IAAA,CAG/D,KAAK,OAAA,CAAUA,EACjB,CAMA,OAAA,CAAQtB,EAA0B,CAChC,GAAM,CACJ,OAAA,CAAAuB,EACA,OAAA,CAAAC,CAAAA,CACA,QAAA,CAAAX,CAAAA,CAAW,IACX,MAAA,CAAAT,CAAAA,CACA,OAAAqB,CAAAA,CAAS,UAAA,CACT,MAAAC,CAAAA,CAAQ,CACV,CAAA,CAAI1B,CAAAA,CAEJ,GAAI,CAACwB,CAAAA,CAAS,OAMd,GAHA,KAAK,MAAA,EAAO,CAGRR,CAAAA,EAAmB,CAAG,CACxB,IAAMW,CAAAA,CAAgB5B,CAAAA,CAAgByB,CAAO,EAC7C,MAAA,CAAO,MAAA,CAAO,IAAA,CAAK,OAAA,CAAQ,MAAO,CAChC,SAAA,CAAWG,CAAAA,CAAc,SAAA,EAAa,GACtC,OAAA,CAASA,CAAAA,CAAc,OAAA,EAAW,EAAA,CAClC,MAAOA,CAAAA,CAAc,KAAA,EAAS,GAC9B,MAAA,CAAQA,CAAAA,CAAc,QAAU,EAClC,CAAC,CAAA,CACG3B,CAAAA,CAAM,kBAAkBA,CAAAA,CAAM,gBAAA,EAAiB,CAC/CA,CAAAA,CAAM,qBAAqBA,CAAAA,CAAM,mBAAA,EAAoB,CACzD,MACF,CAGA,GAAIuB,CAAAA,CAAS,CACX,IAAMK,EAAkB7B,CAAAA,CAAgBwB,CAAO,CAAA,CAC/C,MAAA,CAAO,OAAO,IAAA,CAAK,OAAA,CAAQ,KAAA,CAAO,CAChC,UAAWK,CAAAA,CAAgB,SAAA,EAAa,EAAA,CACxC,OAAA,CAASA,EAAgB,OAAA,EAAW,EAAA,CACpC,MAAOA,CAAAA,CAAgB,KAAA,EAAS,GAChC,MAAA,CAAQA,CAAAA,CAAgB,MAAA,EAAU,EACpC,CAAC,EACH,CAGA,IAAMC,CAAAA,CAAON,EAAUxB,CAAAA,CAAgBwB,CAAO,CAAA,CAAI,GAC5CO,CAAAA,CAAK/B,CAAAA,CAAgByB,CAAO,CAAA,CAG9BO,EAAelB,CAAAA,CACfmB,CAAAA,CAAaP,CAAAA,CAEjB,GAAIrB,EAAQ,CACV,IAAM6B,CAAAA,CAAS9B,CAAAA,CAAeC,CAAM,CAAA,CACpC2B,CAAAA,CAAeE,CAAAA,CAAO,QAAA,CACtBD,EAAaC,CAAAA,CAAO,OACtB,CAGA,IAAA,CAAK,SAAA,CAAY,KAAK,OAAA,CAAQ,OAAA,CAAQ,CAACJ,CAAAA,CAAMC,CAAE,CAAA,CAAG,CAChD,QAAA,CAAUC,CAAAA,CACV,OAAQC,CAAAA,CACR,KAAA,CAAAN,CAAAA,CACA,IAAA,CAAM,UACR,CAAC,CAAA,CAGG1B,CAAAA,CAAM,gBAAA,EACRA,EAAM,gBAAA,EAAiB,CAGzB,IAAA,CAAK,SAAA,CAAU,SAAW,IAAM,CAC1BA,CAAAA,CAAM,mBAAA,EACRA,EAAM,mBAAA,GAEV,EACF,CAMA,MAAM,WAAA,CACJkC,CAAAA,CACArB,EAAW,GAAA,CACXY,CAAAA,CAAS,UACM,CAIf,GAHA,IAAA,CAAK,MAAA,GAGDT,CAAAA,EAAmB,CAAG,CACxB,IAAMW,EAAgB5B,CAAAA,CAAgBmC,CAAS,CAAA,CAC/C,MAAA,CAAO,OAAO,IAAA,CAAK,OAAA,CAAQ,KAAA,CAAO,CAChC,UAAWP,CAAAA,CAAc,SAAA,EAAa,EAAA,CACtC,OAAA,CAASA,EAAc,OAAA,EAAW,EAAA,CAClC,KAAA,CAAOA,CAAAA,CAAc,OAAS,EAAA,CAC9B,MAAA,CAAQA,CAAAA,CAAc,MAAA,EAAU,EAClC,CAAC,CAAA,CACD,MACF,CAEA,IAAMG,EAAK/B,CAAAA,CAAgBmC,CAAS,CAAA,CAEpC,IAAA,CAAK,UAAY,IAAA,CAAK,OAAA,CAAQ,OAAA,CAAQ,CAAC,EAAC,CAAGJ,CAAE,CAAA,CAAG,CAC9C,SAAAjB,CAAAA,CACA,MAAA,CAAAY,CAAAA,CACA,IAAA,CAAM,UACR,CAAC,CAAA,CAED,MAAM,IAAA,CAAK,UAAU,SACvB,CAKA,qBAAA,CAAsBZ,CAAAA,CAAW,IAAKY,CAAAA,CAAS,UAAA,CAAkB,CAE/D,IAAMU,EAAO,IAAA,CAAK,OAAA,CAAQ,uBAAsB,CAChD,IAAA,CAAK,aAAe,CAAE,KAAA,CAAOA,CAAAA,CAAK,KAAA,CAAO,OAAQA,CAAAA,CAAK,MAAO,CAAA,CAG7D,IAAA,CAAK,eAAiB,IAAI,cAAA,CAAgBC,CAAAA,EAAY,CACpD,QAAWC,CAAAA,IAASD,CAAAA,CAAS,CAC3B,GAAI,CAAC,IAAA,CAAK,YAAA,CAAc,CACtB,IAAA,CAAK,aAAe,CAClB,KAAA,CAAOC,CAAAA,CAAM,WAAA,CAAY,MACzB,MAAA,CAAQA,CAAAA,CAAM,WAAA,CAAY,MAC5B,EACA,MACF,CAEA,IAAMC,CAAAA,CAAWD,CAAAA,CAAM,YAAY,KAAA,CAC7BE,CAAAA,CAAYF,CAAAA,CAAM,WAAA,CAAY,QAIlCC,CAAAA,GAAa,IAAA,CAAK,YAAA,CAAa,KAAA,EAC/BC,IAAc,IAAA,CAAK,YAAA,CAAa,MAAA,IAGhC,IAAA,CAAK,QAAO,CAEZ,IAAA,CAAK,SAAA,CAAY,IAAA,CAAK,QAAQ,OAAA,CAC5B,CACE,CACE,KAAA,CAAO,GAAG,IAAA,CAAK,YAAA,CAAa,KAAK,CAAA,EAAA,CAAA,CACjC,OAAQ,CAAA,EAAG,IAAA,CAAK,YAAA,CAAa,MAAM,IACrC,CAAA,CACA,CACE,MAAO,CAAA,EAAGD,CAAQ,KAClB,MAAA,CAAQ,CAAA,EAAGC,CAAS,CAAA,EAAA,CACtB,CACF,CAAA,CACA,CACE,QAAA,CAAA1B,CAAAA,CACA,OAAAY,CAAAA,CACA,IAAA,CAAM,UACR,CACF,EAEA,IAAA,CAAK,YAAA,CAAe,CAAE,KAAA,CAAOa,CAAAA,CAAU,OAAQC,CAAU,CAAA,EAE7D,CACF,CAAC,EAED,IAAA,CAAK,cAAA,CAAe,OAAA,CAAQ,IAAA,CAAK,OAAO,EAC1C,CAKA,sBAAA,EAA+B,CACzB,KAAK,cAAA,GACP,IAAA,CAAK,eAAe,UAAA,EAAW,CAC/B,KAAK,cAAA,CAAiB,IAAA,CACtB,IAAA,CAAK,YAAA,CAAe,MAExB,CAKA,MAAA,EAAe,CACT,IAAA,CAAK,YACP,IAAA,CAAK,SAAA,CAAU,MAAA,EAAO,CACtB,KAAK,SAAA,CAAY,IAAA,EAErB,CAKA,OAAA,EAAgB,CACd,IAAA,CAAK,MAAA,EAAO,CACZ,IAAA,CAAK,yBACP,CACF,EChUA,SAASC,EAAmBC,CAAAA,CAI1B,CACA,OAAQA,CAAAA,EACN,KAAK,MAAA,CACH,OAAO,CACL,KAAA,CAAO,CAAE,OAAA,CAAS,CAAE,CAAA,CACpB,OAAA,CAAS,CAAE,OAAA,CAAS,CAAE,CAAA,CACtB,IAAA,CAAM,CAAE,OAAA,CAAS,CAAE,CACrB,CAAA,CACF,KAAK,UAAA,CACH,OAAO,CACL,KAAA,CAAO,CAAE,OAAA,CAAS,CAAA,CAAG,CAAA,CAAG,EAAG,EAC3B,OAAA,CAAS,CAAE,OAAA,CAAS,CAAA,CAAG,EAAG,CAAE,CAAA,CAC5B,IAAA,CAAM,CAAE,QAAS,CAAA,CAAG,CAAA,CAAG,GAAI,CAC7B,CAAA,CACF,KAAK,YAAA,CACH,OAAO,CACL,KAAA,CAAO,CAAE,OAAA,CAAS,CAAA,CAAG,CAAA,CAAG,GAAI,EAC5B,OAAA,CAAS,CAAE,OAAA,CAAS,CAAA,CAAG,EAAG,CAAE,CAAA,CAC5B,IAAA,CAAM,CAAE,QAAS,CAAA,CAAG,CAAA,CAAG,EAAG,CAC5B,EACF,KAAK,YAAA,CACH,OAAO,CACL,MAAO,CAAE,OAAA,CAAS,CAAA,CAAG,CAAA,CAAG,EAAG,CAAA,CAC3B,OAAA,CAAS,CAAE,OAAA,CAAS,CAAA,CAAG,EAAG,CAAE,CAAA,CAC5B,IAAA,CAAM,CAAE,QAAS,CAAA,CAAG,CAAA,CAAG,GAAI,CAC7B,EACF,KAAK,aAAA,CACH,OAAO,CACL,MAAO,CAAE,OAAA,CAAS,CAAA,CAAG,CAAA,CAAG,GAAI,CAAA,CAC5B,OAAA,CAAS,CAAE,OAAA,CAAS,EAAG,CAAA,CAAG,CAAE,CAAA,CAC5B,IAAA,CAAM,CAAE,OAAA,CAAS,CAAA,CAAG,CAAA,CAAG,EAAG,CAC5B,CAAA,CACF,KAAK,QACH,OAAO,CACL,MAAO,CAAE,KAAA,CAAO,EAAI,CAAA,CACpB,QAAS,CAAE,KAAA,CAAO,CAAE,CAAA,CACpB,KAAM,CAAE,KAAA,CAAO,EAAI,CACrB,EACF,KAAK,YAAA,CACH,OAAO,CACL,MAAO,CAAE,OAAA,CAAS,CAAA,CAAG,KAAA,CAAO,GAAK,CAAA,CACjC,OAAA,CAAS,CAAE,OAAA,CAAS,EAAG,KAAA,CAAO,CAAE,CAAA,CAChC,IAAA,CAAM,CAAE,OAAA,CAAS,CAAA,CAAG,MAAO,GAAK,CAClC,EACF,QACE,OAAO,CACL,KAAA,CAAO,EAAC,CACR,OAAA,CAAS,EAAC,CACV,KAAM,EACR,CACJ,CACF,CAUA,IAAIC,CAAAA,CAAwD,IAAA,CAuBrD,SAASC,EAAW3C,CAAAA,CAAwB,CACjD,GAAM,CACJ,OAAAyC,CAAAA,CACA,KAAA,CAAOG,CAAAA,CACP,OAAA,CAASC,EACT,IAAA,CAAMC,CAAAA,CACN,WAAA,CAAAC,GAAAA,CAAc,CAAE,QAAA,CAAU,GAAA,CAAK,OAAQ,UAAW,CAAA,CAClD,WAAAC,CAAAA,CAAa,CAAE,QAAA,CAAU,GAAA,CAAK,OAAQ,SAAU,CAAA,CAChD,YAAA,CAAAC,CAAAA,CACA,gBAAAC,CAAAA,CACA,WAAA,CAAAC,CAAAA,CACA,cAAA,CAAAC,EACA,QAAA,CAAAC,CACF,CAAA,CAAIrD,CAAAA,CAGEsD,IAAeb,CAAAA,CAASD,CAAAA,CAAmBC,CAAM,CAAA,CAAI,KACrDc,CAAAA,CAAQX,CAAAA,EAAeU,GAAAA,EAAc,KAAA,EAAS,EAAC,CAC/CE,CAAAA,CAAUX,CAAAA,EAAiBS,GAAAA,EAAc,SAAW,EAAC,CACrDG,EAAOX,CAAAA,EAAcQ,GAAAA,EAAc,MAAQ,EAAC,CAG9ChC,CAAAA,CAA8B,IAAA,CAC9BoC,EAAsC,IAAA,CAGpCC,CAAAA,CAAejB,CAAAA,EAAwB,aAAA,IAAmB,CAAA,CAC1DkB,CAAAA,CAAelB,CAAAA,EAAwB,YAAA,EAAgB,EACvDmB,CAAAA,CAAkBF,CAAAA,CAAeC,CAAAA,CAGvC,OAAAE,EAAU,SAAY,CAChBxC,CAAAA,EAAWoC,CAAAA,GACbP,KAAc,CAEd,MAAMO,CAAAA,CAAW,WAAA,CAAYD,EAAMT,CAAAA,CAAW,QAAA,CAAUA,CAAAA,CAAW,MAAM,EAEzEI,CAAAA,IAAiB,EAErB,CAAC,CAAA,CAGMW,CAAAA,CACL,MACA,CACE,KAAA,CAAO,CAAE,OAAA,CAAS,UAAW,CAAA,CAC7B,GAAA,CAAMC,CAAAA,EAA2B,CAC1BA,IAEL1C,CAAAA,CAAU0C,CAAAA,CACVN,CAAAA,CAAa,IAAIrC,EAAG2C,CAAE,CAAA,CAGtB,cAAA,CAAe,IAAM,CACfN,CAAAA,GACFT,CAAAA,IAAe,CAEfS,CAAAA,CAAW,QAAQ,CACjB,OAAA,CAASH,CAAAA,CACT,OAAA,CAASC,EACT,QAAA,CAAUT,GAAAA,CAAY,QAAA,CACtB,MAAA,CAAQA,IAAY,MAAA,CACpB,KAAA,CAAA,CAAQA,IAAY,KAAA,EAAS,CAAA,EAAKc,EAClC,mBAAA,CAAqBX,CACvB,CAAC,CAAA,EAEL,CAAC,CAAA,EACH,CACF,CAAA,CACAG,CACF,CACF,CA2BO,SAASY,CAAAA,CAAgBjE,CAAAA,CAA6B,CAC3D,GAAM,CAAE,OAAA,CAAAkE,CAAAA,CAAU,GAAI,QAAA,CAAAb,CAAS,CAAA,CAAIrD,CAAAA,CAE/BmE,EAAa,CAAA,CAEXC,CAAAA,CAAkC,CACtC,aAAA,CAAe,IAAMD,CAAAA,EAAAA,CACrB,YAAA,CAAcD,CAChB,CAAA,CAEA,OAAO,IAAM,CAEXC,EAAa,CAAA,CAGb,IAAME,EAAgB3B,CAAAA,CACtBA,CAAAA,CAAyB0B,CAAAA,CAEzB,GAAI,CACF,OAAOf,CACT,CAAA,OAAE,CACAX,EAAyB2B,EAC3B,CACF,CACF,KAKaC,CAAAA,CAAc,CACzB,IAAA,CAAM,CAAE,OAAQ,MAAO,CAAA,CACvB,OAAA,CAAS,CAAE,OAAQ,UAAW,CAAA,CAC9B,SAAA,CAAW,CAAE,OAAQ,YAAa,CAAA,CAClC,SAAA,CAAW,CAAE,OAAQ,YAAa,CAAA,CAClC,WAAY,CAAE,MAAA,CAAQ,aAAc,CAAA,CACpC,KAAA,CAAO,CAAE,MAAA,CAAQ,OAAQ,CAAA,CACzB,SAAA,CAAW,CAAE,MAAA,CAAQ,YAAa,CAAA,CAGlC,KAAA,CAAO,CACL,KAAA,CAAO,CAAE,OAAA,CAAS,CAAA,CAAG,KAAA,CAAO,GAAA,CAAM,EAAG,GAAI,CAAA,CACzC,OAAA,CAAS,CAAE,QAAS,CAAA,CAAG,KAAA,CAAO,CAAA,CAAG,CAAA,CAAG,CAAE,CAAA,CACtC,IAAA,CAAM,CAAE,OAAA,CAAS,EAAG,KAAA,CAAO,GAAA,CAAM,EAAG,EAAG,CAAA,CACvC,YAAa,CAAE,QAAA,CAAU,GAAA,CAAK,MAAA,CAAQ,+BAAgC,CAAA,CACtE,UAAA,CAAY,CAAE,QAAA,CAAU,IAAK,MAAA,CAAQ,SAAU,CACjD,CAAA,CAEA,SAAU,CACR,KAAA,CAAO,CAAE,OAAA,CAAS,EAAG,CAAA,CAAG,EAAA,CAAI,KAAA,CAAO,GAAK,EACxC,OAAA,CAAS,CAAE,OAAA,CAAS,CAAA,CAAG,EAAG,CAAA,CAAG,KAAA,CAAO,CAAE,CAAA,CACtC,KAAM,CAAE,OAAA,CAAS,EAAG,CAAA,CAAG,EAAA,CAAI,MAAO,GAAK,CAAA,CACvC,WAAA,CAAa,CAAE,SAAU,GAAA,CAAK,MAAA,CAAQ,UAAW,CAAA,CACjD,WAAY,CAAE,QAAA,CAAU,GAAA,CAAK,MAAA,CAAQ,SAAU,CACjD,CAAA,CAEA,OAAA,CAAS,CACP,MAAO,CAAE,OAAA,CAAS,CAAA,CAAG,KAAA,CAAO,EAAI,CAAA,CAChC,OAAA,CAAS,CAAE,OAAA,CAAS,EAAG,KAAA,CAAO,CAAE,CAAA,CAChC,IAAA,CAAM,CAAE,OAAA,CAAS,CAAA,CAAG,MAAO,EAAI,CAAA,CAC/B,YAAa,CAAE,QAAA,CAAU,GAAA,CAAK,MAAA,CAAQ,UAAW,CAAA,CACjD,UAAA,CAAY,CAAE,QAAA,CAAU,GAAI,MAAA,CAAQ,SAAU,CAChD,CAAA,CAEA,aAAc,CACZ,KAAA,CAAO,CAAE,OAAA,CAAS,EAAG,CAAA,CAAG,GAAI,CAAA,CAC5B,OAAA,CAAS,CAAE,OAAA,CAAS,CAAA,CAAG,CAAA,CAAG,CAAE,EAC5B,IAAA,CAAM,CAAE,OAAA,CAAS,CAAA,CAAG,EAAG,GAAI,CAAA,CAC3B,YAAa,CAAE,QAAA,CAAU,IAAK,MAAA,CAAQ,+BAAgC,CAAA,CACtE,UAAA,CAAY,CAAE,QAAA,CAAU,GAAA,CAAK,MAAA,CAAQ,SAAU,CACjD,CAAA,CAEA,IAAA,CAAM,CACJ,KAAA,CAAO,CAAE,OAAA,CAAS,CAAE,EACpB,OAAA,CAAS,CAAE,QAAS,CAAE,CAAA,CACtB,IAAA,CAAM,CAAE,QAAS,CAAE,CAAA,CACnB,WAAA,CAAa,CAAE,SAAU,GAAA,CAAK,MAAA,CAAQ,UAAW,CAAA,CACjD,WAAY,CAAE,QAAA,CAAU,IAAK,MAAA,CAAQ,SAAU,CACjD,CACF","file":"chunk-GQKN4NPW.mjs","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,2 +1,2 @@
|
|
|
1
|
-
import {e}from'./chunk-
|
|
2
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
import {e}from'./chunk-GFL4VRAO.mjs';function u(n){let e=Symbol("context"),t=r=>r.children;return t._contextId=e,{id:e,Provider:t,defaultValue:n}}function c(n){let e$1=e();if(e$1&&e$1.context){let t=e$1.context[n.id];if(t!==void 0)return t}return n.defaultValue}function l(n,e$1){let t=e();t&&(t.context||(t.context={}),t.context[n]=e$1);}export{u as a,c as b,l as c};//# sourceMappingURL=chunk-JDTJFAXO.mjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-JDTJFAXO.mjs.map
|
|
@@ -0,0 +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,GAAAA,CAAQC,CAAAA,EAAS,CACvB,GAAID,KAASA,GAAAA,CAAM,OAAA,CAAS,CAC1B,IAAME,EAAQF,GAAAA,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,GAAAA,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,GAAAA,EAExB","file":"chunk-JDTJFAXO.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,2 +1,2 @@
|
|
|
1
|
-
import {
|
|
2
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
import {m}from'./chunk-GFL4VRAO.mjs';function x(i){if(!i)return {};let n={};i.display&&(n.display=i.display),i.flex!==void 0&&(n.flex=i.flex),i.flexDirection&&(n.flexDirection=i.flexDirection),i.flexWrap&&(n.flexWrap=i.flexWrap),i.justifyContent&&(n.justifyContent=i.justifyContent),i.alignItems&&(n.alignItems=i.alignItems),i.alignSelf&&(n.alignSelf=i.alignSelf),i.gap!==void 0&&(n.gap=`${i.gap}px`),i.padding!==void 0&&(n.padding=`${i.padding}px`),i.paddingTop!==void 0&&(n.paddingTop=`${i.paddingTop}px`),i.paddingRight!==void 0&&(n.paddingRight=`${i.paddingRight}px`),i.paddingBottom!==void 0&&(n.paddingBottom=`${i.paddingBottom}px`),i.paddingLeft!==void 0&&(n.paddingLeft=`${i.paddingLeft}px`),i.paddingHorizontal!==void 0&&(n.paddingLeft=`${i.paddingHorizontal}px`,n.paddingRight=`${i.paddingHorizontal}px`),i.paddingVertical!==void 0&&(n.paddingTop=`${i.paddingVertical}px`,n.paddingBottom=`${i.paddingVertical}px`),i.margin!==void 0&&(n.margin=`${i.margin}px`),i.marginTop!==void 0&&(n.marginTop=`${i.marginTop}px`),i.marginRight!==void 0&&(n.marginRight=`${i.marginRight}px`),i.marginBottom!==void 0&&(n.marginBottom=`${i.marginBottom}px`),i.marginLeft!==void 0&&(n.marginLeft=`${i.marginLeft}px`),i.marginHorizontal!==void 0&&(n.marginLeft=`${i.marginHorizontal}px`,n.marginRight=`${i.marginHorizontal}px`),i.marginVertical!==void 0&&(n.marginTop=`${i.marginVertical}px`,n.marginBottom=`${i.marginVertical}px`),i.width!==void 0&&(n.width=typeof i.width=="number"?`${i.width}px`:i.width),i.height!==void 0&&(n.height=typeof i.height=="number"?`${i.height}px`:i.height),i.minWidth!==void 0&&(n.minWidth=`${i.minWidth}px`),i.maxWidth!==void 0&&(n.maxWidth=`${i.maxWidth}px`),i.minHeight!==void 0&&(n.minHeight=`${i.minHeight}px`),i.maxHeight!==void 0&&(n.maxHeight=`${i.maxHeight}px`),i.backgroundColor&&(n.backgroundColor=i.backgroundColor),i.borderRadius!==void 0&&(n.borderRadius=`${i.borderRadius}px`),i.borderTopLeftRadius!==void 0&&(n.borderTopLeftRadius=`${i.borderTopLeftRadius}px`),i.borderTopRightRadius!==void 0&&(n.borderTopRightRadius=`${i.borderTopRightRadius}px`),i.borderBottomLeftRadius!==void 0&&(n.borderBottomLeftRadius=`${i.borderBottomLeftRadius}px`),i.borderBottomRightRadius!==void 0&&(n.borderBottomRightRadius=`${i.borderBottomRightRadius}px`),i.opacity!==void 0&&(n.opacity=i.opacity),i.borderWidth!==void 0&&(n.borderWidth=`${i.borderWidth}px`),i.borderColor&&(n.borderColor=i.borderColor),i.borderTopWidth!==void 0&&(n.borderTopWidth=`${i.borderTopWidth}px`),i.borderRightWidth!==void 0&&(n.borderRightWidth=`${i.borderRightWidth}px`),i.borderBottomWidth!==void 0&&(n.borderBottomWidth=`${i.borderBottomWidth}px`),i.borderLeftWidth!==void 0&&(n.borderLeftWidth=`${i.borderLeftWidth}px`),i.position&&(n.position=i.position),i.top!==void 0&&(n.top=`${i.top}px`),i.right!==void 0&&(n.right=`${i.right}px`),i.bottom!==void 0&&(n.bottom=`${i.bottom}px`),i.left!==void 0&&(n.left=`${i.left}px`),i.zIndex!==void 0&&(n.zIndex=i.zIndex),i.transform&&(n.transform=i.transform);let o=i;return o.color&&(n.color=o.color),o.fontSize!==void 0&&(n.fontSize=`${o.fontSize}px`),o.fontWeight&&(n.fontWeight=o.fontWeight),o.fontFamily&&(n.fontFamily=o.fontFamily),o.fontStyle&&(n.fontStyle=o.fontStyle),o.textAlign&&(n.textAlign=o.textAlign),o.textDecoration&&(n.textDecoration=o.textDecoration),o.lineHeight!==void 0&&(n.lineHeight=`${o.lineHeight}px`),o.letterSpacing!==void 0&&(n.letterSpacing=`${o.letterSpacing}px`),n}function k(i){return m(i)}function e(i){return k(i)||i!==null&&typeof i=="object"&&"value"in i&&"peek"in i?i.value:i}function b(i,n,o,r){if(!n)return;let d=Array.isArray(n)?n:[n];for(let t of d)if(!(!t||!t.type))switch(t.type){case "canvas-rect":D(i,t.props);break;case "canvas-circle":W(i,t.props);break;case "canvas-path":C(i,t.props);break;case "canvas-text":S(i,t.props);break;case "canvas-line":v(i,t.props);break;case "canvas-arc":T(i,t.props);break}}function D(i,n){let o=e(n.x),r=e(n.y),d=e(n.width),t=e(n.height),a=e(n.fill),f=e(n.stroke),p=e(n.strokeWidth),g=e(n.opacity);i.save(),g!==void 0&&(i.globalAlpha=g),a&&(i.fillStyle=a,i.fillRect(o,r,d,t)),f&&(i.strokeStyle=f,i.lineWidth=p||1,i.strokeRect(o,r,d,t)),i.restore();}function W(i,n){let o=e(n.x),r=e(n.y),d=e(n.radius),t=e(n.fill),a=e(n.stroke),f=e(n.strokeWidth),p=e(n.opacity);i.save(),p!==void 0&&(i.globalAlpha=p),i.beginPath(),i.arc(o,r,d,0,2*Math.PI),t&&(i.fillStyle=t,i.fill()),a&&(i.strokeStyle=a,i.lineWidth=f||1,i.stroke()),i.restore();}function C(i,n){let o=e(n.d),r=e(n.fill),d=e(n.stroke),t=e(n.strokeWidth),a=e(n.opacity);i.save(),a!==void 0&&(i.globalAlpha=a);let f=new Path2D(o);r&&(i.fillStyle=r,i.fill(f)),d&&(i.strokeStyle=d,i.lineWidth=t||1,i.stroke(f)),i.restore();}function S(i,n){let o=e(n.x),r=e(n.y),d=e(n.text),t=e(n.fill),a=e(n.fontSize)||12,f=e(n.fontFamily)||"sans-serif",p=e(n.fontWeight)||"normal",g=e(n.textAlign)||"left",m=e(n.textBaseline)||"alphabetic";i.save(),i.font=`${p} ${a}px ${f}`,i.textAlign=g,i.textBaseline=m,t&&(i.fillStyle=t,i.fillText(d,o,r)),i.restore();}function v(i,n){let o=e(n.x1),r=e(n.y1),d=e(n.x2),t=e(n.y2),a=e(n.stroke)||"black",f=e(n.strokeWidth)||1,p=e(n.opacity);i.save(),p!==void 0&&(i.globalAlpha=p),i.beginPath(),i.moveTo(o,r),i.lineTo(d,t),i.strokeStyle=a,i.lineWidth=f,i.stroke(),i.restore();}function T(i,n){let o=e(n.x),r=e(n.y),d=e(n.radius),t=e(n.startAngle),a=e(n.endAngle),f=e(n.counterclockwise)||false,p=e(n.fill),g=e(n.stroke),m=e(n.strokeWidth),h=e(n.opacity);i.save(),h!==void 0&&(i.globalAlpha=h),i.beginPath(),i.arc(o,r,d,t,a,f),p&&(i.fillStyle=p,i.fill()),g&&(i.strokeStyle=g,i.lineWidth=m||1,i.stroke()),i.restore();}function N(i){let{width:n,height:o,children:r,style:d,id:t,...a}=i;return {type:"canvas",props:{...a,id:t,width:n,height:o,style:x(d),ref:f=>{if(!f||typeof requestAnimationFrame>"u")return;let p=f.getContext("2d");p&&import('./signal-HM2LG5YL.mjs').then(({effect:g,onCleanup:m,isSignal:h})=>{let c,R=()=>{c!==void 0&&cancelAnimationFrame(c),c=requestAnimationFrame(()=>{p.clearRect(0,0,n,o),b(p,r),c=void 0;});};g(()=>{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.value;}R(),m(()=>{c!==void 0&&(cancelAnimationFrame(c),c=void 0);});});}).catch(g=>{console.error("[Flexium Canvas] Failed to load signal module:",g);});}},children:[]}}function I(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,e as b,b as c,N as d,I as e,j as f,M as g,E as h,J as i,O as j};//# sourceMappingURL=chunk-LXXN76HJ.mjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-LXXN76HJ.mjs.map
|
|
@@ -1 +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","effect","onCleanup","rafId","scheduleRender","key","err","DrawRect","DrawCircle","DrawArc","DrawLine","DrawPath","DrawText"],"mappings":"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","file":"chunk-ZNPYN2TZ.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/signal'\nimport type { Signal } from '../../core/signal'\n\n/**\n * Check if a value is a Signal\n */\nexport function isSignal<T>(value: T | Signal<T>): value is Signal<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 | Signal<T>): T {\n // Check for real signals first (have SIGNAL_MARKER)\n if (isSignal(value)) {\n return value.value\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 // Render canvas children with effect for reactivity\n // Import effect and onCleanup dynamically to avoid circular deps\n import('../../core/signal')\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.value // 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
|
+
{"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","effect","onCleanup","rafId","scheduleRender","key","err","DrawRect","DrawCircle","DrawArc","DrawLine","DrawPath","DrawText"],"mappings":"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","file":"chunk-LXXN76HJ.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/signal'\nimport type { Signal } from '../../core/signal'\n\n/**\n * Check if a value is a Signal\n */\nexport function isSignal<T>(value: T | Signal<T>): value is Signal<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 | Signal<T>): T {\n // Check for real signals first (have SIGNAL_MARKER)\n if (isSignal(value)) {\n return value.value\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 // Render canvas children with effect for reactivity\n // Import effect and onCleanup dynamically to avoid circular deps\n import('../../core/signal')\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.value // 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,3 @@
|
|
|
1
|
+
'use strict';var i={EFFECT_EXECUTION_FAILED:"FLX101",CLEANUP_OUTSIDE_EFFECT:"FLX102",SIGNAL_UPDATE_DURING_RENDER:"FLX103",COMPUTED_EXECUTION_FAILED:"FLX104",CONTEXT_MISSING_PROVIDER:"FLX201",ROUTER_OUTSIDE_PROVIDER:"FLX202",FORM_VALIDATION_FAILED:"FLX301",FORM_SUBMISSION_FAILED:"FLX302",ASYNC_VALIDATION_FAILED:"FLX303",BUTTON_HANDLER_FAILED:"FLX401",BUTTON_MISSING_ARIA_LABEL:"FLX402",COMPONENT_RENDER_FAILED:"FLX403",HYDRATION_MISMATCH:"FLX501",HYDRATION_TEXT_MISMATCH:"FLX502",HYDRATION_TAG_MISMATCH:"FLX503",HYDRATION_ATTRIBUTE_MISMATCH:"FLX504",DEVTOOLS_LISTENER_ERROR:"FLX601",UNCAUGHT_RENDER_ERROR:"FLX701",ERROR_BOUNDARY_CALLBACK_FAILED:"FLX702",DOM_CLEANUP_FAILED:"FLX703",EVENT_HANDLER_FAILED:"FLX801",KEYBOARD_HANDLER_FAILED:"FLX802",RESOURCE_FETCH_FAILED:"FLX901",RESOURCE_TIMEOUT:"FLX902"};function K(n){return typeof process<"u"&&process.env?.NODE_ENV!=="production"?{[i.EFFECT_EXECUTION_FAILED]:{message:"Effect execution failed",suggestion:"Check the effect callback for runtime errors. Consider wrapping async operations in try-catch."},[i.CLEANUP_OUTSIDE_EFFECT]:{message:"onCleanup must be called from within an effect",suggestion:"Move the onCleanup() call inside an effect() callback."},[i.SIGNAL_UPDATE_DURING_RENDER]:{message:"Signal was updated during render",suggestion:"Avoid updating signals inside render functions. Use effect() for side effects."},[i.CONTEXT_MISSING_PROVIDER]:{message:"Context used outside of Provider",suggestion:"Wrap your component tree with the appropriate Context.Provider."},[i.ROUTER_OUTSIDE_PROVIDER]:{message:"router() must be used within a <Router> component",suggestion:"Ensure your component is a descendant of <Router>."},[i.FORM_VALIDATION_FAILED]:{message:"Form field validation failed",suggestion:"Check the validation rules for the field and the input value."},[i.FORM_SUBMISSION_FAILED]:{message:"Form submission failed",suggestion:"Check the onSubmit handler and network connectivity."},[i.BUTTON_HANDLER_FAILED]:{message:"Button press handler failed",suggestion:"Check the onPress/onClick callback for errors."},[i.BUTTON_MISSING_ARIA_LABEL]:{message:"IconButton is missing an aria-label",suggestion:"Add an aria-label prop to IconButton for screen reader accessibility."},[i.HYDRATION_MISMATCH]:{message:"Hydration mismatch detected",suggestion:"Ensure server and client render the same content. Check for browser-only code."},[i.HYDRATION_TEXT_MISMATCH]:{message:"Text content mismatch during hydration",suggestion:"Server and client rendered different text. Check for Date.now(), Math.random(), or client-only data."},[i.HYDRATION_TAG_MISMATCH]:{message:"Element tag mismatch during hydration",suggestion:"Server and client rendered different elements. Verify conditional rendering logic."},[i.DEVTOOLS_LISTENER_ERROR]:{message:"DevTools listener threw an error",suggestion:"Check your DevTools event listener callback."},[i.UNCAUGHT_RENDER_ERROR]:{message:"Uncaught error during render",suggestion:"Wrap components with <ErrorBoundary> to catch and handle errors gracefully."},[i.ERROR_BOUNDARY_CALLBACK_FAILED]:{message:"ErrorBoundary callback failed",suggestion:"Check your onError or onReset callback for errors."},[i.COMPUTED_EXECUTION_FAILED]:{message:"Computed value execution failed",suggestion:"Check the computed callback for runtime errors. Ensure all dependencies are valid."},[i.ASYNC_VALIDATION_FAILED]:{message:"Async form validation failed",suggestion:"Check the async validation function and ensure it handles errors properly."},[i.COMPONENT_RENDER_FAILED]:{message:"Component render failed",suggestion:"Check the component function for runtime errors. Consider wrapping with <ErrorBoundary>."},[i.HYDRATION_ATTRIBUTE_MISMATCH]:{message:"Attribute mismatch during hydration",suggestion:"Server and client rendered different attribute values. Check for dynamic attributes."},[i.DOM_CLEANUP_FAILED]:{message:"DOM cleanup operation failed",suggestion:"A node may have been removed from the DOM unexpectedly. Check for manual DOM manipulation."},[i.EVENT_HANDLER_FAILED]:{message:"Event handler threw an error",suggestion:"Check your event handler callback. Consider adding try-catch for async operations."},[i.KEYBOARD_HANDLER_FAILED]:{message:"Keyboard event handler failed",suggestion:"Check the onKeyDown/onKeyUp handler for errors."},[i.RESOURCE_FETCH_FAILED]:{message:"Resource fetch failed",suggestion:"Check the async function and network connectivity. The resource will show an error state."},[i.RESOURCE_TIMEOUT]:{message:"Resource fetch timed out",suggestion:"The async operation took too long. Consider adding a timeout handler or retry logic."}}[n]||{message:`Error ${n}`}:{message:`Minified Error ${n}`}}function B(n,e,t){let r=K(n);return {code:n,message:r.message,suggestion:r.suggestion,context:e,originalError:t}}function X(n){let e=`[Flexium ${n.code}] ${n.message}`;if(n.context&&Object.keys(n.context).length>0){let t=Object.entries(n.context).map(([r,o])=>`${r}: ${JSON.stringify(o)}`).join(", ");e+=` (${t})`;}return n.suggestion&&(e+=`
|
|
2
|
+
\u2192 ${n.suggestion}`),e}function P(n,e,t){let r=B(n,e,t),o=X(r);t?console.error(o,t):console.error(o);}function G(n,e){let t=B(n,e),r=X(t);console.warn(r);}var m;(o=>{let n=[],e=0;function t(s,u){if(e>0){let a=n[--e];return a.dep=s,a.sub=u,a.prevSub=void 0,a.nextSub=void 0,a.prevDep=void 0,a.nextDep=void 0,a}return {dep:s,sub:u,prevSub:void 0,nextSub:void 0,prevDep:void 0,nextDep:void 0}}o.alloc=t;function r(s){s.dep=void 0,s.sub=void 0,s.prevSub=void 0,s.nextSub=void 0,s.prevDep=void 0,s.nextDep=void 0,e<1e4&&(n[e++]=s);}o.free=r;})(m||(m={}));var c;(t=>{function n(r,o){let s=m.alloc(r,o),u=o.depsHead;s.nextDep=u,u&&(u.prevDep=s),o.depsHead=s;let a=r.subsHead;s.nextSub=a,a&&(a.prevSub=s),r.subsHead=s;}t.connect=n;function e(r){let o=r.depsHead;for(;o;){let s=o.dep,u=o.nextDep,a=o.prevSub,d=o.nextSub;a?a.nextSub=d:s.subsHead=d,d&&(d.prevSub=a),m.free(o),o=u;}r.depsHead=void 0;}t.disconnectDependencies=e;})(c||(c={}));var Y;(r=>{function n(o,s){return (o.flags&s)!==0}r.has=n;function e(o,s){o.flags|=s;}r.add=e;function t(o,s){o.flags&=~s;}r.remove=t;})(Y||(Y={}));var h=null;function p(){return h}function E(n){h=n;}function $(n){let e=h;h=null;try{return n()}finally{h=e;}}var f=null;function T(){return f}function O(n){f=n;}function j(n){let e=f,t={cleanups:[],context:e?Object.create(e.context):null,owner:e};f=t;let r=()=>{for(let o of t.cleanups)o();t.cleanups=[];};try{return n(r)}finally{f=e;}}function q(n){queueMicrotask(()=>{let e=n();e&&typeof e=="function"&&f&&f.cleanups.push(e);});}var b=0,A=new Set,S=new Set,R=false;function x(){R||(R=true,queueMicrotask(V));}function V(){if(R=false,S.size===0)return;let n=Array.from(S);S.clear();for(let e=0;e<n.length;e++)n[e].execute();}function C(n){S.add(n);}function L(n){A.add(n);}function k(){return b}function te(n){let e;if(n){b++;try{e=n();}finally{if(b--,b===0){let t=Array.from(A);A.clear();for(let r=0;r<t.length;r++)t[r].execute();}}}return V(),e}var F=class{constructor(e,t){this.fn=e;this.onError=t;this.cleanups=[];this.flags=0;this.nodeType=3;this.owner=null;this.owner=T();}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 r of this.cleanups)r();this.cleanups=[];}c.disconnectDependencies(this);let e=p(),t=T();E(this),O(this.owner);try{let r=this.fn();typeof r=="function"&&this.cleanups.push(r);}catch(r){this.onError?this.onError(r):P(i.EFFECT_EXECUTION_FAILED,void 0,r);}finally{E(e),O(t);}}dispose(){for(let e of this.cleanups)e();this.cleanups=[],c.disconnectDependencies(this);}};function w(n,e){let t=new F(n,e?.onError);t.execute();let r=()=>t.dispose(),o=T();return o&&o.cleanups.push(r),r}var g=null;function be(n){g=n;}var N=0,H=class{constructor(e){this._value=e;this.version=0;this.nodeType=1;}get(){let e=p();return e&&c.connect(this,e),this._value}set(e){this._value!==e&&(this._value=e,this.version=++N,this.notify());}peek(){return this._value}notify(){if(k()===0){if(this.subsHead){let e=false,t=this.subsHead;for(;t;){let r=t.sub;r.nodeType===2?r.execute():(C(r),e=true),t=t.nextSub;}e&&x();}}else {let e=this.subsHead;for(;e;)e.sub&&L(e.sub),e=e.nextSub;}}},U=class{constructor(e){this.computeFn=e;this.version=0;this.nodeType=2;this.flags=12;this.lastCleanEpoch=0;}execute(){this.flags|=12,this.notify();}_updateIfDirty(){let e=this.flags;if((e&12)===0)return;if((e&4)===0&&(e&8)!==0&&!this._needsRefetch()){this.flags&=-9;return}this.flags&=-13,c.disconnectDependencies(this);let r=p();E(this);try{let o=this.computeFn();this._value!==o&&(this._value=o,this.version=++N),this.lastCleanEpoch=N;}finally{E(r);}}_needsRefetch(){if(!this.depsHead)return true;let e=this.depsHead;for(;e;){let t=e.dep;if(t.version>this.lastCleanEpoch)return true;if(t.nodeType===2){let r=t;if(r.version>this.lastCleanEpoch||(r.flags&12)!==0&&(r.peek(),r.version>this.lastCleanEpoch))return true}e=e.nextDep;}return false}get(){let e=p();return e&&e!==this&&c.connect(this,e),(this.flags&12)!==0&&this._updateIfDirty(),this._value}peek(){return (this.flags&12)!==0&&this._updateIfDirty(),this._value}notify(){if(k()===0){if(this.subsHead){let e=false,t=this.subsHead;for(;t;){let r=t.sub;r.nodeType===2?r.execute():(C(r),e=true),t=t.nextSub;}e&&x();}}else {let e=this.subsHead;for(;e;)e.sub&&L(e.sub),e=e.nextSub;}}};function D(n){let e=new H(n),t=-1,r=function(){return e.get()};return Object.defineProperty(r,"value",{get(){return e.get()},set(o){e.set(o),t>=0&&g?.onSignalUpdate&&g.onSignalUpdate(t,o);},enumerable:true,configurable:true}),r.set=o=>{e.set(o),t>=0&&g?.onSignalUpdate&&g.onSignalUpdate(t,o);},r.peek=()=>e.peek(),r[I]=true,g?.onSignalCreate&&(t=g.onSignalCreate(r)),r}function Se(n){let e=new U(n),t=function(){return e.get()};return Object.defineProperty(t,"value",{get(){return e.get()},enumerable:true,configurable:true}),t.peek=()=>e.peek(),t[I]=true,t}var I=Symbol("flexium.signal");function Q(n){return n!==null&&typeof n=="function"&&I in n}function De(n){let e=p();e&&e.nodeType===3?e.cleanups.push(n):G(i.CLEANUP_OUTSIDE_EFFECT);}function Ie(n,e){let t=D(void 0),r=D(void 0),o=D(false),s=D("unresolved"),u=async(l,M=false)=>{M?(s.value="refreshing",o.value=true):(s.value="pending",o.value=true),r.value=void 0;let v=e(l,{value:t.peek(),refetching:M});a=v;try{let y=await v;a===v&&(t.value=y,s.value="ready",o.value=!1);}catch(y){a===v&&(r.value=y,s.value="errored",o.value=false);}},a=null,d=()=>typeof n=="function"?Q(n)?n.value:n():n;w(()=>{let l=d();u(l,false);});let _=function(){return t()};return Object.defineProperties(_,{value:{get:()=>t.value},loading:{get:()=>o.value},error:{get:()=>r.value},state:{get:()=>s.value},latest:{get:()=>t.peek()},peek:{value:()=>t.peek()},set:{value:l=>t.set(l)}}),_[I]=true,[_,{mutate:l=>t.set(l),refetch:()=>u(d(),true)}]}exports.a=i;exports.b=P;exports.c=G;exports.d=$;exports.e=T;exports.f=j;exports.g=q;exports.h=te;exports.i=w;exports.j=be;exports.k=D;exports.l=Se;exports.m=Q;exports.n=De;exports.o=Ie;//# sourceMappingURL=chunk-MKE3KA43.js.map
|
|
3
|
+
//# sourceMappingURL=chunk-MKE3KA43.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/core/errors.ts","../src/core/graph.ts","../src/core/owner.ts","../src/core/scheduler.ts","../src/core/effect.ts","../src/core/signal.ts"],"names":["ErrorCodes","getErrorDetails","code","createErrorInfo","context","originalError","details","formatErrorMessage","info","message","contextStr","key","value","logError","logWarning","LinkPool","pool","size","alloc","dep","sub","link","free","Graph","connect","depsHead","subsHead","disconnectDependencies","nextDep","prevSub","nextSub","Flags","has","obj","flag","add","remove","activeEffect","getActiveEffect","setActiveEffect","effect","untrack","fn","prev","owner","getOwner","setOwner","newOwner","root","prevOwner","dispose","cleanup","onMount","batchDepth","batchQueue","autoBatchQueue","isAutoBatchScheduled","scheduleAutoBatch","flushAutoBatch","queue","i","addToAutoBatch","addToBatch","getBatchDepth","sync","result","EffectNode","onError","prevEffect","error","options","node","devToolsHooks","setDevToolsHooks","hooks","globalVersion","SignalNode","_value","newValue","shouldSchedule","ComputedNode","computeFn","flags","computedDep","signal","initialValue","devToolsId","sig","SIGNAL_MARKER","computed","comp","isSignal","onCleanup","createResource","source","fetcher","loading","state","load","currentSource","refetching","currentPromise","latestPromise","err","getSource","resource","v"],"mappings":"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","file":"chunk-MKE3KA43.js","sourcesContent":["/**\n * Flexium Error System\n *\n * Standardized error handling with error codes, contextual information,\n * and actionable suggestions for developers.\n */\n\n// Error codes for all Flexium errors\nexport const ErrorCodes = {\n // Signal/Effect errors (1xx)\n EFFECT_EXECUTION_FAILED: 'FLX101',\n CLEANUP_OUTSIDE_EFFECT: 'FLX102',\n SIGNAL_UPDATE_DURING_RENDER: 'FLX103',\n COMPUTED_EXECUTION_FAILED: 'FLX104',\n\n // Context errors (2xx)\n CONTEXT_MISSING_PROVIDER: 'FLX201',\n ROUTER_OUTSIDE_PROVIDER: 'FLX202',\n\n // Form errors (3xx)\n FORM_VALIDATION_FAILED: 'FLX301',\n FORM_SUBMISSION_FAILED: 'FLX302',\n ASYNC_VALIDATION_FAILED: 'FLX303',\n\n // Component errors (4xx)\n BUTTON_HANDLER_FAILED: 'FLX401',\n BUTTON_MISSING_ARIA_LABEL: 'FLX402',\n COMPONENT_RENDER_FAILED: 'FLX403',\n\n // Hydration errors (5xx)\n HYDRATION_MISMATCH: 'FLX501',\n HYDRATION_TEXT_MISMATCH: 'FLX502',\n HYDRATION_TAG_MISMATCH: 'FLX503',\n HYDRATION_ATTRIBUTE_MISMATCH: 'FLX504',\n\n // DevTools errors (6xx)\n DEVTOOLS_LISTENER_ERROR: 'FLX601',\n\n // Render errors (7xx)\n UNCAUGHT_RENDER_ERROR: 'FLX701',\n ERROR_BOUNDARY_CALLBACK_FAILED: 'FLX702',\n DOM_CLEANUP_FAILED: 'FLX703',\n\n // Event errors (8xx)\n EVENT_HANDLER_FAILED: 'FLX801',\n KEYBOARD_HANDLER_FAILED: 'FLX802',\n\n // Resource/Async errors (9xx)\n RESOURCE_FETCH_FAILED: 'FLX901',\n RESOURCE_TIMEOUT: 'FLX902',\n} as const\n\nexport type ErrorCode = (typeof ErrorCodes)[keyof typeof ErrorCodes]\n\ninterface ErrorDefinition {\n message: string\n suggestion?: string\n}\n\n// Error message definitions with suggestions\n// Wrapped in a function to allow tree-shaking in production\nfunction getErrorDetails(code: ErrorCode): {\n message: string\n suggestion?: string\n} {\n const isDev = typeof process !== 'undefined' && process.env?.NODE_ENV !== 'production'\n if (isDev) {\n const errorDefinitions: Record<ErrorCode, ErrorDefinition> = {\n [ErrorCodes.EFFECT_EXECUTION_FAILED]: {\n message: 'Effect execution failed',\n suggestion:\n 'Check the effect callback for runtime errors. Consider wrapping async operations in try-catch.',\n },\n [ErrorCodes.CLEANUP_OUTSIDE_EFFECT]: {\n message: 'onCleanup must be called from within an effect',\n suggestion: 'Move the onCleanup() call inside an effect() callback.',\n },\n [ErrorCodes.SIGNAL_UPDATE_DURING_RENDER]: {\n message: 'Signal was updated during render',\n suggestion:\n 'Avoid updating signals inside render functions. Use effect() for side effects.',\n },\n [ErrorCodes.CONTEXT_MISSING_PROVIDER]: {\n message: 'Context used outside of Provider',\n suggestion:\n 'Wrap your component tree with the appropriate Context.Provider.',\n },\n [ErrorCodes.ROUTER_OUTSIDE_PROVIDER]: {\n message: 'router() must be used within a <Router> component',\n suggestion: 'Ensure your component is a descendant of <Router>.',\n },\n [ErrorCodes.FORM_VALIDATION_FAILED]: {\n message: 'Form field validation failed',\n suggestion:\n 'Check the validation rules for the field and the input value.',\n },\n [ErrorCodes.FORM_SUBMISSION_FAILED]: {\n message: 'Form submission failed',\n suggestion: 'Check the onSubmit handler and network connectivity.',\n },\n [ErrorCodes.BUTTON_HANDLER_FAILED]: {\n message: 'Button press handler failed',\n suggestion: 'Check the onPress/onClick callback for errors.',\n },\n [ErrorCodes.BUTTON_MISSING_ARIA_LABEL]: {\n message: 'IconButton is missing an aria-label',\n suggestion:\n 'Add an aria-label prop to IconButton for screen reader accessibility.',\n },\n [ErrorCodes.HYDRATION_MISMATCH]: {\n message: 'Hydration mismatch detected',\n suggestion:\n 'Ensure server and client render the same content. Check for browser-only code.',\n },\n [ErrorCodes.HYDRATION_TEXT_MISMATCH]: {\n message: 'Text content mismatch during hydration',\n suggestion:\n 'Server and client rendered different text. Check for Date.now(), Math.random(), or client-only data.',\n },\n [ErrorCodes.HYDRATION_TAG_MISMATCH]: {\n message: 'Element tag mismatch during hydration',\n suggestion:\n 'Server and client rendered different elements. Verify conditional rendering logic.',\n },\n [ErrorCodes.DEVTOOLS_LISTENER_ERROR]: {\n message: 'DevTools listener threw an error',\n suggestion: 'Check your DevTools event listener callback.',\n },\n [ErrorCodes.UNCAUGHT_RENDER_ERROR]: {\n message: 'Uncaught error during render',\n suggestion:\n 'Wrap components with <ErrorBoundary> to catch and handle errors gracefully.',\n },\n [ErrorCodes.ERROR_BOUNDARY_CALLBACK_FAILED]: {\n message: 'ErrorBoundary callback failed',\n suggestion: 'Check your onError or onReset callback for errors.',\n },\n [ErrorCodes.COMPUTED_EXECUTION_FAILED]: {\n message: 'Computed value execution failed',\n suggestion:\n 'Check the computed callback for runtime errors. Ensure all dependencies are valid.',\n },\n [ErrorCodes.ASYNC_VALIDATION_FAILED]: {\n message: 'Async form validation failed',\n suggestion:\n 'Check the async validation function and ensure it handles errors properly.',\n },\n [ErrorCodes.COMPONENT_RENDER_FAILED]: {\n message: 'Component render failed',\n suggestion:\n 'Check the component function for runtime errors. Consider wrapping with <ErrorBoundary>.',\n },\n [ErrorCodes.HYDRATION_ATTRIBUTE_MISMATCH]: {\n message: 'Attribute mismatch during hydration',\n suggestion:\n 'Server and client rendered different attribute values. Check for dynamic attributes.',\n },\n [ErrorCodes.DOM_CLEANUP_FAILED]: {\n message: 'DOM cleanup operation failed',\n suggestion:\n 'A node may have been removed from the DOM unexpectedly. Check for manual DOM manipulation.',\n },\n [ErrorCodes.EVENT_HANDLER_FAILED]: {\n message: 'Event handler threw an error',\n suggestion:\n 'Check your event handler callback. Consider adding try-catch for async operations.',\n },\n [ErrorCodes.KEYBOARD_HANDLER_FAILED]: {\n message: 'Keyboard event handler failed',\n suggestion: 'Check the onKeyDown/onKeyUp handler for errors.',\n },\n [ErrorCodes.RESOURCE_FETCH_FAILED]: {\n message: 'Resource fetch failed',\n suggestion:\n 'Check the async function and network connectivity. The resource will show an error state.',\n },\n [ErrorCodes.RESOURCE_TIMEOUT]: {\n message: 'Resource fetch timed out',\n suggestion:\n 'The async operation took too long. Consider adding a timeout handler or retry logic.',\n },\n }\n return errorDefinitions[code] || { message: `Error ${code}` }\n }\n return { message: `Minified Error ${code}` }\n}\n\nexport interface FlexiumErrorInfo {\n code: ErrorCode\n message: string\n suggestion?: string\n context?: Record<string, unknown>\n originalError?: unknown\n}\n\n/**\n * Create a standardized error info object\n */\nexport function createErrorInfo(\n code: ErrorCode,\n context?: Record<string, unknown>,\n originalError?: unknown\n): FlexiumErrorInfo {\n const details = getErrorDetails(code)\n return {\n code,\n message: details.message,\n suggestion: details.suggestion,\n context,\n originalError,\n }\n}\n\n/**\n * Format error message for console output\n */\nexport function formatErrorMessage(info: FlexiumErrorInfo): string {\n let message = `[Flexium ${info.code}] ${info.message}`\n\n if (info.context && Object.keys(info.context).length > 0) {\n const contextStr = Object.entries(info.context)\n .map(([key, value]) => `${key}: ${JSON.stringify(value)}`)\n .join(', ')\n message += ` (${contextStr})`\n }\n\n if (info.suggestion) {\n message += `\\n → ${info.suggestion}`\n }\n\n return message\n}\n\n/**\n * Log an error with standardized formatting\n */\nexport function logError(\n code: ErrorCode,\n context?: Record<string, unknown>,\n originalError?: unknown\n): void {\n const info = createErrorInfo(code, context, originalError)\n const message = formatErrorMessage(info)\n\n if (originalError) {\n console.error(message, originalError)\n } else {\n console.error(message)\n }\n}\n\n/**\n * Log a warning with standardized formatting\n */\nexport function logWarning(\n code: ErrorCode,\n context?: Record<string, unknown>\n): void {\n const info = createErrorInfo(code, context)\n const message = formatErrorMessage(info)\n console.warn(message)\n}\n\n/**\n * Create a FlexiumError with standardized information\n */\nexport class FlexiumError extends Error {\n code: ErrorCode\n suggestion?: string\n context?: Record<string, unknown>\n\n constructor(code: ErrorCode, context?: Record<string, unknown>) {\n const details = getErrorDetails(code)\n super(details.message)\n this.name = 'FlexiumError'\n this.code = code\n this.suggestion = details.suggestion\n this.context = context\n }\n\n toString(): string {\n return formatErrorMessage({\n code: this.code,\n message: this.message,\n suggestion: this.suggestion,\n context: this.context,\n })\n }\n}\n","/**\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","/**\n * Owner.ts\n *\n * Managing reactive scopes and cleanup contexts.\n */\n\n// ==================================================================================\n// 1. Owner & Scope Management\n// ==================================================================================\n\nexport interface Owner {\n cleanups: (() => void)[]\n context: Record<symbol, unknown> | null\n owner: Owner | null // Parent owner\n}\n\nimport type { ISubscriber } from './graph'\n\n// Global context for dependency tracking\nlet activeEffect: ISubscriber | null = null\n\nexport function getActiveEffect(): ISubscriber | null {\n return activeEffect\n}\n\nexport function setActiveEffect(effect: ISubscriber | null): void {\n activeEffect = effect\n}\n\n/**\n * Execute a function without tracking signal dependencies.\n * Useful when you need to read signals inside an effect without creating dependencies.\n *\n * @param fn - Function to execute without tracking\n * @returns The return value of fn\n */\nexport function untrack<T>(fn: () => T): T {\n const prev = activeEffect\n activeEffect = null\n try {\n return fn()\n } finally {\n activeEffect = prev\n }\n}\n\nlet owner: Owner | null = null\n\n/**\n * Get the current owner (scope)\n * @internal\n */\nexport function getOwner(): Owner | null {\n return owner\n}\n\n/**\n * Set the current owner (scope)\n * @internal\n */\nexport function setOwner(newOwner: Owner | null): void {\n owner = newOwner\n}\n\n/**\n * Creates a disposal scope.\n * The return value of the function is returned, and a dispose function is returned.\n *\n * @param fn - Function to run within a new root scope\n * @returns [return value of fn, dispose function]\n *\n * @example\n * ```tsx\n * const [val, dispose] = root((dispose) => {\n * effect(() => console.log('Inside root'));\n * return 123;\n * });\n * dispose(); // Cleans up all effects created inside\n * ```\n */\nexport function root<T>(fn: (dispose: () => void) => T): T {\n const prevOwner = owner\n const newOwner: Owner = {\n cleanups: [],\n context: prevOwner ? Object.create(prevOwner.context) : null,\n owner: prevOwner,\n }\n\n owner = newOwner\n\n const dispose = () => {\n for (const cleanup of newOwner.cleanups) {\n cleanup()\n }\n newOwner.cleanups = []\n }\n\n try {\n return fn(dispose)\n } finally {\n owner = prevOwner\n }\n}\n\n/**\n * Runs a function once when the component mounts.\n * Unlike effect(), onMount does not track dependencies - it runs exactly once.\n *\n * @param fn - Function to run on mount. Can return a cleanup function.\n */\nexport function onMount(fn: () => void | (() => void)): void {\n // Schedule the mount callback to run after the current execution\n // This ensures the component is fully rendered before mount runs\n queueMicrotask(() => {\n const cleanup = fn()\n\n // Register cleanup with owner if available\n if (cleanup && typeof cleanup === 'function' && owner) {\n owner.cleanups.push(cleanup)\n }\n })\n}\n","import { ISubscriber } from './graph'\n\n// Batching state\nlet batchDepth = 0\n// Batch queue now needs to store raw subscribers. Set is efficient for uniqueness.\nconst batchQueue = new Set<ISubscriber>()\n\n// Auto-batching state (Microtask Scheduler)\nconst autoBatchQueue = new Set<ISubscriber>()\nlet isAutoBatchScheduled = false\n\nexport function scheduleAutoBatch(): void {\n if (!isAutoBatchScheduled) {\n isAutoBatchScheduled = true\n queueMicrotask(flushAutoBatch)\n }\n}\n\nexport function flushAutoBatch(): void {\n isAutoBatchScheduled = false\n if (autoBatchQueue.size === 0) return\n\n // Performance: Convert Set to array instead of copying Set (faster)\n const queue = Array.from(autoBatchQueue)\n autoBatchQueue.clear()\n\n // Execute effects - use for loop instead of forEach (slightly faster)\n for (let i = 0; i < queue.length; i++) {\n queue[i].execute()\n }\n}\n\nexport function addToAutoBatch(sub: ISubscriber): void {\n autoBatchQueue.add(sub)\n}\n\nexport function addToBatch(sub: ISubscriber): void {\n batchQueue.add(sub)\n}\n\nexport function getBatchDepth(): number {\n return batchDepth\n}\n\n/**\n * Synchronizes state updates.\n * \n * - `sync()`: Force flushes any pending auto-batched effects.\n * - `sync(fn)`: Batches updates within `fn`, then flushes them and any pending effects synchronously.\n *\n * @param fn - Optional function containing state updates\n * @returns The return value of fn, if provided\n *\n * @example\n * ```tsx\n * // 1. Force flush pending effects\n * count.value++\n * sync() // DOM is now updated\n *\n * // 2. Batch updates and flush immediately\n * sync(() => {\n * count.value = 1\n * name.value = 'Bob'\n * }) // Effects run once here, DOM updated\n * ```\n */\nexport function sync<T>(fn?: () => T): T | void {\n let result: T | undefined\n\n if (fn) {\n batchDepth++\n try {\n result = fn()\n } finally {\n batchDepth--\n if (batchDepth === 0) {\n // Execute all queued subscribers from manual batch\n // Performance: Convert Set to array instead of copying Set (faster)\n const queue = Array.from(batchQueue)\n batchQueue.clear()\n // Use for loop instead of forEach (slightly faster)\n for (let i = 0; i < queue.length; i++) {\n queue[i].execute()\n }\n }\n }\n }\n\n // Always flushing auto-batch queue to ensure everything is synced\n flushAutoBatch()\n\n return result\n}\n","import { ErrorCodes, logError } from './errors'\nimport {\n Graph,\n Flags,\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\n/**\n * Internal effect node for dependency tracking\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 for (const cleanup of this.cleanups) {\n cleanup()\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 for (const cleanup of this.cleanups) {\n cleanup()\n }\n this.cleanups = []\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 * const count = signal(0);\n * const dispose = effect(() => {\n * console.log('Count:', count.value);\n * return () => console.log('Cleanup');\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 * Signal System - Fine-grained reactivity without VDOM\n *\n * Architecture:\n * - Signals are reactive primitives that notify subscribers on change\n * - Computed signals automatically track dependencies and memoize results\n * - Effects run side effects and auto-track dependencies\n * - Batching prevents cascading updates for performance\n */\n\nimport { ErrorCodes, logError, logWarning } from './errors'\nimport {\n Graph,\n Flags,\n type Link,\n type ISubscriber,\n type IObservable,\n SubscriberFlags,\n NodeType\n} from './graph'\nimport {\n type Owner,\n getOwner,\n setOwner,\n getActiveEffect,\n setActiveEffect,\n} from './owner'\nimport {\n scheduleAutoBatch,\n addToAutoBatch,\n addToBatch,\n getBatchDepth\n} from './scheduler'\nimport { EffectNode, effect } from './effect'\n\n/**\n * DevTools hooks interface - set by devtools module to avoid circular imports\n * @internal\n */\nexport interface DevToolsHooks {\n onSignalCreate?: (signal: Signal<unknown>, name?: string) => number\n onSignalUpdate?: (id: number, value: unknown) => void\n onEffectCreate?: (name?: string) => number\n onEffectRun?: (\n id: number,\n status: 'idle' | 'running' | 'error',\n error?: Error\n ) => void\n}\n\n// Global hooks registry - set by devtools when enabled\nlet devToolsHooks: DevToolsHooks | null = null\n\n/**\n * Register devtools hooks (called by devtools module)\n * @internal\n */\nexport function setDevToolsHooks(hooks: DevToolsHooks | null): void {\n devToolsHooks = hooks\n}\n\n// Global version clock for epoch-based validation (Optimization: Epochs)\nlet globalVersion = 0\n\n// ==================================================================================\n// 3. User Facing API\n// ==================================================================================\n\n/**\n * Base interface for reactive signals\n * @internal\n */\nexport interface Signal<T> {\n value: T;\n (): T\n set(value: T): void\n peek(): T\n}\n\n/**\n * Computed signal interface (read-only)\n * @internal\n */\nexport interface Computed<T> {\n readonly value: T;\n (): T\n peek(): T\n}\n\n\n\n/**\n * Internal signal node for writable signals\n */\nclass SignalNode<T> implements IObservable {\n // Performance: Hot path fields first (CPU cache line optimization)\n version = 0 // Frequently read\n nodeType = NodeType.Signal // Frequently checked\n subsHead: Link | undefined // Frequently accessed\n \n // Cold path field\n constructor(private _value: T) { }\n\n get(): T {\n // Track dependency if inside an effect or computed\n const activeEffect = getActiveEffect()\n if (activeEffect) {\n Graph.connect(this, activeEffect)\n }\n return this._value\n }\n\n set(newValue: T): void {\n if (this._value !== newValue) {\n this._value = newValue\n this.version = ++globalVersion\n this.notify()\n }\n }\n\n peek(): T {\n return this._value\n }\n\n notify(): void {\n // Performance: Branch prediction - check most common case first (no batch)\n if (getBatchDepth() === 0) {\n // Automatic microtask batch (most common path)\n if (this.subsHead) {\n let shouldSchedule = false\n let link: Link | undefined = this.subsHead\n\n while (link) {\n const sub = link.sub!\n // Performance: Use nodeType instead of instanceof (much faster)\n if (sub.nodeType === NodeType.Computed) {\n sub.execute() // Mark dirty immediately\n } else {\n addToAutoBatch(sub)\n shouldSchedule = true\n }\n link = link.nextSub\n }\n\n if (shouldSchedule) {\n scheduleAutoBatch()\n }\n }\n } else {\n // Manual batch: queue subscribers (less common path)\n let link = this.subsHead\n while (link) {\n if (link.sub) addToBatch(link.sub)\n link = link.nextSub\n }\n }\n }\n}\n\n/**\n * Internal computed node for derived values\n */\nclass ComputedNode<T> implements ISubscriber, IObservable {\n // Performance: Hot path fields first (CPU cache line optimization)\n version = 0 // Frequently read\n nodeType = NodeType.Computed // Frequently checked\n flags = SubscriberFlags.Dirty | SubscriberFlags.Stale // Frequently checked\n subsHead: Link | undefined // Frequently accessed\n depsHead: Link | undefined // Frequently accessed\n \n // Cold path fields\n private _value!: T\n // Optimization: Track last clean epoch to avoid redundant re-computation\n private lastCleanEpoch = 0\n\n constructor(private computeFn: () => T) { }\n\n execute(): void {\n // Performance: Inline bit operation instead of function call\n // When a dependency changes, mark as dirty and notify subscribers\n this.flags |= SubscriberFlags.Dirty | SubscriberFlags.Stale\n this.notify()\n }\n\n private _updateIfDirty(): void {\n // Performance: Inline flag checks for better branch prediction\n // 1. If not dirty and not stale, we are valid (most common case)\n // Note: This check is now done in peek()/get() for fast path, but kept here for safety\n const flags = this.flags\n const dirtyOrStale = flags & (SubscriberFlags.Dirty | SubscriberFlags.Stale)\n if (dirtyOrStale === 0) {\n return\n }\n\n // 2. If Stale but not Dirty, check dependencies\n // Performance: Single bit check instead of two function calls\n if ((flags & SubscriberFlags.Dirty) === 0 && (flags & SubscriberFlags.Stale) !== 0) {\n if (!this._needsRefetch()) {\n this.flags &= ~SubscriberFlags.Stale\n return\n }\n }\n\n // 3. Must re-compute\n // Performance: Single bit operation instead of function call\n this.flags &= ~(SubscriberFlags.Dirty | SubscriberFlags.Stale)\n\n // Clear previous dependencies via Graph helper\n Graph.disconnectDependencies(this)\n\n const prevEffect = getActiveEffect()\n // const prevOwner = getOwner() // Not used\n setActiveEffect(this)\n\n try {\n const newValue = this.computeFn()\n if (this._value !== newValue) {\n this._value = newValue\n this.version = ++globalVersion\n }\n this.lastCleanEpoch = globalVersion\n } finally {\n setActiveEffect(prevEffect)\n }\n\n // Actually, we need to import setActiveEffect at the top of the file\n // activeEffect = this -> setActiveEffect(this)\n // activeEffect = prevEffect -> setActiveEffect(prevEffect)\n // But since I am generating this chunk, let me check imports again.\n // I added getActiveEffect to imports. I need setActiveEffect too.\n\n // REVISING CHUNK content below to use imported function properly.\n // note: I must add setActiveEffect to imports in the first chunk.\n\n\n // For this specific Chunk:\n // We will use a hack here or I should update the first chunk to include setActiveEffect.\n // I'll update the first chunk in this tool call to include setActiveEffect.\n\n // import { setActiveEffect } from './owner'\n // ...\n // setActiveEffect(this)\n // ...\n // setActiveEffect(prevEffect)\n }\n\n private _needsRefetch(): boolean {\n if (!this.depsHead) return true;\n\n // Iterate dependencies via linked list\n let link: Link | undefined = this.depsHead\n while (link) {\n const dep = link.dep!\n if (dep.version > this.lastCleanEpoch) {\n return true\n }\n\n // Performance: Use nodeType instead of instanceof\n if (dep.nodeType === NodeType.Computed) {\n const computedDep = dep as ComputedNode<unknown>\n // Performance: Check version first before calling peek() (peek() may trigger computation)\n // If already updated, version will be greater than lastCleanEpoch\n if (computedDep.version > this.lastCleanEpoch) {\n return true\n }\n // Performance: Inline bit check instead of function call\n // Only call peek() if dirty/stale (will update version if needed)\n if ((computedDep.flags & (SubscriberFlags.Dirty | SubscriberFlags.Stale)) !== 0) {\n computedDep.peek()\n // Check version again after peek() (may have been updated)\n if (computedDep.version > this.lastCleanEpoch) {\n return true\n }\n }\n }\n link = link.nextDep\n }\n return false\n }\n\n get(): T {\n // Track dependency if inside an effect or computed\n const activeEffect = getActiveEffect()\n if (activeEffect && activeEffect !== this) {\n Graph.connect(this, activeEffect)\n }\n\n // Performance: Fast path - check if update needed before calling _updateIfDirty\n const flags = this.flags\n const dirtyOrStale = flags & (SubscriberFlags.Dirty | SubscriberFlags.Stale)\n if (dirtyOrStale !== 0) {\n this._updateIfDirty()\n }\n return this._value\n }\n\n peek(): T {\n // Performance: Fast path - check if update needed before calling _updateIfDirty\n const flags = this.flags\n const dirtyOrStale = flags & (SubscriberFlags.Dirty | SubscriberFlags.Stale)\n if (dirtyOrStale !== 0) {\n this._updateIfDirty()\n }\n return this._value\n }\n\n notify(): void {\n // Performance: Branch prediction - check most common case first (no batch)\n if (getBatchDepth() === 0) {\n // Automatic microtask batch (most common path)\n if (this.subsHead) {\n let shouldSchedule = false\n let link: Link | undefined = this.subsHead\n\n while (link) {\n const sub = link.sub!\n // Performance: Use nodeType instead of instanceof (much faster)\n if (sub.nodeType === NodeType.Computed) {\n sub.execute()\n } else {\n addToAutoBatch(sub)\n shouldSchedule = true\n }\n link = link.nextSub\n }\n\n if (shouldSchedule) {\n scheduleAutoBatch()\n }\n }\n } else {\n // Manual batch (less common path)\n let link = this.subsHead\n while (link) {\n if (link.sub) addToBatch(link.sub)\n link = link.nextSub\n }\n }\n }\n}\n\n\n\n\n\n/**\n * Creates a reactive signal\n *\n * @param initialValue - The initial value of the signal\n * @returns A signal object with value getter/setter\n *\n * @example\n * const count = signal(0);\n * count.value++; // triggers subscribers\n * console.log(count()); // alternative getter syntax\n */\nexport function signal<T>(initialValue: T): Signal<T> {\n const node = new SignalNode(initialValue)\n let devToolsId = -1\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const sig = function (this: any) {\n return node.get()\n } as Signal<T>\n\n Object.defineProperty(sig, 'value', {\n get() {\n return node.get()\n },\n set(newValue: T) {\n node.set(newValue)\n // Notify devtools of update\n if (devToolsId >= 0 && devToolsHooks?.onSignalUpdate) {\n devToolsHooks.onSignalUpdate(devToolsId, newValue)\n }\n },\n enumerable: true,\n configurable: true,\n })\n\n sig.set = (newValue: T) => {\n node.set(newValue)\n // Notify devtools of update\n if (devToolsId >= 0 && devToolsHooks?.onSignalUpdate) {\n devToolsHooks.onSignalUpdate(devToolsId, newValue)\n }\n }\n sig.peek = () => node.peek()\n\n // Mark as signal for detection\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ; (sig as any)[SIGNAL_MARKER] = true\n\n // Register with devtools if enabled\n if (devToolsHooks?.onSignalCreate) {\n devToolsId = devToolsHooks.onSignalCreate(sig as Signal<unknown>)\n }\n\n return sig\n}\n\n/**\n * Creates a computed signal (derived value)\n * @internal Use `state(() => ...)` instead\n */\nexport function computed<T>(fn: () => T): Computed<T> {\n const node = new ComputedNode(fn)\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const comp = function (this: any) {\n return node.get()\n } as Computed<T>\n\n Object.defineProperty(comp, 'value', {\n get() {\n return node.get()\n },\n enumerable: true,\n configurable: true,\n })\n\n comp.peek = () => node.peek()\n\n // Mark as signal for detection\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ; (comp as any)[SIGNAL_MARKER] = true\n\n return comp\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 * const count = signal(0);\n * const dispose = effect(() => {\n * console.log('Count:', count.value);\n * return () => console.log('Cleanup');\n * });\n */\n\n\n/**\n * Creates a root scope for effects\n * All effects created within the scope can be disposed together\n *\n * @param fn - Function that creates effects\n * @returns Dispose function for all effects in the scope\n */\n\n\n/**\n * Symbol to mark signals for detection\n * @internal\n */\nconst SIGNAL_MARKER = Symbol('flexium.signal')\n\n/**\n * Check if a value is a signal\n * @internal Use state() which handles all reactive patterns\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function isSignal(value: unknown): value is Signal<any> | Computed<any> {\n return value !== null && typeof value === 'function' && SIGNAL_MARKER in value\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\n/**\n * Resource interface for async data\n */\nexport interface Resource<T> extends Signal<T | undefined> {\n loading: boolean\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n error: any\n state: 'unresolved' | 'pending' | 'ready' | 'refreshing' | 'errored'\n latest: T | undefined\n}\n\n/**\n * Creates a resource for handling async data\n * @internal Use state(async () => ...) instead which returns [data, refetch, status, error]\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function createResource<T, S = any>(\n source: S | Signal<S> | (() => S),\n fetcher: (\n source: S,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n { value, refetching }: { value: T | undefined; refetching: any }\n ) => Promise<T>\n): [Resource<T>, { mutate: (v: T | undefined) => void; refetch: () => void }] {\n const value = signal<T | undefined>(undefined)\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const error = signal<any>(undefined)\n const loading = signal<boolean>(false)\n const state = signal<\n 'unresolved' | 'pending' | 'ready' | 'refreshing' | 'errored'\n >('unresolved')\n\n const load = async (currentSource: S, refetching = false) => {\n if (refetching) {\n state.value = 'refreshing'\n loading.value = true\n } else {\n state.value = 'pending'\n loading.value = true\n }\n error.value = undefined\n\n // Track the current promise to avoid race conditions\n // We use a local variable instead of a shared 'lastPromise'\n // because we only care about the latest execution within this closure scope\n // if we needed to support cancellation, we'd need more.\n // Actually, for race conditions we DO need to track the active promise ID or similar.\n // Let's use a simpler counter approach or just compare promise references if we kept track.\n // But since we are removing 'lastPromise' which was used for throwing, \n // we still need to handle race conditions (late resolve).\n\n // Re-introducing a local tracking mechanism just for race conditions\n const currentPromise = fetcher(currentSource, { value: value.peek(), refetching })\n // We need to store this on the closure to compare\n latestPromise = currentPromise\n\n try {\n const result = await currentPromise\n if (latestPromise === currentPromise) {\n value.value = result\n state.value = 'ready'\n loading.value = false\n }\n } catch (err) {\n if (latestPromise === currentPromise) {\n error.value = err\n state.value = 'errored'\n loading.value = false\n }\n }\n }\n\n let latestPromise: Promise<T> | null = null\n\n const getSource = () => {\n if (typeof source === 'function') {\n if (isSignal(source)) {\n return source.value\n }\n return (source as () => S)()\n }\n return source\n }\n\n // Track source changes\n effect(() => {\n const currentSource = getSource()\n load(currentSource, false)\n })\n\n const resource = function () {\n return value()\n } as Resource<T>\n\n Object.defineProperties(resource, {\n value: { get: () => value.value },\n loading: { get: () => loading.value },\n error: { get: () => error.value },\n state: { get: () => state.value },\n latest: { get: () => value.peek() },\n peek: { value: () => value.peek() },\n set: { value: (v: T) => value.set(v) },\n })\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ; (resource as any)[SIGNAL_MARKER] = true\n\n const actions = {\n mutate: (v: T | undefined) => value.set(v),\n refetch: () => load(getSource(), true),\n }\n\n return [resource, actions]\n}\n\n// Re-export commonly used functions for convenience\n// These are imported from other modules but re-exported here for backward compatibility\nexport { effect } from './effect'\nexport { root, onMount, untrack } from './owner'\n"]}
|