sinwan 1.1.0 → 1.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +34 -3
- package/dist/cjs/index.development.js +357 -221
- package/dist/cjs/index.development.js.map +12 -11
- package/dist/cjs/index.production.min.js +2 -2
- package/dist/cjs/index.production.min.js.map +12 -11
- package/dist/cjs/renderer/index.development.js +300 -116
- package/dist/cjs/renderer/index.development.js.map +11 -10
- package/dist/cjs/renderer/index.production.min.js +2 -2
- package/dist/cjs/renderer/index.production.min.js.map +11 -10
- package/dist/cjs/server/index.development.js +146 -68
- package/dist/cjs/server/index.development.js.map +8 -7
- package/dist/cjs/server/index.production.min.js +2 -2
- package/dist/cjs/server/index.production.min.js.map +8 -7
- package/dist/component/control-flow.d.ts +6 -1
- package/dist/component/control-flow.d.ts.map +1 -1
- package/dist/component/instance.d.ts.map +1 -1
- package/dist/esm/index.development.js +357 -221
- package/dist/esm/index.development.js.map +12 -11
- package/dist/esm/index.production.min.js +2 -2
- package/dist/esm/index.production.min.js.map +12 -11
- package/dist/esm/renderer/index.development.js +300 -116
- package/dist/esm/renderer/index.development.js.map +11 -10
- package/dist/esm/renderer/index.production.min.js +2 -2
- package/dist/esm/renderer/index.production.min.js.map +11 -10
- package/dist/esm/server/index.development.js +146 -68
- package/dist/esm/server/index.development.js.map +8 -7
- package/dist/esm/server/index.production.min.js +2 -2
- package/dist/esm/server/index.production.min.js.map +8 -7
- package/dist/reactivity/index.d.ts +2 -1
- package/dist/reactivity/index.d.ts.map +1 -1
- package/dist/reactivity/normalization.d.ts +19 -0
- package/dist/reactivity/normalization.d.ts.map +1 -0
- package/dist/renderer/attributes.d.ts.map +1 -1
- package/dist/renderer/events.d.ts.map +1 -1
- package/dist/renderer/render-children.d.ts.map +1 -1
- package/dist/renderer/render-control-flow.d.ts.map +1 -1
- package/dist/renderer/render-element.d.ts.map +1 -1
- package/dist/renderer/types.d.ts +2 -0
- package/dist/renderer/types.d.ts.map +1 -1
- package/dist/server/renderer.d.ts.map +1 -1
- package/dist/types.d.ts +2 -2
- package/dist/types.d.ts.map +1 -1
- package/package.json +6 -3
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["../../src/jsx/jsx-runtime.ts", "../../src/renderer/dom-ops.ts", "../../src/reactivity/scheduler.ts", "../../src/reactivity/effect.ts", "../../src/reactivity/signal.ts", "../../src/reactivity/computed.ts", "../../src/
|
|
3
|
+
"sources": ["../../src/jsx/jsx-runtime.ts", "../../src/renderer/dom-ops.ts", "../../src/reactivity/scheduler.ts", "../../src/reactivity/effect.ts", "../../src/reactivity/signal.ts", "../../src/reactivity/computed.ts", "../../src/reactivity/batch.ts", "../../src/reactivity/normalization.ts", "../../src/renderer/events.ts", "../../src/component/instance.ts", "../../src/renderer/attributes.ts", "../../src/component/control-flow.ts", "../../src/renderer/unmount.ts", "../../src/renderer/render-control-flow.ts", "../../src/renderer/render-element.ts", "../../src/renderer/render-children.ts", "../../src/renderer/mount.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
5
|
"/**\n * SinwanJS View Module — JSX Runtime\n *\n * JSX factory that returns SinwanElement structures for the view renderer.\n * Imported automatically when using JSX syntax.\n */\n\nimport type { SinwanElement, SinwanNode } from \"../types.ts\";\nimport type { SinwanIntrinsicElements } from \"./jsx-types\";\n\nexport const Fragment = Symbol(\"Fragment\");\n\n/**\n * A string that has been marked as safe HTML (already escaped).\n * Used for raw HTML injection with explicit trust marking.\n */\nexport class HtmlEscapedString extends String {\n constructor(public readonly value: string) {\n super(value);\n }\n override toString() {\n return this.value;\n }\n}\n\nexport const raw = (str: string) => new HtmlEscapedString(str);\n\n// Fast path for intrinsic elements\nconst VOID_ELEMENTS = new Set([\n \"area\",\n \"base\",\n \"br\",\n \"col\",\n \"embed\",\n \"hr\",\n \"img\",\n \"input\",\n \"link\",\n \"meta\",\n \"param\",\n \"source\",\n \"track\",\n \"wbr\",\n]);\n\n/**\n * Normalize children into an array of SinwanNode.\n */\nfunction normalizeChildren(children: any): SinwanNode[] {\n if (children == null || typeof children === \"boolean\") return [];\n if (Array.isArray(children)) return children.flat(Infinity);\n return [children];\n}\n\n/**\n * Build an SinwanElement from a component/tag invocation.\n * Shared logic for jsx, jsxs, and jsxDEV.\n */\nfunction buildElement(\n type: any,\n props: any,\n children: SinwanNode[],\n): SinwanElement {\n // Handle Fragment\n if (type === Fragment) {\n return { tag: \"\", props: {}, children };\n }\n\n // Functional components and intrinsic HTML elements both pass the type\n // through as `tag`. The renderer (client / server / hydration) is the\n // single owner of component-instance creation and lifecycle dispatch.\n // Calling the function eagerly here would bypass instance management\n // and break `onMounted`, `provide`/`inject`, and the parent/child tree.\n if (typeof type === \"function\" || typeof type === \"string\") {\n const finalProps = props ?? {};\n // Mirror children into props.children so component setup can read it.\n if (children.length > 0 && finalProps.children === undefined) {\n finalProps.children = children.length === 1 ? children[0] : children;\n }\n return { tag: type, props: finalProps, children };\n }\n\n // Fallback\n return { tag: \"\", props: {}, children };\n}\n\n/**\n * JSX factory — called for elements with 0 or 1 child.\n * TypeScript auto-imports this in production mode (`react-jsx`).\n */\nexport function jsx(type: any, props: any, key?: any): SinwanElement {\n return buildElement(type, props, normalizeChildren(props?.children));\n}\n\n/**\n * JSX static factory — called for elements with 2+ children.\n * `props.children` is **already an array**, so we skip normalizeChildren.\n */\nexport function jsxs(type: any, props: any, key?: any): SinwanElement {\n const children = props?.children;\n // Children is guaranteed to be an array by the compiler\n return buildElement(\n type,\n props,\n Array.isArray(children)\n ? children.flat(Infinity)\n : normalizeChildren(children),\n );\n}\n\n/**\n * Source location metadata attached by the compiler in dev mode.\n */\nexport interface JSXSource {\n fileName: string;\n lineNumber: number;\n columnNumber: number;\n}\n\n/**\n * JSX dev factory — called in dev mode (`react-jsxdev`).\n * Receives extra source/debug info for better error messages.\n */\nexport function jsxDEV(\n type: any,\n props: any,\n key: any,\n isStaticChildren: boolean,\n source?: JSXSource,\n self?: unknown,\n): SinwanElement {\n const children = isStaticChildren\n ? Array.isArray(props?.children)\n ? props.children.flat(Infinity)\n : normalizeChildren(props?.children)\n : normalizeChildren(props?.children);\n\n const element = buildElement(type, props, children);\n\n // Attach debug metadata (useful for dev-tools / error traces)\n if (source) {\n (element as any).__source = source;\n }\n\n return element;\n}\n\nexport namespace JSX {\n export type Element = SinwanElement | Promise<SinwanElement>;\n export interface IntrinsicAttributes {\n key?: string | number;\n }\n export interface ElementChildrenAttribute {\n children: {};\n }\n export interface IntrinsicElements extends SinwanIntrinsicElements {}\n}\n\ndeclare global {\n namespace JSX {\n type Element = SinwanElement | Promise<SinwanElement>;\n interface IntrinsicAttributes {\n key?: string | number;\n }\n interface ElementChildrenAttribute {\n children: {};\n }\n interface IntrinsicElements extends SinwanIntrinsicElements {}\n }\n}\n",
|
|
6
6
|
"/// <reference lib=\"dom\" />\n\n/**\n * SinwanJS Client Renderer — DOM Operations\n *\n * Thin abstraction over native DOM APIs for testability\n * and potential future server-side DOM (e.g., happy-dom, linkedom).\n */\n\nexport interface DOMOps {\n createElement(tag: string): Element;\n createElementNS(namespace: string, tag: string): Element;\n createTextNode(text: string): Text;\n createComment(text: string): Comment;\n setAttribute(el: Element, key: string, value: string): void;\n removeAttribute(el: Element, key: string): void;\n setProperty(el: Element, key: string, value: unknown): void;\n insertBefore(parent: Node, child: Node, anchor: Node | null): void;\n appendChild(parent: Node, child: Node): void;\n remove(node: Node): void;\n setTextContent(node: Text, text: string): void;\n addEventListener(el: Element, event: string, handler: EventListener): void;\n removeEventListener(el: Element, event: string, handler: EventListener): void;\n parentNode(node: Node): Node | null;\n nextSibling(node: Node): Node | null;\n}\n\nfunction createDefaultDOMOps(): DOMOps {\n return {\n createElement(tag: string): Element {\n return document.createElement(tag);\n },\n\n createElementNS(namespace: string, tag: string): Element {\n return document.createElementNS(namespace, tag);\n },\n\n createTextNode(text: string): Text {\n return document.createTextNode(text);\n },\n\n createComment(text: string): Comment {\n return document.createComment(text);\n },\n\n setAttribute(el: Element, key: string, value: string): void {\n el.setAttribute(key, value);\n },\n\n removeAttribute(el: Element, key: string): void {\n el.removeAttribute(key);\n },\n\n setProperty(el: Element, key: string, value: unknown): void {\n (el as any)[key] = value;\n },\n\n insertBefore(parent: Node, child: Node, anchor: Node | null): void {\n parent.insertBefore(child, anchor);\n },\n\n appendChild(parent: Node, child: Node): void {\n parent.appendChild(child);\n },\n\n remove(node: Node): void {\n node.parentNode?.removeChild(node);\n },\n\n setTextContent(node: Text, text: string): void {\n node.data = text;\n },\n\n addEventListener(el: Element, event: string, handler: EventListener): void {\n el.addEventListener(event, handler);\n },\n\n removeEventListener(el: Element, event: string, handler: EventListener): void {\n el.removeEventListener(event, handler);\n },\n\n parentNode(node: Node): Node | null {\n return node.parentNode;\n },\n\n nextSibling(node: Node): Node | null {\n return node.nextSibling;\n },\n };\n}\n\nconst defaultDOMOps = createDefaultDOMOps();\n\n/**\n * Live DOM operations object used by the renderer.\n */\nexport const domOps: DOMOps = { ...defaultDOMOps };\n\nexport function setDOMOps(overrides: Partial<DOMOps>): void {\n Object.assign(domOps, overrides);\n}\n\nexport function resetDOMOps(): void {\n for (const key of Object.keys(domOps) as (keyof DOMOps)[]) {\n delete (domOps as any)[key];\n }\n Object.assign(domOps, defaultDOMOps);\n}\n",
|
|
@@ -8,18 +8,19 @@
|
|
|
8
8
|
"/**\n * SinwanJS Reactivity — Effect\n *\n * Fine-grained effect system with automatic dependency tracking.\n * When an effect runs, any signal reads are tracked as dependencies.\n * When those signals change, the effect is re-scheduled.\n */\n\nimport { type EffectNode, scheduleEffect, unscheduleEffect } from \"./scheduler.ts\";\n\n// ─── Global tracking state ─────────────────────────────────\n\nlet activeEffect: ReactiveEffect | null = null;\nconst effectStack: ReactiveEffect[] = [];\nlet effectIdCounter = 0;\n\n// ─── Subscription interface ────────────────────────────────\n\n/**\n * A Dep is any object that can track subscribers.\n * Signals and computeds implement this internally.\n */\nexport interface Dep {\n subscribers: Set<ReactiveEffect>;\n}\n\n// ─── ReactiveEffect ────────────────────────────────────────\n\nexport type CleanupFn = () => void;\nexport type EffectFn = () => CleanupFn | void;\n\nexport class ReactiveEffect implements EffectNode {\n id: number;\n active = true;\n\n /** The user-supplied function */\n private fn: EffectFn;\n\n /** Cleanup returned from the last run */\n private cleanup: CleanupFn | void = undefined;\n\n /** All deps this effect is subscribed to (for bidirectional cleanup) */\n deps: Set<Dep> = new Set();\n\n constructor(fn: EffectFn) {\n this.id = effectIdCounter++;\n this.fn = fn;\n }\n\n /**\n * Execute the effect function while tracking dependencies.\n */\n run(): void {\n if (!this.active) return;\n\n // Prevent infinite re-entry\n if (effectStack.includes(this)) return;\n\n // Clean up previous dependencies\n this.cleanupDeps();\n\n // Run user cleanup from previous execution\n if (this.cleanup) {\n this.cleanup();\n this.cleanup = undefined;\n }\n\n // Push onto the tracking stack\n effectStack.push(this);\n const prevEffect = activeEffect;\n activeEffect = this;\n\n try {\n const result = this.fn();\n if (typeof result === \"function\") {\n this.cleanup = result;\n }\n } finally {\n activeEffect = prevEffect;\n effectStack.pop();\n }\n }\n\n /**\n * Unsubscribe from all current deps so stale deps don't trigger this effect.\n */\n private cleanupDeps(): void {\n for (const dep of this.deps) {\n dep.subscribers.delete(this);\n }\n this.deps.clear();\n }\n\n /**\n * Notify the scheduler that this effect should re-run.\n */\n notify(): void {\n scheduleEffect(this);\n }\n\n /**\n * Permanently dispose this effect — stop tracking & unsubscribe.\n */\n dispose(): void {\n if (!this.active) return;\n this.active = false;\n\n // Run user cleanup\n if (this.cleanup) {\n this.cleanup();\n this.cleanup = undefined;\n }\n\n this.cleanupDeps();\n unscheduleEffect(this);\n }\n}\n\n// ─── Public API ────────────────────────────────────────────\n\n/**\n * Create a reactive effect.\n *\n * The effect function runs immediately to establish initial dependencies.\n * It re-runs whenever any tracked signal changes.\n * Returns a dispose function to stop the effect.\n *\n * @example\n * const count = signal(0);\n * const dispose = effect(() => {\n * console.log(\"count is\", count.value);\n * });\n * // logs \"count is 0\" immediately\n *\n * count.value = 1;\n * // logs \"count is 1\" on next microtask\n *\n * dispose(); // stops tracking\n */\nexport function effect(fn: EffectFn): CleanupFn {\n const e = new ReactiveEffect(fn);\n // Run immediately (synchronous first run for initial tracking)\n e.run();\n return () => e.dispose();\n}\n\n// ─── Tracking helpers (used by signals/computed) ───────────\n\n/**\n * Track a dependency from the currently active effect.\n * Called by signal.value getters.\n */\nexport function track(dep: Dep): void {\n if (activeEffect) {\n dep.subscribers.add(activeEffect);\n activeEffect.deps.add(dep);\n }\n}\n\n/**\n * Trigger all subscribers of a dependency.\n * Called by signal.value setters.\n */\nexport function trigger(dep: Dep): void {\n // Copy to avoid modification during iteration\n const effects = [...dep.subscribers];\n for (const effect of effects) {\n effect.notify();\n }\n}\n\n/**\n * Returns the currently active effect (for advanced usage).\n */\nexport function getActiveEffect(): ReactiveEffect | null {\n return activeEffect;\n}\n",
|
|
9
9
|
"/**\n * SinwanJS Reactivity — Signal\n *\n * A signal is a reactive container for a single value.\n * Reading `.value` tracks the current effect as a subscriber.\n * Writing `.value` notifies all subscribers.\n *\n * Inspired by Vue 3 ref(), Solid signals, Preact signals.\n */\n\nimport { type Dep, track, trigger } from \"./effect.ts\";\n\n// ─── Signal interface ──────────────────────────────────────\n\nexport interface Signal<T> {\n /** Get or set the reactive value. Reading tracks; writing notifies. */\n value: T;\n\n /** Read the value without tracking dependencies. */\n peek(): T;\n\n /** Manually subscribe to changes. Returns an unsubscribe function. */\n subscribe(fn: (value: T) => void): () => void;\n}\n\n// Brand for type-checking\nconst SIGNAL_BRAND = Symbol(\"Sinwan:signal\");\n\n// ─── Implementation ────────────────────────────────────────\n\nclass SignalImpl<T> implements Signal<T>, Dep {\n [SIGNAL_BRAND] = true;\n\n subscribers = new Set<import(\"./effect.ts\").ReactiveEffect>();\n private _value: T;\n private _manualSubs = new Set<(value: T) => void>();\n\n constructor(initial: T) {\n this._value = initial;\n }\n\n get value(): T {\n track(this);\n return this._value;\n }\n\n set value(newValue: T) {\n if (Object.is(this._value, newValue)) return;\n this._value = newValue;\n trigger(this);\n\n // Notify manual subscribers\n for (const fn of this._manualSubs) {\n fn(newValue);\n }\n }\n\n peek(): T {\n return this._value;\n }\n\n subscribe(fn: (value: T) => void): () => void {\n this._manualSubs.add(fn);\n return () => {\n this._manualSubs.delete(fn);\n };\n }\n\n /**\n * toString() for interpolation in templates.\n */\n toString(): string {\n return String(this.value);\n }\n\n /**\n * valueOf() for numeric operations.\n */\n valueOf(): T {\n return this.value;\n }\n}\n\n// ─── Public API ────────────────────────────────────────────\n\n/**\n * Create a reactive signal.\n *\n * @example\n * const count = signal(0);\n * console.log(count.value); // 0\n *\n * effect(() => {\n * console.log(count.value); // re-runs when count changes\n * });\n *\n * count.value = 5; // triggers the effect\n */\nexport function signal<T>(initial: T): Signal<T> {\n return new SignalImpl(initial);\n}\n\n/**\n * Type guard: check if a value is a Signal.\n */\nexport function isSignal(value: unknown): value is Signal<unknown> {\n return (\n value != null && typeof value === \"object\" && SIGNAL_BRAND in (value as any)\n );\n}\n",
|
|
10
10
|
"/**\n * SinwanJS Reactivity — Computed\n *\n * A computed is a derived reactive value that lazily re-evaluates\n * when its dependencies change. It caches the result and only\n * recomputes when actually read after a dependency has changed.\n *\n * Design: The computed does NOT use the scheduler for its own\n * re-evaluation. When a dependency changes, it marks itself dirty\n * and triggers downstream subscribers (which ARE scheduled).\n * The actual re-evaluation happens lazily on `.value` access.\n *\n * Inspired by Vue 3 computed(), Solid createMemo().\n */\n\nimport { type Dep, track, trigger, ReactiveEffect } from \"./effect.ts\";\n\n// ─── Computed interface ────────────────────────────────────\n\nexport interface Computed<T> {\n /** Read the computed value (lazy evaluation, cached). */\n readonly value: T;\n\n /** Read without tracking. */\n peek(): T;\n}\n\n// Brand for type-checking\nconst COMPUTED_BRAND = Symbol(\"Sinwan:computed\");\n\n// ─── Implementation ────────────────────────────────────────\n\nclass ComputedImpl<T> implements Computed<T>, Dep {\n [COMPUTED_BRAND] = true;\n\n subscribers = new Set<ReactiveEffect>();\n\n _value!: T;\n _dirty = true;\n _effect: ReactiveEffect;\n\n constructor(getter: () => T) {\n const self = this;\n\n // Internal effect solely for dependency tracking.\n // The fn wraps the getter — it writes to self._value as a side effect.\n this._effect = new ReactiveEffect(() => {\n self._value = getter();\n });\n\n // Override notify: don't schedule this effect via the scheduler.\n // Instead mark dirty and propagate to our own subscribers.\n this._effect.notify = function () {\n if (!self._dirty) {\n self._dirty = true;\n trigger(self);\n }\n };\n\n // Run once synchronously to establish deps and cache initial value\n this._effect.run();\n this._dirty = false;\n }\n\n get value(): T {\n track(this);\n\n if (this._dirty) {\n this._effect.run();\n this._dirty = false;\n }\n\n return this._value;\n }\n\n peek(): T {\n if (this._dirty) {\n this._effect.run();\n this._dirty = false;\n }\n return this._value;\n }\n\n /**\n * toString() for template interpolation.\n */\n toString(): string {\n return String(this.value);\n }\n\n /**\n * valueOf() for numeric operations.\n */\n valueOf(): T {\n return this.value;\n }\n}\n\n// ─── Public API ────────────────────────────────────────────\n\n/**\n * Create a computed reactive value.\n *\n * The getter function is tracked — when any signal it reads changes,\n * the computed is marked dirty and will re-evaluate on next `.value` read.\n *\n * @example\n * const count = signal(2);\n * const doubled = computed(() => count.value * 2);\n *\n * console.log(doubled.value); // 4\n *\n * count.value = 5;\n * console.log(doubled.value); // 10\n */\nexport function computed<T>(getter: () => T): Computed<T> {\n return new ComputedImpl(getter);\n}\n\n/**\n * Type guard: check if a value is a Computed.\n */\nexport function isComputed(value: unknown): value is Computed<unknown> {\n return (\n value != null &&\n typeof value === \"object\" &&\n COMPUTED_BRAND in (value as any)\n );\n}\n",
|
|
11
|
-
"/// <reference lib=\"dom\" />\n\n/**\n * SinwanJS Client Renderer — Event Binding\n *\n * Direct event binding (not delegation). Each handler is attached\n * directly to its target element for simplicity and easy hydration.\n *\n * Design decision: direct binding like Solid.js, not delegation like React.\n */\n\nimport { domOps } from \"./dom-ops.ts\";\nimport type { CleanupFn } from \"../reactivity/index.ts\";\n\n/**\n * Check if a prop key is an event handler (starts with \"on\").\n */\nexport function isEventProp(key: string): boolean {\n return key.length > 2 && key[0] === \"o\" && key[1] === \"n\" && key[2]! >= \"A\" && key[2]! <= \"Z\";\n}\n\n/**\n * Extract the DOM event name from a prop key.\n * e.g., \"onClick\" → \"click\", \"onMouseEnter\" → \"mouseenter\"\n */\nexport function toEventName(key: string): string {\n return key.slice(2).toLowerCase();\n}\n\n/**\n * Bind an event handler to an element.\n * Returns a cleanup function to remove the listener.\n */\nexport function bindEvent(\n el: Element,\n eventName: string,\n handler: EventListener,\n): CleanupFn {\n domOps.addEventListener(el, eventName, handler);\n return () => {\n domOps.removeEventListener(el, eventName, handler);\n };\n}\n\n/**\n * Bind all event props from an element's props object.\n * Returns an array of cleanup functions.\n */\nexport function bindEvents(\n el: Element,\n props: Record<string, unknown>,\n): CleanupFn[] {\n const cleanups: CleanupFn[] = [];\n\n for (const key of Object.keys(props)) {\n if (isEventProp(key)) {\n const handler = props[key];\n if (typeof handler === \"function\") {\n const eventName = toEventName(key);\n cleanups.push(bindEvent(el, eventName, handler as EventListener));\n }\n }\n }\n\n return cleanups;\n}\n",
|
|
12
|
-
"/**\n * SinwanJS Component Runtime — Instance Management\n *\n * Each component rendered on the client gets a ComponentInstance\n * that tracks its lifecycle hooks, effects, parent/child tree,\n * and provide/inject context.\n *\n * A global `currentInstance` stack lets lifecycle hooks (onMounted, etc.)\n * register themselves during setup or synchronous lifecycle callbacks —\n * same pattern as Vue's getCurrentInstance.\n */\n\nimport type { SinwanComponent } from \"../types.ts\";\nimport type { MountedNode } from \"../renderer/types.ts\";\nimport type { CleanupFn } from \"../reactivity/index.ts\";\nimport { nextTick } from \"../reactivity/scheduler.ts\";\n\n// ─── ComponentInstance ─────────────────────────────────────\n\nlet uidCounter = 0;\n\nexport interface ComponentInstance {\n /** Unique identifier for this instance. */\n uid: number;\n\n /** The component definition (setup function). */\n component: SinwanComponent<any>;\n\n /** Props passed to this component. */\n props: Record<string, any>;\n\n /** The rendered DOM subtree (set after render). */\n element: MountedNode | null;\n\n /** Parent instance in the component tree. */\n parent: ComponentInstance | null;\n\n /** Child component instances. */\n children: ComponentInstance[];\n\n /** All effect dispose functions owned by this component. */\n effects: CleanupFn[];\n\n // ─── Lifecycle hook queues ────────────────────────────\n\n /** Callbacks to fire after the component is mounted to DOM. */\n _mountedHooks: (() => void)[];\n\n /** Callbacks to fire when the component is unmounted. */\n _unmountedHooks: (() => void)[];\n\n /** Callbacks to fire after any reactive update in this component. */\n _updatedHooks: (() => void)[];\n\n /** Error handler callbacks. */\n _errorHooks: ((err: Error) => void)[];\n\n // ─── Provide/Inject context ───────────────────────────\n\n /** Values provided by this instance (for inject in children). */\n provides: Record<string | symbol, unknown>;\n\n // ─── State flags ──────────────────────────────────────\n\n isMounted: boolean;\n isUnmounted: boolean;\n}\n\n/**\n * Create a fresh ComponentInstance.\n */\nexport function createComponentInstance(\n component: SinwanComponent<any>,\n props: Record<string, any>,\n parent: ComponentInstance | null,\n): ComponentInstance {\n return {\n uid: uidCounter++,\n component,\n props,\n element: null,\n parent,\n children: [],\n effects: [],\n _mountedHooks: [],\n _unmountedHooks: [],\n _updatedHooks: [],\n _errorHooks: [],\n // Inherit parent's provides (prototype chain for lookup)\n provides: parent ? Object.create(parent.provides) : Object.create(null),\n isMounted: false,\n isUnmounted: false,\n };\n}\n\n// ─── Current instance stack ────────────────────────────────\n\nlet currentInstance: ComponentInstance | null = null;\n\n/**\n * Get the currently active component instance.\n * Used by lifecycle hooks to register themselves.\n */\nexport function getCurrentInstance(): ComponentInstance | null {\n return currentInstance;\n}\n\n/**\n * Set the current instance (called by renderer before setup).\n * Returns the previous instance for restoration.\n */\nexport function setCurrentInstance(\n instance: ComponentInstance | null,\n): ComponentInstance | null {\n const prev = currentInstance;\n currentInstance = instance;\n return prev;\n}\n\n/**\n * Run a function with `instance` as the current component instance.\n * Automatically restores the previous instance when done.\n */\nexport function withInstance<T>(instance: ComponentInstance, fn: () => T): T {\n const prev = setCurrentInstance(instance);\n try {\n return fn();\n } finally {\n setCurrentInstance(prev);\n }\n}\n\n// ─── Lifecycle execution ───────────────────────────────────\n\n/**\n * Fire all onMounted hooks for an instance and its children (depth-first).\n */\nexport function fireMountedHooks(instance: ComponentInstance): void {\n if (instance.isUnmounted) {\n return;\n }\n\n // Children first (bottom-up, like Vue)\n for (const child of instance.children) {\n fireMountedHooks(child);\n }\n\n if (!instance.isMounted) {\n instance.isMounted = true;\n for (const hook of instance._mountedHooks) {\n hook();\n }\n }\n}\n\n/**\n * Fire all onUnmounted hooks and dispose all effects for an instance\n * and its children (depth-first, children first).\n */\nexport function fireUnmountedHooks(instance: ComponentInstance): void {\n // Children first\n for (const child of instance.children) {\n fireUnmountedHooks(child);\n }\n\n if (instance.isMounted && !instance.isUnmounted) {\n instance.isUnmounted = true;\n instance.isMounted = false;\n\n // Fire unmounted hooks\n for (const hook of instance._unmountedHooks) {\n hook();\n }\n\n // Dispose all effects owned by this component\n for (const dispose of instance.effects) {\n dispose();\n }\n instance.effects.length = 0;\n }\n}\n\n/**\n * Fire onUpdated hooks for the current instance.\n */\nexport function fireUpdatedHooks(instance: ComponentInstance): void {\n for (const hook of instance._updatedHooks) {\n hook();\n }\n}\n\nconst queuedUpdatedHooks = new Set<ComponentInstance>();\n\n/**\n * Queue onUpdated hooks to run after the current reactive flush.\n * Multiple DOM effects in the same flush produce one updated callback.\n */\nexport function queueUpdatedHooks(instance: ComponentInstance | null): void {\n if (\n !instance ||\n !instance.isMounted ||\n instance.isUnmounted ||\n instance._updatedHooks.length === 0 ||\n queuedUpdatedHooks.has(instance)\n ) {\n return;\n }\n\n queuedUpdatedHooks.add(instance);\n nextTick(() => {\n queuedUpdatedHooks.delete(instance);\n if (instance.isMounted && !instance.isUnmounted) {\n fireUpdatedHooks(instance);\n }\n });\n}\n\n/**\n * Handle an error in the component tree — walks up to find an error handler.\n */\nexport function handleComponentError(\n instance: ComponentInstance,\n err: Error,\n): void {\n let current: ComponentInstance | null = instance;\n while (current) {\n if (current._errorHooks.length > 0) {\n for (const hook of current._errorHooks) {\n hook(err);\n }\n return;\n }\n current = current.parent;\n }\n // No handler found — re-throw\n console.error(\"[Sinwan] Unhandled component error:\", err);\n}\n",
|
|
13
|
-
"/// <reference lib=\"dom\" />\n\n/**\n * SinwanJS Client Renderer — Attribute Handling\n *\n * Maps JSX props to DOM attributes and properties.\n * Handles special cases: className→class, htmlFor→for,\n * style objects, boolean attributes, and reactive attributes.\n */\n\nimport { domOps } from \"./dom-ops.ts\";\nimport { isEventProp } from \"./events.ts\";\nimport { isSignal } from \"../reactivity/signal.ts\";\nimport { isComputed } from \"../reactivity/computed.ts\";\nimport { effect } from \"../reactivity/effect.ts\";\nimport type { CleanupFn } from \"../reactivity/index.ts\";\nimport {\n getCurrentInstance,\n queueUpdatedHooks,\n} from \"../component/instance.ts\";\n\n// Props that should be skipped during attribute rendering\nconst SKIP_PROPS = new Set([\"children\", \"key\", \"ref\", \"dangerouslySetInnerHTML\"]);\n\n// Props that map to DOM properties rather than attributes\nexport const DOM_PROPERTIES = new Set([\"value\", \"checked\", \"selected\", \"disabled\", \"readOnly\", \"multiple\", \"indeterminate\"]);\n\n// Prop name aliases\nexport const PROP_ALIASES: Record<string, string> = {\n className: \"class\",\n htmlFor: \"for\",\n tabIndex: \"tabindex\",\n crossOrigin: \"crossorigin\",\n};\n\ninterface AttributeBindingState {\n previousStyleProps: Set<string>;\n}\n\n/**\n * Apply all non-event props to a DOM element.\n * Handles static values, reactive signals, and special cases.\n * Returns an array of disposers for reactive attributes.\n */\nexport function applyAttributes(\n el: Element,\n props: Record<string, unknown>,\n): CleanupFn[] {\n const disposers: CleanupFn[] = [];\n const owner = getCurrentInstance();\n\n for (const [key, value] of Object.entries(props)) {\n if (SKIP_PROPS.has(key) || isEventProp(key)) continue;\n\n if (isSignal(value) || isComputed(value)) {\n // Reactive attribute — wrap in an effect\n const state: AttributeBindingState = { previousStyleProps: new Set() };\n let initialized = false;\n const dispose = effect(() => {\n setSingleAttribute(el, key, (value as any).value, state);\n if (initialized) {\n queueUpdatedHooks(owner);\n }\n initialized = true;\n });\n disposers.push(dispose);\n } else {\n setSingleAttribute(el, key, value);\n }\n }\n\n return disposers;\n}\n\n/**\n * Set a single attribute/property on a DOM element.\n */\nexport function setSingleAttribute(\n el: Element,\n key: string,\n value: unknown,\n state?: AttributeBindingState,\n): void {\n // Resolve alias\n const attrName = resolveAttributeName(key);\n\n // Handle style objects\n if (attrName === \"style\" && typeof value === \"object\" && value !== null) {\n applyStyle(\n el as HTMLElement,\n value as Record<string, string | number | null | undefined>,\n state,\n );\n return;\n }\n\n // Handle class arrays/objects\n if (attrName === \"class\" && typeof value === \"object\" && value !== null) {\n applyClass(el, value);\n return;\n }\n\n // Handle null/undefined/false — remove attribute\n if (value == null || value === false) {\n domOps.removeAttribute(el, attrName);\n if (attrName === \"style\" && state) {\n state.previousStyleProps.clear();\n }\n // Also clear the property if it's a DOM property\n if (DOM_PROPERTIES.has(attrName)) {\n domOps.setProperty(el, attrName, attrName === \"value\" ? \"\" : false);\n }\n return;\n }\n\n // Handle boolean true — set as attribute name only\n if (value === true) {\n domOps.setAttribute(el, attrName, \"\");\n if (attrName === \"style\" && state) {\n state.previousStyleProps.clear();\n }\n if (DOM_PROPERTIES.has(attrName)) {\n domOps.setProperty(el, attrName, true);\n }\n return;\n }\n\n // DOM properties — set directly on the element\n if (DOM_PROPERTIES.has(attrName)) {\n if (attrName === \"style\" && state) {\n state.previousStyleProps.clear();\n }\n domOps.setProperty(el, attrName, value);\n return;\n }\n\n // Default — set as string attribute\n if (attrName === \"style\" && state) {\n state.previousStyleProps.clear();\n }\n domOps.setAttribute(el, attrName, String(value));\n}\n\nexport function resolveAttributeName(key: string): string {\n return PROP_ALIASES[key] ?? key;\n}\n\n/**\n * Apply a style object to an element.\n */\nfunction applyStyle(\n el: HTMLElement,\n styles: Record<string, string | number | null | undefined>,\n state?: AttributeBindingState,\n): void {\n const nextProps = new Set<string>();\n\n for (const [prop, val] of Object.entries(styles)) {\n nextProps.add(prop);\n\n if (val == null) {\n removeStyleProperty(el, prop);\n continue;\n }\n\n // Convert camelCase to kebab-case for style.setProperty\n if (prop.includes(\"-\")) {\n el.style.setProperty(prop, String(val));\n } else {\n (el.style as any)[prop] = val;\n }\n }\n\n if (!state) {\n return;\n }\n\n for (const previousProp of state.previousStyleProps) {\n if (!nextProps.has(previousProp)) {\n removeStyleProperty(el, previousProp);\n }\n }\n\n state.previousStyleProps = nextProps;\n}\n\nfunction removeStyleProperty(el: HTMLElement, prop: string): void {\n if (prop.includes(\"-\")) {\n el.style.removeProperty(prop);\n } else {\n (el.style as any)[prop] = \"\";\n }\n}\n\n/**\n * Apply class value — supports string, array, or object notation.\n */\nfunction applyClass(el: Element, value: unknown): void {\n let classStr: string;\n\n if (Array.isArray(value)) {\n // [\"foo\", \"bar\", false && \"baz\"] → \"foo bar\"\n classStr = value.filter(Boolean).join(\" \");\n } else if (typeof value === \"object\" && value !== null) {\n // { foo: true, bar: false } → \"foo\"\n classStr = Object.entries(value)\n .filter(([, v]) => Boolean(v))\n .map(([k]) => k)\n .join(\" \");\n } else {\n classStr = String(value);\n }\n\n domOps.setAttribute(el, \"class\", classStr);\n}\n",
|
|
14
11
|
"/**\n * SinwanJS Reactivity — Batch\n *\n * Batch multiple signal updates into a single synchronous flush.\n * Without batch(), each signal write schedules a microtask flush.\n * With batch(), all writes are collected and effects run once at the end.\n */\n\nimport { flushSync } from \"./scheduler.ts\";\n\nlet batchDepth = 0;\nlet batchScheduled = false;\n\n/**\n * Batch multiple signal writes so effects run only once.\n *\n * @example\n * const a = signal(1);\n * const b = signal(2);\n *\n * // Without batch — effect runs twice (once per signal change)\n * // With batch — effect runs once after both changes\n * batch(() => {\n * a.value = 10;\n * b.value = 20;\n * });\n */\nexport function batch(fn: () => void): void {\n batchDepth++;\n try {\n fn();\n } finally {\n batchDepth--;\n if (batchDepth === 0) {\n // Flush all pending effects synchronously\n flushSync();\n }\n }\n}\n\n/**\n * Returns true if currently inside a batch() call.\n */\nexport function isBatching(): boolean {\n return batchDepth > 0;\n}\n",
|
|
15
|
-
"
|
|
12
|
+
"/**\n * SinwanJS Reactivity — Normalization\n *\n * Provides a unified way to handle different types of reactive inputs:\n * Signals, Computed values, and Function getters.\n */\n\nimport { isSignal, type Signal } from \"./signal.ts\";\nimport { isComputed, type Computed } from \"./computed.ts\";\n\n/**\n * Checks if a value is reactive (Signal, Computed, or Function getter).\n */\nexport function isReactive(value: unknown): value is Signal<any> | Computed<any> | Function {\n return (\n isSignal(value) ||\n isComputed(value) ||\n typeof value === \"function\"\n );\n}\n\n/**\n * Resolves the current value of a potentially reactive input.\n * If the input is a signal, computed, or function, it returns its current value.\n * Otherwise, it returns the input as-is.\n */\nexport function resolve<T>(value: T | Signal<T> | Computed<T> | (() => T)): T {\n if (isSignal(value) || isComputed(value)) {\n return (value as any).value;\n }\n if (typeof value === \"function\") {\n return (value as any)();\n }\n return value as T;\n}\n",
|
|
13
|
+
"/// <reference lib=\"dom\" />\n\n/**\n * SinwanJS Client Renderer — Event Binding\n *\n * Direct event binding (not delegation). Each handler is attached\n * directly to its target element for simplicity and easy hydration.\n *\n * Design decision: direct binding like Solid.js, not delegation like React.\n */\n\nimport { domOps } from \"./dom-ops.ts\";\nimport type { CleanupFn } from \"../reactivity/index.ts\";\n\n/**\n * Check if a prop key is an event handler (starts with \"on\").\n */\nexport function isEventProp(key: string): boolean {\n // Matches onClick, onclick, onMouseMove, onmousemove, etc.\n return key.length > 2 && key.startsWith(\"on\");\n}\n\n/**\n * Extract the DOM event name from a prop key.\n * e.g., \"onClick\" → \"click\", \"onMouseEnter\" → \"mouseenter\"\n */\nexport function toEventName(key: string): string {\n return key.slice(2).toLowerCase();\n}\n\n/**\n * Bind an event handler to an element.\n * Returns a cleanup function to remove the listener.\n */\nexport function bindEvent(\n el: Element,\n eventName: string,\n handler: EventListener,\n): CleanupFn {\n domOps.addEventListener(el, eventName, handler);\n return () => {\n domOps.removeEventListener(el, eventName, handler);\n };\n}\n\n/**\n * Bind all event props from an element's props object.\n * Returns an array of cleanup functions.\n */\nexport function bindEvents(\n el: Element,\n props: Record<string, unknown>,\n): CleanupFn[] {\n const cleanups: CleanupFn[] = [];\n\n for (const key of Object.keys(props)) {\n if (isEventProp(key)) {\n const handler = props[key];\n if (typeof handler === \"function\") {\n const eventName = toEventName(key);\n cleanups.push(bindEvent(el, eventName, handler as EventListener));\n }\n }\n }\n\n return cleanups;\n}\n",
|
|
14
|
+
"/**\n * SinwanJS Component Runtime — Instance Management\n *\n * Each component rendered on the client gets a ComponentInstance\n * that tracks its lifecycle hooks, effects, parent/child tree,\n * and provide/inject context.\n *\n * A global `currentInstance` stack lets lifecycle hooks (onMounted, etc.)\n * register themselves during setup or synchronous lifecycle callbacks —\n * same pattern as Vue's getCurrentInstance.\n */\n\nimport type { SinwanComponent } from \"../types.ts\";\nimport type { MountedNode } from \"../renderer/types.ts\";\nimport type { CleanupFn } from \"../reactivity/index.ts\";\nimport { nextTick } from \"../reactivity/scheduler.ts\";\n\n// ─── ComponentInstance ─────────────────────────────────────\n\nlet uidCounter = 0;\n\nexport interface ComponentInstance {\n /** Unique identifier for this instance. */\n uid: number;\n\n /** The component definition (setup function). */\n component: SinwanComponent<any>;\n\n /** Props passed to this component. */\n props: Record<string, any>;\n\n /** The rendered DOM subtree (set after render). */\n element: MountedNode | null;\n\n /** Parent instance in the component tree. */\n parent: ComponentInstance | null;\n\n /** Child component instances. */\n children: ComponentInstance[];\n\n /** All effect dispose functions owned by this component. */\n effects: CleanupFn[];\n\n // ─── Lifecycle hook queues ────────────────────────────\n\n /** Callbacks to fire after the component is mounted to DOM. */\n _mountedHooks: (() => void)[];\n\n /** Callbacks to fire when the component is unmounted. */\n _unmountedHooks: (() => void)[];\n\n /** Callbacks to fire after any reactive update in this component. */\n _updatedHooks: (() => void)[];\n\n /** Error handler callbacks. */\n _errorHooks: ((err: Error) => void)[];\n\n // ─── Provide/Inject context ───────────────────────────\n\n /** Values provided by this instance (for inject in children). */\n provides: Record<string | symbol, unknown>;\n\n // ─── State flags ──────────────────────────────────────\n\n isMounted: boolean;\n isUnmounted: boolean;\n}\n\n/**\n * Create a fresh ComponentInstance.\n */\nexport function createComponentInstance(\n component: SinwanComponent<any>,\n props: Record<string, any>,\n parent: ComponentInstance | null,\n): ComponentInstance {\n return {\n uid: uidCounter++,\n component,\n props,\n element: null,\n parent,\n children: [],\n effects: [],\n _mountedHooks: [],\n _unmountedHooks: [],\n _updatedHooks: [],\n _errorHooks: [],\n // Inherit parent's provides (prototype chain for lookup)\n provides: parent ? Object.create(parent.provides) : Object.create(null),\n isMounted: false,\n isUnmounted: false,\n };\n}\n\n// ─── Current instance stack ────────────────────────────────\n\nlet currentInstance: ComponentInstance | null = null;\n\n/**\n * Get the currently active component instance.\n * Used by lifecycle hooks to register themselves.\n */\nexport function getCurrentInstance(): ComponentInstance | null {\n return currentInstance;\n}\n\n/**\n * Set the current instance (called by renderer before setup).\n * Returns the previous instance for restoration.\n */\nexport function setCurrentInstance(\n instance: ComponentInstance | null,\n): ComponentInstance | null {\n const prev = currentInstance;\n currentInstance = instance;\n return prev;\n}\n\n/**\n * Run a function with `instance` as the current component instance.\n * Automatically restores the previous instance when done.\n */\nexport function withInstance<T>(instance: ComponentInstance, fn: () => T): T {\n const prev = setCurrentInstance(instance);\n try {\n return fn();\n } finally {\n setCurrentInstance(prev);\n }\n}\n\n// ─── Lifecycle execution ───────────────────────────────────\n\n/**\n * Fire all onMounted hooks for an instance and its children (depth-first).\n */\nexport function fireMountedHooks(instance: ComponentInstance): void {\n if (instance.isUnmounted) {\n return;\n }\n\n // Children first\n for (const child of instance.children) {\n fireMountedHooks(child);\n }\n\n if (!instance.isMounted) {\n instance.isMounted = true;\n for (const hook of instance._mountedHooks) {\n hook();\n }\n }\n}\n\n/**\n * Fire all onUnmounted hooks and dispose all effects for an instance\n * and its children (depth-first, children first).\n */\nexport function fireUnmountedHooks(instance: ComponentInstance): void {\n // Children first\n const children = [...instance.children];\n for (const child of children) {\n fireUnmountedHooks(child);\n }\n\n if (!instance.isUnmounted) {\n instance.isUnmounted = true;\n \n // Only fire unmounted hooks if it was ever mounted\n if (instance.isMounted) {\n instance.isMounted = false;\n for (const hook of instance._unmountedHooks) {\n hook();\n }\n }\n\n // ALWAYS dispose effects owned by this component\n for (const dispose of instance.effects) {\n dispose();\n }\n instance.effects.length = 0;\n\n // Remove from parent to prevent memory leaks\n if (instance.parent) {\n const idx = instance.parent.children.indexOf(instance);\n if (idx !== -1) {\n instance.parent.children.splice(idx, 1);\n }\n }\n }\n}\n\n/**\n * Fire onUpdated hooks for the current instance.\n */\nexport function fireUpdatedHooks(instance: ComponentInstance): void {\n for (const hook of instance._updatedHooks) {\n hook();\n }\n}\n\nconst queuedUpdatedHooks = new Set<ComponentInstance>();\n\n/**\n * Queue onUpdated hooks to run after the current reactive flush.\n * Multiple DOM effects in the same flush produce one updated callback.\n */\nexport function queueUpdatedHooks(instance: ComponentInstance | null): void {\n if (\n !instance ||\n !instance.isMounted ||\n instance.isUnmounted ||\n instance._updatedHooks.length === 0 ||\n queuedUpdatedHooks.has(instance)\n ) {\n return;\n }\n\n queuedUpdatedHooks.add(instance);\n nextTick(() => {\n queuedUpdatedHooks.delete(instance);\n if (instance.isMounted && !instance.isUnmounted) {\n fireUpdatedHooks(instance);\n }\n });\n}\n\n/**\n * Handle an error in the component tree — walks up to find an error handler.\n */\nexport function handleComponentError(\n instance: ComponentInstance,\n err: Error,\n): void {\n let current: ComponentInstance | null = instance;\n while (current) {\n if (current._errorHooks.length > 0) {\n for (const hook of current._errorHooks) {\n hook(err);\n }\n return;\n }\n current = current.parent;\n }\n // No handler found — re-throw\n console.error(\"[Sinwan] Unhandled component error:\", err);\n}\n",
|
|
15
|
+
"/// <reference lib=\"dom\" />\n\n/**\n * SinwanJS Client Renderer — Attribute Handling\n *\n * Maps JSX props to DOM attributes and properties.\n * Handles special cases: className→class, htmlFor→for,\n * style objects, boolean attributes, and reactive attributes.\n */\n\nimport { domOps } from \"./dom-ops.ts\";\nimport { isEventProp } from \"./events.ts\";\nimport { effect, isReactive, resolve } from \"../reactivity/index.ts\";\nimport type { CleanupFn } from \"../reactivity/index.ts\";\nimport {\n getCurrentInstance,\n queueUpdatedHooks,\n} from \"../component/instance.ts\";\n\n// Props that should be skipped during attribute rendering\nconst SKIP_PROPS = new Set([\"children\", \"key\", \"ref\", \"dangerouslySetInnerHTML\"]);\n\n// Props that map to DOM properties rather than attributes\nexport const DOM_PROPERTIES = new Set([\"value\", \"checked\", \"selected\", \"disabled\", \"readOnly\", \"multiple\", \"indeterminate\"]);\n\n// Prop name aliases\nexport const PROP_ALIASES: Record<string, string> = {\n className: \"class\",\n htmlFor: \"for\",\n tabIndex: \"tabindex\",\n crossOrigin: \"crossorigin\",\n};\n\ninterface AttributeBindingState {\n previousStyleProps: Set<string>;\n}\n\n/**\n * Apply all non-event props to a DOM element.\n * Handles static values, reactive signals, and special cases.\n * Returns an array of disposers for reactive attributes.\n */\nexport function applyAttributes(\n el: Element,\n props: Record<string, unknown>,\n): CleanupFn[] {\n const disposers: CleanupFn[] = [];\n const owner = getCurrentInstance();\n\n for (const [key, value] of Object.entries(props)) {\n if (SKIP_PROPS.has(key) || isEventProp(key)) continue;\n\n const attrName = resolveAttributeName(key);\n const isComplex = attrName === \"class\" || attrName === \"style\";\n \n if (isReactive(value) || (isComplex && containsReactive(value))) {\n // Reactive attribute — wrap in an effect\n const state: AttributeBindingState = { previousStyleProps: new Set() };\n let initialized = false;\n const dispose = effect(() => {\n setSingleAttribute(el, key, resolve(value as any), state);\n if (initialized) {\n queueUpdatedHooks(owner);\n }\n initialized = true;\n });\n disposers.push(dispose);\n } else {\n setSingleAttribute(el, key, value);\n }\n }\n\n return disposers;\n}\n\n/**\n * Set a single attribute/property on a DOM element.\n */\nexport function setSingleAttribute(\n el: Element,\n key: string,\n value: unknown,\n state?: AttributeBindingState,\n): void {\n // Resolve alias\n const attrName = resolveAttributeName(key);\n\n // Handle style objects\n if (attrName === \"style\" && typeof value === \"object\" && value !== null) {\n applyStyle(\n el as HTMLElement,\n value as Record<string, string | number | null | undefined>,\n state,\n );\n return;\n }\n\n // Handle class arrays/objects\n if (attrName === \"class\" && typeof value === \"object\" && value !== null) {\n applyClass(el, value);\n return;\n }\n\n // Handle null/undefined/false — remove attribute\n if (value == null || value === false) {\n domOps.removeAttribute(el, attrName);\n if (attrName === \"style\" && state) {\n state.previousStyleProps.clear();\n }\n // Also clear the property if it's a DOM property\n if (DOM_PROPERTIES.has(attrName)) {\n domOps.setProperty(el, attrName, attrName === \"value\" ? \"\" : false);\n }\n return;\n }\n\n // Handle boolean true — set as attribute name only\n if (value === true) {\n domOps.setAttribute(el, attrName, \"\");\n if (attrName === \"style\" && state) {\n state.previousStyleProps.clear();\n }\n if (DOM_PROPERTIES.has(attrName)) {\n domOps.setProperty(el, attrName, true);\n }\n return;\n }\n\n // DOM properties — set directly on the element\n if (DOM_PROPERTIES.has(attrName)) {\n if (attrName === \"style\" && state) {\n state.previousStyleProps.clear();\n }\n domOps.setProperty(el, attrName, value);\n return;\n }\n\n // Default — set as string attribute\n if (attrName === \"style\" && state) {\n state.previousStyleProps.clear();\n }\n domOps.setAttribute(el, attrName, String(value));\n}\n\nexport function resolveAttributeName(key: string): string {\n return PROP_ALIASES[key] ?? key;\n}\n\n/**\n * Apply a style object to an element.\n */\n/**\n * Apply a style object to an element.\n */\nfunction applyStyle(\n el: HTMLElement,\n value: unknown,\n state?: AttributeBindingState,\n): void {\n const styleObj = normalizeStyle(value);\n const nextProps = new Set<string>();\n\n for (const [prop, val] of Object.entries(styleObj)) {\n nextProps.add(prop);\n\n if (val == null) {\n removeStyleProperty(el, prop);\n continue;\n }\n\n const kebabProp = prop.startsWith(\"--\") ? prop : camelToKebab(prop);\n el.style.setProperty(kebabProp, String(val));\n }\n\n if (!state) {\n return;\n }\n\n for (const previousProp of state.previousStyleProps) {\n if (!nextProps.has(previousProp)) {\n removeStyleProperty(el, previousProp);\n }\n }\n\n state.previousStyleProps = nextProps;\n}\n\nfunction normalizeStyle(\n value: unknown,\n): Record<string, string | number | null | undefined> {\n const resolved = resolve(value);\n if (!resolved) return {};\n\n if (typeof resolved === \"string\") {\n return parseStyleString(resolved);\n }\n\n if (Array.isArray(resolved)) {\n return resolved.reduce((acc, item) => {\n const normalized = normalizeStyle(item);\n return Object.assign(acc, normalized);\n }, {} as Record<string, any>);\n }\n\n if (typeof resolved === \"object\") {\n const result: Record<string, any> = {};\n for (const [k, v] of Object.entries(resolved)) {\n result[k] = resolve(v);\n }\n return result;\n }\n\n return {};\n}\n\nfunction parseStyleString(style: string): Record<string, string> {\n const result: Record<string, string> = {};\n style.split(\";\").forEach((rule) => {\n const i = rule.indexOf(\":\");\n if (i > 0) {\n const prop = rule.slice(0, i).trim();\n const val = rule.slice(i + 1).trim();\n if (prop && val) {\n result[prop] = val;\n }\n }\n });\n return result;\n}\n\nfunction removeStyleProperty(el: HTMLElement, prop: string): void {\n const kebabProp = prop.startsWith(\"--\") ? prop : camelToKebab(prop);\n el.style.removeProperty(kebabProp);\n}\n\n/**\n * Apply class value — supports string, array, or object notation.\n * Recursively resolves reactive values.\n */\nfunction applyClass(el: Element, value: unknown): void {\n domOps.setAttribute(el, \"class\", normalizeClass(value));\n}\n\nfunction normalizeClass(value: unknown): string {\n const resolved = resolve(value);\n if (!resolved) return \"\";\n if (typeof resolved === \"string\") return resolved;\n\n if (Array.isArray(resolved)) {\n // [\"foo\", \"bar\", false && \"baz\", signal] → \"foo bar val\"\n return resolved\n .map(normalizeClass)\n .filter(Boolean)\n .join(\" \");\n }\n\n if (typeof resolved === \"object\") {\n // { foo: true, bar: false, baz: signal } → \"foo baz\"\n return Object.entries(resolved)\n .filter(([, v]) => Boolean(resolve(v)))\n .map(([k]) => k)\n .join(\" \");\n }\n\n return String(resolved);\n}\n\n/**\n * Recursively check if a value contains any reactive element.\n */\nfunction containsReactive(value: unknown): boolean {\n if (isReactive(value)) return true;\n if (Array.isArray(value)) return value.some(containsReactive);\n if (typeof value === \"object\" && value !== null) {\n // For style objects/class objects, we only check one level deep for performance\n // but recursive is safer for nested class arrays.\n return Object.values(value).some(containsReactive);\n }\n return false;\n}\n\n/**\n * Convert camelCase to kebab-case.\n */\nfunction camelToKebab(str: string): string {\n return str.replace(/[A-Z]/g, (m) => `-${m.toLowerCase()}`);\n}\n",
|
|
16
|
+
"import type { Reactive, SinwanComponent, SinwanElement, SinwanNode } from \"../types.ts\";\nimport { computed } from \"../reactivity/computed.ts\";\nimport { resolve } from \"../reactivity/index.ts\";\n\nexport const SHOW_TYPE = Symbol.for(\"Sinwan.Show\");\nexport const FOR_TYPE = Symbol.for(\"Sinwan.For\");\nexport const SWITCH_TYPE = Symbol.for(\"Sinwan.Switch\");\nexport const MATCH_TYPE = Symbol.for(\"Sinwan.Match\");\nexport const INDEX_TYPE = Symbol.for(\"Sinwan.Index\");\nexport const KEY_TYPE = Symbol.for(\"Sinwan.Key\");\nexport const DYNAMIC_TYPE = Symbol.for(\"Sinwan.Dynamic\");\nexport const PORTAL_TYPE = Symbol.for(\"Sinwan.Portal\");\n\nexport interface ShowProps<T> {\n when: Reactive<T | false | null | undefined>;\n fallback?: SinwanNode;\n children?: SinwanNode | ((value: NonNullable<T>) => SinwanNode);\n}\n\nexport interface ForProps<T> {\n each: Reactive<readonly T[]>;\n key?: (item: T, index: number) => string | number | symbol;\n fallback?: SinwanNode;\n children?: (item: T, index: () => number) => SinwanNode;\n}\n\nexport interface SwitchProps {\n fallback?: SinwanNode;\n children?: SinwanNode | SinwanNode[];\n}\n\nexport interface MatchProps<T> {\n when: Reactive<T | false | null | undefined>;\n children?: SinwanNode | ((value: NonNullable<T>) => SinwanNode);\n}\n\nexport interface IndexProps<T> {\n each: Reactive<readonly T[]>;\n fallback?: SinwanNode;\n children?: (item: () => T, index: number) => SinwanNode;\n}\n\nexport interface KeyProps<T> {\n when: Reactive<T>;\n children?: SinwanNode | ((value: T) => SinwanNode);\n}\n\nexport type DynamicTag<P extends object = any> =\n | string\n | SinwanComponent<P>;\n\nexport type DynamicProps<P extends object = Record<string, unknown>> = P & {\n component: Reactive<DynamicTag<P> | null | undefined>;\n children?: SinwanNode;\n};\n\nexport interface VisibleProps {\n when: Reactive<unknown>;\n as?: string;\n style?: Reactive<\n Record<string, string | number | null | undefined> | string | null | undefined\n >;\n children?: SinwanNode;\n [key: string]: unknown;\n}\n\nexport interface PortalProps {\n mount?: Reactive<Node | string | (() => Node | null) | null | undefined>;\n children?: SinwanNode;\n}\n\nexport function Show<T>(props: ShowProps<T>): SinwanElement {\n return {\n tag: SHOW_TYPE,\n props: props as unknown as Record<string, unknown>,\n children: [],\n };\n}\n\nexport function For<T>(props: ForProps<T>): SinwanElement {\n return {\n tag: FOR_TYPE,\n props: props as unknown as Record<string, unknown>,\n children: [],\n };\n}\n\nexport function Switch(props: SwitchProps): SinwanElement {\n return {\n tag: SWITCH_TYPE,\n props: props as unknown as Record<string, unknown>,\n children: [],\n };\n}\n\nexport function Match<T>(props: MatchProps<T>): SinwanElement {\n return {\n tag: MATCH_TYPE,\n props: props as unknown as Record<string, unknown>,\n children: [],\n };\n}\n\nexport function Index<T>(props: IndexProps<T>): SinwanElement {\n return {\n tag: INDEX_TYPE,\n props: props as unknown as Record<string, unknown>,\n children: [],\n };\n}\n\nexport function Key<T>(props: KeyProps<T>): SinwanElement {\n return {\n tag: KEY_TYPE,\n props: props as unknown as Record<string, unknown>,\n children: [],\n };\n}\n\nexport function Dynamic<P extends object = Record<string, unknown>>(\n props: DynamicProps<P>,\n): SinwanElement {\n return {\n tag: DYNAMIC_TYPE,\n props: props as unknown as Record<string, unknown>,\n children: [],\n };\n}\n\nexport function Visible(props: VisibleProps): SinwanElement {\n const {\n when,\n as = \"span\",\n style,\n children,\n ...rest\n } = props;\n\n const visibleStyle = computed(() => {\n const base = readReactive(style);\n const visible = Boolean(readReactive(when));\n\n if (typeof base === \"string\") {\n return visible ? base : appendHiddenDisplay(base);\n }\n\n const styleObject =\n base && typeof base === \"object\"\n ? { ...(base as Record<string, string | number | null | undefined>) }\n : {};\n\n styleObject.display = visible ? styleObject.display : \"none\";\n return styleObject;\n });\n\n return {\n tag: as,\n props: {\n ...rest,\n style: visibleStyle,\n children,\n },\n children: normalizeChildren(children),\n };\n}\n\nexport function Portal(props: PortalProps): SinwanElement {\n return {\n tag: PORTAL_TYPE,\n props: props as unknown as Record<string, unknown>,\n children: [],\n };\n}\n\nexport function isElementLike(value: unknown): value is SinwanElement {\n return value != null && typeof value === \"object\" && \"tag\" in value;\n}\n\nexport function isShowElement(element: SinwanElement): boolean {\n return element.tag === SHOW_TYPE;\n}\n\nexport function isForElement(element: SinwanElement): boolean {\n return element.tag === FOR_TYPE;\n}\n\nexport function isSwitchElement(element: SinwanElement): boolean {\n return element.tag === SWITCH_TYPE;\n}\n\nexport function isMatchElement(element: SinwanElement): boolean {\n return element.tag === MATCH_TYPE;\n}\n\nexport function isIndexElement(element: SinwanElement): boolean {\n return element.tag === INDEX_TYPE;\n}\n\nexport function isKeyElement(element: SinwanElement): boolean {\n return element.tag === KEY_TYPE;\n}\n\nexport function isDynamicElement(element: SinwanElement): boolean {\n return element.tag === DYNAMIC_TYPE;\n}\n\nexport function isPortalElement(element: SinwanElement): boolean {\n return element.tag === PORTAL_TYPE;\n}\n\nexport function resolveSwitchContent(element: SinwanElement): SinwanNode {\n const props = element.props as { fallback?: SinwanNode; children?: SinwanNode };\n const children = normalizeContent(props.children ?? element.children);\n\n const match = findTruthyMatch(children);\n return match !== undefined ? match : props.fallback;\n}\n\nfunction findTruthyMatch(nodes: SinwanNode[]): SinwanNode | undefined {\n for (const node of nodes) {\n if (node == null || typeof node === \"boolean\") continue;\n\n if (Array.isArray(node)) {\n const match = findTruthyMatch(node);\n if (match !== undefined) return match;\n continue;\n }\n\n if (isElementLike(node)) {\n let element = node;\n\n // Expand functional control flow components if needed\n if (typeof element.tag === \"function\") {\n const tag = element.tag;\n if (\n tag === Match ||\n tag === Show ||\n tag === For ||\n tag === Index ||\n tag === Key ||\n tag === Switch\n ) {\n element = (tag as Function)(element.props);\n }\n }\n\n if (isMatchElement(element)) {\n const when = readReactive((element.props as any).when);\n if (when) {\n return resolveMatchChildren(element, when);\n }\n } else if (isShowElement(element)) {\n const when = readReactive((element.props as any).when);\n if (when) {\n const content = resolveShowChildren(element, when);\n const match = findTruthyMatch(normalizeContent(content));\n if (match !== undefined) return match;\n } else if ((element.props as any).fallback) {\n const match = findTruthyMatch(\n normalizeContent((element.props as any).fallback),\n );\n if (match !== undefined) return match;\n }\n } else if (isForElement(element)) {\n const props = element.props as any;\n const items = readReactive(props.each);\n if (Array.isArray(items)) {\n for (let i = 0; i < items.length; i++) {\n const child = props.children(items[i], () => i);\n const match = findTruthyMatch(normalizeContent(child));\n if (match !== undefined) return match;\n }\n }\n } else if (isIndexElement(element)) {\n const props = element.props as any;\n const items = readReactive(props.each);\n if (Array.isArray(items)) {\n for (let i = 0; i < items.length; i++) {\n const child = props.children(() => items[i], i);\n const match = findTruthyMatch(normalizeContent(child));\n if (match !== undefined) return match;\n }\n }\n } else if (isKeyElement(element)) {\n const key = readReactive((element.props as any).when);\n const child = resolveKeyChildren(element, key);\n const match = findTruthyMatch(normalizeContent(child));\n if (match !== undefined) return match;\n }\n }\n }\n return undefined;\n}\n\nexport function resolveMatchChildren(\n element: SinwanElement,\n value: unknown,\n): SinwanNode {\n const children = (element.props as any).children ?? element.children;\n if (typeof children === \"function\") {\n return children(value);\n }\n return children as SinwanNode;\n}\n\nexport function resolveShowChildren(\n element: SinwanElement,\n value: unknown,\n): SinwanNode {\n const children = (element.props as any).children ?? element.children;\n if (typeof children === \"function\") {\n return children(value);\n }\n return children as SinwanNode;\n}\n\nexport function resolveKeyChildren(\n element: SinwanElement,\n value: unknown,\n): SinwanNode {\n const children = (element.props as any).children ?? element.children;\n if (typeof children === \"function\") {\n return children(value);\n }\n return children as SinwanNode;\n}\n\nfunction normalizeContent(content: unknown): SinwanNode[] {\n if (content == null || typeof content === \"boolean\") {\n return [];\n }\n return Array.isArray(content) ? content : [content as SinwanNode];\n}\n\nfunction normalizeChildren(children: SinwanNode | undefined): SinwanNode[] {\n if (children == null || typeof children === \"boolean\") {\n return [];\n }\n return Array.isArray(children) ? children : [children];\n}\n\nfunction readReactive(value: unknown): unknown {\n return resolve(value as any);\n}\n\nfunction appendHiddenDisplay(style: string): string {\n const trimmed = style.trim();\n const separator = trimmed.length > 0 && !trimmed.endsWith(\";\") ? \";\" : \"\";\n return `${trimmed}${separator}display:none`;\n}\n",
|
|
16
17
|
"/// <reference lib=\"dom\" />\n\n/**\n * SinwanJS Client Renderer — Unmount helpers\n *\n * Shared cleanup and DOM removal utilities used by mount(), reactive blocks,\n * and future renderer entrypoints.\n */\n\nimport type { MountedNode } from \"./types.ts\";\nimport { domOps } from \"./dom-ops.ts\";\nimport { fireUnmountedHooks } from \"../component/instance.ts\";\n\n/**\n * Return the actual DOM nodes owned by a mounted tree, in document order.\n */\nexport function getMountedDomNodes(node: MountedNode): Node[] {\n switch (node.type) {\n case \"text\":\n case \"reactive-text\":\n return [node.node];\n\n case \"element\":\n return [node.node];\n\n case \"fragment\":\n return [\n node.anchor,\n ...node.children.flatMap((child) => getMountedDomNodes(child)),\n ];\n\n case \"reactive-block\":\n return [\n node.startAnchor,\n ...node.children.flatMap((child) => getMountedDomNodes(child)),\n node.endAnchor,\n ];\n\n case \"component\":\n return node.children.flatMap((child) => getMountedDomNodes(child));\n\n case \"portal\":\n return [node.anchor];\n }\n}\n\n/**\n * Recursively unmount a node tree — disposes effects, removes events and refs.\n */\nexport function unmountNode(node: MountedNode): void {\n switch (node.type) {\n case \"text\":\n break;\n\n case \"reactive-text\":\n node.dispose();\n break;\n\n case \"element\":\n for (const dispose of node.attrDisposers) {\n dispose();\n }\n for (const cleanup of node.eventCleanups) {\n cleanup();\n }\n node.refCleanup?.();\n for (const child of node.children) {\n unmountNode(child);\n }\n break;\n\n case \"fragment\":\n for (const child of node.children) {\n unmountNode(child);\n }\n break;\n\n case \"reactive-block\":\n node.dispose();\n for (const child of node.children) {\n unmountNode(child);\n }\n break;\n\n case \"component\":\n if (node.instance) {\n fireUnmountedHooks(node.instance);\n } else {\n for (const dispose of node.disposers) {\n dispose();\n }\n }\n for (const child of node.children) {\n unmountNode(child);\n }\n break;\n\n case \"portal\":\n node.dispose();\n for (const child of node.children) {\n removeMountedNode(child);\n }\n node.children = [];\n break;\n }\n}\n\n/**\n * Unmount a mounted tree and remove every DOM node it owns.\n */\nexport function removeMountedNode(node: MountedNode): void {\n const domNodes = getMountedDomNodes(node);\n unmountNode(node);\n for (const domNode of domNodes) {\n if (domNode.parentNode) {\n domOps.remove(domNode);\n }\n }\n}\n",
|
|
17
|
-
"/// <reference lib=\"dom\" />\n\n/**\n * SinwanJS Client Renderer — Reactive control-flow blocks\n *\n * `<Show>` and `<For>` render between stable comment anchors. Updates remove,\n * move, or insert only the block-owned DOM nodes.\n */\n\nimport type { SinwanElement, SinwanNode } from \"../types.ts\";\nimport type { MountedNode, MountedPortal, MountedReactiveBlock } from \"./types.ts\";\nimport { domOps } from \"./dom-ops.ts\";\nimport { isSignal } from \"../reactivity/signal.ts\";\nimport { isComputed } from \"../reactivity/computed.ts\";\nimport { signal, type Signal } from \"../reactivity/signal.ts\";\nimport { effect } from \"../reactivity/effect.ts\";\nimport {\n getCurrentInstance,\n fireMountedHooks,\n queueUpdatedHooks,\n withInstance,\n type ComponentInstance,\n} from \"../component/instance.ts\";\nimport {\n isDynamicElement,\n isForElement,\n isIndexElement,\n isKeyElement,\n isMatchElement,\n isPortalElement,\n isShowElement,\n isSwitchElement,\n Match,\n} from \"../component/control-flow.ts\";\nimport {\n getMountedDomNodes,\n removeMountedNode,\n} from \"./unmount.ts\";\nimport { renderNodeToDOM } from \"./render-children.ts\";\n\ninterface ForRecord<T> {\n key: unknown;\n item: T;\n index: number;\n mounted: MountedNode;\n}\n\ninterface IndexRecord<T> {\n item: Signal<T>;\n mounted: MountedNode;\n}\n\n/**\n * Render a built-in reactive helper element.\n */\nexport function renderControlFlowToDOM(\n element: SinwanElement,\n parent: Node,\n anchor: Node | null,\n namespace: string | null,\n): MountedNode {\n if (isPortalElement(element)) {\n return renderPortal(element, parent, anchor, namespace);\n }\n\n const startAnchor = domOps.createComment(\"Sinwan-b\");\n const endAnchor = domOps.createComment(\"/Sinwan-b\");\n insertNode(parent, startAnchor, anchor);\n insertNode(parent, endAnchor, anchor);\n\n const owner = getCurrentInstance();\n let disposeEffect = () => {};\n\n const block: MountedReactiveBlock = {\n type: \"reactive-block\",\n dispose: () => disposeEffect(),\n children: [],\n startAnchor,\n endAnchor,\n };\n\n if (isShowElement(element)) {\n disposeEffect = renderShowBlock(element, block, parent, namespace, owner);\n } else if (isForElement(element)) {\n disposeEffect = renderForBlock(element, block, parent, namespace, owner);\n } else if (isSwitchElement(element)) {\n disposeEffect = renderSwitchBlock(element, block, parent, namespace, owner);\n } else if (isIndexElement(element)) {\n disposeEffect = renderIndexBlock(element, block, parent, namespace, owner);\n } else if (isKeyElement(element)) {\n disposeEffect = renderKeyBlock(element, block, parent, namespace, owner);\n } else if (isDynamicElement(element)) {\n disposeEffect = renderDynamicBlock(element, block, parent, namespace, owner);\n }\n\n return block;\n}\n\nfunction renderShowBlock(\n element: SinwanElement,\n block: MountedReactiveBlock,\n parent: Node,\n namespace: string | null,\n owner: ComponentInstance | null,\n): () => void {\n let initialized = false;\n\n return effect(() => {\n clearChildren(block);\n\n const when = readReactive((element.props as any).when);\n const content = withOptionalInstance(owner, () =>\n when ? resolveShowChildren(element, when) : (element.props as any).fallback,\n );\n\n block.children = renderBlockContent(\n content,\n parent,\n block.endAnchor,\n namespace,\n owner,\n );\n\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n });\n}\n\nfunction renderForBlock<T>(\n element: SinwanElement,\n block: MountedReactiveBlock,\n parent: Node,\n namespace: string | null,\n owner: ComponentInstance | null,\n): () => void {\n let initialized = false;\n let records: ForRecord<T>[] = [];\n\n return effect(() => {\n const props = element.props as {\n each?: unknown;\n key?: (item: T, index: number) => string | number | symbol;\n fallback?: SinwanNode;\n children?: (item: T, index: () => number) => SinwanNode;\n };\n const items = readReactive(props.each) as readonly T[] | null | undefined;\n const list = Array.isArray(items) ? items : [];\n const renderChild = props.children;\n\n if (typeof renderChild !== \"function\") {\n clearChildren(block);\n records = [];\n if (initialized) {\n queueUpdatedHooks(owner);\n }\n initialized = true;\n return;\n }\n\n if (list.length === 0) {\n clearChildren(block);\n records = [];\n block.children = renderBlockContent(\n props.fallback,\n parent,\n block.endAnchor,\n namespace,\n owner,\n );\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n return;\n }\n\n if (records.length === 0 && block.children.length > 0) {\n clearChildren(block);\n }\n\n const oldByKey = new Map<unknown, ForRecord<T>>();\n for (const record of records) {\n oldByKey.set(record.key, record);\n }\n\n const nextRecords: ForRecord<T>[] = [];\n\n list.forEach((item, index) => {\n const key = props.key ? props.key(item, index) : item;\n const old = oldByKey.get(key);\n\n if (old && old.item === item) {\n old.index = index;\n moveBeforeEnd(parent, old.mounted, block.endAnchor);\n nextRecords.push(old);\n oldByKey.delete(key);\n return;\n }\n\n if (old) {\n removeMountedNode(old.mounted);\n oldByKey.delete(key);\n }\n\n const record: ForRecord<T> = {\n key,\n item,\n index,\n mounted: { type: \"text\", node: domOps.createTextNode(\"\") },\n };\n\n record.mounted = withOptionalInstance(owner, () =>\n renderNodeToDOM(\n renderChild(item, () => record.index),\n parent,\n block.endAnchor,\n namespace,\n ),\n );\n nextRecords.push(record);\n });\n\n for (const record of oldByKey.values()) {\n removeMountedNode(record.mounted);\n }\n\n records = nextRecords;\n block.children = nextRecords.map((record) => record.mounted);\n\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n });\n}\n\nfunction renderSwitchBlock(\n element: SinwanElement,\n block: MountedReactiveBlock,\n parent: Node,\n namespace: string | null,\n owner: ComponentInstance | null,\n): () => void {\n let initialized = false;\n\n return effect(() => {\n clearChildren(block);\n\n const content = withOptionalInstance(owner, () => resolveSwitchContent(element));\n block.children = renderBlockContent(\n content,\n parent,\n block.endAnchor,\n namespace,\n owner,\n );\n\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n });\n}\n\nfunction renderIndexBlock<T>(\n element: SinwanElement,\n block: MountedReactiveBlock,\n parent: Node,\n namespace: string | null,\n owner: ComponentInstance | null,\n): () => void {\n let initialized = false;\n let records: IndexRecord<T>[] = [];\n\n return effect(() => {\n const props = element.props as {\n each?: unknown;\n fallback?: SinwanNode;\n children?: (item: () => T, index: number) => SinwanNode;\n };\n const items = readReactive(props.each) as readonly T[] | null | undefined;\n const list = Array.isArray(items) ? items : [];\n const renderChild = props.children;\n\n if (typeof renderChild !== \"function\") {\n clearChildren(block);\n records = [];\n if (initialized) {\n queueUpdatedHooks(owner);\n }\n initialized = true;\n return;\n }\n\n if (list.length === 0) {\n clearChildren(block);\n records = [];\n block.children = renderBlockContent(\n props.fallback,\n parent,\n block.endAnchor,\n namespace,\n owner,\n );\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n return;\n }\n\n if (records.length === 0 && block.children.length > 0) {\n clearChildren(block);\n }\n\n for (let index = 0; index < list.length; index++) {\n const existing = records[index];\n if (existing) {\n existing.item.value = list[index]!;\n continue;\n }\n\n const itemSignal = signal(list[index]!);\n const record: IndexRecord<T> = {\n item: itemSignal,\n mounted: withOptionalInstance(owner, () =>\n renderNodeToDOM(\n renderChild(() => itemSignal.value, index),\n parent,\n block.endAnchor,\n namespace,\n ),\n ),\n };\n records.push(record);\n }\n\n while (records.length > list.length) {\n const removed = records.pop()!;\n removeMountedNode(removed.mounted);\n }\n\n block.children = records.map((record) => record.mounted);\n\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n });\n}\n\nfunction renderKeyBlock(\n element: SinwanElement,\n block: MountedReactiveBlock,\n parent: Node,\n namespace: string | null,\n owner: ComponentInstance | null,\n): () => void {\n let initialized = false;\n let hasKey = false;\n let currentKey: unknown;\n\n return effect(() => {\n const key = readReactive((element.props as any).when);\n if (hasKey && Object.is(currentKey, key)) {\n return;\n }\n\n currentKey = key;\n hasKey = true;\n clearChildren(block);\n\n const content = withOptionalInstance(owner, () =>\n resolveKeyChildren(element, key),\n );\n block.children = renderBlockContent(\n content,\n parent,\n block.endAnchor,\n namespace,\n owner,\n );\n\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n });\n}\n\nfunction renderDynamicBlock(\n element: SinwanElement,\n block: MountedReactiveBlock,\n parent: Node,\n namespace: string | null,\n owner: ComponentInstance | null,\n): () => void {\n let initialized = false;\n let hasTag = false;\n let currentTag: unknown;\n\n return effect(() => {\n const tag = readReactive((element.props as any).component);\n if (hasTag && Object.is(currentTag, tag)) {\n return;\n }\n\n currentTag = tag;\n hasTag = true;\n clearChildren(block);\n\n const content = tag ? createDynamicElement(element, tag) : null;\n block.children = renderBlockContent(\n content,\n parent,\n block.endAnchor,\n namespace,\n owner,\n );\n\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n });\n}\n\nfunction renderPortal(\n element: SinwanElement,\n parent: Node,\n anchor: Node | null,\n namespace: string | null,\n): MountedPortal {\n const placeholder = domOps.createComment(\"Sinwan-p\");\n insertNode(parent, placeholder, anchor);\n\n const owner = getCurrentInstance();\n let disposeEffect = () => {};\n const portal: MountedPortal = {\n type: \"portal\",\n anchor: placeholder,\n children: [],\n dispose: () => disposeEffect(),\n };\n let initialized = false;\n\n disposeEffect = effect(() => {\n clearPortalChildren(portal);\n\n const target = resolvePortalTarget((element.props as any).mount);\n if (target) {\n portal.children = renderBlockContent(\n (element.props as any).children ?? element.children,\n target,\n null,\n namespace,\n owner,\n );\n }\n\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n });\n\n return portal;\n}\n\nfunction resolveShowChildren(element: SinwanElement, value: unknown): SinwanNode {\n const children = (element.props as any).children ?? element.children;\n if (typeof children === \"function\") {\n return children(value);\n }\n return children as SinwanNode;\n}\n\nfunction resolveSwitchContent(element: SinwanElement): SinwanNode {\n const props = element.props as { fallback?: SinwanNode; children?: SinwanNode };\n const children = normalizeContent(props.children ?? element.children);\n\n for (const child of children) {\n const match = getMatchElement(child);\n if (!match) {\n continue;\n }\n\n const when = readReactive((match.props as any).when);\n if (when) {\n return resolveMatchChildren(match, when);\n }\n }\n\n return props.fallback;\n}\n\nfunction resolveMatchChildren(element: SinwanElement, value: unknown): SinwanNode {\n const children = (element.props as any).children ?? element.children;\n if (typeof children === \"function\") {\n return children(value);\n }\n return children as SinwanNode;\n}\n\nfunction resolveKeyChildren(element: SinwanElement, value: unknown): SinwanNode {\n const children = (element.props as any).children ?? element.children;\n if (typeof children === \"function\") {\n return children(value);\n }\n return children as SinwanNode;\n}\n\nfunction createDynamicElement(element: SinwanElement, tag: unknown): SinwanElement | null {\n if (typeof tag !== \"string\" && typeof tag !== \"function\") {\n return null;\n }\n\n const { component, ...props } = element.props as Record<string, unknown>;\n const children = normalizeContent(props.children ?? element.children);\n\n return {\n tag: tag as SinwanElement[\"tag\"],\n props,\n children,\n };\n}\n\nfunction renderBlockContent(\n content: unknown,\n parent: Node,\n anchor: Node | null,\n namespace: string | null,\n owner: ComponentInstance | null,\n): MountedNode[] {\n if (content == null || typeof content === \"boolean\") {\n return [];\n }\n\n const nodes = Array.isArray(content) ? content : [content];\n return nodes.map((node) =>\n withOptionalInstance(owner, () =>\n renderNodeToDOM(node as SinwanNode, parent, anchor, namespace),\n ),\n );\n}\n\nfunction clearChildren(block: MountedReactiveBlock): void {\n for (const child of block.children) {\n removeMountedNode(child);\n }\n block.children = [];\n}\n\nfunction clearPortalChildren(portal: MountedPortal): void {\n for (const child of portal.children) {\n removeMountedNode(child);\n }\n portal.children = [];\n}\n\nfunction moveBeforeEnd(parent: Node, mounted: MountedNode, endAnchor: Node): void {\n for (const node of getMountedDomNodes(mounted)) {\n domOps.insertBefore(parent, node, endAnchor);\n }\n}\n\nfunction fireMountedAndQueueUpdated(owner: ComponentInstance | null): void {\n if (owner) {\n fireMountedHooks(owner);\n }\n queueUpdatedHooks(owner);\n}\n\nfunction withOptionalInstance<T>(\n owner: ComponentInstance | null,\n fn: () => T,\n): T {\n return owner ? withInstance(owner, fn) : fn();\n}\n\nfunction readReactive(value: unknown): unknown {\n return isSignal(value) || isComputed(value) ? (value as any).value : value;\n}\n\nfunction normalizeContent(content: unknown): SinwanNode[] {\n if (content == null || typeof content === \"boolean\") {\n return [];\n }\n return Array.isArray(content) ? content : [content as SinwanNode];\n}\n\nfunction isElementLike(value: unknown): value is SinwanElement {\n return value != null && typeof value === \"object\" && \"tag\" in value;\n}\n\nfunction getMatchElement(value: unknown): SinwanElement | null {\n if (!isElementLike(value)) {\n return null;\n }\n if (isMatchElement(value)) {\n return value;\n }\n return value.tag === Match ? Match(value.props as any) : null;\n}\n\nfunction resolvePortalTarget(value: unknown): Node | null {\n const target = readReactive(value);\n\n if (target == null) {\n return typeof document === \"undefined\" ? null : document.body;\n }\n\n if (typeof target === \"string\") {\n return document.querySelector(target);\n }\n\n if (typeof target === \"function\") {\n return target() as Node | null;\n }\n\n if (typeof target === \"object\" && \"nodeType\" in target) {\n return target as Node;\n }\n\n return null;\n}\n\nfunction insertNode(parent: Node, child: Node, anchor: Node | null): void {\n if (anchor) {\n domOps.insertBefore(parent, child, anchor);\n } else {\n domOps.appendChild(parent, child);\n }\n}\n",
|
|
18
|
-
"/// <reference lib=\"dom\" />\n\n/**\n * SinwanJS Client Renderer — Element Rendering\n *\n * Converts SinwanElement trees into live DOM nodes.\n * Handles intrinsic HTML elements, functional components, and fragments.\n */\n\nimport type { SinwanElement, SinwanNode } from \"../types.ts\";\nimport type { MountedNode, MountedElement, MountedComponent } from \"./types.ts\";\nimport type { CleanupFn } from \"../reactivity/index.ts\";\nimport { domOps } from \"./dom-ops.ts\";\nimport { applyAttributes } from \"./attributes.ts\";\nimport { bindEvents } from \"./events.ts\";\nimport { renderChildrenToDOM, renderNodeToDOM } from \"./render-children.ts\";\nimport { Fragment } from \"../jsx/jsx-runtime.ts\";\nimport {\n Dynamic,\n For,\n Index,\n Key,\n Portal,\n Switch,\n Visible,\n isDynamicElement,\n isForElement,\n isIndexElement,\n isKeyElement,\n isPortalElement,\n isShowElement,\n isSwitchElement,\n Show,\n} from \"../component/control-flow.ts\";\nimport { renderControlFlowToDOM } from \"./render-control-flow.ts\";\nimport {\n createComponentInstance,\n getCurrentInstance,\n setCurrentInstance,\n handleComponentError,\n type ComponentInstance,\n} from \"../component/instance.ts\";\n\n// Void elements — no children, self-closing\nconst VOID_ELEMENTS = new Set([\n \"area\",\n \"base\",\n \"br\",\n \"col\",\n \"embed\",\n \"hr\",\n \"img\",\n \"input\",\n \"link\",\n \"meta\",\n \"param\",\n \"source\",\n \"track\",\n \"wbr\",\n]);\n\nconst SVG_NS = \"http://www.w3.org/2000/svg\";\nconst MATH_NS = \"http://www.w3.org/1998/Math/MathML\";\n\n/**\n * Render an SinwanElement to DOM and insert into parent.\n */\nexport function renderElementToDOM(\n element: SinwanElement,\n parent: Node,\n anchor: Node | null = null,\n namespace: string | null = null,\n): MountedNode {\n const { tag, props, children } = element;\n\n // Fragment — render children directly into parent\n if (tag === \"\" || (tag as any) === Fragment) {\n return renderFragmentToDOM(children, parent, anchor, namespace);\n }\n\n // Built-in control-flow components should belong to the current owner,\n // not create their own component instance.\n if (\n tag === Show ||\n tag === For ||\n tag === Switch ||\n tag === Index ||\n tag === Key ||\n tag === Dynamic ||\n tag === Portal\n ) {\n return renderElementToDOM((tag as Function)(props)
|
|
19
|
-
"/// <reference lib=\"dom\" />\n\n/**\n * SinwanJS Client Renderer — Child Rendering\n *\n * Renders SinwanNode children to DOM nodes. Handles primitives,\n * elements, arrays, signals, and fragments.\n */\n\nimport type { SinwanNode } from \"../types.ts\";\nimport type { MountedNode } from \"./types.ts\";\nimport { domOps } from \"./dom-ops.ts\";\nimport {
|
|
18
|
+
"/// <reference lib=\"dom\" />\n\n/**\n * SinwanJS Client Renderer — Reactive control-flow blocks\n *\n * `<Show>` and `<For>` render between stable comment anchors. Updates remove,\n * move, or insert only the block-owned DOM nodes.\n */\n\nimport type { SinwanElement, SinwanNode } from \"../types.ts\";\nimport type { MountedNode, MountedPortal, MountedReactiveBlock } from \"./types.ts\";\nimport { domOps } from \"./dom-ops.ts\";\nimport { effect, resolve, signal, type Signal } from \"../reactivity/index.ts\";\nimport {\n getCurrentInstance,\n fireMountedHooks,\n queueUpdatedHooks,\n withInstance,\n type ComponentInstance,\n} from \"../component/instance.ts\";\nimport {\n isDynamicElement,\n isForElement,\n isIndexElement,\n isKeyElement,\n isPortalElement,\n isShowElement,\n isSwitchElement,\n resolveKeyChildren,\n resolveShowChildren,\n resolveSwitchContent,\n} from \"../component/control-flow.ts\";\nimport {\n getMountedDomNodes,\n removeMountedNode,\n} from \"./unmount.ts\";\nimport { renderNodeToDOM } from \"./render-children.ts\";\n\ninterface ForRecord<T> {\n key: unknown;\n item: T;\n index: number;\n mounted: MountedNode;\n}\n\ninterface IndexRecord<T> {\n item: Signal<T>;\n mounted: MountedNode;\n}\n\n/**\n * Render a built-in reactive helper element.\n */\nexport function renderControlFlowToDOM(\n element: SinwanElement,\n parent: Node,\n anchor: Node | null,\n namespace: string | null,\n): MountedNode {\n if (isPortalElement(element)) {\n return renderPortal(element, parent, anchor, namespace);\n }\n\n const startAnchor = domOps.createComment(\"Sinwan-b\");\n const endAnchor = domOps.createComment(\"/Sinwan-b\");\n insertNode(parent, startAnchor, anchor);\n insertNode(parent, endAnchor, anchor);\n\n const owner = getCurrentInstance();\n let disposeEffect = () => {};\n\n const block: MountedReactiveBlock = {\n type: \"reactive-block\",\n dispose: () => disposeEffect(),\n children: [],\n startAnchor,\n endAnchor,\n };\n\n if (isShowElement(element)) {\n disposeEffect = renderShowBlock(element, block, parent, namespace, owner);\n } else if (isForElement(element)) {\n disposeEffect = renderForBlock(element, block, parent, namespace, owner);\n } else if (isSwitchElement(element)) {\n disposeEffect = renderSwitchBlock(element, block, parent, namespace, owner);\n } else if (isIndexElement(element)) {\n disposeEffect = renderIndexBlock(element, block, parent, namespace, owner);\n } else if (isKeyElement(element)) {\n disposeEffect = renderKeyBlock(element, block, parent, namespace, owner);\n } else if (isDynamicElement(element)) {\n disposeEffect = renderDynamicBlock(element, block, parent, namespace, owner);\n }\n\n return block;\n}\n\nfunction renderShowBlock(\n element: SinwanElement,\n block: MountedReactiveBlock,\n parent: Node,\n namespace: string | null,\n owner: ComponentInstance | null,\n): () => void {\n let initialized = false;\n\n return effect(() => {\n clearChildren(block);\n const when = readReactive((element.props as any).when);\n block.children = withOptionalInstance(owner, () => {\n const content = when ? resolveShowChildren(element, when) : (element.props as any).fallback;\n return renderBlockContent(\n content,\n parent,\n block.endAnchor,\n namespace,\n owner,\n );\n });\n\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n });\n}\n\nfunction renderForBlock<T>(\n element: SinwanElement,\n block: MountedReactiveBlock,\n parent: Node,\n namespace: string | null,\n owner: ComponentInstance | null,\n): () => void {\n let initialized = false;\n let records: ForRecord<T>[] = [];\n\n return effect(() => {\n const props = element.props as {\n each?: unknown;\n key?: (item: T, index: number) => string | number | symbol;\n fallback?: SinwanNode;\n children?: (item: T, index: () => number) => SinwanNode;\n };\n const items = readReactive(props.each) as readonly T[] | null | undefined;\n const list = Array.isArray(items) ? items : [];\n const renderChild = props.children;\n\n if (typeof renderChild !== \"function\") {\n clearChildren(block);\n records = [];\n if (initialized) {\n queueUpdatedHooks(owner);\n }\n initialized = true;\n return;\n }\n\n if (list.length === 0) {\n clearChildren(block);\n records = [];\n block.children = renderBlockContent(\n props.fallback,\n parent,\n block.endAnchor,\n namespace,\n owner,\n );\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n return;\n }\n\n if (records.length === 0 && block.children.length > 0) {\n clearChildren(block);\n }\n\n const oldByKey = new Map<unknown, ForRecord<T>>();\n for (const record of records) {\n oldByKey.set(record.key, record);\n }\n\n const nextRecords: ForRecord<T>[] = [];\n\n list.forEach((item, index) => {\n const key = props.key ? props.key(item, index) : item;\n const old = oldByKey.get(key);\n\n if (old && old.item === item) {\n old.index = index;\n moveBeforeEnd(parent, old.mounted, block.endAnchor);\n nextRecords.push(old);\n oldByKey.delete(key);\n return;\n }\n\n if (old) {\n removeMountedNode(old.mounted);\n oldByKey.delete(key);\n }\n\n const record: ForRecord<T> = {\n key,\n item,\n index,\n mounted: { type: \"text\", node: domOps.createTextNode(\"\") },\n };\n\n record.mounted = withOptionalInstance(owner, () =>\n renderNodeToDOM(\n renderChild(item, () => record.index),\n parent,\n block.endAnchor,\n namespace,\n ),\n );\n nextRecords.push(record);\n });\n\n for (const record of oldByKey.values()) {\n removeMountedNode(record.mounted);\n }\n\n records = nextRecords;\n block.children = nextRecords.map((record) => record.mounted);\n\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n });\n}\n\nfunction renderSwitchBlock(\n element: SinwanElement,\n block: MountedReactiveBlock,\n parent: Node,\n namespace: string | null,\n owner: ComponentInstance | null,\n): () => void {\n let initialized = false;\n\n return effect(() => {\n clearChildren(block);\n\n const content = withOptionalInstance(owner, () => resolveSwitchContent(element));\n block.children = renderBlockContent(\n content,\n parent,\n block.endAnchor,\n namespace,\n owner,\n );\n\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n });\n}\n\nfunction renderIndexBlock<T>(\n element: SinwanElement,\n block: MountedReactiveBlock,\n parent: Node,\n namespace: string | null,\n owner: ComponentInstance | null,\n): () => void {\n let initialized = false;\n let records: IndexRecord<T>[] = [];\n\n return effect(() => {\n const props = element.props as {\n each?: unknown;\n fallback?: SinwanNode;\n children?: (item: () => T, index: number) => SinwanNode;\n };\n const items = readReactive(props.each) as readonly T[] | null | undefined;\n const list = Array.isArray(items) ? items : [];\n const renderChild = props.children;\n\n if (typeof renderChild !== \"function\") {\n clearChildren(block);\n records = [];\n if (initialized) {\n queueUpdatedHooks(owner);\n }\n initialized = true;\n return;\n }\n\n if (list.length === 0) {\n clearChildren(block);\n records = [];\n block.children = renderBlockContent(\n props.fallback,\n parent,\n block.endAnchor,\n namespace,\n owner,\n );\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n return;\n }\n\n if (records.length === 0 && block.children.length > 0) {\n clearChildren(block);\n }\n\n for (let index = 0; index < list.length; index++) {\n const existing = records[index];\n if (existing) {\n existing.item.value = list[index]!;\n continue;\n }\n\n const itemSignal = signal(list[index]!);\n const record: IndexRecord<T> = {\n item: itemSignal,\n mounted: withOptionalInstance(owner, () =>\n renderNodeToDOM(\n renderChild(() => itemSignal.value, index),\n parent,\n block.endAnchor,\n namespace,\n ),\n ),\n };\n records.push(record);\n }\n\n while (records.length > list.length) {\n const removed = records.pop()!;\n removeMountedNode(removed.mounted);\n }\n\n block.children = records.map((record) => record.mounted);\n\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n });\n}\n\nfunction renderKeyBlock(\n element: SinwanElement,\n block: MountedReactiveBlock,\n parent: Node,\n namespace: string | null,\n owner: ComponentInstance | null,\n): () => void {\n let initialized = false;\n let hasKey = false;\n let currentKey: unknown;\n\n return effect(() => {\n const key = readReactive((element.props as any).when);\n if (hasKey && Object.is(currentKey, key)) {\n return;\n }\n\n currentKey = key;\n hasKey = true;\n clearChildren(block);\n\n const content = withOptionalInstance(owner, () =>\n resolveKeyChildren(element, key),\n );\n block.children = renderBlockContent(\n content,\n parent,\n block.endAnchor,\n namespace,\n owner,\n );\n\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n });\n}\n\nfunction renderDynamicBlock(\n element: SinwanElement,\n block: MountedReactiveBlock,\n parent: Node,\n namespace: string | null,\n owner: ComponentInstance | null,\n): () => void {\n let initialized = false;\n let hasTag = false;\n let currentTag: unknown;\n\n return effect(() => {\n const tag = readReactive((element.props as any).component);\n if (hasTag && Object.is(currentTag, tag)) {\n return;\n }\n\n currentTag = tag;\n hasTag = true;\n clearChildren(block);\n\n const content = tag ? createDynamicElement(element, tag) : null;\n block.children = renderBlockContent(\n content,\n parent,\n block.endAnchor,\n namespace,\n owner,\n );\n\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n });\n}\n\nfunction renderPortal(\n element: SinwanElement,\n parent: Node,\n anchor: Node | null,\n namespace: string | null,\n): MountedPortal {\n const placeholder = domOps.createComment(\"Sinwan-p\");\n insertNode(parent, placeholder, anchor);\n\n const owner = getCurrentInstance();\n let disposeEffect = () => {};\n \n const targetAnchor = domOps.createComment(\"Sinwan-pa\");\n let lastTarget: Node | null = null;\n\n const portal: MountedPortal = {\n type: \"portal\",\n anchor: placeholder,\n children: [],\n dispose: () => disposeEffect(),\n targetAnchor,\n };\n let initialized = false;\n\n disposeEffect = effect(() => {\n const target = resolvePortalTarget((element.props as any).mount);\n \n if (target !== lastTarget) {\n if (lastTarget) {\n domOps.remove(targetAnchor);\n }\n if (target) {\n domOps.appendChild(target, targetAnchor);\n }\n lastTarget = target;\n portal.target = target as Node;\n }\n\n clearPortalChildren(portal);\n\n if (target) {\n portal.children = renderBlockContent(\n (element.props as any).children ?? element.children,\n target,\n targetAnchor,\n namespace,\n owner,\n );\n }\n\n if (initialized) {\n fireMountedAndQueueUpdated(owner);\n }\n initialized = true;\n });\n\n return portal;\n}\n\nfunction createDynamicElement(element: SinwanElement, tag: unknown): SinwanElement | null {\n if (typeof tag !== \"string\" && typeof tag !== \"function\") {\n return null;\n }\n\n const { component, ...props } = element.props as Record<string, unknown>;\n const children = normalizeContent(props.children ?? element.children);\n\n return {\n tag: tag as SinwanElement[\"tag\"],\n props,\n children,\n };\n}\n\nfunction renderBlockContent(\n content: SinwanNode,\n parent: Node,\n anchor: Node | null,\n namespace: string | null,\n owner: ComponentInstance | null,\n): MountedNode[] {\n if (content == null || typeof content === \"boolean\") return [];\n\n return withOptionalInstance(owner, () => {\n if (Array.isArray(content)) {\n return content.map((child) =>\n renderNodeToDOM(child, parent, anchor, namespace),\n );\n }\n\n return [renderNodeToDOM(content, parent, anchor, namespace)];\n });\n}\n\nfunction clearChildren(block: MountedReactiveBlock): void {\n for (const child of block.children) {\n removeMountedNode(child);\n }\n block.children = [];\n}\n\nfunction clearPortalChildren(portal: MountedPortal): void {\n for (const child of portal.children) {\n removeMountedNode(child);\n }\n portal.children = [];\n}\n\nfunction moveBeforeEnd(parent: Node, mounted: MountedNode, endAnchor: Node): void {\n for (const node of getMountedDomNodes(mounted)) {\n domOps.insertBefore(parent, node, endAnchor);\n }\n syncPortalOrder(mounted);\n}\n\nfunction syncPortalOrder(mounted: MountedNode): void {\n if (mounted.type === \"portal\") {\n if (mounted.target && mounted.targetAnchor) {\n for (const child of mounted.children) {\n for (const node of getMountedDomNodes(child)) {\n domOps.appendChild(mounted.target, node);\n }\n }\n domOps.appendChild(mounted.target, mounted.targetAnchor);\n }\n } else if (\"children\" in mounted && Array.isArray((mounted as any).children)) {\n for (const child of (mounted as any).children) {\n syncPortalOrder(child);\n }\n }\n}\n\nfunction fireMountedAndQueueUpdated(owner: ComponentInstance | null): void {\n if (owner) {\n fireMountedHooks(owner);\n }\n queueUpdatedHooks(owner);\n}\n\nfunction withOptionalInstance<T>(\n owner: ComponentInstance | null,\n fn: () => T,\n): T {\n return owner ? withInstance(owner, fn) : fn();\n}\n\nfunction readReactive(value: unknown): unknown {\n return resolve(value as any);\n}\n\nfunction normalizeContent(content: unknown): SinwanNode[] {\n if (content == null || typeof content === \"boolean\") {\n return [];\n }\n return Array.isArray(content) ? content : [content as SinwanNode];\n}\n\nfunction resolvePortalTarget(value: unknown): Node | null {\n const target = readReactive(value);\n\n if (target == null) {\n return typeof document === \"undefined\" ? null : document.body;\n }\n\n if (typeof target === \"string\") {\n return document.querySelector(target);\n }\n\n if (typeof target === \"function\") {\n return target() as Node | null;\n }\n\n if (typeof target === \"object\" && \"nodeType\" in target) {\n return target as Node;\n }\n\n return null;\n}\n\nfunction insertNode(parent: Node, child: Node, anchor: Node | null): void {\n if (anchor) {\n domOps.insertBefore(parent, child, anchor);\n } else {\n domOps.appendChild(parent, child);\n }\n}\n",
|
|
19
|
+
"/// <reference lib=\"dom\" />\n\n/**\n * SinwanJS Client Renderer — Element Rendering\n *\n * Converts SinwanElement trees into live DOM nodes.\n * Handles intrinsic HTML elements, functional components, and fragments.\n */\n\nimport type { SinwanElement, SinwanNode } from \"../types.ts\";\nimport type { MountedNode, MountedElement, MountedComponent } from \"./types.ts\";\nimport type { CleanupFn } from \"../reactivity/index.ts\";\nimport { domOps } from \"./dom-ops.ts\";\nimport { applyAttributes } from \"./attributes.ts\";\nimport { bindEvents } from \"./events.ts\";\nimport { renderChildrenToDOM, renderNodeToDOM } from \"./render-children.ts\";\nimport { Fragment } from \"../jsx/jsx-runtime.ts\";\nimport {\n Dynamic,\n For,\n Index,\n Key,\n Portal,\n Switch,\n Visible,\n isDynamicElement,\n isForElement,\n isIndexElement,\n isKeyElement,\n isPortalElement,\n isShowElement,\n isSwitchElement,\n Show,\n} from \"../component/control-flow.ts\";\nimport { renderControlFlowToDOM } from \"./render-control-flow.ts\";\nimport {\n createComponentInstance,\n getCurrentInstance,\n setCurrentInstance,\n handleComponentError,\n type ComponentInstance,\n} from \"../component/instance.ts\";\n\n// Void elements — no children, self-closing\nconst VOID_ELEMENTS = new Set([\n \"area\",\n \"base\",\n \"br\",\n \"col\",\n \"embed\",\n \"hr\",\n \"img\",\n \"input\",\n \"link\",\n \"meta\",\n \"param\",\n \"source\",\n \"track\",\n \"wbr\",\n]);\n\nconst SVG_NS = \"http://www.w3.org/2000/svg\";\nconst MATH_NS = \"http://www.w3.org/1998/Math/MathML\";\n\n/**\n * Render an SinwanElement to DOM and insert into parent.\n */\nexport function renderElementToDOM(\n element: SinwanElement,\n parent: Node,\n anchor: Node | null = null,\n namespace: string | null = null,\n): MountedNode {\n const { tag, props, children } = element;\n\n // Fragment — render children directly into parent\n if (tag === \"\" || (tag as any) === Fragment) {\n return renderFragmentToDOM(children, parent, anchor, namespace);\n }\n\n // Built-in control-flow components should belong to the current owner,\n // not create their own component instance.\n if (\n tag === Show ||\n tag === For ||\n tag === Switch ||\n tag === Index ||\n tag === Key ||\n tag === Dynamic ||\n tag === Portal\n ) {\n return renderElementToDOM(\n (tag as Function)(props),\n parent,\n anchor,\n namespace,\n );\n }\n\n if (tag === Visible) {\n return renderElementToDOM(\n (tag as Function)(props),\n parent,\n anchor,\n namespace,\n );\n }\n\n if (\n isShowElement(element) ||\n isForElement(element) ||\n isSwitchElement(element) ||\n isIndexElement(element) ||\n isKeyElement(element) ||\n isDynamicElement(element) ||\n isPortalElement(element)\n ) {\n return renderControlFlowToDOM(element, parent, anchor, namespace);\n }\n\n // Functional component — call it and render the result\n if (typeof tag === \"function\") {\n return renderComponentToDOM(tag, props, parent, anchor, namespace);\n }\n\n // Intrinsic HTML element\n if (typeof tag === \"string\") {\n return renderIntrinsicToDOM(\n tag,\n props,\n children,\n parent,\n anchor,\n namespace,\n );\n }\n\n // Fallback — render children\n return renderFragmentToDOM(children, parent, anchor, namespace);\n}\n\n/**\n * Render an intrinsic HTML element (<div>, <p>, <button>, etc.).\n */\nfunction renderIntrinsicToDOM(\n tag: string,\n props: Record<string, unknown>,\n children: SinwanNode[],\n parent: Node,\n anchor: Node | null,\n parentNamespace: string | null,\n): MountedElement {\n const namespace = getElementNamespace(tag, parentNamespace);\n const el = namespace\n ? domOps.createElementNS(namespace, tag)\n : domOps.createElement(tag);\n\n // Apply attributes (returns disposers for reactive attrs)\n const attrDisposers = applyAttributes(el, props);\n\n // Bind event handlers\n const eventCleanups = bindEvents(el, props);\n\n // Render children (unless void element)\n let mountedChildren: MountedNode[] = [];\n if (!VOID_ELEMENTS.has(tag)) {\n // Handle dangerouslySetInnerHTML\n const dangerous = props.dangerouslySetInnerHTML as\n | { __html?: string }\n | undefined;\n if (dangerous && typeof dangerous.__html === \"string\") {\n (el as HTMLElement).innerHTML = dangerous.__html;\n } else {\n mountedChildren = renderChildrenToDOM(\n children,\n el,\n getChildNamespace(tag, namespace),\n );\n }\n }\n\n // Insert into parent\n if (anchor) {\n domOps.insertBefore(parent, el, anchor);\n } else {\n domOps.appendChild(parent, el);\n }\n\n const refCleanup = applyRef(el, props.ref);\n\n return {\n type: \"element\",\n node: el,\n children: mountedChildren,\n eventCleanups,\n attrDisposers,\n refCleanup,\n };\n}\n\n/**\n * Render a functional component.\n *\n * Creates a ComponentInstance, sets it as the active instance during\n * setup so lifecycle hooks (onMounted, etc.) register on it, then\n * renders the returned element tree.\n */\nfunction renderComponentToDOM(\n component: Function,\n props: Record<string, unknown>,\n parent: Node,\n anchor: Node | null,\n namespace: string | null,\n): MountedComponent {\n // Create instance with parent context\n const parentInstance = getCurrentInstance();\n const instance = createComponentInstance(\n component as any,\n props,\n parentInstance,\n );\n\n // Register as child of parent\n if (parentInstance) {\n parentInstance.children.push(instance);\n }\n\n // Set this instance as current during BOTH setup AND rendering,\n // so nested child components discover it as their parent.\n const prevInstance = setCurrentInstance(instance);\n\n let result: any;\n let child: MountedNode;\n\n try {\n result = component(props);\n\n // Render the returned element tree (still under this instance)\n if (result && typeof result === \"object\" && \"tag\" in result) {\n child = renderElementToDOM(\n result as SinwanElement,\n parent,\n anchor,\n namespace,\n );\n } else {\n child = renderNodeToDOM(result as SinwanNode, parent, anchor, namespace);\n }\n } catch (err) {\n // Restore parent before error handling\n setCurrentInstance(prevInstance);\n handleComponentError(instance, err as Error);\n // Return empty placeholder on error\n const text = domOps.createTextNode(\"\");\n if (anchor) {\n domOps.insertBefore(parent, text, anchor);\n } else {\n domOps.appendChild(parent, text);\n }\n return {\n type: \"component\",\n children: [{ type: \"text\", node: text }],\n disposers: [],\n instance,\n };\n }\n\n // Restore parent instance\n setCurrentInstance(prevInstance);\n\n instance.element = child;\n\n return {\n type: \"component\",\n children: [child],\n disposers: instance.effects,\n instance,\n };\n}\n\n/**\n * Render children as a fragment (no wrapper element).\n */\nfunction renderFragmentToDOM(\n children: SinwanNode[],\n parent: Node,\n anchor: Node | null,\n namespace: string | null,\n): MountedNode {\n const anchorComment = domOps.createComment(\"Sinwan-f\");\n if (anchor) {\n domOps.insertBefore(parent, anchorComment, anchor);\n } else {\n domOps.appendChild(parent, anchorComment);\n }\n\n const mounted: MountedNode[] = [];\n for (const child of children) {\n mounted.push(renderNodeToDOM(child, parent, anchor, namespace));\n }\n\n return { type: \"fragment\", children: mounted, anchor: anchorComment };\n}\n\nfunction getElementNamespace(\n tag: string,\n parentNamespace: string | null,\n): string | null {\n if (tag === \"svg\") return SVG_NS;\n if (tag === \"math\") return MATH_NS;\n return parentNamespace;\n}\n\nfunction getChildNamespace(\n tag: string,\n namespace: string | null,\n): string | null {\n if (namespace === SVG_NS && tag === \"foreignObject\") {\n return null;\n }\n return namespace;\n}\n\ntype RefValue =\n | ((el: Element | null) => void)\n | { current: Element | null }\n | null\n | undefined;\n\nfunction applyRef(el: Element, ref: unknown): CleanupFn | null {\n const value = ref as RefValue;\n if (!value) {\n return null;\n }\n\n if (typeof value === \"function\") {\n value(el);\n return () => value(null);\n }\n\n if (typeof value === \"object\" && \"current\" in value) {\n value.current = el;\n return () => {\n value.current = null;\n };\n }\n\n return null;\n}\n",
|
|
20
|
+
"/// <reference lib=\"dom\" />\n\n/**\n * SinwanJS Client Renderer — Child Rendering\n *\n * Renders SinwanNode children to DOM nodes. Handles primitives,\n * elements, arrays, signals, and fragments.\n */\n\nimport type { SinwanNode } from \"../types.ts\";\nimport type { MountedNode, MountedReactiveBlock } from \"./types.ts\";\nimport { domOps } from \"./dom-ops.ts\";\nimport { isReactive, resolve, effect, type Signal, type Computed } from \"../reactivity/index.ts\";\nimport { renderElementToDOM } from \"./render-element.ts\";\nimport { HtmlEscapedString } from \"../jsx/jsx-runtime.ts\";\nimport {\n getCurrentInstance,\n queueUpdatedHooks,\n fireMountedHooks,\n} from \"../component/instance.ts\";\nimport { removeMountedNode } from \"./unmount.ts\";\n\n/**\n * Render a single SinwanNode to DOM and append to parent.\n * Returns the MountedNode descriptor for cleanup/unmount.\n */\nexport function renderNodeToDOM(\n node: SinwanNode,\n parent: Node,\n anchor: Node | null = null,\n namespace: string | null = null,\n): MountedNode {\n // null/undefined/boolean → empty text node (placeholder)\n if (node == null || typeof node === \"boolean\") {\n const text = domOps.createTextNode(\"\");\n insertNode(parent, text, anchor);\n return { type: \"text\", node: text };\n }\n\n // String\n if (typeof node === \"string\") {\n const text = domOps.createTextNode(node);\n insertNode(parent, text, anchor);\n return { type: \"text\", node: text };\n }\n\n // Number\n if (typeof node === \"number\") {\n const text = domOps.createTextNode(String(node));\n insertNode(parent, text, anchor);\n return { type: \"text\", node: text };\n }\n\n // Pre-escaped HTML string\n if (node instanceof HtmlEscapedString) {\n const text = domOps.createTextNode(node.value);\n insertNode(parent, text, anchor);\n return { type: \"text\", node: text };\n }\n\n // Reactive Node (Signal, Computed, or Function Getter)\n if (isReactive(node)) {\n return renderReactiveNodeToDOM(node as any, parent, anchor, namespace);\n }\n\n // Array → fragment\n if (Array.isArray(node)) {\n return renderArrayToDOM(node, parent, anchor, namespace);\n }\n\n // Promise → placeholder (resolved async)\n if (node instanceof Promise) {\n const placeholder = domOps.createTextNode(\"\");\n insertNode(parent, placeholder, anchor);\n // TODO: async component support (Phase 3+)\n node.then((resolved) => {\n const mounted = renderNodeToDOM(resolved, parent, placeholder, namespace);\n domOps.remove(placeholder);\n });\n return { type: \"text\", node: placeholder };\n }\n\n // SinwanElement\n if (typeof node === \"object\" && \"tag\" in node) {\n return renderElementToDOM(node, parent, anchor, namespace);\n }\n\n // Fallback — coerce to string\n const text = domOps.createTextNode(String(node));\n insertNode(parent, text, anchor);\n return { type: \"text\", node: text };\n}\n\n/**\n * Render an array of children to DOM as a fragment.\n */\nfunction renderArrayToDOM(\n nodes: SinwanNode[],\n parent: Node,\n anchor: Node | null,\n namespace: string | null,\n): MountedNode {\n const anchorComment = domOps.createComment(\"Sinwan-f\");\n insertNode(parent, anchorComment, anchor);\n\n const children: MountedNode[] = [];\n for (const child of nodes) {\n children.push(renderNodeToDOM(child, parent, anchor, namespace));\n }\n\n return { type: \"fragment\", children, anchor: anchorComment };\n}\n\n/**\n * Render multiple children into a parent element.\n * Returns array of MountedNode descriptors.\n */\nexport function renderChildrenToDOM(\n children: SinwanNode[],\n parent: Node,\n namespace: string | null = null,\n): MountedNode[] {\n const mounted: MountedNode[] = [];\n for (const child of children) {\n mounted.push(renderNodeToDOM(child, parent, null, namespace));\n }\n return mounted;\n}\n\n/**\n * Render a reactive node (Signal, Computed, or Function) that can resolve to any SinwanNode.\n * Uses comment anchors to allow swapping between different types of content (text, elements, etc.).\n */\nfunction renderReactiveNodeToDOM(\n reactive: Signal<any> | Computed<any> | Function,\n parent: Node,\n anchor: Node | null,\n namespace: string | null,\n): MountedNode {\n const startAnchor = domOps.createComment(\"Sinwan-r\");\n const endAnchor = domOps.createComment(\"/Sinwan-r\");\n insertNode(parent, startAnchor, anchor);\n insertNode(parent, endAnchor, anchor);\n\n const owner = getCurrentInstance();\n let mountedContent: MountedNode | null = null;\n let initialized = false;\n\n const block: MountedReactiveBlock = {\n type: \"reactive-block\",\n startAnchor,\n endAnchor,\n children: [],\n dispose: () => {}, // placeholder\n };\n\n block.dispose = effect(() => {\n // 1. Cleanup previous content\n if (mountedContent) {\n removeMountedNode(mountedContent);\n }\n\n // 2. Resolve and render new content\n const value = resolve(reactive);\n mountedContent = renderNodeToDOM(value as SinwanNode, parent, endAnchor, namespace);\n block.children = [mountedContent];\n\n // 3. Trigger lifecycle hooks\n if (initialized) {\n if (owner) fireMountedHooks(owner);\n queueUpdatedHooks(owner);\n }\n initialized = true;\n });\n\n return block;\n}\n\n/**\n * Insert a node into parent, optionally before an anchor.\n */\nfunction insertNode(parent: Node, child: Node, anchor: Node | null): void {\n if (anchor) {\n domOps.insertBefore(parent, child, anchor);\n } else {\n domOps.appendChild(parent, child);\n }\n}\n",
|
|
20
21
|
"/// <reference lib=\"dom\" />\n\n/**\n * SinwanJS Client Renderer — Mount\n *\n * Entry point for rendering a component tree into a DOM container.\n * Returns an AppInstance handle for unmounting.\n */\n\nimport type { SinwanComponent, SinwanNode, SinwanElement } from \"../types.ts\";\nimport type { AppInstance, MountedNode } from \"./types.ts\";\nimport { renderNodeToDOM } from \"./render-children.ts\";\nimport { renderElementToDOM } from \"./render-element.ts\";\nimport { unmountNode } from \"./unmount.ts\";\nimport {\n createComponentInstance,\n setCurrentInstance,\n fireMountedHooks,\n fireUnmountedHooks,\n handleComponentError,\n} from \"../component/instance.ts\";\n\n/**\n * Mount a component into a DOM container.\n *\n * Creates a root ComponentInstance, runs setup with lifecycle hooks,\n * renders to DOM, then fires onMounted hooks (bottom-up).\n *\n * @example\n * const app = mount(Counter, document.getElementById(\"app\")!, { initial: 0 });\n * // later...\n * app.unmount();\n */\nexport function mount(\n component: SinwanComponent<any>,\n container: Element,\n props?: Record<string, unknown>,\n): AppInstance {\n // Clear the container\n container.innerHTML = \"\";\n\n const mergedProps = props ?? {};\n\n // Create root component instance\n const instance = createComponentInstance(component, mergedProps, null);\n\n let result: any;\n let root: MountedNode;\n\n // Set instance as current for BOTH setup AND rendering,\n // so child components can discover their parent.\n setCurrentInstance(instance);\n\n try {\n result = component(mergedProps);\n\n if (result instanceof Promise) {\n // Async component — render placeholder, then swap\n const placeholder = document.createTextNode(\"\");\n container.appendChild(placeholder);\n root = { type: \"text\", node: placeholder };\n\n result.then((resolved) => {\n container.innerHTML = \"\";\n setCurrentInstance(instance);\n root = renderElementToDOM(resolved, container);\n setCurrentInstance(null);\n instance.element = root;\n fireMountedHooks(instance);\n });\n } else if (result && typeof result === \"object\" && \"tag\" in result) {\n root = renderElementToDOM(result, container);\n } else {\n root = renderNodeToDOM(result as SinwanNode, container);\n }\n } catch (err) {\n setCurrentInstance(null);\n handleComponentError(instance, err as Error);\n return {\n root: { type: \"text\", node: document.createTextNode(\"\") },\n unmount() {},\n };\n }\n\n // Restore — no instance is current at the top level\n setCurrentInstance(null);\n\n instance.element = root;\n\n // Fire onMounted hooks (bottom-up: children first, then parent)\n fireMountedHooks(instance);\n\n return {\n root,\n unmount() {\n // Fire onUnmounted hooks and dispose all effects\n fireUnmountedHooks(instance);\n // Clean up DOM tree\n unmountNode(root);\n container.innerHTML = \"\";\n },\n };\n}\n\n/**\n * Render a raw SinwanElement or SinwanNode tree into a container.\n * Lower-level than mount() — doesn't call a component function.\n */\nexport function render(node: SinwanNode, container: Element): AppInstance {\n container.innerHTML = \"\";\n\n const root = renderNodeToDOM(node, container);\n\n return {\n root,\n unmount() {\n unmountNode(root);\n container.innerHTML = \"\";\n },\n };\n}\n\nexport { unmountNode } from \"./unmount.ts\";\n"
|
|
21
22
|
],
|
|
22
|
-
"mappings": "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",
|
|
23
|
-
"debugId": "
|
|
23
|
+
"mappings": ";AAUO,IAAM,GAAW,OAAO,UAAU,EAMlC,MAAM,UAA0B,MAAO,CAChB,MAA5B,WAAW,CAAiB,EAAe,CACzC,MAAM,CAAK,EADe,aAGnB,QAAQ,EAAG,CAClB,OAAO,KAAK,MAEhB,CAEO,IAAM,GAAM,CAAC,IAAgB,IAAI,EAAkB,CAAG,EAuB7D,SAAS,CAAiB,CAAC,EAA6B,CACtD,GAAI,GAAY,MAAQ,OAAO,IAAa,UAAW,MAAO,CAAC,EAC/D,GAAI,MAAM,QAAQ,CAAQ,EAAG,OAAO,EAAS,KAAK,GAAQ,EAC1D,MAAO,CAAC,CAAQ,EAOlB,SAAS,EAAY,CACnB,EACA,EACA,EACe,CAEf,GAAI,IAAS,GACX,MAAO,CAAE,IAAK,GAAI,MAAO,CAAC,EAAG,UAAS,EAQxC,GAAI,OAAO,IAAS,YAAc,OAAO,IAAS,SAAU,CAC1D,IAAM,EAAa,GAAS,CAAC,EAE7B,GAAI,EAAS,OAAS,GAAK,EAAW,WAAa,OACjD,EAAW,SAAW,EAAS,SAAW,EAAI,EAAS,GAAK,EAE9D,MAAO,CAAE,IAAK,EAAM,MAAO,EAAY,UAAS,EAIlD,MAAO,CAAE,IAAK,GAAI,MAAO,CAAC,EAAG,UAAS,EAOjC,SAAS,EAAG,CAAC,EAAW,EAAY,EAA0B,CACnE,OAAO,GAAa,EAAM,EAAO,EAAkB,GAAO,QAAQ,CAAC,EAO9D,SAAS,EAAI,CAAC,EAAW,EAAY,EAA0B,CACpE,IAAM,EAAW,GAAO,SAExB,OAAO,GACL,EACA,EACA,MAAM,QAAQ,CAAQ,EAClB,EAAS,KAAK,GAAQ,EACtB,EAAkB,CAAQ,CAChC,EAgBK,SAAS,EAAM,CACpB,EACA,EACA,EACA,EACA,EACA,EACe,CACf,IAAM,EAAW,EACb,MAAM,QAAQ,GAAO,QAAQ,EAC3B,EAAM,SAAS,KAAK,GAAQ,EAC5B,EAAkB,GAAO,QAAQ,EACnC,EAAkB,GAAO,QAAQ,EAE/B,EAAU,GAAa,EAAM,EAAO,CAAQ,EAGlD,GAAI,EACD,EAAgB,SAAW,EAG9B,OAAO,ECrHT,SAAS,EAAmB,EAAW,CACrC,MAAO,CACL,aAAa,CAAC,EAAsB,CAClC,OAAO,SAAS,cAAc,CAAG,GAGnC,eAAe,CAAC,EAAmB,EAAsB,CACvD,OAAO,SAAS,gBAAgB,EAAW,CAAG,GAGhD,cAAc,CAAC,EAAoB,CACjC,OAAO,SAAS,eAAe,CAAI,GAGrC,aAAa,CAAC,EAAuB,CACnC,OAAO,SAAS,cAAc,CAAI,GAGpC,YAAY,CAAC,EAAa,EAAa,EAAqB,CAC1D,EAAG,aAAa,EAAK,CAAK,GAG5B,eAAe,CAAC,EAAa,EAAmB,CAC9C,EAAG,gBAAgB,CAAG,GAGxB,WAAW,CAAC,EAAa,EAAa,EAAsB,CACzD,EAAW,GAAO,GAGrB,YAAY,CAAC,EAAc,EAAa,EAA2B,CACjE,EAAO,aAAa,EAAO,CAAM,GAGnC,WAAW,CAAC,EAAc,EAAmB,CAC3C,EAAO,YAAY,CAAK,GAG1B,MAAM,CAAC,EAAkB,CACvB,EAAK,YAAY,YAAY,CAAI,GAGnC,cAAc,CAAC,EAAY,EAAoB,CAC7C,EAAK,KAAO,GAGd,gBAAgB,CAAC,EAAa,EAAe,EAA8B,CACzE,EAAG,iBAAiB,EAAO,CAAO,GAGpC,mBAAmB,CAAC,EAAa,EAAe,EAA8B,CAC5E,EAAG,oBAAoB,EAAO,CAAO,GAGvC,UAAU,CAAC,EAAyB,CAClC,OAAO,EAAK,YAGd,WAAW,CAAC,EAAyB,CACnC,OAAO,EAAK,YAEhB,EAGF,IAAM,GAAgB,GAAoB,EAK7B,EAAiB,IAAK,EAAc,EAE1C,SAAS,EAAS,CAAC,EAAkC,CAC1D,OAAO,OAAO,EAAQ,CAAS,EAG1B,SAAS,EAAW,EAAS,CAClC,QAAW,KAAO,OAAO,KAAK,CAAM,EAClC,OAAQ,EAAe,GAEzB,OAAO,OAAO,EAAQ,EAAa,EC5FrC,IAAM,EAAiB,IAAI,IACvB,EAAiB,GACjB,GAAa,GAGX,GAAmC,CAAC,EAKnC,SAAS,EAAc,CAAC,EAA0B,CACvD,GAAI,CAAC,EAAO,OAAQ,OACpB,EAAe,IAAI,CAAM,EACzB,GAAc,EAMT,SAAS,EAAgB,CAAC,EAA0B,CACzD,EAAe,OAAO,CAAM,EAM9B,SAAS,EAAa,EAAS,CAC7B,GAAI,CAAC,EACH,EAAiB,GACjB,eAAe,EAAK,EAQxB,SAAS,EAAK,EAAS,CACrB,GAAa,GAGb,IAAM,EAAS,CAAC,GAAG,CAAc,EAAE,KAAK,CAAC,EAAG,IAAM,EAAE,GAAK,EAAE,EAAE,EAC7D,EAAe,MAAM,EAErB,QAAW,KAAU,EACnB,GAAI,EAAO,OACT,EAAO,IAAI,EAMf,IAAI,EAAS,GACb,MAAO,EAAe,KAAO,GAAK,KAAW,EAAG,CAC9C,IAAM,EAAO,CAAC,GAAG,CAAc,EAAE,KAAK,CAAC,EAAG,IAAM,EAAE,GAAK,EAAE,EAAE,EAC3D,EAAe,MAAM,EACrB,QAAW,KAAU,EACnB,GAAI,EAAO,OACT,EAAO,IAAI,EAKjB,EAAiB,GACjB,GAAa,GAGb,IAAM,EAAM,GAAiB,OAAO,CAAC,EACrC,QAAW,KAAM,EACf,EAAG,EAeA,SAAS,EAAQ,CAAC,EAAgC,CACvD,OAAO,IAAI,QAAc,CAAC,IAAY,CACpC,IAAM,EAAW,IAAM,CACrB,IAAK,EACL,EAAQ,GAEV,GAAI,GAAkB,GAEpB,GAAiB,KAAK,CAAQ,EAG9B,oBAAe,CAAQ,EAE1B,EAOI,SAAS,EAAS,EAAS,CAChC,GAAI,EACF,EAAiB,GACjB,GAAM,EC7GV,IAAI,EAAsC,KACpC,GAAgC,CAAC,EACnC,GAAkB,EAiBf,MAAM,CAAqC,CAChD,GACA,OAAS,GAGD,GAGA,QAA4B,OAGpC,KAAiB,IAAI,IAErB,WAAW,CAAC,EAAc,CACxB,KAAK,GAAK,KACV,KAAK,GAAK,EAMZ,GAAG,EAAS,CACV,GAAI,CAAC,KAAK,OAAQ,OAGlB,GAAI,GAAY,SAAS,IAAI,EAAG,OAMhC,GAHA,KAAK,YAAY,EAGb,KAAK,QACP,KAAK,QAAQ,EACb,KAAK,QAAU,OAIjB,GAAY,KAAK,IAAI,EACrB,IAAM,EAAa,EACnB,EAAe,KAEf,GAAI,CACF,IAAM,EAAS,KAAK,GAAG,EACvB,GAAI,OAAO,IAAW,WACpB,KAAK,QAAU,SAEjB,CACA,EAAe,EACf,GAAY,IAAI,GAOZ,WAAW,EAAS,CAC1B,QAAW,KAAO,KAAK,KACrB,EAAI,YAAY,OAAO,IAAI,EAE7B,KAAK,KAAK,MAAM,EAMlB,MAAM,EAAS,CACb,GAAe,IAAI,EAMrB,OAAO,EAAS,CACd,GAAI,CAAC,KAAK,OAAQ,OAIlB,GAHA,KAAK,OAAS,GAGV,KAAK,QACP,KAAK,QAAQ,EACb,KAAK,QAAU,OAGjB,KAAK,YAAY,EACjB,GAAiB,IAAI,EAEzB,CAuBO,SAAS,CAAM,CAAC,EAAyB,CAC9C,IAAM,EAAI,IAAI,EAAe,CAAE,EAG/B,OADA,EAAE,IAAI,EACC,IAAM,EAAE,QAAQ,EASlB,SAAS,CAAK,CAAC,EAAgB,CACpC,GAAI,EACF,EAAI,YAAY,IAAI,CAAY,EAChC,EAAa,KAAK,IAAI,CAAG,EAQtB,SAAS,CAAO,CAAC,EAAgB,CAEtC,IAAM,EAAU,CAAC,GAAG,EAAI,WAAW,EACnC,QAAW,KAAU,EACnB,EAAO,OAAO,EC7IlB,IAAM,GAAe,OAAO,eAAe,EAI3C,MAAM,EAAwC,EAC3C,IAAgB,GAEjB,YAAc,IAAI,IACV,OACA,YAAc,IAAI,IAE1B,WAAW,CAAC,EAAY,CACtB,KAAK,OAAS,KAGZ,MAAK,EAAM,CAEb,OADA,EAAM,IAAI,EACH,KAAK,UAGV,MAAK,CAAC,EAAa,CACrB,GAAI,OAAO,GAAG,KAAK,OAAQ,CAAQ,EAAG,OACtC,KAAK,OAAS,EACd,EAAQ,IAAI,EAGZ,QAAW,KAAM,KAAK,YACpB,EAAG,CAAQ,EAIf,IAAI,EAAM,CACR,OAAO,KAAK,OAGd,SAAS,CAAC,EAAoC,CAE5C,OADA,KAAK,YAAY,IAAI,CAAE,EAChB,IAAM,CACX,KAAK,YAAY,OAAO,CAAE,GAO9B,QAAQ,EAAW,CACjB,OAAO,OAAO,KAAK,KAAK,EAM1B,OAAO,EAAM,CACX,OAAO,KAAK,MAEhB,CAiBO,SAAS,EAAS,CAAC,EAAuB,CAC/C,OAAO,IAAI,GAAW,CAAO,EAMxB,SAAS,CAAQ,CAAC,EAA0C,CACjE,OACE,GAAS,MAAQ,OAAO,IAAU,UAAY,MAAiB,EC/EnE,IAAM,GAAiB,OAAO,iBAAiB,EAI/C,MAAM,EAA4C,EAC/C,IAAkB,GAEnB,YAAc,IAAI,IAElB,OACA,OAAS,GACT,QAEA,WAAW,CAAC,EAAiB,CAC3B,IAAM,EAAO,KAIb,KAAK,QAAU,IAAI,EAAe,IAAM,CACtC,EAAK,OAAS,EAAO,EACtB,EAID,KAAK,QAAQ,OAAS,QAAS,EAAG,CAChC,GAAI,CAAC,EAAK,OACR,EAAK,OAAS,GACd,EAAQ,CAAI,GAKhB,KAAK,QAAQ,IAAI,EACjB,KAAK,OAAS,MAGZ,MAAK,EAAM,CAGb,GAFA,EAAM,IAAI,EAEN,KAAK,OACP,KAAK,QAAQ,IAAI,EACjB,KAAK,OAAS,GAGhB,OAAO,KAAK,OAGd,IAAI,EAAM,CACR,GAAI,KAAK,OACP,KAAK,QAAQ,IAAI,EACjB,KAAK,OAAS,GAEhB,OAAO,KAAK,OAMd,QAAQ,EAAW,CACjB,OAAO,OAAO,KAAK,KAAK,EAM1B,OAAO,EAAM,CACX,OAAO,KAAK,MAEhB,CAmBO,SAAS,EAAW,CAAC,EAA8B,CACxD,OAAO,IAAI,GAAa,CAAM,EAMzB,SAAS,CAAU,CAAC,EAA4C,CACrE,OACE,GAAS,MACT,OAAO,IAAU,UACjB,MAAmB,ECpHvB,IAAI,GAAa,EAiBV,SAAS,EAAK,CAAC,EAAsB,CAC1C,KACA,GAAI,CACF,EAAG,SACH,CAEA,GADA,KACI,KAAe,EAEjB,GAAU,GCtBT,SAAS,CAAU,CAAC,EAAiE,CAC1F,OACE,EAAS,CAAK,GACd,EAAW,CAAK,GAChB,OAAO,IAAU,WASd,SAAS,CAAU,CAAC,EAAmD,CAC5E,GAAI,EAAS,CAAK,GAAK,EAAW,CAAK,EACrC,OAAQ,EAAc,MAExB,GAAI,OAAO,IAAU,WACnB,OAAQ,EAAc,EAExB,OAAO,EChBF,SAAS,EAAW,CAAC,EAAsB,CAEhD,OAAO,EAAI,OAAS,GAAK,EAAI,WAAW,IAAI,EAOvC,SAAS,EAAW,CAAC,EAAqB,CAC/C,OAAO,EAAI,MAAM,CAAC,EAAE,YAAY,EAO3B,SAAS,EAAS,CACvB,EACA,EACA,EACW,CAEX,OADA,EAAO,iBAAiB,EAAI,EAAW,CAAO,EACvC,IAAM,CACX,EAAO,oBAAoB,EAAI,EAAW,CAAO,GAQ9C,SAAS,EAAU,CACxB,EACA,EACa,CACb,IAAM,EAAwB,CAAC,EAE/B,QAAW,KAAO,OAAO,KAAK,CAAK,EACjC,GAAI,GAAY,CAAG,EAAG,CACpB,IAAM,EAAU,EAAM,GACtB,GAAI,OAAO,IAAY,WAAY,CACjC,IAAM,EAAY,GAAY,CAAG,EACjC,EAAS,KAAK,GAAU,EAAI,EAAW,CAAwB,CAAC,GAKtE,OAAO,EC9CT,IAAI,GAAa,EAoDV,SAAS,EAAuB,CACrC,EACA,EACA,EACmB,CACnB,MAAO,CACL,IAAK,KACL,YACA,QACA,QAAS,KACT,SACA,SAAU,CAAC,EACX,QAAS,CAAC,EACV,cAAe,CAAC,EAChB,gBAAiB,CAAC,EAClB,cAAe,CAAC,EAChB,YAAa,CAAC,EAEd,SAAU,EAAS,OAAO,OAAO,EAAO,QAAQ,EAAI,OAAO,OAAO,IAAI,EACtE,UAAW,GACX,YAAa,EACf,EAKF,IAAI,GAA4C,KAMzC,SAAS,CAAkB,EAA6B,CAC7D,OAAO,GAOF,SAAS,CAAkB,CAChC,EAC0B,CAC1B,IAAM,EAAO,GAEb,OADA,GAAkB,EACX,EAOF,SAAS,EAAe,CAAC,EAA6B,EAAgB,CAC3E,IAAM,EAAO,EAAmB,CAAQ,EACxC,GAAI,CACF,OAAO,EAAG,SACV,CACA,EAAmB,CAAI,GASpB,SAAS,CAAgB,CAAC,EAAmC,CAClE,GAAI,EAAS,YACX,OAIF,QAAW,KAAS,EAAS,SAC3B,EAAiB,CAAK,EAGxB,GAAI,CAAC,EAAS,UAAW,CACvB,EAAS,UAAY,GACrB,QAAW,KAAQ,EAAS,cAC1B,EAAK,GASJ,SAAS,CAAkB,CAAC,EAAmC,CAEpE,IAAM,EAAW,CAAC,GAAG,EAAS,QAAQ,EACtC,QAAW,KAAS,EAClB,EAAmB,CAAK,EAG1B,GAAI,CAAC,EAAS,YAAa,CAIzB,GAHA,EAAS,YAAc,GAGnB,EAAS,UAAW,CACtB,EAAS,UAAY,GACrB,QAAW,KAAQ,EAAS,gBAC1B,EAAK,EAKT,QAAW,KAAW,EAAS,QAC7B,EAAQ,EAKV,GAHA,EAAS,QAAQ,OAAS,EAGtB,EAAS,OAAQ,CACnB,IAAM,EAAM,EAAS,OAAO,SAAS,QAAQ,CAAQ,EACrD,GAAI,IAAQ,GACV,EAAS,OAAO,SAAS,OAAO,EAAK,CAAC,IASvC,SAAS,EAAgB,CAAC,EAAmC,CAClE,QAAW,KAAQ,EAAS,cAC1B,EAAK,EAIT,IAAM,GAAqB,IAAI,IAMxB,SAAS,CAAiB,CAAC,EAA0C,CAC1E,GACE,CAAC,GACD,CAAC,EAAS,WACV,EAAS,aACT,EAAS,cAAc,SAAW,GAClC,GAAmB,IAAI,CAAQ,EAE/B,OAGF,GAAmB,IAAI,CAAQ,EAC/B,GAAS,IAAM,CAEb,GADA,GAAmB,OAAO,CAAQ,EAC9B,EAAS,WAAa,CAAC,EAAS,YAClC,GAAiB,CAAQ,EAE5B,EAMI,SAAS,EAAoB,CAClC,EACA,EACM,CACN,IAAI,EAAoC,EACxC,MAAO,EAAS,CACd,GAAI,EAAQ,YAAY,OAAS,EAAG,CAClC,QAAW,KAAQ,EAAQ,YACzB,EAAK,CAAG,EAEV,OAEF,EAAU,EAAQ,OAGpB,QAAQ,MAAM,sCAAuC,CAAG,EClO1D,IAAM,GAAa,IAAI,IAAI,CAAC,WAAY,MAAO,MAAO,yBAAyB,CAAC,EAGnE,GAAiB,IAAI,IAAI,CAAC,QAAS,UAAW,WAAY,WAAY,WAAY,WAAY,eAAe,CAAC,EAG9G,GAAuC,CAClD,UAAW,QACX,QAAS,MACT,SAAU,WACV,YAAa,aACf,EAWO,SAAS,EAAe,CAC7B,EACA,EACa,CACb,IAAM,EAAyB,CAAC,EAC1B,EAAQ,EAAmB,EAEjC,QAAY,EAAK,KAAU,OAAO,QAAQ,CAAK,EAAG,CAChD,GAAI,GAAW,IAAI,CAAG,GAAK,GAAY,CAAG,EAAG,SAE7C,IAAM,EAAW,GAAqB,CAAG,EACnC,EAAY,IAAa,SAAW,IAAa,QAEvD,GAAI,EAAW,CAAK,GAAM,GAAa,GAAiB,CAAK,EAAI,CAE/D,IAAM,EAA+B,CAAE,mBAAoB,IAAI,GAAM,EACjE,EAAc,GACZ,EAAU,EAAO,IAAM,CAE3B,GADA,GAAmB,EAAI,EAAK,EAAQ,CAAY,EAAG,CAAK,EACpD,EACF,EAAkB,CAAK,EAEzB,EAAc,GACf,EACD,EAAU,KAAK,CAAO,EAEtB,QAAmB,EAAI,EAAK,CAAK,EAIrC,OAAO,EAMF,SAAS,EAAkB,CAChC,EACA,EACA,EACA,EACM,CAEN,IAAM,EAAW,GAAqB,CAAG,EAGzC,GAAI,IAAa,SAAW,OAAO,IAAU,UAAY,IAAU,KAAM,CACvE,GACE,EACA,EACA,CACF,EACA,OAIF,GAAI,IAAa,SAAW,OAAO,IAAU,UAAY,IAAU,KAAM,CACvE,GAAW,EAAI,CAAK,EACpB,OAIF,GAAI,GAAS,MAAQ,IAAU,GAAO,CAEpC,GADA,EAAO,gBAAgB,EAAI,CAAQ,EAC/B,IAAa,SAAW,EAC1B,EAAM,mBAAmB,MAAM,EAGjC,GAAI,GAAe,IAAI,CAAQ,EAC7B,EAAO,YAAY,EAAI,EAAU,IAAa,QAAU,GAAK,EAAK,EAEpE,OAIF,GAAI,IAAU,GAAM,CAElB,GADA,EAAO,aAAa,EAAI,EAAU,EAAE,EAChC,IAAa,SAAW,EAC1B,EAAM,mBAAmB,MAAM,EAEjC,GAAI,GAAe,IAAI,CAAQ,EAC7B,EAAO,YAAY,EAAI,EAAU,EAAI,EAEvC,OAIF,GAAI,GAAe,IAAI,CAAQ,EAAG,CAChC,GAAI,IAAa,SAAW,EAC1B,EAAM,mBAAmB,MAAM,EAEjC,EAAO,YAAY,EAAI,EAAU,CAAK,EACtC,OAIF,GAAI,IAAa,SAAW,EAC1B,EAAM,mBAAmB,MAAM,EAEjC,EAAO,aAAa,EAAI,EAAU,OAAO,CAAK,CAAC,EAG1C,SAAS,EAAoB,CAAC,EAAqB,CACxD,OAAO,GAAa,IAAQ,EAS9B,SAAS,EAAU,CACjB,EACA,EACA,EACM,CACN,IAAM,EAAW,GAAe,CAAK,EAC/B,EAAY,IAAI,IAEtB,QAAY,EAAM,KAAQ,OAAO,QAAQ,CAAQ,EAAG,CAGlD,GAFA,EAAU,IAAI,CAAI,EAEd,GAAO,KAAM,CACf,GAAoB,EAAI,CAAI,EAC5B,SAGF,IAAM,EAAY,EAAK,WAAW,IAAI,EAAI,EAAO,GAAa,CAAI,EAClE,EAAG,MAAM,YAAY,EAAW,OAAO,CAAG,CAAC,EAG7C,GAAI,CAAC,EACH,OAGF,QAAW,KAAgB,EAAM,mBAC/B,GAAI,CAAC,EAAU,IAAI,CAAY,EAC7B,GAAoB,EAAI,CAAY,EAIxC,EAAM,mBAAqB,EAG7B,SAAS,EAAc,CACrB,EACoD,CACpD,IAAM,EAAW,EAAQ,CAAK,EAC9B,GAAI,CAAC,EAAU,MAAO,CAAC,EAEvB,GAAI,OAAO,IAAa,SACtB,OAAO,GAAiB,CAAQ,EAGlC,GAAI,MAAM,QAAQ,CAAQ,EACxB,OAAO,EAAS,OAAO,CAAC,EAAK,IAAS,CACpC,IAAM,EAAa,GAAe,CAAI,EACtC,OAAO,OAAO,OAAO,EAAK,CAAU,GACnC,CAAC,CAAwB,EAG9B,GAAI,OAAO,IAAa,SAAU,CAChC,IAAM,EAA8B,CAAC,EACrC,QAAY,EAAG,KAAM,OAAO,QAAQ,CAAQ,EAC1C,EAAO,GAAK,EAAQ,CAAC,EAEvB,OAAO,EAGT,MAAO,CAAC,EAGV,SAAS,EAAgB,CAAC,EAAuC,CAC/D,IAAM,EAAiC,CAAC,EAWxC,OAVA,EAAM,MAAM,GAAG,EAAE,QAAQ,CAAC,IAAS,CACjC,IAAM,EAAI,EAAK,QAAQ,GAAG,EAC1B,GAAI,EAAI,EAAG,CACT,IAAM,EAAO,EAAK,MAAM,EAAG,CAAC,EAAE,KAAK,EAC7B,EAAM,EAAK,MAAM,EAAI,CAAC,EAAE,KAAK,EACnC,GAAI,GAAQ,EACV,EAAO,GAAQ,GAGpB,EACM,EAGT,SAAS,EAAmB,CAAC,EAAiB,EAAoB,CAChE,IAAM,EAAY,EAAK,WAAW,IAAI,EAAI,EAAO,GAAa,CAAI,EAClE,EAAG,MAAM,eAAe,CAAS,EAOnC,SAAS,EAAU,CAAC,EAAa,EAAsB,CACrD,EAAO,aAAa,EAAI,QAAS,GAAe,CAAK,CAAC,EAGxD,SAAS,EAAc,CAAC,EAAwB,CAC9C,IAAM,EAAW,EAAQ,CAAK,EAC9B,GAAI,CAAC,EAAU,MAAO,GACtB,GAAI,OAAO,IAAa,SAAU,OAAO,EAEzC,GAAI,MAAM,QAAQ,CAAQ,EAExB,OAAO,EACJ,IAAI,EAAc,EAClB,OAAO,OAAO,EACd,KAAK,GAAG,EAGb,GAAI,OAAO,IAAa,SAEtB,OAAO,OAAO,QAAQ,CAAQ,EAC3B,OAAO,GAAI,KAAO,QAAQ,EAAQ,CAAC,CAAC,CAAC,EACrC,IAAI,EAAE,KAAO,CAAC,EACd,KAAK,GAAG,EAGb,OAAO,OAAO,CAAQ,EAMxB,SAAS,EAAgB,CAAC,EAAyB,CACjD,GAAI,EAAW,CAAK,EAAG,MAAO,GAC9B,GAAI,MAAM,QAAQ,CAAK,EAAG,OAAO,EAAM,KAAK,EAAgB,EAC5D,GAAI,OAAO,IAAU,UAAY,IAAU,KAGzC,OAAO,OAAO,OAAO,CAAK,EAAE,KAAK,EAAgB,EAEnD,MAAO,GAMT,SAAS,EAAY,CAAC,EAAqB,CACzC,OAAO,EAAI,QAAQ,SAAU,CAAC,IAAM,IAAI,EAAE,YAAY,GAAG,ECzRpD,IAAM,GAAY,OAAO,IAAI,aAAa,EACpC,GAAW,OAAO,IAAI,YAAY,EAClC,GAAc,OAAO,IAAI,eAAe,EACxC,GAAa,OAAO,IAAI,cAAc,EACtC,GAAa,OAAO,IAAI,cAAc,EACtC,GAAW,OAAO,IAAI,YAAY,EAClC,GAAe,OAAO,IAAI,gBAAgB,EAC1C,GAAc,OAAO,IAAI,eAAe,EA4D9C,SAAS,EAAO,CAAC,EAAoC,CAC1D,MAAO,CACL,IAAK,GACL,MAAO,EACP,SAAU,CAAC,CACb,EAGK,SAAS,EAAM,CAAC,EAAmC,CACxD,MAAO,CACL,IAAK,GACL,MAAO,EACP,SAAU,CAAC,CACb,EAGK,SAAS,EAAM,CAAC,EAAmC,CACxD,MAAO,CACL,IAAK,GACL,MAAO,EACP,SAAU,CAAC,CACb,EAGK,SAAS,EAAQ,CAAC,EAAqC,CAC5D,MAAO,CACL,IAAK,GACL,MAAO,EACP,SAAU,CAAC,CACb,EAGK,SAAS,EAAQ,CAAC,EAAqC,CAC5D,MAAO,CACL,IAAK,GACL,MAAO,EACP,SAAU,CAAC,CACb,EAGK,SAAS,EAAM,CAAC,EAAmC,CACxD,MAAO,CACL,IAAK,GACL,MAAO,EACP,SAAU,CAAC,CACb,EAGK,SAAS,EAAmD,CACjE,EACe,CACf,MAAO,CACL,IAAK,GACL,MAAO,EACP,SAAU,CAAC,CACb,EAGK,SAAS,EAAO,CAAC,EAAoC,CAC1D,IACE,OACA,KAAK,OACL,QACA,cACG,GACD,EAEE,EAAe,GAAS,IAAM,CAClC,IAAM,EAAO,EAAa,CAAK,EACzB,EAAU,QAAQ,EAAa,CAAI,CAAC,EAE1C,GAAI,OAAO,IAAS,SAClB,OAAO,EAAU,EAAO,GAAoB,CAAI,EAGlD,IAAM,EACJ,GAAQ,OAAO,IAAS,SACpB,IAAM,CAA4D,EAClE,CAAC,EAGP,OADA,EAAY,QAAU,EAAU,EAAY,QAAU,OAC/C,EACR,EAED,MAAO,CACL,IAAK,EACL,MAAO,IACF,EACH,MAAO,EACP,UACF,EACA,SAAU,GAAkB,CAAQ,CACtC,EAGK,SAAS,EAAM,CAAC,EAAmC,CACxD,MAAO,CACL,IAAK,GACL,MAAO,EACP,SAAU,CAAC,CACb,EAGK,SAAS,EAAa,CAAC,EAAwC,CACpE,OAAO,GAAS,MAAQ,OAAO,IAAU,UAAY,QAAS,EAGzD,SAAS,CAAa,CAAC,EAAiC,CAC7D,OAAO,EAAQ,MAAQ,GAGlB,SAAS,CAAY,CAAC,EAAiC,CAC5D,OAAO,EAAQ,MAAQ,GAGlB,SAAS,EAAe,CAAC,EAAiC,CAC/D,OAAO,EAAQ,MAAQ,GAGlB,SAAS,EAAc,CAAC,EAAiC,CAC9D,OAAO,EAAQ,MAAQ,GAGlB,SAAS,CAAc,CAAC,EAAiC,CAC9D,OAAO,EAAQ,MAAQ,GAGlB,SAAS,CAAY,CAAC,EAAiC,CAC5D,OAAO,EAAQ,MAAQ,GAGlB,SAAS,EAAgB,CAAC,EAAiC,CAChE,OAAO,EAAQ,MAAQ,GAGlB,SAAS,EAAe,CAAC,EAAiC,CAC/D,OAAO,EAAQ,MAAQ,GAGlB,SAAS,EAAoB,CAAC,EAAoC,CACvE,IAAM,EAAQ,EAAQ,MAChB,EAAW,EAAiB,EAAM,UAAY,EAAQ,QAAQ,EAE9D,EAAQ,EAAgB,CAAQ,EACtC,OAAO,IAAU,OAAY,EAAQ,EAAM,SAG7C,SAAS,CAAe,CAAC,EAA6C,CACpE,QAAW,KAAQ,EAAO,CACxB,GAAI,GAAQ,MAAQ,OAAO,IAAS,UAAW,SAE/C,GAAI,MAAM,QAAQ,CAAI,EAAG,CACvB,IAAM,EAAQ,EAAgB,CAAI,EAClC,GAAI,IAAU,OAAW,OAAO,EAChC,SAGF,GAAI,GAAc,CAAI,EAAG,CACvB,IAAI,EAAU,EAGd,GAAI,OAAO,EAAQ,MAAQ,WAAY,CACrC,IAAM,EAAM,EAAQ,IACpB,GACE,IAAQ,IACR,IAAQ,IACR,IAAQ,IACR,IAAQ,IACR,IAAQ,IACR,IAAQ,GAER,EAAW,EAAiB,EAAQ,KAAK,EAI7C,GAAI,GAAe,CAAO,EAAG,CAC3B,IAAM,EAAO,EAAc,EAAQ,MAAc,IAAI,EACrD,GAAI,EACF,OAAO,GAAqB,EAAS,CAAI,EAEtC,QAAI,EAAc,CAAO,EAAG,CACjC,IAAM,EAAO,EAAc,EAAQ,MAAc,IAAI,EACrD,GAAI,EAAM,CACR,IAAM,EAAU,GAAoB,EAAS,CAAI,EAC3C,EAAQ,EAAgB,EAAiB,CAAO,CAAC,EACvD,GAAI,IAAU,OAAW,OAAO,EAC3B,QAAK,EAAQ,MAAc,SAAU,CAC1C,IAAM,EAAQ,EACZ,EAAkB,EAAQ,MAAc,QAAQ,CAClD,EACA,GAAI,IAAU,OAAW,OAAO,GAE7B,QAAI,EAAa,CAAO,EAAG,CAChC,IAAM,EAAQ,EAAQ,MAChB,EAAQ,EAAa,EAAM,IAAI,EACrC,GAAI,MAAM,QAAQ,CAAK,EACrB,QAAS,EAAI,EAAG,EAAI,EAAM,OAAQ,IAAK,CACrC,IAAM,EAAQ,EAAM,SAAS,EAAM,GAAI,IAAM,CAAC,EACxC,EAAQ,EAAgB,EAAiB,CAAK,CAAC,EACrD,GAAI,IAAU,OAAW,OAAO,GAG/B,QAAI,EAAe,CAAO,EAAG,CAClC,IAAM,EAAQ,EAAQ,MAChB,EAAQ,EAAa,EAAM,IAAI,EACrC,GAAI,MAAM,QAAQ,CAAK,EACrB,QAAS,EAAI,EAAG,EAAI,EAAM,OAAQ,IAAK,CACrC,IAAM,EAAQ,EAAM,SAAS,IAAM,EAAM,GAAI,CAAC,EACxC,EAAQ,EAAgB,EAAiB,CAAK,CAAC,EACrD,GAAI,IAAU,OAAW,OAAO,GAG/B,QAAI,EAAa,CAAO,EAAG,CAChC,IAAM,EAAM,EAAc,EAAQ,MAAc,IAAI,EAC9C,EAAQ,GAAmB,EAAS,CAAG,EACvC,EAAQ,EAAgB,EAAiB,CAAK,CAAC,EACrD,GAAI,IAAU,OAAW,OAAO,IAItC,OAGK,SAAS,EAAoB,CAClC,EACA,EACY,CACZ,IAAM,EAAY,EAAQ,MAAc,UAAY,EAAQ,SAC5D,GAAI,OAAO,IAAa,WACtB,OAAO,EAAS,CAAK,EAEvB,OAAO,EAGF,SAAS,EAAmB,CACjC,EACA,EACY,CACZ,IAAM,EAAY,EAAQ,MAAc,UAAY,EAAQ,SAC5D,GAAI,OAAO,IAAa,WACtB,OAAO,EAAS,CAAK,EAEvB,OAAO,EAGF,SAAS,EAAkB,CAChC,EACA,EACY,CACZ,IAAM,EAAY,EAAQ,MAAc,UAAY,EAAQ,SAC5D,GAAI,OAAO,IAAa,WACtB,OAAO,EAAS,CAAK,EAEvB,OAAO,EAGT,SAAS,CAAgB,CAAC,EAAgC,CACxD,GAAI,GAAW,MAAQ,OAAO,IAAY,UACxC,MAAO,CAAC,EAEV,OAAO,MAAM,QAAQ,CAAO,EAAI,EAAU,CAAC,CAAqB,EAGlE,SAAS,EAAiB,CAAC,EAAgD,CACzE,GAAI,GAAY,MAAQ,OAAO,IAAa,UAC1C,MAAO,CAAC,EAEV,OAAO,MAAM,QAAQ,CAAQ,EAAI,EAAW,CAAC,CAAQ,EAGvD,SAAS,CAAY,CAAC,EAAyB,CAC7C,OAAO,EAAQ,CAAY,EAG7B,SAAS,EAAmB,CAAC,EAAuB,CAClD,IAAM,EAAU,EAAM,KAAK,EACrB,EAAY,EAAQ,OAAS,GAAK,CAAC,EAAQ,SAAS,GAAG,EAAI,IAAM,GACvE,MAAO,GAAG,IAAU,gBC5Uf,SAAS,CAAkB,CAAC,EAA2B,CAC5D,OAAQ,EAAK,UACN,WACA,gBACH,MAAO,CAAC,EAAK,IAAI,MAEd,UACH,MAAO,CAAC,EAAK,IAAI,MAEd,WACH,MAAO,CACL,EAAK,OACL,GAAG,EAAK,SAAS,QAAQ,CAAC,IAAU,EAAmB,CAAK,CAAC,CAC/D,MAEG,iBACH,MAAO,CACL,EAAK,YACL,GAAG,EAAK,SAAS,QAAQ,CAAC,IAAU,EAAmB,CAAK,CAAC,EAC7D,EAAK,SACP,MAEG,YACH,OAAO,EAAK,SAAS,QAAQ,CAAC,IAAU,EAAmB,CAAK,CAAC,MAE9D,SACH,MAAO,CAAC,EAAK,MAAM,GAOlB,SAAS,CAAW,CAAC,EAAyB,CACnD,OAAQ,EAAK,UACN,OACH,UAEG,gBACH,EAAK,QAAQ,EACb,UAEG,UACH,QAAW,KAAW,EAAK,cACzB,EAAQ,EAEV,QAAW,KAAW,EAAK,cACzB,EAAQ,EAEV,EAAK,aAAa,EAClB,QAAW,KAAS,EAAK,SACvB,EAAY,CAAK,EAEnB,UAEG,WACH,QAAW,KAAS,EAAK,SACvB,EAAY,CAAK,EAEnB,UAEG,iBACH,EAAK,QAAQ,EACb,QAAW,KAAS,EAAK,SACvB,EAAY,CAAK,EAEnB,UAEG,YACH,GAAI,EAAK,SACP,EAAmB,EAAK,QAAQ,EAEhC,aAAW,KAAW,EAAK,UACzB,EAAQ,EAGZ,QAAW,KAAS,EAAK,SACvB,EAAY,CAAK,EAEnB,UAEG,SACH,EAAK,QAAQ,EACb,QAAW,KAAS,EAAK,SACvB,EAAkB,CAAK,EAEzB,EAAK,SAAW,CAAC,EACjB,OAOC,SAAS,CAAiB,CAAC,EAAyB,CACzD,IAAM,EAAW,EAAmB,CAAI,EACxC,EAAY,CAAI,EAChB,QAAW,KAAW,EACpB,GAAI,EAAQ,WACV,EAAO,OAAO,CAAO,EC9DpB,SAAS,EAAsB,CACpC,EACA,EACA,EACA,EACa,CACb,GAAI,GAAgB,CAAO,EACzB,OAAO,GAAa,EAAS,EAAQ,EAAQ,CAAS,EAGxD,IAAM,EAAc,EAAO,cAAc,UAAU,EAC7C,EAAY,EAAO,cAAc,WAAW,EAClD,GAAW,EAAQ,EAAa,CAAM,EACtC,GAAW,EAAQ,EAAW,CAAM,EAEpC,IAAM,EAAQ,EAAmB,EAC7B,EAAgB,IAAM,GAEpB,EAA8B,CAClC,KAAM,iBACN,QAAS,IAAM,EAAc,EAC7B,SAAU,CAAC,EACX,cACA,WACF,EAEA,GAAI,EAAc,CAAO,EACvB,EAAgB,GAAgB,EAAS,EAAO,EAAQ,EAAW,CAAK,EACnE,QAAI,EAAa,CAAO,EAC7B,EAAgB,GAAe,EAAS,EAAO,EAAQ,EAAW,CAAK,EAClE,QAAI,GAAgB,CAAO,EAChC,EAAgB,GAAkB,EAAS,EAAO,EAAQ,EAAW,CAAK,EACrE,QAAI,EAAe,CAAO,EAC/B,EAAgB,GAAiB,EAAS,EAAO,EAAQ,EAAW,CAAK,EACpE,QAAI,EAAa,CAAO,EAC7B,EAAgB,GAAe,EAAS,EAAO,EAAQ,EAAW,CAAK,EAClE,QAAI,GAAiB,CAAO,EACjC,EAAgB,GAAmB,EAAS,EAAO,EAAQ,EAAW,CAAK,EAG7E,OAAO,EAGT,SAAS,EAAe,CACtB,EACA,EACA,EACA,EACA,EACY,CACZ,IAAI,EAAc,GAElB,OAAO,EAAO,IAAM,CAClB,EAAc,CAAK,EACnB,IAAM,EAAO,EAAc,EAAQ,MAAc,IAAI,EAYrD,GAXA,EAAM,SAAW,EAAqB,EAAO,IAAM,CACjD,IAAM,EAAU,EAAO,GAAoB,EAAS,CAAI,EAAK,EAAQ,MAAc,SACnF,OAAO,EACL,EACA,EACA,EAAM,UACN,EACA,CACF,EACD,EAEG,EACF,EAA2B,CAAK,EAElC,EAAc,GACf,EAGH,SAAS,EAAiB,CACxB,EACA,EACA,EACA,EACA,EACY,CACZ,IAAI,EAAc,GACd,EAA0B,CAAC,EAE/B,OAAO,EAAO,IAAM,CAClB,IAAM,EAAQ,EAAQ,MAMhB,EAAQ,EAAa,EAAM,IAAI,EAC/B,EAAO,MAAM,QAAQ,CAAK,EAAI,EAAQ,CAAC,EACvC,EAAc,EAAM,SAE1B,GAAI,OAAO,IAAgB,WAAY,CAGrC,GAFA,EAAc,CAAK,EACnB,EAAU,CAAC,EACP,EACF,EAAkB,CAAK,EAEzB,EAAc,GACd,OAGF,GAAI,EAAK,SAAW,EAAG,CAUrB,GATA,EAAc,CAAK,EACnB,EAAU,CAAC,EACX,EAAM,SAAW,EACf,EAAM,SACN,EACA,EAAM,UACN,EACA,CACF,EACI,EACF,EAA2B,CAAK,EAElC,EAAc,GACd,OAGF,GAAI,EAAQ,SAAW,GAAK,EAAM,SAAS,OAAS,EAClD,EAAc,CAAK,EAGrB,IAAM,EAAW,IAAI,IACrB,QAAW,KAAU,EACnB,EAAS,IAAI,EAAO,IAAK,CAAM,EAGjC,IAAM,EAA8B,CAAC,EAErC,EAAK,QAAQ,CAAC,EAAM,IAAU,CAC5B,IAAM,EAAM,EAAM,IAAM,EAAM,IAAI,EAAM,CAAK,EAAI,EAC3C,EAAM,EAAS,IAAI,CAAG,EAE5B,GAAI,GAAO,EAAI,OAAS,EAAM,CAC5B,EAAI,MAAQ,EACZ,GAAc,EAAQ,EAAI,QAAS,EAAM,SAAS,EAClD,EAAY,KAAK,CAAG,EACpB,EAAS,OAAO,CAAG,EACnB,OAGF,GAAI,EACF,EAAkB,EAAI,OAAO,EAC7B,EAAS,OAAO,CAAG,EAGrB,IAAM,GAAuB,CAC3B,MACA,OACA,QACA,QAAS,CAAE,KAAM,OAAQ,KAAM,EAAO,eAAe,EAAE,CAAE,CAC3D,EAEA,GAAO,QAAU,EAAqB,EAAO,IAC3C,EACE,EAAY,EAAM,IAAM,GAAO,KAAK,EACpC,EACA,EAAM,UACN,CACF,CACF,EACA,EAAY,KAAK,EAAM,EACxB,EAED,QAAW,KAAU,EAAS,OAAO,EACnC,EAAkB,EAAO,OAAO,EAMlC,GAHA,EAAU,EACV,EAAM,SAAW,EAAY,IAAI,CAAC,IAAW,EAAO,OAAO,EAEvD,EACF,EAA2B,CAAK,EAElC,EAAc,GACf,EAGH,SAAS,EAAiB,CACxB,EACA,EACA,EACA,EACA,EACY,CACZ,IAAI,EAAc,GAElB,OAAO,EAAO,IAAM,CAClB,EAAc,CAAK,EAEnB,IAAM,EAAU,EAAqB,EAAO,IAAM,GAAqB,CAAO,CAAC,EAS/E,GARA,EAAM,SAAW,EACf,EACA,EACA,EAAM,UACN,EACA,CACF,EAEI,EACF,EAA2B,CAAK,EAElC,EAAc,GACf,EAGH,SAAS,EAAmB,CAC1B,EACA,EACA,EACA,EACA,EACY,CACZ,IAAI,EAAc,GACd,EAA4B,CAAC,EAEjC,OAAO,EAAO,IAAM,CAClB,IAAM,EAAQ,EAAQ,MAKhB,EAAQ,EAAa,EAAM,IAAI,EAC/B,EAAO,MAAM,QAAQ,CAAK,EAAI,EAAQ,CAAC,EACvC,EAAc,EAAM,SAE1B,GAAI,OAAO,IAAgB,WAAY,CAGrC,GAFA,EAAc,CAAK,EACnB,EAAU,CAAC,EACP,EACF,EAAkB,CAAK,EAEzB,EAAc,GACd,OAGF,GAAI,EAAK,SAAW,EAAG,CAUrB,GATA,EAAc,CAAK,EACnB,EAAU,CAAC,EACX,EAAM,SAAW,EACf,EAAM,SACN,EACA,EAAM,UACN,EACA,CACF,EACI,EACF,EAA2B,CAAK,EAElC,EAAc,GACd,OAGF,GAAI,EAAQ,SAAW,GAAK,EAAM,SAAS,OAAS,EAClD,EAAc,CAAK,EAGrB,QAAS,EAAQ,EAAG,EAAQ,EAAK,OAAQ,IAAS,CAChD,IAAM,EAAW,EAAQ,GACzB,GAAI,EAAU,CACZ,EAAS,KAAK,MAAQ,EAAK,GAC3B,SAGF,IAAM,EAAa,GAAO,EAAK,EAAO,EAChC,EAAyB,CAC7B,KAAM,EACN,QAAS,EAAqB,EAAO,IACnC,EACE,EAAY,IAAM,EAAW,MAAO,CAAK,EACzC,EACA,EAAM,UACN,CACF,CACF,CACF,EACA,EAAQ,KAAK,CAAM,EAGrB,MAAO,EAAQ,OAAS,EAAK,OAAQ,CACnC,IAAM,EAAU,EAAQ,IAAI,EAC5B,EAAkB,EAAQ,OAAO,EAKnC,GAFA,EAAM,SAAW,EAAQ,IAAI,CAAC,IAAW,EAAO,OAAO,EAEnD,EACF,EAA2B,CAAK,EAElC,EAAc,GACf,EAGH,SAAS,EAAc,CACrB,EACA,EACA,EACA,EACA,EACY,CACZ,IAAI,EAAc,GACd,EAAS,GACT,EAEJ,OAAO,EAAO,IAAM,CAClB,IAAM,EAAM,EAAc,EAAQ,MAAc,IAAI,EACpD,GAAI,GAAU,OAAO,GAAG,EAAY,CAAG,EACrC,OAGF,EAAa,EACb,EAAS,GACT,EAAc,CAAK,EAEnB,IAAM,EAAU,EAAqB,EAAO,IAC1C,GAAmB,EAAS,CAAG,CACjC,EASA,GARA,EAAM,SAAW,EACf,EACA,EACA,EAAM,UACN,EACA,CACF,EAEI,EACF,EAA2B,CAAK,EAElC,EAAc,GACf,EAGH,SAAS,EAAkB,CACzB,EACA,EACA,EACA,EACA,EACY,CACZ,IAAI,EAAc,GACd,EAAS,GACT,EAEJ,OAAO,EAAO,IAAM,CAClB,IAAM,EAAM,EAAc,EAAQ,MAAc,SAAS,EACzD,GAAI,GAAU,OAAO,GAAG,EAAY,CAAG,EACrC,OAGF,EAAa,EACb,EAAS,GACT,EAAc,CAAK,EAEnB,IAAM,EAAU,EAAM,GAAqB,EAAS,CAAG,EAAI,KAS3D,GARA,EAAM,SAAW,EACf,EACA,EACA,EAAM,UACN,EACA,CACF,EAEI,EACF,EAA2B,CAAK,EAElC,EAAc,GACf,EAGH,SAAS,EAAY,CACnB,EACA,EACA,EACA,EACe,CACf,IAAM,EAAc,EAAO,cAAc,UAAU,EACnD,GAAW,EAAQ,EAAa,CAAM,EAEtC,IAAM,EAAQ,EAAmB,EAC7B,EAAgB,IAAM,GAEpB,EAAe,EAAO,cAAc,WAAW,EACjD,EAA0B,KAExB,EAAwB,CAC5B,KAAM,SACN,OAAQ,EACR,SAAU,CAAC,EACX,QAAS,IAAM,EAAc,EAC7B,cACF,EACI,EAAc,GAkClB,OAhCA,EAAgB,EAAO,IAAM,CAC3B,IAAM,EAAS,GAAqB,EAAQ,MAAc,KAAK,EAE/D,GAAI,IAAW,EAAY,CACzB,GAAI,EACF,EAAO,OAAO,CAAY,EAE5B,GAAI,EACF,EAAO,YAAY,EAAQ,CAAY,EAEzC,EAAa,EACb,EAAO,OAAS,EAKlB,GAFA,GAAoB,CAAM,EAEtB,EACF,EAAO,SAAW,EACf,EAAQ,MAAc,UAAY,EAAQ,SAC3C,EACA,EACA,EACA,CACF,EAGF,GAAI,EACF,EAA2B,CAAK,EAElC,EAAc,GACf,EAEM,EAGT,SAAS,EAAoB,CAAC,EAAwB,EAAoC,CACxF,GAAI,OAAO,IAAQ,UAAY,OAAO,IAAQ,WAC5C,OAAO,KAGT,IAAQ,eAAc,GAAU,EAAQ,MAClC,EAAW,GAAiB,EAAM,UAAY,EAAQ,QAAQ,EAEpE,MAAO,CACL,IAAK,EACL,QACA,UACF,EAGF,SAAS,CAAkB,CACzB,EACA,EACA,EACA,EACA,EACe,CACf,GAAI,GAAW,MAAQ,OAAO,IAAY,UAAW,MAAO,CAAC,EAE7D,OAAO,EAAqB,EAAO,IAAM,CACvC,GAAI,MAAM,QAAQ,CAAO,EACvB,OAAO,EAAQ,IAAI,CAAC,IAClB,EAAgB,EAAO,EAAQ,EAAQ,CAAS,CAClD,EAGF,MAAO,CAAC,EAAgB,EAAS,EAAQ,EAAQ,CAAS,CAAC,EAC5D,EAGH,SAAS,CAAa,CAAC,EAAmC,CACxD,QAAW,KAAS,EAAM,SACxB,EAAkB,CAAK,EAEzB,EAAM,SAAW,CAAC,EAGpB,SAAS,EAAmB,CAAC,EAA6B,CACxD,QAAW,KAAS,EAAO,SACzB,EAAkB,CAAK,EAEzB,EAAO,SAAW,CAAC,EAGrB,SAAS,EAAa,CAAC,EAAc,EAAsB,EAAuB,CAChF,QAAW,KAAQ,EAAmB,CAAO,EAC3C,EAAO,aAAa,EAAQ,EAAM,CAAS,EAE7C,GAAgB,CAAO,EAGzB,SAAS,EAAe,CAAC,EAA4B,CACnD,GAAI,EAAQ,OAAS,UACnB,GAAI,EAAQ,QAAU,EAAQ,aAAc,CAC1C,QAAW,KAAS,EAAQ,SAC1B,QAAW,KAAQ,EAAmB,CAAK,EACzC,EAAO,YAAY,EAAQ,OAAQ,CAAI,EAG3C,EAAO,YAAY,EAAQ,OAAQ,EAAQ,YAAY,GAEpD,QAAI,aAAc,GAAW,MAAM,QAAS,EAAgB,QAAQ,EACzE,QAAW,KAAU,EAAgB,SACnC,GAAgB,CAAK,EAK3B,SAAS,CAA0B,CAAC,EAAuC,CACzE,GAAI,EACF,EAAiB,CAAK,EAExB,EAAkB,CAAK,EAGzB,SAAS,CAAuB,CAC9B,EACA,EACG,CACH,OAAO,EAAQ,GAAa,EAAO,CAAE,EAAI,EAAG,EAG9C,SAAS,CAAY,CAAC,EAAyB,CAC7C,OAAO,EAAQ,CAAY,EAG7B,SAAS,EAAgB,CAAC,EAAgC,CACxD,GAAI,GAAW,MAAQ,OAAO,IAAY,UACxC,MAAO,CAAC,EAEV,OAAO,MAAM,QAAQ,CAAO,EAAI,EAAU,CAAC,CAAqB,EAGlE,SAAS,EAAmB,CAAC,EAA6B,CACxD,IAAM,EAAS,EAAa,CAAK,EAEjC,GAAI,GAAU,KACZ,OAAO,OAAO,SAAa,IAAc,KAAO,SAAS,KAG3D,GAAI,OAAO,IAAW,SACpB,OAAO,SAAS,cAAc,CAAM,EAGtC,GAAI,OAAO,IAAW,WACpB,OAAO,EAAO,EAGhB,GAAI,OAAO,IAAW,UAAY,aAAc,EAC9C,OAAO,EAGT,OAAO,KAGT,SAAS,EAAU,CAAC,EAAc,EAAa,EAA2B,CACxE,GAAI,EACF,EAAO,aAAa,EAAQ,EAAO,CAAM,EAEzC,OAAO,YAAY,EAAQ,CAAK,ECpjBpC,IAAM,GAAgB,IAAI,IAAI,CAC5B,OACA,OACA,KACA,MACA,QACA,KACA,MACA,QACA,OACA,OACA,QACA,SACA,QACA,KACF,CAAC,EAEK,GAAS,6BACT,GAAU,qCAKT,SAAS,CAAkB,CAChC,EACA,EACA,EAAsB,KACtB,EAA2B,KACd,CACb,IAAQ,MAAK,QAAO,YAAa,EAGjC,GAAI,IAAQ,IAAO,IAAgB,GACjC,OAAO,GAAoB,EAAU,EAAQ,EAAQ,CAAS,EAKhE,GACE,IAAQ,IACR,IAAQ,IACR,IAAQ,IACR,IAAQ,IACR,IAAQ,IACR,IAAQ,IACR,IAAQ,GAER,OAAO,EACJ,EAAiB,CAAK,EACvB,EACA,EACA,CACF,EAGF,GAAI,IAAQ,GACV,OAAO,EACJ,EAAiB,CAAK,EACvB,EACA,EACA,CACF,EAGF,GACE,EAAc,CAAO,GACrB,EAAa,CAAO,GACpB,GAAgB,CAAO,GACvB,EAAe,CAAO,GACtB,EAAa,CAAO,GACpB,GAAiB,CAAO,GACxB,GAAgB,CAAO,EAEvB,OAAO,GAAuB,EAAS,EAAQ,EAAQ,CAAS,EAIlE,GAAI,OAAO,IAAQ,WACjB,OAAO,GAAqB,EAAK,EAAO,EAAQ,EAAQ,CAAS,EAInE,GAAI,OAAO,IAAQ,SACjB,OAAO,GACL,EACA,EACA,EACA,EACA,EACA,CACF,EAIF,OAAO,GAAoB,EAAU,EAAQ,EAAQ,CAAS,EAMhE,SAAS,EAAoB,CAC3B,EACA,EACA,EACA,EACA,EACA,EACgB,CAChB,IAAM,EAAY,GAAoB,EAAK,CAAe,EACpD,EAAK,EACP,EAAO,gBAAgB,EAAW,CAAG,EACrC,EAAO,cAAc,CAAG,EAGtB,EAAgB,GAAgB,EAAI,CAAK,EAGzC,EAAgB,GAAW,EAAI,CAAK,EAGtC,EAAiC,CAAC,EACtC,GAAI,CAAC,GAAc,IAAI,CAAG,EAAG,CAE3B,IAAM,EAAY,EAAM,wBAGxB,GAAI,GAAa,OAAO,EAAU,SAAW,SAC1C,EAAmB,UAAY,EAAU,OAE1C,OAAkB,GAChB,EACA,EACA,GAAkB,EAAK,CAAS,CAClC,EAKJ,GAAI,EACF,EAAO,aAAa,EAAQ,EAAI,CAAM,EAEtC,OAAO,YAAY,EAAQ,CAAE,EAG/B,IAAM,EAAa,GAAS,EAAI,EAAM,GAAG,EAEzC,MAAO,CACL,KAAM,UACN,KAAM,EACN,SAAU,EACV,gBACA,gBACA,YACF,EAUF,SAAS,EAAoB,CAC3B,EACA,EACA,EACA,EACA,EACkB,CAElB,IAAM,EAAiB,EAAmB,EACpC,EAAW,GACf,EACA,EACA,CACF,EAGA,GAAI,EACF,EAAe,SAAS,KAAK,CAAQ,EAKvC,IAAM,EAAe,EAAmB,CAAQ,EAE5C,EACA,EAEJ,GAAI,CAIF,GAHA,EAAS,EAAU,CAAK,EAGpB,GAAU,OAAO,IAAW,UAAY,QAAS,EACnD,EAAQ,EACN,EACA,EACA,EACA,CACF,EAEA,OAAQ,EAAgB,EAAsB,EAAQ,EAAQ,CAAS,EAEzE,MAAO,EAAK,CAEZ,EAAmB,CAAY,EAC/B,GAAqB,EAAU,CAAY,EAE3C,IAAM,EAAO,EAAO,eAAe,EAAE,EACrC,GAAI,EACF,EAAO,aAAa,EAAQ,EAAM,CAAM,EAExC,OAAO,YAAY,EAAQ,CAAI,EAEjC,MAAO,CACL,KAAM,YACN,SAAU,CAAC,CAAE,KAAM,OAAQ,KAAM,CAAK,CAAC,EACvC,UAAW,CAAC,EACZ,UACF,EAQF,OAJA,EAAmB,CAAY,EAE/B,EAAS,QAAU,EAEZ,CACL,KAAM,YACN,SAAU,CAAC,CAAK,EAChB,UAAW,EAAS,QACpB,UACF,EAMF,SAAS,EAAmB,CAC1B,EACA,EACA,EACA,EACa,CACb,IAAM,EAAgB,EAAO,cAAc,UAAU,EACrD,GAAI,EACF,EAAO,aAAa,EAAQ,EAAe,CAAM,EAEjD,OAAO,YAAY,EAAQ,CAAa,EAG1C,IAAM,EAAyB,CAAC,EAChC,QAAW,KAAS,EAClB,EAAQ,KAAK,EAAgB,EAAO,EAAQ,EAAQ,CAAS,CAAC,EAGhE,MAAO,CAAE,KAAM,WAAY,SAAU,EAAS,OAAQ,CAAc,EAGtE,SAAS,EAAmB,CAC1B,EACA,EACe,CACf,GAAI,IAAQ,MAAO,OAAO,GAC1B,GAAI,IAAQ,OAAQ,OAAO,GAC3B,OAAO,EAGT,SAAS,EAAiB,CACxB,EACA,EACe,CACf,GAAI,IAAc,IAAU,IAAQ,gBAClC,OAAO,KAET,OAAO,EAST,SAAS,EAAQ,CAAC,EAAa,EAAgC,CAC7D,IAAM,EAAQ,EACd,GAAI,CAAC,EACH,OAAO,KAGT,GAAI,OAAO,IAAU,WAEnB,OADA,EAAM,CAAE,EACD,IAAM,EAAM,IAAI,EAGzB,GAAI,OAAO,IAAU,UAAY,YAAa,EAE5C,OADA,EAAM,QAAU,EACT,IAAM,CACX,EAAM,QAAU,MAIpB,OAAO,KCjUF,SAAS,CAAe,CAC7B,EACA,EACA,EAAsB,KACtB,EAA2B,KACd,CAEb,GAAI,GAAQ,MAAQ,OAAO,IAAS,UAAW,CAC7C,IAAM,EAAO,EAAO,eAAe,EAAE,EAErC,OADA,EAAW,EAAQ,EAAM,CAAM,EACxB,CAAE,KAAM,OAAQ,KAAM,CAAK,EAIpC,GAAI,OAAO,IAAS,SAAU,CAC5B,IAAM,EAAO,EAAO,eAAe,CAAI,EAEvC,OADA,EAAW,EAAQ,EAAM,CAAM,EACxB,CAAE,KAAM,OAAQ,KAAM,CAAK,EAIpC,GAAI,OAAO,IAAS,SAAU,CAC5B,IAAM,EAAO,EAAO,eAAe,OAAO,CAAI,CAAC,EAE/C,OADA,EAAW,EAAQ,EAAM,CAAM,EACxB,CAAE,KAAM,OAAQ,KAAM,CAAK,EAIpC,GAAI,aAAgB,EAAmB,CACrC,IAAM,EAAO,EAAO,eAAe,EAAK,KAAK,EAE7C,OADA,EAAW,EAAQ,EAAM,CAAM,EACxB,CAAE,KAAM,OAAQ,KAAM,CAAK,EAIpC,GAAI,EAAW,CAAI,EACjB,OAAO,GAAwB,EAAa,EAAQ,EAAQ,CAAS,EAIvE,GAAI,MAAM,QAAQ,CAAI,EACpB,OAAO,GAAiB,EAAM,EAAQ,EAAQ,CAAS,EAIzD,GAAI,aAAgB,QAAS,CAC3B,IAAM,EAAc,EAAO,eAAe,EAAE,EAO5C,OANA,EAAW,EAAQ,EAAa,CAAM,EAEtC,EAAK,KAAK,CAAC,IAAa,CACtB,IAAM,EAAU,EAAgB,EAAU,EAAQ,EAAa,CAAS,EACxE,EAAO,OAAO,CAAW,EAC1B,EACM,CAAE,KAAM,OAAQ,KAAM,CAAY,EAI3C,GAAI,OAAO,IAAS,UAAY,QAAS,EACvC,OAAO,EAAmB,EAAM,EAAQ,EAAQ,CAAS,EAI3D,IAAM,EAAO,EAAO,eAAe,OAAO,CAAI,CAAC,EAE/C,OADA,EAAW,EAAQ,EAAM,CAAM,EACxB,CAAE,KAAM,OAAQ,KAAM,CAAK,EAMpC,SAAS,EAAgB,CACvB,EACA,EACA,EACA,EACa,CACb,IAAM,EAAgB,EAAO,cAAc,UAAU,EACrD,EAAW,EAAQ,EAAe,CAAM,EAExC,IAAM,EAA0B,CAAC,EACjC,QAAW,KAAS,EAClB,EAAS,KAAK,EAAgB,EAAO,EAAQ,EAAQ,CAAS,CAAC,EAGjE,MAAO,CAAE,KAAM,WAAY,WAAU,OAAQ,CAAc,EAOtD,SAAS,EAAmB,CACjC,EACA,EACA,EAA2B,KACZ,CACf,IAAM,EAAyB,CAAC,EAChC,QAAW,KAAS,EAClB,EAAQ,KAAK,EAAgB,EAAO,EAAQ,KAAM,CAAS,CAAC,EAE9D,OAAO,EAOT,SAAS,EAAuB,CAC9B,EACA,EACA,EACA,EACa,CACb,IAAM,EAAc,EAAO,cAAc,UAAU,EAC7C,EAAY,EAAO,cAAc,WAAW,EAClD,EAAW,EAAQ,EAAa,CAAM,EACtC,EAAW,EAAQ,EAAW,CAAM,EAEpC,IAAM,EAAQ,EAAmB,EAC7B,EAAqC,KACrC,EAAc,GAEZ,EAA8B,CAClC,KAAM,iBACN,cACA,YACA,SAAU,CAAC,EACX,QAAS,IAAM,EACjB,EAqBA,OAnBA,EAAM,QAAU,EAAO,IAAM,CAE3B,GAAI,EACF,EAAkB,CAAc,EAIlC,IAAM,EAAQ,EAAQ,CAAQ,EAK9B,GAJA,EAAiB,EAAgB,EAAqB,EAAQ,EAAW,CAAS,EAClF,EAAM,SAAW,CAAC,CAAc,EAG5B,EAAa,CACf,GAAI,EAAO,EAAiB,CAAK,EACjC,EAAkB,CAAK,EAEzB,EAAc,GACf,EAEM,EAMT,SAAS,CAAU,CAAC,EAAc,EAAa,EAA2B,CACxE,GAAI,EACF,EAAO,aAAa,EAAQ,EAAO,CAAM,EAEzC,OAAO,YAAY,EAAQ,CAAK,ECxJ7B,SAAS,EAAK,CACnB,EACA,EACA,EACa,CAEb,EAAU,UAAY,GAEtB,IAAM,EAAc,GAAS,CAAC,EAGxB,EAAW,GAAwB,EAAW,EAAa,IAAI,EAEjE,EACA,EAIJ,EAAmB,CAAQ,EAE3B,GAAI,CAGF,GAFA,EAAS,EAAU,CAAW,EAE1B,aAAkB,QAAS,CAE7B,IAAM,EAAc,SAAS,eAAe,EAAE,EAC9C,EAAU,YAAY,CAAW,EACjC,EAAO,CAAE,KAAM,OAAQ,KAAM,CAAY,EAEzC,EAAO,KAAK,CAAC,IAAa,CACxB,EAAU,UAAY,GACtB,EAAmB,CAAQ,EAC3B,EAAO,EAAmB,EAAU,CAAS,EAC7C,EAAmB,IAAI,EACvB,EAAS,QAAU,EACnB,EAAiB,CAAQ,EAC1B,EACI,QAAI,GAAU,OAAO,IAAW,UAAY,QAAS,EAC1D,EAAO,EAAmB,EAAQ,CAAS,EAE3C,OAAO,EAAgB,EAAsB,CAAS,EAExD,MAAO,EAAK,CAGZ,OAFA,EAAmB,IAAI,EACvB,GAAqB,EAAU,CAAY,EACpC,CACL,KAAM,CAAE,KAAM,OAAQ,KAAM,SAAS,eAAe,EAAE,CAAE,EACxD,OAAO,EAAG,EACZ,EAWF,OAPA,EAAmB,IAAI,EAEvB,EAAS,QAAU,EAGnB,EAAiB,CAAQ,EAElB,CACL,OACA,OAAO,EAAG,CAER,EAAmB,CAAQ,EAE3B,EAAY,CAAI,EAChB,EAAU,UAAY,GAE1B,EAOK,SAAS,EAAM,CAAC,EAAkB,EAAiC,CACxE,EAAU,UAAY,GAEtB,IAAM,EAAO,EAAgB,EAAM,CAAS,EAE5C,MAAO,CACL,OACA,OAAO,EAAG,CACR,EAAY,CAAI,EAChB,EAAU,UAAY,GAE1B",
|
|
24
|
+
"debugId": "38B497FBF63C4B4764756E2164756E21",
|
|
24
25
|
"names": []
|
|
25
26
|
}
|