{"version":3,"file":"index.cjs","names":["z","obj","obj"],"sources":["../src/parser/builtins.ts","../src/parser/prompt.ts","../src/reactive.ts","../src/library.ts","../src/parser/types.ts","../src/parser/ast.ts","../src/parser/expressions.ts","../src/parser/lexer.ts","../src/parser/materialize.ts","../src/parser/statements.ts","../src/parser/parser.ts","../src/parser/enrich-errors.ts","../src/parser/merge.ts","../src/parser/serialize.ts","../src/runtime/evaluator.ts","../src/runtime/evaluate-prop.ts","../src/runtime/evaluate-tree.ts","../src/runtime/mcp.ts","../src/runtime/toolProvider.ts","../src/runtime/queryManager.ts","../src/runtime/state-field.ts","../src/runtime/store.ts","../src/utils/validation.ts"],"sourcesContent":["/**\n * Shared parser/runtime registry hub for:\n *   - Runtime data builtins (evaluator.ts imports `.fn`)\n *   - Prompt builtin docs (prompt.ts imports `.signature` + `.description`)\n *   - Parser/runtime call classification (`isBuiltin`, action names, reserved calls)\n */\n\nexport interface BuiltinDef {\n  /** PascalCase name matching the openui-lang syntax: Count, Sum, etc. */\n  name: string;\n  /** Signature for prompt docs: \"@Count(array) → number\" */\n  signature: string;\n  /** One-line description for prompt docs */\n  description: string;\n  /** Runtime implementation */\n  fn: (...args: unknown[]) => unknown;\n}\n\n/** Resolve a field path on an object. Supports dot-paths: \"state.name\" → obj.state.name */\nfunction resolveField(obj: any, path: string): unknown {\n  if (!path || obj == null) return undefined;\n  if (!path.includes(\".\")) return obj[path];\n  let cur = obj;\n  for (const p of path.split(\".\")) {\n    if (cur == null) return undefined;\n    cur = cur[p];\n  }\n  return cur;\n}\n\nfunction toNumber(val: unknown): number {\n  if (typeof val === \"number\") return val;\n  if (typeof val === \"string\") {\n    const n = Number(val);\n    return isNaN(n) ? 0 : n;\n  }\n  if (typeof val === \"boolean\") return val ? 1 : 0;\n  return 0;\n}\n\nexport const BUILTINS: Record<string, BuiltinDef> = {\n  Count: {\n    name: \"Count\",\n    signature: \"Count(array) → number\",\n    description: \"Returns array length\",\n    fn: (arr) => (Array.isArray(arr) ? arr.length : 0),\n  },\n  First: {\n    name: \"First\",\n    signature: \"First(array) → element\",\n    description: \"Returns first element of array\",\n    fn: (arr) => (Array.isArray(arr) ? (arr[0] ?? null) : null),\n  },\n  Last: {\n    name: \"Last\",\n    signature: \"Last(array) → element\",\n    description: \"Returns last element of array\",\n    fn: (arr) => (Array.isArray(arr) ? (arr[arr.length - 1] ?? null) : null),\n  },\n  Sum: {\n    name: \"Sum\",\n    signature: \"Sum(numbers[]) → number\",\n    description: \"Sum of numeric array\",\n    fn: (arr) =>\n      Array.isArray(arr) ? arr.reduce((a: number, b: unknown) => a + toNumber(b), 0) : 0,\n  },\n  Avg: {\n    name: \"Avg\",\n    signature: \"Avg(numbers[]) → number\",\n    description: \"Average of numeric array\",\n    fn: (arr) =>\n      Array.isArray(arr) && arr.length\n        ? (arr.reduce((a: number, b: unknown) => a + toNumber(b), 0) as number) / arr.length\n        : 0,\n  },\n  Min: {\n    name: \"Min\",\n    signature: \"Min(numbers[]) → number\",\n    description: \"Minimum value in array\",\n    fn: (arr) =>\n      Array.isArray(arr) && arr.length\n        ? arr.reduce((acc: number, b: unknown) => Math.min(acc, toNumber(b)), toNumber(arr[0]))\n        : 0,\n  },\n  Max: {\n    name: \"Max\",\n    signature: \"Max(numbers[]) → number\",\n    description: \"Maximum value in array\",\n    fn: (arr) =>\n      Array.isArray(arr) && arr.length\n        ? arr.reduce((acc: number, b: unknown) => Math.max(acc, toNumber(b)), toNumber(arr[0]))\n        : 0,\n  },\n  Sort: {\n    name: \"Sort\",\n    signature: \"Sort(array, field, direction?) → sorted array\",\n    description: 'Sort array by field. Direction: \"asc\" (default) or \"desc\"',\n    fn: (arr, field, dir) => {\n      if (!Array.isArray(arr)) return arr;\n      const f = String(field ?? \"\");\n      const desc = String(dir ?? \"asc\") === \"desc\";\n      return [...arr].sort((a: any, b: any) => {\n        const av = f ? resolveField(a, f) : a;\n        const bv = f ? resolveField(b, f) : b;\n        const aIsNumeric =\n          typeof av === \"number\" || (typeof av === \"string\" && !isNaN(Number(av)) && av !== \"\");\n        const bIsNumeric =\n          typeof bv === \"number\" || (typeof bv === \"string\" && !isNaN(Number(bv)) && bv !== \"\");\n        if (aIsNumeric && bIsNumeric) {\n          const diff = toNumber(av) - toNumber(bv);\n          return desc ? -diff : diff;\n        }\n        const cmp = String(av ?? \"\").localeCompare(String(bv ?? \"\"));\n        return desc ? -cmp : cmp;\n      });\n    },\n  },\n  Filter: {\n    name: \"Filter\",\n    signature:\n      'Filter(array, field, operator: \"==\" | \"!=\" | \">\" | \"<\" | \">=\" | \"<=\" | \"contains\", value) → filtered array',\n    description: \"Filter array by field value\",\n    fn: (arr, field, op, value) => {\n      if (!Array.isArray(arr)) return [];\n      const f = String(field ?? \"\");\n      const o = String(op ?? \"==\");\n      return arr.filter((item: any) => {\n        const v = f ? resolveField(item, f) : item;\n        switch (o) {\n          case \"==\":\n            return v == value;\n          case \"!=\":\n            return v != value;\n          case \">\":\n            return toNumber(v) > toNumber(value);\n          case \"<\":\n            return toNumber(v) < toNumber(value);\n          case \">=\":\n            return toNumber(v) >= toNumber(value);\n          case \"<=\":\n            return toNumber(v) <= toNumber(value);\n          case \"contains\":\n            return String(v ?? \"\").includes(String(value ?? \"\"));\n          default:\n            return false;\n        }\n      });\n    },\n  },\n  Round: {\n    name: \"Round\",\n    signature: \"Round(number, decimals?) → number\",\n    description: \"Round to N decimal places (default 0)\",\n    fn: (n, decimals) => {\n      const num = toNumber(n);\n      const d = decimals != null ? toNumber(decimals) : 0;\n      const factor = Math.pow(10, d);\n      return Math.round(num * factor) / factor;\n    },\n  },\n  Abs: {\n    name: \"Abs\",\n    signature: \"Abs(number) → number\",\n    description: \"Absolute value\",\n    fn: (n) => Math.abs(toNumber(n)),\n  },\n  Floor: {\n    name: \"Floor\",\n    signature: \"Floor(number) → number\",\n    description: \"Round down to nearest integer\",\n    fn: (n) => Math.floor(toNumber(n)),\n  },\n  Ceil: {\n    name: \"Ceil\",\n    signature: \"Ceil(number) → number\",\n    description: \"Round up to nearest integer\",\n    fn: (n) => Math.ceil(toNumber(n)),\n  },\n};\n\n/**\n * Lazy builtins — these receive AST nodes (not evaluated values) and\n * control their own evaluation. Handled specially in evaluator.ts.\n */\nexport const LAZY_BUILTINS: Set<string> = new Set([\"Each\"]);\n\nexport const LAZY_BUILTIN_DEFS: Record<string, { signature: string; description: string }> = {\n  Each: {\n    signature: \"Each(array, varName, template)\",\n    description:\n      \"Evaluate template for each element. varName is the loop variable — use it ONLY inside the template expression (inline). Do NOT create a separate statement for the template.\",\n  },\n};\n\n/** Maps parser-level action step names → runtime step type values. Single source of truth. */\nexport const ACTION_STEPS = {\n  Run: \"run\",\n  ToAssistant: \"continue_conversation\",\n  OpenUrl: \"open_url\",\n  Set: \"set\",\n  Reset: \"reset\",\n} as const;\n\n/** All action expression names (steps + the Action container) */\nexport const ACTION_NAMES: Set<string> = new Set([\"Action\", ...Object.keys(ACTION_STEPS)]);\n\n/** Set of builtin names for fast lookup (includes action expressions) */\nexport const BUILTIN_NAMES: Set<string> = new Set([\n  ...Object.keys(BUILTINS),\n  ...LAZY_BUILTINS,\n  ...ACTION_NAMES,\n]);\n\n/** Check if a name is a builtin function (not a component) */\nexport function isBuiltin(name: string): boolean {\n  return BUILTIN_NAMES.has(name);\n}\n\n/** Reserved statement-level call names — not builtins, not components */\nexport const RESERVED_CALLS = { Query: \"Query\", Mutation: \"Mutation\" } as const;\n\n/** Check if a name is a reserved statement call (Query, Mutation) */\nexport function isReservedCall(name: string): boolean {\n  return name in RESERVED_CALLS;\n}\n\n/** Re-export toNumber for evaluator compatibility */\nexport { toNumber };\n","import { BUILTINS, LAZY_BUILTIN_DEFS } from \"./builtins\";\n\n// ─── PromptSpec types (JSON-serializable, no Zod deps) ──────────────────────\n\n/**\n * Tool schema for prompt generation — describes a tool the LLM can use via Query()/Mutation().\n * Shape inspired by MCP's tool schema (name, description, inputSchema, annotations).\n */\nexport interface ToolSpec {\n  name: string;\n  description?: string;\n  inputSchema: Record<string, unknown>;\n  outputSchema: Record<string, unknown>;\n  annotations?: { readOnlyHint?: boolean; destructiveHint?: boolean };\n}\n\nexport interface ComponentPromptSpec {\n  signature: string; // pre-built: \"Card(children: Component[], title?: string)\"\n  description?: string;\n}\n\nexport interface ComponentGroup {\n  name: string;\n  components: string[];\n  notes?: string[];\n}\n\nexport interface PromptSpec {\n  root?: string;\n  components: Record<string, ComponentPromptSpec>;\n  componentGroups?: ComponentGroup[];\n  tools?: (string | ToolSpec)[];\n  editMode?: boolean;\n  inlineMode?: boolean;\n  /** Enable Query(), Mutation(), @Run, tool workflow. Default: true if tools provided. */\n  toolCalls?: boolean;\n  /** Enable $variables, @Set, @Reset, interactive filters. Default: true if toolCalls. */\n  bindings?: boolean;\n  preamble?: string;\n  /** General examples (static/layout patterns). Both `examples` and `toolExamples` are included when present. */\n  examples?: string[];\n  /** Tool-specific examples (Query/Mutation patterns). Both `examples` and `toolExamples` are included when present. */\n  toolExamples?: string[];\n  additionalRules?: string[];\n}\n\n// ─── JSON Schema → type string helper ───────────────────────────────────────\n\nfunction jsonSchemaTypeStr(schema: Record<string, unknown>): string {\n  const type = schema.type as string | undefined;\n\n  if (type === \"string\") {\n    const enumVals = schema.enum as string[] | undefined;\n    if (enumVals) return enumVals.map((v) => `\"${v}\"`).join(\" | \");\n    return \"string\";\n  }\n  if (type === \"number\" || type === \"integer\") return \"number\";\n  if (type === \"boolean\") return \"boolean\";\n  if (type === \"array\") {\n    const items = schema.items as Record<string, unknown> | undefined;\n    if (items) return `${jsonSchemaTypeStr(items)}[]`;\n    return \"any[]\";\n  }\n  if (type === \"object\") {\n    const props = schema.properties as Record<string, Record<string, unknown>> | undefined;\n    if (props && Object.keys(props).length > 0) {\n      const required = (schema.required as string[]) ?? [];\n      const fields = Object.entries(props).map(([k, v]) => {\n        const opt = required.includes(k) ? \"\" : \"?\";\n        return `${k}${opt}: ${jsonSchemaTypeStr(v)}`;\n      });\n      return `{${fields.join(\", \")}}`;\n    }\n    return \"object\";\n  }\n\n  return \"any\";\n}\n\n/** Generate a default-values hint object for an output schema. */\nfunction defaultForSchema(schema: Record<string, unknown>): unknown {\n  const type = schema.type as string | undefined;\n  if (type === \"string\") return \"\";\n  if (type === \"number\" || type === \"integer\") return 0;\n  if (type === \"boolean\") return false;\n  if (type === \"array\") return [];\n  if (type === \"object\") {\n    const props = schema.properties as Record<string, Record<string, unknown>> | undefined;\n    if (props && Object.keys(props).length > 0) {\n      const result: Record<string, unknown> = {};\n      for (const [k, v] of Object.entries(props)) {\n        result[k] = defaultForSchema(v);\n      }\n      return result;\n    }\n    return {};\n  }\n  return null;\n}\n\n// ─── Section generators ─────────────────────────────────────────────────────\n\nconst PREAMBLE = `You are an AI assistant that responds using openui-lang, a declarative UI language. Your ENTIRE response must be valid openui-lang code — no markdown, no explanations, just openui-lang.`;\n\nfunction syntaxRules(\n  rootName: string,\n  flags: { supportsExpressions: boolean; bindings: boolean },\n): string {\n  const lines = [\n    \"## Syntax Rules\",\n    \"\",\n    \"1. Each statement is on its own line: `identifier = Expression`\",\n    `2. \\`root\\` is the entry point — every program must define \\`root = ${rootName}(...)\\``,\n    '3. Expressions are: strings (\"...\"), numbers, booleans (true/false), null, arrays ([...]), objects ({...}), or component calls TypeName(arg1, arg2, ...)',\n    \"4. Use references for readability: define `name = ...` on one line, then use `name` later\",\n    \"5. EVERY variable (except root) MUST be referenced by at least one other variable. Unreferenced variables are silently dropped and will NOT render. Always include defined variables in their parent's children/items array.\",\n    '6. Arguments are POSITIONAL (order matters, not names). Write `Stack([children], \"row\", \"l\")` NOT `Stack([children], direction: \"row\", gap: \"l\")` — colon syntax is NOT supported and silently breaks',\n    \"7. Optional arguments can be omitted from the end\",\n  ];\n\n  let ruleNum = 8;\n  if (flags.bindings) {\n    lines.push(\n      `${ruleNum++}. Declare mutable state with \\`$varName = defaultValue\\`. Components marked with \\`$binding\\` can read/write these. Undeclared $variables are auto-created with null default.`,\n    );\n  }\n  if (flags.supportsExpressions) {\n    lines.push(\n      `${ruleNum++}. String concatenation: \\`\"text\" + $var + \"more\"\\``,\n      `${ruleNum++}. Dot member access: \\`query.field\\` reads a field; on arrays it extracts that field from every element`,\n      `${ruleNum++}. Index access: \\`arr[0]\\`, \\`data[index]\\``,\n      `${ruleNum++}. Arithmetic operators: +, -, *, /, % (work on numbers; + is string concat when either side is a string)`,\n      `${ruleNum++}. Comparison: ==, !=, >, <, >=, <=`,\n      `${ruleNum++}. Logical: &&, ||, ! (prefix)`,\n      `${ruleNum++}. Ternary: \\`condition ? valueIfTrue : valueIfFalse\\``,\n      `${ruleNum++}. Parentheses for grouping: \\`(a + b) * c\\``,\n    );\n  }\n\n  lines.push(\"- Strings use double quotes with backslash escaping\");\n\n  return lines.join(\"\\n\");\n}\n\nfunction builtinFunctionsSection(): string {\n  // Auto-generated from shared builtin registry — single source of truth\n  const builtinLines = Object.values(BUILTINS).map((b) => `@${b.signature} — ${b.description}`);\n  const lazyLines = Object.values(LAZY_BUILTIN_DEFS).map(\n    (b) => `@${b.signature} — ${b.description}`,\n  );\n  const lines = [...builtinLines, ...lazyLines].join(\"\\n\");\n\n  return `## Built-in Functions\n\nData functions prefixed with \\`@\\` to distinguish from components. These are the ONLY functions available — do NOT invent new ones.\nUse @-prefixed built-in functions (@Count, @Sum, @Avg, @Min, @Max, @Round) on Query results — do NOT hardcode computed values.\n\n${lines}\n\nBuiltins compose — output of one is input to the next:\n\\`@Count(@Filter(data.rows, \"field\", \"==\", \"val\"))\\` for KPIs/chart values, \\`@Round(@Avg(data.rows.score), 1)\\`, \\`@Each(data.rows, \"item\", Comp(item.field))\\` for per-item rendering.\nArray pluck: \\`data.rows.field\\` extracts a field from every row → use with @Sum, @Avg, charts, tables.\n\nIMPORTANT @Each rule: The loop variable (e.g. \"item\") is ONLY available inside the @Each template expression. Always inline the template — do NOT extract it to a separate statement.\nCORRECT: \\`Col(\"Actions\", @Each(rows, \"t\", Button(\"Edit\", Action([@Set($id, t.id)]))))\\`\nWRONG: \\`myBtn = Button(\"Edit\", Action([@Set($id, t.id)]))\\` then \\`Col(\"Actions\", @Each(rows, \"t\", myBtn))\\` — t is undefined in myBtn.`;\n}\n\nfunction querySection(): string {\n  return `## Query — Live Data Fetching\n\nFetch data from available tools. Returns defaults instantly, swaps in real data when it arrives.\n\n\\`\\`\\`\nmetrics = Query(\"tool_name\", {arg1: value, arg2: $binding}, {defaultField: 0, defaultData: []}, refreshInterval?)\n\\`\\`\\`\n\n- First arg: tool name (string)\n- Second arg: arguments object (may reference $bindings — re-fetches automatically on change)\n- Third arg: default data (rendered immediately before fetch resolves)\n- Fourth arg (optional): refresh interval in seconds (e.g. 30 for auto-refresh every 30s)\n- Use dot access on results: metrics.totalEvents, metrics.data.day (array pluck)\n- Query results must use regular identifiers: \\`metrics = Query(...)\\`, NOT \\`$metrics = Query(...)\\`\n- Manual refresh: \\`Button(\"Refresh\", Action([@Run(query1), @Run(query2)]), \"secondary\")\\` — re-fetches the listed queries\n- Refresh all queries: create Action with @Run for each query`;\n}\n\nfunction mutationSection(): string {\n  return `## Mutation — Write Operations\n\nExecute state-changing tool calls (create, update, delete). Unlike Query (auto-fetches on render), Mutation fires only on button click via Action.\n\n\\`\\`\\`\nresult = Mutation(\"tool_name\", {arg1: $binding, arg2: \"value\"})\n\\`\\`\\`\n\n- First arg: tool name (string)\n- Second arg: arguments object (evaluated with current $binding values at click time)\n- result.status: \"idle\" | \"loading\" | \"success\" | \"error\"\n- result.data: tool response on success\n- result.error: error message on failure\n- Mutation results use regular identifiers: \\`result = Mutation(...)\\`, NOT \\`$result\\`\n- Show loading state: \\`result.status == \"loading\" ? TextContent(\"Saving...\") : null\\``;\n}\n\nfunction actionSection(flags: { toolCalls: boolean; bindings: boolean }): string {\n  const steps = [\n    '- @ToAssistant(\"message\") — Send a message to the assistant (for conversational buttons like \"Tell me more\", \"Explain this\")',\n    '- @OpenUrl(\"https://...\") — Navigate to a URL',\n  ];\n\n  if (flags.bindings) {\n    steps.push(\n      \"- @Set($variable, value) — Set a $variable to a specific value\",\n      '- @Reset($var1, $var2, ...) — Reset $variables to their declared defaults (e.g. @Reset($title, $priority) restores $title=\"\" and $priority=\"medium\")',\n    );\n  }\n\n  if (flags.toolCalls) {\n    steps.unshift(\n      \"- @Run(queryOrMutationRef) — Execute a Mutation or re-fetch a Query (ref must be a declared Query/Mutation)\",\n    );\n  }\n\n  const examples: string[] = [];\n  if (flags.toolCalls) {\n    examples.push(`Example — mutation + refresh + reset (PREFERRED pattern):\n\\`\\`\\`\n$binding = \"default\"\nresult = Mutation(\"tool_name\", {field: $binding})\ndata = Query(\"tool_name\", {}, {rows: []})\nonSubmit = Action([@Run(result), @Run(data), @Reset($binding)])\n\\`\\`\\``);\n  }\n\n  examples.push(`Example — simple nav:\n\\`\\`\\`\nviewBtn = Button(\"View\", Action([@OpenUrl(\"https://example.com\")]))\n\\`\\`\\``);\n\n  const rules = [\n    '- Action can be assigned to a variable or inlined: Button(\"Go\", onSubmit) and Button(\"Go\", Action([...])) both work',\n  ];\n  if (flags.toolCalls) {\n    rules.push(\n      \"- If a @Run(mutation) step fails, remaining steps are skipped (halt on failure)\",\n      \"- @Run(queryRef) re-fetches the query (fire-and-forget, cannot fail)\",\n    );\n  }\n\n  return `## Action — Button Behavior\n\nAction([@steps...]) wires button clicks to operations. Steps are @-prefixed built-in actions. Steps execute in order.\nButtons without an explicit Action prop automatically send their label to the assistant (equivalent to Action([@ToAssistant(label)])).\n\nAvailable steps:\n${steps.join(\"\\n\")}\n\n${examples.join(\"\\n\\n\")}\n\n${rules.join(\"\\n\")}`;\n}\n\nfunction interactiveFiltersSection(): string {\n  return `## Interactive Filters\n\nTo let the user filter data with a dropdown:\n1. Declare a $variable with a default: \\`$dateRange = \"14\"\\`\n2. Create a Select with name, items, and binding: \\`Select(\"dateRange\", [SelectItem(\"7\", \"Last 7 days\"), ...], null, null, $dateRange)\\`\n3. Wrap in FormControl for a label: \\`FormControl(\"Date Range\", Select(...))\\`\n4. Pass $dateRange in Query args: \\`Query(\"tool\", {dateRange: $dateRange}, {defaults})\\`\n5. When the user changes the Select, $dateRange updates and the Query automatically re-fetches\n\nFILTER WIRING RULE: If a $binding filter is visible in the UI, EVERY relevant Query MUST reference that $binding in its args. Never show a filter dropdown while hardcoding the query args.\n\nRules for $variables:\n- $variables hold simple values (strings or numbers), NOT arrays or objects\n- $variables must be bound to a Select/Input component via the value argument (last positional arg) to be interactive\n- Queries must use regular identifiers (NOT $variables): \\`metrics = Query(...)\\` not \\`$metrics = Query(...)\\`\n- **Auto-declare**: You do NOT need to explicitly declare $variables. If you use \\`$foo\\` without declaring it, the parser auto-creates \\`$foo = null\\`. You can still declare explicitly to set a default: \\`$days = \"14\"\\`\n\n## Forms\n\nSimple form — no $bindings needed. Field values are managed internally by the Form via the name prop:\n\\`\\`\\`\ncontactForm = Form(\"contact\", submitBtn, [nameField, emailField])\nnameField = FormControl(\"Name\", Input(\"name\", \"Your name\", \"text\", {required: true}))\nemailField = FormControl(\"Email\", Input(\"email\", \"your@email.com\", \"email\", {required: true, email: true}))\nsubmitBtn = Button(\"Submit\")\n\\`\\`\\`\n\nUse $bindings when you need to read field values elsewhere (in Action context, Query args, or conditionals). They are auto-declared:\n\\`\\`\\`\n$role = \"engineer\"\ncontactForm = Form(\"contact\", submitBtn, [nameField, emailField, roleField])\nnameField = FormControl(\"Name\", Input(\"name\", \"Enter your name\", \"text\", {required: true}, $name))\nemailField = FormControl(\"Email\", Input(\"email\", \"Enter your email\", \"email\", {required: true, email: true}, $email))\nroleField = FormControl(\"Role\", Select(\"role\", [SelectItem(\"engineer\", \"Engineer\"), SelectItem(\"designer\", \"Designer\"), SelectItem(\"pm\", \"PM\")], null, {required: true}, $role))\nsubmitBtn = Button(\"Submit\")\n\\`\\`\\`\n\nFor form + mutation patterns (create, refresh, reset), see the Action section example above.\n\nIMPORTANT: Always add validation rules to form fields used with Mutations. Use OBJECT syntax: {required: true, email: true, minLength: 8}. The renderer shows error messages automatically and blocks submit when validation fails.`;\n}\n\nfunction editModeSection(): string {\n  return `## Edit Mode\n\nThe runtime merges by statement name: same name = replace, new name = append.\nOutput ONLY statements that changed or are new. Everything else is kept automatically.\n\n### Delete\nTo remove a component, update the parent to exclude it from its children array. Orphaned statements are automatically garbage-collected.\nExample — remove chart: \\`root = Stack([header, kpiRow, table])\\` — chart is no longer in the children list, so it and any statements only it referenced are auto-deleted.\n\n### Patch size guide\n- Changing a title or label: 1 statement\n- Adding a component: 2-3 statements (the new component + parent update)\n- Removing a component: 1 statement (re-declare parent without the removed child)\n- Adding a filter + wiring to query: 3-5 statements\n- Restructuring into tabs: 5-10 statements\n\n### Rules\n- Reuse existing statement names exactly — do not rename\n- Do NOT re-emit unchanged statements — the runtime keeps them\n- A typical edit patch is 1-10 statements, not 20+\n- If the existing code already satisfies the request, output only the root statement\n- NEVER output the entire program as a patch. Only output what actually changes\n- If you are about to output more than 10 statements, reconsider — most edits need fewer`;\n}\n\nfunction streamingRules(rootName: string, flags: { supportsExpressions: boolean }): string {\n  const steps = [`1. \\`root = ${rootName}(...)\\` — UI shell appears immediately`];\n  if (flags.supportsExpressions) {\n    steps.push(\"2. $variable declarations — state ready for bindings\");\n    steps.push(\"3. Query statements — defaults resolve immediately so components render with data\");\n    steps.push(\"4. Component definitions — fill in with data already available\");\n    steps.push(\"5. Data values — leaf content last\");\n  } else {\n    steps.push(\"2. Component definitions — fill in as they stream\");\n    steps.push(\"3. Data values — leaf content last\");\n  }\n\n  return `## Hoisting & Streaming (CRITICAL)\n\nopenui-lang supports hoisting: a reference can be used BEFORE it is defined. The parser resolves all references after the full input is parsed.\n\nDuring streaming, the output is re-parsed on every chunk. Undefined references are temporarily unresolved and appear once their definitions stream in. This creates a progressive top-down reveal — structure first, then data fills in.\n\n**Recommended statement order for optimal streaming:**\n${steps.join(\"\\n\")}\n\nAlways write the root = ${rootName}(...) statement first so the UI shell appears immediately, even before child data has streamed in.`;\n}\n\nfunction inlineModeSection(): string {\n  return `## Inline Mode\n\nYou are in inline mode. You can respond in two ways:\n\n### 1. Code response (when the user wants to CREATE or CHANGE the UI)\nWrap openui-lang code in triple-backtick fences. You can include explanatory text before/after:\n\nHere's your dashboard:\n\n\\`\\`\\`openui-lang\nroot = RootComp([header, content])\nheader = SomeHeader(\"Title\")\ncontent = SomeContent(\"Hello world\")\n\\`\\`\\`\n\nI created a simple layout with a header.\n\n### 2. Text-only response (when the user asks a QUESTION)\nIf the user asks \"what is this?\", \"explain the chart\", \"how does this work\", etc. — respond with plain text. Do NOT output any openui-lang code. The existing dashboard stays unchanged.\n\n### Rules\n- When the user asks for changes, output ONLY the changed/new statements in a fenced block\n- When the user asks a question, respond with text only — NO code. The dashboard stays unchanged.\n- The parser extracts code from fences automatically. Text outside fences is shown as chat.`;\n}\n\nfunction toolWorkflowSection(): string {\n  return `## Data Workflow\n\nWhen tools are available, follow this workflow:\n1. FIRST: Call the most relevant tool to inspect the real data shape before generating code\n2. Use Query() for READ operations (data that should stay live) — NEVER hardcode tool results as literal arrays or objects\n3. Use Mutation() for WRITE operations (create, update, delete) — triggered by button clicks via Action([@Run(mutationRef)])\n4. Use the real data from step 1 as condensed Query defaults (3-5 rows) so the UI renders immediately\n5. Use @-prefixed builtins (@Count, @Filter, @Sort, @Sum) on Query results for KPIs and aggregations — the runtime evaluates these live on every refresh\n6. Hardcoded arrays are ONLY for static display data (labels, options) where no tool exists\n\nWRONG — you called a tool and got data back, but you inlined the results:\n\\`\\`\\`\nopenCount = 2\nitem1 = SomeComp(\"first item title\")\nitem2 = SomeComp(\"second item title\")\nlist = Stack([item1, item2])\nchart = SomeChart([\"A\", \"B\"], [12, 8])\n\\`\\`\\`\nThis is static — it shows stale data and won't update. Creating item1, item2, item3... manually is ALWAYS wrong when a tool exists.\n\nRIGHT — use Query() for live data, Mutation() for writes, @builtins to derive values:\n\\`\\`\\`\ndata = Query(\"tool_name\", {}, {rows: []})\nopenCount = @Count(@Filter(data.rows, \"field\", \"==\", \"value\"))\nlist = @Each(data.rows, \"item\", SomeComp(item.title, item.field))\ncreateResult = Mutation(\"create_tool\", {title: $title})\nsubmitBtn = Button(\"Create\", Action([@Run(createResult), @Run(data), @Reset($title)]))\n\\`\\`\\`\nEverything derives from the Query — when data refreshes, the entire dashboard updates automatically.`;\n}\n\nfunction importantRules(\n  rootName: string,\n  flags: { toolCalls: boolean; bindings: boolean },\n): string {\n  const verifyLines = [\n    `1. root = ${rootName}(...) is the FIRST line (for optimal streaming).`,\n    \"2. Every referenced name is defined. Every defined name (other than root) is reachable from root.\",\n  ];\n  if (flags.toolCalls) {\n    verifyLines.push(\"3. Every Query result is referenced by at least one component.\");\n  }\n  if (flags.bindings) {\n    verifyLines.push(\n      `${flags.toolCalls ? \"4\" : \"3\"}. Every $binding appears in at least one component or expression.`,\n    );\n  }\n\n  return `## Important Rules\n- When asked about data, generate realistic/plausible data\n- Choose components that best represent the content (tables for comparisons, charts for trends, forms for input, etc.)\n\n## Final Verification\nBefore finishing, walk your output and verify:\n${verifyLines.join(\"\\n\")}`;\n}\n\n// ─── Tool rendering ─────────────────────────────────────────────────────────\n\nfunction renderToolSignature(tool: ToolSpec): string {\n  let args = \"\";\n  if (tool.inputSchema) {\n    const props = (tool.inputSchema as any).properties as\n      | Record<string, Record<string, unknown>>\n      | undefined;\n    const required = ((tool.inputSchema as any).required as string[]) ?? [];\n    if (props && Object.keys(props).length > 0) {\n      args = Object.entries(props)\n        .map(([k, v]) => {\n          const opt = required.includes(k) ? \"\" : \"?\";\n          return `${k}${opt}: ${jsonSchemaTypeStr(v)}`;\n        })\n        .join(\", \");\n    }\n  }\n\n  let returnType = \"\";\n  if (tool.outputSchema) {\n    returnType = ` → ${jsonSchemaTypeStr(tool.outputSchema as Record<string, unknown>)}`;\n  }\n\n  let line = `- ${tool.name}(${args})${returnType}`;\n  if (tool.description) {\n    line += `\\n  ${tool.description}`;\n  }\n  return line;\n}\n\nfunction renderToolsSection(tools: (string | ToolSpec)[]): string {\n  const lines: string[] = [];\n\n  const stringTools: string[] = [];\n  const specTools: ToolSpec[] = [];\n\n  for (const tool of tools) {\n    if (typeof tool === \"string\") {\n      stringTools.push(tool);\n    } else {\n      specTools.push(tool);\n    }\n  }\n\n  lines.push(\"## Available Tools\");\n  lines.push(\"\");\n  lines.push(\n    \"Use these with Query() for read operations or Mutation() for write operations. The LLM decides which is appropriate based on the tool's purpose.\",\n  );\n  lines.push(\"\");\n  for (const t of stringTools) {\n    lines.push(`- ${t}`);\n  }\n  for (const t of specTools) {\n    lines.push(renderToolSignature(t));\n  }\n\n  // Default values hint for ToolSpec tools with outputSchema\n  const toolsWithOutput = specTools.filter((t) => t.outputSchema);\n  if (toolsWithOutput.length > 0) {\n    lines.push(\"\");\n    lines.push(\"### Default values for Query results\");\n    lines.push(\"\");\n    lines.push(\"Use these shapes as minimal Query defaults:\");\n    for (const t of toolsWithOutput) {\n      const defaults = defaultForSchema(t.outputSchema as Record<string, unknown>);\n      lines.push(`- ${t.name}: \\`${JSON.stringify(defaults)}\\``);\n    }\n  }\n\n  lines.push(\"\");\n  lines.push(\n    \"CRITICAL: Use ONLY the tools listed above in Query() and Mutation() calls. Do NOT invent or guess tool names. If the user asks for functionality that doesn't match any available tool, use realistic mock data instead of fabricating a tool call.\",\n  );\n\n  return lines.join(\"\\n\");\n}\n\n// ─── Component signatures ───────────────────────────────────────────────────\n\nfunction generateComponentSignatures(\n  spec: PromptSpec,\n  flags: { toolCalls: boolean; bindings: boolean; usesActionExpression: boolean },\n): string {\n  const lines = [\n    \"## Component Signatures\",\n    \"\",\n    \"Arguments marked with ? are optional. Sub-components can be inline or referenced; prefer references for better streaming.\",\n  ];\n  if (flags.usesActionExpression) {\n    const allSteps = [\n      flags.toolCalls ? \"@Run\" : \"\",\n      \"@ToAssistant\",\n      \"@OpenUrl\",\n      flags.bindings ? \"@Set\" : \"\",\n      flags.bindings ? \"@Reset\" : \"\",\n    ].filter(Boolean);\n    lines.push(\n      `Props typed \\`ActionExpression\\` accept an Action([@steps...]) expression. See the Action section for available steps (${allSteps.join(\", \")}).`,\n    );\n  }\n  const usesBindings =\n    flags.bindings || Object.values(spec.components).some((c) => c.signature?.includes(\"$binding\"));\n  if (usesBindings) {\n    lines.push(\"Props marked `$binding<type>` accept a `$variable` reference for two-way binding.\");\n  }\n\n  const formatSig = (comp: { signature: string; description?: string }) =>\n    comp.description ? `${comp.signature} — ${comp.description}` : comp.signature;\n\n  if (spec.componentGroups?.length) {\n    const grouped = new Set<string>();\n    for (const group of spec.componentGroups) {\n      lines.push(\"\", `### ${group.name}`);\n      for (const name of group.components) {\n        if (grouped.has(name)) continue;\n        const comp = spec.components[name];\n        if (!comp) continue;\n        grouped.add(name);\n        lines.push(formatSig(comp));\n      }\n      if (group.notes?.length) {\n        for (const note of group.notes) lines.push(note);\n      }\n    }\n    const ungrouped = Object.keys(spec.components).filter((n) => !grouped.has(n));\n    if (ungrouped.length) {\n      lines.push(\"\", \"### Other\");\n      for (const name of ungrouped) {\n        const comp = spec.components[name];\n        lines.push(formatSig(comp));\n      }\n    }\n  } else {\n    lines.push(\"\");\n    for (const [, comp] of Object.entries(spec.components)) {\n      lines.push(formatSig(comp));\n    }\n  }\n  return lines.join(\"\\n\");\n}\n\n// ─── Prompt assembly ────────────────────────────────────────────────────────\n\nexport function generatePrompt(spec: PromptSpec): string {\n  const rootName = spec.root ?? \"Root\";\n  const hasTools = !!spec.tools?.length;\n\n  // Resolve prompt flags — defaults preserve backward compat\n  const toolCalls = spec.toolCalls ?? hasTools;\n  const bindings = spec.bindings ?? toolCalls;\n  const supportsExpressions = toolCalls || bindings;\n\n  // Detect component-level feature usage\n  const usesActionExpression = Object.values(spec.components).some((c) =>\n    c.signature?.includes(\"ActionExpression\"),\n  );\n\n  const parts: string[] = [];\n\n  parts.push(spec.preamble ?? PREAMBLE);\n  parts.push(\"\");\n  parts.push(syntaxRules(rootName, { supportsExpressions, bindings }));\n  parts.push(\"\");\n  parts.push(generateComponentSignatures(spec, { toolCalls, bindings, usesActionExpression }));\n\n  // Built-in functions — only when expressions are enabled (Query/reactive state)\n  if (supportsExpressions) {\n    parts.push(\"\");\n    parts.push(builtinFunctionsSection());\n  }\n\n  // Query + Mutation sections\n  if (toolCalls) {\n    parts.push(\"\");\n    parts.push(querySection());\n    parts.push(\"\");\n    parts.push(mutationSection());\n  }\n\n  // Action section — only when components use ActionExpression (v0.5 action syntax)\n  if (usesActionExpression) {\n    parts.push(\"\");\n    parts.push(actionSection({ toolCalls, bindings }));\n  }\n\n  // Interactive filters (needs both toolCalls and bindings)\n  if (toolCalls && bindings) {\n    parts.push(\"\");\n    parts.push(interactiveFiltersSection());\n  }\n\n  // Tool workflow\n  if (toolCalls) {\n    parts.push(\"\");\n    parts.push(toolWorkflowSection());\n  }\n\n  // Tools list (only if actual tools provided)\n  if (spec.tools?.length) {\n    parts.push(\"\");\n    parts.push(renderToolsSection(spec.tools));\n  }\n\n  parts.push(\"\");\n  parts.push(streamingRules(rootName, { supportsExpressions }));\n\n  // Append both examples and toolExamples when both are present\n  const allExamples = [...(spec.examples ?? []), ...(spec.toolExamples ?? [])];\n  if (allExamples.length) {\n    parts.push(\"\");\n    parts.push(\"## Examples\");\n    parts.push(\"\");\n    for (const ex of allExamples) {\n      parts.push(ex);\n      parts.push(\"\");\n    }\n  }\n\n  // Edit mode instructions\n  if (spec.editMode) {\n    parts.push(\"\");\n    parts.push(editModeSection());\n  }\n\n  // Inline mode instructions\n  if (spec.inlineMode) {\n    parts.push(\"\");\n    parts.push(inlineModeSection());\n  }\n\n  parts.push(importantRules(rootName, { toolCalls, bindings }));\n\n  if (spec.additionalRules?.length) {\n    parts.push(\"\");\n    for (const rule of spec.additionalRules) {\n      parts.push(`- ${rule}`);\n    }\n  }\n\n  return parts.join(\"\\n\");\n}\n","// ─────────────────────────────────────────────────────────────────────────────\n// Reactive schema marker — shared between lang-core (introspection) and\n// framework adapters (runtime binding).\n// ─────────────────────────────────────────────────────────────────────────────\n\n/** WeakSet tracks reactive schemas without mutating the schema objects. */\nconst reactiveSchemas = new WeakSet<object>();\n\n/** Mark a schema as reactive. Called by framework adapters' reactive() function. */\nexport function markReactive(schema: object): void {\n  reactiveSchemas.add(schema);\n}\n\n/** Check if a schema was marked reactive. Used by Zod introspection for $binding<> prefix. */\nexport function isReactiveSchema(schema: unknown): boolean {\n  return typeof schema === \"object\" && schema !== null && reactiveSchemas.has(schema as object);\n}\n","import { object as zObject } from \"zod/v4\";\nimport * as z from \"zod/v4/core\";\nimport type { ComponentPromptSpec, PromptSpec, ToolSpec } from \"./parser/prompt\";\nimport { generatePrompt } from \"./parser/prompt\";\nimport type { LibraryJSONSchema } from \"./parser/types\";\nimport { isReactiveSchema } from \"./reactive\";\n\nexport type { LibraryJSONSchema } from \"./parser/types\";\n\n// ─── Schema ID tagging ─────────────────────────────────────────────────────\n// WeakMap-based naming for schemas. defineComponent tags component schemas\n// automatically. tagSchemaId is exported for non-component schemas\n// (e.g. ActionExpression) that also need friendly names in prompts.\n\nconst schemaIdTags = new WeakMap<object, string>();\n\n/**\n * Tag a schema with an ID for prompt signatures.\n * Use for non-component schemas that need friendly type names (e.g. ActionExpression).\n * This affects prompt output only, not JSON Schema $defs.\n */\nexport function tagSchemaId(schema: object, id: string): void {\n  schemaIdTags.set(schema, id);\n}\n\n// ─── Zod v3 detection ──────────────────────────────────────────────────────\n\nfunction assertV4Schema(schema: unknown, componentName: string): void {\n  if (schema != null && typeof schema === \"object\" && \"_def\" in schema && !(\"_zod\" in schema)) {\n    throw new Error(\n      `[OpenUI] Component \"${componentName}\" was defined with a Zod 3 schema. ` +\n        `OpenUI requires Zod 4 schemas. ` +\n        `If you're on zod@3.25+, import from \"zod/v4\" instead of \"zod\". ` +\n        `See: https://zod.dev/v4/versioning`,\n    );\n  }\n}\n\n// ─── Sub-component type ──────────────────────────────────────────────────────\n\n/**\n * Runtime shape of a parsed sub-component element as seen by parent renderers.\n */\nexport type SubComponentOf<P> = {\n  type: \"element\";\n  typeName: string;\n  props: P;\n  partial: boolean;\n};\n\n// ─── Renderer types (framework-generic) ──────────────────────────────────────\n\n/**\n * The props passed to every component renderer.\n *\n * Framework adapters narrow `RenderNode`:\n * - React:  RenderNode = ReactNode\n * - Svelte: RenderNode = Snippet<[unknown]>\n * - Vue:    RenderNode = VNode\n */\nexport interface ComponentRenderProps<P = Record<string, unknown>, RenderNode = unknown> {\n  props: P;\n  renderNode: (value: unknown) => RenderNode;\n  /** The statement ID from the parsed program (e.g., \"header\", \"prose1\"). Undefined for inline components. */\n  statementId?: string;\n}\n\n// ─── DefinedComponent (framework-generic) ────────────────────────────────────\n\n/**\n * A fully defined component. The `C` parameter represents the\n * framework-specific component/renderer type. lang-core never\n * inspects this value — it is stored opaquely and consumed\n * by the framework adapter's Renderer.\n */\nexport interface DefinedComponent<T extends z.$ZodObject = z.$ZodObject, C = unknown> {\n  name: string;\n  props: T;\n  description: string;\n  component: C;\n  /** Use in parent schemas: `z.array(ChildComponent.ref)` */\n  ref: z.$ZodType<SubComponentOf<T extends z.$ZodType<infer O> ? O : any>>;\n}\n\n/**\n * Define a component with name, schema, description, and renderer.\n * Tags the schema with the component name so it resolves in prompt\n * signatures even if the component isn't in every library.\n */\nexport function defineComponent<T extends z.$ZodObject, C>(config: {\n  name: string;\n  props: T;\n  description: string;\n  component: C;\n}): DefinedComponent<T, C> {\n  assertV4Schema(config.props, config.name);\n  schemaIdTags.set(config.props, config.name);\n  return {\n    ...config,\n    ref: config.props as unknown as z.$ZodType<\n      SubComponentOf<T extends z.$ZodType<infer O> ? O : any>\n    >,\n  };\n}\n\n// ─── Groups & Prompt Options ─────────────────────────────────────────────────\n\nexport interface ComponentGroup {\n  name: string;\n  components: string[];\n  notes?: string[];\n}\n\n/** Tool descriptor for prompt generation — simple string or rich ToolSpec. */\nexport type ToolDescriptor = string | ToolSpec;\n\nexport interface PromptOptions {\n  preamble?: string;\n  additionalRules?: string[];\n  /** Examples shown when no tools are present (static/layout patterns). */\n  examples?: string[];\n  /** Examples shown when tools ARE present (Query/Mutation patterns). Takes priority over `examples`. */\n  toolExamples?: string[];\n  /** Available tools for Query() — string names or rich ToolSpec descriptors injected into the prompt. */\n  tools?: ToolDescriptor[];\n  /** Enable edit-mode instructions in the prompt. */\n  editMode?: boolean;\n  /** Enable inline mode — LLM can respond with text + optional openui-lang fenced code. */\n  inlineMode?: boolean;\n  /** Enable Query(), Mutation(), @Run, tool workflow. Default: true if tools provided. */\n  toolCalls?: boolean;\n  /** Enable $variables, @Set, @Reset, interactive filters. Default: true if toolCalls. */\n  bindings?: boolean;\n}\n\n// ─── Zod introspection ──────────────────────────────────────────────────────\n\nfunction getZodDef(schema: unknown): any {\n  return (schema as any)?._zod?.def;\n}\n\nfunction getZodType(schema: unknown): string | undefined {\n  return getZodDef(schema)?.type;\n}\n\nfunction isOptionalType(schema: unknown): boolean {\n  const type = getZodType(schema);\n  return type === \"optional\" || type === \"default\" || type === \"nullable\";\n}\n\nfunction unwrap(schema: unknown): unknown {\n  let s = schema;\n  let def = getZodDef(s);\n  while (def?.type === \"optional\" || def?.type === \"default\" || def?.type === \"nullable\") {\n    s = def.innerType;\n    def = getZodDef(s);\n  }\n  return s;\n}\n\nfunction isArrayType(schema: unknown): boolean {\n  const s = unwrap(schema);\n  return getZodType(s) === \"array\";\n}\n\nfunction getArrayInnerType(schema: unknown): unknown | undefined {\n  const s = unwrap(schema);\n  const def = getZodDef(s);\n  if (def?.type === \"array\") return def.element ?? def.innerType;\n  return undefined;\n}\n\nfunction getEnumValues(schema: unknown): string[] | undefined {\n  const s = unwrap(schema);\n  const def = getZodDef(s);\n  if (def?.type !== \"enum\") return undefined;\n  if (Array.isArray(def.values)) return def.values;\n  if (def.entries && typeof def.entries === \"object\") return Object.keys(def.entries);\n  return undefined;\n}\n\ntype SchemaRegistry = ReturnType<typeof z.registry<{ id: string }>>;\n\nfunction getSchemaId(schema: unknown, reg: SchemaRegistry): string | undefined {\n  // Check per-library registry first\n  try {\n    const meta = reg.get(schema as z.$ZodType) as { id?: string } | undefined;\n    if (meta?.id) return meta.id;\n  } catch {\n    // not registered — fall through\n  }\n  // Fallback: WeakMap tags from defineComponent / tagSchemaId\n  if (typeof schema === \"object\" && schema !== null) {\n    return schemaIdTags.get(schema);\n  }\n  return undefined;\n}\n\nfunction getUnionOptions(schema: unknown): unknown[] | undefined {\n  const def = getZodDef(schema);\n  if (def?.type === \"union\" && Array.isArray(def.options)) return def.options;\n  return undefined;\n}\n\nfunction getObjectShape(schema: unknown): Record<string, unknown> | undefined {\n  const def = getZodDef(schema);\n  if (def?.type === \"object\" && def.shape && typeof def.shape === \"object\")\n    return def.shape as Record<string, unknown>;\n  return undefined;\n}\n\n/**\n * Resolve the type annotation for a schema field.\n * Returns a human-readable type string for the schema.\n * If the schema is marked reactive(), prefixes with \"$binding<...>\".\n */\nfunction resolveTypeAnnotation(schema: unknown, reg: SchemaRegistry): string | undefined {\n  const isReactive = isReactiveSchema(schema);\n  const inner = unwrap(schema);\n\n  const baseType = resolveBaseType(inner, reg);\n  if (!baseType) return undefined;\n  return isReactive ? `$binding<${baseType}>` : baseType;\n}\n\nfunction resolveBaseType(inner: unknown, reg: SchemaRegistry): string | undefined {\n  const directId = getSchemaId(inner, reg);\n  if (directId) return directId;\n\n  const unionOpts = getUnionOptions(inner);\n  if (unionOpts) {\n    const resolved = unionOpts.map((o) => resolveTypeAnnotation(o, reg));\n    const names = resolved.filter(Boolean) as string[];\n    if (names.length > 0) return names.join(\" | \");\n  }\n\n  if (isArrayType(inner)) {\n    const arrayInner = getArrayInnerType(inner);\n    if (!arrayInner) return undefined;\n    const innerType = resolveTypeAnnotation(arrayInner, reg);\n    if (innerType) {\n      const isUnion = getUnionOptions(unwrap(arrayInner)) !== undefined;\n      return isUnion ? `(${innerType})[]` : `${innerType}[]`;\n    }\n    return undefined;\n  }\n\n  const zodType = getZodType(inner);\n  if (zodType === \"string\") return \"string\";\n  if (zodType === \"number\") return \"number\";\n  if (zodType === \"boolean\") return \"boolean\";\n  if (zodType === \"any\") return \"any\";\n\n  if (zodType === \"record\") {\n    const def = getZodDef(inner);\n    const keyType = resolveTypeAnnotation(def?.keyType, reg) ?? \"string\";\n    const valueType = resolveTypeAnnotation(def?.valueType, reg) ?? \"any\";\n    return `Record<${keyType}, ${valueType}>`;\n  }\n\n  const enumVals = getEnumValues(inner);\n  if (enumVals) return enumVals.map((v) => `\"${v}\"`).join(\" | \");\n\n  if (zodType === \"literal\") {\n    const vals = getZodDef(inner)?.values;\n    if (Array.isArray(vals) && vals.length === 1) {\n      const v = vals[0];\n      return typeof v === \"string\" ? `\"${v}\"` : String(v);\n    }\n  }\n\n  const shape = getObjectShape(inner);\n  if (shape) {\n    const fields = Object.entries(shape).map(([name, fieldSchema]) => {\n      const opt = isOptionalType(fieldSchema) ? \"?\" : \"\";\n      const fieldType = resolveTypeAnnotation(fieldSchema as z.$ZodType, reg);\n      return fieldType ? `${name}${opt}: ${fieldType}` : `${name}${opt}`;\n    });\n    return `{${fields.join(\", \")}}`;\n  }\n\n  // Fallback for unrecognized Zod types (z.tuple, z.date, etc.)\n  // \"any\" is safer than undefined — the LLM sees `param: any` instead of bare `param`\n  return \"any\";\n}\n\n// ─── Field analysis & signature generation ──────────────────────────────────\n\ninterface FieldInfo {\n  name: string;\n  isOptional: boolean;\n  isArray: boolean;\n  typeAnnotation?: string;\n}\n\nfunction analyzeFields(shape: Record<string, z.$ZodType>, reg: SchemaRegistry): FieldInfo[] {\n  return Object.entries(shape).map(([name, schema]) => ({\n    name,\n    isOptional: isOptionalType(schema),\n    isArray: isArrayType(schema),\n    typeAnnotation: resolveTypeAnnotation(schema, reg),\n  }));\n}\n\nfunction buildSignature(componentName: string, fields: FieldInfo[]): string {\n  const params = fields.map((f) => {\n    if (f.typeAnnotation) {\n      return f.isOptional ? `${f.name}?: ${f.typeAnnotation}` : `${f.name}: ${f.typeAnnotation}`;\n    }\n    if (f.isArray) {\n      return f.isOptional ? `[${f.name}]?` : `[${f.name}]`;\n    }\n    return f.isOptional ? `${f.name}?` : f.name;\n  });\n  return `${componentName}(${params.join(\", \")})`;\n}\n\nfunction buildComponentSpecs(\n  components: Record<string, DefinedComponent<any, any>>,\n  reg: SchemaRegistry,\n): Record<string, ComponentPromptSpec> {\n  const specs: Record<string, ComponentPromptSpec> = {};\n  for (const [name, def] of Object.entries(components)) {\n    const fields = analyzeFields(def.props.shape, reg);\n    specs[name] = {\n      signature: buildSignature(name, fields),\n      description: def.description,\n    };\n  }\n  return specs;\n}\n\n// ─── Library ────────────────────────────────────────────────────────────────\n\nexport interface Library<C = unknown> {\n  readonly components: Record<string, DefinedComponent<any, C>>;\n  readonly componentGroups: ComponentGroup[] | undefined;\n  readonly root: string | undefined;\n\n  prompt(options?: PromptOptions): string;\n  toSpec(): PromptSpec;\n  toJSONSchema(): LibraryJSONSchema;\n}\n\nexport interface LibraryDefinition<C = unknown> {\n  components: DefinedComponent<any, C>[];\n  componentGroups?: ComponentGroup[];\n  root?: string;\n}\n\n/**\n * Create a component library from an array of defined components.\n */\nexport function createLibrary<C = unknown>(input: LibraryDefinition<C>): Library<C> {\n  const componentsRecord: Record<string, DefinedComponent<any, C>> = {};\n  const reg = z.registry<{ id: string }>();\n\n  for (const comp of input.components) {\n    reg.add(comp.props as z.$ZodType, { id: comp.name });\n    componentsRecord[comp.name] = comp;\n  }\n\n  if (input.root && !componentsRecord[input.root]) {\n    const available = Object.keys(componentsRecord).join(\", \");\n    throw new Error(\n      `[createLibrary] Root component \"${input.root}\" was not found in components. Available components: ${available}`,\n    );\n  }\n\n  const library: Library<C> = {\n    components: componentsRecord,\n    componentGroups: input.componentGroups,\n    root: input.root,\n\n    prompt(options?: PromptOptions): string {\n      const spec: PromptSpec = {\n        root: input.root,\n        components: buildComponentSpecs(componentsRecord, reg),\n        componentGroups: input.componentGroups,\n        ...options,\n      };\n      return generatePrompt(spec);\n    },\n\n    toSpec(): PromptSpec {\n      return {\n        root: input.root,\n        components: buildComponentSpecs(componentsRecord, reg),\n        componentGroups: input.componentGroups,\n      };\n    },\n\n    toJSONSchema(): LibraryJSONSchema {\n      const combinedSchema = zObject(\n        Object.fromEntries(Object.entries(componentsRecord).map(([k, v]) => [k, v.props])) as any,\n      );\n      return z.toJSONSchema(combinedSchema, { metadata: reg }) as LibraryJSONSchema;\n    },\n  };\n\n  return library;\n}\n","import type { ASTNode } from \"./ast\";\n\n/**\n * The JSON Schema document produced by `library.toJSONSchema()`.\n * All component schemas live in `$defs`, keyed by component name.\n */\nexport interface LibraryJSONSchema {\n  $defs?: Record<\n    string,\n    {\n      properties?: Record<string, unknown>;\n      required?: string[];\n    }\n  >;\n}\n\nexport interface ParamDef {\n  /** Parameter name, e.g. \"title\", \"columns\". */\n  name: string;\n  /** Whether the parameter is required by the component. */\n  required: boolean;\n  /** Default value from JSON Schema — used when the required field is missing/null. */\n  defaultValue?: unknown;\n}\n\n/** Internal parameter map for positional-arg to named-prop mapping. */\nexport type ParamMap = Map<string, { params: ParamDef[] }>;\n\n/**\n * A fully resolved component node from the parser.\n *\n * The parser converts openui-lang text into a tree of these nodes.\n * Each node represents one component invocation with its positional\n * arguments mapped into named `props` via the library's Zod key order.\n */\nexport interface ElementNode {\n  type: \"element\";\n  /** Source variable name (e.g. \"header\" from `header = TextContent(...)`). Undefined for inline components. */\n  statementId?: string;\n  /** Component name as defined in the library (e.g. \"Table\", \"BarChart\"). */\n  typeName: string;\n  /** Named props produced by positional-to-named mapping in the parser. */\n  props: Record<string, unknown>;\n  /**\n   * True when the parser hasn't received all tokens for this node yet\n   * (streaming in progress).\n   */\n  partial: boolean;\n  /**\n   * False when all props are static literals — evaluation can be skipped.\n   * Undefined is treated as true (dynamic) for backward compatibility.\n   */\n  hasDynamicProps?: boolean;\n}\n\nexport function isElementNode(value: unknown): value is ElementNode {\n  if (!value || typeof value !== \"object\" || Array.isArray(value)) return false;\n  const node = value as Record<string, unknown>;\n  return (\n    node.type === \"element\" &&\n    typeof node.typeName === \"string\" &&\n    typeof node.props === \"object\" &&\n    node.props !== null &&\n    typeof node.partial === \"boolean\"\n  );\n}\n\n/**\n * Validation error codes for schema-related issues.\n */\nexport type ValidationErrorCode =\n  | \"missing-required\"\n  | \"null-required\"\n  | \"unknown-component\"\n  | \"inline-reserved\"\n  | \"excess-args\";\n\n/**\n * A prop validation error. Components with missing required props are\n * dropped from the output tree and errors are recorded here.\n */\nexport interface ValidationError {\n  /** Machine-readable error code. */\n  code: ValidationErrorCode;\n  /** Component type name, e.g. \"Header\", \"BarChart\". */\n  component: string;\n  /** JSON Pointer path within the props object, e.g. \"/title\", \"\". */\n  path: string;\n  /** Human-readable error message. */\n  message: string;\n  /** Statement name that triggered the error (e.g. \"header\", \"chart\"). */\n  statementId?: string;\n}\n\n/**\n * Error sources across the openui-lang pipeline.\n */\nexport type OpenUIErrorSource = \"parser\" | \"runtime\" | \"query\" | \"mutation\";\n\n/**\n * Machine-readable error codes for the openui-lang pipeline.\n *\n * - Parser: \"unknown-component\", \"missing-required\", \"null-required\", \"inline-reserved\",\n *   \"parse-exception\", \"parse-failed\"\n * - Runtime: \"runtime-error\" (prop evaluation), \"render-error\" (React render)\n * - Query/Mutation: \"tool-not-found\", \"tool-error\", \"mcp-error\"\n */\nexport type OpenUIErrorCode =\n  | ValidationErrorCode\n  | \"runtime-error\"\n  | \"render-error\"\n  | \"parse-exception\"\n  | \"parse-failed\"\n  | \"tool-not-found\"\n  | \"tool-error\"\n  | \"mcp-error\";\n\n/**\n * Structured, LLM-friendly error from the openui-lang pipeline.\n *\n * Designed for an automated correction loop: send these to the LLM so it can\n * generate patches. Only includes errors that are fixable by changing the\n * openui-lang code — transient streaming errors, network failures, and tool\n * execution errors are excluded.\n */\nexport interface OpenUIError {\n  /** Where the error originated. */\n  source: OpenUIErrorSource;\n  /** Machine-readable error code. */\n  code: OpenUIErrorCode;\n  /** Human/LLM-readable description of what went wrong. */\n  message: string;\n  /** Statement name (e.g. \"header\", \"metrics\") — tells the LLM which statement to patch. */\n  statementId?: string;\n  /** Component type name (e.g. \"BarChart\", \"Query\"). */\n  component?: string;\n  /** Prop path (e.g. \"/title\"). */\n  path?: string;\n  /** Tool name for query/mutation errors (e.g. \"get_users\", \"create_item\"). */\n  toolName?: string;\n  /** Actionable fix context for the LLM (e.g. available components, correct signature). */\n  hint?: string;\n}\n\n/**\n * Built-in action types for host app events.\n */\nexport enum BuiltinActionType {\n  ContinueConversation = \"continue_conversation\",\n  OpenUrl = \"open_url\",\n}\n\n/**\n * A single step in an ActionPlan.\n * Step type values match ACTION_STEPS in builtins.ts (single source of truth).\n */\nexport type ActionStep =\n  | { type: \"run\"; statementId: string; refType: \"query\" | \"mutation\" }\n  | { type: \"continue_conversation\"; message: string; context?: string }\n  | { type: \"open_url\"; url: string }\n  | { type: \"set\"; target: string; valueAST: ASTNode }\n  | { type: \"reset\"; targets: string[] };\n\n/**\n * An ordered sequence of steps to execute when a button is clicked.\n * Produced by evaluating an Action() expression at runtime.\n */\nexport interface ActionPlan {\n  steps: ActionStep[];\n}\n\n/**\n * Structured action event fired by interactive components.\n */\nexport interface ActionEvent {\n  /** Action type. See `BuiltinActionType` for built-in types. */\n  type: BuiltinActionType | (string & {});\n  /** Action-specific params (e.g. { url } for OpenUrl, custom params for Custom). */\n  params: Record<string, unknown>;\n  /** Human-readable label for the action (displayed as user message in chat). */\n  humanFriendlyMessage: string;\n  /** Raw form state at the time of the action — all field values. */\n  formState?: Record<string, unknown>;\n  /** The form name that triggered this action, if any. */\n  formName?: string;\n}\n\n/**\n * Extracted info about a Query() call from the parsed program.\n */\nexport interface QueryStatementInfo {\n  /** Statement name that holds this query (e.g. \"metrics\"). */\n  statementId: string;\n  /** First arg AST — the tool name (should evaluate to a string). */\n  toolAST: ASTNode | null;\n  /** Second arg AST — the arguments object (may contain $var refs). */\n  argsAST: ASTNode | null;\n  /** Third arg AST — default data returned before fetch resolves. */\n  defaultsAST: ASTNode | null;\n  /** Fourth arg AST — refresh interval in seconds. */\n  refreshAST: ASTNode | null;\n  /** Pre-computed $variable deps from argsAST (extracted at parse time). */\n  deps?: string[];\n  /** False while the Query() call is still being streamed. */\n  complete: boolean;\n}\n\n/**\n * Extracted info about a Mutation() call from the parsed program.\n */\nexport interface MutationStatementInfo {\n  /** Statement name that holds this mutation (e.g. \"createResult\"). */\n  statementId: string;\n  /** First arg AST — the tool name (should evaluate to a string). */\n  toolAST: ASTNode | null;\n  /** Second arg AST — the arguments object (may contain $var refs). */\n  argsAST: ASTNode | null;\n}\n\n/**\n * The output of a single `parser.parse(text)` call.\n *\n * During streaming, each chunk produces a new ParseResult as the\n * accumulated text is re-parsed. The `root` progressively resolves\n * from null → partial tree → complete tree.\n */\nexport interface ParseResult {\n  /** The root ElementNode (typically a Root component), or null if parsing hasn't produced one yet. */\n  root: ElementNode | null;\n  meta: {\n    /** True if the parser detected truncated/incomplete input. */\n    incomplete: boolean;\n    /** Names of references used but not yet defined (dropped as null in output). */\n    unresolved: string[];\n    /** Names of value statements defined but not reachable from root. Excludes $state, Query, and Mutation declarations. */\n    orphaned: string[];\n    /** Total number of `identifier = Expression` statements parsed. */\n    statementCount: number;\n    /**\n     * Prop validation errors. Components with missing required props are\n     * redacted (dropped as null) and listed here.\n     */\n    errors: ValidationError[];\n  };\n  /** $variable declarations — maps \"$varName\" to its materialized default value. */\n  stateDeclarations: Record<string, unknown>;\n  /** Extracted Query() calls with their positional args as AST nodes. */\n  queryStatements: QueryStatementInfo[];\n  /** Extracted Mutation() calls with their positional args as AST nodes. */\n  mutationStatements: MutationStatementInfo[];\n}\n","// ─────────────────────────────────────────────────────────────────────────────\n// AST node types for openui-lang\n// ─────────────────────────────────────────────────────────────────────────────\n\n/**\n * Discriminated union representing every value that can appear in an\n * openui-lang expression. The `k` field is the discriminant.\n *\n * Literal & structural nodes:\n * - `Comp`       — a component call: `Header(\"Hello\", \"Subtitle\")`\n * - `Str`        — a string literal: `\"hello\"`\n * - `Num`        — a number literal: `42` or `3.14`\n * - `Bool`       — a boolean literal: `true` or `false`\n * - `Null`       — the null literal\n * - `Arr`        — an array: `[a, b, c]`\n * - `Obj`        — an object: `{ key: value }`\n * - `Ref`        — a reference to another statement: `myTable`\n * - `Ph`         — a placeholder for an unresolvable reference\n *\n * Reactive & expression nodes:\n * - `StateRef`   — a reactive state variable reference: `$count`\n * - `RuntimeRef` — a reference resolved at runtime (e.g. Query results)\n * - `BinOp`      — a binary operation: `a + b`, `x == y`\n * - `UnaryOp`    — a unary operation: `!flag`\n * - `Ternary`    — a conditional expression: `cond ? a : b`\n * - `Member`     — dot member access: `obj.field`\n * - `Index`      — bracket index access: `arr[0]`\n * - `Assign`     — state assignment: `$count = $count + 1`\n */\nexport type ASTNode =\n  | { k: \"Comp\"; name: string; args: ASTNode[]; mappedProps?: Record<string, ASTNode> }\n  | { k: \"Str\"; v: string }\n  | { k: \"Num\"; v: number }\n  | { k: \"Bool\"; v: boolean }\n  | { k: \"Null\" }\n  | { k: \"Arr\"; els: ASTNode[] }\n  | { k: \"Obj\"; entries: [string, ASTNode][] }\n  | { k: \"Ref\"; n: string }\n  | { k: \"Ph\"; n: string }\n  | { k: \"StateRef\"; n: string }\n  | { k: \"RuntimeRef\"; n: string; refType: \"query\" | \"mutation\" }\n  | { k: \"BinOp\"; op: string; left: ASTNode; right: ASTNode }\n  | { k: \"UnaryOp\"; op: string; operand: ASTNode }\n  | { k: \"Ternary\"; cond: ASTNode; then: ASTNode; else: ASTNode }\n  | { k: \"Member\"; obj: ASTNode; field: string }\n  | { k: \"Index\"; obj: ASTNode; index: ASTNode }\n  | { k: \"Assign\"; target: string; value: ASTNode };\n\n/**\n * Subset of ASTNode that must be preserved for runtime evaluation.\n * These nodes survive parser lowering and are resolved by the evaluator.\n */\nexport type RuntimeExprNode = Extract<\n  ASTNode,\n  | { k: \"StateRef\" }\n  | { k: \"RuntimeRef\" }\n  | { k: \"BinOp\" }\n  | { k: \"UnaryOp\" }\n  | { k: \"Ternary\" }\n  | { k: \"Member\" }\n  | { k: \"Index\" }\n  | { k: \"Assign\" }\n>;\n\n/** Type guard for runtime expression nodes that survive parser lowering. */\nexport function isRuntimeExpr(node: ASTNode): node is RuntimeExprNode {\n  switch (node.k) {\n    case \"StateRef\":\n    case \"RuntimeRef\":\n    case \"BinOp\":\n    case \"UnaryOp\":\n    case \"Ternary\":\n    case \"Member\":\n    case \"Index\":\n    case \"Assign\":\n      return true;\n    default:\n      return false;\n  }\n}\n\n/** Valid AST discriminant values. */\nconst AST_KINDS = new Set([\n  \"Comp\",\n  \"Ref\",\n  \"StateRef\",\n  \"RuntimeRef\",\n  \"BinOp\",\n  \"UnaryOp\",\n  \"Ternary\",\n  \"Member\",\n  \"Index\",\n  \"Assign\",\n  \"Str\",\n  \"Num\",\n  \"Bool\",\n  \"Null\",\n  \"Arr\",\n  \"Obj\",\n  \"Ph\",\n]);\n\n/** Check if a value is an AST node (has a valid `k` discriminant field). */\nexport function isASTNode(value: unknown): value is ASTNode {\n  if (!value || typeof value !== \"object\" || Array.isArray(value)) return false;\n  return AST_KINDS.has((value as Record<string, unknown>).k as string);\n}\n\nexport function walkAST(node: ASTNode, visit: (node: ASTNode) => void): void {\n  const walk = (current: ASTNode) => {\n    visit(current);\n\n    switch (current.k) {\n      case \"Comp\":\n        current.args.forEach(walk);\n        Object.values(current.mappedProps ?? {}).forEach(walk);\n        break;\n      case \"Arr\":\n        current.els.forEach(walk);\n        break;\n      case \"Obj\":\n        current.entries.forEach(([, value]) => walk(value));\n        break;\n      case \"BinOp\":\n        walk(current.left);\n        walk(current.right);\n        break;\n      case \"UnaryOp\":\n        walk(current.operand);\n        break;\n      case \"Ternary\":\n        walk(current.cond);\n        walk(current.then);\n        walk(current.else);\n        break;\n      case \"Member\":\n        walk(current.obj);\n        break;\n      case \"Index\":\n        walk(current.obj);\n        walk(current.index);\n        break;\n      case \"Assign\":\n        walk(current.value);\n        break;\n    }\n  };\n\n  walk(node);\n}\n\n// ─── Typed Statement model ─────────────────────────────────────────────────\n// Classification determined at parse time from token type + expression shape.\n// Eliminates id.startsWith(\"$\") and ast.name === \"Query\" hacks downstream.\n\n/** Tool/Query call shape extracted from Comp nodes */\nexport interface CallNode {\n  callee: string;\n  args: ASTNode[];\n}\n\n/** Typed statement — kind known at parse time */\nexport type Statement =\n  | { kind: \"value\"; id: string; expr: ASTNode }\n  | { kind: \"state\"; id: string; init: ASTNode }\n  | { kind: \"query\"; id: string; call: CallNode; expr: ASTNode; deps?: string[] }\n  | { kind: \"mutation\"; id: string; call: CallNode; expr: ASTNode };\n","// ─────────────────────────────────────────────────────────────────────────────\n// Pratt precedence expression parser for openui-lang\n// ─────────────────────────────────────────────────────────────────────────────\n\nimport type { ASTNode } from \"./ast\";\nimport { isBuiltin } from \"./builtins\";\nimport { T, type Token } from \"./tokens\";\n\n// ── Precedence levels (from spec Section 2.11) ─────────────────────────────\nconst PREC_TERNARY = 1;\nconst PREC_OR = 2;\nconst PREC_AND = 3;\nconst PREC_EQ = 4;\nconst PREC_CMP = 5;\nconst PREC_ADD = 6;\nconst PREC_MUL = 7;\nconst PREC_UNARY = 8;\nconst PREC_MEMBER = 9;\n\n/**\n * Parse a token array into an AST node using a Pratt (top-down operator\n * precedence) parser.\n */\nexport function parseExpression(tokens: Token[]): ASTNode {\n  let pos = 0;\n\n  const cur = (): Token => tokens[pos] ?? { t: T.EOF };\n  const adv = (): Token => {\n    const tok = cur();\n    pos++;\n    return tok;\n  };\n  const eat = (kind: T): void => {\n    if (cur().t === kind) pos++;\n  };\n\n  // ── Infix precedence lookup ─────────────────────────────────────────────\n  function getInfixPrec(tok: Token): number {\n    switch (tok.t) {\n      case T.Question:\n        return PREC_TERNARY;\n      case T.Or:\n        return PREC_OR;\n      case T.And:\n        return PREC_AND;\n      case T.EqEq:\n      case T.NotEq:\n        return PREC_EQ;\n      case T.Greater:\n      case T.Less:\n      case T.GreaterEq:\n      case T.LessEq:\n        return PREC_CMP;\n      case T.Plus:\n      case T.Minus:\n        return PREC_ADD;\n      case T.Star:\n      case T.Slash:\n      case T.Percent:\n        return PREC_MUL;\n      case T.Dot:\n      case T.LBrack:\n        return PREC_MEMBER;\n      default:\n        return 0;\n    }\n  }\n\n  // ── Main Pratt loop ─────────────────────────────────────────────────────\n  function parseExpr(minPrec: number = 0): ASTNode {\n    let left = parsePrefix();\n    while (getInfixPrec(cur()) > minPrec) {\n      left = parseInfix(left);\n    }\n    return left;\n  }\n\n  // ── Prefix / atoms ─────────────────────────────────────────────────────\n  function parsePrefix(): ASTNode {\n    const tok = cur();\n\n    // String literal\n    if (tok.t === T.Str) {\n      adv();\n      return { k: \"Str\", v: tok.v as string };\n    }\n\n    // Number literal\n    if (tok.t === T.Num) {\n      adv();\n      return { k: \"Num\", v: tok.v as number };\n    }\n\n    // Boolean literals\n    if (tok.t === T.True) {\n      adv();\n      return { k: \"Bool\", v: true };\n    }\n    if (tok.t === T.False) {\n      adv();\n      return { k: \"Bool\", v: false };\n    }\n\n    // Null literal\n    if (tok.t === T.Null) {\n      adv();\n      return { k: \"Null\" };\n    }\n\n    // Array\n    if (tok.t === T.LBrack) return parseArr();\n\n    // Object\n    if (tok.t === T.LBrace) return parseObj();\n\n    // State variable — may be assignment or reference\n    if (tok.t === T.StateVar) {\n      const name = tok.v as string;\n      adv();\n      // Check for assignment: $var = expr (Equals, NOT EqEq)\n      if (cur().t === T.Equals) {\n        adv(); // consume =\n        const value = parseExpr(0);\n        return { k: \"Assign\", target: name, value };\n      }\n      return { k: \"StateRef\", n: name };\n    }\n\n    // PascalCase — component call or reference\n    if (tok.t === T.Type) {\n      const name = tok.v as string;\n      // Builtins (Count, Each, Set, Run, etc.) require @-prefix — only Action is exempt\n      if (tokens[pos + 1]?.t === T.LParen && (!isBuiltin(name) || name === \"Action\"))\n        return parseComp();\n      adv();\n      return { k: \"Ref\", n: name };\n    }\n\n    // @-prefixed builtin call: @Count(...), @Each(...), @Set(...), etc.\n    if (tok.t === T.BuiltinCall) {\n      if (tokens[pos + 1]?.t === T.LParen) return parseComp();\n      adv();\n      return { k: \"Ref\", n: tok.v as string };\n    }\n\n    // Lowercase identifier — reference\n    if (tok.t === T.Ident) {\n      adv();\n      return { k: \"Ref\", n: tok.v as string };\n    }\n\n    // Unary NOT\n    if (tok.t === T.Not) {\n      adv();\n      return { k: \"UnaryOp\", op: \"!\", operand: parseExpr(PREC_UNARY) };\n    }\n\n    // Unary negation\n    if (tok.t === T.Minus) {\n      adv();\n      return { k: \"UnaryOp\", op: \"-\", operand: parseExpr(PREC_UNARY) };\n    }\n\n    // Grouped expression\n    if (tok.t === T.LParen) {\n      adv(); // skip (\n      const inner = parseExpr(0);\n      eat(T.RParen);\n      return inner;\n    }\n\n    // Unknown token — skip and return Null\n    adv();\n    return { k: \"Null\" };\n  }\n\n  // ── Infix / postfix ────────────────────────────────────────────────────\n  function parseInfix(left: ASTNode): ASTNode {\n    const tok = cur();\n\n    // Arithmetic: + -\n    if (tok.t === T.Plus) {\n      adv();\n      return { k: \"BinOp\", op: \"+\", left, right: parseExpr(PREC_ADD) };\n    }\n    if (tok.t === T.Minus) {\n      adv();\n      return { k: \"BinOp\", op: \"-\", left, right: parseExpr(PREC_ADD) };\n    }\n\n    // Arithmetic: * / %\n    if (tok.t === T.Star) {\n      adv();\n      return { k: \"BinOp\", op: \"*\", left, right: parseExpr(PREC_MUL) };\n    }\n    if (tok.t === T.Slash) {\n      adv();\n      return { k: \"BinOp\", op: \"/\", left, right: parseExpr(PREC_MUL) };\n    }\n    if (tok.t === T.Percent) {\n      adv();\n      return { k: \"BinOp\", op: \"%\", left, right: parseExpr(PREC_MUL) };\n    }\n\n    // Equality: == !=\n    if (tok.t === T.EqEq) {\n      adv();\n      return { k: \"BinOp\", op: \"==\", left, right: parseExpr(PREC_EQ) };\n    }\n    if (tok.t === T.NotEq) {\n      adv();\n      return { k: \"BinOp\", op: \"!=\", left, right: parseExpr(PREC_EQ) };\n    }\n\n    // Comparison: > < >= <=\n    if (tok.t === T.Greater) {\n      adv();\n      return { k: \"BinOp\", op: \">\", left, right: parseExpr(PREC_CMP) };\n    }\n    if (tok.t === T.Less) {\n      adv();\n      return { k: \"BinOp\", op: \"<\", left, right: parseExpr(PREC_CMP) };\n    }\n    if (tok.t === T.GreaterEq) {\n      adv();\n      return { k: \"BinOp\", op: \">=\", left, right: parseExpr(PREC_CMP) };\n    }\n    if (tok.t === T.LessEq) {\n      adv();\n      return { k: \"BinOp\", op: \"<=\", left, right: parseExpr(PREC_CMP) };\n    }\n\n    // Logical AND\n    if (tok.t === T.And) {\n      adv();\n      return { k: \"BinOp\", op: \"&&\", left, right: parseExpr(PREC_AND) };\n    }\n\n    // Logical OR\n    if (tok.t === T.Or) {\n      adv();\n      return { k: \"BinOp\", op: \"||\", left, right: parseExpr(PREC_OR) };\n    }\n\n    // Ternary: cond ? then : else (right-associative)\n    if (tok.t === T.Question) {\n      adv(); // consume ?\n      const then = parseExpr(0);\n      eat(T.Colon);\n      const els = parseExpr(0); // right-assoc: parse at lowest prec\n      return { k: \"Ternary\", cond: left, then, else: els };\n    }\n\n    // Member access: obj.field\n    if (tok.t === T.Dot) {\n      adv(); // consume .\n      const fieldTok = cur();\n      const field =\n        fieldTok.t === T.Ident ||\n        fieldTok.t === T.Type ||\n        fieldTok.t === T.Str ||\n        fieldTok.t === T.Num\n          ? (adv(), String(fieldTok.v))\n          : fieldTok.t === T.StateVar\n            ? (adv(), (fieldTok.v as string).replace(/^\\$/, \"\"))\n            : (adv(), \"?\");\n      return { k: \"Member\", obj: left, field };\n    }\n\n    // Index access: obj[expr]\n    if (tok.t === T.LBrack) {\n      adv(); // consume [\n      const index = parseExpr(0);\n      eat(T.RBrack);\n      return { k: \"Index\", obj: left, index };\n    }\n\n    // Fallback — should not be reached if getInfixPrec is correct\n    return left;\n  }\n\n  // ── Compound parsers ───────────────────────────────────────────────────\n\n  /** Parse `TypeName(arg1, arg2, ...)` */\n  function parseComp(): ASTNode {\n    const name = cur().v as string;\n    adv(); // consume TypeName\n    eat(T.LParen);\n    const args: ASTNode[] = [];\n    while (cur().t !== T.RParen && cur().t !== T.EOF) {\n      args.push(parseExpr(0));\n      if (cur().t === T.Comma) adv();\n    }\n    eat(T.RParen);\n    return { k: \"Comp\", name, args };\n  }\n\n  /** Parse `[elem1, elem2, ...]` */\n  function parseArr(): ASTNode {\n    adv(); // skip [\n    const els: ASTNode[] = [];\n    while (cur().t !== T.RBrack && cur().t !== T.EOF) {\n      els.push(parseExpr(0));\n      if (cur().t === T.Comma) adv();\n    }\n    eat(T.RBrack);\n    return { k: \"Arr\", els };\n  }\n\n  /** Parse `{ key: value, ... }` */\n  function parseObj(): ASTNode {\n    adv(); // skip {\n    const entries: [string, ASTNode][] = [];\n    while (cur().t !== T.RBrace && cur().t !== T.EOF) {\n      const kt = cur();\n      const key =\n        kt.t === T.Ident || kt.t === T.Str || kt.t === T.Type || kt.t === T.Num\n          ? (adv(), String(kt.v))\n          : kt.t === T.StateVar\n            ? (adv(), (kt.v as string).replace(/^\\$/, \"\"))\n            : (adv(), \"?\");\n      eat(T.Colon);\n      entries.push([key, parseExpr(0)]);\n      if (cur().t === T.Comma) adv();\n    }\n    eat(T.RBrace);\n    return { k: \"Obj\", entries };\n  }\n\n  return parseExpr(0);\n}\n","// ─────────────────────────────────────────────────────────────────────────────\n// Lexer for openui-lang\n// ─────────────────────────────────────────────────────────────────────────────\n\nimport { T, type Token } from \"./tokens\";\n\n/**\n * Tokenize an openui-lang source string into a flat token array.\n *\n * Handles all token types: identifiers, literals, operators,\n * state variables ($name), dot access, ternary.\n */\nexport function tokenize(src: string): Token[] {\n  const tokens: Token[] = [];\n  let i = 0;\n  const n = src.length;\n\n  while (i < n) {\n    // Skip horizontal whitespace (not newlines — they're significant)\n    while (i < n && (src[i] === \" \" || src[i] === \"\\t\" || src[i] === \"\\r\")) i++;\n    if (i >= n) break;\n\n    const c = src[i];\n\n    // ── Newline ────────────────────────────────────────────────────────\n    if (c === \"\\n\") {\n      tokens.push({ t: T.Newline });\n      i++;\n      continue;\n    }\n\n    // ── Single-character punctuation (brackets, comma, colon) ─────────\n    if (c === \"(\") {\n      tokens.push({ t: T.LParen });\n      i++;\n      continue;\n    }\n    if (c === \")\") {\n      tokens.push({ t: T.RParen });\n      i++;\n      continue;\n    }\n    if (c === \"[\") {\n      tokens.push({ t: T.LBrack });\n      i++;\n      continue;\n    }\n    if (c === \"]\") {\n      tokens.push({ t: T.RBrack });\n      i++;\n      continue;\n    }\n    if (c === \"{\") {\n      tokens.push({ t: T.LBrace });\n      i++;\n      continue;\n    }\n    if (c === \"}\") {\n      tokens.push({ t: T.RBrace });\n      i++;\n      continue;\n    }\n    if (c === \",\") {\n      tokens.push({ t: T.Comma });\n      i++;\n      continue;\n    }\n    if (c === \":\") {\n      tokens.push({ t: T.Colon });\n      i++;\n      continue;\n    }\n\n    // ── Equals / EqEq ─────────────────────────────────────────────────\n    if (c === \"=\") {\n      if (i + 1 < n && src[i + 1] === \"=\") {\n        tokens.push({ t: T.EqEq });\n        i += 2;\n      } else {\n        tokens.push({ t: T.Equals });\n        i++;\n      }\n      continue;\n    }\n\n    // ── Not / NotEq ───────────────────────────────────────────────────\n    if (c === \"!\") {\n      if (i + 1 < n && src[i + 1] === \"=\") {\n        tokens.push({ t: T.NotEq });\n        i += 2;\n      } else {\n        tokens.push({ t: T.Not });\n        i++;\n      }\n      continue;\n    }\n\n    // ── Greater / GreaterEq ───────────────────────────────────────────\n    if (c === \">\") {\n      if (i + 1 < n && src[i + 1] === \"=\") {\n        tokens.push({ t: T.GreaterEq });\n        i += 2;\n      } else {\n        tokens.push({ t: T.Greater });\n        i++;\n      }\n      continue;\n    }\n\n    // ── Less / LessEq ────────────────────────────────────────────────\n    if (c === \"<\") {\n      if (i + 1 < n && src[i + 1] === \"=\") {\n        tokens.push({ t: T.LessEq });\n        i += 2;\n      } else {\n        tokens.push({ t: T.Less });\n        i++;\n      }\n      continue;\n    }\n\n    // ── And (&&) ──────────────────────────────────────────────────────\n    if (c === \"&\") {\n      if (i + 1 < n && src[i + 1] === \"&\") {\n        tokens.push({ t: T.And });\n        i += 2;\n      } else {\n        tokens.push({ t: T.And });\n        i++;\n      }\n      continue;\n    }\n\n    // ── Or (||) ───────────────────────────────────────────────────────\n    if (c === \"|\") {\n      if (i + 1 < n && src[i + 1] === \"|\") {\n        tokens.push({ t: T.Or });\n        i += 2;\n      } else {\n        tokens.push({ t: T.Or });\n        i++;\n      }\n      continue;\n    }\n\n    // ── Dot ───────────────────────────────────────────────────────────\n    if (c === \".\") {\n      tokens.push({ t: T.Dot });\n      i++;\n      continue;\n    }\n\n    // ── Question ──────────────────────────────────────────────────────\n    if (c === \"?\") {\n      tokens.push({ t: T.Question });\n      i++;\n      continue;\n    }\n\n    // ── Plus ──────────────────────────────────────────────────────────\n    if (c === \"+\") {\n      tokens.push({ t: T.Plus });\n      i++;\n      continue;\n    }\n\n    // ── Star ──────────────────────────────────────────────────────────\n    if (c === \"*\") {\n      tokens.push({ t: T.Star });\n      i++;\n      continue;\n    }\n\n    // ── Slash ─────────────────────────────────────────────────────────\n    if (c === \"/\") {\n      tokens.push({ t: T.Slash });\n      i++;\n      continue;\n    }\n\n    // ── Percent ───────────────────────────────────────────────────────\n    if (c === \"%\") {\n      tokens.push({ t: T.Percent });\n      i++;\n      continue;\n    }\n\n    // ── String literal: \"...\" ─────────────────────────────────────────\n    if (c === '\"') {\n      const start = i;\n      i++; // skip opening quote\n      let isClosed = false;\n      // Fast-forward to the closing quote, respecting escapes\n      while (i < n) {\n        if (src[i] === \"\\\\\") {\n          i += 2; // skip backslash and the escaped character\n        } else if (src[i] === '\"') {\n          i++; // include the closing quote\n          isClosed = true;\n          break;\n        } else {\n          i++;\n        }\n      }\n      const rawString = src.slice(start, i);\n      try {\n        // Let JavaScript's native JSON parser handle all unescaping (\\n, \\t, \\uXXXX, etc.)\n        // If the string is incomplete (streaming), we add a closing quote to parse what we have so far.\n        const validJsonString = isClosed ? rawString : rawString + '\"';\n        tokens.push({ t: T.Str, v: JSON.parse(validJsonString) });\n      } catch {\n        // Fallback if JSON.parse fails (e.g., malformed unicode escape during streaming)\n        // Strip the quotes and return the raw text so the UI doesn't crash\n        const stripped = rawString.replace(/^\"|\"$/g, \"\");\n        tokens.push({ t: T.Str, v: stripped });\n      }\n      continue;\n    }\n\n    // ── String literal: '...' (single quotes) ────────────────────────\n    if (c === \"'\") {\n      i++; // skip opening quote\n      let result = \"\";\n      let isClosed = false;\n      while (i < n) {\n        if (src[i] === \"\\\\\") {\n          i++; // skip backslash\n          if (i < n) {\n            const esc = src[i];\n            if (esc === \"'\") result += \"'\";\n            else if (esc === \"\\\\\") result += \"\\\\\";\n            else if (esc === \"n\") result += \"\\n\";\n            else if (esc === \"t\") result += \"\\t\";\n            else result += esc; // pass through other escaped chars\n            i++;\n          }\n        } else if (src[i] === \"'\") {\n          i++; // skip closing quote\n          isClosed = true;\n          break;\n        } else {\n          result += src[i];\n          i++;\n        }\n      }\n      void isClosed; // consumed for streaming parity with double-quote path\n      tokens.push({ t: T.Str, v: result });\n      continue;\n    }\n\n    // ── Minus: negative number literal or subtraction operator ────────\n    if (c === \"-\") {\n      const prev = tokens.length > 0 ? tokens[tokens.length - 1] : null;\n      const afterValue =\n        prev != null &&\n        (prev.t === T.Num ||\n          prev.t === T.Str ||\n          prev.t === T.Ident ||\n          prev.t === T.Type ||\n          prev.t === T.RParen ||\n          prev.t === T.RBrack ||\n          prev.t === T.True ||\n          prev.t === T.False ||\n          prev.t === T.Null ||\n          prev.t === T.StateVar ||\n          prev.t === T.BuiltinCall);\n\n      if (!afterValue && i + 1 < n && src[i + 1] >= \"0\" && src[i + 1] <= \"9\") {\n        // Negative number literal — fall through to number parsing below\n      } else {\n        // Binary subtraction operator (or unary minus handled by expression parser)\n        tokens.push({ t: T.Minus });\n        i++;\n        continue;\n      }\n    }\n\n    // ── Number literal: 42, -3, 1.5, 1e10 ────────────────────────────\n    const isDigit = c >= \"0\" && c <= \"9\";\n    const isNegDigit = c === \"-\" && i + 1 < n && src[i + 1] >= \"0\" && src[i + 1] <= \"9\";\n    if (isDigit || isNegDigit) {\n      const start = i;\n      if (src[i] === \"-\") i++; // optional minus\n      while (i < n && src[i] >= \"0\" && src[i] <= \"9\") i++; // integer part\n      if (i < n && src[i] === \".\" && i + 1 < n && src[i + 1] >= \"0\" && src[i + 1] <= \"9\") {\n        // optional decimal — only if a digit follows the dot\n        i++;\n        while (i < n && src[i] >= \"0\" && src[i] <= \"9\") i++;\n      }\n      if (i < n && (src[i] === \"e\" || src[i] === \"E\")) {\n        // optional exponent\n        i++;\n        if (i < n && (src[i] === \"+\" || src[i] === \"-\")) i++;\n        while (i < n && src[i] >= \"0\" && src[i] <= \"9\") i++;\n      }\n      tokens.push({ t: T.Num, v: +src.slice(start, i) });\n      continue;\n    }\n\n    // ── State variable: $identifier ───────────────────────────────────\n    if (\n      c === \"$\" &&\n      i + 1 < n &&\n      ((src[i + 1] >= \"a\" && src[i + 1] <= \"z\") ||\n        (src[i + 1] >= \"A\" && src[i + 1] <= \"Z\") ||\n        src[i + 1] === \"_\")\n    ) {\n      const start = i;\n      i++; // skip $\n      while (\n        i < n &&\n        ((src[i] >= \"a\" && src[i] <= \"z\") ||\n          (src[i] >= \"A\" && src[i] <= \"Z\") ||\n          (src[i] >= \"0\" && src[i] <= \"9\") ||\n          src[i] === \"_\")\n      )\n        i++;\n      tokens.push({ t: T.StateVar, v: src.slice(start, i) });\n      continue;\n    }\n\n    // ── Keyword or identifier ─────────────────────────────────────────\n    const isAlpha = (c >= \"a\" && c <= \"z\") || (c >= \"A\" && c <= \"Z\") || c === \"_\";\n    if (isAlpha) {\n      const start = i;\n      while (\n        i < n &&\n        ((src[i] >= \"a\" && src[i] <= \"z\") ||\n          (src[i] >= \"A\" && src[i] <= \"Z\") ||\n          (src[i] >= \"0\" && src[i] <= \"9\") ||\n          src[i] === \"_\")\n      )\n        i++;\n      const word = src.slice(start, i);\n      if (word === \"true\") {\n        tokens.push({ t: T.True });\n        continue;\n      }\n      if (word === \"false\") {\n        tokens.push({ t: T.False });\n        continue;\n      }\n      if (word === \"null\") {\n        tokens.push({ t: T.Null });\n        continue;\n      }\n      // PascalCase → component type name; lowercase → variable reference\n      const kind = c >= \"A\" && c <= \"Z\" ? T.Type : T.Ident;\n      tokens.push({ t: kind, v: word });\n      continue;\n    }\n\n    // ── Builtin call: @identifier ───────────────────────────────────\n    if (\n      c === \"@\" &&\n      i + 1 < n &&\n      ((src[i + 1] >= \"a\" && src[i + 1] <= \"z\") ||\n        (src[i + 1] >= \"A\" && src[i + 1] <= \"Z\") ||\n        src[i + 1] === \"_\")\n    ) {\n      i++; // skip @\n      const start = i;\n      while (\n        i < n &&\n        ((src[i] >= \"a\" && src[i] <= \"z\") ||\n          (src[i] >= \"A\" && src[i] <= \"Z\") ||\n          (src[i] >= \"0\" && src[i] <= \"9\") ||\n          src[i] === \"_\")\n      )\n        i++;\n      tokens.push({ t: T.BuiltinCall, v: src.slice(start, i) });\n      continue;\n    }\n\n    i++; // skip any other character (e.g. #, emojis)\n  }\n\n  tokens.push({ t: T.EOF });\n  return tokens;\n}\n","// ─────────────────────────────────────────────────────────────────────────────\n// Schema-aware materialization — single-pass lowering\n// ─────────────────────────────────────────────────────────────────────────────\n\nimport type { ASTNode } from \"./ast\";\nimport { isASTNode, isRuntimeExpr } from \"./ast\";\nimport { isBuiltin, isReservedCall, LAZY_BUILTINS, RESERVED_CALLS } from \"./builtins\";\nimport { isElementNode, type ParamMap, type ValidationError } from \"./types\";\n\n/**\n * Recursively check if a prop value contains any AST nodes that need runtime\n * evaluation. Walks into arrays, ElementNode children, and plain objects.\n */\nexport function containsDynamicValue(v: unknown): boolean {\n  if (v == null || typeof v !== \"object\") return false;\n  if (isASTNode(v)) return true;\n  if (Array.isArray(v)) return v.some(containsDynamicValue);\n  if (isElementNode(v)) {\n    return Object.values(v.props).some(containsDynamicValue);\n  }\n  const obj = v as Record<string, unknown>;\n  return Object.values(obj).some(containsDynamicValue);\n}\n\nexport interface MaterializeCtx {\n  syms: Map<string, ASTNode>;\n  cat: ParamMap | undefined;\n  errors: ValidationError[];\n  unres: string[];\n  visited: Set<string>;\n  partial: boolean;\n  /** Tracks which statement is currently being materialized (for error attribution). */\n  currentStatementId?: string;\n  /** Statement IDs not yet reached — delete as they're touched. Remaining = orphaned. */\n  unreached?: Set<string>;\n}\n\n/**\n * Resolve a Ref node: inline from symbol table, detect cycles, emit RuntimeRef\n * for Query/Mutation declarations. Shared by materializeValue and materializeExpr.\n */\nfunction resolveRef(name: string, ctx: MaterializeCtx, mode: \"value\" | \"expr\"): unknown | ASTNode {\n  if (ctx.visited.has(name)) {\n    ctx.unres.push(name);\n    return mode === \"expr\" ? { k: \"Ph\", n: name } : null;\n  }\n  if (!ctx.syms.has(name)) {\n    ctx.unres.push(name);\n    return mode === \"expr\" ? { k: \"Ph\", n: name } : null;\n  }\n  const target = ctx.syms.get(name)!;\n  ctx.unreached?.delete(name);\n  // Query/Mutation declarations → RuntimeRef (resolved at runtime by evaluator)\n  if (target.k === \"Comp\" && isReservedCall(target.name)) {\n    const refType =\n      target.name === RESERVED_CALLS.Mutation ? (\"mutation\" as const) : (\"query\" as const);\n    return { k: \"RuntimeRef\", n: name, refType };\n  }\n  ctx.visited.add(name);\n  const prevStatementId = ctx.currentStatementId;\n  ctx.currentStatementId = name;\n  try {\n    const result = mode === \"value\" ? materializeValue(target, ctx) : materializeExpr(target, ctx);\n    // Tag ElementNode with its source statement name\n    if (mode === \"value\" && isElementNode(result)) {\n      result.statementId = name;\n    }\n    return result;\n  } finally {\n    ctx.currentStatementId = prevStatementId;\n    ctx.visited.delete(name);\n  }\n}\n\n/**\n * If node is a lazy builtin like Each(arr, varName, template), temporarily\n * scope the iterator variable during materialization so template refs resolve.\n * Returns the materialized Comp node, or null if not a lazy builtin.\n */\nfunction materializeLazyBuiltin(\n  node: ASTNode & { k: \"Comp\" },\n  ctx: MaterializeCtx,\n  scopedRefs: ReadonlySet<string>,\n): ASTNode | null {\n  if (!LAZY_BUILTINS.has(node.name) || node.args.length < 3) return null;\n  const varArg = node.args[1];\n  const varName = varArg.k === \"Ref\" ? varArg.n : varArg.k === \"Str\" ? varArg.v : null;\n  if (!varName) return null;\n\n  const nextScopedRefs = new Set(scopedRefs);\n  nextScopedRefs.add(varName);\n  // Skip args[1] (the iterator declaration) but preserve scoped refs elsewhere.\n  const recursedArgs = node.args.map((a, i) =>\n    i === 1 ? a : materializeExprInternal(a, ctx, nextScopedRefs),\n  );\n  return { ...node, args: recursedArgs };\n}\n\nfunction materializeExprInternal(\n  node: ASTNode,\n  ctx: MaterializeCtx,\n  scopedRefs: ReadonlySet<string>,\n): ASTNode {\n  switch (node.k) {\n    case \"Ref\":\n      return scopedRefs.has(node.n) ? node : (resolveRef(node.n, ctx, \"expr\") as ASTNode);\n\n    case \"Ph\":\n      return node;\n\n    case \"Comp\": {\n      const lazy = materializeLazyBuiltin(node, ctx, scopedRefs);\n      if (lazy) return lazy;\n      const recursedArgs = node.args.map((a) => materializeExprInternal(a, ctx, scopedRefs));\n      // Builtins, reserved calls, and action calls: recurse args, keep as-is\n      if (isBuiltin(node.name) || isReservedCall(node.name)) {\n        return { ...node, args: recursedArgs };\n      }\n      // Catalog component: add mappedProps for the evaluator\n      const def = ctx.cat?.get(node.name);\n      if (def) {\n        const mappedProps: Record<string, ASTNode> = {};\n        for (let i = 0; i < def.params.length && i < recursedArgs.length; i++) {\n          mappedProps[def.params[i].name] = recursedArgs[i];\n        }\n        return { ...node, args: recursedArgs, mappedProps };\n      }\n      // Unknown component in expression: push error (same as value path)\n      ctx.errors.push({\n        code: \"unknown-component\",\n        component: node.name,\n        path: \"\",\n        message: `Unknown component \"${node.name}\" — not found in catalog or builtins`,\n        statementId: ctx.currentStatementId,\n      });\n      return { ...node, args: recursedArgs };\n    }\n\n    case \"Arr\":\n      return { ...node, els: node.els.map((e) => materializeExprInternal(e, ctx, scopedRefs)) };\n    case \"Obj\":\n      return {\n        ...node,\n        entries: node.entries.map(\n          ([k, v]) => [k, materializeExprInternal(v, ctx, scopedRefs)] as [string, ASTNode],\n        ),\n      };\n    case \"BinOp\":\n      return {\n        ...node,\n        left: materializeExprInternal(node.left, ctx, scopedRefs),\n        right: materializeExprInternal(node.right, ctx, scopedRefs),\n      };\n    case \"UnaryOp\":\n      return { ...node, operand: materializeExprInternal(node.operand, ctx, scopedRefs) };\n    case \"Ternary\":\n      return {\n        ...node,\n        cond: materializeExprInternal(node.cond, ctx, scopedRefs),\n        then: materializeExprInternal(node.then, ctx, scopedRefs),\n        else: materializeExprInternal(node.else, ctx, scopedRefs),\n      };\n    case \"Member\":\n      return { ...node, obj: materializeExprInternal(node.obj, ctx, scopedRefs) };\n    case \"Index\":\n      return {\n        ...node,\n        obj: materializeExprInternal(node.obj, ctx, scopedRefs),\n        index: materializeExprInternal(node.index, ctx, scopedRefs),\n      };\n    case \"Assign\":\n      return { ...node, value: materializeExprInternal(node.value, ctx, scopedRefs) };\n\n    // Literals, StateRef, RuntimeRef — pass through unchanged\n    default:\n      return node;\n  }\n}\n\n/**\n * Normalize an AST node for use inside runtime expressions.\n * Resolves Refs, adds mappedProps to catalog Comp nodes.\n * Returns ASTNode — structure preserved for runtime evaluation by the evaluator.\n */\nexport function materializeExpr(node: ASTNode, ctx: MaterializeCtx): ASTNode {\n  return materializeExprInternal(node, ctx, new Set());\n}\n\n/**\n * Schema-aware materialization: resolves refs, normalizes catalog component args\n * to named props, validates required props, applies defaults, converts literals\n * to plain values, and preserves runtime expressions as AST nodes — all in a\n * single recursive traversal.\n *\n * Returns:\n *   - ElementNode for catalog/unknown components\n *   - ASTNode for builtins and runtime expression nodes\n *   - Plain values for literals, arrays, objects\n *   - null for placeholders\n */\nexport function materializeValue(node: ASTNode, ctx: MaterializeCtx): unknown {\n  switch (node.k) {\n    // ── Ref resolution ───────────────────────────────────────────────────\n    case \"Ref\":\n      return resolveRef(node.n, ctx, \"value\");\n\n    // ── Literals → plain values ──────────────────────────────────────────\n    case \"Str\":\n      return node.v;\n    case \"Num\":\n      return node.v;\n    case \"Bool\":\n      return node.v;\n    case \"Null\":\n      return null;\n    case \"Ph\":\n      return null;\n\n    // ── Collections ──────────────────────────────────────────────────────\n    case \"Arr\": {\n      const items: unknown[] = [];\n      for (const e of node.els) {\n        // Drop unresolved placeholders from arrays\n        if (e.k === \"Ph\") continue;\n        const value = materializeValue(e, ctx);\n        // Drop null entries from component/ref resolution (incomplete props, unresolved refs, unknown components)\n        if (value === null && (e.k === \"Comp\" || e.k === \"Ref\")) continue;\n        items.push(value);\n      }\n      return items;\n    }\n    case \"Obj\": {\n      const o: Record<string, unknown> = {};\n      for (const [k, v] of node.entries) o[k] = materializeValue(v, ctx);\n      return o;\n    }\n\n    // ── Component nodes ──────────────────────────────────────────────────\n    case \"Comp\": {\n      const { name, args } = node;\n\n      // Builtins (Sum, Count, Filter, Action, etc.) → preserve as ASTNode for runtime\n      if (isBuiltin(name)) {\n        const lazy = materializeLazyBuiltin(node, ctx, new Set());\n        if (lazy) return lazy;\n        return { ...node, args: args.map((a) => materializeExpr(a, ctx)) };\n      }\n\n      // Inline Query/Mutation (not from a statement-level declaration) → validation error\n      if (isReservedCall(name)) {\n        ctx.errors.push({\n          code: \"inline-reserved\",\n          component: name,\n          path: \"\",\n          message: `${name}() must be declared as a top-level statement, not used inline as a value`,\n          statementId: ctx.currentStatementId,\n        });\n        return null;\n      }\n\n      const def = ctx.cat?.get(name);\n      const props: Record<string, unknown> = {};\n\n      if (def) {\n        // Catalog component: map positional args → named props\n        for (let i = 0; i < def.params.length && i < args.length; i++) {\n          props[def.params[i].name] = materializeValue(args[i], ctx);\n        }\n\n        // Report excess positional args (extra args are silently dropped)\n        if (args.length > def.params.length) {\n          const excessCount = args.length - def.params.length;\n          ctx.errors.push({\n            code: \"excess-args\",\n            component: name,\n            path: \"\",\n            message: `${name} takes ${def.params.length} arg(s), got ${args.length} (${excessCount} excess dropped)`,\n            statementId: ctx.currentStatementId,\n          });\n        }\n\n        // Validate required props — try defaultValue first before dropping\n        const missingRequired = def.params.filter(\n          (p) => p.required && (!(p.name in props) || props[p.name] === null),\n        );\n        if (missingRequired.length) {\n          const stillInvalid = missingRequired.filter((p) => {\n            if (p.defaultValue !== undefined) {\n              props[p.name] = p.defaultValue;\n              return false;\n            }\n            return true;\n          });\n          if (stillInvalid.length) {\n            for (const p of stillInvalid) {\n              const isNull = p.name in props;\n              ctx.errors.push({\n                code: isNull ? \"null-required\" : \"missing-required\",\n                component: name,\n                path: `/${p.name}`,\n                message: isNull\n                  ? `required field \"${p.name}\" cannot be null`\n                  : `missing required field \"${p.name}\"`,\n                statementId: ctx.currentStatementId,\n              });\n            }\n            return null;\n          }\n        }\n      } else if (!isBuiltin(name) && !isReservedCall(name)) {\n        // Unknown component: error and drop from tree\n        ctx.errors.push({\n          code: \"unknown-component\",\n          component: name,\n          path: \"\",\n          message: `Unknown component \"${name}\" — not found in catalog or builtins`,\n          statementId: ctx.currentStatementId,\n        });\n        return null;\n      }\n\n      const hasDynamicProps = Object.values(props).some((v) => containsDynamicValue(v));\n      return { type: \"element\", typeName: name, props, partial: ctx.partial, hasDynamicProps };\n    }\n\n    // ── Runtime expression nodes → preserve as ASTNode, normalize children ─\n    default: {\n      if (isRuntimeExpr(node)) {\n        return materializeExpr(node, ctx);\n      }\n      // Unreachable for well-formed AST, but preserve the value defensively.\n      return node;\n    }\n  }\n}\n","// ─────────────────────────────────────────────────────────────────────────────\n// Statement splitter for openui-lang\n// ─────────────────────────────────────────────────────────────────────────────\n\nimport { T, type Token } from \"./tokens\";\n\nexport interface RawStmt {\n  id: string;\n  /** Token type of the LHS identifier — used to classify statement kind */\n  idTokenType: T;\n  tokens: Token[];\n}\n\n/**\n * Auto-close unclosed strings and brackets so that partial/streaming input\n * can be parsed without syntax errors.\n */\nexport function autoClose(input: string): { text: string; wasIncomplete: boolean } {\n  const stack: string[] = [];\n  let inStr: false | '\"' | \"'\" = false;\n  let esc = false;\n\n  for (let i = 0; i < input.length; i++) {\n    const c = input[i];\n    if (esc) {\n      esc = false;\n      continue;\n    }\n    if (c === \"\\\\\" && inStr) {\n      esc = true;\n      continue;\n    }\n    if (inStr) {\n      if (c === inStr) inStr = false;\n      continue;\n    }\n    if (c === '\"' || c === \"'\") {\n      inStr = c;\n      continue;\n    }\n    if (c === \"(\" || c === \"[\" || c === \"{\") stack.push(c);\n    else if (c === \")\" && stack[stack.length - 1] === \"(\") stack.pop();\n    else if (c === \"]\" && stack[stack.length - 1] === \"[\") stack.pop();\n    else if (c === \"}\" && stack[stack.length - 1] === \"{\") stack.pop();\n  }\n\n  const wasIncomplete = !!inStr || stack.length > 0;\n  if (!wasIncomplete) return { text: input, wasIncomplete: false };\n\n  let out = input;\n  if (inStr) {\n    if (esc) out += \"\\\\\";\n    out += inStr; // close with matching quote\n  }\n  for (let j = stack.length - 1; j >= 0; j--)\n    out += stack[j] === \"(\" ? \")\" : stack[j] === \"[\" ? \"]\" : \"}\";\n\n  return { text: out, wasIncomplete: true };\n}\n\n/**\n * Splits the flat token stream into individual statements.\n *\n * Each statement has the form `identifier = expression`. Statements are\n * separated by newlines at depth 0 (newlines inside brackets are ignored).\n *\n * Accepts `Ident`, `Type`, and `StateVar` as statement identifiers.\n * For StateVar, the id is the full token value including $ (e.g., \"$count\").\n *\n * Invalid lines (no `=`, or no identifier) are silently skipped.\n */\nexport function split(tokens: Token[]): RawStmt[] {\n  const stmts: RawStmt[] = [];\n  let pos = 0;\n\n  while (pos < tokens.length) {\n    // Skip blank lines\n    while (pos < tokens.length && tokens[pos].t === T.Newline) pos++;\n    if (pos >= tokens.length || tokens[pos].t === T.EOF) break;\n\n    // Expect: Ident|Type|StateVar = expression\n    const tok = tokens[pos];\n    if (tok.t !== T.Ident && tok.t !== T.Type && tok.t !== T.StateVar) {\n      while (pos < tokens.length && tokens[pos].t !== T.Newline && tokens[pos].t !== T.EOF) pos++;\n      continue;\n    }\n    const id = tok.v as string;\n    const idTokenType = tok.t;\n    pos++;\n\n    // Must be followed by `=`\n    if (pos >= tokens.length || tokens[pos].t !== T.Equals) {\n      while (pos < tokens.length && tokens[pos].t !== T.Newline && tokens[pos].t !== T.EOF) pos++;\n      continue;\n    }\n    pos++;\n\n    // Collect expression tokens until a depth-0 newline or EOF.\n    // Track both bracket depth and ternary depth so that multiline\n    // ternary expressions (condition on one line, ? ... : on the next)\n    // are not incorrectly split into separate statements.\n    const expr: Token[] = [];\n    let depth = 0;\n    let ternaryDepth = 0;\n    while (pos < tokens.length && tokens[pos].t !== T.EOF) {\n      const tt = tokens[pos].t;\n      if (tt === T.Newline && depth <= 0 && ternaryDepth <= 0) {\n        // Before breaking, look ahead past whitespace/newlines to see if\n        // the next meaningful token is `?` or `:` — if so, the ternary\n        // continues on the next line and we should NOT split here.\n        let peek = pos + 1;\n        while (peek < tokens.length && tokens[peek].t === T.Newline) peek++;\n        const nextT = peek < tokens.length ? tokens[peek].t : T.EOF;\n        if (nextT === T.Question || (nextT === T.Colon && ternaryDepth > 0)) {\n          // Ternary continuation — skip the newline and keep collecting\n          pos++;\n          continue;\n        }\n        break; // statement boundary\n      }\n      if (tt === T.Newline) {\n        pos++;\n        continue;\n      } // newline inside bracket/ternary — skip\n      if (tt === T.LParen || tt === T.LBrack || tt === T.LBrace) depth++;\n      else if ((tt === T.RParen || tt === T.RBrack || tt === T.RBrace) && depth > 0) depth--;\n      // Track ternary ? and : at bracket depth 0 (colons inside {} are object key separators)\n      else if (tt === T.Question && depth === 0) ternaryDepth++;\n      else if (tt === T.Colon && depth === 0 && ternaryDepth > 0) ternaryDepth--;\n      expr.push(tokens[pos++]);\n    }\n\n    if (expr.length) stmts.push({ id, idTokenType, tokens: expr });\n  }\n\n  return stmts;\n}\n","import type { ASTNode, Statement } from \"./ast\";\nimport { isASTNode, walkAST } from \"./ast\";\nimport { isBuiltin, RESERVED_CALLS } from \"./builtins\";\nimport { parseExpression } from \"./expressions\";\nimport { tokenize } from \"./lexer\";\nimport { materializeValue, type MaterializeCtx } from \"./materialize\";\nimport { autoClose, split, type RawStmt } from \"./statements\";\nimport { T } from \"./tokens\";\nimport {\n  isElementNode,\n  type LibraryJSONSchema,\n  type MutationStatementInfo,\n  type ParamMap,\n  type ParseResult,\n  type QueryStatementInfo,\n  type ValidationError,\n} from \"./types\";\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Result building\n// ─────────────────────────────────────────────────────────────────────────────\n\nfunction emptyResult(incomplete = true): ParseResult {\n  return {\n    root: null,\n    meta: {\n      incomplete,\n      unresolved: [],\n      orphaned: [],\n      statementCount: 0,\n      errors: [],\n    },\n    stateDeclarations: {},\n    queryStatements: [],\n    mutationStatements: [],\n  };\n}\n\n/**\n * Walk an AST node to collect all StateRef ($variable) names referenced\n * within. Used at parse time to pre-compute per-query state dependencies.\n */\nexport function collectQueryDeps(node: unknown): string[] {\n  if (!isASTNode(node)) return [];\n  const refs = new Set<string>();\n  walkAST(node, (current) => {\n    if (current.k === \"StateRef\") refs.add(current.n);\n  });\n  return [...refs];\n}\n\n/**\n * Classify a raw statement + parsed expression into a typed Statement.\n * Determined at parse time from token type + expression shape.\n */\nfunction classifyStatement(raw: RawStmt, expr: ASTNode): Statement {\n  // Query(...) → query declaration — check BEFORE $var to handle `$foo = Query(...)` correctly\n  if (expr.k === \"Comp\" && expr.name === RESERVED_CALLS.Query) {\n    const deps = collectQueryDeps(expr.args[1]);\n    return {\n      kind: \"query\",\n      id: raw.id,\n      call: { callee: RESERVED_CALLS.Query, args: expr.args },\n      expr,\n      deps: deps.length > 0 ? deps : undefined,\n    };\n  }\n  // Mutation(...) → mutation declaration\n  if (expr.k === \"Comp\" && expr.name === RESERVED_CALLS.Mutation) {\n    return {\n      kind: \"mutation\",\n      id: raw.id,\n      call: { callee: RESERVED_CALLS.Mutation, args: expr.args },\n      expr,\n    };\n  }\n  // $variables → state declaration\n  if (raw.idTokenType === T.StateVar) {\n    return { kind: \"state\", id: raw.id, init: expr };\n  }\n  // Everything else → value declaration\n  return { kind: \"value\", id: raw.id, expr };\n}\n\n/**\n * Extract typed statements from the symbol table.\n * State defaults are materialized to plain values (no raw AST in output).\n */\nfunction extractStatements(\n  stmts: Statement[],\n  ctx: MaterializeCtx,\n): {\n  stateDeclarations: Record<string, unknown>;\n  queryStatements: QueryStatementInfo[];\n  mutationStatements: MutationStatementInfo[];\n} {\n  const stateDeclarations: Record<string, unknown> = {};\n  const queryStatements: QueryStatementInfo[] = [];\n  const mutationStatements: MutationStatementInfo[] = [];\n\n  for (const stmt of stmts) {\n    switch (stmt.kind) {\n      case \"state\":\n        stateDeclarations[stmt.id] = materializeValue(stmt.init, ctx);\n        break;\n      case \"query\":\n        queryStatements.push({\n          statementId: stmt.id,\n          toolAST: stmt.call.args[0] ?? null,\n          argsAST: stmt.call.args[1] ?? null,\n          defaultsAST: stmt.call.args[2] ?? null,\n          refreshAST: stmt.call.args[3] ?? null,\n          deps: stmt.deps,\n          complete: true,\n        });\n        break;\n      case \"mutation\":\n        mutationStatements.push({\n          statementId: stmt.id,\n          toolAST: stmt.call.args[0] ?? null,\n          argsAST: stmt.call.args[1] ?? null,\n        });\n        break;\n    }\n  }\n\n  // Auto-declare: any $var referenced in code but not explicitly declared → null default.\n  // collectQueryDeps already walks AST for StateRef nodes — reuse it here.\n  for (const stmt of stmts) {\n    const nodes =\n      stmt.kind === \"state\"\n        ? [stmt.init]\n        : stmt.kind === \"value\"\n          ? [stmt.expr]\n          : stmt.kind === \"query\" || stmt.kind === \"mutation\"\n            ? stmt.call.args\n            : [];\n    for (const node of nodes) {\n      for (const dep of collectQueryDeps(node)) {\n        if (!(dep in stateDeclarations)) {\n          stateDeclarations[dep] = null;\n        }\n      }\n    }\n  }\n\n  return { stateDeclarations, queryStatements, mutationStatements };\n}\n\nconst DEFAULT_ROOT_STATEMENT_ID = \"root\";\n\nfunction isComponentStatement(\n  stmt: Statement,\n): stmt is Extract<Statement, { kind: \"value\" }> & { expr: Extract<ASTNode, { k: \"Comp\" }> } {\n  return (\n    stmt.kind === \"value\" &&\n    stmt.expr.k === \"Comp\" &&\n    !isBuiltin(stmt.expr.name) &&\n    stmt.expr.name !== RESERVED_CALLS.Query &&\n    stmt.expr.name !== RESERVED_CALLS.Mutation\n  );\n}\n\nfunction pickEntryId(\n  stmtMap: Map<string, Statement>,\n  typedStmts: Statement[],\n  firstId: string,\n  rootName?: string,\n): string {\n  if (stmtMap.has(DEFAULT_ROOT_STATEMENT_ID)) return DEFAULT_ROOT_STATEMENT_ID;\n  if (rootName && stmtMap.has(rootName)) return rootName;\n\n  const preferredComponent = rootName\n    ? typedStmts.find((stmt) => isComponentStatement(stmt) && stmt.expr.name === rootName)\n    : undefined;\n  if (preferredComponent) return preferredComponent.id;\n\n  const firstComponent = typedStmts.find(isComponentStatement);\n  return firstComponent?.id ?? firstId;\n}\n\nfunction buildResult(\n  stmtMap: Map<string, Statement>,\n  typedStmts: Statement[],\n  firstId: string,\n  wasIncomplete: boolean,\n  stmtCount: number,\n  cat: ParamMap | undefined,\n  rootName?: string,\n): ParseResult {\n  const entryId = pickEntryId(stmtMap, typedStmts, firstId, rootName);\n  if (!stmtMap.has(entryId)) return emptyResult(wasIncomplete);\n\n  const syms = new Map<string, ASTNode>();\n  for (const [id, stmt] of stmtMap) {\n    syms.set(id, stmt.kind === \"state\" ? stmt.init : stmt.expr);\n  }\n  const unres: string[] = [];\n  const errors: ValidationError[] = [];\n  // Track orphaned: start with value statement IDs, delete as they're reached.\n  // Exclude root, state ($var), query, and mutation declarations — they're consumed separately.\n  const unreached = new Set<string>();\n  for (const [id, stmt] of stmtMap) {\n    if (id === entryId) continue;\n    if (stmt.kind === \"state\" || stmt.kind === \"query\" || stmt.kind === \"mutation\") continue;\n    unreached.add(id);\n  }\n  const ctx: MaterializeCtx = {\n    syms,\n    cat,\n    errors,\n    unres,\n    visited: new Set(),\n    partial: wasIncomplete,\n    currentStatementId: entryId,\n    unreached,\n  };\n  const materialized = materializeValue(syms.get(entryId)!, ctx);\n\n  const root = isElementNode(materialized) ? materialized : null;\n  if (root) root.statementId = entryId;\n\n  const { stateDeclarations, queryStatements, mutationStatements } = extractStatements(\n    typedStmts,\n    ctx,\n  );\n\n  const orphaned = [...unreached];\n\n  return {\n    root,\n    meta: {\n      incomplete: wasIncomplete,\n      unresolved: unres,\n      orphaned,\n      statementCount: stmtCount,\n      errors: errors,\n    },\n    stateDeclarations,\n    queryStatements,\n    mutationStatements,\n  };\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Public API\n// ─────────────────────────────────────────────────────────────────────────────\n\nfunction skipString(input: string, start: number): number {\n  if (input[start] !== '\"') return start;\n  let i = start + 1;\n  while (i < input.length) {\n    const c = input[i];\n    if (c === \"\\\\\") {\n      i += 2; // skip escape character and the escaped character\n    } else if (c === '\"') {\n      return i + 1; // return index after the closing quote\n    } else {\n      i++;\n    }\n  }\n  return i; // return length if string was unclosed\n}\n\n/** Extract code from markdown fences, or return as-is if no fences found.\n *  String-context-aware: skips ``` inside double-quoted strings. */\nexport function stripFences(input: string): string {\n  const blocks: string[] = [];\n  let i = 0;\n\n  while (i < input.length) {\n    // Scan for opening ``` while tracking string context\n    let fenceStart = -1;\n    while (i < input.length) {\n      const nextI = skipString(input, i);\n      if (nextI > i) {\n        i = nextI;\n        continue;\n      }\n\n      const c = input[i];\n      if (\n        c === \"`\" &&\n        i + 1 < input.length &&\n        input[i + 1] === \"`\" &&\n        i + 2 < input.length &&\n        input[i + 2] === \"`\"\n      ) {\n        fenceStart = i;\n        break;\n      }\n      i++;\n    }\n\n    if (fenceStart === -1) break;\n\n    // Skip language tag until newline\n    let j = fenceStart + 3;\n    while (j < input.length && input[j] !== \"\\n\") j++;\n    if (j >= input.length) {\n      // No newline after opening fence (streaming) — take everything after fence marker + lang tag\n      blocks.push(input.slice(fenceStart + 3).replace(/^[^\\n]*\\n?/, \"\"));\n      i = input.length;\n      break;\n    }\n    j++; // skip the newline\n\n    // Scan for closing ``` while tracking string context\n    let closePos = -1;\n    let k = j;\n    while (k < input.length) {\n      const nextK = skipString(input, k);\n      if (nextK > k) {\n        k = nextK;\n        continue;\n      }\n      const c = input[k];\n      if (\n        c === \"`\" &&\n        k + 1 < input.length &&\n        input[k + 1] === \"`\" &&\n        k + 2 < input.length &&\n        input[k + 2] === \"`\"\n      ) {\n        closePos = k;\n        break;\n      }\n      k++;\n    }\n\n    if (closePos !== -1) {\n      blocks.push(input.slice(j, closePos));\n      i = closePos + 3;\n    } else {\n      // No closing fence found (streaming) — take everything after opening fence\n      blocks.push(input.slice(j));\n      i = input.length;\n    }\n  }\n\n  if (blocks.length > 0) return blocks.join(\"\\n\");\n\n  // Fallback: if input starts with ``` but wasn't matched (e.g. no newline after fence)\n  if (input.startsWith(\"```\")) {\n    let j = 3;\n    while (j < input.length && input[j] !== \"\\n\") j++;\n    const start = j < input.length ? j + 1 : 3;\n    // Try to strip trailing ```\n    const body = input.slice(start);\n    const trailingFence = body.lastIndexOf(\"```\");\n    if (trailingFence !== -1) {\n      return body.slice(0, trailingFence);\n    }\n    return body;\n  }\n\n  return input;\n}\n\n/** Strip // and # line comments outside of strings (handles both \" and ' delimiters). */\nfunction stripComments(input: string): string {\n  let inStr: false | '\"' | \"'\" = false;\n  return input\n    .split(\"\\n\")\n    .map((line) => {\n      for (let i = 0; i < line.length; i++) {\n        const c = line[i];\n        if (inStr) {\n          if (c === \"\\\\\" && i + 1 < line.length) {\n            i++; // skip escaped char\n            continue;\n          }\n          if (c === inStr) inStr = false;\n          continue;\n        }\n        if (c === '\"' || c === \"'\") {\n          inStr = c;\n          continue;\n        }\n        // // style comments\n        if (c === \"/\" && line[i + 1] === \"/\") {\n          return line.substring(0, i).trimEnd();\n        }\n        // # style comments (Python/YAML style — LLMs sometimes use these)\n        if (c === \"#\") {\n          return line.substring(0, i).trimEnd();\n        }\n      }\n      return line;\n    })\n    .join(\"\\n\");\n}\n\n/** Clean LLM response: strip fences, comments, whitespace. */\nfunction preprocess(input: string): string {\n  return stripComments(stripFences(input.trim())).trim();\n}\n\n/**\n * Parse a complete openui-lang string in one pass.\n *\n * @param input  - Full openui-lang source text (may be partial/streaming)\n * @param cat    - Param map for positional-arg → named-prop mapping\n * @returns      ParseResult with root ElementNode (or null) and metadata\n */\nexport function parse(input: string, cat: ParamMap, rootName?: string): ParseResult {\n  const trimmed = preprocess(input);\n  if (!trimmed) return emptyResult();\n\n  const { text, wasIncomplete } = autoClose(trimmed);\n  const stmts = split(tokenize(text));\n  if (!stmts.length) return emptyResult(wasIncomplete);\n\n  const stmtMap = new Map<string, Statement>();\n  let firstId = \"\";\n  for (const s of stmts) {\n    const expr = parseExpression(s.tokens);\n    const stmt = classifyStatement(s, expr);\n    stmtMap.set(s.id, stmt);\n    if (!firstId) firstId = s.id;\n  }\n  // Derive from map to deduplicate — Map.set overwrites duplicates\n  const typedStmts = [...stmtMap.values()];\n\n  return buildResult(stmtMap, typedStmts, firstId, wasIncomplete, stmtMap.size, cat, rootName);\n}\n\nexport interface StreamParser {\n  /** Feed the next SSE/stream chunk and get the latest ParseResult. */\n  push(chunk: string): ParseResult;\n  /** Set the full text — diffs against internal buffer, pushes only the delta.\n   *  Resets automatically if the text was replaced (not appended). */\n  set(fullText: string): ParseResult;\n  /** Get the latest ParseResult without consuming new data. */\n  getResult(): ParseResult;\n}\n\nexport function createStreamParser(cat: ParamMap, rootName?: string): StreamParser {\n  let buf = \"\";\n  let completedEnd = 0;\n  const completedStmtMap = new Map<string, Statement>();\n\n  let completedCount = 0;\n  let firstId = \"\";\n\n  function addStmt(text: string) {\n    // Strip comments and skip fence markers\n    const cleaned = stripComments(text).trim();\n    if (!cleaned || /^```/.test(cleaned)) return;\n    for (const s of split(tokenize(cleaned))) {\n      const expr = parseExpression(s.tokens);\n      const stmt = classifyStatement(s, expr);\n      completedStmtMap.set(s.id, stmt);\n      completedCount++;\n      if (!firstId) firstId = s.id;\n    }\n  }\n\n  function scanNewCompleted(): number {\n    let depth = 0,\n      ternaryDepth = 0,\n      inStr: false | '\"' | \"'\" = false,\n      esc = false;\n    let stmtStart = completedEnd;\n\n    for (let i = completedEnd; i < buf.length; i++) {\n      const c = buf[i];\n      if (esc) {\n        esc = false;\n        continue;\n      }\n      if (c === \"\\\\\" && inStr) {\n        esc = true;\n        continue;\n      }\n      if (inStr) {\n        if (c === inStr) inStr = false;\n        continue;\n      }\n      if (c === '\"' || c === \"'\") {\n        inStr = c;\n        continue;\n      }\n\n      if (c === \"(\" || c === \"[\" || c === \"{\") depth++;\n      else if (c === \")\" || c === \"]\" || c === \"}\") depth = Math.max(0, depth - 1);\n      // Track ternary ? and : at bracket depth 0 (colons inside {} are object key separators)\n      else if (c === \"?\" && depth === 0) ternaryDepth++;\n      else if (c === \":\" && depth === 0 && ternaryDepth > 0) ternaryDepth--;\n      else if (c === \"\\n\" && depth <= 0 && ternaryDepth <= 0) {\n        // Before splitting, look ahead past whitespace to see if the next\n        // meaningful character is `?` or `:` — ternary continuation.\n        let peek = i + 1;\n        while (\n          peek < buf.length &&\n          (buf[peek] === \" \" || buf[peek] === \"\\t\" || buf[peek] === \"\\r\" || buf[peek] === \"\\n\")\n        )\n          peek++;\n        if (peek < buf.length && (buf[peek] === \"?\" || (buf[peek] === \":\" && ternaryDepth > 0))) {\n          continue; // ternary continuation — don't split\n        }\n        // Depth-0 newline = end of a statement\n        const t = buf.slice(stmtStart, i).trim();\n        if (t) addStmt(t);\n        stmtStart = i + 1; // next statement begins after this newline\n        completedEnd = i + 1; // advance the \"already processed\" watermark\n      }\n    }\n\n    return stmtStart; // start of the current pending (incomplete) statement\n  }\n\n  function currentResult(): ParseResult {\n    const pendingStart = scanNewCompleted();\n    const pendingText = buf.slice(pendingStart).trim();\n\n    // No pending text — all statements are complete\n    if (!pendingText) {\n      if (completedCount === 0) return emptyResult();\n      return buildResult(\n        completedStmtMap,\n        [...completedStmtMap.values()],\n        firstId,\n        false,\n        completedCount,\n        cat,\n        rootName,\n      );\n    }\n\n    // Apply same cleanup as parse() — strip fences, comments, whitespace\n    const cleaned = stripComments(stripFences(pendingText)).trim();\n    if (!cleaned) {\n      if (completedCount === 0) return emptyResult();\n      return buildResult(\n        completedStmtMap,\n        [...completedStmtMap.values()],\n        firstId,\n        false,\n        completedCount,\n        cat,\n        rootName,\n      );\n    }\n    // Autoclose the incomplete last statement so it's syntactically valid\n    const { text: closed, wasIncomplete } = autoClose(cleaned);\n    const stmts = split(tokenize(closed));\n\n    if (!stmts.length) {\n      if (completedCount === 0) return emptyResult(wasIncomplete);\n      return buildResult(\n        completedStmtMap,\n        [...completedStmtMap.values()],\n        firstId,\n        wasIncomplete,\n        completedCount,\n        cat,\n        rootName,\n      );\n    }\n\n    // Merge: completed cache + re-parsed pending statement.\n    // Pending statements can only add NEW IDs — they cannot overwrite completed ones.\n    // This prevents mid-stream partial text (e.g. `root = Card`) from corrupting\n    // existing completed statements during edit streaming.\n    const allStmtMap = new Map(completedStmtMap);\n    for (const s of stmts) {\n      if (completedStmtMap.has(s.id)) continue;\n      const expr = parseExpression(s.tokens);\n      const stmt = classifyStatement(s, expr);\n      allStmtMap.set(s.id, stmt);\n    }\n    // Derive from map to deduplicate\n    const allTypedStmts = [...allStmtMap.values()];\n\n    const fid = firstId || stmts[0].id;\n    return buildResult(\n      allStmtMap,\n      allTypedStmts,\n      fid,\n      wasIncomplete,\n      completedCount + stmts.length,\n      cat,\n      rootName,\n    );\n  }\n\n  function reset() {\n    buf = \"\";\n    completedEnd = 0;\n    completedStmtMap.clear();\n    completedCount = 0;\n    firstId = \"\";\n  }\n\n  return {\n    push(chunk) {\n      buf += chunk;\n      return currentResult();\n    },\n    set(fullText) {\n      if (fullText.length < buf.length || !fullText.startsWith(buf)) {\n        reset();\n      }\n      const delta = fullText.slice(buf.length);\n      if (delta) buf += delta;\n      return currentResult();\n    },\n    getResult: currentResult,\n  };\n}\n\nexport interface Parser {\n  parse(input: string): ParseResult;\n}\n\nfunction getSchemaDefaultValue(property: unknown): unknown {\n  if (!property || typeof property !== \"object\" || Array.isArray(property)) {\n    return undefined;\n  }\n  return (property as { default?: unknown }).default;\n}\n\nexport function compileSchema(schema: LibraryJSONSchema): ParamMap {\n  const map: ParamMap = new Map();\n  const defs = schema.$defs ?? {};\n\n  for (const [name, def] of Object.entries(defs)) {\n    const properties = def.properties ?? {};\n    const required = def.required ?? [];\n    const params = Object.keys(properties).map((key) => ({\n      name: key,\n      required: required.includes(key),\n      defaultValue: getSchemaDefaultValue(properties[key]),\n    }));\n    map.set(name, { params });\n  }\n\n  return map;\n}\n\n/**\n * Create a parser from a library JSON Schema document.\n * Pass `library.toJSONSchema()` to get the schema.\n *\n * @example\n * ```ts\n * const parser = createParser(library.toJSONSchema());\n * const result = parser.parse(openuiLangString);\n * ```\n */\nexport function createParser(schema: LibraryJSONSchema, rootName?: string): Parser {\n  const paramMap = compileSchema(schema);\n  return {\n    parse(input: string): ParseResult {\n      return parse(input, paramMap, rootName);\n    },\n  };\n}\n\n/**\n * Create a streaming parser from a library JSON Schema document.\n * Pass `library.toJSONSchema()` to get the schema.\n */\nexport function createStreamingParser(schema: LibraryJSONSchema, rootName?: string): StreamParser {\n  return createStreamParser(compileSchema(schema), rootName);\n}\n","import type { LibraryJSONSchema, OpenUIError, ValidationError } from \"./types\";\n\n/** Build a signature hint like \"Header(title*, subtitle, icon)\" from JSON schema. */\nfunction buildSignatureHint(\n  componentName: string,\n  schema: { properties?: Record<string, unknown>; required?: string[] } | undefined,\n): string | undefined {\n  if (!schema?.properties) return undefined;\n  const required = new Set(schema.required ?? []);\n  const params = Object.keys(schema.properties)\n    .map((k) => (required.has(k) ? `${k}*` : k))\n    .join(\", \");\n  return `Signature: ${componentName}(${params}) — * marks required`;\n}\n\n/**\n * Convert parser ValidationErrors into enriched OpenUIErrors with hints.\n *\n * Framework-agnostic — usable by React, Svelte, Vue, or standalone.\n */\nexport function enrichErrors(\n  validationErrors: ValidationError[],\n  schema: LibraryJSONSchema,\n  componentNames: string[],\n): OpenUIError[] {\n  return validationErrors.map((ve) => {\n    const error: OpenUIError = {\n      source: \"parser\",\n      code: ve.code,\n      message: ve.message,\n      component: ve.component,\n      path: ve.path || undefined,\n      statementId: ve.statementId,\n    };\n    if (ve.code === \"unknown-component\" && componentNames.length) {\n      error.hint = `Available components: ${componentNames.join(\", \")}`;\n    } else if (ve.code === \"missing-required\" || ve.code === \"null-required\") {\n      error.hint = buildSignatureHint(ve.component, schema.$defs?.[ve.component]);\n    } else if (ve.code === \"inline-reserved\") {\n      error.hint = `Declare as a top-level statement: myVar = ${ve.component}(...)`;\n    }\n    return error;\n  });\n}\n","// ─────────────────────────────────────────────────────────────────────────────\n// Edit/Merge for openui-lang\n// ─────────────────────────────────────────────────────────────────────────────\n\nimport type { ASTNode } from \"./ast\";\nimport { walkAST } from \"./ast\";\nimport { parseExpression } from \"./expressions\";\nimport { tokenize } from \"./lexer\";\nimport { stripFences } from \"./parser\";\nimport { split } from \"./statements\";\n\ninterface ParsedStatement {\n  id: string;\n  ast: ASTNode;\n  raw: string;\n}\n\nfunction splitStatementSource(input: string): string[] {\n  const stmts: string[] = [];\n  let depth = 0;\n  let inStr: false | '\"' | \"'\" = false;\n  let esc = false;\n  let start = 0;\n\n  for (let i = 0; i < input.length; i++) {\n    const c = input[i];\n\n    if (esc) {\n      esc = false;\n      continue;\n    }\n    if (c === \"\\\\\" && inStr) {\n      esc = true;\n      continue;\n    }\n    if (inStr) {\n      if (c === inStr) inStr = false;\n      continue;\n    }\n    if (c === '\"' || c === \"'\") {\n      inStr = c;\n      continue;\n    }\n\n    if (c === \"(\" || c === \"[\" || c === \"{\") depth++;\n    else if (c === \")\" || c === \"]\" || c === \"}\") depth = Math.max(0, depth - 1);\n    else if (c === \"\\n\" && depth <= 0) {\n      const stmt = input.slice(start, i).trim();\n      if (stmt) stmts.push(stmt);\n      start = i + 1;\n    }\n  }\n\n  const tail = input.slice(start).trim();\n  if (tail) stmts.push(tail);\n  return stmts;\n}\n\nfunction parseStatements(input: string): ParsedStatement[] {\n  const trimmed = input.trim();\n  if (!trimmed) return [];\n\n  const result: ParsedStatement[] = [];\n  for (const raw of splitStatementSource(trimmed)) {\n    const stmt = split(tokenize(raw))[0];\n    if (!stmt) continue;\n    result.push({\n      id: stmt.id,\n      ast: parseExpression(stmt.tokens),\n      raw,\n    });\n  }\n\n  return result;\n}\n\n/**\n * Recursively collect all Ref names from an AST node.\n */\nfunction collectRefs(node: ASTNode, out: Set<string>): void {\n  walkAST(node, (current) => {\n    if (current.k === \"Ref\") out.add(current.n);\n    if (current.k === \"RuntimeRef\") out.add(current.n);\n  });\n}\n\n/**\n * Remove statements unreachable from `root` (garbage collection).\n * Walks the AST graph from root, collecting all referenced statement IDs.\n * $state variables are always kept (they're referenced at runtime, not by Ref nodes).\n */\nfunction gcUnreachable(\n  order: string[],\n  merged: Map<string, string>,\n  asts: Map<string, ASTNode>,\n  rootId = \"root\",\n): void {\n  const rootAst = asts.get(rootId);\n  if (!rootAst) return; // no root → can't GC\n\n  // BFS from root to find all reachable statements\n  const reachable = new Set<string>([rootId]);\n  const queue: string[] = [rootId];\n\n  while (queue.length > 0) {\n    const id = queue.pop()!;\n    const ast = asts.get(id);\n    if (!ast) continue;\n\n    const refs = new Set<string>();\n    collectRefs(ast, refs);\n\n    for (const ref of refs) {\n      if (!reachable.has(ref) && asts.has(ref)) {\n        reachable.add(ref);\n        queue.push(ref);\n      }\n    }\n  }\n\n  // Keep $state variables — they're bound at runtime, not via Ref\n  for (const id of order) {\n    if (id.startsWith(\"$\")) reachable.add(id);\n  }\n\n  // Remove unreachable statements\n  for (let i = order.length - 1; i >= 0; i--) {\n    if (!reachable.has(order[i])) {\n      merged.delete(order[i]);\n      order.splice(i, 1);\n    }\n  }\n}\n\n/**\n * Merge an existing program with a patch (partial update).\n * Patch statements override existing ones by name.\n * Unreachable statements are automatically garbage-collected.\n * Returns the merged program as a string.\n */\nexport function mergeStatements(existing: string, patch: string, rootId = \"root\"): string {\n  const existingStmts = parseStatements(existing);\n  const patchStmts = parseStatements(stripFences(patch));\n\n  if (!existingStmts.length) {\n    return patchStmts.map((stmt) => stmt.raw).join(\"\\n\");\n  }\n  if (!patchStmts.length) return existing;\n\n  // Merge: patch statements override existing by name\n  const merged = new Map<string, string>();\n  const asts = new Map<string, ASTNode>();\n  const order: string[] = [];\n\n  for (const stmt of existingStmts) {\n    merged.set(stmt.id, stmt.raw);\n    asts.set(stmt.id, stmt.ast);\n    order.push(stmt.id);\n  }\n\n  for (const stmt of patchStmts) {\n    if (stmt.ast.k === \"Null\") {\n      // `name = null` in a patch means \"delete this statement\"\n      merged.delete(stmt.id);\n      asts.delete(stmt.id);\n      const idx = order.indexOf(stmt.id);\n      if (idx !== -1) order.splice(idx, 1);\n      continue;\n    }\n    if (!merged.has(stmt.id)) {\n      order.push(stmt.id);\n    }\n    merged.set(stmt.id, stmt.raw);\n    asts.set(stmt.id, stmt.ast);\n  }\n\n  // GC: remove statements unreachable from root\n  gcUnreachable(order, merged, asts, rootId);\n\n  return order\n    .filter((id) => merged.has(id))\n    .map((id) => merged.get(id)!)\n    .join(\"\\n\");\n}\n","// ─────────────────────────────────────────────────────────────────────────────\n// ElementNode → openui-lang source text serializer\n// Inverse of the parse + materialize pipeline.\n// ─────────────────────────────────────────────────────────────────────────────\n\nimport type { Library } from \"../library\";\nimport type { ASTNode } from \"./ast\";\nimport { isASTNode } from \"./ast\";\nimport { isBuiltin } from \"./builtins\";\nimport { compileSchema } from \"./parser\";\nimport { isElementNode, type ElementNode, type ParamMap } from \"./types\";\n\n// ─── Operator precedence (mirrors expressions.ts) ────────────────────────────\n\nconst PRECEDENCE: Record<string, number> = {\n  \"||\": 2,\n  \"&&\": 3,\n  \"==\": 4,\n  \"!=\": 4,\n  \">\": 5,\n  \"<\": 5,\n  \">=\": 5,\n  \"<=\": 5,\n  \"+\": 6,\n  \"-\": 6,\n  \"*\": 7,\n  \"/\": 7,\n  \"%\": 7,\n};\n\n// ─── Statement collector ─────────────────────────────────────────────────────\n\ninterface CollectedStatement {\n  id: string;\n  text: string;\n}\n\nclass StatementCollector {\n  private statements: CollectedStatement[] = [];\n  private registered = new Set<string>();\n\n  /** Register an ElementNode as a named statement. Returns the statementId for use as a reference. */\n  register(id: string, text: string): void {\n    if (this.registered.has(id)) return;\n    this.registered.add(id);\n    this.statements.push({ id, text });\n  }\n\n  has(id: string): boolean {\n    return this.registered.has(id);\n  }\n\n  getStatements(): CollectedStatement[] {\n    return this.statements;\n  }\n}\n\n// ─── AST node serializer ─────────────────────────────────────────────────────\n\nfunction serializeASTNode(node: ASTNode): string {\n  switch (node.k) {\n    case \"Str\":\n      return JSON.stringify(node.v);\n    case \"Num\":\n      return String(node.v);\n    case \"Bool\":\n      return node.v ? \"true\" : \"false\";\n    case \"Null\":\n      return \"null\";\n    case \"Ph\":\n      return node.n;\n    case \"StateRef\":\n      return node.n; // already includes $ prefix\n    case \"RuntimeRef\":\n      return node.n;\n    case \"Arr\":\n      return \"[\" + node.els.map(serializeASTNode).join(\", \") + \"]\";\n    case \"Obj\":\n      return \"{\" + node.entries.map(([k, v]) => `${k}: ${serializeASTNode(v)}`).join(\", \") + \"}\";\n    case \"BinOp\": {\n      const left = serializeBinOpChild(node.left, node.op, \"left\");\n      const right = serializeBinOpChild(node.right, node.op, \"right\");\n      return `${left} ${node.op} ${right}`;\n    }\n    case \"UnaryOp\":\n      return `${node.op}${serializeASTNode(node.operand)}`;\n    case \"Ternary\":\n      return `${serializeASTNode(node.cond)} ? ${serializeASTNode(node.then)} : ${serializeASTNode(node.else)}`;\n    case \"Member\":\n      return `${serializeASTNode(node.obj)}.${node.field}`;\n    case \"Index\":\n      return `${serializeASTNode(node.obj)}[${serializeASTNode(node.index)}]`;\n    case \"Assign\":\n      return `${node.target} = ${serializeASTNode(node.value)}`;\n    case \"Comp\": {\n      const args = node.args.map(serializeASTNode).join(\", \");\n      // Builtin (not Action) → @-prefix\n      if (isBuiltin(node.name) && node.name !== \"Action\") {\n        return `@${node.name}(${args})`;\n      }\n      // Action, reserved calls (Query/Mutation), catalog components → no prefix\n      return `${node.name}(${args})`;\n    }\n    // Ref nodes should not appear after materialization, but handle defensively\n    case \"Ref\":\n      return node.n;\n    default:\n      return \"null\";\n  }\n}\n\n/** Wrap a BinOp child in parens if its precedence is lower than the parent's. */\nfunction serializeBinOpChild(child: ASTNode, parentOp: string, _side: \"left\" | \"right\"): string {\n  const inner = serializeASTNode(child);\n  if (child.k !== \"BinOp\") return inner;\n  const parentPrec = PRECEDENCE[parentOp] ?? 0;\n  const childPrec = PRECEDENCE[child.op] ?? 0;\n  if (childPrec < parentPrec) return `(${inner})`;\n  return inner;\n}\n\n// ─── Value serializer ────────────────────────────────────────────────────────\n\nfunction serializeValue(value: unknown, paramMap: ParamMap, collector: StatementCollector): string {\n  if (value === null || value === undefined) return \"null\";\n  if (typeof value === \"string\") return JSON.stringify(value);\n  if (typeof value === \"number\") return String(value);\n  if (typeof value === \"boolean\") return value ? \"true\" : \"false\";\n\n  // ElementNode — check before isASTNode (they don't overlap, but order is clear)\n  if (isElementNode(value)) {\n    return serializeElementValue(value, paramMap, collector);\n  }\n\n  // ASTNode (surviving runtime expressions in dynamic props)\n  if (isASTNode(value)) {\n    return serializeASTNode(value);\n  }\n\n  // Array\n  if (Array.isArray(value)) {\n    const items = value.map((el) => serializeValue(el, paramMap, collector));\n    return \"[\" + items.join(\", \") + \"]\";\n  }\n\n  // Plain object\n  if (typeof value === \"object\") {\n    const obj = value as Record<string, unknown>;\n    const entries = Object.entries(obj).map(\n      ([k, v]) => `${k}: ${serializeValue(v, paramMap, collector)}`,\n    );\n    return \"{\" + entries.join(\", \") + \"}\";\n  }\n\n  return \"null\";\n}\n\n/** Serialize an ElementNode — either as a reference (if it has statementId) or inline. */\nfunction serializeElementValue(\n  node: ElementNode,\n  paramMap: ParamMap,\n  collector: StatementCollector,\n): string {\n  if (node.statementId) {\n    // Register as separate statement if not already registered\n    if (!collector.has(node.statementId)) {\n      // Serialize the expression first (depth-first → children registered before parent)\n      const expr = serializeElementExpr(node, paramMap, collector);\n      collector.register(node.statementId, `${node.statementId} = ${expr}`);\n    }\n    // Emit bare reference\n    return node.statementId;\n  }\n  // Inline (no statementId)\n  return serializeElementExpr(node, paramMap, collector);\n}\n\n// ─── ElementNode → expression string ─────────────────────────────────────────\n\nfunction serializeElementExpr(\n  node: ElementNode,\n  paramMap: ParamMap,\n  collector: StatementCollector,\n): string {\n  const def = paramMap.get(node.typeName);\n\n  if (def) {\n    // Map named props back to positional args using ParamMap order\n    const args: string[] = [];\n    for (const param of def.params) {\n      const val = node.props[param.name];\n      args.push(serializeValue(val, paramMap, collector));\n    }\n\n    // Trim trailing null/undefined/default args\n    while (args.length > 0) {\n      const last = args[args.length - 1];\n      if (last !== \"null\") break;\n      const paramIdx = args.length - 1;\n      const param = def.params[paramIdx];\n      if (!param) break;\n      // Only trim if the param is optional or has a default matching null\n      if (param.required) break;\n      args.pop();\n    }\n\n    return `${node.typeName}(${args.join(\", \")})`;\n  }\n\n  // Unknown component — fallback to Object.keys() order\n  const fallbackArgs = Object.values(node.props).map((v) => serializeValue(v, paramMap, collector));\n  return `${node.typeName}(${fallbackArgs.join(\", \")})`;\n}\n\n// ─── State declaration serializer ────────────────────────────────────────────\n\nfunction serializeStateDeclarations(\n  stateDeclarations: Record<string, unknown>,\n  paramMap: ParamMap,\n  collector: StatementCollector,\n): string[] {\n  const lines: string[] = [];\n  for (const [name, value] of Object.entries(stateDeclarations)) {\n    // Auto-declared null defaults ($var = null) can be omitted for cleaner output\n    if (value === null) continue;\n    lines.push(`${name} = ${serializeValue(value, paramMap, collector)}`);\n  }\n  return lines;\n}\n\n// ─── Public API ──────────────────────────────────────────────────────────────\n\nexport interface SerializeOptions {\n  /** $variable declarations to include (e.g. from ParseResult.stateDeclarations). */\n  stateDeclarations?: Record<string, unknown>;\n}\n\n/**\n * Convert an ElementNode tree back to openui-lang source text.\n * Output is compatible with `mergeStatements()` for patching existing programs.\n *\n * @param json - The root ElementNode tree\n * @param library - The component Library (for positional arg ordering)\n * @param options - Optional state declarations\n * @returns openui-lang source text (multiple statements joined by newlines)\n */\nexport function jsonToOpenUI(\n  json: ElementNode,\n  library: Library,\n  options?: SerializeOptions,\n): string {\n  const paramMap = compileSchema(library.toJSONSchema());\n  const collector = new StatementCollector();\n\n  // Serialize root — this recursively registers all child statements\n  const rootExpr = serializeElementExpr(json, paramMap, collector);\n  const rootId = json.statementId || \"root\";\n\n  // Build output: root first, then children (depth-first post-order), then state\n  const lines: string[] = [];\n\n  // Root statement\n  lines.push(`${rootId} = ${rootExpr}`);\n\n  // Child statements (already in depth-first post-order from collector)\n  for (const stmt of collector.getStatements()) {\n    // Skip root if it was also registered in collector\n    if (stmt.id === rootId) continue;\n    lines.push(stmt.text);\n  }\n\n  // State declarations\n  if (options?.stateDeclarations) {\n    const stateLines = serializeStateDeclarations(options.stateDeclarations, paramMap, collector);\n    lines.push(...stateLines);\n  }\n\n  return lines.join(\"\\n\");\n}\n","// ─────────────────────────────────────────────────────────────────────────────\n// AST evaluator — resolves AST nodes to runtime values.\n// Framework-agnostic. No React imports.\n// ─────────────────────────────────────────────────────────────────────────────\n\nimport type { ASTNode } from \"../parser/ast\";\nimport { isASTNode } from \"../parser/ast\";\nimport { ACTION_NAMES, ACTION_STEPS, BUILTINS, LAZY_BUILTINS, toNumber } from \"../parser/builtins\";\nimport type { ActionPlan, ActionStep, ElementNode } from \"../parser/types\";\nimport { isElementNode } from \"../parser/types\";\nimport { isReactiveSchema } from \"../reactive\";\nimport { evaluatePropCore } from \"./evaluate-prop\";\n\n/** Optional schema context for reactive-aware evaluation. */\nexport interface SchemaContext {\n  /** Component library — used to look up reactive schemas per prop. */\n  library: { components: Record<string, { props: { shape?: Record<string, unknown> } }> };\n}\n\nexport interface EvaluationContext {\n  /** Read $variable from the store */\n  getState(name: string): unknown;\n  /** Resolve a reference to another declaration's evaluated value */\n  resolveRef(name: string): unknown;\n  /** Extra scope for $value injection during reactive prop evaluation */\n  extraScope?: Record<string, unknown>;\n}\n\nexport interface ReactiveAssign {\n  __reactive: \"assign\";\n  target: string;\n  expr: ASTNode;\n}\n\nexport function isReactiveAssign(value: unknown): value is ReactiveAssign {\n  return typeof value === \"object\" && value !== null && (value as any).__reactive === \"assign\";\n}\n\n/**\n * Evaluate an AST node to a runtime value.\n */\nexport function evaluate(\n  node: ASTNode,\n  context: EvaluationContext,\n  schemaCtx?: SchemaContext,\n): unknown {\n  switch (node.k) {\n    // ── Literals ──────────────────────────────────────────────────────────\n    case \"Str\":\n      return node.v;\n    case \"Num\":\n      return node.v;\n    case \"Bool\":\n      return node.v;\n    case \"Null\":\n      return null;\n    case \"Ph\":\n      return null;\n\n    // ── State references ──────────────────────────────────────────────────\n    case \"StateRef\":\n      return context.extraScope?.[node.n] ?? context.getState(node.n);\n\n    // ── References ────────────────────────────────────────────────────────\n    case \"Ref\":\n    case \"RuntimeRef\":\n      return context.resolveRef(node.n);\n\n    // ── Collections ───────────────────────────────────────────────────────\n    case \"Arr\":\n      return node.els.map((el) => evaluate(el, context));\n    case \"Obj\":\n      return Object.fromEntries(node.entries.map(([k, v]) => [k, evaluate(v, context)]));\n\n    // ── Component ─────────────────────────────────────────────────────────\n    case \"Comp\": {\n      // Lazy builtins — control their own evaluation\n      if (LAZY_BUILTINS.has(node.name)) {\n        return evaluateLazyBuiltin(node.name, node.args, context, schemaCtx);\n      }\n      // Check shared builtin registry first\n      const builtin = BUILTINS[node.name];\n      if (builtin) {\n        const args = node.args.map((a) => evaluate(a, context));\n        return builtin.fn(...args);\n      }\n      // Action calls → evaluate to ActionPlan/ActionStep\n      if (ACTION_NAMES.has(node.name)) {\n        return evaluateActionCall(node.name, node.args, context);\n      }\n      // If parser already mapped args→props (via materializeExpr), use named props.\n      // With schema context: emit ReactiveAssign for StateRef on reactive props.\n      // Without schema context: preserve StateRef as AST for evaluate-tree to handle.\n      if (node.mappedProps) {\n        const def = schemaCtx?.library.components[node.name];\n        const props: Record<string, unknown> = {};\n        for (const [key, val] of Object.entries(node.mappedProps)) {\n          const propSchema = def?.props?.shape?.[key];\n          if (val.k === \"StateRef\" && propSchema && isReactiveSchema(propSchema)) {\n            // Reactive schema + StateRef → emit ReactiveAssign marker\n            props[key] = {\n              __reactive: \"assign\" as const,\n              target: val.n,\n              expr: { k: \"StateRef\" as const, n: \"$value\" },\n            };\n          } else if (val.k === \"StateRef\") {\n            // Non-reactive StateRef or no schema context → preserve for evaluate-tree\n            props[key] = schemaCtx ? context.getState(val.n) : val;\n          } else {\n            props[key] = evaluate(val, context, schemaCtx);\n          }\n        }\n        const result: ElementNode = {\n          type: \"element\",\n          typeName: node.name,\n          props,\n          partial: false,\n          hasDynamicProps: true,\n        };\n        // If we have schema context, recursively evaluate nested ElementNodes in props\n        if (schemaCtx) {\n          for (const [key, val] of Object.entries(props)) {\n            if (isElementNode(val)) {\n              props[key] = evaluateElementInline(val, context, schemaCtx);\n            } else if (Array.isArray(val)) {\n              props[key] = val.map((item) =>\n                isElementNode(item) ? evaluateElementInline(item, context, schemaCtx) : item,\n              );\n            }\n          }\n        }\n        return result;\n      }\n      // After materializeValue, all catalog/unknown components are lowered to\n      // ElementNode at parse time. Only builtins and mappedProps Comp nodes\n      // reach here. If we somehow get an unmapped Comp, warn and return null.\n      console.warn(`[openui] Unexpected unmapped Comp node: ${node.name}`);\n      return null;\n    }\n\n    // ── Binary operators ──────────────────────────────────────────────────\n    case \"BinOp\": {\n      // Short-circuit operators evaluate lazily\n      if (node.op === \"&&\") {\n        const left = evaluate(node.left, context);\n        return left ? evaluate(node.right, context) : left;\n      }\n      if (node.op === \"||\") {\n        const left = evaluate(node.left, context);\n        return left ? left : evaluate(node.right, context);\n      }\n\n      const left = evaluate(node.left, context);\n      const right = evaluate(node.right, context);\n\n      switch (node.op) {\n        case \"+\":\n          if (typeof left === \"string\" || typeof right === \"string\") {\n            // Treat null/undefined as \"\" for string concat to avoid \"textnull\"\n            return String(left ?? \"\") + String(right ?? \"\");\n          }\n          return toNumber(left) + toNumber(right);\n        case \"-\":\n          return toNumber(left) - toNumber(right);\n        case \"*\":\n          return toNumber(left) * toNumber(right);\n        case \"/\":\n          // DSL design choice: division by zero returns 0 instead of JavaScript's Infinity/NaN.\n          return toNumber(right) === 0 ? 0 : toNumber(left) / toNumber(right);\n        case \"%\":\n          return toNumber(right) === 0 ? 0 : toNumber(left) % toNumber(right);\n        case \"==\":\n          // Use loose equality so that e.g. 5 == \"5\" is true,\n          // consistent with the toNumber coercion used by comparison operators.\n          return left == right;\n        case \"!=\":\n          return left != right;\n        case \">\":\n          return toNumber(left) > toNumber(right);\n        case \"<\":\n          return toNumber(left) < toNumber(right);\n        case \">=\":\n          return toNumber(left) >= toNumber(right);\n        case \"<=\":\n          return toNumber(left) <= toNumber(right);\n        default:\n          return null;\n      }\n    }\n\n    // ── Unary operators ───────────────────────────────────────────────────\n    case \"UnaryOp\":\n      if (node.op === \"!\") {\n        return !evaluate(node.operand, context);\n      }\n      if (node.op === \"-\") {\n        return -toNumber(evaluate(node.operand, context));\n      }\n      return null;\n\n    // ── Ternary ───────────────────────────────────────────────────────────\n    case \"Ternary\": {\n      const cond = evaluate(node.cond, context);\n      return cond ? evaluate(node.then, context) : evaluate(node.else, context);\n    }\n\n    // ── Member access ─────────────────────────────────────────────────────\n    case \"Member\": {\n      const obj = evaluate(node.obj, context) as any;\n      if (obj == null) return null;\n      // Array pluck: if obj is an array, extract field from every element\n      if (Array.isArray(obj)) {\n        if (node.field === \"length\") return obj.length;\n        return obj.map((item: any) => item?.[node.field] ?? null);\n      }\n      return obj[node.field];\n    }\n\n    // ── Index access ──────────────────────────────────────────────────────\n    case \"Index\": {\n      const obj = evaluate(node.obj, context) as any;\n      const idx = evaluate(node.index, context);\n      if (obj == null || idx == null) return null;\n      if (Array.isArray(obj)) {\n        return obj[toNumber(idx)];\n      }\n      return obj[String(idx)];\n    }\n\n    // ── Assignment ────────────────────────────────────────────────────────\n    case \"Assign\":\n      return {\n        __reactive: \"assign\" as const,\n        target: node.target,\n        expr: node.value,\n      };\n  }\n}\n\n/**\n * Strip a ReactiveAssign to its current value in a non-reactive context.\n * When transport args or non-reactive props contain a ReactiveAssign, this\n * resolves it to the current state value (or null if getState is unavailable).\n */\nexport function stripReactiveAssign(value: unknown, context: EvaluationContext): unknown {\n  if (!isReactiveAssign(value)) return value;\n  return context.getState(value.target) ?? null;\n}\n\n/**\n * Evaluate an ElementNode's props with schema awareness. Used by evaluate()\n * when schema context is available and a Comp produces an ElementNode that\n * needs its own props evaluated with reactive schema detection.\n */\nfunction evaluateElementInline(\n  el: ElementNode,\n  context: EvaluationContext,\n  schemaCtx: SchemaContext,\n): ElementNode {\n  if (el.hasDynamicProps === false) return el;\n  const def = schemaCtx.library.components[el.typeName];\n  const evaluated: Record<string, unknown> = {};\n\n  for (const [key, value] of Object.entries(el.props)) {\n    const propSchema = def?.props?.shape?.[key];\n    evaluated[key] = evaluatePropInline(value, context, schemaCtx, propSchema);\n  }\n  return { ...el, props: evaluated };\n}\n\n/**\n * Evaluate a single prop value with schema awareness.\n * Delegates to shared evaluatePropCore with inline-specific recursion callbacks.\n */\nfunction evaluatePropInline(\n  value: unknown,\n  context: EvaluationContext,\n  schemaCtx: SchemaContext,\n  reactiveSchema?: unknown,\n): unknown {\n  return evaluatePropCore(value, context, schemaCtx, reactiveSchema, {\n    recurseElement: (el) => evaluateElementInline(el, context, schemaCtx),\n    recurse: (v, rs) => evaluatePropInline(v, context, schemaCtx, rs),\n  });\n}\n\n/** Convert a resolved runtime value back to a literal AST node for deferred evaluation. */\nfunction toLiteralAST(value: unknown): ASTNode {\n  if (value === null || value === undefined) return { k: \"Null\" };\n  if (typeof value === \"string\") return { k: \"Str\", v: value };\n  if (typeof value === \"number\") return { k: \"Num\", v: value };\n  if (typeof value === \"boolean\") return { k: \"Bool\", v: value };\n  if (Array.isArray(value)) return { k: \"Arr\", els: value.map(toLiteralAST) };\n  if (typeof value === \"object\") {\n    return {\n      k: \"Obj\",\n      entries: Object.entries(value).map(([k, v]) => [k, toLiteralAST(v)] as [string, ASTNode]),\n    };\n  }\n  return { k: \"Null\" };\n}\n\n/**\n * Evaluate Action/Run/ToAssistant/OpenUrl Comp nodes into ActionPlan/ActionStep values.\n */\nfunction evaluateActionCall(\n  name: string,\n  args: ASTNode[],\n  context: EvaluationContext,\n): ActionPlan | ActionStep | null {\n  switch (name) {\n    case \"Action\": {\n      // Action([step1, step2, ...]) → ActionPlan\n      const stepsArg = args.length > 0 ? evaluate(args[0], context) : [];\n      const rawSteps = Array.isArray(stepsArg) ? stepsArg : [];\n      const steps: ActionStep[] = rawSteps.filter(\n        (s): s is ActionStep => s != null && typeof s === \"object\" && \"type\" in s,\n      );\n      return { steps };\n    }\n    case \"Run\": {\n      // Run(runtimeRef) → ActionStep { type: \"run\", statementId, refType }\n      if (args.length === 0) return null;\n      const refNode = args[0];\n      if (refNode.k === \"RuntimeRef\") {\n        return { type: ACTION_STEPS.Run, statementId: refNode.n, refType: refNode.refType };\n      }\n      // Unresolved Ref — skip (filtered out by Action's step array)\n      return null;\n    }\n    case \"ToAssistant\": {\n      // ToAssistant(\"message\") or ToAssistant(\"message\", \"context\")\n      const message = args.length > 0 ? String(evaluate(args[0], context) ?? \"\") : \"\";\n      const ctx = args.length > 1 ? String(evaluate(args[1], context) ?? \"\") : undefined;\n      return { type: ACTION_STEPS.ToAssistant, message, context: ctx };\n    }\n    case \"OpenUrl\": {\n      // OpenUrl(\"url\")\n      const url = args.length > 0 ? String(evaluate(args[0], context) ?? \"\") : \"\";\n      return { type: ACTION_STEPS.OpenUrl, url };\n    }\n    case \"Set\": {\n      // Set($varName, value) → ActionStep { type: \"set\", target, valueAST }\n      // First arg must be a StateRef (the $variable), second arg is the value expression.\n      // valueAST is preserved as-is and evaluated at click time by triggerAction.\n      // Loop variables (e.g. t.id from Each) are pre-resolved by Each's substituteRef.\n      if (args.length < 2) return null;\n      const targetNode = args[0];\n      if (targetNode.k !== \"StateRef\") return null;\n      return { type: ACTION_STEPS.Set, target: targetNode.n, valueAST: args[1] };\n    }\n    case \"Reset\": {\n      // Reset($var1, $var2, ...) → ActionStep { type: \"reset\", targets: [...] }\n      // All args must be StateRef nodes. Restores to declared defaults at runtime.\n      const targets = args\n        .filter((a): a is ASTNode & { k: \"StateRef\" } => a.k === \"StateRef\")\n        .map((a) => a.n);\n      if (targets.length === 0) return null;\n      return { type: ACTION_STEPS.Reset, targets };\n    }\n    default:\n      return null;\n  }\n}\n\n/**\n * Substitute all Ref(varName) nodes in an AST tree with a literal value.\n * This pre-resolves loop variables so deferred expressions (like Action steps)\n * don't lose scope when evaluated later at click time.\n */\nfunction substituteRef(node: ASTNode, varName: string, value: unknown): ASTNode {\n  switch (node.k) {\n    case \"Ref\":\n      return node.n === varName ? toLiteralAST(value) : node;\n    case \"Member\": {\n      // Member access on the loop var: t.id → resolve t, then access .id\n      if (isASTNode(node.obj)) {\n        const subObj = substituteRef(node.obj as ASTNode, varName, value);\n        // If obj resolved to a literal, we can inline the member access result\n        if (subObj.k === \"Obj\") {\n          const entry = subObj.entries.find(([k]) => k === node.field);\n          if (entry) return entry[1];\n        }\n        return { ...node, obj: subObj };\n      }\n      return node;\n    }\n    case \"Index\":\n      return {\n        ...node,\n        obj: isASTNode(node.obj) ? substituteRef(node.obj as ASTNode, varName, value) : node.obj,\n        index: isASTNode(node.index)\n          ? substituteRef(node.index as ASTNode, varName, value)\n          : node.index,\n      };\n    case \"BinOp\":\n      return {\n        ...node,\n        left: substituteRef(node.left, varName, value),\n        right: substituteRef(node.right, varName, value),\n      };\n    case \"UnaryOp\":\n      return { ...node, operand: substituteRef(node.operand, varName, value) };\n    case \"Ternary\":\n      return {\n        ...node,\n        cond: substituteRef(node.cond, varName, value),\n        then: substituteRef(node.then, varName, value),\n        else: substituteRef(node.else, varName, value),\n      };\n    case \"Arr\":\n      return { ...node, els: node.els.map((e) => substituteRef(e, varName, value)) };\n    case \"Obj\":\n      return {\n        ...node,\n        entries: node.entries.map(\n          ([k, v]) => [k, substituteRef(v, varName, value)] as [string, ASTNode],\n        ),\n      };\n    case \"Comp\": {\n      const result = { ...node, args: node.args.map((a) => substituteRef(a, varName, value)) };\n      // Also substitute in mappedProps (added by materializer for catalog components)\n      if (node.mappedProps) {\n        const subProps: Record<string, ASTNode> = {};\n        for (const [k, v] of Object.entries(node.mappedProps)) {\n          subProps[k] = substituteRef(v, varName, value);\n        }\n        (result as any).mappedProps = subProps;\n      }\n      return result;\n    }\n    case \"Assign\":\n      return { ...node, value: substituteRef(node.value, varName, value) };\n    default:\n      return node;\n  }\n}\n\n/**\n * Each(array, varName, template) — evaluate template once per array item.\n * varName is user-defined (e.g. `issue`, `ticket`) — no $ prefix collision.\n *\n * Before evaluation, substitutes all Ref(varName) in the template with the\n * current item's literal value. This ensures deferred expressions (like\n * Action/Set steps) capture concrete values instead of dangling loop refs.\n */\nfunction evaluateLazyBuiltin(\n  name: string,\n  args: ASTNode[],\n  context: EvaluationContext,\n  schemaCtx?: SchemaContext,\n): unknown {\n  if (name === \"Each\") {\n    if (args.length < 3) return [];\n    const arr = evaluate(args[0], context);\n    if (!Array.isArray(arr)) return [];\n\n    const varName =\n      args[1].k === \"Ref\" ? args[1].n : args[1].k === \"Str\" ? (args[1] as any).v : null;\n    if (!varName) return [];\n    const template = args[2];\n\n    return arr.map((item, _idx) => {\n      // Pre-substitute loop variable refs with concrete values in the template AST.\n      // This captures the item for deferred expressions (Action steps evaluated at click time).\n      const substituted = substituteRef(template, varName, item);\n      const childCtx: EvaluationContext = {\n        ...context,\n        resolveRef: (refName: string) => {\n          if (refName === varName) return item;\n          return context.resolveRef(refName);\n        },\n      };\n      const result = evaluate(substituted, childCtx, schemaCtx);\n      // If schema context is available and result is an ElementNode, evaluate its props\n      if (schemaCtx && isElementNode(result)) {\n        return evaluateElementInline(result as ElementNode, childCtx, schemaCtx);\n      }\n      return result;\n    });\n  }\n  return null;\n}\n","/**\n * Shared prop value evaluation logic.\n *\n * Both evaluator.ts (inline path) and evaluate-tree.ts (React path) need\n * identical prop evaluation — AST resolution, ReactiveAssign handling,\n * ElementNode recursion, ActionPlan preservation. The only difference is\n * how they recurse into ElementNodes. This module extracts the shared core\n * and takes recursion callbacks so each caller can supply its own strategy.\n *\n * Also fixes the nested reactive drop bug: reactiveSchema is now correctly\n * passed through plain object recursion.\n */\n\nimport { isASTNode } from \"../parser/ast\";\nimport type { ElementNode } from \"../parser/types\";\nimport { isElementNode } from \"../parser/types\";\nimport { isReactiveSchema } from \"../reactive\";\nimport type { EvaluationContext, SchemaContext } from \"./evaluator\";\nimport { evaluate, isReactiveAssign } from \"./evaluator\";\n\nexport interface PropEvalCallbacks {\n  /** How to recurse into an ElementNode (evaluator vs evaluate-tree differ here). */\n  recurseElement: (el: ElementNode) => ElementNode;\n  /** How to self-recurse for a prop value. */\n  recurse: (value: unknown, reactiveSchema?: unknown) => unknown;\n}\n\n/**\n * Evaluate a single prop value with schema awareness. Handles AST nodes,\n * ReactiveAssign markers, nested ElementNodes, arrays, and ActionPlans.\n */\nexport function evaluatePropCore(\n  value: unknown,\n  context: EvaluationContext,\n  schemaCtx: SchemaContext,\n  reactiveSchema: unknown | undefined,\n  callbacks: PropEvalCallbacks,\n): unknown {\n  if (value == null) return value;\n  if (typeof value !== \"object\") return value;\n\n  // AST node — evaluate with schema context\n  if (isASTNode(value)) {\n    // StateRef on reactive prop → ReactiveAssign marker\n    if (value.k === \"StateRef\" && reactiveSchema && isReactiveSchema(reactiveSchema)) {\n      return {\n        __reactive: \"assign\" as const,\n        target: value.n,\n        expr: { k: \"StateRef\" as const, n: \"$value\" },\n      };\n    }\n    const result = evaluate(value, context, schemaCtx);\n    // ElementNode result (from ternary/Comp) → recurse into its props\n    if (isElementNode(result)) {\n      return callbacks.recurseElement(result as ElementNode);\n    }\n    // Array result (from Each) → recurse into any ElementNodes\n    if (Array.isArray(result)) {\n      return result.map((item) =>\n        isElementNode(item) ? callbacks.recurseElement(item as ElementNode) : item,\n      );\n    }\n    // Strip ReactiveAssign from non-reactive props\n    if (isReactiveAssign(result) && !(reactiveSchema && isReactiveSchema(reactiveSchema))) {\n      return context.getState(result.target) ?? null;\n    }\n    return result;\n  }\n\n  // String on reactive schema → pass through (component's useStateField resolves it)\n  if (typeof value === \"string\" && reactiveSchema && isReactiveSchema(reactiveSchema)) {\n    return value;\n  }\n\n  // Array — recurse\n  if (Array.isArray(value)) {\n    return value.map((v) => callbacks.recurse(v, reactiveSchema));\n  }\n\n  // ElementNode — recurse with schema\n  if (isElementNode(value)) {\n    return callbacks.recurseElement(value as ElementNode);\n  }\n\n  // ActionPlan / ActionStep — preserve as-is (deferred click-time evaluation)\n  const obj = value as Record<string, unknown>;\n  if (\"steps\" in obj && Array.isArray(obj.steps)) return value;\n  if (\"type\" in obj && \"valueAST\" in obj) return value;\n\n  // Plain data object — recurse if contains nested objects\n  // NOTE: reactiveSchema is passed through — fixes nested reactive drop bug\n  let needsEval = false;\n  for (const val of Object.values(obj)) {\n    if (typeof val === \"object\" && val !== null) {\n      needsEval = true;\n      break;\n    }\n  }\n  if (needsEval) {\n    const result: Record<string, unknown> = {};\n    for (const [k, v] of Object.entries(obj)) {\n      result[k] = callbacks.recurse(v, reactiveSchema);\n    }\n    return result;\n  }\n\n  return value;\n}\n","/**\n * Evaluate-tree: entry point for evaluating ElementNode prop trees.\n *\n * Delegates to the evaluator's schema-aware evaluation when schema context\n * is available. This ensures reactive schemas, ActionPlan preservation,\n * Each loop variable substitution, and ternary resolution all happen in\n * a single unified pass.\n */\n\nimport type { Library } from \"../library\";\nimport type { ElementNode, OpenUIError } from \"../parser/types\";\nimport { evaluatePropCore } from \"./evaluate-prop\";\nimport type { EvaluationContext, SchemaContext } from \"./evaluator\";\nimport type { Store } from \"./store\";\n\n/** Context passed through the evaluation chain — no module-level state. */\nexport interface EvalContext {\n  /** AST evaluation context (getState, resolveRef) */\n  ctx: EvaluationContext;\n  /** Component library for reactive schema lookup */\n  library: Library;\n  /** Reactive binding store (null in v1 mode) */\n  store: Store | null;\n  /** Runtime errors collected during prop evaluation (optional — populated by evaluateElementProps). */\n  errors?: OpenUIError[];\n}\n\n/**\n * Evaluate all AST nodes in an ElementNode tree's props.\n * Returns a new ElementNode with all props resolved to concrete values.\n *\n * Uses the unified evaluator with schema context for reactive-aware evaluation.\n */\nexport function evaluateElementProps(el: ElementNode, evalCtx: EvalContext): ElementNode {\n  if (el.hasDynamicProps === false) return el;\n\n  const schemaCtx: SchemaContext = { library: evalCtx.library };\n  const def = evalCtx.library.components[el.typeName];\n  const evaluated: Record<string, unknown> = {};\n\n  for (const [key, value] of Object.entries(el.props)) {\n    const propSchema = def?.props?.shape?.[key];\n    try {\n      evaluated[key] = evaluatePropValue(value, evalCtx, schemaCtx, propSchema);\n    } catch (e) {\n      // Use raw value as fallback for this prop, collect structured error\n      evaluated[key] = value;\n      const msg = e instanceof Error ? e.message : String(e);\n      evalCtx.errors?.push({\n        source: \"runtime\",\n        code: \"runtime-error\",\n        component: el.typeName,\n        statementId: el.statementId,\n        message: `Evaluating prop \"${key}\" on ${el.typeName} failed: ${msg}`,\n        hint: `Check the expression used for prop \"${key}\"`,\n      });\n    }\n  }\n\n  return { ...el, props: evaluated };\n}\n\n/**\n * Evaluate a single prop value with schema awareness.\n * Delegates to shared evaluatePropCore with evaluate-tree-specific recursion callbacks.\n */\nfunction evaluatePropValue(\n  value: unknown,\n  evalCtx: EvalContext,\n  schemaCtx: SchemaContext,\n  reactiveSchema?: unknown,\n): unknown {\n  return evaluatePropCore(value, evalCtx.ctx, schemaCtx, reactiveSchema, {\n    recurseElement: (el) => evaluateElementProps(el, evalCtx),\n    recurse: (v, rs) => evaluatePropValue(v, evalCtx, schemaCtx, rs),\n  });\n}\n","/**\n * MCP utilities — type definitions and result extraction for MCP client integration.\n *\n * The Renderer accepts an MCP client directly as `toolProvider`.\n * It detects the MCP client shape (has `callTool({ name, arguments })`) and\n * wraps responses with `extractToolResult` automatically.\n *\n * @example\n * ```tsx\n * import { Client } from \"@modelcontextprotocol/sdk/client/index.js\";\n * import { StreamableHTTPClientTransport } from \"@modelcontextprotocol/sdk/client/streamableHttp.js\";\n *\n * const client = new Client({ name: \"my-app\", version: \"1.0.0\" });\n * await client.connect(new StreamableHTTPClientTransport(new URL(\"/api/mcp\")));\n *\n * // Pass directly — Renderer handles MCP response extraction\n * <Renderer toolProvider={client} library={library} response={content} />\n * ```\n */\n\n/**\n * Error thrown when an MCP tool call returns `isError: true`.\n * Preserves the raw error content from the MCP response for structured handling.\n */\nexport class McpToolError extends Error {\n  readonly toolErrorText: string;\n\n  constructor(errorText: string) {\n    super(`MCP tool error: ${errorText || \"Unknown error\"}`);\n    this.name = \"McpToolError\";\n    this.toolErrorText = errorText;\n  }\n}\n\n/**\n * Minimal shape of an MCP Client — matches @modelcontextprotocol/sdk Client\n * without requiring it as a hard import. Users can pass any object that\n * implements these methods.\n */\nexport interface McpClientLike {\n  callTool(\n    params: { name: string; arguments?: Record<string, unknown> },\n    options?: unknown,\n  ): Promise<{\n    content: Array<{ type: string; text?: string; [key: string]: unknown }>;\n    structuredContent?: unknown;\n    isError?: boolean;\n  }>;\n  close?(): Promise<void>;\n}\n\n/**\n * Extract the actual data from an MCP callTool result.\n * Prefers structuredContent (machine-readable JSON), falls back to parsing text content.\n */\nexport function extractToolResult(result: {\n  content: Array<{ type: string; text?: string; [key: string]: unknown }>;\n  structuredContent?: unknown;\n  isError?: boolean;\n}): unknown {\n  if (result.isError) {\n    const errorText = result.content\n      ?.filter((c) => c.type === \"text\")\n      .map((c) => c.text)\n      .join(\"\\n\");\n    throw new McpToolError(errorText || \"Unknown error\");\n  }\n\n  // Prefer structuredContent (JSON data, no parsing needed)\n  if (result.structuredContent != null) {\n    return result.structuredContent;\n  }\n\n  // Fall back to text content — try to parse as JSON\n  const textParts = result.content?.filter((c) => c.type === \"text\").map((c) => c.text ?? \"\");\n  if (textParts?.length) {\n    const text = textParts.join(\"\");\n    try {\n      return JSON.parse(text);\n    } catch {\n      return text;\n    }\n  }\n\n  return null;\n}\n","/**\n * Standard error thrown when a tool name is not found in a function-map ToolProvider.\n * Used by Renderer's inline normalization to give clear error messages.\n */\nexport class ToolNotFoundError extends Error {\n  readonly toolName: string;\n  readonly availableTools: string[];\n\n  constructor(toolName: string, availableTools: string[] = []) {\n    super(\n      `[openui] No handler for tool \"${toolName}\". Available: ${availableTools.join(\", \") || \"(none)\"}`,\n    );\n    this.name = \"ToolNotFoundError\";\n    this.toolName = toolName;\n    this.availableTools = availableTools;\n  }\n}\n","// ─────────────────────────────────────────────────────────────────────────────\n// Query Manager — reactive data fetching for openui-lang\n// ─────────────────────────────────────────────────────────────────────────────\n\nimport type { OpenUIError } from \"../parser/types\";\nimport { McpToolError } from \"./mcp\";\nimport { ToolNotFoundError } from \"./toolProvider\";\n\n/**\n * ToolProvider interface for Query() and Mutation() tool calls.\n * Framework-agnostic — works with MCP, REST, GraphQL, or any backend.\n *\n * @example\n * ```ts\n * // Function map (Renderer normalizes this automatically)\n * <Renderer toolProvider={{\n *   get_users: (args) => fetch(`/api/users`).then(r => r.json()),\n * }} />\n *\n * // MCP client (Renderer wraps extractToolResult automatically)\n * <Renderer toolProvider={mcpClient} />\n * ```\n */\nexport interface ToolProvider {\n  callTool(toolName: string, args: Record<string, unknown>): Promise<unknown>;\n}\n\n// ── Public types ─────────────────────────────────────────────────────────────\n\nexport interface QueryNode {\n  statementId: string;\n  toolName: string;\n  args: unknown;\n  defaults: unknown;\n  /** Evaluated dependency value — included in cache key to force re-fetch on change. */\n  deps: unknown;\n  /** Auto-refresh interval in seconds. */\n  refreshInterval?: number;\n  complete: boolean;\n}\n\nexport interface MutationNode {\n  statementId: string;\n  toolName: string;\n}\n\nexport interface MutationResult {\n  status: \"idle\" | \"loading\" | \"success\" | \"error\";\n  data?: unknown;\n  error?: unknown;\n}\n\nexport interface QuerySnapshot extends Record<string, unknown> {\n  __openui_loading: string[];\n  __openui_refetching: string[];\n  __openui_errors: OpenUIError[];\n}\n\nexport interface QueryManager {\n  evaluateQueries(queryNodes: QueryNode[]): void;\n  getResult(statementId: string): unknown;\n  isLoading(statementId: string): boolean;\n  isAnyLoading(): boolean;\n  invalidate(statementIds?: string[]): void;\n  registerMutations(nodes: MutationNode[]): void;\n  fireMutation(\n    statementId: string,\n    evaluatedArgs: Record<string, unknown>,\n    refreshQueryIds?: string[],\n  ): Promise<boolean>;\n  getMutationResult(statementId: string): MutationResult | null;\n  subscribe(listener: () => void): () => void;\n  getSnapshot(): QuerySnapshot;\n  activate(): void;\n  dispose(): void;\n}\n\n// ── Internal types ───────────────────────────────────────────────────────────\n\ninterface QueryEntry {\n  toolName: string;\n  args: unknown;\n  defaults: unknown;\n  cacheKey: string;\n  prevCacheKey?: string;\n  loading: boolean;\n  everFetched: boolean;\n  refreshInterval: number;\n  timer?: ReturnType<typeof setInterval>;\n  needsRefetch: boolean;\n  error?: OpenUIError;\n}\n\ninterface MutationEntry {\n  toolName: string;\n  result: MutationResult;\n  error?: OpenUIError;\n}\n\ninterface CacheEntry {\n  data: unknown;\n  inFlight: boolean;\n}\n\n// ── Utilities ────────────────────────────────────────────────────────────────\n\n/** JSON.stringify with stable key ordering at all nesting levels. */\nfunction stableStringify(value: unknown): string {\n  return JSON.stringify(value, (_key: string, val: unknown) => {\n    if (val && typeof val === \"object\" && !Array.isArray(val)) {\n      const sorted: Record<string, unknown> = {};\n      for (const k of Object.keys(val as object).sort()) {\n        sorted[k] = (val as any)[k];\n      }\n      return sorted;\n    }\n    // Serialize non-JSON-safe primitives to stable strings.\n    // evaluate() can pull arbitrary values from store/ref state,\n    // including undefined in object literals and edge-case numbers.\n    if (val === undefined) return \"__undefined__\";\n    if (typeof val === \"number\") {\n      if (Number.isNaN(val)) return \"__NaN__\";\n      if (val === Infinity) return \"__Inf__\";\n      if (val === -Infinity) return \"__-Inf__\";\n    }\n    return val;\n  });\n}\n\nfunction buildCacheKey(toolName: string, args: unknown, deps: unknown): string {\n  const depsKey = deps != null ? \"::\" + stableStringify(deps) : \"\";\n  return toolName + \"::\" + stableStringify(args) + depsKey;\n}\n\n// ── Factory ──────────────────────────────────────────────────────────────────\n\nexport function createQueryManager(toolProvider: ToolProvider | null): QueryManager {\n  const queries = new Map<string, QueryEntry>();\n  const mutations = new Map<string, MutationEntry>();\n  const cache = new Map<string, CacheEntry>();\n  const listeners = new Set<() => void>();\n\n  let snapshot: QuerySnapshot = {\n    __openui_loading: [],\n    __openui_refetching: [],\n    __openui_errors: [],\n  };\n  let snapshotJson = JSON.stringify(snapshot);\n  let disposed = false;\n  let generation = 0;\n\n  // ── Snapshot & notification ──────────────────────────────────────────────\n\n  function rebuildSnapshot(): boolean {\n    const out: QuerySnapshot = {\n      __openui_loading: [],\n      __openui_refetching: [],\n      __openui_errors: [],\n    };\n\n    for (const [sid, q] of queries) {\n      const entry = cache.get(q.cacheKey);\n      if (entry && entry.data !== undefined) {\n        // Use settled data (even while refetching — shows last good value)\n        out[sid] = entry.data;\n      } else if (q.prevCacheKey) {\n        const prev = cache.get(q.prevCacheKey);\n        if (prev && prev.data !== undefined) {\n          out[sid] = prev.data;\n        } else {\n          out[sid] = q.defaults;\n        }\n      } else {\n        out[sid] = q.defaults;\n      }\n      if (q.loading) {\n        out.__openui_loading.push(sid);\n        if (q.everFetched) out.__openui_refetching.push(sid);\n      }\n      if (q.error) out.__openui_errors.push(q.error);\n    }\n\n    for (const [sid, m] of mutations) {\n      out[sid] = m.result;\n      if (m.error) out.__openui_errors.push(m.error);\n    }\n\n    try {\n      const outJson = JSON.stringify(out);\n      if (outJson === snapshotJson) return false;\n      snapshot = out;\n      snapshotJson = outJson;\n    } catch {\n      snapshot = out;\n      snapshotJson = \"\";\n    }\n    return true;\n  }\n\n  function notify() {\n    for (const listener of [...listeners]) {\n      listener();\n    }\n  }\n\n  // ── Fetch execution ──────────────────────────────────────────────────────\n\n  async function executeFetch(cacheKey: string, statementId: string) {\n    if (!toolProvider) return;\n\n    const q = queries.get(statementId);\n    if (!q) return;\n\n    // Capture the cache key at fetch start — if the query's key changes\n    // while we're in-flight (deps changed), this fetch is stale.\n    const fetchKey = cacheKey;\n    const toolName = q.toolName;\n    const args = q.args;\n\n    // Mark in-flight — use undefined as \"no data yet\" sentinel (distinct from null)\n    let entry = cache.get(fetchKey);\n    if (!entry) {\n      entry = { data: undefined, inFlight: true };\n      cache.set(fetchKey, entry);\n    } else {\n      entry.inFlight = true;\n    }\n    q.loading = true;\n    rebuildSnapshot();\n    notify();\n\n    try {\n      const data = await toolProvider.callTool(toolName, (args as Record<string, unknown>) ?? {});\n      if (disposed) return;\n      // Query removed or moved to a different cache key while in-flight — discard\n      const current = queries.get(statementId);\n      if (!current || current.cacheKey !== fetchKey) {\n        entry.inFlight = false;\n        return;\n      }\n\n      entry.data = data ?? null;\n      current.everFetched = true;\n      current.error = undefined;\n\n      // Clean up previous cache entry — clear prevCacheKey FIRST so\n      // cleanupCacheEntry doesn't see this query as a live reference.\n      if (current.prevCacheKey && current.prevCacheKey !== fetchKey) {\n        const prevKey = current.prevCacheKey;\n        current.prevCacheKey = undefined;\n        cleanupCacheEntry(prevKey);\n      }\n    } catch (err) {\n      // Only update error state if this fetch is still current\n      const current = queries.get(statementId);\n      if (current && current.cacheKey === fetchKey) {\n        if (err instanceof ToolNotFoundError) {\n          current.error = {\n            source: \"query\",\n            code: \"tool-not-found\",\n            message: `Query tool \"${toolName}\" not found`,\n            statementId,\n            component: \"Query\",\n            toolName,\n            hint: err.availableTools.length\n              ? `Available tools: ${err.availableTools.join(\", \")}`\n              : undefined,\n          };\n        } else if (err instanceof McpToolError) {\n          current.error = {\n            source: \"query\",\n            code: \"mcp-error\",\n            message: `Query \"${toolName}\" returned an error: ${err.toolErrorText}`,\n            statementId,\n            component: \"Query\",\n            toolName,\n          };\n        } else {\n          const msg = err instanceof Error ? err.message : String(err);\n          current.error = {\n            source: \"query\",\n            code: \"tool-error\",\n            message: `Query \"${toolName}\" failed: ${msg}`,\n            statementId,\n            component: \"Query\",\n            toolName,\n          };\n        }\n      }\n      console.error(`Query \"${toolName}\" failed:`, err);\n    } finally {\n      entry.inFlight = false;\n      const current = queries.get(statementId);\n      // Only clear loading if this fetch is still current\n      if (current && current.cacheKey === fetchKey) {\n        current.loading = false;\n        if (rebuildSnapshot()) notify();\n        // Re-fetch if invalidation occurred while in-flight\n        if (current.needsRefetch) {\n          current.needsRefetch = false;\n          executeFetch(current.cacheKey, statementId);\n        }\n      } else {\n        if (rebuildSnapshot()) notify();\n      }\n    }\n  }\n\n  /** Remove a cache entry if no query references it. */\n  function cleanupCacheEntry(cacheKey: string) {\n    for (const q of queries.values()) {\n      if (q.cacheKey === cacheKey || q.prevCacheKey === cacheKey) return;\n    }\n    cache.delete(cacheKey);\n  }\n\n  // ── Query evaluation ─────────────────────────────────────────────────────\n\n  function evaluateQueries(queryNodes: QueryNode[]) {\n    if (disposed) return;\n\n    const activeIds = new Set(queryNodes.map((n) => n.statementId));\n\n    // Clean up removed queries\n    for (const [sid, q] of queries) {\n      if (!activeIds.has(sid)) {\n        if (q.timer) clearInterval(q.timer);\n        queries.delete(sid);\n        // Clean up cache entries that are no longer referenced\n        cleanupCacheEntry(q.cacheKey);\n        if (q.prevCacheKey) cleanupCacheEntry(q.prevCacheKey);\n      }\n    }\n\n    // Process active queries\n    for (const node of queryNodes) {\n      if (!node.complete) continue;\n\n      const cacheKey = buildCacheKey(node.toolName, node.args, node.deps);\n      const existing = queries.get(node.statementId);\n\n      if (existing) {\n        // Track previous cache key for fallback display\n        if (existing.cacheKey !== cacheKey) {\n          existing.prevCacheKey = existing.cacheKey;\n        }\n        existing.toolName = node.toolName;\n        existing.args = node.args;\n        existing.defaults = node.defaults;\n        existing.cacheKey = cacheKey;\n      } else {\n        queries.set(node.statementId, {\n          toolName: node.toolName,\n          args: node.args,\n          defaults: node.defaults,\n          cacheKey,\n          loading: false,\n          everFetched: false,\n          refreshInterval: 0,\n          needsRefetch: false,\n        });\n      }\n\n      const q = queries.get(node.statementId)!;\n\n      // Fire fetch if no settled data and not already in-flight\n      const entry = cache.get(cacheKey);\n      const hasSettledData = entry && entry.data !== undefined && !entry.inFlight;\n      if (toolProvider && !hasSettledData && !entry?.inFlight) {\n        executeFetch(cacheKey, node.statementId);\n      }\n\n      // Configure auto-refresh timer\n      const newInterval = node.refreshInterval ?? 0;\n      if (newInterval !== q.refreshInterval) {\n        if (q.timer) {\n          clearInterval(q.timer);\n          q.timer = undefined;\n        }\n        if (newInterval > 0) {\n          q.timer = setInterval(() => {\n            if (disposed || !toolProvider) return;\n            const entry = cache.get(q.cacheKey);\n            if (!entry?.inFlight) {\n              executeFetch(q.cacheKey, node.statementId);\n            }\n          }, newInterval * 1000);\n        }\n        q.refreshInterval = newInterval;\n      }\n    }\n\n    if (rebuildSnapshot()) notify();\n  }\n\n  // ── Query accessors ──────────────────────────────────────────────────────\n\n  function getResult(statementId: string): unknown {\n    const q = queries.get(statementId);\n    if (!q) return null;\n    const entry = cache.get(q.cacheKey);\n    if (entry && entry.data !== undefined) return entry.data;\n    // Fall back to previous cache entry while loading\n    if (q.prevCacheKey) {\n      const prev = cache.get(q.prevCacheKey);\n      if (prev && prev.data !== undefined) return prev.data;\n    }\n    return q.defaults;\n  }\n\n  function isLoading(statementId: string): boolean {\n    return queries.get(statementId)?.loading ?? false;\n  }\n\n  function isAnyLoading(): boolean {\n    for (const q of queries.values()) {\n      if (q.loading) return true;\n    }\n    return false;\n  }\n\n  function invalidate(statementIds?: string[]) {\n    if (disposed || !toolProvider) return;\n\n    const targets = statementIds?.length\n      ? statementIds.filter((sid) => queries.has(sid))\n      : [...queries.keys()];\n\n    for (const sid of targets) {\n      const q = queries.get(sid);\n      if (!q) continue;\n      const entry = cache.get(q.cacheKey);\n      if (entry?.inFlight) {\n        q.needsRefetch = true;\n      } else {\n        executeFetch(q.cacheKey, sid);\n      }\n    }\n  }\n\n  // ── Mutation methods ─────────────────────────────────────────────────────\n\n  function registerMutations(nodes: MutationNode[]) {\n    const activeIds = new Set(nodes.map((n) => n.statementId));\n\n    // Clean up removed mutations\n    for (const sid of mutations.keys()) {\n      if (!activeIds.has(sid)) mutations.delete(sid);\n    }\n\n    // Register/update active mutations\n    for (const node of nodes) {\n      const existing = mutations.get(node.statementId);\n      if (existing) {\n        if (existing.toolName !== node.toolName) {\n          existing.toolName = node.toolName;\n          existing.result = { status: \"idle\", data: null, error: null };\n          existing.error = undefined;\n        }\n      } else {\n        mutations.set(node.statementId, {\n          toolName: node.toolName,\n          result: { status: \"idle\" },\n        });\n      }\n    }\n\n    if (rebuildSnapshot()) notify();\n  }\n\n  async function fireMutation(\n    statementId: string,\n    evaluatedArgs: Record<string, unknown>,\n    refreshQueryIds?: string[],\n  ): Promise<boolean> {\n    if (disposed || !toolProvider) return false;\n    const m = mutations.get(statementId);\n    if (!m) return false;\n\n    // Reject concurrent calls on the same mutation — prevents double-submit\n    if (m.result.status === \"loading\") return false;\n\n    const gen = generation;\n\n    m.result = { status: \"loading\" };\n    rebuildSnapshot();\n    notify();\n\n    let success = false;\n    try {\n      const data = await toolProvider.callTool(m.toolName, evaluatedArgs);\n      if (disposed || gen !== generation) return false;\n      m.result = { status: \"success\", data };\n      m.error = undefined;\n      success = true;\n    } catch (err) {\n      if (disposed || gen !== generation) return false;\n      const msg = err instanceof Error ? err.message : String(err);\n      m.result = { status: \"error\", error: msg };\n      if (err instanceof ToolNotFoundError) {\n        m.error = {\n          source: \"mutation\",\n          code: \"tool-not-found\",\n          message: `Mutation tool \"${m.toolName}\" not found`,\n          statementId,\n          component: \"Mutation\",\n          toolName: m.toolName,\n          hint: err.availableTools.length\n            ? `Available tools: ${err.availableTools.join(\", \")}`\n            : undefined,\n        };\n      } else if (err instanceof McpToolError) {\n        m.error = {\n          source: \"mutation\",\n          code: \"mcp-error\",\n          message: `Mutation \"${m.toolName}\" returned an error: ${err.toolErrorText}`,\n          statementId,\n          component: \"Mutation\",\n          toolName: m.toolName,\n        };\n      } else {\n        m.error = {\n          source: \"mutation\",\n          code: \"tool-error\",\n          message: `Mutation \"${m.toolName}\" failed: ${msg}`,\n          statementId,\n          component: \"Mutation\",\n          toolName: m.toolName,\n        };\n      }\n    }\n\n    rebuildSnapshot();\n    notify();\n\n    if (success && refreshQueryIds?.length) {\n      invalidate(refreshQueryIds);\n    }\n\n    return success;\n  }\n\n  function getMutationResult(statementId: string): MutationResult | null {\n    return mutations.get(statementId)?.result ?? null;\n  }\n\n  // ── Pub/sub ──────────────────────────────────────────────────────────────\n\n  function subscribe(listener: () => void): () => void {\n    listeners.add(listener);\n    return () => listeners.delete(listener);\n  }\n\n  function getSnapshot(): QuerySnapshot {\n    return snapshot;\n  }\n\n  // ── Lifecycle ────────────────────────────────────────────────────────────\n\n  function activate() {\n    disposed = false;\n  }\n\n  function dispose() {\n    disposed = true;\n    generation++;\n    listeners.clear();\n    // Clear timers and transient state, preserve cache + query entries for Strict Mode re-attach\n    for (const q of queries.values()) {\n      if (q.timer) {\n        clearInterval(q.timer);\n        q.timer = undefined;\n      }\n      q.refreshInterval = 0;\n      q.loading = false;\n      q.needsRefetch = false;\n    }\n    mutations.clear();\n  }\n\n  return {\n    evaluateQueries,\n    getResult,\n    isLoading,\n    isAnyLoading,\n    invalidate,\n    registerMutations,\n    fireMutation,\n    getMutationResult,\n    subscribe,\n    getSnapshot,\n    activate,\n    dispose,\n  };\n}\n","import type { EvaluationContext } from \"./evaluator\";\nimport { evaluate, isReactiveAssign } from \"./evaluator\";\nimport type { Store } from \"./store\";\n\nexport interface StateField<T = unknown> {\n  name: string;\n  value: T;\n  setValue: (newValue: T) => void;\n  isReactive: boolean;\n}\n\nexport type InferStateFieldValue<T> = T extends StateField<infer U> ? U : T;\n\nexport function resolveStateField<T = unknown>(\n  name: string,\n  bindingValue: unknown,\n  store: Store | null,\n  evaluationContext: EvaluationContext | null,\n  fieldGetter: (fieldName: string) => unknown,\n  fieldSetter: (fieldName: string, value: unknown) => void,\n): StateField<T> {\n  if (isReactiveAssign(bindingValue) && store && evaluationContext) {\n    const { target, expr } = bindingValue;\n    return {\n      name,\n      value: store.get(target) as T,\n      setValue: (value: T) => {\n        const extraScope: Record<string, unknown> = { $value: value };\n        const nextValue = evaluate(expr, { ...evaluationContext, extraScope });\n        store.set(target, nextValue);\n      },\n      isReactive: true,\n    };\n  }\n\n  return {\n    name,\n    value: (fieldGetter(name) ?? bindingValue) as T,\n    setValue: (value: T) => fieldSetter(name, value),\n    isReactive: false,\n  };\n}\n","// ─────────────────────────────────────────────────────────────────────────────\n// Reactive state store for openui-lang\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface Store {\n  get(name: string): unknown;\n  set(name: string, value: unknown): void;\n  subscribe(listener: () => void): () => void;\n  getSnapshot(): Record<string, unknown>;\n  initialize(defaults: Record<string, unknown>, persisted: Record<string, unknown>): void;\n  dispose(): void;\n}\n\nexport function createStore(): Store {\n  const state = new Map<string, unknown>();\n  const listeners = new Set<() => void>();\n  let snapshot: Record<string, unknown> = {};\n\n  function notify() {\n    const currentListeners = [...listeners];\n    for (const listener of currentListeners) {\n      listener();\n    }\n  }\n\n  function rebuildSnapshot() {\n    snapshot = Object.fromEntries(state);\n  }\n\n  function get(name: string): unknown {\n    return state.get(name);\n  }\n\n  function set(name: string, value: unknown): void {\n    const existing = state.get(name);\n    if (Object.is(existing, value)) return;\n    // Shallow-compare plain objects (form data)\n    if (\n      value &&\n      existing &&\n      typeof value === \"object\" &&\n      typeof existing === \"object\" &&\n      !Array.isArray(value) &&\n      !Array.isArray(existing)\n    ) {\n      const nk = Object.keys(value as Record<string, unknown>);\n      const ok = Object.keys(existing as Record<string, unknown>);\n      if (\n        nk.length === ok.length &&\n        nk.every((k) =>\n          Object.is(\n            (value as Record<string, unknown>)[k],\n            (existing as Record<string, unknown>)[k],\n          ),\n        )\n      ) {\n        return;\n      }\n    }\n    state.set(name, value);\n    rebuildSnapshot();\n    notify();\n  }\n\n  function subscribe(listener: () => void): () => void {\n    listeners.add(listener);\n    return () => {\n      listeners.delete(listener);\n    };\n  }\n\n  function getSnapshot(): Record<string, unknown> {\n    return snapshot;\n  }\n\n  function initialize(defaults: Record<string, unknown>, persisted: Record<string, unknown>): void {\n    // Apply persisted values (explicit restore) and defaults for NEW keys only.\n    // Existing user-modified $binding values are always preserved — never\n    // overwrite with defaults, never delete. During streaming, declarations\n    // can temporarily disappear; deleting user state here would cause data loss.\n    for (const key of Object.keys(persisted)) {\n      state.set(key, persisted[key]);\n    }\n    for (const key of Object.keys(defaults)) {\n      if (!state.has(key)) {\n        state.set(key, defaults[key]);\n      }\n    }\n    rebuildSnapshot();\n    notify();\n  }\n\n  function dispose(): void {\n    state.clear();\n    listeners.clear();\n    snapshot = {};\n  }\n\n  return { get, set, subscribe, getSnapshot, initialize, dispose };\n}\n","export interface ParsedRule {\n  type: string;\n  arg?: number | string;\n}\n\n/**\n * Parse a rule string into a structured rule.\n *   \"required\"       → { type: \"required\" }\n *   \"min:8\"          → { type: \"min\", arg: 8 }\n *   \"minLength:3\"    → { type: \"minLength\", arg: 3 }\n *   \"pattern:^[a-z]\" → { type: \"pattern\", arg: \"^[a-z]\" }\n */\nconst NUMERIC_RULES = new Set([\"min\", \"max\", \"minLength\", \"maxLength\"]);\n\nexport function parseRule(rule: string): ParsedRule {\n  const colonIdx = rule.indexOf(\":\");\n  if (colonIdx === -1) return { type: rule };\n\n  const type = rule.slice(0, colonIdx);\n  const rawArg = rule.slice(colonIdx + 1);\n  const arg = NUMERIC_RULES.has(type) && !Number.isNaN(Number(rawArg)) ? Number(rawArg) : rawArg;\n  return { type, arg };\n}\n\nexport function parseRules(rules: unknown): ParsedRule[] {\n  if (!Array.isArray(rules)) return [];\n  return rules.filter((r): r is string => typeof r === \"string\").map(parseRule);\n}\n\nexport type ValidatorFn = (value: unknown, arg?: number | string) => string | undefined;\n\nfunction isEmpty(value: unknown): boolean {\n  if (value === null || value === undefined || value === \"\") return true;\n  if (Array.isArray(value) && value.length === 0) return true;\n  // Form state stores { value, componentType } — extract actual value for validation\n  if (value && typeof value === \"object\" && !Array.isArray(value) && \"value\" in value) {\n    return isEmpty((value as { value: unknown }).value);\n  }\n  // Empty plain object (e.g. CheckBoxGroup with no selection)\n  if (\n    typeof value === \"object\" &&\n    value !== null &&\n    !Array.isArray(value) &&\n    Object.keys(value).length === 0\n  ) {\n    return true;\n  }\n  return false;\n}\n\nexport const builtInValidators: Record<string, ValidatorFn> = {\n  required: (value) => {\n    if (isEmpty(value)) return \"This field is required\";\n    if (typeof value === \"object\" && !Array.isArray(value) && value !== null) {\n      const vals = Object.values(value);\n      if (vals.length > 0 && vals.every((v) => typeof v === \"boolean\") && !vals.some(Boolean)) {\n        return \"At least one option is required\";\n      }\n    }\n    return undefined;\n  },\n\n  email: (value) => {\n    if (isEmpty(value)) return undefined;\n    if (typeof value !== \"string\") return \"Please enter a valid email\";\n    return /^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/.test(value) ? undefined : \"Please enter a valid email\";\n  },\n\n  url: (value) => {\n    if (isEmpty(value)) return undefined;\n    if (typeof value !== \"string\") return \"Please enter a valid URL\";\n    try {\n      new URL(value);\n      return undefined;\n    } catch {\n      return \"Please enter a valid URL\";\n    }\n  },\n\n  numeric: (value) => {\n    if (isEmpty(value)) return undefined;\n    if (typeof value === \"number\" && !isNaN(value)) return undefined;\n    if (typeof value === \"string\" && !isNaN(parseFloat(value)) && value.trim() !== \"\")\n      return undefined;\n    return \"Must be a number\";\n  },\n\n  min: (value, arg) => {\n    if (isEmpty(value)) return undefined;\n    const n = typeof value === \"number\" ? value : parseFloat(String(value));\n    if (isNaN(n)) return undefined;\n    const min = Number(arg);\n    return n >= min ? undefined : `Must be at least ${min}`;\n  },\n\n  max: (value, arg) => {\n    if (isEmpty(value)) return undefined;\n    const n = typeof value === \"number\" ? value : parseFloat(String(value));\n    if (isNaN(n)) return undefined;\n    const max = Number(arg);\n    return n <= max ? undefined : `Must be no more than ${max}`;\n  },\n\n  minLength: (value, arg) => {\n    if (isEmpty(value)) return undefined;\n    if (typeof value !== \"string\") return undefined;\n    const min = Number(arg);\n    return value.length >= min ? undefined : `Must be at least ${min} characters`;\n  },\n\n  maxLength: (value, arg) => {\n    if (isEmpty(value)) return undefined;\n    if (typeof value !== \"string\") return undefined;\n    const max = Number(arg);\n    return value.length <= max ? undefined : `Must be no more than ${max} characters`;\n  },\n\n  pattern: (value, arg) => {\n    if (isEmpty(value)) return undefined;\n    if (typeof value !== \"string\" || typeof arg !== \"string\") return undefined;\n    try {\n      return new RegExp(arg).test(value) ? undefined : \"Invalid format\";\n    } catch {\n      return undefined;\n    }\n  },\n};\n\n/**\n * Run all rules against a value. Stop on first error.\n * Custom validators are checked first, then built-in ones.\n */\nexport function validate(\n  value: unknown,\n  rules: ParsedRule[],\n  customValidators?: Record<string, ValidatorFn>,\n): string | undefined {\n  for (const rule of rules) {\n    const validator = customValidators?.[rule.type] ?? builtInValidators[rule.type];\n    if (!validator) {\n      console.warn(`[openui] Unknown validation rule type: \"${rule.type}\"`);\n      continue;\n    }\n    const error = validator(value, rule.arg);\n    if (error) return error;\n  }\n  return undefined;\n}\n\n/**\n * Parse a structured rules object into ParsedRule[].\n * Accepts: { required: true, minLength: 5, email: true, max: 100 }\n * Skips keys with false/undefined values.\n */\nexport function parseStructuredRules(rules: unknown): ParsedRule[] {\n  if (!rules || typeof rules !== \"object\" || Array.isArray(rules)) return [];\n  const obj = rules as Record<string, any>;\n  const result: ParsedRule[] = [];\n  for (const [key, val] of Object.entries(obj)) {\n    if (val === false || val === undefined || val === null) continue;\n    if (val === true) {\n      result.push({ type: key });\n    } else {\n      result.push({ type: key, arg: val });\n    }\n  }\n  return result;\n}\n"],"mappings":"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"}