fluxflow-cli 2.1.6 → 2.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/fluxflow.js +249 -244
- package/package.json +2 -2
package/dist/fluxflow.js
CHANGED
|
@@ -1,64 +1,62 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
var
|
|
2
|
+
var Pl=Object.defineProperty;var ae=(e,o)=>()=>(e&&(o=e(e=0)),o);var bs=(e,o)=>{for(var t in o)Pl(e,t,{get:o[t],enumerable:!0})};import io,{useState as pr,useEffect as Is,useMemo as Cs,useCallback as Rr,useRef as Bi}from"react";import{Box as fr,Spacer as Bl,Text as mr,useInput as Nl,measureElement as _l}from"ink";function Ul(e,o){return e.replace(/\t/g," ".repeat(o))}function ks(e){return e==null?"":e.replace(/\r\n/g,`
|
|
3
3
|
`).replace(/\r/g,`
|
|
4
|
-
`)}var
|
|
5
|
-
`)+1,
|
|
6
|
-
`);return{preCursor:[{value:
|
|
7
|
-
`),K=Math.max(20,
|
|
8
|
-
`),
|
|
9
|
-
`+e.slice(a);o(
|
|
10
|
-
`+e.slice(a);o(
|
|
11
|
-
`),i=[];if(o<=5)return e;let r=l=>l.replace(t,"").length;return n.forEach(l=>{if(r(l)<=o){i.push(l);return}let
|
|
12
|
-
`)},
|
|
4
|
+
`)}var Ni,Rl,_i,Ui=ae(()=>{Ni=({children:e,onHeightChange:o})=>{let t=Bi(null),n=Bi(void 0);return Is(()=>{if(t.current){let{height:i}=_l(t.current);n.current!==i&&(n.current=i,o?.(i))}}),io.createElement(fr,{ref:t,flexShrink:0,flexGrow:0,width:"100%"},e)},Rl=({value:e,rows:o,maxRows:t,highlightStyle:n,textStyle:i,placeholder:r="",mask:l,showCursor:c=!0,focus:f=!0,tabSize:u=4,cursorIndex:d=0,highlight:a,refreshKey:m})=>{let[p,h]=pr(0),[S,T]=pr(0),[w,I]=pr(0),$=Rr((O,D=!1)=>{let Q=ks(O);if(!D&&l)return Q.replace(/[^\n]/g,l);let G=Ul(Q,u);return D?G:G.replace(/@\[(.*?)\]/g,(Z,X)=>{let z=X.indexOf("#"),Ct=X.indexOf(":L"),Te=X,je="";z!==-1?(Te=X.slice(0,z),je=X.slice(z)):Ct!==-1&&(Te=X.slice(0,Ct),je=X.slice(Ct));let nt=Te.replace(/\\/g,"/"),fe=(process.cwd()||"").replace(/\\/g,"/");fe&&nt.toLowerCase().startsWith(fe.toLowerCase()+"/")?nt=nt.slice(fe.length+1):nt.startsWith("./")&&(nt=nt.slice(2));let ut=nt.split("/");return`[${ut[ut.length-1]}${je}]`})},[u,l]),{preCursor:U,postCursor:K}=Cs(()=>{if(!e)return r&&!f?{preCursor:[{value:$(r,!0),type:"placeholder"}],postCursor:[]}:{preCursor:[{value:c&&f?" ":"",type:"cursor"}],postCursor:[]};let O=e.slice(0,d),D=e.slice(d);if(!f)return{preCursor:[{value:$(e)}],postCursor:[]};if(a&&a.end>a.start&&a.start>=0&&a.end<=e.length)return{preCursor:[{value:$(O.slice(0,a.start))},{value:$(O.slice(a.start,Math.min(a.end,d))),type:"highlight"},{value:$(O.slice(a.end))},{value:c&&f?" ":"",type:"cursor"}],postCursor:[{value:$(D.slice(0,Math.max(a.start-d,0)))},{value:$(D.slice(Math.max(a.start-d,0),Math.max(a.end-d,0))),type:"highlight"},{value:$(D.slice(Math.max(a.end-d,0)))}]};{let G=$(O),Z=$(D),X=G.lastIndexOf(`
|
|
5
|
+
`)+1,z=Z.indexOf(`
|
|
6
|
+
`);return{preCursor:[{value:G.slice(0,X)},{value:G.slice(X),type:"highlight"},{value:c&&f?" ":"",type:"cursor"}],postCursor:[{value:Z.slice(0,z),type:"highlight"},{value:Z.slice(z)}]}}},[d,c,f,e,r,l,a,$,m]),P=Cs(()=>S!==void 0?Math.max(o??t??1,Math.min(t??o??1,S)):1,[o,t,S]);Is(()=>{if(w!==void 0&&P!==void 0){let O=w;h(D=>{let Q=D,G=D+P;if(O<=Q)return Math.max(0,O-1);if(O>G)return O-P;if(S){if(S<P)return 0;if(S<G)return S-P}return D})}},[w,P,S]);let k=Rr(O=>{switch(O){case"placeholder":return{...i,dimColor:!0};case"highlight":return n??i;case"cursor":return{...i,color:c&&f?"cyan":void 0,bold:c&&f,inverse:c&&f};default:return i}},[i,n,c,f]);return io.createElement(fr,{height:P,overflow:"hidden",flexDirection:"column",flexGrow:0,flexShrink:0},io.createElement(fr,{flexDirection:"column"},io.createElement(fr,{height:P,overflowY:"hidden",flexShrink:0,flexDirection:"column"},io.createElement(fr,{marginTop:-p,flexDirection:"column"},io.createElement(Ni,{onHeightChange:T},io.createElement(mr,null,U?.map((O,D)=>io.createElement(mr,{key:D,...k(O.type)},O.value)),K?.map((O,D)=>io.createElement(mr,{key:D,...k(O.type)},O.value))))),io.createElement(Bl,null)),io.createElement(Ni,{onHeightChange:I},io.createElement(mr,null,U?.map((O,D)=>io.createElement(mr,{key:D,...k(O.type)},O.value))))))},_i=({value:e,onChange:o,onSubmit:t,keyBindings:n,showCursor:i=!0,highlightPastedText:r=!1,focus:l=!0,lastFocusEventTime:c=0,columns:f=80,useCustomInput:u=(a,m)=>Nl(a,{isActive:m}),...d})=>{let[a,m]=pr(e.length),[p,h]=pr(0);Is(()=>{a>e.length&&m(e.length)},[e,a]);let S=Rr(I=>{let U=ks(e).split(`
|
|
7
|
+
`),K=Math.max(20,f-10),P=0,k=0,O=0;for(let D=0;D<U.length;D++){let G=U[D].length;if(I>=O&&I<=O+G){let X=I-O;return P+=Math.floor(X/K),k=X%K,{visualLine:P,visualCol:k}}let Z=Math.max(1,Math.ceil(G/K));P+=Z,O+=G+1}return{visualLine:P,visualCol:k}},[e,f]),T=Rr((I,$)=>{let K=ks(e).split(`
|
|
8
|
+
`),P=Math.max(20,f-10),k=0,O=0;for(let D=0;D<K.length;D++){let G=K[D].length,Z=Math.max(1,Math.ceil(G/P));if(I>=k&&I<k+Z){let X=(I-k)*P,z=Math.min($,G-X),Ct=Math.max(0,z);return Math.min(O+X+Ct,O+G)}k+=Z,O+=G+1}return e.length},[e,f]);u((I,$)=>{if(I==="\x1B[I"||I==="\x1B[O"||I==="[I"||I==="[O")return;let U=n?.submit??(k=>k.return&&k.ctrl),K=n?.newline??(k=>k.return);if(U($)){t?.(e);return}else if(K($)){let k=e.slice(0,a)+`
|
|
9
|
+
`+e.slice(a);o(k),m(a+1),h(0);return}if($.tab||$.shift&&$.tab||$.ctrl&&I==="c")return;let P=0;if(I.length>1&&(P=I.length),$.upArrow){if(i){let{visualLine:k,visualCol:O}=S(a);if(k>0){let D=T(k-1,O);m(D),h(0)}}}else if($.downArrow){if(i){let{visualLine:k,visualCol:O}=S(a),D=T(k+1,O);D!==a&&(m(D),h(0))}}else if($.leftArrow)i&&(m(Math.max(0,a-1)),h(0));else if($.rightArrow)i&&(m(Math.min(e.length,a+1)),h(0));else if($.return){let k=e.slice(0,a)+`
|
|
10
|
+
`+e.slice(a);o(k),m(a+1),h(0)}else if($.backspace||$.delete){if(a>0){let k=e.slice(0,a-1)+e.slice(a);o(k),m(a-1),h(0)}}else if(I){let k=e.slice(0,a)+I+e.slice(a);o(k),m(a+I.length),h(P)}},l);let w=Cs(()=>{if(r&&p>1)return{start:Math.max(0,a-p),end:a}},[a,p,r]);return io.createElement(Rl,{...d,value:e,cursorIndex:a,highlight:w,showCursor:i,focus:l})}});import Wl from"os";var _o,Qt,Ri,Wr,Hr,Yr,Bn=ae(()=>{_o=(e,o)=>{if(!e)return"";let t=/\x1B\[[0-?]*[ -/]*[@-~]/g,n=e.split(`
|
|
11
|
+
`),i=[];if(o<=5)return e;let r=l=>l.replace(t,"").length;return n.forEach(l=>{if(r(l)<=o){i.push(l);return}let f=l.split(/(\s+)/),u="",d=0,a=l.match(/^(\s*)/),m=a?a[1]:"";f.forEach((p,h)=>{if(p.length===0)return;let S=r(p);if(d+S>o)if(u.trim().length>0)i.push(u.trimEnd()),u=m+p,d=r(u);else if(t.test(p))i.push(p),u=m,d=r(u);else{let T=p;for(;r(T)>o&&o>10;)i.push(T.substring(0,o)),T=T.substring(o);u=T,d=r(u)}else u+=p,d+=S}),(u.trimEnd().length>0||u===m)&&i.push(u.trimEnd())}),i.join(`
|
|
12
|
+
`)},Qt=e=>{if(!e&&e!==0)return"0.0k";let o=typeof e=="string"?parseFloat(e):e;return o>=1e6?`${(o/1e6).toFixed(1)}m`:o>=1e3?`${(o/1e3).toFixed(1)}k`:o.toString()},Ri=(e,o=40)=>{if(e=e.replace(Wl.homedir(),"~"),!e||e.length<=o)return e;let t=Math.floor((o-3)/2);return e.substring(0,t)+"..."+e.substring(e.length-t)},Wr=e=>{let o=[],t=new Set;Object.keys(e).forEach(i=>{let r=i.match(/^(replaceContent|newContent|content_to_replace|content_to_add)(\d+)?$/);if(r){let l=r[2]?parseInt(r[2]):1;t.add(l)}});let n=Array.from(t).sort((i,r)=>i-r);for(let i of n){let r,l;if(i===1?(r=e.replaceContent1??e.content_to_replace??e.replaceContent,l=e.newContent1??e.content_to_add??e.newContent):(r=e[`replaceContent${i}`]??e[`content_to_replace${i}`],l=e[`newContent${i}`]??e[`content_to_add${i}`]),r!==void 0&&l!==void 0)o.push({replace:r,new:l});else if(r!==void 0||l!==void 0)return{error:`Mismatched replacement pair for index ${i}. Both replacement and new content must be provided.`}}return{patchPairs:o}},Hr=(e,o)=>{let t=[],n=e.replace(/\r\n/g,`
|
|
13
13
|
`).replace(/\r/g,`
|
|
14
|
-
`),i=
|
|
14
|
+
`),i=u=>u.replace(/^```[\w]*\n?/,"").replace(/```\s*$/,"").replace(/\r\n/g,`
|
|
15
15
|
`).replace(/\r/g,`
|
|
16
|
-
`),r=
|
|
17
|
-
`).filter(
|
|
18
|
-
`).filter(
|
|
19
|
-
`).map((
|
|
20
|
-
`)},
|
|
21
|
-
`).map(
|
|
22
|
-
`,
|
|
23
|
-
`).
|
|
24
|
-
|
|
25
|
-
`),
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
`,
|
|
30
|
-
|
|
31
|
-
`,
|
|
32
|
-
`,m=
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
`,m++;if(u===t.length-1){let T=Math.min(r.length,m+3);for(;m<T;)l+=`[UI_CONTEXT] ${m+1} |${r[m]||""}
|
|
38
|
-
`,m++}}),l+="[DIFF_END]",l}});import $t from"react";import{Box as fn,Text as pn}from"ink";var Wr,ks=ie(()=>{Pn();Wr=$t.memo(({command:e,output:o,completed:t=!1,isFocused:n=!1,columns:i=80,isPty:r=!1})=>{let c=(r?(d=>{if(!d)return"";let u=/\x1b\[H|\x1b\[2J|\x1b\[3J|\x1bc/g,a=[...d.matchAll(u)],f=d;if(a.length>0){let h=a[a.length-1];f=d.substring(h.index+h[0].length)}return f.replace(/\r+\n/g,`
|
|
16
|
+
`),r=u=>u.match(/^\s*/)[0],l=u=>{let d=u.split(`
|
|
17
|
+
`).filter(m=>m.trim()!=="");if(d.length===0)return"";let a=r(d[0]);for(let m of d){let p=r(m);p.length<a.length&&(a=p)}return a},c=(u,d,a="")=>{if(!u||d===void 0)return u;let m=P=>{let k=P.split(`
|
|
18
|
+
`).filter(Z=>Z.trim()!=="");if(k.length===0)return{char:" ",size:4};let O=k[0].match(/^\s*/)[0];if(O.includes(" "))return{char:" ",size:1};let D=k.map(Z=>Z.match(/^\s*/)[0].length).filter(Z=>Z>0);if(D.length===0)return{char:" ",size:O.length||4};let Q=(Z,X)=>X?Q(X,Z%X):Z;return{char:" ",size:D.reduce((Z,X)=>Q(Z,X))||4}},p=m(d),h=m(u),S=l(d).length,T=(a.match(/^\s*/)||[""])[0].length,I=(T+S)/p.size,$=l(u).length/h.size,U=I-$;return u.split(`
|
|
19
|
+
`).map((P,k)=>{if(P.trim()===""&&k!==0)return"";let O=P.match(/^\s*/)[0].length/h.size,D=Math.max(0,O+U),Q=D;if(k===0){let G=T/p.size;Q=Math.max(0,D-G)}return p.char.repeat(Q*p.size)+P.trimStart()}).join(`
|
|
20
|
+
`)},f=n;for(let u=0;u<o.length;u++){let d=o[u],a=i(d.replace||""),m=i(d.new||"");if(a===""&&m===""){t.push({success:!1,error:`Block ${u+1}: Empty replace and add content.`});continue}let p=a.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),h=null;if(a!==""&&f.includes(a))h=new RegExp(p,"g");else{let G=a.split(`
|
|
21
|
+
`).map(Z=>Z.trim()).filter(Z=>Z.length>0).map(Z=>Z.replace(/[.*+?^${}()|[\]\\]/g,"\\$&").replace(/\s+/g,"\\s*"));if(G.length>0){let Z=G.join("\\s*");try{h=new RegExp(Z,"g")}catch{h=new RegExp(p,"g")}}else h=new RegExp(p,"g")}let S=[...f.matchAll(h)];if(S.length===0){t.push({success:!1,error:`Block ${u+1}: Could not find match.`});continue}if(S.length>1){t.push({success:!1,error:`Block ${u+1}: Found ${S.length} matches (must be unique).`});continue}let T=S[0].index,w=S[0][0],I=f.lastIndexOf(`
|
|
22
|
+
`,T)+1,$=f.substring(I,T),U=c(m,w,$),K=f.split(`
|
|
23
|
+
`),P=f.substring(0,T).split(`
|
|
24
|
+
`).length,k=[];for(let G=Math.max(0,P-4);G<P-1;G++)k.push({num:G+1,text:K[G]});let O=w.split(`
|
|
25
|
+
`),D=[],Q=P+O.length-1;for(let G=Q;G<Math.min(K.length,Q+3);G++)D.push({num:G+1,text:K[G]});t.push({success:!0,oldContent:w,newContent:U,originalStartLine:P,contextBefore:k,contextAfter:D}),f=f.substring(0,T)+U+f.substring(T+w.length)}return{content:f,results:t}},Yr=(e,o,t,n=8)=>{if(!t||t.length===0)return"";let i=e.split(/\r?\n/),r=o.split(/\r?\n/),l=`[DIFF_START]
|
|
26
|
+
`,c="\u2550".repeat(88),f=0,u=null;if(t.forEach((d,a)=>{if(!d.success)return;if(u===null)for(f=Math.max(0,d.originalStartLine-4);f<d.originalStartLine-1;)l+=`[UI_CONTEXT] ${f+1} |${r[f]||""}
|
|
27
|
+
`,f++;else{let T=u,w=T.originalStartLine+T.oldContent.split(`
|
|
28
|
+
`).length-1;if(d.originalStartLine-w-1>=n){let $=Math.min(r.length,f+3);for(;f<$;)l+=`[UI_CONTEXT] ${f+1} |${r[f]||""}
|
|
29
|
+
`,f++;for(l+=`[UI_CONTEXT] ${c}
|
|
30
|
+
`,f=Math.max(f,d.originalStartLine-4);f<d.originalStartLine-1;)l+=`[UI_CONTEXT] ${f+1} |${r[f]||""}
|
|
31
|
+
`,f++}else for(;f<d.originalStartLine-1;)l+=`[UI_CONTEXT] ${f+1} |${r[f]||""}
|
|
32
|
+
`,f++}let m=d.oldContent.split(`
|
|
33
|
+
`);m.forEach((T,w)=>{l+=`-${d.originalStartLine+w}|${T}
|
|
34
|
+
`});let p=d.originalStartLine+m.length-1,h=i[p]||null,S=f;if(h!==null){let T=a<t.length-1?(t[a+1].originalStartLine||r.length)+10:r.length;for(let w=f;w<T;w++){if(r[w]===h){S=w;break}w===r.length-1&&(S=r.length)}}else S=r.length;for(;f<S;)l+=`+${f+1}|${r[f]||""}
|
|
35
|
+
`,f++;u=d}),u!==null){let d=Math.min(r.length,f+3);for(;f<d;)l+=`[UI_CONTEXT] ${f+1} |${r[f]||""}
|
|
36
|
+
`,f++}return l+="[DIFF_END]",l}});import Ft from"react";import{Box as xn,Text as yn}from"ink";var jr,Ms=ae(()=>{Bn();jr=Ft.memo(({command:e,output:o,completed:t=!1,isFocused:n=!1,columns:i=80,isPty:r=!1})=>{let c=(r?(u=>{if(!u)return"";let d=/\x1b\[H|\x1b\[2J|\x1b\[3J|\x1bc/g,a=[...u.matchAll(d)],m=u;if(a.length>0){let h=a[a.length-1];m=u.substring(h.index+h[0].length)}return m.replace(/\r+\n/g,`
|
|
39
37
|
`).split(`
|
|
40
|
-
`).map(h=>{let
|
|
38
|
+
`).map(h=>{let S=h.split("\r");return S[S.length-1]}).join(`
|
|
41
39
|
`)})(o):(o||"").replace(/\r\n/g,`
|
|
42
40
|
`)).replace(/\n{3,}/g,`
|
|
43
41
|
|
|
44
|
-
`),
|
|
42
|
+
`),f=r?c:c?_o(c,i-6):"";return Ft.createElement(xn,{flexDirection:"column",borderStyle:n?"double":"round",borderColor:t?"#334155":n?"yellow":"cyan",paddingX:2,paddingY:t?0:1,width:"100%"},Ft.createElement(xn,{marginBottom:1,justifyContent:"space-between",width:"100%"},Ft.createElement(xn,{flexShrink:1,paddingRight:2},Ft.createElement(yn,null,Ft.createElement(yn,{color:t?"gray":n?"yellow":"cyan",bold:!0},t?"\u{1F3C1} FINISHED:":"\u26A1 EXECUTING:"," "),Ft.createElement(yn,{color:t?"gray":"white"},e))),r&&Ft.createElement(xn,{flexShrink:0,paddingX:1},Ft.createElement(yn,{color:t?"gray":"magenta",bold:!0},"ADVANCE"))),f?Ft.createElement(xn,{marginTop:t?0:1,backgroundColor:r?void 0:"#0a0a0a",paddingX:1},Ft.createElement(yn,{color:t?"gray":void 0},f)):!t&&Ft.createElement(xn,{marginTop:1,backgroundColor:r?void 0:"#0a0a0a",paddingX:1},Ft.createElement(yn,{color:"gray",italic:!0},"Waiting for output...")),Ft.createElement(xn,{justifyContent:"space-between",marginTop:1},t?Ft.createElement(xn,null):Ft.createElement(yn,{color:"gray",dimColor:!0,italic:!0},n?"Press TAB to unfocus, then double-press ESC to terminate.":"Double-press ESC to terminate if hanging."),Ft.createElement(yn,{color:t?"#475569":n?"yellow":"cyan",bold:!0},t?"\u25CF ARCHIVED":n?"\u25B6 TERMINAL FOCUSED":"\u25CF LIVE (Press TAB to focus)")))})});var Hl,Ce,wn=ae(()=>{Hl=()=>process.env.TERM_PROGRAM==="vscode"?"vscode":process.env.WT_SESSION?"wt":"default",Ce=(e=2)=>{let o=Hl();return o==="wt"?" ".repeat(Math.max(1,e-1)):" ".repeat(e)}});import E from"react";import{Box as H,Text as oe}from"ink";var Yl,jl,Gl,Xl,Wi,Tn,Kl,Hi,ql,Vl,Yi,ji,As,zl,Gi,Xi=ae(()=>{Ms();Bn();wn();Yl={write_file:"WriteFile",update_file:"UpdateFile",read_folder:"ReadFolder",view_file:"ViewFile",exec_command:"ExecuteCommand",web_search:"WebSearch",web_scrape:"ReadSite",search_keyword:"SearchKeyword",write_pdf:"CreatePDF",write_docx:"CreateDocument",generate_image:"GenerateImage",WriteFile:"WriteFile",PatchFile:"PatchFile",ReadFolder:"ReadFolder",ReadFile:"ReadFile",Run:"RunCommand",WebSearch:"WebSearch",WebScrape:"WebScrape",SearchKeyword:"SearchKeyword",WritePDF:"WritePDF",WriteDoc:"WriteDoc",Memory:"Memory",Chat:"Chat",GenerateImage:"GenerateImage"},jl=e=>{if(!e)return e;let o=e.replace(/<\/think>(\r?\n){2}/gi,"</think>").replace(/(\r?\n){2}(?=\[?(?:tool:functions|tool\.functions|\s*turn\s*:))/gi,""),t="tool:functions.";for(;;){let i=o.toLowerCase().indexOf(t);if(i===-1)break;let r=i,l=!1,c=i-1;for(;c>=0&&/\s/.test(o[c]);)c--;c>=0&&o[c]==="["&&(r=c,l=!0);let f=0,u=!1,d=null,a=i;for(;a<o.length;){let m=o[a];if(!d&&(m==="'"||m==='"'||m==="`")?d=m:d&&m===d&&o[a-1]!=="\\"&&(d=null),d||(m==="("?(f++,u=!0):m===")"&&f--),u&&f===0&&!d){let p=a;if(l){let h=a+1;for(;h<o.length&&/\s/.test(o[h]);)h++;h<o.length&&o[h]==="]"&&(p=h)}o=o.substring(0,r)+o.substring(p+1);break}if(a++,a===o.length)return o=o.substring(0,r),o}}return o.replace(/\[TOOL RESULT\]:?\s*/gi,"").split(`
|
|
45
43
|
`).filter(n=>!n.trim().startsWith("SUCCESS:")&&!n.trim().startsWith("ERROR:")).join(`
|
|
46
|
-
`).replace(/\[\s*turn\s*:\s*(continue|finish)\s*\]/gi,"").replace(/\[\s*turn\s*:?.*?$/gi,"").replace(/\n\s*turn\s*:?.*?$/gi,"").replace(/\[\s*$/gi,"").replace(/\n\nResponded on .*/g,"").replace(/\n\n\[Prompted on: .*\]/g,"").replace(/(\$?\\?\/?\\rightarrow\$?|\$\\rightarrow\$)/gi,"\u2192").replace(/(\$?\\?\/?\\leftarrow\$?|\$\\leftarrow\$)/gi,"\u2190").replace(/(\$?\\?\/?\\uparrow\$?|\$\\uparrow\$)/gi,"\u2191").replace(/(\$?\\?\/?\\downarrow\$?|\$\\downarrow\$)/gi,"\u2193").replace(/(\$?\\?\/?\\leftrightarrow\$?|\$\\leftrightarrow\$)/gi,"\u2194").replace(/@\[TerminalName:.*?, ProcessId:.*?\]/gi,"").replace(/\b(write_file|update_file|read_folder|view_file|exec_command|web_search|web_scrape|search_keyword|write_pdf|write_docx|generate_image)\b/gi,n=>
|
|
47
|
-
`),i=[],r=[],l=[],c=
|
|
44
|
+
`).replace(/\[\s*turn\s*:\s*(continue|finish)\s*\]/gi,"").replace(/\[\s*turn\s*:?.*?$/gi,"").replace(/\n\s*turn\s*:?.*?$/gi,"").replace(/\[\s*$/gi,"").replace(/\n\nResponded on .*/g,"").replace(/\n\n\[Prompted on: .*\]/g,"").replace(/(\$?\\?\/?\\rightarrow\$?|\$\\rightarrow\$)/gi,"\u2192").replace(/(\$?\\?\/?\\leftarrow\$?|\$\\leftarrow\$)/gi,"\u2190").replace(/(\$?\\?\/?\\uparrow\$?|\$\\uparrow\$)/gi,"\u2191").replace(/(\$?\\?\/?\\downarrow\$?|\$\\downarrow\$)/gi,"\u2193").replace(/(\$?\\?\/?\\leftrightarrow\$?|\$\\leftrightarrow\$)/gi,"\u2194").replace(/@\[TerminalName:.*?, ProcessId:.*?\]/gi,"").replace(/\b(write_file|update_file|read_folder|view_file|exec_command|web_search|web_scrape|search_keyword|write_pdf|write_docx|generate_image)\b/gi,n=>Yl[n.toLowerCase()]||n).trim()},Gl=(e,o=80)=>{if(!e)return null;let t=o-10,n=_o(e.trim(),t);return E.createElement(H,{width:"100%"},E.createElement(oe,{italic:!0},E.createElement(Tn,{text:n,color:"gray"})))},Xl=e=>e.replace(/\\multiply|\\mul|\\times/g,"\xD7").replace(/\\div/g,"\xF7").replace(/\\cdot/g,"\u22C5").replace(/\\infty/g,"\u221E").replace(/\\pm/g,"\xB1").replace(/\\leq/g,"\u2264").replace(/\\geq/g,"\u2265").replace(/\\neq/g,"\u2260").replace(/\\sqrt\s*\{([^}]+)\}/g,"\u221A($1)").replace(/\\sqrt\s*(\w+|\d+)/g,"\u221A($1)").replace(/\\alpha/g,"\u03B1").replace(/\\beta/g,"\u03B2").replace(/\\theta/g,"\u03B8").replace(/\\pi/g,"\u03C0").replace(/\\approx/g,"\u2248").replace(/\\Delta/g,"\u0394").replace(/\\sigma/g,"\u03C3").replace(/\\sum/g,"\u03A3").replace(/\\prod/g,"\u03A0").replace(/\\rightarrow|\\to/g,"\u2192").replace(/\\left\b|\\right\b/g,"").replace(/\\left\(|\\right\)/g,o=>o.includes("left")?"(":")").replace(/\\left\[|\\right\]/g,o=>o.includes("left")?"[":"]").replace(/\\\{|\\\}/g,o=>o.includes("{")?"{":"}").replace(/\\text\s*\{([^}]+)\}/g,"$1").replace(/\\text\s+(\w+)/g,"$1").replace(/\\%/g,"%"),Wi=(e,o)=>{if(!e)return null;let t=e.replace(/\\frac\s*\{([^{}]*)\}\s*\{([^{}]*)\}/g,"($1/$2)");t=Xl(t);let n=t.split(/(\\(?:mathbf|textbf|textit|underline|texttt)\{[^{}]*\})/g);return E.createElement(E.Fragment,{key:o},n.map((i,r)=>{if(i.startsWith("\\")){let l=i.match(/\\(\w+)\{([^{}]*)\}/);if(l){let c=l[1],f=l[2];return E.createElement(oe,{key:r,bold:c==="mathbf"||c==="textbf",italic:c==="textit",underline:c==="underline",color:c==="texttt"?"cyan":void 0},f)}}return i}))},Tn=E.memo(({text:e,color:o})=>{if(!e)return null;let t=e.split(/(```[\s\S]*?```|`[^`]+`|@\[.*?\]|\*\*.*?\*\*|\*.*?\*|\$.*?\$|\[.*?\]\s*\(.*?\)|\[.*?\]\s*\[.*?\]|https?:\/\/[^\s]+)/g);return E.createElement(oe,{color:o,wrap:"anywhere"},t.map((n,i)=>{if(!n)return null;if(n.startsWith("```")&&n.endsWith("```")){let r=n.slice(3,-3);return E.createElement(oe,{key:i,color:"cyan",backgroundColor:"#003333"}," ",r," ")}if(n.startsWith("**")&&n.endsWith("**"))return E.createElement(oe,{key:i,bold:!0,color:"white"},E.createElement(Tn,{text:n.slice(2,-2),color:"white"}));if(n.startsWith("*")&&n.endsWith("*"))return E.createElement(oe,{key:i,italic:!0,color:"gray"},E.createElement(Tn,{text:n.slice(1,-1),color:"gray"}));if(n.startsWith("`")&&n.endsWith("`")){let r=n.slice(1,-1),l=r.replace(/@\[(.*?)\]/g,(f,u)=>u.split("/").pop().split("\\").pop().replace(/:L/gi,"#L")),c=r.includes("@[");return E.createElement(oe,{key:i,color:"cyan",bold:c,backgroundColor:c?"#111124":"#003333"}," ",l," ")}if(n.startsWith("@[")&&n.endsWith("]")){let l=n.slice(2,-1).split("/").pop().split("\\").pop().replace(/:L/gi,"#L");return E.createElement(oe,{key:i,color:"cyan",bold:!0,backgroundColor:"#111124"}," ",l," ")}if(n.startsWith("$")&&n.endsWith("$")){let r=n.slice(1,-1);return E.createElement(oe,{key:i,color:"yellow"},Wi(r,i))}if(n.startsWith("[")&&(n.includes("](")||n.includes("] ("))){let r=n.match(/\[(.*?)\]\s*\((.*?)\)/);if(r)return E.createElement(oe,{key:i},E.createElement(oe,{color:"cyan",underline:!0,bold:!0},r[1]),E.createElement(oe,{color:"gray",dimColor:!0,italic:!0}," (",r[2],")"))}if(n.startsWith("[")&&(n.includes("][")||n.includes("] ["))){let r=n.match(/\[(.*?)\]\s*\[(.*?)\]/);if(r)return E.createElement(oe,{key:i},E.createElement(oe,{color:"cyan",underline:!0,bold:!0},r[1]),E.createElement(oe,{color:"gray",dimColor:!0,italic:!0}," [",r[2],"]"))}return n.startsWith("http")?E.createElement(oe,{key:i,color:"cyan",underline:!0,italic:!0},n):Wi(n,i)}))}),Kl=E.memo(({buffer:e,terminalWidth:o=80})=>{if(e.length<2)return null;let t=e.map(f=>{let u=f.split("|");return u[0]!==void 0&&u[0].trim()===""&&u.shift(),u.length>0&&u[u.length-1].trim()===""&&u.pop(),u.map(d=>d.trim())}),n=t[0],i=t.slice(2),r=Math.floor(100/n.length),l=o-8,c=Math.floor(l/n.length)-2;return E.createElement(H,{flexDirection:"column",borderStyle:"round",borderColor:"#454545ff",paddingX:1,marginY:0,width:"100%",flexGrow:1},E.createElement(H,{flexDirection:"row",borderStyle:"single",borderBottom:!0,borderTop:!1,borderLeft:!1,borderRight:!1,borderColor:"#444",marginBottom:1,paddingBottom:0,width:"100%"},n.map((f,u)=>E.createElement(H,{key:u,flexBasis:`${r}%`,flexGrow:1,flexShrink:0,paddingRight:2},E.createElement(Tn,{text:_o(f,c),color:"cyan"})))),i.map((f,u)=>E.createElement(H,{key:u,flexDirection:"row",marginBottom:u===i.length-1?0:1,width:"100%"},f.map((d,a)=>E.createElement(H,{key:a,flexBasis:`${r}%`,flexGrow:1,flexShrink:0,paddingRight:2,flexDirection:"column"},E.createElement(Tn,{text:_o(d,c),color:"white"}))))))}),Hi=E.memo(({text:e,color:o="white",columns:t=80})=>{if(!e)return null;let n=e.split(`
|
|
45
|
+
`),i=[],r=[],l=[],c=f=>{r.length>0&&(i.push(E.createElement(Kl,{key:`table-${f}`,buffer:[...r],terminalWidth:t})),r=[]),l.length>0&&(i.push(E.createElement(H,{key:`quote-${f}`,borderStyle:"bold",borderLeft:!0,borderRight:!1,borderTop:!1,borderBottom:!1,borderColor:"gray",paddingLeft:1,marginY:1,flexDirection:"column"},l.map((u,d)=>E.createElement(Tn,{key:d,text:u,color:"gray"})))),l=[])};return n.forEach((f,u)=>{let d=f.trim(),a=d.startsWith("|"),m=d.startsWith(">");if(a)l.length>0&&c(u),r.push(f);else if(m)r.length>0&&c(u),l.push(d.replace(/^>\s*/,""));else{if(c(u),d===""){i.push(E.createElement(H,{key:u,height:1}));return}if(d==="---"||d==="***"||d==="___"){i.push(E.createElement(H,{key:u,marginY:1,borderStyle:"single",borderTop:!0,borderBottom:!1,borderLeft:!1,borderRight:!1,width:"100%",borderColor:"#333"}));return}let p=d.match(/^(#{1,6})\s+(.*)/);if(p){let I=p[1].length,$=p[2];i.push(E.createElement(H,{key:u,marginTop:1,marginBottom:1,width:"100%"},E.createElement(oe,{bold:!0,color:I===1?"cyan":I===2?"magenta":I===3?"yellow":I===4?"green":I===5?"blue":"white",underline:!0},$.toUpperCase())));return}let h=d.startsWith("* ")||d.startsWith("- "),S=/^\d+\.\s/.test(d),T=f.includes("\u2588")||f.includes("\u2554")||f.includes("\u255A")||f.includes("\u2550"),w="";if(T)w=f;else if(h||S){let I=h?" \u2022 ":d.match(/^\d+\.\s/)[0],$=" ".repeat(I.length),U=_o(d.replace(/^[\*\-\d+\.]+\s/,""),t-(I.length+6));w=I+U.split(`
|
|
48
46
|
`).join(`
|
|
49
|
-
|
|
50
|
-
`);return
|
|
51
|
-
`),
|
|
52
|
-
`),
|
|
53
|
-
`).map((a,
|
|
47
|
+
`+$)}else w=_o(d,t-4);i.push(E.createElement(H,{key:u,width:"100%"},E.createElement(Tn,{text:w,color:o})))}}),c("final"),E.createElement(H,{flexDirection:"column",width:t-2},i)}),ql=E.memo(({line:e,columns:o=80})=>{let t=e.includes("[UI_CONTEXT]"),n=e.replace("[UI_CONTEXT]","");if(t&&n.includes("\u2550"))return E.createElement(H,{backgroundColor:"#1a1a1a",paddingX:1,width:"100%"},E.createElement(oe,{color:"gray",dimColor:!0},"\u2550".repeat(Math.max(10,o-4))));let i=n.startsWith("-"),r=n.startsWith("+"),l=n[0],c=n.substring(1),f=c.indexOf("|"),u=f!==-1?c.substring(0,f).trim():"",d=f!==-1?c.substring(f+1):c,a=i?"#3a0c0c":r?"#0c3a1a":"#1a1a1a",m=i?"#ff4d4d":r?"#4dff88":t?"gray":"white";return E.createElement(H,{backgroundColor:a,paddingX:1,width:"100%"},E.createElement(H,{width:5,flexShrink:0},E.createElement(oe,{color:i?"#cf3a3a":r?"#3acf65":"gray",dimColor:t},u)),E.createElement(H,{width:2,flexShrink:0,marginLeft:1},E.createElement(oe,{color:m,bold:!0},i?"-":r?"+":" ")),E.createElement(H,{flexGrow:1,marginLeft:1},E.createElement(oe,{color:m,dimColor:t},_o(d,o-14))))}),Vl=E.memo(({text:e,columns:o=80})=>{let t=e.match(/\[DIFF_START\]([\s\S]*?)\[DIFF_END\]/),i=(t?t[1].trim():"").split(`
|
|
48
|
+
`);return E.createElement(H,{flexDirection:"column",width:o-3,marginBottom:0},E.createElement(H,{flexDirection:"column",backgroundColor:"#1a1a1a",paddingY:0,width:"100%"},i.map((r,l)=>E.createElement(ql,{key:l,line:r,columns:o-3}))))}),Yi=E.memo(({text:e,columns:o=80})=>{if(!e)return null;if(e.includes("[DIFF_START]"))return E.createElement(Vl,{text:e,columns:o});if(e.includes("- Content Preview:")){let t=e.split("- Content Preview:"),n=t[0],i=t[1]||"",r="Check if Starting and Ending matches",l=i.split(r),c=l[0]?.trim()||"",f=l[1]?`${r}${l[1]}`:"",u=c.split(`
|
|
49
|
+
`),d=String(u.length).length;return E.createElement(H,{flexDirection:"column",width:o-3},E.createElement(H,{flexDirection:"column",borderStyle:"round",borderColor:"#444",paddingX:1,width:"100%"},E.createElement(H,{alignSelf:"flex-end",marginTop:-1,marginRight:1},E.createElement(oe,{backgroundColor:"#444",color:"white"}," FILE SNAPSHOT ")),E.createElement(H,{flexDirection:"column",paddingY:1,width:"100%"},u.map((a,m)=>E.createElement(H,{key:m,width:"100%"},E.createElement(H,{width:d+2,flexShrink:0},E.createElement(oe,{color:"gray",dimColor:!0},String(m+1).padStart(d," ")," ")),E.createElement(H,{flexGrow:1},E.createElement(oe,{color:"white"},a)))))))}if(e.includes("```")){let t=e.split(/(```\w*\n?[\s\S]*?(?:```|$))/g);return E.createElement(H,{flexDirection:"column",width:o-3},t.map((n,i)=>{if(n.startsWith("```")){let l=n.match(/```(\w*)\n?([\s\S]*?)(?:```|$)/),c=l?l[1]:"code",u=(l?l[2]:n.replace(/^```\w*\n?/,"").replace(/```$/,"")).trimEnd().split(`
|
|
50
|
+
`),d=String(u.length).length;return E.createElement(H,{key:i,flexDirection:"column",marginY:0,backgroundColor:"#111",borderStyle:"round",borderColor:"#333",paddingX:1,width:"100%"},E.createElement(H,{alignSelf:"flex-end",marginTop:-1,marginRight:1},E.createElement(oe,{backgroundColor:"#333",color:"white"}," ",c.toUpperCase()," ")),E.createElement(H,{flexDirection:"column",paddingY:1,width:"100%"},u.map((a,m)=>E.createElement(H,{key:m,width:"100%"},E.createElement(H,{width:d+2,flexShrink:0},E.createElement(oe,{color:"gray",dimColor:!0},String(m+1).padStart(d," ")," ")),E.createElement(H,{flexGrow:1},E.createElement(oe,{color:"cyan"},a))))))}let r=n;return i>0&&(r=r.replace(/^[\r\n]+/,"")),i<t.length-1&&(r=r.replace(/[\r\n]+$/,"")),r?E.createElement(Hi,{key:i,text:r,columns:o-3}):null}))}return E.createElement(Hi,{text:e,columns:o-3})}),ji=e=>{let o=Math.round(e/1e3);if(o<=0)return"0s";let t=Math.floor(o/60),n=o%60;return t>0?`${t}m ${n}s`:`${o}s`},As=E.memo(({msg:e,showFullThinking:o,columns:t=80})=>{let n=e.role==="system"&&(e.text?.includes("[DIFF_START]")||e.text?.includes("- Content Preview:")),i=e.role==="system"&&e.text?.includes("[TOOL RESULT]: ERROR:")&&!e.text?.includes("[DIFF_START]")&&(e.toolName==="update_file"||e.text?.includes("Could not find exact match")),r=e.isTerminalRecord;if(e.isHomeWarning)return E.createElement(H,{marginBottom:1,paddingX:1,width:"100%"},E.createElement(H,{flexDirection:"column",borderStyle:"round",borderColor:"red",padding:0,width:"100%"},E.createElement(H,{paddingX:1,backgroundColor:"#3a0000"},E.createElement(oe,{color:"red",bold:!0},e.text)),E.createElement(H,{paddingX:1,marginTop:1,marginBottom:1},E.createElement(oe,{color:"white"},e.subText))));if(e.isLogo)return E.createElement(H,{flexDirection:"column",alignItems:"center",width:"100%",marginY:1},E.createElement(oe,null,e.text));if(e.id&&String(e.id).startsWith("welcome"))return E.createElement(H,{flexDirection:"column",alignItems:"center",width:"100%",marginY:1},E.createElement(H,{borderStyle:"round",borderColor:"gray",paddingX:3,paddingY:0},E.createElement(oe,{color:"cyan",bold:!0},e.text.trim())));if(e.isVisualFeedback)return E.createElement(H,{marginBottom:0,marginTop:0,paddingX:1,width:"100%"},E.createElement(oe,{color:"white"},e.text));if(i)return E.createElement(H,{marginBottom:1},E.createElement(H,{flexDirection:"column",borderStyle:"round",borderColor:"red",paddingX:1,paddingY:0},E.createElement(oe,{color:"red",bold:!0,underline:!0},"\u274C PATCH FAILED"),E.createElement(H,{marginTop:1},E.createElement(oe,{color:"red"},"Patch failed: ",E.createElement(oe,{color:"white",bold:!0},"Model generated malformed edit.")))));if(e.role==="system"&&e.text?.includes("[TOOL RESULT]")&&!n&&!r&&!i)return null;if(e.isImageStats)return E.createElement(H,{marginBottom:1,paddingX:1,width:"100%"},E.createElement(H,{flexDirection:"column",borderStyle:"round",borderColor:"cyan",padding:0,width:"100%"},E.createElement(H,{paddingX:1,backgroundColor:"#0e1b21"},E.createElement(oe,{color:"cyan",bold:!0},"\u{1F4B3} IMAGE STATS")),E.createElement(H,{paddingX:1,marginTop:1,marginBottom:1,flexDirection:"column"},e.text.split(`
|
|
51
|
+
`).map((a,m)=>E.createElement(oe,{key:m,color:"white"},a)))));if(e.isAskRecord){let a=e.text.match(/Selection: (.*)/),m=a?a[1]:"No selection",p=Ce(2);return E.createElement(H,{marginBottom:1,paddingX:1,width:"100%"},E.createElement(H,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},E.createElement(H,{paddingX:1},E.createElement(oe,{color:"cyan",bold:!0},"\u{1F4AC} AGENT REQUEST: RESOLVED")),E.createElement(H,{paddingX:1,marginTop:1,marginBottom:1},E.createElement(oe,{color:"white"},"Selection: ",E.createElement(oe,{color:"yellow",bold:!0},m)))))}if(e.isAboutRecord)return E.createElement(H,{marginBottom:1,paddingX:1,width:"100%"},E.createElement(H,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},E.createElement(H,{paddingX:1},E.createElement(oe,{color:"cyan",bold:!0},"\u{1F4A0} ABOUT FLUX FLOW")),E.createElement(H,{paddingX:1,marginTop:1,marginBottom:1},E.createElement(oe,null,e.text))));if(e.isUpdateNotification)return E.createElement(H,{marginBottom:1,paddingX:1,width:"100%"},E.createElement(H,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},E.createElement(H,{paddingX:1},E.createElement(oe,{color:"cyan",bold:!0},"\u{1F680} FLUX FLOW UPDATE AVAILABLE")),E.createElement(H,{paddingX:1,marginTop:1,marginBottom:1},E.createElement(Yi,{text:e.text,columns:t}))));if(e.isHelpRecord)return E.createElement(H,{marginBottom:1,paddingX:1,width:"100%"},E.createElement(H,{flexDirection:"column",borderStyle:"round",borderColor:"magenta",paddingX:2,paddingY:1,width:"100%"},E.createElement(oe,{color:"magenta",bold:!0,underline:!0},"\u{1F4DC} COMMAND REFERENCE"),E.createElement(H,{flexDirection:"column",marginTop:1},[{cmd:"/quit",desc:"Exit and shutdown Flux"},{cmd:"/help",desc:"Show all available commands"},{cmd:"/clear",desc:"Clear terminal screen"},{cmd:"/resume",desc:"Load previous session"},{cmd:"/revert",desc:"Revert codebase to checkpoint"},{cmd:"/save",desc:"Force save current chat"},{cmd:"/export",desc:"Export current chat in a .txt file"},{cmd:"/chats",desc:"List all chat sessions"},{cmd:"/image",desc:"Generate images"},{cmd:"/mode",desc:"Toggle Flux/Flow modes"},{cmd:"/thinking",desc:"Set AI reasoning depth"},{cmd:"/model",desc:"Switch AI model"},{cmd:"/settings",desc:"Configure system prefs"},{cmd:"/key",desc:"Manage API keys"},{cmd:"/profile",desc:"Edit developer persona"},{cmd:"/memory",desc:"Manage agent memory"},{cmd:"/stats",desc:"Show session usage"},{cmd:"/reset",desc:"Wipe all project data"},{cmd:"/about",desc:"Project info & credits"},{cmd:"/changelog",desc:"View latest updates"},{cmd:"/fluxflow",desc:"Project management"},{cmd:"/update",desc:"Check/Install updates"}].map((m,p)=>E.createElement(H,{key:p,flexDirection:"row"},E.createElement(H,{width:15},E.createElement(oe,{color:"cyan",bold:!0},m.cmd)),E.createElement(oe,{color:"gray"}," - ",m.desc))))));if(e.isTerminalRecord){let a=e.text.match(/COMMAND: (.*)/),m=e.text.match(/PTY: (true|false)/),p=e.text.match(/OUTPUT: ([\s\S]*)/),h=a?a[1]:"Unknown",S=m?m[1]==="true":!1,T=p?p[1]:"";return E.createElement(H,{marginBottom:1,paddingX:1,width:"100%"},E.createElement(jr,{command:h,output:T,completed:!0,columns:t,isPty:S}))}let[c,f]=E.useState(!e.isStreaming),u=E.useMemo(()=>jl(e.text),[e.text]);E.useEffect(()=>{e.isStreaming&&f(!1)},[e.id]);let d=E.useMemo(()=>e.role==="think"&&!o?"Thinking...":e.isStreaming?u:u.trimEnd(),[u,e.role,o,e.isStreaming]);return E.createElement(H,{marginBottom:e.role==="think"?0:e.role==="user"?1:e.role==="agent"?0:1,marginTop:(e.role==="think"||e.role==="user"||e.role==="agent",0),flexDirection:"column",flexShrink:0,width:"100%",flexGrow:1},e.role==="user"?E.createElement(H,{backgroundColor:"#262626",paddingX:1,paddingY:1,width:"100%",flexDirection:"column"},_o(d.replace(/\r\n/g,`
|
|
54
52
|
`).replace(/\r/g,`
|
|
55
53
|
`).replace(/\\\n/g,`
|
|
56
54
|
`).replace(/\\$/,""),t-6).split(`
|
|
57
|
-
`).map((a,
|
|
58
|
-
`),columns:t}),e.memoryUpdated&&
|
|
59
|
-
`)){let
|
|
60
|
-
`)[0];if(!
|
|
61
|
-
`;case"r":return"\r";case"t":return" ";case"\\":return"\\";default:return
|
|
55
|
+
`).map((a,m)=>E.createElement(H,{key:m,flexDirection:"row",width:"100%"},E.createElement(H,{flexShrink:0,width:2},E.createElement(oe,{bold:!0,color:"white"},m===0?"\u276F":" ")),E.createElement(H,{flexGrow:1,marginLeft:1},E.createElement(Tn,{text:a,color:e.color||"white"}))))):e.role==="think"?E.createElement(H,{flexDirection:"column",marginTop:0,marginBottom:0,paddingX:1,width:"100%"},e.isStreaming&&!e.duration?E.createElement(oe,{bold:!0,color:"white"},"\u2727 Thinking..."):E.createElement(oe,{bold:!0,color:"white"},"\u2726 Thought",e.duration?E.createElement(oe,{color:"gray"}," for ",E.createElement(oe,{bold:!0,color:"cyan"},ji(e.duration))):""),E.createElement(H,{borderStyle:"single",borderLeft:!0,borderRight:!1,borderTop:!1,borderBottom:!1,paddingLeft:2,paddingTop:1,paddingBottom:1,flexDirection:"column",width:"100%"},Gl(d,t))):E.createElement(H,{flexDirection:"column",paddingX:1,marginTop:0,width:"100%"},E.createElement(Yi,{text:d.replace(/ \|\n\n/g,` |
|
|
56
|
+
`),columns:t}),e.memoryUpdated&&E.createElement(H,{marginTop:1,width:"100%"},E.createElement(oe,{color:"yellow",italic:!0},"\u2728 [Memory Updated]")),e.role==="agent"&&e.workedDuration?E.createElement(H,{marginTop:1,marginBottom:2,width:"100%"},E.createElement(oe,null,"["),E.createElement(oe,{color:"gray"},"\u26A1 Worked for ",E.createElement(oe,{bold:!0,color:"cyan"},ji(e.workedDuration))),E.createElement(oe,null,"]")):null))}),zl=E.memo(({messages:e,showFullThinking:o,columns:t=80})=>E.createElement(H,{flexDirection:"column",width:"100%"},e.map((n,i)=>E.createElement(As,{key:n.id||i,msg:n,showFullThinking:o,columns:t})))),Gi=zl});import Ue from"react";import{Box as tn,Text as Pt}from"ink";var Jl,Ki,qi=ae(()=>{Bn();Jl=Ue.memo(({mode:e,thinkingLevel:o,tokens:t="0.0k",tokensTotal:n="0.0k",chatId:i="NEW-SESSION",isMemoryEnabled:r=!0,apiTier:l="Free",aiProvider:c="Google"})=>{let f=e==="Flux"?"yellow":"cyan",u=e==="Flux"?"\u26A1":"\u{1F30A}",d=256e3;return(c==="DeepSeek"||c==="Google"&&l==="Paid")&&(d=4e5),Ue.createElement(tn,{borderStyle:"round",borderColor:"gray",flexDirection:"row",justifyContent:"space-between",paddingX:1,width:"100%"},Ue.createElement(tn,null,Ue.createElement(tn,{marginRight:1},Ue.createElement(Pt,{color:f,bold:!0},u," ",e.toUpperCase())),Ue.createElement(Pt,{color:"gray",dimColor:!0},"\u2503 "),Ue.createElement(tn,{marginX:1},Ue.createElement(Pt,{color:"magenta"},"\u{1F9E0} ",o)),Ue.createElement(Pt,{color:"gray",dimColor:!0},"\u2503 "),Ue.createElement(tn,{marginX:1},Ue.createElement(Pt,{color:"gray"},"MEM: "),Ue.createElement(Pt,{color:r?"green":"red",bold:!0},r?"ON":"OFF"))),Ue.createElement(tn,{flexGrow:1,justifyContent:"center",paddingX:2},Ue.createElement(Pt,null,"\u{1F4C1}"),Ue.createElement(Pt,{color:"gray",italic:!0}," ",Ri(process.cwd(),35))),Ue.createElement(tn,null,Ue.createElement(Pt,{color:"gray",dimColor:!0},"\u2503 "),Ue.createElement(tn,{marginX:1},Ue.createElement(Pt,null,"\u2728"),Ue.createElement(Pt,{color:"blue"}," ",Qt(n)," ",Ue.createElement(Pt,{dimColor:!0},"(",(t/d*100).toFixed(0),"%)"))),Ue.createElement(Pt,{color:"gray",dimColor:!0},"\u2503 "),Ue.createElement(tn,{marginLeft:1},Ue.createElement(Pt,null,"\u{1F194}"),Ue.createElement(Pt,{color:"gray",dimColor:!0,italic:!0}," ",i),(l==="Custom"||l==="Paid")&&Ue.createElement(Pt,{color:"gray",dimColor:!0}," | ",Ue.createElement(Pt,{color:"green",bold:!0},"PAID")))))}),Ki=Jl});import Oo from"react";import{Box as Jn,Text as Gr}from"ink";import Ql from"ink-select-input";function ao({title:e,subtitle:o,items:t,onSelect:n}){return Oo.createElement(Jn,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,marginTop:1,flexShrink:0,width:"100%"},Oo.createElement(Jn,{paddingX:1,paddingY:0,marginBottom:o?0:1},Oo.createElement(Gr,{color:"magenta",bold:!0},"\u{1F527} ",typeof e=="string"?e.toUpperCase():e)),o&&Oo.createElement(Jn,{paddingX:1,marginBottom:1},Oo.createElement(Gr,{color:"yellow",dimColor:!0,italic:!0}," ",o)),Oo.createElement(Jn,{flexDirection:"column",width:"100%"},Oo.createElement(Ql,{items:t,onSelect:n,itemComponent:Zl,indicatorComponent:()=>null})),Oo.createElement(Jn,{paddingX:1,marginTop:1},Oo.createElement(Gr,{color:"gray",dimColor:!0,italic:!0},"(Arrows to select \u2022 Enter to confirm)")))}var Zl,Vi=ae(()=>{Zl=({label:e,isSelected:o})=>{let t=e==="Cancel"||e==="Back"||e.toLowerCase().includes("exit")||e.toLowerCase().includes("back");return Oo.createElement(Jn,{marginTop:t?1:0,backgroundColor:o?"#2a2a2a":void 0,paddingX:1,width:"100%"},Oo.createElement(Gr,{color:o?"cyan":"white",bold:o},o?"\u276F ":" ",e))}});var ne,Zt=ae(()=>{ne=e=>{let o={};if(!e)return o;let t=0;for(;t<e.length;){for(;t<e.length&&/[\s,]/.test(e[t]);)t++;if(t>=e.length)break;let n=e.substring(t).match(/^(\w+)\s*=\s*/);if(!n){t++;continue}let i=n[1];t+=n[0].length;let r="";if(t<e.length&&(e[t]==='"'||e[t]==="'"||e[t]==="`")){let l=e[t];t++;let c=t,f=-1,u=t;for(;u<e.length;){let a=e.indexOf(l,u);if(a===-1)break;let m=0;for(let T=a-1;T>=0&&e[T]==="\\";T--)m++;if(m%2!==0){u=a+1;continue}let p=e.substring(a+1),h=p.trim(),S=h===""||/^,\s*\w+\s*=/.test(h)||h.startsWith(")")&&(h.length===1||/^\)\s*([,\]\s]|tool:)/i.test(h));if(S&&p.startsWith(`
|
|
57
|
+
`)){let T=h.split(`
|
|
58
|
+
`)[0];if(!T.includes("=")&&!T.includes(")")){u=a+1;continue}}if(S){f=a;break}u=a+1}f!==-1?(r=e.substring(c,f),t=f+1):(r=e.substring(c),t=e.length);let d=i.toLowerCase().includes("path")||["dest","source","to","from"].includes(i.toLowerCase());r=r.replace(/\\(.)/g,(a,m)=>{switch(m){case"n":return`
|
|
59
|
+
`;case"r":return"\r";case"t":return" ";case"\\":return"\\";default:return m===l?l:a}})}else if(t<e.length&&e[t]==="["){let l=0,c=null,f=t,u=-1;for(let d=t;d<e.length;d++){let a=e[d];if(c&&a===c){let m=0;for(let p=d-1;p>=0&&e[p]==="\\";p--)m++;m%2===0&&(c=null)}else!c&&(a==='"'||a==="'"||a==="`")&&(c=a);if(!c&&(a==="["?l++:a==="]"&&l--,l===0)){u=d;break}}if(u!==-1){r=e.substring(f,u+1),t=u+1;try{let d=r.trim();d.startsWith("'")||d.includes("'")}catch{}}else r=e.substring(f),t=e.length}else{let l=e.substring(t),c=l.match(/,\s*\w+\s*=|(?:\s*\)\s*(?:$|\]))/);if(c){let f=c.index;r=l.substring(0,f).trim(),t+=f}else r=l.trim(),t=e.length}r==="true"?r=!0:r==="false"?r=!1:typeof r=="string"&&!isNaN(r)&&r.trim()!==""&&(r=Number(r)),typeof r=="string"&&(i.toLowerCase().includes("path")||["dest","source","to","from"].includes(i.toLowerCase()))&&(r=r.replace(/\x0C/g,"\\f").replace(/\x0D/g,"\\r").replace(/\x0B/g,"\\v").replace(/\x08/g,"\\b")),o[i]=r}return o}});import{execSync as ec}from"child_process";var hr,Qn,zi,Os=ae(async()=>{await gr();hr=null,Qn=()=>{if(process.platform!=="win32")return!1;if(hr!==null)return hr;try{ec('powershell.exe -NoProfile -Command "exit"',{stdio:"ignore"}),hr=!0}catch{hr=!1}return hr},zi=(e,o,t,n)=>`
|
|
62
60
|
-- TOOL DEFINITIONS --
|
|
63
61
|
Access to internal tools. MUST use the exact syntax on a new line: [tool:functions.ToolName(args)]
|
|
64
62
|
MANDATORY TOOL POLICY:
|
|
@@ -77,44 +75,43 @@ ${e==="Flux"?`- **File Tools >> Code in chat**
|
|
|
77
75
|
${e==="Flux"?`- PROJECT TOOLS (path = relative to CWD, path separator: '/') -
|
|
78
76
|
1. [tool:functions.ReadFile(path="...", startLine=number, endLine=number)]. ${n!=="Google"?`${t?"Supports images/docs. User gives image/doc: VIEW FIRST":"No Multimodal support"}`:"Supports images/docs. User gives image/doc: VIEW FIRST"}
|
|
79
77
|
2. [tool:functions.ReadFolder(path="...")]. Detailed DIR stats
|
|
80
|
-
3. [tool:functions.PatchFile(path="...", replaceContent1="exact string", newContent1="...", ...MAX
|
|
81
|
-
4. [tool:functions.WriteFile(path="...", content="...")]. Creates/Overwrites. File Exist? PatchFile
|
|
78
|
+
3. [tool:functions.PatchFile(path="...", replaceContent1="exact string", newContent1="...", ...MAX 10)]. Surgical Patch. **Multiple patch on same file/path? Use replaceContent2, newContent2 etc >>> multiple spams**. Unsure? ReadFile >> guessing
|
|
79
|
+
4. [tool:functions.WriteFile(path="...", content="...")]. Creates/Overwrites. File Exist? PatchFile > WriteFile. Verify Imports
|
|
82
80
|
5. [tool:functions.SearchKeyword(keyword="...", file="optional")]. Global project search. If 'file' is provided, searches only that file. Finds definitions/logic without reading every file
|
|
83
|
-
6. [tool:functions.Run(command="...")]. Runs ${o==="Windows"?
|
|
81
|
+
6. [tool:functions.Run(command="...")]. Runs ${o==="Windows"?Qn()?`${Nn?"Interactive ":""}WINDOWS POWERSHELL ONLY`:`${Nn?"Interactive ":""}WINDOWS CMD ONLY`:`${Nn?"Interactive ":""}BASH`} command. Destructive/Irreversible ops -> Ask user
|
|
84
82
|
7. [tool:functions.GenerateImage(path="... png", prompt="detailed", ratio="16:9, 9:16, 1:1")]. Usage: Mockups, PDF thumbnails, any visual content
|
|
85
|
-
8. [tool:functions.WritePDF(path="...", content="...", orientation="...")]. PROACTIVE A4 PAGE BREAKS MUST IN CSS. HTML/CSS for PREMIUM layout
|
|
83
|
+
8. [tool:functions.WritePDF(path="...", content="...", orientation="...")]. PROACTIVE A4 PAGE BREAKS MUST IN CSS. HTML/CSS for PREMIUM layout
|
|
86
84
|
9. [tool:functions.WriteDoc(path="...", content="...")]. A4 Word document
|
|
87
85
|
|
|
88
86
|
- VERIFY TOOL RESULT CONTENTS. Fix errors. No hallucinations
|
|
89
87
|
|
|
90
88
|
- Escape quotes: \\" for code strings
|
|
91
89
|
- Literal escapes: Double-escape sequences (e.g., \\\\n, \\\\t)
|
|
92
|
-
- File structure: Real newlines for code formatting`.trim():"\n- FILE TOOLS ARE NOT AVAILABLE IN FLOW (Tell user,` /mode flux` if needed)".trim()}
|
|
90
|
+
- File structure: Real newlines for code formatting`.trim():"\n- FILE TOOLS ARE NOT AVAILABLE IN FLOW (Tell user to,` /mode flux` if needed)".trim()}
|
|
93
91
|
|
|
94
|
-
- Results: Passed as [TOOL RESULT]
|
|
95
|
-
- MAX Tool call stack: STRICTLY 3 per turn`.trim()});import{spawn as Os}from"child_process";var Hr,Fn,jr,Ct,So,Eo,Ki,qi,Ls,As,xr=ie(async()=>{Qt();await Ms();Hr=null;try{let e=await import("node-pty");Hr=e.default||e}catch{}Fn=!!Hr,jr=e=>typeof e!="string"?e:e.replace(/[\u001b\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g,""),Ct=null,So=!1,Eo=e=>{try{Ct&&(So&&typeof Ct.write=="function"?Ct.write(e):Ct.stdin&&Ct.stdin.writable&&Ct.stdin.write(e))}catch{}},Ki=()=>{if(Ct){try{So&&typeof Ct.destroy=="function"?Ct.destroy():typeof Ct.kill=="function"&&(process.platform==="win32"?Os("taskkill",["/pid",Ct.pid,"/f","/t"]):Ct.kill("SIGKILL"))}catch{}Ct=null,So=!1}},qi=(e,o=!1)=>{if(process.platform!=="win32")return e;let t=[],n="",i=null,r=!1;for(let u=0;u<e.length;u++){let a=e[u];if(r){n+=a,r=!1;continue}if(a==="\\"){if(e[u+1]===" "){n+=" ",u++;continue}n+=a,r=!0;continue}i?(a===i&&(i=null),n+=a):a==='"'||a==="'"?(i=a,n+=a):a===";"&&!n.includes("://")?(n.length>0&&(t.push(n),n=""),t.push(o?";":"&")):a==="|"&&!n.includes("://")?(n.length>0&&(t.push(n),n=""),t.push("|")):/\s/.test(a)?n.length>0&&(t.push(n),n=""):n+=a}n.length>0&&t.push(n);let l=u=>!(!u.includes("/")||/^(https?|file|ftp):\/\//i.test(u)||u.startsWith("/")&&(u.match(/\//g)||[]).length===1||/\s\/|\/\s/.test(u)||/[\(\)\{\}\;\<\>\=\'\"]/.test(u)),c=[];for(let u=0;u<t.length;u++){let a=t[u];if(a==="mkdir"&&o&&Kn()){let f=[],p=u+1;for(;p<t.length;){let h=t[p];if([">",">>","<","&","&&","|","||",";"].includes(h))break;h!=="-p"&&h!=="--parents"&&h!=="-v"&&h!=="--verbose"&&f.push(h),p++}if(f.length>0){let h=f.map(T=>{let w=T.replace(/^['"]|['"]$/g,""),E=T;return l(w)&&(E=T.replace(/\//g,"\\")),E});c.push("New-Item","-ItemType","Directory","-Force","-Path",h.join(","))}else c.push("New-Item","-ItemType","Directory","-Force");u=p-1;continue}if(a==="rm"&&o&&Kn()){let f=[],p=!1,h=!1,T=u+1;for(;T<t.length;){let E=t[T];if([">",">>","<","&","&&","|","||",";"].includes(E))break;E==="-rf"||E==="-fr"?(p=!0,h=!0):E==="-r"||E==="-R"||E==="--recursive"?p=!0:E==="-f"||E==="--force"?h=!0:f.push(E),T++}let w=["Remove-Item"];if(p&&w.push("-Recurse"),h&&w.push("-Force"),f.length>0){let E=f.map(k=>{let D=k.replace(/^['"]|['"]$/g,""),_=k;return l(D)&&(_=k.replace(/\//g,"\\")),_});w.push("-Path",E.join(","))}c.push(...w),u=T-1;continue}if(a==="cp"&&o&&Kn()){let f=[],p=!1,h=!1,T=u+1;for(;T<t.length;){let E=t[T];if([">",">>","<","&","&&","|","||",";"].includes(E))break;E==="-r"||E==="-R"||E==="--recursive"?p=!0:E==="-f"||E==="--force"?h=!0:f.push(E),T++}let w=["Copy-Item"];if(p&&w.push("-Recurse"),h&&w.push("-Force"),f.length>0){let E=f.map(k=>{let D=k.replace(/^['"]|['"]$/g,""),_=k;return l(D)&&(_=k.replace(/\//g,"\\")),_});if(E.length>1){let k=E.pop();w.push("-Path",E.join(","),"-Destination",k)}else w.push("-Path",E[0])}c.push(...w),u=T-1;continue}if(a==="touch"&&o&&Kn()){let f=[],p=u+1;for(;p<t.length;){let h=t[p];if([">",">>","<","&","&&","|","||",";"].includes(h))break;f.push(h),p++}if(f.length>0){let T=`(${f.map(w=>{let E=w.replace(/^['"]|['"]$/g,""),k=w;return l(E)&&(k=w.replace(/\//g,"\\")),k}).join(", ")}) | ForEach-Object { if (Test-Path $_) { (Get-Item $_).LastWriteTime = [System.DateTime]::Now } else { $null | Out-File -FilePath $_ } }`;c.push(T)}u=p-1;continue}if(a==="|"&&t[u+1]==="tee"){t[u+2]==="-a"?(c.push(">>"),u+=2):(c.push(">"),u+=1);continue}if(a==="|"&&t[u+1]==="cat"&&t[u+2]===">"){c.push(">"),u+=2;continue}if(a==="|"){let f=t[u+1];if(f){let p=f.replace(/^['"]|['"]$/g,""),h=/\.(txt|md|json|log|csv|html|css|py|js|xml|yaml|yml|pdf|docx|pptx|xlsx)$/i.test(p);if(l(p)&&h){c.push(">");continue}}}c.push(a)}let m=!1;return c.map(u=>{if(u==="echo")return m=!0,u;[">",">>","<","&","&&","|","||",";"].includes(u)&&(m=!1);let f=/^['"]|['"]$/.test(u),p=u;m&&f&&(p=u.replace(/^['"]|['"]$/g,""));let h=/^['"]|['"]$/.test(p),T=p.replace(/^['"]|['"]$/g,"");l(T)&&(p=p.replace(/\//g,"\\"));let w=p.replace(/^['"]|['"]$/g,"");return w.includes(" ")&&!h&&(p=`"${w}"`),p}).join(" ")},Ls=async(e,o={})=>{let{command:t}=oe(e),{onChunk:n}=o;if(!t)return'ERROR: Missing "command" argument for exec_command.';let i=process.platform==="win32",r=o.systemSettings||{},l={};return r.networkAccess===!1&&(l.HTTP_PROXY="http://127.0.0.1:9999",l.HTTPS_PROXY="http://127.0.0.1:9999",l.ALL_PROXY="socks5://127.0.0.1:9999",l.http_proxy="http://127.0.0.1:9999",l.https_proxy="http://127.0.0.1:9999",l.all_proxy="socks5://127.0.0.1:9999",l.NO_PROXY="localhost,127.0.0.1"),new Promise(c=>{let m=d=>{let u=qi(t,d),a=i?d?"powershell.exe":"cmd.exe":process.env.SHELL||"bash",f=i?d?["-NoProfile","-Command",u]:["/c",u]:["-c",u];if(Hr)try{let p=Hr.spawn(a,f,{name:"xterm-256color",cols:o.cols||120,rows:o.rows||30,cwd:process.cwd(),env:{...process.env,CI:"false",TERM:"xterm-256color",FORCE_COLOR:"1",...l}});Ct=p,So=!0;let h="",T=!1;return p.onData(w=>{if(!T){h+=w,n&&n(w);let E=jr(h);/(?:Network:\s+use\s+--host\s+to|Network:\s+Type\s+--host\s+to|Local:\s+http:\/\/localhost:\d+|ready in \d+\s*ms|Compiled successfully|Development server is running|Listening on:)/i.test(E)&&(T=!0,setTimeout(()=>c(`SUCCESS: Dev server started successfully in background.
|
|
92
|
+
- Results: Passed as [TOOL RESULT] in user turn`.trim()});import{spawn as Ls}from"child_process";var Xr,Nn,Kr,It,Eo,bo,Ji,Qi,vs,Ds,gr=ae(async()=>{Zt();await Os();Xr=null;try{let e=await import("node-pty");Xr=e.default||e}catch{}Nn=!!Xr,Kr=e=>typeof e!="string"?e:e.replace(/[\u001b\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g,""),It=null,Eo=!1,bo=e=>{try{It&&(Eo&&typeof It.write=="function"?It.write(e):It.stdin&&It.stdin.writable&&It.stdin.write(e))}catch{}},Ji=()=>{if(It){try{Eo&&typeof It.destroy=="function"?It.destroy():typeof It.kill=="function"&&(process.platform==="win32"?Ls("taskkill",["/pid",It.pid,"/f","/t"]):It.kill("SIGKILL"))}catch{}It=null,Eo=!1}},Qi=(e,o=!1)=>{if(process.platform!=="win32")return e;let t=[],n="",i=null,r=!1;for(let d=0;d<e.length;d++){let a=e[d];if(r){n+=a,r=!1;continue}if(a==="\\"){if(e[d+1]===" "){n+=" ",d++;continue}n+=a,r=!0;continue}i?(a===i&&(i=null),n+=a):a==='"'||a==="'"?(i=a,n+=a):a===";"&&!n.includes("://")?(n.length>0&&(t.push(n),n=""),t.push(o?";":"&")):a==="|"&&!n.includes("://")?(n.length>0&&(t.push(n),n=""),t.push("|")):/\s/.test(a)?n.length>0&&(t.push(n),n=""):n+=a}n.length>0&&t.push(n);let l=d=>!(!d.includes("/")||/^(https?|file|ftp):\/\//i.test(d)||d.startsWith("/")&&(d.match(/\//g)||[]).length===1||/\s\/|\/\s/.test(d)||/[\(\)\{\}\;\<\>\=\'\"]/.test(d)),c=[];for(let d=0;d<t.length;d++){let a=t[d];if(a==="mkdir"&&o&&Qn()){let m=[],p=d+1;for(;p<t.length;){let h=t[p];if([">",">>","<","&","&&","|","||",";"].includes(h))break;h!=="-p"&&h!=="--parents"&&h!=="-v"&&h!=="--verbose"&&m.push(h),p++}if(m.length>0){let h=m.map(S=>{let T=S.replace(/^['"]|['"]$/g,""),w=S;return l(T)&&(w=S.replace(/\//g,"\\")),w});c.push("New-Item","-ItemType","Directory","-Force","-Path",h.join(","))}else c.push("New-Item","-ItemType","Directory","-Force");d=p-1;continue}if(a==="rm"&&o&&Qn()){let m=[],p=!1,h=!1,S=d+1;for(;S<t.length;){let w=t[S];if([">",">>","<","&","&&","|","||",";"].includes(w))break;w==="-rf"||w==="-fr"?(p=!0,h=!0):w==="-r"||w==="-R"||w==="--recursive"?p=!0:w==="-f"||w==="--force"?h=!0:m.push(w),S++}let T=["Remove-Item"];if(p&&T.push("-Recurse"),h&&T.push("-Force"),m.length>0){let w=m.map(I=>{let $=I.replace(/^['"]|['"]$/g,""),U=I;return l($)&&(U=I.replace(/\//g,"\\")),U});T.push("-Path",w.join(","))}c.push(...T),d=S-1;continue}if(a==="cp"&&o&&Qn()){let m=[],p=!1,h=!1,S=d+1;for(;S<t.length;){let w=t[S];if([">",">>","<","&","&&","|","||",";"].includes(w))break;w==="-r"||w==="-R"||w==="--recursive"?p=!0:w==="-f"||w==="--force"?h=!0:m.push(w),S++}let T=["Copy-Item"];if(p&&T.push("-Recurse"),h&&T.push("-Force"),m.length>0){let w=m.map(I=>{let $=I.replace(/^['"]|['"]$/g,""),U=I;return l($)&&(U=I.replace(/\//g,"\\")),U});if(w.length>1){let I=w.pop();T.push("-Path",w.join(","),"-Destination",I)}else T.push("-Path",w[0])}c.push(...T),d=S-1;continue}if(a==="touch"&&o&&Qn()){let m=[],p=d+1;for(;p<t.length;){let h=t[p];if([">",">>","<","&","&&","|","||",";"].includes(h))break;m.push(h),p++}if(m.length>0){let S=`(${m.map(T=>{let w=T.replace(/^['"]|['"]$/g,""),I=T;return l(w)&&(I=T.replace(/\//g,"\\")),I}).join(", ")}) | ForEach-Object { if (Test-Path $_) { (Get-Item $_).LastWriteTime = [System.DateTime]::Now } else { $null | Out-File -FilePath $_ } }`;c.push(S)}d=p-1;continue}if(a==="|"&&t[d+1]==="tee"){t[d+2]==="-a"?(c.push(">>"),d+=2):(c.push(">"),d+=1);continue}if(a==="|"&&t[d+1]==="cat"&&t[d+2]===">"){c.push(">"),d+=2;continue}if(a==="|"){let m=t[d+1];if(m){let p=m.replace(/^['"]|['"]$/g,""),h=/\.(txt|md|json|log|csv|html|css|py|js|xml|yaml|yml|pdf|docx|pptx|xlsx)$/i.test(p);if(l(p)&&h){c.push(">");continue}}}c.push(a)}let f=!1;return c.map(d=>{if(d==="echo")return f=!0,d;[">",">>","<","&","&&","|","||",";"].includes(d)&&(f=!1);let m=/^['"]|['"]$/.test(d),p=d;f&&m&&(p=d.replace(/^['"]|['"]$/g,""));let h=/^['"]|['"]$/.test(p),S=p.replace(/^['"]|['"]$/g,"");l(S)&&(p=p.replace(/\//g,"\\"));let T=p.replace(/^['"]|['"]$/g,"");return T.includes(" ")&&!h&&(p=`"${T}"`),p}).join(" ")},vs=async(e,o={})=>{let{command:t}=ne(e),{onChunk:n}=o;if(!t)return'ERROR: Missing "command" argument for exec_command.';let i=process.platform==="win32",r=o.systemSettings||{},l={};return r.networkAccess===!1&&(l.HTTP_PROXY="http://127.0.0.1:9999",l.HTTPS_PROXY="http://127.0.0.1:9999",l.ALL_PROXY="socks5://127.0.0.1:9999",l.http_proxy="http://127.0.0.1:9999",l.https_proxy="http://127.0.0.1:9999",l.all_proxy="socks5://127.0.0.1:9999",l.NO_PROXY="localhost,127.0.0.1"),new Promise(c=>{let f=u=>{let d=Qi(t,u),a=i?u?"powershell.exe":"cmd.exe":process.env.SHELL||"bash",m=i?u?["-NoProfile","-Command",d]:["/c",d]:["-c",d];if(Xr)try{let p=Xr.spawn(a,m,{name:"xterm-256color",cols:o.cols||120,rows:o.rows||30,cwd:process.cwd(),env:{...process.env,CI:"false",TERM:"xterm-256color",FORCE_COLOR:"1",...l}});It=p,Eo=!0;let h="",S=!1;return p.onData(T=>{if(!S){h+=T,n&&n(T);let w=Kr(h);/(?:Network:\s+use\s+--host\s+to|Network:\s+Type\s+--host\s+to|Local:\s+http:\/\/localhost:\d+|ready in \d+\s*ms|Compiled successfully|Development server is running|Listening on:)/i.test(w)&&(S=!0,setTimeout(()=>c(`SUCCESS: Dev server started successfully in background.
|
|
96
93
|
|
|
97
|
-
${
|
|
94
|
+
${w}`),500))}}),p.onExit(({exitCode:T})=>{if(S)return;It=null;let w=(h||"").replace(/\r\n/g,`
|
|
98
95
|
`).replace(/\r/g,`
|
|
99
|
-
`),
|
|
96
|
+
`),I=Kr(w).replace(/\n{3,}/g,`
|
|
100
97
|
|
|
101
|
-
`)||"Command executed with no output.";c(
|
|
98
|
+
`)||"Command executed with no output.";c(T!==0?`ERROR: Command [${t}] failed with exit code [${T}].
|
|
102
99
|
|
|
103
|
-
${
|
|
100
|
+
${I}`:`SUCCESS: Command [${t}] completed.
|
|
104
101
|
|
|
105
|
-
${
|
|
102
|
+
${I}`)}),!0}catch(p){return i&&u&&p.code==="ENOENT"?!1:(Ds(c,d,t,l,n,u),!0)}else return Ds(c,d,t,l,n,u),!0};i&&f(!0)||f(!1)})},Ds=(e,o,t,n,i,r=!0)=>{let l=process.platform==="win32",c=l?r?"powershell.exe":"cmd.exe":process.env.SHELL||"bash",u=l?Ls(c,l?r?["-NoProfile","-Command",o]:["/c",o]:["-c",o],{cwd:process.cwd(),env:{...process.env,...n}}):Ls(o,{shell:!0,cwd:process.cwd(),env:{...process.env,CI:"false",TERM:"xterm-256color",FORCE_COLOR:"1",...n}});It=u,Eo=!1,u.stdin&&u.stdin.on("error",()=>{It=null});let d="",a="",m=!1;u.stdout.on("data",p=>{if(!m){let h=p.toString();d+=h,i&&i(h);let S=Kr(d);/(?:Network:\s+use\s+--host\s+to|Network:\s+Type\s+--host\s+to|Local:\s+http:\/\/localhost:\d+|ready in \d+\s*ms|Compiled successfully|Development server is running|Listening on:)/i.test(S)&&(m=!0,setTimeout(()=>e(`SUCCESS: Dev server started successfully in background.
|
|
106
103
|
|
|
107
|
-
${
|
|
108
|
-
${
|
|
109
|
-
${a}`),p!==0&&h.push(`EXIT CODE: ${p}`);let
|
|
104
|
+
${S}`),500))}}),u.stderr.on("data",p=>{if(!m){let h=p.toString();a+=h,i&&i(h)}}),u.on("close",p=>{if(m)return;It=null;let h=[];d&&h.push(`STDOUT:
|
|
105
|
+
${d}`),a&&h.push(`STDERR:
|
|
106
|
+
${a}`),p!==0&&h.push(`EXIT CODE: ${p}`);let S=h.join(`
|
|
110
107
|
|
|
111
|
-
`)||"Command executed with no output.",
|
|
108
|
+
`)||"Command executed with no output.",T=Kr(S).replace(/\n{3,}/g,`
|
|
112
109
|
|
|
113
110
|
`);e(p!==0?`ERROR: Command [${t}] failed with exit code [${p}].
|
|
114
111
|
|
|
115
|
-
${
|
|
112
|
+
${T}`:`SUCCESS: Command [${t}] completed.
|
|
116
113
|
|
|
117
|
-
${w}`)}),d.on("error",p=>{if(l&&r&&p.code==="ENOENT"){let h=qi(t,!1);return As(e,h,t,n,i,!1)}Ct=null,e(`ERROR: Failed to start command [${t}]: ${p.message}`)})}});import Te,{useState as yr}from"react";import{Box as At,Text as Rt,useInput as Jl}from"ink";import Ql from"ink-text-input";function vs({systemSettings:e,setSystemSettings:o,apiTier:t,setActiveView:n,setInputConfig:i,saveSettings:r,quotas:l,setMessages:c,aiProvider:m}){let[d,u]=yr("categories"),[a,f]=yr(0),[p,h]=yr(0),[T,w]=yr(null),[E,k]=yr(""),D=I=>{switch(I){case"memory":return[{label:"Toggle Memory",value:"memory",status:e.memory?"ON":"OFF"}];case"security":return[{label:"Sandbox Preset",value:"sandboxPreset",status:Vi(e),section:"Sandbox"},{label:"YOLO Mode",value:"autoExec",status:e.autoExec?"ON":"OFF",section:"Sandbox"},{label:"External Workspace Access",value:"externalAccess",status:e.allowExternalAccess?"ON":"OFF",section:"Sandbox"},{label:"Network Access (Terminal)",value:"networkAccess",status:e.networkAccess!==!1?"ON":"OFF",section:"Sandbox"},{label:"Always Ask Commands",value:"alwaysAsk",status:Ds(e.alwaysAskCommands),section:"Sandbox"},{label:"Auto Approve Commands",value:"autoApprove",status:Ds(e.autoApproveCommands),section:"Sandbox"},{label:"Auto Disapprove Commands",value:"autoDisallow",status:Ds(e.autoDisallowCommands),section:"Sandbox"},{label:"Auto Approve Git Commits",value:"autoApproveGit",status:e.autoApproveGit?"ON":"OFF",section:"Sandbox"},{label:"Auto-Delete History",value:"autoDelete",status:e.autoDeleteHistory||"30d",section:"Other"},{label:"Save AppData Externally",value:"externalData",status:e.useExternalData?"ON":"OFF",section:"Other"}];case"updater":return[{label:"Auto-Update",value:"autoUpdate",status:e.autoUpdate?"ON":"OFF"},{label:"Preferred Updater",value:"updateManager",status:(e.updateManager||"npm")==="custom"?"Custom":(e.updateManager||"npm").toUpperCase()}];case"other":return[{label:"Current Provider",value:"aiProvider",status:m},{label:"API Tier",value:"apiTier",status:t}];default:return[]}},_=on[a].id,K=D(_);Jl((I,A)=>{if(T){A.escape&&w(null);return}if(d==="categories")A.upArrow?f(v=>(v-1+on.length)%on.length):A.downArrow?f(v=>(v+1)%on.length):A.return||A.rightArrow?on[a].id==="exit"?n("chat"):(u("items"),h(0)):A.escape&&n("chat");else if(d==="items"){if(A.upArrow)h(v=>(v-1+K.length)%K.length);else if(A.downArrow)h(v=>(v+1)%K.length);else if(A.leftArrow||A.escape)u("categories");else if(A.return){let v=K[p];F(v)}}});let F=I=>{if(I.value==="memory")o(A=>({...A,memory:!A.memory}));else if(I.value==="sandboxPreset"){let A=Vi(e),v=["Autonomous","Balanced","Strict"],q=(v.indexOf(A)+1)%v.length,le=v[q];o(U=>{let G={...U,sandboxPreset:le};return le==="Strict"?(G.autoExec=!1,G.allowExternalAccess=!1,G.networkAccess=!1,G.autoApproveCommands="",G.autoDisallowCommands="rm -rf, rm -f, del /f, del /q, rd /s, rmdir /s, format, mkfs, dd if=/dev, shred, srm, Remove-Item -Recurse -Force, Initialize-Disk, Clear-Disk, format c:, flashrom, nvram -c",G.alwaysAskCommands="killall, pkill, taskkill, shutdown, reboot, init 0, init 6, Stop-Process, Stop-Service, mv /*, move c:\\*, chmod 000, chmod -R 777, chown, icacls, netsh advfirewall, iptables -F, ufw disable, git reset --hard, git clean -fd, npm r, npm uninstall",G.autoApproveGit=!1):le==="Balanced"?(G.autoExec=!0,G.allowExternalAccess=!1,G.networkAccess=!0,G.autoApproveCommands="ls, dir, cat, type, echo, pwd, cd, git status, git log, git diff, git branch, git show, help, mkdir, touch, md, whoami, hostname, ps, Get-Process, date, time",G.autoDisallowCommands="rm -rf, rm -f, del /f, del /q, rd /s, rmdir /s, format, mkfs, dd if=/dev, shred, srm, Remove-Item -Recurse -Force, Initialize-Disk, Clear-Disk, format c:, flashrom, nvram -c",G.alwaysAskCommands="killall, pkill, taskkill, Stop-Process, mv /*, move c:\\*, chmod 000, chmod -R 777, chown, icacls, shutdown, reboot, init 0, init 6, git reset --hard, git clean -fd, npm r, npm uninstall",G.autoApproveGit=!1):le==="Autonomous"&&(G.autoExec=!0,G.allowExternalAccess=!0,G.networkAccess=!0,G.autoApproveCommands="",G.autoDisallowCommands="",G.alwaysAskCommands="rm -rf, rm -f, del /f, del /q, rd /s, rmdir /s, format, mkfs, dd if=/dev, shred, srm, Remove-Item -Recurse -Force, Initialize-Disk, Clear-Disk, format c:, flashrom, nvram -c",G.autoApproveGit=!0),G})}else if(I.value==="autoExec")e.autoExec?o(A=>({...A,autoExec:!1,sandboxPreset:"Custom"})):e.allowExternalAccess?n("doubleDanger"):n("autoExecDanger");else if(I.value==="externalAccess")e.allowExternalAccess?o(A=>({...A,allowExternalAccess:!1,sandboxPreset:"Custom"})):e.autoExec?n("doubleDanger"):n("externalDanger");else if(I.value==="networkAccess")o(A=>({...A,networkAccess:A.networkAccess===!1,sandboxPreset:"Custom"}));else if(I.value==="alwaysAsk")w("alwaysAskCommands"),k(e.alwaysAskCommands||"");else if(I.value==="autoApprove")w("autoApproveCommands"),k(e.autoApproveCommands||"");else if(I.value==="autoApproveGit")o(A=>({...A,autoApproveGit:!A.autoApproveGit,sandboxPreset:"Custom"}));else if(I.value==="autoDisallow")w("autoDisallowCommands"),k(e.autoDisallowCommands||"");else if(I.value==="apiTier")n("apiTier");else if(I.value==="aiProvider")n("selectProvider");else if(I.value==="autoDelete"){let A=["1d","7d","30d"],J=(A.indexOf(e.autoDeleteHistory||"30d")+1)%A.length;o(q=>({...q,autoDeleteHistory:A[J]}))}else if(I.value==="autoUpdate")o(A=>({...A,autoUpdate:!A.autoUpdate}));else if(I.value==="externalData")if(!e.useExternalData)i({label:"Enter absolute path for External AppData:",note:"All history, logs and secrets will be stored here. ~/.fluxflow/settings.json stays as anchor.",key:"externalDataPath",value:e.externalDataPath||""}),n("input");else{let A={...e,useExternalData:!1};o(A),r({systemSettings:A,apiTier:t,quotas:l}),c(v=>[...v,{id:Date.now(),role:"system",text:"\u{1F3E0} [STORAGE RESET] Flux Flow will return to default ~/.fluxflow after restart."}]),n("chat")}else I.value==="updateManager"&&n("updateManager")};return Te.createElement(At,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},Te.createElement(At,{paddingX:1,paddingY:0,marginBottom:1,borderStyle:"single",borderColor:"magenta",width:"100%"},Te.createElement(Rt,{color:"magenta",bold:!0},"\u{1F527} SYSTEM CONFIGURATION")),Te.createElement(At,{flexDirection:"row",width:"100%",minHeight:8},Te.createElement(At,{flexDirection:"column",width:"30%",borderStyle:"round",borderColor:d==="categories"?"cyan":"gray",padding:1},Te.createElement(At,{marginBottom:1},Te.createElement(Rt,{color:d==="categories"?"cyan":"white",bold:!0,underline:!0},"CATEGORIES")),on.map((I,A)=>{let v=a===A,J=I.id==="exit";return Te.createElement(At,{key:I.id,marginTop:J?1:0,backgroundColor:v?d==="categories"?"#2a2a2a":"#1e1e1e":void 0,paddingX:1},Te.createElement(Rt,{color:v?d==="categories"?"cyan":"yellow":"white",bold:v},v?"\u276F ":" ",I.label))})),Te.createElement(At,{flexDirection:"column",width:"70%",borderStyle:"round",borderColor:d==="items"?"cyan":"gray",padding:1,marginLeft:1},Te.createElement(At,{marginBottom:1},Te.createElement(Rt,{color:d==="items"?"cyan":"white",bold:!0,underline:!0},on[a].label.toUpperCase()," SETTINGS")),K.length>0?(()=>{let I=null,A=[],v=ce=>(ce||"").split(",").map(De=>De.trim().toLowerCase()).filter(Boolean),J=v(e.autoApproveCommands),q=v(e.autoDisallowCommands),le=v(e.alwaysAskCommands),U=[...J,...q,...le],G=new Set(U),Pe=_==="security"&&U.length!==G.size;return K.forEach((ce,De)=>{let nt=d==="items"&&p===De,pe=ce.label.length,ut=Math.max(2,35-pe),Ve=".".repeat(ut),ze=fe=>_==="security"?(fe.value==="autoExec"||fe.value==="externalAccess")&&fe.status==="ON"?"red":"yellow":fe.status?.startsWith("\u2713")?"green":fe.status?.startsWith("\u26A0")?"yellow":fe.status==="ON"?"green":fe.status==="OFF"?"red":"yellow";ce.section&&ce.section!==I&&(I=ce.section,A.push(Te.createElement(At,{key:`sec-hdr-${ce.section}`,marginTop:A.length>0?1:0,marginBottom:0,paddingX:1},Te.createElement(Rt,{color:"magenta",bold:!0,underline:!0},"\u{1F4C2} ",ce.section.toUpperCase()))));let _e=nt&&T&&(T==="alwaysAskCommands"&&ce.value==="alwaysAsk"||T==="autoApproveCommands"&&ce.value==="autoApprove"||T==="autoDisallowCommands"&&ce.value==="autoDisallow"),Je=ce.value==="alwaysAsk"||ce.value==="autoApprove"||ce.value==="autoDisallow";A.push(Te.createElement(At,{key:ce.value,flexDirection:"column"},Te.createElement(At,{backgroundColor:nt&&!_e?"#2a2a2a":void 0,paddingX:2},Te.createElement(Rt,{color:nt?"cyan":"white",bold:nt},nt?"\u276F ":" ",ce.label),!Je&&Te.createElement(Te.Fragment,null,Te.createElement(Rt,{color:"gray",dimColor:!0},Ve),Te.createElement(Rt,{color:ze(ce),bold:!0},ce.value==="aiProvider"?ce.status:`[ ${ce.status} ]`))),Je&&!_e&&ce.status!=="None"&&Te.createElement(At,{paddingX:4,marginBottom:1},Te.createElement(Rt,{color:"gray",dimColor:!0},"\u21B3 ",ce.status)),_e&&Te.createElement(At,{flexDirection:"column",marginLeft:4,marginBottom:1},Te.createElement(At,{paddingX:1,borderStyle:"single",borderColor:"cyan",flexDirection:"row"},Te.createElement(Rt,{color:"cyan",bold:!0},"> "," "),Te.createElement(Ql,{value:E,onChange:k,onSubmit:fe=>{let ho={...e,[T]:fe.trim(),sandboxPreset:"Custom"};o(ho),r({systemSettings:ho,apiTier:t,quotas:l}),w(null)}})),Te.createElement(Rt,{color:"gray",dimColor:!0,italic:!0}," Comma separated \u2022 Press Enter to save, Esc to cancel"))))}),_==="other"&&A.push(Te.createElement(At,{key:"pty-notice",marginTop:4,paddingX:1},Te.createElement(Rt,{color:Fn?"green":"yellow"},Fn?"\u2713 Advance Interactive Terminal Supported":"\u26A0 Interactive Terminal is Limited"))),Pe&&A.push(Te.createElement(At,{key:"conflict-warning",marginTop:1,paddingX:1},Te.createElement(Rt,{color:"red",dimColor:!0,italic:!0},"* Conflicting commands will be ignored and defaulted to highest priority"))),A})():Te.createElement(At,{paddingX:1},Te.createElement(Rt,{color:"gray",italic:!0},on[a].desc)))),Te.createElement(At,{paddingX:1,marginTop:1,flexDirection:"row",justifyContent:"space-between"},Te.createElement(Rt,{color:"gray",dimColor:!0,italic:!0},d==="categories"?"\u25B2\u25BC Select Category \u2022 Enter/\u25BA to configure":"\u25B2\u25BC Select Option \u2022 Enter to Toggle \u2022 \u25C4/ESC to go back"),d==="categories"&&Te.createElement(Rt,{color:"gray",dimColor:!0},on[a].desc)))}var on,Vi,Ds,zi=ie(async()=>{await xr();on=[{id:"memory",label:"\u{1F9E0} Memory",desc:"Manage system context & agent's memory"},{id:"security",label:"\u{1F512} Security",desc:"Configure permissions & data safety"},{id:"updater",label:"\u{1F504} Updater",desc:"Manage application updates"},{id:"other",label:"\u{1F4CB} Other",desc:"Miscellaneous preferences"},{id:"exit",label:"\u{1F6AA} Exit Settings",desc:"Return to chat view"}],Vi=e=>{let o=e.autoApproveCommands||"",t=e.autoDisallowCommands||"",n=e.alwaysAskCommands||"",i=e.autoExec===!1&&e.allowExternalAccess===!1&&e.networkAccess===!1&&o===""&&t==="rm -rf, rm -f, del /f, del /q, rd /s, rmdir /s, format, mkfs, dd if=/dev, shred, srm, Remove-Item -Recurse -Force, Initialize-Disk, Clear-Disk, format c:, flashrom, nvram -c"&&n==="killall, pkill, taskkill, shutdown, reboot, init 0, init 6, Stop-Process, Stop-Service, mv /*, move c:\\*, chmod 000, chmod -R 777, chown, icacls, netsh advfirewall, iptables -F, ufw disable, git reset --hard, git clean -fd, npm r, npm uninstall"&&e.autoApproveGit===!1,r=e.autoExec===!0&&e.allowExternalAccess===!1&&e.networkAccess!==!1&&o==="ls, dir, cat, type, echo, pwd, cd, git status, git log, git diff, git branch, git show, help, mkdir, touch, md, whoami, hostname, ps, Get-Process, date, time"&&t==="rm -rf, rm -f, del /f, del /q, rd /s, rmdir /s, format, mkfs, dd if=/dev, shred, srm, Remove-Item -Recurse -Force, Initialize-Disk, Clear-Disk, format c:, flashrom, nvram -c"&&n==="killall, pkill, taskkill, Stop-Process, mv /*, move c:\\*, chmod 000, chmod -R 777, chown, icacls, shutdown, reboot, init 0, init 6, git reset --hard, git clean -fd, npm r, npm uninstall"&&e.autoApproveGit===!1,l=e.autoExec===!0&&e.allowExternalAccess===!0&&e.networkAccess!==!1&&o===""&&t===""&&n==="rm -rf, rm -f, del /f, del /q, rd /s, rmdir /s, format, mkfs, dd if=/dev, shred, srm, Remove-Item -Recurse -Force, Initialize-Disk, Clear-Disk, format c:, flashrom, nvram -c"&&e.autoApproveGit===!0;return i?"Strict":r?"Balanced":l?"Autonomous":e.sandboxPreset||"Custom"},Ds=e=>!e||e.trim()===""?"None":e.length>40?e.substring(0,40)+"...":e});import Do,{useState as $s,useEffect as Zl}from"react";import{Box as qn,Text as Gr}from"ink";import ec from"ink-text-input";function Ps({initialData:e,onSave:o,onCancel:t}){let[n,i]=$s(0),[r,l]=$s(""),[c,m]=$s(()=>({name:e?.name||"",nickname:e?.nickname||"",instructions:e?.instructions||""})),d=[{key:"name",label:"Enter your Name: "},{key:"nickname",label:"Enter a Nickname (Agent will use this): "},{key:"instructions",label:"System Instructions (Persona overrides): "}];Zl(()=>{let a=d[n].key;l(c[a]||"")},[n,c]);let u=a=>{if(a.trim().toLowerCase()==="/cancel"){t();return}let f=d[n].key,p={...c,[f]:a.trim()};m(p),l(""),n<d.length-1?i(n+1):o(p)};return Do.createElement(qn,{borderStyle:"round",borderColor:"gray",padding:0,marginTop:1,flexShrink:0,flexDirection:"column",width:"100%"},Do.createElement(qn,{paddingX:1,marginBottom:1},Do.createElement(Gr,{color:"magenta",bold:!0},"\u{1F464} DEVELOPER PROFILE CONFIGURATION")),Do.createElement(qn,{paddingX:1,flexDirection:"column"},Do.createElement(qn,null,Do.createElement(Gr,{color:"cyan",bold:!0},d[n].label),Do.createElement(ec,{value:r,onChange:l,onSubmit:u})),Do.createElement(qn,{marginTop:1},Do.createElement(Gr,{color:"gray",dimColor:!0,italic:!0},"Step ",n+1," of ",d.length))),Do.createElement(qn,{paddingX:1,marginTop:1},Do.createElement(Gr,{color:"gray",dimColor:!0,italic:!0},"(Enter to submit \u2022 Type /cancel to abort)")))}var Ji=ie(()=>{});import dt,{useState as Fs}from"react";import{Box as bo,Text as nn,useInput as tc}from"ink";import oc from"ink-text-input";var nc,Qi,Zi=ie(()=>{hn();nc=({question:e,options:o,onResolve:t})=>{let[n,i]=Fs(!1),[r,l]=Fs(""),[c,m]=Fs(0),d=[...o,{id:"CUSTOM",label:"Suggest something else...",description:"Provide a custom response"}];tc((a,f)=>{if(!n&&((f.leftArrow||f.upArrow)&&m(p=>Math.max(0,p-1)),(f.rightArrow||f.downArrow)&&m(p=>Math.min(d.length-1,p+1)),f.return)){let p=d[c];p.id==="CUSTOM"?i(!0):t(p.label)}});let u=Ce(2);return n?dt.createElement(bo,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},dt.createElement(bo,{paddingX:1},dt.createElement(nn,{color:"cyan",bold:!0},"\u{1F4AC} SUGGEST SOMETHING ELSE")),dt.createElement(bo,{marginTop:1,paddingX:1},dt.createElement(nn,{italic:!0,color:"gray"},"Replying to: ",e)),dt.createElement(bo,{marginTop:1,paddingX:1,flexDirection:"row"},dt.createElement(nn,{color:"cyan",bold:!0},"\u{1F4A0} "),dt.createElement(oc,{value:r,onChange:l,onSubmit:()=>t(r)})),dt.createElement(bo,{marginTop:1,paddingX:1,marginBottom:1},dt.createElement(nn,{color:"gray",dimColor:!0,italic:!0},"(Press Enter to send)"))):dt.createElement(bo,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},dt.createElement(bo,{paddingX:1,marginBottom:1},dt.createElement(nn,{color:"cyan",bold:!0},"\u{1F4AC} AGENT REQUEST: ACTION REQUIRED")),dt.createElement(bo,{paddingX:1,marginBottom:1},dt.createElement(nn,{bold:!0,color:"white"},e)),dt.createElement(bo,{flexDirection:"column",width:"100%"},d.map((a,f)=>{let p=f===c;return dt.createElement(bo,{key:a.id,flexDirection:"column",width:"100%",backgroundColor:p?"#2a2a2a":void 0,paddingX:1,marginBottom:f===d.length-1?0:1},dt.createElement(nn,{color:p?"cyan":"white",bold:p},p?"\u276F ":" ",a.label),a.description&&dt.createElement(bo,{marginLeft:4},dt.createElement(nn,{color:"gray",italic:!0,dimColor:!0},a.description)))})),dt.createElement(bo,{paddingX:1,marginTop:1,marginBottom:1},dt.createElement(nn,{color:"gray",dimColor:!0,italic:!0},"(Use Arrows to navigate, Enter to confirm)")))},Qi=nc});import wr from"fs";import Bs from"path";import Xr from"crypto";var rc,sc,ea,ta,Tr,xn,we,ke,Kr,qr,vo=ie(()=>{rc=66,sc=e=>{let o=Buffer.isBuffer(e)?e:Buffer.from(e),t=Buffer.alloc(o.length);for(let n=0;n<o.length;n++)t[n]=o[n]^rc;return t},ea="aes-256-cbc",ta=Xr.createHash("sha256").update("fluxflow-cli-sanctuary-key").digest(),Tr=e=>{let o=Xr.randomBytes(16),t=Xr.createCipheriv(ea,ta,o),n=t.update(e,"utf8","hex");return n+=t.final("hex"),o.toString("hex")+":"+n},xn=e=>{let o=e.split(":");if(o.length!==2)throw new Error("Invalid AES format");let t=Buffer.from(o[0],"hex"),n=o[1],i=Xr.createDecipheriv(ea,ta,t),r=i.update(n,"hex","utf8");return r+=i.final("utf8"),r},we=(e,o={})=>{try{if(!wr.existsSync(e))return o;let t=wr.readFileSync(e),n=t.toString("utf8").trim();if(n.startsWith("{")||n.startsWith("["))return JSON.parse(n);try{let r=xn(n);return JSON.parse(r)}catch{}let i=sc(t).toString("utf8");if(i.startsWith("{")||i.startsWith("["))return JSON.parse(i);throw new Error("Unsupported or corrupt encryption format")}catch(t){return console.error(`Vault Read Error [${Bs.basename(e)}]:`,t.message),o}},ke=(e,o)=>{try{let t=Bs.dirname(e);wr.existsSync(t)||wr.mkdirSync(t,{recursive:!0});let n=JSON.stringify(o,null,2),i=Tr(n);wr.writeFileSync(e,i,"utf8")}catch(t){console.error(`Vault Write Error [${Bs.basename(e)}]:`,t.message)}},Kr=we,qr=ke});var sa={};Ss(sa,{BACKUPS_DIR:()=>yn,DATA_DIR:()=>Vr,FLUXFLOW_DIR:()=>Bn,HISTORY_FILE:()=>_n,LEDGER_FILE:()=>rn,LOGS_DIR:()=>ko,MEMORIES_FILE:()=>Ft,PATHS_FILE:()=>zr,SECRET_DIR:()=>eo,SETTINGS_FILE:()=>Zt,TEMP_MEM_CHAT_FILE:()=>_o,TEMP_MEM_FILE:()=>mo,USAGE_FILE:()=>Wt});import ic from"os";import Co from"path";import oa from"fs";import na from"crypto";var Bn,Zt,ra,Vr,ko,eo,_n,Wt,Ft,mo,_o,yn,rn,zr,to=ie(()=>{Bn=Co.join(ic.homedir(),".fluxflow"),Zt=Co.join(Bn,"settings.json"),ra=null;try{if(oa.existsSync(Zt)){let e=oa.readFileSync(Zt,"utf8").trim(),o;if(e.startsWith("{"))o=JSON.parse(e);else{let t=e.split(":");if(t.length===2){let n=Buffer.from(t[0],"hex"),i=t[1],r=na.createHash("sha256").update("fluxflow-cli-sanctuary-key").digest(),l=na.createDecipheriv("aes-256-cbc",r,n),c=l.update(i,"hex","utf8");c+=l.final("utf8"),o=JSON.parse(c)}}if(o){let t=o.systemSettings||{};t.useExternalData&&t.externalDataPath&&(ra=t.externalDataPath)}}}catch{}Vr=ra||Bn,ko=Co.join(Vr,"logs"),eo=Co.join(Vr,"secret"),_n=Co.join(eo,"history.json"),Wt=Co.join(Bn,"usage.json"),Ft=Co.join(eo,"memories.json"),mo=Co.join(eo,"memory-temp.json"),_o=Co.join(eo,"temp-memory-chat.json"),yn=Co.join(Vr,"backups"),rn=Co.join(eo,"ledger.json"),zr=Co.join(eo,"path.json")});var Zr={};Ss(Zr,{getAPIKey:()=>cc,getProviderAPIKey:()=>Jr,getSearchSecrets:()=>uc,getSecret:()=>dc,removeAPIKey:()=>_s,removeSecret:()=>ia,saveAPIKey:()=>mc,saveProviderAPIKey:()=>Qr,saveSearchId:()=>pc,saveSearchKey:()=>fc,saveSecret:()=>wn});import ac from"fs-extra";import lc from"path";var Tn,cc,Jr,Qr,dc,wn,uc,mc,fc,pc,ia,_s,Sr=ie(()=>{vo();to();Tn=lc.join(eo,"secrets.json"),cc=async()=>{try{let e=we(Tn,{});if(e.API_KEY)return e.API_KEY}catch{}return null},Jr=async e=>{try{let o=we(Tn,{});if(e==="Google")return o.GOOGLE_API_KEY||o.API_KEY||null;if(e==="DeepSeek")return o.DEEPSEEK_API_KEY||null;if(e==="OpenRouter")return o.OPENROUTER_API_KEY||null}catch{}return null},Qr=async(e,o)=>{e==="Google"?(await wn("GOOGLE_API_KEY",o),await wn("API_KEY",o)):e==="DeepSeek"?await wn("DEEPSEEK_API_KEY",o):e==="OpenRouter"&&await wn("OPENROUTER_API_KEY",o)},dc=async e=>{try{return we(Tn,{})[e]||null}catch{return null}},wn=async(e,o)=>{await ac.ensureDir(eo);let t=we(Tn,{});t[e]=o,ke(Tn,t)},uc=async()=>{try{let e=we(Tn,{});return{key:e.GOOGLE_API_KEY||e.API_KEY,cx:e.SEARCH_ID}}catch{}return{key:null,cx:null}},mc=async e=>wn("API_KEY",e),fc=async e=>wn("GOOGLE_API_KEY",e),pc=async e=>wn("SEARCH_ID",e),ia=async e=>{try{let o=we(Tn,{});delete o[e],ke(Tn,o)}catch{}},_s=async()=>ia("API_KEY")});var aa,la=ie(()=>{aa=(e=!0,o=!0)=>`
|
|
114
|
+
${T}`)}),u.on("error",p=>{if(l&&r&&p.code==="ENOENT"){let h=Qi(t,!1);return Ds(e,h,t,n,i,!1)}It=null,e(`ERROR: Failed to start command [${t}]: ${p.message}`)})}});import we,{useState as xr}from"react";import{Box as Ot,Text as Rt,useInput as tc}from"ink";import oc from"ink-text-input";function Fs({systemSettings:e,setSystemSettings:o,apiTier:t,setActiveView:n,setInputConfig:i,saveSettings:r,quotas:l,setMessages:c,aiProvider:f}){let[u,d]=xr("categories"),[a,m]=xr(0),[p,h]=xr(0),[S,T]=xr(null),[w,I]=xr(""),$=k=>{switch(k){case"memory":return[{label:"Toggle Memory",value:"memory",status:e.memory?"ON":"OFF"}];case"security":return[{label:"Sandbox Preset",value:"sandboxPreset",status:Zi(e),section:"Sandbox"},{label:"YOLO Mode",value:"autoExec",status:e.autoExec?"ON":"OFF",section:"Sandbox"},{label:"External Workspace Access",value:"externalAccess",status:e.allowExternalAccess?"ON":"OFF",section:"Sandbox"},{label:"Network Access (Terminal)",value:"networkAccess",status:e.networkAccess!==!1?"ON":"OFF",section:"Sandbox"},{label:"Always Ask Commands",value:"alwaysAsk",status:$s(e.alwaysAskCommands),section:"Sandbox"},{label:"Auto Approve Commands",value:"autoApprove",status:$s(e.autoApproveCommands),section:"Sandbox"},{label:"Auto Disapprove Commands",value:"autoDisallow",status:$s(e.autoDisallowCommands),section:"Sandbox"},{label:"Auto Approve Git Commits",value:"autoApproveGit",status:e.autoApproveGit?"ON":"OFF",section:"Sandbox"},{label:"Auto-Delete History",value:"autoDelete",status:e.autoDeleteHistory||"30d",section:"Other"},{label:"Save AppData Externally",value:"externalData",status:e.useExternalData?"ON":"OFF",section:"Other"}];case"updater":return[{label:"Auto-Update",value:"autoUpdate",status:e.autoUpdate?"ON":"OFF"},{label:"Preferred Updater",value:"updateManager",status:(e.updateManager||"npm")==="custom"?"Custom":(e.updateManager||"npm").toUpperCase()}];case"other":return[{label:"Current Provider",value:"aiProvider",status:f},{label:"API Tier",value:"apiTier",status:t}];default:return[]}},U=on[a].id,K=$(U);tc((k,O)=>{if(S){O.escape&&T(null);return}if(u==="categories")O.upArrow?m(D=>(D-1+on.length)%on.length):O.downArrow?m(D=>(D+1)%on.length):O.return||O.rightArrow?on[a].id==="exit"?n("chat"):(d("items"),h(0)):O.escape&&n("chat");else if(u==="items"){if(O.upArrow)h(D=>(D-1+K.length)%K.length);else if(O.downArrow)h(D=>(D+1)%K.length);else if(O.leftArrow||O.escape)d("categories");else if(O.return){let D=K[p];P(D)}}});let P=k=>{if(k.value==="memory")o(O=>({...O,memory:!O.memory}));else if(k.value==="sandboxPreset"){let O=Zi(e),D=["Autonomous","Balanced","Strict"],G=(D.indexOf(O)+1)%D.length,Z=D[G];o(X=>{let z={...X,sandboxPreset:Z};return Z==="Strict"?(z.autoExec=!1,z.allowExternalAccess=!1,z.networkAccess=!1,z.autoApproveCommands="",z.autoDisallowCommands="rm -rf, rm -f, del /f, del /q, rd /s, rmdir /s, format, mkfs, dd if=/dev, shred, srm, Remove-Item -Recurse -Force, Initialize-Disk, Clear-Disk, format c:, flashrom, nvram -c",z.alwaysAskCommands="killall, pkill, taskkill, shutdown, reboot, init 0, init 6, Stop-Process, Stop-Service, mv /*, move c:\\*, chmod 000, chmod -R 777, chown, icacls, netsh advfirewall, iptables -F, ufw disable, git reset --hard, git clean -fd, npm r, npm uninstall",z.autoApproveGit=!1):Z==="Balanced"?(z.autoExec=!0,z.allowExternalAccess=!1,z.networkAccess=!0,z.autoApproveCommands="ls, dir, cat, type, echo, pwd, cd, git status, git log, git diff, git branch, git show, help, mkdir, touch, md, whoami, hostname, ps, Get-Process, date, time",z.autoDisallowCommands="rm -rf, rm -f, del /f, del /q, rd /s, rmdir /s, format, mkfs, dd if=/dev, shred, srm, Remove-Item -Recurse -Force, Initialize-Disk, Clear-Disk, format c:, flashrom, nvram -c",z.alwaysAskCommands="killall, pkill, taskkill, Stop-Process, mv /*, move c:\\*, chmod 000, chmod -R 777, chown, icacls, shutdown, reboot, init 0, init 6, git reset --hard, git clean -fd, npm r, npm uninstall",z.autoApproveGit=!1):Z==="Autonomous"&&(z.autoExec=!0,z.allowExternalAccess=!0,z.networkAccess=!0,z.autoApproveCommands="",z.autoDisallowCommands="",z.alwaysAskCommands="rm -rf, rm -f, del /f, del /q, rd /s, rmdir /s, format, mkfs, dd if=/dev, shred, srm, Remove-Item -Recurse -Force, Initialize-Disk, Clear-Disk, format c:, flashrom, nvram -c",z.autoApproveGit=!0),z})}else if(k.value==="autoExec")e.autoExec?o(O=>({...O,autoExec:!1,sandboxPreset:"Custom"})):e.allowExternalAccess?n("doubleDanger"):n("autoExecDanger");else if(k.value==="externalAccess")e.allowExternalAccess?o(O=>({...O,allowExternalAccess:!1,sandboxPreset:"Custom"})):e.autoExec?n("doubleDanger"):n("externalDanger");else if(k.value==="networkAccess")o(O=>({...O,networkAccess:O.networkAccess===!1,sandboxPreset:"Custom"}));else if(k.value==="alwaysAsk")T("alwaysAskCommands"),I(e.alwaysAskCommands||"");else if(k.value==="autoApprove")T("autoApproveCommands"),I(e.autoApproveCommands||"");else if(k.value==="autoApproveGit")o(O=>({...O,autoApproveGit:!O.autoApproveGit,sandboxPreset:"Custom"}));else if(k.value==="autoDisallow")T("autoDisallowCommands"),I(e.autoDisallowCommands||"");else if(k.value==="apiTier")n("apiTier");else if(k.value==="aiProvider")n("selectProvider");else if(k.value==="autoDelete"){let O=["1d","7d","30d"],Q=(O.indexOf(e.autoDeleteHistory||"30d")+1)%O.length;o(G=>({...G,autoDeleteHistory:O[Q]}))}else if(k.value==="autoUpdate")o(O=>({...O,autoUpdate:!O.autoUpdate}));else if(k.value==="externalData")if(!e.useExternalData)i({label:"Enter absolute path for External AppData:",note:"All history, logs and secrets will be stored here. ~/.fluxflow/settings.json stays as anchor.",key:"externalDataPath",value:e.externalDataPath||""}),n("input");else{let O={...e,useExternalData:!1};o(O),r({systemSettings:O,apiTier:t,quotas:l}),c(D=>[...D,{id:Date.now(),role:"system",text:"\u{1F3E0} [STORAGE RESET] Flux Flow will return to default ~/.fluxflow after restart."}]),n("chat")}else k.value==="updateManager"&&n("updateManager")};return we.createElement(Ot,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%",height:27},we.createElement(Ot,{paddingX:1,paddingY:0,marginBottom:1,borderStyle:"single",borderColor:"magenta",width:"100%"},we.createElement(Rt,{color:"magenta",bold:!0},"\u{1F527} SYSTEM CONFIGURATION")),we.createElement(Ot,{flexDirection:"row",width:"100%",minHeight:19},we.createElement(Ot,{flexDirection:"column",width:"30%",borderStyle:"round",borderColor:u==="categories"?"cyan":"gray",padding:1},we.createElement(Ot,{marginBottom:1},we.createElement(Rt,{color:u==="categories"?"cyan":"white",bold:!0,underline:!0},"CATEGORIES")),on.map((k,O)=>{let D=a===O,Q=k.id==="exit";return we.createElement(Ot,{key:k.id,marginTop:Q?8:0,backgroundColor:D?u==="categories"?"#2a2a2a":"#1e1e1e":void 0,paddingX:1},we.createElement(Rt,{color:D?u==="categories"?"cyan":"yellow":"white",bold:D},D?"\u276F ":" ",k.label))})),we.createElement(Ot,{flexDirection:"column",width:"70%",borderStyle:"round",borderColor:u==="items"?"cyan":"gray",padding:1,marginLeft:1},we.createElement(Ot,{marginBottom:1},we.createElement(Rt,{color:u==="items"?"cyan":"white",bold:!0,underline:!0},on[a].label.toUpperCase()," SETTINGS")),K.length>0?(()=>{let k=null,O=[],D=Te=>(Te||"").split(",").map(je=>je.trim().toLowerCase()).filter(Boolean),Q=D(e.autoApproveCommands),G=D(e.autoDisallowCommands),Z=D(e.alwaysAskCommands),X=[...Q,...G,...Z],z=new Set(X),Ct=U==="security"&&X.length!==z.size;return K.forEach((Te,je)=>{let nt=u==="items"&&p===je,fe=Te.label.length,ut=Math.max(2,35-fe),ze=".".repeat(ut),Je=me=>U==="security"?(me.value==="autoExec"||me.value==="externalAccess")&&me.status==="ON"?"red":"yellow":me.status?.startsWith("\u2713")?"green":me.status?.startsWith("\u26A0")?"yellow":me.status==="ON"?"green":me.status==="OFF"?"red":"yellow";Te.section&&Te.section!==k&&(k=Te.section,O.push(we.createElement(Ot,{key:`sec-hdr-${Te.section}`,marginTop:O.length>0?1:0,marginBottom:0,paddingX:1},we.createElement(Rt,{color:"magenta",bold:!0,underline:!0},"\u{1F4C2} ",Te.section.toUpperCase()))));let Fe=nt&&S&&(S==="alwaysAskCommands"&&Te.value==="alwaysAsk"||S==="autoApproveCommands"&&Te.value==="autoApprove"||S==="autoDisallowCommands"&&Te.value==="autoDisallow"),Qe=Te.value==="alwaysAsk"||Te.value==="autoApprove"||Te.value==="autoDisallow";O.push(we.createElement(Ot,{key:Te.value,flexDirection:"column"},we.createElement(Ot,{backgroundColor:nt&&!Fe?"#2a2a2a":void 0,paddingX:2},we.createElement(Rt,{color:nt?"cyan":"white",bold:nt},nt?"\u276F ":" ",Te.label),!Qe&&we.createElement(we.Fragment,null,we.createElement(Rt,{color:"gray",dimColor:!0},ze),we.createElement(Rt,{color:Je(Te),bold:!0},Te.value==="aiProvider"?Te.status:`[ ${Te.status} ]`))),Qe&&!Fe&&Te.status!=="None"&&we.createElement(Ot,{paddingX:4,marginBottom:1},we.createElement(Rt,{color:"gray",dimColor:!0},"\u21B3 ",Te.status)),Fe&&we.createElement(Ot,{flexDirection:"column",marginLeft:4,marginBottom:1},we.createElement(Ot,{paddingX:1,borderStyle:"single",borderColor:"cyan",flexDirection:"row"},we.createElement(Rt,{color:"cyan",bold:!0},"> "," "),we.createElement(oc,{value:w,onChange:I,onSubmit:me=>{let yo={...e,[S]:me.trim(),sandboxPreset:"Custom"};o(yo),r({systemSettings:yo,apiTier:t,quotas:l}),T(null)}})),we.createElement(Rt,{color:"gray",dimColor:!0,italic:!0}," Comma separated \u2022 Press Enter to save, Esc to cancel"))))}),U==="other"&&O.push(we.createElement(Ot,{key:"pty-notice",marginTop:10,paddingX:1},we.createElement(Rt,{color:Nn?"green":"yellow"},Nn?"\u2713 Advance Interactive Terminal Supported":"\u26A0 Interactive Terminal is Limited"))),Ct&&O.push(we.createElement(Ot,{key:"conflict-warning",marginTop:1,paddingX:1},we.createElement(Rt,{color:"red",dimColor:!0,italic:!0},"* Conflicting commands will be ignored and defaulted to highest priority"))),O})():we.createElement(Ot,{paddingX:1},we.createElement(Rt,{color:"gray",italic:!0},on[a].desc)))),we.createElement(Ot,{paddingX:1,marginTop:1,flexDirection:"row",justifyContent:"space-between"},we.createElement(Rt,{color:"gray",dimColor:!0,italic:!0},u==="categories"?"\u25B2\u25BC Select Category \u2022 Enter/\u25BA to configure":"\u25B2\u25BC Select Option \u2022 Enter to Toggle \u2022 \u25C4/ESC to go back"),u==="categories"&&we.createElement(Rt,{color:"gray",dimColor:!0},on[a].desc)))}var on,Zi,$s,ea=ae(async()=>{await gr();on=[{id:"memory",label:"\u{1F9E0} Memory",desc:"Manage system context & agent's memory"},{id:"security",label:"\u{1F512} Security",desc:"Configure permissions & data safety"},{id:"updater",label:"\u{1F504} Updater",desc:"Manage application updates"},{id:"other",label:"\u{1F4CB} Other",desc:"Miscellaneous preferences"},{id:"exit",label:"\u{1F6AA} Exit Settings",desc:"Return to chat view"}],Zi=e=>{let o=e.autoApproveCommands||"",t=e.autoDisallowCommands||"",n=e.alwaysAskCommands||"",i=e.autoExec===!1&&e.allowExternalAccess===!1&&e.networkAccess===!1&&o===""&&t==="rm -rf, rm -f, del /f, del /q, rd /s, rmdir /s, format, mkfs, dd if=/dev, shred, srm, Remove-Item -Recurse -Force, Initialize-Disk, Clear-Disk, format c:, flashrom, nvram -c"&&n==="killall, pkill, taskkill, shutdown, reboot, init 0, init 6, Stop-Process, Stop-Service, mv /*, move c:\\*, chmod 000, chmod -R 777, chown, icacls, netsh advfirewall, iptables -F, ufw disable, git reset --hard, git clean -fd, npm r, npm uninstall"&&e.autoApproveGit===!1,r=e.autoExec===!0&&e.allowExternalAccess===!1&&e.networkAccess!==!1&&o==="ls, dir, cat, type, echo, pwd, cd, git status, git log, git diff, git branch, git show, help, mkdir, touch, md, whoami, hostname, ps, Get-Process, date, time"&&t==="rm -rf, rm -f, del /f, del /q, rd /s, rmdir /s, format, mkfs, dd if=/dev, shred, srm, Remove-Item -Recurse -Force, Initialize-Disk, Clear-Disk, format c:, flashrom, nvram -c"&&n==="killall, pkill, taskkill, Stop-Process, mv /*, move c:\\*, chmod 000, chmod -R 777, chown, icacls, shutdown, reboot, init 0, init 6, git reset --hard, git clean -fd, npm r, npm uninstall"&&e.autoApproveGit===!1,l=e.autoExec===!0&&e.allowExternalAccess===!0&&e.networkAccess!==!1&&o===""&&t===""&&n==="rm -rf, rm -f, del /f, del /q, rd /s, rmdir /s, format, mkfs, dd if=/dev, shred, srm, Remove-Item -Recurse -Force, Initialize-Disk, Clear-Disk, format c:, flashrom, nvram -c"&&e.autoApproveGit===!0;return i?"Strict":r?"Balanced":l?"Autonomous":e.sandboxPreset||"Custom"},$s=e=>!e||e.trim()===""?"None":e.length>40?e.substring(0,40)+"...":e});import Lo,{useState as Ps,useEffect as nc}from"react";import{Box as Zn,Text as qr}from"ink";import rc from"ink-text-input";function Bs({initialData:e,onSave:o,onCancel:t}){let[n,i]=Ps(0),[r,l]=Ps(""),[c,f]=Ps(()=>({name:e?.name||"",nickname:e?.nickname||"",instructions:e?.instructions||""})),u=[{key:"name",label:"Enter your Name: "},{key:"nickname",label:"Enter a Nickname (Agent will use this): "},{key:"instructions",label:"System Instructions (Persona overrides): "}];nc(()=>{let a=u[n].key;l(c[a]||"")},[n,c]);let d=a=>{if(a.trim().toLowerCase()==="/cancel"){t();return}let m=u[n].key,p={...c,[m]:a.trim()};f(p),l(""),n<u.length-1?i(n+1):o(p)};return Lo.createElement(Zn,{borderStyle:"round",borderColor:"gray",padding:0,marginTop:1,flexShrink:0,flexDirection:"column",width:"100%"},Lo.createElement(Zn,{paddingX:1,marginBottom:1},Lo.createElement(qr,{color:"magenta",bold:!0},"\u{1F464} DEVELOPER PROFILE CONFIGURATION")),Lo.createElement(Zn,{paddingX:1,flexDirection:"column"},Lo.createElement(Zn,null,Lo.createElement(qr,{color:"cyan",bold:!0},u[n].label),Lo.createElement(rc,{value:r,onChange:l,onSubmit:d})),Lo.createElement(Zn,{marginTop:1},Lo.createElement(qr,{color:"gray",dimColor:!0,italic:!0},"Step ",n+1," of ",u.length))),Lo.createElement(Zn,{paddingX:1,marginTop:1},Lo.createElement(qr,{color:"gray",dimColor:!0,italic:!0},"(Enter to submit \u2022 Type /cancel to abort)")))}var ta=ae(()=>{});import ct,{useState as Ns}from"react";import{Box as Co,Text as nn,useInput as sc}from"ink";import ic from"ink-text-input";var ac,oa,na=ae(()=>{wn();ac=({question:e,options:o,onResolve:t})=>{let[n,i]=Ns(!1),[r,l]=Ns(""),[c,f]=Ns(0),u=[...o,{id:"CUSTOM",label:"Suggest something else...",description:"Provide a custom response"}];sc((a,m)=>{if(!n&&((m.leftArrow||m.upArrow)&&f(p=>Math.max(0,p-1)),(m.rightArrow||m.downArrow)&&f(p=>Math.min(u.length-1,p+1)),m.return)){let p=u[c];p.id==="CUSTOM"?i(!0):t(p.label)}});let d=Ce(2);return n?ct.createElement(Co,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},ct.createElement(Co,{paddingX:1},ct.createElement(nn,{color:"cyan",bold:!0},"\u{1F4AC} SUGGEST SOMETHING ELSE")),ct.createElement(Co,{marginTop:1,paddingX:1},ct.createElement(nn,{italic:!0,color:"gray"},"Replying to: ",e)),ct.createElement(Co,{marginTop:1,paddingX:1,flexDirection:"row"},ct.createElement(nn,{color:"cyan",bold:!0},"\u{1F4A0} "),ct.createElement(ic,{value:r,onChange:l,onSubmit:()=>t(r)})),ct.createElement(Co,{marginTop:1,paddingX:1,marginBottom:1},ct.createElement(nn,{color:"gray",dimColor:!0,italic:!0},"(Press Enter to send)"))):ct.createElement(Co,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},ct.createElement(Co,{paddingX:1,marginBottom:1},ct.createElement(nn,{color:"cyan",bold:!0},"\u{1F4AC} AGENT REQUEST: ACTION REQUIRED")),ct.createElement(Co,{paddingX:1,marginBottom:1},ct.createElement(nn,{bold:!0,color:"white"},e)),ct.createElement(Co,{flexDirection:"column",width:"100%"},u.map((a,m)=>{let p=m===c;return ct.createElement(Co,{key:a.id,flexDirection:"column",width:"100%",backgroundColor:p?"#2a2a2a":void 0,paddingX:1,marginBottom:m===u.length-1?0:1},ct.createElement(nn,{color:p?"cyan":"white",bold:p},p?"\u276F ":" ",a.label),a.description&&ct.createElement(Co,{marginLeft:4},ct.createElement(nn,{color:"gray",italic:!0,dimColor:!0},a.description)))})),ct.createElement(Co,{paddingX:1,marginTop:1,marginBottom:1},ct.createElement(nn,{color:"gray",dimColor:!0,italic:!0},"(Use Arrows to navigate, Enter to confirm)")))},oa=ac});import yr from"fs";import _s from"path";import Vr from"crypto";var lc,cc,ra,sa,wr,Sn,ye,ke,zr,Jr,Do=ae(()=>{lc=66,cc=e=>{let o=Buffer.isBuffer(e)?e:Buffer.from(e),t=Buffer.alloc(o.length);for(let n=0;n<o.length;n++)t[n]=o[n]^lc;return t},ra="aes-256-cbc",sa=Vr.createHash("sha256").update("fluxflow-cli-sanctuary-key").digest(),wr=e=>{let o=Vr.randomBytes(16),t=Vr.createCipheriv(ra,sa,o),n=t.update(e,"utf8","hex");return n+=t.final("hex"),o.toString("hex")+":"+n},Sn=e=>{let o=e.split(":");if(o.length!==2)throw new Error("Invalid AES format");let t=Buffer.from(o[0],"hex"),n=o[1],i=Vr.createDecipheriv(ra,sa,t),r=i.update(n,"hex","utf8");return r+=i.final("utf8"),r},ye=(e,o={})=>{try{if(!yr.existsSync(e))return o;let t=yr.readFileSync(e),n=t.toString("utf8").trim();if(n.startsWith("{")||n.startsWith("["))return JSON.parse(n);try{let r=Sn(n);return JSON.parse(r)}catch{}let i=cc(t).toString("utf8");if(i.startsWith("{")||i.startsWith("["))return JSON.parse(i);throw new Error("Unsupported or corrupt encryption format")}catch(t){return console.error(`Vault Read Error [${_s.basename(e)}]:`,t.message),o}},ke=(e,o)=>{try{let t=_s.dirname(e);yr.existsSync(t)||yr.mkdirSync(t,{recursive:!0});let n=JSON.stringify(o,null,2),i=wr(n);yr.writeFileSync(e,i,"utf8")}catch(t){console.error(`Vault Write Error [${_s.basename(e)}]:`,t.message)}},zr=ye,Jr=ke});var ca={};bs(ca,{BACKUPS_DIR:()=>En,DATA_DIR:()=>Qr,FLUXFLOW_DIR:()=>_n,HISTORY_FILE:()=>Un,LEDGER_FILE:()=>rn,LOGS_DIR:()=>Io,MEMORIES_FILE:()=>Bt,PATHS_FILE:()=>Zr,SECRET_DIR:()=>to,SETTINGS_FILE:()=>eo,TEMP_MEM_CHAT_FILE:()=>Uo,TEMP_MEM_FILE:()=>ho,USAGE_FILE:()=>Wt});import dc from"os";import ko from"path";import ia from"fs";import aa from"crypto";var _n,eo,la,Qr,Io,to,Un,Wt,Bt,ho,Uo,En,rn,Zr,oo=ae(()=>{_n=ko.join(dc.homedir(),".fluxflow"),eo=ko.join(_n,"settings.json"),la=null;try{if(ia.existsSync(eo)){let e=ia.readFileSync(eo,"utf8").trim(),o;if(e.startsWith("{"))o=JSON.parse(e);else{let t=e.split(":");if(t.length===2){let n=Buffer.from(t[0],"hex"),i=t[1],r=aa.createHash("sha256").update("fluxflow-cli-sanctuary-key").digest(),l=aa.createDecipheriv("aes-256-cbc",r,n),c=l.update(i,"hex","utf8");c+=l.final("utf8"),o=JSON.parse(c)}}if(o){let t=o.systemSettings||{};t.useExternalData&&t.externalDataPath&&(la=t.externalDataPath)}}}catch{}Qr=la||_n,Io=ko.join(Qr,"logs"),to=ko.join(Qr,"secret"),Un=ko.join(to,"history.json"),Wt=ko.join(_n,"usage.json"),Bt=ko.join(to,"memories.json"),ho=ko.join(to,"memory-temp.json"),Uo=ko.join(to,"temp-memory-chat.json"),En=ko.join(Qr,"backups"),rn=ko.join(to,"ledger.json"),Zr=ko.join(to,"path.json")});var os={};bs(os,{getAPIKey:()=>fc,getProviderAPIKey:()=>es,getSearchSecrets:()=>hc,getSecret:()=>pc,removeAPIKey:()=>Us,removeSecret:()=>da,saveAPIKey:()=>gc,saveProviderAPIKey:()=>ts,saveSearchId:()=>yc,saveSearchKey:()=>xc,saveSecret:()=>bn});import uc from"fs-extra";import mc from"path";var Cn,fc,es,ts,pc,bn,hc,gc,xc,yc,da,Us,Tr=ae(()=>{Do();oo();Cn=mc.join(to,"secrets.json"),fc=async()=>{try{let e=ye(Cn,{});if(e.API_KEY)return e.API_KEY}catch{}return null},es=async e=>{try{let o=ye(Cn,{});if(e==="Google")return o.GOOGLE_API_KEY||o.API_KEY||null;if(e==="DeepSeek")return o.DEEPSEEK_API_KEY||null;if(e==="OpenRouter")return o.OPENROUTER_API_KEY||null}catch{}return null},ts=async(e,o)=>{e==="Google"?(await bn("GOOGLE_API_KEY",o),await bn("API_KEY",o)):e==="DeepSeek"?await bn("DEEPSEEK_API_KEY",o):e==="OpenRouter"&&await bn("OPENROUTER_API_KEY",o)},pc=async e=>{try{return ye(Cn,{})[e]||null}catch{return null}},bn=async(e,o)=>{await uc.ensureDir(to);let t=ye(Cn,{});t[e]=o,ke(Cn,t)},hc=async()=>{try{let e=ye(Cn,{});return{key:e.GOOGLE_API_KEY||e.API_KEY,cx:e.SEARCH_ID}}catch{}return{key:null,cx:null}},gc=async e=>bn("API_KEY",e),xc=async e=>bn("GOOGLE_API_KEY",e),yc=async e=>bn("SEARCH_ID",e),da=async e=>{try{let o=ye(Cn,{});delete o[e],ke(Cn,o)}catch{}},Us=async()=>da("API_KEY")});var ua,ma=ae(()=>{ua=(e=!0,o=!0)=>`
|
|
118
115
|
Your tool syntax is: '[tool:functions.ToolName(args...)]'
|
|
119
116
|
|
|
120
117
|
-- CHAT MANAGEMENT TOOLS (MUST CALL THESE 2 TOOLS ALWAYS) --
|
|
@@ -139,7 +136,7 @@ Explicit Triggers for permanent memory:
|
|
|
139
136
|
|
|
140
137
|
Usage Rules:
|
|
141
138
|
- Frequency for 'user' action: Based on explicit triggers.
|
|
142
|
-
- IF YOU WANT TO SAVE SOMETHING, BUT SIMILAR MEMORY ALREADY EXISTS, USE THE UPDATE METHOD NOT THE ADD METHOD`:""}`.trim()});var
|
|
139
|
+
- IF YOU WANT TO SAVE SOMETHING, BUT SIMILAR MEMORY ALREADY EXISTS, USE THE UPDATE METHOD NOT THE ADD METHOD`:""}`.trim()});var Rs,fa=ae(()=>{Rs={xHigh:`EFFORT LEVEL: MAX
|
|
143
140
|
Think in a continuous, relentless analytical monologue within <think>...</think>. Engage in adversarial self interrogation that treats every assumption as hostile until proven:
|
|
144
141
|
Deconstruct requirements into atomic invariants. Trace every implicit dependency, side effect, and state mutation. Map the entire dependency graph and identify circular dependencies or tight coupling before they manifest
|
|
145
142
|
Evaluate algorithmic complexity (time/space) for every operation. Consider memory models, cache locality, and allocation patterns. For concurrent systems, reason through race conditions, deadlocks, and memory ordering
|
|
@@ -193,24 +190,24 @@ RULES:
|
|
|
193
190
|
- Suitable for simple requests/greetings`,Off:`EFFORT LEVEL: INSTANT
|
|
194
191
|
No thinking. Immediate response
|
|
195
192
|
RULES:
|
|
196
|
-
- Verify ALL imports and system stability, AVOID ANY Syntax errors, re-read TOOL RESULTS/files to verify`}});import
|
|
193
|
+
- Verify ALL imports and system stability, AVOID ANY Syntax errors, re-read TOOL RESULTS/files to verify`}});import Tc from"fs";var Ws,pa,ha,ga,xa=ae(async()=>{await Os();ma();fa();Ws=null,pa=(e="",o="",t=!0,n=!1)=>{if(!t)return"";let i=e?.length>0&&!n?`-- RECENT CONTEXT FROM OTHER CHATS (PRIORITY: DYNAMIC-LOW, FOCUS: Chat Context > Recent) --
|
|
197
194
|
${e}`:"",l=[o?.length>0?`--- SAVED MEMORIES (PRIORITY: MEDIUM, USER PREFERENCES) ---
|
|
198
195
|
${o}`:"",i].filter(c=>c.length>0);return l.length>0?`[SYSTEM CONTEXT]
|
|
199
196
|
${l.join(`
|
|
200
197
|
|
|
201
198
|
`)}
|
|
202
|
-
`:""},
|
|
199
|
+
`:""},ha=(e,o,t,n,i=!0,r=!1,l="Google",c=!1)=>{let f="";if(o!=="GEM"){let w=o;o==="Fast"&&(w="Off"),o==="Low"&&(w="Minimal"),(o==="xHigh"||o==="Max")&&(w="xHigh"),f=Rs[w]||Rs.Medium}let u=process.platform==="win32"?"Windows":process.platform==="darwin"?"macOS":"Linux",d=e.instructions&&e.instructions?.length>0?`User Instructions: ${e.instructions}
|
|
203
200
|
|
|
204
201
|
`:"",a=e.nickname&&e.nickname?.length>0?`User Nickname: ${e.nickname}
|
|
205
|
-
${
|
|
206
|
-
`}`:"",
|
|
207
|
-
${a.length||
|
|
208
|
-
`}`:"",p=process.cwd(),h=(()=>{let
|
|
202
|
+
${d.length?"":`
|
|
203
|
+
`}`:"",m=e.name&&e.name?.length>0?`User Name: ${e.name}
|
|
204
|
+
${a.length||d.length?"":`
|
|
205
|
+
`}`:"",p=process.cwd(),h=(()=>{let w=process.cwd().toLowerCase();if(process.platform==="win32"){let I=process.env.SystemRoot?.toLowerCase()||"c:\\windows",$=process.env.ProgramFiles?.toLowerCase()||"c:\\program files",U=process.env["ProgramFiles(x86)"]?.toLowerCase()||"c:\\program files (x86)";return w.startsWith(I)||w.startsWith($)||w.startsWith(U)}else return w==="/"||["/bin","/sbin","/etc","/usr","/var","/root"].some($=>w.startsWith($))})(),S=[{name:"Fluxflow.md",desc:"HIGH PRIORITY. Overrides other files"},{name:"README.md",desc:"Goals"},{name:"Agent.md",desc:"Standards"},{name:"Skills.md",desc:"Workflows"},{name:"design.md",desc:"UI/UX"},{name:"architecture.md",desc:"System Structure"}];if(r||Ws===null){let w=S.filter(I=>Tc.existsSync(I.name));Ws=t==="Flux"&&w.length>0?`
|
|
209
206
|
-- PROJECT CONTEXT (Source of Truth) --
|
|
210
|
-
${
|
|
207
|
+
${w.map(I=>`- ${I.name}: ${I.desc}`).join(`
|
|
211
208
|
`)}
|
|
212
209
|
Check these first; These Files > Training Data. Safety rules apply
|
|
213
|
-
`:""}let
|
|
210
|
+
`:""}let T=Ws;return`${m}${a}${d}[SYSTEM]
|
|
214
211
|
Identity: Flux Flow (by Kushal Roy Chowdhury). Conversational, Sassy${t==="Flux"?", Respectful":", Friendly, Humorous, Sarcastic"}, CLI Agent
|
|
215
212
|
Mode: ${t}${o!=="Fast"?" (Thinking Mode)":""}. ${t==="Flux"?"Logical, Highly Detailed, Task-Driven. Prioritizes scalable file/folder structures, modular architecture, clean code abstractions, step-by-step execution. Industry standard latest coding practices/libraries, clean code, Double Check Imports, Client-Server Sync":"Concise"}
|
|
216
213
|
|
|
@@ -223,14 +220,14 @@ Mode: ${t}${o!=="Fast"?" (Thinking Mode)":""}. ${t==="Flux"?"Logical, Highly Det
|
|
|
223
220
|
- SYSTEM NOTIFICATION: [SYSTEM], [METADATA] in user turn
|
|
224
221
|
${l==="Google"?`${o!=="GEM"?`
|
|
225
222
|
-- THINKING RULES --
|
|
226
|
-
${
|
|
223
|
+
${f}
|
|
227
224
|
${o!=="Fast"?`
|
|
228
225
|
CRITICAL THINKING POLICY
|
|
229
226
|
- ALWAYS use <think> ... </think> before responding, even with simple queries/greetings
|
|
230
227
|
- ${o==="Low"||o==="Medium"||o==="Fast"?"C":"Interrogate approaches adversarially, but c"}ommit once best solution is determined through analysis. Avoid spiraling after reaching decision point
|
|
231
228
|
`:""}`:""}`:""}
|
|
232
|
-
${
|
|
233
|
-
${
|
|
229
|
+
${zi(t,u,l.toLowerCase()==="deepseek"?!1:c,l)}
|
|
230
|
+
${T}
|
|
234
231
|
-- MEMORY RULES --
|
|
235
232
|
- Memory: ${i?"Subtly Personalize. Auto Saves":"OFF. Decline Remembering Memories"}
|
|
236
233
|
- Temporal Awareness: RELATIVE TIME REFERENCE eg. few mins ago
|
|
@@ -245,7 +242,7 @@ PROTECTED DIRECTORY: ASK BEFORE MODIFYING`:""}
|
|
|
245
242
|
- GFM Supported
|
|
246
243
|
- NO EMOJI AT END OF RESPONSE
|
|
247
244
|
- NO LaTeX${t==="Flux"?"":". Kaomojis"}
|
|
248
|
-
[/SYSTEM]`.trim()},
|
|
245
|
+
[/SYSTEM]`.trim()},ga=(e="",o=!0,t=!0)=>`${e?`-- CURRENT SAVED USER MEMORIES --
|
|
249
246
|
${e}
|
|
250
247
|
-------------------------------------------------
|
|
251
248
|
|
|
@@ -264,67 +261,73 @@ YOU ARE A SILENT BACKGROUND SYSTEM PROCESS. YOU HAVE NO MOUTH. YOUR ONLY OUTPUT
|
|
|
264
261
|
YOUR JOB: Analyze the 'User prompt' and 'Agent Raws' to extract facts for long-term memory or handle system tasks.
|
|
265
262
|
${o?"If user tell something that is important (like, hobbies, preferences, facts about user, hates, likes, etc) to know user better over time, use long term memory tools.":""}
|
|
266
263
|
|
|
267
|
-
${
|
|
264
|
+
${ua(o,t)}
|
|
268
265
|
|
|
269
266
|
Current date and Time: ${new Date().toLocaleString([],{year:"numeric",month:"numeric",day:"numeric",hour:"2-digit",hour12:!0})}.
|
|
270
|
-
=== END SYSTEM PROMPT ===`.trim()});import
|
|
271
|
-
`),n=[],i=null,r=/^\s*(?:DEBUG|ERROR|SEARCH|PUPPETEER)\b/i;for(let a of t)r.test(a)?(i&&n.push(i),i={header:a,body:[]}):i?i.body.push(a):n.push({header:a,body:[]});i&&n.push(i);let l=10080*60*1e3,c=Date.now(),
|
|
267
|
+
=== END SYSTEM PROMPT ===`.trim()});import go from"fs-extra";import Rn from"path";var sn,bt,an=ae(()=>{oo();Do();go.ensureDirSync(En);sn=null,bt={async startTransaction(e,o){sn={id:`tx_prompt_${Date.now()}`,chatId:e,timestamp:new Date().toISOString(),prompt:o.trim(),changes:[],reverted:!1}},async recordFileChange(e,o=null){if(!sn||sn.changes.some(l=>l.filePath===e))return;let n=await go.pathExists(e),i=n&&!o||o?"update":"create";!n&&!o&&(i="create");let r=null;if(n||o){i="update";let l=Rn.basename(e);r=`${sn.id}_${l}.bak`;let c=Rn.join(En,sn.chatId);await go.ensureDir(c);let f=Rn.join(c,r),u=o!==null?o:await go.readFile(e,"utf8"),d=wr(u);await go.writeFile(f,d,"utf8")}sn.changes.push({filePath:e,type:i,backupFile:r})},async commitTransaction(){if(!sn)return;let e=ye(rn,[]);if(e.push(sn),e.length>512e3){let o=e.shift();if(o.changes){for(let t of o.changes)if(t.backupFile){let n=Rn.join(En,o.chatId,t.backupFile);await go.remove(n)}}}ke(rn,e),sn=null},async rollbackToBefore(e){let o=ye(rn,null);if(!o)throw new Error("No transaction ledger found.");let t=o.findIndex(c=>c.id===e);if(t===-1)throw new Error(`Transaction [${e}] not found.`);let n=o[t].chatId,i=o[t].prompt,r=o.slice(t).filter(c=>c.chatId===n&&!c.reverted).reverse();for(let c of r){for(let f of[...c.changes].reverse())if(f.type==="create")await go.pathExists(f.filePath)&&await go.remove(f.filePath);else if(f.type==="update"){let u=Rn.join(En,c.chatId,f.backupFile);if(await go.pathExists(u)){let d=await go.readFile(u,"utf8"),a=Sn(d);await go.writeFile(f.filePath,a,"utf8")}}c.reverted=!0}for(let c of r)for(let f of c.changes)if(f.backupFile){let u=Rn.join(En,c.chatId,f.backupFile);await go.remove(u)}let l=o.filter(c=>!r.some(f=>f.id===c.id));return ke(rn,l),{success:!0,chatId:n,targetPrompt:i}},async getChatHistory(e){try{return ye(rn,[]).filter(t=>t.chatId===e&&!t.reverted)}catch{return[]}},async deleteChatBackups(e){try{let o=Rn.join(En,e);await go.remove(o);let t=ye(rn,[]),n=t.length;t=t.filter(i=>i.chatId!==e),t.length!==n&&ke(rn,t)}catch{}}}});import Ro from"fs-extra";import Sc from"path";import{nanoid as Ec}from"nanoid";var ya,Hs,vo,ns,wa,Ys,js,Ta,bc,Cc,Sa,Ea,Sr=ae(()=>{Do();oo();an();ya=Promise.resolve(),Hs=e=>{let o=ya.then(async()=>{try{return await e()}catch(t){throw console.error("Lock Operation Failed:",t),t}});return ya=o.catch(()=>{}),o},vo=async()=>{if(await Ro.pathExists(Un))try{return ye(Un,{})}catch{return{}}return{}},ns=async(e,o,t)=>Hs(async()=>{let n=await vo(),i=n[e],r=(t||[]).filter(c=>!c.isUpdateNotification&&!c.isMeta),l=o||(i?i.name:`Session ${e.slice(-6)}`);n[e]={name:l,messages:r,updatedAt:Date.now()},ke(Un,n)}),wa=async(e,o)=>Hs(async()=>{let t=await vo();t[e]?(t[e].name=o,t[e].updatedAt=Date.now()):t[e]={name:o,messages:[],updatedAt:Date.now()},ke(Un,t)}),Ys=async e=>Hs(async()=>{let o=await vo();delete o[e],ke(Un,o);let t=ye(ho,{});t[e]&&(delete t[e],ke(ho,t));let n=ye(Uo,{});return n[e]&&(delete n[e],ke(Uo,n)),await bt.deleteChatBackups(e),o}),js=()=>`flow-${Ec(6)}`,Ta=async e=>{if(!e||e==="Never")return;let o=parseInt(e);if(isNaN(o))return;let t=await vo(),n=Date.now(),i=o*24*60*60*1e3,r=0;for(let l in t){let c=t[l];c.updatedAt&&n-c.updatedAt>i&&(await Ys(l),r++)}return r},bc=e=>{let o=e.replace(/[\[\]]/g,"").trim(),t=new Date(o);if(!isNaN(t.getTime()))return t.getTime();let n=o.split(/,\s*|\s+/);if(n.length===0)return null;let i=n[0],r=n[1]||"",l=n[2]||"",c=i.split(/[-/.]/).map(Number);if(c.length!==3)return null;let f,u,d;if(c[0]>1e3)f=c[0],u=c[1],d=c[2];else if(c[2]>1e3)f=c[2],c[0]>12?(d=c[0],u=c[1]):c[1]>12?(d=c[1],u=c[0]):(u=c[0],d=c[1]);else return null;let a=0,m=0,p=0;if(r){let S=r.split(":").map(Number);a=S[0]||0,m=S[1]||0,p=S[2]||0,l.toLowerCase()==="pm"&&a<12?a+=12:l.toLowerCase()==="am"&&a===12&&(a=0)}let h=new Date(f,u-1,d,a,m,p);return isNaN(h.getTime())?null:h.getTime()},Cc=async e=>{try{if(!await Ro.pathExists(e))return;let o=await Ro.readFile(e,"utf8");if(!o.trim())return;let t=o.split(`
|
|
268
|
+
`),n=[],i=null,r=/^\s*(?:DEBUG|ERROR|SEARCH|PUPPETEER)\b/i;for(let a of t)r.test(a)?(i&&n.push(i),i={header:a,body:[]}):i?i.body.push(a):n.push({header:a,body:[]});i&&n.push(i);let l=10080*60*1e3,c=Date.now(),f=[],u=/(\d{1,4}[-/.]\d{1,4}[-/.]\d{1,4}(?:,\s*|\s+)?(?:\d{1,2}:\d{2}:\d{2}(?:\s*[aApP][mM])?)?)/;for(let a of n){let m=a.header+(a.body.length>0?`
|
|
272
269
|
`+a.body.join(`
|
|
273
|
-
`):""),p=
|
|
274
|
-
`).trim();
|
|
275
|
-
`,"utf8"):await
|
|
276
|
-
Source: ${
|
|
277
|
-
Snippet: ${
|
|
270
|
+
`):""),p=m.match(u);if(p){let h=bc(p[1]);if(h&&c-h>l)continue}f.push(m)}let d=f.join(`
|
|
271
|
+
`).trim();d?await Ro.writeFile(e,d+`
|
|
272
|
+
`,"utf8"):await Ro.writeFile(e,"","utf8")}catch{}},Sa=async e=>{try{if(!await Ro.pathExists(e))return;let o=async t=>{let n=await Ro.readdir(t);for(let i of n){let r=Sc.join(t,i);(await Ro.stat(r)).isDirectory()?(await o(r),(await Ro.readdir(r)).length===0&&await Ro.remove(r)):i.endsWith(".log")&&await Cc(r)}};await o(e)}catch{}},Ea=(e,o=4)=>{if(e.length<=1)return e;let t=e[0],n=e.slice(1),i=o*2,r=n.slice(i);return[t,...r]}});import Ve from"fs-extra";import Wo from"path";import Gs from"os";var kc,ln,Ic,xt,kn,ba,rs,Xs,Ca,Ks,qs,ka,Ia,In,Ho,xo,Vs,zs,Ma,Aa,ss,Oa,is=ae(()=>{oo();Do();kc=()=>{if(process.platform==="win32"){let o=process.env.LOCALAPPDATA||Wo.join(Gs.homedir(),"AppData","Local");return Wo.join(o,"FxFl","backups","backup.json")}if(process.platform==="darwin")return Wo.join(Gs.homedir(),"Library","Application Support","FxFl","backups","backup.json");let e=process.env.XDG_DATA_HOME||Wo.join(Gs.homedir(),".local","share");return Wo.join(e,"fxfl","backups","backup.json")},ln=kc(),Ic=()=>Math.random().toString(36).substring(2)+Date.now().toString(36),xt=null,kn=null,ba=0,rs=!1,Xs={agent:0,background:0,search:0,toolSuccess:0,toolFailure:0,toolDenied:0,duration:0,tokens:0,cachedTokens:0,candidateTokens:0,linesAdded:0,linesRemoved:0,imageCalls:[]},Ca=async()=>{let e=new Date().toISOString().split("T")[0],o=Wt+".tmp",t=null,n=null;try{if(await Ve.exists(o)){let r=(await Ve.readFile(o,"utf8")).trim(),l=null;if(r.startsWith("{")||r.startsWith("[")?l=JSON.parse(r):l=JSON.parse(Sn(r)),l&&l.date&&l.stats){t=l;try{await Ve.rename(o,Wt)}catch{}}else try{await Ve.remove(o)}catch{}}}catch{try{await Ve.remove(o)}catch{}}if(!t)try{if(await Ve.exists(Wt)){let r=(await Ve.readFile(Wt,"utf8")).trim();r.startsWith("{")||r.startsWith("[")?t=JSON.parse(r):t=JSON.parse(Sn(r))}}catch{}try{if(await Ve.exists(ln)){let r=(await Ve.readFile(ln,"utf8")).trim();r.startsWith("{")||r.startsWith("[")?n=JSON.parse(r):n=JSON.parse(Sn(r))}}catch{}let i=null;if(t&&n)if(t.saveId!==n.saveId){i=t;try{await Ve.ensureDir(Wo.dirname(ln)),await Ve.copy(Wt,ln)}catch{}}else i=t;else if(t&&!n){i=t;try{await Ve.ensureDir(Wo.dirname(ln)),await Ve.copy(Wt,ln)}catch{}}else if(!t&&n){i=n;try{await Ve.ensureDir(Wo.dirname(Wt)),await Ve.copy(ln,Wt)}catch{}}if(i&&i.date===e&&i.stats){let r={...Xs,...i.stats};return Array.isArray(r.imageCalls)||(r.imageCalls=[]),{...i,stats:r}}return{date:e,stats:{...Xs}}},Ks=async()=>{if(!(!rs||!xt))try{await Ve.ensureDir(Wo.dirname(Wt));let e=null;try{if(await Ve.exists(Wt)){let i=(await Ve.readFile(Wt,"utf8")).trim();i.startsWith("{")||i.startsWith("[")?e=JSON.parse(i):e=JSON.parse(Sn(i))}}catch{}if(e&&e.date===xt.date&&e.stats){for(let i in xt.stats)if(e.stats[i]!==void 0)if(Array.isArray(xt.stats[i])){let r=Array.isArray(e.stats[i])?e.stats[i]:[],l=xt.stats[i],c=new Map;for(let f of[...r,...l])f&&f.timestamp&&c.set(f.timestamp,f);xt.stats[i]=Array.from(c.values())}else typeof xt.stats[i]=="number"&&(xt.stats[i]=Math.max(xt.stats[i],Number(e.stats[i])||0))}xt.saveId=Ic();let o=Wt+".tmp",t=wr(JSON.stringify(xt,null,2));await Ve.writeFile(o,t,"utf8");let n=await Ve.open(o,"r+");await Ve.fsync(n),await Ve.close(n),await Ve.rename(o,Wt);try{await Ve.ensureDir(Wo.dirname(ln)),await Ve.copy(Wt,ln)}catch{}rs=!1,ba=Date.now()}catch{}},qs=()=>{if(rs=!0,kn)return;let e=Date.now(),o=Math.max(0,1500-(e-ba));kn=setTimeout(async()=>{await Ks(),kn=null},o),kn.unref&&kn.unref()},ka=async()=>{xt=await Ca()},Ia=async()=>{kn&&(clearTimeout(kn),kn=null),await Ks()},In=async()=>{let e=new Date().toISOString().split("T")[0];return xt?xt.date!==e&&(xt={date:e,stats:{...Xs}},rs=!0,await Ks()):xt=await Ca(),xt&&xt.stats&&!Array.isArray(xt.stats.imageCalls)&&(xt.stats.imageCalls=[]),xt.stats},Ho=async e=>{let o=await In();o[e]!==void 0&&(o[e]++,qs())},xo=async(e,o)=>{let t=await In();t[e]!==void 0&&(t[e]+=Math.floor(o),qs())},Vs=async(e,o)=>{let t=await In(),n=o.apiTier||"Free",i=o.quotas||{};if(n==="Free"){if(e==="agent"||e==="background")return t.agent+t.background<999999;if(e==="search")return!0}if(n==="Paid"||n==="Custom"){if(e==="agent")return t.agent<(i.agentLimit||999999);if(e==="background")return t.background<(i.backgroundLimit||999999);if(e==="search")return t.search<(i.searchLimit||100)}return!0},zs=e=>{if(!e||e.length===0)return[];let t=[...e].sort((i,r)=>i.timestamp-r.timestamp),n=[];for(let i of t){if(n.length>0){let r=n[n.length-1];if(i.timestamp>=r.start&&i.timestamp<r.end){r.calls.push(i),r.spent+=i.cost;continue}}n.push({start:i.timestamp,end:i.timestamp+36e5,calls:[i],spent:i.cost})}return n},Ma=(e,o)=>{if(!e||e.length===0)return .025;let n=zs(e);if(n.length===0)return .025;let i=[];for(let a of n){let m=.025;if(i.length>0){let h=i[i.length-1],S=!1;if(i.length>=2){let T=i[i.length-2];h.ratio>=.8&&T.ratio>=.8&&(S=!0)}if(S)m=.015;else{let T=h.limit,w=h.ratio;w>=.8?m=T===.015?.015:T:w<.4?m=Math.min(.025,T+.005):w>=.4&&w<.6?m=Math.min(.025,T+.004):m=Math.min(.025,T+.002)}}let p=m>0?a.spent/m:0;i.push({limit:m,spent:a.spent,ratio:p})}let r=n[n.length-1];if(o<r.end)return i[i.length-1].limit;let l=i[i.length-1].limit,c=l,f=i[i.length-1].ratio,u=r.end,d=0;for(let a=i.length-1;a>=0&&i[a].ratio>=.8;a--)d++;for(;u<=o;){let a=.025;d>=2?a=.015:f>=.8?a=c===.015?.015:c:f<.4?a=Math.min(.025,c+.005):f>=.4&&f<.6?a=Math.min(.025,c+.004):a=Math.min(.025,c+.002),c=a,f=0,d=0,u+=36e5,l=a}return l},Aa=async e=>{let o=e.imageSettings||{keyType:"Default",quality:"Low-High"};if(o.keyType!=="Default")return!0;let n={Low:.001,"Low-High":.002,Medium:.008,"Medium-High":.01,High:.045,Ultra:.0488,Premium:.15}[o.quality]||.002,i=await In();i.imageCalls||(i.imageCalls=[]);let r=Date.now(),l=zs(i.imageCalls),c=0;if(l.length>0){let u=l[l.length-1];r>=u.start&&r<u.end&&(c=u.spent)}let f=Ma(i.imageCalls,r);return c+n<=f},ss=async()=>{let e=await In();e.imageCalls||(e.imageCalls=[]);let o=Date.now(),t=zs(e.imageCalls),n=[],i=0,r=0;if(t.length>0){let u=t[t.length-1];o>=u.start&&o<u.end&&(n=u.calls,i=u.spent,r=Math.max(0,Math.ceil((u.end-o)/(60*1e3))))}let l=Ma(e.imageCalls,o),c=Math.max(0,l-i),f=i;return{totalSpent:i,remaining:c,activeCallsCount:n.length,nextResetMin:r,reclaimCost:f,limit:l}},Oa=async e=>{let o=e.imageSettings||{keyType:"Default",quality:"Low-High"},n={Low:.001,"Low-High":.002,Medium:.008,"Medium-High":.01,High:.045,Ultra:.0488,Premium:.1}[o.quality]||.002,i=await In();i.imageCalls||(i.imageCalls=[]),i.imageCalls.push({timestamp:Date.now(),cost:n}),qs()}});import Mc from"puppeteer";var Js,La=ae(()=>{Zt();oo();Js=async e=>{let{query:o,limit:t=10}=ne(e);if(!o)return'ERROR: Missing "query" argument for web_search.';let n=3,i=null;for(let r=1;r<=n;r++){let l=null;try{l=await Mc.launch({headless:!0,args:["--no-sandbox","--disable-setuid-sandbox","--disable-gpu","--disable-dev-shm-usage"]});let c=await l.newPage();await c.setUserAgent("Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/148.0.7778.97 Safari/537.36"),await c.setViewport({width:1366,height:768});let f=r===1?Math.random()*1e3+500:Math.random()*2e3+1e3;await new Promise(m=>setTimeout(m,f));let u=`https://html.duckduckgo.com/html/?q=${encodeURIComponent(o)}`;await c.goto(u,{waitUntil:"networkidle2",timeout:18e4});let d=await c.$$eval(".result",(m,p)=>m.slice(0,p).map((h,S)=>{let T=h.querySelector(".result__a"),w=h.querySelector(".result__snippet"),I=T?T.href:"";I.includes("uddg=")&&(I=decodeURIComponent(I.split("uddg=")[1].split("&")[0]));let $=T?T.innerText.trim():"No Title",U=w?w.innerText.trim():"No Snippet";return`${S+1}. ${$}
|
|
273
|
+
Source: ${I}
|
|
274
|
+
Snippet: ${U}`}),t);if(d.length===0){if((await c.evaluate(()=>document.body.innerText)).includes("anomaly"))throw new Error("ANOMALY_DETECTED");return await l.close(),`No results found for query: [${o}].`}let a=d.join(`
|
|
278
275
|
|
|
279
276
|
`);return await l.close(),`Search results for [${o}]:
|
|
280
277
|
|
|
281
|
-
${a}`}catch(c){if(i=c,l&&await l.close(),r<n){let
|
|
278
|
+
${a}`}catch(c){if(i=c,l&&await l.close(),r<n){let f=Math.pow(2,r)*1e3;await new Promise(u=>setTimeout(u,f))}}}return`ERROR: Search failed after ${n+1} attempts. Last error: ${i.message}`}});import Ac from"puppeteer";var Qs,Da=ae(()=>{oo();Qs=async e=>{let o=e.match(/url\s*=\s*["'](.*)["']/),t=o?o[1]:e,n=3,i=null;for(let r=1;r<=n;r++){let l=null;try{l=await Ac.launch({headless:!0,args:["--no-sandbox","--disable-setuid-sandbox","--disable-gpu","--disable-dev-shm-usage"]});let c=await l.newPage();await c.setUserAgent("Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/148.0.7778.97 Safari/537.36"),await c.setViewport({width:1366,height:768});let f=r===1?Math.random()*1e3+500:Math.random()*2e3+1e3;await new Promise(a=>setTimeout(a,f)),await c.goto(t,{waitUntil:"networkidle2",timeout:18e4}),await new Promise(a=>setTimeout(a,5e3));let u=await c.evaluate(()=>{document.querySelectorAll("script, style, nav, footer, header, noscript, svg, canvas, iframe, ad, .ads, link, meta, img").forEach(T=>T.remove());let m=document.createNodeIterator(document.body,NodeFilter.SHOW_COMMENT),p;for(;p=m.nextNode();)p.remove();document.querySelectorAll("*").forEach(T=>{let w=T.attributes;for(let I=w.length-1;I>=0;I--){let $=w[I].name;$!=="href"&&$!=="src"&&T.removeAttribute($)}(T.tagName==="SPAN"||T.tagName==="DIV"||T.tagName==="SECTION")&&T.attributes.length===0&&(T.tagName==="SPAN"||T.tagName==="DIV"&&T.childNodes.length===1&&T.childNodes[0].nodeType===Node.TEXT_NODE)&&T.replaceWith(...T.childNodes)});let S=()=>{let T=!1;document.querySelectorAll("*:not(br)").forEach(w=>{w.childNodes.length===0&&!w.innerText.trim()&&(w.remove(),T=!0)}),T&&S()};return S(),document.body.innerHTML});if(!u)throw new Error("EMPTY_RENDER_RESULT");let d=u.replace(/\s+/g," ").replace(/>\s+</g,"><").trim().substring(0,3e4);return await l.close(),`CLEANED HTML FROM [${t}]:
|
|
282
279
|
|
|
283
|
-
${
|
|
280
|
+
${d}${u.length>3e4?`
|
|
284
281
|
|
|
285
|
-
[TRUNCATED AT 30K CHARS]`:""}`}catch(c){if(i=c,l&&await l.close(),r<n){let
|
|
282
|
+
[TRUNCATED AT 30K CHARS]`:""}`}catch(c){if(i=c,l&&await l.close(),r<n){let f=Math.pow(2,r)*1e3;await new Promise(u=>setTimeout(u,f))}}}return`ERROR: Scrape failed after ${n+1} attempts. Last error: ${i.message}`}});var Oc,Zs,va=ae(()=>{Do();oo();Oc=4*(1024*2),Zs=async(e,o={})=>{let t=d=>{let a=new RegExp(`${d}\\s*[:=]\\s*(["'])(.*?)\\1(?=\\s*[,)]|\\s+\\w+\\s*[:=]|$)`,"s"),m=e.match(a);if(m)return m[2].trim();let p=new RegExp(`${d}\\s*[:=]\\s*([^,\\s)]+)`,"s"),h=e.match(p);return h?h[1].trim():null},n=t("action"),i=t("method"),r=t("content"),l=t("content-new"),c=t("content-old"),f=t("id"),u=t("chat-id")||o.chatId||o.sessionId||"default-session";if(n==="temp"){if(!r)return"ERROR: Missing 'content' for temp memory.";let d=ye(ho,{});d[u]||(d[u]=[]),d[u].push(r),ke(ho,d);let a=d[u].reduce((m,p)=>m+p.length,0);return`SUCCESS: Temporary context saved for session [${u}]. (Size: ${a} chars)`}if(n==="user"){let d=ye(Bt,[]).map(a=>(a.score===void 0&&(a.score=.5),a));if(i==="add"){if(!r)return"ERROR: Missing 'content' for memory addition.";let a=new Date,m=`${a.getDate()}/${a.getMonth()+1}/${a.getFullYear()}`,p=r.includes("[Saved on:")?r:`${r.trim()} [Saved on: ${m}]`,h=Oc,S=d.reduce(($,U)=>$+(U.memory?.length||0),0);for(;d.length>0&&S+p.length>h;){let $=d.shift();S-=$.memory?.length||0}let T=t("score"),w=T?parseFloat(T):.5,I={id:`mem-${Date.now().toString(36)}`,memory:p,score:Math.min(2,isNaN(w)?.5:w)};return d.push(I),ke(Bt,d),`SUCCESS: Memory added with ID [${I.id}] and score [${I.score}]. (Vault Size: ${S+p.length} chars)`}if(i==="update"){let a=f||c,m=l||r;if(!a||!m)return"ERROR: Missing 'id' or content for update.";let p=d.findIndex(w=>w.id===a);if(p===-1)return`ERROR: Memory ID [${a}] not found.`;let h=new Date,S=`${h.getDate()}/${h.getMonth()+1}/${h.getFullYear()}`,T=m.includes("[Saved on:")?m:`${m.trim()} [Saved on: ${S}]`;return d[p].memory=T,ke(Bt,d),`SUCCESS: Memory [${a}] updated.`}if(i==="delete"){let a=f||r;if(!a)return"ERROR: Missing 'id' for deletion.";let m=d.length,p=d.filter(h=>h.id!==a);return p.length===m?`ERROR: Memory ID [${a}] not found.`:(ke(Bt,p),`SUCCESS: Memory [${a}] deleted.`)}return`ERROR: Invalid method [${i}] for user memory. Use 'add', 'update', or 'delete'.`}return`ERROR: Unknown action [${n}] for memory tool.`}});var ei,$a=ae(()=>{Sr();Zt();ei=async(e,o={})=>{let t=ne(e).title,n=o.chatId||o.sessionId;if(!n)return"ERROR: No active chatId found in tool context.";if(!t)return"ERROR: Missing 'title' argument.";try{return await wa(n,t),`SUCCESS: Chat title updated to [${t}] for session [${n}].`}catch(i){return`ERROR: Failed to update chat title: ${i.message}`}}});import as from"fs";import Fa from"path";var ti,Pa=ae(()=>{Zt();ti=async(e,o={})=>{let{path:t,StartLine:n,EndLine:i,start_line:r,end_line:l,startLine:c,endLine:f}=ne(e),u=parseInt(n||r||c),d=parseInt(i||l||f),a=u||1,m=d||(u?u+800:800);if(!t)return'ERROR: Missing "path" argument for view_file.';let p=Fa.resolve(process.cwd(),t);try{if(!as.existsSync(p))return`ERROR: File [${t}] does not exist.`;if(as.statSync(p).isDirectory())return`ERROR: Path [${t}] is a directory. Use list_files instead.`;let S=Fa.extname(t).toLowerCase();if([".mp4",".mkv",".avi",".mov",".webm",".flv",".wmv",".mpeg",".mpg"].includes(S))return`ERROR: Unable to read. Type ${S.slice(1).toUpperCase()} not supported`;let w={".pdf":"application/pdf",".jpg":"image/jpeg",".jpeg":"image/jpeg",".png":"image/png",".webp":"image/webp",".docx":"application/vnd.openxmlformats-officedocument.wordprocessingml.document",".doc":"application/msword"};if(w[S]){if(!(o.isMultiModal!==!1))return`ERROR: Multimodality is not supported for the current model. Unable to load [${t}].`;let Z=as.readFileSync(p).toString("base64"),X=w[S];return{text:`[BINARY FILE]: ${t} (${X}) - Loaded as multimodal part.`,binaryPart:{inlineData:{data:Z,mimeType:X}}}}let I=as.readFileSync(p,"utf8");I.startsWith("\uFEFF")&&(I=I.slice(1)),I=I.replace(/\r\n/g,`
|
|
286
283
|
`).replace(/\r/g,`
|
|
287
|
-
`);let
|
|
288
|
-
`),
|
|
289
|
-
`);return`${
|
|
284
|
+
`);let $=I.split(`
|
|
285
|
+
`),U=$.length,K=Math.max(0,a-1),P=Math.min(U,m),k=$.slice(K,P),O=`File: [${t}] (Showing lines ${K+1}-${P} of ${U}).`,D=k.map((Q,G)=>`${String(K+G+1).padStart(4)}: ${Q}`).join(`
|
|
286
|
+
`);return`${O}
|
|
290
287
|
|
|
291
|
-
${
|
|
288
|
+
${D}`}catch(h){return`ERROR: Failed to read file [${t}]: ${h.message}`}}});import er from"fs";import Ba from"path";var oi,Na=ae(()=>{Zt();an();oi=async(e,o={})=>{let{path:t,content:n}=ne(e);if(!t)return'ERROR: Missing "path" argument for write_file.';if(n===void 0)return'ERROR: Missing "content" argument for write_file.';n=n.replace(/^```[\w]*\n?/,"").replace(/```\s*$/,"").replace(/\r\n/g,`
|
|
292
289
|
`).replace(/\r/g,`
|
|
293
|
-
`);let i=
|
|
294
|
-
${
|
|
290
|
+
`);let i=Ba.resolve(process.cwd(),t),r=Ba.dirname(i);try{await bt.recordFileChange(i);let l="";if(er.existsSync(i))try{l=`Old File contents:
|
|
291
|
+
${er.readFileSync(i,"utf8").split(/\r?\n/).map((I,$)=>`${$+1} | ${I}`).join(`
|
|
295
292
|
`)}
|
|
296
293
|
|
|
297
294
|
`}catch{l=`[Note: Could not read existing file for reversal reference]
|
|
298
295
|
|
|
299
|
-
`}
|
|
296
|
+
`}er.existsSync(r)||er.mkdirSync(r,{recursive:!0});let f=(T=>T.replace(/^```[\w]*\n?/,"").replace(/```\s*$/,"").replace(/\r\n/g,`
|
|
300
297
|
`).replace(/\r/g,`
|
|
301
|
-
`))(n),
|
|
302
|
-
`);else{let
|
|
303
|
-
`),
|
|
304
|
-
`);
|
|
298
|
+
`))(n),u=f.split(/\r?\n/).length,d=Buffer.byteLength(f,"utf8");er.writeFileSync(i,f,"utf8");let a=er.readFileSync(i,"utf8"),m=Buffer.byteLength(a,"utf8"),p=a.split(/\r?\n/),h=p.length;if(m===0&&d>0)return a=null,`ERROR: CRITICAL FAILURE: Verification failed. File [${t}] is empty on disk despite success report!`;let S="";if(h<=200)S=p.join(`
|
|
299
|
+
`);else{let T=p.slice(0,100).join(`
|
|
300
|
+
`),w=p.slice(-100).join(`
|
|
301
|
+
`);S=`${T}
|
|
305
302
|
|
|
306
303
|
... [${h-200} lines truncated] ...
|
|
307
304
|
|
|
308
|
-
${
|
|
305
|
+
${w}`}return a=null,`SUCCESS: File [${t}] saved.
|
|
309
306
|
|
|
310
|
-
- Stats: [${h} lines, ${(
|
|
307
|
+
- Stats: [${h} lines, ${(m/1024).toFixed(1)} KB]
|
|
311
308
|
${l}- Content Preview:
|
|
312
|
-
${
|
|
309
|
+
${S}
|
|
313
310
|
|
|
314
|
-
Check if Starting and Ending matches your write.`}catch(l){return`ERROR: Failed to write file [${t}]: ${l.message}`}}});import
|
|
311
|
+
Check if Starting and Ending matches your write.`}catch(l){return`ERROR: Failed to write file [${t}]: ${l.message}`}}});import ni from"fs";import Lc from"path";var ri,_a=ae(()=>{Zt();an();Bn();ri=async(e,o={})=>{let t=ne(e),n=t.path;if(!n)return'ERROR: Missing "path" argument for update_file.';let{patchPairs:i,error:r}=Wr(t);if(r)return`ERROR: ${r}`;if(i.length===0)return"ERROR: No valid replacement pairs found. Use replaceContent1, newContent1, etc.";let l=Lc.resolve(process.cwd(),n);try{if(!ni.existsSync(l))return`ERROR: File [${n}] does not exist. Use write_file instead.`;let c=o.forcedContent||ni.readFileSync(l,"utf8");c.startsWith("\uFEFF")&&(c=c.slice(1));let f=c.replace(/\r\n/g,`
|
|
315
312
|
`).replace(/\r/g,`
|
|
316
|
-
`),{content:
|
|
317
|
-
${a.map(
|
|
318
|
-
`)}`;await
|
|
313
|
+
`),{content:u,results:d}=Hr(f,i),a=d.filter(h=>!h.success),m=d.filter(h=>h.success);if(m.length===0)return`ERROR: Patch Failed to apply to [${n}].
|
|
314
|
+
${a.map(h=>` \u2022 ${h.error}`).join(`
|
|
315
|
+
`)}`;await bt.recordFileChange(l,f),ni.writeFileSync(l,u,"utf8");let p=Yr(f,u,d,12);return a.length>0?`SUCCESS: File [${n}] updated with some blocks failed. [${m.length}/${i.length}] blocks applied.
|
|
316
|
+
|
|
317
|
+
Failures:
|
|
318
|
+
${a.map(h=>` \u2022 ${h.error}`).join(`
|
|
319
|
+
`)}
|
|
320
|
+
|
|
321
|
+
${p}`:`SUCCESS: File [${n}] updated. [${d.length}/${i.length}] blocks applied.
|
|
319
322
|
|
|
320
|
-
${
|
|
321
|
-
`),
|
|
323
|
+
${p}`}catch(c){return`ERROR: Failed to update file [${n}]: ${c.message}`}}});import ls from"fs";import Ua from"path";var si,Ra=ae(()=>{Zt();si=async e=>{let{path:o="."}=ne(e),t=Ua.resolve(process.cwd(),o);try{if(!ls.existsSync(t))return`ERROR: Path [${o}] does not exist.`;if(!ls.statSync(t).isDirectory())return`ERROR: Path [${o}] is a file, not a directory. Use view_file instead.`;let i=ls.readdirSync(t),r=i.length,l=100,c=i.slice(0,l),f=[];for(let m of c){let p=Ua.join(t,m),h="\u{1F4C4}",S={name:m,type:"unknown",size:"N/A",mtime:"N/A"};try{let T=ls.statSync(p);S={name:m,type:T.isDirectory()?"directory":"file",size:(T.size/1024).toFixed(1)+" KB",mtime:T.mtime.toLocaleString()}}catch{S.type="inaccessible"}f.push(S)}let u=f.map(m=>{let p=m.type==="directory"?"\u{1F4C1}":m.type==="file"?"\u{1F4C4}":"\u2753";return m.type==="directory"?`${p} ${m.name} - [DIR] - [Modified: ${m.mtime}]`:`${p} ${m.name} - [Size: ${m.size}] - [Modified: ${m.mtime}]`}).join(`
|
|
324
|
+
`),d=`
|
|
322
325
|
|
|
323
|
-
(Total items in folder: ${r})`;r>l&&(
|
|
326
|
+
(Total items in folder: ${r})`;r>l&&(d=`
|
|
324
327
|
|
|
325
328
|
\u26A0\uFE0F TRUNCATED: Showing first ${l} of ${r} items.`);let a=`Detailed folder stats for [${o}]:
|
|
326
329
|
|
|
327
|
-
${
|
|
330
|
+
${u}${d}`;return i.length=0,c.length=0,f.length=0,a}catch(n){return`ERROR: Failed to read folder [${o}]: ${n.message}`}}});var ii,Wa=ae(()=>{Zt();ii=async(e,o)=>{let t=ne(e),{question:n}=t;if(!n)return'ERROR: Missing "question" argument for ask.';if(!o.onAskUser)return"ERROR: onAskUser callback not provided in tool context.";let i=[];Object.keys(t).forEach(r=>{if(r.startsWith("option")){let l=t[r];if(typeof l=="string"&&l.includes("::")){let[c,f]=l.split("::");i.push({id:r,label:c.trim(),description:f.trim()})}else i.push({id:r,label:String(l).trim(),description:""})}});try{return`USER CHOOSE: ${await o.onAskUser(n,i)}`}catch(r){return`ERROR: Failed to get user input: ${r.message}`}}});import Dc from"puppeteer";import tr from"path";import Wn from"fs-extra";import{PDFDocument as vc}from"pdf-lib";var ai,Ha=ae(()=>{Zt();an();ai=async e=>{let{path:o,content:t,orientation:n="portrait",margin:i="0px"}=ne(e);if(!o)return'ERROR: Missing "path" argument for write_pdf.';if(!t)return'ERROR: Missing "content" (HTML/CSS) for write_pdf.';let r=tr.resolve(process.cwd(),o),l=null;try{await Wn.ensureDir(tr.dirname(r)),await bt.recordFileChange(r),l=await Dc.launch({headless:!0,args:["--no-sandbox","--disable-setuid-sandbox","--disable-gpu","--disable-dev-shm-usage"]});let c=await l.newPage(),f=t,u={},d=async P=>{if(!P||P.startsWith("http://")||P.startsWith("https://")||P.startsWith("data:"))return null;try{let k=tr.resolve(process.cwd(),P);if(await Wn.pathExists(k)){let O=tr.extname(k).toLowerCase().replace(".","")||"png",D=O==="jpg"?"jpeg":O==="svg"?"svg+xml":O,Q=await Wn.readFile(k,"base64");return`data:image/${D};base64,${Q}`}}catch{}return null},a=/<link[^>]+href=["']([^"']+)["']/gi,m={},p;for(;(p=a.exec(t))!==null;){let P=p[1],k=p[0];if(P&&k.toLowerCase().includes("stylesheet")&&!P.startsWith("http://")&&!P.startsWith("https://")&&!P.startsWith("data:"))try{let O=tr.resolve(process.cwd(),P);if(await Wn.pathExists(O)){let D=await Wn.readFile(O,"utf-8");m[k]=`<style>${D}</style>`}}catch{}}for(let[P,k]of Object.entries(m))f=f.split(P).join(k);let h=/<img[^>]+src=["']([^"']+)["']/gi;for(;(p=h.exec(f))!==null;){let P=p[1];if(P&&!u[P]){let k=await d(P);k&&(u[P]=k)}}let S=/url\(\s*['"]?([^'")]+?)['"]?\s*\)/gi;for(;(p=S.exec(f))!==null;){let P=p[1].trim();if(P&&!u[P]){let k=await d(P);k&&(u[P]=k)}}for(let[P,k]of Object.entries(u)){let O=P.replace(/[-\/\\^$*+?.()|[\]{}]/g,"\\$&"),D=new RegExp(`(src=["'])(${O})(["'])`,"gi");f=f.replace(D,`$1${k}$3`);let Q=new RegExp(`url\\(\\s*(['"]?)(${O})\\1\\s*\\)`,"gi");f=f.replace(Q,`url($1${k}$1)`)}let T=`
|
|
328
331
|
<style>
|
|
329
332
|
@page {
|
|
330
333
|
margin: ${i};
|
|
@@ -353,8 +356,8 @@ ${d}${u}`;return i.length=0,c.length=0,m.length=0,a}catch(n){return`ERROR: Faile
|
|
|
353
356
|
}
|
|
354
357
|
</style>
|
|
355
358
|
<div class="watermark">Generated by FluxFlow CLI (AI)</div>
|
|
356
|
-
${
|
|
357
|
-
`;await c.setContent(
|
|
359
|
+
${f}
|
|
360
|
+
`;await c.setContent(T,{waitUntil:"networkidle0",timeout:18e4});let w=await c.pdf({format:"A4",landscape:String(n).toLowerCase()==="landscape",margin:{top:i,right:i,bottom:i,left:i},printBackground:!0}),I=await vc.load(w),$=tr.basename(o);I.setTitle(`FluxFlow_${$}`),I.setAuthor("FluxFlow CLI"),I.setSubject("Generated with Agentic AI System"),I.setKeywords(["FluxFlow","AI","Agentic","Automated"]),I.setCreator("FluxFlow PDF Engine"),I.setProducer("FluxFlow (Generative AI)");let U=await I.save();await Wn.writeFile(r,U);let K=await Wn.stat(r);return`SUCCESS: PDF generated successfully at [${o}] (${(K.size/1024).toFixed(2)} KB).`}catch(c){return`ERROR: Failed to generate PDF [${o}]: ${c.message}`}finally{l&&await l.close()}}});import Ya from"fs-extra";import li from"path";import $c from"html-to-docx";var ci,ja=ae(()=>{Zt();an();ci=async e=>{let{path:o,content:t}=ne(e);if(!o)return'ERROR: Missing "path" argument for write_docx.';if(!t)return'ERROR: Missing "content" (HTML) for write_docx.';let n=li.resolve(process.cwd(),o);try{await Ya.ensureDir(li.dirname(n)),await bt.recordFileChange(n);let i=li.basename(o),r=t.includes("<html")?t:`
|
|
358
361
|
<!DOCTYPE html>
|
|
359
362
|
<html lang="en">
|
|
360
363
|
<head>
|
|
@@ -365,29 +368,29 @@ ${d}${u}`;return i.length=0,c.length=0,m.length=0,a}catch(n){return`ERROR: Faile
|
|
|
365
368
|
${t}
|
|
366
369
|
</body>
|
|
367
370
|
</html>
|
|
368
|
-
`,l=await
|
|
369
|
-
- Size: ${(l.length/1024).toFixed(1)} KB`}catch(i){return`ERROR: Failed to generate DOCX [${o}]: ${i.message}`}}});import
|
|
370
|
-
|
|
371
|
-
`;return u
|
|
372
|
-
`),u}catch(r){return`ERROR: ${r.message}`}}});import Cr from"fs-extra";import di from"path";var Jn,kr,Lc,Wn,ui=ie(()=>{to();vo();Jn={mode:"Flux",thinkingLevel:"Medium",aiProvider:"Google",activeModel:"gemma-4-31b-it",showFullThinking:!0,apiTier:"Free",quotas:{agentLimit:999999,backgroundLimit:999999,searchLimit:100,customModelId:"",customLimit:0},systemSettings:{memory:!0,compression:0,autoExec:!1,allowExternalAccess:!1,autoDeleteHistory:"7d",useExternalData:!1,externalDataPath:""},profileData:{name:null,nickname:null,instructions:null},imageSettings:{keyType:"Default",quality:"Low-High",apiKey:""}},kr=async()=>{let e={...Jn};try{if(await Cr.exists(Zt)){let o=Kr(Zt);if(o.imageSettings&&o.imageSettings.apiKey)try{let t=o.imageSettings.apiKey,{saveSecret:n}=await Promise.resolve().then(()=>(Sr(),Zr));await n("POLLINATIONS_API_KEY",t),o.imageSettings.apiKey="",qr(Zt,o)}catch{}e={...Jn,...o,quotas:{...Jn.quotas,...o.quotas},systemSettings:{...Jn.systemSettings,...o.systemSettings},profileData:{...Jn.profileData,...o.profileData},imageSettings:{...Jn.imageSettings,...o.imageSettings}}}}catch(o){console.error("Failed to load settings:",o)}try{let{getSecret:o}=await Promise.resolve().then(()=>(Sr(),Zr)),t=await o("POLLINATIONS_API_KEY");t&&(e.imageSettings.apiKey=t)}catch{}if(e.showFullThinking===!1){e.showFullThinking=!0;try{qr(Zt,e)}catch{}}return e},Lc=async e=>{let{FLUXFLOW_DIR:o}=await Promise.resolve().then(()=>(to(),sa)),t=["logs","secret"];for(let n of t){let i=di.join(o,n),r=di.join(e,n);try{await Cr.exists(i)&&(await Cr.ensureDir(r),await Cr.copy(i,r,{overwrite:!0}))}catch(l){console.error(`Migration failed for ${n}:`,l)}}},Wn=async e=>{try{let o=await kr();if(!o.systemSettings.useExternalData&&e.systemSettings?.useExternalData&&e.systemSettings?.externalDataPath&&await Lc(e.systemSettings.externalDataPath),e.imageSettings&&e.imageSettings.apiKey!==void 0){let{saveSecret:n,removeSecret:i}=await Promise.resolve().then(()=>(Sr(),Zr)),r=e.imageSettings.apiKey;r?await n("POLLINATIONS_API_KEY",r):await i("POLLINATIONS_API_KEY")}let t={...o,...e};return t.imageSettings&&(t.imageSettings={...t.imageSettings,apiKey:""}),await Cr.ensureDir(di.dirname(Zt)),qr(Zt,t),!0}catch(o){return console.error("Failed to save settings:",o),!1}}});var Ha,ja=ie(()=>{Ha="pk_oH8wkUdQaQK1cmst"});import Ga from"fs-extra";import mi from"path";var Dc,fi,Xa=ie(()=>{Qt();ui();ns();ja();an();Dc=(e,o={})=>{try{if(e.length<8||e[0]!==137||e[1]!==80||e[2]!==78||e[3]!==71)return e;let t=[],n=[];for(let l=0;l<256;l++){let c=l;for(let m=0;m<8;m++)c&1?c=3988292384^c>>>1:c=c>>>1;n[l]=c}let i=l=>{let c=4294967295;for(let m=0;m<l.length;m++)c=n[(c^l[m])&255]^c>>>8;return(c^4294967295)>>>0},r=(l,c)=>{let m=Buffer.from(l,"ascii"),d=Buffer.from(c,"utf-8"),u=m.length+1+d.length,a=Buffer.alloc(8+u+4);a.writeUInt32BE(u,0),a.write("tEXt",4,"ascii"),m.copy(a,8),a[8+m.length]=0,d.copy(a,8+m.length+1);let f=i(a.subarray(4,8+u));return a.writeUInt32BE(f,8+u),a};for(let[l,c]of Object.entries(o))c!=null&&t.push(r(l,String(c)));if(t.length===0)return e;if(e.subarray(12,16).toString("ascii")==="IHDR"){let c=e.subarray(0,33),m=e.subarray(33);return Buffer.concat([c,...t,m])}return e}catch{return e}},fi=async(e,o={})=>{let t=oe(e),n=t.prompt||t.text,i=t.path||t.outputPath||t.output||"generated_image.png",r=t.ratio;if(!n)return'ERROR: Missing "prompt" argument for generate_image.';let l=["nsfw","naked","nudity","nude","porn","sex","xxx","erotic","gore","bloody","violence","abuse","suicide","murder","hentai","pedophile","rape"],c=n.toLowerCase();if(l.some(d=>c.includes(d)))return"ERROR: Prompt blocked by system safety filter (inappropriate or unsafe content detected).";try{let d=await kr();if(!await Ca(d))return`ERROR: Insufficient Quota for selected quality. Either tell user reduce quality or wait for next refresh cycle (${(await os()).nextResetMin||60}m).`;let a=d.imageSettings||{keyType:"Default",quality:"Low-High",apiKey:""},f=a.keyType==="Custom"&&a.apiKey?a.apiKey:Ha,h={Low:"flux","Low-High":"zimage",Medium:"gptimage","Medium-High":"gptimage",High:"qwen-image",Ultra:"gptimage-large",Premium:"nanobanana-pro"}[a.quality]||"zimage",T=1024,w=1024;if(r){let G=r.replace(/\s+/g,"");G==="16:9"?(T=1024,w=576):G==="9:16"?(T=576,w=1024):G==="4:3"?(T=1024,w=768):G==="3:4"?(T=768,w=1024):G==="1:1"&&(T=1024,w=1024)}let E=Math.floor(Math.random()*1e7),D=`https://gen.pollinations.ai/image/${encodeURIComponent(n)}?model=${h}&width=${T}&height=${w}&seed=${E}&enhance=true&reasoning=high&quality=high&negative=${encodeURIComponent("deformed, distorted, disfigured, poorly drawn, bad anatomy, wrong anatomy, extra limb, missing limb, floating limbs, disconnected limbs, mutation, mutated hands and fingers, blurry, low quality, low resolution, extra fingers, censored, watermarks, signatures")}`,_=await fetch(D,{method:"GET",headers:{Authorization:`Bearer ${f}`}});if(!_.ok){let G=_.status,Pe="";try{Pe=await _.text()}catch{}return G===402||Pe.includes("Insufficient balance")||Pe.includes("PAYMENT_REQUIRED")?"ERROR: Image Generation Currently unavailable. Try again later.":`ERROR: Image Generation failed with status [${G}]: ${Pe||"Unknown API Error"}`}if((_.headers.get("content-type")||"").includes("application/json")){let G=await _.json();return G.status===402||G.error&&G.error.code==="PAYMENT_REQUIRED"?"ERROR: Image Generation Currently unavailable. Try again later.":`ERROR: Image Generation failed: ${G.error?.message||JSON.stringify(G)}`}let F=await _.arrayBuffer(),I=Buffer.from(F),A={Title:n,Description:"Generated via FluxFlow CLI",Software:"FluxFlow CLI",Author:"FluxFlow","Creation Time":new Date().toISOString(),Prompt:n,Model:`Fluxflow:${h}`,Ratio:r||"1:1",Seed:String(E)};I=Dc(I,A);let v=mi.resolve(process.cwd(),i);await Ga.ensureDir(mi.dirname(v)),await Et.recordFileChange(v),await Ga.writeFile(v,I),await ka(d);let J=mi.extname(i).toLowerCase(),le={".jpg":"image/jpeg",".jpeg":"image/jpeg",".png":"image/png",".webp":"image/webp"}[J]||"image/png";return o.isMultiModal!==!1?{text:`SUCCESS: Image successfully generated from prompt [${n}] and saved to [${i}]. Output attached to multimodal part`,binaryPart:{inlineData:{data:I.toString("base64"),mimeType:le}}}:`SUCCESS: Image successfully generated from prompt [${n}] and saved to [${i}].`}catch(d){return`ERROR: Failed during image generation: ${d.message}`}}});var Ir,Ka=ie(()=>{vo();to();Ir=async(e,o={})=>{let t=r=>{let l=new RegExp(`${r}\\s*[:=]\\s*(["'])(.*?)\\1(?=\\s*[,)]|\\s+\\w+\\s*[:=]|$)`,"s"),c=e.match(l);return c?c[2].trim():null},n=t("id"),i=t("summary");if(!n||!i)return"ERROR: Missing 'id' or 'summary' for saveSummary tool.";try{let r=we(mo,{}),l=we(_o,{});return l[n]=i,delete r[n],ke(_o,l),ke(mo,r),`SUCCESS: Saved summary and purged raw memories for chat [${n}].`}catch(r){return`ERROR: Failed to save summary for chat [${n}]: ${r.message}`}}});var Qn,qa=ie(()=>{vo();to();Qn=async(e,o={})=>{let n=(i=>{let r=new RegExp(`${i}\\s*[:=]\\s*(["'])(.*?)\\1(?=\\s*[,)]|\\s+\\w+\\s*[:=]|$)`,"s"),l=e.match(r);return l?l[2].trim():null})("id");if(!n)return"ERROR: Missing 'id' parameter for addMemScore tool.";try{let i=we(Ft,[]),r=!1,l=[];for(let u of i)u.score===void 0&&(u.score=.5),u.id===n?(u.score=Math.min(2,u.score+.2),r=!0):(u.score*=.98,u.score<.05&&(u.score=0)),u.score=Math.round(u.score*1e5)/1e5,u.score>0&&l.push(u);if(ke(Ft,l),!r)return`WARNING: Memory ID [${n}] not found. Other memories decayed by -0.01.`;let c=l.find(u=>u.id===n),m=c?c.score.toFixed(2):"deleted (score <= 0)",d=i.length-l.length;return`SUCCESS: Adjusted memory scores. Target [${n}] is now ${m}.${d>0?` Purged ${d} decayed memories.`:""}`}catch(i){return`ERROR: Failed to adjust memory score for [${n}]: ${i.message}`}}});var vc,is,Va=ie(async()=>{Ia();Ma();Oa();Aa();Da();$a();Pa();await xr();Ba();_a();Na();Ra();Ya();Xa();Ka();qa();vc={web_search:Vs,web_scrape:zs,memory:Js,chat:Qs,view_file:Zs,write_file:ei,update_file:oi,exec_command:Ls,read_folder:ni,write_pdf:si,write_docx:ai,search_keyword:ci,generate_image:fi,saveSummary:Ir,addMemScore:Qn,ask:ri,Ask:ri,WebSearch:Vs,WebScrape:zs,ReadFile:Zs,ReadFolder:ni,WriteFile:ei,PatchFile:oi,WritePDF:si,WriteDoc:ai,Run:Ls,SearchKeyword:ci,Memory:Js,Chat:Qs,GenerateImage:fi,saveSumary:Ir,SaveSummary:Ir,SaveSumary:Ir,add_mem_score:Qn,AddMemScore:Qn,addMemoryScore:Qn,AddMemoryScore:Qn},is=async(e,o,t={})=>{if(t.mode&&t.mode.toLowerCase()==="flow"){let i=e.toLowerCase();if(!(i.startsWith("web")||i.startsWith("ask")))return`ERROR: Tool [${e}] is restricted in Flow mode.`}let n=vc[e];if(!n)return`ERROR: Tool [${e}] not found in registry.`;try{return await n(o,t)}catch(i){return`ERROR: Execution failed for [${e}]: ${i.message}`}}});import{WebSocket as as}from"ws";var ao,Zn,$c,pi,er,za,hi,Ja,ls,Ro,cs,Mr,Qa,gi,Za,xi=ie(()=>{ao=null,Zn=!1,$c="ws://localhost:56832",pi=[],er=null,za="2.0.0",hi=e=>{za=e,Ja()},Ja=()=>{if(ao||Zn)return;Zn=!0;let e=new as($c);e.on("open",()=>{for(ao=e,Zn=!1,ao.send(JSON.stringify({command:"version",version:za,pid:process.pid,ppid:process.ppid}));pi.length>0;)ao.send(JSON.stringify(pi.shift()))}),e.on("message",o=>{try{let t=JSON.parse(o.toString());t.command==="contextResponse"&&er&&(er(t.data),er=null)}catch{}}),e.on("error",()=>{Zn=!1,ao=null}),e.on("close",()=>{Zn=!1,ao=null})},ls=e=>{ao&&ao.readyState===as.OPEN?ao.send(JSON.stringify(e)):(pi.push(e),Zn||Ja())},Ro=()=>ao!==null&&ao.readyState===as.OPEN,cs=e=>{ls({command:"status",status:e})},Mr=()=>new Promise(e=>{if(!ao||ao.readyState!==as.OPEN){e({cursor_line:0,selected:0,manual_edits:"",file_focused:"none",opened_editors:[]});return}er=e,ao.send(JSON.stringify({command:"requestContext"})),setTimeout(()=>{er===e&&(e({cursor_line:0,selected:0,manual_edits:"",file_focused:"none",opened_editors:[]}),er=null)},1e3)}),Qa=e=>{ls({command:"open",filePath:e})},gi=(e,o,t)=>{ls({command:"showDiff",filePath:e,originalContent:o,modifiedContent:t})},Za=(e,o)=>{ls({command:"closeDiff",filePath:e,result:o})}});import{GoogleGenAI as Pc,ThinkingLevel as Wo,HarmBlockThreshold as bn,HarmCategory as Cn}from"@google/genai";import Ie from"path";import Bt from"fs";var or,tr,Fc,yi,Bc,ol,Ti,Si,nl,el,_c,rl,Nc,sl,Uc,tl,Ei,Or,wi,Rc,il,al=ie(async()=>{await fa();Er();ns();await Va();vo();Qt();hn();Pn();to();an();xi();or=null,tr=!1,Fc=["google/gemma-4-31b-it:free","moonshotai/kimi-k2.6:free","google/gemini-3.5-flash","qwen/qwen3.7-plus","minimax/minimax-m3","anthropic/claude-sonnet-4.5","anthropic/claude-opus-4.6","anthropic/claude-opus-4.8","openai/gpt-5.2-codex","openai/gpt-5.2-pro","openai/gpt-5.5-pro","moonshotai/kimi-k2.6","gemma-4-31b-it","gemini-2.5-flash","gemini-3-flash-preview","gemini-3.5-flash","gemini-3.1-flash-lite","gemini-3.1-pro-preview"],yi=e=>{if(!e)return!1;let o=e.toLowerCase();return o.startsWith("gemini-")||o.startsWith("gemma-")?!0:Fc.some(t=>t.toLowerCase()===o)},Bc=e=>typeof e!="string"?e:e.replace(/[\u001b\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g,""),ol=async(e,o,t=5,n=1e3)=>{for(let i=0;i<t;i++){try{let r=await fetch(e,o);if(r.ok||r.status!==429&&r.status<500)return r}catch(r){if(i===t-1)throw r}await new Promise(r=>setTimeout(r,n*Math.pow(2,i)))}return fetch(e,o)},Ti=async function*(e,o,t,n,i,r,l){let c=[];n&&c.push({role:"system",content:n});for(let E of t){let k=E.role==="user"?"user":"assistant",D=[];if(Array.isArray(E.parts)){for(let _ of E.parts)if(_.text)D.push({type:"text",text:_.text});else if(_.inlineData&&l){let K=_.inlineData.mimeType,F=_.inlineData.data;K.startsWith("image/")&&D.push({type:"image_url",image_url:{url:`data:${K};base64,${F}`}})}}else{let _=E.text||"";_&&D.push({type:"text",text:_})}c.push({role:k,content:D.length===1&&D[0].type==="text"?D[0].text:D})}let m={model:o,messages:c,stream:!0,stream_options:{include_usage:!0},temperature:r==="Flux"?1:1.4};if(i!=="Fast"){let E={Low:"high",Medium:"high",High:"high",xHigh:"max"};m.reasoning_effort=E[i]||"high",m.extra_body={thinking:{type:"enabled"}}}else m.extra_body={thinking:{type:"disabled"}};let d=await ol("https://api.deepseek.com/chat/completions",{method:"POST",headers:{Authorization:`Bearer ${e}`,"Content-Type":"application/json"},body:JSON.stringify(m)});if(!d.ok){let E=await d.json().catch(()=>({}));throw new Error(`DeepSeek Error (${d.status}): ${E.error?.message||d.statusText}`)}let u=d.body.getReader(),a=new TextDecoder,f="",p=[],h=null,T=Date.now(),w=!1;for(;;){let{done:E,value:k}=await u.read();if(E){w&&(p.length>0||h)&&(yield{candidates:p.length>0?[{content:{parts:p}}]:[],usageMetadata:h});break}f+=a.decode(k,{stream:!0});let D=f.split(`
|
|
373
|
-
`);
|
|
374
|
-
`);h=K.pop();for(let
|
|
375
|
-
`),
|
|
371
|
+
`,l=await $c(r,null,{title:`FluxFlow_${i}`,creator:"FluxFlow CLI",description:"Generated by Agentic AI System",table:{row:{cantSplit:!0}},footer:!0,pageNumber:!0});return await Ya.writeFile(n,l),`SUCCESS: Word document [${o}] generated successfully.
|
|
372
|
+
- Size: ${(l.length/1024).toFixed(1)} KB`}catch(i){return`ERROR: Failed to generate DOCX [${o}]: ${i.message}`}}});import di from"fs/promises";import Er from"path";async function Ga(e,o,t=e,n=1){if(n>12)return[];let i=[],r;try{r=await di.readdir(e,{withFileTypes:!0})}catch{return[]}for(let l of r){let c=Er.join(e,l.name),f=Er.relative(t,c),u=f.split(Er.sep).map(a=>a.toLowerCase());if(!o.some(a=>u.includes(a.toLowerCase())))if(l.isDirectory()){let a=await Ga(c,o,t,n+1);i=i.concat(a)}else l.isFile()&&i.push({fullPath:c,relativePath:f})}return i}var ui,Xa=ae(()=>{Zt();ui=async e=>{let{keyword:o,file:t}=ne(e);if(!o)return'ERROR: Missing "keyword" argument.';let n=["node_modules",".git","dist",".next",".gemini",".exe",".dll",".png",".jpg",".jpeg",".gif",".zip",".tgz"],i=150;try{let r=[],l=process.cwd();if(t){let a=Er.resolve(l,t);try{(await di.stat(a)).isFile()&&r.push({fullPath:a,relativePath:Er.relative(l,a)})}catch{return`ERROR: File not found: ${t}`}}else r=await Ga(l,n);let c=r.map(async a=>{try{let m=await di.readFile(a.fullPath,"utf-8");if(m.includes("\0"))return[];let p=m.split(/\r?\n/),h=[];for(let S=0;S<p.length;S++)if(p[S].includes(o)){let T=a.relativePath.replace(/\\/g,"/");h.push(`${T} \u2192 ${S+1}`)}return h}catch{return[]}}),u=(await Promise.all(c)).flat().slice(0,i);if(typeof global.gc=="function"&&global.gc(),u.length===0)return`Found 0 matches for keyword: "${o}"${t?` in file: ${t}`:". Try to specify files"}`;let d=`Found ${u.length} matches:
|
|
373
|
+
|
|
374
|
+
`;return d+=u.join(`
|
|
375
|
+
`),d}catch(r){return`ERROR: ${r.message}`}}});import br from"fs-extra";import mi from"path";var or,Cr,Fc,Hn,fi=ae(()=>{oo();Do();or={mode:"Flux",thinkingLevel:"Medium",aiProvider:"Google",activeModel:"gemma-4-31b-it",showFullThinking:!0,apiTier:"Free",quotas:{agentLimit:999999,backgroundLimit:999999,searchLimit:100,customModelId:"",customLimit:0},systemSettings:{memory:!0,compression:0,autoExec:!1,allowExternalAccess:!1,autoDeleteHistory:"7d",useExternalData:!1,externalDataPath:""},profileData:{name:null,nickname:null,instructions:null},imageSettings:{keyType:"Default",quality:"Low-High",apiKey:""}},Cr=async()=>{let e={...or};try{if(await br.exists(eo)){let o=zr(eo);if(o.imageSettings&&o.imageSettings.apiKey)try{let t=o.imageSettings.apiKey,{saveSecret:n}=await Promise.resolve().then(()=>(Tr(),os));await n("POLLINATIONS_API_KEY",t),o.imageSettings.apiKey="",Jr(eo,o)}catch{}e={...or,...o,quotas:{...or.quotas,...o.quotas},systemSettings:{...or.systemSettings,...o.systemSettings},profileData:{...or.profileData,...o.profileData},imageSettings:{...or.imageSettings,...o.imageSettings}}}}catch(o){console.error("Failed to load settings:",o)}try{let{getSecret:o}=await Promise.resolve().then(()=>(Tr(),os)),t=await o("POLLINATIONS_API_KEY");t&&(e.imageSettings.apiKey=t)}catch{}if(e.showFullThinking===!1){e.showFullThinking=!0;try{Jr(eo,e)}catch{}}return e},Fc=async e=>{let{FLUXFLOW_DIR:o}=await Promise.resolve().then(()=>(oo(),ca)),t=["logs","secret"];for(let n of t){let i=mi.join(o,n),r=mi.join(e,n);try{await br.exists(i)&&(await br.ensureDir(r),await br.copy(i,r,{overwrite:!0}))}catch(l){console.error(`Migration failed for ${n}:`,l)}}},Hn=async e=>{try{let o=await Cr();if(!o.systemSettings.useExternalData&&e.systemSettings?.useExternalData&&e.systemSettings?.externalDataPath&&await Fc(e.systemSettings.externalDataPath),e.imageSettings&&e.imageSettings.apiKey!==void 0){let{saveSecret:n,removeSecret:i}=await Promise.resolve().then(()=>(Tr(),os)),r=e.imageSettings.apiKey;r?await n("POLLINATIONS_API_KEY",r):await i("POLLINATIONS_API_KEY")}let t={...o,...e};return t.imageSettings&&(t.imageSettings={...t.imageSettings,apiKey:""}),await br.ensureDir(mi.dirname(eo)),Jr(eo,t),!0}catch(o){return console.error("Failed to save settings:",o),!1}}});var Ka,qa=ae(()=>{Ka="pk_oH8wkUdQaQK1cmst"});import Va from"fs-extra";import pi from"path";var Pc,hi,za=ae(()=>{Zt();fi();is();qa();an();Pc=(e,o={})=>{try{if(e.length<8||e[0]!==137||e[1]!==80||e[2]!==78||e[3]!==71)return e;let t=[],n=[];for(let l=0;l<256;l++){let c=l;for(let f=0;f<8;f++)c&1?c=3988292384^c>>>1:c=c>>>1;n[l]=c}let i=l=>{let c=4294967295;for(let f=0;f<l.length;f++)c=n[(c^l[f])&255]^c>>>8;return(c^4294967295)>>>0},r=(l,c)=>{let f=Buffer.from(l,"ascii"),u=Buffer.from(c,"utf-8"),d=f.length+1+u.length,a=Buffer.alloc(8+d+4);a.writeUInt32BE(d,0),a.write("tEXt",4,"ascii"),f.copy(a,8),a[8+f.length]=0,u.copy(a,8+f.length+1);let m=i(a.subarray(4,8+d));return a.writeUInt32BE(m,8+d),a};for(let[l,c]of Object.entries(o))c!=null&&t.push(r(l,String(c)));if(t.length===0)return e;if(e.subarray(12,16).toString("ascii")==="IHDR"){let c=e.subarray(0,33),f=e.subarray(33);return Buffer.concat([c,...t,f])}return e}catch{return e}},hi=async(e,o={})=>{let t=ne(e),n=t.prompt||t.text,i=t.path||t.outputPath||t.output||"generated_image.png",r=t.ratio;if(!n)return'ERROR: Missing "prompt" argument for generate_image.';let l=["nsfw","naked","nudity","nude","porn","sex","xxx","erotic","gore","bloody","violence","abuse","suicide","murder","hentai","pedophile","rape"],c=n.toLowerCase();if(l.some(u=>c.includes(u)))return"ERROR: Prompt blocked by system safety filter (inappropriate or unsafe content detected).";try{let u=await Cr();if(!await Aa(u))return`ERROR: Insufficient Quota for selected quality. Either tell user reduce quality or wait for next refresh cycle (${(await ss()).nextResetMin||60}m).`;let a=u.imageSettings||{keyType:"Default",quality:"Low-High",apiKey:""},m=a.keyType==="Custom"&&a.apiKey?a.apiKey:Ka,h={Low:"flux","Low-High":"zimage",Medium:"gptimage","Medium-High":"gptimage",High:"qwen-image",Ultra:"gptimage-large",Premium:"nanobanana-pro"}[a.quality]||"zimage",S=1024,T=1024;if(r){let z=r.replace(/\s+/g,"");z==="16:9"?(S=1024,T=576):z==="9:16"?(S=576,T=1024):z==="4:3"?(S=1024,T=768):z==="3:4"?(S=768,T=1024):z==="1:1"&&(S=1024,T=1024)}let w=Math.floor(Math.random()*1e7),$=`https://gen.pollinations.ai/image/${encodeURIComponent(n)}?model=${h}&width=${S}&height=${T}&seed=${w}&enhance=true&reasoning=high&quality=high&negative=${encodeURIComponent("deformed, distorted, disfigured, poorly drawn, bad anatomy, wrong anatomy, extra limb, missing limb, floating limbs, disconnected limbs, mutation, mutated hands and fingers, blurry, low quality, low resolution, extra fingers, censored, watermarks, signatures")}`,U=await fetch($,{method:"GET",headers:{Authorization:`Bearer ${m}`}});if(!U.ok){let z=U.status,Ct="";try{Ct=await U.text()}catch{}return z===402||Ct.includes("Insufficient balance")||Ct.includes("PAYMENT_REQUIRED")?"ERROR: Image Generation Currently unavailable. Try again later.":`ERROR: Image Generation failed with status [${z}]: ${Ct||"Unknown API Error"}`}if((U.headers.get("content-type")||"").includes("application/json")){let z=await U.json();return z.status===402||z.error&&z.error.code==="PAYMENT_REQUIRED"?"ERROR: Image Generation Currently unavailable. Try again later.":`ERROR: Image Generation failed: ${z.error?.message||JSON.stringify(z)}`}let P=await U.arrayBuffer(),k=Buffer.from(P),O={Title:n,Description:"Generated via FluxFlow CLI",Software:"FluxFlow CLI",Author:"FluxFlow","Creation Time":new Date().toISOString(),Prompt:n,Model:`Fluxflow:${h}`,Ratio:r||"1:1",Seed:String(w)};k=Pc(k,O);let D=pi.resolve(process.cwd(),i);await Va.ensureDir(pi.dirname(D)),await bt.recordFileChange(D),await Va.writeFile(D,k),await Oa(u);let Q=pi.extname(i).toLowerCase(),Z={".jpg":"image/jpeg",".jpeg":"image/jpeg",".png":"image/png",".webp":"image/webp"}[Q]||"image/png";return o.isMultiModal!==!1?{text:`SUCCESS: Image successfully generated from prompt [${n}] and saved to [${i}]. Output attached to multimodal part`,binaryPart:{inlineData:{data:k.toString("base64"),mimeType:Z}}}:`SUCCESS: Image successfully generated from prompt [${n}] and saved to [${i}].`}catch(u){return`ERROR: Failed during image generation: ${u.message}`}}});var kr,Ja=ae(()=>{Do();oo();kr=async(e,o={})=>{let t=r=>{let l=new RegExp(`${r}\\s*[:=]\\s*(["'])(.*?)\\1(?=\\s*[,)]|\\s+\\w+\\s*[:=]|$)`,"s"),c=e.match(l);return c?c[2].trim():null},n=t("id"),i=t("summary");if(!n||!i)return"ERROR: Missing 'id' or 'summary' for saveSummary tool.";try{let r=ye(ho,{}),l=ye(Uo,{});return l[n]=i,delete r[n],ke(Uo,l),ke(ho,r),`SUCCESS: Saved summary and purged raw memories for chat [${n}].`}catch(r){return`ERROR: Failed to save summary for chat [${n}]: ${r.message}`}}});var nr,Qa=ae(()=>{Do();oo();nr=async(e,o={})=>{let n=(i=>{let r=new RegExp(`${i}\\s*[:=]\\s*(["'])(.*?)\\1(?=\\s*[,)]|\\s+\\w+\\s*[:=]|$)`,"s"),l=e.match(r);return l?l[2].trim():null})("id");if(!n)return"ERROR: Missing 'id' parameter for addMemScore tool.";try{let i=ye(Bt,[]),r=!1,l=[];for(let d of i)d.score===void 0&&(d.score=.5),d.id===n?(d.score=Math.min(2,d.score+.2),r=!0):(d.score*=.98,d.score<.05&&(d.score=0)),d.score=Math.round(d.score*1e5)/1e5,d.score>0&&l.push(d);if(ke(Bt,l),!r)return`WARNING: Memory ID [${n}] not found. Other memories decayed by -0.01.`;let c=l.find(d=>d.id===n),f=c?c.score.toFixed(2):"deleted (score <= 0)",u=i.length-l.length;return`SUCCESS: Adjusted memory scores. Target [${n}] is now ${f}.${u>0?` Purged ${u} decayed memories.`:""}`}catch(i){return`ERROR: Failed to adjust memory score for [${n}]: ${i.message}`}}});var Bc,cs,Za=ae(async()=>{La();Da();va();$a();Pa();Na();_a();await gr();Ra();Wa();Ha();ja();Xa();za();Ja();Qa();Bc={web_search:Js,web_scrape:Qs,memory:Zs,chat:ei,view_file:ti,write_file:oi,update_file:ri,exec_command:vs,read_folder:si,write_pdf:ai,write_docx:ci,search_keyword:ui,generate_image:hi,saveSummary:kr,addMemScore:nr,ask:ii,Ask:ii,WebSearch:Js,WebScrape:Qs,ReadFile:ti,ReadFolder:si,WriteFile:oi,PatchFile:ri,WritePDF:ai,WriteDoc:ci,Run:vs,SearchKeyword:ui,Memory:Zs,Chat:ei,GenerateImage:hi,saveSumary:kr,SaveSummary:kr,SaveSumary:kr,add_mem_score:nr,AddMemScore:nr,addMemoryScore:nr,AddMemoryScore:nr},cs=async(e,o,t={})=>{if(t.mode&&t.mode.toLowerCase()==="flow"){let i=e.toLowerCase();if(!(i.startsWith("web")||i.startsWith("ask")))return`ERROR: Tool [${e}] is restricted in Flow mode.`}let n=Bc[e];if(!n)return`ERROR: Tool [${e}] not found in registry.`;try{return await n(o,t)}catch(i){return`ERROR: Execution failed for [${e}]: ${i.message}`}}});import{WebSocket as ds}from"ws";var lo,rr,Nc,gi,sr,xi,el,yi,wi,tl,us,Yo,ms,Ir,ol,Ti,nl,Si=ae(()=>{lo=null,rr=!1,Nc="ws://localhost:56832",gi=[],sr=null,xi=null,el="2.0.0",yi=e=>{el=e,tl()},wi=e=>{xi=e},tl=()=>{if(lo||rr)return;rr=!0;let e=new ds(Nc);e.on("open",()=>{for(lo=e,rr=!1,lo.send(JSON.stringify({command:"version",version:el,pid:process.pid,ppid:process.ppid}));gi.length>0;)lo.send(JSON.stringify(gi.shift()))}),e.on("message",o=>{try{let t=JSON.parse(o.toString());t.command==="contextResponse"&&sr?(sr(t.data),sr=null):t.command==="securityResponse"&&xi&&xi(t.result)}catch{}}),e.on("error",()=>{rr=!1,lo=null}),e.on("close",()=>{rr=!1,lo=null})},us=e=>{lo&&lo.readyState===ds.OPEN?lo.send(JSON.stringify(e)):(gi.push(e),rr||tl())},Yo=()=>lo!==null&&lo.readyState===ds.OPEN,ms=e=>{us({command:"status",status:e})},Ir=()=>new Promise(e=>{if(!lo||lo.readyState!==ds.OPEN){e({cursor_line:0,selected:0,manual_edits:"",file_focused:"none",opened_editors:[]});return}sr=e,lo.send(JSON.stringify({command:"requestContext"})),setTimeout(()=>{sr===e&&(e({cursor_line:0,selected:0,manual_edits:"",file_focused:"none",opened_editors:[]}),sr=null)},1e3)}),ol=e=>{us({command:"open",filePath:e})},Ti=(e,o,t)=>{us({command:"showDiff",filePath:e,originalContent:o,modifiedContent:t})},nl=(e,o)=>{us({command:"closeDiff",filePath:e,result:o})}});import{GoogleGenAI as _c,ThinkingLevel as jo,HarmBlockThreshold as Mn,HarmCategory as An}from"@google/genai";import Ee from"path";import dt from"fs";var ar,bi,ir,Uc,Ei,Rc,il,ki,Ii,al,rl,Wc,ll,Hc,cl,Yc,sl,Mi,Mr,Ci,jc,dl,ul=ae(async()=>{await xa();Sr();is();await Za();Do();Zt();wn();Bn();oo();an();Si();ar=null,bi={},ir=!1,Uc=["google/gemma-4-31b-it:free","moonshotai/kimi-k2.6:free","google/gemini-3.5-flash","qwen/qwen3.7-plus","minimax/minimax-m3","anthropic/claude-sonnet-4.5","anthropic/claude-opus-4.6","anthropic/claude-opus-4.8","openai/gpt-5.2-codex","openai/gpt-5.2-pro","openai/gpt-5.5-pro","moonshotai/kimi-k2.6","gemma-4-31b-it","gemini-2.5-flash","gemini-3-flash-preview","gemini-3.5-flash","gemini-3.1-flash-lite","gemini-3.1-pro-preview"],Ei=e=>{if(!e)return!1;let o=e.toLowerCase();return o.startsWith("gemini-")||o.startsWith("gemma-")?!0:Uc.some(t=>t.toLowerCase()===o)},Rc=e=>typeof e!="string"?e:e.replace(/[\u001b\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g,""),il=async(e,o,t=5,n=1e3)=>{for(let i=0;i<t;i++){try{let r=await fetch(e,o);if(r.ok||r.status!==429&&r.status<500)return r}catch(r){if(i===t-1)throw r}await new Promise(r=>setTimeout(r,n*Math.pow(2,i)))}return fetch(e,o)},ki=async function*(e,o,t,n,i,r,l){let c=[];n&&c.push({role:"system",content:n});for(let w of t){let I=w.role==="user"?"user":"assistant",$=[];if(Array.isArray(w.parts)){for(let U of w.parts)if(U.text)$.push({type:"text",text:U.text});else if(U.inlineData&&l){let K=U.inlineData.mimeType,P=U.inlineData.data;K.startsWith("image/")&&$.push({type:"image_url",image_url:{url:`data:${K};base64,${P}`}})}}else{let U=w.text||"";U&&$.push({type:"text",text:U})}c.push({role:I,content:$.length===1&&$[0].type==="text"?$[0].text:$})}let f={model:o,messages:c,stream:!0,stream_options:{include_usage:!0},temperature:r==="Flux"?1:1.4};if(i!=="Fast"){let w={Low:"high",Medium:"high",High:"high",xHigh:"max"};f.reasoning_effort=w[i]||"high",f.extra_body={thinking:{type:"enabled"}}}else f.extra_body={thinking:{type:"disabled"}};let u=await il("https://api.deepseek.com/chat/completions",{method:"POST",headers:{Authorization:`Bearer ${e}`,"Content-Type":"application/json"},body:JSON.stringify(f)});if(!u.ok){let w=await u.json().catch(()=>({}));throw new Error(`DeepSeek Error (${u.status}): ${w.error?.message||u.statusText}`)}let d=u.body.getReader(),a=new TextDecoder,m="",p=[],h=null,S=Date.now(),T=!1;for(;;){let{done:w,value:I}=await d.read();if(w){T&&(p.length>0||h)&&(yield{candidates:p.length>0?[{content:{parts:p}}]:[],usageMetadata:h});break}m+=a.decode(I,{stream:!0});let $=m.split(`
|
|
376
|
+
`);m=$.pop();for(let U of $){let K=U.trim();if(!(!K||!K.startsWith("data: "))){if(K==="data: [DONE]")break;try{let P=JSON.parse(K.substring(6)),k=P.choices?.[0]?.delta,O=P.usage;if(O&&(h={totalTokenCount:O.total_tokens||O.prompt_tokens+O.completion_tokens,promptTokenCount:O.prompt_tokens||0,candidatesTokenCount:O.completion_tokens||0,cachedContentTokenCount:O.prompt_tokens_details?.cached_tokens||0,thoughtsTokenCount:O.completion_tokens_details?.reasoning_tokens||0},T=!0),k){let D=k.reasoning_content||null;D&&(p.push({text:D,thought:!0}),T=!0),k.content&&(p.push({text:k.content}),T=!0)}}catch{}}}Date.now()-S>=150&&T&&(yield{candidates:p.length>0?[{content:{parts:[...p]}}]:[],usageMetadata:h},p=[],S=Date.now(),T=!1)}},Ii=async function*(e,o,t,n,i,r,l){let c=[];n&&c.push({role:"system",content:n});for(let $ of t){let U=$.role==="user"?"user":"assistant",K=[];if(Array.isArray($.parts)){for(let P of $.parts)if(P.text)K.push({type:"text",text:P.text});else if(P.inlineData&&l){let k=P.inlineData.mimeType,O=P.inlineData.data;k.startsWith("image/")?K.push({type:"image_url",image_url:{url:`data:${k};base64,${O}`}}):K.push({type:"file",file:{filename:P.filename||"file",file_data:`data:${k};base64,${O}`}})}}else{let P=$.text||"";P&&K.push({type:"text",text:P})}c.push({role:U,content:K.length===1&&K[0].type==="text"?K[0].text:K})}let f={Low:"low",Medium:"medium",High:"high",xHigh:"high"},u={model:o,messages:c,stream:!0,temperature:r==="Flux"?1:1.4},d=f[i];d&&i!=="Fast"&&(u.reasoning_effort=d);let a=await il("https://openrouter.ai/api/v1/chat/completions",{method:"POST",headers:{Authorization:`Bearer ${e}`,"Content-Type":"application/json","X-Title":"FluxFlow CLI","X-Cache":"true"},body:JSON.stringify(u)});if(!a.ok){let $=await a.json().catch(()=>({}));throw new Error(`OpenRouter Error (${a.status}): ${$.error?.message||a.statusText}`)}let m=a.body.getReader(),p=new TextDecoder,h="",S=[],T=null,w=Date.now(),I=!1;for(;;){let{done:$,value:U}=await m.read();if($){I&&(S.length>0||T)&&(yield{candidates:S.length>0?[{content:{parts:S}}]:[],usageMetadata:T});break}h+=p.decode(U,{stream:!0});let K=h.split(`
|
|
377
|
+
`);h=K.pop();for(let P of K){let k=P.trim();if(!(!k||!k.startsWith("data: "))){if(k==="data: [DONE]")break;try{let O=JSON.parse(k.substring(6)),D=O.choices?.[0]?.delta,Q=O.usage;if(Q&&(T={totalTokenCount:Q.total_tokens||Q.prompt_tokens+Q.completion_tokens,promptTokenCount:Q.prompt_tokens||0,candidatesTokenCount:Q.completion_tokens||0,cachedContentTokenCount:Q.prompt_tokens_details?.cached_tokens||0,thoughtsTokenCount:Q.completion_tokens_details?.reasoning_tokens||0},I=!0),D){let G=D.reasoning||(D.reasoning_details?D.reasoning_details.map(Z=>Z.text).join(""):null);G&&(S.push({text:G,thought:!0}),I=!0),D.content&&(S.push({text:D.content}),I=!0)}}catch{}}}Date.now()-w>=150&&I&&(yield{candidates:S.length>0?[{content:{parts:[...S]}}]:[],usageMetadata:T},S=[],w=Date.now(),I=!1)}},al=()=>{ir=!0},rl={write_file:"Writing",update_file:"Editing",read_folder:"Reading",view_file:"Reading",exec_command:"Executing Command",web_search:"Searching",web_scrape:"Reading",memory:"Updating Memory",search_keyword:"Searching",ask:"User Input",write_pdf:"Creating",write_docx:"Creating",generate_image:"Generating"},Wc=(e,o)=>{try{let t=ne(o),n=t.path||t.targetFile||t.TargetFile||t.directory;return n?Ee.basename(n.replace(/["']/g,"").replace(/\\/g,"/")):null}catch{return null}},ll=async(e,o,t,n,i={})=>{process.stdout.isTTY&&(process.stdout.write("\x1B]0;Finalizing...\x07"),process.stdout.write("\x1B]633;P;TerminalTitle=Finalizing...\x07"));let r=4*(1024*2),l=4*(1024*8),{onStatus:c,onMemoryUpdated:f,onBackgroundIncrement:u}=i,{profile:d,thinkingLevel:a,mode:m,janitorModel:p,chatId:h,systemSettings:S,sessionStats:T,aiProvider:w="Google",apiKey:I}=e,$=S?.memory!==!1,K=ye(Bt,[]).map(fe=>`- [${fe.id}]: ${fe.memory}`).join(`
|
|
378
|
+
`),P=n.slice(0,-1).filter(fe=>fe.text&&!fe.text.includes("[TOOL RESULT]")&&!fe.text.includes("OBSERVATION:")&&!fe.text.startsWith("[TERMINAL_RECORD]")&&!fe.isTerminalRecord&&!fe.isMeta&&!fe.isLogo&&!String(fe.id).startsWith("welcome")&&!String(fe.id).startsWith("logo")).slice(-14).map(fe=>{let ut=Rc(fe.text).replace(/\[tool:functions\..*?\]/g,"").replace(/(?:<think>|\[think\])[\s\S]*?(?:<\/think>|\[\/think\])/g,"").replace(/\[Prompted on:.*?\]/g,"").replace(/\[METADATA \(PRIORITY: DYNAMIC\)\] Time: ([^|\n]+)/g,(Qe,me)=>`[METADATA (PRIORITY: DYNAMIC)] Time: ${me.replace(/:\d{2}/g,"")}`).replace(/\[turn: continue\]/g,"").replace(/\[turn: finish\]/g,"").replace(/\[TOOL RESULTS\]/g,"").replace(/\[tool results\]/g,"").replace(/\r?\n\r?\n/g,`
|
|
376
379
|
`).replace(/\n\n/g,`
|
|
377
|
-
`).replace(/\\n\\n/g,"").trim(),
|
|
378
|
-
... (truncated) ...`);let
|
|
379
|
-
... (truncated) ...`);let
|
|
380
|
+
`).replace(/\\n\\n/g,"").trim(),ze=fe.role==="user"?r:l,Je=ut.substring(0,ze);ut.length>ze&&(Je+=`
|
|
381
|
+
... (truncated) ...`);let Fe=fe.role==="user"?Je.startsWith("[USER]")?"":"[USER]: ":Je.startsWith("[AGENT]")?"":"[AGENT]: ";return{role:fe.role==="user"?"user":"model",parts:[{text:`${Fe}${Je}`}]}}),k=n.filter(fe=>fe.role==="user").length===1,O=o.includes("[TITLE-UPDATE]"),D=Math.random()<.8,Q=k||O||D,G=t.replace(/(?:<think>|\[think\])[\s\S]*?(?:<\/think>|\[\/think\])/g,"").trim(),Z=ga(K,$,Q),X=`${G.replace(/\[tool:functions\..*?\]/g,"").replace(/(?:<think>|\[think\])[\s\S]*?(?:<\/think>|\[\/think\])/g,"").replace(/\[Prompted on:.*?\]/g,"").replace(/\[turn: continue\]/g,"").replace(/\[turn: finish\]/g,"").replace(/\[TOOL RESULTS\]/g,"").replace(/\[tool results\]/g,"").substring(0,l)}`;X.length>l&&(X+=`
|
|
382
|
+
... (truncated) ...`);let z=o.replace(/\[Prompted on:.*?\]/g,"").trim();X=X.replace(/\r?\n\r?\n/g,`
|
|
380
383
|
`).replace(/\n\n/g,`
|
|
381
|
-
`).replace(/\\n\\n/g,"").trim();let
|
|
382
|
-
${
|
|
384
|
+
`).replace(/\\n\\n/g,"").trim();let Ct=`[USER]: ${z.substring(0,r)}
|
|
385
|
+
${z.length>r?`... (truncated) ...
|
|
383
386
|
|
|
384
387
|
`:""}
|
|
385
|
-
[AGENT (current turn)]: ${
|
|
388
|
+
[AGENT (current turn)]: ${X}`;P.push({role:"user",parts:[{text:Ct}]});let Te="",je=0,nt=$?12:-1;for(;je<=nt;){process.stdout.isTTY&&(process.stdout.write(`\x1B]0;Retrying Finalizing... (${je+1})...\x07`),process.stdout.write(`\x1B]633;P;TerminalTitle=Retrying Finalizing... (${je+1})...\x07`));try{if(!await Vs("background",e))return;let fe="",ut=null;try{let Fe=new Promise((ro,Le)=>setTimeout(()=>Le(new Error("JANITOR_TIMEOUT")),6e4)),Qe=(async()=>{if(w==="OpenRouter"){let yt=Ii(I,"google/gemma-4-26b-a4b-it:free",P,Z,"Fast",m)[Symbol.asyncIterator](),Vo=await yt.next();return{iterator:yt,firstResult:Vo}}else if(w==="DeepSeek"){let Le=ki(I,"deepseek-chat",P,Z,"Fast",m,!1)[Symbol.asyncIterator](),yt=await Le.next();return{iterator:Le,firstResult:yt}}else{let Le=(await ar.models.generateContentStream({model:p||"gemma-4-26b-a4b-it",contents:P,config:{systemInstruction:Z,maxOutputTokens:512,temperature:.3,safetySettings:[{category:An.HARM_CATEGORY_HARASSMENT,threshold:Mn.BLOCK_NONE},{category:An.HARM_CATEGORY_HATE_SPEECH,threshold:Mn.BLOCK_NONE},{category:An.HARM_CATEGORY_SEXUALLY_EXPLICIT,threshold:Mn.BLOCK_NONE},{category:An.HARM_CATEGORY_DANGEROUS_CONTENT,threshold:Mn.BLOCK_NONE}],thinkingConfig:{includeThoughts:!1,thinkingLevel:jo.MINIMAL}}}))[Symbol.asyncIterator](),yt=await Le.next();return{iterator:Le,firstResult:yt}}})(),{iterator:me,firstResult:yo}=await Promise.race([Qe,Fe]),{value:wo,done:un}=yo;if(!un&&wo){let ro=wo.candidates?.[0]?.content?.parts,Le=ro?.[1]?.text||ro?.[0]?.text||(typeof wo.text=="function"?wo.text():"");Le&&(fe+=Le),ut=wo.usageMetadata;for await(let yt of{[Symbol.asyncIterator]:()=>me}){let Vo=yt.candidates?.[0]?.content?.parts,zo=Vo?.[1]?.text||Vo?.[0]?.text||(typeof yt.text=="function"?yt.text():"");zo&&(fe+=zo),ut=yt.usageMetadata}}}catch(Fe){throw Fe}if(fe)Te=fe,ut&&await xo("tokens",ut.totalTokenCount||0);else throw new Error("No synthesis generated by Janitor.");u&&(u(),await Ho("background"));let ze=Mi(Te),Je=!1;for(let Fe of ze){let Qe=Fe.toolName;["addMemScore","add_mem_score","AddMemScore","addMemoryScore","AddMemoryScore"].includes(Qe)&&(Je=!0);let me={chatId:h,sessionId:h,history:n},yo=await cs(Qe,Fe.args,me);Qe.toLowerCase()==="memory"&&(Fe.args.includes("action='user'")||Fe.args.includes('action="user"'))&&!yo.startsWith("ERROR")&&(f&&f(),process.stdout.isTTY&&(process.stdout.write("\x1B]0;Memory Updated\x07"),process.stdout.write("\x1B]633;P;TerminalTitle=Memory Updated\x07")),await new Promise(un=>setTimeout(un,3e3)))}if(!Je)try{let Fe=ye(Bt,[]);if(Fe.length>0){let Qe=[];for(let me of Fe)me.score===void 0&&(me.score=.5),me.score*=.9995,me.score<.05&&(me.score=0),me.score=Math.round(me.score*1e5)/1e5,me.score>0&&Qe.push(me);ke(Bt,Qe)}}catch{}break}catch(fe){je++;let ut=new Date().toLocaleString();process.stdout.isTTY&&process.stdout.write("\x1B]0;Finalizing Error\x07"),await new Promise(Fe=>setTimeout(Fe,1e3));let ze=Ee.join(Io,"janitor");if(dt.existsSync(ze)||dt.mkdirSync(ze,{recursive:!0}),dt.appendFileSync(Ee.join(ze,"error.log"),`ERROR [Attempt ${je}/${nt+1}] [${ut}]: ${String(fe)}
|
|
386
389
|
|
|
387
|
-
`),
|
|
390
|
+
`),je>nt)break;let Je=Math.min(1e3*Math.pow(2,je-1),8e3);await new Promise(Fe=>setTimeout(Fe,Je))}}if(je){let fe=Ee.join(Io,"janitor");dt.appendFileSync(Ee.join(fe,"error.log"),`-----------------------------------------------------------------------------
|
|
388
391
|
|
|
389
392
|
|
|
390
|
-
`),
|
|
393
|
+
`),je>=nt&&(process.stdout.isTTY&&process.stdout.write(`\x1B]0;${$?"Finalizing Error":"Finalizing Skipped"}\x07`),await new Promise(ut=>setTimeout(ut,3e3)))}process.stdout.isTTY&&(process.stdout.write("\x1B]0;FluxFlow | Idle\x07"),process.stdout.write("\x1B]633;P;TerminalTitle=FluxFlow | Idle\x07"))},Hc=e=>{let o=/\[\s*tool:functions\.([a-z0-9_]+)\s*\(/gi,t;for(;(t=o.exec(e))!==null;){let n=t.index+t[0].length-1,i=0,r=null,l=!1,c=!1;for(let f=n;f<e.length;f++){let u=e[f];if(!r&&(u==='"'||u==="'"||u==="`")?(r=u,l=!1):r&&u===r&&!l&&(r=null),!r&&(u==="("?i++:u===")"&&i--,i===0)){let d=f+1;for(;d<e.length&&/\s/.test(e[d]);)d++;if(d<e.length&&e[d]==="]"){c=!0,o.lastIndex=d+1;break}}u==="\\"?l=!l:l=!1}if(!c)return{inside:!0,toolName:t[1],startIndex:t.index,args:e.substring(t.index+t[0].length)}}return{inside:!1}},cl=(e,o=!0)=>{let t=/\[\s*tool:functions\.([a-z0-9_]+)\s*\(/gi,n="",i=0,r;for(;(r=t.exec(e))!==null;){let l=e.substring(i,r.index);n+=o?l.replace(/(?:<think>|\[think\])[\s\S]*?(?:<\/think>|\[\/think\]|$)/gi,""):l;let c=r.index+r[0].length-1,f=0,u=null,d=-1;for(let a=c;a<e.length;a++){let m=e[a];if(u){if(m===u){let p=0;for(let h=a-1;h>=0&&e[h]==="\\";h--)p++;p%2===0&&(u=null)}}else if(m==='"'||m==="'"||m==="`")u=m;else if(m==="(")f++;else if(m===")"&&(f--,f===0)){let p=a+1;for(;p<e.length&&/\s/.test(e[p]);)p++;if(p<e.length&&e[p]==="]"){d=p;break}}}if(d!==-1)n+="[tool:functions."+r[1]+"()]",i=d+1,t.lastIndex=i;else{n+="[tool:functions."+r[1]+"(",i=e.length;break}}return i<e.length&&(n+=o?e.substring(i).replace(/(?:<think>|\[think\])[\s\S]*?(?:<\/think>|\[\/think\]|$)/gi,""):e.substring(i)),n},Yc=(e,o,t)=>{let n=/\[\s*tool:functions\.([a-z0-9_]+)\s*\(/gi,i="",r=0,l;for(;(l=n.exec(e))!==null;){let c=e.substring(r,l.index);i+=c.replace(o,t);let f=l.index+l[0].length-1,u=0,d=null,a=-1;for(let m=f;m<e.length;m++){let p=e[m];if(d){if(p===d){let h=0;for(let S=m-1;S>=0&&e[S]==="\\";S--)h++;h%2===0&&(d=null)}}else if(p==='"'||p==="'"||p==="`")d=p;else if(p==="(")u++;else if(p===")"&&(u--,u===0)){let h=m+1;for(;h<e.length&&/\s/.test(e[h]);)h++;if(h<e.length&&e[h]==="]"){a=h;break}}}if(a!==-1)i+=e.substring(l.index,a+1),r=a+1,n.lastIndex=r;else{i+=e.substring(l.index),r=e.length;break}}return r<e.length&&(i+=e.substring(r).replace(o,t)),i},sl=e=>cl(e,!0),Mi=e=>{let o=[],t=/\[\s*tool:functions\.([a-z0-9_]+)\s*\(/gi,n;for(;(n=t.exec(e))!==null;){let i=n[1],r=n.index+n[0].length-1,l=0,c=null,f=-1,u=-1;for(let d=r;d<e.length;d++){let a=e[d];if(c){if(a===c){let m=0;for(let p=d-1;p>=0&&e[p]==="\\";p--)m++;m%2===0&&(c=null)}}else if(a==='"'||a==="'"||a==="`")c=a;else if(a==="(")l++;else if(a===")"&&(l--,l===0)){u=d;let m=d+1;for(;m<e.length&&/\s/.test(e[m]);)m++;if(m<e.length&&e[m]==="]"){f=m;break}}}if(f!==-1){let d=e.substring(r+1,u),a=e.substring(n.index,f+1);o.push({fullMatch:a,toolName:i.trim(),args:d.trim()}),t.lastIndex=f+1}}return o},Mr=(e,o={})=>e?(bi=o,ar=new _c({apiKey:e}),ar):null,Ci=async(e,o,t,n,i="Fast")=>{let{aiProvider:r="Google",apiKey:l,mode:c}=e,f="",u=null,d;r==="OpenRouter"?d=Ii(l,o,t,n,i,c,!1):r==="DeepSeek"?d=ki(l,o,t,n,i,c,!1):d=await ar.models.generateContentStream({model:o,contents:t,config:{systemInstruction:n,maxOutputTokens:2048,temperature:.3,thinkingConfig:{includeThoughts:!1,thinkingLevel:jo.MINIMAL}}});for await(let a of d){if(a.candidates?.[0]?.content?.parts)for(let m of a.candidates[0].content.parts)m.text&&!m.thought&&(f+=m.text);a.usageMetadata&&(u=a.usageMetadata)}return{text:f,usageMetadata:u}},jc=async(e,o)=>{try{let{aiProvider:t="Google"}=o,n=ye(ho,{});if(Object.values(n).flat().length<=2)return;let r=Object.keys(n).filter(m=>m!==e&&Array.isArray(n[m])&&n[m].length>2);if(r.length===0)return;let l=`You are a silent background process for the FluxFlow CLI Agent.
|
|
391
394
|
Your task is to summarize or merge temporary context memories from one or more past conversation sessions.
|
|
392
395
|
For each Chat ID provided, you must output a tool call to save the consolidated summary.
|
|
393
396
|
|
|
@@ -402,19 +405,19 @@ Guidelines:
|
|
|
402
405
|
|
|
403
406
|
Chats to process:
|
|
404
407
|
|
|
405
|
-
`,c=
|
|
406
|
-
`),
|
|
407
|
-
`,
|
|
408
|
+
`,c=ye(Uo,{});for(let m of r){let h=n[m].map(T=>`- ${T}`).join(`
|
|
409
|
+
`),S=c[m];l+=`[Chat ID: ${m}]
|
|
410
|
+
`,S?(l+=`- Existing Summary: "${S}"
|
|
408
411
|
`,l+=`-- New Memories to integrate:
|
|
409
412
|
${h}
|
|
410
413
|
|
|
411
414
|
`):l+=`-- Individual Memories:
|
|
412
415
|
${h}
|
|
413
416
|
|
|
414
|
-
`}let
|
|
415
|
-
`)}},
|
|
417
|
+
`}let f=0,u=5,d=!1,a="gemma-4-26b-a4b-it";for(t==="OpenRouter"&&(a="google/gemma-4-26b-a4b-it:free"),t==="DeepSeek"&&(a="deepseek-v4-flash");f<=u&&!d;){f++;try{let m=await Ci(o,a,l,null,"Fast"),p=m.text||"",h=Mi(p);if(h.length===0)throw new Error("No tool calls detected in synthesis response");for(let S of h){let T=S.toolName;["saveSummary","saveSumary","SaveSummary","SaveSumary"].includes(T)&&await cs(T,S.args,{chatId:e})}m.usageMetadata&&await xo("tokens",m.usageMetadata.totalTokenCount||0),d=!0}catch(m){if(f>=u)throw new Error(`Failed after ${u} attempts. Last error: ${m.message}`)}}}catch(t){let n=Ee.join(Io,"janitor");dt.existsSync(n)||dt.mkdirSync(n,{recursive:!0}),dt.appendFileSync(Ee.join(n,"error.log"),`[${new Date().toLocaleString()}] Past memory batch consolidation error: ${t.message}
|
|
418
|
+
`)}},dl=async function*(e,o,t,n,i){let{profile:r,thinkingLevel:l,mode:c,janitorModel:f,chatId:u,systemSettings:d,sessionStats:a,aiProvider:m="Google",apiTier:p}=t,h=Ei(e);if(!ar&&m==="Google")throw new Error("AI not initialized");let S=d?.memory!==!1,T=o[o.length-1].text,w=Ee.join(to,"chat-summaries.json"),I=!1,$=o.filter(k=>k.role==="user").length===1,U=T.includes("[TITLE-UPDATE]"),K=$||U,P=T.replace(/\[TITLE-UPDATE\]/g,"").trim();P=P.replace(/\s*\[Prompted on:.*?\]/g,"").trim(),await bt.startTransaction(u,P);try{let k=[...o.slice(0,-1)],O=252e3,D=254e3;if((m==="DeepSeek"||m==="Google"&&p==="Paid")&&(O=396e3,D=4e5),d?.compression===0&&(a?.tokens||0)>O){yield{type:"status_history",content:"Context Limit Reached. Condensing session history..."};let te=wt=>wt.filter(ft=>(ft.role==="user"||ft.role==="agent"||ft.role==="system")&&!String(ft.id).startsWith("welcome")&&!ft.isMeta).map(ft=>`[${ft.text?.startsWith("[TOOL RESULT]")?"TOOL":ft.role==="agent"?"AGENT":"USER"}]: ${ft.text}`).join(`
|
|
416
419
|
|
|
417
|
-
`),
|
|
420
|
+
`),Ie=async(wt,ft)=>{let Be="You are an expert context condenser. Summarize the provided chat history (which may include previous summaries, user instructions, agent outputs, and tool results) into a detailed, coherent, and highly technical summary of 1000 to 1500 words. Focus on preserving the architectural decisions made, current system state, task progress, and critical code details. Under no circumstances exceed MAX 2000 words.",ce=ft?`Here is the previous summary:
|
|
418
421
|
${ft}
|
|
419
422
|
|
|
420
423
|
Here is the new conversation history:
|
|
@@ -423,135 +426,137 @@ ${wt}
|
|
|
423
426
|
Provide a new consolidated summary of the entire session.`:`Here is the conversation history:
|
|
424
427
|
${wt}
|
|
425
428
|
|
|
426
|
-
Provide a consolidated summary of the entire session.`,
|
|
427
|
-
`),
|
|
428
|
-
`),
|
|
429
|
-
`;let st=""
|
|
430
|
-
`;return}
|
|
431
|
-
`:
|
|
432
|
-
`:(st+=`${rt}${pt}${
|
|
433
|
-
`,st+=
|
|
434
|
-
`}),st};yield{type:"status",content:"Gathering Context..."},await new Promise(
|
|
429
|
+
Provide a consolidated summary of the entire session.`,_t="gemma-4-26b-a4b-it";m==="OpenRouter"&&(_t="google/gemma-4-26b-a4b-it:free"),m==="DeepSeek"&&(_t="deepseek-v4-flash");let it=0,uo=!1,pt=null;for(;it<=3&&!uo;){it++;try{pt=await Ci(t,_t,ce,Be,"Fast"),uo=!0}catch{if(it>3){if(m==="Google")try{return(await Ci(t,"gemini-3.1-flash-lite",ce,Be,"Fast")).text||""}catch{return""}return""}}}return pt&&pt.text||""},rt=te(k),re=ye(w,{}),ge=re[u]||{summary:"",historyLength:0};typeof ge=="string"&&(ge={summary:ge,historyLength:0});let pe=k.filter(wt=>(wt.role==="user"||wt.role==="agent"||wt.role==="system")&&!String(wt.id).startsWith("welcome")&&!wt.isMeta).length;ge.historyLength&&pe<ge.historyLength&&(ge.summary="",ge.historyLength=0,re[u]=ge,ke(w,re));let st=ge.summary||"",$o=await Ie(rt,st);$o&&(ge.summary=$o,re[u]=ge,ke(w,re),k=[],I=!0)}$&&S&&(yield{type:"status",content:"Condensing past chat memories..."},await jc(u,t));let Q=ye(ho,{}),G=ye(Uo,{}),Z=Object.entries(Q).filter(([te])=>te!==u).flatMap(([te,Ie])=>Ie),z=[...Object.entries(G).filter(([te])=>te!==u).slice(-20).map(([te,Ie])=>`[Chat Summary]: ${Ie}`),...Z].map(te=>`- ${te}`).join(`
|
|
430
|
+
`),Te=ye(Bt,[]).map(te=>`- ${te.memory}`).join(`
|
|
431
|
+
`),je=(a?.tokens||0)>=24e3,nt=pa(z,Te,S,je),fe=new Date().toLocaleString([],{year:"numeric",month:"numeric",day:"numeric",hour:"2-digit",minute:"2-digit",hour12:!0}),ut=[".git","node_modules",".gemini","dist","build",".next","out",".cache","bin","obj","vendor","venv",".idea",".gradle",".terraform","target","coverage",".vscode",".svn",".hg",".fslckout",".github",".gitlab",".circleci",".gitea",".gitee",".lerna",".changeset",".nx",".npm",".yarn",".pnpm-store",".expo",".nuxt",".svelte-kit",".docusaurus",".turbo",".vercel","bower_components",".netlify",".vuepress",".quasar",".output",".angular","jspm_packages",".parcel-cache",".rollup.cache",".rspack",".vitepress","__pycache__",".pytest_cache",".mypy_cache",".tox",".poetry","env","vhdl",".ipynb_checkpoints",".jupyter",".conda",".pdm-build",".bundle",".yardoc",".metadata","App_Data","ClientBin",".cargo",".rustc_info",".go","Godeps","_vendor",".rake_tasks","CMakefiles",".wakatime",".dart_tool",".fvm",".cocoapods","Pods",".pub-cache",".symlinks","DerivedData",".xcworkspace",".serverless",".aws",".gcloud",".azure",".kube",".vagrant",".docker","postgres-data","redis-data","mongo-data",".Spotlight-V100",".Trashes","$RECYCLE.BIN","System Volume Information",".DocumentRevisions-V100",".fseventsd","AppData","Application Data","Local","LocalLow","Roaming","$WinREAgent","$WINDOWS.~BT","$WINDOWS.~WS","scw","System32","SysWOW64",".AppleDouble",".AppleDB",".AppleDesktop","_CodeSignature",".cmio",".LSOverride",".localized",".TemporaryItems",".Trash",".Trash-0",".Trash-1000",".gvfs",".local",".config",".dbus",".fontconfig",".snap",".var",".lost+found","lost+found",".thumb",".thumbnails","EFI","boot","grub","logs","log",".nyc_output",".sonar",".ruff_cache"],ze=te=>{try{return dt.readdirSync(te,{withFileTypes:!0})}catch{return[]}},Je=(te,Ie={value:0},rt=1)=>{if(Ie.value>6200||rt>7)return Ie.value;let re=ze(te);for(let ge of re){if(Ie.value>6200)break;ut.includes(ge.name)||ge.isDirectory()&&(Ie.value++,Je(Ee.join(te,ge.name),Ie,rt+1))}return Ie.value},Fe=(te,Ie,rt="",re=1)=>{let ge=ze(te),pe=Ee.sep;if(ge.length>100)return`${rt}\u2514\u2500\u2500 ${Ee.basename(te)}${pe} ...100+ files...
|
|
432
|
+
`;let st="",$o=ut,wt=ge.filter(ce=>!$o.includes(ce.name)),ft=ge.filter(ce=>$o.includes(ce.name)).map(ce=>ce.name).sort();wt.sort((ce,_t)=>ce.isDirectory()&&!_t.isDirectory()?-1:!ce.isDirectory()&&_t.isDirectory()?1:ce.name.localeCompare(_t.name));let Be=[...wt.map(ce=>({name:ce.name,isDir:ce.isDirectory()})),...ft.map(ce=>({name:ce,isDir:!0,isCollapsed:!0}))];return Be.forEach((ce,_t)=>{let it=_t===Be.length-1,uo=Ee.join(te,ce.name),pt=it?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 ",mn=rt+(it?" ":"\u2502 ");if(ce.isCollapsed){st+=`${rt}${pt}${ce.name}${pe}...
|
|
433
|
+
`;return}ce.isDir?re>Ie?st+=`${rt}${pt}${ce.name}${pe} ...depth exceeded...
|
|
434
|
+
`:ze(uo).length>80?st+=`${rt}${pt}${ce.name}${pe} ...80+ files...
|
|
435
|
+
`:(st+=`${rt}${pt}${ce.name}${pe}
|
|
436
|
+
`,st+=Fe(uo,Ie,mn,re+1)):st+=`${rt}${pt}${ce.name}
|
|
437
|
+
`}),st};yield{type:"status",content:"Gathering Context..."},await new Promise(te=>setTimeout(te,500));let Qe=Je(process.cwd()),me=12;Qe>4096?me=1:Qe>3072?me=2:Qe>2048?me=3:Qe>1024?me=4:Qe>512?me=6:Qe>256?me=7:Qe>128?me=8:Qe>64?me=9:Qe>32&&(me=10);let yo=ye(Zr,{}),wo=yo[u],un=wo?wo!==process.cwd():!1;yo[u]=process.cwd(),ke(Zr,yo);let ro=ye(w,{}),Le=ro[u]||{summary:"",historyLength:0};typeof Le=="string"&&(Le={summary:Le,historyLength:0});let yt=o.filter(te=>(te.role==="user"||te.role==="agent"||te.role==="system")&&!String(te.id).startsWith("welcome")&&!te.isMeta).length;Le.historyLength&&yt<Le.historyLength&&(Le.summary="",Le.historyLength=0,ro[u]=Le,ke(w,ro));let Vo=typeof Le=="object"?Le.summary||"":Le||"",zo=Vo?`
|
|
435
438
|
**CONTEXT SUMMARY OF PREVIOUS TURNS (PRIORITY: HIGH)**
|
|
436
|
-
${
|
|
437
|
-
`+
|
|
438
|
-
`,
|
|
439
|
-
Cursor Line: ${
|
|
440
|
-
`,
|
|
441
|
-
`),
|
|
442
|
-
`);st.length>
|
|
439
|
+
${Vo}`:"",Yt=process.cwd()+`
|
|
440
|
+
`+Fe(process.cwd(),me),W=await Ir(),Re="";if(Yo())if(Re=`[IDE CONTEXT]
|
|
441
|
+
`,W.file_focused!=="none"){let te=Ee.relative(process.cwd(),W.file_focused),Ie=(W.opened_editors||[]).map(re=>{let ge=Ee.relative(process.cwd(),re);return ge.startsWith("..")?`[External] ${Ee.basename(re)}`:ge});if(Re+=`Focused File: ${te}
|
|
442
|
+
Cursor Line: ${W.cursor_line}
|
|
443
|
+
`,W.selected&&(Re+=`Current Selection: "${W.selected}"
|
|
444
|
+
`),W.manual_edits){let re=W.manual_edits,ge=4*512,pe=50,st=re.split(`
|
|
445
|
+
`);st.length>pe&&(re=st.slice(0,pe).join(`
|
|
443
446
|
`)+`
|
|
444
|
-
... (${st.length-
|
|
445
|
-
... (Character limit reached, truncated)`),
|
|
446
|
-
${
|
|
447
|
-
`}
|
|
447
|
+
... (${st.length-pe} more lines truncated)`),re.length>ge&&(re=re.substring(0,ge)+`
|
|
448
|
+
... (Character limit reached, truncated)`),Re+=`Recent Manual Edits:
|
|
449
|
+
${re}
|
|
450
|
+
`}Ie.length>0&&(Re+=`All Opened Editors: ${Ie.join(", ")}`),W.diagnostics&&(Re+=`
|
|
448
451
|
**ACTIVE FILE ERRORS**:
|
|
449
|
-
${
|
|
450
|
-
`),(
|
|
452
|
+
${W.diagnostics}
|
|
453
|
+
`),(P.toLowerCase().includes("lint")||P.toLowerCase().includes("warning"))&&W.warnings&&(Re+=`
|
|
451
454
|
**LINT WARNINGS**:
|
|
452
|
-
${
|
|
453
|
-
`)}else
|
|
454
|
-
CWD: ${process.cwd()}${un?` (WARNING: CWD Mismatch! Previous Path: ${
|
|
455
|
+
${W.warnings}
|
|
456
|
+
`)}else Re+="No file currently focused.";let Or=`[SYSTEM METADATA (PRIORITY: DYNAMIC), Chat Context >> Metadata] Time: ${fe}
|
|
457
|
+
CWD: ${process.cwd()}${un?` (WARNING: CWD Mismatch! Previous Path: ${wo})`:""}
|
|
455
458
|
**DIRECTORY STRUCTURE**
|
|
456
|
-
${
|
|
457
|
-
${l!="Fast"&&
|
|
458
|
-
`:""}`:""}[USER] ${
|
|
459
|
-
|
|
460
|
-
[STEERING HINT]: ${
|
|
461
|
-
`:""}`:""}[STEERING HINT]: ${
|
|
462
|
-
[SYSTEM] Tool result received. Analyze output and proceed with your turn${l!="Fast"&&
|
|
463
|
-
[SYSTEM] WARNING, Turn Limit Impending: Step ${ot}/${
|
|
464
|
-
`).length
|
|
465
|
-
${
|
|
466
|
-
${
|
|
467
|
-
${
|
|
468
|
-
|
|
469
|
-
${
|
|
459
|
+
${Yt}${zo}${nt}${Re}
|
|
460
|
+
${l!="Fast"&&m==="Google"?`${e.toLowerCase().startsWith("gemma")?`[SYSTEM] **STRICTLY FOLLOW THINKING POLICY AS CRITICAL PRIORITY. DO NOT START A RESPONSE WITHOUT <think> ... </think>**
|
|
461
|
+
`:""}`:""}[USER] ${P.replace(/\s*\[Prompted on:.*?\]/g,"").trim()}`.trim();k.push({role:"user",text:Or});let jt=null,jn=c==="Flux"?70:7,mt=16;yield{type:"status",content:"Connecting..."},ir=!1;let Mo=[],Nt=!1;k.forEach(te=>{te.text&&te.role==="agent"&&(te.text=te.text.replace(/(?:<(think|thought)>|\[(think|thought)\])[\s\S]*?(?:<\/(think|thought)>|\[\/(think|thought)\])/gi,"").trim())});for(let te=0;te<=jn;te++){if(Nt=!1,d?.compression===0&&(a?.tokens||0)>D&&(k=Ea(k,6)),te>0&&(yield{type:"status",content:"Processed. Reconnecting..."}),ir){yield{type:"status",content:"Termination Signal Received."},await new Promise(se=>setTimeout(se,1500));break}if(n){let se=await n();se&&(k.length>0&&k[k.length-1].role==="user"?k[k.length-1].text+=`
|
|
462
|
+
|
|
463
|
+
[STEERING HINT]: ${se}`:k.push({role:"user",text:`${l!="Fast"&&m==="Google"?`${e.toLowerCase().startsWith("gemma")?`[SYSTEM] **STRICTLY FOLLOW THINKING POLICY AS CRITICAL PRIORITY. DO NOT START A RESPONSE WITHOUT <think> ... </think>**
|
|
464
|
+
`:""}`:""}[STEERING HINT]: ${se}`}),yield{type:"status",content:"Steering Hint Injected."})}let Ie,rt=!1,re=1,ge=1,pe="",st=null,$o=null,wt=null,ft=0,Be=[],ce=0,_t=!1,it=!1,uo=!1,pt=!1,mn=!0,et="",at="",Ut=!1,Gt=e,Jo="";for(;re<=mt&&ge<=mt&&!rt&&!ir;){let se=!1;try{pe="",mn&&(process.stdout.isTTY&&process.stdout.write("\x1B]0;Working...\x07"),yield{type:"turn_reset",content:!0},yield{type:"spinner",content:!0},mn=!1,ge===1&&(et=""));let Ne=k.filter(Se=>(Se.role==="user"||Se.role==="agent"||Se.role==="system")&&!String(Se.id).startsWith("welcome")&&!Se.isMeta&&!Se.isTerminalRecord&&!(Se.text&&Se.text.startsWith("[TERMINAL_RECORD]"))).map((Se,ot,qt)=>{let Pe=Se.text||"";Se.role==="agent"&&(Pe=Pe.replace(/\[turn:\s*finish\]/gi,"").trim());let mo=[{text:Pe}];return Se.binaryPart&&Ei(Gt)&&qt.slice(ot+1).filter(Qo=>Qo.role==="user"&&!Qo.text?.startsWith("[TOOL RESULT]")).length<=2&&mo.push(Se.binaryPart),{role:Se.role==="user"||Se.role==="system"?"user":"model",parts:mo}});if(!await Vs("agent",t))throw new Error("Error: Quota Exausted for Agent");Gt=e,m==="DeepSeek"&&l==="Fast"&&(Gt="deepseek-chat"),re===mt-1?(Gt=m==="DeepSeek"?"deepseek-v4-flash":"gemini-3-flash-preview",yield{type:"model_update",content:"Trying with fallback model"}):re===mt?(Gt=m==="DeepSeek"?"deepseek-v4-pro":"gemini-3.5-flash",yield{type:"model_update",content:"Trying with fallback model"}):re>12&&re<mt-2&&t.apiKey!=="custom"?(Gt="gemma-4-31b-it",yield{type:"model_update",content:"Trying with fallback Gemma Model"}):re>0&&(yield{type:"model_update",content:null}),Jo=ha(r,(Gt||"gemma").toLowerCase().startsWith("gemma")?l:"GEM",c,d,S,$,m,h);let _e=e&&e.toLowerCase().startsWith("gemma"),lt=Ne[Ne.length-1];if(_e){let Se=`
|
|
465
|
+
[SYSTEM] Tool result received. Analyze output and proceed with your turn${l!="Fast"&&m==="Google"?". **STRICTLY MAINTAIN THINKING POLICY. DO NOT START A RESPONSE WITHOUT <think> ... </think>}**":""}`;lt&<.role==="user"&<.parts?.[0]?.text?.startsWith("[TOOL RESULT]")&&(lt.parts[0].text+=Se)}if(_e){let Se=Math.floor(jn*(c==="Flux"?.98:.7)),ot=te+1;ot>=Se&<&<.parts?.[0]&&(lt.parts[0].text+=`
|
|
466
|
+
[SYSTEM] WARNING, Turn Limit Impending: Step ${ot}/${jn}. Wrap up quickly/prompt user to continue & use [turn:finish] quickly.`)}let Tt=Ne;m==="OpenRouter"?Ie=Ii(t.apiKey,Gt,Tt,Jo,l,c,h):m==="DeepSeek"?Ie=ki(t.apiKey,Gt,Tt,Jo,l,c,h):Ie=await ar.models.generateContentStream({model:Gt||"gemma-4-31b-it",contents:Tt,config:{systemInstruction:Jo,temperature:c==="Flux"?1:1.4,maxOutputTokens:32768,mediaResolution:"MEDIA_RESOLUTION_MEDIUM",safetySettings:[{category:An.HARM_CATEGORY_HARASSMENT,threshold:Mn.BLOCK_NONE},{category:An.HARM_CATEGORY_HATE_SPEECH,threshold:Mn.BLOCK_NONE},{category:An.HARM_CATEGORY_SEXUALLY_EXPLICIT,threshold:Mn.BLOCK_NONE},{category:An.HARM_CATEGORY_DANGEROUS_CONTENT,threshold:Mn.BLOCK_NONE}],thinkingConfig:(()=>{let Se=(Gt||"").toLowerCase(),ot=Se.includes("gemma-4")||Se.startsWith("gemma"),qt=Se.includes("gemini-3");if(ot||qt)return ot?{includeThoughts:!1,thinkingLevel:jo.MINIMAL}:{includeThoughts:!0,thinkingLevel:{Fast:Se.includes("pro")?jo.LOW:jo.MINIMAL,Low:jo.LOW,Medium:jo.MEDIUM,High:jo.HIGH,xHigh:jo.HIGH}[l]||jo.MEDIUM};{let Pe={Fast:0,Low:512,Medium:2048,High:16384,xHigh:24576}[l]||2048;return Pe===0?{includeThoughts:!1}:{includeThoughts:!0,thinkingBudget:Pe}}})()}}),pe="",st=null,wt=null,Be=[],ce=0,yield{type:"model_update",content:null},yield{type:"status",content:"Working..."},at="",Ut=et.length>0;let tt="",Xt=Date.now();for await(let Se of Ie){if(ir){yield{type:"status",content:"Termination Signal Received."},await new Promise(Pe=>setTimeout(Pe,1500));break}let ot="",qt=Se.candidates?.[0]?.content?.parts;if(qt&&qt.length>0)for(let Pe of qt)Pe.thought?Pe.text&&(se||(ot+="<think>",se=!0),ot+=Pe.text):Pe.text&&(se&&(ot+="</think>",se=!1),ot+=Pe.text);else{let Pe=Se.text||"";Pe&&se&&(ot+="</think>",se=!1),ot+=Pe}if(ot){if(Ut){if(at+=ot,at.length>=30){let J=0,We=Math.min(et.length,at.length);for(let Y=We;Y>0;Y--)if(et.endsWith(at.substring(0,Y))){J=Y;break}let St=at.substring(J);if(St){let Ge=/(?:<(think|thought)>|\[(think|thought)\])(?:(?!(?:<\/(?:think|thought)>|\[\/(?:think|thought)\]))[\s\S])*$/i.test(et)?St.replace(/^\s*(?:<(think|thought)>|\[(think|thought)\])\s*/gi,""):St.replace(/^\s*(?:<(think|thought)>|\[(think|thought)\])[\s\S]*?(?:<\/(think|thought)>|\[\/(think|thought)\])\s*/gi,"").replace(/^\s*(?:<(think|thought)>|\[(think|thought)\])\s*/gi,"");Ge&&(pe+=Ge,m==="Google"?tt+=Ge:yield{type:"text",content:Ge})}Ut=!1,at=""}continue}else pe+=ot,m==="Google"?tt+=ot:yield{type:"text",content:ot};let Pe=sl(pe),mo=Hc(pe);if(mo.inside){wt||(wt=Date.now());let J=mo.toolName,St={Ask:"ask",WebSearch:"web_search",WebScrape:"web_scrape",ReadFile:"view_file",ReadFolder:"read_folder",WriteFile:"write_file",PatchFile:"update_file",WritePDF:"write_pdf",WriteDoc:"write_docx",Run:"exec_command",SearchKeyword:"search_keyword",Memory:"memory",Chat:"chat",chat:"chat",GenerateImage:"generate_image",generate_image:"generate_image"}[J]||J,Y=mo.args||"",Ge=null;if(["write_file","update_file","view_file","read_folder","write_pdf","write_docx","search_keyword","generate_image"].includes(St)){let $e=ne(Y),Bo=$e.path||$e.targetFile||$e.TargetFile||$e.directory,en=$e.keyword;if(en)Ge=en.replace(/["']/g,"");else if(Bo)Ge=Ee.basename(Bo.replace(/["']/g,"").replace(/\\/g,"/"));else{let Pn=Y.match(/(?:path|targetFile|TargetFile|directory|keyword)\s*=\s*\\?["']?([^\\"' \),]+)/);if(Pn){let Et=Pn[1].replace(/["']/g,"");Ge=St==="search_keyword"?Et:Ee.basename(Et.replace(/\\/g,"/"))}}}let Vt=`${rl[St]||St}${Ge?` (${Ge})`:""}`;if((St!==st||Ge!==$o)&&(st=St,$o=Ge,yield{type:"status",content:`${Vt}...`},process.stdout.isTTY)){let Bo={web_search:"Searching",web_scrape:"Reading",view_file:"Reading",read_folder:"Reading",list_files:"Reading",write_file:"Writing",update_file:"Editing",write_pdf:"Creating",write_docx:"Creating",search_keyword:"Searching",exec_command:"Executing",ask:"User Input",memory:"Updating Memory",generate_image:"Generating"}[St]||"Working";process.stdout.write(`\x1B]0;${Bo}...\x07`)}}let Xn=cl(pe,!1),fn=(Xn.match(/(?:<think>|\[think\])([\s\S]*?)(?:<\/think>|\[\/think\]|$)/gi)||[]).join("").trim(),Zo=fn.split(/[.!?]\s+/),vr=new Set(Zo),Fn=Zo.length>10?(Zo.length-vr.size)/Zo.length:0,$r=fn.split(/\s+/).filter(J=>J.length>0).length,Fo=.4,Fr=.6,Kn=!1;if((Gt||"").toLowerCase().startsWith("gemma")){let We={low:256,medium:768,high:2048,max:4096,xhigh:4096}[l?.toLowerCase()]||2500;Kn=$r>We}if(Fn>Fo||Kn){yield{type:"status",content:`${Fn>Fo?"Reasoning Loop Detected":"Thinking Budget Exceeded"}. Re-centering...`},it=!0,await new Promise(We=>setTimeout(We,3e3));break}let qn=Pe.trim().split(/[.!?]\s+/),pn=new Set(qn);if((qn.length>10?(qn.length-pn.size)/qn.length:0)>Fr){yield{type:"status",content:"Response Loop Detected. Re-centering..."},it=!1,pt=!0,await new Promise(J=>setTimeout(J,3e3));break}let Po=Xn.toLowerCase().split(/\s+/).filter(J=>J.length>0),hn=!1;if(Po.length>5)for(let J=1;J<=15;J++){let We=Math.max(3,Math.ceil(8/J));if(Po.length<J*We)continue;let St=!0,Ge=Po.slice(Po.length-J).join(" ");for(let Vt=1;Vt<We;Vt++)if(Po.slice(Po.length-J*(Vt+1),Po.length-J*Vt).join(" ")!==Ge){St=!1;break}if(St){hn=!0;break}}if(!hn){let J=Xn.toLowerCase().replace(/[^a-z0-9]/gi,"");if(J.length>=10)for(let We=1;We<=10;We++){let St=Math.max(4,Math.ceil(12/We));if(J.length<We*St)continue;let Y=J.substring(J.length-We),Ge=!0;for(let Vt=1;Vt<St;Vt++)if(J.substring(J.length-We*(Vt+1),J.length-We*Vt)!==Y){Ge=!1;break}if(Ge){hn=!0;break}}}if(hn){yield{type:"status",content:"Stuttering Detected. Re-centering..."},it=!1,uo=!0,await new Promise(J=>setTimeout(J,3e3));break}let Vn=pe.replace(/(?:<(think|thought|thoughts)>|\[(think|thought|thoughts)\])[\s\S]*?(?:<\/(think|thought|thoughts)>|\[\/(think|thought|thoughts)\]|$)/gi,""),Br=Mi(Vn);for(;Br.length>ce;){let J=Br[ce],We=Date.now(),Y={Ask:"ask",WebSearch:"web_search",WebScrape:"web_scrape",ReadFile:"view_file",ReadFolder:"read_folder",WriteFile:"write_file",PatchFile:"update_file",WritePDF:"write_pdf",WriteDoc:"write_docx",Run:"exec_command",SearchKeyword:"search_keyword",Memory:"memory",Chat:"chat",chat:"chat",GenerateImage:"generate_image",generate_image:"generate_image"}[J.toolName]||J.toolName,Ge=rl[Y]||J.toolName,Vt=Wc(Y,J.args);yield{type:"status",content:`${Ge}${Vt?` (${Vt})`:""}...`};let $e="";if(Y==="web_search"){let{query:le,limit:Me=10}=ne(J.args);$e=`\u{1F50D} Searched: ${le}`}else if(Y==="web_scrape")$e=`\u{1F4D6} Visited: ${ne(J.args).url||"..."}`;else if(Y==="view_file"){let{path:le,StartLine:Me,EndLine:He,start_line:Xe,end_line:ht,startLine:be,endLine:fo}=ne(J.args),x=Me||Xe||be,g=He||ht||fo,M=parseInt(x)||1,B=parseInt(g)||(x?M+800:800),A="...",v=B;try{let R=Ee.resolve(process.cwd(),le);if(dt.existsSync(R)){let De=dt.readFileSync(R,"utf8").split(`
|
|
467
|
+
`).length;A=De,v=Math.min(B,De)}}catch{}let j=le.toLowerCase(),b=j.endsWith(".pdf"),L=j.endsWith(".docx")||j.endsWith(".doc")||j.endsWith(".ppt")||j.endsWith(".pptx")||j.endsWith(".xls")||j.endsWith(".xlsx"),F=/\.(png|jpg|jpeg|webp|gif|bmp)$/.test(j);b||L?$e=`\u{1F4C4} Viewed: ${le}`:F?$e=`\u{1F4F8} Viewed: ${le}`:$e=`\u{1F4C4} Read: ${le} \u2192 Lines ${M} - ${v} of ${A}`}else if(Y==="list_files"||Y==="read_folder"){let le=Y==="list_files"?"List":"Viewed",Me=ne(J.args).path;$e=`\u{1F4C2} ${le}: ${Me==="."?"./":Me}`}else if(Y==="write_file"||Y==="update_file")$e=`\u{1F4BE} ${Y==="write_file"?"Created":"Edited"}: ${ne(J.args).path||"..."}`;else if(Y==="write_pdf")$e=`\u{1F4D1} Created: ${ne(J.args).path||"..."}`;else if(Y==="write_docx")$e=`\u{1F4DD} Created: ${ne(J.args).path||"..."}`;else if(Y==="search_keyword")$e="";else if(Y==="generate_image"){let{path:le,outputPath:Me,output:He}=ne(J.args);$e=`\u{1F3A8} Generated: ${le||Me||He||"generated_image.png"}`}else Y==="exec_command"||Y==="ask"?$e="":$e=`Executed: ${J.toolName}`;if(Y==="exec_command"){let{command:le}=ne(J.args);if(le&&t.systemSettings&&t.systemSettings.allowExternalAccess===!1){let Me=[/[a-zA-Z]:[\\\/]/i,/^\//,/\.\.[\\\/]/,/\/etc\//,/\/var\//,/\/root\//,/\/bin\//,/\/usr\//],He=Ee.resolve(process.cwd()).substring(0,3).toLowerCase();if(Me.some(ht=>{if(ht.source==="[a-zA-Z]:[\\\\\\/]"){let be=le.match(/[a-zA-Z]:[\\\/]/i);return be&&be[0].toLowerCase()!==He}return ht.test(le)})){let ht='Access Denied. Terminal is prohibited from accessing system drives (C://) or external directories while "External Workspace Access" is disabled.';t.onExecStart&&t.onExecStart(le||"Unknown"),yield{type:"exec_start"},await new Promise(be=>setTimeout(be,50)),t.onExecChunk&&t.onExecChunk(`ERROR: ${ht}`),await new Promise(be=>setTimeout(be,50)),t.onExecEnd&&t.onExecEnd(),Be.push({role:"user",text:`[TOOL RESULT]: ERROR: ${ht}`}),yield{type:"tool_result",content:`[TOOL RESULT]: ERROR: ${ht}`},ce++;continue}}t.onExecStart&&t.onExecStart(le||"Unknown"),yield{type:"exec_start"}}let Bo=ne(J.args),en=Bo.path||Bo.targetPath||null;if(en){let le=t.systemSettings&&t.systemSettings.allowExternalAccess===!1,Me=Ee.resolve(en),He=Ee.resolve(process.cwd());if(le&&!Me.startsWith(He)){let Xe="Access Denied. You are not allowed to access files outside the current workspace.";if(Y==="write_file"||Y==="update_file"){let be=`\u{1F4BE} ${Y==="write_file"?"Write Canceled":"Edit Canceled"}: ${Bo.path||"..."}`,fo=Math.min(be.length+4,115),x=`\u256D${"\u2500".repeat(fo)}\u256E`,g=`\u2502 ${be.padEnd(fo-2).substring(0,fo-2)} \u2502`,M=`\u2570${"\u2500".repeat(fo)}\u256F`;yield{type:"visual_feedback",content:`${x}
|
|
468
|
+
${g}
|
|
469
|
+
${M}`}}Be.push({role:"user",text:`[TOOL RESULT]: ERROR: ${Xe}`}),yield{type:"tool_result",content:`[TOOL RESULT]: ERROR: ${Xe}`},ce++;continue}}if(t.onToolApproval&&(Y==="write_file"||Y==="update_file"||Y==="exec_command")){let Me=t.systemSettings||{},He=Me.autoExec,Xe=null,ht=!1,be=!1,fo=!1;if(Y==="exec_command"){let{command:b}=ne(J.args),L=(b||"").trim(),F=(De,xe)=>{if(!xe)return!1;let Ae=xe.split(",").map(Ye=>Ye.trim().toLowerCase()).filter(Boolean),ve=De.toLowerCase();return Ae.some(Ye=>ve.startsWith(Ye))},R=F(L,Me.alwaysAskCommands),V=F(L,Me.autoApproveCommands);be=F(L,Me.autoDisallowCommands),R?ht=!0:(V||Me.autoApproveGit&&/^git\s+commit\b/i.test(L))&&(Xe="allow"),!ht&&!Xe&&(Me.networkAccess===!1&&/\b(curl|wget|npm|yarn|pnpm|pip|pip3|ssh|docker|git\s+(clone|push|pull|fetch))\b/i.test(L)&&(Xe="deny",fo=!0),!Xe&&be&&(Xe="deny")),!ht&&!Xe&&He&&(Xe="allow")}else He&&(Xe="allow");let x=Xe,g="";Xe==="deny"&&(fo?g="network":be?g="settings":g="prohibited");let M=!1,B="",A=[],v=0,j=!1;if(!x){if(Y==="write_file"||Y==="update_file")try{let F=ne(J.args),{path:R}=F;if(R){let V=Ee.resolve(process.cwd(),R),De=zt=>zt?zt.toLowerCase().replace(/\\/g,"/").replace(/^[a-z]:/,$t=>$t.toUpperCase()):"",xe=De(V),Ae="",ve=!1,Ye=await Ir(),gn=De(Ye?.file_focused);if(Ye&&gn===xe&&Ye.full_content?(Ae=Ye.full_content,ve=!0):dt.existsSync(V)&&(Ae=dt.readFileSync(V,"utf8"),ve=!0),B=Ae,await bt.recordFileChange(V,Ae),ve){let zt=Ae;if(Y==="write_file")zt=F.content||F.newContent||"";else{let{patchPairs:$t,error:No}=Wr(F);if(No){let N=`[TOOL RESULT]: ERROR: ${No}`;Be.push({role:"user",text:N}),await Ho("toolFailure"),t.onToolResult&&t.onToolResult("failure",Y),yield{type:"tool_result",content:N,toolName:Y},ce++;continue}v=$t.length;let po=Hr(Ae,$t);zt=po.content,A=po.results;let _r=A.filter(N=>N.success),zn=A.filter(N=>!N.success);if(_r.length===0){let N=`[TOOL RESULT]: ERROR: Failed to apply patches to [${Ee.basename(V)}].
|
|
470
|
+
${zn.map(he=>` \u2022 ${he.error}`).join(`
|
|
471
|
+
`)}`,ie=`\u{1F4BE} Edited: ${Ee.basename(V)}`.toUpperCase(),ue=Math.min(ie.length+4,115),Oe=`\u256D${"\u2500".repeat(ue)}\u256E`,kt=`\u2502 ${ie.padEnd(ue-2).substring(0,ue-2)} \u2502`,de=`\u2570${"\u2500".repeat(ue)}\u256F`;yield{type:"visual_feedback",content:`${Oe}
|
|
472
|
+
${kt}
|
|
473
|
+
${de}`},Be.push({role:"user",text:N}),await Ho("toolFailure"),t.onToolResult&&t.onToolResult("failure",Y),yield{type:"tool_result",content:N,toolName:Y},ce++;continue}}yield{type:"status",content:`Opening Diff in IDE: ${Ee.basename(V)}...`},Ti(V,Ae,zt),M=!0,await new Promise($t=>setTimeout($t,50))}else if(Y==="write_file"){let zt=F.content||F.newContent||"";dt.existsSync(V)||(j=!0,dt.mkdirSync(Ee.dirname(V),{recursive:!0}),dt.writeFileSync(V,"","utf8")),yield{type:"status",content:`Opening New File Diff in IDE: ${Ee.basename(V)}...`},Ti(V,"",zt),M=!0,await new Promise($t=>setTimeout($t,50))}}}catch(F){console.error("Simulation/Diff Error:",F)}let b=null;wi(F=>{b=F});let L=t.onToolApproval;if(x=await new Promise(async F=>{let R=setInterval(()=>{b&&(bi.onIDEApproval&&bi.onIDEApproval(b),clearInterval(R),F(b))},100);try{let V=await L(Y,J.args);clearInterval(R),F(V)}catch{clearInterval(R),F("deny")}}),wi(null),Y==="write_file"||Y==="update_file"){let{path:F}=ne(J.args);if(F){let R=Ee.resolve(process.cwd(),F);if(nl(R,x),x==="deny"&&j&&dt.existsSync(R))try{dt.unlinkSync(R)}catch{}}}x==="deny"&&(g="user")}if(x==="allow"&&M&&Yo()){let{path:b}=ne(J.args),L=Ee.resolve(process.cwd(),b),F=await Ir(),R="";F&&F.file_focused===L&&F.full_content?R=F.full_content:dt.existsSync(L)&&(R=dt.readFileSync(L,"utf8"));let V=R.split(/\r?\n/),De=V.length,xe=Buffer.byteLength(R,"utf8"),Ae="";B&&(Ae=`Old File contents:
|
|
474
|
+
${B.split(/\r?\n/).map((ue,Oe)=>`${Oe+1} | ${ue}`).join(`
|
|
470
475
|
`)}
|
|
471
476
|
|
|
472
|
-
`);let
|
|
473
|
-
`);else{let
|
|
474
|
-
`),
|
|
475
|
-
`);
|
|
477
|
+
`);let ve="";if(De<=200)ve=V.join(`
|
|
478
|
+
`);else{let ie=V.slice(0,100).join(`
|
|
479
|
+
`),ue=V.slice(-100).join(`
|
|
480
|
+
`);ve=`${ie}
|
|
476
481
|
|
|
477
|
-
... [${
|
|
482
|
+
... [${De-200} lines truncated for history stability] ...
|
|
478
483
|
|
|
479
|
-
${
|
|
484
|
+
${ue}`}let Ye="";if(Y==="update_file"){let ie=Yr(B,R,A,12);Ye=`SUCCESS: File [${b}] updated via IDE Companion (May have user edits). [${A.length}/${v}] blocks applied.
|
|
480
485
|
|
|
481
|
-
${
|
|
482
|
-
${
|
|
486
|
+
${ie}`}else{let ie=R.split(/\r?\n/),ue=ie.length,Oe=Buffer.byteLength(R,"utf8"),kt="";B&&(kt=`Old File contents:
|
|
487
|
+
${B.split(/\r?\n/).map((Ke,qe)=>`${qe+1} | ${Ke}`).join(`
|
|
483
488
|
`)}
|
|
484
489
|
|
|
485
|
-
`);let
|
|
486
|
-
`);else{let
|
|
487
|
-
`),
|
|
488
|
-
`);
|
|
490
|
+
`);let de="";if(ue<=200)de=ie.join(`
|
|
491
|
+
`);else{let he=ie.slice(0,100).join(`
|
|
492
|
+
`),Ke=ie.slice(-100).join(`
|
|
493
|
+
`);de=`${he}
|
|
489
494
|
|
|
490
|
-
... [${
|
|
495
|
+
... [${ue-200} lines truncated] ...
|
|
491
496
|
|
|
492
|
-
${
|
|
497
|
+
${Ke}`}Ye=`SUCCESS: File [${b}] saved via IDE Companion (May have user edits).
|
|
493
498
|
|
|
494
|
-
- Stats: [${
|
|
495
|
-
${
|
|
496
|
-
${
|
|
499
|
+
- Stats: [${ue} lines, ${(Oe/1024).toFixed(1)} KB]
|
|
500
|
+
${kt}- Content Preview:
|
|
501
|
+
${de}
|
|
497
502
|
|
|
498
|
-
Check if Starting and Ending matches your write.`}let
|
|
499
|
-
${
|
|
500
|
-
${
|
|
501
|
-
${
|
|
502
|
-
${
|
|
503
|
-
${
|
|
504
|
-
${
|
|
505
|
-
${
|
|
506
|
-
${
|
|
507
|
-
`)}`;
|
|
503
|
+
Check if Starting and Ending matches your write.`}let zt=`\u{1F4BE} ${Y==="write_file"?"Written":"Edited"}: ${b||"..."}`,$t=Math.min(zt.length+4,115),No=`\u256D${"\u2500".repeat($t)}\u256E`,po=`\u2502 ${zt.padEnd($t-2).substring(0,$t-2)} \u2502`,_r=`\u2570${"\u2500".repeat($t)}\u256F`;yield{type:"visual_feedback",content:`${No}
|
|
504
|
+
${po}
|
|
505
|
+
${_r}`};let zn=Date.now();ft=zn,yield{type:"tool_time",content:zn-We};let N=`[TOOL RESULT]: ${Ye}`;Be.push({role:"user",text:N}),_t=!0,await Ho("toolSuccess"),t.onToolResult&&t.onToolResult("success",Y),yield{type:"tool_result",content:Ye,aiContent:N,toolName:Y},ce++;continue}if(x==="deny"){let b=`Permission Denied: Prohibited ${Y==="exec_command"?"Command":"file edit"}.`;if(g==="user"?b="Permission Denied by User":g==="settings"?b="Permission Denied by User Policy":g==="network"?b="Permission Denied: Sandbox Network Access Disabled by User Policy.":g==="prohibited"&&Y==="exec_command"&&(b="Permission Denied: Prohibited Command"),Y==="write_file"||Y==="update_file"){let F=`\u{1F4BE} ${Y==="write_file"?"WRITE DENIED":"UPDATE DENIED"}: ${ne(J.args).path||"..."}`.toUpperCase(),R=Math.min(F.length+4,115),V=`\u256D${"\u2500".repeat(R)}\u256E`,De=`\u2502 ${F.padEnd(R-2).substring(0,R-2)} \u2502`,xe=`\u2570${"\u2500".repeat(R)}\u256F`;yield{type:"visual_feedback",content:`${V}
|
|
506
|
+
${De}
|
|
507
|
+
${xe}`}}Y==="exec_command"&&(await new Promise(L=>setTimeout(L,50)),t.onExecChunk&&t.onExecChunk(`ERROR: ${b}`),await new Promise(L=>setTimeout(L,50)),t.onExecEnd&&t.onExecEnd()),Be.push({role:"user",text:`[TOOL RESULT]: DENIED: ${b}`}),yield{type:"tool_result",content:`[TOOL RESULT]: DENIED: ${b}`},await Ho("toolDenied"),t.onToolResult&&t.onToolResult("denied",Y),ce++;continue}}if($e){let le=Math.min($e.length+4,115),Me=`\u256D${"\u2500".repeat(le)}\u256E`,He=`\u2502 ${$e.padEnd(le-2).substring(0,le-2)} \u2502`,Xe=`\u2570${"\u2500".repeat(le)}\u256F`;yield{type:"visual_feedback",content:`${Me}
|
|
508
|
+
${He}
|
|
509
|
+
${Xe}`}}if(ft>0){let le=Date.now()-ft;le<1e3&&await new Promise(Me=>setTimeout(Me,1e3-le))}yield{type:"spinner",content:!1};let Pn={chatId:u,history:o,onChunk:le=>t.onExecChunk?t.onExecChunk(le):null,onAskUser:t.onAskUser,systemSettings:t.systemSettings,mode:c,isMultiModal:Ei(Gt)};if(Y==="write_file"||Y==="update_file")try{let{path:le}=ne(J.args);if(le){let Me=Ee.resolve(process.cwd(),le),He=await Ir();He&&He.file_focused===Me&&He.full_content&&(Pn.forcedContent=He.full_content)}}catch{}let Et=await cs(Y,J.args,Pn);if(yield{type:"spinner",content:!0},Y==="write_file"&&Et.startsWith("SUCCESS")){let{path:le}=ne(J.args);if(le){let Me=Ee.resolve(process.cwd(),le);ol(Me)}}process.stdout.isTTY&&process.stdout.write("\x1B]0;Working...\x07");let vt=Date.now();ft=vt,yield{type:"tool_time",content:vt-We},wt=vt;let _=null;if(typeof Et=="object"&&Et.binaryPart&&(_=Et.binaryPart,Et=Et.text),Y==="search_keyword"){let{keyword:le,file:Me}=ne(J.args),He=0;if(Et){let g=Et.match(/Found (\d+) matches/i);g&&(He=parseInt(g[1]))}let Xe=`\u{1F50E} Searched: "${le}" in ${Me?`"${Me}"`:"./"} \u2192 ${He} Match${He===1?"":"es"}`,ht=Math.min(Xe.length+4,115),be=`\u256D${"\u2500".repeat(ht)}\u256E`,fo=`\u2502 ${Xe.padEnd(ht-2).substring(0,ht-2)} \u2502`,x=`\u2570${"\u2500".repeat(ht)}\u256F`;yield{type:"visual_feedback",content:`${be}
|
|
510
|
+
${fo}
|
|
511
|
+
${x}`}}Y==="exec_command"&&t.onExecEnd&&(await new Promise(le=>setTimeout(le,800)),t.onExecEnd());let Ao=Et&&Et.startsWith("DENIED:");Et&&!Et.startsWith("ERROR:")&&!Ao?(await Ho("toolSuccess"),t.onToolResult&&t.onToolResult("success",Y)):Ao||(await Ho("toolFailure"),t.onToolResult&&t.onToolResult("failure",Y));let ee=`[TOOL RESULT]: ${(Et||"").toString().split(/\r?\n/).filter(le=>!le.includes("[UI_CONTEXT]")).join(`
|
|
512
|
+
`)}`;Be.push({role:"user",text:ee,binaryPart:_}),_t=!0;let Nr=`[TOOL RESULT]: ${Et||""}`;(Y==="view_file"||Y==="web_scrape")&&(Nr=`[TOOL RESULT]: ${$e} (Context Locked for UI Clarity)`),yield{type:"tool_result",content:Nr,aiContent:ee,binaryPart:_,toolName:Y},Y==="memory"&&Et.includes("SUCCESS")&&(yield{type:"memory_updated"}),ce++}m==="Google"&&tt&&Date.now()-Xt>=150&&(yield{type:"text",content:tt},tt="",Xt=Date.now())}Se.usageMetadata&&(jt=Se.usageMetadata),jt&&(yield{type:"liveTokens",content:jt.totalTokenCount})}if(se&&(se=!1,Ut?at+="</think>":(pe+="</think>",m==="Google"?tt+="</think>":yield{type:"text",content:"</think>"})),Ut&&at.length>0){let Se=0,ot=Math.min(et.length,at.length);for(let Pe=ot;Pe>0;Pe--)if(et.endsWith(at.substring(0,Pe))){Se=Pe;break}let qt=at.substring(Se);if(qt){let mo=/(?:<(think|thought)>|\[(think|thought)\])(?:(?!(?:<\/(?:think|thought)>|\[\/(?:think|thought)\]))[\s\S])*$/i.test(et)?qt.replace(/^\s*(?:<(think|thought)>|\[(think|thought)\])\s*/gi,""):qt.replace(/^\s*(?:<(think|thought)>|\[(think|thought)\])[\s\S]*?(?:<\/(think|thought)>|\[\/(think|thought)\])\s*/gi,"").replace(/^\s*(?:<(think|thought)>|\[(think|thought)\])\s*/gi,"");mo&&(pe+=mo,m==="Google"?tt+=mo:yield{type:"text",content:mo})}Ut=!1,at=""}if(m==="Google"&&tt&&(yield{type:"text",content:tt},tt=""),ir)break;let To=(pe||"").trim(),Kt=/\[\s*(turn\s*:)?\s*finish\s*\]/i.test(To.toLowerCase()),Dt=/\[\s*(turn\s*:)?\s*continue\s*\]/i.test(To.toLowerCase()),so=Be.length>0||st!==null,So=To.replace(/(?:<think>|\[think\])[\s\S]*?(?:<\/think>|\[\/think\])/gi,"").trim(),$n=/(\p{Emoji_Presentation}|\p{Extended_Pictographic})$/u.test(So),Dr=/[.!?}"'`’“”]$|```$/s.test(So)||So.endsWith('."')||$n;if(!Kt&&!Dt&&!so&&To.length>0&&!Dr&&!it&&!uo&&!pt)throw new Error("Silent stream cutoff (500): Model stream closed cleanly but cut off mid-sentence without signals.");rt=!0,await Ho("agent")}catch(Ne){if(String(Ne).includes("Incomplete JSON segment at the end")){se&&(se=!1,Ut?at+="</think>":(pe+="</think>",yield{type:"text",content:"</think>"})),rt=!0,await Ho("agent");break}if(se&&(se=!1,Ut?at+="</think>":pe+="</think>"),Ut&&at.length>0){let Kt=0,Dt=Math.min(et.length,at.length);for(let So=Dt;So>0;So--)if(et.endsWith(at.substring(0,So))){Kt=So;break}let so=at.substring(Kt);if(so){let $n=/(?:<(think|thought)>|\[(think|thought)\])(?:(?!(?:<\/(?:think|thought)>|\[\/(?:think|thought)\]))[\s\S])*$/i.test(et)?so.replace(/^\s*(?:<(think|thought)>|\[(think|thought)\])\s*/gi,""):so.replace(/^\s*(?:<(think|thought)>|\[(think|thought)\])[\s\S]*?(?:<\/(think|thought)>|\[\/(think|thought)\])\s*/gi,"").replace(/^\s*(?:<(think|thought)>|\[(think|thought)\])\s*/gi,"");$n&&(pe+=$n)}Ut=!1,at=""}let _e=Ne.status||Ne.error&&Ne.error.message||String(Ne),lt=String(Ne),Tt=new Date().toLocaleString(),tt=Ee.join(Io,"agent");dt.existsSync(tt)||dt.mkdirSync(tt,{recursive:!0}),dt.appendFileSync(Ee.join(tt,"error.log"),`ERROR [${Tt}]: ${lt}
|
|
508
513
|
|
|
509
514
|
----------------------------------------------------------------------
|
|
510
515
|
|
|
511
|
-
`);let Xt=
|
|
516
|
+
`);let Xt=Ne.status||Ne.statusCode||Ne.code;if(!(Xt&&(Xt>=500&&Xt<600||Xt===408)||!Xt&&(/status[ :]+(5\d\d|408)/i.test(String(Ne))||/code[ :]+(5\d\d|408)/i.test(String(Ne))||/(500|503|408)/.test(String(Ne))))&&re<mt-3)throw Ne;if(pe.trim().length>0||ge>1)if(ge<=mt){ge++;let Kt=Math.min(1e3*Math.pow(2,ge-1),24e3);if(pe.trim().length>0){k.push({role:"agent",text:pe});let Dt=`[SYSTEM]
|
|
512
517
|
- SEAMLESS CONTINUATION: Resume immediately. Pick up from last words with zero gap/disruption
|
|
513
518
|
- NO REPETITION: Do not repeat any text already written
|
|
514
519
|
- NO RE-THINK: Do not restart or open <think> if reasoning already started. Continue the thinking and close thinking block with </think> if opened
|
|
515
520
|
- MID-TOOL SAFETY: If cutoff was mid-tool call, restart that tool call from start
|
|
516
|
-
- STEALTH: Do not mention/apologize for cutoff`;
|
|
521
|
+
- STEALTH: Do not mention/apologize for cutoff`;Be.length>0?Be.forEach((so,So)=>{So===Be.length-1?k.push({...so,text:`${so.text}
|
|
517
522
|
|
|
518
|
-
${Dt}`}):
|
|
519
|
-
Error Log can be found in ${
|
|
520
|
-
Error Log can be found in ${
|
|
521
|
-
`),
|
|
523
|
+
${Dt}`}):k.push(so)}):k.push({role:"user",text:Dt}),et+=pe}for(let Dt=Kt/1e3;Dt>0;Dt--)yield{type:"status",content:`Error Occured. Recovering Stream (${ge}/${mt}) [Retrying in ${Dt}s]...`},await new Promise(so=>setTimeout(so,1e3));yield{type:"status",content:"Error Occured. Recovering Stream..."}}else throw new Error(`Stream collapsed too many times. (Failed to resolve ${mt} times)
|
|
524
|
+
Error Log can be found in ${Ee.join(Io,"agent","error.log")}`);else if(re<=mt){re++,ge=1,et="";let Kt=Math.min(1e3*Math.pow(2,re-1),32e3);mn=!0,yield{type:"status",content:`Trying to reach ${e} (${re}/${mt}) [Retrying in ${(Kt/1e3).toFixed(0)}s]...`};for(let Dt=Kt/1e3;Dt>0;Dt--)yield{type:"status",content:`Trying to reach ${e} (${re}/${mt}) [Retrying in ${Dt}s]...`},await new Promise(so=>setTimeout(so,1e3));yield{type:"status",content:`Trying to reach ${e}...`}}else throw new Error(`Model ${e} cannot be reached. (Failed ${mt} times)
|
|
525
|
+
Error Log can be found in ${Ee.join(Io,"agent","error.log")}`)}}if(jt){let se=jt.totalTokenCount||0,Ne=jt.cachedContentTokenCount||0,_e=(jt.candidatesTokenCount||0)+(jt.thoughtsTokenCount||0);await xo("tokens",se),Ne>0&&await xo("cachedTokens",Ne),_e>0&&await xo("candidateTokens",_e),yield{type:"usage",content:jt}}Mo.push(pe);let ys=pe;pe.match(/(?:<think>|\[think\])([\s\S]*?)(?:<\/think>|\[\/think\])/i)&&(ys=pe.replace(/(?:<think>|\[think\])[\s\S]*?(?:<\/think>|\[\/think\])/i,""));let Lr=sl(pe),Gn=/\[\s*(turn\s*:)?\s*finish\s*\]/i.test(Lr.toLowerCase()),Pi=/\[\s*(turn\s*:)?\s*continue\s*\]/i.test(Lr.toLowerCase()),dr=ce>0;yield{type:"status",content:"Working..."};let ws=Yc(pe,/\[\s*(turn\s*:)?\s*(continue|finish)\s*\]/gi,"").trim(),vn=(Gn||Be.length===0)&&!it&&!uo&&!pt;if(vn=Be.length===0?vn:!1,vn){let se=Mo.join(`
|
|
526
|
+
`),Ne=se.replace(/(?:<think>|\[think\])[\s\S]*?(?:<\/think>|\[\/think\])/g,"").trim();yield{type:"interactive_turn_finished",data:{agentText:P,fullAgentTextRaw:se,history:[...k],needTitle:K}},k.length>0&&k[k.length-1].role==="agent"?k[k.length-1].text=Ne:k.push({role:"agent",text:Ne});try{let _e=ye(w,{}),lt=_e[u]||{summary:"",historyLength:0};typeof lt=="string"&&(lt={summary:lt,historyLength:0});let Tt=k.filter(tt=>(tt.role==="user"||tt.role==="agent"||tt.role==="system")&&!String(tt.id).startsWith("welcome")&&!tt.isMeta).length;I?lt.historyLength=(lt.historyLength||0)+Tt:lt.historyLength=Tt,_e[u]=lt,ke(w,_e)}catch{}}if(vn)break;let Ts=ws.trim()||"*Working...*";if(k.push({role:"agent",text:Ts}),Be.length>0||_t){if(Be.length>0){let se=Be.map(_e=>_e.text).join(`
|
|
522
527
|
|
|
523
|
-
`),
|
|
528
|
+
`),Ne=Be.find(_e=>_e.binaryPart)?.binaryPart||null;k.push({role:"user",text:se,binaryPart:Ne})}}else Nt?k.push({role:"user",text:"[SYSTEM] Failed to verify tool execution, Verify tool syntax, proper escaping or ask user if tool worked if unsure"}):k.push({role:"user",text:`[SYSTEM] ${uo&&!it?"STUTTERING DETECTED by Internal System. Re-calibrate your response & proceed.":`${it?" OVER THINKING":" LOOP"} DETECTED by Internal System${it?" for current EFFORT_LEVEL":""}. ${it?"If you have planned the task, prioritize execution/output":"If you have finished your task use [turn: finish] else continue"}`}`}),it=!1,uo=!1,pt=!1;Nt=ce>0||_t}e&&e.toLowerCase().startsWith("gemma")&&k.forEach(te=>{if(te.role==="user"&&te.text&&te.text.startsWith("[TOOL RESULT]")){let Ie=`
|
|
524
529
|
[SYSTEM] Tool result received. Analyze output and proceed with your turn`,rt=`
|
|
525
|
-
[SYSTEM] Tool result received. Analyze output and proceed with your turn. **STRICTLY MAINTAIN THINKING POLICY. DO NOT START A RESPONSE WITHOUT <think> ... </think>}**`;
|
|
526
|
-
`+
|
|
530
|
+
[SYSTEM] Tool result received. Analyze output and proceed with your turn. **STRICTLY MAINTAIN THINKING POLICY. DO NOT START A RESPONSE WITHOUT <think> ... </think>}**`;te.text=te.text.replace(rt,"").replace(Ie,"").trim()}})}finally{await bt.commitTransaction()}yield{type:"status",content:null}}});import Lt,{useState as Ai,useEffect as Gc}from"react";import{Box as Go,Text as On,useInput as Xc}from"ink";function Oi({onSelect:e,onDelete:o,onClose:t}){let[n,i]=Ai({}),[r,l]=Ai([]),[c,f]=Ai(0);Gc(()=>{(async()=>{let h=await vo();i(h),l(Object.keys(h).sort((S,T)=>(h[T].updatedAt||0)-(h[S].updatedAt||0)))})()},[]),Xc((p,h)=>{if(h.escape&&t(),h.upArrow&&f(S=>Math.max(0,S-1)),h.downArrow&&f(S=>Math.min(r.length-1,S+1)),h.return&&r[c]&&e(r[c]),p==="x"&&r[c]){let S=r[c];o(S).then(T=>{let w=T||{};i(w);let I=Object.keys(w).sort(($,U)=>(w[U]?.updatedAt||0)-(w[$]?.updatedAt||0));l(I),f($=>Math.max(0,Math.min(I.length-1,$)))})}});let u=Ce(2),d=15,a=0;if(r.length>d){let p=Math.floor(d/2);a=c-p,a<0?a=0:a+d>r.length&&(a=r.length-d)}let m=r.slice(a,a+d);return Lt.createElement(Go,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},Lt.createElement(Go,{paddingX:1,marginBottom:1},Lt.createElement(On,{color:"cyan",bold:!0},"\u{1F4A0} CHAT HISTORY: RESUME CONVERSATION")),r.length===0?Lt.createElement(Go,{paddingX:2,paddingY:1},Lt.createElement(On,{italic:!0,color:"gray"},"No saved chats found.")):Lt.createElement(Go,{flexDirection:"column",width:"100%"},a>0&&Lt.createElement(Go,{paddingX:2,marginBottom:1},Lt.createElement(On,{color:"gray",dimColor:!0},"\u25B2 (+",a," more chats above)")),m.map((p,h)=>{let S=n[p],w=a+h===c,I=Kc(S?.updatedAt);return Lt.createElement(Go,{key:p,paddingX:1,backgroundColor:w?"#2a2a2a":void 0,width:"100%"},Lt.createElement(Go,{flexGrow:1},Lt.createElement(On,{color:w?"cyan":"white",bold:w},w?"\u276F ":" ",S?.name||p,Lt.createElement(On,{color:"gray",dimColor:!w}," [",I," \u2022 ",p.slice(5),"]"))),w&&Lt.createElement(Go,{flexShrink:0},Lt.createElement(On,{color:"red",bold:!0},"[X] DELETE ")))}),a+d<r.length&&Lt.createElement(Go,{paddingX:2,marginTop:1},Lt.createElement(On,{color:"gray",dimColor:!0},"\u25BC (+",r.length-(a+d)," more chats below)"))),Lt.createElement(Go,{marginTop:1,paddingX:1,borderStyle:"single",borderLeft:!1,borderRight:!1,borderBottom:!1,borderColor:"gray"},Lt.createElement(On,{dimColor:!0,italic:!0},"\u2191\u2193 navigate \u2022 Enter select \u2022 x delete \u2022 Esc close")))}function Kc(e){if(!e)return"N/A";let o=new Date(e);if(isNaN(o.getTime()))return"N/A";let t=c=>String(c).padStart(2,"0"),n=t(o.getMonth()+1),i=t(o.getDate()),r=t(o.getHours()),l=t(o.getMinutes());return`${n}-${i} ${r}:${l}`}var ml=ae(()=>{Sr();wn()});import Mt,{useState as Li,useEffect as qc}from"react";import{Box as Xo,Text as cn,useInput as Vc}from"ink";function Di({onClose:e}){let[o,t]=Li([]),[n,i]=Li(0),[r,l]=Li(!0),c=()=>{let w=ye(Bt,[]);t(w);try{let $=zr(eo,{}).systemSettings?.memory!==!1;l($)}catch{l(!0)}};qc(()=>{c()},[]),Vc((w,I)=>{if(I.escape&&e(),I.upArrow&&i($=>Math.max(0,$-1)),I.downArrow&&i($=>Math.min(o.length-1,$+1)),w==="x"&&o.length>0){let $=o[n].id,U=o.filter(K=>K.id!==$);ke(Bt,U),t(U),n>=U.length&&U.length>0&&i(U.length-1)}});let f=w=>w?w.replace(/\[Saved on: .*?\]/g,"").replace(/\\+'/g,"'").trim():"",u=4*1024*2,d=o.reduce((w,I)=>w+(I.memory?.length||0),0),a=Math.min(100,Math.round(d/u*100)),m=12,p=Math.round(a/100*m),h="\u2588".repeat(p)+"\u2591".repeat(Math.max(0,m-p)),S=()=>a<50?"green":a<90?"yellow":"red",T=Ce(2);return Mt.createElement(Xo,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},Mt.createElement(Xo,{paddingX:1,marginBottom:1,justifyContent:"space-between"},Mt.createElement(cn,{color:"cyan",bold:!0},"\u{1F9E0} AGENT MEMORY: LONG-TERM KNOWLEDGE"),Mt.createElement(Xo,null,Mt.createElement(cn,{color:"gray"},"Vault: "),Mt.createElement(cn,{color:S()},h),Mt.createElement(cn,{color:"white",bold:!0}," ",a,"%"))),!r&&o.length>0?Mt.createElement(Xo,{paddingX:2,paddingY:1},Mt.createElement(cn,{italic:!0,color:"gray"},"Memory is currently Off...")):o.length===0?Mt.createElement(Xo,{paddingX:2,paddingY:1},Mt.createElement(cn,{italic:!0,color:"gray"},r?"Learning...":"Memory not available...")):Mt.createElement(Xo,{flexDirection:"column"},o.map((w,I)=>{let $=I===n;return Mt.createElement(Xo,{key:w.id,paddingX:1,backgroundColor:$?"#2a2a2a":void 0,width:"100%"},Mt.createElement(Xo,{flexGrow:1},Mt.createElement(cn,{color:$?"cyan":"white",bold:$},$?"\u276F ":" ",I+1,". ",f(w.memory))),$&&Mt.createElement(Xo,{flexShrink:0},Mt.createElement(cn,{color:"red",bold:!0},"[X] WIPE ")))})),Mt.createElement(Xo,{marginTop:1,paddingX:1,borderStyle:"single",borderLeft:!1,borderRight:!1,borderBottom:!1,borderColor:"gray"},Mt.createElement(cn,{dimColor:!0,italic:!0},"\u2191\u2193 navigate \u2022 x wipe memory \u2022 Esc close")))}var fl=ae(()=>{Do();oo();wn()});import Ze,{useState as fs,useEffect as pl}from"react";import{Box as Ln,Text as Ht}from"ink";import{spawn as hl}from"child_process";var ps,gl,zc,xl,yl=ae(async()=>{ps=null;try{let e=await import("node-pty");ps=e.default||e,ps=!1}catch{}gl=["\u280B","\u2819","\u2839","\u2838","\u283C","\u2834","\u2826","\u2827","\u2807","\u280F"],zc=({latest:e,current:o,settings:t,onClose:n,onUpdateSettings:i,onSuccess:r})=>{let[l,c]=fs("initializing"),[f,u]=fs(""),[d,a]=fs(null),[m,p]=fs(0);if(pl(()=>{let h=setInterval(()=>{p(S=>(S+1)%1e3)},33);return()=>clearInterval(h)},[]),pl(()=>{let h;return(async()=>{let T=t.updateManager||"npm";if(!t.updateManager){i();return}let w="";T==="pnpm"?w=`pnpm add -g fluxflow-cli@${e}`:T==="bun"?w=`bun add -g fluxflow-cli@${e}`:T==="yarn"?w=`yarn global add fluxflow-cli@${e}`:T==="custom"?w=t.customUpdateCommand:w=`npm install -g fluxflow-cli@${e}`,c("downloading"),u(`Running: ${w}...`);let I=process.platform==="win32",$=K=>new Promise(P=>{let k=I?K?"powershell.exe":"cmd.exe":process.env.SHELL||"bash",O=I?K?["-NoProfile","-Command",w]:["/c",w]:["-c",w],D=G=>{let X=G.toString().replace(/\x1B\[[0-?]*[ -/]*[@-~]|\x1B\][^\x07\x1B]*[\x07\x1B]|\b|\x07/g,"").replace(/\r/g,"").trim();X&&u(z=>(z+`
|
|
531
|
+
`+X).split(`
|
|
527
532
|
`).slice(-5).join(`
|
|
528
|
-
`))};if(
|
|
533
|
+
`))};if(ps)try{let G=ps.spawn(k,O,{name:"xterm-256color",cols:80,rows:30,cwd:process.cwd(),env:process.env});h=G,G.onData(D),G.onExit(({exitCode:Z})=>{h=null,P(Z!==0?{error:`Process exited with code ${Z}`}:{success:!0})});return}catch(G){if(I&&K&&G.code==="ENOENT"){P({retryCmd:!0});return}}let Q=I?hl(k,O,{cwd:process.cwd(),env:process.env}):hl(w,{shell:!0,cwd:process.cwd(),env:process.env});h=Q,Q.stdout.on("data",D),Q.stderr.on("data",D),Q.on("close",G=>{h=null,P(G!==0?{error:`Process exited with code ${G}`}:{success:!0})}),Q.on("error",G=>{I&&K&&G.code==="ENOENT"?P({retryCmd:!0}):(h=null,P({error:G.message}))})}),U={};I?(U=await $(!0),U.retryCmd&&(U=await $(!1))):U=await $(!1),U.error?(a(U.error),c("error")):U.success&&(c("success"),r&&r())})(),()=>{if(h)try{typeof h.destroy=="function"?h.destroy():typeof h.kill=="function"&&h.kill()}catch{}}},[]),l==="initializing"||l==="downloading"){let h=gl[Math.floor(m/3)%gl.length];return Ze.createElement(Ln,{flexDirection:"column",borderStyle:"round",borderColor:"cyan",paddingX:2,paddingY:1},Ze.createElement(Ln,null,Ze.createElement(Ht,{color:"magenta"},h),Ze.createElement(Ht,{marginLeft:1,bold:!0}," Updating Flux Flow to v",e,"...")),Ze.createElement(Ln,{marginTop:1,paddingX:1,borderStyle:"single",borderColor:"#333"},Ze.createElement(Ht,{color:"gray",italic:!0},f||"Preparing environment...")),Ze.createElement(Ht,{marginTop:1,dimColor:!0},"(Please do not close the terminal)"))}return l==="success"?Ze.createElement(Ln,{flexDirection:"column",borderStyle:"round",borderColor:"green",paddingX:2,paddingY:1},Ze.createElement(Ht,{color:"green",bold:!0},"\u2705 UPDATE SUCCESSFUL!"),Ze.createElement(Ht,{marginTop:1},"Flux Flow has been updated to ",Ze.createElement(Ht,{color:"cyan"},"v",e),"."),Ze.createElement(Ht,{marginTop:1,color:"yellow",bold:!0},"Please restart your terminal session to apply changes."),Ze.createElement(Ln,{marginTop:1},Ze.createElement(Ht,{dimColor:!0},"(Press ESC to return to chat)"))):l==="error"?Ze.createElement(Ln,{flexDirection:"column",borderStyle:"round",borderColor:"red",paddingX:2,paddingY:1},Ze.createElement(Ht,{color:"red",bold:!0},"\u274C UPDATE FAILED"),Ze.createElement(Ln,{marginTop:1,paddingX:1,borderStyle:"single",borderColor:"red"},Ze.createElement(Ht,{color:"red"},d)),Ze.createElement(Ht,{marginTop:1},"Possible causes:"),Ze.createElement(Ht,null,"\u2022 Missing permissions (Try running as Administrator/Sudo)"),Ze.createElement(Ht,null,"\u2022 Package manager (",t.updateManager,") not found"),Ze.createElement(Ht,null,"\u2022 Network failure"),Ze.createElement(Ln,{marginTop:1},Ze.createElement(Ht,{dimColor:!0},"(Press ESC to return to chat)"))):null},xl=zc});import At,{useState as Jc}from"react";import{Box as Ko,Text as dn,useInput as Qc}from"ink";function vi({prompts:e,onSelect:o,onClose:t}){let[n,i]=Jc(0);Qc((u,d)=>{d.escape&&t(),d.upArrow&&i(a=>Math.max(0,a-1)),d.downArrow&&i(a=>Math.min(e.length-1,a+1)),d.return&&e[n]&&o(e[n].id)});let r=Ce(2),l=10,c=0;if(e.length>l){let u=Math.floor(l/2);c=n-u,c<0?c=0:c+l>e.length&&(c=e.length-l)}let f=e.slice(c,c+l);return At.createElement(Ko,{flexDirection:"column",borderStyle:"round",borderColor:"cyan",padding:0,width:"100%"},At.createElement(Ko,{paddingX:1,marginBottom:1},At.createElement(dn,{color:"cyan",bold:!0},"\u{1F504} CODEBASE TIME TRAVEL: SELECT UNDO POINT")),At.createElement(Ko,{paddingX:2,marginBottom:1},At.createElement(dn,null,"Select a prompt to revert the codebase back to the state ",At.createElement(dn,{bold:!0,color:"blue"},"immediately before")," it was executed:")),e.length===0?At.createElement(Ko,{paddingX:2,paddingY:1},At.createElement(dn,{italic:!0,color:"gray"},"No prompt checkpoints found for this session.")):At.createElement(Ko,{flexDirection:"column",width:"100%"},c>0&&At.createElement(Ko,{paddingX:2,marginBottom:1},At.createElement(dn,{color:"gray",dimColor:!0},"\u25B2 (+",c," more prompts above)")),f.map((u,d)=>{let m=c+d===n,p=ed(u.timestamp),h=u.changes?u.changes.length:0;return At.createElement(Ko,{key:u.id,paddingX:1,backgroundColor:m?"#1a2a3a":void 0,width:"100%"},At.createElement(Ko,{flexGrow:1},At.createElement(dn,{color:m?"cyan":"white",bold:m},m?"\u276F ":" ",'"',Zc(u.prompt),'"',At.createElement(dn,{color:"gray",dimColor:!m}," [",p," \u2022 ",h," file(s) changed]"))))}),c+l<e.length&&At.createElement(Ko,{paddingX:2,marginTop:1},At.createElement(dn,{color:"gray",dimColor:!0},"\u25BC (+",e.length-(c+l)," more prompts below)"))),At.createElement(Ko,{marginTop:1,paddingX:1,borderStyle:"single",borderLeft:!1,borderRight:!1,borderBottom:!1,borderColor:"cyan"},At.createElement(dn,{dimColor:!0,italic:!0},"\u2191\u2193 navigate \u2022 Enter select undo point \u2022 Esc close")))}function Zc(e){if(!e)return"";let t=(e.split(`
|
|
529
534
|
`)[0]||"").replace(/@\[(.*?)\]/g,(n,i)=>{let r=i.replace(/\\/g,"/").split("/");return`[${r[r.length-1]}]`});return t.length>69?t.slice(0,67)+"...":e.includes(`
|
|
530
|
-
`)?t+"...":t}function
|
|
535
|
+
`)?t+"...":t}function ed(e){if(!e)return"N/A";let o=new Date(e);if(isNaN(o.getTime()))return"N/A";let t=l=>String(l).padStart(2,"0"),n=t(o.getHours()),i=t(o.getMinutes()),r=t(o.getSeconds());return`${n}:${i}:${r}`}var wl=ae(()=>{wn()});import td from"puppeteer";import{exec as od}from"child_process";import{promisify as nd}from"util";import rd from"fs";var Tl,Sl,El,bl=ae(()=>{Tl=nd(od),Sl=()=>{try{let e=td.executablePath();if(e&&rd.existsSync(e))return!0}catch{return!1}return!1},El=async e=>{e&&e("\u{1F4E5} Downloading Chromium engine (chrome@148)...");try{try{await Tl("pnpm exec puppeteer browsers install chrome@148")}catch{await Tl("npx -y puppeteer browsers install chrome@148")}return await new Promise(o=>setTimeout(o,1e3)),{success:!0}}catch(o){return console.error("[SETUP ERROR]",o),{success:!1,error:o.message}}}});var Dl={};bs(Dl,{default:()=>Ll});import Cl from"os";import s,{useState as q,useEffect as co,useRef as qo,useMemo as Ar}from"react";import{Box as C,Text as y,useInput as sd,useStdout as id}from"ink";import no from"fs-extra";import Yn from"path";import{exec as $i}from"child_process";import{fileURLToPath as ad}from"url";import kl from"ink-text-input";import ld from"gradient-string";function Ll({args:e=[]}){let[o,t]=q(!1),[n,i]=q(10),{stdout:r}=id(),[l,c]=q(""),[f,u]=q(0),[d,a]=q(!1),[m,p]=q("Flux"),[h,S]=q({columns:r?.columns||80,rows:r?.rows||24}),[T,w]=q(0),[I,$]=q(!1),[U,K]=q(!1),[P,k]=q(0),O=qo(null);co(()=>{let x=xs(),g=!["Terminal","Windows Terminal"].includes(x)||!!process.env.VSC_TERMINAL_URL,M=setTimeout(()=>{g&&!Yo()&&K(!0)},500),B=setInterval(()=>{Yo()&&K(!1)},1e3);return()=>{clearTimeout(M),clearInterval(B)}},[]);let D=Ar(()=>{let x={};for(let g=0;g<e.length;g++){let M=e[g];if(M==="--model"&&e[g+1])x.model=e[g+1],g++;else if(M==="--memory"&&e[g+1])x.memory=e[g+1].toLowerCase(),g++;else if(M==="--resume"&&e[g+1])x.resume=e[g+1],g++;else if(M==="--update"&&e[g+1])x.update=e[g+1].toLowerCase(),g++;else if(M==="--package"&&e[g+1]){let B=e[g+1].toLowerCase();["npm","pnpm","yarn","bun"].includes(B)&&(x.package=B),g++}else if(M==="--auto-del"&&e[g+1]){let B=e[g+1].toLowerCase();["1d","7d","30d"].includes(B)&&(x.autoDel=B),g++}else if(M==="--auto-exec"&&e[g+1])x.autoExec=e[g+1].toLowerCase(),g++;else if(M==="--yolo"&&e[g+1])x.autoExec=e[g+1].toLowerCase(),g++;else if(M==="--external-access"&&e[g+1])x.externalAccess=e[g+1].toLowerCase(),g++;else if(M==="--mode"&&e[g+1]){let A=e[g+1].toLowerCase();if(["flux","flow"].includes(A)){let v="Flux";A==="flux"?v="Flux":A==="flow"&&(v="Flow"),x.mode=v}g++}else if(M==="--thinking"&&e[g+1]){let A=e[g+1].toLowerCase();if(["fast","low","medium","high","xhigh"].includes(A)){let v="Medium";A==="fast"?v="Fast":A==="low"?v="Low":A==="medium"?v="Medium":A==="high"?v="High":A==="xhigh"&&(v="xHigh"),x.thinking=v}g++}}return x},[e]),Q=async(x=!1,g=null)=>{let M=g||Nt;x&&_(B=>(ee(B.length+1),[...B,{id:"check-"+Date.now(),role:"system",text:"\u{1F50D} Checking for updates...",isMeta:!0}]));try{let A=await(await fetch("https://registry.npmjs.org/fluxflow-cli",{cache:"no-store"})).json(),v=A["dist-tags"]?.latest,j=A["dist-tags"]?.stable;if(v&&nt(v),v&&v!==Dn){let b=v===j?`v${v}-stable`:`v${v}`;!x&&M.autoUpdate?W("update"):_(L=>{let F=[...L],R=x?F.length:Math.min(F.length,3);return F.splice(R,0,{id:"update-"+Date.now(),role:"system",text:`A new version (${b}) is here.
|
|
531
536
|
|
|
532
537
|
\u2022 Type \`/update latest\` to apply the update.
|
|
533
|
-
\u2022 Type \`/changelog\` to view the release notes.`,isUpdateNotification:!0,isMeta:!0}),
|
|
538
|
+
\u2022 Type \`/changelog\` to view the release notes.`,isUpdateNotification:!0,isMeta:!0}),F})}else x&&_(b=>{ee(b.length+1);let L=v&&v===j?`${Dn}-stable`:Dn;return[...b,{id:"uptodate-"+Date.now(),role:"system",text:`\u2705 [SYSTEM] Flux Flow is already up to date (${L}).`,isMeta:!0}]})}catch(B){x&&_(A=>(ee(A.length+1),[...A,{id:"check-err-"+Date.now(),role:"system",text:`\u274C ERROR: Failed to check for updates: ${B.message}`,isMeta:!0}]))}};co(()=>{let x=()=>{r.write("\x1B[2J\x1B[3J\x1B[H"),S({columns:r.columns,rows:r.rows})};return r.on("resize",x),()=>{r.off("resize",x)}},[r]);let[G,Z]=q("Medium"),[X,z]=q("Google"),[Ct,Te]=q(0),[je,nt]=q(null),[fe,ut]=q(!1),[ze,Je]=q("gemma-4-31b-it"),[Fe,Qe]=q("gemma-4-26b-a4b-it"),[me,yo]=q(!0),[wo,un]=q(!0),ro=qo(0),[Le,yt]=q(null),[Vo,zo]=q(""),[Yt,W]=q("chat"),[Re,Or]=q("Free"),[jt,jn]=q({agentLimit:999999,backgroundLimit:999999,searchLimit:100,customModelId:"",customLimit:0}),[mt,Mo]=q(null),[Nt,te]=q({memory:!0,compression:0,autoExec:!1,autoDeleteHistory:"7d",autoUpdate:!1,updateManager:"npm",customUpdateCommand:""}),[Ie,rt]=q({name:null,nickname:null,instructions:null}),[re,ge]=q({keyType:"Default",quality:"Low-High",apiKey:""}),[pe,st]=q({tokens:0}),[$o,wt]=q(0),[ft,Be]=q(0),[ce,_t]=q(0),[it,uo]=q(0),[pt,mn]=q(0),[et,at]=q(0),[Ut,Gt]=q(0),[Jo,ys]=q(0),[cr,Lr]=q(0),[Gn,Pi]=q(0),[dr,ws]=q(0),[vn,Ts]=q(0),[se,Ne]=q(null),[_e,lt]=q(js()),[Tt,tt]=q(null),[Xt,To]=q(""),[Kt,Dt]=q(!1),[so,So]=q(0),$n=qo(!0),Dr=qo(!0),Se=qo(!0);co(()=>{if(!Le)return;if($n.current){$n.current=!1,setTimeout(()=>{Dr.current=!1,setTimeout(()=>{Se.current=!1},1e3)},2e3);return}if(Dr.current||Se.current)return;let x=Ce(2),g="",M="";Re==="Free"?X==="Google"?(g="gemma-4-31b-it",M="Gemma 4 (Free default)"):X==="DeepSeek"?(g="deepseek-v4-flash",M="DeepSeek Flash (Free default)"):(g="google/gemma-4-31b-it:free",M="Gemma 4 (Free default)"):X==="Google"?(g="gemini-3-flash-preview",M="Gemini 3 Flash"):X==="DeepSeek"?(g="deepseek-v4-flash",M="DeepSeek Flash"):(g="deepseek/deepseek-v4-flash",M="DeepSeek Flash"),Je(g),Hn({apiTier:Re,activeModel:g}),_(B=>(ee(B.length+1),[...B,{id:"tier-switch-"+Date.now(),role:"system",text:`\u26A0\uFE0F${x}**[TIER LIMIT]** Auto-switched to ${M}.`,isMeta:!0}]))},[Re,X,Le]);let ot=Ar(()=>{let x=xs(),g=!["Terminal","Windows Terminal"].includes(x)||!!process.env.VSC_TERMINAL_URL||!!process.env.INTELLIJ_TERMINAL_COMMAND_BLOCKS;return{isIDE:g,shortcut:g?"Shift + Enter":"Ctrl + Enter"}},[]),qt=qo(null),Pe=qo("");co(()=>{qt.current=Tt},[Tt]),co(()=>{Pe.current=Xt},[Xt]);let[mo,Xn]=q(!1),[Qo,fn]=q(null),[Zo,vr]=q(null),Fn=x=>{fn(null),W("chat")},$r=x=>{let g=Math.floor(x/3600),M=Math.floor(x%3600/60),B=x%60,A=[];return g>0&&A.push(`${g}h`),(M>0||g>0)&&A.push(`${M}m`),A.push(`${B}s`),A.join(" ")},Fo=x=>x<1e3?`${x}ms`:$r(Math.floor(x/1e3)),[Fr,Kn]=q(null),[ur,qn]=q(!0),[pn,Pr]=q(!1),[Po,hn]=q(!1),[Vn,Br]=q(null),[J,We]=q(0),[St,Y]=q([]),Ge=qo(null),[Vt,$e]=q(null),[Bo,en]=q(null),[Pn,Et]=q(null);co(()=>We(0),[l]);let[vt,_]=q(()=>{let x={id:"logo-"+Date.now(),role:"system",text:lr,isLogo:!0,isMeta:!0},g={id:"welcome",role:"system",text:"\u{1F30A}\u26A1 Welcome to Flux Flow! Type /help for commands.",isMeta:!0},M=process.cwd()===Cl.homedir(),B=(()=>{let v=process.cwd().toLowerCase();if(process.platform==="win32"){let j=process.env.SystemRoot?.toLowerCase()||"c:\\windows",b=process.env.ProgramFiles?.toLowerCase()||"c:\\program files",L=process.env["ProgramFiles(x86)"]?.toLowerCase()||"c:\\program files (x86)";return v.startsWith(j)||v.startsWith(b)||v.startsWith(L)}else return v==="/"||["/bin","/sbin","/etc","/usr","/var","/root"].some(b=>v.startsWith(b))})(),A=[x,g];return B?A.push({id:"system-warning",role:"system",text:"\u{1F6D1} [CRITICAL SECURITY ALERT] SYSTEM DIRECTORY DETECTED",subText:`You are currently in a PROTECTED SYSTEM DIRECTORY (${process.cwd()}). Operating here is EXTREMELY dangerous as the agent could accidentally corrupt your OS or installed applications. PLEASE MOVE TO A PROJECT FOLDER FOR SAFETY.`,isHomeWarning:!0,isMeta:!0}):M&&A.push({id:"home-warning",role:"system",text:"[SECURITY ALERT] HOME DIRECTORY DETECTED",subText:`You are currently in ${Cl.homedir()}. Working here is high-risk as the agent may modify system-sensitive configurations. Please move to a project folder for safety.`,isHomeWarning:!0,isMeta:!0}),A}),Ao=qo(null),[Ss,ee]=q(vt.length),Nr=Ar(()=>{let g=h.columns||80,M=0,B=0;for(let A=vt.length-1;A>=0;A--){let v=vt[A];if(!v)continue;let j=v.text||"",b=j.split(/\r?\n/).length;if(j.split(/\r?\n/).forEach(L=>{b+=Math.floor(L.length/g)}),v.isHelpRecord&&(b=15),v.isUpdateNotification&&(b=8),v.isTerminalRecord&&(b=10),b+=v.role==="think"?3:2,M+b>2e3){B=A+1;break}M+=b}return{items:vt.slice(B,Ss),isTruncated:B>0}},[vt,h.columns,h.rows]),le=Ar(()=>{if(!Tt||!Xt)return!1;let x=Xt.trim();return x.endsWith("?")||x.endsWith(":")||/\[[yYnN/]+\]\s*$/.test(x)||/\([yYnN]\)\s*$/.test(x)},[Tt,Xt]);sd((x,g)=>{if(!(x==="\x1B[I"||x==="\x1B[O"||x==="[I"||x==="[O")){if(U){let M=xs(),B=Al(M);if(g.upArrow)k(A=>A>0?A-1:B.length-1);else if(g.downArrow)k(A=>A<B.length-1?A+1:0);else if(g.return){let A=B[P];if(A.action==="dismiss")K(!1);else if(A.url){let v=process.platform==="win32"?`start ${A.url}`:process.platform==="darwin"?`open ${A.url}`:`xdg-open ${A.url}`;$i(v),K(!1)}}return}if(g.tab&&Tt){Dt(M=>!M);return}if(Kt&&Tt){if(g.return){let M=process.platform==="win32";bo(M?`\r
|
|
534
539
|
`:`
|
|
535
|
-
`),
|
|
536
|
-
`)}else if(g.backspace||g.delete)
|
|
537
|
-
`)}}),
|
|
540
|
+
`),Eo||To(B=>B+`
|
|
541
|
+
`)}else if(g.backspace||g.delete)Eo?bo("\x7F"):(bo("\b \b"),To(M=>M.slice(0,-1)));else if(g.upArrow)bo(g.shift?"\x1B[1;2A":"\x1B[A");else if(g.downArrow)bo(g.shift?"\x1B[1;2B":"\x1B[B");else if(g.rightArrow)bo(g.shift?"\x1B[1;2C":"\x1B[C");else if(g.leftArrow)bo(g.shift?"\x1B[1;2D":"\x1B[D");else if(g.escape)bo("\x1B");else if(g.ctrl&&x){let M=x.toLowerCase().charCodeAt(0);M>=97&&M<=122?bo(String.fromCharCode(M-96)):bo(x)}else x&&(bo(x),Eo||To(M=>M+x));return}if(g.escape){if(be.length>0&&Yt==="chat"){$(!0);return}if(o){t(!1);return}if(pn||Tt)Po?(al(),Ji(),hn(!1),Vn&&clearTimeout(Vn)):(hn(!0),Vn&&clearTimeout(Vn),Br(setTimeout(()=>hn(!1),3e3)));else if(Yt==="revert")W("chat"),We(0);else if(Yt!=="chat"&&Yt!=="settings")W("chat");else{if(!Le&&Ct===1){Te(0),zo("");return}We(M=>{let B=M+1;return B===1?(Ge.current&&clearTimeout(Ge.current),Ge.current=setTimeout(()=>We(0),2e3)):B===2&&(Ge.current&&clearTimeout(Ge.current),We(0),l.length>0?c(""):bt.getChatHistory(_e).then(A=>{A.length>0?(Y(A.reverse()),W("revert")):_(v=>(ee(v.length+1),[...v,{id:"revert-empty-"+Date.now(),role:"system",text:"\u{1F6C8} No revert checkpoints found for this session.",isMeta:!0}]))})),B})}}if(be.length>0&&Yt==="chat"){if(g.upArrow){w(M=>M>0?M-1:be.length-1);return}if(g.downArrow){w(M=>M<be.length-1?M+1:0);return}if(g.return)return}if(g.tab,g.ctrl&&x==="c"&&Yt!=="exit"){if(l.length>0){c("");return}if(g.shift){W("exit"),t(!1);return}o?(W("exit"),t(!1)):t(!0)}g.return&&(g.shift||g.ctrl||g.meta||g.leftAlt||g.rightAlt)&&c(M=>M.replace(/\\\r?$/,"").replace(/\r?$/,"")+`
|
|
542
|
+
`)}}),co(()=>{process.stdout.write("\x1B[?1004h");let x=g=>{let M=g.toString();M.includes("\x1B[I")?(un(!0),ro.current=Date.now()):M.includes("\x1B[O")&&(un(!1),ro.current=Date.now())};return process.stdin.on("data",x),()=>{process.stdout.write("\x1B[?1004l"),process.stdin.off("data",x)}},[]),co(()=>{async function x(){try{let v=JSON.parse(no.readFileSync(Yn.join(process.cwd(),"package.json"),"utf8"));yi(Dn||v.version||"2.0.0")}catch{yi("2.0.0")}process.stdout.isTTY&&(process.stdout.write("\x1B]0;FluxFlow\x07"),process.stdout.write("\x1B]633;P;TerminalTitle=FluxFlow\x07")),Sl()||(_(v=>(ee(v.length+1),[...v,{id:"setup-"+Date.now(),role:"system",text:"\u{1F527} [SYSTEM] Installing Required dependencies... (One-time setup)",isMeta:!0}])),await El(),_(v=>(ee(v.length+1),[...v,{id:"setup-done-"+Date.now(),role:"system",text:"\u2705 [SYSTEM] All dependencies installed successfully.",isMeta:!0}])));let g=await Cr();D.mode?p(D.mode):p(g.mode),D.thinking?Z(D.thinking):Z(g.thinkingLevel),z(g.aiProvider||"Google"),O.current=g.activeModel,D.model?Je(D.model):Je(g.activeModel),ut(g.showFullThinking),Or(g.apiTier||"Free"),jn(g.quotas||{agentLimit:999999,backgroundLimit:999999,searchLimit:100,customModelId:"",customLimit:0});let M={memory:!0,compression:0,autoExec:!1,autoDeleteHistory:"7d",autoUpdate:!1,updateManager:"npm",customUpdateCommand:"",...g.systemSettings||{}};D.memory==="on"?M.memory=!0:D.memory==="off"&&(M.memory=!1),D.package&&(M.updateManager=D.package),D.autoDel&&(M.autoDeleteHistory=D.autoDel),D.autoExec==="on"?M.autoExec=!0:D.autoExec==="off"&&(M.autoExec=!1),D.externalAccess==="on"?M.allowExternalAccess=!0:D.externalAccess==="off"&&(M.allowExternalAccess=!1),te(M),rt(g.profileData),ge(g.imageSettings||{keyType:"Default",quality:"Low-High",apiKey:""});let B=g.aiProvider||"Google",A=await es(B);if(A&&(yt(A),Mr(A,{aiProvider:X,onIDEApproval:Fn})),g.systemSettings?.autoDeleteHistory&&Ta(g.systemSettings.autoDeleteHistory),Sa(Io),D.update==="check"?Q(!0,M):D.update==="latest"?(W("update"),Q(!0,M)):Q(!1,M),await ka(),D.resume){let v=await vo(),j=D.resume;if(v[j]){lt(j);let b=[...v[j].messages];b[0]?.text?.includes("\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2557")||b.unshift({id:"welcome-"+Date.now(),role:"system",text:lr+`
|
|
538
543
|
|
|
539
|
-
\u{1F30A}\u26A1 Resuming Flux Flow Session...`,isMeta:!0}),
|
|
544
|
+
\u{1F30A}\u26A1 Resuming Flux Flow Session...`,isMeta:!0}),_(b),W("chat"),_(F=>{let R=[...F,{id:"sys-"+Date.now(),role:"system",text:`\u{1F4E1} SESSION RESUMED VIA CLI: [${j}]`,isMeta:!0}];return ee(R.length),R})}else _(b=>[...b,{id:"sys-err-"+Date.now(),role:"system",text:`\u274C ERROR: Chat session [${j}] not found. Started new session.`,isMeta:!0}])}yo(!1)}x()},[]),co(()=>{let x;return o&&(i(10),x=setInterval(()=>{i(g=>g<=1?(t(!1),0):g-1)},1e3)),()=>{x&&clearInterval(x)}},[o]),co(()=>{if(!me){let x=D.model&&ze===D.model?O.current:ze;Hn({mode:m,thinkingLevel:G,aiProvider:X,activeModel:x||ze,showFullThinking:fe,systemSettings:Nt,profileData:Ie,imageSettings:re,apiTier:Re})}},[m,G,X,ze,fe,Nt,Ie,re,me,D,Re]);let Me=async x=>{let g=x.trim(),M=30;if(X==="OpenRouter"&&(M=10),X==="DeepSeek"&&(M=20),g.length>=M){await ts(X,g),yt(g),Mr(g,{aiProvider:X,onIDEApproval:Fn});let B="gemma-4-31b-it";X==="OpenRouter"?B="google/gemma-4-31b-it:free":X==="DeepSeek"&&(B="deepseek-v4-flash"),Je(B),_(A=>[...A,{role:"system",text:`\u2705 ${X} API Key saved successfully! Model set to ${B}. Initialization complete.`,isMeta:!0}])}else _(B=>[...B,{role:"system",text:`\u274C INVALID KEY: ${X} API keys must be at least ${M} characters.`,isMeta:!0}]),zo("")},He=qo(Fi);co(()=>{if(Yt==="exit"){(async()=>{let M=Date.now(),B=Math.floor((M-He.current)/1e3);B>=1&&(await xo("duration",B),He.current+=B*1e3),await Ia()})();let g=setTimeout(()=>{process.exit(0)},1700);return()=>clearTimeout(g)}},[Yt]),co(()=>{let x=setInterval(async()=>{if(!me){let g=Date.now(),M=Math.floor((g-He.current)/1e3);M>=1&&(await xo("duration",M),He.current+=M*1e3)}},1500);return()=>clearInterval(x)},[me]);let Xe=[{cmd:"/quit",desc:"Exit and shutdown Flux"},{cmd:"/help",desc:"Show all available commands"},{cmd:"/clear",desc:"Clear terminal screen"},{cmd:"/resume",desc:"Load previous session"},{cmd:"/revert",desc:"Revert codebase back to a checkpoint"},{cmd:"/save",desc:"Force save current chat"},{cmd:"/export",desc:"Export current chat in a .txt file"},{cmd:"/chats",desc:"List all chat sessions"},{cmd:"/image",desc:"Generate images using Pollinations",subs:[{cmd:"setup",desc:"Configure defaults",subs:[{cmd:"key",desc:"Set API key strategy",subs:[{cmd:"default",desc:"Default (Quota: Dynamic 25 max/hr)"},{cmd:"custom",desc:"Custom Key"}]},{cmd:"quality",desc:"Set default quality",subs:[{cmd:"low",desc:re?.keyType==="Custom"?"(0.001/img)":"(1/img)"},{cmd:"low-high",desc:re?.keyType==="Custom"?"(0.002/img)":"(2/img)"},{cmd:"medium",desc:re?.keyType==="Custom"?"(0.008/img)":"(8/img)"},{cmd:"medium-high",desc:re?.keyType==="Custom"?"(0.01/img)":"(10/img)"},{cmd:"high",desc:re?.keyType==="Custom"?"(0.045/img)":"(45/img)"},{cmd:"ultra",desc:re?.keyType==="Custom"?"(0.0488/img)":"(49/img)"},{cmd:"premium",desc:re?.keyType==="Custom"?"(0.1/img)":"(100/img)"}]}]},{cmd:"stats",desc:"Show remaining credits or Pollinations balance status"}]},{cmd:"/mode",desc:"Toggle Flux/Flow modes",subs:[{cmd:"flux",desc:"Enable Dev toolset"},{cmd:"flow",desc:"Enable Chat mode"}]},{cmd:"/thinking",desc:"Set AI reasoning depth",subs:X==="DeepSeek"?[{cmd:"Fast",desc:"Fastest"},{cmd:"Standard",desc:"Standard Reasoning"},{cmd:"xHigh",desc:"Extended Reasoning"}]:X==="OpenRouter"?[{cmd:"Fast",desc:"Fastest"},{cmd:"Low",desc:"Quick Reasoning"},{cmd:"Medium",desc:"Balanced Reasoning"},{cmd:"High",desc:"Deep Reasoning"},{cmd:"xHigh",desc:"Extended Reasoning"}]:ze&&ze.toLowerCase().startsWith("gemini-3")?[{cmd:"Fast",desc:"Fastest"},{cmd:"Low",desc:"Quick Reasoning"},{cmd:"Medium",desc:"Balanced Reasoning"},{cmd:"High",desc:"Deep Reasoning"}]:[{cmd:"Fast",desc:"Fastest"},{cmd:"Low",desc:"Quick Reasoning"},{cmd:"Medium",desc:"Balanced Reasoning"},{cmd:"High",desc:"Deep Reasoning"},{cmd:"xHigh",desc:"Extended Reasoning"}]},{cmd:"/model",desc:"Switch Model for Agent",subs:X==="OpenRouter"?Re==="Free"?[{cmd:"google/gemma-4-31b-it:free",desc:"Multimodal"},{cmd:"moonshotai/kimi-k2.6:free",desc:"Multimodal"},{cmd:"qwen/qwen3-coder:free",desc:""},{cmd:"z-ai/glm-4.5-air:free",desc:""}]:[{cmd:"google/gemini-3.5-flash",desc:"Multimodal"},{cmd:"qwen/qwen3.7-plus",desc:"Multimodal"},{cmd:"minimax/minimax-m3",desc:"Multimodal"},{cmd:"anthropic/claude-sonnet-4.5",desc:"Multimodal"},{cmd:"anthropic/claude-opus-4.6",desc:"Multimodal"},{cmd:"anthropic/claude-opus-4.8",desc:"Multimodal"},{cmd:"deepseek/deepseek-v4-pro",desc:""},{cmd:"deepseek/deepseek-v4-flash",desc:""},{cmd:"xiaomi/mimo-v2.5-pro",desc:""},{cmd:"z-ai/glm-5",desc:""},{cmd:"openai/gpt-5.2-codex",desc:"Multimodal"},{cmd:"openai/gpt-5.2-pro",desc:"Multimodal"},{cmd:"openai/gpt-5.5-pro",desc:"Multimodal"},{cmd:"moonshotai/kimi-k2.6",desc:"Multimodal"}]:X==="DeepSeek"?[{cmd:"deepseek-v4-flash",desc:"Fast & Efficient"},{cmd:"deepseek-v4-pro",desc:"High-Intelligence Reasoning"}]:Re==="Free"?[{cmd:"gemma-4-31b-it",desc:"Standard Default"},{cmd:"gemini-2.5-flash",desc:"Fast & Reliable (Limited Free Quota)"},{cmd:"gemini-3-flash-preview",desc:"Fast & Lightweight (Limited Free Quota)"},{cmd:"gemini-3.5-flash",desc:"Flash Latest (Limited Free Quota) [Instability Issues]"}]:[{cmd:"gemini-2.5-flash",desc:"Fast & Reliable"},{cmd:"gemini-3.1-flash-lite",desc:"Ultra-Fast & Lite"},{cmd:"gemini-3-flash-preview",desc:"Default, Fast & Lightweight"},{cmd:"gemini-3.5-flash",desc:"Flash Latest [Instability Issues]"},{cmd:"gemini-3.1-pro-preview",desc:"Pro Reasoning"}]},{cmd:"/settings",desc:"Configure system prefs"},{cmd:"/key",desc:"Manage API keys"},{cmd:"/profile",desc:"Edit developer persona"},{cmd:"/memory",desc:"Manage agent memory"},{cmd:"/stats",desc:"Show session usage"},{cmd:"/reset",desc:"Wipe all project data"},{cmd:"/about",desc:"Project info & credits"},{cmd:"/changelog",desc:"View latest updates"},{cmd:"/fluxflow",desc:"Project management",subs:[{cmd:"init",desc:"Create FluxFlow.md template"}]},{cmd:"/update",desc:"Check/Install updates",subs:[{cmd:"check",desc:"Check for new version"},{cmd:"latest",desc:"Install latest release"}]}],ht=async(x,g=!1)=>{if(!g&&be.length>0){let A=be[T]||be[0],v=x.split(" ");if(v.length===1)c(A.cmd+" ");else{let j=v.slice(0,-1);c(j.join(" ")+" "+A.cmd+" ")}w(0),u(j=>j+1);return}let M=x.replace(/\r\n/g,`
|
|
540
545
|
`).replace(/\r/g,`
|
|
541
546
|
`).trimEnd();if(M.endsWith("\\")){c(M.slice(0,-1)+`
|
|
542
547
|
`);return}let B=M.replace(/\\\s*\n/g,`
|
|
543
|
-
`).split(/\r?\n/).map(
|
|
544
|
-
`);if(B.trim()){if(
|
|
545
|
-
${
|
|
548
|
+
`).split(/\r?\n/).map(A=>A.replace(/\\$/,"")).join(`
|
|
549
|
+
`);if(B.trim()){if(pn){let A=B.trim();if(A.startsWith("/")){_(v=>(ee(v.length+1),[...v,{id:"hint-err-"+Date.now(),role:"system",text:"\u274C [RESTRICTED] Steering Hints cannot start with /",isMeta:!0}])),c("");return}$e(A),Ao.current=A,_(v=>(ee(v.length+1),[...v,{id:"hint-"+Date.now(),role:"user",text:`[STEERING HINT: QUEUED]
|
|
550
|
+
${A}`,color:"magenta"}])),c("");return}if(!Le){Me(B),zo("");return}if(B.startsWith("/")){let A=B.split(" "),v=A[0]?.toLowerCase();switch(v){case"/quit":{W("exit");break}case"/resume":{if(A[1]){let b=A[1];(async()=>{let F=await vo(),R=F[b]||Object.values(F).find(V=>V.name.toLowerCase()===b.toLowerCase());if(R){r.write("\x1B[2J\x1B[3J\x1B[H"),lt(b);let V=[...R.messages];V[0]?.text?.includes("\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2557")||(V.unshift({id:"welcome-"+Date.now(),role:"system",text:"\u{1F30A}\u26A1 Resuming Flux Flow Session...",isMeta:!0}),V.unshift({id:"logo-"+Date.now(),role:"system",text:lr,isLogo:!0,isMeta:!0})),_(V),_(xe=>[...xe,{id:"sys-"+Date.now(),role:"system",text:`\u{1F4E1} SESSION RESUMED: [${b}]`,isMeta:!0}]),ee(0)}else _(V=>[...V,{id:"err-"+Date.now(),role:"system",text:`\u274C ERROR: Session [${b}] not found.`}])})()}else W("resume");break}case"/clear":{_([{id:"logo-"+Date.now(),role:"system",text:lr,isLogo:!0,isMeta:!0},{id:"welcome-"+Date.now(),role:"system",text:"\u{1F30A}\u26A1 Welcome back to Flux Flow! Context cleared.",isMeta:!0}]),ee(2),lt(js()),st({tokens:0}),a(!1);break}case"/revert":{bt.getChatHistory(_e).then(b=>{if(b.length>0)Y(b.reverse()),W("revert");else{let L=Ce(2);_(F=>(ee(F.length+1),[...F,{id:"revert-empty-"+Date.now(),role:"system",text:"No revert checkpoints found for this session.",isMeta:!0}]))}});break}case"/mode":{if(A[1]){let b=A[1].toLowerCase()==="flow"?"Flow":"Flux";p(b),b==="Flow"?Z("Fast"):b==="Flux"&&Z("High");let L=Ce(2);_(F=>(ee(F.length+1),[...F,{id:Date.now(),role:"system",text:`\u{1F527}${L}[SYSTEM] Mode switched to ${b}`,isMeta:!0}]))}else W("mode");break}case"/image":{if(A[1]?.toLowerCase()==="stats"){let b=Ce(2);if(re.keyType==="Custom")_(L=>(ee(L.length+1),[...L,{id:Date.now(),role:"system",text:`\u{1F517}${b}[SYSTEM] Key strategy is Custom. Redirecting to Pollinations dashboard (https://enter.pollinations.ai/#pollen)...`,isMeta:!0}])),$i("start https://enter.pollinations.ai/#pollen");else try{let L=await ss();_(F=>(ee(F.length+1),[...F,{id:Date.now(),role:"system",isImageStats:!0,text:`\u2022 Hourly Limit: ${Number((L.limit*1e3).toFixed(0))} credits
|
|
546
551
|
\u2022 Spent (Last 1hr): ${Number((L.totalSpent*1e3).toFixed(0))} credits
|
|
547
552
|
\u2022 Remaining: ${Number((L.remaining*1e3).toFixed(0))} credits
|
|
548
553
|
\u2022 Requests (Last 1hr): ${L.activeCallsCount} requests
|
|
549
|
-
`+(L.nextResetMin>0?`\u2022 Refreshes in: ${L.nextResetMin}m`:""),isMeta:!0}]))}catch{
|
|
550
|
-
`);try{
|
|
551
|
-
`);
|
|
552
|
-
${
|
|
553
|
-
\u{1F539} Status: ${
|
|
554
|
-
\u{1F539} Released on: ${
|
|
554
|
+
`+(L.nextResetMin>0?`\u2022 Refreshes in: ${L.nextResetMin}m`:""),isMeta:!0}]))}catch{_(F=>(ee(F.length+1),[...F,{id:Date.now(),role:"system",text:"\u274C [SYSTEM] Failed to load image quota stats.",isMeta:!0}]))}}else if(A[1]?.toLowerCase()==="setup")if(A[2]?.toLowerCase()==="key")if(A[3]){let b=["default","custom"].find(L=>L===A[3].toLowerCase());if(b){let L=b==="default"?"Default":"Custom";ge(R=>({...R,keyType:L}));let F=Ce(2);_(R=>(ee(R.length+1),[...R,{id:Date.now(),role:"system",text:`\u{1F527}${F}[SYSTEM] Image key strategy set to ${L}`,isMeta:!0}])),L==="Custom"&&(Mo({label:"Enter Pollinations API key (starting with sk_):",note:"Get a key from https://enter.pollinations.ai",key:"imageSettings",subKey:"apiKey",value:re.apiKey||"",returnView:"chat"}),W("input"))}else{let L=Ce(2);_(F=>(ee(F.length+1),[...F,{id:Date.now(),role:"system",text:"\u274C [SYSTEM] Invalid key option. Choose: Default or Custom.",isMeta:!0}]))}}else{let b=Ce(2);_(L=>(ee(L.length+1),[...L,{id:Date.now(),role:"system",text:"\u274C [SYSTEM] Usage: /image setup Key <Default|Custom>",isMeta:!0}]))}else if(A[2]?.toLowerCase()==="quality")if(A[3]){let b=["low","low-high","medium","medium-high","high","ultra","premium"].find(L=>L===A[3].toLowerCase());if(b){let F={low:"Low","low-high":"Low-High",medium:"Medium","medium-high":"Medium-High",high:"High",ultra:"Ultra",premium:"Premium"}[b];ge(V=>({...V,quality:F}));let R=Ce(2);_(V=>(ee(V.length+1),[...V,{id:Date.now(),role:"system",text:`\u{1F527}${R}[SYSTEM] Image quality set to ${F}`,isMeta:!0}]))}else{let L=Ce(2);_(F=>(ee(F.length+1),[...F,{id:Date.now(),role:"system",text:"\u274C [SYSTEM] Invalid quality level. Choose from: Low, Low-High, Medium, Medium-High, High, Ultra, Premium.",isMeta:!0}]))}}else{let b=Ce(2);_(L=>(ee(L.length+1),[...L,{id:Date.now(),role:"system",text:"\u274C [SYSTEM] Usage: /image setup Quality <Low|Low-High|Medium|Medium-High|High|Ultra>",isMeta:!0}]))}else{let b=Ce(2);_(L=>(ee(L.length+1),[...L,{id:Date.now(),role:"system",text:"\u274C [SYSTEM] Usage: /image setup <Key|Quality> ...",isMeta:!0}]))}else{let b=Ce(2);_(L=>(ee(L.length+1),[...L,{id:Date.now(),role:"system",text:"\u274C [SYSTEM] Usage: /image setup <Key|Quality> ...",isMeta:!0}]))}break}case"/thinking":{let b;if(A[1]){let L=A[1].toLowerCase(),F=A.includes("--bypass");if(b=L.charAt(0).toUpperCase()+L.slice(1),L==="xhigh"&&(b="xHigh"),!F&&m==="Flow"&&(b==="Medium"||b==="High"||b==="xHigh"))_(R=>(ee(R.length+1),[...R,{id:Date.now(),role:"system",text:`\u274C [RESTRICTED] "${b}" is restricted in Flow mode. Switch to Flux to enable Higher Thinking Levels.`,isMeta:!0}]));else{Z(b);let R=Ce(1);_(V=>(ee(V.length+1),[...V,{id:Date.now(),role:"system",text:`\u{1F527} [SYSTEM] Thinking level set to ${b}${F?` (Bypass Activated \u{1F575}\uFE0F${R})`:""}`,isMeta:!0}]))}}else W("thinking");break}case"/model":{if(A[1]){let b=A.slice(1).join(" ");if(b==="gemma-4-31b-it"&&Re!=="Free"&&X==="Google")_(L=>(ee(L.length+1),[...L,{id:Date.now(),role:"system",text:"\u274C **[ACCESS DENIED]** Gemma is restricted to the Free API tier. Automatically switching you to **Gemini 3 Flash Preview** for optimal performance.",isMeta:!0}])),Je("gemini-3-flash-preview");else{Je(b);let L=Ce(2);_(F=>(ee(F.length+1),[...F,{id:Date.now(),role:"system",text:`\u{1F527}${L}[SYSTEM] Model switched to ${b}`,isMeta:!0}]))}}else W("model");break}case"/settings":{W("settings");break}case"/key":{W("key");break}case"/profile":{W("profile");break}case"/stats":{(async()=>{let L=await In();Ne(L),W("stats")})();break}case"/save":{let b=A.slice(1).join(" ")||`Session ${new Date().toLocaleTimeString()}`;ns(_e,b,vt),_(L=>(ee(L.length+1),[...L,{id:Date.now(),role:"system",text:`\u{1F4BE} [MEMORY] Chat saved as "${b}" (ID: ${_e})`,isMeta:!0}]));break}case"/export":{let b=`export-fluxflow-${_e}.txt`,L=Yn.join(process.cwd(),b),F=[],R=!1;for(let De=0;De<vt.length;De++){let xe=vt[De];if(xe&&!(xe.role==="system"||xe.isMeta||xe.isLogo||String(xe.id).startsWith("welcome"))){if(xe.role==="user"){let Ae=xe.text||"";Ae=Ae.replace(/\s*\[Prompted on:.*?\]/g,"").trim(),F.length>0&&F.push(""),F.push("[USER]"),F.push(Ae),R=!1}else if(xe.role==="think"){R||(F.push(""),F.push("[AGENT]"),R=!0);let Ae=(xe.text||"").replace(/\[turn:\s*continue\]/gi,"").replace(/\[turn:\s*finish\]/gi,"").replace(/\[TOOL RESULTS\]/gi,"").trim();Ae&&(F.push("[thoughts]"),F.push(Ae))}else if(xe.role==="agent"){R||(F.push(""),F.push("[AGENT]"),R=!0);let Ae=pd(xe.text||"");for(let ve of Ae)if(ve.type==="output"){let Ye=ve.content.replace(/\[turn:\s*continue\]/gi,"").replace(/\[turn:\s*finish\]/gi,"").replace(/\[TOOL RESULTS\]/gi,"").trim();Ye&&(F.push("[output]"),F.push(Ye))}else ve.type==="tool"&&(F.push("[tool]"),F.push(`${ve.toolName} ${ve.args}`))}}}let V=F.join(`
|
|
555
|
+
`);try{no.writeFileSync(L,V,"utf8"),_(De=>(ee(De.length+1),[...De,{id:Date.now(),role:"system",text:`\u{1F4E4} [EXPORT] Chat exported successfully to "${b}"`,isMeta:!0}]))}catch(De){_(xe=>(ee(xe.length+1),[...xe,{id:Date.now(),role:"system",text:`\u274C [EXPORT ERROR] Failed to export chat: ${De.message}`,isMeta:!0}]))}break}case"/chats":{(async()=>{let L=await vo(),F=Object.entries(L).map(([R,V])=>`\u2022 ${R}: ${V.name}`).join(`
|
|
556
|
+
`);_(R=>(ee(R.length+1),[...R,{id:Date.now(),role:"system",text:`\u{1F5C3}\uFE0F [HISTORY] Saved Chats:
|
|
557
|
+
${F||"No saved chats found."}`,isMeta:!0}]))})();break}case"/memory":{W("memory");break}case"/reset":{(async()=>{try{_(L=>(ee(L.length+1),[...L,{id:Date.now(),role:"system",text:"\u2622\uFE0F [NUCLEAR] Initiating reset...",isMeta:!0}])),no.existsSync(Io)&&no.removeSync(Io),no.existsSync(to)&&no.removeSync(to),no.existsSync(eo)&&no.removeSync(eo);try{no.readdirSync(_n).length===0&&no.removeSync(_n)}catch{}setTimeout(()=>{W("exit"),setTimeout(()=>process.exit(0),500)},500)}catch(L){_(F=>(ee(F.length+1),[...F,{id:Date.now(),role:"system",text:`\u274C [RESET ERROR] Failed to purge data: ${L.message}`}]))}})();break}case"/about":{let b=Ce(2),L=`\u{1F539} FluxFlow Version: v${Dn}
|
|
558
|
+
\u{1F539} Status: ${je&&je!==Dn?`Update Available [v${je}]`:"Up to date"}
|
|
559
|
+
\u{1F539} Released on: ${ud}`;_(F=>(ee(F.length+1),[...F,{id:"about-"+Date.now(),role:"system",text:L,isAboutRecord:!0,isMeta:!0}]));break}case"/changelog":{let b=process.platform;$i(`${b==="win32"?"start":b==="darwin"?"open":"xdg-open"} ${Il}`),_(F=>(ee(F.length+1),[...F,{id:Date.now(),role:"system",text:`\u{1F310} [BROWSER] Opening changelog: ${Il}`,isMeta:!0}]));break}case"/fluxflow":{if(A.slice(1)[0]==="init"){let L=`# FluxFlow Configuration
|
|
555
560
|
# This file defines project-specific instructions for the Flux Flow Agent.
|
|
556
561
|
|
|
557
562
|
# IDENTITY & TONE
|
|
@@ -566,32 +571,32 @@ ${P||"No saved chats found."}`,isMeta:!0}]))})();break}case"/memory":{Y("memory"
|
|
|
566
571
|
|
|
567
572
|
# SKILLS & WORKFLOWS
|
|
568
573
|
- [Define custom step-by-step recipes for this project here]
|
|
569
|
-
`,
|
|
574
|
+
`,F=Yn.join(process.cwd(),"FluxFlow.md");if(no.pathExistsSync(F))_(R=>(ee(R.length+1),[...R,{id:"init-err-"+Date.now(),role:"system",text:"\u274C ERROR: FluxFlow.md already exists in this directory.",isMeta:!0}]));else try{no.writeFileSync(F,L),_(R=>(ee(R.length+1),[...R,{id:"init-ok-"+Date.now(),role:"system",text:"\u2705 [SUCCESS] FluxFlow.md has been initialized. You can now customize it for this project.",isMeta:!0}]))}catch(R){_(V=>(ee(V.length+1),[...V,{id:"init-err-"+Date.now(),role:"system",text:`\u274C ERROR: Failed to initialize FluxFlow.md: ${R.message}`,isMeta:!0}]))}}else _(L=>(ee(L.length+1),[...L,{id:"ff-err-"+Date.now(),role:"system",text:"\u2753 Usage: /fluxflow init",isMeta:!0}]));break}case"/update":{if(A[1]?.toLowerCase()==="check"){Q(!0);break}let L=A.includes("--latest");W("update");break}case"/help":{_(b=>(ee(b.length+1),[...b,{id:Date.now(),role:"system",isHelpRecord:!0,isMeta:!0}]));break}default:let j=Ce(2);_(b=>(ee(b.length+1),[...b,{id:Date.now(),role:"system",text:`\u{1F527}${j}[SYSTEM] Unknown command: ${v}`,isMeta:!0}]))}}else{let A=`[Prompted on: ${new Date().toLocaleString(void 0,{year:"numeric",month:"numeric",day:"numeric",hour:"2-digit",minute:"2-digit"})}]`,v={id:"user-"+Date.now(),role:"user",text:`${B}
|
|
570
575
|
|
|
571
|
-
${
|
|
576
|
+
${A}`};_(b=>(ee(b.length+1),[...b,v])),(async()=>{let b=!1;Pr(!0),a(!1);let L=Date.now(),F=!0;try{let R=[...vt,v].filter(N=>N.role!=="think"&&!N.isVisualFeedback&&!N.isMeta&&!String(N.id).startsWith("welcome")),V=[];R.forEach((N,ie)=>{let ue=N.fullText||N.text;if(N.role==="user"&&ie<R.length-1){let Oe=ue.lastIndexOf("[USER]");Oe!==-1&&(ue=ue.substring(Oe+6).trim())}if(N.role==="system"&&ue?.startsWith("[TOOL RESULT]")){let Oe=V[V.length-1];if(Oe&&Oe.role==="system"&&Oe.text?.startsWith("[TOOL RESULT]")){Oe.text+=`
|
|
572
577
|
|
|
573
|
-
`+
|
|
578
|
+
`+ue;return}}V.push({...N,text:ue})});let De=dl(ze,V,{profile:Ie,thinkingLevel:G,mode:m,systemSettings:Nt,janitorModel:Fe,sessionStats:pe,chatId:_e,aiProvider:X,apiKey:Le,apiTier:Re,cols:h.columns-6,rows:30,onExecStart:N=>{tt(N),To("")},onExecChunk:N=>{To(ie=>ie+N)},onExecEnd:()=>{_(N=>{if(!qt.current)return N;let ie=Pe.current||"",ue="";if(Eo){let kt=/\x1b\[H|\x1b\[2J|\x1b\[3J|\x1bc/g,de=[...ie.matchAll(kt)],he=ie;if(de.length>0){let qe=de[de.length-1];he=ie.substring(qe.index+qe[0].length)}ue=he.replace(/\r+\n/g,`
|
|
574
579
|
`).split(`
|
|
575
|
-
`).map(
|
|
576
|
-
`)}else
|
|
577
|
-
`);let
|
|
580
|
+
`).map(qe=>{let gt=qe.split("\r");return gt[gt.length-1]}).join(`
|
|
581
|
+
`)}else ue=ie.replace(/\r\n/g,`
|
|
582
|
+
`);let Oe=`[TERMINAL_RECORD]
|
|
578
583
|
COMMAND: ${qt.current}
|
|
579
|
-
PTY: ${
|
|
580
|
-
OUTPUT: ${
|
|
584
|
+
PTY: ${Eo}
|
|
585
|
+
OUTPUT: ${ue.replace(/\n{3,}/g,`
|
|
581
586
|
|
|
582
|
-
`)}`;return[...
|
|
583
|
-
Selection: ${
|
|
584
|
-
`),
|
|
585
|
-
`),gt=!1;for(let zt of Ke){if(zt.includes("Old File contents:")){gt=!0;continue}gt&&(zt.trim()===""?gt=!1:/^\d+ \|/.test(zt)&&Xe++)}}ms+=ye,fs+=Xe,po("linesAdded",ye),po("linesRemoved",Xe)}continue}let ae=R.content,ge=ae.toLowerCase();if(ae.includes("```")&&($e=!$e),ge.includes("tool:functions.")&&(Vt=!0,Fo=0,Ot=null,ae.includes("[tool:functions.")&&(Fo=0)),Vt){for(let me=0;me<ae.length;me++){let ye=ae[me];!Ot&&(ye==="'"||ye==='"'||ye==="`")?Ot=ye:Ot&&ye===Ot&&ae[me-1]!=="\\"&&(Ot=null),Ot||(ye==="("||ye==="["?Fo++:(ye===")"||ye==="]")&&Fo--)}Fo<=0&&!Ot&&(Vt=!1)}if((ge.includes("<think")||ge.includes("<thought"))&&(!ue&&!$e&&!Vt&&!Zo)&&(ue=!0,Zo=!0,ae=ae.replace(/<(think|thought)>[\s\S]*?<\/(think|thought)>/gi,"").replace(/<(think|thought)>/gi,""),Fe="think-"+Date.now(),N(me=>[...me,{id:Fe,role:"think",text:"",isStreaming:!0,startTime:Date.now()}])),(ge.includes("</think>")||ge.includes("</thought>"))&&Fe){let me=ae.split(/<\/(think|thought)>/gi),ye=me[0]||"",Xe=me.slice(2).join("").replace(/<\/?(think|thought)>/gi,"");N(Ke=>{let gt=Ke.map(zt=>{if(zt.id===Fe&&typeof zt.id=="string"){let Br=zt.startTime||parseInt(zt.id.split("-")[1])||Date.now(),Ts=Date.now()-Br;return{...zt,text:zt.text+ye,isStreaming:!1,duration:Ts}}return zt});return ue=!1,Be="agent-"+Date.now(),[...gt,{id:Be,role:"agent",text:Xe,isStreaming:!0}]});continue}if(ue&&Fe)N(me=>{let ye=!1,Xe="",Ke=me.map(gt=>{if(gt.id===Fe){let zt=gt.text+ae;if(zt.toLowerCase().includes("</think>")){ye=!0;let Br=zt.split(/<\/think>/gi);Xe=Br.slice(1).join("</think>")||"";let Ts=gt.startTime||parseInt(gt.id.split("-")[1])||Date.now(),Ll=Date.now()-Ts;return{...gt,text:Br[0],isStreaming:!1,duration:Ll}}return{...gt,text:zt,isStreaming:!0}}return gt});return ye?(ue=!1,Be="agent-"+Date.now(),[...Ke,{id:Be,role:"agent",text:Xe.replace(/<\/?(think|thought)>/gi,""),isStreaming:!0}]):Ke});else if(!ue){let me=ae.toLowerCase();!Ao&&me.includes("tool:functions.")&&(Ao=!0),Be?N(ye=>ye.map(Xe=>Xe.id===Be?{...Xe,text:Xe.text+ae,isStreaming:!0}:Xe)):(Be="agent-"+Date.now(),N(ye=>[...ye,{id:Be,role:"agent",text:ae,isStreaming:!0}]))}}let en=Date.now();Dr(R=>R+(en-L))}catch(j){N(te=>(ee(te.length+1),[...te,{id:"error-"+Date.now(),role:"system",text:`\u274C ERROR: ${j.message}`}]))}finally{if(cr(!1),lr(null),S||process.stdout.isTTY&&(process.stdout.write("\x1B]0;FluxFlow | Idle\x07"),process.stdout.write("\x1B]633;P;TerminalTitle=FluxFlow | Idle\x07")),To.current){wo(To.current),Mt(null);let j=To.current;To.current=null,N(te=>{let be=[...te],ue=be.reverse().find(Fe=>Fe.text?.includes("[STEERING HINT: QUEUED]"));return ue&&(ue.text=ue.text.replace("[STEERING HINT: QUEUED]","[STEERING HINT: FINISHED_TURN]")),be.reverse()}),Y("resolution")}N(j=>{let te=Date.now()-L,be=!1,ue=[...j].reverse().map(Be=>{let $e=Be.isStreaming?{...Be,isStreaming:!1}:Be;return!be&&$e.role==="agent"&&(be=!0,$e={...$e,workedDuration:te}),$e}).reverse(),Fe=ue.filter(Be=>!String(Be.id).startsWith("welcome")&&!Be.isMeta);return es(Ye,null,Fe),ee(ue.length),ue})}})()}c(""),a(!1)}},Ee=Ar(()=>{if(l.startsWith("/")&&!k){let M=l.split(" "),B=M[M.length-1].toLowerCase();if(M.length===1){let $=B.startsWith("/")?B.slice(1):B;return Qe.filter(X=>(X.cmd.startsWith("/")?X.cmd.slice(1):X.cmd).toLowerCase().includes($))}let O=Qe;for(let $=0;$<M.length-1;$++){let X=M[$].toLowerCase(),S=O.find(L=>L.cmd.toLowerCase()===X);if(S&&S.subs)O=S.subs;else return[]}return O.filter($=>$.cmd.toLowerCase().includes(B))}let x=l.split(" "),g=x[x.length-1];if(g&&g.startsWith("@")&&!k){let M=g.indexOf("#"),B=M!==-1,O=B?g.substring(1,M).toLowerCase():g.slice(1).toLowerCase(),$=B?g.substring(M):"";return ud(process.cwd()).filter(L=>L.name.toLowerCase().includes(O)).map(L=>{let P=L.relativePath.replace(/\\/g,"/");return{cmd:"@["+(P.startsWith(".")?P:"./"+P)+$+"]",desc:L.relativePath}})}return[]},[l,k]);lo(()=>{E(0)},[Ee]);let bt=()=>{switch(Ht){case"settings":return s.createElement(vs,{systemSettings:_t,setSystemSettings:Q,apiTier:je,setActiveView:Y,setInputConfig:Io,saveSettings:Wn,quotas:jt,setMessages:N,aiProvider:U});case"selectProvider":return s.createElement(io,{title:"SELECT AI PROVIDER",items:[{label:"Google (Free/Paid)",value:"Google"},{label:"DeepSeek (Paid)",value:"DeepSeek"},{label:"OpenRouter (Free/Paid) [EXPERIMENTAL]",value:"OpenRouter"},{label:"Back",value:"settings"}],onSelect:async x=>{if(x.value==="settings"||x.value==="Back"){Y("settings");return}let g=x.value,M=await Jr(g);if(M){G(g),yt(M),Or(M);let B="gemma-4-31b-it";g==="OpenRouter"?B="google/gemma-4-31b-it:free":g==="DeepSeek"&&(B="deepseek-v4-flash"),ze(B),Wn({aiProvider:g,activeModel:B,apiTier:je,quotas:jt}),N(O=>[...O,{role:"system",text:`\u2705 Switched to ${g}! Key loaded from Vault. Model set to ${B}.`,isMeta:!0}]),Y("settings")}else Io({label:`Enter ${g} API Key:`,key:"providerKey",provider:g,value:"",returnView:"settings"}),Y("input")},onClose:()=>Y("settings")});case"apiTier":return s.createElement(io,{title:s.createElement(y,null,"SELECT YOUR CURRENT API TIER BASED ON ",s.createElement(y,{color:"cyan",underline:!0,bold:!0},"\x1B]8;;https://aistudio.google.com/projects\x07AI STUDIO\x1B]8;;\x07"),". (CURRENT: ",je.toUpperCase(),")"),items:[{label:"Free Tier (Gemini API Free Tier)",value:"Free"},{label:"Paid Tier (API with Billing Account)",value:"Paid"},{label:"Back",value:"settings"}],onSelect:x=>{if(x.value==="settings"||x.value==="Back"){Y("settings");return}let g=x.value;Lr(g),g==="Paid"?(Io({label:"Enter Agent daily budget (requests made):",key:"quotas",subKey:"agentLimit",value:String(jt.agentLimit)}),Y("input")):(Wn({apiTier:g,quotas:jt}),Y("settings"))},onClose:()=>Y("settings")});case"input":return s.createElement(C,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},s.createElement(C,{paddingX:1},s.createElement(y,{color:"magenta",bold:!0},"\u{1F527} DATA CONFIGURATION")),mt?.note&&s.createElement(C,{paddingX:1,marginBottom:1},s.createElement(y,{color:"yellow",dimColor:!0,italic:!0},mt.note)),s.createElement(C,{paddingX:1,flexDirection:"row"},s.createElement(y,{color:"cyan",bold:!0},mt?.label," "),s.createElement(Sl,{value:mt?.value||"",onChange:x=>Io(g=>({...g,value:x})),onSubmit:async x=>{let{key:g,subKey:M,next:B}=mt,O={...jt},$={};if(g==="quotas"){let X=M.toLowerCase().includes("limit")?parseInt(x)||0:x;O[M]=X,Hn(O),$.quotas=O}else if(g==="activeModel")ze(x),$.activeModel=x;else if(g==="janitorModel")Je(x),$.janitorModel=x;else if(g==="autoApproveCommands"||g==="autoDisallowCommands"||g==="alwaysAskCommands"){let X={..._t,[g]:x.trim(),sandboxPreset:"Custom"};Q(X),$.systemSettings=X}else if(g==="externalDataPath"){let X={..._t,useExternalData:!0,externalDataPath:x.trim()};Q(X),$.systemSettings=X,N(S=>[...S,{id:Date.now(),role:"system",text:"\u{1F4C1} [EXTERNAL STORAGE] Flux Flow will use "+x.trim()+" for data after restart."}])}else if(g==="imageSettings"){let X=x.trim();if(X.startsWith("sk_")){let S={...ne,apiKey:X};xe(S),$.imageSettings=S,N(L=>(ee(L.length+1),[...L,{id:Date.now(),role:"system",text:"\u{1F511} [IMAGE KEY] Custom API key saved successfully.",isMeta:!0}]))}else xe(S=>({...S,keyType:"Default"})),$.imageSettings={...ne,keyType:"Default"},N(S=>(ee(S.length+1),[...S,{id:Date.now(),role:"system",text:"\u274C [IMAGE KEY ERROR] API key must start with sk_. Key strategy reset to Default.",isMeta:!0}]))}else if(g==="providerKey"){let X=x.trim(),S=mt.provider;await Qr(S,X),G(S),yt(X),Or(X);let L="gemma-4-31b-it";S==="OpenRouter"?L="google/gemma-4-31b-it:free":S==="DeepSeek"&&(L="deepseek-v4-flash"),ze(L),$.aiProvider=S,$.activeModel=L,N(P=>(ee(P.length+1),[...P,{id:Date.now(),role:"system",text:`\u2705 ${S} API Key saved successfully! Model set to ${L}.`,isMeta:!0}]))}B?Io(B(g==="quotas"?O:x)):(Wn({...$,apiTier:je,quotas:O,imageSettings:$.imageSettings||ne}),Io(null),Y(mt?.returnView||"settings"))}})),s.createElement(C,{paddingX:1,marginTop:1},s.createElement(y,{color:"gray",dimColor:!0,italic:!0},"(Press Enter to confirm selection)")));case"stats":return s.createElement(C,{flexDirection:"column",borderStyle:"round",paddingX:3,paddingY:1,width:Math.min(100,(r?.columns||100)-2)},s.createElement(C,{marginBottom:1},s.createElement(y,{color:"white",bold:!0,underline:!0},"SESSION TELEMETRY")),s.createElement(C,{flexDirection:"column"},s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Session Duration:")),s.createElement(y,{color:"white"},Jo(Date.now()-Ai))),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Agent Interactions:")),s.createElement(y,{color:"white"},Po)),s.createElement(C,{marginLeft:2},s.createElement(C,{width:23},s.createElement(y,{color:"blue",dimColor:!0},"\xBB API Time:")),s.createElement(y,{color:"white"},Jo(rr))),s.createElement(C,{marginLeft:2},s.createElement(C,{width:23},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Tool Time:")),s.createElement(y,{color:"white"},Jo(jn))),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Background Tasks:")),s.createElement(y,{color:"white"},ft)),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Tokens Consumed:")),s.createElement(y,{color:"white"},Jt(de))),de>0&&s.createElement(s.Fragment,null,s.createElement(C,{marginLeft:2},s.createElement(C,{width:23},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Input Tokens:")),s.createElement(y,{color:"white"},Jt(de-pt))),it>0&&s.createElement(C,{marginLeft:4},s.createElement(C,{width:21},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Cached:")),s.createElement(y,{color:"white"},Jt(it))),pt>0&&s.createElement(C,{marginLeft:2},s.createElement(C,{width:23},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Output Tokens:")),s.createElement(y,{color:"white"},Jt(pt)))),sr>0&&s.createElement(s.Fragment,null,s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Images Made:")),s.createElement(y,{color:"white"},sr)),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Image Credits:")),s.createElement(y,{color:"white"},Number(((On||0)*1e3).toFixed(0))," credits"))),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Code Changes (Sess):")),s.createElement(y,{color:"white"},s.createElement(y,{color:"green"},"+",ms)," ",s.createElement(y,{color:"red"},"-",fs))),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Tool Calls (Sess):")),s.createElement(y,{color:"white"},et+Ut+qo," ( "),s.createElement(y,{color:"green"},"\u2713 ",et),s.createElement(y,{color:"white"}," "),s.createElement(y,{color:"yellow"},"\u2298 ",qo),s.createElement(y,{color:"white"}," "),s.createElement(y,{color:"red"},"\u2715 ",Ut),s.createElement(y,{color:"white"}," )"))),s.createElement(C,{flexDirection:"column",marginTop:1},s.createElement(y,{color:"white",bold:!0,underline:!0},"DAILY USAGE TRACKER"),s.createElement(C,{marginTop:1},s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Wall Time Today:")),s.createElement(y,{color:"white"},ir(re?.duration||0))),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Agent Interactions:")),s.createElement(y,{color:"white"},re?.agent||0)),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Background Tasks:")),s.createElement(y,{color:"white"},re?.background||0)),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Tokens Used Today:")),s.createElement(y,{color:"white"},Jt(re?.tokens||0))),(re?.tokens||0)>0&&s.createElement(s.Fragment,null,s.createElement(C,{marginLeft:2},s.createElement(C,{width:23},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Input Tokens:")),s.createElement(y,{color:"white"},Jt((re?.tokens||0)-(re?.candidateTokens||0)))),(re?.cachedTokens||0)>0&&s.createElement(C,{marginLeft:4},s.createElement(C,{width:21},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Cached:")),s.createElement(y,{color:"white"},Jt(re.cachedTokens))),(re?.candidateTokens||0)>0&&s.createElement(C,{marginLeft:2},s.createElement(C,{width:23},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Output Tokens:")),s.createElement(y,{color:"white"},Jt(re.candidateTokens)))),(re?.imageCalls?.length||0)>0&&s.createElement(s.Fragment,null,s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Images Made Today:")),s.createElement(y,{color:"white"},re.imageCalls.length)),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Image Credits Today:")),s.createElement(y,{color:"white"},Number(((re.imageCalls.reduce((x,g)=>x+g.cost,0)||0)*1e3).toFixed(0))," credits"))),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Code Changes Today:")),s.createElement(y,{color:"white"},s.createElement(y,{color:"green"},"+",re?.linesAdded||0)," ",s.createElement(y,{color:"red"},"-",re?.linesRemoved||0))),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Tool Calls Today:")),s.createElement(y,{color:"white"},(re?.toolSuccess||0)+(re?.toolFailure||0)+(re?.toolDenied||0)," ( "),s.createElement(y,{color:"green"},"\u2713 ",re?.toolSuccess||0),s.createElement(y,{color:"white"}," "),s.createElement(y,{color:"yellow"},"\u2298 ",re?.toolDenied||0),s.createElement(y,{color:"white"}," "),s.createElement(y,{color:"red"},"\u2715 ",re?.toolFailure||0),s.createElement(y,{color:"white"}," )"))),s.createElement(y,{dimColor:!0,marginTop:1,italic:!0},"(Press ESC to return to chat)"));case"autoExecDanger":return s.createElement(C,{flexDirection:"column",borderStyle:"round",borderColor:"yellow",paddingX:2,paddingY:1,width:"100%"},s.createElement(y,{color:"yellow",bold:!0,underline:!0},"\u26A0\uFE0F SECURITY WARNING: YOLO MODE"),s.createElement(y,{marginTop:1},"Turning this ON allows the agent to execute terminal commands automatically without requiring your approval for each step."),s.createElement(y,{marginTop:1,color:"yellow"},"RISKS INVOLVED:"),s.createElement(y,null,"\u2022 The agent may execute destructive commands (rm -rf, etc.) by mistake."),s.createElement(y,null,"\u2022 Unintended system changes if the agent hallucinates a path or command."),s.createElement(y,null,"\u2022 Reduced control over the agent's step-by-step decision making."),s.createElement(C,{marginTop:1},s.createElement(io,{title:"Confirm Intent",items:[{label:"I know the risk and turning on intentionally",value:"on"},{label:"Keep Off (Recommended)",value:"off"}],onSelect:x=>{x.value==="on"&&Q(g=>({...g,autoExec:!0})),Y("settings")}})));case"externalDanger":return s.createElement(C,{flexDirection:"column",borderStyle:"round",borderColor:"red",paddingX:2,paddingY:1,width:"100%"},s.createElement(y,{color:"red",bold:!0,underline:!0},"\u26A0\uFE0F SECURITY WARNING: EXTERNAL WORKSPACE ACCESS"),s.createElement(y,{marginTop:1},"Turning this ON allows the agent to execute tools (Read/Write/Exec) outside of the current active workspace directory."),s.createElement(y,{marginTop:1,color:"yellow"},"RISKS INVOLVED:"),s.createElement(y,null,"\u2022 Access to sensitive system files (SSH keys, Browser data, etc.)"),s.createElement(y,null,"\u2022 Potential for accidental or malicious deletion of OS-critical files."),s.createElement(y,null,"\u2022 Unauthorized script execution across your entire file system."),s.createElement(C,{marginTop:1},s.createElement(io,{title:"Confirm Intent",items:[{label:"I know the risk and turning on intentionally",value:"on"},{label:"Keep Off (Recommended)",value:"off"}],onSelect:x=>{x.value==="on"&&Q(g=>({...g,allowExternalAccess:!0})),Y("settings")}})));case"doubleDanger":return s.createElement(C,{flexDirection:"column",borderStyle:"round",borderColor:"red",paddingX:2,paddingY:1,width:"100%"},s.createElement(y,{color:"red",bold:!0,underline:!0},"\u26D4 CRITICAL SECURITY WARNING: COMBINED SYSTEM RISK"),s.createElement(y,{marginTop:1},"You are attempting to enable BOTH [YOLO Mode] and [External Workspace Access] simultaneously."),s.createElement(y,{marginTop:1,color:"red",bold:!0},"THIS IS NOT RECOMMENDED."),s.createElement(y,{marginTop:1,color:"yellow"},"THE CRITICAL RISK:"),s.createElement(y,null,"The agent will have the power to execute any command across your entire system WITHOUT your approval or supervision."),s.createElement(y,{color:"red",italic:!0,marginTop:1},"A single hallucination or error could result in full system wipe or data theft."),s.createElement(C,{marginTop:1},s.createElement(io,{title:"Final Confirmation",items:[{label:"I agree knowing the consequences",value:"on"},{label:"Keep Off",value:"off"}],onSelect:x=>{x.value==="on"&&Q(g=>({...g,autoExec:!0,allowExternalAccess:!0})),Y("settings")}})));case"key":return s.createElement(io,{title:"\u{1F511} API KEY MANAGEMENT",items:[{label:"Edit Current Key (Update)",value:"edit"},{label:"Remove Current Key (Purge)",value:"remove"},{label:"Cancel",value:"Cancel"}],onSelect:x=>{if(x.value==="edit"){yt(null),Y("chat");let g=Ce(2);N(M=>[...M,{id:Date.now(),role:"system",text:`\u{1F511}${g}[ACTION] Flux waiting for new API Key...`}])}else x.value==="remove"?Y("deleteKey"):Y("chat")}});case"deleteKey":return s.createElement(C,{flexDirection:"column",borderStyle:"round",borderColor:"red",paddingX:2,paddingY:1},(()=>{let x=Ce(2);return s.createElement(y,{color:"red",bold:!0},"\u26D4",x,"DANGER: PURGE API KEY")})(),s.createElement(y,{marginTop:1},"This will permanently delete the saved API key from the project vault. You will need to enter it again to use Flux."),s.createElement(C,{marginTop:1},s.createElement(io,{title:"Are you absolutely sure?",items:[{label:"YES, PURGE KEY",value:"yes"},{label:"NO, GO BACK",value:"no"}],onSelect:async x=>{if(x.value==="yes"){await _s(),yt(null),Y("chat");let g=Ce(2);N(M=>[...M,{id:Date.now(),role:"system",text:`\u2728${g}[VAULT PURGED] API Key removed successfully.`}])}else Y("key")}})));case"exit":return null;case"ask":return s.createElement(C,{width:"100%"},s.createElement(Qi,{question:zo?.question,options:zo?.options,onResolve:x=>{zo?.resolve&&zo.resolve(x),$r(null),Y("chat")}}));case"revert":return s.createElement(C,{width:"100%",alignItems:"center",justifyContent:"center"},s.createElement(Mi,{prompts:ct,onSelect:async x=>{try{let g=await Et.rollbackToBefore(x);if(g.success){let{targetPrompt:M}=g,B=Oe.findIndex(S=>S.role==="user"&&S.text&&(S.text.startsWith(M)||S.text.includes(M))),O=[...Oe];B!==-1&&(O=Oe.slice(0,B)),N(O),ee(O.length),c(M),a(M.split(`
|
|
586
|
-
`).length>2);let
|
|
587
|
+
`)}`;return[...N,{id:"term-"+Date.now(),role:"system",text:Oe,isTerminalRecord:!0}]}),tt(null),Dt(!1),To("")},onToolResult:(N,ie)=>{if(N==="success"){if(at(ue=>ue+1),ie==="generate_image"){ws(kt=>kt+1);let Oe={Low:.001,"Low-High":.002,Medium:.008,"Medium-High":.01,High:.045,Ultra:.0488,Premium:.1}[re.quality]||.002;Ts(kt=>kt+Oe)}}else N==="denied"?ys(ue=>ue+1):Gt(ue=>ue+1)},onToolApproval:async(N,ie)=>{let ue=mo||Nt.autoExec;if(N==="exec_command"){let{command:Oe}=ne(ie||"{}");return ue||Oe&&/^(echo|ls|dir|pwd|cd|git status|git log|git diff|type|cat|help)\b/i.test(Oe.trim())?"allow":new Promise(de=>{fn({tool:N,args:ie,resolve:de}),W("terminalApproval")})}return ue?"allow":new Promise(Oe=>{fn({tool:N,args:ie,resolve:Oe}),W("approval")})},onAskUser:async(N,ie)=>new Promise(ue=>{vr({question:N,options:ie,resolve:Oe=>{_(kt=>[...kt,{id:"ask-"+Date.now(),role:"system",text:`\u{1F4AC} **Ask User**
|
|
588
|
+
Selection: ${Oe}`,isAskRecord:!0}]),ue(Oe)}}),W("ask")})},async()=>{if(Ao.current){let N=Ao.current;return $e(null),Ao.current=null,_(ie=>{let ue=[...ie].reverse().findIndex(Oe=>Oe.text?.includes("[STEERING HINT: QUEUED]"));if(ue!==-1){let Oe=ie.length-1-ue,kt=[...ie];return kt[Oe]={...kt[Oe],text:kt[Oe].text.replace("[STEERING HINT: QUEUED]","[STEERING HINT: INJECTED]"),color:"cyan"},kt}return ie}),N}return null},Dn),xe=!1,Ae=null,ve=null,Ye=!1,gn=!1,zt=!1,$t=!1,No=0,po=null,_r=/\[?\s*turn\s*:\s*.*?\s*\]?/gi;for await(let N of De){if(F&&N.type==="text"&&(L=Date.now(),F=!1),N.type==="status"){Kn(N.content),Yo()&&ms(N.content);continue}if(N.type==="status_history"){Kn(N.content),Yo()&&ms(N.content),_(de=>[...de,{id:"condense-"+Date.now(),role:"system",text:`\u2699\uFE0F [SYSTEM] ${N.content}`,isMeta:!0}]);continue}if(N.type==="spinner"){qn(N.content);continue}if(N.type==="model_update"){Et(N.content);continue}if(N.type==="turn_reset"){Ae=null,ve=null,xe=!1,Ye=!1,gn=!1,$t=!1,zt=!1;continue}if(N.type==="interactive_turn_finished"){Pr(!1),Yo()&&ms(null),b=!0,ll({profile:Ie,thinkingLevel:G,mode:m,janitorModel:Fe,chatId:_e,systemSettings:Nt,sessionStats:pe,aiProvider:X,apiKey:Le},N.data.agentText,N.data.fullAgentTextRaw,N.data.history,{onMemoryUpdated:()=>_(de=>{let he=[...de];return he.length>0&&(he[he.length-1].memoryUpdated=!0),he}),onBackgroundIncrement:()=>Be(de=>de+1)});continue}if(N.type==="visual_feedback"){_(de=>[...de,{id:"feedback-"+Date.now(),role:"system",text:N.content,isVisualFeedback:!0}]);continue}if(N.type==="exec_start")continue;if(N.type==="liveTokens"){st({tokens:N.content});continue}if(N.type==="usage"){let de=N.content.totalTokenCount||0,he=N.content.cachedContentTokenCount||0,Ke=N.content.candidatesTokenCount||0;st({tokens:de}),_t(qe=>qe+de),he>0&&uo(qe=>qe+he),Ke>0&&mn(qe=>qe+Ke),wt(qe=>qe+1);continue}if(N.type==="tool_time"){Pi(de=>de+N.content);continue}if(N.type==="tool_result"){if(_(de=>[...de,{id:"tool-"+Date.now(),role:"system",text:N.content,fullText:N.aiContent,binaryPart:N.binaryPart,toolName:N.toolName}]),N.toolName==="update_file"&&N.aiContent){let de=N.aiContent.split(`
|
|
589
|
+
`),he=0,Ke=0,qe=!1;for(let gt of de){if(gt.includes("[DIFF_START]")){qe=!0;continue}if(gt.includes("[DIFF_END]")){qe=!1;continue}qe&&(/^\+\d+/.test(gt)?he++:/^\-\d+/.test(gt)&&Ke++)}hs+=he,gs+=Ke,xo("linesAdded",he),xo("linesRemoved",Ke)}else if(N.toolName==="write_file"&&N.aiContent){let de=N.aiContent.match(/- Stats: \[(\d+) lines/),he=de?parseInt(de[1]):0,Ke=0;if(N.aiContent.includes("Old File contents:")){let qe=N.aiContent.split(`
|
|
590
|
+
`),gt=!1;for(let Jt of qe){if(Jt.includes("Old File contents:")){gt=!0;continue}gt&&(Jt.trim()===""?gt=!1:/^\d+ \|/.test(Jt)&&Ke++)}}hs+=he,gs+=Ke,xo("linesAdded",he),xo("linesRemoved",Ke)}continue}let ie=N.content,ue=ie.toLowerCase();if(ie.includes("```")&&(Ye=!Ye),ue.includes("tool:functions.")&&(gn=!0,No=0,po=null,ie.includes("[tool:functions.")&&(No=0)),gn){for(let de=0;de<ie.length;de++){let he=ie[de];!po&&(he==="'"||he==='"'||he==="`")?po=he:po&&he===po&&ie[de-1]!=="\\"&&(po=null),po||(he==="("||he==="["?No++:(he===")"||he==="]")&&No--)}No<=0&&!po&&(gn=!1)}if((ue.includes("<think")||ue.includes("<thought"))&&(!xe&&!Ye&&!gn&&!zt)&&(xe=!0,zt=!0,ie=ie.replace(/<(think|thought)>[\s\S]*?<\/(think|thought)>/gi,"").replace(/<(think|thought)>/gi,""),Ae="think-"+Date.now(),_(de=>[...de,{id:Ae,role:"think",text:"",isStreaming:!0,startTime:Date.now()}])),(ue.includes("</think>")||ue.includes("</thought>"))&&Ae){let de=ie.split(/<\/(think|thought)>/gi),he=de[0]||"",Ke=de.slice(2).join("").replace(/<\/?(think|thought)>/gi,"");_(qe=>{let gt=qe.map(Jt=>{if(Jt.id===Ae&&typeof Jt.id=="string"){let Ur=Jt.startTime||parseInt(Jt.id.split("-")[1])||Date.now(),Es=Date.now()-Ur;return{...Jt,text:Jt.text+he,isStreaming:!1,duration:Es}}return Jt});return xe=!1,ve="agent-"+Date.now(),[...gt,{id:ve,role:"agent",text:Ke,isStreaming:!0}]});continue}if(xe&&Ae)_(de=>{let he=!1,Ke="",qe=de.map(gt=>{if(gt.id===Ae){let Jt=gt.text+ie;if(Jt.toLowerCase().includes("</think>")){he=!0;let Ur=Jt.split(/<\/think>/gi);Ke=Ur.slice(1).join("</think>")||"";let Es=gt.startTime||parseInt(gt.id.split("-")[1])||Date.now(),Fl=Date.now()-Es;return{...gt,text:Ur[0],isStreaming:!1,duration:Fl}}return{...gt,text:Jt,isStreaming:!0}}return gt});return he?(xe=!1,ve="agent-"+Date.now(),[...qe,{id:ve,role:"agent",text:Ke.replace(/<\/?(think|thought)>/gi,""),isStreaming:!0}]):qe});else if(!xe){let de=ie.toLowerCase();!$t&&de.includes("tool:functions.")&&($t=!0),ve?_(he=>he.map(Ke=>Ke.id===ve?{...Ke,text:Ke.text+ie,isStreaming:!0}:Ke)):(ve="agent-"+Date.now(),_(he=>[...he,{id:ve,role:"agent",text:ie,isStreaming:!0}]))}}let zn=Date.now();Lr(N=>N+(zn-L))}catch(R){_(V=>(ee(V.length+1),[...V,{id:"error-"+Date.now(),role:"system",text:`\u274C ERROR: ${R.message}`}]))}finally{if(Pr(!1),Kn(null),b||process.stdout.isTTY&&(process.stdout.write("\x1B]0;FluxFlow | Idle\x07"),process.stdout.write("\x1B]633;P;TerminalTitle=FluxFlow | Idle\x07")),Ao.current){en(Ao.current),$e(null);let R=Ao.current;Ao.current=null,_(V=>{let De=[...V],xe=De.reverse().find(Ae=>Ae.text?.includes("[STEERING HINT: QUEUED]"));return xe&&(xe.text=xe.text.replace("[STEERING HINT: QUEUED]","[STEERING HINT: FINISHED_TURN]")),De.reverse()}),W("resolution")}_(R=>{let V=Date.now()-L,De=!1,xe=[...R].reverse().map(ve=>{let Ye=ve.isStreaming?{...ve,isStreaming:!1}:ve;return!De&&Ye.role==="agent"&&(De=!0,Ye={...Ye,workedDuration:V}),Ye}).reverse(),Ae=xe.filter(ve=>!String(ve.id).startsWith("welcome")&&!ve.isMeta);return ns(_e,null,Ae),ee(xe.length),xe})}})()}c(""),a(!1)}},be=Ar(()=>{if(l.startsWith("/")&&!I){let M=l.split(" "),B=M[M.length-1].toLowerCase();if(M.length===1){let v=B.startsWith("/")?B.slice(1):B;return Xe.filter(j=>(j.cmd.startsWith("/")?j.cmd.slice(1):j.cmd).toLowerCase().includes(v))}let A=Xe;for(let v=0;v<M.length-1;v++){let j=M[v].toLowerCase(),b=A.find(L=>L.cmd.toLowerCase()===j);if(b&&b.subs)A=b.subs;else return[]}return A.filter(v=>v.cmd.toLowerCase().includes(B))}let x=l.split(" "),g=x[x.length-1];if(g&&g.startsWith("@")&&!I){let M=g.indexOf("#"),B=M!==-1,A=B?g.substring(1,M).toLowerCase():g.slice(1).toLowerCase(),v=B?g.substring(M):"";return hd(process.cwd()).filter(L=>L.name.toLowerCase().includes(A)).map(L=>{let F=L.relativePath.replace(/\\/g,"/");return{cmd:"@["+(F.startsWith(".")?F:"./"+F)+v+"]",desc:L.relativePath}})}return[]},[l,I]);co(()=>{w(0)},[be]);let fo=()=>{switch(Yt){case"settings":return s.createElement(Fs,{systemSettings:Nt,setSystemSettings:te,apiTier:Re,setActiveView:W,setInputConfig:Mo,saveSettings:Hn,quotas:jt,setMessages:_,aiProvider:X});case"selectProvider":return s.createElement(ao,{title:"SELECT AI PROVIDER",items:[{label:"Google (Free/Paid)",value:"Google"},{label:"DeepSeek (Paid)",value:"DeepSeek"},{label:"OpenRouter (Free/Paid) [EXPERIMENTAL]",value:"OpenRouter"},{label:"Back",value:"settings"}],onSelect:async x=>{if(x.value==="settings"||x.value==="Back"){W("settings");return}let g=x.value,M=await es(g);if(M){z(g),yt(M),Mr(M,{aiProvider:g,onIDEApproval:Fn});let B="gemma-4-31b-it";g==="OpenRouter"?B="google/gemma-4-31b-it:free":g==="DeepSeek"&&(B="deepseek-v4-flash"),Je(B),Hn({aiProvider:g,activeModel:B,apiTier:Re,quotas:jt}),_(A=>[...A,{role:"system",text:`\u2705 Switched to ${g}! Key loaded from Vault. Model set to ${B}.`,isMeta:!0}]),W("settings")}else Mo({label:`Enter ${g} API Key:`,key:"providerKey",provider:g,value:"",returnView:"settings"}),W("input")},onClose:()=>W("settings")});case"apiTier":return s.createElement(ao,{title:s.createElement(y,null,"SELECT YOUR CURRENT API TIER BASED ON ",s.createElement(y,{color:"cyan",underline:!0,bold:!0},"\x1B]8;;https://aistudio.google.com/projects\x07AI STUDIO\x1B]8;;\x07"),". (CURRENT: ",Re.toUpperCase(),")"),items:[{label:"Free Tier (Gemini API Free Tier)",value:"Free"},{label:"Paid Tier (API with Billing Account)",value:"Paid"},{label:"Back",value:"settings"}],onSelect:x=>{if(x.value==="settings"||x.value==="Back"){W("settings");return}let g=x.value;Or(g),g==="Paid"?(Mo({label:"Enter Agent daily budget (requests made):",key:"quotas",subKey:"agentLimit",value:String(jt.agentLimit)}),W("input")):(Hn({apiTier:g,quotas:jt}),W("settings"))},onClose:()=>W("settings")});case"input":return s.createElement(C,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},s.createElement(C,{paddingX:1},s.createElement(y,{color:"magenta",bold:!0},"\u{1F527} DATA CONFIGURATION")),mt?.note&&s.createElement(C,{paddingX:1,marginBottom:1},s.createElement(y,{color:"yellow",dimColor:!0,italic:!0},mt.note)),s.createElement(C,{paddingX:1,flexDirection:"row"},s.createElement(y,{color:"cyan",bold:!0},mt?.label," "),s.createElement(kl,{value:mt?.value||"",onChange:x=>Mo(g=>({...g,value:x})),onSubmit:async x=>{let{key:g,subKey:M,next:B}=mt,A={...jt},v={};if(g==="quotas"){let j=M.toLowerCase().includes("limit")?parseInt(x)||0:x;A[M]=j,jn(A),v.quotas=A}else if(g==="activeModel")Je(x),v.activeModel=x;else if(g==="janitorModel")Qe(x),v.janitorModel=x;else if(g==="autoApproveCommands"||g==="autoDisallowCommands"||g==="alwaysAskCommands"){let j={...Nt,[g]:x.trim(),sandboxPreset:"Custom"};te(j),v.systemSettings=j}else if(g==="externalDataPath"){let j={...Nt,useExternalData:!0,externalDataPath:x.trim()};te(j),v.systemSettings=j,_(b=>[...b,{id:Date.now(),role:"system",text:"\u{1F4C1} [EXTERNAL STORAGE] Flux Flow will use "+x.trim()+" for data after restart."}])}else if(g==="imageSettings"){let j=x.trim();if(j.startsWith("sk_")){let b={...re,apiKey:j};ge(b),v.imageSettings=b,_(L=>(ee(L.length+1),[...L,{id:Date.now(),role:"system",text:"\u{1F511} [IMAGE KEY] Custom API key saved successfully.",isMeta:!0}]))}else ge(b=>({...b,keyType:"Default"})),v.imageSettings={...re,keyType:"Default"},_(b=>(ee(b.length+1),[...b,{id:Date.now(),role:"system",text:"\u274C [IMAGE KEY ERROR] API key must start with sk_. Key strategy reset to Default.",isMeta:!0}]))}else if(g==="providerKey"){let j=x.trim(),b=mt.provider;await ts(b,j),z(b),yt(j),Mr(j,{aiProvider:b,onIDEApproval:Fn});let L="gemma-4-31b-it";b==="OpenRouter"?L="google/gemma-4-31b-it:free":b==="DeepSeek"&&(L="deepseek-v4-flash"),Je(L),v.aiProvider=b,v.activeModel=L,_(F=>(ee(F.length+1),[...F,{id:Date.now(),role:"system",text:`\u2705 ${b} API Key saved successfully! Model set to ${L}.`,isMeta:!0}]))}B?Mo(B(g==="quotas"?A:x)):(Hn({...v,apiTier:Re,quotas:A,imageSettings:v.imageSettings||re}),Mo(null),W(mt?.returnView||"settings"))}})),s.createElement(C,{paddingX:1,marginTop:1},s.createElement(y,{color:"gray",dimColor:!0,italic:!0},"(Press Enter to confirm selection)")));case"stats":return s.createElement(C,{flexDirection:"column",borderStyle:"round",paddingX:3,paddingY:1,width:Math.min(100,(r?.columns||100)-2)},s.createElement(C,{marginBottom:1},s.createElement(y,{color:"white",bold:!0,underline:!0},"SESSION TELEMETRY")),s.createElement(C,{flexDirection:"column"},s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Session Duration:")),s.createElement(y,{color:"white"},Fo(Date.now()-Fi))),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Agent Interactions:")),s.createElement(y,{color:"white"},$o)),s.createElement(C,{marginLeft:2},s.createElement(C,{width:23},s.createElement(y,{color:"blue",dimColor:!0},"\xBB API Time:")),s.createElement(y,{color:"white"},Fo(cr))),s.createElement(C,{marginLeft:2},s.createElement(C,{width:23},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Tool Time:")),s.createElement(y,{color:"white"},Fo(Gn))),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Background Tasks:")),s.createElement(y,{color:"white"},ft)),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Tokens Consumed:")),s.createElement(y,{color:"white"},Qt(ce))),ce>0&&s.createElement(s.Fragment,null,s.createElement(C,{marginLeft:2},s.createElement(C,{width:23},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Input Tokens:")),s.createElement(y,{color:"white"},Qt(ce-pt))),it>0&&s.createElement(C,{marginLeft:4},s.createElement(C,{width:21},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Cached:")),s.createElement(y,{color:"white"},Qt(it))),pt>0&&s.createElement(C,{marginLeft:2},s.createElement(C,{width:23},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Output Tokens:")),s.createElement(y,{color:"white"},Qt(pt)))),dr>0&&s.createElement(s.Fragment,null,s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Images Made:")),s.createElement(y,{color:"white"},dr)),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Image Credits:")),s.createElement(y,{color:"white"},Number(((vn||0)*1e3).toFixed(0))," credits"))),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Code Changes (Sess):")),s.createElement(y,{color:"white"},s.createElement(y,{color:"green"},"+",hs)," ",s.createElement(y,{color:"red"},"-",gs))),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Tool Calls (Sess):")),s.createElement(y,{color:"white"},et+Ut+Jo," ( "),s.createElement(y,{color:"green"},"\u2713 ",et),s.createElement(y,{color:"white"}," "),s.createElement(y,{color:"yellow"},"\u2298 ",Jo),s.createElement(y,{color:"white"}," "),s.createElement(y,{color:"red"},"\u2715 ",Ut),s.createElement(y,{color:"white"}," )"))),s.createElement(C,{flexDirection:"column",marginTop:1},s.createElement(y,{color:"white",bold:!0,underline:!0},"DAILY USAGE TRACKER"),s.createElement(C,{marginTop:1},s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Wall Time Today:")),s.createElement(y,{color:"white"},$r(se?.duration||0))),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Agent Interactions:")),s.createElement(y,{color:"white"},se?.agent||0)),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Background Tasks:")),s.createElement(y,{color:"white"},se?.background||0)),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Tokens Used Today:")),s.createElement(y,{color:"white"},Qt(se?.tokens||0))),(se?.tokens||0)>0&&s.createElement(s.Fragment,null,s.createElement(C,{marginLeft:2},s.createElement(C,{width:23},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Input Tokens:")),s.createElement(y,{color:"white"},Qt((se?.tokens||0)-(se?.candidateTokens||0)))),(se?.cachedTokens||0)>0&&s.createElement(C,{marginLeft:4},s.createElement(C,{width:21},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Cached:")),s.createElement(y,{color:"white"},Qt(se.cachedTokens))),(se?.candidateTokens||0)>0&&s.createElement(C,{marginLeft:2},s.createElement(C,{width:23},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Output Tokens:")),s.createElement(y,{color:"white"},Qt(se.candidateTokens)))),(se?.imageCalls?.length||0)>0&&s.createElement(s.Fragment,null,s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Images Made Today:")),s.createElement(y,{color:"white"},se.imageCalls.length)),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Image Credits Today:")),s.createElement(y,{color:"white"},Number(((se.imageCalls.reduce((x,g)=>x+g.cost,0)||0)*1e3).toFixed(0))," credits"))),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Code Changes Today:")),s.createElement(y,{color:"white"},s.createElement(y,{color:"green"},"+",se?.linesAdded||0)," ",s.createElement(y,{color:"red"},"-",se?.linesRemoved||0))),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Tool Calls Today:")),s.createElement(y,{color:"white"},(se?.toolSuccess||0)+(se?.toolFailure||0)+(se?.toolDenied||0)," ( "),s.createElement(y,{color:"green"},"\u2713 ",se?.toolSuccess||0),s.createElement(y,{color:"white"}," "),s.createElement(y,{color:"yellow"},"\u2298 ",se?.toolDenied||0),s.createElement(y,{color:"white"}," "),s.createElement(y,{color:"red"},"\u2715 ",se?.toolFailure||0),s.createElement(y,{color:"white"}," )"))),s.createElement(y,{dimColor:!0,marginTop:1,italic:!0},"(Press ESC to return to chat)"));case"autoExecDanger":return s.createElement(C,{flexDirection:"column",borderStyle:"round",borderColor:"yellow",paddingX:2,paddingY:1,width:"100%"},s.createElement(y,{color:"yellow",bold:!0,underline:!0},"\u26A0\uFE0F SECURITY WARNING: YOLO MODE"),s.createElement(y,{marginTop:1},"Turning this ON allows the agent to execute terminal commands automatically without requiring your approval for each step."),s.createElement(y,{marginTop:1,color:"yellow"},"RISKS INVOLVED:"),s.createElement(y,null,"\u2022 The agent may execute destructive commands (rm -rf, etc.) by mistake."),s.createElement(y,null,"\u2022 Unintended system changes if the agent hallucinates a path or command."),s.createElement(y,null,"\u2022 Reduced control over the agent's step-by-step decision making."),s.createElement(C,{marginTop:1},s.createElement(ao,{title:"Confirm Intent",items:[{label:"I know the risk and turning on intentionally",value:"on"},{label:"Keep Off (Recommended)",value:"off"}],onSelect:x=>{x.value==="on"&&te(g=>({...g,autoExec:!0})),W("settings")}})));case"externalDanger":return s.createElement(C,{flexDirection:"column",borderStyle:"round",borderColor:"red",paddingX:2,paddingY:1,width:"100%"},s.createElement(y,{color:"red",bold:!0,underline:!0},"\u26A0\uFE0F SECURITY WARNING: EXTERNAL WORKSPACE ACCESS"),s.createElement(y,{marginTop:1},"Turning this ON allows the agent to execute tools (Read/Write/Exec) outside of the current active workspace directory."),s.createElement(y,{marginTop:1,color:"yellow"},"RISKS INVOLVED:"),s.createElement(y,null,"\u2022 Access to sensitive system files (SSH keys, Browser data, etc.)"),s.createElement(y,null,"\u2022 Potential for accidental or malicious deletion of OS-critical files."),s.createElement(y,null,"\u2022 Unauthorized script execution across your entire file system."),s.createElement(C,{marginTop:1},s.createElement(ao,{title:"Confirm Intent",items:[{label:"I know the risk and turning on intentionally",value:"on"},{label:"Keep Off (Recommended)",value:"off"}],onSelect:x=>{x.value==="on"&&te(g=>({...g,allowExternalAccess:!0})),W("settings")}})));case"doubleDanger":return s.createElement(C,{flexDirection:"column",borderStyle:"round",borderColor:"red",paddingX:2,paddingY:1,width:"100%"},s.createElement(y,{color:"red",bold:!0,underline:!0},"\u26D4 CRITICAL SECURITY WARNING: COMBINED SYSTEM RISK"),s.createElement(y,{marginTop:1},"You are attempting to enable BOTH [YOLO Mode] and [External Workspace Access] simultaneously."),s.createElement(y,{marginTop:1,color:"red",bold:!0},"THIS IS NOT RECOMMENDED."),s.createElement(y,{marginTop:1,color:"yellow"},"THE CRITICAL RISK:"),s.createElement(y,null,"The agent will have the power to execute any command across your entire system WITHOUT your approval or supervision."),s.createElement(y,{color:"red",italic:!0,marginTop:1},"A single hallucination or error could result in full system wipe or data theft."),s.createElement(C,{marginTop:1},s.createElement(ao,{title:"Final Confirmation",items:[{label:"I agree knowing the consequences",value:"on"},{label:"Keep Off",value:"off"}],onSelect:x=>{x.value==="on"&&te(g=>({...g,autoExec:!0,allowExternalAccess:!0})),W("settings")}})));case"key":return s.createElement(ao,{title:"\u{1F511} API KEY MANAGEMENT",items:[{label:"Edit Current Key (Update)",value:"edit"},{label:"Remove Current Key (Purge)",value:"remove"},{label:"Cancel",value:"Cancel"}],onSelect:x=>{if(x.value==="edit"){yt(null),W("chat");let g=Ce(2);_(M=>[...M,{id:Date.now(),role:"system",text:`\u{1F511}${g}[ACTION] Flux waiting for new API Key...`}])}else x.value==="remove"?W("deleteKey"):W("chat")}});case"deleteKey":return s.createElement(C,{flexDirection:"column",borderStyle:"round",borderColor:"red",paddingX:2,paddingY:1},(()=>{let x=Ce(2);return s.createElement(y,{color:"red",bold:!0},"\u26D4",x,"DANGER: PURGE API KEY")})(),s.createElement(y,{marginTop:1},"This will permanently delete the saved API key from the project vault. You will need to enter it again to use Flux."),s.createElement(C,{marginTop:1},s.createElement(ao,{title:"Are you absolutely sure?",items:[{label:"YES, PURGE KEY",value:"yes"},{label:"NO, GO BACK",value:"no"}],onSelect:async x=>{if(x.value==="yes"){await Us(),yt(null),W("chat");let g=Ce(2);_(M=>[...M,{id:Date.now(),role:"system",text:`\u2728${g}[VAULT PURGED] API Key removed successfully.`}])}else W("key")}})));case"exit":return null;case"ask":return s.createElement(C,{width:"100%"},s.createElement(oa,{question:Zo?.question,options:Zo?.options,onResolve:x=>{Zo?.resolve&&Zo.resolve(x),vr(null),W("chat")}}));case"revert":return s.createElement(C,{width:"100%",alignItems:"center",justifyContent:"center"},s.createElement(vi,{prompts:St,onSelect:async x=>{try{let g=await bt.rollbackToBefore(x);if(g.success){let{targetPrompt:M}=g,B=vt.findIndex(b=>b.role==="user"&&b.text&&(b.text.startsWith(M)||b.text.includes(M))),A=[...vt];B!==-1&&(A=vt.slice(0,B)),_(A),ee(A.length),c(M),a(M.split(`
|
|
591
|
+
`).length>2);let v=A.filter(b=>!String(b.id).startsWith("welcome")&&!b.isMeta);await ns(_e,null,v);let j=Ce(2);_(b=>{let L=[...b,{id:"revert-ok-"+Date.now(),role:"system",text:`\u{1F504}${j}[TIME TRAVEL] Codebase rolled back successfully! Reverted prompt loaded to input box.`,isMeta:!0}];return ee(L.length),L}),W("chat")}}catch(g){let M=Ce(2);_(B=>{let A=[...B,{id:"revert-err-"+Date.now(),role:"system",text:`\u274C${M}[TIME TRAVEL ERROR] Failed to rollback: ${g.message}`,isMeta:!0}];return ee(A.length),A}),W("chat")}},onClose:()=>W("chat")}));case"resume":return s.createElement(C,{width:"100%",alignItems:"center",justifyContent:"center"},s.createElement(Oi,{onSelect:async x=>{let g=await vo();if(g[x]){r.write("\x1B[2J\x1B[3J\x1B[H"),lt(x);let M=[...g[x].messages];M[0]?.text?.includes("\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2557")||M.unshift({id:"welcome-"+Date.now(),role:"system",text:lr+`
|
|
587
592
|
|
|
588
|
-
\u{1F30A}\u26A1 Resuming Flux Flow Session...`,isMeta:!0}),
|
|
589
|
-
\u{1F680} **Restart Flux Flow to see changes.**`,isMeta:!0}])),
|
|
593
|
+
\u{1F30A}\u26A1 Resuming Flux Flow Session...`,isMeta:!0}),_(M),W("chat"),_(A=>{let v=[...A,{id:"sys-"+Date.now(),role:"system",text:`\u{1F4E1} SESSION RESUMED: [${x}]`,isMeta:!0}];return ee(v.length),v})}},onDelete:async x=>await Ys(x),onClose:()=>W("chat")}));case"memory":return s.createElement(C,{width:"100%",alignItems:"center",justifyContent:"center"},s.createElement(Di,{onClose:()=>W("chat")}));case"profile":return s.createElement(Bs,{initialData:Ie,onSave:x=>{rt(x),_(g=>[...g,{id:Date.now(),role:"system",text:`\u2705 Profile updated: ${x.name} (${x.nickname})`}]),W("chat")},onCancel:()=>W("chat")});case"resolution":return s.createElement(C,{width:"100%",alignItems:"center",justifyContent:"center"},s.createElement(fd,{data:Bo,onResolve:x=>{en(null),W("chat"),setTimeout(()=>{ht(x,!0)},500)},onEdit:x=>{en(null),W("chat"),c(x)}}));case"approval":return s.createElement(C,{flexDirection:"column",borderStyle:"round",borderColor:"yellow",paddingX:2,paddingY:1,width:"100%"},s.createElement(y,{color:"yellow",bold:!0,underline:!0},"\u{1F510} SECURITY GATE: FILE WRITE PERMISSION"),s.createElement(y,{marginTop:1},"The agent is attempting to modify: ",s.createElement(y,{color:"cyan"},ne(Qo?.args||"{}").path||"Unknown File")),Yo()?s.createElement(C,{marginTop:1,paddingX:1},s.createElement(y,{color:"cyan",italic:!0},"\u26A1\uFE0F FluxFlow Companion is active. Review the changes in your editor.")):s.createElement(C,{marginTop:1,borderStyle:"single",borderColor:"#333",paddingX:1,flexDirection:"column"},s.createElement(y,{color:"gray"},"--- PROPOSED CONTENT / DIFF ---"),(()=>{let x=ne(Qo?.args||"{}"),g=[],M=new Set;if(Object.keys(x).forEach(v=>{let j=v.match(/^(replaceContent|newContent|content_to_replace|content_to_add|TargetContent|ReplacementContent|replacementContent)(\d+)?$/);if(j){let b=j[2]?parseInt(j[2]):1;M.add(b)}}),Array.from(M).sort((v,j)=>v-j).forEach(v=>{let j,b;v===1?(j=x.replaceContent1??x.content_to_replace1??x.replaceContent??x.content_to_replace??x.TargetContent??null,b=x.newContent1??x.content_to_add1??x.newContent??x.content_to_add??x.ReplacementContent??x.replacementContent??null):(j=x[`replaceContent${v}`]??x[`content_to_replace${v}`]??null,b=x[`newContent${v}`]??x[`content_to_add${v}`]??null),(j!==null||b!==null)&&g.push({replace:j,new:b})}),g.length>0)return s.createElement(C,{flexDirection:"column",marginTop:1},g.map((v,j)=>{let b=v.replace!==null,L=v.new!==null;return s.createElement(C,{key:j,flexDirection:"column",marginTop:j>0?1:0},g.length>1&&s.createElement(y,{color:"gray"},"Block ",j+1,":"),b&&s.createElement(C,null,s.createElement(y,{color:"red",wrap:"anywhere",bold:!0},"- ",v.replace)),L&&s.createElement(C,{marginTop:b?1:0},s.createElement(y,{color:"green",wrap:"anywhere",bold:!0},"+ ",v.new.replace(/\[\/n\]?/g,"\\n"))))}));let A=x.content||x.ReplacementContent||x.content_to_add||x.replacementContent||x.newContent||null;return s.createElement(y,{color:"white",wrap:"anywhere"},(A?A.replace(/\[\/n\]?/g,"\\n"):null)||"Updating file content...")})()),s.createElement(C,{marginTop:1},s.createElement(ao,{title:"Action Required",items:[{label:"\u2705 Accept this time",value:"allow"},{label:"\u{1F510} Accept for this session",value:"always"},{label:"\u274C Don't accept",value:"deny"}],onSelect:x=>{x.value==="always"&&Xn(!0);let g=x.value==="deny"?"deny":"allow";Qo.resolve(g),fn(null),W("chat")}})));case"updateManager":return s.createElement(ao,{title:"Select Preferred Update Manager",subtitle:"NOTE: If you are unsure about these, go with NPM",items:[{label:"NPM (Standard)",value:"npm"},{label:"PNPM (Recommended)",value:"pnpm"},{label:"BUN (Ultra Fast)",value:"bun"},{label:"YARN (Classic)",value:"yarn"},{label:"Custom Command",value:"custom"},{label:"Back",value:"settings"}],onSelect:x=>{if(x.value==="settings"||x.value==="Back"){W("settings");return}x.value==="custom"?(Mo({label:"Enter Custom Update Command (Global install recommended):",key:"customUpdateCommand",value:Nt.customUpdateCommand,next:g=>(te(M=>({...M,updateManager:"custom",customUpdateCommand:g})),null)}),W("input")):(te(g=>({...g,updateManager:x.value})),W("settings"))}});case"update":return s.createElement(xl,{latest:je,current:Dn,settings:Nt,onClose:()=>W("chat"),onSuccess:()=>{_(x=>(ee(x.length+1),[...x,{id:"update-success-"+Date.now(),role:"system",text:`\u2728 **[UPDATE COMPLETED]** Flux Flow successfully upgraded to v${je}.
|
|
594
|
+
\u{1F680} **Restart Flux Flow to see changes.**`,isMeta:!0}])),W("chat")},onUpdateSettings:x=>{W("updateManager")}});case"terminalApproval":return s.createElement(C,{flexDirection:"column",borderStyle:"round",borderColor:"red",paddingX:2,paddingY:1,width:"100%"},s.createElement(y,{color:"red",bold:!0,underline:!0},"\u{1F510} SECURITY GATE: TERMINAL COMMAND OVERSIGHT"),s.createElement(C,{marginTop:1},s.createElement(y,null,"Agent requested to run: ",s.createElement(y,{color:"yellow",bold:!0},ne(Qo?.args||"{}").command||"Unknown Command"))),s.createElement(C,{marginTop:1},s.createElement(ao,{title:"Risk Assessment Required",items:[{label:"\u{1F680} Run",value:"allow"},{label:"\u274C Deny",value:"deny"}],onSelect:x=>{Qo.resolve(x.value),fn(null),W("chat")}})));default:return s.createElement(C,{flexDirection:"column",marginTop:1,flexShrink:0,width:"100%"},s.createElement(C,{paddingX:1,marginBottom:0,justifyContent:"space-between",width:"100%"},s.createElement(C,null,Fr?s.createElement(C,null,ur&&!ur&&s.createElement(md,null),s.createElement(y,{color:"magenta",bold:!0,italic:!0},ur&&!ur?" ":"",Fr.toUpperCase())):s.createElement(y,{color:"cyan",dimColor:!0,italic:!0}," ",l.length>0&&J?"Press ESC again to clear input":"READY FOR COMMAND...")),s.createElement(C,null,s.createElement(y,{color:"gray",bold:!0},"[ "),s.createElement(y,{color:"white"},Pn||ze),s.createElement(y,{color:"gray",bold:!0}," ]"))),s.createElement(C,{borderStyle:"round",borderColor:pn?"magenta":"cyan",paddingX:1,paddingY:0,width:"100%"},s.createElement(C,{flexDirection:"column",width:"100%"},s.createElement(C,{flexDirection:"row",width:"100%",paddingY:0},s.createElement(C,{flexShrink:0,width:4},s.createElement(y,{color:pn?"magenta":"cyan",bold:!0},pn?"\u2726 ":"\u{1F4A0} ")),s.createElement(C,{flexGrow:1},s.createElement(C,{flexGrow:1,position:"relative"},l===""&&s.createElement(C,{position:"absolute",paddingLeft:0},Tt&&!Kt?s.createElement(y,{color:"yellow"},le?" Terminal is waiting for user input. Press TAB to interact":" Press TAB to interact with terminal..."):Tt&&Kt?s.createElement(y,{color:"yellow",bold:!0}," [ TERMINAL FOCUSED ] Type to interact, press TAB to exit..."):J===1?s.createElement(y,{color:"cyan",bold:!0}," Press ESC again to ",l.length>0?"clear input":"revert codebase to checkpoint","..."):s.createElement(y,{color:"gray"},Po?" Press ESC again to cancel the request.":pn?" Enter a prompt to steer the agent.":` Send message or /cmd ... (${ot.shortcut} for newline), @file`)),s.createElement(_i,{key:`input-${f}`,focus:!Kt,showCursor:wo,lastFocusEventTime:ro.current,value:l,columns:h.columns,onChange:x=>{let g=x.replace(/\r\n/g,`
|
|
590
595
|
`).replace(/\r/g,`
|
|
591
596
|
`).replace(/\\\s*\n/g,`
|
|
592
|
-
`);c(g),D(!1)},onSubmit:Ge,maxRows:3,keyBindings:{submit:x=>x.return&&!x.shift&&!x.ctrl,newline:x=>x.return&&x.shift||x.return&&x.ctrl}})))))))}};return s.createElement(C,{flexDirection:"column",width:"100%"},_?s.createElement(sd,{width:r?.columns||80,height:r?.rows||24,selectedIndex:F}):s.createElement(s.Fragment,null,s.createElement(C,{flexDirection:"column",width:"100%",flexGrow:1},Pr.items.map((x,g)=>s.createElement(Is,{key:x.id||g,msg:x,showFullThinking:pe,columns:r?.columns||80}))),s.createElement(C,{flexDirection:"column",padding:1,width:"100%"},(Ht==="chat"||["ask","approval","terminalApproval"].includes(Ht))&&s.createElement(C,{flexDirection:"column",width:"100%"},s.createElement(Wi,{messages:Oe.slice(ur),showFullThinking:pe,columns:Math.max(20,(r?.columns||80)-1)}),Tt&&s.createElement(C,{marginTop:1},s.createElement(Wr,{command:Tt,output:Xt,isFocused:Kt,isPty:So}))),fe?s.createElement(C,{borderStyle:"double",borderColor:"magenta",padding:1,flexShrink:0},s.createElement(y,{color:"magenta"},"\u{1F30A} Starting Flux Flow...")):ve?bt():s.createElement(C,{borderStyle:"round",borderColor:"gray",padding:0,flexDirection:"column",flexShrink:0,width:"100%"},s.createElement(C,{paddingX:1,marginBottom:1},s.createElement(y,{color:"yellow",bold:!0},"\u{1F511}",Ce(2),"API KEY REQUIRED")),s.createElement(C,{paddingX:1,flexDirection:"column"},Pe===0?s.createElement(s.Fragment,null,s.createElement(y,null,"Select your Preferred Provider:"),s.createElement(C,{marginTop:1},s.createElement(io,{items:[{label:"Google (Free/Paid)",value:"Google"},{label:"DeepSeek (Paid)",value:"DeepSeek"},{label:"OpenRouter (Free/Paid) [EXPERIMENTAL]",value:"OpenRouter"}],onSelect:x=>{G(x.value),ce(1)}}))):s.createElement(s.Fragment,null,s.createElement(y,null,"Please enter your ",U," API Key to initialize the agent (If billing is enabled set Tier to paid in /settings \u2192 other \u2192 API Tier)."),s.createElement(C,{marginTop:1},s.createElement(y,{color:"cyan",bold:!0},"\u{1F4A0} "),s.createElement(Sl,{value:Xo,onChange:Ko,onSubmit:se,mask:"*"})),s.createElement(C,{marginTop:1},s.createElement(y,{color:"gray",italic:!0},"(Press ESC to go back to provider selection)")))),s.createElement(C,{paddingX:1,marginTop:1},s.createElement(y,{color:"gray",dimColor:!0,italic:!0},Pe===0?"(Use arrows to select and Enter to confirm)":"(Press Enter to confirm and initialize)"))),o&&s.createElement(C,{borderStyle:"round",borderColor:"red",paddingX:2,marginY:0,width:"100%"},s.createElement(y,{color:"red",bold:!0},"\u{1F534} EXIT CONFIRMATION: "),s.createElement(y,{color:"white"},"Press "),s.createElement(y,{color:"red",bold:!0},"CTRL + C"),s.createElement(y,{color:"white"}," again to exit (",n,"s). Press "),s.createElement(y,{color:"cyan",bold:!0},"ESC"),s.createElement(y,{color:"white"}," to cancel.")),s.createElement(C,{flexShrink:0,width:"100%"},s.createElement(Hi,{mode:f,thinkingLevel:q,tokens:he.tokens,tokensTotal:he.tokens,chatId:Ye,isMemoryEnabled:_t.memory,apiTier:je,aiProvider:U})),Ht==="exit"&&(()=>{let x=Date.now()-Ai,g=et+Ut,M=g>0?(et/g*100).toFixed(1):"0.0",B=rr+jn,O=B>0?(rr/B*100).toFixed(1):"0.0",$=B>0?(jn/B*100).toFixed(1):"0.0";return s.createElement(C,{flexDirection:"column",borderStyle:"round",paddingX:3,paddingY:1,borderColor:"red",width:Math.min(100,(r?.columns||100)-2),marginTop:0,marginBottom:0},s.createElement(C,{marginBottom:1},s.createElement(y,{color:"cyan",bold:!0},"Agent powering down. ",s.createElement(y,{color:"magenta"},"Goodbye!"))),s.createElement(C,{flexDirection:"column"},s.createElement(y,{color:"white",bold:!0,underline:!0},"Interaction Summary"),s.createElement(C,{marginTop:1},s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Session ID:")),s.createElement(y,{color:"white"},Ye)),s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Tool Calls:")),s.createElement(y,{color:"white"},et+Ut+qo," ( ",s.createElement(y,{color:"green"},"\u2713 ",et)," ",s.createElement(y,{color:"yellow"},"\u2298 ",qo)," ",s.createElement(y,{color:"red"},"\u2715 ",Ut)," )")),s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Success Rate:")),s.createElement(y,{color:"white"},M,"%")),s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Code Changes:")),s.createElement(y,{color:"white"},s.createElement(y,{color:"green"},"+",ms)," ",s.createElement(y,{color:"red"},"-",fs))),s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Tokens Consumed:")),s.createElement(y,{color:"white"},Jt(de))),de>0&&s.createElement(s.Fragment,null,s.createElement(C,{marginLeft:2},s.createElement(C,{width:18},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Input Tokens:")),s.createElement(y,{color:"white"},Jt(de-pt))),it>0&&s.createElement(C,{marginLeft:4},s.createElement(C,{width:16},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Cached:")),s.createElement(y,{color:"white"},Jt(it))),pt>0&&s.createElement(C,{marginLeft:2},s.createElement(C,{width:18},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Output Tokens:")),s.createElement(y,{color:"white"},Jt(pt)))),sr>0&&s.createElement(s.Fragment,null,s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Images Made:")),s.createElement(y,{color:"white"},sr)),s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Image Credits:")),s.createElement(y,{color:"white"},Number(((On||0)*1e3).toFixed(0))," credits")))),s.createElement(C,{flexDirection:"column",marginTop:1},s.createElement(y,{color:"white",bold:!0,underline:!0},"Performance"),s.createElement(C,{marginTop:1},s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Wall Time:")),s.createElement(y,{color:"white"},Jo(x))),s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Agent Active:")),s.createElement(y,{color:"white"},Jo(B))),s.createElement(C,{marginLeft:2},s.createElement(C,{width:18},s.createElement(y,{color:"blue",dimColor:!0},"\xBB API Time:")),s.createElement(y,{color:"white"},Jo(rr)," (",O,"%)")),s.createElement(C,{marginLeft:2},s.createElement(C,{width:18},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Tool Time:")),s.createElement(y,{color:"white"},Jo(jn)," (",$,"%)"))))})(),Ee.length>0&&(()=>{let g=Math.max(0,Math.min(w-2,Ee.length-5)),M=Ee.slice(g,g+5),B=Ee.length-(g+M.length);return s.createElement(C,{flexDirection:"column",borderStyle:"round",borderColor:"gray",paddingX:0,paddingY:0,width:"100%"},s.createElement(C,{paddingX:1,marginBottom:0,justifyContent:"space-between",width:"100%"},s.createElement(y,{color:"gray",bold:!0,dimColor:!0},Ee[0]?.cmd?.startsWith("@")?"\u{1F4C1} FILE SUGGESTIONS":"\u{1F50D} COMMAND SUGGESTIONS"),Ee[0]?.cmd?.startsWith("@")?s.createElement(y,{color:"gray",dimColor:!0,italic:!0},"(Use '#Lstart-Lend' to specify line numbers)"):l.startsWith("/model")&&je==="Free"?(()=>{let O="https://aistudio.google.com/billing",$="billing";return U==="DeepSeek"?(O="https://platform.deepseek.com/usage",$="billing"):U==="OpenRouter"&&(O="https://openrouter.ai/settings/profile",$="profile"),s.createElement(y,{color:"gray",dimColor:!0,italic:!0},"Paid API has more models. Configure ",s.createElement(y,{color:"cyan",underline:!0},`\x1B]8;;${O}\x07${$}\x1B]8;;\x07`)," & /settings")})():null),M.map((O,$)=>{let S=g+$===w,L=O.cmd==="gemma-4-31b-it"&&je!=="Free";return s.createElement(C,{key:O.cmd,flexDirection:"row",backgroundColor:S?"#2a2a2a":void 0,paddingX:1},s.createElement(C,{width:3},s.createElement(y,{color:S?"cyan":"gray",bold:S},S?" \u276F":" ")),s.createElement(C,{width:55},s.createElement(y,{color:L?"gray":S?"yellow":"white",bold:S,dimColor:L&&!S},O.cmd?.startsWith("@[")&&O.cmd?.endsWith("]")?(()=>{let j=O.cmd.slice(2,-1).split(/[/\\]/);return j[j.length-1]})():O.cmd)),s.createElement(C,{flexGrow:1},s.createElement(y,{color:"gray",italic:!0,dimColor:!S},O.desc)))}),Ee.length>5&&s.createElement(C,{paddingX:1,height:1},B>0?s.createElement(y,{color:"gray",dimColor:!0,italic:!0}," ... (",B," more commands available)"):s.createElement(y,{color:"gray",dimColor:!0,italic:!0}," (End of list)")))})())))}var ps,Cl,sd,Ai,El,ms,fs,id,kl,Mn,ad,bl,ld,cd,nr,dd,ud,Ol=ie(async()=>{Fi();Yi();ji();Gi();await zi();Ji();Zi();Sr();await al();ui();Er();ll();cl();await pl();an();hl();ns();ks();Qt();to();hn();await xr();wl();Pn();xi();ps=()=>{let e=(process.env.TERM_PROGRAM||"").toLowerCase();if(process.env.WT_SESSION)return"Windows Terminal";let o=t=>{let n=t.toLowerCase();for(let[i,r]of Object.entries(process.env))if(!["PATH","PWD","CWD","PS1","LS_COLORS","PROMPT"].includes(i)&&String(r).toLowerCase().includes(n))return!0;return!1};return e==="cursor"||process.env.CURSOR_SETTINGS_DIR||o("cursor")?"Cursor":e==="windsurf"||o("windsurf")?"Windsurf":o("antigravity")?"Antigravity":e==="trae"||o("trae")?"Trae":e==="codium"||o("codium")||o("vscode-oss")?"VSCodium":o("positron")?"Positron":e==="vscode"||process.env.VSCODE_GIT_IPC_HANDLE||o("vscode")?"VS Code":process.env.INTELLIJ_TERMINAL_COMMAND_BLOCKS||o("intellij")?"JetBrains":"Terminal"},Cl=e=>{let o=e==="VS Code",t=[];return o?(t.push({label:"Install Manually (VSIX)",url:"https://github.com/KushalRoyChowdhury/fluxflow-cli/releases"}),t.push({label:"Install from VS Code Marketplace",url:"https://marketplace.visualstudio.com/items?itemName=fluxflow-cli.fluxflow-cli-companion"})):t.push({label:`Download for ${e} (GitHub)`,url:"https://github.com/KushalRoyChowdhury/fluxflow-cli/releases"}),t.push({label:"Continue to CLI only",action:"dismiss"}),t},sd=({width:e,height:o,selectedIndex:t})=>{let n=ps(),i=Cl(n);return s.createElement(C,{flexDirection:"column",alignItems:"center",justifyContent:"center",width:e,height:o},s.createElement(C,{marginBottom:1},s.createElement(y,null,nr)),s.createElement(C,{flexDirection:"column",borderStyle:"double",borderColor:"cyan",paddingX:3,paddingY:1,width:Math.min(80,e-4)},s.createElement(y,{bold:!0,color:"cyan",textAlign:"center"},"\u{1F680} UPGRADE YOUR WORKFLOW"),s.createElement(C,{marginY:1,flexDirection:"column",alignItems:"left"},s.createElement(y,null,"You're in ",s.createElement(y,{bold:!0,color:"cyan"},n),", but the ",s.createElement(y,{bold:!0,color:"magenta"},"FluxFlow-CLI Companion")," is not installed."),s.createElement(C,{flexDirection:"column",marginY:1},s.createElement(y,{color:"gray"}," \u2705 Real-time file & cursor tracking"),s.createElement(y,{color:"gray"}," \u2705 Auto-open files created by agent"),s.createElement(y,{color:"gray"}," \u2705 Native DIFF viewer for AI edits"),s.createElement(y,{color:"gray"}," \u2705 Direct IDE context sharing"),s.createElement(y,{color:"gray"}," \u2705 Surgical Diagnostic Sync"),s.createElement(y,{color:"gray"}," \u2705 Native Right-Click \u276F Chat integration"),s.createElement(y,{color:"gray"}," \u2705 Live Status in IDE"),s.createElement(y,{color:"gray"}," \u2705 Clickable terminal-to-code links"))),s.createElement(C,{flexDirection:"column",marginTop:1},i.map((r,l)=>s.createElement(C,{key:l},s.createElement(y,{color:t===l?"yellow":"white",bold:t===l},t===l?" \u276F ":" ",r.label)))),s.createElement(C,{marginTop:1,alignItems:"center",justifyContent:"center"},s.createElement(y,{dimColor:!0,italic:!0},"(Use arrows to navigate, Enter to select)"))))},Ai=Date.now(),El="https://fluxflow-cli.onrender.com/changelog.html",ms=0,fs=0,id=Yn.join(Yn.dirname(nd(import.meta.url)),"../package.json"),kl=JSON.parse(oo.readFileSync(id,"utf8")),Mn=kl.version,ad=kl.date||"2026-05-20",bl=["\u280B","\u2819","\u2839","\u2838","\u283C","\u2834","\u2826","\u2827","\u2807","\u280F"],ld=()=>{let[e,o]=V(0);return lo(()=>{let t=setInterval(()=>{o(n=>(n+1)%1e3)},33);return()=>clearInterval(t)},[]),s.createElement(y,{color:"magenta"},bl[Math.floor(e/3)%bl.length])},cd=({data:e,onResolve:o,onEdit:t})=>s.createElement(C,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},s.createElement(C,{paddingX:1},s.createElement(y,{color:"magenta",bold:!0,underline:!0},"\u{1F7E3} STEERING HINT RESOLUTION")),s.createElement(C,{paddingX:1,marginTop:1},s.createElement(y,null,"The agent already finished the task before your hint was consumed.")),s.createElement(C,{marginTop:1,backgroundColor:"#222",paddingX:2,width:"100%"},s.createElement(y,{italic:!0,color:"gray"},'"',e,'"')),s.createElement(C,{paddingX:1,marginTop:1},s.createElement(y,{color:"cyan"},"How would you like to proceed?")),s.createElement(C,{marginTop:0},s.createElement(io,{title:"Select Action",items:[{label:"Send Anyway",value:"send"},{label:"Edit Prompt",value:"edit"}],onSelect:n=>{n==="send"?o(e):t(e)}}))),nr=rd(["#00ffff","#0077ff","#ff00ff"]).multiline(`\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2557\u2588\u2588\u2557 \u2588\u2588\u2557 \u2588\u2588\u2557\u2588\u2588\u2557 \u2588\u2588\u2557 \u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2557\u2588\u2588\u2557 \u2588\u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2557 \u2588\u2588\u2557
|
|
597
|
+
`);c(g),$(!1)},onSubmit:ht,maxRows:3,keyBindings:{submit:x=>x.return&&!x.shift&&!x.ctrl,newline:x=>x.return&&x.shift||x.return&&x.ctrl}})))))))}};return s.createElement(C,{flexDirection:"column",width:"100%"},U?s.createElement(cd,{width:r?.columns||80,height:r?.rows||24,selectedIndex:P}):s.createElement(s.Fragment,null,s.createElement(C,{flexDirection:"column",width:"100%",flexGrow:1},Nr.items.map((x,g)=>s.createElement(As,{key:x.id||g,msg:x,showFullThinking:fe,columns:r?.columns||80}))),s.createElement(C,{flexDirection:"column",padding:1,width:"100%"},(Yt==="chat"||["ask","approval","terminalApproval"].includes(Yt))&&s.createElement(C,{flexDirection:"column",width:"100%"},s.createElement(Gi,{messages:vt.slice(Ss),showFullThinking:fe,columns:Math.max(20,(r?.columns||80)-1)}),Tt&&s.createElement(C,{marginTop:1},s.createElement(jr,{command:Tt,output:Xt,isFocused:Kt,isPty:Eo}))),me?s.createElement(C,{borderStyle:"double",borderColor:"magenta",padding:1,flexShrink:0},s.createElement(y,{color:"magenta"},"\u{1F30A} Starting Flux Flow...")):Le?fo():s.createElement(C,{borderStyle:"round",borderColor:"gray",padding:0,flexDirection:"column",flexShrink:0,width:"100%"},s.createElement(C,{paddingX:1,marginBottom:1},s.createElement(y,{color:"yellow",bold:!0},"\u{1F511}",Ce(2),"API KEY REQUIRED")),s.createElement(C,{paddingX:1,flexDirection:"column"},Ct===0?s.createElement(s.Fragment,null,s.createElement(y,null,"Select your Preferred Provider:"),s.createElement(C,{marginTop:1},s.createElement(ao,{items:[{label:"Google (Free/Paid)",value:"Google"},{label:"DeepSeek (Paid)",value:"DeepSeek"},{label:"OpenRouter (Free/Paid) [EXPERIMENTAL]",value:"OpenRouter"}],onSelect:x=>{z(x.value),Te(1)}}))):s.createElement(s.Fragment,null,s.createElement(y,null,"Please enter your ",X," API Key to initialize the agent (If billing is enabled set Tier to paid in /settings \u2192 other \u2192 API Tier)."),s.createElement(C,{marginTop:1},s.createElement(y,{color:"cyan",bold:!0},"\u{1F4A0} "),s.createElement(kl,{value:Vo,onChange:zo,onSubmit:Me,mask:"*"})),s.createElement(C,{marginTop:1},s.createElement(y,{color:"gray",italic:!0},"(Press ESC to go back to provider selection)")))),s.createElement(C,{paddingX:1,marginTop:1},s.createElement(y,{color:"gray",dimColor:!0,italic:!0},Ct===0?"(Use arrows to select and Enter to confirm)":"(Press Enter to confirm and initialize)"))),o&&s.createElement(C,{borderStyle:"round",borderColor:"red",paddingX:2,marginY:0,width:"100%"},s.createElement(y,{color:"red",bold:!0},"\u{1F534} EXIT CONFIRMATION: "),s.createElement(y,{color:"white"},"Press "),s.createElement(y,{color:"red",bold:!0},"CTRL + C"),s.createElement(y,{color:"white"}," again to exit (",n,"s). Press "),s.createElement(y,{color:"cyan",bold:!0},"ESC"),s.createElement(y,{color:"white"}," to cancel.")),s.createElement(C,{flexShrink:0,width:"100%"},s.createElement(Ki,{mode:m,thinkingLevel:G,tokens:pe.tokens,tokensTotal:pe.tokens,chatId:_e,isMemoryEnabled:Nt.memory,apiTier:Re,aiProvider:X})),Yt==="exit"&&(()=>{let x=Date.now()-Fi,g=et+Ut,M=g>0?(et/g*100).toFixed(1):"0.0",B=cr+Gn,A=B>0?(cr/B*100).toFixed(1):"0.0",v=B>0?(Gn/B*100).toFixed(1):"0.0";return s.createElement(C,{flexDirection:"column",borderStyle:"round",paddingX:3,paddingY:1,borderColor:"red",width:Math.min(100,(r?.columns||100)-2),marginTop:0,marginBottom:0},s.createElement(C,{marginBottom:1},s.createElement(y,{color:"cyan",bold:!0},"Agent powering down. ",s.createElement(y,{color:"magenta"},"Goodbye!"))),s.createElement(C,{flexDirection:"column"},s.createElement(y,{color:"white",bold:!0,underline:!0},"Interaction Summary"),s.createElement(C,{marginTop:1},s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Session ID:")),s.createElement(y,{color:"white"},_e)),s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Tool Calls:")),s.createElement(y,{color:"white"},et+Ut+Jo," ( ",s.createElement(y,{color:"green"},"\u2713 ",et)," ",s.createElement(y,{color:"yellow"},"\u2298 ",Jo)," ",s.createElement(y,{color:"red"},"\u2715 ",Ut)," )")),s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Success Rate:")),s.createElement(y,{color:"white"},M,"%")),s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Code Changes:")),s.createElement(y,{color:"white"},s.createElement(y,{color:"green"},"+",hs)," ",s.createElement(y,{color:"red"},"-",gs))),s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Tokens Consumed:")),s.createElement(y,{color:"white"},Qt(ce))),ce>0&&s.createElement(s.Fragment,null,s.createElement(C,{marginLeft:2},s.createElement(C,{width:18},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Input Tokens:")),s.createElement(y,{color:"white"},Qt(ce-pt))),it>0&&s.createElement(C,{marginLeft:4},s.createElement(C,{width:16},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Cached:")),s.createElement(y,{color:"white"},Qt(it))),pt>0&&s.createElement(C,{marginLeft:2},s.createElement(C,{width:18},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Output Tokens:")),s.createElement(y,{color:"white"},Qt(pt)))),dr>0&&s.createElement(s.Fragment,null,s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Images Made:")),s.createElement(y,{color:"white"},dr)),s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Image Credits:")),s.createElement(y,{color:"white"},Number(((vn||0)*1e3).toFixed(0))," credits")))),s.createElement(C,{flexDirection:"column",marginTop:1},s.createElement(y,{color:"white",bold:!0,underline:!0},"Performance"),s.createElement(C,{marginTop:1},s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Wall Time:")),s.createElement(y,{color:"white"},Fo(x))),s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Agent Active:")),s.createElement(y,{color:"white"},Fo(B))),s.createElement(C,{marginLeft:2},s.createElement(C,{width:18},s.createElement(y,{color:"blue",dimColor:!0},"\xBB API Time:")),s.createElement(y,{color:"white"},Fo(cr)," (",A,"%)")),s.createElement(C,{marginLeft:2},s.createElement(C,{width:18},s.createElement(y,{color:"blue",dimColor:!0},"\xBB Tool Time:")),s.createElement(y,{color:"white"},Fo(Gn)," (",v,"%)"))))})(),be.length>0&&(()=>{let g=Math.max(0,Math.min(T-2,be.length-5)),M=be.slice(g,g+5),B=be.length-(g+M.length);return s.createElement(C,{flexDirection:"column",borderStyle:"round",borderColor:"gray",paddingX:0,paddingY:0,width:"100%"},s.createElement(C,{paddingX:1,marginBottom:0,justifyContent:"space-between",width:"100%"},s.createElement(y,{color:"gray",bold:!0,dimColor:!0},be[0]?.cmd?.startsWith("@")?"\u{1F4C1} FILE SUGGESTIONS":"\u{1F50D} COMMAND SUGGESTIONS"),be[0]?.cmd?.startsWith("@")?s.createElement(y,{color:"gray",dimColor:!0,italic:!0},"(Use '#Lstart-Lend' to specify line numbers)"):l.startsWith("/model")&&Re==="Free"?(()=>{let A="https://aistudio.google.com/billing",v="billing";return X==="DeepSeek"?(A="https://platform.deepseek.com/usage",v="billing"):X==="OpenRouter"&&(A="https://openrouter.ai/settings/profile",v="profile"),s.createElement(y,{color:"gray",dimColor:!0,italic:!0},"Paid API has more models. Configure ",s.createElement(y,{color:"cyan",underline:!0},`\x1B]8;;${A}\x07${v}\x1B]8;;\x07`)," & /settings")})():null),M.map((A,v)=>{let b=g+v===T,L=A.cmd==="gemma-4-31b-it"&&Re!=="Free";return s.createElement(C,{key:A.cmd,flexDirection:"row",backgroundColor:b?"#2a2a2a":void 0,paddingX:1},s.createElement(C,{width:3},s.createElement(y,{color:b?"cyan":"gray",bold:b},b?" \u276F":" ")),s.createElement(C,{width:55},s.createElement(y,{color:L?"gray":b?"yellow":"white",bold:b,dimColor:L&&!b},A.cmd?.startsWith("@[")&&A.cmd?.endsWith("]")?(()=>{let R=A.cmd.slice(2,-1).split(/[/\\]/);return R[R.length-1]})():A.cmd)),s.createElement(C,{flexGrow:1},s.createElement(y,{color:"gray",italic:!0,dimColor:!b},A.desc)))}),be.length>5&&s.createElement(C,{paddingX:1,height:1},B>0?s.createElement(y,{color:"gray",dimColor:!0,italic:!0}," ... (",B," more commands available)"):s.createElement(y,{color:"gray",dimColor:!0,italic:!0}," (End of list)")))})())))}var xs,Al,cd,Fi,Il,hs,gs,dd,Ol,Dn,ud,Ml,md,fd,lr,pd,hd,vl=ae(async()=>{Ui();Xi();qi();Vi();await ea();ta();na();Tr();await ul();fi();Sr();ml();fl();await yl();an();wl();is();Ms();Zt();oo();wn();await gr();bl();Bn();Si();xs=()=>{let e=(process.env.TERM_PROGRAM||"").toLowerCase();if(process.env.WT_SESSION)return"Windows Terminal";let o=t=>{let n=t.toLowerCase();for(let[i,r]of Object.entries(process.env))if(!["PATH","PWD","CWD","PS1","LS_COLORS","PROMPT"].includes(i)&&String(r).toLowerCase().includes(n))return!0;return!1};return e==="cursor"||process.env.CURSOR_SETTINGS_DIR||o("cursor")?"Cursor":e==="windsurf"||o("windsurf")?"Windsurf":o("antigravity")?"Antigravity":e==="trae"||o("trae")?"Trae":e==="codium"||o("codium")||o("vscode-oss")?"VSCodium":o("positron")?"Positron":e==="vscode"||process.env.VSCODE_GIT_IPC_HANDLE||o("vscode")?"VS Code":process.env.INTELLIJ_TERMINAL_COMMAND_BLOCKS||o("intellij")?"JetBrains":"Terminal"},Al=e=>{let o=e==="VS Code",t=[];return o?(t.push({label:"Install Manually (VSIX)",url:"https://github.com/KushalRoyChowdhury/fluxflow-cli/releases"}),t.push({label:"Install from VS Code Marketplace",url:"https://marketplace.visualstudio.com/items?itemName=fluxflow-cli.fluxflow-cli-companion"})):t.push({label:`Download for ${e} (GitHub)`,url:"https://github.com/KushalRoyChowdhury/fluxflow-cli/releases"}),t.push({label:"Continue to CLI only",action:"dismiss"}),t},cd=({width:e,height:o,selectedIndex:t})=>{let n=xs(),i=Al(n);return s.createElement(C,{flexDirection:"column",alignItems:"center",justifyContent:"center",width:e,height:o},s.createElement(C,{marginBottom:1},s.createElement(y,null,lr)),s.createElement(C,{flexDirection:"column",borderStyle:"double",borderColor:"cyan",paddingX:3,paddingY:1,width:Math.min(80,e-4)},s.createElement(y,{bold:!0,color:"cyan",textAlign:"center"},"\u{1F680} UPGRADE YOUR WORKFLOW"),s.createElement(C,{marginY:1,flexDirection:"column",alignItems:"left"},s.createElement(y,null,"You're in ",s.createElement(y,{bold:!0,color:"cyan"},n),", but the ",s.createElement(y,{bold:!0,color:"magenta"},"FluxFlow-CLI Companion")," is not installed."),s.createElement(C,{flexDirection:"column",marginY:1},s.createElement(y,{color:"gray"}," \u2705 Real-time file & cursor tracking"),s.createElement(y,{color:"gray"}," \u2705 Auto-open files created by agent"),s.createElement(y,{color:"gray"}," \u2705 Native DIFF viewer for AI edits"),s.createElement(y,{color:"gray"}," \u2705 Direct IDE context sharing"),s.createElement(y,{color:"gray"}," \u2705 Surgical Diagnostic Sync"),s.createElement(y,{color:"gray"}," \u2705 Native Right-Click \u276F Chat integration"),s.createElement(y,{color:"gray"}," \u2705 Live Status in IDE"),s.createElement(y,{color:"gray"}," \u2705 Clickable terminal-to-code links"))),s.createElement(C,{flexDirection:"column",marginTop:1},i.map((r,l)=>s.createElement(C,{key:l},s.createElement(y,{color:t===l?"yellow":"white",bold:t===l},t===l?" \u276F ":" ",r.label)))),s.createElement(C,{marginTop:1,alignItems:"center",justifyContent:"center"},s.createElement(y,{dimColor:!0,italic:!0},"(Use arrows to navigate, Enter to select)"))))},Fi=Date.now(),Il="https://fluxflow-cli.onrender.com/changelog.html",hs=0,gs=0,dd=Yn.join(Yn.dirname(ad(import.meta.url)),"../package.json"),Ol=JSON.parse(no.readFileSync(dd,"utf8")),Dn=Ol.version,ud=Ol.date||"2026-05-20",Ml=["\u280B","\u2819","\u2839","\u2838","\u283C","\u2834","\u2826","\u2827","\u2807","\u280F"],md=()=>{let[e,o]=q(0);return co(()=>{let t=setInterval(()=>{o(n=>(n+1)%1e3)},33);return()=>clearInterval(t)},[]),s.createElement(y,{color:"magenta"},Ml[Math.floor(e/3)%Ml.length])},fd=({data:e,onResolve:o,onEdit:t})=>s.createElement(C,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},s.createElement(C,{paddingX:1},s.createElement(y,{color:"magenta",bold:!0,underline:!0},"\u{1F7E3} STEERING HINT RESOLUTION")),s.createElement(C,{paddingX:1,marginTop:1},s.createElement(y,null,"The agent already finished the task before your hint was consumed.")),s.createElement(C,{marginTop:1,backgroundColor:"#222",paddingX:2,width:"100%"},s.createElement(y,{italic:!0,color:"gray"},'"',e,'"')),s.createElement(C,{paddingX:1,marginTop:1},s.createElement(y,{color:"cyan"},"How would you like to proceed?")),s.createElement(C,{marginTop:0},s.createElement(ao,{title:"Select Action",items:[{label:"Send Anyway",value:"send"},{label:"Edit Prompt",value:"edit"}],onSelect:n=>{n==="send"?o(e):t(e)}}))),lr=ld(["#00ffff","#0077ff","#ff00ff"]).multiline(`\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2557\u2588\u2588\u2557 \u2588\u2588\u2557 \u2588\u2588\u2557\u2588\u2588\u2557 \u2588\u2588\u2557 \u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2557\u2588\u2588\u2557 \u2588\u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2557 \u2588\u2588\u2557
|
|
593
598
|
\u2588\u2588\u2554\u2550\u2550\u2550\u2550\u255D\u2588\u2588\u2551 \u2588\u2588\u2551 \u2588\u2588\u2551\u255A\u2588\u2588\u2557\u2588\u2588\u2554\u255D \u2588\u2588\u2554\u2550\u2550\u2550\u2550\u255D\u2588\u2588\u2551 \u2588\u2588\u2554\u2550\u2550\u2550\u2588\u2588\u2557\u2588\u2588\u2551 \u2588\u2588\u2551
|
|
594
599
|
\u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2551 \u2588\u2588\u2551 \u2588\u2588\u2551 \u255A\u2588\u2588\u2588\u2554\u255D \u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2551 \u2588\u2588\u2551 \u2588\u2588\u2551\u2588\u2588\u2551 \u2588\u2557 \u2588\u2588\u2551
|
|
595
600
|
\u2588\u2588\u2554\u2550\u2550\u255D \u2588\u2588\u2551 \u2588\u2588\u2551 \u2588\u2588\u2551 \u2588\u2588\u2554\u2588\u2588\u2557 \u2588\u2588\u2554\u2550\u2550\u255D \u2588\u2588\u2551 \u2588\u2588\u2551 \u2588\u2588\u2551\u2588\u2588\u2551\u2588\u2588\u2588\u2557\u2588\u2588\u2551
|
|
596
601
|
\u2588\u2588\u2551 \u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2557\u255A\u2588\u2588\u2588\u2588\u2588\u2588\u2554\u255D\u2588\u2588\u2554\u255D \u2588\u2588\u2557 \u2588\u2588\u2551 \u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2557\u255A\u2588\u2588\u2588\u2588\u2588\u2588\u2554\u255D\u255A\u2588\u2588\u2588\u2554\u2588\u2588\u2588\u2554\u255D
|
|
597
|
-
\u255A\u2550\u255D \u255A\u2550\u2550\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u255D \u255A\u2550\u255D \u255A\u2550\u255D \u255A\u2550\u2550\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u2550\u255D\u255A\u2550\u2550\u255D`),
|
|
602
|
+
\u255A\u2550\u255D \u255A\u2550\u2550\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u255D \u255A\u2550\u255D \u255A\u2550\u255D \u255A\u2550\u2550\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u2550\u255D\u255A\u2550\u2550\u255D`),pd=e=>{let o=[],t=/\[\s*tool:functions\.([a-z0-9_]+)\s*\(/gi,n=0,i;for(;(i=t.exec(e))!==null;){let r=i[1],l=i.index+i[0].length-1,c=0,f=null,u=-1,d=-1;for(let a=l;a<e.length;a++){let m=e[a];if(f){if(m===f){let p=0;for(let h=a-1;h>=0&&e[h]==="\\";h--)p++;p%2===0&&(f=null)}}else if(m==='"'||m==="'"||m==="`")f=m;else if(m==="(")c++;else if(m===")"&&(c--,c===0)){d=a;let p=a+1;for(;p<e.length&&/\s/.test(e[p]);)p++;if(p<e.length&&e[p]==="]"){u=p;break}}}if(u!==-1){let a=e.substring(n,i.index);a.trim()&&o.push({type:"output",content:a});let m=e.substring(l+1,d);o.push({type:"tool",toolName:r.trim(),args:m.trim()}),n=u+1,t.lastIndex=n}else break}if(n<e.length){let r=e.substring(n);r.trim()&&o.push({type:"output",content:r})}return o},hd=(()=>{let e=null,o=0;return t=>{let n=Date.now();if(e&&n-o<5e3)return e;let i=[],r=l=>{try{let c=no.readdirSync(l);for(let f of c){if(["node_modules",".git",".gemini","dist","build",".next",".cache","out"].includes(f))continue;let u=Yn.join(l,f);no.statSync(u).isDirectory()?r(u):i.push({name:f,relativePath:Yn.relative(process.cwd(),u)})}}catch{}};return r(t),e=i,o=n,i}})()});import{spawn as gd}from"child_process";import{fileURLToPath as $l}from"url";var xd=4096,yd=$l(import.meta.url).endsWith(".js");if(yd&&!process.execArgv.some(e=>e.includes("max-old-space-size")))gd(process.execPath,[`--max-old-space-size=${xd}`,$l(import.meta.url),...process.argv.slice(2)],{stdio:"inherit"}).on("exit",o=>process.exit(o||0));else{let{default:e}=await import("react"),{render:o}=await import("ink"),{default:t}=await vl().then(()=>Dl);process.env.NODE_NO_WARNINGS="1";let n=["cuimp","Found existing binary","Binary verified","curl.exe not found","Falling back to .bat file","DeprecationWarning"],i=console.log,r=console.warn,l=console.error,c=f=>{let u=f.map(String).join(" ");return n.some(d=>u.includes(d))};console.log=(...f)=>!c(f)&&i(...f),console.warn=(...f)=>!c(f)&&r(...f),console.error=(...f)=>!c(f)&&l(...f),process.stdout.write("\x1B[2J\x1B[3J\x1B[H"),process.stdout.isTTY&&(process.stdout.write("\x1B]0;FluxFlow\x07"),process.stdout.write("\x1B]633;P;TerminalTitle=FluxFlow\x07")),o(e.createElement(t,{args:process.argv.slice(2)}),{exitOnCtrlC:!1})}
|