@easbot/agent 0.2.25 → 0.2.27

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (98) hide show
  1. package/dist/assets/txt/tool/gateway-channel.txt +77 -41
  2. package/dist/chunks/{acp-STZJ75XV.mjs → acp-7YXFQ45K.mjs} +2 -2
  3. package/dist/chunks/adapter-loader-3676SVTM.mjs +1 -0
  4. package/dist/chunks/{agent-FF52NW42.mjs → agent-52URJRBC.mjs} +1 -1
  5. package/dist/chunks/{agent-4EMYYWV6.mjs → agent-DIUQQQYM.mjs} +1 -1
  6. package/dist/chunks/app-TR66U2CP.mjs +1 -0
  7. package/dist/chunks/{auth-2I7U24YF.mjs → auth-DHIUZUBT.mjs} +1 -1
  8. package/dist/chunks/bootstrap-AD7IUF7M.mjs +1 -0
  9. package/dist/chunks/{build-program-43NDEGM2.mjs → build-program-WP5P33JQ.mjs} +1 -1
  10. package/dist/chunks/bus-CBFYNJXU.mjs +1 -0
  11. package/dist/chunks/{chunk-KLJ7PPSA.mjs → chunk-3P7JMESZ.mjs} +1 -1
  12. package/dist/chunks/{chunk-GMEJX6PC.mjs → chunk-47PBZEYM.mjs} +1 -1
  13. package/dist/chunks/{chunk-LFNGHYRC.mjs → chunk-6JRVLYTU.mjs} +1 -1
  14. package/dist/chunks/{chunk-I6MBTO75.mjs → chunk-6M4SMEZK.mjs} +1 -1
  15. package/dist/chunks/{chunk-IHHFG47N.mjs → chunk-JCC3ZOI6.mjs} +1 -1
  16. package/dist/chunks/{chunk-KY3H2HGJ.mjs → chunk-MMN3J3YS.mjs} +228 -224
  17. package/dist/chunks/{chunk-EEWP2VV6.mjs → chunk-NQDXG75V.mjs} +4 -4
  18. package/dist/chunks/{chunk-ARCMKYQI.mjs → chunk-ROHSYOEJ.mjs} +1 -1
  19. package/dist/chunks/{chunk-I7A5JGO5.mjs → chunk-RRQRZ6MW.mjs} +1 -1
  20. package/dist/chunks/{chunk-CVTJJBGW.mjs → chunk-TMAVGPNZ.mjs} +1 -1
  21. package/dist/chunks/{chunk-WN2HAJBB.mjs → chunk-VCVFFLHV.mjs} +7 -7
  22. package/dist/chunks/{chunk-QJ6QTASU.mjs → chunk-YCYECTVW.mjs} +1 -1
  23. package/dist/chunks/{command-H77IO5J2.mjs → command-5C6WIRH5.mjs} +1 -1
  24. package/dist/chunks/compaction-LD7EJA6I.mjs +1 -0
  25. package/dist/chunks/config-JVIING4F.mjs +1 -0
  26. package/dist/chunks/{confirm-dialog-AGHMTHWU.mjs → confirm-dialog-XBLCGOEC.mjs} +1 -1
  27. package/dist/chunks/{debug-55VJ74IW.mjs → debug-UKX4WQ3F.mjs} +3 -3
  28. package/dist/chunks/{export-BGH24SO2.mjs → export-I4GL3OUG.mjs} +1 -1
  29. package/dist/chunks/file-X44TUOLQ.mjs +1 -0
  30. package/dist/chunks/gateway-WMMPUO46.mjs +16 -0
  31. package/dist/chunks/{generate-QMA5OAOD.mjs → generate-ATBLMTBG.mjs} +1 -1
  32. package/dist/chunks/{github-EJCNXJ6F.mjs → github-VDDFKDCK.mjs} +2 -2
  33. package/dist/chunks/global-EVUKT3AP.mjs +1 -0
  34. package/dist/chunks/{import-4TX5SVFQ.mjs → import-JXNBDWIF.mjs} +1 -1
  35. package/dist/chunks/installation-PL26SKTI.mjs +1 -0
  36. package/dist/chunks/instance-6NPZLEWW.mjs +1 -0
  37. package/dist/chunks/loader-E7GJBAIA.mjs +1 -0
  38. package/dist/chunks/loader-PDYDFUCE.mjs +1 -0
  39. package/dist/chunks/lsp-TAHMSZIF.mjs +1 -0
  40. package/dist/chunks/mcp-JBQOYJSH.mjs +1 -0
  41. package/dist/chunks/{mcp-BGU4XS34.mjs → mcp-WVQBQVTR.mjs} +1 -1
  42. package/dist/chunks/models-AHPQPXDG.mjs +1 -0
  43. package/dist/chunks/{pr-XD7C7PDJ.mjs → pr-NLGAGRR2.mjs} +1 -1
  44. package/dist/chunks/preferences-H2TY25O6.mjs +1 -0
  45. package/dist/chunks/project-RYTIRGTX.mjs +1 -0
  46. package/dist/chunks/prompt-5QAKRVXS.mjs +1 -0
  47. package/dist/chunks/provider-VPOZDMMP.mjs +1 -0
  48. package/dist/chunks/registry-SYGK57RE.mjs +1 -0
  49. package/dist/chunks/revert-QWJ7WVG5.mjs +1 -0
  50. package/dist/chunks/ripgrep-OHTQKKDR.mjs +1 -0
  51. package/dist/chunks/{run-KL5CA5M6.mjs → run-3YPI6XKG.mjs} +2 -2
  52. package/dist/chunks/scheduler-ZEHS5N2M.mjs +1 -0
  53. package/dist/chunks/server-LZVS7PBL.mjs +1 -0
  54. package/dist/chunks/{session-REKMEA3V.mjs → session-4MTNN2T4.mjs} +1 -1
  55. package/dist/chunks/session-DVMBXQNW.mjs +1 -0
  56. package/dist/chunks/session-SD2Y7TSF.mjs +1 -0
  57. package/dist/chunks/{settings-panel-BWCVKC4G.mjs → settings-panel-4GBMKF7S.mjs} +1 -1
  58. package/dist/chunks/share-NAAYDAC3.mjs +1 -0
  59. package/dist/chunks/snapshot-QYVGLPZG.mjs +1 -0
  60. package/dist/chunks/{stats-MILDLIZD.mjs → stats-KXJDFVQY.mjs} +1 -1
  61. package/dist/chunks/storage-R2S2HFGM.mjs +1 -0
  62. package/dist/chunks/tui-MDEMUHXR.mjs +1 -0
  63. package/dist/chunks/{tui-HU55FGHV.mjs → tui-YDIPDB2Q.mjs} +1 -1
  64. package/dist/chunks/types-TQH77CIP.mjs +1 -0
  65. package/dist/chunks/{update-IOQCRELU.mjs → update-K6SAKANZ.mjs} +1 -1
  66. package/dist/cli.mjs +3 -3
  67. package/package.json +13 -13
  68. package/dist/chunks/adapter-loader-BLTYHARQ.mjs +0 -1
  69. package/dist/chunks/app-CGZZFC54.mjs +0 -1
  70. package/dist/chunks/bootstrap-GVMMOFUK.mjs +0 -1
  71. package/dist/chunks/bus-PFFRRCH3.mjs +0 -1
  72. package/dist/chunks/compaction-LQXOGRP7.mjs +0 -1
  73. package/dist/chunks/config-J54DTNPX.mjs +0 -1
  74. package/dist/chunks/file-KEMX6XWX.mjs +0 -1
  75. package/dist/chunks/gateway-45LKZAQS.mjs +0 -16
  76. package/dist/chunks/global-KAF6JHVQ.mjs +0 -1
  77. package/dist/chunks/installation-CGMLIGLA.mjs +0 -1
  78. package/dist/chunks/instance-YUOFE3Q3.mjs +0 -1
  79. package/dist/chunks/loader-YOPK5OTL.mjs +0 -1
  80. package/dist/chunks/loader-ZTWTX2GS.mjs +0 -1
  81. package/dist/chunks/lsp-YNF5BCPV.mjs +0 -1
  82. package/dist/chunks/models-TN65RCBA.mjs +0 -1
  83. package/dist/chunks/preferences-3HCTNG2J.mjs +0 -1
  84. package/dist/chunks/project-HH3IL3QQ.mjs +0 -1
  85. package/dist/chunks/prompt-W7772MHB.mjs +0 -1
  86. package/dist/chunks/provider-ULN4YD2M.mjs +0 -1
  87. package/dist/chunks/registry-TL5F5F7C.mjs +0 -1
  88. package/dist/chunks/revert-TZSK52JS.mjs +0 -1
  89. package/dist/chunks/ripgrep-E3GWWA2V.mjs +0 -1
  90. package/dist/chunks/scheduler-SCM4SRS2.mjs +0 -1
  91. package/dist/chunks/server-Z6BORWAL.mjs +0 -1
  92. package/dist/chunks/session-BHXYW2JD.mjs +0 -1
  93. package/dist/chunks/session-PMZOQPFQ.mjs +0 -1
  94. package/dist/chunks/share-JFZ3O2BX.mjs +0 -1
  95. package/dist/chunks/snapshot-V23GRQBM.mjs +0 -1
  96. package/dist/chunks/storage-DKQ7S6QX.mjs +0 -1
  97. package/dist/chunks/tui-YGASP4NS.mjs +0 -1
  98. package/dist/chunks/types-WN4LZEB5.mjs +0 -1
