flexium 0.9.1 → 0.10.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (142) hide show
  1. package/README.md +14 -0
  2. package/dist/{DrawText-CJikXQjL.d.cts → DrawText-ccZrs3Xs.d.cts} +1 -1
  3. package/dist/{DrawText-Bvzl40Vi.d.ts → DrawText-ngwNNh8O.d.ts} +1 -1
  4. package/dist/advanced.d.cts +1 -1
  5. package/dist/advanced.d.ts +1 -1
  6. package/dist/advanced.js +1 -1
  7. package/dist/advanced.js.map +1 -1
  8. package/dist/advanced.mjs +1 -1
  9. package/dist/advanced.mjs.map +1 -1
  10. package/dist/canvas.d.cts +4 -4
  11. package/dist/canvas.d.ts +4 -4
  12. package/dist/canvas.js +1 -1
  13. package/dist/canvas.mjs +1 -1
  14. package/dist/chunk-3AWR7IKE.js +2 -0
  15. package/dist/chunk-3AWR7IKE.js.map +1 -0
  16. package/dist/chunk-3BQXIHYI.mjs +3 -0
  17. package/dist/chunk-3BQXIHYI.mjs.map +1 -0
  18. package/dist/chunk-5236IK5I.js +2 -0
  19. package/dist/chunk-5236IK5I.js.map +1 -0
  20. package/dist/{chunk-JHJHIMWD.js → chunk-63AW5ZOC.js} +2 -2
  21. package/dist/{chunk-JHJHIMWD.js.map → chunk-63AW5ZOC.js.map} +1 -1
  22. package/dist/chunk-6K44QCMT.mjs +3 -0
  23. package/dist/chunk-6K44QCMT.mjs.map +1 -0
  24. package/dist/chunk-7Q4UE442.mjs +2 -0
  25. package/dist/chunk-7Q4UE442.mjs.map +1 -0
  26. package/dist/chunk-AJT35P3Z.js +3 -0
  27. package/dist/chunk-AJT35P3Z.js.map +1 -0
  28. package/dist/chunk-AYQMU7XC.js +3 -0
  29. package/dist/chunk-AYQMU7XC.js.map +1 -0
  30. package/dist/chunk-B7VP6HBY.mjs +2 -0
  31. package/dist/chunk-B7VP6HBY.mjs.map +1 -0
  32. package/dist/{chunk-R5CS7UZG.mjs → chunk-BYHIHYRR.mjs} +2 -2
  33. package/dist/{chunk-R5CS7UZG.mjs.map → chunk-BYHIHYRR.mjs.map} +1 -1
  34. package/dist/chunk-HLPVL6EK.mjs +2 -0
  35. package/dist/{chunk-RUXAK74B.mjs.map → chunk-HLPVL6EK.mjs.map} +1 -1
  36. package/dist/{chunk-HDCPA76O.mjs → chunk-KJPIJNFH.mjs} +2 -2
  37. package/dist/chunk-KJPIJNFH.mjs.map +1 -0
  38. package/dist/chunk-PVPY55Z7.mjs +2 -0
  39. package/dist/{chunk-TRIEKNVZ.mjs.map → chunk-PVPY55Z7.mjs.map} +1 -1
  40. package/dist/chunk-Q7WT5IIF.mjs +3 -0
  41. package/dist/chunk-Q7WT5IIF.mjs.map +1 -0
  42. package/dist/chunk-S3EDPCYT.js +3 -0
  43. package/dist/chunk-S3EDPCYT.js.map +1 -0
  44. package/dist/{chunk-L4C5UBOX.js → chunk-WOHSSPKD.js} +2 -2
  45. package/dist/chunk-WOHSSPKD.js.map +1 -0
  46. package/dist/{chunk-DFG62GKW.js → chunk-WXEHDEIH.js} +2 -2
  47. package/dist/{chunk-DFG62GKW.js.map → chunk-WXEHDEIH.js.map} +1 -1
  48. package/dist/{chunk-3P6DMEGB.js → chunk-YDZ37ZZ4.js} +2 -2
  49. package/dist/{chunk-3P6DMEGB.js.map → chunk-YDZ37ZZ4.js.map} +1 -1
  50. package/dist/{components-D4WeooPi.d.ts → components-B7KQ8C-i.d.ts} +2 -2
  51. package/dist/{components-DZy2r6m5.d.cts → components-CxnAnbpI.d.cts} +2 -2
  52. package/dist/core.d.cts +48 -136
  53. package/dist/core.d.ts +48 -136
  54. package/dist/core.js +1 -1
  55. package/dist/core.mjs +1 -1
  56. package/dist/dom.d.cts +2 -2
  57. package/dist/dom.d.ts +2 -2
  58. package/dist/dom.js +1 -1
  59. package/dist/dom.js.map +1 -1
  60. package/dist/dom.mjs +1 -1
  61. package/dist/dom.mjs.map +1 -1
  62. package/dist/{effect-BlnnM1t5.d.cts → effect-14CxUU8r.d.cts} +8 -4
  63. package/dist/{effect-BlnnM1t5.d.ts → effect-14CxUU8r.d.ts} +8 -4
  64. package/dist/effect-3LUCHSAZ.mjs +2 -0
  65. package/dist/effect-3LUCHSAZ.mjs.map +1 -0
  66. package/dist/effect-K45UU3N4.js +2 -0
  67. package/dist/effect-K45UU3N4.js.map +1 -0
  68. package/dist/index.d.cts +1 -1
  69. package/dist/index.d.ts +1 -1
  70. package/dist/index.js +1 -1
  71. package/dist/index.js.map +1 -1
  72. package/dist/index.mjs +1 -1
  73. package/dist/index.mjs.map +1 -1
  74. package/dist/interactive.d.cts +15 -10
  75. package/dist/interactive.d.ts +15 -10
  76. package/dist/interactive.js +1 -1
  77. package/dist/interactive.js.map +1 -1
  78. package/dist/interactive.mjs +1 -1
  79. package/dist/interactive.mjs.map +1 -1
  80. package/dist/metafile-cjs.json +1 -1
  81. package/dist/metafile-esm.json +1 -1
  82. package/dist/{portal-C3ESJhlv.d.ts → portal-CVqrpmHd.d.ts} +2 -2
  83. package/dist/{portal-CAEbiMUZ.d.cts → portal-NLlE-fNZ.d.cts} +2 -2
  84. package/dist/primitives/layout.js +1 -1
  85. package/dist/primitives/layout.mjs +1 -1
  86. package/dist/primitives/motion.js +1 -1
  87. package/dist/primitives/motion.mjs +1 -1
  88. package/dist/primitives/ui.d.cts +3 -3
  89. package/dist/primitives/ui.d.ts +3 -3
  90. package/dist/primitives/ui.js +1 -1
  91. package/dist/primitives/ui.js.map +1 -1
  92. package/dist/primitives/ui.mjs +1 -1
  93. package/dist/primitives/ui.mjs.map +1 -1
  94. package/dist/primitives.d.cts +4 -4
  95. package/dist/primitives.d.ts +4 -4
  96. package/dist/primitives.js +1 -1
  97. package/dist/primitives.js.map +1 -1
  98. package/dist/primitives.mjs +1 -1
  99. package/dist/primitives.mjs.map +1 -1
  100. package/dist/router.d.cts +3 -3
  101. package/dist/router.d.ts +3 -3
  102. package/dist/router.js +1 -1
  103. package/dist/router.mjs +1 -1
  104. package/dist/server.js +1 -1
  105. package/dist/server.js.map +1 -1
  106. package/dist/server.mjs +1 -1
  107. package/dist/server.mjs.map +1 -1
  108. package/dist/signal-2QUI7H7B.js +2 -0
  109. package/dist/{signal-3YZHUCLL.js.map → signal-2QUI7H7B.js.map} +1 -1
  110. package/dist/signal-C6936A3J.d.cts +175 -0
  111. package/dist/signal-C6936A3J.d.ts +175 -0
  112. package/dist/signal-L3ZWGOVT.mjs +2 -0
  113. package/dist/{signal-F2HEYB6F.mjs.map → signal-L3ZWGOVT.mjs.map} +1 -1
  114. package/dist/test-exports.d.cts +6 -6
  115. package/dist/test-exports.d.ts +6 -6
  116. package/dist/test-exports.js +1 -1
  117. package/dist/test-exports.mjs +1 -1
  118. package/package.json +2 -1
  119. package/dist/chunk-2ZHUQBNI.mjs +0 -2
  120. package/dist/chunk-2ZHUQBNI.mjs.map +0 -1
  121. package/dist/chunk-HDCPA76O.mjs.map +0 -1
  122. package/dist/chunk-J4CK5NRW.mjs +0 -3
  123. package/dist/chunk-J4CK5NRW.mjs.map +0 -1
  124. package/dist/chunk-JEDCNAAI.mjs +0 -3
  125. package/dist/chunk-JEDCNAAI.mjs.map +0 -1
  126. package/dist/chunk-L4C5UBOX.js.map +0 -1
  127. package/dist/chunk-M4ANLZ6P.js +0 -3
  128. package/dist/chunk-M4ANLZ6P.js.map +0 -1
  129. package/dist/chunk-RDA77IE6.js +0 -2
  130. package/dist/chunk-RDA77IE6.js.map +0 -1
  131. package/dist/chunk-RUXAK74B.mjs +0 -2
  132. package/dist/chunk-TRIEKNVZ.mjs +0 -2
  133. package/dist/chunk-VIVO4FHN.js +0 -3
  134. package/dist/chunk-VIVO4FHN.js.map +0 -1
  135. package/dist/chunk-XLE6SMWX.mjs +0 -3
  136. package/dist/chunk-XLE6SMWX.mjs.map +0 -1
  137. package/dist/chunk-YGMMJWAA.js +0 -3
  138. package/dist/chunk-YGMMJWAA.js.map +0 -1
  139. package/dist/signal-3YZHUCLL.js +0 -2
  140. package/dist/signal-Dxh9PsKr.d.cts +0 -69
  141. package/dist/signal-Dxh9PsKr.d.ts +0 -69
  142. package/dist/signal-F2HEYB6F.mjs +0 -2
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/core/errors.ts","../src/core/graph.ts","../src/core/owner.ts","../src/core/sync.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","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","hasScheduled","ComputedNode","computeFn","flags","computedDep","oldVersion","shouldSchedule","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-YGMMJWAA.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 // Performance: Fast path when no cleanups\n if (newOwner.cleanups.length === 0) return\n \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","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: Direct iteration instead of Array.from() to avoid array allocation\n // Build array while iterating Set\n const queue: ISubscriber[] = []\n for (const sub of autoBatchQueue) {\n queue.push(sub)\n }\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: Direct iteration instead of Array.from() to avoid array allocation\n const queue: ISubscriber[] = []\n for (const sub of batchQueue) {\n queue.push(sub)\n }\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 // Performance: Run cleanups in reverse order (most recent first)\n // This ensures proper dependency cleanup order and matches React's behavior\n for (let i = this.cleanups.length - 1; i >= 0; i--) {\n this.cleanups[i]()\n }\n this.cleanups = []\n }\n\n // Clean up previous dependencies via Graph helper\n Graph.disconnectDependencies(this)\n\n const prevEffect = getActiveEffect()\n const prevOwner = getOwner()\n setActiveEffect(this)\n setOwner(this.owner)\n\n try {\n const result = this.fn()\n if (typeof result === 'function') {\n this.cleanups.push(result)\n }\n } catch (error) {\n if (this.onError) {\n this.onError(error as Error)\n } else {\n logError(ErrorCodes.EFFECT_EXECUTION_FAILED, undefined, error)\n }\n } finally {\n setActiveEffect(prevEffect)\n setOwner(prevOwner)\n }\n }\n\n dispose(): void {\n // Performance: Run cleanups in reverse order (most recent first)\n // This ensures proper dependency cleanup order\n if (this.cleanups.length > 0) {\n for (let i = this.cleanups.length - 1; i >= 0; i--) {\n this.cleanups[i]()\n }\n this.cleanups = []\n }\n Graph.disconnectDependencies(this)\n }\n}\n\n/**\n * Creates a side effect that runs when dependencies change\n *\n * @param fn - Effect function, can return a cleanup function\n * @param options - Optional error handler\n * @returns Dispose function to stop the effect\n *\n * @example\n * 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 './sync'\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 // Performance: Schedule immediately on first non-computed subscriber\n let hasScheduled = 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 if (!hasScheduled) {\n hasScheduled = true\n scheduleAutoBatch() // Schedule on first non-computed subscriber\n }\n }\n link = link.nextSub\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 \n // Performance: Check version first (fastest check, avoids type check for most cases)\n if (dep.version > this.lastCleanEpoch) {\n return true\n }\n\n // Performance: Use nodeType instead of instanceof\n // Only check computed dependencies if version check passed (less common case)\n if (dep.nodeType === NodeType.Computed) {\n const computedDep = dep as ComputedNode<unknown>\n \n // Performance: Check if dirty/stale before calling peek() (peek() may trigger computation)\n // Only call peek() if actually needs update\n const flags = computedDep.flags\n const isDirtyOrStale = (flags & (SubscriberFlags.Dirty | SubscriberFlags.Stale)) !== 0\n \n if (isDirtyOrStale) {\n // Performance: Track version before peek() to detect if it actually updated\n const oldVersion = computedDep.version\n computedDep.peek()\n // Only check version again if peek() actually updated it (version changed)\n // This avoids redundant comparison when peek() didn't change anything\n if (computedDep.version !== oldVersion && 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 // Performance: Check devToolsId first (most signals don't have devtools)\n // Then check hooks existence (short-circuit if null)\n if (devToolsId >= 0) {\n const hooks = devToolsHooks\n if (hooks?.onSignalUpdate) {\n hooks.onSignalUpdate(devToolsId, newValue)\n }\n }\n },\n enumerable: true,\n configurable: true,\n })\n\n sig.set = (newValue: T) => {\n node.set(newValue)\n // Performance: Check devToolsId first (most signals don't have devtools)\n // Then check hooks existence (short-circuit if null)\n if (devToolsId >= 0) {\n const hooks = devToolsHooks\n if (hooks?.onSignalUpdate) {\n hooks.onSignalUpdate(devToolsId, newValue)\n }\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 // Performance: Cache hooks check to avoid repeated optional chaining\n // Register with devtools if enabled\n const hooks = devToolsHooks\n if (hooks?.onSignalCreate) {\n devToolsId = hooks.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, untrack } from './owner'\n"]}
@@ -1,2 +0,0 @@
1
- 'use strict';var chunkYGMMJWAA_js=require('./chunk-YGMMJWAA.js');Object.defineProperty(exports,"computed",{enumerable:true,get:function(){return chunkYGMMJWAA_js.k}});Object.defineProperty(exports,"createResource",{enumerable:true,get:function(){return chunkYGMMJWAA_js.n}});Object.defineProperty(exports,"effect",{enumerable:true,get:function(){return chunkYGMMJWAA_js.h}});Object.defineProperty(exports,"isSignal",{enumerable:true,get:function(){return chunkYGMMJWAA_js.l}});Object.defineProperty(exports,"onCleanup",{enumerable:true,get:function(){return chunkYGMMJWAA_js.m}});Object.defineProperty(exports,"root",{enumerable:true,get:function(){return chunkYGMMJWAA_js.f}});Object.defineProperty(exports,"setDevToolsHooks",{enumerable:true,get:function(){return chunkYGMMJWAA_js.i}});Object.defineProperty(exports,"signal",{enumerable:true,get:function(){return chunkYGMMJWAA_js.j}});Object.defineProperty(exports,"untrack",{enumerable:true,get:function(){return chunkYGMMJWAA_js.d}});//# sourceMappingURL=signal-3YZHUCLL.js.map
2
- //# sourceMappingURL=signal-3YZHUCLL.js.map
@@ -1,69 +0,0 @@
1
- /**
2
- * Base interface for reactive signals
3
- * @internal
4
- */
5
- interface Signal<T> {
6
- value: T;
7
- (): T;
8
- set(value: T): void;
9
- peek(): T;
10
- }
11
- /**
12
- * Computed signal interface (read-only)
13
- * @internal
14
- */
15
- interface Computed<T> {
16
- readonly value: T;
17
- (): T;
18
- peek(): T;
19
- }
20
- /**
21
- * Creates a reactive signal
22
- *
23
- * @param initialValue - The initial value of the signal
24
- * @returns A signal object with value getter/setter
25
- *
26
- * @example
27
- * const count = signal(0);
28
- * count.value++; // triggers subscribers
29
- * console.log(count()); // alternative getter syntax
30
- */
31
- declare function signal<T>(initialValue: T): Signal<T>;
32
- /**
33
- * Creates a computed signal (derived value)
34
- * @internal Use `state(() => ...)` instead
35
- */
36
- declare function computed<T>(fn: () => T): Computed<T>;
37
- /**
38
- * Check if a value is a signal
39
- * @internal Use state() which handles all reactive patterns
40
- */
41
- declare function isSignal(value: unknown): value is Signal<any> | Computed<any>;
42
- /**
43
- * Registers a cleanup function that runs before the current effect re-runs or is disposed
44
- *
45
- * @param fn - Cleanup function
46
- */
47
- declare function onCleanup(fn: () => void): void;
48
- /**
49
- * Resource interface for async data
50
- */
51
- interface Resource<T> extends Signal<T | undefined> {
52
- loading: boolean;
53
- error: any;
54
- state: 'unresolved' | 'pending' | 'ready' | 'refreshing' | 'errored';
55
- latest: T | undefined;
56
- }
57
- /**
58
- * Creates a resource for handling async data
59
- * @internal Use state(async () => ...) instead which returns [data, refetch, status, error]
60
- */
61
- declare function createResource<T, S = any>(source: S | Signal<S> | (() => S), fetcher: (source: S, { value, refetching }: {
62
- value: T | undefined;
63
- refetching: any;
64
- }) => Promise<T>): [Resource<T>, {
65
- mutate: (v: T | undefined) => void;
66
- refetch: () => void;
67
- }];
68
-
69
- export { type Computed as C, type Signal as S, createResource as a, computed as c, isSignal as i, onCleanup as o, signal as s };
@@ -1,69 +0,0 @@
1
- /**
2
- * Base interface for reactive signals
3
- * @internal
4
- */
5
- interface Signal<T> {
6
- value: T;
7
- (): T;
8
- set(value: T): void;
9
- peek(): T;
10
- }
11
- /**
12
- * Computed signal interface (read-only)
13
- * @internal
14
- */
15
- interface Computed<T> {
16
- readonly value: T;
17
- (): T;
18
- peek(): T;
19
- }
20
- /**
21
- * Creates a reactive signal
22
- *
23
- * @param initialValue - The initial value of the signal
24
- * @returns A signal object with value getter/setter
25
- *
26
- * @example
27
- * const count = signal(0);
28
- * count.value++; // triggers subscribers
29
- * console.log(count()); // alternative getter syntax
30
- */
31
- declare function signal<T>(initialValue: T): Signal<T>;
32
- /**
33
- * Creates a computed signal (derived value)
34
- * @internal Use `state(() => ...)` instead
35
- */
36
- declare function computed<T>(fn: () => T): Computed<T>;
37
- /**
38
- * Check if a value is a signal
39
- * @internal Use state() which handles all reactive patterns
40
- */
41
- declare function isSignal(value: unknown): value is Signal<any> | Computed<any>;
42
- /**
43
- * Registers a cleanup function that runs before the current effect re-runs or is disposed
44
- *
45
- * @param fn - Cleanup function
46
- */
47
- declare function onCleanup(fn: () => void): void;
48
- /**
49
- * Resource interface for async data
50
- */
51
- interface Resource<T> extends Signal<T | undefined> {
52
- loading: boolean;
53
- error: any;
54
- state: 'unresolved' | 'pending' | 'ready' | 'refreshing' | 'errored';
55
- latest: T | undefined;
56
- }
57
- /**
58
- * Creates a resource for handling async data
59
- * @internal Use state(async () => ...) instead which returns [data, refetch, status, error]
60
- */
61
- declare function createResource<T, S = any>(source: S | Signal<S> | (() => S), fetcher: (source: S, { value, refetching }: {
62
- value: T | undefined;
63
- refetching: any;
64
- }) => Promise<T>): [Resource<T>, {
65
- mutate: (v: T | undefined) => void;
66
- refetch: () => void;
67
- }];
68
-
69
- export { type Computed as C, type Signal as S, createResource as a, computed as c, isSignal as i, onCleanup as o, signal as s };
@@ -1,2 +0,0 @@
1
- export{k as computed,n as createResource,h as effect,l as isSignal,m as onCleanup,f as root,i as setDevToolsHooks,j as signal,d as untrack}from'./chunk-J4CK5NRW.mjs';//# sourceMappingURL=signal-F2HEYB6F.mjs.map
2
- //# sourceMappingURL=signal-F2HEYB6F.mjs.map