yaml-flow 8.4.3 → 8.4.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/browser/asset-integrity.json +3 -3
- package/browser/board-livecards-localstorage.js +5 -5
- package/cli/{board-live-cards-lib-tjYsPt5U.d.ts → board-live-cards-lib-COi4bSpk.d.ts} +1 -0
- package/cli/browser-api/board-live-cards-browser-adapter.d.ts +2 -2
- package/cli/browser-api/card-store-browser-api.d.ts +1 -1
- package/cli/browser-api/card-store-browser-api.js +1 -1
- package/cli/node/artifacts-store-cli.js +2 -2
- package/cli/node/batch-runner-cli.js +1 -1
- package/cli/node/board-live-cards-cli.js +10 -10
- package/cli/node/card-store-cli.js +2 -2
- package/cli/node/chat-store-cli.d.ts +9 -9
- package/cli/node/chat-store-cli.js +7 -7
- package/cli/node/execution-adapter.js +2 -2
- package/cli/node/fs-board-adapter.d.ts +4 -4
- package/cli/node/fs-board-adapter.js +10 -10
- package/cli/node/step-machine-cli.js +3 -3
- package/cli/{types-Dc2VRMUw.d.ts → types-BkJvnXVD.d.ts} +1 -1
- package/examples/board/demo-shell-with-server.html +2 -2
- package/examples/board/doc.html +2 -2
- package/examples/board/server/chat-flow/flow-steps.json +8 -4
- package/examples/board-local/demo-shell-localstorage.html +3 -3
- package/lib/artifacts-store-public.d.cts +1 -1
- package/lib/artifacts-store-public.d.ts +1 -1
- package/lib/board-live-cards-node.cjs +10 -10
- package/lib/board-live-cards-node.d.cts +4 -4
- package/lib/board-live-cards-node.d.ts +4 -4
- package/lib/board-live-cards-node.js +10 -10
- package/lib/{board-live-cards-public-BM6jCEIa.d.cts → board-live-cards-public-CU8VVw3v.d.cts} +1 -0
- package/lib/{board-live-cards-public-Bz07XKRK.d.ts → board-live-cards-public-Crjm8KWn.d.ts} +1 -0
- package/lib/board-live-cards-public.cjs +2 -2
- package/lib/board-live-cards-public.d.cts +1 -1
- package/lib/board-live-cards-public.d.ts +1 -1
- package/lib/board-live-cards-public.js +2 -2
- package/lib/board-live-cards-server-runtime.cjs +3 -3
- package/lib/board-live-cards-server-runtime.d.cts +2 -2
- package/lib/board-live-cards-server-runtime.d.ts +2 -2
- package/lib/board-live-cards-server-runtime.js +3 -3
- package/lib/card-store-public.d.cts +1 -1
- package/lib/card-store-public.d.ts +1 -1
- package/lib/chat-store-public.d.cts +2 -2
- package/lib/chat-store-public.d.ts +2 -2
- package/lib/server-runtime/index.cjs +3 -3
- package/lib/server-runtime/index.d.cts +3 -3
- package/lib/server-runtime/index.d.ts +3 -3
- package/lib/server-runtime/index.js +3 -3
- package/lib/step-machine-public/index.cjs +3 -3
- package/lib/step-machine-public/index.js +3 -3
- package/lib/{types-Cn0b8G-i.d.ts → types-BC8ZnA6i.d.ts} +1 -1
- package/lib/{types-Dszjwfud.d.cts → types-DX8wXuZ0.d.cts} +1 -1
- package/package.json +1 -1
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
{
|
|
2
|
-
"generatedAt": "2026-05-
|
|
2
|
+
"generatedAt": "2026-05-19T23:49:11.003Z",
|
|
3
3
|
"algorithm": "sha256",
|
|
4
4
|
"files": {
|
|
5
5
|
"browser/board-livecards-localstorage.js": {
|
|
6
|
-
"sha256": "sha256-
|
|
7
|
-
"bytes":
|
|
6
|
+
"sha256": "sha256-PMW7B8y+CH76jEhL35AZZUIOO4QsFttxkmMb6S6EPbk=",
|
|
7
|
+
"bytes": 100280
|
|
8
8
|
},
|
|
9
9
|
"browser/live-cards.schema.json": {
|
|
10
10
|
"sha256": "sha256-9CUv3YSTpgq3k0Dsi8bs7bNUlGoBA1SGWMCBSZcbzys=",
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
var BoardLiveCardsLocalStorage=(function(exports){'use strict';var Gr=Object.defineProperty;var Ur=(t,e,r)=>e in t?Gr(t,e,{enumerable:true,configurable:true,writable:true,value:r}):t[e]=r;var Oe=(t,e,r)=>Ur(t,e+"",r);var re="b64:";function Jr(t){let e=new TextEncoder().encode(t),r=globalThis.Buffer,n;if(r)n=r.from(e).toString("base64");else if(typeof btoa=="function"){let o="";for(let s of e)o+=String.fromCharCode(s);n=btoa(o);}else throw new Error("No base64 encoder available in this runtime");return n.replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function Hr(t){let e=t.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-t.length%4)%4),r=globalThis.Buffer;if(r)return r.from(e,"base64").toString("utf8");if(typeof atob=="function"){let n=atob(e),o=new Uint8Array(n.length);for(let s=0;s<n.length;s+=1)o[s]=n.charCodeAt(s);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function ot(t){return `${re}${Jr(JSON.stringify(t))}`}function St(t){if(!t.startsWith(re))throw new Error(`Invalid ref format (expected ${re}<base64url(json)>): ${t}`);let e;try{e=JSON.parse(Hr(t.slice(re.length)));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${t}`)}if(!e||typeof e!="object")throw new Error(`Invalid ref format (expected object payload): ${t}`);let r=e;if(typeof r.kind!="string"||typeof r.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${t}`);return {kind:r.kind,value:r.value}}async function Be(t,e,r){let n=t.tryAcquire();if(!n)return false;try{await e();}finally{n();}return r?.(),true}var It={RUNNING:"running",COMPLETED:"completed",FAILED:"failed",INACTIVATED:"inactivated"};function gt(t){return t?Array.isArray(t.provides)?t.provides:[]:[]}function Et(t){return t?Array.isArray(t.requires)?t.requires:[]:[]}function je(t){return t.tasks??{}}function Ce(t){return t?t.status===It.FAILED||t.status===It.INACTIVATED:false}function $e(t,e){return t.refreshStrategy??e?.refreshStrategy??"data-changed"}function Ne(t){return t.maxExecutions}function Fe(t,e){let r=new Set;for(let[n,o]of Object.entries(e))if(o.status===It.COMPLETED){let s=t.tasks[n];s&>(s).forEach(a=>r.add(a));}return Array.from(r)}function De(t,e){let r={};return t.forEach(n=>{let o=e[n];if(!o)return;gt(o).forEach(i=>{r[i]||(r[i]=[]),r[i].push(n);});}),r}function Le(t,e,r){let n=t.tasks[e]??ne(),o={};if(r){let i=r.tasks[e],a=Et(i);for(let c of a)for(let[f,p]of Object.entries(r.tasks))if(gt(p).includes(c)){let g=t.tasks[f];g?.lastDataHash&&(o[c]=g.lastDataHash);break}}let s={...n,status:"running",startedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),progress:0,error:void 0,startConsumedHashes:o};return {...t,tasks:{...t.tasks,[e]:s},lastUpdated:new Date().toISOString()}}function qe(t,e,r,n,o,s){let i=t.tasks[r]??ne(),a=e.tasks[r];if(!a)throw new Error(`Task "${r}" not found in graph`);let c;n&&a.on&&a.on[n]?c=a.on[n]:c=gt(a);let f=i.startConsumedHashes?{...i.startConsumedHashes}:{...i.lastConsumedHashes};if(!i.startConsumedHashes){let l=a.requires??[];for(let h of l)for(let[y,S]of Object.entries(e.tasks))if(gt(S).includes(h)){let T=t.tasks[y];T?.lastDataHash&&(f[h]=T.lastDataHash);break}}let p={...i,status:"completed",completedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),executionCount:i.executionCount+1,lastEpoch:i.executionCount+1,lastDataHash:o,data:s,lastConsumedHashes:f,error:void 0},g=[...new Set([...t.availableOutputs,...c])];return {...t,tasks:{...t.tasks,[r]:p},availableOutputs:g,lastUpdated:new Date().toISOString()}}function Pe(t,e,r,n){let o=t.tasks[r]??ne(),s=e.tasks[r];if(s?.retry){let c=o.retryCount+1;if(c<=s.retry.max_attempts){let f={...o,status:"not-started",retryCount:c,lastUpdated:new Date().toISOString(),error:n};return {...t,tasks:{...t.tasks,[r]:f},lastUpdated:new Date().toISOString()}}}let i={...o,status:"failed",failedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),error:n,executionCount:o.executionCount+1},a=t.availableOutputs;if(s?.on_failure&&s.on_failure.length>0&&(a=[...new Set([...t.availableOutputs,...s.on_failure])]),s?.circuit_breaker&&i.executionCount>=s.circuit_breaker.max_executions){let c=s.circuit_breaker.on_break;a=[...new Set([...a,...c])];}return {...t,tasks:{...t.tasks,[r]:i},availableOutputs:a,lastUpdated:new Date().toISOString()}}function Me(t,e,r,n){let o=t.tasks[e]??ne(),s={...o,progress:typeof n=="number"?n:o.progress,messages:[...o.messages??[],...r?[{message:r,timestamp:new Date().toISOString(),status:o.status}]:[]],lastUpdated:new Date().toISOString()};return {...t,tasks:{...t.tasks,[e]:s},lastUpdated:new Date().toISOString()}}function Ge(t,e){let r=t.tasks[e];if(!r)return t;let n={...r,status:"not-started",startedAt:void 0,completedAt:void 0,failedAt:void 0,error:void 0,data:void 0,progress:null,lastUpdated:new Date().toISOString()};return {...t,tasks:{...t.tasks,[e]:n},lastUpdated:new Date().toISOString()}}function ne(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function oe(t,e){let r=`live-${Date.now()}`,n={};for(let s of Object.keys(t.tasks))n[s]=Je();let o={status:"running",tasks:n,availableOutputs:[],stuckDetection:{is_stuck:false,stuck_description:null,outputs_unresolvable:[],tasks_blocked:[]},lastUpdated:new Date().toISOString(),executionId:r,executionConfig:{executionMode:t.settings.execution_mode??"eligibility-mode",conflictStrategy:t.settings.conflict_strategy??"alphabetical",completionStrategy:t.settings.completion}};return {config:t,state:o}}function Vr(t,e){let{config:r,state:n}=t;if("executionId"in e&&e.executionId&&e.executionId!==n.executionId)return t;switch(e.type){case "task-started":return {config:r,state:Le(n,e.taskName,r)};case "task-completed":return {config:r,state:qe(n,r,e.taskName,e.result,e.dataHash,e.data)};case "task-failed":return {config:r,state:Pe(n,r,e.taskName,e.error)};case "task-progress":return {config:r,state:Me(n,e.taskName,e.message,e.progress)};case "task-restart":return {config:r,state:Ge(n,e.taskName)};case "inject-tokens":return {config:r,state:{...n,availableOutputs:[...new Set([...n.availableOutputs,...e.tokens])],lastUpdated:new Date().toISOString()}};case "agent-action":return {config:r,state:Qr(n,e.action)};case "task-upsert":return Kr(t,e.taskName,e.taskConfig);case "task-removal":return zr(t,e.taskName);case "node-requires-add":return Wr(t,e.nodeName,e.tokens);case "node-requires-remove":return Xr(t,e.nodeName,e.tokens);case "node-provides-add":return Yr(t,e.nodeName,e.tokens);case "node-provides-remove":return Zr(t,e.nodeName,e.tokens);default:return t}}function Ue(t,e){return e.reduce((r,n)=>Vr(r,n),t)}function Kr(t,e,r){let n=!!t.config.tasks[e];return {config:{...t.config,tasks:{...t.config.tasks,[e]:r}},state:{...t.state,tasks:{...t.state.tasks,[e]:n?t.state.tasks[e]:Je()},lastUpdated:new Date().toISOString()}}}function zr(t,e){if(!t.config.tasks[e])return t;let{[e]:r,...n}=t.config.tasks,{[e]:o,...s}=t.state.tasks;return {config:{...t.config,tasks:n},state:{...t.state,tasks:s,lastUpdated:new Date().toISOString()}}}function Wr(t,e,r){let n=t.config.tasks[e];if(!n)return t;let o=Et(n),s=r.filter(i=>!o.includes(i));return s.length===0?t:{config:{...t.config,tasks:{...t.config.tasks,[e]:{...n,requires:[...o,...s]}}},state:t.state}}function Xr(t,e,r){let n=t.config.tasks[e];if(!n)return t;let o=Et(n),s=o.filter(i=>!r.includes(i));return s.length===o.length?t:{config:{...t.config,tasks:{...t.config.tasks,[e]:{...n,requires:s}}},state:t.state}}function Yr(t,e,r){let n=t.config.tasks[e];if(!n)return t;let o=gt(n),s=r.filter(i=>!o.includes(i));return s.length===0?t:{config:{...t.config,tasks:{...t.config.tasks,[e]:{...n,provides:[...o,...s]}}},state:t.state}}function Zr(t,e,r){let n=t.config.tasks[e];if(!n)return t;let o=gt(n),s=o.filter(i=>!r.includes(i));return s.length===o.length?t:{config:{...t.config,tasks:{...t.config.tasks,[e]:{...n,provides:s}}},state:t.state}}function Kt(t){return {version:1,config:t.config,state:t.state,snapshotAt:new Date().toISOString()}}function se(t){if(!t||typeof t!="object")throw new Error("Invalid snapshot: expected an object");let e=t;if(!e.config||typeof e.config!="object")throw new Error('Invalid snapshot: missing or invalid "config"');if(!e.state||typeof e.state!="object")throw new Error('Invalid snapshot: missing or invalid "state"');let r=e.config,n=e.state;if(!r.settings||typeof r.settings!="object")throw new Error("Invalid snapshot: config.settings missing");if(!r.tasks||typeof r.tasks!="object")throw new Error("Invalid snapshot: config.tasks missing");if(!n.tasks||typeof n.tasks!="object")throw new Error("Invalid snapshot: state.tasks missing");if(!Array.isArray(n.availableOutputs))throw new Error("Invalid snapshot: state.availableOutputs must be an array");return {config:r,state:n}}function Je(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function Qr(t,e){let r=new Date().toISOString();switch(e){case "stop":return {...t,status:"stopped",lastUpdated:r};case "pause":return {...t,status:"paused",lastUpdated:r};case "resume":return {...t,status:"running",lastUpdated:r};default:return t}}function zt(t){let{config:e,state:r}=t,n=je(e);if(Object.keys(n).length===0)return {eligible:[],pending:[],unresolved:[],blocked:[],conflicts:{}};let s=tn(n),i=Fe(e,r.tasks),a=new Set([...i,...r.availableOutputs]),c=[],f=[],p=[],g=[];for(let[h,y]of Object.entries(n)){let S=r.tasks[h],T=$e(y,e.settings),I=T!=="once";if(S?.status===It.RUNNING||Ce(S))continue;let b=Ne(y);if(b!==void 0&&S&&S.executionCount>=b||y.circuit_breaker&&S&&S.executionCount>=y.circuit_breaker.max_executions||!I&&S?.status===It.COMPLETED)continue;if(I&&S?.status===It.COMPLETED){let A=Et(y),B=false;switch(T){case "data-changed":{A.length>0&&A.some(J=>{for(let[V,st]of Object.entries(n))if(gt(st).includes(J)){let Z=r.tasks[V];if(!Z)continue;let _t=S.lastConsumedHashes?.[J];return Z.lastDataHash==null?Z.executionCount>S.lastEpoch:Z.lastDataHash!==_t}return false})||(B=true);break}case "epoch-changed":{A.length>0&&A.some(J=>{for(let[V,st]of Object.entries(n))if(gt(st).includes(J)){let Z=r.tasks[V];if(Z&&Z.executionCount>S.lastEpoch)return true}return false})||(B=true);break}case "time-based":{let L=y.refreshInterval??0;if(L<=0){B=true;break}let J=S.completedAt;if(!J){B=true;break}(Date.now()-Date.parse(J))/1e3<L&&(B=true);break}case "manual":B=true;break}if(B)continue}let _=Et(y);if(_.length===0){c.push(h);continue}let F=[],U=[],x=[];for(let A of _){if(a.has(A))continue;let B=s[A]||[];B.length===0?F.push(A):B.every(J=>Ce(r.tasks[J]))?x.push({token:A,failedProducer:B[0]}):U.push(A);}F.length>0?p.push({taskName:h,missingTokens:F}):x.length>0?g.push({taskName:h,failedTokens:x.map(A=>A.token),failedProducers:[...new Set(x.map(A=>A.failedProducer))]}):U.length>0?f.push({taskName:h,waitingOn:U}):c.push(h);}let l={};if(c.length>1){let h=De(c,n);for(let[y,S]of Object.entries(h))S.length>1&&(l[y]=S);}return {eligible:c,pending:f,unresolved:p,blocked:g,conflicts:l}}function tn(t){let e={};for(let[r,n]of Object.entries(t)){for(let o of gt(n))e[o]||(e[o]=[]),e[o].push(r);if(n.on)for(let o of Object.values(n.on))for(let s of o)e[s]||(e[s]=[]),e[s].includes(r)||e[s].push(r);if(n.on_failure)for(let o of n.on_failure)e[o]||(e[o]=[]),e[o].includes(r)||e[o].push(r);}return e}var Wt=class{constructor(){Oe(this,"buffer",[]);}append(e){this.buffer.push(e);}drain(){let e=this.buffer;return this.buffer=[],e}get size(){return this.buffer.length}};function be(t){let e=Re(t);return en(e)}function Re(t){if(t==null||typeof t!="object")return JSON.stringify(t);if(Array.isArray(t))return "["+t.map(Re).join(",")+"]";let e=t;return "{"+Object.keys(e).sort().map(n=>JSON.stringify(n)+":"+Re(e[n])).join(",")+"}"}function en(t){let e=0xcbf29ce484222325n,r=0x100000001b3n,n=0xffffffffffffffffn;for(let o=0;o<t.length;o++)e^=BigInt(t.charCodeAt(o)),e=e*r&n;return e.toString(16).padStart(16,"0")}function rn(t){if(typeof Buffer<"u")return Buffer.from(t,"utf8").toString("base64url");if(typeof btoa=="function"){let e=new TextEncoder().encode(t),r="";for(let n of e)r+=String.fromCharCode(n);return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}throw new Error("No base64 encoder available in this runtime")}function nn(t){if(typeof Buffer<"u")return Buffer.from(t,"base64url").toString("utf8");if(typeof atob=="function"){let e=t.replace(/-/g,"+").replace(/_/g,"/"),r=e+"=".repeat((4-e.length%4)%4),n=atob(r),o=new Uint8Array(n.length);for(let s=0;s<n.length;s++)o[s]=n.charCodeAt(s);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function He(t){let e=JSON.stringify({t,n:Date.now().toString(36)+Math.random().toString(36).slice(2,6)});return rn(e)}function on(t){try{let e=JSON.parse(nn(t));return typeof e?.t=="string"?{taskName:e.t}:null}catch{return null}}function we(t,e,r){let{handlers:n,onDrain:o}=e,s=new Wt,i="state"in t&&"config"in t?t:oe(t),a=false,c=new Set,f=new Map(Object.entries(n)),p=new Wt,g=false,l=false;function h(){if(!a){if(g){l=true;return}g=true;try{do l=!1,y();while(l)}finally{g=false;}}}function y(){let b=p.drain(),_=s.drain(),F=[...b,..._];F.length>0&&(i=Ue(i,F));let U=zt(i);F.length>0&&o?.(F,i,U);for(let x of U.eligible)I(x);for(let x of F)if(x.type==="task-progress"){let{taskName:A,update:B}=x;if(!i.config.tasks[A])continue;let J=i.state.tasks[A];if(!J||J.status!=="running")continue;let V=He(A),st=T(A,V,B).catch(Z=>{a||(p.append({type:"task-failed",taskName:A,error:Z.message??String(Z),timestamp:new Date().toISOString()}),h());}).finally(()=>{c.delete(st);});c.add(st);}}function S(b){let F=i.config.tasks[b].requires??[],U=new Map;for(let[A,B]of Object.entries(i.config.tasks))for(let L of B.provides??[])U.set(L,A);let x={};for(let A of F){let B=U.get(A);B?x[A]=i.state.tasks[B]?.data:x[A]=void 0;}return x}async function T(b,_,F){let U=i.config.tasks[b],x=U.taskHandlers??[],A=S(b);for(let B of x){let L=f.get(B);if(!L)throw new Error(`Handler '${B}' not found in registry (task '${b}')`);let J={nodeId:b,state:A,taskState:i.state.tasks[b],config:U,callbackToken:_,update:F};if(await L(J)==="task-initiate-failure")throw new Error(`Handler '${B}' returned task-initiate-failure (task '${b}')`)}}function I(b){let F=i.config.tasks[b]?.taskHandlers;if(!F||F.length===0)return;p.append({type:"task-started",taskName:b,timestamp:new Date().toISOString()}),h();let U=He(b),x=T(b,U).catch(A=>{a||(p.append({type:"task-failed",taskName:b,error:A.message??String(A),timestamp:new Date().toISOString()}),h());}).finally(()=>{c.delete(x);});c.add(x);}return {push(b){a||(b.type==="task-completed"&&b.data&&!b.dataHash&&(b={...b,dataHash:be(b.data)}),s.append(b),h());},pushAll(b){if(!a){for(let _ of b)_.type==="task-completed"&&_.data&&!_.dataHash?s.append({..._,dataHash:be(_.data)}):s.append(_);h();}},resolveCallback(b,_,F){if(a)return;let U=on(b);if(!U)return;let{taskName:x}=U;if(i.config.tasks[x]){if(F&&F.length>0)s.append({type:"task-failed",taskName:x,error:F.join("; "),timestamp:new Date().toISOString()});else {let A=_&&Object.keys(_).length>0?be(_):void 0;s.append({type:"task-completed",taskName:x,data:_,dataHash:A,timestamp:new Date().toISOString()});}h();}},addNode(b,_){a||(s.append({type:"task-upsert",taskName:b,taskConfig:_,timestamp:new Date().toISOString()}),h());},removeNode(b){a||(s.append({type:"task-removal",taskName:b,timestamp:new Date().toISOString()}),h());},addRequires(b,_){a||(s.append({type:"node-requires-add",nodeName:b,tokens:_,timestamp:new Date().toISOString()}),h());},removeRequires(b,_){a||(s.append({type:"node-requires-remove",nodeName:b,tokens:_,timestamp:new Date().toISOString()}),h());},addProvides(b,_){a||(s.append({type:"node-provides-add",nodeName:b,tokens:_,timestamp:new Date().toISOString()}),h());},removeProvides(b,_){a||(s.append({type:"node-provides-remove",nodeName:b,tokens:_,timestamp:new Date().toISOString()}),h());},registerHandler(b,_){f.set(b,_);},unregisterHandler(b){f.delete(b);},retrigger(b){a||i.config.tasks[b]&&(s.append({type:"task-restart",taskName:b,timestamp:new Date().toISOString()}),h());},retriggerAll(b){if(!a){for(let _ of b)i.config.tasks[_]&&s.append({type:"task-restart",taskName:_,timestamp:new Date().toISOString()});h();}},snapshot(){return Kt(i)},getState(){return i},getSchedule(){return zt(i)},async waitForHandlers(){c.size>0&&await Promise.allSettled([...c]);},async dispose(b){b?.wait&&c.size>0&&await Promise.allSettled([...c]),a=true;}}}function ae(){return function(t){if(t==="./jsonata-sync.cjs")return typeof globalThis<"u"&&globalThis.__jsonataSync||typeof globalThis<"u"&&globalThis.jsonataSync;throw new Error("Unsupported require in browser bundle: "+t)}}var sn=ae();sn("./jsonata-sync.cjs");var an=ae(),ie=an("./jsonata-sync.cjs"),ze=ie;function Ve(t,e){if(!e||!t)return;let r=e.split("."),n=t;for(let o=0;o<r.length;o++){if(n==null)return;n=n[r[o]];}return n}function We(t,e,r){let n=e.split("."),o=t;for(let s=0;s<n.length-1;s++)(o[n[s]]==null||typeof o[n[s]]!="object")&&(o[n[s]]={}),o=o[n[s]];o[n[n.length-1]]=r;}async function cn(t,e){if(!t?.compute?.length)return t;t.card_data||(t.card_data={}),t.computed_values={},t._sourcesData=e?.sourcesData??{};let r=t.requires??{},n={card_data:t.card_data,requires:r,expects_data:r,fetched_sources:t._sourcesData,data:t.computed_values,computed_values:t.computed_values};for(let o of t.compute)try{let s=await ie(o.expr).evaluate(n);We(t.computed_values,o.bindTo,s),n.computed_values=t.computed_values;}catch{}return t}function un(t,e){if(!t?.compute?.length)return {ok:true,node:t};t.card_data||(t.card_data={}),t.computed_values={},t._sourcesData=e?.sourcesData??{};let r=t.requires??{},n={card_data:t.card_data,requires:r,expects_data:r,fetched_sources:t._sourcesData,data:t.computed_values,computed_values:t.computed_values},o=[];for(let s of t.compute)try{let i=ze(s.expr).evaluate(n);We(t.computed_values,s.bindTo,i),n.computed_values=t.computed_values;}catch(i){let a=i instanceof Error?i.message:String(i);o.push({bindTo:s.bindTo,error:a});}return o.length>0?{ok:true,node:t,errors:o}:{ok:true,node:t}}async function dn(t,e,r){let n={...r??{},card_data:e.card_data??{},requires:e.requires??{},fetched_sources:e._sourcesData??{},computed_values:e.computed_values??{}};return ie(t).evaluate(n)}function ln(t,e){return e.startsWith("fetched_sources.")?Ve(t._sourcesData??{},e.slice(16)):Ve(t,e)}var Ke=new Set(["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]),fn=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function gn(t){let e=[];if(!t||typeof t!="object"||Array.isArray(t))return {ok:false,errors:["Node must be a non-null object"]};let r=t;(typeof r.id!="string"||!r.id)&&e.push("id: required, must be a non-empty string");for(let n of Object.keys(r))fn.has(n)||e.push(`Unknown top-level key: "${n}"`);if((r.card_data==null||typeof r.card_data!="object"||Array.isArray(r.card_data))&&e.push("card_data: required, must be an object"),r.meta!=null)if(typeof r.meta!="object"||Array.isArray(r.meta))e.push("meta: must be an object");else {let n=r.meta;n.title!=null&&typeof n.title!="string"&&e.push("meta.title: must be a string"),n.tags!=null&&!Array.isArray(n.tags)&&e.push("meta.tags: must be an array");}if(r.requires!=null&&!Array.isArray(r.requires)&&e.push("requires: must be an array of strings"),r.provides!=null&&(Array.isArray(r.provides)?r.provides.forEach((n,o)=>{if(!n||typeof n!="object"||Array.isArray(n))e.push(`provides[${o}]: must be an object with bindTo and ref`);else {let s=n;(typeof s.bindTo!="string"||!s.bindTo)&&e.push(`provides[${o}]: missing required "bindTo" string`),(typeof s.ref!="string"||!s.ref)&&e.push(`provides[${o}]: missing required "ref" string`);}}):e.push("provides: must be an array of { bindTo, ref } bindings")),r.compute!=null&&(Array.isArray(r.compute)?r.compute.forEach((n,o)=>{if(!n||typeof n!="object"||Array.isArray(n))e.push(`compute[${o}]: must be a compute step object`);else {let s=n;(typeof s.bindTo!="string"||!s.bindTo)&&e.push(`compute[${o}]: missing required "bindTo" property`),(typeof s.expr!="string"||!s.expr)&&e.push(`compute[${o}]: missing required "expr" string (JSONata expression)`);}}):e.push("compute: must be an array of compute steps")),r.source_defs!=null)if(!Array.isArray(r.source_defs))e.push("source_defs: must be an array");else {let n=new Set,o=new Set;r.source_defs.forEach((s,i)=>{if(!s||typeof s!="object"||Array.isArray(s))e.push(`source_defs[${i}]: must be an object`);else {let a=s;typeof a.bindTo!="string"||!a.bindTo?e.push(`source_defs[${i}]: missing required "bindTo" property`):(n.has(a.bindTo)&&e.push(`source_defs[${i}]: bindTo "${a.bindTo}" is not unique across source_defs`),n.add(a.bindTo)),typeof a.outputFile!="string"||!a.outputFile?e.push(`source_defs[${i}]: missing required "outputFile" property`):(o.has(a.outputFile)&&e.push(`source_defs[${i}]: outputFile "${a.outputFile}" is not unique across source_defs`),o.add(a.outputFile)),a.optionalForCompletionGating!=null&&typeof a.optionalForCompletionGating!="boolean"&&e.push(`source_defs[${i}]: optionalForCompletionGating must be a boolean`);}});}if(r.view!=null)if(typeof r.view!="object"||Array.isArray(r.view))e.push("view: must be an object");else {let n=r.view;!Array.isArray(n.elements)||n.elements.length===0?e.push("view.elements: required, must be a non-empty array"):n.elements.forEach((o,s)=>{if(!o||typeof o!="object"){e.push(`view.elements[${s}]: must be an object`);return}!o.kind||typeof o.kind!="string"?e.push(`view.elements[${s}].kind: required, must be a string`):Ke.has(o.kind)||e.push(`view.elements[${s}].kind: unknown kind "${o.kind}". Valid: ${[...Ke].join(", ")}`),o.data!=null&&(typeof o.data!="object"||Array.isArray(o.data))&&e.push(`view.elements[${s}].data: must be an object`);}),n.layout!=null&&(typeof n.layout!="object"||Array.isArray(n.layout))&&e.push("view.layout: must be an object"),n.features!=null&&(typeof n.features!="object"||Array.isArray(n.features))&&e.push("view.features: must be an object");}return {ok:e.length===0,errors:e}}async function pn(t,e){if(!t||t.length===0)return [];let r={card_data:e.card_data??{},requires:e.requires??{}};return Promise.all(t.map(async n=>{let o={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[s,i]of Object.entries(n.projections))if(typeof i=="string"&&i.trim().length>0)try{o[s]=await ie(i).evaluate(r);}catch{o[s]=void 0;}}return {...n,_projections:o}}))}function mn(t,e){if(!t||t.length===0)return [];let r={card_data:e.card_data??{},requires:e.requires??{}};return t.map(n=>{let o={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[s,i]of Object.entries(n.projections))if(typeof i=="string"&&i.trim().length>0)try{o[s]=ze(i).evaluate(r);}catch{o[s]=void 0;}}return {...n,_projections:o}})}var Ut={run:cn,runSync:un,eval:dn,resolve:ln,validate:gn,enrichSources:pn,enrichSourcesSync:mn};function Xe(t){return JSON.stringify(t)}function Ye(t){let e;try{e=JSON.parse(t);}catch{throw new Error(`parseExecutionRef: invalid JSON \u2014 ${t}`)}if(typeof e!="object"||e===null||typeof e.howToRun!="string"||typeof e.whatToRun!="string")throw new Error(`parseExecutionRef: missing required fields howToRun/whatToRun \u2014 ${t}`);return e}function ce(t,e){function r(){return t.readIndex()??{}}function n(o,s,i){let a=String(s||"").split(".").filter(Boolean);if(a.length===0)return i&&typeof i=="object"&&!Array.isArray(i)?i:{value:i};let c={...o},f=c;for(let p=0;p<a.length-1;p++){let g=a[p],l=f[g],h=l&&typeof l=="object"&&!Array.isArray(l)?{...l}:{};f[g]=h,f=h;}return f[a[a.length-1]]=i,c}return {readCard(o){let s=r()[o];return !s||!t.cardExists(s.key)?null:t.readCard(s.key)},readCardKey(o){return r()[o]?.key??null},readAllCards(){let o=[];for(let[s,i]of Object.entries(r())){if(!t.cardExists(i.key))continue;let a=t.readCard(i.key);a?o.push(a):e?.(`[card-store] could not read card "${s}" at key "${i.key}"`);}return o},readChecksumIndex(){let o={};for(let[s,i]of Object.entries(r()))o[s]=i.checksum;return o},changedSince(o){let s=r(),i=[];for(let[a,c]of Object.entries(s))o[a]!==c.checksum&&i.push(a);for(let a of Object.keys(o))s[a]||i.push(a);return i},validateUpsert(o,s){let i=r(),a=i[o],c=Object.entries(i).find(([,f])=>f.key===s);return a&&a.key!==s?{ok:false,error:`Card id "${o}" is already mapped to key "${a.key}", cannot remap to "${s}"`}:c&&c[0]!==o?{ok:false,error:`Key "${s}" is already mapped to card id "${c[0]}", cannot remap to "${o}"`}:{ok:true}},writeCard(o,s,i){let a=r(),c=i??a[o]?.key??t.defaultCardKey(o),f=t.writeCard(c,s);a[o]={key:c,checksum:f,updatedAt:new Date().toISOString()},t.writeIndex(a);},patchCard(o,s,i){let a=r(),c=a[o];if(!c||!t.cardExists(c.key))throw new Error(`card "${o}" not found`);let f=t.readCard(c.key);if(!f||typeof f!="object"||Array.isArray(f))throw new Error(`card "${o}" is not patchable`);let p=n(f,s,i),g=t.writeCard(c.key,p);a[o]={key:c.key,checksum:g,updatedAt:new Date().toISOString()},t.writeIndex(a);},removeCard(o){let s=r();s[o]&&(delete s[o],t.writeIndex(s));},readIndex(){return r()}}}function ve(t,e){return {readSourceData(r,n){let o=t.read(`${r}/${n}`);if(o==null)return null;let s=o.trim();if(!s)return null;try{return JSON.parse(s)}catch{return s}},ingestSourceDataStaged(r,n,o,s){let i=e(o);t.write(`${r}/.staged/${s}/${n}`,i);},commitSourceData(r,n,o){let s=`${r}/.staged/${o}/${n}`,i=t.read(s);return i==null?false:(t.write(`${r}/${n}`,i),t.remove(s),true)},hasSource(r,n){return t.exists(`${r}/${n}`)}}}function rr(t){function e(r){let n=t.readAllEntries();if(!r)return n;let o=n.findIndex(s=>s.id===r);return o===-1?n:n.slice(o+1)}return {readEntriesAfterCursor(r){let n=e(r);return n.length===0?{events:[],newCursor:r}:{events:n.map(o=>o.event),newCursor:n[n.length-1].id}},pendingCount(r){return e(r).length},appendEvent(r){t.appendEntry({id:t.generateId(),event:r});}}}function nr(t,e){return {appendEntries(r,n){if(!r||n.length===0)return;let o=t.read(r)??[];t.write(r,[...o,...n]);},dispatchEntriesForJournalId(r,n){if(!r)return;let o=t.read(r);if(!(!o||o.length===0)){for(let s of o)try{n(s);}catch(i){let a=i instanceof Error?i.message:String(i);try{e(s,a);}catch{}}t.delete(r);}}}}var ue="v1",Nt="board/graph",or="board/lastJournalProcessedId";function Ze(t){return `cards/${t}/runtime`}function sr(t){return {readRuntime(e){return t.read(Ze(e))??{_sources:{}}},writeRuntime(e,r){t.write(Ze(e),r);}}}function hn(t,e){let r={...t};for(let n of e.deleteKeys)delete r[n];return {...r,...e.shallowMerge}}function ar(t){return {readSnapshot(e){return t.readValues(e)},commitSnapshot(e,r){if(r.schemaVersion!==ue)throw new Error(`Unsupported snapshot schema version: ${r.schemaVersion}`);let n=t.readValues(e);if(n.version!==r.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:n.version};let o=hn(n.values,r);return {ok:true,newVersion:t.writeValues(e,o,r.deleteKeys)}}}}function ir(t){function e(r){let n=t.read(r);return n==null?null:typeof n=="string"?n:JSON.stringify(n)}return {readTaskExecutorRef(){let r=e("task-executor");if(r?.trim())return Ye(r.trim())},writeTaskExecutorRef(r){t.write("task-executor",Xe(r));},readChatHandlerFlow(){return t.read("chat-handler-flow")},writeChatHandlerFlow(r){t.write("chat-handler-flow",r);},readCardStoreRef(){return e("card-store-ref")},writeCardStoreRef(r){t.write("card-store-ref",r);},readOutputsStoreRef(){return e("outputs-store-ref")},writeOutputsStoreRef(r){t.write("outputs-store-ref",r);},readScratchStoreRef(){return e("scratch-store-ref")},writeScratchStoreRef(r){t.write("scratch-store-ref",r);},readArchiveStoreRef(){return e("archive-store-ref")},writeArchiveStoreRef(r){t.write("archive-store-ref",r);}}}function cr(t){return {writeComputedValues(e,r){t.write(`cards/${e}/computed_values`,r);},readComputedValues(e){return t.read(`cards/${e}/computed_values`)},readAllComputedValues(){let e={};for(let r of t.listKeys("cards/")){let n=r.match(/^cards\/([^/]+)\/computed_values$/);n&&(e[n[1]]=t.read(r));}return e},writeDataObjects(e){for(let[r,n]of Object.entries(e))r&&t.write(`data-objects/${r}`,n);},readDataObject(e){return t.read(`data-objects/${e}`)},readAllDataObjects(){let e={};for(let r of t.listKeys("data-objects/"))e[r.slice(13)]=t.read(r);return e},writeStatusSnapshot(e){t.write("status",e);},readStatusSnapshot(){return t.read("status")}}}function Qe(t){return t?{lastRequestedToken:t.lastRequestedToken,lastCompletedToken:t.lastCompletedToken,lastCompletionStatus:t.lastCompletionStatus??(t.lastCompletedToken?"success":"not-started"),queueRequestedToken:t.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function yn(t){return t?.lastRequestedToken?t.lastCompletedToken!==t.lastRequestedToken:false}function tr(t,e){return t?.lastRequestedToken?yn(t)?"in-flight":!t.lastCompletedToken||t.lastCompletedToken<e?"dispatch":"idle":"dispatch"}function kn(t,e){return {...t,lastCompletedToken:e,lastCompletionStatus:"success"}}function er(t,e){return {...t,lastCompletedToken:e,lastCompletionStatus:"failure"}}function de(t,e){let r=e.state.tasks,n=e.config.tasks,o=Object.keys(r),s=zt(e),i={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},a=new Map;for(let y of s.pending)a.set(y.taskName,y.waitingOn);for(let y of s.unresolved)a.set(y.taskName,y.missingTokens);for(let y of s.blocked)a.set(y.taskName,y.failedTokens);let c=new Map;for(let[y,S]of Object.entries(n))for(let T of S.requires??[]){let I=c.get(T)??[];I.push(y),c.set(T,I);}let f=o.sort().map(y=>{let S=r[y],T=n[y]??{requires:[],provides:[]};S.status==="completed"?i.completed+=1:S.status==="failed"?i.failed+=1:S.status==="in-progress"&&(i.in_progress+=1);let I=T.requires??[],b=T.provides??[],_=Object.keys(S.data??{}).sort(),F=I.filter(J=>e.state.availableOutputs.includes(J)),U=I.filter(J=>!e.state.availableOutputs.includes(J)),x=a.get(y)??U,A=new Set;for(let J of b)for(let V of c.get(J)??[])V!==y&&A.add(V);let B=S.failedAt,L=S.error?{message:S.error,code:"TASK_FAILED",at:B,source:"task-runtime"}:void 0;return {name:y,status:S.status,error:L,requires:I,requires_satisfied:F,requires_missing:U,provides_declared:b,provides_runtime:_,blocked_by:x,unblocks:Array.from(A).sort(),runtime:{attempt_count:S.executionCount??0,restart_count:S.retryCount??0,in_progress_since:S.status==="in-progress"?S.startedAt??null:null,last_transition_at:S.lastUpdated??null,last_completed_at:S.completedAt??null,last_restarted_at:S.startedAt??null,status_age_ms:S.lastUpdated?0:null}}});i.pending=s.pending.length,i.blocked=s.blocked.length,i.unresolved=s.unresolved.length;let p=f.map(y=>({name:y.name,fanOut:y.unblocks.length})).sort((y,S)=>S.fanOut-y.fanOut||y.name.localeCompare(S.name)),g=p.length>0?p[0]:{name:null,fanOut:0},l=new Set;for(let y of Object.values(n))for(let S of y.requires??[])l.add(S);let h=0;for(let[y,S]of Object.entries(n)){let T=(S.requires??[]).length===0,b=(S.provides??[]).some(_=>(c.get(_)??[]).some(F=>F!==y));T&&!b&&(h+=1);}return {schema_version:"v1",meta:{board:{path:t}},summary:{card_count:o.length,completed:i.completed,eligible:s.eligible.length,pending:i.pending,blocked:i.blocked,unresolved:i.unresolved,failed:i.failed,in_progress:i.in_progress,orphan_cards:h,topology:{edge_count:Array.from(l).length,max_fan_out_card:g.name,max_fan_out:g.fanOut}},cards:f}}function Sn(){return new Date().toISOString()}function ur(t,e,r,n,o,s,i){return async a=>{let c=[],f=r.cardStore.readCard(a.nodeId);if(!f)return "task-initiate-failure";let p=f.id,g=f.card_data??{},l=f.source_defs??[],h=l.filter(P=>P.optionalForCompletionGating!==true),y=r.cardRuntimeStore.readRuntime(p),S=false,T=()=>{S&&(r.cardRuntimeStore.writeRuntime(p,y),S=false);},I=P=>Qe(y._sources[P]),b=(P,M)=>{y._sources[P]=Qe(M),S=true;},_=a.taskState?.executionCount??0;if(y._lastExecutionCount!==_&&(y._sources={},y._lastExecutionCount=_,S=true),a.update){let P=a.update,M=P.outputFile;if(M){let K=I(M);if(P.failure){let nt=P.rqt??K.lastRequestedToken??K.queueRequestedToken;nt&&b(M,er(K,nt));}else {let nt=P.rqt;if(!K.lastCompletedToken||nt>K.lastCompletedToken){let w=typeof P.deliveryToken=="string"?P.deliveryToken:void 0,k=false;w&&(k=r.fetchedSourcesStore.commitSourceData(p,M,w)),k?b(M,kn(K,nt)):b(M,er(K,nt));}}T();}}let U={};for(let P of l)if(P.outputFile){let M=r.fetchedSourcesStore.readSourceData(p,P.outputFile);M!==null&&(U[P.bindTo]=M);}let x={};for(let[P,M]of Object.entries(a.state??{}))if(M!==null&&typeof M=="object"&&!Array.isArray(M)){let K=M[P];x[P]=K!==void 0?K:M;}else x[P]=M;let A={id:p,card_data:{...g},requires:x,source_defs:l,compute:f.compute};A._sourcesData=U,f.compute&&Ut.runSync(A,{sourcesData:U}),(s??r.outputStore.writeComputedValues.bind(r.outputStore))(p,A.computed_values??{});let B={...f},L=Ut.enrichSourcesSync(Array.isArray(f.source_defs)?f.source_defs:void 0,{card_data:f.card_data,requires:x}),J=t.value;B.source_defs=Array.isArray(L)?L.map(P=>({...P,boardDir:typeof P.boardDir=="string"&&P.boardDir?P.boardDir:J})):L;let V=Sn(),st=a.update?void 0:V,Z=h.filter(P=>{let M=P.outputFile;if(typeof M!="string"||!M)return true;let K=I(M);st&&(K={...K,queueRequestedToken:st},b(M,K));let nt=K.queueRequestedToken??K.lastRequestedToken??V,w=tr(K,nt);return w==="in-flight"?false:w==="dispatch"});if(T(),Z.length>0){let P=false,M=V;for(let K of Z){let nt=K.outputFile;if(typeof nt!="string"||!nt)continue;let w=I(nt),k=w.queueRequestedToken??V;b(nt,{...w,lastRequestedToken:k}),M=k,P=true;}return P&&T(),P&&(c.push({taskKind:"source-fetch",payload:{boardRef:ot(t),enrichedCard:B,callbackToken:a.callbackToken,rqt:M}}),r.executionRequestStore.appendEntries(e,c)),"task-initiated"}if(h.some(P=>{let M=P.outputFile;if(typeof M!="string"||!M)return false;let K=I(M),nt=K.queueRequestedToken??K.lastRequestedToken??V;return tr(K,nt)==="in-flight"}))return "task-initiated";let xt=f.provides??[],Ot={};for(let{bindTo:P,ref:M}of xt)Ot[P]=Ut.resolve(A,M);return (i??r.outputStore.writeDataObjects.bind(r.outputStore))(Ot),l.filter(P=>{if(P.optionalForCompletionGating!==true)return false;let M=I(P.outputFile);return !M.lastRequestedToken||!M.lastCompletedToken?true:M.lastCompletedToken<=M.lastRequestedToken}).length>0&&c.push({taskKind:"source-fetch",payload:{boardRef:ot(t),enrichedCard:B,callbackToken:a.callbackToken,rqt:V}}),n(a.nodeId,Ot),c.length>0&&r.executionRequestStore.appendEntries(e,c),"task-initiated"}}var Ae={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function dr(t){return {[Nt]:t.graph,[or]:t.lastDrainedJournalId}}function lr(t){let e=t[Nt],r=t[or];if(!e||typeof e!="object")throw new Error(`State snapshot is missing required key: ${Nt}`);return {graph:e,lastDrainedJournalId:typeof r=="string"?r:""}}function fr(t){let e=t.requires,r=t.provides?.map(n=>n.bindTo)??[];return {requires:e&&e.length>0?e:void 0,provides:r,taskHandlers:["card-handler"],description:t.meta?.title??t.id}}function at(t){return t!==void 0?{status:"success",data:t}:{status:"success"}}function rt(t){return {status:"fail",error:t}}function it(t){return {status:"error",error:t instanceof Error?t.message:String(t)}}function Cn(t){let e=new TextEncoder().encode(t),r=Array.from(e,n=>String.fromCharCode(n)).join("");return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function pr(t){let e=t.replace(/-/g,"+").replace(/_/g,"/"),r=e+"=".repeat((4-e.length%4)%4),n=atob(r),o=Uint8Array.from(n,s=>s.charCodeAt(0));return new TextDecoder().decode(o)}function le(t){try{let e=JSON.parse(pr(t));return typeof e?.t=="string"?{taskName:e.t}:null}catch{return null}}function bn(t){return Cn(JSON.stringify(t))}function gr(t){try{let e=JSON.parse(pr(t));return typeof e?.cbk=="string"&&typeof e?.cid=="string"&&typeof e?.b=="string"&&typeof e?.d=="string"?e:null}catch{return null}}function lt(){return new Date().toISOString()}function mr(t,e){let r=e.onWarn??(()=>{}),n=ot(t);function o(w){if(w.length!==0)try{let k=e.publishBoardChangeNotifications?.(w);k&&typeof k.catch=="function"&&k.catch(O=>r(`[board-live-cards-public] publishBoardChangeNotifications failed: ${O instanceof Error?O.message:String(O)}`));}catch(k){r(`[board-live-cards-public] publishBoardChangeNotifications failed: ${k instanceof Error?k.message:String(k)}`);}}function s(){let w=a().readCardStoreRef();if(!w)throw new Error(`Board at ${t.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let k=e.kvStorageForRef(w);return {readIndex(){return k.read("_index")},writeIndex(O){k.write("_index",O);},readCard(O){return k.read(O)},writeCard(O,q){return k.write(O,q),e.hashFn(q)},cardExists(O){return k.read(O)!==null},defaultCardKey(O){return O}}}let i={readValues(w){let k=e.kvStorage("state-snapshot"),O=k.listKeys().sort();if(O.length===0)return {version:null,values:{}};let q={};for(let Q of O)q[Q]=k.read(Q);return {version:e.hashFn(q),values:q}},writeValues(w,k,O){let q=e.kvStorage("state-snapshot");for(let Q of O)q.delete(Q);for(let[Q,z]of Object.entries(k))q.write(Q,z);return e.hashFn(k)}},a=()=>ir(e.kvStorage("config")),c=()=>ar(i),f=()=>rr(e.journalAdapter()),p=()=>ce(s(),r),g=()=>{let w=a().readOutputsStoreRef();if(!w)throw new Error(`Board at ${t.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return cr(e.kvStorageForRef(w))},l=()=>{let w=a().readArchiveStoreRef();return w?e.archiveFactoryForRef(w):e.archiveFactory()};function h(){return !!c().readSnapshot(t.value).values[Nt]}function y(){let w=c().readSnapshot(t.value);if(!w.values[Nt])throw new Error(`Board not initialized at ${t.value}`);return lr(w.values)}function S(w,k){let O=c().commitSnapshot(t.value,{schemaVersion:ue,expectedVersion:k,commitId:e.genId(),committedAt:lt(),deleteKeys:[],shallowMerge:dr(w)});if(!O.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${k??"null"} current=${O.currentVersion??"null"}`)}function T(w){f().appendEvent(w);}async function I(){let w=(E,$)=>{let tt=E.payload,u=(tt?.enrichedCard??{}).id??tt?.cardId??"unknown";T({type:"task-failed",taskName:u,error:$,timestamp:lt()});},k=nr(e.kvStorage("execution-requests"),w),O=sr(e.kvStorage("card-runtime")),q=ve(e.blobStorage("sources"),E=>e.resolveBlob(E)),Q=new Map,z={readRuntime(E){return Q.get(E)??O.readRuntime(E)},writeRuntime(E,$){Q.set(E,$);}},ct=[],ut=new Map,bt={readSourceData(E,$){let tt=`${E}/${$}`;return ut.has(tt)?ut.get(tt):q.readSourceData(E,$)},ingestSourceDataStaged(E,$,tt,Tt){q.ingestSourceDataStaged(E,$,tt,Tt);},commitSourceData(E,$,tt){let Tt=`${E}/.staged/${tt}/${$}`,d=e.blobStorage("sources").read(Tt);if(d==null)return false;let m=`${E}/${$}`,C=d.trim();try{ut.set(m,JSON.parse(C));}catch{ut.set(m,C);}return ct.push({cardId:E,outputFile:$,deliveryToken:tt}),true},hasSource(E,$){let tt=`${E}/${$}`;return ut.has(tt)?true:q.hasSource(E,$)}},dt={cardStore:p(),cardRuntimeStore:z,fetchedSourcesStore:bt,outputStore:g(),executionRequestStore:k},Rt=y(),wt=se(Rt.graph),{events:W,newCursor:pt}=f().readEntriesAfterCursor(Rt.lastDrainedJournalId),vt=[],Dt=[],Lt=[],Ht=new Map,Zt=(E,$)=>{vt.push({type:"task-completed",taskName:E,data:$,timestamp:lt()});try{l().stream("exec-history").append({taskName:E,status:"completed",completedAt:lt()});}catch{}},qt=(E,$)=>{T({type:"task-failed",taskName:E,error:$,timestamp:lt()});try{l().stream("exec-history").append({taskName:E,status:"failed",error:$,completedAt:lt()});}catch{}},Bt=we(wt,{handlers:{"card-handler":ur(t,pt,dt,Zt,qt,(E,$)=>{Dt.push({cardId:E,values:$});},E=>{Lt.push(E);})}});for(vt=W;vt.length>0;){let E=vt;vt=[];for(let $ of E)if($.type==="task-restart"){let tt=dt.cardStore.readCard($.taskName);tt&&Ht.set($.taskName,tt);}Bt.pushAll(E),await Bt.waitForHandlers();}let Pt=Bt.getState();await Bt.dispose({wait:true});let Vt=c().readSnapshot(t.value).version;S({lastDrainedJournalId:pt,graph:Kt(Pt)},Vt);for(let{cardId:E,values:$}of Dt)dt.outputStore.writeComputedValues(E,$);for(let E of Lt)dt.outputStore.writeDataObjects(E);for(let[E,$]of Q)O.writeRuntime(E,$);for(let{cardId:E,outputFile:$,deliveryToken:tt}of ct)q.commitSourceData(E,$,tt);let Mt;try{Mt=de(n,Pt),dt.outputStore.writeStatusSnapshot(Mt);}catch(E){r(`[board-live-cards-public] status publish failed: ${E instanceof Error?E.message:String(E)}`);}let jt=[];for(let{cardId:E,values:$}of Dt)jt.push({kind:"computed_values",cardId:E,values:$});for(let E of Lt)for(let[$,tt]of Object.entries(E))$&&jt.push({kind:"data_object",key:$,payload:tt});for(let[E,$]of Ht)jt.push({kind:"card_refreshed",cardId:E,card:$});Mt!==void 0&&jt.push({kind:"status",status:Mt}),o(jt);let ke=a().readTaskExecutorRef()??{howToRun:"built-in",whatToRun:ot({kind:"built-in",value:"source-cli-task-executor"})};k.dispatchEntriesForJournalId(pt,E=>{if(E.taskKind!=="source-fetch"){r(`[process-accumulated-events] unknown taskKind "${E.taskKind}" \u2014 skipping`);return}let $=E.payload,tt=$.enrichedCard?.id??"unknown",Tt=$.enrichedCard?.source_defs??[];for(let u of Tt){if(!u.outputFile){r(`[dispatch] source "${u.bindTo}" has no outputFile \u2014 skipping`);continue}let d=bn({cbk:$.callbackToken,rg:t.value,br:ot(t),cid:tt,b:u.bindTo,d:u.outputFile,cs:void 0,rqt:$.rqt});e.dispatchExecution(ke,{source_def:u,base_ref:ot(t),callback:{token:d,via:e.selfRef}}).catch(m=>qt(tt,m instanceof Error?m.message:String(m)));}});}async function b(){try{let w=()=>{let O=y(),{events:q}=f().readEntriesAfterCursor(O.lastDrainedJournalId);q.length<=0||(b(),e.requestProcessAccumulated?.());},k=await Be(e.lock,I,w);return at({ran:k!==!1})}catch(w){return it(w)}}function _(w){try{let k=w.params?.cardStoreRef;if(!k)return rt("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(!h()){let ut=oe(Ae);S({lastDrainedJournalId:"",graph:Kt(ut)},null);}let O=w.params?.outputsStoreRef;if(!O)return rt("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let q=w.params?.scratchStoreRef,Q=w.params?.archiveStoreRef,z=a();z.writeCardStoreRef(k),z.writeOutputsStoreRef(O),q&&z.writeScratchStoreRef(q),Q&&z.writeArchiveStoreRef(Q);let ct=w.body??{};ct["task-executor-ref"]&&z.writeTaskExecutorRef(ct["task-executor-ref"]),Object.prototype.hasOwnProperty.call(ct,"chat-handler-flow")&&z.writeChatHandlerFlow(ct["chat-handler-flow"]);try{g().writeStatusSnapshot(de(n,se(y().graph)));}catch{}return at()}catch(k){return it(k)}}function F(w){try{let k=g().readStatusSnapshot();if(!k){k=de(n,se(y().graph));try{g().writeStatusSnapshot(k);}catch{}}return at(k)}catch(k){return it(k)}}function U(w){try{let k=w.params?.id;return k?(T({type:"task-removal",taskName:k,timestamp:lt()}),b(),at()):rt("removeCard requires params.id")}catch(k){return it(k)}}function x(w){try{let k=w.params?.id;return k?(T({type:"task-restart",taskName:k,timestamp:lt()}),b(),at()):rt("retrigger requires params.id")}catch(k){return it(k)}}async function A(w){return b()}function B(w){try{let k=w.params?.cardId,O=w.params?.all,q=!!w.params?.restart;if(!k&&!O)return rt("upsertCard requires --card-id <id> or --all");let Q=O?p().readAllCards().map(z=>z.id):[k];for(let z of Q)if(!p().readCard(z))return rt(`Card "${z}" not found in board at ${t.value}`);for(let z of Q){let ct=p().readCard(z),ut=fr(ct),bt=e.hashFn(ut),dt=e.kvStorage("card-upsert"),Rt=dt.read(z),wt=Rt?.taskConfigHash!==bt;if(!(!wt&&!q)){if(wt){let W=Rt?.blobRef??p().readCardKey(z)??z;T({type:"task-upsert",taskName:z,taskConfig:ut,timestamp:lt()}),dt.write(z,{blobRef:W,taskConfigHash:bt,updatedAt:lt()});}q&&T({type:"task-restart",taskName:z,timestamp:lt()});}}return b(),at()}catch(k){return it(k)}}function L(w){try{let k=w.params?.token;if(!k)return rt("taskFailed requires params.token");let O=w.params?.error??"unknown error",q=le(k);if(!q)return rt("Invalid callback token");T({type:"task-failed",taskName:q.taskName,error:O,timestamp:lt()});try{l().stream("exec-history").append({taskName:q.taskName,status:"failed",error:O,completedAt:lt()});}catch{}return b(),at()}catch(k){return it(k)}}function J(w){try{let k=w.params?.token;if(!k)return rt("taskProgress requires params.token");let q=(w.body??{}).update??{},Q=le(k);return Q?(T({type:"task-progress",taskName:Q.taskName,update:q,timestamp:lt()}),b(),at()):rt("Invalid callback token")}catch(k){return it(k)}}function V(w){try{let k=w.params?.token,O=w.params?.ref;if(!k)return rt("sourceDataFetched requires params.token");if(!O)return rt("sourceDataFetched requires params.ref");let q=gr(k);if(!q)return rt("Invalid source token");let{cbk:Q,cid:z,b:ct,d:ut,cs:bt,rqt:dt}=q,Rt=ve(e.blobStorage("sources"),vt=>e.resolveBlob(vt)),wt=e.genId();Rt.ingestSourceDataStaged(z,ut,St(O),wt);let W=le(Q);if(!W)return rt("Invalid callback token embedded in source token");let pt=lt();return T({type:"task-progress",taskName:W.taskName,update:{bindTo:ct,outputFile:ut,fetchedAt:pt,deliveryToken:wt,sourceChecksum:bt,rqt:dt},timestamp:pt}),b(),at()}catch(k){return it(k)}}function st(w){try{let k=w.params?.token,O=w.params?.reason??"unknown";if(!k)return rt("sourceDataFetchFailure requires params.token");let q=gr(k);if(!q)return rt("Invalid source token");let{cbk:Q,b:z,d:ct,cs:ut,rqt:bt}=q,dt=le(Q);return dt?(T({type:"task-progress",taskName:dt.taskName,update:{bindTo:z,outputFile:ct,failure:!0,reason:O,sourceChecksum:ut,rqt:bt},timestamp:lt()}),b(),at()):rt("Invalid callback token embedded in source token")}catch(k){return it(k)}}function Z(w){try{let k=a().readCardStoreRef();return k?at({storeRef:k}):rt(`Board at ${t.value} has no card store configured`)}catch(k){return it(k)}}function _t(w){try{let k=a().readOutputsStoreRef();return k?at({storeRef:k}):rt(`Board at ${t.value} has no outputs store configured`)}catch(k){return it(k)}}function xt(w){try{let k=a().readScratchStoreRef();return at({storeRef:k})}catch(k){return it(k)}}function Ot(w){try{let k=a().readArchiveStoreRef();return at({storeRef:k})}catch(k){return it(k)}}function Yt(w){try{let k=w.params?.key;if(!k)return rt("getConfig requires params.key");let O=a(),q;switch(k){case "task-executor":q=O.readTaskExecutorRef()??null;break;case "chat-handler-flow":q=O.readChatHandlerFlow()??null;break;case "card-store-ref":q=O.readCardStoreRef();break;case "outputs-store-ref":q=O.readOutputsStoreRef();break;case "scratch-store-ref":q=O.readScratchStoreRef();break;case "archive-store-ref":q=O.readArchiveStoreRef();break;default:return rt(`getConfig: unknown key "${k}"`)}return at({value:q})}catch(k){return it(k)}}function P(w){try{let k=w.params?.key;if(!k)return rt("getOutputsDataObject requires params.key");let O=g().readDataObject(k);return at(O)}catch(k){return it(k)}}function M(w){try{return at(g().readAllDataObjects())}catch(k){return it(k)}}function K(w){try{let k=w.params?.key;if(!k)return rt("getOutputsComputedValues requires params.key");let O=g().readComputedValues(k);return at(O)}catch(k){return it(k)}}function nt(w){try{return at(g().readAllComputedValues())}catch(k){return it(k)}}return {init:_,status:F,getCardStoreRef:Z,getOutputsStoreRef:_t,getScratchStoreRef:xt,getArchiveStoreRef:Ot,getConfig:Yt,getOutputsDataObject:P,getAllOutputsDataObjects:M,getOutputsComputedValues:K,getAllOutputsComputedValues:nt,removeCard:U,retrigger:x,processAccumulatedEvents:A,upsertCard:B,taskFailed:L,taskProgress:J,sourceDataFetched:V,sourceDataFetchFailure:st}}function hr(t){function e(o){return {status:"success",data:o}}function r(o){return {status:"fail",error:o}}function n(o){return {status:"error",error:o instanceof Error?o.message:String(o)}}return {get(o){try{let s=o.params?.id;if(s){let i=t.readCard(s);return i?e({cards:[i]}):r(`card "${s}" not found`)}return e({cards:t.readAllCards()})}catch(s){return n(s)}},set(o){try{let s=o.body;if(s==null)return r("set requires a body (card object or array of cards)");let i=Array.isArray(s)?s:[s];for(let a of i){if(typeof a.id!="string")return r("each card must have a string `id` field");t.writeCard(a.id,a);}return e({count:i.length})}catch(s){return n(s)}},del(o){try{let s=o.body?.ids??[],i=o.params?.id,a=i?[...s,i]:s;if(a.length===0)return r("del requires body.ids (string[]) or params.id");for(let c of a)t.removeCard(c);return e({count:a.length})}catch(s){return n(s)}},patch(o){try{let s=o.params?.id,i=o.params?.path;if(!s)return r("patch requires params.id");if(!i)return r("patch requires params.path");let a=o.body,c=a&&Object.prototype.hasOwnProperty.call(a,"value")?a.value:o.body;return t.patchCard(s,i,c),e({count:1})}catch(s){return n(s)}}}}function yr(){return new Date().toISOString()}function kr(t){return new TextEncoder().encode(t).byteLength}function Rn(t){return t?{key:t.key,size:t.size,updatedAt:t.updatedAt,contentType:t.contentType}:null}function wn(t){let e=String(t||"").match(/^(\d+)[-_]/);return e?parseInt(e[1],10):0}function vn(t){let e=String(t||"").trim();if(!e)return "upload.bin";let r=Math.max(e.lastIndexOf("/"),e.lastIndexOf("\\"));return (r>=0?e.slice(r+1):e)||"upload.bin"}function An(t){return String(t||"").toLowerCase().replace(/\s+/g,"_").replace(/[^a-z0-9_-]/g,"_").replace(/_+/g,"_").replace(/^_+|_+$/g,"")||"file"}function _n(t){if(!t||t===".")return "";let e=String(t).replace(/^\./,"").toLowerCase().replace(/[^a-z0-9]/g,"");return e?`.${e}`:""}function xn(t){let e=vn(t),r=e.lastIndexOf(".");return r<=0||r===e.length-1?{stem:e,ext:""}:{stem:e.slice(0,r),ext:e.slice(r)}}function Tn(t){let e=t.lastIndexOf("/");return e>=0?t.slice(e+1):t}function Sr(t){function e(r){let n=t.stat?Rn(t.stat(r)):null;if(n)return n;if(!t.exists(r))return null;let o=t.read(r);return o===null?{key:r}:{key:r,size:kr(o)}}return {exists(r){return t.exists(r)},putText(r,n,o="text/plain; charset=utf-8"){t.write(r,n);let s=e(r)??{key:r};return s.contentType=o,s.updatedAt=s.updatedAt??yr(),s.size=s.size??kr(n),s},putBytes(r,n,o="application/octet-stream"){if(t.writeBytes)t.writeBytes(r,n);else {let i=JSON.stringify({__kind:"bytes-array",data:[...n]});t.write(r,i);}let s=e(r)??{key:r};return s.contentType=o,s.updatedAt=s.updatedAt??yr(),s.size=s.size??n.byteLength,s},getText(r){let n=t.read(r);if(n===null){if(!t.readBytes)return null;let o=t.readBytes(r);return o===null?null:Buffer.from(o).toString("utf-8")}try{let o=JSON.parse(n);if(o&&o.__kind==="bytes-array"&&Array.isArray(o.data))return new TextDecoder("utf-8").decode(new Uint8Array(o.data))}catch{}return n},getBytes(r){if(t.readBytes){let o=t.readBytes(r);if(o!==null)return o}let n=t.read(r);if(n===null)return null;try{let o=JSON.parse(n);if(o&&o.__kind==="bytes-array"&&Array.isArray(o.data))return new Uint8Array(o.data)}catch{}return new TextEncoder().encode(n)},head:e,list(r=""){return t.listKeys(r).map(n=>e(n)??{key:n}).sort((n,o)=>n.key.localeCompare(o.key))},remove(r){t.remove(r);}}}function Cr(t){function e(o,s){let i=0,a=[];Array.isArray(s)&&a.push(...s);for(let c of t.list(`${o}/`))a.push(Tn(c.key));for(let c of a){let f=wn(c);Number.isFinite(f)&&f>i&&(i=f);}return i+1}function r(o,s,i){let a=Number(i?.maxLen||32),{stem:c,ext:f}=xn(o),p=_n(f),g=An(c),l=`${String(s).padStart(3,"0")}-`,h=p,y=a-l.length-h.length;y<1&&(h="",y=a-l.length);let S=g.slice(0,Math.max(1,y)),T=`${l}${S}${h}`;return T.length>a&&(T=T.slice(0,a).replace(/\.$/,"")),T}function n(o,s,i){let a=e(o,i?.seedNames),c=r(s,a,{maxLen:i?.maxLen});for(;t.exists(`${o}/${c}`);)a+=1,c=r(s,a,{maxLen:i?.maxLen});return c}return {nextSerial:e,buildStoredName:r,allocateStoredName:n}}function br(){function t(o,s){if(!Array.isArray(o))return [];let i=[];for(let a of o){if(!a||typeof a!="object")continue;let c=a;typeof c.stored_name=="string"&&i.push({name:typeof c.name=="string"?c.name:c.stored_name,stored_name:c.stored_name,size:typeof c.size=="number"&&Number.isFinite(c.size)?c.size:null,mime_type:typeof c.mime_type=="string"?c.mime_type:null,path:typeof c.path=="string"?c.path:null,uploaded_at:typeof c.uploaded_at=="string"?c.uploaded_at:s||null});}return i}function e(o){return !o||typeof o!="object"?[]:t(o.files,void 0)}function r(o,s){let i=e(o);if(s.length===0)return o.files=i,i;let a=new Set(i.map(c=>c.stored_name));for(let c of s)a.has(c.stored_name)||(i.push(c),a.add(c.stored_name));return o.files=i,i}function n(o,s,i){let a=e(o);if(!Number.isInteger(s)||s<0||s>=a.length)return {ok:false,reason:"index_out_of_range"};let c=a[s];return !c||!c.stored_name?{ok:false,reason:"missing_stored_name"}:i&&i!==c.stored_name?{ok:false,reason:"stale_reference"}:{ok:true,file:c}}return {read:e,normalizeIncoming:t,merge:r,resolve:n}}function Rr(t){return String(t).replace(/[^a-zA-Z0-9_-]/g,"_")}function wr(t){let e=t.payload??{};return {id:t.id,role:typeof e.role=="string"?e.role:"system",text:typeof e.text=="string"?e.text:"",files:Array.isArray(e.files)?e.files:[],updated_at:typeof e.updated_at=="string"?e.updated_at:""}}function vr(t,e){let r=o=>`chats/${Rr(o)}/processing`,n=o=>`chats/${Rr(o)}/config`;return {append(o,s,i,a=[]){return t(o).append({role:s,text:i,files:a,updated_at:new Date().toISOString()}).id},readAll(o){return t(o).readAll().map(wr)},readAfter(o,s){let i=t(o).readAfter(s);return {records:i.entries.map(wr),cursor:i.newCursor}},clear(o){t(o).clear?.();},setProcessing(o,s){s?e.write(r(o),true):e.delete(r(o));},isProcessing(o){return e.read(r(o))===true},getConfig(o){return e.read(n(o))??{}},setConfig(o,s){let i=e.read(n(o))??{};e.write(n(o),{...i,...s});}}}function In(){let t=globalThis.crypto;return typeof t?.randomUUID=="function"?String(t.randomUUID()):`id-${Date.now()}-${Math.random().toString(36).slice(2)}`}function Ar(){let t=new Map,e=new Map;function r(n){return t.has(n)||t.set(n,[]),t.get(n)}return {append(n,o,s,i=[]){let a={id:In(),role:o,text:s,files:i,updated_at:new Date().toISOString()};return r(n).push(a),a.id},readAll(n){return r(n).slice()},readAfter(n,o){let s=r(n);if(!o)return {records:s.slice(),cursor:s.length>0?s[s.length-1].id:null};let i=s.findIndex(c=>c.id===o),a=i===-1?s.slice():s.slice(i+1);return {records:a,cursor:a.length>0?a[a.length-1].id:o}},clear(n){t.set(n,[]);},setProcessing(n,o){o?e.set(`p:${n}`,true):e.delete(`p:${n}`);},isProcessing(n){return e.get(`p:${n}`)===true},getConfig(n){return e.get(`c:${n}`)??{}},setConfig(n,o){let s=e.get(`c:${n}`)??{};e.set(`c:${n}`,{...s,...o});}}}function _r(t){function e(a){return {status:"success",data:a}}function r(a){return {status:"fail",error:a}}function n(a){return {status:"error",error:a instanceof Error?a.message:String(a)}}function o(a,c="command envelope"){let f=typeof a.cardId=="string"?a.cardId:void 0;if(!a.command)return r(`chat-store: ${c} missing "command"`);if(!f)return r(`chat-store: ${c} missing "cardId"`);if(a.command==="append")return i.append({params:{cardId:f},body:{role:a.role,text:a.text,files:a.files}});if(a.command==="read-all")return i.readAll({params:{cardId:f}});if(a.command==="read-after")return i.readAfter({params:{cardId:f},body:{cursor:a.cursor??null}});if(a.command==="clear")return i.clear({params:{cardId:f}});if(a.command==="set-processing")return i.setProcessing({params:{cardId:f},body:{active:a.active}});if(a.command==="is-processing")return i.isProcessing({params:{cardId:f}});if(a.command==="get-config")return i.getConfig({params:{cardId:f}});if(a.command==="set-config"){let{command:p,cardId:g,...l}=a;return i.setConfig({params:{cardId:f},body:l})}return r(`chat-store: unknown command "${String(a.command)}"`)}function s(a){if(!Array.isArray(a.commands)||a.commands.length===0)return r('chat-store: command envelope must include a non-empty "commands" array');let c=[];for(let f=0;f<a.commands.length;f+=1){let p=a.commands[f];if(!p||typeof p!="object"||Array.isArray(p))return r(`chat-store: command envelope entry ${f} must be an object`);let g={cardId:a.cardId,...p},l=o(g,`command envelope entry ${f}`);if(l.status!=="success")return l;c.push({index:f,command:String(g.command),data:l.data});}return e({results:c})}let i={append(a){try{let c=a.params?.cardId;if(!c)return r("append requires params.cardId");let f=a.body??{},p=typeof f.role=="string"?f.role:"",g=typeof f.text=="string"?f.text:"",l=Array.isArray(f.files)?f.files:[];if(!p)return r("append requires body.role");let h=t.append(c,p,g,l);return e({id:h})}catch(c){return n(c)}},readAll(a){try{let c=a.params?.cardId;return c?e({records:t.readAll(c)}):r("readAll requires params.cardId")}catch(c){return n(c)}},readAfter(a){try{let c=a.params?.cardId;if(!c)return r("readAfter requires params.cardId");let p=(a.body??{}).cursor??null;return e(t.readAfter(c,p))}catch(c){return n(c)}},clear(a){try{let c=a.params?.cardId;return c?(t.clear(c),e({ok:!0})):r("clear requires params.cardId")}catch(c){return n(c)}},setProcessing(a){try{let c=a.params?.cardId;if(!c)return r("setProcessing requires params.cardId");let f=a.body??{};return typeof f.active!="boolean"?r("setProcessing requires body.active (boolean)"):(t.setProcessing(c,f.active),e({ok:!0}))}catch(c){return n(c)}},isProcessing(a){try{let c=a.params?.cardId;return c?e({active:t.isProcessing(c)}):r("isProcessing requires params.cardId")}catch(c){return n(c)}},getConfig(a){try{let c=a.params?.cardId;return c?e({config:t.getConfig(c)}):r("getConfig requires params.cardId")}catch(c){return n(c)}},setConfig(a){try{let c=a.params?.cardId;if(!c)return r("setConfig requires params.cardId");let f=a.body??{};return t.setConfig(c,f),e({ok:!0})}catch(c){return n(c)}},run:o,runBatch:s};return i}var En={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},On=32;function Bn(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function xr(t){if(!t||typeof t!="object")return false;let e=t.summary;return !e||typeof e!="object"?false:Number(e.card_count||0)>0}function Tr(t,e){if(!e||typeof e!="object")return;let r=e;if(r.kind==="notification-batch"&&Array.isArray(r.notifications)){for(let n of r.notifications)Tr(t,n);return}r.kind==="status"&&xr(r.status)&&(t.status=r.status),r.kind==="computed_values"&&r.cardId&&(t.computedValues[r.cardId]=r.values),r.kind==="data_object"&&r.key&&(t.dataObjects[r.key]=r.payload),r.kind==="card_refreshed"&&r.cardId&&(t.cards[r.cardId]=r.card);}function Ir(t){let e=String(t.apiBasePath||"/api/board").replace(/\/$/,""),r={...En,...t.corsHeaders||{}},n=t.boardId||"",o=t.logger||{info:console.log,warn:console.warn,error:console.error},s=t.invocationAdapter,i=t.chatFlowRunner||null,a=t.chatStorage??Ar(),c=_r(a),f=t.notificationTransport||null,p=t.serverUrl||null,g=t.executionExtra||{},l=new Map,h=new Map,y=new Map,S=null;function T(u){let d=mr(u.baseRef,u.boardAdapter),m=u.boardAdapter.kvStorageForRef(u.cardStoreRef),R=hr(ce({readIndex:()=>m.read("_index"),writeIndex:j=>m.write("_index",j),readCard:j=>m.read(j),writeCard:(j,X)=>(m.write(j,X),j),cardExists:j=>m.read(j)!==null,defaultCardKey:j=>j},o.warn)),v=u.artifactsAdapter||u.boardAdapter,N=u.filesArtifactsStore??null,D=null;return {label:u.label,board:d,cardStore:R,get filesArtifacts(){return D??(D=N??Sr(v.blobStorage("files")))},boardAdapter:u.boardAdapter,cardStoreRef:u.cardStoreRef,outputsStoreRef:u.outputsStoreRef,scratchStoreRef:u.scratchStoreRef,archiveStoreRef:u.archiveStoreRef,notifyRef:u.notifyRef,taskExecutorRef:u.taskExecutorRef,chatHandlerRef:u.chatHandlerRef,chatHandlerFlow:u.chatHandlerFlow,inferenceAdapterRef:u.inferenceAdapterRef,notification:Bn(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let I=t.boards.map(T),b=new Map;function _(u){return b.get(u)??0}function F(u){let d=I[_(u)];return {files:d?d.filesArtifacts:null}}function U(u){let d=F(u);return d.files?Cr(d.files):null}function x(){return br()}function A(u){return String(u||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function B(u){if(!u||u.notificationTeardown||!f||!u.notifyRef)return;let d=await f.subscribe(u.notifyRef,m=>{Tr(u.notification,m);let C=m.kind==="notification-batch"?m.notifications:[m];$(C);});u.notificationTeardown=d;}async function L(u){if(!u||u.initialized)return;let d={cardStoreRef:u.cardStoreRef,outputsStoreRef:u.outputsStoreRef};u.scratchStoreRef&&(d.scratchStoreRef=u.scratchStoreRef),u.archiveStoreRef&&(d.archiveStoreRef=u.archiveStoreRef);let m={};u.taskExecutorRef&&(m["task-executor-ref"]=u.taskExecutorRef),u.chatHandlerFlow!==void 0&&(m["chat-handler-flow"]=u.chatHandlerFlow),u.inferenceAdapterRef&&(m["inference-adapter-ref"]=u.inferenceAdapterRef);let C=u.board.init({params:d,body:m});if(C.status!=="success")throw Object.assign(new Error(C.error||`init failed for ${u.label}`),{statusCode:500});if(await B(u),!u.chatHandlerFlow&&u.chatHandlerRef&&s.describe)try{let R=await s.describe(u.chatHandlerRef);R&&R.kind!=="chat-handler"?o.warn(`[init] chat-handler describe returned kind="${R.kind}", expected "chat-handler" for ${u.label}`):R&&o.info(`[init] chat-handler validated: ${R.name} (protocol ${R.protocolVersion}) for ${u.label}`);}catch(R){o.warn(`[init] chat-handler describe failed for ${u.label}: ${R?.message||String(R)}`);}u.initialized=true;}function J(u){if(!u.boardAdapter.publishBoardChangeNotifications)return;let d=[],m=u.board.status({});m.status==="success"&&m.data!=null&&xr(m.data)&&d.push({kind:"status",status:m.data});let C=u.board.getAllOutputsDataObjects({});if(C.status==="success"&&C.data!=null)for(let[v,N]of Object.entries(C.data))v&&d.push({kind:"data_object",key:v,payload:N});let R=u.board.getAllOutputsComputedValues({});if(R.status==="success"&&R.data!=null)for(let[v,N]of Object.entries(R.data))v&&d.push({kind:"computed_values",cardId:v,values:N});d.length>0&&u.boardAdapter.publishBoardChangeNotifications(d);}function V(u,d){if(!u||u.cardsBootstrapped)return;let m=u.cardStore.get({}),C=m.status==="success"&&Array.isArray(m.data?.cards)?m.data.cards:[];for(let R of C)typeof R.id=="string"&&(b.set(R.id,d),u.board.upsertCard({params:{cardId:R.id}}));u.cardsBootstrapped=true;}async function st(){for(let u of I)await L(u);}async function Z(){await st();for(let u=0;u<I.length;u++)J(I[u]),V(I[u],u);}function _t(u){return I[_(u)]??null}function xt(u){let d=_t(u);if(!d)return null;let m=d.cardStore.get({params:{id:u}});if(m.status!=="success")return null;let C=Array.isArray(m.data?.cards)?m.data.cards:[];return C.length>0?C[0]:null}function Ot(){let u=m=>{if(!m||!m.cardStore)return [];let C=m.cardStore.get({});return C.status!=="success"||!Array.isArray(C.data?.cards)?[]:C.data.cards},d=[];for(let m of I)d.push(...u(m));return d}function Yt(){let u=I.map(v=>{try{let D=v.boardAdapter.kvStorageForRef(v.outputsStoreRef).read("status");if(D!=null)return D}catch{}return v.notification.status}).filter(Boolean);if(u.length===0)return null;if(u.length===1)return u[0];let d=[],m=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],C={};for(let v of m)C[v]=0;for(let v of u){let N=v,D=Array.isArray(N.cards)?N.cards:[];d.push(...D);for(let j of m)C[j]+=Number(N?.summary?.[j]||0);}let R=u[0];return {...R,cards:d,summary:{...R.summary||{},card_count:d.length,...C}}}function P(){let u={},d=m=>{for(let[C,R]of Object.entries(m.notification.computedValues)){let v=m.notification.cards[C];u[C]={schema_version:"v1",card_id:C,card_data:v?.card_data??{},computed_values:R??{}};}};for(let m of I)d(m);return u}function M(){let u={};for(let d of I)Object.assign(u,d.notification.dataObjects||{});return u}function K(){let u=Ot(),d=P(),m=M(),C={};for(let v of u){if(!v?.id)continue;let N=v.id,D=d[N]||{},j={...D.card_data&&typeof D.card_data=="object"?D.card_data:v.card_data&&typeof v.card_data=="object"?v.card_data:{}};C[N]={schema_version:D.schema_version||"v1",card_id:D.card_id||N,card_data:j,computed_values:D.computed_values&&typeof D.computed_values=="object"?D.computed_values:{}};}let R={};for(let v of u){if(!v?.id)continue;let N=v.id;try{let D=ct(N),j=a.isProcessing(N);(D.length>0||j)&&(R[N]={messages:D.map(X=>({role:String(X.role||"system"),text:String(X.text||""),files:Array.isArray(X.files)?X.files:[]})),receiving:!1,processing:j});}catch{}}return {boardId:n,cardDefinitions:u,statusSnapshot:Yt(),dataObjectsByToken:m,cardRuntimeById:C,cardChatsByCardId:R}}function nt(u,d,m){let C=m?.syncBoard!==false,R=_t(u);if(!R)throw Object.assign(new Error(`Card not found: ${u}`),{statusCode:404});let v=xt(u);if(!v)throw Object.assign(new Error(`Card not found: ${u}`),{statusCode:404});let N=d(v)||v,D=R.cardStore.set({body:N});if(D.status!=="success")throw Object.assign(new Error(D.error||`Failed to persist card: ${u}`),{statusCode:500});if(C){let j=R.board.upsertCard({params:{cardId:u,restart:true}});if(j.status!=="success")throw Object.assign(new Error(j.error||`Failed to upsert card: ${u}`),{statusCode:500})}}function w(u,d){nt(u,d,{syncBoard:true});}function k(u,d){nt(u,d,{syncBoard:false});}function O(u,d){w(u,m=>{if(!d||typeof d!="object"||Object.keys(d).length===0)return m;function C(R,v,N){let D=String(v||"").split(".").filter(Boolean);if(!D.length)return;let j=R;for(let X=0;X<D.length-1;X++){let et=D[X];(!j[et]||typeof j[et]!="object")&&(j[et]={}),j=j[et];}j[D[D.length-1]]=N;}if(d.fieldValues!==void 0&&d.fieldValues!==null){let R=null,v=m.view;if(v&&Array.isArray(v.elements)){for(let N of v.elements)if(N?.data&&N.data.writeTo){R=N.data.writeTo;break}}R?C(m,R,d.fieldValues):typeof d.fieldValues=="object"&&!Array.isArray(d.fieldValues)&&(m.card_data={...m.card_data||{},...d.fieldValues});}else {if(Array.isArray(d._stagedFiles)&&d._stagedFiles.length>0)return m;for(let[R,v]of Object.entries(d))R!=="_stagedFiles"&&(v!==null&&typeof v=="object"&&!Array.isArray(v)&&m[R]!==null&&typeof m[R]=="object"&&!Array.isArray(m[R])?m[R]={...m[R],...v}:m[R]=v);}return m});}function q(u){let d=String(u||"").trim();if(!d)return "upload.bin";let m=Math.max(d.lastIndexOf("/"),d.lastIndexOf("\\"));return (m>=0?d.slice(m+1):d)||"upload.bin"}function Q(u){a.clear(u),a.setProcessing(u,false);}function z(u,d,m,C){let R=typeof m=="string"?m.trim():"";return a.append(u,d,R,C)}function ct(u){return a.readAll(u)}function ut(u){let d=[];try{let m=xt(u);if(!m)return d;let C=x().read(m.card_data&&typeof m.card_data=="object"?m.card_data:null);for(let R of C)d.push(R.stored_name);}catch{}return d}function bt(u,d,m,C){let R=A(u),v=F(u),N=q(d),D=U(u),j=D?D.allocateStoredName(R,N,{seedNames:ut(u),maxLen:On}):`${String(Date.now())}-${N}`;return v.files&&v.files.putBytes(`${R}/${j}`,new Uint8Array(C),m||"application/octet-stream"),{name:N,stored_name:j,size:C.length,mime_type:m||"application/octet-stream",path:`${u}/files/${j}`,uploaded_at:new Date().toISOString()}}function dt(u){let d=_t(u);if(!d)return null;let m=d.board.getConfig({params:{key:"chat-handler-flow"}}),C=m.status==="success"?m.data?.value:null,R=d.chatHandlerRef;return C==null&&(!R||typeof R!="object")?null:{ctx:d,handlerFlow:C,handlerRef:R}}function Rt(u,d,m=false){let C=dt(u);if(!C)return;let{ctx:R,handlerFlow:v,handlerRef:N}=C;if(!m)try{a.setProcessing(u,!0);}catch{}let D={boardId:n,cardId:String(u),lastChatEntryId:d,...g,...p?{serverUrl:p}:{}};if(!i&&v!=null){try{a.setProcessing(u,!1);}catch{}o.warn(`[chat-handler-flow] configured for card "${u}" but no chatFlowRunner was provided`);return}if(v!=null){let X=i;if(!X)return;X.run(v,D,{boardId:n,cardId:String(u),label:R.label,logger:o,serverUrl:p,executionExtra:g}).then(et=>{if(et.dispatched)o.info(`[chat-handler-flow] invoked for card "${u}" (boardId: "${n}")`);else {try{a.setProcessing(u,!1);}catch{}o.warn(`[chat-handler-flow] dispatch failed for card "${u}": ${et.error||"unknown"}`);}},et=>{try{a.setProcessing(u,!1);}catch{}o.warn(`[chat-handler-flow] invoke failed for card "${u}": ${et?.message||String(et)}`);});return}let j=N;j&&s.invoke(j,D).then(X=>{if(X.dispatched)o.info(`[chat-handler] invoked for card "${u}" (boardId: "${n}")`);else {try{a.setProcessing(u,!1);}catch{}o.warn(`[chat-handler] dispatch failed for card "${u}": ${X.error||"unknown"}`);}},X=>{try{a.setProcessing(u,!1);}catch{}o.warn(`[chat-handler] invoke failed for card "${u}": ${X?.message||String(X)}`);});}function wt(u,d,m){let C=d==="chat-send"?k:w,R;C(u,v=>{let N=new Date().toISOString(),D=v.card_data&&typeof v.card_data=="object"?v.card_data:{};if(v.card_data=D,d==="chat-send"){let j=m&&typeof m.text=="string"?m.text.trim():"",X=[];if(Array.isArray(m?.files)){for(let et of m.files)if(et){if(typeof et=="string"){X.push({name:et});continue}if(typeof et=="object"){let ft=et;typeof ft.name=="string"&&X.push({name:ft.name,size:ft.size,mime_type:ft.mime_type,path:ft.path,uploaded_at:ft.uploaded_at,stored_name:ft.stored_name});}}}if(j||X.length>0){let et=c.runBatch({cardId:u,commands:[{command:"append",role:"user",text:j,files:X},{command:"set-processing",active:true}]});if(et.status!=="success")throw new Error(et.error);let ft=et.data.results[0]?.data?.id;if(typeof ft!="string"||!ft)throw new Error(`chat-send did not return an append id for card ${u}`);R={cardId:u,lastEntryId:ft,processingAlreadySet:true};for(let G of X){if(!G||typeof G!="object")continue;let Y=typeof G.name=="string"?G.name:"file",mt=typeof G.stored_name=="string"?G.stored_name:null;mt&&z(u,"system",`File ${Y} uploaded as ${mt}.`,[]);}try{let G=ct(u);$([{kind:"card_chats",cardId:u,messages:G.map(Y=>({role:String(Y.role||"system"),text:String(Y.text||""),files:Array.isArray(Y.files)?Y.files:[]})),receiving:!0,processing:a.isProcessing(u)}]);}catch{}}return v}if(d==="file-upload"){let j=x().normalizeIncoming(m?.files,N);return j.length>0&&x().merge(D,j),v}if(d==="action"){let j=m&&typeof m.buttonId=="string"?m.buttonId:"";if(!j)return v;D.lastAction={buttonId:j,at:N},D.lastActionText=`${j} @ ${N}`;}return v}),R&&Rt(R.cardId,R.lastEntryId,R.processingAlreadySet);}function W(u,d,m){let C=JSON.stringify(m),R=typeof Buffer<"u"?Buffer.byteLength(C):new TextEncoder().encode(C).length;u.writeHead(d,{...r,"Content-Type":"application/json; charset=utf-8","Content-Length":R}),u.end(C);}async function pt(u){let d=[];for await(let C of u)d.push(C);let m=typeof Buffer<"u"?Buffer.concat(d).toString("utf-8").trim():new TextDecoder().decode(Dt(d)).trim();return m?JSON.parse(m):{}}async function vt(u){let d=[];for await(let m of u)d.push(m);return typeof Buffer<"u"?Buffer.concat(d):Dt(d)}function Dt(u){let d=u.reduce((R,v)=>R+v.length,0),m=new Uint8Array(d),C=0;for(let R of u)m.set(R,C),C+=R.length;return m}let Lt=0;function Ht(u){let d=JSON.stringify(u);return Lt++,`id: ${Lt}
|
|
1
|
+
var BoardLiveCardsLocalStorage=(function(exports){'use strict';var Gr=Object.defineProperty;var Ur=(t,e,r)=>e in t?Gr(t,e,{enumerable:true,configurable:true,writable:true,value:r}):t[e]=r;var Oe=(t,e,r)=>Ur(t,e+"",r);var te="b64:";function Jr(t){let e=new TextEncoder().encode(t),r=globalThis.Buffer,n;if(r)n=r.from(e).toString("base64");else if(typeof btoa=="function"){let o="";for(let s of e)o+=String.fromCharCode(s);n=btoa(o);}else throw new Error("No base64 encoder available in this runtime");return n.replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function Hr(t){let e=t.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-t.length%4)%4),r=globalThis.Buffer;if(r)return r.from(e,"base64").toString("utf8");if(typeof atob=="function"){let n=atob(e),o=new Uint8Array(n.length);for(let s=0;s<n.length;s+=1)o[s]=n.charCodeAt(s);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function ot(t){return `${te}${Jr(JSON.stringify(t))}`}function bt(t){if(!t.startsWith(te))throw new Error(`Invalid ref format (expected ${te}<base64url(json)>): ${t}`);let e;try{e=JSON.parse(Hr(t.slice(te.length)));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${t}`)}if(!e||typeof e!="object")throw new Error(`Invalid ref format (expected object payload): ${t}`);let r=e;if(typeof r.kind!="string"||typeof r.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${t}`);return {kind:r.kind,value:r.value}}async function Be(t,e,r){let n=t.tryAcquire();if(!n)return false;try{await e();}finally{n();}return r?.(),true}var Et={RUNNING:"running",COMPLETED:"completed",FAILED:"failed",INACTIVATED:"inactivated"};function pt(t){return t?Array.isArray(t.provides)?t.provides:[]:[]}function Ot(t){return t?Array.isArray(t.requires)?t.requires:[]:[]}function je(t){return t.tasks??{}}function Ce(t){return t?t.status===Et.FAILED||t.status===Et.INACTIVATED:false}function $e(t,e){return t.refreshStrategy??e?.refreshStrategy??"data-changed"}function Ne(t){return t.maxExecutions}function Fe(t,e){let r=new Set;for(let[n,o]of Object.entries(e))if(o.status===Et.COMPLETED){let s=t.tasks[n];s&&pt(s).forEach(a=>r.add(a));}return Array.from(r)}function De(t,e){let r={};return t.forEach(n=>{let o=e[n];if(!o)return;pt(o).forEach(i=>{r[i]||(r[i]=[]),r[i].push(n);});}),r}function Le(t,e,r){let n=t.tasks[e]??ee(),o={};if(r){let i=r.tasks[e],a=Ot(i);for(let c of a)for(let[f,p]of Object.entries(r.tasks))if(pt(p).includes(c)){let g=t.tasks[f];g?.lastDataHash&&(o[c]=g.lastDataHash);break}}let s={...n,status:"running",startedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),progress:0,error:void 0,startConsumedHashes:o};return {...t,tasks:{...t.tasks,[e]:s},lastUpdated:new Date().toISOString()}}function qe(t,e,r,n,o,s){let i=t.tasks[r]??ee(),a=e.tasks[r];if(!a)throw new Error(`Task "${r}" not found in graph`);let c;n&&a.on&&a.on[n]?c=a.on[n]:c=pt(a);let f=i.startConsumedHashes?{...i.startConsumedHashes}:{...i.lastConsumedHashes};if(!i.startConsumedHashes){let l=a.requires??[];for(let h of l)for(let[y,k]of Object.entries(e.tasks))if(pt(k).includes(h)){let T=t.tasks[y];T?.lastDataHash&&(f[h]=T.lastDataHash);break}}let p={...i,status:"completed",completedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),executionCount:i.executionCount+1,lastEpoch:i.executionCount+1,lastDataHash:o,data:s,lastConsumedHashes:f,error:void 0},g=[...new Set([...t.availableOutputs,...c])];return {...t,tasks:{...t.tasks,[r]:p},availableOutputs:g,lastUpdated:new Date().toISOString()}}function Pe(t,e,r,n){let o=t.tasks[r]??ee(),s=e.tasks[r];if(s?.retry){let c=o.retryCount+1;if(c<=s.retry.max_attempts){let f={...o,status:"not-started",retryCount:c,lastUpdated:new Date().toISOString(),error:n};return {...t,tasks:{...t.tasks,[r]:f},lastUpdated:new Date().toISOString()}}}let i={...o,status:"failed",failedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),error:n,executionCount:o.executionCount+1},a=t.availableOutputs;if(s?.on_failure&&s.on_failure.length>0&&(a=[...new Set([...t.availableOutputs,...s.on_failure])]),s?.circuit_breaker&&i.executionCount>=s.circuit_breaker.max_executions){let c=s.circuit_breaker.on_break;a=[...new Set([...a,...c])];}return {...t,tasks:{...t.tasks,[r]:i},availableOutputs:a,lastUpdated:new Date().toISOString()}}function Me(t,e,r,n){let o=t.tasks[e]??ee(),s={...o,progress:typeof n=="number"?n:o.progress,messages:[...o.messages??[],...r?[{message:r,timestamp:new Date().toISOString(),status:o.status}]:[]],lastUpdated:new Date().toISOString()};return {...t,tasks:{...t.tasks,[e]:s},lastUpdated:new Date().toISOString()}}function Ge(t,e){let r=t.tasks[e];if(!r)return t;let n={...r,status:"not-started",startedAt:void 0,completedAt:void 0,failedAt:void 0,error:void 0,data:void 0,progress:null,lastUpdated:new Date().toISOString()};return {...t,tasks:{...t.tasks,[e]:n},lastUpdated:new Date().toISOString()}}function ee(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function re(t,e){let r=`live-${Date.now()}`,n={};for(let s of Object.keys(t.tasks))n[s]=Je();let o={status:"running",tasks:n,availableOutputs:[],stuckDetection:{is_stuck:false,stuck_description:null,outputs_unresolvable:[],tasks_blocked:[]},lastUpdated:new Date().toISOString(),executionId:r,executionConfig:{executionMode:t.settings.execution_mode??"eligibility-mode",conflictStrategy:t.settings.conflict_strategy??"alphabetical",completionStrategy:t.settings.completion}};return {config:t,state:o}}function Vr(t,e){let{config:r,state:n}=t;if("executionId"in e&&e.executionId&&e.executionId!==n.executionId)return t;switch(e.type){case "task-started":return {config:r,state:Le(n,e.taskName,r)};case "task-completed":return {config:r,state:qe(n,r,e.taskName,e.result,e.dataHash,e.data)};case "task-failed":return {config:r,state:Pe(n,r,e.taskName,e.error)};case "task-progress":return {config:r,state:Me(n,e.taskName,e.message,e.progress)};case "task-restart":return {config:r,state:Ge(n,e.taskName)};case "inject-tokens":return {config:r,state:{...n,availableOutputs:[...new Set([...n.availableOutputs,...e.tokens])],lastUpdated:new Date().toISOString()}};case "agent-action":return {config:r,state:Qr(n,e.action)};case "task-upsert":return Kr(t,e.taskName,e.taskConfig);case "task-removal":return zr(t,e.taskName);case "node-requires-add":return Wr(t,e.nodeName,e.tokens);case "node-requires-remove":return Xr(t,e.nodeName,e.tokens);case "node-provides-add":return Yr(t,e.nodeName,e.tokens);case "node-provides-remove":return Zr(t,e.nodeName,e.tokens);default:return t}}function Ue(t,e){return e.reduce((r,n)=>Vr(r,n),t)}function Kr(t,e,r){let n=!!t.config.tasks[e];return {config:{...t.config,tasks:{...t.config.tasks,[e]:r}},state:{...t.state,tasks:{...t.state.tasks,[e]:n?t.state.tasks[e]:Je()},lastUpdated:new Date().toISOString()}}}function zr(t,e){if(!t.config.tasks[e])return t;let{[e]:r,...n}=t.config.tasks,{[e]:o,...s}=t.state.tasks;return {config:{...t.config,tasks:n},state:{...t.state,tasks:s,lastUpdated:new Date().toISOString()}}}function Wr(t,e,r){let n=t.config.tasks[e];if(!n)return t;let o=Ot(n),s=r.filter(i=>!o.includes(i));return s.length===0?t:{config:{...t.config,tasks:{...t.config.tasks,[e]:{...n,requires:[...o,...s]}}},state:t.state}}function Xr(t,e,r){let n=t.config.tasks[e];if(!n)return t;let o=Ot(n),s=o.filter(i=>!r.includes(i));return s.length===o.length?t:{config:{...t.config,tasks:{...t.config.tasks,[e]:{...n,requires:s}}},state:t.state}}function Yr(t,e,r){let n=t.config.tasks[e];if(!n)return t;let o=pt(n),s=r.filter(i=>!o.includes(i));return s.length===0?t:{config:{...t.config,tasks:{...t.config.tasks,[e]:{...n,provides:[...o,...s]}}},state:t.state}}function Zr(t,e,r){let n=t.config.tasks[e];if(!n)return t;let o=pt(n),s=o.filter(i=>!r.includes(i));return s.length===o.length?t:{config:{...t.config,tasks:{...t.config.tasks,[e]:{...n,provides:s}}},state:t.state}}function Kt(t){return {version:1,config:t.config,state:t.state,snapshotAt:new Date().toISOString()}}function ne(t){if(!t||typeof t!="object")throw new Error("Invalid snapshot: expected an object");let e=t;if(!e.config||typeof e.config!="object")throw new Error('Invalid snapshot: missing or invalid "config"');if(!e.state||typeof e.state!="object")throw new Error('Invalid snapshot: missing or invalid "state"');let r=e.config,n=e.state;if(!r.settings||typeof r.settings!="object")throw new Error("Invalid snapshot: config.settings missing");if(!r.tasks||typeof r.tasks!="object")throw new Error("Invalid snapshot: config.tasks missing");if(!n.tasks||typeof n.tasks!="object")throw new Error("Invalid snapshot: state.tasks missing");if(!Array.isArray(n.availableOutputs))throw new Error("Invalid snapshot: state.availableOutputs must be an array");return {config:r,state:n}}function Je(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function Qr(t,e){let r=new Date().toISOString();switch(e){case "stop":return {...t,status:"stopped",lastUpdated:r};case "pause":return {...t,status:"paused",lastUpdated:r};case "resume":return {...t,status:"running",lastUpdated:r};default:return t}}function zt(t){let{config:e,state:r}=t,n=je(e);if(Object.keys(n).length===0)return {eligible:[],pending:[],unresolved:[],blocked:[],conflicts:{}};let s=tn(n),i=Fe(e,r.tasks),a=new Set([...i,...r.availableOutputs]),c=[],f=[],p=[],g=[];for(let[h,y]of Object.entries(n)){let k=r.tasks[h],T=$e(y,e.settings),I=T!=="once";if(k?.status===Et.RUNNING||Ce(k))continue;let b=Ne(y);if(b!==void 0&&k&&k.executionCount>=b||y.circuit_breaker&&k&&k.executionCount>=y.circuit_breaker.max_executions||!I&&k?.status===Et.COMPLETED)continue;if(I&&k?.status===Et.COMPLETED){let _=Ot(y),B=false;switch(T){case "data-changed":{_.length>0&&_.some(J=>{for(let[z,st]of Object.entries(n))if(pt(st).includes(J)){let Q=r.tasks[z];if(!Q)continue;let _t=k.lastConsumedHashes?.[J];return Q.lastDataHash==null?Q.executionCount>k.lastEpoch:Q.lastDataHash!==_t}return false})||(B=true);break}case "epoch-changed":{_.length>0&&_.some(J=>{for(let[z,st]of Object.entries(n))if(pt(st).includes(J)){let Q=r.tasks[z];if(Q&&Q.executionCount>k.lastEpoch)return true}return false})||(B=true);break}case "time-based":{let L=y.refreshInterval??0;if(L<=0){B=true;break}let J=k.completedAt;if(!J){B=true;break}(Date.now()-Date.parse(J))/1e3<L&&(B=true);break}case "manual":B=true;break}if(B)continue}let w=Ot(y);if(w.length===0){c.push(h);continue}let N=[],U=[],x=[];for(let _ of w){if(a.has(_))continue;let B=s[_]||[];B.length===0?N.push(_):B.every(J=>Ce(r.tasks[J]))?x.push({token:_,failedProducer:B[0]}):U.push(_);}N.length>0?p.push({taskName:h,missingTokens:N}):x.length>0?g.push({taskName:h,failedTokens:x.map(_=>_.token),failedProducers:[...new Set(x.map(_=>_.failedProducer))]}):U.length>0?f.push({taskName:h,waitingOn:U}):c.push(h);}let l={};if(c.length>1){let h=De(c,n);for(let[y,k]of Object.entries(h))k.length>1&&(l[y]=k);}return {eligible:c,pending:f,unresolved:p,blocked:g,conflicts:l}}function tn(t){let e={};for(let[r,n]of Object.entries(t)){for(let o of pt(n))e[o]||(e[o]=[]),e[o].push(r);if(n.on)for(let o of Object.values(n.on))for(let s of o)e[s]||(e[s]=[]),e[s].includes(r)||e[s].push(r);if(n.on_failure)for(let o of n.on_failure)e[o]||(e[o]=[]),e[o].includes(r)||e[o].push(r);}return e}var Wt=class{constructor(){Oe(this,"buffer",[]);}append(e){this.buffer.push(e);}drain(){let e=this.buffer;return this.buffer=[],e}get size(){return this.buffer.length}};function be(t){let e=Re(t);return en(e)}function Re(t){if(t==null||typeof t!="object")return JSON.stringify(t);if(Array.isArray(t))return "["+t.map(Re).join(",")+"]";let e=t;return "{"+Object.keys(e).sort().map(n=>JSON.stringify(n)+":"+Re(e[n])).join(",")+"}"}function en(t){let e=0xcbf29ce484222325n,r=0x100000001b3n,n=0xffffffffffffffffn;for(let o=0;o<t.length;o++)e^=BigInt(t.charCodeAt(o)),e=e*r&n;return e.toString(16).padStart(16,"0")}function rn(t){if(typeof Buffer<"u")return Buffer.from(t,"utf8").toString("base64url");if(typeof btoa=="function"){let e=new TextEncoder().encode(t),r="";for(let n of e)r+=String.fromCharCode(n);return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}throw new Error("No base64 encoder available in this runtime")}function nn(t){if(typeof Buffer<"u")return Buffer.from(t,"base64url").toString("utf8");if(typeof atob=="function"){let e=t.replace(/-/g,"+").replace(/_/g,"/"),r=e+"=".repeat((4-e.length%4)%4),n=atob(r),o=new Uint8Array(n.length);for(let s=0;s<n.length;s++)o[s]=n.charCodeAt(s);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function He(t){let e=JSON.stringify({t,n:Date.now().toString(36)+Math.random().toString(36).slice(2,6)});return rn(e)}function on(t){try{let e=JSON.parse(nn(t));return typeof e?.t=="string"?{taskName:e.t}:null}catch{return null}}function we(t,e,r){let{handlers:n,onDrain:o}=e,s=new Wt,i="state"in t&&"config"in t?t:re(t),a=false,c=new Set,f=new Map(Object.entries(n)),p=new Wt,g=false,l=false;function h(){if(!a){if(g){l=true;return}g=true;try{do l=!1,y();while(l)}finally{g=false;}}}function y(){let b=p.drain(),w=s.drain(),N=[...b,...w];N.length>0&&(i=Ue(i,N));let U=zt(i);N.length>0&&o?.(N,i,U);for(let x of U.eligible)I(x);for(let x of N)if(x.type==="task-progress"){let{taskName:_,update:B}=x;if(!i.config.tasks[_])continue;let J=i.state.tasks[_];if(!J||J.status!=="running")continue;let z=He(_),st=T(_,z,B).catch(Q=>{a||(p.append({type:"task-failed",taskName:_,error:Q.message??String(Q),timestamp:new Date().toISOString()}),h());}).finally(()=>{c.delete(st);});c.add(st);}}function k(b){let N=i.config.tasks[b].requires??[],U=new Map;for(let[_,B]of Object.entries(i.config.tasks))for(let L of B.provides??[])U.set(L,_);let x={};for(let _ of N){let B=U.get(_);B?x[_]=i.state.tasks[B]?.data:x[_]=void 0;}return x}async function T(b,w,N){let U=i.config.tasks[b],x=U.taskHandlers??[],_=k(b);for(let B of x){let L=f.get(B);if(!L)throw new Error(`Handler '${B}' not found in registry (task '${b}')`);let J={nodeId:b,state:_,taskState:i.state.tasks[b],config:U,callbackToken:w,update:N};if(await L(J)==="task-initiate-failure")throw new Error(`Handler '${B}' returned task-initiate-failure (task '${b}')`)}}function I(b){let N=i.config.tasks[b]?.taskHandlers;if(!N||N.length===0)return;p.append({type:"task-started",taskName:b,timestamp:new Date().toISOString()}),h();let U=He(b),x=T(b,U).catch(_=>{a||(p.append({type:"task-failed",taskName:b,error:_.message??String(_),timestamp:new Date().toISOString()}),h());}).finally(()=>{c.delete(x);});c.add(x);}return {push(b){a||(b.type==="task-completed"&&b.data&&!b.dataHash&&(b={...b,dataHash:be(b.data)}),s.append(b),h());},pushAll(b){if(!a){for(let w of b)w.type==="task-completed"&&w.data&&!w.dataHash?s.append({...w,dataHash:be(w.data)}):s.append(w);h();}},resolveCallback(b,w,N){if(a)return;let U=on(b);if(!U)return;let{taskName:x}=U;if(i.config.tasks[x]){if(N&&N.length>0)s.append({type:"task-failed",taskName:x,error:N.join("; "),timestamp:new Date().toISOString()});else {let _=w&&Object.keys(w).length>0?be(w):void 0;s.append({type:"task-completed",taskName:x,data:w,dataHash:_,timestamp:new Date().toISOString()});}h();}},addNode(b,w){a||(s.append({type:"task-upsert",taskName:b,taskConfig:w,timestamp:new Date().toISOString()}),h());},removeNode(b){a||(s.append({type:"task-removal",taskName:b,timestamp:new Date().toISOString()}),h());},addRequires(b,w){a||(s.append({type:"node-requires-add",nodeName:b,tokens:w,timestamp:new Date().toISOString()}),h());},removeRequires(b,w){a||(s.append({type:"node-requires-remove",nodeName:b,tokens:w,timestamp:new Date().toISOString()}),h());},addProvides(b,w){a||(s.append({type:"node-provides-add",nodeName:b,tokens:w,timestamp:new Date().toISOString()}),h());},removeProvides(b,w){a||(s.append({type:"node-provides-remove",nodeName:b,tokens:w,timestamp:new Date().toISOString()}),h());},registerHandler(b,w){f.set(b,w);},unregisterHandler(b){f.delete(b);},retrigger(b){a||i.config.tasks[b]&&(s.append({type:"task-restart",taskName:b,timestamp:new Date().toISOString()}),h());},retriggerAll(b){if(!a){for(let w of b)i.config.tasks[w]&&s.append({type:"task-restart",taskName:w,timestamp:new Date().toISOString()});h();}},snapshot(){return Kt(i)},getState(){return i},getSchedule(){return zt(i)},async waitForHandlers(){c.size>0&&await Promise.allSettled([...c]);},async dispose(b){b?.wait&&c.size>0&&await Promise.allSettled([...c]),a=true;}}}function oe(){return function(t){if(t==="./jsonata-sync.cjs")return typeof globalThis<"u"&&globalThis.__jsonataSync||typeof globalThis<"u"&&globalThis.jsonataSync;throw new Error("Unsupported require in browser bundle: "+t)}}var sn=oe();sn("./jsonata-sync.cjs");var an=oe(),se=an("./jsonata-sync.cjs"),ze=se;function Ve(t,e){if(!e||!t)return;let r=e.split("."),n=t;for(let o=0;o<r.length;o++){if(n==null)return;n=n[r[o]];}return n}function We(t,e,r){let n=e.split("."),o=t;for(let s=0;s<n.length-1;s++)(o[n[s]]==null||typeof o[n[s]]!="object")&&(o[n[s]]={}),o=o[n[s]];o[n[n.length-1]]=r;}async function cn(t,e){if(!t?.compute?.length)return t;t.card_data||(t.card_data={}),t.computed_values={},t._sourcesData=e?.sourcesData??{};let r=t.requires??{},n={card_data:t.card_data,requires:r,expects_data:r,fetched_sources:t._sourcesData,data:t.computed_values,computed_values:t.computed_values};for(let o of t.compute)try{let s=await se(o.expr).evaluate(n);We(t.computed_values,o.bindTo,s),n.computed_values=t.computed_values;}catch{}return t}function un(t,e){if(!t?.compute?.length)return {ok:true,node:t};t.card_data||(t.card_data={}),t.computed_values={},t._sourcesData=e?.sourcesData??{};let r=t.requires??{},n={card_data:t.card_data,requires:r,expects_data:r,fetched_sources:t._sourcesData,data:t.computed_values,computed_values:t.computed_values},o=[];for(let s of t.compute)try{let i=ze(s.expr).evaluate(n);We(t.computed_values,s.bindTo,i),n.computed_values=t.computed_values;}catch(i){let a=i instanceof Error?i.message:String(i);o.push({bindTo:s.bindTo,error:a});}return o.length>0?{ok:true,node:t,errors:o}:{ok:true,node:t}}async function dn(t,e,r){let n={...r??{},card_data:e.card_data??{},requires:e.requires??{},fetched_sources:e._sourcesData??{},computed_values:e.computed_values??{}};return se(t).evaluate(n)}function ln(t,e){return e.startsWith("fetched_sources.")?Ve(t._sourcesData??{},e.slice(16)):Ve(t,e)}var Ke=new Set(["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]),fn=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function gn(t){let e=[];if(!t||typeof t!="object"||Array.isArray(t))return {ok:false,errors:["Node must be a non-null object"]};let r=t;(typeof r.id!="string"||!r.id)&&e.push("id: required, must be a non-empty string");for(let n of Object.keys(r))fn.has(n)||e.push(`Unknown top-level key: "${n}"`);if((r.card_data==null||typeof r.card_data!="object"||Array.isArray(r.card_data))&&e.push("card_data: required, must be an object"),r.meta!=null)if(typeof r.meta!="object"||Array.isArray(r.meta))e.push("meta: must be an object");else {let n=r.meta;n.title!=null&&typeof n.title!="string"&&e.push("meta.title: must be a string"),n.tags!=null&&!Array.isArray(n.tags)&&e.push("meta.tags: must be an array");}if(r.requires!=null&&!Array.isArray(r.requires)&&e.push("requires: must be an array of strings"),r.provides!=null&&(Array.isArray(r.provides)?r.provides.forEach((n,o)=>{if(!n||typeof n!="object"||Array.isArray(n))e.push(`provides[${o}]: must be an object with bindTo and ref`);else {let s=n;(typeof s.bindTo!="string"||!s.bindTo)&&e.push(`provides[${o}]: missing required "bindTo" string`),(typeof s.ref!="string"||!s.ref)&&e.push(`provides[${o}]: missing required "ref" string`);}}):e.push("provides: must be an array of { bindTo, ref } bindings")),r.compute!=null&&(Array.isArray(r.compute)?r.compute.forEach((n,o)=>{if(!n||typeof n!="object"||Array.isArray(n))e.push(`compute[${o}]: must be a compute step object`);else {let s=n;(typeof s.bindTo!="string"||!s.bindTo)&&e.push(`compute[${o}]: missing required "bindTo" property`),(typeof s.expr!="string"||!s.expr)&&e.push(`compute[${o}]: missing required "expr" string (JSONata expression)`);}}):e.push("compute: must be an array of compute steps")),r.source_defs!=null)if(!Array.isArray(r.source_defs))e.push("source_defs: must be an array");else {let n=new Set,o=new Set;r.source_defs.forEach((s,i)=>{if(!s||typeof s!="object"||Array.isArray(s))e.push(`source_defs[${i}]: must be an object`);else {let a=s;typeof a.bindTo!="string"||!a.bindTo?e.push(`source_defs[${i}]: missing required "bindTo" property`):(n.has(a.bindTo)&&e.push(`source_defs[${i}]: bindTo "${a.bindTo}" is not unique across source_defs`),n.add(a.bindTo)),typeof a.outputFile!="string"||!a.outputFile?e.push(`source_defs[${i}]: missing required "outputFile" property`):(o.has(a.outputFile)&&e.push(`source_defs[${i}]: outputFile "${a.outputFile}" is not unique across source_defs`),o.add(a.outputFile)),a.optionalForCompletionGating!=null&&typeof a.optionalForCompletionGating!="boolean"&&e.push(`source_defs[${i}]: optionalForCompletionGating must be a boolean`);}});}if(r.view!=null)if(typeof r.view!="object"||Array.isArray(r.view))e.push("view: must be an object");else {let n=r.view;!Array.isArray(n.elements)||n.elements.length===0?e.push("view.elements: required, must be a non-empty array"):n.elements.forEach((o,s)=>{if(!o||typeof o!="object"){e.push(`view.elements[${s}]: must be an object`);return}!o.kind||typeof o.kind!="string"?e.push(`view.elements[${s}].kind: required, must be a string`):Ke.has(o.kind)||e.push(`view.elements[${s}].kind: unknown kind "${o.kind}". Valid: ${[...Ke].join(", ")}`),o.data!=null&&(typeof o.data!="object"||Array.isArray(o.data))&&e.push(`view.elements[${s}].data: must be an object`);}),n.layout!=null&&(typeof n.layout!="object"||Array.isArray(n.layout))&&e.push("view.layout: must be an object"),n.features!=null&&(typeof n.features!="object"||Array.isArray(n.features))&&e.push("view.features: must be an object");}return {ok:e.length===0,errors:e}}async function pn(t,e){if(!t||t.length===0)return [];let r={card_data:e.card_data??{},requires:e.requires??{}};return Promise.all(t.map(async n=>{let o={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[s,i]of Object.entries(n.projections))if(typeof i=="string"&&i.trim().length>0)try{o[s]=await se(i).evaluate(r);}catch{o[s]=void 0;}}return {...n,_projections:o}}))}function mn(t,e){if(!t||t.length===0)return [];let r={card_data:e.card_data??{},requires:e.requires??{}};return t.map(n=>{let o={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[s,i]of Object.entries(n.projections))if(typeof i=="string"&&i.trim().length>0)try{o[s]=ze(i).evaluate(r);}catch{o[s]=void 0;}}return {...n,_projections:o}})}var Ut={run:cn,runSync:un,eval:dn,resolve:ln,validate:gn,enrichSources:pn,enrichSourcesSync:mn};function Xe(t){return JSON.stringify(t)}function Ye(t){let e;try{e=JSON.parse(t);}catch{throw new Error(`parseExecutionRef: invalid JSON \u2014 ${t}`)}if(typeof e!="object"||e===null||typeof e.howToRun!="string"||typeof e.whatToRun!="string")throw new Error(`parseExecutionRef: missing required fields howToRun/whatToRun \u2014 ${t}`);return e}function ae(t,e){function r(){return t.readIndex()??{}}function n(o,s,i){let a=String(s||"").split(".").filter(Boolean);if(a.length===0)return i&&typeof i=="object"&&!Array.isArray(i)?i:{value:i};let c={...o},f=c;for(let p=0;p<a.length-1;p++){let g=a[p],l=f[g],h=l&&typeof l=="object"&&!Array.isArray(l)?{...l}:{};f[g]=h,f=h;}return f[a[a.length-1]]=i,c}return {readCard(o){let s=r()[o];return !s||!t.cardExists(s.key)?null:t.readCard(s.key)},readCardKey(o){return r()[o]?.key??null},readAllCards(){let o=[];for(let[s,i]of Object.entries(r())){if(!t.cardExists(i.key))continue;let a=t.readCard(i.key);a?o.push(a):e?.(`[card-store] could not read card "${s}" at key "${i.key}"`);}return o},readChecksumIndex(){let o={};for(let[s,i]of Object.entries(r()))o[s]=i.checksum;return o},changedSince(o){let s=r(),i=[];for(let[a,c]of Object.entries(s))o[a]!==c.checksum&&i.push(a);for(let a of Object.keys(o))s[a]||i.push(a);return i},validateUpsert(o,s){let i=r(),a=i[o],c=Object.entries(i).find(([,f])=>f.key===s);return a&&a.key!==s?{ok:false,error:`Card id "${o}" is already mapped to key "${a.key}", cannot remap to "${s}"`}:c&&c[0]!==o?{ok:false,error:`Key "${s}" is already mapped to card id "${c[0]}", cannot remap to "${o}"`}:{ok:true}},writeCard(o,s,i){let a=r(),c=i??a[o]?.key??t.defaultCardKey(o),f=t.writeCard(c,s);a[o]={key:c,checksum:f,updatedAt:new Date().toISOString()},t.writeIndex(a);},patchCard(o,s,i){let a=r(),c=a[o];if(!c||!t.cardExists(c.key))throw new Error(`card "${o}" not found`);let f=t.readCard(c.key);if(!f||typeof f!="object"||Array.isArray(f))throw new Error(`card "${o}" is not patchable`);let p=n(f,s,i),g=t.writeCard(c.key,p);a[o]={key:c.key,checksum:g,updatedAt:new Date().toISOString()},t.writeIndex(a);},removeCard(o){let s=r(),i=s[o];i&&(t.removeCard(i.key),delete s[o],t.writeIndex(s));},readIndex(){return r()}}}function ve(t,e){return {readSourceData(r,n){let o=t.read(`${r}/${n}`);if(o==null)return null;let s=o.trim();if(!s)return null;try{return JSON.parse(s)}catch{return s}},ingestSourceDataStaged(r,n,o,s){let i=e(o);t.write(`${r}/.staged/${s}/${n}`,i);},commitSourceData(r,n,o){let s=`${r}/.staged/${o}/${n}`,i=t.read(s);return i==null?false:(t.write(`${r}/${n}`,i),t.remove(s),true)},hasSource(r,n){return t.exists(`${r}/${n}`)}}}function rr(t){function e(r){let n=t.readAllEntries();if(!r)return n;let o=n.findIndex(s=>s.id===r);return o===-1?n:n.slice(o+1)}return {readEntriesAfterCursor(r){let n=e(r);return n.length===0?{events:[],newCursor:r}:{events:n.map(o=>o.event),newCursor:n[n.length-1].id}},pendingCount(r){return e(r).length},appendEvent(r){t.appendEntry({id:t.generateId(),event:r});}}}function nr(t,e){return {appendEntries(r,n){if(!r||n.length===0)return;let o=t.read(r)??[];t.write(r,[...o,...n]);},dispatchEntriesForJournalId(r,n){if(!r)return;let o=t.read(r);if(!(!o||o.length===0)){for(let s of o)try{n(s);}catch(i){let a=i instanceof Error?i.message:String(i);try{e(s,a);}catch{}}t.delete(r);}}}}var ie="v1",Nt="board/graph",or="board/lastJournalProcessedId";function Ze(t){return `cards/${t}/runtime`}function sr(t){return {readRuntime(e){return t.read(Ze(e))??{_sources:{}}},writeRuntime(e,r){t.write(Ze(e),r);}}}function hn(t,e){let r={...t};for(let n of e.deleteKeys)delete r[n];return {...r,...e.shallowMerge}}function ar(t){return {readSnapshot(e){return t.readValues(e)},commitSnapshot(e,r){if(r.schemaVersion!==ie)throw new Error(`Unsupported snapshot schema version: ${r.schemaVersion}`);let n=t.readValues(e);if(n.version!==r.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:n.version};let o=hn(n.values,r);return {ok:true,newVersion:t.writeValues(e,o,r.deleteKeys)}}}}function ir(t){function e(r){let n=t.read(r);return n==null?null:typeof n=="string"?n:JSON.stringify(n)}return {readTaskExecutorRef(){let r=e("task-executor");if(r?.trim())return Ye(r.trim())},writeTaskExecutorRef(r){t.write("task-executor",Xe(r));},readChatHandlerFlow(){return t.read("chat-handler-flow")},writeChatHandlerFlow(r){t.write("chat-handler-flow",r);},readCardStoreRef(){return e("card-store-ref")},writeCardStoreRef(r){t.write("card-store-ref",r);},readOutputsStoreRef(){return e("outputs-store-ref")},writeOutputsStoreRef(r){t.write("outputs-store-ref",r);},readScratchStoreRef(){return e("scratch-store-ref")},writeScratchStoreRef(r){t.write("scratch-store-ref",r);},readArchiveStoreRef(){return e("archive-store-ref")},writeArchiveStoreRef(r){t.write("archive-store-ref",r);}}}function cr(t){return {writeComputedValues(e,r){t.write(`cards/${e}/computed_values`,r);},readComputedValues(e){return t.read(`cards/${e}/computed_values`)},readAllComputedValues(){let e={};for(let r of t.listKeys("cards/")){let n=r.match(/^cards\/([^/]+)\/computed_values$/);n&&(e[n[1]]=t.read(r));}return e},writeDataObjects(e){for(let[r,n]of Object.entries(e))r&&t.write(`data-objects/${r}`,n);},readDataObject(e){return t.read(`data-objects/${e}`)},readAllDataObjects(){let e={};for(let r of t.listKeys("data-objects/"))e[r.slice(13)]=t.read(r);return e},writeStatusSnapshot(e){t.write("status",e);},readStatusSnapshot(){return t.read("status")}}}function Qe(t){return t?{lastRequestedToken:t.lastRequestedToken,lastCompletedToken:t.lastCompletedToken,lastCompletionStatus:t.lastCompletionStatus??(t.lastCompletedToken?"success":"not-started"),queueRequestedToken:t.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function yn(t){return t?.lastRequestedToken?t.lastCompletedToken!==t.lastRequestedToken:false}function tr(t,e){return t?.lastRequestedToken?yn(t)?"in-flight":!t.lastCompletedToken||t.lastCompletedToken<e?"dispatch":"idle":"dispatch"}function kn(t,e){return {...t,lastCompletedToken:e,lastCompletionStatus:"success"}}function er(t,e){return {...t,lastCompletedToken:e,lastCompletionStatus:"failure"}}function ce(t,e){let r=e.state.tasks,n=e.config.tasks,o=Object.keys(r),s=zt(e),i={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},a=new Map;for(let y of s.pending)a.set(y.taskName,y.waitingOn);for(let y of s.unresolved)a.set(y.taskName,y.missingTokens);for(let y of s.blocked)a.set(y.taskName,y.failedTokens);let c=new Map;for(let[y,k]of Object.entries(n))for(let T of k.requires??[]){let I=c.get(T)??[];I.push(y),c.set(T,I);}let f=o.sort().map(y=>{let k=r[y],T=n[y]??{requires:[],provides:[]};k.status==="completed"?i.completed+=1:k.status==="failed"?i.failed+=1:k.status==="in-progress"&&(i.in_progress+=1);let I=T.requires??[],b=T.provides??[],w=Object.keys(k.data??{}).sort(),N=I.filter(J=>e.state.availableOutputs.includes(J)),U=I.filter(J=>!e.state.availableOutputs.includes(J)),x=a.get(y)??U,_=new Set;for(let J of b)for(let z of c.get(J)??[])z!==y&&_.add(z);let B=k.failedAt,L=k.error?{message:k.error,code:"TASK_FAILED",at:B,source:"task-runtime"}:void 0;return {name:y,status:k.status,error:L,requires:I,requires_satisfied:N,requires_missing:U,provides_declared:b,provides_runtime:w,blocked_by:x,unblocks:Array.from(_).sort(),runtime:{attempt_count:k.executionCount??0,restart_count:k.retryCount??0,in_progress_since:k.status==="in-progress"?k.startedAt??null:null,last_transition_at:k.lastUpdated??null,last_completed_at:k.completedAt??null,last_restarted_at:k.startedAt??null,status_age_ms:k.lastUpdated?0:null}}});i.pending=s.pending.length,i.blocked=s.blocked.length,i.unresolved=s.unresolved.length;let p=f.map(y=>({name:y.name,fanOut:y.unblocks.length})).sort((y,k)=>k.fanOut-y.fanOut||y.name.localeCompare(k.name)),g=p.length>0?p[0]:{name:null,fanOut:0},l=new Set;for(let y of Object.values(n))for(let k of y.requires??[])l.add(k);let h=0;for(let[y,k]of Object.entries(n)){let T=(k.requires??[]).length===0,b=(k.provides??[]).some(w=>(c.get(w)??[]).some(N=>N!==y));T&&!b&&(h+=1);}return {schema_version:"v1",meta:{board:{path:t}},summary:{card_count:o.length,completed:i.completed,eligible:s.eligible.length,pending:i.pending,blocked:i.blocked,unresolved:i.unresolved,failed:i.failed,in_progress:i.in_progress,orphan_cards:h,topology:{edge_count:Array.from(l).length,max_fan_out_card:g.name,max_fan_out:g.fanOut}},cards:f}}function Sn(){return new Date().toISOString()}function ur(t,e,r,n,o,s,i){return async a=>{let c=[],f=r.cardStore.readCard(a.nodeId);if(!f)return "task-initiate-failure";let p=f.id,g=f.card_data??{},l=f.source_defs??[],h=l.filter(P=>P.optionalForCompletionGating!==true),y=r.cardRuntimeStore.readRuntime(p),k=false,T=()=>{k&&(r.cardRuntimeStore.writeRuntime(p,y),k=false);},I=P=>Qe(y._sources[P]),b=(P,M)=>{y._sources[P]=Qe(M),k=true;},w=a.taskState?.executionCount??0;if(y._lastExecutionCount!==w&&(y._sources={},y._lastExecutionCount=w,k=true),a.update){let P=a.update,M=P.outputFile;if(M){let W=I(M);if(P.failure){let nt=P.rqt??W.lastRequestedToken??W.queueRequestedToken;nt&&b(M,er(W,nt));}else {let nt=P.rqt;if(!W.lastCompletedToken||nt>W.lastCompletedToken){let gt=typeof P.deliveryToken=="string"?P.deliveryToken:void 0,A=false;gt&&(A=r.fetchedSourcesStore.commitSourceData(p,M,gt)),A?b(M,kn(W,nt)):b(M,er(W,nt));}}T();}}let U={};for(let P of l)if(P.outputFile){let M=r.fetchedSourcesStore.readSourceData(p,P.outputFile);M!==null&&(U[P.bindTo]=M);}let x={};for(let[P,M]of Object.entries(a.state??{}))if(M!==null&&typeof M=="object"&&!Array.isArray(M)){let W=M[P];x[P]=W!==void 0?W:M;}else x[P]=M;let _={id:p,card_data:{...g},requires:x,source_defs:l,compute:f.compute};_._sourcesData=U,f.compute&&Ut.runSync(_,{sourcesData:U}),(s??r.outputStore.writeComputedValues.bind(r.outputStore))(p,_.computed_values??{});let B={...f},L=Ut.enrichSourcesSync(Array.isArray(f.source_defs)?f.source_defs:void 0,{card_data:f.card_data,requires:x}),J=t.value;B.source_defs=Array.isArray(L)?L.map(P=>({...P,boardDir:typeof P.boardDir=="string"&&P.boardDir?P.boardDir:J})):L;let z=Sn(),st=a.update?void 0:z,Q=h.filter(P=>{let M=P.outputFile;if(typeof M!="string"||!M)return true;let W=I(M);st&&(W={...W,queueRequestedToken:st},b(M,W));let nt=W.queueRequestedToken??W.lastRequestedToken??z,gt=tr(W,nt);return gt==="in-flight"?false:gt==="dispatch"});if(T(),Q.length>0){let P=false,M=z;for(let W of Q){let nt=W.outputFile;if(typeof nt!="string"||!nt)continue;let gt=I(nt),A=gt.queueRequestedToken??z;b(nt,{...gt,lastRequestedToken:A}),M=A,P=true;}return P&&T(),P&&(c.push({taskKind:"source-fetch",payload:{boardRef:ot(t),enrichedCard:B,callbackToken:a.callbackToken,rqt:M}}),r.executionRequestStore.appendEntries(e,c)),"task-initiated"}if(h.some(P=>{let M=P.outputFile;if(typeof M!="string"||!M)return false;let W=I(M),nt=W.queueRequestedToken??W.lastRequestedToken??z;return tr(W,nt)==="in-flight"}))return "task-initiated";let xt=f.provides??[],Bt={};for(let{bindTo:P,ref:M}of xt)Bt[P]=Ut.resolve(_,M);return (i??r.outputStore.writeDataObjects.bind(r.outputStore))(Bt),l.filter(P=>{if(P.optionalForCompletionGating!==true)return false;let M=I(P.outputFile);return !M.lastRequestedToken||!M.lastCompletedToken?true:M.lastCompletedToken<=M.lastRequestedToken}).length>0&&c.push({taskKind:"source-fetch",payload:{boardRef:ot(t),enrichedCard:B,callbackToken:a.callbackToken,rqt:z}}),n(a.nodeId,Bt),c.length>0&&r.executionRequestStore.appendEntries(e,c),"task-initiated"}}var Ae={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function dr(t){return {[Nt]:t.graph,[or]:t.lastDrainedJournalId}}function lr(t){let e=t[Nt],r=t[or];if(!e||typeof e!="object")throw new Error(`State snapshot is missing required key: ${Nt}`);return {graph:e,lastDrainedJournalId:typeof r=="string"?r:""}}function fr(t){let e=t.requires,r=t.provides?.map(n=>n.bindTo)??[];return {requires:e&&e.length>0?e:void 0,provides:r,taskHandlers:["card-handler"],description:t.meta?.title??t.id}}function at(t){return t!==void 0?{status:"success",data:t}:{status:"success"}}function rt(t){return {status:"fail",error:t}}function it(t){return {status:"error",error:t instanceof Error?t.message:String(t)}}function Cn(t){let e=new TextEncoder().encode(t),r=Array.from(e,n=>String.fromCharCode(n)).join("");return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function pr(t){let e=t.replace(/-/g,"+").replace(/_/g,"/"),r=e+"=".repeat((4-e.length%4)%4),n=atob(r),o=Uint8Array.from(n,s=>s.charCodeAt(0));return new TextDecoder().decode(o)}function ue(t){try{let e=JSON.parse(pr(t));return typeof e?.t=="string"?{taskName:e.t}:null}catch{return null}}function bn(t){return Cn(JSON.stringify(t))}function gr(t){try{let e=JSON.parse(pr(t));return typeof e?.cbk=="string"&&typeof e?.cid=="string"&&typeof e?.b=="string"&&typeof e?.d=="string"?e:null}catch{return null}}function ut(){return new Date().toISOString()}function mr(t,e){let r=e.onWarn??(()=>{}),n=ot(t);function o(A){if(A.length!==0)try{let S=e.publishBoardChangeNotifications?.(A);S&&typeof S.catch=="function"&&S.catch(O=>r(`[board-live-cards-public] publishBoardChangeNotifications failed: ${O instanceof Error?O.message:String(O)}`));}catch(S){r(`[board-live-cards-public] publishBoardChangeNotifications failed: ${S instanceof Error?S.message:String(S)}`);}}function s(){let A=a().readCardStoreRef();if(!A)throw new Error(`Board at ${t.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let S=e.kvStorageForRef(A);return {readIndex(){return S.read("_index")},writeIndex(O){S.write("_index",O);},readCard(O){return S.read(O)},writeCard(O,q){return S.write(O,q),e.hashFn(q)},removeCard(O){S.delete(O);},cardExists(O){return S.read(O)!==null},defaultCardKey(O){return O}}}let i={readValues(A){let S=e.kvStorage("state-snapshot"),O=S.listKeys().sort();if(O.length===0)return {version:null,values:{}};let q={};for(let Z of O)q[Z]=S.read(Z);return {version:e.hashFn(q),values:q}},writeValues(A,S,O){let q=e.kvStorage("state-snapshot");for(let Z of O)q.delete(Z);for(let[Z,H]of Object.entries(S))q.write(Z,H);return e.hashFn(S)}},a=()=>ir(e.kvStorage("config")),c=()=>ar(i),f=()=>rr(e.journalAdapter()),p=()=>ae(s(),r),g=()=>{let A=a().readOutputsStoreRef();if(!A)throw new Error(`Board at ${t.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return cr(e.kvStorageForRef(A))},l=()=>{let A=a().readArchiveStoreRef();return A?e.archiveFactoryForRef(A):e.archiveFactory()};function h(){return !!c().readSnapshot(t.value).values[Nt]}function y(){let A=c().readSnapshot(t.value);if(!A.values[Nt])throw new Error(`Board not initialized at ${t.value}`);return lr(A.values)}function k(A,S){let O=c().commitSnapshot(t.value,{schemaVersion:ie,expectedVersion:S,commitId:e.genId(),committedAt:ut(),deleteKeys:[],shallowMerge:dr(A)});if(!O.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${S??"null"} current=${O.currentVersion??"null"}`)}function T(A){f().appendEvent(A);}async function I(){let A=(E,F)=>{let tt=E.payload,d=(tt?.enrichedCard??{}).id??tt?.cardId??"unknown";T({type:"task-failed",taskName:d,error:F,timestamp:ut()});},S=nr(e.kvStorage("execution-requests"),A),O=sr(e.kvStorage("card-runtime")),q=ve(e.blobStorage("sources"),E=>e.resolveBlob(E)),Z=new Map,H={readRuntime(E){return Z.get(E)??O.readRuntime(E)},writeRuntime(E,F){Z.set(E,F);}},dt=[],ct=new Map,Ct={readSourceData(E,F){let tt=`${E}/${F}`;return ct.has(tt)?ct.get(tt):q.readSourceData(E,F)},ingestSourceDataStaged(E,F,tt,u){q.ingestSourceDataStaged(E,F,tt,u);},commitSourceData(E,F,tt){let u=`${E}/.staged/${tt}/${F}`,m=e.blobStorage("sources").read(u);if(m==null)return false;let C=`${E}/${F}`,R=m.trim();try{ct.set(C,JSON.parse(R));}catch{ct.set(C,R);}return dt.push({cardId:E,outputFile:F,deliveryToken:tt}),true},hasSource(E,F){let tt=`${E}/${F}`;return ct.has(tt)?true:q.hasSource(E,F)}},lt={cardStore:p(),cardRuntimeStore:H,fetchedSourcesStore:Ct,outputStore:g(),executionRequestStore:S},vt=y(),K=ne(vt.graph),{events:mt,newCursor:Tt}=f().readEntriesAfterCursor(vt.lastDrainedJournalId),wt=[],Dt=[],Lt=[],Ht=new Map,Vt=(E,F)=>{wt.push({type:"task-completed",taskName:E,data:F,timestamp:ut()});try{l().stream("exec-history").append({taskName:E,status:"completed",completedAt:ut()});}catch{}},qt=(E,F)=>{T({type:"task-failed",taskName:E,error:F,timestamp:ut()});try{l().stream("exec-history").append({taskName:E,status:"failed",error:F,completedAt:ut()});}catch{}},It=we(K,{handlers:{"card-handler":ur(t,Tt,lt,Vt,qt,(E,F)=>{Dt.push({cardId:E,values:F});},E=>{Lt.push(E);})}});for(wt=mt;wt.length>0;){let E=wt;wt=[];for(let F of E)if(F.type==="task-restart"){let tt=lt.cardStore.readCard(F.taskName);tt&&Ht.set(F.taskName,tt);}It.pushAll(E),await It.waitForHandlers();}let Pt=It.getState();await It.dispose({wait:true});let ye=c().readSnapshot(t.value).version;k({lastDrainedJournalId:Tt,graph:Kt(Pt)},ye);for(let{cardId:E,values:F}of Dt)lt.outputStore.writeComputedValues(E,F);for(let E of Lt)lt.outputStore.writeDataObjects(E);for(let[E,F]of Z)O.writeRuntime(E,F);for(let{cardId:E,outputFile:F,deliveryToken:tt}of dt)q.commitSourceData(E,F,tt);let Mt;try{Mt=ce(n,Pt),lt.outputStore.writeStatusSnapshot(Mt);}catch(E){r(`[board-live-cards-public] status publish failed: ${E instanceof Error?E.message:String(E)}`);}let jt=[];for(let{cardId:E,values:F}of Dt)jt.push({kind:"computed_values",cardId:E,values:F});for(let E of Lt)for(let[F,tt]of Object.entries(E))F&&jt.push({kind:"data_object",key:F,payload:tt});for(let[E,F]of Ht)jt.push({kind:"card_refreshed",cardId:E,card:F});Mt!==void 0&&jt.push({kind:"status",status:Mt}),o(jt);let ke=a().readTaskExecutorRef()??{howToRun:"built-in",whatToRun:ot({kind:"built-in",value:"source-cli-task-executor"})};S.dispatchEntriesForJournalId(Tt,E=>{if(E.taskKind!=="source-fetch"){r(`[process-accumulated-events] unknown taskKind "${E.taskKind}" \u2014 skipping`);return}let F=E.payload,tt=F.enrichedCard?.id??"unknown",u=F.enrichedCard?.source_defs??[];for(let d of u){if(!d.outputFile){r(`[dispatch] source "${d.bindTo}" has no outputFile \u2014 skipping`);continue}let m=bn({cbk:F.callbackToken,rg:t.value,br:ot(t),cid:tt,b:d.bindTo,d:d.outputFile,cs:void 0,rqt:F.rqt});e.dispatchExecution(ke,{source_def:d,base_ref:ot(t),callback:{token:m,via:e.selfRef}}).catch(C=>qt(tt,C instanceof Error?C.message:String(C)));}});}async function b(){try{let A=()=>{let O=y(),{events:q}=f().readEntriesAfterCursor(O.lastDrainedJournalId);q.length<=0||(b(),e.requestProcessAccumulated?.());},S=await Be(e.lock,I,A);return at({ran:S!==!1})}catch(A){return it(A)}}function w(){b(),e.requestProcessAccumulated?.();}function N(A){try{let S=A.params?.cardStoreRef;if(!S)return rt("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(!h()){let ct=re(Ae);k({lastDrainedJournalId:"",graph:Kt(ct)},null);}let O=A.params?.outputsStoreRef;if(!O)return rt("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let q=A.params?.scratchStoreRef,Z=A.params?.archiveStoreRef,H=a();H.writeCardStoreRef(S),H.writeOutputsStoreRef(O),q&&H.writeScratchStoreRef(q),Z&&H.writeArchiveStoreRef(Z);let dt=A.body??{};dt["task-executor-ref"]&&H.writeTaskExecutorRef(dt["task-executor-ref"]),Object.prototype.hasOwnProperty.call(dt,"chat-handler-flow")&&H.writeChatHandlerFlow(dt["chat-handler-flow"]);try{g().writeStatusSnapshot(ce(n,ne(y().graph)));}catch{}return at()}catch(S){return it(S)}}function U(A){try{let S=g().readStatusSnapshot();if(!S){S=ce(n,ne(y().graph));try{g().writeStatusSnapshot(S);}catch{}}return at(S)}catch(S){return it(S)}}function x(A){try{let S=A.params?.id;return S?(T({type:"task-removal",taskName:S,timestamp:ut()}),w(),at()):rt("removeCard requires params.id")}catch(S){return it(S)}}function _(A){try{let S=A.params?.id;return S?(T({type:"task-restart",taskName:S,timestamp:ut()}),w(),at()):rt("retrigger requires params.id")}catch(S){return it(S)}}async function B(A){return b()}function L(A){try{let S=A.params?.cardId,O=A.params?.all,q=!!A.params?.restart;if(!S&&!O)return rt("upsertCard requires --card-id <id> or --all");let Z=O?p().readAllCards().map(H=>H.id):[S];for(let H of Z)if(!p().readCard(H))return rt(`Card "${H}" not found in board at ${t.value}`);for(let H of Z){let dt=p().readCard(H),ct=fr(dt),Ct=e.hashFn(ct),lt=e.kvStorage("card-upsert"),vt=lt.read(H),K=vt?.taskConfigHash!==Ct;if(!(!K&&!q)){if(K){let mt=vt?.blobRef??p().readCardKey(H)??H;T({type:"task-upsert",taskName:H,taskConfig:ct,timestamp:ut()}),lt.write(H,{blobRef:mt,taskConfigHash:Ct,updatedAt:ut()});}q&&T({type:"task-restart",taskName:H,timestamp:ut()});}}return w(),at()}catch(S){return it(S)}}function J(A){try{let S=A.params?.token;if(!S)return rt("taskFailed requires params.token");let O=A.params?.error??"unknown error",q=ue(S);if(!q)return rt("Invalid callback token");T({type:"task-failed",taskName:q.taskName,error:O,timestamp:ut()});try{l().stream("exec-history").append({taskName:q.taskName,status:"failed",error:O,completedAt:ut()});}catch{}return w(),at()}catch(S){return it(S)}}function z(A){try{let S=A.params?.token;if(!S)return rt("taskProgress requires params.token");let q=(A.body??{}).update??{},Z=ue(S);return Z?(T({type:"task-progress",taskName:Z.taskName,update:q,timestamp:ut()}),w(),at()):rt("Invalid callback token")}catch(S){return it(S)}}function st(A){try{let S=A.params?.token,O=A.params?.ref;if(!S)return rt("sourceDataFetched requires params.token");if(!O)return rt("sourceDataFetched requires params.ref");let q=gr(S);if(!q)return rt("Invalid source token");let{cbk:Z,cid:H,b:dt,d:ct,cs:Ct,rqt:lt}=q,vt=ve(e.blobStorage("sources"),wt=>e.resolveBlob(wt)),K=e.genId();vt.ingestSourceDataStaged(H,ct,bt(O),K);let mt=ue(Z);if(!mt)return rt("Invalid callback token embedded in source token");let Tt=ut();return T({type:"task-progress",taskName:mt.taskName,update:{bindTo:dt,outputFile:ct,fetchedAt:Tt,deliveryToken:K,sourceChecksum:Ct,rqt:lt},timestamp:Tt}),w(),at()}catch(S){return it(S)}}function Q(A){try{let S=A.params?.token,O=A.params?.reason??"unknown";if(!S)return rt("sourceDataFetchFailure requires params.token");let q=gr(S);if(!q)return rt("Invalid source token");let{cbk:Z,b:H,d:dt,cs:ct,rqt:Ct}=q,lt=ue(Z);return lt?(T({type:"task-progress",taskName:lt.taskName,update:{bindTo:H,outputFile:dt,failure:!0,reason:O,sourceChecksum:ct,rqt:Ct},timestamp:ut()}),w(),at()):rt("Invalid callback token embedded in source token")}catch(S){return it(S)}}function _t(A){try{let S=a().readCardStoreRef();return S?at({storeRef:S}):rt(`Board at ${t.value} has no card store configured`)}catch(S){return it(S)}}function xt(A){try{let S=a().readOutputsStoreRef();return S?at({storeRef:S}):rt(`Board at ${t.value} has no outputs store configured`)}catch(S){return it(S)}}function Bt(A){try{let S=a().readScratchStoreRef();return at({storeRef:S})}catch(S){return it(S)}}function Yt(A){try{let S=a().readArchiveStoreRef();return at({storeRef:S})}catch(S){return it(S)}}function P(A){try{let S=A.params?.key;if(!S)return rt("getConfig requires params.key");let O=a(),q;switch(S){case "task-executor":q=O.readTaskExecutorRef()??null;break;case "chat-handler-flow":q=O.readChatHandlerFlow()??null;break;case "card-store-ref":q=O.readCardStoreRef();break;case "outputs-store-ref":q=O.readOutputsStoreRef();break;case "scratch-store-ref":q=O.readScratchStoreRef();break;case "archive-store-ref":q=O.readArchiveStoreRef();break;default:return rt(`getConfig: unknown key "${S}"`)}return at({value:q})}catch(S){return it(S)}}function M(A){try{let S=A.params?.key;if(!S)return rt("getOutputsDataObject requires params.key");let O=g().readDataObject(S);return at(O)}catch(S){return it(S)}}function W(A){try{return at(g().readAllDataObjects())}catch(S){return it(S)}}function nt(A){try{let S=A.params?.key;if(!S)return rt("getOutputsComputedValues requires params.key");let O=g().readComputedValues(S);return at(O)}catch(S){return it(S)}}function gt(A){try{return at(g().readAllComputedValues())}catch(S){return it(S)}}return {init:N,status:U,getCardStoreRef:_t,getOutputsStoreRef:xt,getScratchStoreRef:Bt,getArchiveStoreRef:Yt,getConfig:P,getOutputsDataObject:M,getAllOutputsDataObjects:W,getOutputsComputedValues:nt,getAllOutputsComputedValues:gt,removeCard:x,retrigger:_,processAccumulatedEvents:B,upsertCard:L,taskFailed:J,taskProgress:z,sourceDataFetched:st,sourceDataFetchFailure:Q}}function hr(t){function e(o){return {status:"success",data:o}}function r(o){return {status:"fail",error:o}}function n(o){return {status:"error",error:o instanceof Error?o.message:String(o)}}return {get(o){try{let s=o.params?.id;if(s){let i=t.readCard(s);return i?e({cards:[i]}):r(`card "${s}" not found`)}return e({cards:t.readAllCards()})}catch(s){return n(s)}},set(o){try{let s=o.body;if(s==null)return r("set requires a body (card object or array of cards)");let i=Array.isArray(s)?s:[s];for(let a of i){if(typeof a.id!="string")return r("each card must have a string `id` field");t.writeCard(a.id,a);}return e({count:i.length})}catch(s){return n(s)}},del(o){try{let s=o.body?.ids??[],i=o.params?.id,a=i?[...s,i]:s;if(a.length===0)return r("del requires body.ids (string[]) or params.id");for(let c of a)t.removeCard(c);return e({count:a.length})}catch(s){return n(s)}},patch(o){try{let s=o.params?.id,i=o.params?.path;if(!s)return r("patch requires params.id");if(!i)return r("patch requires params.path");let a=o.body,c=a&&Object.prototype.hasOwnProperty.call(a,"value")?a.value:o.body;return t.patchCard(s,i,c),e({count:1})}catch(s){return n(s)}}}}function yr(){return new Date().toISOString()}function kr(t){return new TextEncoder().encode(t).byteLength}function Rn(t){return t?{key:t.key,size:t.size,updatedAt:t.updatedAt,contentType:t.contentType}:null}function wn(t){let e=String(t||"").match(/^(\d+)[-_]/);return e?parseInt(e[1],10):0}function vn(t){let e=String(t||"").trim();if(!e)return "upload.bin";let r=Math.max(e.lastIndexOf("/"),e.lastIndexOf("\\"));return (r>=0?e.slice(r+1):e)||"upload.bin"}function An(t){return String(t||"").toLowerCase().replace(/\s+/g,"_").replace(/[^a-z0-9_-]/g,"_").replace(/_+/g,"_").replace(/^_+|_+$/g,"")||"file"}function _n(t){if(!t||t===".")return "";let e=String(t).replace(/^\./,"").toLowerCase().replace(/[^a-z0-9]/g,"");return e?`.${e}`:""}function xn(t){let e=vn(t),r=e.lastIndexOf(".");return r<=0||r===e.length-1?{stem:e,ext:""}:{stem:e.slice(0,r),ext:e.slice(r)}}function Tn(t){let e=t.lastIndexOf("/");return e>=0?t.slice(e+1):t}function Sr(t){function e(r){let n=t.stat?Rn(t.stat(r)):null;if(n)return n;if(!t.exists(r))return null;let o=t.read(r);return o===null?{key:r}:{key:r,size:kr(o)}}return {exists(r){return t.exists(r)},putText(r,n,o="text/plain; charset=utf-8"){t.write(r,n);let s=e(r)??{key:r};return s.contentType=o,s.updatedAt=s.updatedAt??yr(),s.size=s.size??kr(n),s},putBytes(r,n,o="application/octet-stream"){if(t.writeBytes)t.writeBytes(r,n);else {let i=JSON.stringify({__kind:"bytes-array",data:[...n]});t.write(r,i);}let s=e(r)??{key:r};return s.contentType=o,s.updatedAt=s.updatedAt??yr(),s.size=s.size??n.byteLength,s},getText(r){let n=t.read(r);if(n===null){if(!t.readBytes)return null;let o=t.readBytes(r);return o===null?null:Buffer.from(o).toString("utf-8")}try{let o=JSON.parse(n);if(o&&o.__kind==="bytes-array"&&Array.isArray(o.data))return new TextDecoder("utf-8").decode(new Uint8Array(o.data))}catch{}return n},getBytes(r){if(t.readBytes){let o=t.readBytes(r);if(o!==null)return o}let n=t.read(r);if(n===null)return null;try{let o=JSON.parse(n);if(o&&o.__kind==="bytes-array"&&Array.isArray(o.data))return new Uint8Array(o.data)}catch{}return new TextEncoder().encode(n)},head:e,list(r=""){return t.listKeys(r).map(n=>e(n)??{key:n}).sort((n,o)=>n.key.localeCompare(o.key))},remove(r){t.remove(r);}}}function Cr(t){function e(o,s){let i=0,a=[];Array.isArray(s)&&a.push(...s);for(let c of t.list(`${o}/`))a.push(Tn(c.key));for(let c of a){let f=wn(c);Number.isFinite(f)&&f>i&&(i=f);}return i+1}function r(o,s,i){let a=Number(i?.maxLen||32),{stem:c,ext:f}=xn(o),p=_n(f),g=An(c),l=`${String(s).padStart(3,"0")}-`,h=p,y=a-l.length-h.length;y<1&&(h="",y=a-l.length);let k=g.slice(0,Math.max(1,y)),T=`${l}${k}${h}`;return T.length>a&&(T=T.slice(0,a).replace(/\.$/,"")),T}function n(o,s,i){let a=e(o,i?.seedNames),c=r(s,a,{maxLen:i?.maxLen});for(;t.exists(`${o}/${c}`);)a+=1,c=r(s,a,{maxLen:i?.maxLen});return c}return {nextSerial:e,buildStoredName:r,allocateStoredName:n}}function br(){function t(o,s){if(!Array.isArray(o))return [];let i=[];for(let a of o){if(!a||typeof a!="object")continue;let c=a;typeof c.stored_name=="string"&&i.push({name:typeof c.name=="string"?c.name:c.stored_name,stored_name:c.stored_name,size:typeof c.size=="number"&&Number.isFinite(c.size)?c.size:null,mime_type:typeof c.mime_type=="string"?c.mime_type:null,path:typeof c.path=="string"?c.path:null,uploaded_at:typeof c.uploaded_at=="string"?c.uploaded_at:s||null});}return i}function e(o){return !o||typeof o!="object"?[]:t(o.files,void 0)}function r(o,s){let i=e(o);if(s.length===0)return o.files=i,i;let a=new Set(i.map(c=>c.stored_name));for(let c of s)a.has(c.stored_name)||(i.push(c),a.add(c.stored_name));return o.files=i,i}function n(o,s,i){let a=e(o);if(!Number.isInteger(s)||s<0||s>=a.length)return {ok:false,reason:"index_out_of_range"};let c=a[s];return !c||!c.stored_name?{ok:false,reason:"missing_stored_name"}:i&&i!==c.stored_name?{ok:false,reason:"stale_reference"}:{ok:true,file:c}}return {read:e,normalizeIncoming:t,merge:r,resolve:n}}function Rr(t){return String(t).replace(/[^a-zA-Z0-9_-]/g,"_")}function wr(t){let e=t.payload??{};return {id:t.id,role:typeof e.role=="string"?e.role:"system",text:typeof e.text=="string"?e.text:"",files:Array.isArray(e.files)?e.files:[],updated_at:typeof e.updated_at=="string"?e.updated_at:""}}function vr(t,e){let r=o=>`chats/${Rr(o)}/processing`,n=o=>`chats/${Rr(o)}/config`;return {append(o,s,i,a=[]){return t(o).append({role:s,text:i,files:a,updated_at:new Date().toISOString()}).id},readAll(o){return t(o).readAll().map(wr)},readAfter(o,s){let i=t(o).readAfter(s);return {records:i.entries.map(wr),cursor:i.newCursor}},clear(o){t(o).clear?.();},setProcessing(o,s){s?e.write(r(o),true):e.delete(r(o));},isProcessing(o){return e.read(r(o))===true},getConfig(o){return e.read(n(o))??{}},setConfig(o,s){let i=e.read(n(o))??{};e.write(n(o),{...i,...s});}}}function In(){let t=globalThis.crypto;return typeof t?.randomUUID=="function"?String(t.randomUUID()):`id-${Date.now()}-${Math.random().toString(36).slice(2)}`}function Ar(){let t=new Map,e=new Map;function r(n){return t.has(n)||t.set(n,[]),t.get(n)}return {append(n,o,s,i=[]){let a={id:In(),role:o,text:s,files:i,updated_at:new Date().toISOString()};return r(n).push(a),a.id},readAll(n){return r(n).slice()},readAfter(n,o){let s=r(n);if(!o)return {records:s.slice(),cursor:s.length>0?s[s.length-1].id:null};let i=s.findIndex(c=>c.id===o),a=i===-1?s.slice():s.slice(i+1);return {records:a,cursor:a.length>0?a[a.length-1].id:o}},clear(n){t.set(n,[]);},setProcessing(n,o){o?e.set(`p:${n}`,true):e.delete(`p:${n}`);},isProcessing(n){return e.get(`p:${n}`)===true},getConfig(n){return e.get(`c:${n}`)??{}},setConfig(n,o){let s=e.get(`c:${n}`)??{};e.set(`c:${n}`,{...s,...o});}}}function _r(t){function e(a){return {status:"success",data:a}}function r(a){return {status:"fail",error:a}}function n(a){return {status:"error",error:a instanceof Error?a.message:String(a)}}function o(a,c="command envelope"){let f=typeof a.cardId=="string"?a.cardId:void 0;if(!a.command)return r(`chat-store: ${c} missing "command"`);if(!f)return r(`chat-store: ${c} missing "cardId"`);if(a.command==="append")return i.append({params:{cardId:f},body:{role:a.role,text:a.text,files:a.files}});if(a.command==="read-all")return i.readAll({params:{cardId:f}});if(a.command==="read-after")return i.readAfter({params:{cardId:f},body:{cursor:a.cursor??null}});if(a.command==="clear")return i.clear({params:{cardId:f}});if(a.command==="set-processing")return i.setProcessing({params:{cardId:f},body:{active:a.active}});if(a.command==="is-processing")return i.isProcessing({params:{cardId:f}});if(a.command==="get-config")return i.getConfig({params:{cardId:f}});if(a.command==="set-config"){let{command:p,cardId:g,...l}=a;return i.setConfig({params:{cardId:f},body:l})}return r(`chat-store: unknown command "${String(a.command)}"`)}function s(a){if(!Array.isArray(a.commands)||a.commands.length===0)return r('chat-store: command envelope must include a non-empty "commands" array');let c=[];for(let f=0;f<a.commands.length;f+=1){let p=a.commands[f];if(!p||typeof p!="object"||Array.isArray(p))return r(`chat-store: command envelope entry ${f} must be an object`);let g={cardId:a.cardId,...p},l=o(g,`command envelope entry ${f}`);if(l.status!=="success")return l;c.push({index:f,command:String(g.command),data:l.data});}return e({results:c})}let i={append(a){try{let c=a.params?.cardId;if(!c)return r("append requires params.cardId");let f=a.body??{},p=typeof f.role=="string"?f.role:"",g=typeof f.text=="string"?f.text:"",l=Array.isArray(f.files)?f.files:[];if(!p)return r("append requires body.role");let h=t.append(c,p,g,l);return e({id:h})}catch(c){return n(c)}},readAll(a){try{let c=a.params?.cardId;return c?e({records:t.readAll(c)}):r("readAll requires params.cardId")}catch(c){return n(c)}},readAfter(a){try{let c=a.params?.cardId;if(!c)return r("readAfter requires params.cardId");let p=(a.body??{}).cursor??null;return e(t.readAfter(c,p))}catch(c){return n(c)}},clear(a){try{let c=a.params?.cardId;return c?(t.clear(c),e({ok:!0})):r("clear requires params.cardId")}catch(c){return n(c)}},setProcessing(a){try{let c=a.params?.cardId;if(!c)return r("setProcessing requires params.cardId");let f=a.body??{};return typeof f.active!="boolean"?r("setProcessing requires body.active (boolean)"):(t.setProcessing(c,f.active),e({ok:!0}))}catch(c){return n(c)}},isProcessing(a){try{let c=a.params?.cardId;return c?e({active:t.isProcessing(c)}):r("isProcessing requires params.cardId")}catch(c){return n(c)}},getConfig(a){try{let c=a.params?.cardId;return c?e({config:t.getConfig(c)}):r("getConfig requires params.cardId")}catch(c){return n(c)}},setConfig(a){try{let c=a.params?.cardId;if(!c)return r("setConfig requires params.cardId");let f=a.body??{};return t.setConfig(c,f),e({ok:!0})}catch(c){return n(c)}},run:o,runBatch:s};return i}var En={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},On=32;function Bn(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function xr(t){if(!t||typeof t!="object")return false;let e=t.summary;return !e||typeof e!="object"?false:Number(e.card_count||0)>0}function Tr(t,e){if(!e||typeof e!="object")return;let r=e;if(r.kind==="notification-batch"&&Array.isArray(r.notifications)){for(let n of r.notifications)Tr(t,n);return}r.kind==="status"&&xr(r.status)&&(t.status=r.status),r.kind==="computed_values"&&r.cardId&&(t.computedValues[r.cardId]=r.values),r.kind==="data_object"&&r.key&&(t.dataObjects[r.key]=r.payload),r.kind==="card_refreshed"&&r.cardId&&(t.cards[r.cardId]=r.card);}function Ir(t){let e=String(t.apiBasePath||"/api/board").replace(/\/$/,""),r={...En,...t.corsHeaders||{}},n=t.boardId||"",o=t.logger||{info:console.log,warn:console.warn,error:console.error},s=t.invocationAdapter,i=t.chatFlowRunner||null,a=t.chatStorage??Ar(),c=_r(a),f=t.notificationTransport||null,p=t.serverUrl||null,g=t.executionExtra||{},l=new Map,h=new Map,y=new Map,k=null;function T(u){let d=mr(u.baseRef,u.boardAdapter),m=u.boardAdapter.kvStorageForRef(u.cardStoreRef),R=hr(ae({readIndex:()=>m.read("_index"),writeIndex:j=>m.write("_index",j),readCard:j=>m.read(j),writeCard:(j,X)=>(m.write(j,X),j),cardExists:j=>m.read(j)!==null,defaultCardKey:j=>j},o.warn)),v=u.artifactsAdapter||u.boardAdapter,$=u.filesArtifactsStore??null,D=null;return {label:u.label,board:d,cardStore:R,get filesArtifacts(){return D??(D=$??Sr(v.blobStorage("files")))},boardAdapter:u.boardAdapter,cardStoreRef:u.cardStoreRef,outputsStoreRef:u.outputsStoreRef,scratchStoreRef:u.scratchStoreRef,archiveStoreRef:u.archiveStoreRef,notifyRef:u.notifyRef,taskExecutorRef:u.taskExecutorRef,chatHandlerRef:u.chatHandlerRef,chatHandlerFlow:u.chatHandlerFlow,inferenceAdapterRef:u.inferenceAdapterRef,notification:Bn(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let I=t.boards.map(T),b=new Map;function w(u){return b.get(u)??0}function N(u){let d=I[w(u)];return {files:d?d.filesArtifacts:null}}function U(u){let d=N(u);return d.files?Cr(d.files):null}function x(){return br()}function _(u){return String(u||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function B(u){if(!u||u.notificationTeardown||!f||!u.notifyRef)return;let d=await f.subscribe(u.notifyRef,m=>{Tr(u.notification,m);let C=m.kind==="notification-batch"?m.notifications:[m];E(C);});u.notificationTeardown=d;}async function L(u){if(!u||u.initialized)return;let d={cardStoreRef:u.cardStoreRef,outputsStoreRef:u.outputsStoreRef};u.scratchStoreRef&&(d.scratchStoreRef=u.scratchStoreRef),u.archiveStoreRef&&(d.archiveStoreRef=u.archiveStoreRef);let m={};u.taskExecutorRef&&(m["task-executor-ref"]=u.taskExecutorRef),u.chatHandlerFlow!==void 0&&(m["chat-handler-flow"]=u.chatHandlerFlow),u.inferenceAdapterRef&&(m["inference-adapter-ref"]=u.inferenceAdapterRef);let C=u.board.init({params:d,body:m});if(C.status!=="success")throw Object.assign(new Error(C.error||`init failed for ${u.label}`),{statusCode:500});if(await B(u),!u.chatHandlerFlow&&u.chatHandlerRef&&s.describe)try{let R=await s.describe(u.chatHandlerRef);R&&R.kind!=="chat-handler"?o.warn(`[init] chat-handler describe returned kind="${R.kind}", expected "chat-handler" for ${u.label}`):R&&o.info(`[init] chat-handler validated: ${R.name} (protocol ${R.protocolVersion}) for ${u.label}`);}catch(R){o.warn(`[init] chat-handler describe failed for ${u.label}: ${R?.message||String(R)}`);}u.initialized=true;}function J(u){if(!u.boardAdapter.publishBoardChangeNotifications)return;let d=[],m=u.board.status({});m.status==="success"&&m.data!=null&&xr(m.data)&&d.push({kind:"status",status:m.data});let C=u.board.getAllOutputsDataObjects({});if(C.status==="success"&&C.data!=null)for(let[v,$]of Object.entries(C.data))v&&d.push({kind:"data_object",key:v,payload:$});let R=u.board.getAllOutputsComputedValues({});if(R.status==="success"&&R.data!=null)for(let[v,$]of Object.entries(R.data))v&&d.push({kind:"computed_values",cardId:v,values:$});d.length>0&&u.boardAdapter.publishBoardChangeNotifications(d);}function z(u,d){if(!u||u.cardsBootstrapped)return;let m=u.cardStore.get({}),C=m.status==="success"&&Array.isArray(m.data?.cards)?m.data.cards:[];for(let R of C)typeof R.id=="string"&&(b.set(R.id,d),u.board.upsertCard({params:{cardId:R.id}}));u.cardsBootstrapped=true;}async function st(){for(let u of I)await L(u);}async function Q(){await st();for(let u=0;u<I.length;u++)J(I[u]),z(I[u],u);}function _t(u){return I[w(u)]??null}function xt(u){let d=_t(u);if(!d)return null;let m=d.cardStore.get({params:{id:u}});if(m.status!=="success")return null;let C=Array.isArray(m.data?.cards)?m.data.cards:[];return C.length>0?C[0]:null}function Bt(){let u=m=>{if(!m||!m.cardStore)return [];let C=m.cardStore.get({});return C.status!=="success"||!Array.isArray(C.data?.cards)?[]:C.data.cards},d=[];for(let m of I)d.push(...u(m));return d}function Yt(){let u=I.map(v=>{try{let D=v.boardAdapter.kvStorageForRef(v.outputsStoreRef).read("status");if(D!=null)return D}catch{}return v.notification.status}).filter(Boolean);if(u.length===0)return null;if(u.length===1)return u[0];let d=[],m=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],C={};for(let v of m)C[v]=0;for(let v of u){let $=v,D=Array.isArray($.cards)?$.cards:[];d.push(...D);for(let j of m)C[j]+=Number($?.summary?.[j]||0);}let R=u[0];return {...R,cards:d,summary:{...R.summary||{},card_count:d.length,...C}}}function P(){let u={},d=m=>{for(let[C,R]of Object.entries(m.notification.computedValues)){let v=m.notification.cards[C];u[C]={schema_version:"v1",card_id:C,card_data:v?.card_data??{},computed_values:R??{}};}};for(let m of I)d(m);return u}function M(){let u={};for(let d of I)Object.assign(u,d.notification.dataObjects||{});return u}function W(){let u=Bt(),d=P(),m=M(),C={};for(let v of u){if(!v?.id)continue;let $=v.id,D=d[$]||{},j={...D.card_data&&typeof D.card_data=="object"?D.card_data:v.card_data&&typeof v.card_data=="object"?v.card_data:{}};C[$]={schema_version:D.schema_version||"v1",card_id:D.card_id||$,card_data:j,computed_values:D.computed_values&&typeof D.computed_values=="object"?D.computed_values:{}};}let R={};for(let v of u){if(!v?.id)continue;let $=v.id;try{let D=H($),j=a.isProcessing($);(D.length>0||j)&&(R[$]={messages:D.map(X=>({role:String(X.role||"system"),text:String(X.text||""),files:Array.isArray(X.files)?X.files:[]})),receiving:!1,processing:j});}catch{}}return {boardId:n,cardDefinitions:u,statusSnapshot:Yt(),dataObjectsByToken:m,cardRuntimeById:C,cardChatsByCardId:R}}function nt(u,d,m){let C=m?.syncBoard!==false,R=_t(u);if(!R)throw Object.assign(new Error(`Card not found: ${u}`),{statusCode:404});let v=xt(u);if(!v)throw Object.assign(new Error(`Card not found: ${u}`),{statusCode:404});let $=d(v)||v,D=R.cardStore.set({body:$});if(D.status!=="success")throw Object.assign(new Error(D.error||`Failed to persist card: ${u}`),{statusCode:500});if(C){let j=R.board.upsertCard({params:{cardId:u,restart:true}});if(j.status!=="success")throw Object.assign(new Error(j.error||`Failed to upsert card: ${u}`),{statusCode:500})}}function gt(u,d){nt(u,d,{syncBoard:true});}function A(u,d){nt(u,d,{syncBoard:false});}function S(u,d){gt(u,m=>{if(!d||typeof d!="object"||Object.keys(d).length===0)return m;function C(R,v,$){let D=String(v||"").split(".").filter(Boolean);if(!D.length)return;let j=R;for(let X=0;X<D.length-1;X++){let et=D[X];(!j[et]||typeof j[et]!="object")&&(j[et]={}),j=j[et];}j[D[D.length-1]]=$;}if(d.fieldValues!==void 0&&d.fieldValues!==null){let R=null,v=m.view;if(v&&Array.isArray(v.elements)){for(let $ of v.elements)if($?.data&&$.data.writeTo){R=$.data.writeTo;break}}R?C(m,R,d.fieldValues):typeof d.fieldValues=="object"&&!Array.isArray(d.fieldValues)&&(m.card_data={...m.card_data||{},...d.fieldValues});}else {if(Array.isArray(d._stagedFiles)&&d._stagedFiles.length>0)return m;for(let[R,v]of Object.entries(d))R!=="_stagedFiles"&&(v!==null&&typeof v=="object"&&!Array.isArray(v)&&m[R]!==null&&typeof m[R]=="object"&&!Array.isArray(m[R])?m[R]={...m[R],...v}:m[R]=v);}return m});}function O(u){let d=String(u||"").trim();if(!d)return "upload.bin";let m=Math.max(d.lastIndexOf("/"),d.lastIndexOf("\\"));return (m>=0?d.slice(m+1):d)||"upload.bin"}function q(u){a.clear(u),a.setProcessing(u,false);}function Z(u,d,m,C){let R=typeof m=="string"?m.trim():"";return a.append(u,d,R,C)}function H(u){return a.readAll(u)}function dt(u){let d=[];try{let m=xt(u);if(!m)return d;let C=x().read(m.card_data&&typeof m.card_data=="object"?m.card_data:null);for(let R of C)d.push(R.stored_name);}catch{}return d}function ct(u,d,m,C){let R=_(u),v=N(u),$=O(d),D=U(u),j=D?D.allocateStoredName(R,$,{seedNames:dt(u),maxLen:On}):`${String(Date.now())}-${$}`;return v.files&&v.files.putBytes(`${R}/${j}`,new Uint8Array(C),m||"application/octet-stream"),{name:$,stored_name:j,size:C.length,mime_type:m||"application/octet-stream",path:`${u}/files/${j}`,uploaded_at:new Date().toISOString()}}function Ct(u){let d=_t(u);if(!d)return null;let m=d.board.getConfig({params:{key:"chat-handler-flow"}}),C=m.status==="success"?m.data?.value:null,R=d.chatHandlerRef;return C==null&&(!R||typeof R!="object")?null:{ctx:d,handlerFlow:C,handlerRef:R}}function lt(u,d,m=false){let C=Ct(u);if(!C)return;let{ctx:R,handlerFlow:v,handlerRef:$}=C;if(!m)try{a.setProcessing(u,!0);}catch{}let D={boardId:n,cardId:String(u),lastChatEntryId:d,...g,...p?{serverUrl:p}:{}};if(!i&&v!=null){try{a.setProcessing(u,!1);}catch{}o.warn(`[chat-handler-flow] configured for card "${u}" but no chatFlowRunner was provided`);return}if(v!=null){let X=i;if(!X)return;X.run(v,D,{boardId:n,cardId:String(u),label:R.label,logger:o,serverUrl:p,executionExtra:g}).then(et=>{if(et.dispatched)o.info(`[chat-handler-flow] invoked for card "${u}" (boardId: "${n}")`);else {try{a.setProcessing(u,!1);}catch{}o.warn(`[chat-handler-flow] dispatch failed for card "${u}": ${et.error||"unknown"}`);}},et=>{try{a.setProcessing(u,!1);}catch{}o.warn(`[chat-handler-flow] invoke failed for card "${u}": ${et?.message||String(et)}`);});return}let j=$;j&&s.invoke(j,D).then(X=>{if(X.dispatched)o.info(`[chat-handler] invoked for card "${u}" (boardId: "${n}")`);else {try{a.setProcessing(u,!1);}catch{}o.warn(`[chat-handler] dispatch failed for card "${u}": ${X.error||"unknown"}`);}},X=>{try{a.setProcessing(u,!1);}catch{}o.warn(`[chat-handler] invoke failed for card "${u}": ${X?.message||String(X)}`);});}function vt(u,d,m){let C=d==="chat-send"?A:gt,R;C(u,v=>{let $=new Date().toISOString(),D=v.card_data&&typeof v.card_data=="object"?v.card_data:{};if(v.card_data=D,d==="chat-send"){let j=m&&typeof m.text=="string"?m.text.trim():"",X=[];if(Array.isArray(m?.files)){for(let et of m.files)if(et){if(typeof et=="string"){X.push({name:et});continue}if(typeof et=="object"){let ft=et;typeof ft.name=="string"&&X.push({name:ft.name,size:ft.size,mime_type:ft.mime_type,path:ft.path,uploaded_at:ft.uploaded_at,stored_name:ft.stored_name});}}}if(j||X.length>0){let et=c.runBatch({cardId:u,commands:[{command:"append",role:"user",text:j,files:X},{command:"set-processing",active:true}]});if(et.status!=="success")throw new Error(et.error);let ft=et.data.results[0]?.data?.id;if(typeof ft!="string"||!ft)throw new Error(`chat-send did not return an append id for card ${u}`);R={cardId:u,lastEntryId:ft,processingAlreadySet:true};for(let G of X){if(!G||typeof G!="object")continue;let Y=typeof G.name=="string"?G.name:"file",ht=typeof G.stored_name=="string"?G.stored_name:null;ht&&Z(u,"system",`File ${Y} uploaded as ${ht}.`,[]);}try{let G=H(u);E([{kind:"card_chats",cardId:u,messages:G.map(Y=>({role:String(Y.role||"system"),text:String(Y.text||""),files:Array.isArray(Y.files)?Y.files:[]})),receiving:!0,processing:a.isProcessing(u)}]);}catch{}}return v}if(d==="file-upload"){let j=x().normalizeIncoming(m?.files,$);return j.length>0&&x().merge(D,j),v}if(d==="action"){let j=m&&typeof m.buttonId=="string"?m.buttonId:"";if(!j)return v;D.lastAction={buttonId:j,at:$},D.lastActionText=`${j} @ ${$}`;}return v}),R&<(R.cardId,R.lastEntryId,R.processingAlreadySet);}function K(u,d,m){let C=JSON.stringify(m),R=typeof Buffer<"u"?Buffer.byteLength(C):new TextEncoder().encode(C).length;u.writeHead(d,{...r,"Content-Type":"application/json; charset=utf-8","Content-Length":R}),u.end(C);}async function mt(u){let d=[];for await(let C of u)d.push(C);let m=typeof Buffer<"u"?Buffer.concat(d).toString("utf-8").trim():new TextDecoder().decode(wt(d)).trim();return m?JSON.parse(m):{}}async function Tt(u){let d=[];for await(let m of u)d.push(m);return typeof Buffer<"u"?Buffer.concat(d):wt(d)}function wt(u){let d=u.reduce((R,v)=>R+v.length,0),m=new Uint8Array(d),C=0;for(let R of u)m.set(R,C),C+=R.length;return m}let Dt=0;function Lt(u){let d=JSON.stringify(u);return Dt++,`id: ${Dt}
|
|
2
2
|
data: ${d}
|
|
3
3
|
|
|
4
|
-
`}function
|
|
4
|
+
`}function Ht(u){let d=u;try{d.flushHeaders?.();}catch{}try{d.flush?.();}catch{}try{d.socket?.setNoDelay?.(!0);}catch{}try{d.socket?.uncork?.();}catch{}}function Vt(u,d){let m=l.get(u);if(!m)return;let C=Lt(d);try{m.res.write(C),Ht(m.res);}catch{l.delete(u);}}function qt(){let u=new Set;for(let d of l.values())for(let m of d.subscribedChatCardIds)u.add(m);return Array.from(u)}function Ee(u){let d=h.has(u)?h.get(u):null,{cursor:m}=a.readAfter(u,d),C=a.isProcessing(u),R=C!==(y.get(u)??false),v=m!==d;return v&&h.set(u,m),y.set(u,C),v||R}function he(u,d=true){let m=H(u),C=Date.now();return {kind:"card_chats",cardId:u,sentAt:new Date(C).toISOString(),sentAtMs:C,messages:m.map(R=>({role:String(R.role||"system"),text:String(R.text||""),files:Array.isArray(R.files)?R.files:[]})),receiving:d,processing:a.isProcessing(u)}}function It(u,d=true){let m={kind:"notification-batch",notifications:[he(u,d)]};for(let[C,R]of l.entries())R.subscribedChatCardIds.has(u)&&Vt(C,m);}function Pt(){qt().length>0||(k&&(clearInterval(k),k=null),h.clear(),y.clear());}function ye(){if(k)return;let u=()=>{let d=qt();if(d.length===0){Pt();return}let m=new Set(d);for(let C of Array.from(h.keys()))m.has(C)||h.delete(C);for(let C of Array.from(y.keys()))m.has(C)||y.delete(C);for(let C of d)Ee(C)&&It(C,true);};u(),k=setInterval(u,1e3);}function Mt(u,d){let m=l.get(u);if(!m)return false;m.subscribedChatCardIds.add(d);let{cursor:C}=a.readAfter(d,null);return h.set(d,C),y.set(d,a.isProcessing(d)),ye(),Vt(u,{kind:"notification-batch",notifications:[he(d,true)]}),true}function jt(u,d){let m=l.get(u);return m?(m.subscribedChatCardIds.delete(d),qt().includes(d)||(h.delete(d),y.delete(d)),Pt(),true):false}function ke(u){if(!u||typeof u!="object")return false;let d=u.kind;return d==="card_chats"||d==="chat_messages"}function E(u){if(!u||u.length===0)return;let d=[],m=new Set;for(let C of u)ke(C)&&typeof C.cardId=="string"?m.add(String(C.cardId)):d.push(C);if(d.length>0){let C={kind:"notification-batch",notifications:d};for(let R of l.keys())Vt(R,C);}for(let C of m)It(C,true);}function F(u,d,m){let C=l.get(m),R=C?new Set(C.subscribedChatCardIds):new Set;if(C)try{C.res.end();}catch{}d.writeHead(200,{...r,"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}),Ht(d),l.set(m,{res:d,subscribedChatCardIds:R});let v=W(),$=Lt(v);d.write($);let D=setInterval(()=>{try{d.write(`: keepalive
|
|
5
5
|
|
|
6
|
-
`);}catch{}},15e3);u.on("close",()=>{clearInterval(D),l.get(m)?.res===d&&(l.delete(m),
|
|
7
|
-
${new Date().toISOString()}`);}catch{}function i(){let g=globalThis.localStorage.getItem(r);if(g===null)return {};try{let l=JSON.parse(g);return l&&typeof l=="object"&&!Array.isArray(l)?l:{}}catch{return {}}}function a(g){try{globalThis.localStorage.setItem(r,JSON.stringify(g));}catch{}}if(s){let g=i();typeof g["retention.lastSweepAt"]!="number"&&(g["retention.lastSweepAt"]=Date.now(),a(g));}function c(){if(globalThis.localStorage.getItem(e)===null)return;let g=i(),l=typeof g["retention.maxAgeMs"]=="number"?g["retention.maxAgeMs"]:Nn,h=typeof g["retention.sweepIntervalMs"]=="number"?g["retention.sweepIntervalMs"]:Fn;if(l<=0||h<=0)return;let y=typeof g["retention.lastSweepAt"]=="number"?g["retention.lastSweepAt"]:0,
|
|
8
|
-
${new Date().toISOString()}`);}catch{}function o(){let a=globalThis.localStorage.getItem(r);if(a===null)return {};try{let c=JSON.parse(a);return c&&typeof c=="object"&&!Array.isArray(c)?c:{}}catch{return {}}}function s(a){try{globalThis.localStorage.setItem(r,JSON.stringify(a));}catch{}}function i(){if(globalThis.localStorage.getItem(e)===null)return;let a=o(),c=typeof a["retention.maxAgeMs"]=="number"?a["retention.maxAgeMs"]:0,f=typeof a["retention.sweepIntervalMs"]=="number"?a["retention.sweepIntervalMs"]:0;if(c<=0||f<=0)return;let p=typeof a["retention.lastSweepAt"]=="number"?a["retention.lastSweepAt"]:0,g=Date.now();if(g-p<f)return;a["retention.lastSweepAt"]=g,s(a);let l=`${t}${_e}`;for(let h=0;h<globalThis.localStorage.length;h++){let y=globalThis.localStorage.key(h);if(!y||!y.startsWith(l))continue;let S=globalThis.localStorage.getItem(y);if(S)try{let T=JSON.parse(S),I=T.filter(b=>typeof b.__ts!="number"||g-b.__ts<=c);I.length!==T.length&&globalThis.localStorage.setItem(y,JSON.stringify(I));}catch{}}}return {stream(a){let c=Br(a),f=n(c);function p(){let l=globalThis.localStorage.getItem(f);if(!l)return [];try{return JSON.parse(l)}catch{return []}}function g(l){try{globalThis.localStorage.setItem(f,JSON.stringify(l));}catch{}}return {append(l){let h={id:globalThis.crypto.randomUUID(),payload:l,__ts:Date.now()},y=p();y.push(h),g(y);try{i();}catch{}return {id:h.id,payload:h.payload}},readAll(){return p().map(l=>({id:l.id,payload:l.payload}))},readAfter(l){let h=p();if(!l){let I=h.map(b=>({id:b.id,payload:b.payload}));return {entries:I,newCursor:I.length>0?I[I.length-1].id:null}}let y=h.findIndex(I=>I.id===l),T=(y===-1?h:h.slice(y+1)).map(I=>({id:I.id,payload:I.payload}));return {entries:T,newCursor:T.length>0?T[T.length-1].id:l}},clear(){try{globalThis.localStorage.removeItem(f);}catch{}}}},blob(a){let c=Br(a),f=pe(`${t}${Or}${c}`);return {read:p=>f.read(p),write:(p,g)=>{f.write(p,g);try{i();}catch{}},exists:p=>f.exists(p),remove:p=>f.remove(p),readBytes:f.readBytes?p=>f.readBytes(p):void 0,writeBytes:f.writeBytes?(p,g)=>{f.writeBytes(p,g);try{i();}catch{}}:void 0,listKeys:p=>f.listKeys(p),stat:f.stat?p=>f.stat(p):void 0}},listStreams(a){let c=`${t}${_e}`,f=[];for(let p=0;p<globalThis.localStorage.length;p++){let g=globalThis.localStorage.key(p);if(!g||!g.startsWith(c))continue;let l=g.slice(c.length);(!a||l.startsWith(a))&&f.push(l);}return f.sort()},listBlobs(a){let c=`${t}${Or}`,f=new Set;for(let p=0;p<globalThis.localStorage.length;p++){let g=globalThis.localStorage.key(p);if(!g||!g.startsWith(c))continue;let l=g.slice(c.length),h=l.indexOf(":"),y=h===-1?l:l.slice(0,h);(!a||y.startsWith(a))&&f.add(y);}return Array.from(f).sort()},config:{get(a){return o()[a]??null},set(a,c){let f=o();c==null?delete f[a]:f[a]=c,s(f);}}}}function me(t){function e(r){return `${t}:kv:${r}`}return {read(r){let n=globalThis.localStorage.getItem(e(r));if(n===null)return null;try{return JSON.parse(n)}catch{return null}},write(r,n){globalThis.localStorage.setItem(e(r),JSON.stringify(n));},delete(r){globalThis.localStorage.removeItem(e(r));},listKeys(r){let n=e(r??""),o=[];for(let s=0;s<globalThis.localStorage.length;s++){let i=globalThis.localStorage.key(s);i!==null&&i.startsWith(n)&&o.push(i.slice(e("").length));}return o}}}function $r(t){function e(){let n=globalThis.localStorage.getItem(t);if(!n)return [];try{return JSON.parse(n)}catch{return []}}function r(n){globalThis.localStorage.setItem(t,JSON.stringify(n));}return {readAllEntries(){return e()},appendEntry(n){let o=e();o.push(n),r(o);},generateId(){return globalThis.crypto.randomUUID()}}}function Pn(){let t=false;return {tryAcquire(){return t?null:(t=true,()=>{t=false;})}}}function Mn(t){return String(t).replace(/[^a-zA-Z0-9_-]/g,"_")}function Gn(t){function e(){let n=globalThis.localStorage.getItem(t);if(!n)return [];try{return JSON.parse(n)}catch{return []}}function r(n){globalThis.localStorage.setItem(t,JSON.stringify(n));}return {append(n){let o={id:globalThis.crypto.randomUUID(),payload:n},s=e();return s.push(o),r(s),o},readAll(){return e()},readAfter(n){let o=e();if(!n)return {entries:o,newCursor:o.length>0?o[o.length-1].id:null};let s=o.findIndex(a=>a.id===n),i=s===-1?o:o.slice(s+1);return {entries:i,newCursor:i.length>0?i[i.length-1].id:n}},clear(){globalThis.localStorage.removeItem(t);}}}function Fr(t){return vr(e=>Gn(`${t}:chat:journal:${Mn(e)}`),me(`${t}:chat`))}var Nr=new Map;function he(t){let e=Nr.get(t);if(!e){let r=new Set;e={publish(n){for(let o of r)o(n);},subscribe(n){return r.add(n),()=>{r.delete(n);}}},Nr.set(t,e);}return e}function Dr(){return {async subscribe(t,e){return t.kind!=="in-memory-bus"?(console.warn(`[in-memory-transport] unsupported kind: ${t.kind}`),()=>{}):he(t.value).subscribe(n=>{let o=n;if(o&&o.kind==="notification-batch"&&Array.isArray(o.notifications)){for(let s of o.notifications)e(s);return}e(n);})}}}function Lr(t,e){let r=e?.callbackBaseUrl?{meta:"board-live-cards",howToRun:"http:post",whatToRun:e.callbackBaseUrl}:{meta:"board-live-cards",howToRun:"in-browser",whatToRun:ot({kind:"in-browser",value:t})},n=new Map,o=new Map,s=Pn();return {kvStorage:i=>me(`${t}:${i}`),blobStorage:i=>pe(i?`${t}:${i}`:t),scratchStorage:()=>Te(`${t}:scratch`),scratchStorageForRef:i=>Te(St(i).value),archiveFactory:()=>Ie(`${t}:archive`),archiveFactoryForRef:i=>Ie(St(i).value),journalAdapter:()=>$r(`${t}:journal`),lock:s,selfRef:r,async dispatchExecution(i,a){if(i.howToRun==="http:post")try{let c=i.whatToRun,f=typeof c=="object"?c.value:St(c).value,p=await fetch(f,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(a)});return p.ok?{dispatched:!0}:{dispatched:!1,error:`HTTP ${p.status}: ${p.statusText}`}}catch(c){return {dispatched:false,error:c instanceof Error?c.message:String(c)}}if(i.howToRun==="http:get")try{let c=i.whatToRun,f=typeof c=="object"?c.value:St(c).value,p=new URLSearchParams(Object.entries(a).filter(([,h])=>h!=null).map(([h,y])=>[h,String(y)])),g=`${f}?${p.toString()}`,l=await fetch(g);return l.ok?{dispatched:!0}:{dispatched:!1,error:`HTTP ${l.status}: ${l.statusText}`}}catch(c){return {dispatched:false,error:c instanceof Error?c.message:String(c)}}if(i.howToRun==="in-browser"){let c=i.whatToRun,f=typeof c=="object"?c.value:St(c).value,p=n.get(f);return p?p(i,a):{dispatched:false,error:`No in-browser handler registered for: ${f}`}}return {dispatched:false,error:`Browser adapter: unsupported dispatch kind (got: ${i.howToRun})`}},resolveBlob(i){if(i.kind==="in-memory"){let f=o.get(i.value);if(f==null)throw new Error(`resolveBlob: in-memory blob not found: ${ot(i)}`);return f}let c=pe(t).read(i.value);if(c===null)throw new Error(`resolveBlob: blob not found: ${ot(i)}`);return c},hashFn:jr,genId:()=>globalThis.crypto.randomUUID().replace(/-/g,""),kvStorageForRef:i=>me(St(i).value),publishBoardChangeNotifications(i){if(!e?.notifyChannel||i.length===0)return;he(e.notifyChannel).publish({kind:"notification-batch",notifications:i});},onWarn:e?.onWarn,registerHandler(i,a){n.set(i,a);},writeMemoryBlob(i,a){return o.set(i,a),ot({kind:"in-memory",value:i})}}}function qr(t){return t==="running"||t==="in-progress"?"loading":t==="failed"?"error":"fresh"}function Un(t,e){let r=e&&typeof e=="object"&&!Array.isArray(e)?e:{};return {schema_version:r.schema_version||"v1",card_id:typeof r.card_id=="string"?r.card_id:t,card_data:r.card_data&&typeof r.card_data=="object"&&!Array.isArray(r.card_data)?structuredClone(r.card_data):{},computed_values:r.computed_values&&typeof r.computed_values=="object"&&!Array.isArray(r.computed_values)?structuredClone(r.computed_values):{}}}function Xt(t,e){if(!t||typeof t!="object")throw new Error("payload must be an object");if(!e)throw new Error("cardId is required");let n=(Array.isArray(t.cardDefinitions)?t.cardDefinitions:[]).find(_=>_.id===e);if(!n)throw new Error(`cardDefinitions has no entry with id ${e}`);let o=t.statusSnapshot&&typeof t.statusSnapshot=="object"?t.statusSnapshot:{},s=t.cardRuntimeById&&typeof t.cardRuntimeById=="object"?t.cardRuntimeById:{},i=t.dataObjectsByToken&&typeof t.dataObjectsByToken=="object"?t.dataObjectsByToken:{},c=(Array.isArray(o.cards)?o.cards:[]).find(_=>_.name===e),f=structuredClone(n),p=Un(e,s[e]),l={...f.card_data&&typeof f.card_data=="object"&&!Array.isArray(f.card_data)?f.card_data:{},...p.card_data||{},status:qr(c?.status),lastRun:c?.runtime?.last_transition_at??null};c?.error?.message&&(l.error=c.error.message);let h=c?{task_status:c.status??null,card_status:qr(c.status),runtime:structuredClone(c.runtime??{}),error:c.error?structuredClone(c.error):null,blocked_by:Array.isArray(c.blocked_by)?structuredClone(c.blocked_by):[],requires_missing:Array.isArray(c.requires_missing)?structuredClone(c.requires_missing):[]}:{task_status:null,card_status:l.status??"fresh",runtime:{last_transition_at:l.lastRun??null},error:l.error?{message:l.error}:null,blocked_by:[],requires_missing:[]},y=Array.isArray(f.requires)?f.requires:[],S={};for(let[_,F]of Object.entries(i))S[_]=structuredClone(F);for(let _ of y)Object.prototype.hasOwnProperty.call(S,_)||(S[_]=null);let I=(t.cardChatsByCardId&&typeof t.cardChatsByCardId=="object"?t.cardChatsByCardId:{})[e],b=I?{messages:Array.isArray(I.messages)?I.messages:[],receiving:!!I.receiving,processing:!!I.processing}:null;return {id:e,card:f,card_data:l,requires:S,computed_values:p.computed_values,runtime_state:h,card_chats:b}}function Jn(t){if(!t||typeof t!="object")throw new Error("payload must be an object");return (Array.isArray(t.cardDefinitions)?t.cardDefinitions:[]).map(r=>Xt(t,r.id))}function ye(t){return JSON.parse(JSON.stringify(t))}function Jt(t,e){if(t===e)return t;try{if(JSON.stringify(t)===JSON.stringify(e))return t}catch{}return e}function Ct(t,e){if(t===e)return true;try{return JSON.stringify(t)===JSON.stringify(e)}catch{return false}}function Hn(t){return t==="running"||t==="in-progress"?"loading":t==="failed"?"error":"fresh"}function Pr(t,e,r){let n=t,s=(n&&Array.isArray(n.cardDefinitions)?n.cardDefinitions:[]).map(c=>c.id),i=e&&e.modelsById||{},a={};for(let c of s){let f=r(t,c),p=i[c];if(!p){a[c]=f;continue}let g=f.card_chats!=null?Jt(p.card_chats,f.card_chats??null):p.card_chats??null,l={id:f.id,card:Jt(p.card,f.card),card_data:Jt(p.card_data,f.card_data),requires:Jt(p.requires,f.requires),computed_values:Jt(p.computed_values,f.computed_values),runtime_state:Jt(p.runtime_state,f.runtime_state),card_chats:g};a[c]=l.card===p.card&&l.card_data===p.card_data&&l.requires===p.requires&&l.computed_values===p.computed_values&&l.runtime_state===p.runtime_state&&l.card_chats===p.card_chats?p:l;}return {payload:t,cardIds:s,modelsById:a}}function Mr(t,e,r,n){if(!t||!Array.isArray(e)||e.length===0)return t;let o=t.modelsById,s=t.cardIds,i=false,a=false,c={};for(let p of s){let g=o[p],l=g&&g.requires;if(l&&typeof l=="object")for(let h of Object.keys(l))(c[h]=c[h]||[]).push(p);}function f(){i||(o={...o},i=true);}for(let p of e)if(!(!p||!p.kind)){if(p.kind==="computed_values"){let g=p.cardId,l=o[g];if(!l)continue;let h=p.values||{};if(Ct(l.computed_values,h))continue;f(),o[g]={...l,computed_values:h},a=true;}else if(p.kind==="data_object"){let g=p.key,l=p.payload,h=c[g]||[];for(let y of h){let S=o[y];if(!S)continue;let T=S.requires||{};Ct(T[g],l)||(f(),o[y]={...S,requires:{...T,[g]:l}},a=true);}}else if(p.kind==="card_refreshed"){let g=p.cardId,l=null,h=o[g],y=p.card;if(h&&y&&typeof y=="object"&&!Array.isArray(y)){let S=y,T=S.card_data&&typeof S.card_data=="object"&&!Array.isArray(S.card_data)?S.card_data:h.card_data,I=S.requires&&typeof S.requires=="object"&&!Array.isArray(S.requires)?S.requires:h.requires,b=S.computed_values&&typeof S.computed_values=="object"&&!Array.isArray(S.computed_values)?S.computed_values:h.computed_values,_=S.runtime_state&&typeof S.runtime_state=="object"&&!Array.isArray(S.runtime_state)?S.runtime_state:h.runtime_state;l={...h,card:y,card_data:T,requires:I,computed_values:b,runtime_state:_};}if(!l)try{let S=n();S&&(l=r(S,g));}catch{}if(!l||h&&Ct(h.card,l.card)&&Ct(h.card_data,l.card_data)&&Ct(h.requires,l.requires)&&Ct(h.computed_values,l.computed_values)&&Ct(h.runtime_state,l.runtime_state))continue;f(),o[g]=l,s.includes(g)||(s=[...s,g]),a=true;}else if(p.kind==="card_chats"){let g=p.cardId,l=o[g];if(!l)continue;let h=Array.isArray(p.messages)?p.messages:l.card_chats?.messages??[],y=typeof p.receiving=="boolean"?p.receiving:l.card_chats?.receiving??false,S=typeof p.processing=="boolean"?p.processing:l.card_chats?.processing??false,T={messages:h,receiving:y,processing:S};if(Ct(l.card_chats,T))continue;f(),o[g]={...l,card_chats:T},a=true;}else if(p.kind==="chat_messages"){let g=p.cardId,l=o[g];if(!l)continue;let h=Array.isArray(p.messages)?p.messages:[],y=l.card_chats||{receiving:false,processing:false},S={messages:h,receiving:y.receiving,processing:!!y.processing};if(Ct(l.card_chats,S))continue;f(),o[g]={...l,card_chats:S},a=true;}else if(p.kind==="status"){let g=p.status?.cards??[];for(let l of g){let h=l?.name;if(!h||!o[h])continue;let y=o[h],S=Hn(l.status),T={...y.card_data||{},status:S,lastRun:l.runtime?.last_transition_at??null,...l.error?.message?{error:l.error.message}:{}};l.error?.message||delete T.error;let I={task_status:l.status??null,card_status:S,runtime:l.runtime?ye(l.runtime):{},error:l.error?ye(l.error):null,blocked_by:Array.isArray(l.blocked_by)?ye(l.blocked_by):[],requires_missing:Array.isArray(l.requires_missing)?ye(l.requires_missing):[]};Ct(y.card_data,T)&&Ct(y.runtime_state,I)||(f(),o[h]={...y,card_data:T,runtime_state:I},a=true);}}}return a?{payload:t.payload,cardIds:s,modelsById:o}:t}function gs(t,e){let r=e?.cards??[],n=e?.onWarn??(()=>{}),o=`${t}:notify`,s=Lr(t,{callbackBaseUrl:e?.callbackBaseUrl,notifyChannel:o,onWarn:n}),i=St(ot({kind:"localstorage",value:t})),a=ot({kind:"localstorage",value:`${t}:card-store`}),c=ot({kind:"localstorage",value:`${t}:outputs`}),f=e?.taskExecutor??null,p=e?.chatHandler??null,g=ot({kind:"in-browser",value:`${t}:task-executor`}),l=ot({kind:"in-browser",value:`${t}:chat-handler`});f&&s.registerHandler(g,f),p&&s.registerHandler(l,p);let h={async invoke(x,A){return x.howToRun==="in-browser",s.dispatchExecution(x,A)}},y=e?.taskExecutorRef??(f?{meta:"task-executor",howToRun:"in-browser",whatToRun:g}:void 0),S=e?.chatHandlerRef??(p?{meta:"chat-handler",howToRun:"in-browser",whatToRun:l}:void 0),T=Dr(),I=Fr(t),b=Ir({boardId:t,chatStorage:I,boards:[{label:t,boardAdapter:s,baseRef:i,cardStoreRef:a,outputsStoreRef:c,notifyRef:{kind:"in-memory-bus",value:o},taskExecutorRef:y,chatHandlerRef:S}],invocationAdapter:h,notificationTransport:T,logger:{info:(...x)=>console.log("[board]",...x),warn:(...x)=>{n(String(x[0])),console.warn("[board]",...x);},error:(...x)=>console.error("[board]",...x)}});r.length&&b.cardStore.set({body:r}),e?.onBoardChange&&he(o).subscribe(A=>{let B=A;!B||B.kind!=="notification-batch"||!Array.isArray(B.notifications)||B.notifications.length===0||e.onBoardChange?.({notifications:B.notifications});});function _(x,A,B){let L=B?JSON.stringify(B):"",J=new TextEncoder().encode(L),V=false;return {method:x,url:A,headers:{"content-type":"application/json"},on(st,Z){},[Symbol.asyncIterator](){let st={async next(){return V?{done:true,value:void 0}:(V=true,{done:false,value:J})},[Symbol.asyncIterator](){return st}};return st}}}function F(){let x=200,A=[];return {res:{writeHead(L){x=L;},write(L){return A.push(typeof L=="string"?L:new TextDecoder().decode(L)),true},end(L){L&&A.push(typeof L=="string"?L:new TextDecoder().decode(L));}},getResult:()=>{let L=A.join(""),J;try{J=JSON.parse(L);}catch{J=L;}return {status:x,body:J}}}}let U=b.apiBasePath;return {async bootstrap(){let x=_("GET",`${U}/bootstrap`),{res:A}=F();await b.handleRuntimeApi(x,A,new URL(`http://localhost${U}/bootstrap`));},getState(){return b.buildPublishedRuntimePayload()},async patchCard(x,A){let B=`${U}/cards/${encodeURIComponent(x)}`,L=_("PATCH",B,A),{res:J}=F();await b.handleRuntimeApi(L,J,new URL(`http://localhost${B}`));},async applyCardAction(x,A,B){let L=`${U}/cards/${encodeURIComponent(x)}/actions`,J=_("POST",L,{actionType:A,payload:B}),{res:V}=F();await b.handleRuntimeApi(J,V,new URL(`http://localhost${L}`));},readChatRecords(x){let A=`${U}/cards/${encodeURIComponent(x)}/chats`,B=_("GET",A),L=F();b.handleRuntimeApi(B,L.res,new URL(`http://localhost${A}`));let V=L.getResult().body;return Array.isArray(V?.messages)?V.messages:[]},clearChatRecords(x){b.clearChatRecords(x);},writeMemoryBlob(x,A){return s.writeMemoryBlob(x,A)},reportSourceFetched(x,A){b.reportSourceFetched(x,A);},reportSourceFetchFailure(x,A){b.reportSourceFetchFailure(x,A);},get runtime(){return b}}}function hs(t,e){return Pr(t,e,Xt)}function ys(t,e,r){return Mr(t,e,Xt,r)}
|
|
6
|
+
`);}catch{}},15e3);u.on("close",()=>{clearInterval(D),l.get(m)?.res===d&&(l.delete(m),Pt());try{d.end();}catch{}});}async function tt(u,d,m){let C=u.method||"GET",R=m,v=R.pathname;try{if(C==="GET"&&v===`${e}/init-board`)return await st(),K(d,200,W()),!0;if(C==="GET"&&v===`${e}/sse`){await st();let V=String(R.searchParams.get("clientId")||"").trim();if(!V)return K(d,400,{error:"clientId query param is required for SSE"}),!0;F(u,d,V);for(let G=0;G<I.length;G++)J(I[G]),z(I[G],G);return !0}if(C==="GET"&&v===`${e}/board-status`)return K(d,200,W()),!0;let $=v.match(new RegExp(`^${Ft(e)}/cards/([^/]+)$`));if(C==="GET"&&$){await Q();let V=decodeURIComponent($[1]),G=xt(V);return G?(K(d,200,G),!0):(K(d,404,{error:`card not found: ${V}`}),!0)}if(C==="PATCH"&&$){await Q();let V=decodeURIComponent($[1]),G=await mt(u);return S(V,G),K(d,200,{ok:!0}),!0}let D=v.match(new RegExp(`^${Ft(e)}/cards/([^/]+)/actions$`));if(C==="POST"&&D){await Q();let V=decodeURIComponent(D[1]),G=Date.now(),Y=new Date(G).toISOString(),ht=await mt(u),yt=ht?.actionType;if(yt==="chat-send"&&!Ct(V)){let At=Date.now();return K(d,409,{error:`chat handler is not configured for card: ${V}`,requestReceivedAt:Y,requestReceivedAtMs:G,responseSentAt:new Date(At).toISOString(),responseSentAtMs:At,responseStatus:409}),!0}vt(V,yt,ht?.payload);let kt=Date.now();return K(d,200,{ok:!0,requestReceivedAt:Y,requestReceivedAtMs:G,responseSentAt:new Date(kt).toISOString(),responseSentAtMs:kt,responseStatus:200}),!0}let j=v.match(new RegExp(`^${Ft(e)}/cards/([^/]+)/chats$`));if(C==="GET"&&j){await Q();let V=decodeURIComponent(j[1]);return K(d,200,{ok:!0,messages:H(V)}),!0}if(C==="POST"&&j){await Q();let V=decodeURIComponent(j[1]),G=await mt(u),Y=typeof G?.role=="string"?G.role:"assistant",ht=typeof G?.text=="string"?G.text:"",yt=Array.isArray(G?.files)?G.files:[],kt=G?.done===!0,At=a.append(V,Y,ht,yt);return kt&&a.setProcessing(V,!1),It(V,!kt),K(d,200,{ok:!0,id:At}),!0}let X=v.match(new RegExp(`^${Ft(e)}/cards/([^/]+)/chats/subscribe-sse$`));if(C==="POST"&&X){await Q();let V=decodeURIComponent(X[1]),G=await mt(u),Y=typeof G?.clientId=="string"?G.clientId.trim():"";return Y?Mt(Y,V)?(K(d,200,{ok:!0,clientId:Y,cardId:V,subscribed:!0}),!0):(K(d,404,{error:`SSE client not connected: ${Y}`}),!0):(K(d,400,{error:"clientId is required"}),!0)}let et=v.match(new RegExp(`^${Ft(e)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(C==="POST"&&et){await Q();let V=decodeURIComponent(et[1]),G=await mt(u),Y=typeof G?.clientId=="string"?G.clientId.trim():"";return Y?jt(Y,V)?(K(d,200,{ok:!0,clientId:Y,cardId:V,subscribed:!1}),!0):(K(d,404,{error:`SSE client not connected: ${Y}`}),!0):(K(d,400,{error:"clientId is required"}),!0)}let ft=v.match(new RegExp(`^${Ft(e)}/cards/([^/]+)/files$`));if(C==="POST"&&ft){await Q();let V=decodeURIComponent(ft[1]),G=String(R.searchParams.get("inChat")||"").toLowerCase()==="true",Y=u.headers["x-file-name"],ht=String(u.headers["content-type"]||"application/octet-stream"),yt=Array.isArray(Y)?Y[0]:Y,kt=yt?decodeURIComponent(String(yt)):"upload.bin",At=await Tt(u);if(!At.length)return K(d,400,{error:"Empty upload body"}),!0;let St=ct(V,kt,ht,At);return A(V,$t=>{let Gt=new Date().toISOString(),Qt=$t.card_data&&typeof $t.card_data=="object"?$t.card_data:{};$t.card_data=Qt;let Se=x().normalizeIncoming([{name:St.name,stored_name:St.stored_name,size:St.size,mime_type:St.mime_type,path:St.path,uploaded_at:St.uploaded_at||Gt}],Gt);return x().merge(Qt,Se),$t}),G&&Z(V,"system",`file uploaded: ${St.name} as ${St.stored_name}`,[]),K(d,200,{ok:!0,file:St}),!0}let Zt=v.match(new RegExp(`^${Ft(e)}/cards/([^/]+)/files/(\\d+)$`));if(C==="GET"&&Zt){let V=decodeURIComponent(Zt[1]),G=parseInt(Zt[2],10),Y=R.searchParams.get("sn"),ht=xt(V);if(!ht)return K(d,404,{error:"Card not found"}),!0;let yt=x().resolve(ht.card_data,G,Y);if(!yt.ok&&yt.reason==="stale_reference")return K(d,409,{error:"File reference is stale. Refresh and try again."}),!0;if(!yt.ok)return K(d,404,{error:"File not found"}),!0;let kt=yt.file,At=_(V),St=N(V),$t=`${At}/${kt.stored_name}`,Gt=St.files?St.files.getBytes($t):null;if(!Gt)return K(d,404,{error:"File not found"}),!0;let Qt=kt.name||kt.stored_name,Se=kt.mime_type||"application/octet-stream";return d.writeHead(200,{"Content-Type":Se,"Content-Disposition":`attachment; filename="${Qt}"`,"Content-Length":Gt.length}),d.end(Gt),!0}return !1}catch($){let D=$?.statusCode||500;return K(d,D,{error:String($?.message||$)}),true}}return {get apiBasePath(){return e},get corsHeaders(){return r},handleRuntimeApi:tt,buildPublishedRuntimePayload:W,clearChatRecords:q,reportSourceFetched(u,d){let m=I[0];return m?m.board.sourceDataFetched({params:{token:u,ref:d}}):{status:"fail",error:"no board context"}},reportSourceFetchFailure(u,d){let m=I[0];return m?m.board.sourceDataFetchFailure({params:{token:u,reason:d}}):{status:"fail",error:"no board context"}},get cardStore(){return I[0]?.cardStore??{set(){return {status:"fail",error:"no board context"}}}}}}function Ft(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function xe(t){if(t==null||typeof t!="object")return JSON.stringify(t);if(Array.isArray(t))return `[${t.map(xe).join(",")}]`;let e=t;return `{${Object.keys(e).sort().map(n=>`${JSON.stringify(n)}:${xe(e[n])}`).join(",")}}`}function de(t,e){let r=e>>>0;for(let n=0;n<t.length;n++)r^=t.charCodeAt(n),r=Math.imul(r,16777619)>>>0;return r}function jr(t){let e=xe(t),r=de(e,2166136261),n=de(e,3735928559),o=de(e,19088743),s=de(e,4277009102);return [r,n,o,s].map(i=>i.toString(16).padStart(8,"0")).join("")}function fe(t){function e(s){return `${t}:blob:${s}`}let r=new TextEncoder;function n(s){if(typeof btoa=="function"){let i="";for(let a=0;a<s.length;a++)i+=String.fromCharCode(s[a]);return btoa(i)}return ""}function o(s){if(typeof atob=="function"){let i=atob(s),a=new Uint8Array(i.length);for(let c=0;c<i.length;c++)a[c]=i.charCodeAt(c);return a}return new Uint8Array}return {read(s){return globalThis.localStorage.getItem(e(s))},write(s,i){globalThis.localStorage.setItem(e(s),i);},exists(s){return globalThis.localStorage.getItem(e(s))!==null},remove(s){globalThis.localStorage.removeItem(e(s));},readBytes(s){let i=globalThis.localStorage.getItem(e(s));if(i===null)return null;try{let a=JSON.parse(i);if(a&&a.__kind==="bytes-b64"&&typeof a.data=="string")return o(a.data)}catch{}return r.encode(i)},writeBytes(s,i){let a=JSON.stringify({__kind:"bytes-b64",data:n(i)});globalThis.localStorage.setItem(e(s),a);},listKeys(s){let i=e(s??""),a=[];for(let c=0;c<globalThis.localStorage.length;c++){let f=globalThis.localStorage.key(c);f&&f.startsWith(i)&&a.push(f.slice(e("").length));}return a.sort()},stat(s){let i=globalThis.localStorage.getItem(e(s));if(i===null)return null;let a=r.encode(i).byteLength;try{let c=JSON.parse(i);c&&c.__kind==="bytes-b64"&&typeof c.data=="string"&&(a=o(c.data).byteLength);}catch{}return {key:s,size:a}}}}var jn=":scratch-marker",$n=":scratch-config",le=":scratch:",Nn=1440*60*1e3,Fn=720*60*1e3,Dn=200;function Er(t,e){if(!t)return e;let r=t.replace(/[^A-Za-z0-9._-]/g,"_");return r.length>0?r:e}function Te(t){let e=`${t}${jn}`,r=`${t}${$n}`,n=g=>`${t}${le}${g}`,o=g=>`${t}${le}${g}:__ts`,s=globalThis.localStorage.getItem(e)===null;if(s)try{globalThis.localStorage.setItem(e,`scratch-store
|
|
7
|
+
${new Date().toISOString()}`);}catch{}function i(){let g=globalThis.localStorage.getItem(r);if(g===null)return {};try{let l=JSON.parse(g);return l&&typeof l=="object"&&!Array.isArray(l)?l:{}}catch{return {}}}function a(g){try{globalThis.localStorage.setItem(r,JSON.stringify(g));}catch{}}if(s){let g=i();typeof g["retention.lastSweepAt"]!="number"&&(g["retention.lastSweepAt"]=Date.now(),a(g));}function c(){if(globalThis.localStorage.getItem(e)===null)return;let g=i(),l=typeof g["retention.maxAgeMs"]=="number"?g["retention.maxAgeMs"]:Nn,h=typeof g["retention.sweepIntervalMs"]=="number"?g["retention.sweepIntervalMs"]:Fn;if(l<=0||h<=0)return;let y=typeof g["retention.lastSweepAt"]=="number"?g["retention.lastSweepAt"]:0,k=Date.now();if(k-y<h)return;g["retention.lastSweepAt"]=k,a(g);let T=k,I=`${t}${le}`,b=[];for(let w=0;w<globalThis.localStorage.length;w++){let N=globalThis.localStorage.key(w);N&&N.startsWith(I)&&!N.endsWith(":__ts")&&b.push(N);}for(let w of b){if(Date.now()-T>Dn)break;let N=globalThis.localStorage.getItem(`${w}:__ts`),U=N===null?0:Number(N);if(Number.isFinite(U)&&U>0&&k-U>l){try{globalThis.localStorage.removeItem(w);}catch{}try{globalThis.localStorage.removeItem(`${w}:__ts`);}catch{}}}}function f(g,l){let h=Er(g,"scratch"),y=Er(l,".json"),k=y.startsWith(".")?y:`.${y}`,T=Math.random().toString(36).slice(2,10);return `${h}-${Date.now()}-${T}${k}`}function p(g,l){globalThis.localStorage.setItem(n(g),l),globalThis.localStorage.setItem(o(g),String(Date.now()));}return {read(g){return globalThis.localStorage.getItem(n(g))},write(g,l){p(g,l);try{c();}catch{}},exists(g){return globalThis.localStorage.getItem(n(g))!==null},remove(g){try{globalThis.localStorage.removeItem(n(g));}catch{}try{globalThis.localStorage.removeItem(o(g));}catch{}},readBytes(g){let l=globalThis.localStorage.getItem(n(g));return l===null?null:new TextEncoder().encode(l)},writeBytes(g,l){let h="";for(let y=0;y<l.length;y++)h+=String.fromCharCode(l[y]);p(g,h);try{c();}catch{}},stat(g){let l=globalThis.localStorage.getItem(n(g));if(l===null)return null;let h=globalThis.localStorage.getItem(o(g)),y=h===null?null:Number(h);return {key:g,size:new TextEncoder().encode(l).byteLength,updatedAt:y!==null&&Number.isFinite(y)?new Date(y).toISOString():void 0}},listKeys(g){let l=`${t}${le}`,h=[];for(let y=0;y<globalThis.localStorage.length;y++){let k=globalThis.localStorage.key(y);if(k&&k.startsWith(l)&&!k.endsWith(":__ts")){let T=k.slice(l.length);(!g||T.startsWith(g))&&h.push(T);}}return h.sort()},getUniqueKey(g,l){return f(g,l)},create(g,l,h){let y=f(l,h);p(y,g);try{c();}catch{}return y},keyRef(g){return {kind:"local-storage-scratch",value:g,extra:{prefix:t}}},config:{get(g){return i()[g]??null},set(g,l){let h=i();l==null?delete h[g]:h[g]=l,a(h);}}}}var Ln=":archive-marker",qn=":archive-config",_e=":archive:stream:",Or=":archive:blob:";function Br(t){let e=t.replace(/[^A-Za-z0-9._-]/g,"_");if(!e)throw new Error("Archive segment name cannot be empty after sanitization");return e}function Ie(t){let e=`${t}${Ln}`,r=`${t}${qn}`,n=a=>`${t}${_e}${a}`;if(globalThis.localStorage.getItem(e)===null)try{globalThis.localStorage.setItem(e,`archive-store
|
|
8
|
+
${new Date().toISOString()}`);}catch{}function o(){let a=globalThis.localStorage.getItem(r);if(a===null)return {};try{let c=JSON.parse(a);return c&&typeof c=="object"&&!Array.isArray(c)?c:{}}catch{return {}}}function s(a){try{globalThis.localStorage.setItem(r,JSON.stringify(a));}catch{}}function i(){if(globalThis.localStorage.getItem(e)===null)return;let a=o(),c=typeof a["retention.maxAgeMs"]=="number"?a["retention.maxAgeMs"]:0,f=typeof a["retention.sweepIntervalMs"]=="number"?a["retention.sweepIntervalMs"]:0;if(c<=0||f<=0)return;let p=typeof a["retention.lastSweepAt"]=="number"?a["retention.lastSweepAt"]:0,g=Date.now();if(g-p<f)return;a["retention.lastSweepAt"]=g,s(a);let l=`${t}${_e}`;for(let h=0;h<globalThis.localStorage.length;h++){let y=globalThis.localStorage.key(h);if(!y||!y.startsWith(l))continue;let k=globalThis.localStorage.getItem(y);if(k)try{let T=JSON.parse(k),I=T.filter(b=>typeof b.__ts!="number"||g-b.__ts<=c);I.length!==T.length&&globalThis.localStorage.setItem(y,JSON.stringify(I));}catch{}}}return {stream(a){let c=Br(a),f=n(c);function p(){let l=globalThis.localStorage.getItem(f);if(!l)return [];try{return JSON.parse(l)}catch{return []}}function g(l){try{globalThis.localStorage.setItem(f,JSON.stringify(l));}catch{}}return {append(l){let h={id:globalThis.crypto.randomUUID(),payload:l,__ts:Date.now()},y=p();y.push(h),g(y);try{i();}catch{}return {id:h.id,payload:h.payload}},readAll(){return p().map(l=>({id:l.id,payload:l.payload}))},readAfter(l){let h=p();if(!l){let I=h.map(b=>({id:b.id,payload:b.payload}));return {entries:I,newCursor:I.length>0?I[I.length-1].id:null}}let y=h.findIndex(I=>I.id===l),T=(y===-1?h:h.slice(y+1)).map(I=>({id:I.id,payload:I.payload}));return {entries:T,newCursor:T.length>0?T[T.length-1].id:l}},clear(){try{globalThis.localStorage.removeItem(f);}catch{}}}},blob(a){let c=Br(a),f=fe(`${t}${Or}${c}`);return {read:p=>f.read(p),write:(p,g)=>{f.write(p,g);try{i();}catch{}},exists:p=>f.exists(p),remove:p=>f.remove(p),readBytes:f.readBytes?p=>f.readBytes(p):void 0,writeBytes:f.writeBytes?(p,g)=>{f.writeBytes(p,g);try{i();}catch{}}:void 0,listKeys:p=>f.listKeys(p),stat:f.stat?p=>f.stat(p):void 0}},listStreams(a){let c=`${t}${_e}`,f=[];for(let p=0;p<globalThis.localStorage.length;p++){let g=globalThis.localStorage.key(p);if(!g||!g.startsWith(c))continue;let l=g.slice(c.length);(!a||l.startsWith(a))&&f.push(l);}return f.sort()},listBlobs(a){let c=`${t}${Or}`,f=new Set;for(let p=0;p<globalThis.localStorage.length;p++){let g=globalThis.localStorage.key(p);if(!g||!g.startsWith(c))continue;let l=g.slice(c.length),h=l.indexOf(":"),y=h===-1?l:l.slice(0,h);(!a||y.startsWith(a))&&f.add(y);}return Array.from(f).sort()},config:{get(a){return o()[a]??null},set(a,c){let f=o();c==null?delete f[a]:f[a]=c,s(f);}}}}function ge(t){function e(r){return `${t}:kv:${r}`}return {read(r){let n=globalThis.localStorage.getItem(e(r));if(n===null)return null;try{return JSON.parse(n)}catch{return null}},write(r,n){globalThis.localStorage.setItem(e(r),JSON.stringify(n));},delete(r){globalThis.localStorage.removeItem(e(r));},listKeys(r){let n=e(r??""),o=[];for(let s=0;s<globalThis.localStorage.length;s++){let i=globalThis.localStorage.key(s);i!==null&&i.startsWith(n)&&o.push(i.slice(e("").length));}return o}}}function $r(t){function e(){let n=globalThis.localStorage.getItem(t);if(!n)return [];try{return JSON.parse(n)}catch{return []}}function r(n){globalThis.localStorage.setItem(t,JSON.stringify(n));}return {readAllEntries(){return e()},appendEntry(n){let o=e();o.push(n),r(o);},generateId(){return globalThis.crypto.randomUUID()}}}function Pn(){let t=false;return {tryAcquire(){return t?null:(t=true,()=>{t=false;})}}}function Mn(t){return String(t).replace(/[^a-zA-Z0-9_-]/g,"_")}function Gn(t){function e(){let n=globalThis.localStorage.getItem(t);if(!n)return [];try{return JSON.parse(n)}catch{return []}}function r(n){globalThis.localStorage.setItem(t,JSON.stringify(n));}return {append(n){let o={id:globalThis.crypto.randomUUID(),payload:n},s=e();return s.push(o),r(s),o},readAll(){return e()},readAfter(n){let o=e();if(!n)return {entries:o,newCursor:o.length>0?o[o.length-1].id:null};let s=o.findIndex(a=>a.id===n),i=s===-1?o:o.slice(s+1);return {entries:i,newCursor:i.length>0?i[i.length-1].id:n}},clear(){globalThis.localStorage.removeItem(t);}}}function Fr(t){return vr(e=>Gn(`${t}:chat:journal:${Mn(e)}`),ge(`${t}:chat`))}var Nr=new Map;function pe(t){let e=Nr.get(t);if(!e){let r=new Set;e={publish(n){for(let o of r)o(n);},subscribe(n){return r.add(n),()=>{r.delete(n);}}},Nr.set(t,e);}return e}function Dr(){return {async subscribe(t,e){return t.kind!=="in-memory-bus"?(console.warn(`[in-memory-transport] unsupported kind: ${t.kind}`),()=>{}):pe(t.value).subscribe(n=>{let o=n;if(o&&o.kind==="notification-batch"&&Array.isArray(o.notifications)){for(let s of o.notifications)e(s);return}e(n);})}}}function Lr(t,e){let r=e?.callbackBaseUrl?{meta:"board-live-cards",howToRun:"http:post",whatToRun:e.callbackBaseUrl}:{meta:"board-live-cards",howToRun:"in-browser",whatToRun:ot({kind:"in-browser",value:t})},n=new Map,o=new Map,s=Pn();return {kvStorage:i=>ge(`${t}:${i}`),blobStorage:i=>fe(i?`${t}:${i}`:t),scratchStorage:()=>Te(`${t}:scratch`),scratchStorageForRef:i=>Te(bt(i).value),archiveFactory:()=>Ie(`${t}:archive`),archiveFactoryForRef:i=>Ie(bt(i).value),journalAdapter:()=>$r(`${t}:journal`),lock:s,selfRef:r,async dispatchExecution(i,a){if(i.howToRun==="http:post")try{let c=i.whatToRun,f=typeof c=="object"?c.value:bt(c).value,p=await fetch(f,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(a)});return p.ok?{dispatched:!0}:{dispatched:!1,error:`HTTP ${p.status}: ${p.statusText}`}}catch(c){return {dispatched:false,error:c instanceof Error?c.message:String(c)}}if(i.howToRun==="http:get")try{let c=i.whatToRun,f=typeof c=="object"?c.value:bt(c).value,p=new URLSearchParams(Object.entries(a).filter(([,h])=>h!=null).map(([h,y])=>[h,String(y)])),g=`${f}?${p.toString()}`,l=await fetch(g);return l.ok?{dispatched:!0}:{dispatched:!1,error:`HTTP ${l.status}: ${l.statusText}`}}catch(c){return {dispatched:false,error:c instanceof Error?c.message:String(c)}}if(i.howToRun==="in-browser"){let c=i.whatToRun,f=typeof c=="object"?c.value:bt(c).value,p=n.get(f);return p?p(i,a):{dispatched:false,error:`No in-browser handler registered for: ${f}`}}return {dispatched:false,error:`Browser adapter: unsupported dispatch kind (got: ${i.howToRun})`}},resolveBlob(i){if(i.kind==="in-memory"){let f=o.get(i.value);if(f==null)throw new Error(`resolveBlob: in-memory blob not found: ${ot(i)}`);return f}let c=fe(t).read(i.value);if(c===null)throw new Error(`resolveBlob: blob not found: ${ot(i)}`);return c},hashFn:jr,genId:()=>globalThis.crypto.randomUUID().replace(/-/g,""),kvStorageForRef:i=>ge(bt(i).value),publishBoardChangeNotifications(i){if(!e?.notifyChannel||i.length===0)return;pe(e.notifyChannel).publish({kind:"notification-batch",notifications:i});},onWarn:e?.onWarn,registerHandler(i,a){n.set(i,a);},writeMemoryBlob(i,a){return o.set(i,a),ot({kind:"in-memory",value:i})}}}function qr(t){return t==="running"||t==="in-progress"?"loading":t==="failed"?"error":"fresh"}function Un(t,e){let r=e&&typeof e=="object"&&!Array.isArray(e)?e:{};return {schema_version:r.schema_version||"v1",card_id:typeof r.card_id=="string"?r.card_id:t,card_data:r.card_data&&typeof r.card_data=="object"&&!Array.isArray(r.card_data)?structuredClone(r.card_data):{},computed_values:r.computed_values&&typeof r.computed_values=="object"&&!Array.isArray(r.computed_values)?structuredClone(r.computed_values):{}}}function Xt(t,e){if(!t||typeof t!="object")throw new Error("payload must be an object");if(!e)throw new Error("cardId is required");let n=(Array.isArray(t.cardDefinitions)?t.cardDefinitions:[]).find(w=>w.id===e);if(!n)throw new Error(`cardDefinitions has no entry with id ${e}`);let o=t.statusSnapshot&&typeof t.statusSnapshot=="object"?t.statusSnapshot:{},s=t.cardRuntimeById&&typeof t.cardRuntimeById=="object"?t.cardRuntimeById:{},i=t.dataObjectsByToken&&typeof t.dataObjectsByToken=="object"?t.dataObjectsByToken:{},c=(Array.isArray(o.cards)?o.cards:[]).find(w=>w.name===e),f=structuredClone(n),p=Un(e,s[e]),l={...f.card_data&&typeof f.card_data=="object"&&!Array.isArray(f.card_data)?f.card_data:{},...p.card_data||{},status:qr(c?.status),lastRun:c?.runtime?.last_transition_at??null};c?.error?.message&&(l.error=c.error.message);let h=c?{task_status:c.status??null,card_status:qr(c.status),runtime:structuredClone(c.runtime??{}),error:c.error?structuredClone(c.error):null,blocked_by:Array.isArray(c.blocked_by)?structuredClone(c.blocked_by):[],requires_missing:Array.isArray(c.requires_missing)?structuredClone(c.requires_missing):[]}:{task_status:null,card_status:l.status??"fresh",runtime:{last_transition_at:l.lastRun??null},error:l.error?{message:l.error}:null,blocked_by:[],requires_missing:[]},y=Array.isArray(f.requires)?f.requires:[],k={};for(let[w,N]of Object.entries(i))k[w]=structuredClone(N);for(let w of y)Object.prototype.hasOwnProperty.call(k,w)||(k[w]=null);let I=(t.cardChatsByCardId&&typeof t.cardChatsByCardId=="object"?t.cardChatsByCardId:{})[e],b=I?{messages:Array.isArray(I.messages)?I.messages:[],receiving:!!I.receiving,processing:!!I.processing}:null;return {id:e,card:f,card_data:l,requires:k,computed_values:p.computed_values,runtime_state:h,card_chats:b}}function Jn(t){if(!t||typeof t!="object")throw new Error("payload must be an object");return (Array.isArray(t.cardDefinitions)?t.cardDefinitions:[]).map(r=>Xt(t,r.id))}function me(t){return JSON.parse(JSON.stringify(t))}function Jt(t,e){if(t===e)return t;try{if(JSON.stringify(t)===JSON.stringify(e))return t}catch{}return e}function Rt(t,e){if(t===e)return true;try{return JSON.stringify(t)===JSON.stringify(e)}catch{return false}}function Hn(t){return t==="running"||t==="in-progress"?"loading":t==="failed"?"error":"fresh"}function Pr(t,e,r){let n=t,s=(n&&Array.isArray(n.cardDefinitions)?n.cardDefinitions:[]).map(c=>c.id),i=e&&e.modelsById||{},a={};for(let c of s){let f=r(t,c),p=i[c];if(!p){a[c]=f;continue}let g=f.card_chats!=null?Jt(p.card_chats,f.card_chats??null):p.card_chats??null,l={id:f.id,card:Jt(p.card,f.card),card_data:Jt(p.card_data,f.card_data),requires:Jt(p.requires,f.requires),computed_values:Jt(p.computed_values,f.computed_values),runtime_state:Jt(p.runtime_state,f.runtime_state),card_chats:g};a[c]=l.card===p.card&&l.card_data===p.card_data&&l.requires===p.requires&&l.computed_values===p.computed_values&&l.runtime_state===p.runtime_state&&l.card_chats===p.card_chats?p:l;}return {payload:t,cardIds:s,modelsById:a}}function Mr(t,e,r,n){if(!t||!Array.isArray(e)||e.length===0)return t;let o=t.modelsById,s=t.cardIds,i=false,a=false,c={};for(let p of s){let g=o[p],l=g&&g.requires;if(l&&typeof l=="object")for(let h of Object.keys(l))(c[h]=c[h]||[]).push(p);}function f(){i||(o={...o},i=true);}for(let p of e)if(!(!p||!p.kind)){if(p.kind==="computed_values"){let g=p.cardId,l=o[g];if(!l)continue;let h=p.values||{};if(Rt(l.computed_values,h))continue;f(),o[g]={...l,computed_values:h},a=true;}else if(p.kind==="data_object"){let g=p.key,l=p.payload,h=c[g]||[];for(let y of h){let k=o[y];if(!k)continue;let T=k.requires||{};Rt(T[g],l)||(f(),o[y]={...k,requires:{...T,[g]:l}},a=true);}}else if(p.kind==="card_refreshed"){let g=p.cardId,l=null,h=o[g],y=p.card;if(h&&y&&typeof y=="object"&&!Array.isArray(y)){let k=y,T=k.card_data&&typeof k.card_data=="object"&&!Array.isArray(k.card_data)?k.card_data:h.card_data,I=k.requires&&typeof k.requires=="object"&&!Array.isArray(k.requires)?k.requires:h.requires,b=k.computed_values&&typeof k.computed_values=="object"&&!Array.isArray(k.computed_values)?k.computed_values:h.computed_values,w=k.runtime_state&&typeof k.runtime_state=="object"&&!Array.isArray(k.runtime_state)?k.runtime_state:h.runtime_state;l={...h,card:y,card_data:T,requires:I,computed_values:b,runtime_state:w};}if(!l)try{let k=n();k&&(l=r(k,g));}catch{}if(!l||h&&Rt(h.card,l.card)&&Rt(h.card_data,l.card_data)&&Rt(h.requires,l.requires)&&Rt(h.computed_values,l.computed_values)&&Rt(h.runtime_state,l.runtime_state))continue;f(),o[g]=l,s.includes(g)||(s=[...s,g]),a=true;}else if(p.kind==="card_chats"){let g=p.cardId,l=o[g];if(!l)continue;let h=Array.isArray(p.messages)?p.messages:l.card_chats?.messages??[],y=typeof p.receiving=="boolean"?p.receiving:l.card_chats?.receiving??false,k=typeof p.processing=="boolean"?p.processing:l.card_chats?.processing??false,T={messages:h,receiving:y,processing:k};if(Rt(l.card_chats,T))continue;f(),o[g]={...l,card_chats:T},a=true;}else if(p.kind==="chat_messages"){let g=p.cardId,l=o[g];if(!l)continue;let h=Array.isArray(p.messages)?p.messages:[],y=l.card_chats||{receiving:false,processing:false},k={messages:h,receiving:y.receiving,processing:!!y.processing};if(Rt(l.card_chats,k))continue;f(),o[g]={...l,card_chats:k},a=true;}else if(p.kind==="status"){let g=p.status?.cards??[];for(let l of g){let h=l?.name;if(!h||!o[h])continue;let y=o[h],k=Hn(l.status),T={...y.card_data||{},status:k,lastRun:l.runtime?.last_transition_at??null,...l.error?.message?{error:l.error.message}:{}};l.error?.message||delete T.error;let I={task_status:l.status??null,card_status:k,runtime:l.runtime?me(l.runtime):{},error:l.error?me(l.error):null,blocked_by:Array.isArray(l.blocked_by)?me(l.blocked_by):[],requires_missing:Array.isArray(l.requires_missing)?me(l.requires_missing):[]};Rt(y.card_data,T)&&Rt(y.runtime_state,I)||(f(),o[h]={...y,card_data:T,runtime_state:I},a=true);}}}return a?{payload:t.payload,cardIds:s,modelsById:o}:t}function gs(t,e){let r=e?.cards??[],n=e?.onWarn??(()=>{}),o=`${t}:notify`,s=Lr(t,{callbackBaseUrl:e?.callbackBaseUrl,notifyChannel:o,onWarn:n}),i=bt(ot({kind:"localstorage",value:t})),a=ot({kind:"localstorage",value:`${t}:card-store`}),c=ot({kind:"localstorage",value:`${t}:outputs`}),f=e?.taskExecutor??null,p=e?.chatHandler??null,g=ot({kind:"in-browser",value:`${t}:task-executor`}),l=ot({kind:"in-browser",value:`${t}:chat-handler`});f&&s.registerHandler(g,f),p&&s.registerHandler(l,p);let h={async invoke(x,_){return x.howToRun==="in-browser",s.dispatchExecution(x,_)}},y=e?.taskExecutorRef??(f?{meta:"task-executor",howToRun:"in-browser",whatToRun:g}:void 0),k=e?.chatHandlerRef??(p?{meta:"chat-handler",howToRun:"in-browser",whatToRun:l}:void 0),T=Dr(),I=Fr(t),b=Ir({boardId:t,chatStorage:I,boards:[{label:t,boardAdapter:s,baseRef:i,cardStoreRef:a,outputsStoreRef:c,notifyRef:{kind:"in-memory-bus",value:o},taskExecutorRef:y,chatHandlerRef:k}],invocationAdapter:h,notificationTransport:T,logger:{info:(...x)=>console.log("[board]",...x),warn:(...x)=>{n(String(x[0])),console.warn("[board]",...x);},error:(...x)=>console.error("[board]",...x)}});r.length&&b.cardStore.set({body:r}),e?.onBoardChange&&pe(o).subscribe(_=>{let B=_;!B||B.kind!=="notification-batch"||!Array.isArray(B.notifications)||B.notifications.length===0||e.onBoardChange?.({notifications:B.notifications});});function w(x,_,B){let L=B?JSON.stringify(B):"",J=new TextEncoder().encode(L),z=false;return {method:x,url:_,headers:{"content-type":"application/json"},on(st,Q){},[Symbol.asyncIterator](){let st={async next(){return z?{done:true,value:void 0}:(z=true,{done:false,value:J})},[Symbol.asyncIterator](){return st}};return st}}}function N(){let x=200,_=[];return {res:{writeHead(L){x=L;},write(L){return _.push(typeof L=="string"?L:new TextDecoder().decode(L)),true},end(L){L&&_.push(typeof L=="string"?L:new TextDecoder().decode(L));}},getResult:()=>{let L=_.join(""),J;try{J=JSON.parse(L);}catch{J=L;}return {status:x,body:J}}}}let U=b.apiBasePath;return {async bootstrap(){let x=w("GET",`${U}/bootstrap`),{res:_}=N();await b.handleRuntimeApi(x,_,new URL(`http://localhost${U}/bootstrap`));},getState(){return b.buildPublishedRuntimePayload()},async patchCard(x,_){let B=`${U}/cards/${encodeURIComponent(x)}`,L=w("PATCH",B,_),{res:J}=N();await b.handleRuntimeApi(L,J,new URL(`http://localhost${B}`));},async applyCardAction(x,_,B){let L=`${U}/cards/${encodeURIComponent(x)}/actions`,J=w("POST",L,{actionType:_,payload:B}),{res:z}=N();await b.handleRuntimeApi(J,z,new URL(`http://localhost${L}`));},readChatRecords(x){let _=`${U}/cards/${encodeURIComponent(x)}/chats`,B=w("GET",_),L=N();b.handleRuntimeApi(B,L.res,new URL(`http://localhost${_}`));let z=L.getResult().body;return Array.isArray(z?.messages)?z.messages:[]},clearChatRecords(x){b.clearChatRecords(x);},writeMemoryBlob(x,_){return s.writeMemoryBlob(x,_)},reportSourceFetched(x,_){b.reportSourceFetched(x,_);},reportSourceFetchFailure(x,_){b.reportSourceFetchFailure(x,_);},get runtime(){return b}}}function hs(t,e){return Pr(t,e,Xt)}function ys(t,e,r){return Mr(t,e,Xt,r)}
|
|
9
9
|
exports.applyNotification=ys;exports.buildBoardState=hs;exports.create=gs;exports.selectAllLiveCardModels=Jn;exports.selectLiveCardModel=Xt;return exports;})({});//# sourceMappingURL=board-livecards-localstorage.js.map
|
|
10
10
|
//# sourceMappingURL=board-livecards-localstorage.js.map
|
|
@@ -220,6 +220,7 @@ interface CardStorageAdapter {
|
|
|
220
220
|
readCard(key: string): LiveCard | null;
|
|
221
221
|
/** Write card content; returns checksum of what was written. */
|
|
222
222
|
writeCard(key: string, card: LiveCard): string;
|
|
223
|
+
removeCard(key: string): void;
|
|
223
224
|
cardExists(key: string): boolean;
|
|
224
225
|
defaultCardKey(cardId: string): string;
|
|
225
226
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { B as BoardPlatformAdapter, N as NotificationTransport, C as ChatStorage } from '../types-
|
|
1
|
+
import { B as BoardPlatformAdapter, N as NotificationTransport, C as ChatStorage } from '../types-BkJvnXVD.js';
|
|
2
2
|
import { E as ExecutionRef } from '../execution-interface-DCFBy4L8.js';
|
|
3
|
-
import '../board-live-cards-lib-
|
|
3
|
+
import '../board-live-cards-lib-COi4bSpk.js';
|
|
4
4
|
|
|
5
5
|
declare function createLocalStorageChatStorage(namespace: string): ChatStorage;
|
|
6
6
|
interface InMemoryBus {
|