@@ -1,2 +1,2 @@
1
- import {a}from'./chunk-LFYBZHOI.mjs';import {a as a$1}from'./chunk-I6MBTO75.mjs';import E from'path';import j from'fs/promises';import t from'zod';import {NamedError,lazy,PKG,Filesystem,Fetch,Shell}from'@easbot/utils';import {ZipReader,BlobReader,BlobWriter}from'@zip.js/zip.js';var P;(c=>{let $=a.create({service:"ripgrep"}),A=t.object({elapsed:t.object({secs:t.number(),nanos:t.number(),human:t.string()}),searches:t.number(),searches_with_match:t.number(),bytes_searched:t.number(),bytes_printed:t.number(),matched_lines:t.number(),matches:t.number()}),S=t.object({type:t.literal("begin"),data:t.object({path:t.object({text:t.string()})})});c.Match=t.object({type:t.literal("match"),data:t.object({path:t.object({text:t.string()}),lines:t.object({text:t.string()}),line_number:t.number(),absolute_offset:t.number(),submatches:t.array(t.object({match:t.object({text:t.string()}),start:t.number(),end:t.number()}))})});let M=t.object({type:t.literal("end"),data:t.object({path:t.object({text:t.string()}),binary_offset:t.number().nullable(),stats:A})}),D=t.object({type:t.literal("summary"),data:t.object({elapsed_total:t.object({human:t.string(),nanos:t.number(),secs:t.number()}),stats:A})}),O=t.union([S,c.Match,M,D]),W={"arm64-darwin":{platform:"aarch64-apple-darwin",extension:"tar.gz"},"arm64-linux":{platform:"aarch64-unknown-linux-gnu",extension:"tar.gz"},"x64-darwin":{platform:"x86_64-apple-darwin",extension:"tar.gz"},"x64-linux":{platform:"x86_64-unknown-linux-musl",extension:"tar.gz"},"x64-win32":{platform:"x86_64-pc-windows-msvc",extension:"zip"}};c.ExtractionFailedError=NamedError.create("RipgrepExtractionFailedError",t.object({filepath:t.string(),stderr:t.string()})),c.UnsupportedPlatformError=NamedError.create("RipgrepUnsupportedPlatformError",t.object({platform:t.string()})),c.DownloadFailedError=NamedError.create("RipgrepDownloadFailedError",t.object({url:t.string(),status:t.number()}));let L=lazy(async()=>{let e=await PKG.which("rg");if(e){if((await j.stat(e).catch(()=>{}))?.isFile())return {filepath:Filesystem.resolve(e)};$.warn("bun.which returned invalid rg path",{filepath:e});}let l=Filesystem.resolve(E.join(a$1.Path.bin,"rg"+(process.platform==="win32"?".exe":"")));if(!await PKG.file(l).exists()){let i=`${process.arch}-${process.platform}`,f=W[i];if(!f)throw new c.UnsupportedPlatformError({platform:i});let r="14.1.1",b=`ripgrep-${r}-${f.platform}.${f.extension}`,p=`https://github.com/BurntSushi/ripgrep/releases/download/${r}/${b}`,m=await Fetch.get(p,{responseType:"arrayBuffer"});if(!m.ok)throw new c.DownloadFailedError({url:p,status:m.status});let u=m.data,n=E.join(a$1.Path.bin,b);if(await PKG.write(n,new Uint8Array(u)),f.extension==="tar.gz"){let o=["tar","-xzf",n,"--strip-components=1"];i.endsWith("-darwin")&&o.push("--include=*/rg"),i.endsWith("-linux")&&o.push("--wildcards","*/rg");let a=await Shell.run(void 0,o.join(" "),{cwd:a$1.Path.bin});if(a.code!==0)throw new c.ExtractionFailedError({filepath:l,stderr:a.stderr})}if(f.extension==="zip"){let a=await PKG.file(n).arrayBuffer(),d=new ZipReader(new BlobReader(new Blob([a]))),g=await d.getEntries(),w;for(let v of g)if(v.filename.endsWith("rg.exe")){w=v;break}if(!w)throw new c.ExtractionFailedError({filepath:n,stderr:"rg.exe not found in zip archive"});let x=await w.getData(new BlobWriter);if(!x)throw new c.ExtractionFailedError({filepath:n,stderr:"Failed to extract rg.exe from zip archive"});let C=await x.arrayBuffer();await PKG.write(l,new Uint8Array(C)),await d.close();}await j.unlink(n),i.endsWith("-win32")||await j.chmod(l,493);}return {filepath:l}});async function N(){let{filepath:e}=await L();return e}c.filepath=N;async function*H(e){e.signal?.throwIfAborted();let l=await N(),s=["--files","--glob=!.git/*"];if(e.follow&&s.push("--follow"),e.hidden!==false&&s.push("--hidden"),e.maxDepth!==void 0&&s.push(`--max-depth=${e.maxDepth}`),e.glob)for(let r of e.glob)s.push(`--glob=${r}`);if(!(await j.stat(e.cwd).catch(()=>{}))?.isDirectory())throw Object.assign(new Error(`No such file or directory: '${e.cwd}'`),{code:"ENOENT",errno:-2,path:e.cwd});let f=(await PKG.run([l,...s],{cwd:e.cwd})).stdout.trim().split(/\r?\n/).filter(Boolean);for(let r of f)e.signal?.throwIfAborted(),r&&(yield r);}c.files=H;async function Q(e){$.info("tree",e);let l=await Array.fromAsync(c.files({cwd:e.cwd,signal:e.signal}));function s(n,o){let a=n.children.get(o);if(a)return a;let d={name:o,children:new Map};return n.children.set(o,d),d}let i={children:new Map};for(let n of l){if(n.includes(".easbot"))continue;let o=n.split(E.sep);if(o.length<2)continue;let a=i;for(let d of o.slice(0,-1))a=s(a,d);}function f(n){let o=0;for(let a of n.children.values())o+=1+f(a);return o}let r=f(i),b=e.limit??r,p=[],m=[];for(let n of Array.from(i.children.values()).sort((o,a)=>o.name.localeCompare(a.name)))m.push({node:n,path:n.name});let u=0;for(let n=0;n<m.length&&u<b;n++){let o=m[n];if(!o)continue;let{node:a,path:d}=o;p.push(d),u++;for(let g of Array.from(a.children.values()).sort((w,x)=>w.name.localeCompare(x.name)))m.push({node:g,path:`${d}/${g.name}`});}return r>u&&p.push(`[${r-u} truncated]`),p.join(`
1
+ import {a}from'./chunk-LFYBZHOI.mjs';import {a as a$1}from'./chunk-6M4SMEZK.mjs';import E from'path';import j from'fs/promises';import t from'zod';import {NamedError,lazy,PKG,Filesystem,Fetch,Shell}from'@easbot/utils';import {ZipReader,BlobReader,BlobWriter}from'@zip.js/zip.js';var P;(c=>{let $=a.create({service:"ripgrep"}),A=t.object({elapsed:t.object({secs:t.number(),nanos:t.number(),human:t.string()}),searches:t.number(),searches_with_match:t.number(),bytes_searched:t.number(),bytes_printed:t.number(),matched_lines:t.number(),matches:t.number()}),S=t.object({type:t.literal("begin"),data:t.object({path:t.object({text:t.string()})})});c.Match=t.object({type:t.literal("match"),data:t.object({path:t.object({text:t.string()}),lines:t.object({text:t.string()}),line_number:t.number(),absolute_offset:t.number(),submatches:t.array(t.object({match:t.object({text:t.string()}),start:t.number(),end:t.number()}))})});let M=t.object({type:t.literal("end"),data:t.object({path:t.object({text:t.string()}),binary_offset:t.number().nullable(),stats:A})}),D=t.object({type:t.literal("summary"),data:t.object({elapsed_total:t.object({human:t.string(),nanos:t.number(),secs:t.number()}),stats:A})}),O=t.union([S,c.Match,M,D]),W={"arm64-darwin":{platform:"aarch64-apple-darwin",extension:"tar.gz"},"arm64-linux":{platform:"aarch64-unknown-linux-gnu",extension:"tar.gz"},"x64-darwin":{platform:"x86_64-apple-darwin",extension:"tar.gz"},"x64-linux":{platform:"x86_64-unknown-linux-musl",extension:"tar.gz"},"x64-win32":{platform:"x86_64-pc-windows-msvc",extension:"zip"}};c.ExtractionFailedError=NamedError.create("RipgrepExtractionFailedError",t.object({filepath:t.string(),stderr:t.string()})),c.UnsupportedPlatformError=NamedError.create("RipgrepUnsupportedPlatformError",t.object({platform:t.string()})),c.DownloadFailedError=NamedError.create("RipgrepDownloadFailedError",t.object({url:t.string(),status:t.number()}));let L=lazy(async()=>{let e=await PKG.which("rg");if(e){if((await j.stat(e).catch(()=>{}))?.isFile())return {filepath:Filesystem.resolve(e)};$.warn("bun.which returned invalid rg path",{filepath:e});}let l=Filesystem.resolve(E.join(a$1.Path.bin,"rg"+(process.platform==="win32"?".exe":"")));if(!await PKG.file(l).exists()){let i=`${process.arch}-${process.platform}`,f=W[i];if(!f)throw new c.UnsupportedPlatformError({platform:i});let r="14.1.1",b=`ripgrep-${r}-${f.platform}.${f.extension}`,p=`https://github.com/BurntSushi/ripgrep/releases/download/${r}/${b}`,m=await Fetch.get(p,{responseType:"arrayBuffer"});if(!m.ok)throw new c.DownloadFailedError({url:p,status:m.status});let u=m.data,n=E.join(a$1.Path.bin,b);if(await PKG.write(n,new Uint8Array(u)),f.extension==="tar.gz"){let o=["tar","-xzf",n,"--strip-components=1"];i.endsWith("-darwin")&&o.push("--include=*/rg"),i.endsWith("-linux")&&o.push("--wildcards","*/rg");let a=await Shell.run(void 0,o.join(" "),{cwd:a$1.Path.bin});if(a.code!==0)throw new c.ExtractionFailedError({filepath:l,stderr:a.stderr})}if(f.extension==="zip"){let a=await PKG.file(n).arrayBuffer(),d=new ZipReader(new BlobReader(new Blob([a]))),g=await d.getEntries(),w;for(let v of g)if(v.filename.endsWith("rg.exe")){w=v;break}if(!w)throw new c.ExtractionFailedError({filepath:n,stderr:"rg.exe not found in zip archive"});let x=await w.getData(new BlobWriter);if(!x)throw new c.ExtractionFailedError({filepath:n,stderr:"Failed to extract rg.exe from zip archive"});let C=await x.arrayBuffer();await PKG.write(l,new Uint8Array(C)),await d.close();}await j.unlink(n),i.endsWith("-win32")||await j.chmod(l,493);}return {filepath:l}});async function N(){let{filepath:e}=await L();return e}c.filepath=N;async function*H(e){e.signal?.throwIfAborted();let l=await N(),s=["--files","--glob=!.git/*"];if(e.follow&&s.push("--follow"),e.hidden!==false&&s.push("--hidden"),e.maxDepth!==void 0&&s.push(`--max-depth=${e.maxDepth}`),e.glob)for(let r of e.glob)s.push(`--glob=${r}`);if(!(await j.stat(e.cwd).catch(()=>{}))?.isDirectory())throw Object.assign(new Error(`No such file or directory: '${e.cwd}'`),{code:"ENOENT",errno:-2,path:e.cwd});let f=(await PKG.run([l,...s],{cwd:e.cwd})).stdout.trim().split(/\r?\n/).filter(Boolean);for(let r of f)e.signal?.throwIfAborted(),r&&(yield r);}c.files=H;async function Q(e){$.info("tree",e);let l=await Array.fromAsync(c.files({cwd:e.cwd,signal:e.signal}));function s(n,o){let a=n.children.get(o);if(a)return a;let d={name:o,children:new Map};return n.children.set(o,d),d}let i={children:new Map};for(let n of l){if(n.includes(".easbot"))continue;let o=n.split(E.sep);if(o.length<2)continue;let a=i;for(let d of o.slice(0,-1))a=s(a,d);}function f(n){let o=0;for(let a of n.children.values())o+=1+f(a);return o}let r=f(i),b=e.limit??r,p=[],m=[];for(let n of Array.from(i.children.values()).sort((o,a)=>o.name.localeCompare(a.name)))m.push({node:n,path:n.name});let u=0;for(let n=0;n<m.length&&u<b;n++){let o=m[n];if(!o)continue;let{node:a,path:d}=o;p.push(d),u++;for(let g of Array.from(a.children.values()).sort((w,x)=>w.name.localeCompare(x.name)))m.push({node:g,path:`${d}/${g.name}`});}return r>u&&p.push(`[${r-u} truncated]`),p.join(`
2
2
  `)}c.tree=Q;async function R(e){let l=await N(),s=["--json","--hidden","--glob=!.git/*"];if(e.follow&&s.push("--follow"),e.glob)for(let r of e.glob)s.push(`--glob=${r}`);e.limit&&s.push(`--max-count=${e.limit}`),s.push("--"),s.push(e.pattern);let i=await PKG.run([l,...s],{cwd:e.cwd});return i.code!==0?[]:i.stdout.trim().split(/\r?\n/).filter(Boolean).map(r=>JSON.parse(r)).map(r=>O.parse(r)).filter(r=>r.type==="match").map(r=>r.data)}c.search=R;})(P||(P={}));export{P as a};
@@ -1,2 +1,2 @@
1
- import {a}from'./chunk-LFYBZHOI.mjs';import {a as a$1}from'./chunk-I6MBTO75.mjs';import {c,d}from'./chunk-X6ISXWBN.mjs';import s from'path';import a$2 from'fs/promises';import {NamedError,lazy,Filesystem,PKG,$ as $$1,Lock}from'@easbot/utils';import E from'zod';import {glob}from'glob';var $;(J=>{let d$1=a.create({service:"storage"});J.NotFoundError=NamedError.create("NotFoundError",E.object({message:E.string()}));let O=[async n=>{let o=s.resolve(n,"../project");if(await Filesystem.isDir(o))for await(let i of new PKG.Glob("*").scan({cwd:o})){d$1.info(`migrating project ${i}`);let t=i,r=s.join(o,i),e="/";if(t!=="global"){let g=await glob("storage/session/message/*/*.json",{cwd:s.join(o,i),absolute:true});for(let c of g)if(e=(await a$2.readFile(c,"utf-8").then(m=>JSON.parse(m))).path?.root??"",e)break;if(!e||!await Filesystem.isDir(e))continue;let[u]=await $$1`git rev-list --max-parents=0 --all`.quiet().nothrow().cwd(e).text().then(c=>c.split(`
1
+ import {a}from'./chunk-LFYBZHOI.mjs';import {a as a$1}from'./chunk-6M4SMEZK.mjs';import {c,d}from'./chunk-X6ISXWBN.mjs';import s from'path';import a$2 from'fs/promises';import {NamedError,lazy,Filesystem,PKG,$ as $$1,Lock}from'@easbot/utils';import E from'zod';import {glob}from'glob';var $;(J=>{let d$1=a.create({service:"storage"});J.NotFoundError=NamedError.create("NotFoundError",E.object({message:E.string()}));let O=[async n=>{let o=s.resolve(n,"../project");if(await Filesystem.isDir(o))for await(let i of new PKG.Glob("*").scan({cwd:o})){d$1.info(`migrating project ${i}`);let t=i,r=s.join(o,i),e="/";if(t!=="global"){let g=await glob("storage/session/message/*/*.json",{cwd:s.join(o,i),absolute:true});for(let c of g)if(e=(await a$2.readFile(c,"utf-8").then(m=>JSON.parse(m))).path?.root??"",e)break;if(!e||!await Filesystem.isDir(e))continue;let[u]=await $$1`git rev-list --max-parents=0 --all`.quiet().nothrow().cwd(e).text().then(c=>c.split(`
2
2
  `).filter(Boolean).map(w=>w.trim()).toSorted());if(!u)continue;t=u,await PKG.write(s.join(n,"project",t+".json"),JSON.stringify({id:u,vcs:"git",worktree:e,time:{created:Date.now(),initialized:Date.now()}})),d$1.info(`migrating sessions for project ${t}`);for await(let c of new PKG.Glob("storage/session/info/*.json").scan({cwd:r,absolute:true})){let w=s.join(n,"session",t,s.basename(c));d$1.info("copying",{sessionFile:c,dest:w});let m=await a$2.readFile(c,"utf-8").then(p=>JSON.parse(p));await a$2.writeFile(w,JSON.stringify(m)),d$1.info(`migrating messages for session ${m.id}`);for await(let p of new PKG.Glob(`storage/session/message/${m.id}/*.json`).scan({cwd:r,absolute:true})){let S=s.join(n,"message",m.id,s.basename(p));d$1.info("copying",{msgFile:p,dest:S});let h=await a$2.readFile(p,"utf-8").then(j=>JSON.parse(j));await a$2.writeFile(S,JSON.stringify(h)),d$1.info(`migrating parts for message ${h.id}`);for await(let j of new PKG.Glob(`storage/session/part/${m.id}/${h.id}/*.json`).scan({cwd:r,absolute:true})){let T=s.join(n,"part",h.id,s.basename(j)),P=await PKG.file(j).json();d$1.info("copying",{partFile:j,dest:T}),await PKG.write(T,JSON.stringify(P));}}}}}},async n=>{for await(let o of new PKG.Glob("session/*/*.json").scan({cwd:n,absolute:true})){let i=await PKG.file(o).json();if(!i.projectID||!i.summary?.diffs)continue;let{diffs:t}=i.summary;await PKG.write(s.join(n,"session_diff",i.id+".json"),JSON.stringify(t)),await PKG.write(s.join(n,"session",i.projectID,i.id+".json"),JSON.stringify({...i,summary:{additions:t.reduce((r,e)=>r+e.additions,0),deletions:t.reduce((r,e)=>r+e.deletions,0)}}));}}],l=lazy(async()=>{let n=s.join(a$1.Path.data,"storage");await a$2.mkdir(n,{recursive:true});let o=s.join(n,"migration"),i=await a$2.readFile(o,"utf-8").then(t=>parseInt(t,10)).catch(()=>0);for(let t=i;t<O.length;t++){d$1.info("running migration",{index:t});let r=O[t];r&&(await r(n).catch(()=>d$1.error("failed to run migration",{index:t})),await a$2.writeFile(o,(t+1).toString(),"utf-8"));}return {dir:n}});async function M(n){let o=await l().then(t=>t.dir),i=s.join(o,...n)+".json";return y(async()=>{await a$2.unlink(i).catch(()=>{});})}J.remove=M;async function R(n){let o=await l().then(t=>t.dir),i=s.join(o,...n)+".json";return y(async()=>{var e=[];try{let t=c(e,await Lock.read(i));let r=await a$2.readFile(i,"utf-8");return JSON.parse(r)}catch(g){var u=g,c$1=true;}finally{d(e,u,c$1);}})}J.read=R;async function A(n,o){let i=await l().then(r=>r.dir),t=s.join(i,...n)+".json";return y(async()=>{var g=[];try{let r=c(g,await Lock.write(t));let e=await a$2.readFile(t,"utf-8").then(m=>JSON.parse(m));o(e);await a$2.writeFile(t,JSON.stringify(e,null,2),"utf-8");return e}catch(u){var c$1=u,w=true;}finally{d(g,c$1,w);}})}J.update=A;async function B(n,o){let i=await l().then(r=>r.dir),t=s.join(i,...n)+".json";return y(async()=>{var e=[];try{let r=c(e,await Lock.write(t));await a$2.mkdir(s.dirname(t),{recursive:!0});await a$2.writeFile(t,JSON.stringify(o,null,2),"utf-8");}catch(g){var u=g,c$1=true;}finally{d(e,u,c$1);}})}J.write=B;async function y(n){return n().catch(o=>{if(!(o instanceof Error))throw o;let i=o;throw i.code==="ENOENT"?new J.NotFoundError({message:`Resource not found: ${i.path}`}):o})}let k="**/*";async function q(n){let o=await l().then(i=>i.dir);try{let t=(await glob(k,{cwd:s.join(o,...n),nodir:!0})).map(r=>[...n,...r.slice(0,-5).split(s.sep)]);return t.sort(),t}catch{return []}}J.list=q;})($||($={}));export{$ as a};
@@ -1 +1 @@
1
- import {formatLocalISOCompact}from'@easbot/utils';import {CommandMetadataSchema}from'@easbot/plugin';export{CommandMetadataSchema as a}from'@easbot/plugin';async function h(n){let{ConfigMarkdown:t}=await import('./markdown-Z6UXVBNP.mjs'),e=await t.parse(n);return {metadata:CommandMetadataSchema.parse(e.data),content:e.content}}function x(n,t,e="command"){return {name:n.name,description:n.description,agent:n.agent,model:n.model,source:e,scope:n.scope,commandType:n.commandType??"prompt",hints:n.hints??[],hidden:n.hidden??false,execute:async(o,i)=>{let m=w(t,o);return {title:n.name,metadata:{sessionID:i.sessionID},output:m,success:true,parts:[{type:"text",text:m}]}}}}async function D(n,t="command"){let{glob:e}=await import('glob'),{Filesystem:o}=await import('@easbot/utils');if(!await o.isDir(n))return [];let i=await e("*.md",{cwd:n,absolute:true,nodir:true,follow:false,dot:false}),m=[];for(let r of i){let{ConfigMarkdown:d}=await import('./markdown-Z6UXVBNP.mjs'),{Bus:u}=await import('./bus-PFFRRCH3.mjs'),{Session:p}=await import('./session-BHXYW2JD.mjs'),{NamedError:C}=await import('@easbot/utils');await d.parse(r).then(a=>{let s=CommandMetadataSchema.parse(a.data),f=x(s,a.content,t);m.push(f);}).catch(a=>{let s=a instanceof Error?a.message:`Failed to load command ${r}`;u.publish(p.Event.Error,{error:new C.Unknown({message:s}).toObject()});});}return m}function g(n){return n instanceof Date?formatLocalISOCompact(n):Array.isArray(n)||n!==null&&typeof n=="object"&&n.constructor===Object?JSON.stringify(n,null,2):String(n)}function w(n,t){return typeof t=="string"?n.replace(/\{\{ARGUMENTS\}\}/gi,t):n.replace(/\{\{(\w+)\}\}/gi,(e,o)=>{let i=o.toUpperCase();if(i==="ARGUMENTS")return JSON.stringify(t);let m=t[o]??t[i];return m===void 0?`{{${o}}}`:g(m)})}function I(n,t){let{init:e,isEnabled:o,...i}=t;return {...i,name:n,isEnabled:o,init:e?async m=>({isEnabled:(await e(m)).isEnabled??(typeof o=="function"?await o():o)}):void 0}}export{h as b,x as c,D as d,w as e,I as f};
1
+ import {formatLocalISOCompact}from'@easbot/utils';import {CommandMetadataSchema}from'@easbot/plugin';export{CommandMetadataSchema as a}from'@easbot/plugin';async function h(n){let{ConfigMarkdown:t}=await import('./markdown-Z6UXVBNP.mjs'),e=await t.parse(n);return {metadata:CommandMetadataSchema.parse(e.data),content:e.content}}function x(n,t,e="command"){return {name:n.name,description:n.description,agent:n.agent,model:n.model,source:e,scope:n.scope,commandType:n.commandType??"prompt",hints:n.hints??[],hidden:n.hidden??false,execute:async(o,i)=>{let m=w(t,o);return {title:n.name,metadata:{sessionID:i.sessionID},output:m,success:true,parts:[{type:"text",text:m}]}}}}async function D(n,t="command"){let{glob:e}=await import('glob'),{Filesystem:o}=await import('@easbot/utils');if(!await o.isDir(n))return [];let i=await e("*.md",{cwd:n,absolute:true,nodir:true,follow:false,dot:false}),m=[];for(let r of i){let{ConfigMarkdown:d}=await import('./markdown-Z6UXVBNP.mjs'),{Bus:u}=await import('./bus-CBFYNJXU.mjs'),{Session:p}=await import('./session-SD2Y7TSF.mjs'),{NamedError:C}=await import('@easbot/utils');await d.parse(r).then(a=>{let s=CommandMetadataSchema.parse(a.data),f=x(s,a.content,t);m.push(f);}).catch(a=>{let s=a instanceof Error?a.message:`Failed to load command ${r}`;u.publish(p.Event.Error,{error:new C.Unknown({message:s}).toObject()});});}return m}function g(n){return n instanceof Date?formatLocalISOCompact(n):Array.isArray(n)||n!==null&&typeof n=="object"&&n.constructor===Object?JSON.stringify(n,null,2):String(n)}function w(n,t){return typeof t=="string"?n.replace(/\{\{ARGUMENTS\}\}/gi,t):n.replace(/\{\{(\w+)\}\}/gi,(e,o)=>{let i=o.toUpperCase();if(i==="ARGUMENTS")return JSON.stringify(t);let m=t[o]??t[i];return m===void 0?`{{${o}}}`:g(m)})}function I(n,t){let{init:e,isEnabled:o,...i}=t;return {...i,name:n,isEnabled:o,init:e?async m=>({isEnabled:(await e(m)).isEnabled??(typeof o=="function"?await o():o)}):void 0}}export{h as b,x as c,D as d,w as e,I as f};
@@ -1,11 +1,11 @@
1
- import {a as a$2,b as b$1}from'./chunk-CQVEAYYW.mjs';import {la,qa,sa,ra,na,oa,pa,Ha,ma,fa}from'./chunk-KY3H2HGJ.mjs';import {c as c$1}from'./chunk-ZBRXNYEM.mjs';import {b as b$2}from'./chunk-IHHFG47N.mjs';import {c}from'./chunk-DEZT7DOH.mjs';import {a as a$1}from'./chunk-EEWP2VV6.mjs';import {a}from'./chunk-LFYBZHOI.mjs';import {a as a$3}from'./chunk-I6MBTO75.mjs';import {b}from'./chunk-X6ISXWBN.mjs';import {Input,truncateToWidth,isKeyRelease,getKeybindings,Editor,matchesKey,Key,Container,Text,Markdown}from'@easbot/tui';import {loadTextFile,Shell,parseModelId,Fetch,Filesystem}from'@easbot/utils';import {randomUUID}from'crypto';import {readdirSync,existsSync}from'fs';import zt from'path';import {pathToFileURL}from'url';import {GatewayClient}from'@easbot/gateway';var _e=class extends Editor{constructor(t,n){super(t,n);b(this,"onEscape");b(this,"onCtrlC");b(this,"onCtrlD");b(this,"onCtrlG");b(this,"onCtrlL");b(this,"onCtrlO");b(this,"onCtrlP");b(this,"onCtrlT");b(this,"inputHandlerManager");}setInputHandlerManager(t){this.inputHandlerManager=t;}addToHistory(t){this.inputHandlerManager?.isHistoryBrowsing()||super.addToHistory(t);}handleInput(t){t.includes("\x1B")||t.includes("\r")||t.includes(`
1
+ import {a as a$2,b as b$1}from'./chunk-CQVEAYYW.mjs';import {ma,ra,ta,sa,oa,pa,qa,Ja,na,ga}from'./chunk-MMN3J3YS.mjs';import {c as c$1}from'./chunk-ZBRXNYEM.mjs';import {b as b$2}from'./chunk-JCC3ZOI6.mjs';import {c}from'./chunk-DEZT7DOH.mjs';import {a as a$1}from'./chunk-NQDXG75V.mjs';import {a}from'./chunk-LFYBZHOI.mjs';import {a as a$3}from'./chunk-6M4SMEZK.mjs';import {b}from'./chunk-X6ISXWBN.mjs';import {Input,truncateToWidth,isKeyRelease,getKeybindings,Editor,matchesKey,Key,Container,Text,Markdown}from'@easbot/tui';import {loadTextFile,Shell,parseModelId,Fetch,Filesystem}from'@easbot/utils';import {randomUUID}from'crypto';import {readdirSync,existsSync}from'fs';import zt from'path';import {pathToFileURL}from'url';import {GatewayClient}from'@easbot/gateway';var _e=class extends Editor{constructor(t,n){super(t,n);b(this,"onEscape");b(this,"onCtrlC");b(this,"onCtrlD");b(this,"onCtrlG");b(this,"onCtrlL");b(this,"onCtrlO");b(this,"onCtrlP");b(this,"onCtrlT");b(this,"inputHandlerManager");}setInputHandlerManager(t){this.inputHandlerManager=t;}addToHistory(t){this.inputHandlerManager?.isHistoryBrowsing()||super.addToHistory(t);}handleInput(t){t.includes("\x1B")||t.includes("\r")||t.includes(`
2
2
  `);let n=matchesKey(t,Key.up)||matchesKey(t,Key.down);if(n&&this.inputHandlerManager?this.inputHandlerManager.setHistoryBrowsing(true):this.inputHandlerManager&&!n&&(matchesKey(t,Key.ctrl("l"))||matchesKey(t,Key.ctrl("o"))||matchesKey(t,Key.ctrl("p"))||matchesKey(t,Key.ctrl("g"))||matchesKey(t,Key.ctrl("t"))||matchesKey(t,Key.escape)||matchesKey(t,Key.ctrl("c"))||matchesKey(t,Key.ctrl("d"))||this.inputHandlerManager.setHistoryBrowsing(false)),matchesKey(t,Key.ctrl("l"))&&this.onCtrlL){this.onCtrlL();return}if(matchesKey(t,Key.ctrl("o"))&&this.onCtrlO){this.onCtrlO();return}if(matchesKey(t,Key.ctrl("p"))&&this.onCtrlP){this.onCtrlP();return}if(matchesKey(t,Key.ctrl("g"))&&this.onCtrlG){this.onCtrlG();return}if(matchesKey(t,Key.ctrl("t"))&&this.onCtrlT){this.onCtrlT();return}if(matchesKey(t,Key.escape)){if(this.isShowingAutocomplete()){super.handleInput(t);return}if(this.onEscape){this.onEscape();return}}if(matchesKey(t,Key.ctrl("c"))&&this.onCtrlC){this.onCtrlC();return}if(matchesKey(t,Key.ctrl("d"))){this.getText().length===0&&this.onCtrlD&&this.onCtrlD();return}super.handleInput(t);}};var x={text:"#E8E3D5",dim:"#7B7F87",accent:"#F6C453",accentSoft:"#F2A65A",border:"#3C414B",userBg:"#2B2F36",userText:"#5A9F7A",userLabel:"#5A9F7A",systemText:"#9BA3B2",systemLabel:"#7B7F87",assistantLabel:"#B85C5C",subagentLabel:"#9B72CF",subagentBg:"#2A2535",toolPendingBg:"#1F2A2F",toolSuccessBg:"#1E2D23",toolErrorBg:"#2F1F1F",toolTitle:"#F6C453",toolOutput:"#E1DACB",quote:"#8CC8FF",quoteBorder:"#3B4D6B",code:"#F0C987",codeBorder:"#343A45",link:"#7DD3A5",error:"#F97066",success:"#7DD3A5"},I=s=>e=>`\x1B[38;2;${Lt(s)}m${e}\x1B[0m`,Ce=s=>e=>`\x1B[48;2;${Lt(s)}m${e}\x1B[0m`,ve=s=>`\x1B[1m${s}\x1B[0m`,rt=s=>`\x1B[3m${s}\x1B[0m`;function Lt(s){let e=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(s);if(!e)return "255;255;255";let t=Number.parseInt(e[1]||"0",16),n=Number.parseInt(e[2]||"0",16),r=Number.parseInt(e[3]||"0",16);return `${t};${n};${r}`}var ts={selectedPrefix:s=>I(x.accent)(s),selectedText:s=>ve(I(x.accent)(s)),description:s=>I(x.dim)(s),scrollInfo:s=>I(x.dim)(s),noMatch:s=>I(x.dim)(s)},ee={fg:I(x.text),assistantText:s=>s,dim:I(x.dim),accent:I(x.accent),accentSoft:I(x.accentSoft),success:I(x.success),error:I(x.error),header:s=>ve(I(x.accent)(s)),system:I(x.systemText),userBg:Ce(x.userBg),userText:I(x.userText),userLabel:s=>I(x.userLabel)(s),systemLabel:s=>I(x.systemLabel)(s),assistantLabel:s=>I(x.assistantLabel)(s),subagentLabel:s=>I(x.subagentLabel)(s),subagentBg:Ce(x.subagentBg),subagent:s=>I(x.subagentLabel)(s),toolTitle:I(x.toolTitle),toolOutput:I(x.toolOutput),toolPendingBg:Ce(x.toolPendingBg),toolSuccessBg:Ce(x.toolSuccessBg),toolErrorBg:Ce(x.toolErrorBg),border:I(x.border),bold:ve,italic:rt,user:s=>I(x.userText)(s),assistant:s=>I(x.text)(s),code:I(x.code),quote:I(x.quote),link:I(x.link),tool:I(x.toolTitle),thinking:s=>rt(I(x.dim)(s)),warning:I(x.accentSoft),muted:I(x.dim),highlight:s=>ve(I(x.accent)(s))},ss=ts;function ns(s,e){let t=s.split(`
3
3
  `);if(!e)return t.map(a=>I(x.code)(a));let n={keyword:I("#C586C0"),string:I("#CE9178"),comment:I("#6A9955"),number:I("#B5CEA8"),function:I("#DCDCAA"),type:I("#4EC9B0"),operator:I("#D4D4D4"),default:I(x.code)},r=e.toLowerCase();return r==="typescript"||r==="ts"||r==="javascript"||r==="js"?t.map(a=>is(a,n)):r==="python"||r==="py"?t.map(a=>rs(a,n)):r==="bash"||r==="sh"||r==="shell"?t.map(a=>os(a,n)):r==="json"?t.map(a=>as(a,n)):t.map(a=>n.default(a))}function is(s,e){if(s.trim().startsWith("//"))return e.comment?.(s)??s;let t=/\b(const|let|var|function|async|await|return|if|else|for|while|class|interface|type|import|export|from|default|new|this|super|extends|implements)\b/g,n=s.replace(t,r=>e.keyword?.(r)??r);return n=n.replace(/(['"`])(?:(?=(\\?))\2.)*?\1/g,r=>e.string?.(r)??r),n=n.replace(/\b\d+(\.\d+)?\b/g,r=>e.number?.(r)??r),n}function rs(s,e){if(s.trim().startsWith("#"))return e.comment?.(s)??s;let t=/\b(def|class|if|elif|else|for|while|return|import|from|as|try|except|finally|with|async|await|lambda|yield|pass|break|continue|None|True|False)\b/g,n=s.replace(t,r=>e.keyword?.(r)??r);return n=n.replace(/(['"])(?:(?=(\\?))\2.)*?\1/g,r=>e.string?.(r)??r),n=n.replace(/\b\d+(\.\d+)?\b/g,r=>e.number?.(r)??r),n}function os(s,e){if(s.trim().startsWith("#"))return e.comment?.(s)??s;let t=/\b(if|then|else|elif|fi|for|while|do|done|case|esac|function|return|exit|export|source|alias)\b/g,n=s.replace(t,r=>e.keyword?.(r)??r);return n=n.replace(/(['"])(?:(?=(\\?))\2.)*?\1/g,r=>e.string?.(r)??r),n=n.replace(/\$\{?[\w_]+\}?/g,r=>e.type?.(r)??r),n}function as(s,e){let t=s;return t=t.replace(/"([^"]+)":/g,(n,r)=>`${e.type?.(`"${r}"`)??`"${r}"`}: `),t=t.replace(/:\s*"([^"]+)"/g,(n,r)=>`: ${e.string?.(`"${r}"`)??`"${r}"`}`),t=t.replace(/:\s*(\d+(\.\d+)?)/g,(n,r)=>`: ${e.number?.(r)??r}`),t=t.replace(/:\s*(true|false|null)/g,(n,r)=>`: ${e.keyword?.(r)??r}`),t}var xe={heading:s=>ve(I(x.accent)(s)),link:s=>I(x.link)(s),linkUrl:s=>I(x.dim)(s),code:s=>I(x.code)(s),codeBlock:s=>I(x.code)(s),codeBlockBorder:s=>I(x.codeBorder)(s),quote:s=>I(x.quote)(s),quoteBorder:s=>I(x.quoteBorder)(s),hr:s=>I(x.border)(s),listBullet:s=>I(x.accentSoft)(s),bold:ve,italic:rt,strikethrough:s=>`\x1B[9m${s}\x1B[0m`,underline:s=>`\x1B[4m${s}\x1B[0m`,highlightCode:ns,codeBlockIndent:" "},Mt={borderColor:s=>I(x.border)(s),selectList:ss};var z=a.create({service:"cli-tui-chatlog"}),ot=null;function ds(){if(ot)return ot;let s=a$1("tui.system.tool_executing",{vars:{tool:""}}).split(":")[0]?.trim()||"",e=a$1("tui.system.tool_completed",{vars:{tool:""}}).split(":")[0]?.trim()||"",t=a$1("tui.system.tool_failed",{vars:{tool:""}}).split(":")[0]?.trim()||"",n=[],r=a=>a.replace(/[.*+?^${}()|[\]\\]/g,"\\$&");return s&&s!=="tui.system.tool_executing"&&n.push(new RegExp(r(s),"i")),e&&e!=="tui.system.tool_completed"&&n.push(new RegExp(r(e),"i")),t&&t!=="tui.system.tool_failed"&&n.push(new RegExp(r(t),"i")),n.push(/[⚙🔧]\s*(执行工具|Executing tool)/iu,/[✓✅]\s*(工具完成|工具执行完成|Tool completed|Tool execution completed)/iu,/[✗❌]\s*(工具失败|工具执行失败|Tool failed|Tool execution failed)/iu),ot=n,n}var $e=class extends Container{constructor(){super();b(this,"messages",[]);b(this,"maxMessages",1e3);b(this,"containerWidth",80);b(this,"getState");b(this,"cachedProtocolMetadata",null);b(this,"_cachedPrimaryAgents",null);}setStateGetter(t){this.getState=t,this.loadProtocolMetadata();}async loadProtocolMetadata(){let t=this.getState?.();if(t?.sdk)try{let n=await t.sdk.app.context({});n.data?.protocolMetadata&&(this.cachedProtocolMetadata=n.data.protocolMetadata);}catch(n){z.debug("Failed to load protocol metadata",{error:n});}}setWidth(t){this.containerWidth=t;}addUser(t,n,r){this.addMessage("user",t,n,r);}addAssistant(t,n,r){this.addMessage("assistant",t,n,r);}addSystem(t,n,r){this.addMessage("system",t,n,r);}addMessage(t,n,r,a){if(z.debug("addMessage called",{type:t,content:n.substring(0,100),id:r,currentMessagesCount:this.messages.length}),r&&this.messages.findIndex(l=>l.id===r)!==-1){z.debug("Message with same ID already exists, skipping",{id:r});return}this.messages.push({type:t,content:n,timestamp:Date.now(),id:r,metadata:a}),z.debug("After push, messages count",{count:this.messages.length}),this.messages.length>this.maxMessages&&(this.messages=this.messages.slice(-this.maxMessages)),z.debug("Calling updateChildren"),this.updateChildren(),z.debug("updateChildren completed");}clear(){this.messages=[],this.updateChildren();}updateChildren(){let t=this.getState?.(),n=t?.toolsExpanded??false,r=t?.showThinking??false,a=t?.verboseLevel??"off",o=t?.messageLimit??50;z.debug("updateChildren called",{messagesCount:this.messages.length,childrenBeforeClear:this.children.length,toolsExpanded:n,showThinking:r,verboseLevel:a,messageLimit:o}),this.children=[],z.debug("Children cleared",{childrenAfterClear:this.children.length});let l=new Set,d=0,u=this.messages.slice(-o);z.debug("Applied message limit",{originalCount:this.messages.length,limitedCount:u.length,messageLimit:o});for(let c of u){if(c.id&&l.has(c.id)){z.debug("Skipping duplicate ID",{id:c.id});continue}if(!n&&this.shouldFilterToolMessage(c)){z.debug("Filtering tool message (tools collapsed)",{content:c.content.substring(0,50),metadata:c.metadata});continue}if(c.id&&!r&&this.shouldFilterThinkingMessage(c)){z.debug("Filtering thinking message (thinking mode off)",{content:c.content.substring(0,50),metadata:c.metadata});continue}if(c.id&&a==="off"&&this.shouldFilterBackgroundAgentMessage(c)){z.debug("Filtering background agent message (verbose off)",{content:c.content.substring(0,50),agent:c.metadata?.agent});continue}if(c.type==="assistant"&&this.shouldFilterAssistantMessage(c.content)){z.debug("Filtering assistant metadata",{content:c.content.substring(0,50)});continue}c.id&&l.add(c.id),z.debug("Rendering message",{type:c.type,content:c.content.substring(0,50),id:c.id,hasId:!!c.id,metadata:c.metadata}),this.renderMessage(c),d++;}z.debug("updateChildren completed",{childrenAfterRender:this.children.length,renderedCount:d}),this.invalidate();}shouldFilterSystemMessage(t){return ds().some(r=>r.test(t))}shouldFilterToolMessage(t){return t.metadata?.isTool===true?true:t.type==="system"?this.shouldFilterSystemMessage(t.content):false}shouldFilterThinkingMessage(t){return t.metadata?.isThinking===true}shouldFilterBackgroundAgentMessage(t){let n=t.metadata?.agent;if(!n)return false;let r=this.getState?.();if(!r?.sdk)return false;let a=async()=>{try{return ((await r.sdk.app.agents({})).data||[]).filter(d=>d.mode==="primary"&&d.hidden!==!0).map(d=>d.name)}catch{return []}};return this._cachedPrimaryAgents?!this._cachedPrimaryAgents.includes(n):(a().then(o=>{this._cachedPrimaryAgents=o,this.updateChildren();}),false)}shouldFilterAssistantMessage(t){return /^>\s+[\w-]+(\s+·\s+[\w-]+)?$/.test(t.trim())}renderMessage(t){let n=new Date(t.timestamp).toLocaleTimeString();switch(t.type){case "user":{if(t.metadata?.isSubagentResult){let l=t.metadata.agent||"SubAgent",d=ee.subagentLabel(`[${n}] ${l}: `),u=new Text(d,1,0);this.addChild(u);let p=new Markdown(t.content,0,0,xe).render(this.containerWidth-2);for(let _ of p){let $=new Text(_,1,0);this.addChild($);}break}let r=ee.userLabel(`[${n}] ${a$1("tui.chatlog.user_prefix")}: `),a=new Text(r,1,0);if(this.addChild(a),t.content.trim().startsWith("/")){let l=ee.accent(t.content),d=new Text(l,1,0);this.addChild(d);}else {let l=ee.userText(t.content),u=new Markdown(l,0,0,xe).render(this.containerWidth-2);for(let c of u){let p=new Text(c,1,0);this.addChild(p);}}break}case "assistant":{let r=a$1("tui.chatlog.assistant_prefix");this.cachedProtocolMetadata?.name?r=this.cachedProtocolMetadata.name:t.metadata?.agent&&(r=t.metadata.agent);let a=ee.assistantLabel(`[${n}] ${r}: `),o=new Text(a,1,0);this.addChild(o);let d=new Markdown(t.content,0,0,xe).render(this.containerWidth-2);for(let u of d){let c=new Text(u,1,0);this.addChild(c);}break}case "system":{let r=ee.systemLabel(`[${n}] ${a$1("tui.chatlog.system_prefix")}: `),a=new Text(r,1,0);this.addChild(a);let o=ee.system(t.content),d=new Markdown(o,0,0,xe).render(this.containerWidth-2);for(let u of d){let c=new Text(u,1,0);this.addChild(c);}break}}}};var cs={q:"exit",quit:"exit",h:"help",s:"status",a:"agent",m:"model",sess:"session",skills:"skill",commands:"command",mcps:"mcp",models:"model",agents:"agent",sessions:"session",btw:"command"},us=new Set(["btw","sync","abort","compact"]);function Dt(s){let e=s.replace(/^\//,"").trim();if(!e)return {name:"",args:""};let[t="",...n]=e.split(/\s+/),r=t.toLowerCase();return us.has(r)?{name:"command",args:e}:{name:cs[r]??r,args:n.join(" ").trim()}}var at=[{name:"help",description:a$1("tui.command.help.description")},{name:"status",description:a$1("tui.command.status.description")},{name:"command",description:a$1("tui.command.command.description")},{name:"agent",description:a$1("tui.command.agent.description")},{name:"session",description:a$1("tui.command.session.description")},{name:"new",description:a$1("tui.command.new.description")},{name:"fork",description:a$1("tui.command.fork.description")},{name:"reset",description:a$1("tui.command.reset.description")},{name:"model",description:a$1("tui.command.model.description")},{name:"settings",description:a$1("tui.command.settings.description")},{name:"verbose",description:a$1("tui.command.verbose.description")},{name:"thinking",description:a$1("tui.command.thinking.description")},{name:"abort",description:a$1("tui.command.abort.description")},{name:"clear",description:a$1("tui.command.clear.description")},{name:"compact",description:a$1("tui.command.compact.description")},{name:"skill",description:a$1("tui.command.skill.description")},{name:"mcp",description:a$1("tui.command.mcp.description")},{name:"exit",description:a$1("tui.command.exit.description")}];async function _t(s,e){let t=[...at];if(s)try{let r=(await s.command.list({contextMode:e})).data||[],a=new Set(at.map(o=>o.name));for(let o of r)a.has(o.name)||t.push({name:o.name,description:o.description||""});}catch(n){console.error("Failed to fetch dynamic commands:",n);}return t}function Rt(){return at}function $t(){let s=[];return s.push("# "+a$1("tui.help.title")),s.push(""),s.push("## "+a$1("tui.help.section.basic")),s.push("- `"+a$1("tui.help.command.help")+"`"),s.push("- `"+a$1("tui.help.command.status")+"`"),s.push("- `"+a$1("tui.help.command.command")+"`"),s.push(""),s.push("## "+a$1("tui.help.section.agent")),s.push("- `"+a$1("tui.help.command.agent")+"`"),s.push(""),s.push("## "+a$1("tui.help.section.session")),s.push("- `"+a$1("tui.help.command.session")+"`"),s.push("- `"+a$1("tui.help.command.new")+"`"),s.push("- `"+a$1("tui.help.command.fork")+"`"),s.push("- `"+a$1("tui.help.command.reset")+"`"),s.push(""),s.push("## "+a$1("tui.help.section.model")),s.push("- `"+a$1("tui.help.command.model")+"`"),s.push(""),s.push("## "+a$1("tui.help.section.settings")),s.push("- `"+a$1("tui.help.command.settings")+"`"),s.push("- `"+a$1("tui.help.command.verbose")+"`"),s.push("- `"+a$1("tui.help.command.thinking")+"`"),s.push(""),s.push("## "+a$1("tui.help.section.operations")),s.push("- `"+a$1("tui.help.command.abort")+"`"),s.push("- `"+a$1("tui.help.command.clear")+"`"),s.push("- `"+a$1("tui.help.command.compact")+"`"),s.push(""),s.push("## "+a$1("tui.help.section.skill")),s.push("- `"+a$1("tui.help.command.skill")+"`"),s.push("- `"+a$1("tui.help.command.mcp")+"`"),s.push(""),s.push("## "+a$1("tui.help.section.exit")),s.push("- `"+a$1("tui.help.command.exit")+"`"),s.push(""),s.push("## "+a$1("tui.help.section.local")),s.push("- `"+a$1("tui.help.command.local")+"`"),s.push(""),s.push("## "+a$1("tui.help.section.shortcuts")),s.push("- `"+a$1("tui.help.shortcut.ctrl_c")+"`"),s.push("- `"+a$1("tui.help.shortcut.ctrl_d")+"`"),s.push("- `"+a$1("tui.help.shortcut.ctrl_l")+"`"),s.push("- `"+a$1("tui.help.shortcut.ctrl_p")+"`"),s.push("- `"+a$1("tui.help.shortcut.ctrl_g")+"`"),s.push("- `"+a$1("tui.help.shortcut.esc")+"`"),s.join(`
4
4
  `)}var ms=/[\s\-_./:#@]/;function Ht(s,e){return e===0||ms.test(s[e-1]??"")}function Ft(s,e){if(!e)return null;let t=s.toLowerCase(),n=e.toLowerCase(),r=t.length-n.length;if(r<0)return null;for(let a=0;a<=r;a++)if(t.startsWith(n,a)&&Ht(t,a))return a;return null}function gs(s,e){if(s.length===0)return 0;if(s.length>e.length)return null;let t=0,n=0,r=-1,a=0;for(let o=0;o<e.length&&t<s.length;o++)if(e[o]===s[t]){let l=Ht(e,o);r===o-1?(a++,n-=a*5):(a=0,r>=0&&(n+=(o-r-1)*2)),l&&(n-=10),n+=o*.1,r=o,t++;}return t<s.length?null:n}function qt(s,e){let t=e.trim();if(!t)return s;let n=t.split(/\s+/).filter(a=>a.length>0);if(n.length===0)return s;let r=[];for(let a of s){let o=a.searchTextLower??"",l=0,d=true;for(let u of n){let c=gs(u,o);if(c!==null)l+=c;else {d=false;break}}d&&r.push({item:a,score:l});}return r.sort((a,o)=>a.score-o.score),r.map(a=>a.item)}var ys="\x1B",Bt=new RegExp(`${ys}\\[[0-9;]*m`,"g"),se=class se{constructor(e,t,n){b(this,"items");b(this,"filteredItems");b(this,"selectedIndex",0);b(this,"maxVisible");b(this,"theme");b(this,"searchInput");b(this,"regexCache",new Map);b(this,"onSelect");b(this,"onCancel");b(this,"onSelectionChange");b(this,"compareByScore",(e,t)=>e.tier!==t.tier?e.tier-t.tier:e.score!==t.score?e.score-t.score:this.getItemLabel(e.item).localeCompare(this.getItemLabel(t.item)));this.items=e,this.filteredItems=e,this.maxVisible=t,this.theme=n,this.searchInput=new Input;}getCachedRegex(e){let t=this.regexCache.get(e);return t||(t=new RegExp(this.escapeRegex(e),"gi"),this.regexCache.set(e,t)),t}updateFilter(){let e=this.searchInput.getValue().trim();e?this.filteredItems=this.smartFilter(e):this.filteredItems=this.items,this.selectedIndex=0,this.notifySelectionChange();}smartFilter(e){let t=e.toLowerCase(),n=[],r=[];for(let o of this.items){let l=this.getItemLabel(o),d=o.description??"",u=a$2(l).toLowerCase(),c=a$2(d).toLowerCase(),p=u.indexOf(t);if(p!==-1){n.push({item:o,tier:0,score:p});continue}let _=Ft(u,t);if(_!==null){n.push({item:o,tier:1,score:_});continue}let $=c.indexOf(t);if($!==-1){n.push({item:o,tier:2,score:$});continue}let ne=o.searchText??"";r.push({item:o,searchTextLower:[l,d,ne].map(A=>a$2(A)).filter(Boolean).join(" ").toLowerCase()});}n.sort(this.compareByScore);let a=qt(r,t);return [...n.map(o=>o.item),...a.map(o=>o.item)]}escapeRegex(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}getItemLabel(e){return e.label||e.value}splitAnsiParts(e){let t=[];Bt.lastIndex=0;let n=0,r;for(;(r=Bt.exec(e))!==null;)r.index>n&&t.push({text:e.slice(n,r.index),isAnsi:false}),t.push({text:r[0],isAnsi:true}),n=r.index+r[0].length;return n<e.length&&t.push({text:e.slice(n),isAnsi:false}),t}highlightMatch(e,t){let n=t.trim().split(/\s+/).map(o=>o.toLowerCase()).filter(o=>o.length>0);if(n.length===0)return e;let r=Array.from(new Set(n)).toSorted((o,l)=>l.length-o.length),a=this.splitAnsiParts(e);for(let o of r){let l=this.getCachedRegex(o),d=[];for(let u of a){if(u.isAnsi){d.push(u);continue}l.lastIndex=0;let c=u.text.replace(l,p=>this.theme.matchHighlight(p));if(c===u.text){d.push(u);continue}d.push(...this.splitAnsiParts(c));}a=d;}return a.map(o=>o.text).join("")}setSelectedIndex(e){this.selectedIndex=Math.max(0,Math.min(e,this.filteredItems.length-1));}invalidate(){this.searchInput.invalidate();}render(e){let t=[],r=this.theme.searchPrompt("search: "),a=Math.max(1,e-b$1(r)),l=this.searchInput.render(a)[0]??"";t.push(`${r}${this.theme.searchInput(l)}`),t.push("");let d=this.searchInput.getValue().trim();if(this.filteredItems.length===0)return t.push(this.theme.noMatch(" No matches")),t;let u=Math.max(0,Math.min(this.selectedIndex-Math.floor(this.maxVisible/2),this.filteredItems.length-this.maxVisible)),c=Math.min(u+this.maxVisible,this.filteredItems.length);for(let p=u;p<c;p++){let _=this.filteredItems[p];if(!_)continue;let $=p===this.selectedIndex;t.push(this.renderItemLine(_,$,e,d));}if(this.filteredItems.length>this.maxVisible){let p=`${this.selectedIndex+1}/${this.filteredItems.length}`;t.push(this.theme.scrollInfo(` ${p}`));}return t}renderItemLine(e,t,n,r){let a=t?"\u2192 ":" ",o=a.length,l=this.getItemLabel(e),d=e.description;if(d){let $=this.getDescriptionLayout(n,o);if($){let ne=truncateToWidth(l,$.maxValueWidth,""),A=this.highlightMatch(ne,r),M=b$1(A),h=$.availableWidth-M-$.spacingWidth;if(h>=se.DESCRIPTION_MIN_WIDTH){let re=" ".repeat($.spacingWidth),H=truncateToWidth(d,h,""),w=this.highlightMatch(H,r),f=t?w:this.theme.description(w),g=`${a}${A}${re}${f}`;return t?this.theme.selectedText(g):g}}}let u=n-o-2,c=truncateToWidth(l,u,""),p=this.highlightMatch(c,r),_=`${a}${p}`;return t?this.theme.selectedText(_):_}getDescriptionLayout(e,t){if(e<=se.DESCRIPTION_LAYOUT_MIN_WIDTH)return null;let n=Math.max(1,e-t-se.RIGHT_MARGIN_WIDTH),r=n-se.DESCRIPTION_MIN_WIDTH-se.DESCRIPTION_SPACING_WIDTH;return r<1?null:{availableWidth:n,maxValueWidth:r,spacingWidth:se.DESCRIPTION_SPACING_WIDTH}}handleInput(e){if(isKeyRelease(e))return;let t=getKeybindings(),n=!this.searchInput.getValue().trim();if(t.matches(e,"tui.select.up")||t.matches(e,"tui.editor.cursorUp")||n&&e==="k"){this.selectedIndex=Math.max(0,this.selectedIndex-1),this.notifySelectionChange();return}if(t.matches(e,"tui.select.down")||t.matches(e,"tui.editor.cursorDown")||n&&e==="j"){this.selectedIndex=Math.min(this.filteredItems.length-1,this.selectedIndex+1),this.notifySelectionChange();return}if(t.matches(e,"tui.select.confirm")){let o=this.filteredItems[this.selectedIndex];o&&this.onSelect&&this.onSelect(o);return}if(t.matches(e,"tui.select.cancel")){this.onCancel&&this.onCancel();return}let r=this.searchInput.getValue();this.searchInput.handleInput(e);let a=this.searchInput.getValue();r!==a&&this.updateFilter();}notifySelectionChange(){let e=this.filteredItems[this.selectedIndex];e&&this.onSelectionChange&&this.onSelectionChange(e);}getSelectedItem(){return this.filteredItems[this.selectedIndex]??null}};b(se,"DESCRIPTION_LAYOUT_MIN_WIDTH",40),b(se,"DESCRIPTION_MIN_WIDTH",12),b(se,"DESCRIPTION_SPACING_WIDTH",2),b(se,"RIGHT_MARGIN_WIDTH",2);var He=se;var ge=a.create({service:"cli-tui-selectors"}),Ss={selectedPrefix:s=>`\x1B[36m${s}\x1B[0m`,selectedText:s=>`\x1B[1;36m${s}\x1B[0m`,description:s=>`\x1B[90m${s}\x1B[0m`,scrollInfo:s=>`\x1B[90m${s}\x1B[0m`,noMatch:s=>`\x1B[90m${s}\x1B[0m`,searchPrompt:s=>`\x1B[36m${s}\x1B[0m`,searchInput:s=>s,matchHighlight:s=>`\x1B[1;33m${s}\x1B[0m`};function pe(s,e){ge.debug("Creating searchable select list",{itemsCount:s.length,title:e.title});let t=e.maxVisible??10,n=new He(s,t,Ss);return e.onSelect&&(n.onSelect=e.onSelect),e.onCancel&&(n.onCancel=e.onCancel),n}function Fe(s,e){ge.info("Creating model selector with data");let t=[];for(let[n,r]of Object.entries(s))if(r?.models)for(let[a,o]of Object.entries(r.models))t.push({label:`${r.name} - ${o.name}`,value:`${n}/${a}`,description:o.family||""});return ge.debug("Model list loaded",{count:t.length}),pe(t,{title:e.title||a$1("tui.selector.model.title"),placeholder:e.placeholder||a$1("tui.selector.model.placeholder"),onSelect:e.onSelect,onCancel:e.onCancel})}function qe(s,e){ge.info("Creating session selector with data",{count:s.length});let t=s.map(n=>({label:n.title||n.id,value:n.id,description:`\u66F4\u65B0\u65F6\u95F4: ${n.time?.updated?new Date(n.time.updated).toLocaleString():"\u672A\u77E5"}`}));return ge.debug("Session list loaded",{count:t.length}),pe(t,{title:e.title||a$1("tui.selector.session.title"),placeholder:e.placeholder||a$1("tui.selector.session.placeholder"),onSelect:e.onSelect,onCancel:e.onCancel})}function Be(s,e){ge.info("Creating agent selector with data",{count:s.length});let t=s.map(n=>({label:n.name,value:n.name,description:n.description||(n.mode?`\u6A21\u5F0F: ${n.mode}`:"")}));return ge.debug("Agent list loaded",{count:t.length}),pe(t,{title:e.title||a$1("tui.selector.agent.title"),placeholder:e.placeholder||a$1("tui.selector.agent.placeholder"),onSelect:e.onSelect,onCancel:e.onCancel})}var T=a.create({service:"cli-tui-command-handlers"});async function vs(s,e){let t=[];t.push("## "+a$1("tui.handler.status.title")),t.push(""),t.push("### "+a$1("tui.handler.status.system_info")),t.push("- **"+a$1("tui.handler.status.system")+"**: "+a$1("tui.handler.status.ok")),t.push("- **"+a$1("tui.handler.status.directory")+"**: `"+e+"`"),t.push(""),t.push("### "+a$1("tui.handler.status.global_paths")),t.push("- **home**: `"+a$3.Path.home+"`"),t.push("- **data**: `"+a$3.Path.data+"`"),t.push("- **bin**: `"+a$3.Path.bin+"`"),t.push("- **log**: `"+a$3.Path.log+"`"),t.push("- **cache**: `"+a$3.Path.cache+"`"),t.push("- **config**: `"+a$3.Path.config+"`"),t.push("- **state**: `"+a$3.Path.state+"`"),t.push(""),t.push("### "+a$1("tui.handler.status.session_info")),t.push("- **"+a$1("tui.handler.status.agent_label")+"**: "+(s.agent||a$1("tui.handler.status.not_set"))),t.push("- **"+a$1("tui.handler.status.session_label")+"**: "+(s.currentSessionKey||a$1("tui.handler.status.not_set"))),t.push("- **"+a$1("tui.handler.status.model_label")+"**: "+(s.sessionInfo.model||a$1("tui.handler.status.not_set"))),t.push("");try{let r=(await s.sdk.command.list({})).data||[],a=r.filter(d=>d.source==="skill"),o=r.filter(d=>d.source==="mcp"),l=r.filter(d=>d.source==="command");if(t.push("### "+a$1("tui.handler.status.skills")+" ("+a.length+")"),a.length>0){let d=a.map(u=>u.name).join(", ");t.push(d);}t.push("");try{let u=(await s.sdk.mcp.status({})).data||{},p=(await s.sdk.mcp.tools({})).data||{},_=Object.entries(u).filter(([,$])=>$.status==="connected");if(t.push("### "+a$1("tui.handler.status.mcp")+" ("+_.length+")"),_.length>0)for(let[$]of _){let ne=p[$]||[];ne.length>0?t.push("- **"+$+"** ("+ne.length+"): "+ne.join(", ")):t.push("- **"+$+"**");}t.push("");}catch(d){T.error("Failed to get MCP status",{error:d}),t.push("### "+a$1("tui.handler.status.mcp")+" (0)"),t.push("");}if(t.push("### "+a$1("tui.handler.status.commands")+" ("+l.length+")"),l.length>0){let d=l.map(u=>u.name).join(", ");t.push(d);}t.push(""),t.push("### "+a$1("tui.handler.status.services"));try{if(!s.sdk?.lsp)T.warn("SDK or LSP API is not initialized"),t.push("- **LSP**: "+a$1("tui.handler.status.error_loading_lsp"));else {let d=await s.sdk.lsp.status({});if(!d||typeof d!="object")T.warn("LSP status response is not a valid object",{response:d,responseType:typeof d}),t.push("- **LSP**: "+a$1("tui.handler.status.error_loading_lsp"));else {let u=Array.isArray(d.data)?d.data:[];if(t.push("- **LSP ("+u.length+")**: "),u.length>0){let c=u.filter(p=>p&&typeof p=="object").map(p=>p?.name||"unknown").join(", ");t.push(" "+c);}else t.push(" "+a$1("tui.handler.status.no_lsp"));}}}catch(d){T.error("Failed to get LSP status",{error:d}),t.push("- **LSP**: "+a$1("tui.handler.status.error_loading_lsp"));}}catch(n){T.error("Failed to get command list for status",{error:n}),t.push(""),t.push("_"+a$1("tui.handler.status.error_loading")+"_");}return t.join(`
5
- `)}function Ut(s,e){let{chatLog:t,tui:n,directory:r,openOverlay:a,closeOverlay:o,requestExit:l,setActivityStatus:d,updateFooter:u,refreshSessionInfo:c$1,loadHistory:p,setSession:_,refreshAgents:$,abortActive:ne}=s,A=()=>{o();},M=async(H,w,f,g)=>{try{if(!w){T.warn("Cannot publish command event: no session ID",{name:H});return}await ma(e,fa.Event.Executed,{name:H,sessionID:w,arguments:f,messageID:g}),T.debug("Command event published",{name:H,sessionId:w,messageId:g});}catch(k){T.error("Failed to publish command event",{name:H,sessionId:w,messageId:g,error:k instanceof Error?k.message:String(k),stack:k instanceof Error?k.stack:void 0});}},he=async H=>{T.debug("Handle command called",{raw:H});let{name:w,args:f}=Dt(H);if(T.debug("Parsed command",{name:w,args:f}),!w){T.debug("No command name, returning");return}try{switch(w){case "help":T.debug("Executing help command"),t.addSystem($t()),T.debug("Help text added to chatLog"),await M("help",e.currentSessionId||"",f||"",randomUUID());break;case "commands":case "command":case "cmds":case "cmd":{try{let b=((await e.sdk.command.list({})).data||[]).filter(y=>y.source==="command");if(b.length===0){t.addSystem(a$1("tui.handler.command.empty")),await M(w,e.currentSessionId||"",f||"",randomUUID());break}if(f){let y=f.split(/\s+/),G=y[0],te=y.slice(1).join(" ");b.some(ae=>ae.name===G)?await re("command",G,e,t,d,te||void 0):t.addSystem(a$1("tui.handler.command.not_found",{vars:{name:G}})),await M(w,e.currentSessionId||"",f,randomUUID());break}T.info("Opening command selector");let S=b.map(y=>({label:y.name,description:y.description||"",value:y.name})),E=pe(S,{onSelect:async y=>{A(),s.setInputText?s.setInputText(`/command ${y.value} `):await re("command",y.value,e,t,d);},onCancel:A});a(E),await M(w,e.currentSessionId||"","",randomUUID());}catch(g){T.error("Failed to handle command",{error:g}),t.addSystem(a$1("tui.handler.command.error",{vars:{error:String(g)}})),await M(w,e.currentSessionId||"",f||"",randomUUID());}break}case "status":t.addSystem(await vs(e,r)),await M("status",e.currentSessionId||"",f||"",randomUUID());break;case "agents":case "agent":if(f)e.agent=f,t.addSystem(a$1("tui.handler.agent.switched",{vars:{agentId:f}})),u(),await b$2(e),await M(w,e.currentSessionId||"",f,randomUUID());else {T.info("Opening agent selector");let k=(await qa(e)).filter(S=>S.mode==="primary"&&S.hidden!==!0),b=Be(k,{onSelect:async S=>{e.agent=S.value,t.addSystem(a$1("tui.handler.agent.switched",{vars:{agentId:S.value}})),u(),A(),await b$2(e);},onCancel:A});a(b),await M(w,e.currentSessionId||"","",randomUUID());}break;case "sessions":case "session":if(f&&_)await _(f),u(),await M(w,e.currentSessionId||"",f,randomUUID());else {T.info("Opening session selector");let g=await ra(e),k=qe(g,{onSelect:async b=>{_&&await _(b.value),u(),A();},onCancel:A});a(k),await M(w,e.currentSessionId||"","",randomUUID());}break;case "models":case "model":if(f)e.sessionInfo.model=f,t.addSystem(a$1("tui.handler.model.set",{vars:{model:f}})),u(),await b$2(e),await M(w,e.currentSessionId||"",f,randomUUID());else {T.info("Opening model selector");let g=await sa(e),k=Fe(g,{onSelect:async b=>{e.sessionInfo.model=b.value,t.addSystem(a$1("tui.handler.model.set",{vars:{model:b.value}})),u(),A(),await b$2(e);},onCancel:A});a(k),await M(w,e.currentSessionId||"","",randomUUID());}break;case "fork":{try{d(a$1("tui.handler.fork.begin"));let g=e.currentSessionId;if(g&&e.activeChatRunId)try{await e.sdk.session.abort({sessionID:g}),e.activeChatRunId=null,T.info("Aborted running agent before forking session",{sessionId:g});}catch(k){T.warn("Failed to abort agent before forking, continuing anyway",{error:k});}if(t.clear(),g){let b=(await e.sdk.session.fork({sessionID:g})).data;b&&(e.currentSessionId=b.id,e.currentSessionKey=b.title||b.slug||b.id,e.sessionInfo={model:e.sessionInfo.model},await b$2(e));}p&&await p(),u(),d(a$1("tui.status.ready"));}catch(g){T.error("Failed to fork session",{error:g}),t.addSystem(a$1("tui.handler.fork.error",{vars:{error:String(g)}})),d(a$1("tui.status.error"));}await M("fork",e.currentSessionId||"",f||"",randomUUID());break}case "new":{try{d(a$1("tui.handler.new.begin"));let g=e.currentSessionId;if(g&&e.activeChatRunId)try{await e.sdk.session.abort({sessionID:g}),e.activeChatRunId=null,T.info("Aborted running agent before creating new session",{sessionId:g});}catch(E){T.warn("Failed to abort agent before creating new session, continuing anyway",{error:E});}t.clear();let k=e.instanceContext.directory,S=(await e.sdk.session.create({directory:k})).data;S&&(e.currentSessionId=S.id,e.currentSessionKey=S.title||S.slug||S.id,e.sessionInfo={model:e.sessionInfo.model},await b$2(e)),u(),d(a$1("tui.status.ready"));}catch(g){T.error("Failed to create new session",{error:g}),t.addSystem(a$1("tui.handler.new.error",{vars:{error:String(g)}})),d(a$1("tui.status.error"));}await M("new",e.currentSessionId||"",f||"",randomUUID());break}case "reset":{try{let g=e.currentSessionId;if(g&&e.activeChatRunId)try{await e.sdk.session.abort({sessionID:g}),e.activeChatRunId=null,T.info("Aborted running agent before reset",{sessionId:g});}catch(k){T.warn("Failed to abort agent before reset, continuing anyway",{error:k});}t.clear(),t.addSystem(a$1("tui.handler.session.reset")),p&&await p();}catch(g){T.error("Failed to reset session",{error:g}),t.addSystem(a$1("tui.handler.session.reset_error",{vars:{error:String(g)}}));}await M("reset",e.currentSessionId||"",f||"",randomUUID());break}case "settings":{T.info("Opening settings panel");let{createSettingsPanel:g}=await import('./settings-panel-BWCVKC4G.mjs'),k=g({currentSettings:{thinkingLevel:e.thinkingLevel,showThinking:e.showThinking,verboseLevel:e.verboseLevel,messageLimit:e.messageLimit,toolsExpanded:e.toolsExpanded,localShellPermission:e.localShellPermission,contextMode:e.contextMode},onChange:(b,S)=>{switch(b){case "thinkingLevel":e.thinkingLevel=S,t.addSystem(a$1("tui.handler.thinking_level.set",{vars:{level:S}}));break;case "showThinking":e.showThinking=S==="true",T.info("showThinking changed",{newValue:S,showThinking:e.showThinking}),t.addSystem(e.showThinking?a$1("tui.hint.show_thinking_on"):a$1("tui.hint.show_thinking_off"));break;case "verboseLevel":e.verboseLevel=S,t.addSystem(a$1("tui.handler.verbose_level.set",{vars:{level:S}}));break;case "messageLimit":e.messageLimit=Number.parseInt(S,10),t.addSystem(a$1("tui.handler.message_limit.set",{vars:{limit:S}}));break;case "toolsExpanded":e.toolsExpanded=S==="true",T.info("toolsExpanded changed",{newValue:S,toolsExpanded:e.toolsExpanded}),t.addSystem(e.toolsExpanded?a$1("tui.hint.tools_expanded"):a$1("tui.hint.tools_collapsed"));break;case "localShellPermission":e.localShellPermission=S,T.info("localShellPermission changed",{newValue:S,localShellPermission:e.localShellPermission}),t.addSystem(a$1("tui.shell.permission.updated",{vars:{permission:S}}));break;case "contextMode":{let E=S;e.contextMode=E,T.info("contextMode changed",{newValue:S,contextMode:E}),t.addSystem(a$1("tui.handler.context_mode.set",{vars:{mode:E}})),e.currentSessionId&&e.sdk.session.contextMode.set({sessionID:e.currentSessionId,mode:E}).catch(y=>{T.error("Failed to update session contextMode",{error:y,sessionId:e.currentSessionId});});break}}b$2(e).then(async()=>{try{T.info("Publishing HeaderRefresh event",{id:b,newValue:S}),await ma(e,c.StatusBarRefresh,{reason:`settings changed: ${b}`});}catch(E){T.error("Failed to publish HeaderRefresh event",{error:E});}}).catch(E=>{T.error("Failed to save TUI state after settings change",{error:E,id:b});});},onCancel:A});a(k),await M("settings",e.currentSessionId||"",f||"",randomUUID());break}case "verbose":if(!f){t.addSystem(a$1("tui.handler.verbose.usage")),await M(w,e.currentSessionId||"","",randomUUID());break}if(f!=="on"&&f!=="off"){t.addSystem(a$1("tui.handler.verbose.invalid",{vars:{value:f}})),await M(w,e.currentSessionId||"",f,randomUUID());break}e.verboseLevel=f,t.addSystem(a$1("tui.handler.verbose.set",{vars:{level:f}})),await b$2(e),await M(w,e.currentSessionId||"",f,randomUUID());break;case "thinking":if(!f){t.addSystem(a$1("tui.handler.thinking.usage"));break}e.thinkingLevel=f,t.addSystem(a$1("tui.handler.thinking.set",{vars:{level:f}})),await b$2(e),await M("thinking",e.currentSessionId||"",f||"",randomUUID());break;case "clear":{T.info("Opening clear confirmation dialog");let{createConfirmDialog:g}=await import('./confirm-dialog-AGHMTHWU.mjs'),k=g({message:a$1("tui.dialog.clear.message"),onConfirm:async()=>{try{d(a$1("tui.handler.clear.begin")),A();let b=e.currentSessionId;if(b&&e.activeChatRunId)try{await e.sdk.session.abort({sessionID:b}),e.activeChatRunId=null,T.info("Aborted running agent before clearing session",{sessionId:b});}catch(y){T.warn("Failed to abort agent before clearing, continuing anyway",{error:y});}t.clear(),b&&await e.sdk.session.delete({sessionID:b});let E=(await e.sdk.session.create({directory:e.instanceContext.directory})).data;E&&(e.currentSessionId=E.id,e.currentSessionKey=E.title||E.slug||E.id,e.sessionInfo={model:e.sessionInfo.model},await b$2(e)),u(),t.addSystem(a$1("tui.handler.clear.success")),d(a$1("tui.status.ready")),await M("clear",e.currentSessionId||"",f||"",randomUUID());}catch(b){T.error("Failed to clear chat history",{error:b}),t.addSystem(a$1("tui.handler.clear.error",{vars:{error:String(b)}})),d(a$1("tui.status.error")),await M("clear",e.currentSessionId||"",f||"",randomUUID());}},onCancel:()=>{t.addSystem(a$1("tui.clear.cancel")),A();}});a(k);break}case "skills":case "skill":{try{let b=((await e.sdk.command.list({})).data||[]).filter(y=>y.source==="skill");if(b.length===0){t.addSystem(a$1("tui.handler.skill.empty")),await M(w,e.currentSessionId||"",f||"",randomUUID());break}if(f){let y=f.split(/\s+/),G=y[0],te=y.slice(1).join(" ");b.some(ae=>ae.name===G)?await re("skill",G,e,t,d,te||void 0):t.addSystem(a$1("tui.handler.skill.not_found",{vars:{name:G}})),await M(w,e.currentSessionId||"",f,randomUUID());break}T.info("Opening skill selector");let S=b.map(y=>({label:y.name,description:y.description||"",value:y.name})),E=pe(S,{onSelect:async y=>{A(),s.setInputText?s.setInputText(`/skill ${y.value} `):await re("skill",y.value,e,t,d);},onCancel:A});a(E),await M(w,e.currentSessionId||"","",randomUUID());}catch(g){T.error("Failed to handle skill",{error:g}),t.addSystem(a$1("tui.handler.skill.error",{vars:{error:String(g)}})),await M(w,e.currentSessionId||"",f||"",randomUUID());}break}case "mcps":case "mcp":{try{let b=((await e.sdk.command.list({})).data||[]).filter(y=>y.source==="mcp");if(b.length===0){t.addSystem(a$1("tui.handler.mcp.empty")),await M(w,e.currentSessionId||"",f||"",randomUUID());break}if(f){let y=f.split(/\s+/),G=y[0],te=y.slice(1).join(" ");b.some(ae=>ae.name===G)?await re("mcp",G,e,t,d,te||void 0):t.addSystem(a$1("tui.handler.mcp.not_found",{vars:{name:G}})),await M(w,e.currentSessionId||"",f,randomUUID());break}T.info("Opening MCP prompt selector");let S=b.map(y=>({label:y.name,description:y.description||"",value:y.name})),E=pe(S,{onSelect:async y=>{A(),s.setInputText?s.setInputText(`/mcp ${y.value} `):await re("mcp",y.value,e,t,d);},onCancel:A});a(E),await M(w,e.currentSessionId||"","",randomUUID());}catch(g){T.error("Failed to handle MCP prompt",{error:g}),t.addSystem(a$1("tui.handler.mcp.error",{vars:{error:String(g)}})),await M(w,e.currentSessionId||"",f||"",randomUUID());}break}case "exit":case "quit":await M(w,e.currentSessionId||"",f||"",randomUUID()),l();break;default:T.debug("Unknown command, sending as message"),await h(H);break}}catch(g){let k=g instanceof Error?g.message:String(g);T.error("Command execution failed",{command:w,args:f,error:k,stack:g instanceof Error?g.stack:void 0}),t.addSystem(a$1("tui.handler.command.error",{vars:{command:w,error:k}}));}T.debug("handleCommand completed");},h=async(H,w,f)=>{try{let g=randomUUID();if(e.activeChatRunId=g,d(a$1("tui.handler.send.sending")),!e.currentSessionId)throw new Error("No active session");let k;if(e.sessionInfo.model){let{provider:E,model:y}=parseModelId(e.sessionInfo.model);E&&y&&(k={providerID:E,modelID:y});}let b=[{type:"text",text:H}];if(w&&w.length>0)for(let E of w)b.push({type:"file",url:E.url,filename:E.filename,mime:E.mime});f&&b.push({type:"agent",name:f});let S=await e.sdk.session.prompt({sessionID:e.currentSessionId,parts:b,agent:e.agent||void 0,model:k,variant:e.thinkingLevel,contextMode:e.contextMode});if(S.data&&e.currentSessionId&&await M("message",e.currentSessionId,H,S.data.info?.id||randomUUID()),S.data){let E=S.data.parts?.filter(y=>y.type==="text")||[];for(let y of E)"text"in y&&y.text&&t.addAssistant(y.text,S.data.info?.id);}e.activeChatRunId=null,d("");}catch(g){e.activeChatRunId=null;let k=g instanceof Error?g.message:String(g),b=g instanceof Error?g.name:"Error";t.addSystem(a$1("tui.handler.send.error",{vars:{error:k}})),d(a$1("tui.handler.send.error_status")),T.error("Failed to send message",{error:k,errorName:b,sessionId:e.currentSessionId,hasModel:!!e.sessionInfo.model,stack:g instanceof Error?g.stack:void 0});}},re=async(H,w,f,g,k,b)=>{try{let S=H==="skill"?a$1("tui.handler.skill.executing"):H==="command"?a$1("tui.handler.command.executing"):a$1("tui.handler.mcp.executing");if(g.addSystem(S+`: ${w}`),k(a$1("tui.handler.executing",{vars:{command:w}})),!f.currentSessionId)throw new Error("No active session");let E;f.sessionInfo.model&&(E=f.sessionInfo.model);let y=b?[{type:"text",text:b}]:void 0,te=(await f.sdk.session.command({sessionID:f.currentSessionId,command:w,arguments:b??"",agent:f.agent||void 0,model:E,variant:f.thinkingLevel,contextMode:f.contextMode,parts:y})).data,ae=te?.metadata?.commandType;if(te?.success)ae==="local"&&g.addSystem(a$1("tui.handler.local.completed")+`: ${w}
5
+ `)}function Ut(s,e){let{chatLog:t,tui:n,directory:r,openOverlay:a,closeOverlay:o,requestExit:l,setActivityStatus:d,updateFooter:u,refreshSessionInfo:c$1,loadHistory:p,setSession:_,refreshAgents:$,abortActive:ne}=s,A=()=>{o();},M=async(H,w,f,g)=>{try{if(!w){T.warn("Cannot publish command event: no session ID",{name:H});return}await na(e,ga.Event.Executed,{name:H,sessionID:w,arguments:f,messageID:g}),T.debug("Command event published",{name:H,sessionId:w,messageId:g});}catch(k){T.error("Failed to publish command event",{name:H,sessionId:w,messageId:g,error:k instanceof Error?k.message:String(k),stack:k instanceof Error?k.stack:void 0});}},he=async H=>{T.debug("Handle command called",{raw:H});let{name:w,args:f}=Dt(H);if(T.debug("Parsed command",{name:w,args:f}),!w){T.debug("No command name, returning");return}try{switch(w){case "help":T.debug("Executing help command"),t.addSystem($t()),T.debug("Help text added to chatLog"),await M("help",e.currentSessionId||"",f||"",randomUUID());break;case "commands":case "command":case "cmds":case "cmd":{try{let b=((await e.sdk.command.list({})).data||[]).filter(y=>y.source==="command");if(b.length===0){t.addSystem(a$1("tui.handler.command.empty")),await M(w,e.currentSessionId||"",f||"",randomUUID());break}if(f){let y=f.split(/\s+/),G=y[0],te=y.slice(1).join(" ");b.some(ae=>ae.name===G)?await re("command",G,e,t,d,te||void 0):t.addSystem(a$1("tui.handler.command.not_found",{vars:{name:G}})),await M(w,e.currentSessionId||"",f,randomUUID());break}T.info("Opening command selector");let S=b.map(y=>({label:y.name,description:y.description||"",value:y.name})),E=pe(S,{onSelect:async y=>{A(),s.setInputText?s.setInputText(`/command ${y.value} `):await re("command",y.value,e,t,d);},onCancel:A});a(E),await M(w,e.currentSessionId||"","",randomUUID());}catch(g){T.error("Failed to handle command",{error:g}),t.addSystem(a$1("tui.handler.command.error",{vars:{error:String(g)}})),await M(w,e.currentSessionId||"",f||"",randomUUID());}break}case "status":t.addSystem(await vs(e,r)),await M("status",e.currentSessionId||"",f||"",randomUUID());break;case "agents":case "agent":if(f)e.agent=f,t.addSystem(a$1("tui.handler.agent.switched",{vars:{agentId:f}})),u(),await b$2(e),await M(w,e.currentSessionId||"",f,randomUUID());else {T.info("Opening agent selector");let k=(await ra(e)).filter(S=>S.mode==="primary"&&S.hidden!==!0),b=Be(k,{onSelect:async S=>{e.agent=S.value,t.addSystem(a$1("tui.handler.agent.switched",{vars:{agentId:S.value}})),u(),A(),await b$2(e);},onCancel:A});a(b),await M(w,e.currentSessionId||"","",randomUUID());}break;case "sessions":case "session":if(f&&_)await _(f),u(),await M(w,e.currentSessionId||"",f,randomUUID());else {T.info("Opening session selector");let g=await sa(e),k=qe(g,{onSelect:async b=>{_&&await _(b.value),u(),A();},onCancel:A});a(k),await M(w,e.currentSessionId||"","",randomUUID());}break;case "models":case "model":if(f)e.sessionInfo.model=f,t.addSystem(a$1("tui.handler.model.set",{vars:{model:f}})),u(),await b$2(e),await M(w,e.currentSessionId||"",f,randomUUID());else {T.info("Opening model selector");let g=await ta(e),k=Fe(g,{onSelect:async b=>{e.sessionInfo.model=b.value,t.addSystem(a$1("tui.handler.model.set",{vars:{model:b.value}})),u(),A(),await b$2(e);},onCancel:A});a(k),await M(w,e.currentSessionId||"","",randomUUID());}break;case "fork":{try{d(a$1("tui.handler.fork.begin"));let g=e.currentSessionId;if(g&&e.activeChatRunId)try{await e.sdk.session.abort({sessionID:g}),e.activeChatRunId=null,T.info("Aborted running agent before forking session",{sessionId:g});}catch(k){T.warn("Failed to abort agent before forking, continuing anyway",{error:k});}if(t.clear(),g){let b=(await e.sdk.session.fork({sessionID:g})).data;b&&(e.currentSessionId=b.id,e.currentSessionKey=b.title||b.slug||b.id,e.sessionInfo={model:e.sessionInfo.model},await b$2(e));}p&&await p(),u(),d(a$1("tui.status.ready"));}catch(g){T.error("Failed to fork session",{error:g}),t.addSystem(a$1("tui.handler.fork.error",{vars:{error:String(g)}})),d(a$1("tui.status.error"));}await M("fork",e.currentSessionId||"",f||"",randomUUID());break}case "new":{try{d(a$1("tui.handler.new.begin"));let g=e.currentSessionId;if(g&&e.activeChatRunId)try{await e.sdk.session.abort({sessionID:g}),e.activeChatRunId=null,T.info("Aborted running agent before creating new session",{sessionId:g});}catch(E){T.warn("Failed to abort agent before creating new session, continuing anyway",{error:E});}t.clear();let k=e.instanceContext.directory,S=(await e.sdk.session.create({directory:k})).data;S&&(e.currentSessionId=S.id,e.currentSessionKey=S.title||S.slug||S.id,e.sessionInfo={model:e.sessionInfo.model},await b$2(e)),u(),d(a$1("tui.status.ready"));}catch(g){T.error("Failed to create new session",{error:g}),t.addSystem(a$1("tui.handler.new.error",{vars:{error:String(g)}})),d(a$1("tui.status.error"));}await M("new",e.currentSessionId||"",f||"",randomUUID());break}case "reset":{try{let g=e.currentSessionId;if(g&&e.activeChatRunId)try{await e.sdk.session.abort({sessionID:g}),e.activeChatRunId=null,T.info("Aborted running agent before reset",{sessionId:g});}catch(k){T.warn("Failed to abort agent before reset, continuing anyway",{error:k});}t.clear(),t.addSystem(a$1("tui.handler.session.reset")),p&&await p();}catch(g){T.error("Failed to reset session",{error:g}),t.addSystem(a$1("tui.handler.session.reset_error",{vars:{error:String(g)}}));}await M("reset",e.currentSessionId||"",f||"",randomUUID());break}case "settings":{T.info("Opening settings panel");let{createSettingsPanel:g}=await import('./settings-panel-4GBMKF7S.mjs'),k=g({currentSettings:{thinkingLevel:e.thinkingLevel,showThinking:e.showThinking,verboseLevel:e.verboseLevel,messageLimit:e.messageLimit,toolsExpanded:e.toolsExpanded,localShellPermission:e.localShellPermission,contextMode:e.contextMode},onChange:(b,S)=>{switch(b){case "thinkingLevel":e.thinkingLevel=S,t.addSystem(a$1("tui.handler.thinking_level.set",{vars:{level:S}}));break;case "showThinking":e.showThinking=S==="true",T.info("showThinking changed",{newValue:S,showThinking:e.showThinking}),t.addSystem(e.showThinking?a$1("tui.hint.show_thinking_on"):a$1("tui.hint.show_thinking_off"));break;case "verboseLevel":e.verboseLevel=S,t.addSystem(a$1("tui.handler.verbose_level.set",{vars:{level:S}}));break;case "messageLimit":e.messageLimit=Number.parseInt(S,10),t.addSystem(a$1("tui.handler.message_limit.set",{vars:{limit:S}}));break;case "toolsExpanded":e.toolsExpanded=S==="true",T.info("toolsExpanded changed",{newValue:S,toolsExpanded:e.toolsExpanded}),t.addSystem(e.toolsExpanded?a$1("tui.hint.tools_expanded"):a$1("tui.hint.tools_collapsed"));break;case "localShellPermission":e.localShellPermission=S,T.info("localShellPermission changed",{newValue:S,localShellPermission:e.localShellPermission}),t.addSystem(a$1("tui.shell.permission.updated",{vars:{permission:S}}));break;case "contextMode":{let E=S;e.contextMode=E,T.info("contextMode changed",{newValue:S,contextMode:E}),t.addSystem(a$1("tui.handler.context_mode.set",{vars:{mode:E}})),e.currentSessionId&&e.sdk.session.contextMode.set({sessionID:e.currentSessionId,mode:E}).catch(y=>{T.error("Failed to update session contextMode",{error:y,sessionId:e.currentSessionId});});break}}b$2(e).then(async()=>{try{T.info("Publishing HeaderRefresh event",{id:b,newValue:S}),await na(e,c.StatusBarRefresh,{reason:`settings changed: ${b}`});}catch(E){T.error("Failed to publish HeaderRefresh event",{error:E});}}).catch(E=>{T.error("Failed to save TUI state after settings change",{error:E,id:b});});},onCancel:A});a(k),await M("settings",e.currentSessionId||"",f||"",randomUUID());break}case "verbose":if(!f){t.addSystem(a$1("tui.handler.verbose.usage")),await M(w,e.currentSessionId||"","",randomUUID());break}if(f!=="on"&&f!=="off"){t.addSystem(a$1("tui.handler.verbose.invalid",{vars:{value:f}})),await M(w,e.currentSessionId||"",f,randomUUID());break}e.verboseLevel=f,t.addSystem(a$1("tui.handler.verbose.set",{vars:{level:f}})),await b$2(e),await M(w,e.currentSessionId||"",f,randomUUID());break;case "thinking":if(!f){t.addSystem(a$1("tui.handler.thinking.usage"));break}e.thinkingLevel=f,t.addSystem(a$1("tui.handler.thinking.set",{vars:{level:f}})),await b$2(e),await M("thinking",e.currentSessionId||"",f||"",randomUUID());break;case "clear":{T.info("Opening clear confirmation dialog");let{createConfirmDialog:g}=await import('./confirm-dialog-XBLCGOEC.mjs'),k=g({message:a$1("tui.dialog.clear.message"),onConfirm:async()=>{try{d(a$1("tui.handler.clear.begin")),A();let b=e.currentSessionId;if(b&&e.activeChatRunId)try{await e.sdk.session.abort({sessionID:b}),e.activeChatRunId=null,T.info("Aborted running agent before clearing session",{sessionId:b});}catch(y){T.warn("Failed to abort agent before clearing, continuing anyway",{error:y});}t.clear(),b&&await e.sdk.session.delete({sessionID:b});let E=(await e.sdk.session.create({directory:e.instanceContext.directory})).data;E&&(e.currentSessionId=E.id,e.currentSessionKey=E.title||E.slug||E.id,e.sessionInfo={model:e.sessionInfo.model},await b$2(e)),u(),t.addSystem(a$1("tui.handler.clear.success")),d(a$1("tui.status.ready")),await M("clear",e.currentSessionId||"",f||"",randomUUID());}catch(b){T.error("Failed to clear chat history",{error:b}),t.addSystem(a$1("tui.handler.clear.error",{vars:{error:String(b)}})),d(a$1("tui.status.error")),await M("clear",e.currentSessionId||"",f||"",randomUUID());}},onCancel:()=>{t.addSystem(a$1("tui.clear.cancel")),A();}});a(k);break}case "skills":case "skill":{try{let b=((await e.sdk.command.list({})).data||[]).filter(y=>y.source==="skill");if(b.length===0){t.addSystem(a$1("tui.handler.skill.empty")),await M(w,e.currentSessionId||"",f||"",randomUUID());break}if(f){let y=f.split(/\s+/),G=y[0],te=y.slice(1).join(" ");b.some(ae=>ae.name===G)?await re("skill",G,e,t,d,te||void 0):t.addSystem(a$1("tui.handler.skill.not_found",{vars:{name:G}})),await M(w,e.currentSessionId||"",f,randomUUID());break}T.info("Opening skill selector");let S=b.map(y=>({label:y.name,description:y.description||"",value:y.name})),E=pe(S,{onSelect:async y=>{A(),s.setInputText?s.setInputText(`/skill ${y.value} `):await re("skill",y.value,e,t,d);},onCancel:A});a(E),await M(w,e.currentSessionId||"","",randomUUID());}catch(g){T.error("Failed to handle skill",{error:g}),t.addSystem(a$1("tui.handler.skill.error",{vars:{error:String(g)}})),await M(w,e.currentSessionId||"",f||"",randomUUID());}break}case "mcps":case "mcp":{try{let b=((await e.sdk.command.list({})).data||[]).filter(y=>y.source==="mcp");if(b.length===0){t.addSystem(a$1("tui.handler.mcp.empty")),await M(w,e.currentSessionId||"",f||"",randomUUID());break}if(f){let y=f.split(/\s+/),G=y[0],te=y.slice(1).join(" ");b.some(ae=>ae.name===G)?await re("mcp",G,e,t,d,te||void 0):t.addSystem(a$1("tui.handler.mcp.not_found",{vars:{name:G}})),await M(w,e.currentSessionId||"",f,randomUUID());break}T.info("Opening MCP prompt selector");let S=b.map(y=>({label:y.name,description:y.description||"",value:y.name})),E=pe(S,{onSelect:async y=>{A(),s.setInputText?s.setInputText(`/mcp ${y.value} `):await re("mcp",y.value,e,t,d);},onCancel:A});a(E),await M(w,e.currentSessionId||"","",randomUUID());}catch(g){T.error("Failed to handle MCP prompt",{error:g}),t.addSystem(a$1("tui.handler.mcp.error",{vars:{error:String(g)}})),await M(w,e.currentSessionId||"",f||"",randomUUID());}break}case "exit":case "quit":await M(w,e.currentSessionId||"",f||"",randomUUID()),l();break;default:T.debug("Unknown command, sending as message"),await h(H);break}}catch(g){let k=g instanceof Error?g.message:String(g);T.error("Command execution failed",{command:w,args:f,error:k,stack:g instanceof Error?g.stack:void 0}),t.addSystem(a$1("tui.handler.command.error",{vars:{command:w,error:k}}));}T.debug("handleCommand completed");},h=async(H,w,f)=>{try{let g=randomUUID();if(e.activeChatRunId=g,d(a$1("tui.handler.send.sending")),!e.currentSessionId)throw new Error("No active session");let k;if(e.sessionInfo.model){let{provider:E,model:y}=parseModelId(e.sessionInfo.model);E&&y&&(k={providerID:E,modelID:y});}let b=[{type:"text",text:H}];if(w&&w.length>0)for(let E of w)b.push({type:"file",url:E.url,filename:E.filename,mime:E.mime});f&&b.push({type:"agent",name:f});let S=await e.sdk.session.prompt({sessionID:e.currentSessionId,parts:b,agent:e.agent||void 0,model:k,variant:e.thinkingLevel,contextMode:e.contextMode});if(S.data&&e.currentSessionId&&await M("message",e.currentSessionId,H,S.data.info?.id||randomUUID()),S.data){let E=S.data.parts?.filter(y=>y.type==="text")||[];for(let y of E)"text"in y&&y.text&&t.addAssistant(y.text,S.data.info?.id);}e.activeChatRunId=null,d("");}catch(g){e.activeChatRunId=null;let k=g instanceof Error?g.message:String(g),b=g instanceof Error?g.name:"Error";t.addSystem(a$1("tui.handler.send.error",{vars:{error:k}})),d(a$1("tui.handler.send.error_status")),T.error("Failed to send message",{error:k,errorName:b,sessionId:e.currentSessionId,hasModel:!!e.sessionInfo.model,stack:g instanceof Error?g.stack:void 0});}},re=async(H,w,f,g,k,b)=>{try{let S=H==="skill"?a$1("tui.handler.skill.executing"):H==="command"?a$1("tui.handler.command.executing"):a$1("tui.handler.mcp.executing");if(g.addSystem(S+`: ${w}`),k(a$1("tui.handler.executing",{vars:{command:w}})),!f.currentSessionId)throw new Error("No active session");let E;f.sessionInfo.model&&(E=f.sessionInfo.model);let y=b?[{type:"text",text:b}]:void 0,te=(await f.sdk.session.command({sessionID:f.currentSessionId,command:w,arguments:b??"",agent:f.agent||void 0,model:E,variant:f.thinkingLevel,contextMode:f.contextMode,parts:y})).data,ae=te?.metadata?.commandType;if(te?.success)ae==="local"&&g.addSystem(a$1("tui.handler.local.completed")+`: ${w}
6
6
  `+a$1("tui.handler.local.output")+`:
7
7
  `+te.output);else {let Je=te?.error??"Command execution failed",ke=H==="skill"?"tui.handler.skill.error":H==="command"?"tui.handler.command.error":"tui.handler.mcp.error";g.addSystem(a$1(ke,{vars:{command:w,error:Je}}));}k("");}catch(S){let E=S instanceof Error?S.message:String(S),y=S instanceof Error?S.name:"Error",G=H==="skill"?a$1("tui.handler.skill.error"):H==="command"?a$1("tui.handler.command.error"):a$1("tui.handler.mcp.error");g.addSystem(G+`: ${w}
8
- ${E}`),k(a$1("tui.status.error")),T.error("Failed to execute command",{type:H,name:w,error:E,errorName:y,sessionId:f.currentSessionId,stack:S instanceof Error?S.stack:void 0});}};return {handleCommand:he,sendMessage:h}}var L=a.create({service:"cli-tui-events"});function Ot(s){return e=>{try{if(e.type==="message.updated"){xs(s,e);return}if(e.type==="message.part.updated"){ws(s,e);return}if(e.type==="session.status"){Fs(s,e);return}if(e.type==="session.error"){qs(s,e);return}if(e.type==="agent.updated"){Bs(s,e);return}if(e.type==="session.updated"){Us(s,e);return}if(e.type==="permission.asked"){Os(s,e);return}if(e.type==="question.asked"){Ws(s,e);return}}catch(t){L.error("Event handling failed",{eventType:e.type,error:t instanceof Error?t.message:String(t)});}}}function xs(s,e){if(e.type!=="message.updated")return;let{properties:t}=e,{info:n}=t,r=s.state?.currentSessionId||s.sessionId;if(!(r&&n.sessionID!==r)&&(L.debug("Message updated",{role:n.role,agent:n.agent,sessionID:n.sessionID,messageId:n.id}),n.role,s.state&&"model"in n&&n.model)){let a=`${n.model.providerID}/${n.model.modelID}`;s.state.sessionInfo.model=a,L.debug("Model info updated",{model:a}),s.updateFooter&&s.updateFooter();}}function ws(s,e){if(e.type!=="message.part.updated")return;let{properties:t}=e,{part:n}=t;if(!n){L.warn("Message part is undefined",{event:e,properties:t,propertiesType:typeof t,propertiesKeys:t?Object.keys(t):[]});return}let r=s.state?.currentSessionId||s.sessionId;r&&n.sessionID!==r||(Ts(n),ks(s,n));}function Ts(s){L.debug("handleMessagePartUpdated",{type:s.type,status:"state"in s?s.state?.status:void 0,hasTimeEnd:"time"in s&&s.time&&"end"in s.time?!!s.time.end:false,timeEnd:"time"in s&&s.time&&"end"in s.time?s.time.end:void 0,hasText:"text"in s,textLength:"text"in s&&s.text?.length||0,textPreview:"text"in s?s.text?.substring(0,100):void 0,sessionID:s.sessionID});}function ks(s,e){if(e.type==="tool"){Rs(s,e);return}if(e.type==="text"){if("time"in e&&e.time&&"end"in e.time&&e.time.end){L.info("Calling handleTextPart",{hasText:"text"in e&&!!e.text,textLength:"text"in e&&e.text?.length||0}),$s(s,e);return}if(!("time"in e)){L.info("Calling handleUserTextPart for user message",{hasText:!!e.text,textLength:e.text?.length||0}),Ps(s,e);return}}if(e.type==="reasoning"&&"time"in e&&e.time&&"end"in e.time&&e.time.end){Hs(s,e);return}if(e.type==="step-start"){As(s);return}if(e.type==="step-finish"){Es(s,e);return}if(e.type==="subtask-result"){Ls(s,e);return}}function Ps(s,e){let t=e.text?.trim();t&&(L.debug("User text output",{length:t.length,messageId:e.messageID}),s.chatLog.addUser(t,e.messageID),s.tui.requestRender());}function As(s){s.setActivityStatus(a$1("tui.status.executing_step"));}function Es(s,e){s.setActivityStatus(a$1("tui.status.step_completed")),s.state&&e.tokens&&Ds(s,e.tokens);}function Ls(s,e){L.debug("handleSubagentResultPart called",{taskId:e.taskId,agent:e.agent,status:e.status});let t=Ha.formatSubtaskResultPart(e);L.debug("formattedContent",{content:t}),s.chatLog.addUser(t,e.id,{agent:e.agent,isSubagentResult:true,subtaskResultPart:{taskId:e.taskId,source:e.source,agent:e.agent,status:e.status,result:e.result,error:e.error,duration:e.duration,rounds:e.rounds,time:e.time,metadata:e.metadata}}),s.tui.requestRender();}async function Ms(s){let e=s.sessionInfo.model;if(!e)return null;let{provider:t,model:n}=parseModelId(e);if(!t||!n)return null;try{return ((await s.sdk.config.providers({})).data?.providers??[]).find(d=>d.id===t)?.models?.[n]?.limit?.context??null}catch(r){return L.warn("Failed to get context limit from model config",{error:r,providerID:t,modelID:n}),null}}function Ds(s,e){let t=e.input+e.output+e.reasoning+e.cache.read+e.cache.write;s.state.sessionInfo.totalTokens=t,s.state.sessionInfo.contextTokens||Ms(s.state).then(n=>{s.state.sessionInfo.contextTokens=n??2e5,L.debug("Context limit updated",{contextLimit:s.state.sessionInfo.contextTokens}),s.updateFooter&&s.updateFooter();}),L.debug("Token usage updated",{total:t,input:e.input,output:e.output,reasoning:e.reasoning,cacheRead:e.cache.read,cacheWrite:e.cache.write});}function _s(s){let e=s.state?.status==="running"||s.state?.status==="completed"?s.state.input:void 0;if(!e)return;let t=e.filePath??e.filepath??e.path,n=e.title;return t?n=Filesystem.normalize(t):e.url&&(n=e.url),n}function Rs(s,e){if(!e.state){L.warn("Tool part missing state",{tool:e.tool,partType:e.type});return}let t=_s(e),n=t?`${e.tool} ${t}`:e.tool;if(e.state.status==="running"&&(s.setActivityStatus(a$1("tui.status.executing_tool",{vars:{tool:e.tool}})),s.chatLog.addSystem(a$1("tui.system.tool_executing",{vars:{tool:n}}),e.id,{isTool:true,toolName:e.tool,toolCallId:e.callID,toolStatus:"executing",title:t}),s.updateChatLog&&s.updateChatLog()),e.state.status==="completed"){if(s.setActivityStatus(a$1("tui.status.tool_completed")),s.chatLog.addSystem(a$1("tui.system.tool_completed",{vars:{tool:n}}),e.id,{isTool:true,toolName:e.tool,toolCallId:e.callID,toolStatus:"completed",result:e.state.output,title:t}),s.state?.toolsExpanded&&s.state?.verboseLevel==="on"&&e.state.output){let a=(typeof e.state.output=="string"?e.state.output:JSON.stringify(e.state.output,null,2)).trim();a&&s.chatLog.addSystem(`Tool output:
8
+ ${E}`),k(a$1("tui.status.error")),T.error("Failed to execute command",{type:H,name:w,error:E,errorName:y,sessionId:f.currentSessionId,stack:S instanceof Error?S.stack:void 0});}};return {handleCommand:he,sendMessage:h}}var L=a.create({service:"cli-tui-events"});function Ot(s){return e=>{try{if(e.type==="message.updated"){xs(s,e);return}if(e.type==="message.part.updated"){ws(s,e);return}if(e.type==="session.status"){Fs(s,e);return}if(e.type==="session.error"){qs(s,e);return}if(e.type==="agent.updated"){Bs(s,e);return}if(e.type==="session.updated"){Us(s,e);return}if(e.type==="permission.asked"){Os(s,e);return}if(e.type==="question.asked"){Ws(s,e);return}}catch(t){L.error("Event handling failed",{eventType:e.type,error:t instanceof Error?t.message:String(t)});}}}function xs(s,e){if(e.type!=="message.updated")return;let{properties:t}=e,{info:n}=t,r=s.state?.currentSessionId||s.sessionId;if(!(r&&n.sessionID!==r)&&(L.debug("Message updated",{role:n.role,agent:n.agent,sessionID:n.sessionID,messageId:n.id}),n.role,s.state&&"model"in n&&n.model)){let a=`${n.model.providerID}/${n.model.modelID}`;s.state.sessionInfo.model=a,L.debug("Model info updated",{model:a}),s.updateFooter&&s.updateFooter();}}function ws(s,e){if(e.type!=="message.part.updated")return;let{properties:t}=e,{part:n}=t;if(!n){L.warn("Message part is undefined",{event:e,properties:t,propertiesType:typeof t,propertiesKeys:t?Object.keys(t):[]});return}let r=s.state?.currentSessionId||s.sessionId;r&&n.sessionID!==r||(Ts(n),ks(s,n));}function Ts(s){L.debug("handleMessagePartUpdated",{type:s.type,status:"state"in s?s.state?.status:void 0,hasTimeEnd:"time"in s&&s.time&&"end"in s.time?!!s.time.end:false,timeEnd:"time"in s&&s.time&&"end"in s.time?s.time.end:void 0,hasText:"text"in s,textLength:"text"in s&&s.text?.length||0,textPreview:"text"in s?s.text?.substring(0,100):void 0,sessionID:s.sessionID});}function ks(s,e){if(e.type==="tool"){Rs(s,e);return}if(e.type==="text"){if("time"in e&&e.time&&"end"in e.time&&e.time.end){L.info("Calling handleTextPart",{hasText:"text"in e&&!!e.text,textLength:"text"in e&&e.text?.length||0}),$s(s,e);return}if(!("time"in e)){L.info("Calling handleUserTextPart for user message",{hasText:!!e.text,textLength:e.text?.length||0}),Ps(s,e);return}}if(e.type==="reasoning"&&"time"in e&&e.time&&"end"in e.time&&e.time.end){Hs(s,e);return}if(e.type==="step-start"){As(s);return}if(e.type==="step-finish"){Es(s,e);return}if(e.type==="subtask-result"){Ls(s,e);return}}function Ps(s,e){let t=e.text?.trim();t&&(L.debug("User text output",{length:t.length,messageId:e.messageID}),s.chatLog.addUser(t,e.messageID),s.tui.requestRender());}function As(s){s.setActivityStatus(a$1("tui.status.executing_step"));}function Es(s,e){s.setActivityStatus(a$1("tui.status.step_completed")),s.state&&e.tokens&&Ds(s,e.tokens);}function Ls(s,e){L.debug("handleSubagentResultPart called",{taskId:e.taskId,agent:e.agent,status:e.status});let t=Ja.formatSubtaskResultPart(e);L.debug("formattedContent",{content:t}),s.chatLog.addUser(t,e.id,{agent:e.agent,isSubagentResult:true,subtaskResultPart:{taskId:e.taskId,source:e.source,agent:e.agent,status:e.status,result:e.result,error:e.error,duration:e.duration,rounds:e.rounds,time:e.time,metadata:e.metadata}}),s.tui.requestRender();}async function Ms(s){let e=s.sessionInfo.model;if(!e)return null;let{provider:t,model:n}=parseModelId(e);if(!t||!n)return null;try{return ((await s.sdk.config.providers({})).data?.providers??[]).find(d=>d.id===t)?.models?.[n]?.limit?.context??null}catch(r){return L.warn("Failed to get context limit from model config",{error:r,providerID:t,modelID:n}),null}}function Ds(s,e){let t=e.input+e.output+e.reasoning+e.cache.read+e.cache.write;s.state.sessionInfo.totalTokens=t,s.state.sessionInfo.contextTokens||Ms(s.state).then(n=>{s.state.sessionInfo.contextTokens=n??2e5,L.debug("Context limit updated",{contextLimit:s.state.sessionInfo.contextTokens}),s.updateFooter&&s.updateFooter();}),L.debug("Token usage updated",{total:t,input:e.input,output:e.output,reasoning:e.reasoning,cacheRead:e.cache.read,cacheWrite:e.cache.write});}function _s(s){let e=s.state?.status==="running"||s.state?.status==="completed"?s.state.input:void 0;if(!e)return;let t=e.filePath??e.filepath??e.path,n=e.title;return t?n=Filesystem.normalize(t):e.url&&(n=e.url),n}function Rs(s,e){if(!e.state){L.warn("Tool part missing state",{tool:e.tool,partType:e.type});return}let t=_s(e),n=t?`${e.tool} ${t}`:e.tool;if(e.state.status==="running"&&(s.setActivityStatus(a$1("tui.status.executing_tool",{vars:{tool:e.tool}})),s.chatLog.addSystem(a$1("tui.system.tool_executing",{vars:{tool:n}}),e.id,{isTool:true,toolName:e.tool,toolCallId:e.callID,toolStatus:"executing",title:t}),s.updateChatLog&&s.updateChatLog()),e.state.status==="completed"){if(s.setActivityStatus(a$1("tui.status.tool_completed")),s.chatLog.addSystem(a$1("tui.system.tool_completed",{vars:{tool:n}}),e.id,{isTool:true,toolName:e.tool,toolCallId:e.callID,toolStatus:"completed",result:e.state.output,title:t}),s.state?.toolsExpanded&&s.state?.verboseLevel==="on"&&e.state.output){let a=(typeof e.state.output=="string"?e.state.output:JSON.stringify(e.state.output,null,2)).trim();a&&s.chatLog.addSystem(`Tool output:
9
9
  `+a);}s.updateChatLog&&s.updateChatLog();}e.state.status==="error"&&(s.setActivityStatus(a$1("tui.status.tool_failed")),s.chatLog.addSystem(a$1("tui.system.tool_failed",{vars:{tool:n}}),e.id,{isTool:true,toolName:e.tool,toolCallId:e.callID,toolStatus:"failed",error:e.state.error,title:t}),s.updateChatLog&&s.updateChatLog());}function $s(s,e){let t=e.text?.trim();t&&(L.debug("Text output",{length:t.length,messageId:e.messageID}),s.chatLog.addAssistant(t,e.messageID),s.setActivityStatus(a$1("tui.status.receiving")));}function Hs(s,e){let t=e.text?.trim();if(!t){L.warn("Reasoning part has no text, skipping",{partId:e.id});return}if(t=t.replace("[REDACTED]","").trim(),!t){L.warn("Reasoning part is redacted, skipping",{partId:e.id});return}if(t=t.trim(),!t){L.warn("Reasoning part has no content after cleanup",{partId:e.id});return}if(L.info("Adding reasoning message to ChatLog",{textLength:t.length,partId:e.id,showThinking:s.state?.showThinking,hasTimeEnd:"time"in e&&e.time&&"end"in e.time?!!e.time.end:false}),s.chatLog.addSystem(a$1("tui.system.thinking",{vars:{text:t}}),e.id,{isThinking:true}),L.info("Reasoning message added, requesting render"),s.state?.pendingQuestion){s.state.questionDisplayTimer&&(clearTimeout(s.state.questionDisplayTimer),s.state.questionDisplayTimer=null,L.debug("Question display fallback timer cleared (reasoning-end)"));let n=s.state.pendingQuestion;if(n.questions.length>0){let r=n.questions[0];r&&(L.debug("Show first question after reasoning-end",{header:r.header,question:r.question,optionCount:r.options?.length||0}),Wt(s,r,0,n.questions.length));}}}function Fs(s,e){let{properties:t}=e,{sessionID:n,status:r}=t,a=s.state?.currentSessionId||s.sessionId;if(!(a&&n!==a)){if(L.debug("Session status",{status:r.type,sessionID:n}),r.type==="idle"){if(s.state){if(s.state.questionDisplayTimer&&(clearTimeout(s.state.questionDisplayTimer),s.state.questionDisplayTimer=null,L.debug("Question display fallback timer cleared (session idle)")),s.state.pendingQuestion){let o=s.state.pendingQuestion.id;L.info("Rejecting pending question due to session idle",{questionId:o,sessionID:n}),s.state.pendingQuestion=null,s.chatLog.addSystem(a$1("tui.question.cancelled")),s.state.sdk.question.reject({requestID:o}).catch(l=>{L.error("Failed to reject question",{error:l});});}if(s.state.pendingPermission){let o=s.state.pendingPermission.sessionID,l=s.state.pendingPermission.id;L.info("Rejecting pending permission due to session idle",{permissionId:l,sessionID:n}),s.state.pendingPermission=null,s.chatLog.addSystem(a$1("tui.permission.cancelled")),s.state.sdk.permission.respond({sessionID:o,permissionID:l,response:"reject"}).catch(d=>{L.error("Failed to reject permission",{error:d});});}}s.setActivityStatus(a$1("tui.status.ready"));}r.type==="running"&&s.setActivityStatus(a$1("tui.status.running")),r.type==="waiting"&&s.setActivityStatus(a$1("tui.status.waiting"));}}function qs(s,e){let{properties:t}=e,{sessionID:n,error:r}=t,a=s.state?.currentSessionId||s.sessionId;if(a&&n!==a)return;L.error("Session error",{error:r,sessionID:n});let o=String(r.name);"data"in r&&r.data&&"message"in r.data&&(o=String(r.data.message)),s.chatLog.addSystem(a$1("tui.system.error",{vars:{message:o}})),s.setActivityStatus(a$1("tui.status.error"));}function Bs(s,e){let{properties:t}=e,{agentId:n}=t;L.debug("Agent updated (backend event)",{agentId:n});}function Us(s,e){let{properties:t}=e,{info:n}=t,r=s.state?.currentSessionId||s.sessionId;r&&n.id!==r||(L.debug("Session updated",{sessionId:n.id,title:n.title}),s.state&&(s.state.currentSessionKey=n.title||n.id,n.model&&(s.state.sessionInfo.model=`${n.model.providerID}/${n.model.modelID}`)),s.updateFooter&&s.updateFooter());}function Os(s,e){let{properties:t}=e,n=t,r=s.state?.currentSessionId||s.sessionId;if(r&&n.sessionID!==r){L.debug("Ignore permission request from other session",{sessionID:n.sessionID,currentSessionId:r});return}L.info("Received permission request",{permission:n.permission,patterns:n.patterns,sessionID:n.sessionID}),s.state&&(s.state.pendingPermission={id:n.id,sessionID:n.sessionID,permission:n.permission,patterns:n.patterns});let a=`
10
10
  `+a$1("tui.permission.request_header")+`
11
11
  `;a+=a$1("tui.permission.type",{vars:{type:n.permission}})+`
@@ -31,9 +31,9 @@ ${E}`),k(a$1("tui.status.error")),T.error("Failed to execute command",{type:H,na
31
31
  `:l+=`
32
32
  `+a$1("tui.question.hint.custom_disabled")+`
33
33
  `;}L.debug("displayQuestion - final message",{messageLength:l.length,messagePreview:l.substring(0,100)}),s.chatLog.addSystem(l);}var K=a.create({service:"cli-tui-session-actions"});async function Nt(s){K.info("Refreshing agent list");try{s.setActivityStatus(a$1("tui.session.loading_agents"));let n=((await s.sdk.app.agents({})).data||[]).map(r=>r.name);return K.info("Agent list loaded",{count:n.length}),s.setActivityStatus(a$1("tui.status.ready")),n}catch(e){return K.error("Failed to refresh agent list",{error:e}),s.chatLog.addSystem(a$1("tui.session.agents_failed",{vars:{error:String(e)}})),s.setActivityStatus(a$1("tui.status.error")),[]}}async function dt(s,e){K.info("Refreshing session info",{sessionId:e});try{s.setActivityStatus(a$1("tui.session.loading_info"));let n=(await s.sdk.session.get({sessionID:e})).data;return K.info("Session info loaded",{sessionId:e}),s.setActivityStatus(a$1("tui.status.ready")),n??null}catch(t){return K.error("Failed to refresh session info",{sessionId:e,error:t}),s.chatLog.addSystem(a$1("tui.session.info_failed",{vars:{error:String(t)}})),s.setActivityStatus(a$1("tui.status.error")),null}}async function Ue(s,e,t){K.info("Loading history",{sessionId:e,limit:t});try{s.setActivityStatus(a$1("tui.session.loading_history"));let r=(await s.sdk.session.messages({sessionID:e,limit:t})).data||[];K.info("History loaded",{sessionId:e,count:r.length});for(let a=0;a<r.length;a++){let o=r[a],l=o?.info?.role;if(l==="user"){let u=(o?.parts?.filter(p=>p.type==="text")||[]).map(p=>("text"in p?p.text:"")||"").join(`
34
- `),c=o?.parts?.filter(p=>p.type==="subtask-result")||[];K.debug("loadHistory processing user message",{messageId:o?.info?.id,partCount:o?.parts?.length||0,subtaskPartCount:c.length});for(let p of c)if("agent"in p&&"taskId"in p){K.debug("loadHistory adding subtask-result",{messageId:o?.info?.id,agent:p.agent,taskId:p.taskId});let _=Ha.formatSubtaskResultPart(p);s.chatLog.addUser(_,o?.info?.id,{agent:p.agent||"SubAgent",isSubagentResult:!0,subtaskResultPart:{taskId:p.taskId,source:p.source,agent:p.agent,status:p.status,result:p.result,error:p.error,duration:p.duration,rounds:p.rounds,time:p.time,metadata:p.metadata}});}u&&s.chatLog.addUser(u,o?.info?.id,{agent:o?.info?.agent});}else if(l==="assistant"){let u=(o?.parts?.filter(c=>c.type==="text")||[]).map(c=>("text"in c?c.text:"")||"").join(`
34
+ `),c=o?.parts?.filter(p=>p.type==="subtask-result")||[];K.debug("loadHistory processing user message",{messageId:o?.info?.id,partCount:o?.parts?.length||0,subtaskPartCount:c.length});for(let p of c)if("agent"in p&&"taskId"in p){K.debug("loadHistory adding subtask-result",{messageId:o?.info?.id,agent:p.agent,taskId:p.taskId});let _=Ja.formatSubtaskResultPart(p);s.chatLog.addUser(_,o?.info?.id,{agent:p.agent||"SubAgent",isSubagentResult:!0,subtaskResultPart:{taskId:p.taskId,source:p.source,agent:p.agent,status:p.status,result:p.result,error:p.error,duration:p.duration,rounds:p.rounds,time:p.time,metadata:p.metadata}});}u&&s.chatLog.addUser(u,o?.info?.id,{agent:o?.info?.agent});}else if(l==="assistant"){let u=(o?.parts?.filter(c=>c.type==="text")||[]).map(c=>("text"in c?c.text:"")||"").join(`
35
35
  `);u&&s.chatLog.addAssistant(u,o?.info?.id,{agent:o?.info?.agent});}else if(l==="system"){let u=(o?.parts?.filter(c=>c.type==="text")||[]).map(c=>("text"in c?c.text:"")||"").join(`
36
- `);s.chatLog.addSystem(u,o?.info?.id,{agent:o?.info?.agent});}}return s.setActivityStatus(a$1("tui.status.ready")),r}catch(n){return K.error("Failed to load history",{sessionId:e,error:n}),s.chatLog.addSystem(a$1("tui.session.history_failed",{vars:{error:String(n)}})),s.setActivityStatus(a$1("tui.status.error")),[]}}async function Qt(s,e,t){K.info("Switching session",{sessionId:e});try{t.currentSessionId=e,t.currentSessionKey=e,t.historyLoaded=!1;let n=await dt(s,e);n&&(t.currentSessionKey=n.title||e,t.sessionInfo.model=n.model,t.sessionInfo.modelProvider=n.modelProvider);let{loadTuiState:r,saveTuiStateToStorage:a}=await import('./preferences-3HCTNG2J.mjs'),o=await r(e);t.toolsExpanded=o.toolsExpanded,t.showThinking=o.showThinking,t.thinkingLevel=o.thinkingLevel,t.verboseLevel=o.verboseLevel,t.messageLimit=o.messageLimit,t.localShellPermission=o.localShellPermission,o.model&&(t.sessionInfo.model=o.model),o.agent&&(t.agent=o.agent),K.debug("Session preferences loaded",{sessionId:e,model:t.sessionInfo.model,agent:t.agent,thinkingLevel:t.thinkingLevel}),await a(t),await Ue(s,e,t.messageLimit),t.historyLoaded=!0,s.chatLog.addSystem(a$1("tui.session.switched",{vars:{sessionId:e}}));}catch(n){K.error("Failed to switch session",{sessionId:e,error:n}),s.chatLog.addSystem(a$1("tui.session.switch_failed",{vars:{error:String(n)}})),s.setActivityStatus(a$1("tui.status.error"));}}async function Gt(s,e){K.info("Aborting current run",{sessionId:e});try{s.setActivityStatus(a$1("tui.session.aborting"));let t=s.sdk.session.abort({sessionID:e}),n=new Promise((r,a)=>{setTimeout(()=>a(new Error(a$1("tui.abort.timeout"))),5e3);});await Promise.race([t,n]),s.chatLog.addSystem(a$1("tui.session.aborted")),s.setActivityStatus(a$1("tui.status.ready"));}catch(t){K.error("Failed to abort",{sessionId:e,error:t}),s.chatLog.addSystem(a$1("tui.session.abort_failed",{vars:{error:String(t)}})),s.setActivityStatus(a$1("tui.status.error"));}}function jt(s,e){return {openOverlay:r=>{s.showOverlay(r);},closeOverlay:()=>{s.hasOverlay()&&s.hideOverlay(),s.setFocus(e);}}}var Oe=a.create({service:"tui-autocomplete"});function Kt(s){return new ct(s)}var ct=class{constructor(e){b(this,"basePath");b(this,"commands");b(this,"getAgents");this.basePath=e.basePath,this.commands=e.slashCommands,this.getAgents=e.getAgents;}updateCommands(e){this.commands=e;}setGetAgents(e){this.getAgents=e;}async getSuggestions(e,t,n,r){let o=(e[t]||"").slice(0,n),l=this.extractHashPrefix(o);if(l)return this.getFileSuggestions(l);let d=this.extractAtPrefix(o);return d?await this.getAgentSuggestions(d):o.startsWith("/")?this.getCommandSuggestions(o):null}applyCompletion(e,t,n,r,a){let o=e[t]||"",l=o.slice(0,n-a.length),d=o.slice(n);if(a.startsWith("#")){let u=r.label.endsWith("/"),c=u?r.value.replace(/\/$/,""):r.value,p=u?"":" ";return {lines:[...e.slice(0,t),l+c+p+d,...e.slice(t+1)],cursorLine:t,cursorCol:l.length+c.length+p.length}}if(a.startsWith("@"))return {lines:[...e.slice(0,t),l+r.value+" "+d,...e.slice(t+1)],cursorLine:t,cursorCol:l.length+r.value.length+1};if(a.startsWith("/")){let u="/"+r.value+" ";return {lines:[...e.slice(0,t),l+u+d,...e.slice(t+1)],cursorLine:t,cursorCol:l.length+u.length}}return {lines:[...e.slice(0,t),l+r.value+" "+d,...e.slice(t+1)],cursorLine:t,cursorCol:l.length+r.value.length+1}}async getCommandSuggestions(e){let t=e.indexOf(" ");if(t===-1){let d=e.slice(1),u=this.commands.filter(c=>c.name.toLowerCase().includes(d.toLowerCase())).map(c=>({value:c.name,label:c.name,description:c.description}));return u.length===0?null:{items:u.slice(0,50),prefix:e}}let n=e.slice(1,t),r=e.slice(t+1),a=this.commands.find(d=>d.name===n);if(!a?.getArgumentCompletions)return null;let o=a.getArgumentCompletions(r),l=o instanceof Promise?await o:o;return !l||l.length===0?null:{items:l.slice(0,50),prefix:r}}getFileSuggestions(e){let t=e.startsWith('#"')?e.slice(2):e.slice(1),n=e.startsWith('#"'),r=t.replace(/\\/g,"/");if(this.isDrivePath(r))return Oe.debug("Drive path, skip autocomplete",{normalizedPath:r}),null;let{targetPath:a,searchQuery:o}=this.parsePath(r),l=this.resolveBaseDir(a);try{let d;try{d=readdirSync(l,{withFileTypes:!0});}catch{return Oe.debug("Directory not found",{baseDir:l}),null}let u=[];for(let c of d){if(o&&!c.name.toLowerCase().includes(o.toLowerCase()))continue;let p=c.isDirectory(),_=a?`${a}${c.name}`:c.name;if(u.push({value:n?`#"${_}${p?"/":""}"`:`#${_}${p?"/":""}`,label:p?`${c.name}/`:c.name,description:_}),u.length>=50)break}return u.sort((c,p)=>{let _=c.label.endsWith("/"),$=p.label.endsWith("/");return _&&!$?-1:!_&&$?1:c.label.localeCompare(p.label)}),u.length===0?null:{items:u,prefix:e}}catch(d){return Oe.debug("File search failed",{error:d,targetPath:a}),null}}async getAgentSuggestions(e){if(!this.getAgents)return null;let t=e.slice(1);try{let r=(await this.getAgents()).filter(a=>a.hidden!==!0).filter(a=>a.name.toLowerCase().includes(t.toLowerCase())).map(a=>({value:`@${a.name}`,label:a.name,description:a.description}));return r.length===0?null:{items:r.slice(0,50),prefix:e}}catch(n){return Oe.debug("Agent search failed",{error:n,prefix:e}),null}}extractAtPrefix(e){let t=new Set([" "," ",'"',"'","="]);for(let n=e.length-1;n>=0;n--)if(t.has(e[n]??"")){let r=n+1;return e[r]==="@"?e.slice(r):null}return e.startsWith("@")?e:null}extractHashPrefix(e){let t=new Set([" "," ",'"',"'","="]);for(let n=e.length-1;n>=0;n--)if(t.has(e[n]??"")){let r=n+1;return e[r]==="#"?e.slice(r):null}return e.startsWith("#")?e:null}isDrivePath(e){return /^[A-Za-z]:[/\\]?$/.test(e)}parsePath(e){let t=Math.max(e.lastIndexOf("/"),e.lastIndexOf("\\"));return t===-1?{targetPath:"",searchQuery:e}:{targetPath:e.slice(0,t+1),searchQuery:e.slice(t+1)}}resolveBaseDir(e){return e?zt.join(this.basePath,e):this.basePath}};function ut(s,e){let t=[],n=/(?<![\w`])#(\S+)/g,r;for(;(r=n.exec(s))!==null;){let a=r[1];if(!a)continue;let o=a.replace(/\\/g,"/"),l=js(o,e);existsSync(l)&&t.push({path:a,url:pathToFileURL(l).href,exists:true});}return {attachments:t,invalidPaths:[]}}function js(s,e){if(/^[A-Za-z]:[/\\]/.test(s))return s;let t=s.replace(/^[/\\]+/,"");return zt.join(e,t)}var U=a.create({service:"cli-tui-input-handlers"}),We=class{constructor(){b(this,"handlers",[]);b(this,"isBrowsingHistory",false);}register(e){this.handlers.push(e),U.debug("Register input handler",{name:e.name,total:this.handlers.length});}setHistoryBrowsing(e){this.isBrowsingHistory=e;}isHistoryBrowsing(){return this.isBrowsingHistory}async handle(e,t){let n=e.trim();if(n){this.isBrowsingHistory;for(let r of this.handlers)if(r.canHandle(n,t.state)){U.debug("Handle input with handler",{handler:r.name,input:n.substring(0,50)}),await r.handle(n,t);return}U.warn("No handler can process input",{input:n.substring(0,50)});}}getPrompt(e){for(let t of this.handlers)if(t.getPrompt&&t.canHandle("",e)){let n=t.getPrompt(e);if(n)return n}return "> "}},Ne=class{constructor(){b(this,"name","permission");}canHandle(e,t){return t.pendingPermission!==null}async handle(e,t){let{state:n,chatLog:r,tui:a}=t,o=n.pendingPermission;if(!o)return;let l=e.toLowerCase().trim(),d;if(l==="y"||l==="yes")d="once";else if(l==="a"||l==="always")d="always";else if(l==="n"||l==="no"||l==="reject")d="reject";else {r.addSystem(a$1("tui.permission.invalid_input"));return}try{await oa(n,{requestID:o.id,reply:d}),n.pendingPermission=null;let u=d==="once"?a$1("tui.permission.once"):d==="always"?a$1("tui.permission.always"):a$1("tui.permission.reject");r.addSystem(a$1("tui.permission.replied",{vars:{reply:u}})),U.info("Permission request replied",{requestID:o.id,reply:d});}catch(u){U.error("Failed to reply permission request",{error:u}),r.addSystem(a$1("tui.permission.error")),n.pendingPermission=null;}}getPrompt(e){return e.pendingPermission?a$1("tui.permission.prompt"):"> "}},Qe=class{constructor(){b(this,"name","question");}canHandle(e,t){return !(t.pendingQuestion===null||e.startsWith("/"))}async handle(e,t){let{state:n,chatLog:r,tui:a}=t,o=n.pendingQuestion;if(!o){U.warn("QuestionInputHandler.handle - no pending question");return}U.debug("QuestionInputHandler.handle - processing input",{input:e.substring(0,50),currentIndex:o.currentQuestionIndex,totalQuestions:o.questions.length,requestID:o.id});let l=o.currentQuestionIndex,d=o.questions[l];if(!d){U.error("Current question does not exist",{currentIndex:l,totalQuestions:o.questions.length}),n.pendingQuestion=null;return}let u=this.parseAnswer(e,d);if(!u){U.debug("QuestionInputHandler.handle - invalid input",{input:e}),r.addSystem(a$1("tui.question.invalid_input"));return}if(U.debug("QuestionInputHandler.handle - answer parsed",{answer:u,answerLength:u.length}),o.collectedAnswers.push(u),o.currentQuestionIndex++,o.currentQuestionIndex<o.questions.length){U.debug("QuestionInputHandler.handle - showing next question",{nextIndex:o.currentQuestionIndex,totalQuestions:o.questions.length});let c=o.questions[o.currentQuestionIndex];c&&this.displayQuestion(c,o.currentQuestionIndex,o.questions.length,r);}else {U.info("QuestionInputHandler.handle - all questions answered, calling API",{requestID:o.id,answerCount:o.collectedAnswers.length,answers:o.collectedAnswers});try{await pa(n,{requestID:o.id,answers:o.collectedAnswers}),n.pendingQuestion=null,r.addSystem(a$1("tui.question.completed",{vars:{count:o.collectedAnswers.length}})),U.info("Question request completed",{requestID:o.id});}catch(c){U.error("Failed to reply question request",{error:c instanceof Error?c.message:String(c),stack:c instanceof Error?c.stack:void 0,requestID:o.id,answers:o.collectedAnswers,errorType:c instanceof Error?c.constructor.name:typeof c});let p=c instanceof Error?c.message:String(c);r.addSystem(`${a$1("tui.question.error")}: ${p}`),n.pendingQuestion=null;}}}parseAnswer(e,t){let n=e.trim();if(!t.options||t.options.length===0)return [n];let r=n.match(/^(\d+(?:,\s*\d+)*)$/);if(r?.[1]){let o=r[1].split(",").map(l=>Number.parseInt(l.trim(),10)).filter(l=>l>0&&l<=t.options.length);if(o.length===0)return null;if(!t.multiple&&o.length>1){let l=o[0];if(l!==void 0){let d=t.options[l-1];if(d)return [d.label]}return null}return o.map(l=>{let d=t.options[l-1];return d?d.label:""}).filter(l=>l!=="")}return t.custom===false?null:[n]}displayQuestion(e,t,n,r){let a=`
36
+ `);s.chatLog.addSystem(u,o?.info?.id,{agent:o?.info?.agent});}}return s.setActivityStatus(a$1("tui.status.ready")),r}catch(n){return K.error("Failed to load history",{sessionId:e,error:n}),s.chatLog.addSystem(a$1("tui.session.history_failed",{vars:{error:String(n)}})),s.setActivityStatus(a$1("tui.status.error")),[]}}async function Qt(s,e,t){K.info("Switching session",{sessionId:e});try{t.currentSessionId=e,t.currentSessionKey=e,t.historyLoaded=!1;let n=await dt(s,e);n&&(t.currentSessionKey=n.title||e,t.sessionInfo.model=n.model,t.sessionInfo.modelProvider=n.modelProvider);let{loadTuiState:r,saveTuiStateToStorage:a}=await import('./preferences-H2TY25O6.mjs'),o=await r(e);t.toolsExpanded=o.toolsExpanded,t.showThinking=o.showThinking,t.thinkingLevel=o.thinkingLevel,t.verboseLevel=o.verboseLevel,t.messageLimit=o.messageLimit,t.localShellPermission=o.localShellPermission,o.model&&(t.sessionInfo.model=o.model),o.agent&&(t.agent=o.agent),K.debug("Session preferences loaded",{sessionId:e,model:t.sessionInfo.model,agent:t.agent,thinkingLevel:t.thinkingLevel}),await a(t),await Ue(s,e,t.messageLimit),t.historyLoaded=!0,s.chatLog.addSystem(a$1("tui.session.switched",{vars:{sessionId:e}}));}catch(n){K.error("Failed to switch session",{sessionId:e,error:n}),s.chatLog.addSystem(a$1("tui.session.switch_failed",{vars:{error:String(n)}})),s.setActivityStatus(a$1("tui.status.error"));}}async function Gt(s,e){K.info("Aborting current run",{sessionId:e});try{s.setActivityStatus(a$1("tui.session.aborting"));let t=s.sdk.session.abort({sessionID:e}),n=new Promise((r,a)=>{setTimeout(()=>a(new Error(a$1("tui.abort.timeout"))),5e3);});await Promise.race([t,n]),s.chatLog.addSystem(a$1("tui.session.aborted")),s.setActivityStatus(a$1("tui.status.ready"));}catch(t){K.error("Failed to abort",{sessionId:e,error:t}),s.chatLog.addSystem(a$1("tui.session.abort_failed",{vars:{error:String(t)}})),s.setActivityStatus(a$1("tui.status.error"));}}function jt(s,e){return {openOverlay:r=>{s.showOverlay(r);},closeOverlay:()=>{s.hasOverlay()&&s.hideOverlay(),s.setFocus(e);}}}var Oe=a.create({service:"tui-autocomplete"});function Kt(s){return new ct(s)}var ct=class{constructor(e){b(this,"basePath");b(this,"commands");b(this,"getAgents");this.basePath=e.basePath,this.commands=e.slashCommands,this.getAgents=e.getAgents;}updateCommands(e){this.commands=e;}setGetAgents(e){this.getAgents=e;}async getSuggestions(e,t,n,r){let o=(e[t]||"").slice(0,n),l=this.extractHashPrefix(o);if(l)return this.getFileSuggestions(l);let d=this.extractAtPrefix(o);return d?await this.getAgentSuggestions(d):o.startsWith("/")?this.getCommandSuggestions(o):null}applyCompletion(e,t,n,r,a){let o=e[t]||"",l=o.slice(0,n-a.length),d=o.slice(n);if(a.startsWith("#")){let u=r.label.endsWith("/"),c=u?r.value.replace(/\/$/,""):r.value,p=u?"":" ";return {lines:[...e.slice(0,t),l+c+p+d,...e.slice(t+1)],cursorLine:t,cursorCol:l.length+c.length+p.length}}if(a.startsWith("@"))return {lines:[...e.slice(0,t),l+r.value+" "+d,...e.slice(t+1)],cursorLine:t,cursorCol:l.length+r.value.length+1};if(a.startsWith("/")){let u="/"+r.value+" ";return {lines:[...e.slice(0,t),l+u+d,...e.slice(t+1)],cursorLine:t,cursorCol:l.length+u.length}}return {lines:[...e.slice(0,t),l+r.value+" "+d,...e.slice(t+1)],cursorLine:t,cursorCol:l.length+r.value.length+1}}async getCommandSuggestions(e){let t=e.indexOf(" ");if(t===-1){let d=e.slice(1),u=this.commands.filter(c=>c.name.toLowerCase().includes(d.toLowerCase())).map(c=>({value:c.name,label:c.name,description:c.description}));return u.length===0?null:{items:u.slice(0,50),prefix:e}}let n=e.slice(1,t),r=e.slice(t+1),a=this.commands.find(d=>d.name===n);if(!a?.getArgumentCompletions)return null;let o=a.getArgumentCompletions(r),l=o instanceof Promise?await o:o;return !l||l.length===0?null:{items:l.slice(0,50),prefix:r}}getFileSuggestions(e){let t=e.startsWith('#"')?e.slice(2):e.slice(1),n=e.startsWith('#"'),r=t.replace(/\\/g,"/");if(this.isDrivePath(r))return Oe.debug("Drive path, skip autocomplete",{normalizedPath:r}),null;let{targetPath:a,searchQuery:o}=this.parsePath(r),l=this.resolveBaseDir(a);try{let d;try{d=readdirSync(l,{withFileTypes:!0});}catch{return Oe.debug("Directory not found",{baseDir:l}),null}let u=[];for(let c of d){if(o&&!c.name.toLowerCase().includes(o.toLowerCase()))continue;let p=c.isDirectory(),_=a?`${a}${c.name}`:c.name;if(u.push({value:n?`#"${_}${p?"/":""}"`:`#${_}${p?"/":""}`,label:p?`${c.name}/`:c.name,description:_}),u.length>=50)break}return u.sort((c,p)=>{let _=c.label.endsWith("/"),$=p.label.endsWith("/");return _&&!$?-1:!_&&$?1:c.label.localeCompare(p.label)}),u.length===0?null:{items:u,prefix:e}}catch(d){return Oe.debug("File search failed",{error:d,targetPath:a}),null}}async getAgentSuggestions(e){if(!this.getAgents)return null;let t=e.slice(1);try{let r=(await this.getAgents()).filter(a=>a.hidden!==!0).filter(a=>a.name.toLowerCase().includes(t.toLowerCase())).map(a=>({value:`@${a.name}`,label:a.name,description:a.description}));return r.length===0?null:{items:r.slice(0,50),prefix:e}}catch(n){return Oe.debug("Agent search failed",{error:n,prefix:e}),null}}extractAtPrefix(e){let t=new Set([" "," ",'"',"'","="]);for(let n=e.length-1;n>=0;n--)if(t.has(e[n]??"")){let r=n+1;return e[r]==="@"?e.slice(r):null}return e.startsWith("@")?e:null}extractHashPrefix(e){let t=new Set([" "," ",'"',"'","="]);for(let n=e.length-1;n>=0;n--)if(t.has(e[n]??"")){let r=n+1;return e[r]==="#"?e.slice(r):null}return e.startsWith("#")?e:null}isDrivePath(e){return /^[A-Za-z]:[/\\]?$/.test(e)}parsePath(e){let t=Math.max(e.lastIndexOf("/"),e.lastIndexOf("\\"));return t===-1?{targetPath:"",searchQuery:e}:{targetPath:e.slice(0,t+1),searchQuery:e.slice(t+1)}}resolveBaseDir(e){return e?zt.join(this.basePath,e):this.basePath}};function ut(s,e){let t=[],n=/(?<![\w`])#(\S+)/g,r;for(;(r=n.exec(s))!==null;){let a=r[1];if(!a)continue;let o=a.replace(/\\/g,"/"),l=js(o,e);existsSync(l)&&t.push({path:a,url:pathToFileURL(l).href,exists:true});}return {attachments:t,invalidPaths:[]}}function js(s,e){if(/^[A-Za-z]:[/\\]/.test(s))return s;let t=s.replace(/^[/\\]+/,"");return zt.join(e,t)}var U=a.create({service:"cli-tui-input-handlers"}),We=class{constructor(){b(this,"handlers",[]);b(this,"isBrowsingHistory",false);}register(e){this.handlers.push(e),U.debug("Register input handler",{name:e.name,total:this.handlers.length});}setHistoryBrowsing(e){this.isBrowsingHistory=e;}isHistoryBrowsing(){return this.isBrowsingHistory}async handle(e,t){let n=e.trim();if(n){this.isBrowsingHistory;for(let r of this.handlers)if(r.canHandle(n,t.state)){U.debug("Handle input with handler",{handler:r.name,input:n.substring(0,50)}),await r.handle(n,t);return}U.warn("No handler can process input",{input:n.substring(0,50)});}}getPrompt(e){for(let t of this.handlers)if(t.getPrompt&&t.canHandle("",e)){let n=t.getPrompt(e);if(n)return n}return "> "}},Ne=class{constructor(){b(this,"name","permission");}canHandle(e,t){return t.pendingPermission!==null}async handle(e,t){let{state:n,chatLog:r,tui:a}=t,o=n.pendingPermission;if(!o)return;let l=e.toLowerCase().trim(),d;if(l==="y"||l==="yes")d="once";else if(l==="a"||l==="always")d="always";else if(l==="n"||l==="no"||l==="reject")d="reject";else {r.addSystem(a$1("tui.permission.invalid_input"));return}try{await pa(n,{requestID:o.id,reply:d}),n.pendingPermission=null;let u=d==="once"?a$1("tui.permission.once"):d==="always"?a$1("tui.permission.always"):a$1("tui.permission.reject");r.addSystem(a$1("tui.permission.replied",{vars:{reply:u}})),U.info("Permission request replied",{requestID:o.id,reply:d});}catch(u){U.error("Failed to reply permission request",{error:u}),r.addSystem(a$1("tui.permission.error")),n.pendingPermission=null;}}getPrompt(e){return e.pendingPermission?a$1("tui.permission.prompt"):"> "}},Qe=class{constructor(){b(this,"name","question");}canHandle(e,t){return !(t.pendingQuestion===null||e.startsWith("/"))}async handle(e,t){let{state:n,chatLog:r,tui:a}=t,o=n.pendingQuestion;if(!o){U.warn("QuestionInputHandler.handle - no pending question");return}U.debug("QuestionInputHandler.handle - processing input",{input:e.substring(0,50),currentIndex:o.currentQuestionIndex,totalQuestions:o.questions.length,requestID:o.id});let l=o.currentQuestionIndex,d=o.questions[l];if(!d){U.error("Current question does not exist",{currentIndex:l,totalQuestions:o.questions.length}),n.pendingQuestion=null;return}let u=this.parseAnswer(e,d);if(!u){U.debug("QuestionInputHandler.handle - invalid input",{input:e}),r.addSystem(a$1("tui.question.invalid_input"));return}if(U.debug("QuestionInputHandler.handle - answer parsed",{answer:u,answerLength:u.length}),o.collectedAnswers.push(u),o.currentQuestionIndex++,o.currentQuestionIndex<o.questions.length){U.debug("QuestionInputHandler.handle - showing next question",{nextIndex:o.currentQuestionIndex,totalQuestions:o.questions.length});let c=o.questions[o.currentQuestionIndex];c&&this.displayQuestion(c,o.currentQuestionIndex,o.questions.length,r);}else {U.info("QuestionInputHandler.handle - all questions answered, calling API",{requestID:o.id,answerCount:o.collectedAnswers.length,answers:o.collectedAnswers});try{await qa(n,{requestID:o.id,answers:o.collectedAnswers}),n.pendingQuestion=null,r.addSystem(a$1("tui.question.completed",{vars:{count:o.collectedAnswers.length}})),U.info("Question request completed",{requestID:o.id});}catch(c){U.error("Failed to reply question request",{error:c instanceof Error?c.message:String(c),stack:c instanceof Error?c.stack:void 0,requestID:o.id,answers:o.collectedAnswers,errorType:c instanceof Error?c.constructor.name:typeof c});let p=c instanceof Error?c.message:String(c);r.addSystem(`${a$1("tui.question.error")}: ${p}`),n.pendingQuestion=null;}}}parseAnswer(e,t){let n=e.trim();if(!t.options||t.options.length===0)return [n];let r=n.match(/^(\d+(?:,\s*\d+)*)$/);if(r?.[1]){let o=r[1].split(",").map(l=>Number.parseInt(l.trim(),10)).filter(l=>l>0&&l<=t.options.length);if(o.length===0)return null;if(!t.multiple&&o.length>1){let l=o[0];if(l!==void 0){let d=t.options[l-1];if(d)return [d.label]}return null}return o.map(l=>{let d=t.options[l-1];return d?d.label:""}).filter(l=>l!=="")}return t.custom===false?null:[n]}displayQuestion(e,t,n,r){let a=`
37
37
  ${a$1("tui.question.header",{vars:{current:t+1,total:n}})}
38
38
  `;if(a+=`${e.header}
39
39
  `,a+=`${e.question}
@@ -52,8 +52,8 @@ ${a$1("tui.question.header",{vars:{current:t+1,total:n}})}
52
52
  ${o.stdout}`),o.stderr?.trim()&&(l+=`
53
53
  ${o.stderr}`),l&&n.addSystem(l),n.addSystem(a$1("tui.shell.success",{vars:{code:o.code}})),a(""),U.info("Shell command executed successfully",{command:e,exitCode:o.code,stdoutLength:o.stdout?.length||0,stderrLength:o.stderr?.length||0});}catch(o){U.error("Failed to execute shell command",{command:e,error:o instanceof Error?o.message:String(o)});let l=o instanceof Error?o.message:String(o);n.addSystem(a$1("tui.shell.error",{vars:{error:l}})),a("");}}getPrompt(e){return "$ "}},je=class{constructor(){b(this,"name","command");}canHandle(e,t){return e.startsWith("/")}async handle(e,t){t.handleCommand?await t.handleCommand(e):U.warn("handleCommand is not defined");}getPrompt(e){return "> "}},ze=class{constructor(){b(this,"name","normal");}canHandle(e,t){return true}async handle(e,t){t.sendMessage?await t.sendMessage(e):U.warn("sendMessage is not defined");}getPrompt(e){return "> "}},Ke=class{constructor(){b(this,"name","at-mention");}canHandle(e,t){if(e.startsWith("/")||e.startsWith("!"))return false;let n=e.trimStart();return n.startsWith("@")||n.startsWith("#")}async handle(e,t){let{chatLog:n,sendMessage:r,state:a}=t,o=e.trimStart();if(o.startsWith("@")){let l=o.slice(1).split(/\s+/)[0];if(!l)return;let d=e.replace(/@\S+/g,"").trim(),c=ut(e,a.instanceContext.directory).attachments.map(p=>({url:p.url,filename:p.path.split("/").pop()||p.path.split("\\").pop()||p.path,mime:"text/plain"}));r&&await r(d,c.length>0?c:void 0,l);return}if(o.startsWith("#")){let l=ut(e,a.instanceContext.directory);if(l.attachments.length===0)return;let d=e.replace(/#\S+/g,"").trim(),u=l.attachments.map(c=>({url:c.url,filename:c.path.split("/").pop()||c.path.split("\\").pop()||c.path,mime:"text/plain"}));r&&await r(d,u);return}}getPrompt(e){return "> "}};var Vs=loadTextFile("./banner.txt",import.meta.url),Js=Vs();function Vt(){try{let s=Js.replace("${Global.getVersion()}",a$3.getVersion());return s=s.replace("${t('tui.header.title')}",a$1("tui.header.title")),s}catch{return `EasBot v${a$3.getVersion()}
54
54
  ${a$1("tui.header.title")}
55
- `}}var mt=class{constructor(e){b(this,"log");b(this,"client");b(this,"config");b(this,"connected",false);this.config=e,this.log=a.create({service:"tui-gateway-client"}),this.client=new GatewayClient({url:e.gatewayUrl,type:"tui",reconnect:{enabled:true,maxAttempts:5,delay:3e3},heartbeat:{enabled:true,interval:3e4}}),this.client.onMessage(async t=>{this.log.debug("received message from gateway",{messageId:t.id,sessionId:t.sessionId,type:t.type}),e.onMessage&&await e.onMessage(t);});}async connect(){if(this.connected){this.log.warn("already connected");return}this.log.info("connecting to gateway",{url:this.config.gatewayUrl});try{await this.client.connect(),this.connected=!0,await this.client.subscribe(this.config.sessionId,this.config.backendSessionId),this.log.info("connected to gateway",{sessionId:this.config.sessionId,backendSessionId:this.config.backendSessionId}),this.config.onStateChange?.("connected");}catch(e){throw this.log.error("failed to connect to gateway",{error:String(e)}),e}}async disconnect(){this.connected&&(this.log.info("disconnecting from gateway"),await this.client.unsubscribe(this.config.sessionId),await this.client.disconnect(),this.connected=false,this.config.onStateChange?.("disconnected"),this.log.info("disconnected from gateway"));}async sendMessage(e,t="output"){if(!this.connected)throw new Error("Not connected to gateway");let n={id:this.generateId(),sessionId:this.config.sessionId,type:t,content:[{type:"text",text:e}],metadata:{channel:{platform:"tui",channelId:this.client.getId()}},timestamp:Date.now()};await this.client.send(n),this.log.debug("message sent",{id:n.id,type:t});}async subscribeSession(e,t){if(!this.connected)throw new Error("Not connected to gateway");await this.client.subscribe(e,t||this.config.backendSessionId),this.log.info("subscribed to session",{sessionId:e,backendSessionId:t||this.config.backendSessionId});}async unsubscribeSession(e){if(!this.connected)throw new Error("Not connected to gateway");await this.client.unsubscribe(e),this.log.info("unsubscribed from session",{sessionId:e});}isConnected(){return this.connected}getClientId(){return this.client.getId()}getSubscribedSessions(){return this.client.getSubscriptions()}generateId(){return `tui_${Date.now()}_${Math.random().toString(36).substring(2,9)}`}};function Jt(s){return new mt(s)}var C=a.create({service:"cli-tui-app"}),gt=null;function Xs(s){gt=s;}function en(){gt=null;}function Xi(){return gt}async function er(s,e){C.debug("Create TUI app component",{options:e}),process.env.EASBOT_TUI_MODE="1",C.debug("Set TUI mode environment variable",{EASBOT_TUI_MODE:process.env.EASBOT_TUI_MODE});let t=new Container,n=new Container,r=Vt(),a=new Text(ee.header(r),1,0);n.addChild(a),t.addChild(n);let o=new $e;t.addChild(o),o.setWidth(s.terminal.columns);let l=s.requestRender.bind(s);s.requestRender=()=>{o.setWidth(s.terminal.columns),l();},o.addSystem(a$1("tui.system.welcome")),o.addSystem(a$1("tui.system.help_hint"));let d=new Container;t.addChild(d);let u=null,c=null,p=()=>{u&&c||(d.clear(),u=new Text("",1,0),c=new Text("",1,0),d.addChild(u),d.addChild(c));},_=new Container,$=new Text("",1,0);_.addChild($),t.addChild(_);let ne=new Container,A=new _e(s,Mt);ne.addChild(A),t.addChild(ne);let M=Rt(),he=Kt({basePath:e.directory||process.cwd(),slashCommands:M});A.setAutocompleteProvider(he);let{state:h,unsubscribe:re}=await la({options:e,agent:e.agent,model:e.model,sessionId:e.sessionId},s,o,()=>{q();});C.debug("TUI state initialized",{agent:h.agent,model:h.sessionInfo.model,sessionId:h.currentSessionId}),he.setGetAgents(async()=>qa(h));try{M=await _t(h.sdk,h.contextMode),he.updateCommands?.(M),C.debug("Dynamic commands loaded with contextMode",{contextMode:h.contextMode,count:M.length});}catch(m){C.warn("Failed to load dynamic commands, using static commands only",{error:m});}o.setStateGetter(()=>h),C.debug("ChatLog state getter configured");let H="disconnected",w=async()=>{try{let{getGatewayServerConfig:m}=await import('./gateway-loader-6P6BTWQP.mjs'),P=await m(),R=`http://${P.hostname}:${P.port}`,F=new AbortController,j=setTimeout(()=>F.abort(),2e3);try{let Z=await Fetch.get(R,{signal:F.signal});return clearTimeout(j),Z.ok||Z.status===400||Z.status===404?"connected":"disconnected"}catch{return clearTimeout(j),"disconnected"}}catch{return "disconnected"}},f=async()=>{H=await w(),b=H==="connected"?a$1("tui.status.connection.gateway_connected"):a$1("tui.status.connection.local"),Y();},g=()=>{f(),setInterval(f,6e4);},k=a$1("tui.status.idle"),b=a$1("tui.status.connection.local"),S="",E=null,y=null,G=k,te=new Set([a$1("tui.handler.send.sending"),a$1("tui.status.thinking"),a$1("tui.status.receiving"),a$1("tui.status.running"),a$1("tui.status.waiting"),a$1("tui.status.executing_step"),a$1("tui.status.sending"),a$1("tui.status.waiting_permission"),a$1("tui.status.waiting_answer"),a$1("tui.status.step_completed"),a$1("tui.status.tool_completed")]),fe=m=>{if(te.has(m))return true;let P=a$1("tui.status.executing_tool",{vars:{tool:""}}).split(":")[0];if(m.startsWith(P))return true;let R=a$1("tui.handler.executing",{vars:{command:""}}).split(":")[0];return !!m.startsWith(R)},ae=m=>{let P=Math.max(0,Math.floor((Date.now()-m)/1e3));if(P<60)return `${P}s`;let R=Math.floor(P/60),F=P%60;return `${R}m ${F}s`},Je=()=>{y||(y=setInterval(()=>{!E||!fe(k)||(Y(),q());},1e3));},ke=()=>{y&&(clearInterval(y),y=null);},Y=()=>{if(p(),!u||!c)return;let m=fe(k);G!==k&&(m?(E=Date.now(),Je()):(E=null,ke()),G=k);let P=a$1("tui.status.label"),R=k;if(m&&E){let Ct=ae(E);R=`${R} \u2022 ${Ct}`;}let F=`${P} ${R} | ${b}`;u.setText(ee.header(F));let j=h.showThinking?a$1("tui.system.on"):a$1("tui.system.off"),Z=h.toolsExpanded?a$1("tui.system.on"):a$1("tui.system.off"),ue=[`ctrl+l: ${a$1("tui.keyhints.model")} | ctrl+g: ${a$1("tui.keyhints.agent")} | ctrl+p: ${a$1("tui.keyhints.session")} | ctrl+t: ${a$1("tui.keyhints.thinking")}(${j}) | ctrl+o: ${a$1("tui.keyhints.tools")}(${Z})`];S&&ue.push(S);let X=ue.join(" | ");c.setText(ee.header(X)),d.invalidate();},Ye=()=>{},oe=()=>{let m=h.agent||"unknown",P=h.sessionInfo.model||"unknown",R=h.currentSessionKey||"new",j=((Z,O)=>{if(!Z||Z===0)return "";let ue=Z.toLocaleString();if(O&&O>0){let X=Math.round(Z/O*100);return ` | Tokens: ${ue} (${X}%)`}return ` | Tokens: ${ue}`})(h.sessionInfo.totalTokens,h.sessionInfo.contextTokens);$.setText(ee.dim(a$1("tui.footer.info",{vars:{agent:m,model:P,session:R,tokens:j}}))),_.invalidate();};Y(),oe();let q=()=>{s.requestRender();},pt=setInterval(()=>{oe(),q();},1e3),Yt=()=>{pt&&clearInterval(pt),ke();},{openOverlay:Pe,closeOverlay:de}=jt(s,A),Ze=()=>{C.debug("Request TUI exit"),h.currentSessionId&&(console.log(`
55
+ `}}var mt=class{constructor(e){b(this,"log");b(this,"client");b(this,"config");b(this,"connected",false);this.config=e,this.log=a.create({service:"tui-gateway-client"}),this.client=new GatewayClient({url:e.gatewayUrl,type:"tui",reconnect:{enabled:true,maxAttempts:5,delay:3e3},heartbeat:{enabled:true,interval:3e4}}),this.client.onMessage(async t=>{this.log.debug("received message from gateway",{messageId:t.id,sessionId:t.sessionId,type:t.type}),e.onMessage&&await e.onMessage(t);});}async connect(){if(this.connected){this.log.warn("already connected");return}this.log.info("connecting to gateway",{url:this.config.gatewayUrl});try{await this.client.connect(),this.connected=!0,await this.client.subscribe(this.config.sessionId,this.config.backendSessionId),this.log.info("connected to gateway",{sessionId:this.config.sessionId,backendSessionId:this.config.backendSessionId}),this.config.onStateChange?.("connected");}catch(e){throw this.log.error("failed to connect to gateway",{error:String(e)}),e}}async disconnect(){this.connected&&(this.log.info("disconnecting from gateway"),await this.client.unsubscribe(this.config.sessionId),await this.client.disconnect(),this.connected=false,this.config.onStateChange?.("disconnected"),this.log.info("disconnected from gateway"));}async sendMessage(e,t="output"){if(!this.connected)throw new Error("Not connected to gateway");let n={id:this.generateId(),sessionId:this.config.sessionId,type:t,content:[{type:"text",text:e}],metadata:{channel:{platform:"tui",channelId:this.client.getId()}},timestamp:Date.now()};await this.client.send(n),this.log.debug("message sent",{id:n.id,type:t});}async subscribeSession(e,t){if(!this.connected)throw new Error("Not connected to gateway");await this.client.subscribe(e,t||this.config.backendSessionId),this.log.info("subscribed to session",{sessionId:e,backendSessionId:t||this.config.backendSessionId});}async unsubscribeSession(e){if(!this.connected)throw new Error("Not connected to gateway");await this.client.unsubscribe(e),this.log.info("unsubscribed from session",{sessionId:e});}isConnected(){return this.connected}getClientId(){return this.client.getId()}getSubscribedSessions(){return this.client.getSubscriptions()}generateId(){return `tui_${Date.now()}_${Math.random().toString(36).substring(2,9)}`}};function Jt(s){return new mt(s)}var C=a.create({service:"cli-tui-app"}),gt=null;function Xs(s){gt=s;}function en(){gt=null;}function Xi(){return gt}async function er(s,e){C.debug("Create TUI app component",{options:e}),process.env.EASBOT_TUI_MODE="1",C.debug("Set TUI mode environment variable",{EASBOT_TUI_MODE:process.env.EASBOT_TUI_MODE});let t=new Container,n=new Container,r=Vt(),a=new Text(ee.header(r),1,0);n.addChild(a),t.addChild(n);let o=new $e;t.addChild(o),o.setWidth(s.terminal.columns);let l=s.requestRender.bind(s);s.requestRender=()=>{o.setWidth(s.terminal.columns),l();},o.addSystem(a$1("tui.system.welcome")),o.addSystem(a$1("tui.system.help_hint"));let d=new Container;t.addChild(d);let u=null,c=null,p=()=>{u&&c||(d.clear(),u=new Text("",1,0),c=new Text("",1,0),d.addChild(u),d.addChild(c));},_=new Container,$=new Text("",1,0);_.addChild($),t.addChild(_);let ne=new Container,A=new _e(s,Mt);ne.addChild(A),t.addChild(ne);let M=Rt(),he=Kt({basePath:e.directory||process.cwd(),slashCommands:M});A.setAutocompleteProvider(he);let{state:h,unsubscribe:re}=await ma({options:e,agent:e.agent,model:e.model,sessionId:e.sessionId},s,o,()=>{q();});C.debug("TUI state initialized",{agent:h.agent,model:h.sessionInfo.model,sessionId:h.currentSessionId}),he.setGetAgents(async()=>ra(h));try{M=await _t(h.sdk,h.contextMode),he.updateCommands?.(M),C.debug("Dynamic commands loaded with contextMode",{contextMode:h.contextMode,count:M.length});}catch(m){C.warn("Failed to load dynamic commands, using static commands only",{error:m});}o.setStateGetter(()=>h),C.debug("ChatLog state getter configured");let H="disconnected",w=async()=>{try{let{getGatewayServerConfig:m}=await import('./gateway-loader-6P6BTWQP.mjs'),P=await m(),R=`http://${P.hostname}:${P.port}`,F=new AbortController,j=setTimeout(()=>F.abort(),2e3);try{let Z=await Fetch.get(R,{signal:F.signal});return clearTimeout(j),Z.ok||Z.status===400||Z.status===404?"connected":"disconnected"}catch{return clearTimeout(j),"disconnected"}}catch{return "disconnected"}},f=async()=>{H=await w(),b=H==="connected"?a$1("tui.status.connection.gateway_connected"):a$1("tui.status.connection.local"),Y();},g=()=>{f(),setInterval(f,6e4);},k=a$1("tui.status.idle"),b=a$1("tui.status.connection.local"),S="",E=null,y=null,G=k,te=new Set([a$1("tui.handler.send.sending"),a$1("tui.status.thinking"),a$1("tui.status.receiving"),a$1("tui.status.running"),a$1("tui.status.waiting"),a$1("tui.status.executing_step"),a$1("tui.status.sending"),a$1("tui.status.waiting_permission"),a$1("tui.status.waiting_answer"),a$1("tui.status.step_completed"),a$1("tui.status.tool_completed")]),fe=m=>{if(te.has(m))return true;let P=a$1("tui.status.executing_tool",{vars:{tool:""}}).split(":")[0];if(m.startsWith(P))return true;let R=a$1("tui.handler.executing",{vars:{command:""}}).split(":")[0];return !!m.startsWith(R)},ae=m=>{let P=Math.max(0,Math.floor((Date.now()-m)/1e3));if(P<60)return `${P}s`;let R=Math.floor(P/60),F=P%60;return `${R}m ${F}s`},Je=()=>{y||(y=setInterval(()=>{!E||!fe(k)||(Y(),q());},1e3));},ke=()=>{y&&(clearInterval(y),y=null);},Y=()=>{if(p(),!u||!c)return;let m=fe(k);G!==k&&(m?(E=Date.now(),Je()):(E=null,ke()),G=k);let P=a$1("tui.status.label"),R=k;if(m&&E){let Ct=ae(E);R=`${R} \u2022 ${Ct}`;}let F=`${P} ${R} | ${b}`;u.setText(ee.header(F));let j=h.showThinking?a$1("tui.system.on"):a$1("tui.system.off"),Z=h.toolsExpanded?a$1("tui.system.on"):a$1("tui.system.off"),ue=[`ctrl+l: ${a$1("tui.keyhints.model")} | ctrl+g: ${a$1("tui.keyhints.agent")} | ctrl+p: ${a$1("tui.keyhints.session")} | ctrl+t: ${a$1("tui.keyhints.thinking")}(${j}) | ctrl+o: ${a$1("tui.keyhints.tools")}(${Z})`];S&&ue.push(S);let X=ue.join(" | ");c.setText(ee.header(X)),d.invalidate();},Ye=()=>{},oe=()=>{let m=h.agent||"unknown",P=h.sessionInfo.model||"unknown",R=h.currentSessionKey||"new",j=((Z,O)=>{if(!Z||Z===0)return "";let ue=Z.toLocaleString();if(O&&O>0){let X=Math.round(Z/O*100);return ` | Tokens: ${ue} (${X}%)`}return ` | Tokens: ${ue}`})(h.sessionInfo.totalTokens,h.sessionInfo.contextTokens);$.setText(ee.dim(a$1("tui.footer.info",{vars:{agent:m,model:P,session:R,tokens:j}}))),_.invalidate();};Y(),oe();let q=()=>{s.requestRender();},pt=setInterval(()=>{oe(),q();},1e3),Yt=()=>{pt&&clearInterval(pt),ke();},{openOverlay:Pe,closeOverlay:de}=jt(s,A),Ze=()=>{C.debug("Request TUI exit"),h.currentSessionId&&(console.log(`
56
56
 
57
- `),console.log(a$1("tui.exit.resume_hint",{vars:{sessionId:h.currentSessionId}})),console.log("")),s.stop(),e.onExit&&e.onExit(),process.exit(0);},Ae=m=>{k=m||a$1("tui.status.idle"),Y(),q();},Xe=(m,P)=>{S=m,Y(),q(),P&&P>0&&setTimeout(()=>{S="",Y(),q();},P);},ye={tui:s,chatLog:o,setActivityStatus:Ae,sdk:h.sdk},et=Ut({chatLog:o,tui:s,directory:e.directory||process.cwd(),openOverlay:Pe,closeOverlay:de,requestExit:Ze,setActivityStatus:Ae,updateStatusBar:Y,updateFooter:oe,refreshSessionInfo:async()=>{h.currentSessionId&&await dt(ye,h.currentSessionId);},loadHistory:async()=>{h.currentSessionId&&await Ue(ye,h.currentSessionId,h.messageLimit);},setSession:async m=>{o.clear(),await Qt(ye,m,h),Y(),oe(),q();},refreshAgents:async()=>{await Nt(ye);},abortActive:async()=>{h.currentSessionId&&await Gt(ye,h.currentSessionId);},setInputText:m=>{A.setText(m),q();}},h),ce=new We;ce.register(new je),ce.register(new Ne),ce.register(new Qe),ce.register(new Ge),ce.register(new we),ce.register(new Ke),ce.register(new ze),A.onSubmit=async m=>{let R=m.trim();A.setText(""),R&&(C.debug("User input",{text:R}),A.addToHistory(R),await ce.handle(R,{chatLog:o,tui:s,state:h,setActivityStatus:Ae,updateStatusBar:Y,updateFooter:oe,sendMessage:et.sendMessage,handleCommand:et.handleCommand}));};let tt=0;A.onCtrlC=()=>{C.debug("User pressed Ctrl+C");let m=A.getText(),P=Date.now();m.trim()?(A.setText(""),Xe(a$1("tui.hint.input_cleared"),3e3),tt=P,s.requestRender()):P-tt<=1e3?Ze():(Xe(a$1("tui.hint.press_ctrlc_exit"),3e3),tt=P,s.requestRender());},A.onCtrlD=()=>{C.debug("User pressed Ctrl+D, exit TUI"),Ze();},A.onEscape=()=>{C.debug("[app.ts] onEscape callback called"),C.debug("User pressed Escape"),s.hasOverlay()?(C.debug("[app.ts] Overlay detected, closing overlay"),de(),C.debug("[app.ts] Calling tui.requestRender(true) for complete cleanup"),s.requestRender(true),C.debug("[app.ts] onEscape completed")):C.debug("[app.ts] No overlay, doing nothing");},A.onCtrlL=async()=>{C.debug("User pressed Ctrl+L, open model selector");try{let m=await sa(h),P=Fe(m,{onSelect:async R=>{h.sessionInfo.model=R.value,o.addSystem(a$1("tui.handler.model.set",{vars:{model:R.value}})),de(),b$2(h).catch(F=>{C.error("Failed to save TUI state after model change",{error:F});}),oe(),q();},onCancel:()=>{de();}});Pe(P);}catch(m){C.error("Failed to open model selector",{error:m}),o.addSystem(a$1("tui.selector.model.error",{vars:{error:String(m)}})),q();}},A.onCtrlP=async()=>{C.debug("User pressed Ctrl+P, open session selector");try{let m=await ra(h),P=qe(m,{onSelect:async R=>{h.currentSessionKey=R.value,o.addSystem(a$1("tui.handler.session.switched",{vars:{sessionKey:R.value}})),de(),oe(),q();},onCancel:()=>{de();}});Pe(P);}catch(m){C.error("Failed to open session selector",{error:m}),o.addSystem(a$1("tui.selector.session.error",{vars:{error:String(m)}})),q();}},A.onCtrlG=async()=>{C.debug("User pressed Ctrl+G, open agent selector");try{let P=(await qa(h)).filter(F=>F.mode==="primary"&&F.hidden!==!0),R=Be(P,{onSelect:async F=>{h.agent=F.value,o.addSystem(a$1("tui.handler.agent.switched",{vars:{agentId:F.value}})),de(),b$2(h).catch(j=>{C.error("Failed to save TUI state after agent change",{error:j});}),oe(),q();},onCancel:()=>{de();}});Pe(R);}catch(m){C.error("Failed to open agent selector",{error:m}),o.addSystem(a$1("tui.selector.agent.error",{vars:{error:String(m)}})),q();}},A.onCtrlT=()=>{C.debug("User pressed Ctrl+T"),h.showThinking=!h.showThinking,o.addSystem(a$1("tui.system.thinking_mode",{vars:{mode:h.showThinking?a$1("tui.system.on"):a$1("tui.system.off")}})),b$2(h).catch(m=>{C.error("Failed to save TUI state after Ctrl+T",{error:m});}),Y(),q();},A.onCtrlO=()=>{C.debug("User pressed Ctrl+O"),h.toolsExpanded=!h.toolsExpanded;let m=a$1("tui.system.tools_output",{vars:{mode:h.toolsExpanded?a$1("tui.system.expanded"):a$1("tui.system.collapsed")}});o.addSystem(m),Xe(h.toolsExpanded?a$1("tui.hint.tools_expanded"):a$1("tui.hint.tools_collapsed"),2e3),b$2(h).catch(P=>{C.error("Failed to save TUI state after Ctrl+O",{error:P});}),Y(),q();},s.setFocus(A);let Zt={tui:s,chatLog:o,sessionId:h.currentSessionId,setActivityStatus:Ae,updateStatusBar:Y,updateFooter:oe,updateChatLog:Ye,state:h},Xt=Ot(Zt),{TuiEvent:Se}=await import('./event-A4SSIBOT.mjs'),ht=()=>{},ft=()=>{},yt=()=>{},St=()=>{},bt=()=>{},vt=()=>{};ht=await na(h,Se.StatusBarRefresh,async m=>{C.debug("StatusBarRefresh event received",{reason:m.properties.reason}),Y(),q();}),ft=await na(h,Se.FooterBarRefresh,async m=>{C.debug("FooterBarRefresh event received",{reason:m.properties.reason}),oe(),q();}),yt=await na(h,Se.ChatLogRefresh,async m=>{C.debug("ChatLogRefresh event received",{reason:m.properties.reason}),q();}),St=await na(h,Se.CommandExecute,async m=>{C.debug("TUI CommandExecute event received",{command:m.properties.command}),await et.handleCommand(m.properties.command);}),bt=await na(h,Se.PromptAppend,async m=>{C.debug("TUI PromptAppend event received",{text:m.properties.text});let P=A.getText();A.setText(P+m.properties.text),q();}),vt=await na(h,Se.ToastShow,async m=>{C.debug("TUI ToastShow event received",{message:m.properties.message});let{title:P,message:R,variant:F}=m.properties,j=F==="error"?"\u274C ":F==="warning"?"\u26A0\uFE0F ":F==="success"?"\u2705 ":"\u2139\uFE0F ";o.addSystem(`${j}${P?`[${P}] `:""}${R}`),q();}),Xs((m,P)=>{let R=m instanceof Error?m.message:String(m),F=m instanceof Error?m.stack:void 0;C.error(`Global ${P} caught`,{type:P,message:R,stack:F,errorType:m instanceof Error?m.constructor.name:typeof m,fullError:m}),R.includes("No context found for instance")&&C.error("Instance context error detected",{currentSessionId:h.currentSessionId,instanceContext:h.instanceContext,stackTrace:F}),o.addSystem(a$1(`tui.error.global.${P}`,{vars:{error:R}})),q();});let It=new AbortController;return h.sdk.global.event({signal:It.signal}).then(async({stream:m})=>{C.debug("SDK event subscription successful"),g();let P=null;if(H==="connected"&&h.currentSessionId){let j=await c$1(),Z=`http://${j.hostname}:${j.port}`;P=Jt({gatewayUrl:Z,sessionId:h.currentSessionId,backendSessionId:h.currentSessionId,onMessage:async O=>{if(C.debug("Gateway message received in TUI",{messageId:O.id,sessionId:O.sessionId,type:O.type}),O.type==="input"&&h.currentSessionId){let ue=O.content.filter(X=>X.type==="text").map(X=>X.text||"").join(`
57
+ `),console.log(a$1("tui.exit.resume_hint",{vars:{sessionId:h.currentSessionId}})),console.log("")),s.stop(),e.onExit&&e.onExit(),process.exit(0);},Ae=m=>{k=m||a$1("tui.status.idle"),Y(),q();},Xe=(m,P)=>{S=m,Y(),q(),P&&P>0&&setTimeout(()=>{S="",Y(),q();},P);},ye={tui:s,chatLog:o,setActivityStatus:Ae,sdk:h.sdk},et=Ut({chatLog:o,tui:s,directory:e.directory||process.cwd(),openOverlay:Pe,closeOverlay:de,requestExit:Ze,setActivityStatus:Ae,updateStatusBar:Y,updateFooter:oe,refreshSessionInfo:async()=>{h.currentSessionId&&await dt(ye,h.currentSessionId);},loadHistory:async()=>{h.currentSessionId&&await Ue(ye,h.currentSessionId,h.messageLimit);},setSession:async m=>{o.clear(),await Qt(ye,m,h),Y(),oe(),q();},refreshAgents:async()=>{await Nt(ye);},abortActive:async()=>{h.currentSessionId&&await Gt(ye,h.currentSessionId);},setInputText:m=>{A.setText(m),q();}},h),ce=new We;ce.register(new je),ce.register(new Ne),ce.register(new Qe),ce.register(new Ge),ce.register(new we),ce.register(new Ke),ce.register(new ze),A.onSubmit=async m=>{let R=m.trim();A.setText(""),R&&(C.debug("User input",{text:R}),A.addToHistory(R),await ce.handle(R,{chatLog:o,tui:s,state:h,setActivityStatus:Ae,updateStatusBar:Y,updateFooter:oe,sendMessage:et.sendMessage,handleCommand:et.handleCommand}));};let tt=0;A.onCtrlC=()=>{C.debug("User pressed Ctrl+C");let m=A.getText(),P=Date.now();m.trim()?(A.setText(""),Xe(a$1("tui.hint.input_cleared"),3e3),tt=P,s.requestRender()):P-tt<=1e3?Ze():(Xe(a$1("tui.hint.press_ctrlc_exit"),3e3),tt=P,s.requestRender());},A.onCtrlD=()=>{C.debug("User pressed Ctrl+D, exit TUI"),Ze();},A.onEscape=()=>{C.debug("[app.ts] onEscape callback called"),C.debug("User pressed Escape"),s.hasOverlay()?(C.debug("[app.ts] Overlay detected, closing overlay"),de(),C.debug("[app.ts] Calling tui.requestRender(true) for complete cleanup"),s.requestRender(true),C.debug("[app.ts] onEscape completed")):C.debug("[app.ts] No overlay, doing nothing");},A.onCtrlL=async()=>{C.debug("User pressed Ctrl+L, open model selector");try{let m=await ta(h),P=Fe(m,{onSelect:async R=>{h.sessionInfo.model=R.value,o.addSystem(a$1("tui.handler.model.set",{vars:{model:R.value}})),de(),b$2(h).catch(F=>{C.error("Failed to save TUI state after model change",{error:F});}),oe(),q();},onCancel:()=>{de();}});Pe(P);}catch(m){C.error("Failed to open model selector",{error:m}),o.addSystem(a$1("tui.selector.model.error",{vars:{error:String(m)}})),q();}},A.onCtrlP=async()=>{C.debug("User pressed Ctrl+P, open session selector");try{let m=await sa(h),P=qe(m,{onSelect:async R=>{h.currentSessionKey=R.value,o.addSystem(a$1("tui.handler.session.switched",{vars:{sessionKey:R.value}})),de(),oe(),q();},onCancel:()=>{de();}});Pe(P);}catch(m){C.error("Failed to open session selector",{error:m}),o.addSystem(a$1("tui.selector.session.error",{vars:{error:String(m)}})),q();}},A.onCtrlG=async()=>{C.debug("User pressed Ctrl+G, open agent selector");try{let P=(await ra(h)).filter(F=>F.mode==="primary"&&F.hidden!==!0),R=Be(P,{onSelect:async F=>{h.agent=F.value,o.addSystem(a$1("tui.handler.agent.switched",{vars:{agentId:F.value}})),de(),b$2(h).catch(j=>{C.error("Failed to save TUI state after agent change",{error:j});}),oe(),q();},onCancel:()=>{de();}});Pe(R);}catch(m){C.error("Failed to open agent selector",{error:m}),o.addSystem(a$1("tui.selector.agent.error",{vars:{error:String(m)}})),q();}},A.onCtrlT=()=>{C.debug("User pressed Ctrl+T"),h.showThinking=!h.showThinking,o.addSystem(a$1("tui.system.thinking_mode",{vars:{mode:h.showThinking?a$1("tui.system.on"):a$1("tui.system.off")}})),b$2(h).catch(m=>{C.error("Failed to save TUI state after Ctrl+T",{error:m});}),Y(),q();},A.onCtrlO=()=>{C.debug("User pressed Ctrl+O"),h.toolsExpanded=!h.toolsExpanded;let m=a$1("tui.system.tools_output",{vars:{mode:h.toolsExpanded?a$1("tui.system.expanded"):a$1("tui.system.collapsed")}});o.addSystem(m),Xe(h.toolsExpanded?a$1("tui.hint.tools_expanded"):a$1("tui.hint.tools_collapsed"),2e3),b$2(h).catch(P=>{C.error("Failed to save TUI state after Ctrl+O",{error:P});}),Y(),q();},s.setFocus(A);let Zt={tui:s,chatLog:o,sessionId:h.currentSessionId,setActivityStatus:Ae,updateStatusBar:Y,updateFooter:oe,updateChatLog:Ye,state:h},Xt=Ot(Zt),{TuiEvent:Se}=await import('./event-A4SSIBOT.mjs'),ht=()=>{},ft=()=>{},yt=()=>{},St=()=>{},bt=()=>{},vt=()=>{};ht=await oa(h,Se.StatusBarRefresh,async m=>{C.debug("StatusBarRefresh event received",{reason:m.properties.reason}),Y(),q();}),ft=await oa(h,Se.FooterBarRefresh,async m=>{C.debug("FooterBarRefresh event received",{reason:m.properties.reason}),oe(),q();}),yt=await oa(h,Se.ChatLogRefresh,async m=>{C.debug("ChatLogRefresh event received",{reason:m.properties.reason}),q();}),St=await oa(h,Se.CommandExecute,async m=>{C.debug("TUI CommandExecute event received",{command:m.properties.command}),await et.handleCommand(m.properties.command);}),bt=await oa(h,Se.PromptAppend,async m=>{C.debug("TUI PromptAppend event received",{text:m.properties.text});let P=A.getText();A.setText(P+m.properties.text),q();}),vt=await oa(h,Se.ToastShow,async m=>{C.debug("TUI ToastShow event received",{message:m.properties.message});let{title:P,message:R,variant:F}=m.properties,j=F==="error"?"\u274C ":F==="warning"?"\u26A0\uFE0F ":F==="success"?"\u2705 ":"\u2139\uFE0F ";o.addSystem(`${j}${P?`[${P}] `:""}${R}`),q();}),Xs((m,P)=>{let R=m instanceof Error?m.message:String(m),F=m instanceof Error?m.stack:void 0;C.error(`Global ${P} caught`,{type:P,message:R,stack:F,errorType:m instanceof Error?m.constructor.name:typeof m,fullError:m}),R.includes("No context found for instance")&&C.error("Instance context error detected",{currentSessionId:h.currentSessionId,instanceContext:h.instanceContext,stackTrace:F}),o.addSystem(a$1(`tui.error.global.${P}`,{vars:{error:R}})),q();});let It=new AbortController;return h.sdk.global.event({signal:It.signal}).then(async({stream:m})=>{C.debug("SDK event subscription successful"),g();let P=null;if(H==="connected"&&h.currentSessionId){let j=await c$1(),Z=`http://${j.hostname}:${j.port}`;P=Jt({gatewayUrl:Z,sessionId:h.currentSessionId,backendSessionId:h.currentSessionId,onMessage:async O=>{if(C.debug("Gateway message received in TUI",{messageId:O.id,sessionId:O.sessionId,type:O.type}),O.type==="input"&&h.currentSessionId){let ue=O.content.filter(X=>X.type==="text").map(X=>X.text||"").join(`
58
58
  `);ue&&P&&(C.debug("Calling SDK prompt for Gateway message",{sessionId:O.sessionId}),h.sdk.session.prompt({sessionID:O.sessionId,parts:[{type:"text",text:ue}]}).then(X=>{if(X?.data?.parts){let xt=(Array.isArray(X.data.parts)?X.data.parts:[X.data.parts]).filter(be=>be.type==="text"&&be.time?.end);if(xt.length>0){let be=xt.map(st=>st.text||"").join(`
59
59
  `);be&&(C.debug("Sending prompt result to Gateway",{sessionId:O.sessionId,textLength:be.length}),P?.sendMessage(be,"output").catch(st=>{C.error("Failed to send message to Gateway",{error:String(st)});}));}}}).catch(X=>{C.error("SDK prompt error",{error:String(X)});}));}},onStateChange:O=>{C.debug("Gateway client state changed",{state:O}),O==="connected"?b=a$1("tui.status.connection.gateway_connected"):b=a$1("tui.status.connection.local"),Y();}}),P.connect().catch(O=>{C.error("Failed to connect to gateway",{error:O});});}(async()=>{try{for await(let j of m){let Z=j.payload;Xt(Z);}}catch(j){C.debug("Event stream ended",{error:j});}})();let F=e.onExit;e.onExit=async()=>{C.debug("Unsubscribe events"),It.abort(),re(),ht(),ft(),yt(),St(),bt(),vt(),Yt(),en(),P&&(await P.disconnect(),C.debug("Gateway client disconnected")),delete process.env.EASBOT_TUI_MODE,C.debug("Cleared TUI mode environment variable"),F&&await F();};}).catch(m=>{C.error("SDK event subscription failed",{error:m});}),h.currentSessionId&&!h.historyLoaded&&(async()=>{try{await Ue(ye,h.currentSessionId,h.messageLimit),h.historyLoaded=!0;}catch(m){C.error("Failed to auto-load history messages",{error:m});}})(),e.prompt&&setTimeout(()=>{A.setText(e.prompt),A.onSubmit?.(e.prompt);},100),C.debug("TUI app component created"),t}export{_e as a,ee as b,ss as c,Mt as d,Xs as e,en as f,Xi as g,er as h};
@@ -1 +1 @@
1
- import {La,nb}from'./chunk-KY3H2HGJ.mjs';import {a}from'./chunk-LFYBZHOI.mjs';var e=a.create({service:"cli-bootstrap"});async function f(o,i){let r=o||process.cwd();try{let{Global:t}=await import('./global-KAF6JHVQ.mjs');await t.init();}catch(t){throw e.error("Failed to initialize Global",{error:t instanceof Error?t.message:String(t)}),new Error(`Global initialization failed: ${t instanceof Error?t.message:String(t)}`)}try{return await La.provide({directory:r,init:nb,fn:async()=>await i()})}catch(t){throw e.error("Failed to execute in Instance context",{directory:r,error:t instanceof Error?t.message:String(t)}),t}}async function g(o={}){let i=o.directory??process.cwd();try{let{Global:r}=await import('./global-KAF6JHVQ.mjs');await r.init();}catch(r){throw e.error("Failed to initialize Global",{error:r instanceof Error?r.message:String(r)}),new Error(`Global initialization failed: ${r instanceof Error?r.message:String(r)}`)}try{return await La.provide({directory:i,init:nb,fn:async()=>{let{buildProgram:r}=await import('./build-program-43NDEGM2.mjs');return await r(o)}})}catch(r){throw e.error("Failed to build program in Instance context",{directory:i,error:r instanceof Error?r.message:String(r)}),r}}export{f as a,g as b};
1
+ import {Na,pb}from'./chunk-MMN3J3YS.mjs';import {a}from'./chunk-LFYBZHOI.mjs';var e=a.create({service:"cli-bootstrap"});async function f(o,i){let r=o||process.cwd();try{let{Global:t}=await import('./global-EVUKT3AP.mjs');await t.init();}catch(t){throw e.error("Failed to initialize Global",{error:t instanceof Error?t.message:String(t)}),new Error(`Global initialization failed: ${t instanceof Error?t.message:String(t)}`)}try{return await Na.provide({directory:r,init:pb,fn:async()=>await i()})}catch(t){throw e.error("Failed to execute in Instance context",{directory:r,error:t instanceof Error?t.message:String(t)}),t}}async function g(o={}){let i=o.directory??process.cwd();try{let{Global:r}=await import('./global-EVUKT3AP.mjs');await r.init();}catch(r){throw e.error("Failed to initialize Global",{error:r instanceof Error?r.message:String(r)}),new Error(`Global initialization failed: ${r instanceof Error?r.message:String(r)}`)}try{return await Na.provide({directory:i,init:pb,fn:async()=>{let{buildProgram:r}=await import('./build-program-WP5P33JQ.mjs');return await r(o)}})}catch(r){throw e.error("Failed to build program in Instance context",{directory:i,error:r instanceof Error?r.message:String(r)}),r}}export{f as a,g as b};
@@ -1 +1 @@
1
- export{a as CommandMetadataSchema,c as createCommandFromMarkdown,f as define,b as loadCommandFromFile,e as replaceTemplateVars,d as scanCommands}from'./chunk-CVTJJBGW.mjs';import'./chunk-X6ISXWBN.mjs';
1
+ export{a as CommandMetadataSchema,c as createCommandFromMarkdown,f as define,b as loadCommandFromFile,e as replaceTemplateVars,d as scanCommands}from'./chunk-TMAVGPNZ.mjs';import'./chunk-X6ISXWBN.mjs';
@@ -0,0 +1 @@
1
+ export{O as Compaction,o as CompactionCache,n as DEFAULT_CACHE_CONFIG,p as createCompactionCache,q as subscribeCacheEvents}from'./chunk-MMN3J3YS.mjs';import'./chunk-ROHSYOEJ.mjs';import'./chunk-ZBRXNYEM.mjs';import'./chunk-TMAVGPNZ.mjs';import'./chunk-JCC3ZOI6.mjs';import'./chunk-DEZT7DOH.mjs';import'./chunk-AAJAKVQY.mjs';import'./chunk-NQDXG75V.mjs';import'./chunk-47PBZEYM.mjs';import'./chunk-3P7JMESZ.mjs';import'./chunk-CJTCCLW4.mjs';import'./chunk-RRQRZ6MW.mjs';import'./chunk-LFYBZHOI.mjs';import'./chunk-6M4SMEZK.mjs';import'./chunk-2RSIOAZV.mjs';import'./chunk-X6ISXWBN.mjs';
@@ -0,0 +1 @@
1
+ export{eb as Agent,cb as Command,ob as Config,nb as ConfigDirectoryTypoError,kb as Info,v as InvalidError,u as JsonError,fb as Keybinds,ib as Layout,Za as Mcp,Wa as McpLocal,Xa as McpOAuth,Ya as McpRemote,Va as ModelId,bb as Permission,_a as PermissionAction,$a as PermissionObject,ab as PermissionRule,jb as Provider,hb as Server,db as Skills,Ra as SubAgent,Sa as SubAgentConfigSchema,Qa as SubAgentModel,Oa as SubAgentRunMode,Pa as SubAgentTransportType,gb as TUI,D as deduplicatePlugins,H as directories,G as get,U as getACPClientsConfig,T as getACPServerConfig,X as getAcpAgentName,V as getAcpAgentRuntimeConfig,W as getAcpModelConfig,ja as getFileCacheConfig,J as getGlobal,C as getPluginName,Ua as getSubAgentConfig,ka as getTokenEstimationConfig,I as global,t as installDependencies,L as isAutoCompactEnabled,N as isBackupEnabled,M as isPruneEnabled,x as load,S as loadACPConfig,z as loadAgent,ca as loadCodebase,A as loadCommand,la as loadContextConfig,w as loadFile,ea as loadKnowledge,da as loadMemory,ba as loadNote,B as loadPlugin,Ta as loadSubAgentConfig,r as mergeConfigConcatArrays,s as needsInstall,y as parseConfig,E as state,lb as update,mb as updateGlobal,F as waitForDependencies}from'./chunk-MMN3J3YS.mjs';import'./chunk-ROHSYOEJ.mjs';export{h as getAgentRegistryConfig,m as getAgentSyncConfig,k as getAuthConfig,d as getChannelConfig,e as getConnectionPoolConfig,l as getGatewayClusterConfig,c as getGatewayServerConfig,j as getHTTPSConfig,f as getMessageQueueConfig,i as getSessionConfig,b as loadGatewayConfig}from'./chunk-ZBRXNYEM.mjs';import'./chunk-TMAVGPNZ.mjs';import'./chunk-JCC3ZOI6.mjs';import'./chunk-DEZT7DOH.mjs';import'./chunk-AAJAKVQY.mjs';import'./chunk-NQDXG75V.mjs';import'./chunk-47PBZEYM.mjs';import'./chunk-3P7JMESZ.mjs';import'./chunk-CJTCCLW4.mjs';import'./chunk-RRQRZ6MW.mjs';import'./chunk-LFYBZHOI.mjs';import'./chunk-6M4SMEZK.mjs';import'./chunk-2RSIOAZV.mjs';import'./chunk-X6ISXWBN.mjs';
@@ -1 +1 @@
1
- import {a}from'./chunk-EEWP2VV6.mjs';import'./chunk-X6ISXWBN.mjs';import {SelectList}from'@easbot/tui';var x={selectedPrefix:e=>`\x1B[36m${e}\x1B[0m`,selectedText:e=>`\x1B[1;36m${e}\x1B[0m`,description:e=>`\x1B[90m${e}\x1B[0m`,scrollInfo:e=>`\x1B[90m${e}\x1B[0m`,noMatch:e=>`\x1B[90m${e}\x1B[0m`};function C(e){let{message:o,confirmText:c,cancelText:r,onConfirm:s,onCancel:i}=e,l=[{label:c||a("tui.dialog.confirm"),value:"confirm",description:o},{label:r||a("tui.dialog.cancel"),value:"cancel",description:""}],t=new SelectList(l,2,x);return t.onSelect=m=>{m.value==="confirm"?s():i();},t.onCancel=i,t}export{C as createConfirmDialog};
1
+ import {a}from'./chunk-NQDXG75V.mjs';import'./chunk-X6ISXWBN.mjs';import {SelectList}from'@easbot/tui';var x={selectedPrefix:e=>`\x1B[36m${e}\x1B[0m`,selectedText:e=>`\x1B[1;36m${e}\x1B[0m`,description:e=>`\x1B[90m${e}\x1B[0m`,scrollInfo:e=>`\x1B[90m${e}\x1B[0m`,noMatch:e=>`\x1B[90m${e}\x1B[0m`};function C(e){let{message:o,confirmText:c,cancelText:r,onConfirm:s,onCancel:i}=e,l=[{label:c||a("tui.dialog.confirm"),value:"confirm",description:o},{label:r||a("tui.dialog.cancel"),value:"cancel",description:""}],t=new SelectList(l,2,x);return t.onSelect=m=>{m.value==="confirm"?s():i();},t.onCancel=i,t}export{C as createConfirmDialog};
@@ -1,3 +1,3 @@
1
- import {a as a$2}from'./chunk-QJ6QTASU.mjs';import {e}from'./chunk-M3K32WJV.mjs';import'./chunk-KY3H2HGJ.mjs';import'./chunk-ZBRXNYEM.mjs';import'./chunk-CVTJJBGW.mjs';import'./chunk-IHHFG47N.mjs';import'./chunk-DEZT7DOH.mjs';import'./chunk-AAJAKVQY.mjs';import'./chunk-ARCMKYQI.mjs';import {a as a$1}from'./chunk-EEWP2VV6.mjs';import'./chunk-GMEJX6PC.mjs';import'./chunk-KLJ7PPSA.mjs';import'./chunk-CJTCCLW4.mjs';import'./chunk-I7A5JGO5.mjs';import {a}from'./chunk-LFYBZHOI.mjs';import'./chunk-I6MBTO75.mjs';import'./chunk-2RSIOAZV.mjs';import {c,d}from'./chunk-X6ISXWBN.mjs';import {PKG}from'@easbot/utils';var v=a.create({service:"debug.config"});function k(g,s){g.command("config").description(a$1("debug.config.command.describe")).action(async()=>{v.debug("Loading configuration");try{let r=await s.sdk.config.get();console.log(JSON.stringify(r.data,null,2));}catch(r){v.error("Failed to load configuration",{error:r instanceof Error?r.message:String(r)}),console.error(e(a$1("debug.config.error.load_failed",{vars:{error:r instanceof Error?r.message:String(r)}}))),process.exit(1);}});}var l=a.create({service:"debug.file"});function F(g,s){let n=g.command("file").description(a$1("debug.file.command.describe"));n.command("search <query>").description(a$1("debug.file.search.command.describe")).action(async r=>{await a$2(s.config.directory,async()=>{let{File:t}=await import('./file-KEMX6XWX.mjs');l.debug("Searching files",{query:r});try{let o=await t.search({query:r});console.log(o.join(`
2
- `));}catch(o){l.error("File search failed",{query:r,error:o instanceof Error?o.message:String(o)}),console.error(e(a$1("debug.file.search.error",{vars:{error:o instanceof Error?o.message:String(o)}}))),process.exit(1);}});}),n.command("read <path>").description(a$1("debug.file.read.command.describe")).action(async r=>{await a$2(s.config.directory,async()=>{let{File:t}=await import('./file-KEMX6XWX.mjs');l.debug("Reading file",{path:r});try{let o=await t.read(r);console.log(JSON.stringify(o,null,2));}catch(o){l.error("File read failed",{path:r,error:o instanceof Error?o.message:String(o)}),console.error(e(a$1("debug.file.read.error",{vars:{error:o instanceof Error?o.message:String(o)}}))),process.exit(1);}});}),n.command("status").description(a$1("debug.file.status.command.describe")).action(async()=>{await a$2(s.config.directory,async()=>{let{File:r}=await import('./file-KEMX6XWX.mjs');l.debug("Getting file status");try{let t=await r.status();console.log(JSON.stringify(t,null,2));}catch(t){l.error("File status failed",{error:t instanceof Error?t.message:String(t)}),console.error(e(a$1("debug.file.status.error",{vars:{error:t instanceof Error?t.message:String(t)}}))),process.exit(1);}});}),n.command("list <path>").description(a$1("debug.file.list.command.describe")).action(async r=>{await a$2(s.config.directory,async()=>{let{File:t}=await import('./file-KEMX6XWX.mjs');l.debug("Listing files",{path:r});try{let o=await t.list(r);console.log(JSON.stringify(o,null,2));}catch(o){l.error("File list failed",{path:r,error:o instanceof Error?o.message:String(o)}),console.error(e(a$1("debug.file.list.error",{vars:{error:o instanceof Error?o.message:String(o)}}))),process.exit(1);}});}),n.command("tree [dir]").description(a$1("debug.file.tree.command.describe")).option("--limit <number>",a$1("debug.file.tree.option.limit.description")).action(async(r,t)=>{await a$2(s.config.directory,async()=>{let{Ripgrep:o}=await import('./ripgrep-E3GWWA2V.mjs'),{Instance:p}=await import('./instance-YUOFE3Q3.mjs');l.debug("Showing file tree",{dir:r});try{let i=await o.tree({cwd:r||p.directory,limit:t?.limit||200});console.log(JSON.stringify(i,null,2));}catch(i){l.error("File tree failed",{dir:r,error:i instanceof Error?i.message:String(i)}),console.error(e(a$1("debug.file.tree.error",{vars:{error:i instanceof Error?i.message:String(i)}}))),process.exit(1);}});});}var u=a.create({service:"debug.lsp"});function x(g,s){let n=g.command("lsp").description(a$1("debug.lsp.command.describe"));n.command("diagnostics <file>").description(a$1("debug.lsp.diagnostics.command.describe")).action(async r=>{await a$2(s.config.directory,async()=>{let{LSP:t}=await import('./lsp-YNF5BCPV.mjs');u.debug("Getting diagnostics",{file:r});try{await t.touchFile(r,!0),await PKG.sleep(1e3);let o=await t.diagnostics();console.log(JSON.stringify(o,null,2));}catch(o){u.error("Failed to get diagnostics",{file:r,error:o instanceof Error?o.message:String(o)}),console.error(e(a$1("debug.lsp.diagnostics.error",{vars:{error:o instanceof Error?o.message:String(o)}}))),process.exit(1);}});}),n.command("symbols <query>").description(a$1("debug.lsp.symbols.command.describe")).action(async r=>{await a$2(s.config.directory,async()=>{let{LSP:t}=await import('./lsp-YNF5BCPV.mjs');u.debug("Searching workspace symbols",{query:r});try{var o=[];try{let d=c(o,a.Default.time("symbols"));let h=await t.workspaceSymbol(r);console.log(JSON.stringify(h,null,2));}catch(p){var i=p,S=!0;}finally{d(o,i,S);}}catch(d){u.error("Failed to search symbols",{query:r,error:d instanceof Error?d.message:String(d)}),console.error(e(a$1("debug.lsp.symbols.error",{vars:{error:d instanceof Error?d.message:String(d)}}))),process.exit(1);}});}),n.command("document-symbols <file>").description(a$1("debug.lsp.document_symbols.command.describe")).action(async r=>{await a$2(s.config.directory,async()=>{let{LSP:t}=await import('./lsp-YNF5BCPV.mjs');u.debug("Getting document symbols",{file:r});try{var o=[];try{let d=c(o,a.Default.time("document-symbols"));let h=await t.documentSymbol({file:r});console.log(JSON.stringify(h,null,2));}catch(p){var i=p,S=!0;}finally{d(o,i,S);}}catch(d){u.error("Failed to get document symbols",{file:r,error:d instanceof Error?d.message:String(d)}),console.error(e(a$1("debug.lsp.document_symbols.error",{vars:{error:d instanceof Error?d.message:String(d)}}))),process.exit(1);}});});}var y=a.create({service:"debug.ripgrep"});function L(g,s){let n=g.command("rg").description(a$1("debug.ripgrep.command.describe"));n.command("tree").description(a$1("debug.ripgrep.tree.command.describe")).option("--limit <number>",a$1("debug.ripgrep.tree.option.limit.description")).action(async(r,t)=>{await a$2(s.config.directory,async()=>{let{Ripgrep:o}=await import('./ripgrep-E3GWWA2V.mjs'),{Instance:p}=await import('./instance-YUOFE3Q3.mjs');y.debug("Showing file tree",{limit:t?.limit});try{let i=await o.tree({cwd:p.directory,limit:t?.limit});console.log(i);}catch(i){y.error("File tree failed",{error:i instanceof Error?i.message:String(i)}),console.error(e(a$1("debug.ripgrep.tree.error",{vars:{error:i instanceof Error?i.message:String(i)}}))),process.exit(1);}});}),n.command("files").description(a$1("debug.ripgrep.files.command.describe")).option("--query <string>",a$1("debug.ripgrep.files.option.query.description")).option("--glob <string>",a$1("debug.ripgrep.files.option.glob.description")).option("--limit <number>",a$1("debug.ripgrep.files.option.limit.description")).action(async(r,t)=>{await a$2(s.config.directory,async()=>{let{Ripgrep:o}=await import('./ripgrep-E3GWWA2V.mjs'),{Instance:p}=await import('./instance-YUOFE3Q3.mjs');y.debug("Listing files",{query:t?.query,glob:t?.glob,limit:t?.limit});try{let i=[];for await(let S of o.files({cwd:p.directory,glob:t?.glob?[t.glob]:void 0}))if(i.push(S),t?.limit&&i.length>=t.limit)break;console.log(i.join(`
3
- `));}catch(i){y.error("File listing failed",{error:i instanceof Error?i.message:String(i)}),console.error(e(a$1("debug.ripgrep.files.error",{vars:{error:i instanceof Error?i.message:String(i)}}))),process.exit(1);}});}),n.command("search <pattern>").description(a$1("debug.ripgrep.search.command.describe")).option("--glob <glob...>",a$1("debug.ripgrep.search.option.glob.description")).option("--limit <number>",a$1("debug.ripgrep.search.option.limit.description")).action(async(r,t)=>{await a$2(s.config.directory,async()=>{let{Ripgrep:o}=await import('./ripgrep-E3GWWA2V.mjs'),{Instance:p}=await import('./instance-YUOFE3Q3.mjs');y.debug("Searching files",{pattern:r,glob:t?.glob,limit:t?.limit});try{let i=await o.search({cwd:p.directory,pattern:r,glob:t?.glob,limit:t?.limit});console.log(JSON.stringify(i,null,2));}catch(i){y.error("Search failed",{pattern:r,error:i instanceof Error?i.message:String(i)}),console.error(e(a$1("debug.ripgrep.search.error",{vars:{error:i instanceof Error?i.message:String(i)}}))),process.exit(1);}});});}var G=a.create({service:"debug.scrap"});function P(g,s){g.command("scrap").description(a$1("debug.scrap.command.describe")).action(async()=>{G.debug("Listing projects");let r=await s.sdk.project.list();console.log(JSON.stringify(r.data,null,2));});}var O=a.create({service:"debug.skill"});function J(g,s){g.command("skill").description(a$1("debug.skill.command.describe")).action(async()=>{O.debug("Listing skills");try{let r=await s.sdk.app.skills();console.log(JSON.stringify(r.data,null,2));}catch(r){O.error("Failed to list skills",{error:r instanceof Error?r.message:String(r)}),console.error(e(a$1("debug.skill.error.list_failed",{vars:{error:r instanceof Error?r.message:String(r)}}))),process.exit(1);}});}var w=a.create({service:"debug.snapshot"});function N(g,s){let n=g.command("snapshot").description(a$1("debug.snapshot.command.describe"));n.command("track").description(a$1("debug.snapshot.track.command.describe")).action(async()=>{await a$2(s.config.directory,async()=>{let{Snapshot:r}=await import('./snapshot-V23GRQBM.mjs');w.debug("Tracking snapshot");try{let t=await r.track();console.log(t);}catch(t){w.error("Snapshot track failed",{error:t instanceof Error?t.message:String(t)}),console.error(e(a$1("debug.snapshot.track.error",{vars:{error:t instanceof Error?t.message:String(t)}}))),process.exit(1);}});}),n.command("patch <hash>").description(a$1("debug.snapshot.patch.command.describe")).action(async r=>{await a$2(s.config.directory,async()=>{let{Snapshot:t}=await import('./snapshot-V23GRQBM.mjs');w.debug("Getting snapshot patch",{hash:r});try{let o=await t.patch(r);console.log(o);}catch(o){w.error("Snapshot patch failed",{hash:r,error:o instanceof Error?o.message:String(o)}),console.error(e(a$1("debug.snapshot.patch.error",{vars:{error:o instanceof Error?o.message:String(o)}}))),process.exit(1);}});}),n.command("diff <hash>").description(a$1("debug.snapshot.diff.command.describe")).action(async r=>{await a$2(s.config.directory,async()=>{let{Snapshot:t}=await import('./snapshot-V23GRQBM.mjs');w.debug("Getting snapshot diff",{hash:r});try{let o=await t.diff(r);console.log(o);}catch(o){w.error("Snapshot diff failed",{hash:r,error:o instanceof Error?o.message:String(o)}),console.error(e(a$1("debug.snapshot.diff.error",{vars:{error:o instanceof Error?o.message:String(o)}}))),process.exit(1);}});});}a.create({service:"debug"});function Nr(g,s){let n=g.command("debug").description(a$1("debug.command.description"));k(n,s),F(n,s),x(n,s),L(n,s),P(n,s),J(n,s),N(n,s),n.command("agent <name>").description(a$1("debug.agent.command.describe")).option("--tool <tool-id>",a$1("debug.agent.option.tool.description")).option("--params <json>",a$1("debug.agent.option.params.description")).action(async(r,t)=>{let{registerAgentCommand:o}=await import('./agent-4EMYYWV6.mjs');o(s,r,t);}),n.command("paths").description(a$1("debug.paths.command.describe")).action(async()=>{let{Global:r}=await import('./global-KAF6JHVQ.mjs');for(let[t,o]of Object.entries(r.Path))console.log(`${t.padEnd(10)}${o}`);}),n.command("wait").description(a$1("debug.wait.command.describe")).action(async()=>{await a$2(s.config.directory,async()=>{await new Promise(r=>setTimeout(r,1e3*60*60*24));});});}export{Nr as registerDebugCommands};
1
+ import {a as a$2}from'./chunk-YCYECTVW.mjs';import {e}from'./chunk-M3K32WJV.mjs';import'./chunk-MMN3J3YS.mjs';import'./chunk-ROHSYOEJ.mjs';import'./chunk-ZBRXNYEM.mjs';import'./chunk-TMAVGPNZ.mjs';import'./chunk-JCC3ZOI6.mjs';import'./chunk-DEZT7DOH.mjs';import'./chunk-AAJAKVQY.mjs';import {a as a$1}from'./chunk-NQDXG75V.mjs';import'./chunk-47PBZEYM.mjs';import'./chunk-3P7JMESZ.mjs';import'./chunk-CJTCCLW4.mjs';import'./chunk-RRQRZ6MW.mjs';import {a}from'./chunk-LFYBZHOI.mjs';import'./chunk-6M4SMEZK.mjs';import'./chunk-2RSIOAZV.mjs';import {c,d}from'./chunk-X6ISXWBN.mjs';import {PKG}from'@easbot/utils';var v=a.create({service:"debug.config"});function k(g,s){g.command("config").description(a$1("debug.config.command.describe")).action(async()=>{v.debug("Loading configuration");try{let r=await s.sdk.config.get();console.log(JSON.stringify(r.data,null,2));}catch(r){v.error("Failed to load configuration",{error:r instanceof Error?r.message:String(r)}),console.error(e(a$1("debug.config.error.load_failed",{vars:{error:r instanceof Error?r.message:String(r)}}))),process.exit(1);}});}var l=a.create({service:"debug.file"});function F(g,s){let n=g.command("file").description(a$1("debug.file.command.describe"));n.command("search <query>").description(a$1("debug.file.search.command.describe")).action(async r=>{await a$2(s.config.directory,async()=>{let{File:t}=await import('./file-X44TUOLQ.mjs');l.debug("Searching files",{query:r});try{let o=await t.search({query:r});console.log(o.join(`
2
+ `));}catch(o){l.error("File search failed",{query:r,error:o instanceof Error?o.message:String(o)}),console.error(e(a$1("debug.file.search.error",{vars:{error:o instanceof Error?o.message:String(o)}}))),process.exit(1);}});}),n.command("read <path>").description(a$1("debug.file.read.command.describe")).action(async r=>{await a$2(s.config.directory,async()=>{let{File:t}=await import('./file-X44TUOLQ.mjs');l.debug("Reading file",{path:r});try{let o=await t.read(r);console.log(JSON.stringify(o,null,2));}catch(o){l.error("File read failed",{path:r,error:o instanceof Error?o.message:String(o)}),console.error(e(a$1("debug.file.read.error",{vars:{error:o instanceof Error?o.message:String(o)}}))),process.exit(1);}});}),n.command("status").description(a$1("debug.file.status.command.describe")).action(async()=>{await a$2(s.config.directory,async()=>{let{File:r}=await import('./file-X44TUOLQ.mjs');l.debug("Getting file status");try{let t=await r.status();console.log(JSON.stringify(t,null,2));}catch(t){l.error("File status failed",{error:t instanceof Error?t.message:String(t)}),console.error(e(a$1("debug.file.status.error",{vars:{error:t instanceof Error?t.message:String(t)}}))),process.exit(1);}});}),n.command("list <path>").description(a$1("debug.file.list.command.describe")).action(async r=>{await a$2(s.config.directory,async()=>{let{File:t}=await import('./file-X44TUOLQ.mjs');l.debug("Listing files",{path:r});try{let o=await t.list(r);console.log(JSON.stringify(o,null,2));}catch(o){l.error("File list failed",{path:r,error:o instanceof Error?o.message:String(o)}),console.error(e(a$1("debug.file.list.error",{vars:{error:o instanceof Error?o.message:String(o)}}))),process.exit(1);}});}),n.command("tree [dir]").description(a$1("debug.file.tree.command.describe")).option("--limit <number>",a$1("debug.file.tree.option.limit.description")).action(async(r,t)=>{await a$2(s.config.directory,async()=>{let{Ripgrep:o}=await import('./ripgrep-OHTQKKDR.mjs'),{Instance:p}=await import('./instance-6NPZLEWW.mjs');l.debug("Showing file tree",{dir:r});try{let i=await o.tree({cwd:r||p.directory,limit:t?.limit||200});console.log(JSON.stringify(i,null,2));}catch(i){l.error("File tree failed",{dir:r,error:i instanceof Error?i.message:String(i)}),console.error(e(a$1("debug.file.tree.error",{vars:{error:i instanceof Error?i.message:String(i)}}))),process.exit(1);}});});}var u=a.create({service:"debug.lsp"});function x(g,s){let n=g.command("lsp").description(a$1("debug.lsp.command.describe"));n.command("diagnostics <file>").description(a$1("debug.lsp.diagnostics.command.describe")).action(async r=>{await a$2(s.config.directory,async()=>{let{LSP:t}=await import('./lsp-TAHMSZIF.mjs');u.debug("Getting diagnostics",{file:r});try{await t.touchFile(r,!0),await PKG.sleep(1e3);let o=await t.diagnostics();console.log(JSON.stringify(o,null,2));}catch(o){u.error("Failed to get diagnostics",{file:r,error:o instanceof Error?o.message:String(o)}),console.error(e(a$1("debug.lsp.diagnostics.error",{vars:{error:o instanceof Error?o.message:String(o)}}))),process.exit(1);}});}),n.command("symbols <query>").description(a$1("debug.lsp.symbols.command.describe")).action(async r=>{await a$2(s.config.directory,async()=>{let{LSP:t}=await import('./lsp-TAHMSZIF.mjs');u.debug("Searching workspace symbols",{query:r});try{var o=[];try{let d=c(o,a.Default.time("symbols"));let h=await t.workspaceSymbol(r);console.log(JSON.stringify(h,null,2));}catch(p){var i=p,S=!0;}finally{d(o,i,S);}}catch(d){u.error("Failed to search symbols",{query:r,error:d instanceof Error?d.message:String(d)}),console.error(e(a$1("debug.lsp.symbols.error",{vars:{error:d instanceof Error?d.message:String(d)}}))),process.exit(1);}});}),n.command("document-symbols <file>").description(a$1("debug.lsp.document_symbols.command.describe")).action(async r=>{await a$2(s.config.directory,async()=>{let{LSP:t}=await import('./lsp-TAHMSZIF.mjs');u.debug("Getting document symbols",{file:r});try{var o=[];try{let d=c(o,a.Default.time("document-symbols"));let h=await t.documentSymbol({file:r});console.log(JSON.stringify(h,null,2));}catch(p){var i=p,S=!0;}finally{d(o,i,S);}}catch(d){u.error("Failed to get document symbols",{file:r,error:d instanceof Error?d.message:String(d)}),console.error(e(a$1("debug.lsp.document_symbols.error",{vars:{error:d instanceof Error?d.message:String(d)}}))),process.exit(1);}});});}var y=a.create({service:"debug.ripgrep"});function L(g,s){let n=g.command("rg").description(a$1("debug.ripgrep.command.describe"));n.command("tree").description(a$1("debug.ripgrep.tree.command.describe")).option("--limit <number>",a$1("debug.ripgrep.tree.option.limit.description")).action(async(r,t)=>{await a$2(s.config.directory,async()=>{let{Ripgrep:o}=await import('./ripgrep-OHTQKKDR.mjs'),{Instance:p}=await import('./instance-6NPZLEWW.mjs');y.debug("Showing file tree",{limit:t?.limit});try{let i=await o.tree({cwd:p.directory,limit:t?.limit});console.log(i);}catch(i){y.error("File tree failed",{error:i instanceof Error?i.message:String(i)}),console.error(e(a$1("debug.ripgrep.tree.error",{vars:{error:i instanceof Error?i.message:String(i)}}))),process.exit(1);}});}),n.command("files").description(a$1("debug.ripgrep.files.command.describe")).option("--query <string>",a$1("debug.ripgrep.files.option.query.description")).option("--glob <string>",a$1("debug.ripgrep.files.option.glob.description")).option("--limit <number>",a$1("debug.ripgrep.files.option.limit.description")).action(async(r,t)=>{await a$2(s.config.directory,async()=>{let{Ripgrep:o}=await import('./ripgrep-OHTQKKDR.mjs'),{Instance:p}=await import('./instance-6NPZLEWW.mjs');y.debug("Listing files",{query:t?.query,glob:t?.glob,limit:t?.limit});try{let i=[];for await(let S of o.files({cwd:p.directory,glob:t?.glob?[t.glob]:void 0}))if(i.push(S),t?.limit&&i.length>=t.limit)break;console.log(i.join(`
3
+ `));}catch(i){y.error("File listing failed",{error:i instanceof Error?i.message:String(i)}),console.error(e(a$1("debug.ripgrep.files.error",{vars:{error:i instanceof Error?i.message:String(i)}}))),process.exit(1);}});}),n.command("search <pattern>").description(a$1("debug.ripgrep.search.command.describe")).option("--glob <glob...>",a$1("debug.ripgrep.search.option.glob.description")).option("--limit <number>",a$1("debug.ripgrep.search.option.limit.description")).action(async(r,t)=>{await a$2(s.config.directory,async()=>{let{Ripgrep:o}=await import('./ripgrep-OHTQKKDR.mjs'),{Instance:p}=await import('./instance-6NPZLEWW.mjs');y.debug("Searching files",{pattern:r,glob:t?.glob,limit:t?.limit});try{let i=await o.search({cwd:p.directory,pattern:r,glob:t?.glob,limit:t?.limit});console.log(JSON.stringify(i,null,2));}catch(i){y.error("Search failed",{pattern:r,error:i instanceof Error?i.message:String(i)}),console.error(e(a$1("debug.ripgrep.search.error",{vars:{error:i instanceof Error?i.message:String(i)}}))),process.exit(1);}});});}var G=a.create({service:"debug.scrap"});function P(g,s){g.command("scrap").description(a$1("debug.scrap.command.describe")).action(async()=>{G.debug("Listing projects");let r=await s.sdk.project.list();console.log(JSON.stringify(r.data,null,2));});}var O=a.create({service:"debug.skill"});function J(g,s){g.command("skill").description(a$1("debug.skill.command.describe")).action(async()=>{O.debug("Listing skills");try{let r=await s.sdk.app.skills();console.log(JSON.stringify(r.data,null,2));}catch(r){O.error("Failed to list skills",{error:r instanceof Error?r.message:String(r)}),console.error(e(a$1("debug.skill.error.list_failed",{vars:{error:r instanceof Error?r.message:String(r)}}))),process.exit(1);}});}var w=a.create({service:"debug.snapshot"});function N(g,s){let n=g.command("snapshot").description(a$1("debug.snapshot.command.describe"));n.command("track").description(a$1("debug.snapshot.track.command.describe")).action(async()=>{await a$2(s.config.directory,async()=>{let{Snapshot:r}=await import('./snapshot-QYVGLPZG.mjs');w.debug("Tracking snapshot");try{let t=await r.track();console.log(t);}catch(t){w.error("Snapshot track failed",{error:t instanceof Error?t.message:String(t)}),console.error(e(a$1("debug.snapshot.track.error",{vars:{error:t instanceof Error?t.message:String(t)}}))),process.exit(1);}});}),n.command("patch <hash>").description(a$1("debug.snapshot.patch.command.describe")).action(async r=>{await a$2(s.config.directory,async()=>{let{Snapshot:t}=await import('./snapshot-QYVGLPZG.mjs');w.debug("Getting snapshot patch",{hash:r});try{let o=await t.patch(r);console.log(o);}catch(o){w.error("Snapshot patch failed",{hash:r,error:o instanceof Error?o.message:String(o)}),console.error(e(a$1("debug.snapshot.patch.error",{vars:{error:o instanceof Error?o.message:String(o)}}))),process.exit(1);}});}),n.command("diff <hash>").description(a$1("debug.snapshot.diff.command.describe")).action(async r=>{await a$2(s.config.directory,async()=>{let{Snapshot:t}=await import('./snapshot-QYVGLPZG.mjs');w.debug("Getting snapshot diff",{hash:r});try{let o=await t.diff(r);console.log(o);}catch(o){w.error("Snapshot diff failed",{hash:r,error:o instanceof Error?o.message:String(o)}),console.error(e(a$1("debug.snapshot.diff.error",{vars:{error:o instanceof Error?o.message:String(o)}}))),process.exit(1);}});});}a.create({service:"debug"});function Nr(g,s){let n=g.command("debug").description(a$1("debug.command.description"));k(n,s),F(n,s),x(n,s),L(n,s),P(n,s),J(n,s),N(n,s),n.command("agent <name>").description(a$1("debug.agent.command.describe")).option("--tool <tool-id>",a$1("debug.agent.option.tool.description")).option("--params <json>",a$1("debug.agent.option.params.description")).action(async(r,t)=>{let{registerAgentCommand:o}=await import('./agent-DIUQQQYM.mjs');o(s,r,t);}),n.command("paths").description(a$1("debug.paths.command.describe")).action(async()=>{let{Global:r}=await import('./global-EVUKT3AP.mjs');for(let[t,o]of Object.entries(r.Path))console.log(`${t.padEnd(10)}${o}`);}),n.command("wait").description(a$1("debug.wait.command.describe")).action(async()=>{await a$2(s.config.directory,async()=>{await new Promise(r=>setTimeout(r,1e3*60*60*24));});});}export{Nr as registerDebugCommands};
@@ -1 +1 @@
1
- import {e,h}from'./chunk-M3K32WJV.mjs';import {a as a$1}from'./chunk-EEWP2VV6.mjs';import {a}from'./chunk-LFYBZHOI.mjs';import'./chunk-X6ISXWBN.mjs';var n=a.create({service:"cli-command-export"});function S(p,i){p.command("export [sessionID]").description(a$1("export.command.description")).action(async o=>{n.debug("Exporting session",{sessionId:o});try{if(!o){let{data:e$1}=await i.sdk.session.list({});(!e$1||e$1.length===0)&&(console.error(e(a$1("export.error.no_sessions"))),process.exit(1));let a=[...e$1].sort((f,l)=>l.time.updated-f.time.updated)[0];a||(console.error(e(a$1("export.error.no_sessions"))),process.exit(1)),o=a.id,n.debug("Using latest session",{sessionId:o});}console.log(h(a$1("export.exporting",{vars:{sessionId:o}})));let{data:r}=await i.sdk.session.get({sessionID:o}),{data:c}=await i.sdk.session.messages({sessionID:o}),g={info:r,messages:(c??[]).map(e=>({info:e.info,parts:e.parts}))};console.log(JSON.stringify(g,null,2)),n.debug("Session exported successfully",{sessionId:o});}catch(r){n.error("Failed to export session",{sessionId:o,error:r instanceof Error?r.message:String(r)}),console.error(e(a$1("export.error.failed",{vars:{error:r instanceof Error?r.message:String(r)}}))),process.exit(1);}});}export{S as registerExportCommand};
1
+ import {e,h}from'./chunk-M3K32WJV.mjs';import {a as a$1}from'./chunk-NQDXG75V.mjs';import {a}from'./chunk-LFYBZHOI.mjs';import'./chunk-X6ISXWBN.mjs';var n=a.create({service:"cli-command-export"});function S(p,i){p.command("export [sessionID]").description(a$1("export.command.description")).action(async o=>{n.debug("Exporting session",{sessionId:o});try{if(!o){let{data:e$1}=await i.sdk.session.list({});(!e$1||e$1.length===0)&&(console.error(e(a$1("export.error.no_sessions"))),process.exit(1));let a=[...e$1].sort((f,l)=>l.time.updated-f.time.updated)[0];a||(console.error(e(a$1("export.error.no_sessions"))),process.exit(1)),o=a.id,n.debug("Using latest session",{sessionId:o});}console.log(h(a$1("export.exporting",{vars:{sessionId:o}})));let{data:r}=await i.sdk.session.get({sessionID:o}),{data:c}=await i.sdk.session.messages({sessionID:o}),g={info:r,messages:(c??[]).map(e=>({info:e.info,parts:e.parts}))};console.log(JSON.stringify(g,null,2)),n.debug("Session exported successfully",{sessionId:o});}catch(r){n.error("Failed to export session",{sessionId:o,error:r instanceof Error?r.message:String(r)}),console.error(e(a$1("export.error.failed",{vars:{error:r instanceof Error?r.message:String(r)}}))),process.exit(1);}});}export{S as registerExportCommand};
@@ -0,0 +1 @@
1
+ export{Z as File}from'./chunk-MMN3J3YS.mjs';import'./chunk-ROHSYOEJ.mjs';import'./chunk-ZBRXNYEM.mjs';import'./chunk-TMAVGPNZ.mjs';import'./chunk-JCC3ZOI6.mjs';import'./chunk-DEZT7DOH.mjs';import'./chunk-AAJAKVQY.mjs';import'./chunk-NQDXG75V.mjs';import'./chunk-47PBZEYM.mjs';import'./chunk-3P7JMESZ.mjs';import'./chunk-CJTCCLW4.mjs';import'./chunk-RRQRZ6MW.mjs';import'./chunk-LFYBZHOI.mjs';import'./chunk-6M4SMEZK.mjs';import'./chunk-2RSIOAZV.mjs';import'./chunk-X6ISXWBN.mjs';