@akashjs/runtime 0.1.28 → 0.1.29

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 (55) hide show
  1. package/dist/{chunk-TYDY46CL.js → chunk-367DJVST.js} +3 -3
  2. package/dist/{chunk-TYDY46CL.js.map → chunk-367DJVST.js.map} +1 -1
  3. package/dist/chunk-4PK4YNND.js +2 -0
  4. package/dist/{chunk-LR2QY7QP.js.map → chunk-4PK4YNND.js.map} +1 -1
  5. package/dist/chunk-5NJYYK3Q.js +2 -0
  6. package/dist/{chunk-WEPYZZSS.js.map → chunk-5NJYYK3Q.js.map} +1 -1
  7. package/dist/{chunk-QEA2QRNB.cjs → chunk-A3VPGLBN.cjs} +2 -2
  8. package/dist/{chunk-QEA2QRNB.cjs.map → chunk-A3VPGLBN.cjs.map} +1 -1
  9. package/dist/{chunk-JMPZTCEE.js → chunk-CEJF44LZ.js} +2 -2
  10. package/dist/{chunk-JMPZTCEE.js.map → chunk-CEJF44LZ.js.map} +1 -1
  11. package/dist/{chunk-NIA62JQ5.cjs → chunk-JSBB2VV3.cjs} +2 -2
  12. package/dist/{chunk-NIA62JQ5.cjs.map → chunk-JSBB2VV3.cjs.map} +1 -1
  13. package/dist/chunk-RTJ6UDGV.cjs +13 -0
  14. package/dist/chunk-RTJ6UDGV.cjs.map +1 -0
  15. package/dist/{chunk-Y6NQXWYS.cjs → chunk-TBCX5WQQ.cjs} +3 -3
  16. package/dist/{chunk-Y6NQXWYS.cjs.map → chunk-TBCX5WQQ.cjs.map} +1 -1
  17. package/dist/{chunk-NEVUOTBQ.js → chunk-TS5UKZTG.js} +2 -2
  18. package/dist/{chunk-NEVUOTBQ.js.map → chunk-TS5UKZTG.js.map} +1 -1
  19. package/dist/chunk-TWA4T6PX.js +13 -0
  20. package/dist/chunk-TWA4T6PX.js.map +1 -0
  21. package/dist/{chunk-H4LBIF5X.cjs → chunk-VBAO65QP.cjs} +2 -2
  22. package/dist/{chunk-H4LBIF5X.cjs.map → chunk-VBAO65QP.cjs.map} +1 -1
  23. package/dist/{chunk-6ZQNSNL4.js → chunk-WG5GKD3B.js} +3 -3
  24. package/dist/{chunk-6ZQNSNL4.js.map → chunk-WG5GKD3B.js.map} +1 -1
  25. package/dist/{chunk-XLHWCP6E.cjs → chunk-YIVBLM2A.cjs} +3 -3
  26. package/dist/{chunk-XLHWCP6E.cjs.map → chunk-YIVBLM2A.cjs.map} +1 -1
  27. package/dist/{chunk-VBLTST4K.cjs → chunk-YN2TQLVA.cjs} +2 -2
  28. package/dist/{chunk-VBLTST4K.cjs.map → chunk-YN2TQLVA.cjs.map} +1 -1
  29. package/dist/core.cjs +1 -1
  30. package/dist/core.js +1 -1
  31. package/dist/index.cjs +10 -21
  32. package/dist/index.cjs.map +1 -1
  33. package/dist/index.js +10 -21
  34. package/dist/index.js.map +1 -1
  35. package/dist/machine.cjs +1 -1
  36. package/dist/machine.js +1 -1
  37. package/dist/offline.cjs +1 -1
  38. package/dist/offline.js +1 -1
  39. package/dist/pwa.cjs +1 -1
  40. package/dist/pwa.js +1 -1
  41. package/dist/ssr.cjs +1 -1
  42. package/dist/ssr.js +1 -1
  43. package/dist/store.cjs +1 -1
  44. package/dist/store.js +1 -1
  45. package/dist/sync.cjs +1 -1
  46. package/dist/sync.js +1 -1
  47. package/dist/test.cjs +1 -1
  48. package/dist/test.js +1 -1
  49. package/package.json +1 -1
  50. package/dist/chunk-JBHFILMZ.js +0 -2
  51. package/dist/chunk-JBHFILMZ.js.map +0 -1
  52. package/dist/chunk-L4DNCDUA.cjs +0 -2
  53. package/dist/chunk-L4DNCDUA.cjs.map +0 -1
  54. package/dist/chunk-LR2QY7QP.js +0 -2
  55. package/dist/chunk-WEPYZZSS.js +0 -2
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/pwa.ts"],"names":["registerServiceWorker","swUrl","options","registered","signal","updateAvailable","offline","registration","ready","resolve","reject","reg","newWorker","err","generateSWScript","routes","script","route","pattern","cacheName","generateStrategyCode","strategy","subscribePush","vapidPublicKey","urlBase64ToUint8Array","base64String","padding","base64","rawData","char"],"mappings":"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","file":"chunk-6ZQNSNL4.js","sourcesContent":["/**\n * PWA / Service Worker support.\n *\n * Register service workers, configure caching strategies,\n * handle updates, and manage push notifications.\n *\n * ```ts\n * const sw = registerServiceWorker('/sw.js', {\n * onUpdate: () => toast.info('New version available!'),\n * });\n * sw.ready; // Promise<ServiceWorkerRegistration>\n * sw.update(); // check for updates\n * ```\n */\n\nimport { signal } from './signals.js';\nimport type { ReadonlySignal } from './signals.js';\n\n// =========================================================================\n// Types\n// =========================================================================\n\nexport interface SWOptions {\n /** Callback when a new version is available */\n onUpdate?: (registration: ServiceWorkerRegistration) => void;\n /** Callback when the SW is ready */\n onReady?: (registration: ServiceWorkerRegistration) => void;\n /** Callback on registration error */\n onError?: (error: Error) => void;\n /** Auto-reload on update (default: false) */\n autoReload?: boolean;\n /** Scope of the service worker */\n scope?: string;\n}\n\nexport interface SWRegistration {\n /** Whether the SW is registered */\n registered: ReadonlySignal<boolean>;\n /** Whether an update is available */\n updateAvailable: ReadonlySignal<boolean>;\n /** Whether the app is running offline */\n offline: ReadonlySignal<boolean>;\n /** The raw SW registration (available after ready) */\n ready: Promise<ServiceWorkerRegistration>;\n /** Check for updates */\n update(): Promise<void>;\n /** Skip waiting and activate new SW */\n skipWaiting(): void;\n /** Unregister the service worker */\n unregister(): Promise<boolean>;\n}\n\n// =========================================================================\n// Service Worker registration\n// =========================================================================\n\n/**\n * Register a service worker with update detection.\n */\nexport function registerServiceWorker(\n swUrl: string,\n options: SWOptions = {},\n): SWRegistration {\n const registered = signal(false);\n const updateAvailable = signal(false);\n const offline = signal(!navigator.onLine);\n\n let registration: ServiceWorkerRegistration | null = null;\n\n // Track online/offline\n window.addEventListener('online', () => offline.set(false));\n window.addEventListener('offline', () => offline.set(true));\n\n const ready = new Promise<ServiceWorkerRegistration>((resolve, reject) => {\n if (!('serviceWorker' in navigator)) {\n reject(new Error('Service workers not supported'));\n return;\n }\n\n navigator.serviceWorker\n .register(swUrl, { scope: options.scope })\n .then((reg) => {\n registration = reg;\n registered.set(true);\n options.onReady?.(reg);\n resolve(reg);\n\n // Listen for updates\n reg.addEventListener('updatefound', () => {\n const newWorker = reg.installing;\n if (!newWorker) return;\n\n newWorker.addEventListener('statechange', () => {\n if (newWorker.state === 'installed' && navigator.serviceWorker.controller) {\n updateAvailable.set(true);\n options.onUpdate?.(reg);\n\n if (options.autoReload) {\n newWorker.postMessage({ type: 'SKIP_WAITING' });\n window.location.reload();\n }\n }\n });\n });\n })\n .catch((err) => {\n options.onError?.(err);\n reject(err);\n });\n });\n\n return {\n registered: () => registered(),\n updateAvailable: () => updateAvailable(),\n offline: () => offline(),\n ready,\n async update() {\n if (registration) {\n await registration.update();\n }\n },\n skipWaiting() {\n if (registration?.waiting) {\n registration.waiting.postMessage({ type: 'SKIP_WAITING' });\n window.location.reload();\n }\n },\n async unregister() {\n if (registration) {\n return registration.unregister();\n }\n return false;\n },\n };\n}\n\n// =========================================================================\n// Caching strategies (for SW scripts)\n// =========================================================================\n\nexport type CacheStrategy = 'cache-first' | 'network-first' | 'stale-while-revalidate' | 'network-only' | 'cache-only';\n\nexport interface CacheRoute {\n /** URL pattern to match (string or regex) */\n match: string | RegExp;\n /** Caching strategy */\n strategy: CacheStrategy;\n /** Cache name */\n cacheName?: string;\n /** Max entries in cache */\n maxEntries?: number;\n /** Max age in seconds */\n maxAgeSeconds?: number;\n}\n\n/**\n * Generate a service worker script from cache route configs.\n *\n * ```ts\n * const swScript = generateSWScript([\n * { match: /\\.(?:js|css)$/, strategy: 'cache-first', cacheName: 'assets' },\n * { match: '/api/', strategy: 'network-first', maxAgeSeconds: 300 },\n * { match: /\\.(?:png|jpg|svg)$/, strategy: 'cache-first', cacheName: 'images' },\n * ]);\n * ```\n */\nexport function generateSWScript(routes: CacheRoute[]): string {\n let script = `// Auto-generated service worker by AkashJS\nconst CACHE_VERSION = 'v1';\n\nself.addEventListener('install', (event) => {\n self.skipWaiting();\n});\n\nself.addEventListener('activate', (event) => {\n event.waitUntil(clients.claim());\n});\n\nself.addEventListener('message', (event) => {\n if (event.data?.type === 'SKIP_WAITING') {\n self.skipWaiting();\n }\n});\n\nself.addEventListener('fetch', (event) => {\n const url = new URL(event.request.url);\n`;\n\n for (const route of routes) {\n const pattern = route.match instanceof RegExp\n ? route.match.toString()\n : `new RegExp(${JSON.stringify(route.match.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&'))})`;\n\n const cacheName = route.cacheName ?? 'akash-cache';\n\n script += `\n if (${pattern}.test(url.pathname)) {\n event.respondWith(${generateStrategyCode(route.strategy, cacheName)});\n return;\n }\n`;\n }\n\n script += `\n // Default: network-first\n event.respondWith(\n fetch(event.request).catch(() => caches.match(event.request))\n );\n});\n`;\n\n return script;\n}\n\nfunction generateStrategyCode(strategy: CacheStrategy, cacheName: string): string {\n switch (strategy) {\n case 'cache-first':\n return `caches.match(event.request).then(cached => cached || fetch(event.request).then(response => { const clone = response.clone(); caches.open('${cacheName}').then(cache => cache.put(event.request, clone)); return response; }))`;\n case 'network-first':\n return `fetch(event.request).then(response => { const clone = response.clone(); caches.open('${cacheName}').then(cache => cache.put(event.request, clone)); return response; }).catch(() => caches.match(event.request))`;\n case 'stale-while-revalidate':\n return `caches.match(event.request).then(cached => { const fetchPromise = fetch(event.request).then(response => { caches.open('${cacheName}').then(cache => cache.put(event.request, response.clone())); return response; }); return cached || fetchPromise; })`;\n case 'network-only':\n return `fetch(event.request)`;\n case 'cache-only':\n return `caches.match(event.request)`;\n }\n}\n\n// =========================================================================\n// Push notifications\n// =========================================================================\n\n/**\n * Request push notification permission and subscribe.\n */\nexport async function subscribePush(\n registration: ServiceWorkerRegistration,\n vapidPublicKey: string,\n): Promise<PushSubscription | null> {\n const permission = await Notification.requestPermission();\n if (permission !== 'granted') return null;\n\n const subscription = await registration.pushManager.subscribe({\n userVisibleOnly: true,\n applicationServerKey: urlBase64ToUint8Array(vapidPublicKey),\n });\n\n return subscription;\n}\n\nfunction urlBase64ToUint8Array(base64String: string): Uint8Array {\n const padding = '='.repeat((4 - (base64String.length % 4)) % 4);\n const base64 = (base64String + padding).replace(/-/g, '+').replace(/_/g, '/');\n const rawData = atob(base64);\n return Uint8Array.from(rawData, (char) => char.charCodeAt(0));\n}\n"]}
1
+ {"version":3,"sources":["../src/pwa.ts"],"names":["registerServiceWorker","swUrl","options","registered","signal","updateAvailable","offline","registration","ready","resolve","reject","reg","newWorker","err","generateSWScript","routes","script","route","pattern","cacheName","generateStrategyCode","strategy","subscribePush","vapidPublicKey","urlBase64ToUint8Array","base64String","padding","base64","rawData","char"],"mappings":"oCA2DO,SAASA,CAAAA,CACdC,EACAC,CAAAA,CAAqB,GACL,CAChB,IAAMC,CAAAA,CAAaC,CAAAA,CAAO,KAAK,CAAA,CACzBC,EAAkBD,CAAAA,CAAO,KAAK,EAC9BE,CAAAA,CAAUF,CAAAA,CAAO,CAAC,SAAA,CAAU,MAAM,CAAA,CAEpCG,CAAAA,CAAiD,IAAA,CAGrD,MAAA,CAAO,iBAAiB,QAAA,CAAU,IAAMD,EAAQ,GAAA,CAAI,KAAK,CAAC,CAAA,CAC1D,MAAA,CAAO,gBAAA,CAAiB,SAAA,CAAW,IAAMA,CAAAA,CAAQ,IAAI,IAAI,CAAC,CAAA,CAE1D,IAAME,CAAAA,CAAQ,IAAI,QAAmC,CAACC,CAAAA,CAASC,CAAAA,GAAW,CACxE,GAAI,EAAE,kBAAmB,SAAA,CAAA,CAAY,CACnCA,EAAO,IAAI,KAAA,CAAM,+BAA+B,CAAC,CAAA,CACjD,MACF,CAEA,SAAA,CAAU,aAAA,CACP,SAAST,CAAAA,CAAO,CAAE,MAAOC,CAAAA,CAAQ,KAAM,CAAC,CAAA,CACxC,IAAA,CAAMS,CAAAA,EAAQ,CACbJ,CAAAA,CAAeI,CAAAA,CACfR,EAAW,GAAA,CAAI,IAAI,EACnBD,CAAAA,CAAQ,OAAA,GAAUS,CAAG,CAAA,CACrBF,CAAAA,CAAQE,CAAG,CAAA,CAGXA,CAAAA,CAAI,gBAAA,CAAiB,cAAe,IAAM,CACxC,IAAMC,CAAAA,CAAYD,CAAAA,CAAI,UAAA,CACjBC,GAELA,CAAAA,CAAU,gBAAA,CAAiB,aAAA,CAAe,IAAM,CAC1CA,CAAAA,CAAU,QAAU,WAAA,EAAe,SAAA,CAAU,cAAc,UAAA,GAC7DP,CAAAA,CAAgB,IAAI,IAAI,CAAA,CACxBH,CAAAA,CAAQ,QAAA,GAAWS,CAAG,CAAA,CAElBT,EAAQ,UAAA,GACVU,CAAAA,CAAU,YAAY,CAAE,IAAA,CAAM,cAAe,CAAC,CAAA,CAC9C,MAAA,CAAO,QAAA,CAAS,MAAA,EAAO,CAAA,EAG7B,CAAC,EACH,CAAC,EACH,CAAC,CAAA,CACA,MAAOC,CAAAA,EAAQ,CACdX,CAAAA,CAAQ,OAAA,GAAUW,CAAG,CAAA,CACrBH,EAAOG,CAAG,EACZ,CAAC,EACL,CAAC,CAAA,CAED,OAAO,CACL,UAAA,CAAY,IAAMV,CAAAA,EAAW,CAC7B,eAAA,CAAiB,IAAME,CAAAA,EAAgB,CACvC,QAAS,IAAMC,CAAAA,GACf,KAAA,CAAAE,CAAAA,CACA,MAAM,MAAA,EAAS,CACTD,CAAAA,EACF,MAAMA,CAAAA,CAAa,MAAA,GAEvB,CAAA,CACA,WAAA,EAAc,CACRA,GAAc,OAAA,GAChBA,CAAAA,CAAa,OAAA,CAAQ,WAAA,CAAY,CAAE,IAAA,CAAM,cAAe,CAAC,CAAA,CACzD,OAAO,QAAA,CAAS,MAAA,IAEpB,CAAA,CACA,MAAM,UAAA,EAAa,CACjB,OAAIA,CAAAA,CACKA,EAAa,UAAA,EAAW,CAE1B,KACT,CACF,CACF,CAgCO,SAASO,CAAAA,CAAiBC,CAAAA,CAA8B,CAC7D,IAAIC,CAAAA,CAAS,CAAA;AAAA;;AAAA;AAAA;AAAA;;AAAA;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;;AAAA;AAAA;AAAA,CAAA,CAqBb,IAAA,IAAWC,CAAAA,IAASF,CAAAA,CAAQ,CAC1B,IAAMG,CAAAA,CAAUD,CAAAA,CAAM,KAAA,YAAiB,MAAA,CACnCA,CAAAA,CAAM,KAAA,CAAM,QAAA,EAAS,CACrB,CAAA,WAAA,EAAc,IAAA,CAAK,SAAA,CAAUA,CAAAA,CAAM,KAAA,CAAM,OAAA,CAAQ,qBAAA,CAAuB,MAAM,CAAC,CAAC,CAAA,CAAA,CAAA,CAE9EE,CAAAA,CAAYF,CAAAA,CAAM,SAAA,EAAa,aAAA,CAErCD,CAAAA,EAAU;AAAA,MAAA,EACNE,CAAO,CAAA;AAAA,sBAAA,EACSE,CAAAA,CAAqBH,CAAAA,CAAM,QAAA,CAAUE,CAAS,CAAC,CAAA;AAAA;AAAA;AAAA,EAIrE,CAEA,OAAAH,CAAAA,EAAU;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,CAAA,CAQHA,CACT,CAEA,SAASI,CAAAA,CAAqBC,EAAyBF,CAAAA,CAA2B,CAChF,OAAQE,CAAAA,EACN,KAAK,cACH,OAAO,CAAA,0IAAA,EAA6IF,CAAS,CAAA,uEAAA,CAAA,CAC/J,KAAK,gBACH,OAAO,CAAA,qFAAA,EAAwFA,CAAS,CAAA,+GAAA,CAAA,CAC1G,KAAK,wBAAA,CACH,OAAO,CAAA,uHAAA,EAA0HA,CAAS,uHAC5I,KAAK,cAAA,CACH,OAAO,sBAAA,CACT,KAAK,YAAA,CACH,OAAO,6BACX,CACF,CASA,eAAsBG,CAAAA,CACpBf,CAAAA,CACAgB,CAAAA,CACkC,CAElC,OADmB,MAAM,YAAA,CAAa,iBAAA,EAAkB,GACrC,SAAA,CAAkB,IAAA,CAEhB,MAAMhB,EAAa,WAAA,CAAY,SAAA,CAAU,CAC5D,eAAA,CAAiB,IAAA,CACjB,qBAAsBiB,CAAAA,CAAsBD,CAAc,CAC5D,CAAC,CAGH,CAEA,SAASC,CAAAA,CAAsBC,CAAAA,CAAkC,CAC/D,IAAMC,CAAAA,CAAU,IAAI,MAAA,CAAA,CAAQ,CAAA,CAAKD,CAAAA,CAAa,MAAA,CAAS,CAAA,EAAM,CAAC,EACxDE,CAAAA,CAAAA,CAAUF,CAAAA,CAAeC,GAAS,OAAA,CAAQ,IAAA,CAAM,GAAG,CAAA,CAAE,OAAA,CAAQ,IAAA,CAAM,GAAG,CAAA,CACtEE,CAAAA,CAAU,KAAKD,CAAM,CAAA,CAC3B,OAAO,UAAA,CAAW,IAAA,CAAKC,CAAAA,CAAUC,GAASA,CAAAA,CAAK,UAAA,CAAW,CAAC,CAAC,CAC9D","file":"chunk-WG5GKD3B.js","sourcesContent":["/**\n * PWA / Service Worker support.\n *\n * Register service workers, configure caching strategies,\n * handle updates, and manage push notifications.\n *\n * ```ts\n * const sw = registerServiceWorker('/sw.js', {\n * onUpdate: () => toast.info('New version available!'),\n * });\n * sw.ready; // Promise<ServiceWorkerRegistration>\n * sw.update(); // check for updates\n * ```\n */\n\nimport { signal } from './signals.js';\nimport type { ReadonlySignal } from './signals.js';\n\n// =========================================================================\n// Types\n// =========================================================================\n\nexport interface SWOptions {\n /** Callback when a new version is available */\n onUpdate?: (registration: ServiceWorkerRegistration) => void;\n /** Callback when the SW is ready */\n onReady?: (registration: ServiceWorkerRegistration) => void;\n /** Callback on registration error */\n onError?: (error: Error) => void;\n /** Auto-reload on update (default: false) */\n autoReload?: boolean;\n /** Scope of the service worker */\n scope?: string;\n}\n\nexport interface SWRegistration {\n /** Whether the SW is registered */\n registered: ReadonlySignal<boolean>;\n /** Whether an update is available */\n updateAvailable: ReadonlySignal<boolean>;\n /** Whether the app is running offline */\n offline: ReadonlySignal<boolean>;\n /** The raw SW registration (available after ready) */\n ready: Promise<ServiceWorkerRegistration>;\n /** Check for updates */\n update(): Promise<void>;\n /** Skip waiting and activate new SW */\n skipWaiting(): void;\n /** Unregister the service worker */\n unregister(): Promise<boolean>;\n}\n\n// =========================================================================\n// Service Worker registration\n// =========================================================================\n\n/**\n * Register a service worker with update detection.\n */\nexport function registerServiceWorker(\n swUrl: string,\n options: SWOptions = {},\n): SWRegistration {\n const registered = signal(false);\n const updateAvailable = signal(false);\n const offline = signal(!navigator.onLine);\n\n let registration: ServiceWorkerRegistration | null = null;\n\n // Track online/offline\n window.addEventListener('online', () => offline.set(false));\n window.addEventListener('offline', () => offline.set(true));\n\n const ready = new Promise<ServiceWorkerRegistration>((resolve, reject) => {\n if (!('serviceWorker' in navigator)) {\n reject(new Error('Service workers not supported'));\n return;\n }\n\n navigator.serviceWorker\n .register(swUrl, { scope: options.scope })\n .then((reg) => {\n registration = reg;\n registered.set(true);\n options.onReady?.(reg);\n resolve(reg);\n\n // Listen for updates\n reg.addEventListener('updatefound', () => {\n const newWorker = reg.installing;\n if (!newWorker) return;\n\n newWorker.addEventListener('statechange', () => {\n if (newWorker.state === 'installed' && navigator.serviceWorker.controller) {\n updateAvailable.set(true);\n options.onUpdate?.(reg);\n\n if (options.autoReload) {\n newWorker.postMessage({ type: 'SKIP_WAITING' });\n window.location.reload();\n }\n }\n });\n });\n })\n .catch((err) => {\n options.onError?.(err);\n reject(err);\n });\n });\n\n return {\n registered: () => registered(),\n updateAvailable: () => updateAvailable(),\n offline: () => offline(),\n ready,\n async update() {\n if (registration) {\n await registration.update();\n }\n },\n skipWaiting() {\n if (registration?.waiting) {\n registration.waiting.postMessage({ type: 'SKIP_WAITING' });\n window.location.reload();\n }\n },\n async unregister() {\n if (registration) {\n return registration.unregister();\n }\n return false;\n },\n };\n}\n\n// =========================================================================\n// Caching strategies (for SW scripts)\n// =========================================================================\n\nexport type CacheStrategy = 'cache-first' | 'network-first' | 'stale-while-revalidate' | 'network-only' | 'cache-only';\n\nexport interface CacheRoute {\n /** URL pattern to match (string or regex) */\n match: string | RegExp;\n /** Caching strategy */\n strategy: CacheStrategy;\n /** Cache name */\n cacheName?: string;\n /** Max entries in cache */\n maxEntries?: number;\n /** Max age in seconds */\n maxAgeSeconds?: number;\n}\n\n/**\n * Generate a service worker script from cache route configs.\n *\n * ```ts\n * const swScript = generateSWScript([\n * { match: /\\.(?:js|css)$/, strategy: 'cache-first', cacheName: 'assets' },\n * { match: '/api/', strategy: 'network-first', maxAgeSeconds: 300 },\n * { match: /\\.(?:png|jpg|svg)$/, strategy: 'cache-first', cacheName: 'images' },\n * ]);\n * ```\n */\nexport function generateSWScript(routes: CacheRoute[]): string {\n let script = `// Auto-generated service worker by AkashJS\nconst CACHE_VERSION = 'v1';\n\nself.addEventListener('install', (event) => {\n self.skipWaiting();\n});\n\nself.addEventListener('activate', (event) => {\n event.waitUntil(clients.claim());\n});\n\nself.addEventListener('message', (event) => {\n if (event.data?.type === 'SKIP_WAITING') {\n self.skipWaiting();\n }\n});\n\nself.addEventListener('fetch', (event) => {\n const url = new URL(event.request.url);\n`;\n\n for (const route of routes) {\n const pattern = route.match instanceof RegExp\n ? route.match.toString()\n : `new RegExp(${JSON.stringify(route.match.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&'))})`;\n\n const cacheName = route.cacheName ?? 'akash-cache';\n\n script += `\n if (${pattern}.test(url.pathname)) {\n event.respondWith(${generateStrategyCode(route.strategy, cacheName)});\n return;\n }\n`;\n }\n\n script += `\n // Default: network-first\n event.respondWith(\n fetch(event.request).catch(() => caches.match(event.request))\n );\n});\n`;\n\n return script;\n}\n\nfunction generateStrategyCode(strategy: CacheStrategy, cacheName: string): string {\n switch (strategy) {\n case 'cache-first':\n return `caches.match(event.request).then(cached => cached || fetch(event.request).then(response => { const clone = response.clone(); caches.open('${cacheName}').then(cache => cache.put(event.request, clone)); return response; }))`;\n case 'network-first':\n return `fetch(event.request).then(response => { const clone = response.clone(); caches.open('${cacheName}').then(cache => cache.put(event.request, clone)); return response; }).catch(() => caches.match(event.request))`;\n case 'stale-while-revalidate':\n return `caches.match(event.request).then(cached => { const fetchPromise = fetch(event.request).then(response => { caches.open('${cacheName}').then(cache => cache.put(event.request, response.clone())); return response; }); return cached || fetchPromise; })`;\n case 'network-only':\n return `fetch(event.request)`;\n case 'cache-only':\n return `caches.match(event.request)`;\n }\n}\n\n// =========================================================================\n// Push notifications\n// =========================================================================\n\n/**\n * Request push notification permission and subscribe.\n */\nexport async function subscribePush(\n registration: ServiceWorkerRegistration,\n vapidPublicKey: string,\n): Promise<PushSubscription | null> {\n const permission = await Notification.requestPermission();\n if (permission !== 'granted') return null;\n\n const subscription = await registration.pushManager.subscribe({\n userVisibleOnly: true,\n applicationServerKey: urlBase64ToUint8Array(vapidPublicKey),\n });\n\n return subscription;\n}\n\nfunction urlBase64ToUint8Array(base64String: string): Uint8Array {\n const padding = '='.repeat((4 - (base64String.length % 4)) % 4);\n const base64 = (base64String + padding).replace(/-/g, '+').replace(/_/g, '/');\n const rawData = atob(base64);\n return Uint8Array.from(rawData, (char) => char.charCodeAt(0));\n}\n"]}
@@ -1,5 +1,5 @@
1
- 'use strict';var chunkL4DNCDUA_cjs=require('./chunk-L4DNCDUA.cjs');var v={AK0010:{code:"AK0010",message:"provide() called outside of component setup.",hint:"provide() must be called inside defineComponent()."},AK0012:{code:"AK0012",message:"inject() called outside of component setup.",hint:"inject() must be called inside defineComponent()."},AK0013:{code:"AK0013",message:"No provider found for injected context.",hint:"Make sure an ancestor component calls provide() with this key."},AK0020:{code:"AK0020",message:"onMount() called outside of component setup.",hint:"onMount() must be called inside defineComponent()."},AK0021:{code:"AK0021",message:"onUnmount() called outside of component setup.",hint:"onUnmount() must be called inside defineComponent()."},AK0022:{code:"AK0022",message:"onError() called outside of component setup.",hint:"onError() must be called inside defineComponent()."},AK0030:{code:"AK0030",message:"Circular dependency detected in computed signal.",hint:"A computed signal is reading itself, directly or via other computeds."},AK0031:{code:"AK0031",message:"Signal set() called during computation.",hint:"Do not set signals inside computed() or during effect execution. Use batch() or set signals in event handlers."},AK0040:{code:"AK0040",message:"Component setup must return a render function.",hint:"The function passed to defineComponent() must return () => AkashNode."},AK0041:{code:"AK0041",message:"Required prop is missing.",hint:"Check that the parent component is passing all required props."},AK0050:{code:"AK0050",message:"useRoute() called outside of router context.",hint:"Make sure your component is rendered inside a router provider."},AK0051:{code:"AK0051",message:"No route matched the current URL.",hint:"Add a catch-all route ([...rest]) to handle unmatched paths."},AK0052:{code:"AK0052",message:"Route guard threw an error.",hint:"Check the guard function for unhandled exceptions."},AK0060:{code:"AK0060",message:"Form submitted while invalid.",hint:"The submit handler was not called because validation failed. Check form.errors()."},AK0061:{code:"AK0061",message:"Async validator timed out.",hint:"The async validator did not resolve within the expected time. Check your async validation logic."},AK0070:{code:"AK0070",message:"HTTP request failed.",hint:"Check the server response status and network connectivity."},AK0071:{code:"AK0071",message:"createResource() fetcher threw an error.",hint:"Check the fetcher function passed to createResource()."}},P="https://akashjs.dev/errors";function L(e,n){let t=v[e];if(!t)return `[AkashJS ${e}] Unknown error code.`;let o=`[AkashJS ${e}] ${t.message}`;return n&&(o+=`
1
+ 'use strict';var chunkRTJ6UDGV_cjs=require('./chunk-RTJ6UDGV.cjs');var v={AK0010:{code:"AK0010",message:"provide() called outside of component setup.",hint:"provide() must be called inside defineComponent()."},AK0012:{code:"AK0012",message:"inject() called outside of component setup.",hint:"inject() must be called inside defineComponent()."},AK0013:{code:"AK0013",message:"No provider found for injected context.",hint:"Make sure an ancestor component calls provide() with this key."},AK0020:{code:"AK0020",message:"onMount() called outside of component setup.",hint:"onMount() must be called inside defineComponent()."},AK0021:{code:"AK0021",message:"onUnmount() called outside of component setup.",hint:"onUnmount() must be called inside defineComponent()."},AK0022:{code:"AK0022",message:"onError() called outside of component setup.",hint:"onError() must be called inside defineComponent()."},AK0030:{code:"AK0030",message:"Circular dependency detected in computed signal.",hint:"A computed signal is reading itself, directly or via other computeds."},AK0031:{code:"AK0031",message:"Signal set() called during computation.",hint:"Do not set signals inside computed() or during effect execution. Use batch() or set signals in event handlers."},AK0040:{code:"AK0040",message:"Component setup must return a render function.",hint:"The function passed to defineComponent() must return () => AkashNode."},AK0041:{code:"AK0041",message:"Required prop is missing.",hint:"Check that the parent component is passing all required props."},AK0050:{code:"AK0050",message:"useRoute() called outside of router context.",hint:"Make sure your component is rendered inside a router provider."},AK0051:{code:"AK0051",message:"No route matched the current URL.",hint:"Add a catch-all route ([...rest]) to handle unmatched paths."},AK0052:{code:"AK0052",message:"Route guard threw an error.",hint:"Check the guard function for unhandled exceptions."},AK0060:{code:"AK0060",message:"Form submitted while invalid.",hint:"The submit handler was not called because validation failed. Check form.errors()."},AK0061:{code:"AK0061",message:"Async validator timed out.",hint:"The async validator did not resolve within the expected time. Check your async validation logic."},AK0070:{code:"AK0070",message:"HTTP request failed.",hint:"Check the server response status and network connectivity."},AK0071:{code:"AK0071",message:"createResource() fetcher threw an error.",hint:"Check the fetcher function passed to createResource()."}},P="https://akashjs.dev/errors";function L(e,n){let t=v[e];if(!t)return `[AkashJS ${e}] Unknown error code.`;let o=`[AkashJS ${e}] ${t.message}`;return n&&(o+=`
2
2
  ${n}`),o+=`
3
3
  ${t.hint}`,o+=`
4
- See: ${P}/${e}`,o}function g(e,n){return new Error(L(e,n))}function D(e){return v[e]}function F(){return Object.keys(v)}var M=Symbol("akash.context"),p=null;function S(e=p){let n={values:new Map,parent:e};return p=n,n}function w(e){p=e.parent;}function C(){return p}function K(e,n){let t=p;p=e;try{return n()}finally{p=t;}}function I(e){return {[M]:true,_type:void 0,defaultValue:e,id:Symbol("context")}}function B(e,n){if(!p)throw g("AK0010");p.values.set(e.id,n);}function O(e,n){if(!p)throw g("AK0012");let t=p;for(;t;){if(t.values.has(e.id))return t.values.get(e.id);t=t.parent;}if(n!==void 0)return n;if(e.defaultValue!==void 0)return e.defaultValue;throw g("AK0013")}function q(e,n){let t=document.createElement(e);if(n)for(let[o,a]of Object.entries(n))E(t,o,a);return t}function J(e){return document.createTextNode(e)}function W(e){let n=document.createElement("template");return n.innerHTML=e,n.content.cloneNode(true)}function E(e,n,t){if(n==="class"||n==="className")e.className=t;else if(n==="style"&&typeof t=="object"&&t!==null)Object.assign(e.style,t);else if(n==="innerHTML")e.innerHTML=t;else if(n!=="ref")if(n.startsWith("on")){let o=n.slice(2).toLowerCase();e.addEventListener(o,t);}else n in e?e[n]=t:t===false||t==null?e.removeAttribute(n):e.setAttribute(n,t===true?"":String(t));}function X(e,n){return chunkL4DNCDUA_cjs.e(()=>{e.textContent=String(n());},{render:true})}function z(e,n,t){return chunkL4DNCDUA_cjs.e(()=>{E(e,n,t());},{render:true})}function G(e,n){return chunkL4DNCDUA_cjs.e(()=>{e.style.display=n()?"":"none";},{render:true})}function b(e=""){return document.createComment(e)}function R(e,n,t,o,a){let s=null,A=C(),N=chunkL4DNCDUA_cjs.e(()=>{let i=t();if(s){for(let l of s.nodes)try{l.parentNode?.removeChild(l);}catch{}s.dispose?.(),s=null;}let d=i?o:a,h=n.parentNode;if(d&&h){let l=A?K(A,d):d(),r=l instanceof DocumentFragment?Array.from(l.childNodes):[l];for(let c of r)h.insertBefore(c,n);s={nodes:r,dispose:null};}},{render:true});return ()=>{if(N(),s){for(let i of s.nodes)try{i.parentNode?.removeChild(i);}catch{}s.dispose?.();}}}function j(e,n,t,o,a){let s=[],A=C(),N=chunkL4DNCDUA_cjs.e(()=>{let i=t(),d=[],h=new Map;for(let r of s)h.set(r.key,r);for(let r=0;r<i.length;r++){let c=i[r],u=o(c,r),f=h.get(u);if(f)h.delete(u),f.value=c,d.push(f);else {let T=A?K(A,()=>a(c,r)):a(c,r),y=T instanceof DocumentFragment?Array.from(T.childNodes):[T];d.push({key:u,value:c,nodes:y,dispose:null});}}for(let r of h.values()){for(let c of r.nodes)c.parentNode&&c.parentNode.removeChild(c);r.dispose?.();}let l=n.parentNode;if(l)for(let r of d)for(let c of r.nodes)l.insertBefore(c,n);s=d;},{render:true});return ()=>{N();for(let i of s){for(let d of i.nodes)d.parentNode&&d.parentNode.removeChild(d);i.dispose?.();}s=[];}}function Q(e){let n=b("show"),t=document.createDocumentFragment();t.appendChild(n);let o=typeof e.when=="function"?e.when:()=>e.when,a;return R(t,n,()=>(a=o(),!!a),()=>x(e.children(a)),e.fallback?()=>x(e.fallback()):void 0),t}function Y(e){let n=b("for"),t=document.createDocumentFragment();t.appendChild(n);let o=typeof e.each=="function"?e.each:()=>e.each;return j(t,n,o,e.key,(a,s)=>x(e.children(a,s))),t}function x(e){if(e==null||typeof e=="boolean")return document.createTextNode("");if(typeof e=="string"||typeof e=="number")return document.createTextNode(String(e));if(e instanceof Node)return e;if(Array.isArray(e)){let n=document.createDocumentFragment();for(let t of e)n.appendChild(x(t));return n}return document.createTextNode(String(e))}function Z(e,n,t){let o=x(n);t?e.insertBefore(o,t):e.appendChild(o);}function re(e){return e.__reactive=true,e}var m=null;function ie(e){if(!m)throw g("AK0020");m.mount.push(e);}function se(e){if(!m)throw g("AK0021");m.unmount.push(e);}function ce(e){if(!m)throw g("AK0022");m.error.push(e);}function de(){return {current:void 0}}function ae(e){let n=t=>{let{children:o,...a}=t??{},N={props:new Proxy(a,{get(u,f,T){let y=Reflect.get(u,f,T);return typeof y=="function"&&y.__reactive?y():y}}),children:typeof o=="function"?o:()=>o??null},i={mount:[],unmount:[],error:[]},d=m;m=i;let h=C(),l=S(h),r,c;try{if(r=e(N),typeof r!="function")throw g("AK0040");let u=r();c=x(u);}catch(u){if(w(l),m=d,i.error.length>0){for(let f of i.error)f(u instanceof Error?u:new Error(String(u)));return document.createComment("error")}throw u}return w(l),m=d,i.mount.length>0&&queueMicrotask(()=>{for(let u of i.mount)try{let f=u();typeof f=="function"&&i.unmount.push(f);}catch(f){for(let T of i.error)T(f instanceof Error?f:new Error(String(f)));}}),c};return n._akash=true,n}exports.A=de;exports.B=ae;exports.a=L;exports.b=g;exports.c=D;exports.d=F;exports.e=C;exports.f=K;exports.g=I;exports.h=B;exports.i=O;exports.j=q;exports.k=J;exports.l=W;exports.m=E;exports.n=X;exports.o=z;exports.p=G;exports.q=R;exports.r=j;exports.s=Q;exports.t=Y;exports.u=x;exports.v=Z;exports.w=re;exports.x=ie;exports.y=se;exports.z=ce;//# sourceMappingURL=chunk-XLHWCP6E.cjs.map
5
- //# sourceMappingURL=chunk-XLHWCP6E.cjs.map
4
+ See: ${P}/${e}`,o}function g(e,n){return new Error(L(e,n))}function D(e){return v[e]}function F(){return Object.keys(v)}var M=Symbol("akash.context"),p=null;function S(e=p){let n={values:new Map,parent:e};return p=n,n}function w(e){p=e.parent;}function C(){return p}function K(e,n){let t=p;p=e;try{return n()}finally{p=t;}}function I(e){return {[M]:true,_type:void 0,defaultValue:e,id:Symbol("context")}}function B(e,n){if(!p)throw g("AK0010");p.values.set(e.id,n);}function O(e,n){if(!p)throw g("AK0012");let t=p;for(;t;){if(t.values.has(e.id))return t.values.get(e.id);t=t.parent;}if(n!==void 0)return n;if(e.defaultValue!==void 0)return e.defaultValue;throw g("AK0013")}function q(e,n){let t=document.createElement(e);if(n)for(let[o,a]of Object.entries(n))E(t,o,a);return t}function J(e){return document.createTextNode(e)}function W(e){let n=document.createElement("template");return n.innerHTML=e,n.content.cloneNode(true)}function E(e,n,t){if(n==="class"||n==="className")e.className=t;else if(n==="style"&&typeof t=="object"&&t!==null)Object.assign(e.style,t);else if(n==="innerHTML")e.innerHTML=t;else if(n!=="ref")if(n.startsWith("on")){let o=n.slice(2).toLowerCase();e.addEventListener(o,t);}else n in e?e[n]=t:t===false||t==null?e.removeAttribute(n):e.setAttribute(n,t===true?"":String(t));}function X(e,n){return chunkRTJ6UDGV_cjs.n(()=>{e.textContent=String(n());},{render:true})}function z(e,n,t){return chunkRTJ6UDGV_cjs.n(()=>{E(e,n,t());},{render:true})}function G(e,n){return chunkRTJ6UDGV_cjs.n(()=>{e.style.display=n()?"":"none";},{render:true})}function b(e=""){return document.createComment(e)}function R(e,n,t,o,a){let s=null,A=C(),N=chunkRTJ6UDGV_cjs.n(()=>{let i=t();if(s){for(let l of s.nodes)try{l.parentNode?.removeChild(l);}catch{}s.dispose?.(),s=null;}let d=i?o:a,h=n.parentNode;if(d&&h){let l=A?K(A,d):d(),r=l instanceof DocumentFragment?Array.from(l.childNodes):[l];for(let c of r)h.insertBefore(c,n);s={nodes:r,dispose:null};}},{render:true});return ()=>{if(N(),s){for(let i of s.nodes)try{i.parentNode?.removeChild(i);}catch{}s.dispose?.();}}}function j(e,n,t,o,a){let s=[],A=C(),N=chunkRTJ6UDGV_cjs.n(()=>{let i=t(),d=[],h=new Map;for(let r of s)h.set(r.key,r);for(let r=0;r<i.length;r++){let c=i[r],u=o(c,r),f=h.get(u);if(f)h.delete(u),f.value=c,d.push(f);else {let T=A?K(A,()=>a(c,r)):a(c,r),y=T instanceof DocumentFragment?Array.from(T.childNodes):[T];d.push({key:u,value:c,nodes:y,dispose:null});}}for(let r of h.values()){for(let c of r.nodes)c.parentNode&&c.parentNode.removeChild(c);r.dispose?.();}let l=n.parentNode;if(l)for(let r of d)for(let c of r.nodes)l.insertBefore(c,n);s=d;},{render:true});return ()=>{N();for(let i of s){for(let d of i.nodes)d.parentNode&&d.parentNode.removeChild(d);i.dispose?.();}s=[];}}function Q(e){let n=b("show"),t=document.createDocumentFragment();t.appendChild(n);let o=typeof e.when=="function"?e.when:()=>e.when,a;return R(t,n,()=>(a=o(),!!a),()=>x(e.children(a)),e.fallback?()=>x(e.fallback()):void 0),t}function Y(e){let n=b("for"),t=document.createDocumentFragment();t.appendChild(n);let o=typeof e.each=="function"?e.each:()=>e.each;return j(t,n,o,e.key,(a,s)=>x(e.children(a,s))),t}function x(e){if(e==null||typeof e=="boolean")return document.createTextNode("");if(typeof e=="string"||typeof e=="number")return document.createTextNode(String(e));if(e instanceof Node)return e;if(Array.isArray(e)){let n=document.createDocumentFragment();for(let t of e)n.appendChild(x(t));return n}return document.createTextNode(String(e))}function Z(e,n,t){let o=x(n);t?e.insertBefore(o,t):e.appendChild(o);}function re(e){return e.__reactive=true,e}var m=null;function ie(e){if(!m)throw g("AK0020");m.mount.push(e);}function se(e){if(!m)throw g("AK0021");m.unmount.push(e);}function ce(e){if(!m)throw g("AK0022");m.error.push(e);}function de(){return {current:void 0}}function ae(e){let n=t=>{let{children:o,...a}=t??{},N={props:new Proxy(a,{get(u,f,T){let y=Reflect.get(u,f,T);return typeof y=="function"&&y.__reactive?y():y}}),children:typeof o=="function"?o:()=>o??null},i={mount:[],unmount:[],error:[]},d=m;m=i;let h=C(),l=S(h),r,c;try{if(r=e(N),typeof r!="function")throw g("AK0040");let u=r();c=x(u);}catch(u){if(w(l),m=d,i.error.length>0){for(let f of i.error)f(u instanceof Error?u:new Error(String(u)));return document.createComment("error")}throw u}return w(l),m=d,i.mount.length>0&&queueMicrotask(()=>{for(let u of i.mount)try{let f=u();typeof f=="function"&&i.unmount.push(f);}catch(f){for(let T of i.error)T(f instanceof Error?f:new Error(String(f)));}}),c};return n._akash=true,n}exports.A=de;exports.B=ae;exports.a=L;exports.b=g;exports.c=D;exports.d=F;exports.e=C;exports.f=K;exports.g=I;exports.h=B;exports.i=O;exports.j=q;exports.k=J;exports.l=W;exports.m=E;exports.n=X;exports.o=z;exports.p=G;exports.q=R;exports.r=j;exports.s=Q;exports.t=Y;exports.u=x;exports.v=Z;exports.w=re;exports.x=ie;exports.y=se;exports.z=ce;//# sourceMappingURL=chunk-YIVBLM2A.cjs.map
5
+ //# sourceMappingURL=chunk-YIVBLM2A.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/errors.ts","../src/context.ts","../src/dom.ts","../src/component.ts"],"names":["errors","DOC_BASE","formatError","code","context","def","msg","akashError","getErrorDef","getAllErrorCodes","CONTEXT_BRAND","currentScope","pushScope","parent","scope","popScope","getCurrentScope","runInScope","fn","prev","createContext","defaultValue","provide","key","value","inject","fallback","createElement","tag","attrs","el","setProperty","createText","cloneTemplate","html","template","event","bindText","node","effect","bindProperty","bindVisible","createAnchor","label","renderConditional","anchor","condition","trueBranch","falseBranch","current","dispose","branch","liveParent","fragment","nodes","renderList","items","keyFn","renderItem","currentItems","newData","newItems","oldMap","item","i","data","existing","Show","props","container","getWhen","whenValue","nodeToDOM","For","getEach","index","child","insert","domNode","__getter","currentHooks","onMount","onUnmount","onError","ref","defineComponent","setup","component","rawProps","childrenProp","restProps","ctx","target","receiver","val","hooks","prevHooks","parentScope","renderFn","rendered","err","handler","mountFn","cleanup"],"mappings":"mEAqBA,IAAMA,EAAmC,CAEvC,MAAA,CAAQ,CACN,IAAA,CAAM,QAAA,CACN,QAAS,8CAAA,CACT,IAAA,CAAM,oDACR,CAAA,CACA,MAAA,CAAQ,CACN,IAAA,CAAM,QAAA,CACN,QAAS,6CAAA,CACT,IAAA,CAAM,mDACR,CAAA,CACA,MAAA,CAAQ,CACN,IAAA,CAAM,QAAA,CACN,QAAS,yCAAA,CACT,IAAA,CAAM,gEACR,CAAA,CAGA,MAAA,CAAQ,CACN,IAAA,CAAM,QAAA,CACN,QAAS,8CAAA,CACT,IAAA,CAAM,oDACR,CAAA,CACA,MAAA,CAAQ,CACN,IAAA,CAAM,QAAA,CACN,QAAS,gDAAA,CACT,IAAA,CAAM,sDACR,CAAA,CACA,OAAQ,CACN,IAAA,CAAM,SACN,OAAA,CAAS,8CAAA,CACT,KAAM,oDACR,CAAA,CAGA,OAAQ,CACN,IAAA,CAAM,SACN,OAAA,CAAS,kDAAA,CACT,KAAM,uEACR,CAAA,CACA,OAAQ,CACN,IAAA,CAAM,SACN,OAAA,CAAS,yCAAA,CACT,KAAM,gHACR,CAAA,CAGA,OAAQ,CACN,IAAA,CAAM,SACN,OAAA,CAAS,gDAAA,CACT,KAAM,uEACR,CAAA,CACA,OAAQ,CACN,IAAA,CAAM,SACN,OAAA,CAAS,2BAAA,CACT,KAAM,gEACR,CAAA,CAGA,MAAA,CAAQ,CACN,KAAM,QAAA,CACN,OAAA,CAAS,+CACT,IAAA,CAAM,gEACR,EACA,MAAA,CAAQ,CACN,KAAM,QAAA,CACN,OAAA,CAAS,oCACT,IAAA,CAAM,8DACR,EACA,MAAA,CAAQ,CACN,KAAM,QAAA,CACN,OAAA,CAAS,8BACT,IAAA,CAAM,oDACR,EAGA,MAAA,CAAQ,CACN,KAAM,QAAA,CACN,OAAA,CAAS,gCACT,IAAA,CAAM,mFACR,EACA,MAAA,CAAQ,CACN,KAAM,QAAA,CACN,OAAA,CAAS,6BACT,IAAA,CAAM,kGACR,EAGA,MAAA,CAAQ,CACN,KAAM,QAAA,CACN,OAAA,CAAS,uBACT,IAAA,CAAM,4DACR,EACA,MAAA,CAAQ,CACN,KAAM,QAAA,CACN,OAAA,CAAS,2CACT,IAAA,CAAM,wDACR,CACF,CAAA,CAIMC,CAAAA,CAAW,6BAKV,SAASC,CAAAA,CAAYC,EAAcC,CAAAA,CAA0B,CAClE,IAAMC,CAAAA,CAAML,CAAAA,CAAOG,CAAI,CAAA,CACvB,GAAI,CAACE,CAAAA,CACH,OAAO,YAAYF,CAAI,CAAA,qBAAA,CAAA,CAGzB,IAAIG,CAAAA,CAAM,CAAA,SAAA,EAAYH,CAAI,CAAA,EAAA,EAAKE,CAAAA,CAAI,OAAO,CAAA,CAAA,CAC1C,OAAID,IACFE,CAAAA,EAAO;AAAA,EAAA,EAAOF,CAAO,IAEvBE,CAAAA,EAAO;AAAA,EAAA,EAAOD,CAAAA,CAAI,IAAI,CAAA,CAAA,CACtBC,CAAAA,EAAO;AAAA,OAAA,EAAYL,CAAQ,CAAA,CAAA,EAAIE,CAAI,CAAA,CAAA,CAC5BG,CACT,CAKO,SAASC,CAAAA,CAAWJ,CAAAA,CAAcC,CAAAA,CAAyB,CAChE,OAAO,IAAI,MAAMF,CAAAA,CAAYC,CAAAA,CAAMC,CAAO,CAAC,CAC7C,CAKO,SAASI,CAAAA,CAAYL,EAAoC,CAC9D,OAAOH,CAAAA,CAAOG,CAAI,CACpB,CAKO,SAASM,CAAAA,EAA6B,CAC3C,OAAO,MAAA,CAAO,IAAA,CAAKT,CAAM,CAC3B,CCxJA,IAAMU,CAAAA,CAAgB,MAAA,CAAO,eAAe,CAAA,CAgBxCC,CAAAA,CAAoC,IAAA,CAGjC,SAASC,EAAUC,CAAAA,CAA8BF,CAAAA,CAA4B,CAClF,IAAMG,EAAsB,CAAE,MAAA,CAAQ,IAAI,GAAA,CAAO,MAAA,CAAAD,CAAO,CAAA,CACxD,OAAAF,EAAeG,CAAAA,CACRA,CACT,CAGO,SAASC,EAASD,CAAAA,CAA2B,CAClDH,CAAAA,CAAeG,CAAAA,CAAM,OACvB,CAGO,SAASE,CAAAA,EAAuC,CACrD,OAAOL,CACT,CAOO,SAASM,EAAcH,CAAAA,CAAqBI,CAAAA,CAAgB,CACjE,IAAMC,CAAAA,CAAOR,CAAAA,CACbA,CAAAA,CAAeG,CAAAA,CACf,GAAI,CACF,OAAOI,CAAAA,EACT,CAAA,OAAE,CACAP,CAAAA,CAAeQ,EACjB,CACF,CAWO,SAASC,CAAAA,CAAiBC,CAAAA,CAAmC,CAClE,OAAO,CACL,CAACX,CAAa,EAAG,IAAA,CACjB,KAAA,CAAO,MAAA,CACP,YAAA,CAAAW,CAAAA,CACA,EAAA,CAAI,MAAA,CAAO,SAAS,CACtB,CACF,CAQO,SAASC,CAAAA,CAAWC,EAAsBC,CAAAA,CAAgB,CAC/D,GAAI,CAACb,EACH,MAAMJ,CAAAA,CAAW,QAAQ,CAAA,CAE3BI,CAAAA,CAAa,MAAA,CAAO,GAAA,CAAIY,CAAAA,CAAI,GAAIC,CAAK,EACvC,CASO,SAASC,EAAUF,CAAAA,CAAsBG,CAAAA,CAAiB,CAC/D,GAAI,CAACf,CAAAA,CACH,MAAMJ,CAAAA,CAAW,QAAQ,CAAA,CAI3B,IAAIO,CAAAA,CAA6BH,CAAAA,CACjC,KAAOG,CAAAA,EAAO,CACZ,GAAIA,CAAAA,CAAM,MAAA,CAAO,GAAA,CAAIS,CAAAA,CAAI,EAAE,EACzB,OAAOT,CAAAA,CAAM,MAAA,CAAO,GAAA,CAAIS,CAAAA,CAAI,EAAE,CAAA,CAEhCT,CAAAA,CAAQA,EAAM,OAChB,CAGA,GAAIY,CAAAA,GAAa,OAAW,OAAOA,CAAAA,CACnC,GAAIH,CAAAA,CAAI,eAAiB,MAAA,CAAW,OAAOA,CAAAA,CAAI,YAAA,CAE/C,MAAMhB,CAAAA,CAAW,QAAQ,CAC3B,CCvGO,SAASoB,CAAAA,CACdC,CAAAA,CACAC,CAAAA,CACa,CACb,IAAMC,CAAAA,CAAK,QAAA,CAAS,aAAA,CAAcF,CAAG,CAAA,CACrC,GAAIC,CAAAA,CACF,IAAA,GAAW,CAACN,CAAAA,CAAKC,CAAK,CAAA,GAAK,OAAO,OAAA,CAAQK,CAAK,CAAA,CAC7CE,CAAAA,CAAYD,EAAIP,CAAAA,CAAKC,CAAK,CAAA,CAG9B,OAAOM,CACT,CAGO,SAASE,CAAAA,CAAWR,CAAAA,CAAqB,CAC9C,OAAO,QAAA,CAAS,cAAA,CAAeA,CAAK,CACtC,CAGO,SAASS,CAAAA,CAAcC,CAAAA,CAAgC,CAC5D,IAAMC,CAAAA,CAAW,SAAS,aAAA,CAAc,UAAU,CAAA,CAClD,OAAAA,CAAAA,CAAS,SAAA,CAAYD,CAAAA,CACdC,CAAAA,CAAS,QAAQ,SAAA,CAAU,IAAI,CACxC,CAIO,SAASJ,CAAAA,CAAYD,CAAAA,CAAiBP,CAAAA,CAAaC,CAAAA,CAAsB,CAC9E,GAAID,CAAAA,GAAQ,OAAA,EAAWA,CAAAA,GAAQ,WAAA,CAC7BO,CAAAA,CAAG,SAAA,CAAYN,CAAAA,CAAAA,KAAAA,GACND,IAAQ,OAAA,EAAW,OAAOC,CAAAA,EAAU,QAAA,EAAYA,IAAU,IAAA,CACnE,MAAA,CAAO,MAAA,CAAOM,CAAAA,CAAG,MAAON,CAAK,CAAA,CAAA,KAAA,GACpBD,CAAAA,GAAQ,WAAA,CACjBO,CAAAA,CAAG,SAAA,CAAYN,CAAAA,CAAAA,KAAAA,GACND,CAAAA,GAAQ,MAEZ,GAAIA,CAAAA,CAAI,UAAA,CAAW,IAAI,EAAG,CAC/B,IAAMa,CAAAA,CAAQb,CAAAA,CAAI,MAAM,CAAC,CAAA,CAAE,WAAA,EAAY,CACvCO,CAAAA,CAAG,gBAAA,CAAiBM,CAAAA,CAAOZ,CAAsB,EACnD,CAAA,KAAWD,CAAAA,IAAOO,CAAAA,CACfA,CAAAA,CAA+BP,CAAG,CAAA,CAAIC,CAAAA,CAC9BA,CAAAA,GAAU,OAASA,CAAAA,EAAS,IAAA,CACrCM,CAAAA,CAAG,eAAA,CAAgBP,CAAG,CAAA,CAEtBO,CAAAA,CAAG,YAAA,CAAaP,EAAKC,CAAAA,GAAU,IAAA,CAAO,EAAA,CAAK,MAAA,CAAOA,CAAK,CAAC,EAE5D,CAKO,SAASa,EAASC,CAAAA,CAAYpB,CAAAA,CAA+B,CAClE,OAAOqB,mBAAAA,CACL,IAAM,CACJD,CAAAA,CAAK,YAAc,MAAA,CAAOpB,CAAAA,EAAI,EAChC,EACA,CAAE,MAAA,CAAQ,IAAK,CACjB,CACF,CAGO,SAASsB,CAAAA,CACdV,CAAAA,CACAP,CAAAA,CACAL,CAAAA,CACY,CACZ,OAAOqB,oBACL,IAAM,CACJR,CAAAA,CAAYD,CAAAA,CAAIP,EAAKL,CAAAA,EAAI,EAC3B,CAAA,CACA,CAAE,MAAA,CAAQ,IAAK,CACjB,CACF,CAGO,SAASuB,CAAAA,CAAYX,CAAAA,CAAiBZ,EAA+B,CAC1E,OAAOqB,mBAAAA,CACL,IAAM,CACJT,CAAAA,CAAG,KAAA,CAAM,OAAA,CAAUZ,GAAG,CAAI,EAAA,CAAK,OACjC,CAAA,CACA,CAAE,MAAA,CAAQ,IAAK,CACjB,CACF,CAOA,SAASwB,CAAAA,CAAaC,CAAAA,CAAQ,GAAY,CACxC,OAAO,QAAA,CAAS,aAAA,CAAcA,CAAK,CACrC,CAWO,SAASC,CAAAA,CACd/B,CAAAA,CACAgC,CAAAA,CACAC,CAAAA,CACAC,CAAAA,CACAC,EACY,CACZ,IAAIC,CAAAA,CAAmC,IAAA,CAGjCnC,EAAQE,CAAAA,EAAgB,CAExBkC,CAAAA,CAAUX,mBAAAA,CACd,IAAM,CACJ,IAAMf,CAAAA,CAAQsB,CAAAA,EAAU,CAGxB,GAAIG,CAAAA,CAAS,CACX,QAAWX,CAAAA,IAAQW,CAAAA,CAAQ,KAAA,CACzB,GAAI,CAAEX,CAAAA,CAAK,UAAA,EAAY,WAAA,CAAYA,CAAI,EAAG,CAAA,KAAQ,CAAC,CAErDW,CAAAA,CAAQ,OAAA,IAAU,CAClBA,CAAAA,CAAU,KACZ,CAIA,IAAME,CAAAA,CAAS3B,CAAAA,CAAQuB,CAAAA,CAAaC,CAAAA,CAC9BI,CAAAA,CAAaP,CAAAA,CAAO,UAAA,CAC1B,GAAIM,CAAAA,EAAUC,CAAAA,CAAY,CACxB,IAAMC,CAAAA,CAAWvC,CAAAA,CAAQG,CAAAA,CAAWH,CAAAA,CAAOqC,CAAM,CAAA,CAAIA,CAAAA,EAAO,CACtDG,CAAAA,CAAQD,aAAoB,gBAAA,CAC9B,KAAA,CAAM,IAAA,CAAKA,CAAAA,CAAS,UAAU,CAAA,CAC9B,CAACA,CAAQ,CAAA,CACb,IAAA,IAAWf,CAAAA,IAAQgB,CAAAA,CACjBF,CAAAA,CAAW,aAAad,CAAAA,CAAMO,CAAM,CAAA,CAEtCI,CAAAA,CAAU,CAAE,KAAA,CAAAK,CAAAA,CAAO,OAAA,CAAS,IAAK,EACnC,CACF,CAAA,CACA,CAAE,MAAA,CAAQ,IAAK,CACjB,CAAA,CAEA,OAAO,IAAM,CAEX,GADAJ,CAAAA,EAAQ,CACJD,EAAS,CACX,IAAA,IAAWX,CAAAA,IAAQW,CAAAA,CAAQ,MACzB,GAAI,CAAEX,CAAAA,CAAK,UAAA,EAAY,WAAA,CAAYA,CAAI,EAAG,CAAA,KAAQ,CAAC,CAErDW,CAAAA,CAAQ,OAAA,KACV,CACF,CACF,CAeO,SAASM,CAAAA,CACd1C,EACAgC,CAAAA,CACAW,CAAAA,CACAC,CAAAA,CACAC,CAAAA,CACY,CACZ,IAAIC,CAAAA,CAA8B,GAG5B7C,CAAAA,CAAQE,CAAAA,EAAgB,CAExBkC,CAAAA,CAAUX,oBACd,IAAM,CACJ,IAAMqB,CAAAA,CAAUJ,GAAM,CAChBK,CAAAA,CAA0B,EAAC,CAC3BC,CAAAA,CAAS,IAAI,GAAA,CAEnB,IAAA,IAAWC,KAAQJ,CAAAA,CACjBG,CAAAA,CAAO,GAAA,CAAIC,CAAAA,CAAK,IAAKA,CAAI,CAAA,CAI3B,IAAA,IAASC,CAAAA,CAAI,EAAGA,CAAAA,CAAIJ,CAAAA,CAAQ,MAAA,CAAQI,CAAAA,EAAAA,CAAK,CACvC,IAAMC,CAAAA,CAAOL,CAAAA,CAAQI,CAAC,CAAA,CAChBzC,CAAAA,CAAMkC,CAAAA,CAAMQ,CAAAA,CAAMD,CAAC,CAAA,CACnBE,CAAAA,CAAWJ,CAAAA,CAAO,GAAA,CAAIvC,CAAG,CAAA,CAE/B,GAAI2C,CAAAA,CACFJ,CAAAA,CAAO,MAAA,CAAOvC,CAAG,CAAA,CACjB2C,CAAAA,CAAS,MAAQD,CAAAA,CACjBJ,CAAAA,CAAS,IAAA,CAAKK,CAAQ,CAAA,CAAA,KACjB,CACL,IAAMb,CAAAA,CAAWvC,EAAQG,CAAAA,CAAWH,CAAAA,CAAO,IAAM4C,CAAAA,CAAWO,CAAAA,CAAMD,CAAC,CAAC,CAAA,CAAIN,EAAWO,CAAAA,CAAMD,CAAC,CAAA,CACpFV,CAAAA,CAAQD,aAAoB,gBAAA,CAC9B,KAAA,CAAM,IAAA,CAAKA,CAAAA,CAAS,UAAU,CAAA,CAC9B,CAACA,CAAQ,CAAA,CACbQ,CAAAA,CAAS,IAAA,CAAK,CAAE,GAAA,CAAAtC,EAAK,KAAA,CAAO0C,CAAAA,CAAM,KAAA,CAAAX,CAAAA,CAAO,QAAS,IAAK,CAAC,EAC1D,CACF,CAGA,IAAA,IAAWS,CAAAA,IAAQD,CAAAA,CAAO,MAAA,EAAO,CAAG,CAClC,IAAA,IAAWxB,CAAAA,IAAQyB,EAAK,KAAA,CAClBzB,CAAAA,CAAK,UAAA,EAAYA,CAAAA,CAAK,WAAW,WAAA,CAAYA,CAAI,CAAA,CAEvDyB,CAAAA,CAAK,YACP,CAIA,IAAMX,CAAAA,CAAaP,CAAAA,CAAO,UAAA,CAC1B,GAAIO,CAAAA,CACF,QAAWW,CAAAA,IAAQF,CAAAA,CACjB,IAAA,IAAWvB,CAAAA,IAAQyB,CAAAA,CAAK,KAAA,CACtBX,CAAAA,CAAW,YAAA,CAAad,EAAMO,CAAM,CAAA,CAK1Cc,CAAAA,CAAeE,EACjB,CAAA,CACA,CAAE,MAAA,CAAQ,IAAK,CACjB,CAAA,CAEA,OAAO,IAAM,CACXX,GAAQ,CACR,IAAA,IAAWa,CAAAA,IAAQJ,CAAAA,CAAc,CAC/B,IAAA,IAAWrB,CAAAA,IAAQyB,CAAAA,CAAK,KAAA,CAClBzB,CAAAA,CAAK,UAAA,EAAYA,CAAAA,CAAK,UAAA,CAAW,YAAYA,CAAI,CAAA,CAEvDyB,CAAAA,CAAK,OAAA,KACP,CACAJ,CAAAA,CAAe,GACjB,CACF,CAgBO,SAASQ,CAAAA,CAAQC,CAAAA,CAA2B,CACjD,IAAMvB,CAAAA,CAASH,CAAAA,CAAa,MAAM,CAAA,CAC5B2B,CAAAA,CAAY,QAAA,CAAS,sBAAA,GAC3BA,CAAAA,CAAU,WAAA,CAAYxB,CAAM,CAAA,CAI5B,IAAMyB,CAAAA,CAAU,OAAOF,CAAAA,CAAM,IAAA,EAAS,UAAA,CAClCA,CAAAA,CAAM,IAAA,CACN,IAAMA,EAAM,IAAA,CAIZG,CAAAA,CACJ,OAAA3B,CAAAA,CACEyB,CAAAA,CACAxB,CAAAA,CACA,KAAQ0B,CAAAA,CAAYD,GAAQ,CAAU,CAAC,CAACC,CAAAA,CAAAA,CACxC,IAAMC,CAAAA,CAAUJ,CAAAA,CAAM,QAAA,CAASG,CAAc,CAAC,CAAA,CAC9CH,CAAAA,CAAM,QAAA,CAAW,IAAMI,CAAAA,CAAUJ,CAAAA,CAAM,QAAA,EAAW,EAAI,MACxD,CAAA,CAEOC,CACT,CAaO,SAASI,CAAAA,CAAOL,CAAAA,CAA0B,CAC/C,IAAMvB,CAAAA,CAASH,CAAAA,CAAa,KAAK,CAAA,CAC3B2B,EAAY,QAAA,CAAS,sBAAA,EAAuB,CAClDA,CAAAA,CAAU,YAAYxB,CAAM,CAAA,CAI5B,IAAM6B,CAAAA,CAAU,OAAON,CAAAA,CAAM,IAAA,EAAS,UAAA,CAClCA,EAAM,IAAA,CACN,IAAMA,CAAAA,CAAM,IAAA,CAEhB,OAAAb,CAAAA,CACEc,CAAAA,CACAxB,CAAAA,CACA6B,CAAAA,CACAN,EAAM,GAAA,CACN,CAACL,CAAAA,CAAMY,CAAAA,GAAUH,CAAAA,CAAUJ,CAAAA,CAAM,QAAA,CAASL,CAAAA,CAAMY,CAAK,CAAC,CACxD,CAAA,CAEON,CACT,CAKO,SAASG,CAAAA,CAAUlC,CAAAA,CAAuB,CAC/C,GAAIA,CAAAA,EAAQ,IAAA,EAAQ,OAAOA,CAAAA,EAAS,SAAA,CAClC,OAAO,QAAA,CAAS,cAAA,CAAe,EAAE,CAAA,CAEnC,GAAI,OAAOA,CAAAA,EAAS,UAAY,OAAOA,CAAAA,EAAS,QAAA,CAC9C,OAAO,SAAS,cAAA,CAAe,MAAA,CAAOA,CAAI,CAAC,CAAA,CAE7C,GAAIA,CAAAA,YAAgB,IAAA,CAClB,OAAOA,CAAAA,CAET,GAAI,KAAA,CAAM,OAAA,CAAQA,CAAI,CAAA,CAAG,CACvB,IAAMe,CAAAA,CAAW,SAAS,sBAAA,EAAuB,CACjD,IAAA,IAAWuB,CAAAA,IAAStC,CAAAA,CAClBe,CAAAA,CAAS,WAAA,CAAYmB,CAAAA,CAAUI,CAAK,CAAC,CAAA,CAEvC,OAAOvB,CACT,CACA,OAAO,QAAA,CAAS,cAAA,CAAe,MAAA,CAAOf,CAAI,CAAC,CAC7C,CAGO,SAASuC,CAAAA,CAAOhE,CAAAA,CAAcyB,CAAAA,CAAiBO,CAAAA,CAAqB,CACzE,IAAMiC,CAAAA,CAAUN,CAAAA,CAAUlC,CAAI,CAAA,CAC1BO,CAAAA,CACFhC,CAAAA,CAAO,YAAA,CAAaiE,EAASjC,CAAM,CAAA,CAEnChC,CAAAA,CAAO,WAAA,CAAYiE,CAAO,EAE9B,CC3VO,SAASC,GAAY7D,CAAAA,CAA+C,CACzE,OAACA,CAAAA,CAAW,WAAa,IAAA,CAClBA,CACT,CA0BA,IAAI8D,EAAsC,IAAA,CAQnC,SAASC,EAAAA,CAAQ/D,CAAAA,CAAqC,CAC3D,GAAI,CAAC8D,CAAAA,CACH,MAAMzE,CAAAA,CAAW,QAAQ,CAAA,CAE3ByE,CAAAA,CAAa,MAAM,IAAA,CAAK9D,CAAE,EAC5B,CAKO,SAASgE,EAAAA,CAAUhE,CAAAA,CAAsB,CAC9C,GAAI,CAAC8D,CAAAA,CACH,MAAMzE,CAAAA,CAAW,QAAQ,CAAA,CAE3ByE,CAAAA,CAAa,OAAA,CAAQ,IAAA,CAAK9D,CAAE,EAC9B,CAKO,SAASiE,EAAAA,CAAQjE,EAAkC,CACxD,GAAI,CAAC8D,CAAAA,CACH,MAAMzE,CAAAA,CAAW,QAAQ,CAAA,CAE3ByE,EAAa,KAAA,CAAM,IAAA,CAAK9D,CAAE,EAC5B,CAKO,SAASkE,EAAAA,EAA+B,CAC7C,OAAO,CAAE,OAAA,CAAS,MAAU,CAC9B,CAeO,SAASC,EAAAA,CACdC,CAAAA,CACc,CACd,IAAMC,CAAAA,CAAaC,CAAAA,EAAqE,CAEtF,GAAM,CAAE,QAAA,CAAUC,CAAAA,CAAc,GAAGC,CAAU,CAAA,CAAIF,CAAAA,EAAY,EAAC,CAiBxDG,CAAAA,CAA2B,CAC/B,KAAA,CAjBY,IAAI,MAAMD,CAAAA,CAA2B,CACjD,GAAA,CAAIE,CAAAA,CAAQrE,EAAKsE,CAAAA,CAAU,CACzB,IAAMC,CAAAA,CAAM,QAAQ,GAAA,CAAIF,CAAAA,CAAQrE,CAAAA,CAAKsE,CAAQ,CAAA,CAE7C,OAAI,OAAOC,CAAAA,EAAQ,YAAeA,CAAAA,CAAY,UAAA,CACrCA,CAAAA,EAAI,CAENA,CACT,CACF,CAAC,CAAA,CASC,QAAA,CANA,OAAOL,CAAAA,EAAiB,UAAA,CACpBA,CAAAA,CACA,IAAMA,CAAAA,EAAgB,IAK5B,CAAA,CAGMM,CAAAA,CAAwB,CAAE,KAAA,CAAO,EAAC,CAAG,OAAA,CAAS,EAAC,CAAG,KAAA,CAAO,EAAG,CAAA,CAC5DC,CAAAA,CAAYhB,CAAAA,CAClBA,CAAAA,CAAee,CAAAA,CAGf,IAAME,CAAAA,CAAcjF,CAAAA,GACdF,CAAAA,CAAQF,CAAAA,CAAUqF,CAAW,CAAA,CAE/BC,EACApB,CAAAA,CAEJ,GAAI,CAEF,GADAoB,EAAWZ,CAAAA,CAAMK,CAAG,CAAA,CAChB,OAAOO,CAAAA,EAAa,UAAA,CAAc,MAAM3F,CAAAA,CAAW,QAAQ,CAAA,CAC/D,IAAM4F,CAAAA,CAAWD,CAAAA,GACjBpB,CAAAA,CAAUN,CAAAA,CAAU2B,CAAQ,EAC9B,OAASC,CAAAA,CAAK,CAGZ,GAFArF,CAAAA,CAASD,CAAK,CAAA,CACdkE,CAAAA,CAAegB,CAAAA,CACXD,EAAM,KAAA,CAAM,MAAA,CAAS,CAAA,CAAG,CAC1B,QAAWM,CAAAA,IAAWN,CAAAA,CAAM,KAAA,CAC1BM,CAAAA,CAAQD,aAAe,KAAA,CAAQA,CAAAA,CAAM,IAAI,KAAA,CAAM,MAAA,CAAOA,CAAG,CAAC,CAAC,EAE7D,OAAO,QAAA,CAAS,aAAA,CAAc,OAAO,CACvC,CACA,MAAMA,CACR,CAGA,OAAArF,CAAAA,CAASD,CAAK,CAAA,CACdkE,CAAAA,CAAegB,CAAAA,CAGXD,CAAAA,CAAM,KAAA,CAAM,MAAA,CAAS,GACvB,cAAA,CAAe,IAAM,CACnB,IAAA,IAAWO,KAAWP,CAAAA,CAAM,KAAA,CAC1B,GAAI,CACF,IAAMQ,CAAAA,CAAUD,CAAAA,EAAQ,CACpB,OAAOC,CAAAA,EAAY,UAAA,EACrBR,CAAAA,CAAM,OAAA,CAAQ,KAAKQ,CAAO,EAE9B,CAAA,MAASH,CAAAA,CAAK,CACZ,IAAA,IAAWC,CAAAA,IAAWN,CAAAA,CAAM,KAAA,CAC1BM,EAAQD,CAAAA,YAAe,KAAA,CAAQA,CAAAA,CAAM,IAAI,KAAA,CAAM,MAAA,CAAOA,CAAG,CAAC,CAAC,EAE/D,CAEJ,CAAC,CAAA,CAGItB,CACT,CAAA,CAEA,OAAAS,CAAAA,CAAU,MAAA,CAAS,KACZA,CACT","file":"chunk-XLHWCP6E.cjs","sourcesContent":["/**\n * Error message catalog.\n *\n * Every AkashJS runtime error has a unique code (AK0001, AK0002, etc.),\n * a one-line description, and a link to detailed documentation.\n *\n * Usage:\n * throw akashError('AK0010', 'provide()');\n */\n\n// --- Error registry ---\n\nexport interface ErrorDef {\n /** Error code */\n code: string;\n /** Short description */\n message: string;\n /** Extended explanation and fix suggestion */\n hint: string;\n}\n\nconst errors: Record<string, ErrorDef> = {\n // --- Context errors (AK001x) ---\n AK0010: {\n code: 'AK0010',\n message: 'provide() called outside of component setup.',\n hint: 'provide() must be called inside defineComponent().',\n },\n AK0012: {\n code: 'AK0012',\n message: 'inject() called outside of component setup.',\n hint: 'inject() must be called inside defineComponent().',\n },\n AK0013: {\n code: 'AK0013',\n message: 'No provider found for injected context.',\n hint: 'Make sure an ancestor component calls provide() with this key.',\n },\n\n // --- Lifecycle errors (AK002x) ---\n AK0020: {\n code: 'AK0020',\n message: 'onMount() called outside of component setup.',\n hint: 'onMount() must be called inside defineComponent().',\n },\n AK0021: {\n code: 'AK0021',\n message: 'onUnmount() called outside of component setup.',\n hint: 'onUnmount() must be called inside defineComponent().',\n },\n AK0022: {\n code: 'AK0022',\n message: 'onError() called outside of component setup.',\n hint: 'onError() must be called inside defineComponent().',\n },\n\n // --- Signal errors (AK003x) ---\n AK0030: {\n code: 'AK0030',\n message: 'Circular dependency detected in computed signal.',\n hint: 'A computed signal is reading itself, directly or via other computeds.',\n },\n AK0031: {\n code: 'AK0031',\n message: 'Signal set() called during computation.',\n hint: 'Do not set signals inside computed() or during effect execution. Use batch() or set signals in event handlers.',\n },\n\n // --- Component errors (AK004x) ---\n AK0040: {\n code: 'AK0040',\n message: 'Component setup must return a render function.',\n hint: 'The function passed to defineComponent() must return () => AkashNode.',\n },\n AK0041: {\n code: 'AK0041',\n message: 'Required prop is missing.',\n hint: 'Check that the parent component is passing all required props.',\n },\n\n // --- Router errors (AK005x) ---\n AK0050: {\n code: 'AK0050',\n message: 'useRoute() called outside of router context.',\n hint: 'Make sure your component is rendered inside a router provider.',\n },\n AK0051: {\n code: 'AK0051',\n message: 'No route matched the current URL.',\n hint: 'Add a catch-all route ([...rest]) to handle unmatched paths.',\n },\n AK0052: {\n code: 'AK0052',\n message: 'Route guard threw an error.',\n hint: 'Check the guard function for unhandled exceptions.',\n },\n\n // --- Form errors (AK006x) ---\n AK0060: {\n code: 'AK0060',\n message: 'Form submitted while invalid.',\n hint: 'The submit handler was not called because validation failed. Check form.errors().',\n },\n AK0061: {\n code: 'AK0061',\n message: 'Async validator timed out.',\n hint: 'The async validator did not resolve within the expected time. Check your async validation logic.',\n },\n\n // --- HTTP errors (AK007x) ---\n AK0070: {\n code: 'AK0070',\n message: 'HTTP request failed.',\n hint: 'Check the server response status and network connectivity.',\n },\n AK0071: {\n code: 'AK0071',\n message: 'createResource() fetcher threw an error.',\n hint: 'Check the fetcher function passed to createResource().',\n },\n};\n\n// --- Public API ---\n\nconst DOC_BASE = 'https://akashjs.dev/errors';\n\n/**\n * Format an AkashJS error with code, message, hint, and doc link.\n */\nexport function formatError(code: string, context?: string): string {\n const def = errors[code];\n if (!def) {\n return `[AkashJS ${code}] Unknown error code.`;\n }\n\n let msg = `[AkashJS ${code}] ${def.message}`;\n if (context) {\n msg += `\\n ${context}`;\n }\n msg += `\\n ${def.hint}`;\n msg += `\\n See: ${DOC_BASE}/${code}`;\n return msg;\n}\n\n/**\n * Create and throw an AkashJS error.\n */\nexport function akashError(code: string, context?: string): Error {\n return new Error(formatError(code, context));\n}\n\n/**\n * Get the error definition for a code.\n */\nexport function getErrorDef(code: string): ErrorDef | undefined {\n return errors[code];\n}\n\n/**\n * Get all registered error codes.\n */\nexport function getAllErrorCodes(): string[] {\n return Object.keys(errors);\n}\n","/**\n * Lightweight dependency injection via provide/inject.\n *\n * Context is scoped to the component tree — no injector hierarchy,\n * no decorators, no classes. Just createContext(), provide(), inject().\n */\n\n// --- Types ---\n\nimport { akashError } from './errors.js';\n\nconst CONTEXT_BRAND = Symbol('akash.context');\n\nexport interface InjectionKey<T> {\n readonly [CONTEXT_BRAND]: true;\n readonly _type: T; // phantom type — never used at runtime\n readonly defaultValue: T | undefined;\n readonly id: symbol;\n}\n\n// --- Context stack (managed by component system) ---\n\ninterface ContextScope {\n values: Map<symbol, unknown>;\n parent: ContextScope | null;\n}\n\nlet currentScope: ContextScope | null = null;\n\n/** @internal — called by defineComponent to push/pop context scopes */\nexport function pushScope(parent: ContextScope | null = currentScope): ContextScope {\n const scope: ContextScope = { values: new Map(), parent };\n currentScope = scope;\n return scope;\n}\n\n/** @internal */\nexport function popScope(scope: ContextScope): void {\n currentScope = scope.parent;\n}\n\n/** @internal */\nexport function getCurrentScope(): ContextScope | null {\n return currentScope;\n}\n\n/**\n * Run a function within a given scope so that provide/inject\n * work correctly for components created asynchronously\n * (e.g., lazy-loaded route components).\n */\nexport function runInScope<T>(scope: ContextScope, fn: () => T): T {\n const prev = currentScope;\n currentScope = scope;\n try {\n return fn();\n } finally {\n currentScope = prev;\n }\n}\n\n// --- Public API ---\n\n/**\n * Create a typed context key with an optional default value.\n *\n * ```ts\n * const ThemeContext = createContext<'light' | 'dark'>('light');\n * ```\n */\nexport function createContext<T>(defaultValue?: T): InjectionKey<T> {\n return {\n [CONTEXT_BRAND]: true,\n _type: undefined as T,\n defaultValue,\n id: Symbol('context'),\n };\n}\n\n/**\n * Provide a value for a context key in the current component scope.\n * All descendant components can inject() this value.\n *\n * Must be called inside defineComponent() setup.\n */\nexport function provide<T>(key: InjectionKey<T>, value: T): void {\n if (!currentScope) {\n throw akashError('AK0010');\n }\n currentScope.values.set(key.id, value);\n}\n\n/**\n * Inject a value from the nearest ancestor that provided it.\n *\n * Must be called inside defineComponent() setup.\n */\nexport function inject<T>(key: InjectionKey<T>): T;\nexport function inject<T>(key: InjectionKey<T>, fallback: T): T;\nexport function inject<T>(key: InjectionKey<T>, fallback?: T): T {\n if (!currentScope) {\n throw akashError('AK0012');\n }\n\n // Walk up the scope chain\n let scope: ContextScope | null = currentScope;\n while (scope) {\n if (scope.values.has(key.id)) {\n return scope.values.get(key.id) as T;\n }\n scope = scope.parent;\n }\n\n // Check fallback, then default\n if (fallback !== undefined) return fallback;\n if (key.defaultValue !== undefined) return key.defaultValue;\n\n throw akashError('AK0013');\n}\n","/**\n * Direct DOM rendering runtime.\n *\n * No virtual DOM. The compiler generates calls to these helpers.\n * Signal reads inside templates become fine-grained effects that\n * update only the specific DOM node that changed.\n */\n\nimport { effect } from './signals.js';\nimport { getCurrentScope, runInScope } from './context.js';\nimport type { AkashNode } from './types.js';\n\n// --- DOM creation helpers (used by compiler output) ---\n\n/** Create an element and optionally set static attributes */\nexport function createElement(\n tag: string,\n attrs?: Record<string, unknown>,\n): HTMLElement {\n const el = document.createElement(tag);\n if (attrs) {\n for (const [key, value] of Object.entries(attrs)) {\n setProperty(el, key, value);\n }\n }\n return el;\n}\n\n/** Create a text node */\nexport function createText(value: string): Text {\n return document.createTextNode(value);\n}\n\n/** Clone a template element for static structure */\nexport function cloneTemplate(html: string): DocumentFragment {\n const template = document.createElement('template');\n template.innerHTML = html;\n return template.content.cloneNode(true) as DocumentFragment;\n}\n\n// --- Property/attribute setting ---\n\nexport function setProperty(el: HTMLElement, key: string, value: unknown): void {\n if (key === 'class' || key === 'className') {\n el.className = value as string;\n } else if (key === 'style' && typeof value === 'object' && value !== null) {\n Object.assign(el.style, value);\n } else if (key === 'innerHTML') {\n el.innerHTML = value as string;\n } else if (key === 'ref') {\n // Handled separately by component system\n } else if (key.startsWith('on')) {\n const event = key.slice(2).toLowerCase();\n el.addEventListener(event, value as EventListener);\n } else if (key in el) {\n (el as Record<string, unknown>)[key] = value;\n } else if (value === false || value == null) {\n el.removeAttribute(key);\n } else {\n el.setAttribute(key, value === true ? '' : String(value));\n }\n}\n\n// --- Reactive binding (used by compiler for dynamic expressions) ---\n\n/** Bind a reactive expression to a text node's content */\nexport function bindText(node: Text, fn: () => unknown): () => void {\n return effect(\n () => {\n node.textContent = String(fn());\n },\n { render: true },\n );\n}\n\n/** Bind a reactive expression to an element's attribute/property */\nexport function bindProperty(\n el: HTMLElement,\n key: string,\n fn: () => unknown,\n): () => void {\n return effect(\n () => {\n setProperty(el, key, fn());\n },\n { render: true },\n );\n}\n\n/** Bind a reactive expression to an element's visibility (display) */\nexport function bindVisible(el: HTMLElement, fn: () => boolean): () => void {\n return effect(\n () => {\n el.style.display = fn() ? '' : 'none';\n },\n { render: true },\n );\n}\n\n// --- Conditional rendering ---\n\n/** Anchor node type for marking insertion points */\ntype Anchor = Comment;\n\nfunction createAnchor(label = ''): Anchor {\n return document.createComment(label);\n}\n\ninterface ConditionalBlock {\n nodes: Node[];\n dispose: (() => void) | null;\n}\n\n/**\n * Render a conditional block. Swaps DOM fragments based on a reactive\n * condition. Used by the compiler for :if directives and <Show>.\n */\nexport function renderConditional(\n parent: Node,\n anchor: Node,\n condition: () => boolean,\n trueBranch: () => Node,\n falseBranch?: () => Node,\n): () => void {\n let current: ConditionalBlock | null = null;\n\n // Capture scope so children created in branches inherit provide/inject context\n const scope = getCurrentScope();\n\n const dispose = effect(\n () => {\n const value = condition();\n\n // Remove old nodes\n if (current) {\n for (const node of current.nodes) {\n try { node.parentNode?.removeChild(node); } catch {}\n }\n current.dispose?.();\n current = null;\n }\n\n // Insert new nodes — use anchor.parentNode since the anchor may have\n // moved from the initial DocumentFragment into the real DOM\n const branch = value ? trueBranch : falseBranch;\n const liveParent = anchor.parentNode;\n if (branch && liveParent) {\n const fragment = scope ? runInScope(scope, branch) : branch();\n const nodes = fragment instanceof DocumentFragment\n ? Array.from(fragment.childNodes)\n : [fragment];\n for (const node of nodes) {\n liveParent.insertBefore(node, anchor);\n }\n current = { nodes, dispose: null };\n }\n },\n { render: true },\n );\n\n return () => {\n dispose();\n if (current) {\n for (const node of current.nodes) {\n try { node.parentNode?.removeChild(node); } catch {}\n }\n current.dispose?.();\n }\n };\n}\n\n// --- List rendering ---\n\ninterface ListItem<T> {\n key: unknown;\n value: T;\n nodes: Node[];\n dispose: (() => void) | null;\n}\n\n/**\n * Render a reactive list with keyed reconciliation.\n * Used by the compiler for :for directives and <For>.\n */\nexport function renderList<T>(\n parent: Node,\n anchor: Node,\n items: () => T[],\n keyFn: (item: T, index: number) => unknown,\n renderItem: (item: T, index: number) => Node,\n): () => void {\n let currentItems: ListItem<T>[] = [];\n\n // Capture scope so children created in renderItem inherit provide/inject context\n const scope = getCurrentScope();\n\n const dispose = effect(\n () => {\n const newData = items();\n const newItems: ListItem<T>[] = [];\n const oldMap = new Map<unknown, ListItem<T>>();\n\n for (const item of currentItems) {\n oldMap.set(item.key, item);\n }\n\n // Build new list, reuse existing DOM nodes when keys match\n for (let i = 0; i < newData.length; i++) {\n const data = newData[i];\n const key = keyFn(data, i);\n const existing = oldMap.get(key);\n\n if (existing) {\n oldMap.delete(key);\n existing.value = data;\n newItems.push(existing);\n } else {\n const fragment = scope ? runInScope(scope, () => renderItem(data, i)) : renderItem(data, i);\n const nodes = fragment instanceof DocumentFragment\n ? Array.from(fragment.childNodes)\n : [fragment];\n newItems.push({ key, value: data, nodes, dispose: null });\n }\n }\n\n // Remove items that are no longer in the list\n for (const item of oldMap.values()) {\n for (const node of item.nodes) {\n if (node.parentNode) node.parentNode.removeChild(node);\n }\n item.dispose?.();\n }\n\n // Reconcile DOM order — use anchor.parentNode since anchor may have\n // moved from the initial DocumentFragment into the real DOM\n const liveParent = anchor.parentNode;\n if (liveParent) {\n for (const item of newItems) {\n for (const node of item.nodes) {\n liveParent.insertBefore(node, anchor);\n }\n }\n }\n\n currentItems = newItems;\n },\n { render: true },\n );\n\n return () => {\n dispose();\n for (const item of currentItems) {\n for (const node of item.nodes) {\n if (node.parentNode) node.parentNode.removeChild(node);\n }\n item.dispose?.();\n }\n currentItems = [];\n };\n}\n\n// --- Built-in control flow components ---\n\n/** Props for the <Show> component */\nexport interface ShowProps<T> {\n when: (() => T | null | undefined | false) | T | null | undefined | false;\n fallback?: () => AkashNode;\n children: (value: T) => AkashNode;\n}\n\n/**\n * <Show> component — conditionally renders children with type narrowing.\n * The children callback receives the non-null/undefined value.\n * `when` can be a reactive getter or a static value.\n */\nexport function Show<T>(props: ShowProps<T>): Node {\n const anchor = createAnchor('show');\n const container = document.createDocumentFragment();\n container.appendChild(anchor);\n\n // Resolve when — if it's a function, always call it (supports both\n // compiler-generated __reactive getters and plain programmatic functions)\n const getWhen = typeof props.when === 'function'\n ? props.when as () => T | null | undefined | false\n : () => props.when as T | null | undefined | false;\n\n // Capture the when value once per evaluation so the condition check\n // and the children callback receive the same value (fixes nested For contexts)\n let whenValue: T | null | undefined | false;\n renderConditional(\n container,\n anchor,\n () => { whenValue = getWhen(); return !!whenValue; },\n () => nodeToDOM(props.children(whenValue as T)),\n props.fallback ? () => nodeToDOM(props.fallback!()) : undefined,\n );\n\n return container;\n}\n\n/** Props for the <For> component */\nexport interface ForProps<T> {\n each: (() => T[]) | T[];\n key: (item: T) => unknown;\n children: (item: T, index: number) => AkashNode;\n}\n\n/**\n * <For> component — renders a list with keyed reconciliation.\n * `each` can be a reactive getter or a static array.\n */\nexport function For<T>(props: ForProps<T>): Node {\n const anchor = createAnchor('for');\n const container = document.createDocumentFragment();\n container.appendChild(anchor);\n\n // Resolve each — if it's a function, always call it (supports both\n // compiler-generated __reactive getters and plain programmatic functions)\n const getEach = typeof props.each === 'function'\n ? props.each as () => T[]\n : () => props.each as T[];\n\n renderList(\n container,\n anchor,\n getEach,\n props.key,\n (item, index) => nodeToDOM(props.children(item, index)),\n );\n\n return container;\n}\n\n// --- Helpers ---\n\n/** Convert an AkashNode to a DOM Node */\nexport function nodeToDOM(node: AkashNode): Node {\n if (node == null || typeof node === 'boolean') {\n return document.createTextNode('');\n }\n if (typeof node === 'string' || typeof node === 'number') {\n return document.createTextNode(String(node));\n }\n if (node instanceof Node) {\n return node;\n }\n if (Array.isArray(node)) {\n const fragment = document.createDocumentFragment();\n for (const child of node) {\n fragment.appendChild(nodeToDOM(child));\n }\n return fragment;\n }\n return document.createTextNode(String(node));\n}\n\n/** Insert a node into a parent before an anchor */\nexport function insert(parent: Node, node: AkashNode, anchor?: Node): void {\n const domNode = nodeToDOM(node);\n if (anchor) {\n parent.insertBefore(domNode, anchor);\n } else {\n parent.appendChild(domNode);\n }\n}\n","/**\n * Component system.\n *\n * Components are functions. defineComponent() wraps a setup function\n * that runs once, establishes signals and effects, and returns a\n * render function that produces DOM nodes.\n */\n\nimport { effect } from './signals.js';\nimport { pushScope, popScope, getCurrentScope } from './context.js';\nimport { nodeToDOM } from './dom.js';\nimport { akashError } from './errors.js';\nimport type { AkashNode } from './types.js';\n\n// --- Reactive getter marker (used by compiler) ---\n\n/** Mark a function as a compiler-generated reactive getter */\nexport function __getter<T>(fn: () => T): (() => T) & { __reactive: true } {\n (fn as any).__reactive = true;\n return fn as any;\n}\n\n// --- Types ---\n\nexport interface Ref<T = HTMLElement> {\n current: T | undefined;\n}\n\nexport interface ComponentContext<P extends Record<string, unknown> = Record<string, unknown>> {\n props: Readonly<P>;\n children: () => AkashNode;\n}\n\nexport type Component<P extends Record<string, unknown> = Record<string, unknown>> = {\n (props: P & { children?: AkashNode | (() => AkashNode) }): Node;\n _akash: true;\n};\n\n// --- Lifecycle hook storage ---\n\ninterface LifecycleHooks {\n mount: Array<() => void | (() => void)>;\n unmount: Array<() => void>;\n error: Array<(error: Error) => void>;\n}\n\nlet currentHooks: LifecycleHooks | null = null;\n\n// --- Public lifecycle hooks ---\n\n/**\n * Register a callback to run after the component is mounted to the DOM.\n * If the callback returns a function, it will be called on unmount (cleanup).\n */\nexport function onMount(fn: () => void | (() => void)): void {\n if (!currentHooks) {\n throw akashError('AK0020');\n }\n currentHooks.mount.push(fn);\n}\n\n/**\n * Register a callback to run before the component is unmounted.\n */\nexport function onUnmount(fn: () => void): void {\n if (!currentHooks) {\n throw akashError('AK0021');\n }\n currentHooks.unmount.push(fn);\n}\n\n/**\n * Register an error handler for this component and its descendants.\n */\nexport function onError(fn: (error: Error) => void): void {\n if (!currentHooks) {\n throw akashError('AK0022');\n }\n currentHooks.error.push(fn);\n}\n\n/**\n * Create a ref for accessing a DOM element.\n */\nexport function ref<T = HTMLElement>(): Ref<T> {\n return { current: undefined };\n}\n\n// --- defineComponent ---\n\n/**\n * Define a component. The setup function runs once per instance.\n * It receives a context with typed props and must return a render function.\n *\n * ```ts\n * const Counter = defineComponent<{ initial: number }>((ctx) => {\n * const count = signal(ctx.props.initial);\n * return () => <div>{count()}</div>;\n * });\n * ```\n */\nexport function defineComponent<P extends Record<string, unknown> = Record<string, unknown>>(\n setup: (ctx: ComponentContext<P>) => () => AkashNode,\n): Component<P> {\n const component = (rawProps: P & { children?: AkashNode | (() => AkashNode) }): Node => {\n // Separate children from props, unwrap getter functions for reactivity\n const { children: childrenProp, ...restProps } = rawProps ?? {};\n const props = new Proxy(restProps as unknown as P, {\n get(target, key, receiver) {\n const val = Reflect.get(target, key, receiver);\n // Unwrap compiler-generated reactive getters (marked with __reactive)\n if (typeof val === 'function' && (val as any).__reactive) {\n return val();\n }\n return val;\n },\n });\n\n const childrenFn: () => AkashNode =\n typeof childrenProp === 'function'\n ? childrenProp\n : () => childrenProp ?? null;\n\n const ctx: ComponentContext<P> = {\n props,\n children: childrenFn,\n };\n\n // Set up lifecycle hooks collector\n const hooks: LifecycleHooks = { mount: [], unmount: [], error: [] };\n const prevHooks = currentHooks;\n currentHooks = hooks;\n\n // Push context scope for provide/inject\n const parentScope = getCurrentScope();\n const scope = pushScope(parentScope);\n\n let renderFn: () => AkashNode;\n let domNode: Node;\n\n try {\n renderFn = setup(ctx);\n if (typeof renderFn !== 'function') { throw akashError('AK0040'); }\n const rendered = renderFn();\n domNode = nodeToDOM(rendered);\n } catch (err) {\n popScope(scope);\n currentHooks = prevHooks;\n if (hooks.error.length > 0) {\n for (const handler of hooks.error) {\n handler(err instanceof Error ? err : new Error(String(err)));\n }\n return document.createComment('error');\n }\n throw err;\n }\n\n // Restore parent state\n popScope(scope);\n currentHooks = prevHooks;\n\n // Run mount callbacks (microtask to ensure DOM is attached)\n if (hooks.mount.length > 0) {\n queueMicrotask(() => {\n for (const mountFn of hooks.mount) {\n try {\n const cleanup = mountFn();\n if (typeof cleanup === 'function') {\n hooks.unmount.push(cleanup);\n }\n } catch (err) {\n for (const handler of hooks.error) {\n handler(err instanceof Error ? err : new Error(String(err)));\n }\n }\n }\n });\n }\n\n return domNode;\n };\n\n component._akash = true as const;\n return component as Component<P>;\n}\n"]}
1
+ {"version":3,"sources":["../src/errors.ts","../src/context.ts","../src/dom.ts","../src/component.ts"],"names":["errors","DOC_BASE","formatError","code","context","def","msg","akashError","getErrorDef","getAllErrorCodes","CONTEXT_BRAND","currentScope","pushScope","parent","scope","popScope","getCurrentScope","runInScope","fn","prev","createContext","defaultValue","provide","key","value","inject","fallback","createElement","tag","attrs","el","setProperty","createText","cloneTemplate","html","template","event","bindText","node","effect","bindProperty","bindVisible","createAnchor","label","renderConditional","anchor","condition","trueBranch","falseBranch","current","dispose","branch","liveParent","fragment","nodes","renderList","items","keyFn","renderItem","currentItems","newData","newItems","oldMap","item","i","data","existing","Show","props","container","getWhen","whenValue","nodeToDOM","For","getEach","index","child","insert","domNode","__getter","currentHooks","onMount","onUnmount","onError","ref","defineComponent","setup","component","rawProps","childrenProp","restProps","ctx","target","receiver","val","hooks","prevHooks","parentScope","renderFn","rendered","err","handler","mountFn","cleanup"],"mappings":"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","file":"chunk-YIVBLM2A.cjs","sourcesContent":["/**\n * Error message catalog.\n *\n * Every AkashJS runtime error has a unique code (AK0001, AK0002, etc.),\n * a one-line description, and a link to detailed documentation.\n *\n * Usage:\n * throw akashError('AK0010', 'provide()');\n */\n\n// --- Error registry ---\n\nexport interface ErrorDef {\n /** Error code */\n code: string;\n /** Short description */\n message: string;\n /** Extended explanation and fix suggestion */\n hint: string;\n}\n\nconst errors: Record<string, ErrorDef> = {\n // --- Context errors (AK001x) ---\n AK0010: {\n code: 'AK0010',\n message: 'provide() called outside of component setup.',\n hint: 'provide() must be called inside defineComponent().',\n },\n AK0012: {\n code: 'AK0012',\n message: 'inject() called outside of component setup.',\n hint: 'inject() must be called inside defineComponent().',\n },\n AK0013: {\n code: 'AK0013',\n message: 'No provider found for injected context.',\n hint: 'Make sure an ancestor component calls provide() with this key.',\n },\n\n // --- Lifecycle errors (AK002x) ---\n AK0020: {\n code: 'AK0020',\n message: 'onMount() called outside of component setup.',\n hint: 'onMount() must be called inside defineComponent().',\n },\n AK0021: {\n code: 'AK0021',\n message: 'onUnmount() called outside of component setup.',\n hint: 'onUnmount() must be called inside defineComponent().',\n },\n AK0022: {\n code: 'AK0022',\n message: 'onError() called outside of component setup.',\n hint: 'onError() must be called inside defineComponent().',\n },\n\n // --- Signal errors (AK003x) ---\n AK0030: {\n code: 'AK0030',\n message: 'Circular dependency detected in computed signal.',\n hint: 'A computed signal is reading itself, directly or via other computeds.',\n },\n AK0031: {\n code: 'AK0031',\n message: 'Signal set() called during computation.',\n hint: 'Do not set signals inside computed() or during effect execution. Use batch() or set signals in event handlers.',\n },\n\n // --- Component errors (AK004x) ---\n AK0040: {\n code: 'AK0040',\n message: 'Component setup must return a render function.',\n hint: 'The function passed to defineComponent() must return () => AkashNode.',\n },\n AK0041: {\n code: 'AK0041',\n message: 'Required prop is missing.',\n hint: 'Check that the parent component is passing all required props.',\n },\n\n // --- Router errors (AK005x) ---\n AK0050: {\n code: 'AK0050',\n message: 'useRoute() called outside of router context.',\n hint: 'Make sure your component is rendered inside a router provider.',\n },\n AK0051: {\n code: 'AK0051',\n message: 'No route matched the current URL.',\n hint: 'Add a catch-all route ([...rest]) to handle unmatched paths.',\n },\n AK0052: {\n code: 'AK0052',\n message: 'Route guard threw an error.',\n hint: 'Check the guard function for unhandled exceptions.',\n },\n\n // --- Form errors (AK006x) ---\n AK0060: {\n code: 'AK0060',\n message: 'Form submitted while invalid.',\n hint: 'The submit handler was not called because validation failed. Check form.errors().',\n },\n AK0061: {\n code: 'AK0061',\n message: 'Async validator timed out.',\n hint: 'The async validator did not resolve within the expected time. Check your async validation logic.',\n },\n\n // --- HTTP errors (AK007x) ---\n AK0070: {\n code: 'AK0070',\n message: 'HTTP request failed.',\n hint: 'Check the server response status and network connectivity.',\n },\n AK0071: {\n code: 'AK0071',\n message: 'createResource() fetcher threw an error.',\n hint: 'Check the fetcher function passed to createResource().',\n },\n};\n\n// --- Public API ---\n\nconst DOC_BASE = 'https://akashjs.dev/errors';\n\n/**\n * Format an AkashJS error with code, message, hint, and doc link.\n */\nexport function formatError(code: string, context?: string): string {\n const def = errors[code];\n if (!def) {\n return `[AkashJS ${code}] Unknown error code.`;\n }\n\n let msg = `[AkashJS ${code}] ${def.message}`;\n if (context) {\n msg += `\\n ${context}`;\n }\n msg += `\\n ${def.hint}`;\n msg += `\\n See: ${DOC_BASE}/${code}`;\n return msg;\n}\n\n/**\n * Create and throw an AkashJS error.\n */\nexport function akashError(code: string, context?: string): Error {\n return new Error(formatError(code, context));\n}\n\n/**\n * Get the error definition for a code.\n */\nexport function getErrorDef(code: string): ErrorDef | undefined {\n return errors[code];\n}\n\n/**\n * Get all registered error codes.\n */\nexport function getAllErrorCodes(): string[] {\n return Object.keys(errors);\n}\n","/**\n * Lightweight dependency injection via provide/inject.\n *\n * Context is scoped to the component tree — no injector hierarchy,\n * no decorators, no classes. Just createContext(), provide(), inject().\n */\n\n// --- Types ---\n\nimport { akashError } from './errors.js';\n\nconst CONTEXT_BRAND = Symbol('akash.context');\n\nexport interface InjectionKey<T> {\n readonly [CONTEXT_BRAND]: true;\n readonly _type: T; // phantom type — never used at runtime\n readonly defaultValue: T | undefined;\n readonly id: symbol;\n}\n\n// --- Context stack (managed by component system) ---\n\ninterface ContextScope {\n values: Map<symbol, unknown>;\n parent: ContextScope | null;\n}\n\nlet currentScope: ContextScope | null = null;\n\n/** @internal — called by defineComponent to push/pop context scopes */\nexport function pushScope(parent: ContextScope | null = currentScope): ContextScope {\n const scope: ContextScope = { values: new Map(), parent };\n currentScope = scope;\n return scope;\n}\n\n/** @internal */\nexport function popScope(scope: ContextScope): void {\n currentScope = scope.parent;\n}\n\n/** @internal */\nexport function getCurrentScope(): ContextScope | null {\n return currentScope;\n}\n\n/**\n * Run a function within a given scope so that provide/inject\n * work correctly for components created asynchronously\n * (e.g., lazy-loaded route components).\n */\nexport function runInScope<T>(scope: ContextScope, fn: () => T): T {\n const prev = currentScope;\n currentScope = scope;\n try {\n return fn();\n } finally {\n currentScope = prev;\n }\n}\n\n// --- Public API ---\n\n/**\n * Create a typed context key with an optional default value.\n *\n * ```ts\n * const ThemeContext = createContext<'light' | 'dark'>('light');\n * ```\n */\nexport function createContext<T>(defaultValue?: T): InjectionKey<T> {\n return {\n [CONTEXT_BRAND]: true,\n _type: undefined as T,\n defaultValue,\n id: Symbol('context'),\n };\n}\n\n/**\n * Provide a value for a context key in the current component scope.\n * All descendant components can inject() this value.\n *\n * Must be called inside defineComponent() setup.\n */\nexport function provide<T>(key: InjectionKey<T>, value: T): void {\n if (!currentScope) {\n throw akashError('AK0010');\n }\n currentScope.values.set(key.id, value);\n}\n\n/**\n * Inject a value from the nearest ancestor that provided it.\n *\n * Must be called inside defineComponent() setup.\n */\nexport function inject<T>(key: InjectionKey<T>): T;\nexport function inject<T>(key: InjectionKey<T>, fallback: T): T;\nexport function inject<T>(key: InjectionKey<T>, fallback?: T): T {\n if (!currentScope) {\n throw akashError('AK0012');\n }\n\n // Walk up the scope chain\n let scope: ContextScope | null = currentScope;\n while (scope) {\n if (scope.values.has(key.id)) {\n return scope.values.get(key.id) as T;\n }\n scope = scope.parent;\n }\n\n // Check fallback, then default\n if (fallback !== undefined) return fallback;\n if (key.defaultValue !== undefined) return key.defaultValue;\n\n throw akashError('AK0013');\n}\n","/**\n * Direct DOM rendering runtime.\n *\n * No virtual DOM. The compiler generates calls to these helpers.\n * Signal reads inside templates become fine-grained effects that\n * update only the specific DOM node that changed.\n */\n\nimport { effect } from './signals.js';\nimport { getCurrentScope, runInScope } from './context.js';\nimport type { AkashNode } from './types.js';\n\n// --- DOM creation helpers (used by compiler output) ---\n\n/** Create an element and optionally set static attributes */\nexport function createElement(\n tag: string,\n attrs?: Record<string, unknown>,\n): HTMLElement {\n const el = document.createElement(tag);\n if (attrs) {\n for (const [key, value] of Object.entries(attrs)) {\n setProperty(el, key, value);\n }\n }\n return el;\n}\n\n/** Create a text node */\nexport function createText(value: string): Text {\n return document.createTextNode(value);\n}\n\n/** Clone a template element for static structure */\nexport function cloneTemplate(html: string): DocumentFragment {\n const template = document.createElement('template');\n template.innerHTML = html;\n return template.content.cloneNode(true) as DocumentFragment;\n}\n\n// --- Property/attribute setting ---\n\nexport function setProperty(el: HTMLElement, key: string, value: unknown): void {\n if (key === 'class' || key === 'className') {\n el.className = value as string;\n } else if (key === 'style' && typeof value === 'object' && value !== null) {\n Object.assign(el.style, value);\n } else if (key === 'innerHTML') {\n el.innerHTML = value as string;\n } else if (key === 'ref') {\n // Handled separately by component system\n } else if (key.startsWith('on')) {\n const event = key.slice(2).toLowerCase();\n el.addEventListener(event, value as EventListener);\n } else if (key in el) {\n (el as Record<string, unknown>)[key] = value;\n } else if (value === false || value == null) {\n el.removeAttribute(key);\n } else {\n el.setAttribute(key, value === true ? '' : String(value));\n }\n}\n\n// --- Reactive binding (used by compiler for dynamic expressions) ---\n\n/** Bind a reactive expression to a text node's content */\nexport function bindText(node: Text, fn: () => unknown): () => void {\n return effect(\n () => {\n node.textContent = String(fn());\n },\n { render: true },\n );\n}\n\n/** Bind a reactive expression to an element's attribute/property */\nexport function bindProperty(\n el: HTMLElement,\n key: string,\n fn: () => unknown,\n): () => void {\n return effect(\n () => {\n setProperty(el, key, fn());\n },\n { render: true },\n );\n}\n\n/** Bind a reactive expression to an element's visibility (display) */\nexport function bindVisible(el: HTMLElement, fn: () => boolean): () => void {\n return effect(\n () => {\n el.style.display = fn() ? '' : 'none';\n },\n { render: true },\n );\n}\n\n// --- Conditional rendering ---\n\n/** Anchor node type for marking insertion points */\ntype Anchor = Comment;\n\nfunction createAnchor(label = ''): Anchor {\n return document.createComment(label);\n}\n\ninterface ConditionalBlock {\n nodes: Node[];\n dispose: (() => void) | null;\n}\n\n/**\n * Render a conditional block. Swaps DOM fragments based on a reactive\n * condition. Used by the compiler for :if directives and <Show>.\n */\nexport function renderConditional(\n parent: Node,\n anchor: Node,\n condition: () => boolean,\n trueBranch: () => Node,\n falseBranch?: () => Node,\n): () => void {\n let current: ConditionalBlock | null = null;\n\n // Capture scope so children created in branches inherit provide/inject context\n const scope = getCurrentScope();\n\n const dispose = effect(\n () => {\n const value = condition();\n\n // Remove old nodes\n if (current) {\n for (const node of current.nodes) {\n try { node.parentNode?.removeChild(node); } catch {}\n }\n current.dispose?.();\n current = null;\n }\n\n // Insert new nodes — use anchor.parentNode since the anchor may have\n // moved from the initial DocumentFragment into the real DOM\n const branch = value ? trueBranch : falseBranch;\n const liveParent = anchor.parentNode;\n if (branch && liveParent) {\n const fragment = scope ? runInScope(scope, branch) : branch();\n const nodes = fragment instanceof DocumentFragment\n ? Array.from(fragment.childNodes)\n : [fragment];\n for (const node of nodes) {\n liveParent.insertBefore(node, anchor);\n }\n current = { nodes, dispose: null };\n }\n },\n { render: true },\n );\n\n return () => {\n dispose();\n if (current) {\n for (const node of current.nodes) {\n try { node.parentNode?.removeChild(node); } catch {}\n }\n current.dispose?.();\n }\n };\n}\n\n// --- List rendering ---\n\ninterface ListItem<T> {\n key: unknown;\n value: T;\n nodes: Node[];\n dispose: (() => void) | null;\n}\n\n/**\n * Render a reactive list with keyed reconciliation.\n * Used by the compiler for :for directives and <For>.\n */\nexport function renderList<T>(\n parent: Node,\n anchor: Node,\n items: () => T[],\n keyFn: (item: T, index: number) => unknown,\n renderItem: (item: T, index: number) => Node,\n): () => void {\n let currentItems: ListItem<T>[] = [];\n\n // Capture scope so children created in renderItem inherit provide/inject context\n const scope = getCurrentScope();\n\n const dispose = effect(\n () => {\n const newData = items();\n const newItems: ListItem<T>[] = [];\n const oldMap = new Map<unknown, ListItem<T>>();\n\n for (const item of currentItems) {\n oldMap.set(item.key, item);\n }\n\n // Build new list, reuse existing DOM nodes when keys match\n for (let i = 0; i < newData.length; i++) {\n const data = newData[i];\n const key = keyFn(data, i);\n const existing = oldMap.get(key);\n\n if (existing) {\n oldMap.delete(key);\n existing.value = data;\n newItems.push(existing);\n } else {\n const fragment = scope ? runInScope(scope, () => renderItem(data, i)) : renderItem(data, i);\n const nodes = fragment instanceof DocumentFragment\n ? Array.from(fragment.childNodes)\n : [fragment];\n newItems.push({ key, value: data, nodes, dispose: null });\n }\n }\n\n // Remove items that are no longer in the list\n for (const item of oldMap.values()) {\n for (const node of item.nodes) {\n if (node.parentNode) node.parentNode.removeChild(node);\n }\n item.dispose?.();\n }\n\n // Reconcile DOM order — use anchor.parentNode since anchor may have\n // moved from the initial DocumentFragment into the real DOM\n const liveParent = anchor.parentNode;\n if (liveParent) {\n for (const item of newItems) {\n for (const node of item.nodes) {\n liveParent.insertBefore(node, anchor);\n }\n }\n }\n\n currentItems = newItems;\n },\n { render: true },\n );\n\n return () => {\n dispose();\n for (const item of currentItems) {\n for (const node of item.nodes) {\n if (node.parentNode) node.parentNode.removeChild(node);\n }\n item.dispose?.();\n }\n currentItems = [];\n };\n}\n\n// --- Built-in control flow components ---\n\n/** Props for the <Show> component */\nexport interface ShowProps<T> {\n when: (() => T | null | undefined | false) | T | null | undefined | false;\n fallback?: () => AkashNode;\n children: (value: T) => AkashNode;\n}\n\n/**\n * <Show> component — conditionally renders children with type narrowing.\n * The children callback receives the non-null/undefined value.\n * `when` can be a reactive getter or a static value.\n */\nexport function Show<T>(props: ShowProps<T>): Node {\n const anchor = createAnchor('show');\n const container = document.createDocumentFragment();\n container.appendChild(anchor);\n\n // Resolve when — if it's a function, always call it (supports both\n // compiler-generated __reactive getters and plain programmatic functions)\n const getWhen = typeof props.when === 'function'\n ? props.when as () => T | null | undefined | false\n : () => props.when as T | null | undefined | false;\n\n // Capture the when value once per evaluation so the condition check\n // and the children callback receive the same value (fixes nested For contexts)\n let whenValue: T | null | undefined | false;\n renderConditional(\n container,\n anchor,\n () => { whenValue = getWhen(); return !!whenValue; },\n () => nodeToDOM(props.children(whenValue as T)),\n props.fallback ? () => nodeToDOM(props.fallback!()) : undefined,\n );\n\n return container;\n}\n\n/** Props for the <For> component */\nexport interface ForProps<T> {\n each: (() => T[]) | T[];\n key: (item: T) => unknown;\n children: (item: T, index: number) => AkashNode;\n}\n\n/**\n * <For> component — renders a list with keyed reconciliation.\n * `each` can be a reactive getter or a static array.\n */\nexport function For<T>(props: ForProps<T>): Node {\n const anchor = createAnchor('for');\n const container = document.createDocumentFragment();\n container.appendChild(anchor);\n\n // Resolve each — if it's a function, always call it (supports both\n // compiler-generated __reactive getters and plain programmatic functions)\n const getEach = typeof props.each === 'function'\n ? props.each as () => T[]\n : () => props.each as T[];\n\n renderList(\n container,\n anchor,\n getEach,\n props.key,\n (item, index) => nodeToDOM(props.children(item, index)),\n );\n\n return container;\n}\n\n// --- Helpers ---\n\n/** Convert an AkashNode to a DOM Node */\nexport function nodeToDOM(node: AkashNode): Node {\n if (node == null || typeof node === 'boolean') {\n return document.createTextNode('');\n }\n if (typeof node === 'string' || typeof node === 'number') {\n return document.createTextNode(String(node));\n }\n if (node instanceof Node) {\n return node;\n }\n if (Array.isArray(node)) {\n const fragment = document.createDocumentFragment();\n for (const child of node) {\n fragment.appendChild(nodeToDOM(child));\n }\n return fragment;\n }\n return document.createTextNode(String(node));\n}\n\n/** Insert a node into a parent before an anchor */\nexport function insert(parent: Node, node: AkashNode, anchor?: Node): void {\n const domNode = nodeToDOM(node);\n if (anchor) {\n parent.insertBefore(domNode, anchor);\n } else {\n parent.appendChild(domNode);\n }\n}\n","/**\n * Component system.\n *\n * Components are functions. defineComponent() wraps a setup function\n * that runs once, establishes signals and effects, and returns a\n * render function that produces DOM nodes.\n */\n\nimport { effect } from './signals.js';\nimport { pushScope, popScope, getCurrentScope } from './context.js';\nimport { nodeToDOM } from './dom.js';\nimport { akashError } from './errors.js';\nimport type { AkashNode } from './types.js';\n\n// --- Reactive getter marker (used by compiler) ---\n\n/** Mark a function as a compiler-generated reactive getter */\nexport function __getter<T>(fn: () => T): (() => T) & { __reactive: true } {\n (fn as any).__reactive = true;\n return fn as any;\n}\n\n// --- Types ---\n\nexport interface Ref<T = HTMLElement> {\n current: T | undefined;\n}\n\nexport interface ComponentContext<P extends Record<string, unknown> = Record<string, unknown>> {\n props: Readonly<P>;\n children: () => AkashNode;\n}\n\nexport type Component<P extends Record<string, unknown> = Record<string, unknown>> = {\n (props: P & { children?: AkashNode | (() => AkashNode) }): Node;\n _akash: true;\n};\n\n// --- Lifecycle hook storage ---\n\ninterface LifecycleHooks {\n mount: Array<() => void | (() => void)>;\n unmount: Array<() => void>;\n error: Array<(error: Error) => void>;\n}\n\nlet currentHooks: LifecycleHooks | null = null;\n\n// --- Public lifecycle hooks ---\n\n/**\n * Register a callback to run after the component is mounted to the DOM.\n * If the callback returns a function, it will be called on unmount (cleanup).\n */\nexport function onMount(fn: () => void | (() => void)): void {\n if (!currentHooks) {\n throw akashError('AK0020');\n }\n currentHooks.mount.push(fn);\n}\n\n/**\n * Register a callback to run before the component is unmounted.\n */\nexport function onUnmount(fn: () => void): void {\n if (!currentHooks) {\n throw akashError('AK0021');\n }\n currentHooks.unmount.push(fn);\n}\n\n/**\n * Register an error handler for this component and its descendants.\n */\nexport function onError(fn: (error: Error) => void): void {\n if (!currentHooks) {\n throw akashError('AK0022');\n }\n currentHooks.error.push(fn);\n}\n\n/**\n * Create a ref for accessing a DOM element.\n */\nexport function ref<T = HTMLElement>(): Ref<T> {\n return { current: undefined };\n}\n\n// --- defineComponent ---\n\n/**\n * Define a component. The setup function runs once per instance.\n * It receives a context with typed props and must return a render function.\n *\n * ```ts\n * const Counter = defineComponent<{ initial: number }>((ctx) => {\n * const count = signal(ctx.props.initial);\n * return () => <div>{count()}</div>;\n * });\n * ```\n */\nexport function defineComponent<P extends Record<string, unknown> = Record<string, unknown>>(\n setup: (ctx: ComponentContext<P>) => () => AkashNode,\n): Component<P> {\n const component = (rawProps: P & { children?: AkashNode | (() => AkashNode) }): Node => {\n // Separate children from props, unwrap getter functions for reactivity\n const { children: childrenProp, ...restProps } = rawProps ?? {};\n const props = new Proxy(restProps as unknown as P, {\n get(target, key, receiver) {\n const val = Reflect.get(target, key, receiver);\n // Unwrap compiler-generated reactive getters (marked with __reactive)\n if (typeof val === 'function' && (val as any).__reactive) {\n return val();\n }\n return val;\n },\n });\n\n const childrenFn: () => AkashNode =\n typeof childrenProp === 'function'\n ? childrenProp\n : () => childrenProp ?? null;\n\n const ctx: ComponentContext<P> = {\n props,\n children: childrenFn,\n };\n\n // Set up lifecycle hooks collector\n const hooks: LifecycleHooks = { mount: [], unmount: [], error: [] };\n const prevHooks = currentHooks;\n currentHooks = hooks;\n\n // Push context scope for provide/inject\n const parentScope = getCurrentScope();\n const scope = pushScope(parentScope);\n\n let renderFn: () => AkashNode;\n let domNode: Node;\n\n try {\n renderFn = setup(ctx);\n if (typeof renderFn !== 'function') { throw akashError('AK0040'); }\n const rendered = renderFn();\n domNode = nodeToDOM(rendered);\n } catch (err) {\n popScope(scope);\n currentHooks = prevHooks;\n if (hooks.error.length > 0) {\n for (const handler of hooks.error) {\n handler(err instanceof Error ? err : new Error(String(err)));\n }\n return document.createComment('error');\n }\n throw err;\n }\n\n // Restore parent state\n popScope(scope);\n currentHooks = prevHooks;\n\n // Run mount callbacks (microtask to ensure DOM is attached)\n if (hooks.mount.length > 0) {\n queueMicrotask(() => {\n for (const mountFn of hooks.mount) {\n try {\n const cleanup = mountFn();\n if (typeof cleanup === 'function') {\n hooks.unmount.push(cleanup);\n }\n } catch (err) {\n for (const handler of hooks.error) {\n handler(err instanceof Error ? err : new Error(String(err)));\n }\n }\n }\n });\n }\n\n return domNode;\n };\n\n component._akash = true as const;\n return component as Component<P>;\n}\n"]}
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkL4DNCDUA_cjs=require('./chunk-L4DNCDUA.cjs');var g=class{entry;constructor(e,n){this.entry={value:e,timestamp:Date.now(),peerId:n};}get value(){return this.entry.value}get timestamp(){return this.entry.timestamp}set(e,n){let s=Date.now();return n===this.entry.peerId||s>this.entry.timestamp||s===this.entry.timestamp&&n>this.entry.peerId?(this.entry={value:e,timestamp:Math.max(s,this.entry.timestamp+1),peerId:n},true):false}merge(e){return e.timestamp>this.entry.timestamp||e.timestamp===this.entry.timestamp&&e.peerId>this.entry.peerId?(this.entry=e,true):false}toEntry(){return {...this.entry}}};function I(i){let e=null,n=[],s=[];return {send(t){e?.send(JSON.stringify({type:"op",room:i.room,...t}));},onReceive(t){n.push(t);let o=false;return ()=>{if(o)return;o=true;let c=n.indexOf(t);c!==-1&&n.splice(c,1);}},onPresence(t){return s.push(t),()=>{let o=s.indexOf(t);o!==-1&&s.splice(o,1);}},sendPresence(t){e?.send(JSON.stringify({type:"presence",room:i.room,data:t}));},connect(){e=new WebSocket(i.url,i.protocols),e.onmessage=t=>{try{let o=JSON.parse(t.data);if(o.type==="op")for(let c of n)c(o);else if(o.type==="presence")for(let c of s)c(o.peerId,o.data);}catch{}},e.onopen=()=>{e?.send(JSON.stringify({type:"join",room:i.room}));};},disconnect(){e?.close(),e=null;}}}function h(){let i=[];return {send(e){for(let n of i)n(e);},onReceive(e){i.push(e);let n=false;return ()=>{if(n)return;n=true;let s=i.indexOf(e);s!==-1&&i.splice(s,1);}},connect(){},disconnect(){}}}var w=0;function O(i,e,n={}){let s=n.peerId??`peer-${++w}-${Date.now()}`,t=n.transport??h(),o=new Map,c={};for(let[r,a]of Object.entries(e))o.set(r,new g(a,s)),c[r]=chunkL4DNCDUA_cjs.c(a);let l={};for(let r of Object.keys(e)){let a=c[r],y=o.get(r),p=(()=>a());p.set=u=>{y.set(u,s),a.set(u),t.send({type:"set",key:r,value:u,timestamp:y.timestamp,peerId:s});},p.update=u=>{p.set(u(a()));},p.peek=()=>a.peek(),l[r]=p;}let S=chunkL4DNCDUA_cjs.c([]),m=chunkL4DNCDUA_cjs.c(false),k=chunkL4DNCDUA_cjs.c({}),f=chunkL4DNCDUA_cjs.c(new Map),v=t.onReceive(r=>{r.type==="set"&&o.has(r.key)&&o.get(r.key).merge({value:r.value,timestamp:r.timestamp,peerId:r.peerId})&&c[r.key].set(r.value);}),T=t.onPresence?.((r,a)=>{f.update(y=>{let p=new Map(y);return p.set(r,a),p});});return {state:l,peers:()=>S(),presence:k,peerPresence:()=>f(),peerId:s,connected:()=>m(),connect(){t.connect(),m.set(true);},disconnect(){t.disconnect(),m.set(false);},dispose(){v(),T?.(),t.disconnect();}}}exports.a=g;exports.b=I;exports.c=h;exports.d=O;//# sourceMappingURL=chunk-VBLTST4K.cjs.map
2
- //# sourceMappingURL=chunk-VBLTST4K.cjs.map
1
+ 'use strict';var chunkRTJ6UDGV_cjs=require('./chunk-RTJ6UDGV.cjs');var g=class{entry;constructor(e,n){this.entry={value:e,timestamp:Date.now(),peerId:n};}get value(){return this.entry.value}get timestamp(){return this.entry.timestamp}set(e,n){let s=Date.now();return n===this.entry.peerId||s>this.entry.timestamp||s===this.entry.timestamp&&n>this.entry.peerId?(this.entry={value:e,timestamp:Math.max(s,this.entry.timestamp+1),peerId:n},true):false}merge(e){return e.timestamp>this.entry.timestamp||e.timestamp===this.entry.timestamp&&e.peerId>this.entry.peerId?(this.entry=e,true):false}toEntry(){return {...this.entry}}};function I(i){let e=null,n=[],s=[];return {send(t){e?.send(JSON.stringify({type:"op",room:i.room,...t}));},onReceive(t){n.push(t);let o=false;return ()=>{if(o)return;o=true;let c=n.indexOf(t);c!==-1&&n.splice(c,1);}},onPresence(t){return s.push(t),()=>{let o=s.indexOf(t);o!==-1&&s.splice(o,1);}},sendPresence(t){e?.send(JSON.stringify({type:"presence",room:i.room,data:t}));},connect(){e=new WebSocket(i.url,i.protocols),e.onmessage=t=>{try{let o=JSON.parse(t.data);if(o.type==="op")for(let c of n)c(o);else if(o.type==="presence")for(let c of s)c(o.peerId,o.data);}catch{}},e.onopen=()=>{e?.send(JSON.stringify({type:"join",room:i.room}));};},disconnect(){e?.close(),e=null;}}}function h(){let i=[];return {send(e){for(let n of i)n(e);},onReceive(e){i.push(e);let n=false;return ()=>{if(n)return;n=true;let s=i.indexOf(e);s!==-1&&i.splice(s,1);}},connect(){},disconnect(){}}}var w=0;function O(i,e,n={}){let s=n.peerId??`peer-${++w}-${Date.now()}`,t=n.transport??h(),o=new Map,c={};for(let[r,a]of Object.entries(e))o.set(r,new g(a,s)),c[r]=chunkRTJ6UDGV_cjs.l(a);let l={};for(let r of Object.keys(e)){let a=c[r],y=o.get(r),p=(()=>a());p.set=u=>{y.set(u,s),a.set(u),t.send({type:"set",key:r,value:u,timestamp:y.timestamp,peerId:s});},p.update=u=>{p.set(u(a()));},p.peek=()=>a.peek(),l[r]=p;}let S=chunkRTJ6UDGV_cjs.l([]),m=chunkRTJ6UDGV_cjs.l(false),k=chunkRTJ6UDGV_cjs.l({}),f=chunkRTJ6UDGV_cjs.l(new Map),v=t.onReceive(r=>{r.type==="set"&&o.has(r.key)&&o.get(r.key).merge({value:r.value,timestamp:r.timestamp,peerId:r.peerId})&&c[r.key].set(r.value);}),T=t.onPresence?.((r,a)=>{f.update(y=>{let p=new Map(y);return p.set(r,a),p});});return {state:l,peers:()=>S(),presence:k,peerPresence:()=>f(),peerId:s,connected:()=>m(),connect(){t.connect(),m.set(true);},disconnect(){t.disconnect(),m.set(false);},dispose(){v(),T?.(),t.disconnect();}}}exports.a=g;exports.b=I;exports.c=h;exports.d=O;//# sourceMappingURL=chunk-YN2TQLVA.cjs.map
2
+ //# sourceMappingURL=chunk-YN2TQLVA.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/sync.ts"],"names":["LWWRegister","initialValue","peerId","value","ts","remote","createWebSocketTransport","options","ws","opHandlers","presenceHandlers","op","handler","removed","i","data","e","msg","h","createLocalTransport","peerIdCounter","createSync","roomId","initialState","transport","registers","stateSignals","key","signal","state","original","register","proxy","fn","peers","connected","presence","peerPresenceMap","unsubOps","unsubPresence","remotePeerId","map","next"],"mappings":"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","file":"chunk-VBLTST4K.cjs","sourcesContent":["/**\n * Collaborative signals with CRDT.\n *\n * Make any signal multiplayer with one line. Multiple users can\n * edit the same state simultaneously with automatic conflict\n * resolution via Last-Writer-Wins Register and Operation-based CRDTs.\n *\n * ```ts\n * const doc = createSync('doc-123', {\n * title: '',\n * blocks: [],\n * cursor: { x: 0, y: 0 },\n * });\n *\n * doc.state.title.set('Hello'); // syncs to all peers\n * doc.peers(); // list of connected users\n * doc.presence.set({ cursor: { x: 10, y: 20 } });\n * ```\n */\n\nimport { signal, computed } from './signals.js';\nimport type { Signal, ReadonlySignal } from './signals.js';\n\n// =========================================================================\n// CRDT — Last-Writer-Wins Register\n// =========================================================================\n\nexport interface LWWEntry<T> {\n value: T;\n timestamp: number;\n peerId: string;\n}\n\n/**\n * Last-Writer-Wins Register — simplest CRDT for single values.\n * The write with the highest timestamp wins on conflict.\n */\nexport class LWWRegister<T> {\n private entry: LWWEntry<T>;\n\n constructor(initialValue: T, peerId: string) {\n this.entry = { value: initialValue, timestamp: Date.now(), peerId };\n }\n\n get value(): T {\n return this.entry.value;\n }\n\n get timestamp(): number {\n return this.entry.timestamp;\n }\n\n set(value: T, peerId: string): boolean {\n const ts = Date.now();\n // Local writes always succeed (same peer always advances its own state).\n // Cross-peer conflicts resolve by highest timestamp, then peerId tiebreak.\n if (\n peerId === this.entry.peerId ||\n ts > this.entry.timestamp ||\n (ts === this.entry.timestamp && peerId > this.entry.peerId)\n ) {\n this.entry = { value, timestamp: Math.max(ts, this.entry.timestamp + 1), peerId };\n return true;\n }\n return false;\n }\n\n merge(remote: LWWEntry<T>): boolean {\n if (\n remote.timestamp > this.entry.timestamp ||\n (remote.timestamp === this.entry.timestamp && remote.peerId > this.entry.peerId)\n ) {\n this.entry = remote;\n return true;\n }\n return false;\n }\n\n toEntry(): LWWEntry<T> {\n return { ...this.entry };\n }\n}\n\n// =========================================================================\n// Operation log for list CRDTs\n// =========================================================================\n\nexport type SyncOp =\n | { type: 'set'; key: string; value: unknown; timestamp: number; peerId: string }\n | { type: 'insert'; key: string; index: number; value: unknown; timestamp: number; peerId: string }\n | { type: 'delete'; key: string; index: number; timestamp: number; peerId: string };\n\n// =========================================================================\n// Sync transport interface\n// =========================================================================\n\nexport interface SyncTransport {\n /** Send an operation to peers */\n send(op: SyncOp): void;\n /** Listen for operations from peers */\n onReceive(handler: (op: SyncOp) => void): () => void;\n /** Listen for peer presence updates */\n onPresence?(handler: (peerId: string, data: unknown) => void): () => void;\n /** Send presence data */\n sendPresence?(data: unknown): void;\n /** Connect to the sync channel */\n connect(): void;\n /** Disconnect */\n disconnect(): void;\n}\n\n// =========================================================================\n// WebSocket transport\n// =========================================================================\n\nexport interface WebSocketTransportOptions {\n url: string;\n room: string;\n protocols?: string | string[];\n}\n\nexport function createWebSocketTransport(options: WebSocketTransportOptions): SyncTransport {\n let ws: WebSocket | null = null;\n const opHandlers: Array<(op: SyncOp) => void> = [];\n const presenceHandlers: Array<(peerId: string, data: unknown) => void> = [];\n\n return {\n send(op: SyncOp) {\n ws?.send(JSON.stringify({ type: 'op', room: options.room, ...op }));\n },\n onReceive(handler) {\n opHandlers.push(handler);\n let removed = false;\n return () => {\n if (removed) return;\n removed = true;\n const i = opHandlers.indexOf(handler);\n if (i !== -1) opHandlers.splice(i, 1);\n };\n },\n onPresence(handler) {\n presenceHandlers.push(handler);\n return () => {\n const i = presenceHandlers.indexOf(handler);\n if (i !== -1) presenceHandlers.splice(i, 1);\n };\n },\n sendPresence(data) {\n ws?.send(JSON.stringify({ type: 'presence', room: options.room, data }));\n },\n connect() {\n ws = new WebSocket(options.url, options.protocols);\n ws.onmessage = (e) => {\n try {\n const msg = JSON.parse(e.data);\n if (msg.type === 'op') {\n for (const h of opHandlers) h(msg);\n } else if (msg.type === 'presence') {\n for (const h of presenceHandlers) h(msg.peerId, msg.data);\n }\n } catch { /* ignore parse errors */ }\n };\n ws.onopen = () => {\n ws?.send(JSON.stringify({ type: 'join', room: options.room }));\n };\n },\n disconnect() {\n ws?.close();\n ws = null;\n },\n };\n}\n\n// =========================================================================\n// In-memory transport (for testing / single-tab)\n// =========================================================================\n\nexport function createLocalTransport(): SyncTransport {\n const opHandlers: Array<(op: SyncOp) => void> = [];\n return {\n send(op) {\n for (const h of opHandlers) h(op);\n },\n onReceive(handler) {\n opHandlers.push(handler);\n let removed = false;\n return () => {\n if (removed) return;\n removed = true;\n const i = opHandlers.indexOf(handler);\n if (i !== -1) opHandlers.splice(i, 1);\n };\n },\n connect() {},\n disconnect() {},\n };\n}\n\n// =========================================================================\n// createSync — the main API\n// =========================================================================\n\nexport interface SyncOptions {\n /** Transport for sending/receiving operations */\n transport?: SyncTransport;\n /** Unique peer ID (default: random) */\n peerId?: string;\n}\n\nexport interface SyncDoc<T extends Record<string, unknown>> {\n /** Reactive synced state — each key is a Signal */\n state: { [K in keyof T]: Signal<T[K]> };\n /** Connected peers (reactive) */\n peers: ReadonlySignal<PeerInfo[]>;\n /** Local presence data */\n presence: Signal<Record<string, unknown>>;\n /** Peer presence map (reactive) */\n peerPresence: ReadonlySignal<Map<string, unknown>>;\n /** This peer's ID */\n peerId: string;\n /** Whether connected */\n connected: ReadonlySignal<boolean>;\n /** Connect to the sync channel */\n connect(): void;\n /** Disconnect */\n disconnect(): void;\n /** Dispose the sync doc */\n dispose(): void;\n}\n\nexport interface PeerInfo {\n id: string;\n joinedAt: number;\n}\n\nlet peerIdCounter = 0;\n\n/**\n * Create a collaborative synced document.\n *\n * ```ts\n * const doc = createSync('room-1', { title: '', count: 0 }, {\n * transport: createWebSocketTransport({ url: 'wss://sync.example.com', room: 'room-1' }),\n * });\n *\n * doc.state.title.set('Hello'); // auto-syncs to all peers\n * doc.peers(); // connected users\n * ```\n */\nexport function createSync<T extends Record<string, unknown>>(\n roomId: string,\n initialState: T,\n options: SyncOptions = {},\n): SyncDoc<T> {\n const peerId = options.peerId ?? `peer-${++peerIdCounter}-${Date.now()}`;\n const transport = options.transport ?? createLocalTransport();\n\n // Create CRDT registers and signals for each state key\n const registers = new Map<string, LWWRegister<unknown>>();\n const stateSignals: Record<string, Signal<unknown>> = {};\n\n for (const [key, value] of Object.entries(initialState)) {\n registers.set(key, new LWWRegister(value, peerId));\n stateSignals[key] = signal(value);\n }\n\n // Intercept signal.set to broadcast operations\n const state = {} as { [K in keyof T]: Signal<T[K]> };\n for (const key of Object.keys(initialState)) {\n const original = stateSignals[key];\n const register = registers.get(key)!;\n\n const proxy: Signal<any> = (() => original()) as any;\n proxy.set = (value: any) => {\n register.set(value, peerId);\n original.set(value);\n transport.send({\n type: 'set',\n key,\n value,\n timestamp: register.timestamp,\n peerId,\n });\n };\n proxy.update = (fn: (prev: any) => any) => {\n proxy.set(fn(original()));\n };\n proxy.peek = () => original.peek();\n\n (state as any)[key] = proxy;\n }\n\n // Peers\n const peers = signal<PeerInfo[]>([]);\n const connected = signal(false);\n const presence = signal<Record<string, unknown>>({});\n const peerPresenceMap = signal(new Map<string, unknown>());\n\n // Listen for remote operations\n const unsubOps = transport.onReceive((op) => {\n if (op.type === 'set' && registers.has(op.key)) {\n const register = registers.get(op.key)!;\n const merged = register.merge({\n value: op.value,\n timestamp: op.timestamp,\n peerId: op.peerId,\n });\n if (merged) {\n stateSignals[op.key].set(op.value);\n }\n }\n });\n\n // Listen for presence\n const unsubPresence = transport.onPresence?.((remotePeerId, data) => {\n peerPresenceMap.update((map) => {\n const next = new Map(map);\n next.set(remotePeerId, data);\n return next;\n });\n });\n\n return {\n state,\n peers: () => peers(),\n presence,\n peerPresence: () => peerPresenceMap(),\n peerId,\n connected: () => connected(),\n connect() {\n transport.connect();\n connected.set(true);\n },\n disconnect() {\n transport.disconnect();\n connected.set(false);\n },\n dispose() {\n unsubOps();\n unsubPresence?.();\n transport.disconnect();\n },\n };\n}\n"]}
1
+ {"version":3,"sources":["../src/sync.ts"],"names":["LWWRegister","initialValue","peerId","value","ts","remote","createWebSocketTransport","options","ws","opHandlers","presenceHandlers","op","handler","removed","i","data","e","msg","h","createLocalTransport","peerIdCounter","createSync","roomId","initialState","transport","registers","stateSignals","key","signal","state","original","register","proxy","fn","peers","connected","presence","peerPresenceMap","unsubOps","unsubPresence","remotePeerId","map","next"],"mappings":"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","file":"chunk-YN2TQLVA.cjs","sourcesContent":["/**\n * Collaborative signals with CRDT.\n *\n * Make any signal multiplayer with one line. Multiple users can\n * edit the same state simultaneously with automatic conflict\n * resolution via Last-Writer-Wins Register and Operation-based CRDTs.\n *\n * ```ts\n * const doc = createSync('doc-123', {\n * title: '',\n * blocks: [],\n * cursor: { x: 0, y: 0 },\n * });\n *\n * doc.state.title.set('Hello'); // syncs to all peers\n * doc.peers(); // list of connected users\n * doc.presence.set({ cursor: { x: 10, y: 20 } });\n * ```\n */\n\nimport { signal, computed } from './signals.js';\nimport type { Signal, ReadonlySignal } from './signals.js';\n\n// =========================================================================\n// CRDT — Last-Writer-Wins Register\n// =========================================================================\n\nexport interface LWWEntry<T> {\n value: T;\n timestamp: number;\n peerId: string;\n}\n\n/**\n * Last-Writer-Wins Register — simplest CRDT for single values.\n * The write with the highest timestamp wins on conflict.\n */\nexport class LWWRegister<T> {\n private entry: LWWEntry<T>;\n\n constructor(initialValue: T, peerId: string) {\n this.entry = { value: initialValue, timestamp: Date.now(), peerId };\n }\n\n get value(): T {\n return this.entry.value;\n }\n\n get timestamp(): number {\n return this.entry.timestamp;\n }\n\n set(value: T, peerId: string): boolean {\n const ts = Date.now();\n // Local writes always succeed (same peer always advances its own state).\n // Cross-peer conflicts resolve by highest timestamp, then peerId tiebreak.\n if (\n peerId === this.entry.peerId ||\n ts > this.entry.timestamp ||\n (ts === this.entry.timestamp && peerId > this.entry.peerId)\n ) {\n this.entry = { value, timestamp: Math.max(ts, this.entry.timestamp + 1), peerId };\n return true;\n }\n return false;\n }\n\n merge(remote: LWWEntry<T>): boolean {\n if (\n remote.timestamp > this.entry.timestamp ||\n (remote.timestamp === this.entry.timestamp && remote.peerId > this.entry.peerId)\n ) {\n this.entry = remote;\n return true;\n }\n return false;\n }\n\n toEntry(): LWWEntry<T> {\n return { ...this.entry };\n }\n}\n\n// =========================================================================\n// Operation log for list CRDTs\n// =========================================================================\n\nexport type SyncOp =\n | { type: 'set'; key: string; value: unknown; timestamp: number; peerId: string }\n | { type: 'insert'; key: string; index: number; value: unknown; timestamp: number; peerId: string }\n | { type: 'delete'; key: string; index: number; timestamp: number; peerId: string };\n\n// =========================================================================\n// Sync transport interface\n// =========================================================================\n\nexport interface SyncTransport {\n /** Send an operation to peers */\n send(op: SyncOp): void;\n /** Listen for operations from peers */\n onReceive(handler: (op: SyncOp) => void): () => void;\n /** Listen for peer presence updates */\n onPresence?(handler: (peerId: string, data: unknown) => void): () => void;\n /** Send presence data */\n sendPresence?(data: unknown): void;\n /** Connect to the sync channel */\n connect(): void;\n /** Disconnect */\n disconnect(): void;\n}\n\n// =========================================================================\n// WebSocket transport\n// =========================================================================\n\nexport interface WebSocketTransportOptions {\n url: string;\n room: string;\n protocols?: string | string[];\n}\n\nexport function createWebSocketTransport(options: WebSocketTransportOptions): SyncTransport {\n let ws: WebSocket | null = null;\n const opHandlers: Array<(op: SyncOp) => void> = [];\n const presenceHandlers: Array<(peerId: string, data: unknown) => void> = [];\n\n return {\n send(op: SyncOp) {\n ws?.send(JSON.stringify({ type: 'op', room: options.room, ...op }));\n },\n onReceive(handler) {\n opHandlers.push(handler);\n let removed = false;\n return () => {\n if (removed) return;\n removed = true;\n const i = opHandlers.indexOf(handler);\n if (i !== -1) opHandlers.splice(i, 1);\n };\n },\n onPresence(handler) {\n presenceHandlers.push(handler);\n return () => {\n const i = presenceHandlers.indexOf(handler);\n if (i !== -1) presenceHandlers.splice(i, 1);\n };\n },\n sendPresence(data) {\n ws?.send(JSON.stringify({ type: 'presence', room: options.room, data }));\n },\n connect() {\n ws = new WebSocket(options.url, options.protocols);\n ws.onmessage = (e) => {\n try {\n const msg = JSON.parse(e.data);\n if (msg.type === 'op') {\n for (const h of opHandlers) h(msg);\n } else if (msg.type === 'presence') {\n for (const h of presenceHandlers) h(msg.peerId, msg.data);\n }\n } catch { /* ignore parse errors */ }\n };\n ws.onopen = () => {\n ws?.send(JSON.stringify({ type: 'join', room: options.room }));\n };\n },\n disconnect() {\n ws?.close();\n ws = null;\n },\n };\n}\n\n// =========================================================================\n// In-memory transport (for testing / single-tab)\n// =========================================================================\n\nexport function createLocalTransport(): SyncTransport {\n const opHandlers: Array<(op: SyncOp) => void> = [];\n return {\n send(op) {\n for (const h of opHandlers) h(op);\n },\n onReceive(handler) {\n opHandlers.push(handler);\n let removed = false;\n return () => {\n if (removed) return;\n removed = true;\n const i = opHandlers.indexOf(handler);\n if (i !== -1) opHandlers.splice(i, 1);\n };\n },\n connect() {},\n disconnect() {},\n };\n}\n\n// =========================================================================\n// createSync — the main API\n// =========================================================================\n\nexport interface SyncOptions {\n /** Transport for sending/receiving operations */\n transport?: SyncTransport;\n /** Unique peer ID (default: random) */\n peerId?: string;\n}\n\nexport interface SyncDoc<T extends Record<string, unknown>> {\n /** Reactive synced state — each key is a Signal */\n state: { [K in keyof T]: Signal<T[K]> };\n /** Connected peers (reactive) */\n peers: ReadonlySignal<PeerInfo[]>;\n /** Local presence data */\n presence: Signal<Record<string, unknown>>;\n /** Peer presence map (reactive) */\n peerPresence: ReadonlySignal<Map<string, unknown>>;\n /** This peer's ID */\n peerId: string;\n /** Whether connected */\n connected: ReadonlySignal<boolean>;\n /** Connect to the sync channel */\n connect(): void;\n /** Disconnect */\n disconnect(): void;\n /** Dispose the sync doc */\n dispose(): void;\n}\n\nexport interface PeerInfo {\n id: string;\n joinedAt: number;\n}\n\nlet peerIdCounter = 0;\n\n/**\n * Create a collaborative synced document.\n *\n * ```ts\n * const doc = createSync('room-1', { title: '', count: 0 }, {\n * transport: createWebSocketTransport({ url: 'wss://sync.example.com', room: 'room-1' }),\n * });\n *\n * doc.state.title.set('Hello'); // auto-syncs to all peers\n * doc.peers(); // connected users\n * ```\n */\nexport function createSync<T extends Record<string, unknown>>(\n roomId: string,\n initialState: T,\n options: SyncOptions = {},\n): SyncDoc<T> {\n const peerId = options.peerId ?? `peer-${++peerIdCounter}-${Date.now()}`;\n const transport = options.transport ?? createLocalTransport();\n\n // Create CRDT registers and signals for each state key\n const registers = new Map<string, LWWRegister<unknown>>();\n const stateSignals: Record<string, Signal<unknown>> = {};\n\n for (const [key, value] of Object.entries(initialState)) {\n registers.set(key, new LWWRegister(value, peerId));\n stateSignals[key] = signal(value);\n }\n\n // Intercept signal.set to broadcast operations\n const state = {} as { [K in keyof T]: Signal<T[K]> };\n for (const key of Object.keys(initialState)) {\n const original = stateSignals[key];\n const register = registers.get(key)!;\n\n const proxy: Signal<any> = (() => original()) as any;\n proxy.set = (value: any) => {\n register.set(value, peerId);\n original.set(value);\n transport.send({\n type: 'set',\n key,\n value,\n timestamp: register.timestamp,\n peerId,\n });\n };\n proxy.update = (fn: (prev: any) => any) => {\n proxy.set(fn(original()));\n };\n proxy.peek = () => original.peek();\n\n (state as any)[key] = proxy;\n }\n\n // Peers\n const peers = signal<PeerInfo[]>([]);\n const connected = signal(false);\n const presence = signal<Record<string, unknown>>({});\n const peerPresenceMap = signal(new Map<string, unknown>());\n\n // Listen for remote operations\n const unsubOps = transport.onReceive((op) => {\n if (op.type === 'set' && registers.has(op.key)) {\n const register = registers.get(op.key)!;\n const merged = register.merge({\n value: op.value,\n timestamp: op.timestamp,\n peerId: op.peerId,\n });\n if (merged) {\n stateSignals[op.key].set(op.value);\n }\n }\n });\n\n // Listen for presence\n const unsubPresence = transport.onPresence?.((remotePeerId, data) => {\n peerPresenceMap.update((map) => {\n const next = new Map(map);\n next.set(remotePeerId, data);\n return next;\n });\n });\n\n return {\n state,\n peers: () => peers(),\n presence,\n peerPresence: () => peerPresenceMap(),\n peerId,\n connected: () => connected(),\n connect() {\n transport.connect();\n connected.set(true);\n },\n disconnect() {\n transport.disconnect();\n connected.set(false);\n },\n dispose() {\n unsubOps();\n unsubPresence?.();\n transport.disconnect();\n },\n };\n}\n"]}
package/dist/core.cjs CHANGED
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkXLHWCP6E_cjs=require('./chunk-XLHWCP6E.cjs'),chunkL4DNCDUA_cjs=require('./chunk-L4DNCDUA.cjs');Object.defineProperty(exports,"For",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.t}});Object.defineProperty(exports,"Show",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.s}});Object.defineProperty(exports,"bindProperty",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.o}});Object.defineProperty(exports,"bindText",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.n}});Object.defineProperty(exports,"bindVisible",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.p}});Object.defineProperty(exports,"cloneTemplate",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.l}});Object.defineProperty(exports,"createContext",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.g}});Object.defineProperty(exports,"createElement",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.j}});Object.defineProperty(exports,"createText",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.k}});Object.defineProperty(exports,"defineComponent",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.B}});Object.defineProperty(exports,"inject",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.i}});Object.defineProperty(exports,"insert",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.v}});Object.defineProperty(exports,"nodeToDOM",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.u}});Object.defineProperty(exports,"onError",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.z}});Object.defineProperty(exports,"onMount",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.x}});Object.defineProperty(exports,"onUnmount",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.y}});Object.defineProperty(exports,"provide",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.h}});Object.defineProperty(exports,"ref",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.A}});Object.defineProperty(exports,"renderConditional",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.q}});Object.defineProperty(exports,"renderList",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.r}});Object.defineProperty(exports,"setProperty",{enumerable:true,get:function(){return chunkXLHWCP6E_cjs.m}});Object.defineProperty(exports,"batch",{enumerable:true,get:function(){return chunkL4DNCDUA_cjs.a}});Object.defineProperty(exports,"computed",{enumerable:true,get:function(){return chunkL4DNCDUA_cjs.d}});Object.defineProperty(exports,"effect",{enumerable:true,get:function(){return chunkL4DNCDUA_cjs.e}});Object.defineProperty(exports,"flushSync",{enumerable:true,get:function(){return chunkL4DNCDUA_cjs.b}});Object.defineProperty(exports,"signal",{enumerable:true,get:function(){return chunkL4DNCDUA_cjs.c}});Object.defineProperty(exports,"untrack",{enumerable:true,get:function(){return chunkL4DNCDUA_cjs.f}});//# sourceMappingURL=core.cjs.map
1
+ 'use strict';var chunkYIVBLM2A_cjs=require('./chunk-YIVBLM2A.cjs'),chunkRTJ6UDGV_cjs=require('./chunk-RTJ6UDGV.cjs');Object.defineProperty(exports,"For",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.t}});Object.defineProperty(exports,"Show",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.s}});Object.defineProperty(exports,"bindProperty",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.o}});Object.defineProperty(exports,"bindText",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.n}});Object.defineProperty(exports,"bindVisible",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.p}});Object.defineProperty(exports,"cloneTemplate",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.l}});Object.defineProperty(exports,"createContext",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.g}});Object.defineProperty(exports,"createElement",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.j}});Object.defineProperty(exports,"createText",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.k}});Object.defineProperty(exports,"defineComponent",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.B}});Object.defineProperty(exports,"inject",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.i}});Object.defineProperty(exports,"insert",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.v}});Object.defineProperty(exports,"nodeToDOM",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.u}});Object.defineProperty(exports,"onError",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.z}});Object.defineProperty(exports,"onMount",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.x}});Object.defineProperty(exports,"onUnmount",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.y}});Object.defineProperty(exports,"provide",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.h}});Object.defineProperty(exports,"ref",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.A}});Object.defineProperty(exports,"renderConditional",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.q}});Object.defineProperty(exports,"renderList",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.r}});Object.defineProperty(exports,"setProperty",{enumerable:true,get:function(){return chunkYIVBLM2A_cjs.m}});Object.defineProperty(exports,"batch",{enumerable:true,get:function(){return chunkRTJ6UDGV_cjs.a}});Object.defineProperty(exports,"computed",{enumerable:true,get:function(){return chunkRTJ6UDGV_cjs.m}});Object.defineProperty(exports,"effect",{enumerable:true,get:function(){return chunkRTJ6UDGV_cjs.n}});Object.defineProperty(exports,"flushSync",{enumerable:true,get:function(){return chunkRTJ6UDGV_cjs.b}});Object.defineProperty(exports,"signal",{enumerable:true,get:function(){return chunkRTJ6UDGV_cjs.l}});Object.defineProperty(exports,"untrack",{enumerable:true,get:function(){return chunkRTJ6UDGV_cjs.o}});//# sourceMappingURL=core.cjs.map
2
2
  //# sourceMappingURL=core.cjs.map
package/dist/core.js CHANGED
@@ -1,2 +1,2 @@
1
- export{t as For,s as Show,o as bindProperty,n as bindText,p as bindVisible,l as cloneTemplate,g as createContext,j as createElement,k as createText,B as defineComponent,i as inject,v as insert,u as nodeToDOM,z as onError,x as onMount,y as onUnmount,h as provide,A as ref,q as renderConditional,r as renderList,m as setProperty}from'./chunk-TYDY46CL.js';export{a as batch,d as computed,e as effect,b as flushSync,c as signal,f as untrack}from'./chunk-JBHFILMZ.js';//# sourceMappingURL=core.js.map
1
+ export{t as For,s as Show,o as bindProperty,n as bindText,p as bindVisible,l as cloneTemplate,g as createContext,j as createElement,k as createText,B as defineComponent,i as inject,v as insert,u as nodeToDOM,z as onError,x as onMount,y as onUnmount,h as provide,A as ref,q as renderConditional,r as renderList,m as setProperty}from'./chunk-367DJVST.js';export{a as batch,m as computed,n as effect,b as flushSync,l as signal,o as untrack}from'./chunk-TWA4T6PX.js';//# sourceMappingURL=core.js.map
2
2
  //# sourceMappingURL=core.js.map