fluxflow-cli 2.1.3 → 2.1.4
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 +88 -84
- package/package.json +1 -1
package/dist/fluxflow.js
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
var Dl=Object.defineProperty;var ie=(e,o)=>()=>(e&&(o=e(e=0)),o);var Ss=(e,o)=>{for(var t in o)Dl(e,t,{get:o[t],enumerable:!0})};import so,{useState as hr,useEffect as Cs,useMemo as Es,useCallback as _r,useRef as vi}from"react";import{Box as pr,Spacer as vl,Text as fr,useInput as $l,measureElement as
|
|
2
|
+
var Dl=Object.defineProperty;var ie=(e,o)=>()=>(e&&(o=e(e=0)),o);var Ss=(e,o)=>{for(var t in o)Dl(e,t,{get:o[t],enumerable:!0})};import so,{useState as hr,useEffect as Cs,useMemo as Es,useCallback as _r,useRef as vi}from"react";import{Box as pr,Spacer as vl,Text as fr,useInput as $l,measureElement as Pl}from"ink";function Fl(e,o){return e.replace(/\t/g," ".repeat(o))}function bs(e){return e==null?"":e.replace(/\r\n/g,`
|
|
3
3
|
`).replace(/\r/g,`
|
|
4
|
-
`)}var $i,Bl,Fi
|
|
4
|
+
`)}var $i,Bl,Pi,Fi=ie(()=>{$i=({children:e,onHeightChange:o})=>{let t=vi(null),n=vi(void 0);return Cs(()=>{if(t.current){let{height:i}=Pl(t.current);n.current!==i&&(n.current=i,o?.(i))}}),so.createElement(pr,{ref:t,flexShrink:0,flexGrow:0,width:"100%"},e)},Bl=({value:e,rows:o,maxRows:t,highlightStyle:n,textStyle:i,placeholder:r="",mask:l,showCursor:c=!0,focus:m=!0,tabSize:d=4,cursorIndex:u=0,highlight:a,refreshKey:f})=>{let[p,h]=hr(0),[T,w]=hr(0),[E,k]=hr(0),D=_r((A,v=!1)=>{let J=bs(A);if(!v&&l)return J.replace(/[^\n]/g,l);let q=Fl(J,d);return v?q:q.replace(/@\[(.*?)\]/g,(le,U)=>{let G=U.indexOf("#"),Pe=U.indexOf(":L"),ce=U,De="";G!==-1?(ce=U.slice(0,G),De=U.slice(G)):Pe!==-1&&(ce=U.slice(0,Pe),De=U.slice(Pe));let nt=ce.replace(/\\/g,"/"),pe=(process.cwd()||"").replace(/\\/g,"/");pe&&nt.toLowerCase().startsWith(pe.toLowerCase()+"/")?nt=nt.slice(pe.length+1):nt.startsWith("./")&&(nt=nt.slice(2));let ut=nt.split("/");return`[${ut[ut.length-1]}${De}]`})},[d,l]),{preCursor:_,postCursor:K}=Es(()=>{if(!e)return r&&!m?{preCursor:[{value:D(r,!0),type:"placeholder"}],postCursor:[]}:{preCursor:[{value:c&&m?" ":"",type:"cursor"}],postCursor:[]};let A=e.slice(0,u),v=e.slice(u);if(!m)return{preCursor:[{value:D(e)}],postCursor:[]};if(a&&a.end>a.start&&a.start>=0&&a.end<=e.length)return{preCursor:[{value:D(A.slice(0,a.start))},{value:D(A.slice(a.start,Math.min(a.end,u))),type:"highlight"},{value:D(A.slice(a.end))},{value:c&&m?" ":"",type:"cursor"}],postCursor:[{value:D(v.slice(0,Math.max(a.start-u,0)))},{value:D(v.slice(Math.max(a.start-u,0),Math.max(a.end-u,0))),type:"highlight"},{value:D(v.slice(Math.max(a.end-u,0)))}]};{let q=D(A),le=D(v),U=q.lastIndexOf(`
|
|
5
5
|
`)+1,G=le.indexOf(`
|
|
6
|
-
`);return{preCursor:[{value:q.slice(0,U)},{value:q.slice(U),type:"highlight"},{value:c&&m?" ":"",type:"cursor"}],postCursor:[{value:le.slice(0,G),type:"highlight"},{value:le.slice(G)}]}}},[u,c,m,e,r,l,a,D,f]),
|
|
7
|
-
`),K=Math.max(20,m-10),
|
|
8
|
-
`),
|
|
9
|
-
`+e.slice(a);o(I),f(a+1),h(0);return}if(D.tab||D.shift&&D.tab||D.ctrl&&k==="c")return;let
|
|
10
|
-
`+e.slice(a);o(I),f(a+1),h(0)}else if(D.backspace||D.delete){if(a>0){let I=e.slice(0,a-1)+e.slice(a);o(I),f(a-1),h(0)}}else if(k){let I=e.slice(0,a)+k+e.slice(a);o(I),f(a+k.length),h(
|
|
6
|
+
`);return{preCursor:[{value:q.slice(0,U)},{value:q.slice(U),type:"highlight"},{value:c&&m?" ":"",type:"cursor"}],postCursor:[{value:le.slice(0,G),type:"highlight"},{value:le.slice(G)}]}}},[u,c,m,e,r,l,a,D,f]),F=Es(()=>T!==void 0?Math.max(o??t??1,Math.min(t??o??1,T)):1,[o,t,T]);Cs(()=>{if(E!==void 0&&F!==void 0){let A=E;h(v=>{let J=v,q=v+F;if(A<=J)return Math.max(0,A-1);if(A>q)return A-F;if(T){if(T<F)return 0;if(T<q)return T-F}return v})}},[E,F,T]);let I=_r(A=>{switch(A){case"placeholder":return{...i,dimColor:!0};case"highlight":return n??i;case"cursor":return{...i,color:c&&m?"cyan":void 0,bold:c&&m,inverse:c&&m};default:return i}},[i,n,c,m]);return so.createElement(pr,{height:F,overflow:"hidden",flexDirection:"column",flexGrow:0,flexShrink:0},so.createElement(pr,{flexDirection:"column"},so.createElement(pr,{height:F,overflowY:"hidden",flexShrink:0,flexDirection:"column"},so.createElement(pr,{marginTop:-p,flexDirection:"column"},so.createElement($i,{onHeightChange:w},so.createElement(fr,null,_?.map((A,v)=>so.createElement(fr,{key:v,...I(A.type)},A.value)),K?.map((A,v)=>so.createElement(fr,{key:v,...I(A.type)},A.value))))),so.createElement(vl,null)),so.createElement($i,{onHeightChange:k},so.createElement(fr,null,_?.map((A,v)=>so.createElement(fr,{key:v,...I(A.type)},A.value))))))},Pi=({value:e,onChange:o,onSubmit:t,keyBindings:n,showCursor:i=!0,highlightPastedText:r=!1,focus:l=!0,lastFocusEventTime:c=0,columns:m=80,useCustomInput:d=(a,f)=>$l(a,{isActive:f}),...u})=>{let[a,f]=hr(e.length),[p,h]=hr(0);Cs(()=>{a>e.length&&f(e.length)},[e,a]);let T=_r(k=>{let _=bs(e).split(`
|
|
7
|
+
`),K=Math.max(20,m-10),F=0,I=0,A=0;for(let v=0;v<_.length;v++){let q=_[v].length;if(k>=A&&k<=A+q){let U=k-A;return F+=Math.floor(U/K),I=U%K,{visualLine:F,visualCol:I}}let le=Math.max(1,Math.ceil(q/K));F+=le,A+=q+1}return{visualLine:F,visualCol:I}},[e,m]),w=_r((k,D)=>{let K=bs(e).split(`
|
|
8
|
+
`),F=Math.max(20,m-10),I=0,A=0;for(let v=0;v<K.length;v++){let q=K[v].length,le=Math.max(1,Math.ceil(q/F));if(k>=I&&k<I+le){let U=(k-I)*F,G=Math.min(D,q-U),Pe=Math.max(0,G);return Math.min(A+U+Pe,A+q)}I+=le,A+=q+1}return e.length},[e,m]);d((k,D)=>{if(k==="\x1B[I"||k==="\x1B[O"||k==="[I"||k==="[O")return;let _=n?.submit??(I=>I.return&&I.ctrl),K=n?.newline??(I=>I.return);if(_(D)){t?.(e);return}else if(K(D)){let I=e.slice(0,a)+`
|
|
9
|
+
`+e.slice(a);o(I),f(a+1),h(0);return}if(D.tab||D.shift&&D.tab||D.ctrl&&k==="c")return;let F=0;if(k.length>1&&(F=k.length),D.upArrow){if(i){let{visualLine:I,visualCol:A}=T(a);if(I>0){let v=w(I-1,A);f(v),h(0)}}}else if(D.downArrow){if(i){let{visualLine:I,visualCol:A}=T(a),v=w(I+1,A);v!==a&&(f(v),h(0))}}else if(D.leftArrow)i&&(f(Math.max(0,a-1)),h(0));else if(D.rightArrow)i&&(f(Math.min(e.length,a+1)),h(0));else if(D.return){let I=e.slice(0,a)+`
|
|
10
|
+
`+e.slice(a);o(I),f(a+1),h(0)}else if(D.backspace||D.delete){if(a>0){let I=e.slice(0,a-1)+e.slice(a);o(I),f(a-1),h(0)}}else if(k){let I=e.slice(0,a)+k+e.slice(a);o(I),f(a+k.length),h(F)}},l);let E=Es(()=>{if(r&&p>1)return{start:Math.max(0,a-p),end:a}},[a,p,r]);return so.createElement(Bl,{...u,value:e,cursorIndex:a,highlight:E,showCursor:i,focus:l})}});import _l from"os";var Bo,Jt,Bi,Nr,Ur,Rr,$n=ie(()=>{Bo=(e,o)=>{if(!e)return"";let t=/\x1B\[[0-?]*[ -/]*[@-~]/g,n=e.split(`
|
|
11
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 m=l.split(/(\s+)/),d="",u=0,a=l.match(/^(\s*)/),f=a?a[1]:"";m.forEach((p,h)=>{if(p.length===0)return;let T=r(p);if(u+T>o)if(d.trim().length>0)i.push(d.trimEnd()),d=f+p,u=r(d);else if(t.test(p))i.push(p),d=f,u=r(d);else{let w=p;for(;r(w)>o&&o>10;)i.push(w.substring(0,o)),w=w.substring(o);d=w,u=r(d)}else d+=p,u+=T}),(d.trimEnd().length>0||d===f)&&i.push(d.trimEnd())}),i.join(`
|
|
12
12
|
`)},Jt=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()},Bi=(e,o=40)=>{if(e=e.replace(_l.homedir(),"~"),!e||e.length<=o)return e;let t=Math.floor((o-3)/2);return e.substring(0,t)+"..."+e.substring(e.length-t)},Nr=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}},Ur=(e,o)=>{let t=[],n=e.replace(/\r\n/g,`
|
|
13
13
|
`).replace(/\r/g,`
|
|
@@ -15,16 +15,16 @@ var Dl=Object.defineProperty;var ie=(e,o)=>()=>(e&&(o=e(e=0)),o);var Ss=(e,o)=>{
|
|
|
15
15
|
`).replace(/\r/g,`
|
|
16
16
|
`),r=p=>p.match(/^\s*/)[0],l=p=>{let h=p.split(`
|
|
17
17
|
`).filter(w=>w.trim()!=="");if(h.length===0)return"";let T=r(h[0]);for(let w of h){let E=r(w);E.length<T.length&&(T=E)}return T},c=(p,h,T="")=>{if(!p||h===void 0)return p;let w=J=>{let q=J.split(`
|
|
18
|
-
`).filter(ce=>ce.trim()!=="");if(q.length===0)return{char:" ",size:4};let le=q[0].match(/^\s*/)[0];if(le.includes(" "))return{char:" ",size:1};let U=q.map(ce=>ce.match(/^\s*/)[0].length).filter(ce=>ce>0);if(U.length===0)return{char:" ",size:le.length||4};let G=(ce,De)=>De?G(De,ce%De):ce;return{char:" ",size:U.reduce((ce,De)=>G(ce,De))||4}},E=w(h),k=w(p),D=l(h).length,_=(T.match(/^\s*/)||[""])[0].length,
|
|
19
|
-
`).map((J,q)=>{if(J.trim()===""&&q!==0)return"";let le=J.match(/^\s*/)[0].length/k.size,U=Math.max(0,le+A),G=U;if(q===0){let
|
|
18
|
+
`).filter(ce=>ce.trim()!=="");if(q.length===0)return{char:" ",size:4};let le=q[0].match(/^\s*/)[0];if(le.includes(" "))return{char:" ",size:1};let U=q.map(ce=>ce.match(/^\s*/)[0].length).filter(ce=>ce>0);if(U.length===0)return{char:" ",size:le.length||4};let G=(ce,De)=>De?G(De,ce%De):ce;return{char:" ",size:U.reduce((ce,De)=>G(ce,De))||4}},E=w(h),k=w(p),D=l(h).length,_=(T.match(/^\s*/)||[""])[0].length,F=(_+D)/E.size,I=l(p).length/k.size,A=F-I;return p.split(`
|
|
19
|
+
`).map((J,q)=>{if(J.trim()===""&&q!==0)return"";let le=J.match(/^\s*/)[0].length/k.size,U=Math.max(0,le+A),G=U;if(q===0){let Pe=_/E.size;G=Math.max(0,U-Pe)}return E.char.repeat(G*E.size)+J.trimStart()}).join(`
|
|
20
20
|
`)},m=n,d=[];for(let p of o){let h=i(p.replace||""),T=i(p.new||"");if(h===""&&T==="")continue;let w=h.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),E=null;if(h!==""&&m.includes(h))E=new RegExp(w,"g");else{let A=h.split(`
|
|
21
21
|
`).map(v=>v.trim()).filter(v=>v.length>0).map(v=>v.replace(/[.*+?^${}()|[\]\\]/g,"\\$&").replace(/\s+/g,"\\s*"));if(A.length>0){let v=A.join("\\s*");try{E=new RegExp(v,"g")}catch{E=new RegExp(w,"g")}}else E=new RegExp(w,"g")}let k=[...m.matchAll(E)];if(k.length===0){t.push({success:!1,error:`Block ${t.length+1}: Could not find match.`});continue}if(k.length>1){t.push({success:!1,error:`Block ${t.length+1}: Found ${k.length} matches (must be unique).`});continue}let D=k[0].index,_=k[0][0],K=m.lastIndexOf(`
|
|
22
|
-
`,D)+1,
|
|
23
|
-
`).map(
|
|
24
|
-
`,k)+1,K=a.substring(_,k),
|
|
22
|
+
`,D)+1,F=m.substring(K,D),I=c(T,_,F);d.push({startPos:D,firstMatchContent:_,finalReplacement:I,content_to_replace:h,content_to_add:T}),m=m.substring(0,D)+I+m.substring(D+_.length)}if(t.filter(p=>!p.success).length>0)return{content:e,results:t};let a=n,f=[];for(let p=0;p<d.length;p++){let h=d[p],T=h.content_to_replace.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),w=null;if(h.content_to_replace!==""&&a.includes(h.content_to_replace))w=new RegExp(T,"g");else{let G=h.content_to_replace.split(`
|
|
23
|
+
`).map(Pe=>Pe.trim()).filter(Pe=>Pe.length>0).map(Pe=>Pe.replace(/[.*+?^${}()|[\]\\]/g,"\\$&").replace(/\s+/g,"\\s*")).join("\\s*");try{w=new RegExp(G,"g")}catch{w=new RegExp(T,"g")}}let E=[...a.matchAll(w)],k=E[0].index,D=E[0][0],_=a.lastIndexOf(`
|
|
24
|
+
`,k)+1,K=a.substring(_,k),F=c(h.content_to_add,D,K),I=a.split(`
|
|
25
25
|
`),A=a.substring(0,k).split(`
|
|
26
26
|
`).length,v=[];for(let U=Math.max(0,A-4);U<A-1;U++)v.push({num:U+1,text:I[U]});let J=D.split(`
|
|
27
|
-
`),q=[],le=A+J.length-1;for(let U=le;U<Math.min(I.length,le+3);U++)q.push({num:U+1,text:I[U]});f.push({success:!0,oldContent:D,newContent:
|
|
27
|
+
`),q=[],le=A+J.length-1;for(let U=le;U<Math.min(I.length,le+3);U++)q.push({num:U+1,text:I[U]});f.push({success:!0,oldContent:D,newContent:F,originalStartLine:A,contextBefore:v,contextAfter:q}),a=a.substring(0,k)+F+a.substring(k+D.length)}return{content:a,results:f}},Rr=(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]
|
|
28
28
|
`,c="\u2550".repeat(88),m=0;return t.forEach((d,u)=>{if(!d.success)return;if(u===0)for(m=Math.max(0,d.originalStartLine-4);m<d.originalStartLine-1;)l+=`[UI_CONTEXT] ${m+1} |${r[m]||""}
|
|
29
29
|
`,m++;else{let T=t[u-1],w=T.originalStartLine+T.oldContent.split(`
|
|
30
30
|
`).length-1;if(d.originalStartLine-w-1>=n){let k=Math.min(r.length,m+3);for(;m<k;)l+=`[UI_CONTEXT] ${m+1} |${r[m]||""}
|
|
@@ -55,10 +55,10 @@ var Dl=Object.defineProperty;var ie=(e,o)=>()=>(e&&(o=e(e=0)),o);var Ss=(e,o)=>{
|
|
|
55
55
|
`).replace(/\\\n/g,`
|
|
56
56
|
`).replace(/\\$/,""),t-6).split(`
|
|
57
57
|
`).map((a,f)=>b.createElement(W,{key:f,flexDirection:"row",width:"100%"},b.createElement(W,{flexShrink:0,width:2},b.createElement(Z,{bold:!0,color:"white"},f===0?"\u276F":" ")),b.createElement(W,{flexGrow:1,marginLeft:1},b.createElement(gn,{text:a,color:e.color||"white"}))))):e.role==="think"?b.createElement(W,{flexDirection:"column",marginTop:0,marginBottom:0,paddingX:1,width:"100%"},e.isStreaming&&!e.duration?b.createElement(Z,{bold:!0,color:"white"},"\u2727 Thinking..."):b.createElement(Z,{bold:!0,color:"white"},"\u2726 Thought",e.duration?b.createElement(Z,{color:"gray"}," for ",b.createElement(Z,{bold:!0,color:"cyan"},Ri(e.duration))):""),b.createElement(W,{borderStyle:"single",borderLeft:!0,borderRight:!1,borderTop:!1,borderBottom:!1,paddingLeft:2,paddingTop:1,paddingBottom:1,flexDirection:"column",width:"100%"},Wl(u,t))):b.createElement(W,{flexDirection:"column",paddingX:1,marginTop:0,width:"100%"},b.createElement(Ui,{text:u.replace(/ \|\n\n/g,` |
|
|
58
|
-
`),columns:t}),e.memoryUpdated&&b.createElement(W,{marginTop:1,width:"100%"},b.createElement(Z,{color:"yellow",italic:!0},"\u2728 [Memory Updated]")),e.role==="agent"&&e.workedDuration?b.createElement(W,{marginTop:1,marginBottom:2,width:"100%"},b.createElement(Z,null,"["),b.createElement(Z,{color:"gray"},"\u26A1 Worked for ",b.createElement(Z,{bold:!0,color:"cyan"},Ri(e.workedDuration))),b.createElement(Z,null,"]")):null))}),Xl=b.memo(({messages:e,showFullThinking:o,columns:t=80})=>b.createElement(W,{flexDirection:"column",width:"100%"},e.map((n,i)=>b.createElement(Is,{key:n.id||i,msg:n,showFullThinking:o,columns:t})))),Wi=Xl});import Ye from"react";import{Box as en,Text as
|
|
58
|
+
`),columns:t}),e.memoryUpdated&&b.createElement(W,{marginTop:1,width:"100%"},b.createElement(Z,{color:"yellow",italic:!0},"\u2728 [Memory Updated]")),e.role==="agent"&&e.workedDuration?b.createElement(W,{marginTop:1,marginBottom:2,width:"100%"},b.createElement(Z,null,"["),b.createElement(Z,{color:"gray"},"\u26A1 Worked for ",b.createElement(Z,{bold:!0,color:"cyan"},Ri(e.workedDuration))),b.createElement(Z,null,"]")):null))}),Xl=b.memo(({messages:e,showFullThinking:o,columns:t=80})=>b.createElement(W,{flexDirection:"column",width:"100%"},e.map((n,i)=>b.createElement(Is,{key:n.id||i,msg:n,showFullThinking:o,columns:t})))),Wi=Xl});import Ye from"react";import{Box as en,Text as Pt}from"ink";var Kl,Hi,ji=ie(()=>{$n();Kl=Ye.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 m=e==="Flux"?"yellow":"cyan",d=e==="Flux"?"\u26A1":"\u{1F30A}",u=256e3;return(c==="DeepSeek"||c==="Google"&&l==="Paid")&&(u=4e5),Ye.createElement(en,{borderStyle:"round",borderColor:"gray",flexDirection:"row",justifyContent:"space-between",paddingX:1,width:"100%"},Ye.createElement(en,null,Ye.createElement(en,{marginRight:1},Ye.createElement(Pt,{color:m,bold:!0},d," ",e.toUpperCase())),Ye.createElement(Pt,{color:"gray",dimColor:!0},"\u2503 "),Ye.createElement(en,{marginX:1},Ye.createElement(Pt,{color:"magenta"},"\u{1F9E0} ",o)),Ye.createElement(Pt,{color:"gray",dimColor:!0},"\u2503 "),Ye.createElement(en,{marginX:1},Ye.createElement(Pt,{color:"gray"},"MEM: "),Ye.createElement(Pt,{color:r?"green":"red",bold:!0},r?"ON":"OFF"))),Ye.createElement(en,{flexGrow:1,justifyContent:"center",paddingX:2},Ye.createElement(Pt,null,"\u{1F4C1}"),Ye.createElement(Pt,{color:"gray",italic:!0}," ",Bi(process.cwd(),35))),Ye.createElement(en,null,Ye.createElement(Pt,{color:"gray",dimColor:!0},"\u2503 "),Ye.createElement(en,{marginX:1},Ye.createElement(Pt,null,"\u2728"),Ye.createElement(Pt,{color:"blue"}," ",Jt(n)," ",Ye.createElement(Pt,{dimColor:!0},"(",(t/u*100).toFixed(0),"%)"))),Ye.createElement(Pt,{color:"gray",dimColor:!0},"\u2503 "),Ye.createElement(en,{marginLeft:1},Ye.createElement(Pt,null,"\u{1F194}"),Ye.createElement(Pt,{color:"gray",dimColor:!0,italic:!0}," ",i),(l==="Custom"||l==="Paid")&&Ye.createElement(Pt,{color:"gray",dimColor:!0}," | ",Ye.createElement(Pt,{color:"green",bold:!0},"PAID")))))}),Hi=Kl});import Lo from"react";import{Box as Gn,Text as Yr}from"ink";import ql from"ink-select-input";function io({title:e,subtitle:o,items:t,onSelect:n}){return Lo.createElement(Gn,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,marginTop:1,flexShrink:0,width:"100%"},Lo.createElement(Gn,{paddingX:1,paddingY:0,marginBottom:o?0:1},Lo.createElement(Yr,{color:"magenta",bold:!0},"\u{1F527} ",typeof e=="string"?e.toUpperCase():e)),o&&Lo.createElement(Gn,{paddingX:1,marginBottom:1},Lo.createElement(Yr,{color:"yellow",dimColor:!0,italic:!0}," ",o)),Lo.createElement(Gn,{flexDirection:"column",width:"100%"},Lo.createElement(ql,{items:t,onSelect:n,itemComponent:Vl,indicatorComponent:()=>null})),Lo.createElement(Gn,{paddingX:1,marginTop:1},Lo.createElement(Yr,{color:"gray",dimColor:!0,italic:!0},"(Arrows to select \u2022 Enter to confirm)")))}var Vl,Gi=ie(()=>{Vl=({label:e,isSelected:o})=>{let t=e==="Cancel"||e==="Back"||e.toLowerCase().includes("exit")||e.toLowerCase().includes("back");return Lo.createElement(Gn,{marginTop:t?1:0,backgroundColor:o?"#2a2a2a":void 0,paddingX:1,width:"100%"},Lo.createElement(Yr,{color:o?"cyan":"white",bold:o},o?"\u276F ":" ",e))}});var oe,Qt=ie(()=>{oe=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,m=-1,d=t;for(;d<e.length;){let a=e.indexOf(l,d);if(a===-1)break;let f=0;for(let w=a-1;w>=0&&e[w]==="\\";w--)f++;if(f%2!==0){d=a+1;continue}let p=e.substring(a+1),h=p.trim(),T=h===""||/^,\s*\w+\s*=/.test(h)||h.startsWith(")")&&(h.length===1||/^\)\s*([,\]\s]|tool:)/i.test(h));if(T&&p.startsWith(`
|
|
59
59
|
`)){let w=h.split(`
|
|
60
60
|
`)[0];if(!w.includes("=")&&!w.includes(")")){d=a+1;continue}}if(T){m=a;break}d=a+1}m!==-1?(r=e.substring(c,m),t=m+1):(r=e.substring(c),t=e.length);let u=i.toLowerCase().includes("path")||["dest","source","to","from"].includes(i.toLowerCase());r=r.replace(/\\(.)/g,(a,f)=>{switch(f){case"n":return`
|
|
61
|
-
`;case"r":return"\r";case"t":return" ";case"\\":return"\\";default:return f===l?l:a}})}else if(t<e.length&&e[t]==="["){let l=0,c=null,m=t,d=-1;for(let u=t;u<e.length;u++){let a=e[u];if(c&&a===c){let f=0;for(let p=u-1;p>=0&&e[p]==="\\";p--)f++;f%2===0&&(c=null)}else!c&&(a==='"'||a==="'"||a==="`")&&(c=a);if(!c&&(a==="["?l++:a==="]"&&l--,l===0)){d=u;break}}if(d!==-1){r=e.substring(m,d+1),t=d+1;try{let u=r.trim();u.startsWith("'")||u.includes("'")}catch{}}else r=e.substring(m),t=e.length}else{let l=e.substring(t),c=l.match(/,\s*\w+\s*=|(?:\s*\)\s*(?:$|\]))/);if(c){let m=c.index;r=l.substring(0,m).trim(),t+=m}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 zl}from"child_process";var gr,
|
|
61
|
+
`;case"r":return"\r";case"t":return" ";case"\\":return"\\";default:return f===l?l:a}})}else if(t<e.length&&e[t]==="["){let l=0,c=null,m=t,d=-1;for(let u=t;u<e.length;u++){let a=e[u];if(c&&a===c){let f=0;for(let p=u-1;p>=0&&e[p]==="\\";p--)f++;f%2===0&&(c=null)}else!c&&(a==='"'||a==="'"||a==="`")&&(c=a);if(!c&&(a==="["?l++:a==="]"&&l--,l===0)){d=u;break}}if(d!==-1){r=e.substring(m,d+1),t=d+1;try{let u=r.trim();u.startsWith("'")||u.includes("'")}catch{}}else r=e.substring(m),t=e.length}else{let l=e.substring(t),c=l.match(/,\s*\w+\s*=|(?:\s*\)\s*(?:$|\]))/);if(c){let m=c.index;r=l.substring(0,m).trim(),t+=m}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 zl}from"child_process";var gr,Xn,Xi,Ms=ie(async()=>{await xr();gr=null,Xn=()=>{if(process.platform!=="win32")return!1;if(gr!==null)return gr;try{zl('powershell.exe -NoProfile -Command "exit"',{stdio:"ignore"}),gr=!0}catch{gr=!1}return gr},Xi=(e,o,t,n)=>`
|
|
62
62
|
-- TOOL DEFINITIONS --
|
|
63
63
|
Access to internal tools. MUST use the exact syntax on a new line: [tool:functions.ToolName(args)]
|
|
64
64
|
MANDATORY TOOL POLICY:
|
|
@@ -80,7 +80,7 @@ ${e==="Flux"?`- PROJECT TOOLS (path = relative to CWD, path separator: '/') -
|
|
|
80
80
|
3. [tool:functions.PatchFile(path="...", replaceContent1="exact string", newContent1="...", ...MAX 8)]. Surgical Patch. **Multiple patch on same file/path? Use replaceContent2, newContent2 etc >>> multiple spams**. Unsure? ReadFile > guessing.
|
|
81
81
|
4. [tool:functions.WriteFile(path="...", content="...")]. Creates/Overwrites. File Exist? PatchFile >>> WriteFile. Verify Imports
|
|
82
82
|
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"?
|
|
83
|
+
6. [tool:functions.Run(command="...")]. Runs ${o==="Windows"?Xn()?`${Pn?"Interactive ":""}WINDOWS POWERSHELL ONLY`:`${Pn?"Interactive ":""}WINDOWS CMD`:`${Pn?"Interactive ":""}BASH`} command. Destructive/Irreversible ops -> Ask user
|
|
84
84
|
7. [tool:functions.GenerateImage(path="... png", prompt="detailed", ratio="16:9, 9:16, 1:1")]. Usage: Mockups, PDF thumbnails, any visual content
|
|
85
85
|
8. [tool:functions.WritePDF(path="...", content="...", orientation="...")]. PROACTIVE A4 PAGE BREAKS MUST IN CSS. HTML/CSS for PREMIUM layout (100vh/vw)
|
|
86
86
|
9. [tool:functions.WriteDoc(path="...", content="...")]. A4 Word document
|
|
@@ -92,7 +92,7 @@ ${e==="Flux"?`- PROJECT TOOLS (path = relative to CWD, path separator: '/') -
|
|
|
92
92
|
- File structure: Real newlines for code formatting`.trim():"\n- FILE TOOLS ARE NOT AVAILABLE IN FLOW (Tell user,` /mode flux` if needed)".trim()}
|
|
93
93
|
|
|
94
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,
|
|
95
|
+
- MAX Tool call stack: STRICTLY 3 per turn`.trim()});import{spawn as Os}from"child_process";var Hr,Pn,jr,Ct,To,So,Ki,qi,Ls,As,xr=ie(async()=>{Qt();await Ms();Hr=null;try{let e=await import("node-pty");Hr=e.default||e}catch{}Pn=!!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,To=!1,So=e=>{try{Ct&&(To&&typeof Ct.write=="function"?Ct.write(e):Ct.stdin&&Ct.stdin.writable&&Ct.stdin.write(e))}catch{}},Ki=()=>{if(Ct){try{To&&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,To=!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&&Xn()){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&&Xn()){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&&Xn()){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&&Xn()){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,To=!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.
|
|
96
96
|
|
|
97
97
|
${E}`),500))}}),p.onExit(({exitCode:w})=>{if(T)return;Ct=null;let E=(h||"").replace(/\r\n/g,`
|
|
98
98
|
`).replace(/\r/g,`
|
|
@@ -102,7 +102,7 @@ ${E}`),500))}}),p.onExit(({exitCode:w})=>{if(T)return;Ct=null;let E=(h||"").repl
|
|
|
102
102
|
|
|
103
103
|
${k}`:`SUCCESS: Command [${t}] completed.
|
|
104
104
|
|
|
105
|
-
${k}`)}),!0}catch(p){return i&&d&&p.code==="ENOENT"?!1:(As(c,u,t,l,n,d),!0)}else return As(c,u,t,l,n,d),!0};i&&m(!0)||m(!1)})},As=(e,o,t,n,i,r=!0)=>{let l=process.platform==="win32",c=l?r?"powershell.exe":"cmd.exe":process.env.SHELL||"bash",d=l?Os(c,l?r?["-NoProfile","-Command",o]:["/c",o]:["-c",o],{cwd:process.cwd(),env:{...process.env,...n}}):Os(o,{shell:!0,cwd:process.cwd(),env:{...process.env,CI:"false",TERM:"xterm-256color",FORCE_COLOR:"1",...n}});Ct=d,
|
|
105
|
+
${k}`)}),!0}catch(p){return i&&d&&p.code==="ENOENT"?!1:(As(c,u,t,l,n,d),!0)}else return As(c,u,t,l,n,d),!0};i&&m(!0)||m(!1)})},As=(e,o,t,n,i,r=!0)=>{let l=process.platform==="win32",c=l?r?"powershell.exe":"cmd.exe":process.env.SHELL||"bash",d=l?Os(c,l?r?["-NoProfile","-Command",o]:["/c",o]:["-c",o],{cwd:process.cwd(),env:{...process.env,...n}}):Os(o,{shell:!0,cwd:process.cwd(),env:{...process.env,CI:"false",TERM:"xterm-256color",FORCE_COLOR:"1",...n}});Ct=d,To=!1,d.stdin&&d.stdin.on("error",()=>{Ct=null});let u="",a="",f=!1;d.stdout.on("data",p=>{if(!f){let h=p.toString();u+=h,i&&i(h);let T=jr(u);/(?: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(T)&&(f=!0,setTimeout(()=>e(`SUCCESS: Dev server started successfully in background.
|
|
106
106
|
|
|
107
107
|
${T}`),500))}}),d.stderr.on("data",p=>{if(!f){let h=p.toString();a+=h,i&&i(h)}}),d.on("close",p=>{if(f)return;Ct=null;let h=[];u&&h.push(`STDOUT:
|
|
108
108
|
${u}`),a&&h.push(`STDERR:
|
|
@@ -114,7 +114,7 @@ ${a}`),p!==0&&h.push(`EXIT CODE: ${p}`);let T=h.join(`
|
|
|
114
114
|
|
|
115
115
|
${w}`:`SUCCESS: Command [${t}] completed.
|
|
116
116
|
|
|
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 Se,{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[]}},_=tn[a].id,K=D(_);Jl((I,A)=>{if(T){A.escape&&w(null);return}if(d==="categories")A.upArrow?f(v=>(v-1+tn.length)%tn.length):A.downArrow?f(v=>(v+1)%tn.length):A.return||A.rightArrow?tn[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];P(v)}}});let P=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 Se.createElement(At,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},Se.createElement(At,{paddingX:1,paddingY:0,marginBottom:1,borderStyle:"single",borderColor:"magenta",width:"100%"},Se.createElement(Rt,{color:"magenta",bold:!0},"\u{1F527} SYSTEM CONFIGURATION")),Se.createElement(At,{flexDirection:"row",width:"100%",minHeight:8},Se.createElement(At,{flexDirection:"column",width:"30%",borderStyle:"round",borderColor:d==="categories"?"cyan":"gray",padding:1},Se.createElement(At,{marginBottom:1},Se.createElement(Rt,{color:d==="categories"?"cyan":"white",bold:!0,underline:!0},"CATEGORIES")),tn.map((I,A)=>{let v=a===A,J=I.id==="exit";return Se.createElement(At,{key:I.id,marginTop:J?1:0,backgroundColor:v?d==="categories"?"#2a2a2a":"#1e1e1e":void 0,paddingX:1},Se.createElement(Rt,{color:v?d==="categories"?"cyan":"yellow":"white",bold:v},v?"\u276F ":" ",I.label))})),Se.createElement(At,{flexDirection:"column",width:"70%",borderStyle:"round",borderColor:d==="items"?"cyan":"gray",padding:1,marginLeft:1},Se.createElement(At,{marginBottom:1},Se.createElement(Rt,{color:d==="items"?"cyan":"white",bold:!0,underline:!0},tn[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),Fe=_==="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(Se.createElement(At,{key:`sec-hdr-${ce.section}`,marginTop:A.length>0?1:0,marginBottom:0,paddingX:1},Se.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(Se.createElement(At,{key:ce.value,flexDirection:"column"},Se.createElement(At,{backgroundColor:nt&&!_e?"#2a2a2a":void 0,paddingX:2},Se.createElement(Rt,{color:nt?"cyan":"white",bold:nt},nt?"\u276F ":" ",ce.label),!Je&&Se.createElement(Se.Fragment,null,Se.createElement(Rt,{color:"gray",dimColor:!0},Ve),Se.createElement(Rt,{color:ze(ce),bold:!0},ce.value==="aiProvider"?ce.status:`[ ${ce.status} ]`))),Je&&!_e&&ce.status!=="None"&&Se.createElement(At,{paddingX:4,marginBottom:1},Se.createElement(Rt,{color:"gray",dimColor:!0},"\u21B3 ",ce.status)),_e&&Se.createElement(At,{flexDirection:"column",marginLeft:4,marginBottom:1},Se.createElement(At,{paddingX:1,borderStyle:"single",borderColor:"cyan",flexDirection:"row"},Se.createElement(Rt,{color:"cyan",bold:!0},"> "," "),Se.createElement(Ql,{value:E,onChange:k,onSubmit:fe=>{let po={...e,[T]:fe.trim(),sandboxPreset:"Custom"};o(po),r({systemSettings:po,apiTier:t,quotas:l}),w(null)}})),Se.createElement(Rt,{color:"gray",dimColor:!0,italic:!0}," Comma separated \u2022 Press Enter to save, Esc to cancel"))))}),_==="other"&&A.push(Se.createElement(At,{key:"pty-notice",marginTop:4,paddingX:1},Se.createElement(Rt,{color:Fn?"green":"yellow"},Fn?"\u2713 Advance Interactive Terminal Supported":"\u26A0 Interactive Terminal is Limited"))),Fe&&A.push(Se.createElement(At,{key:"conflict-warning",marginTop:1,paddingX:1},Se.createElement(Rt,{color:"red",dimColor:!0,italic:!0},"* Conflicting commands will be ignored and defaulted to highest priority"))),A})():Se.createElement(At,{paddingX:1},Se.createElement(Rt,{color:"gray",italic:!0},tn[a].desc)))),Se.createElement(At,{paddingX:1,marginTop:1,flexDirection:"row",justifyContent:"space-between"},Se.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"&&Se.createElement(Rt,{color:"gray",dimColor:!0},tn[a].desc)))}var tn,Vi,Ds,zi=ie(async()=>{await xr();tn=[{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 Xn,Text as Gr}from"ink";import ec from"ink-text-input";function Fs({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(Xn,{borderStyle:"round",borderColor:"gray",padding:0,marginTop:1,flexShrink:0,flexDirection:"column",width:"100%"},Do.createElement(Xn,{paddingX:1,marginBottom:1},Do.createElement(Gr,{color:"magenta",bold:!0},"\u{1F464} DEVELOPER PROFILE CONFIGURATION")),Do.createElement(Xn,{paddingX:1,flexDirection:"column"},Do.createElement(Xn,null,Do.createElement(Gr,{color:"cyan",bold:!0},d[n].label),Do.createElement(ec,{value:r,onChange:l,onSubmit:u})),Do.createElement(Xn,{marginTop:1},Do.createElement(Gr,{color:"gray",dimColor:!0,italic:!0},"Step ",n+1," of ",d.length))),Do.createElement(Xn,{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 Ps}from"react";import{Box as So,Text as on,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]=Ps(!1),[r,l]=Ps(""),[c,m]=Ps(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(So,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},dt.createElement(So,{paddingX:1},dt.createElement(on,{color:"cyan",bold:!0},"\u{1F4AC} SUGGEST SOMETHING ELSE")),dt.createElement(So,{marginTop:1,paddingX:1},dt.createElement(on,{italic:!0,color:"gray"},"Replying to: ",e)),dt.createElement(So,{marginTop:1,paddingX:1,flexDirection:"row"},dt.createElement(on,{color:"cyan",bold:!0},"\u{1F4A0} "),dt.createElement(oc,{value:r,onChange:l,onSubmit:()=>t(r)})),dt.createElement(So,{marginTop:1,paddingX:1,marginBottom:1},dt.createElement(on,{color:"gray",dimColor:!0,italic:!0},"(Press Enter to send)"))):dt.createElement(So,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},dt.createElement(So,{paddingX:1,marginBottom:1},dt.createElement(on,{color:"cyan",bold:!0},"\u{1F4AC} AGENT REQUEST: ACTION REQUIRED")),dt.createElement(So,{paddingX:1,marginBottom:1},dt.createElement(on,{bold:!0,color:"white"},e)),dt.createElement(So,{flexDirection:"column",width:"100%"},d.map((a,f)=>{let p=f===c;return dt.createElement(So,{key:a.id,flexDirection:"column",width:"100%",backgroundColor:p?"#2a2a2a":void 0,paddingX:1,marginBottom:f===d.length-1?0:1},dt.createElement(on,{color:p?"cyan":"white",bold:p},p?"\u276F ":" ",a.label),a.description&&dt.createElement(So,{marginLeft:4},dt.createElement(on,{color:"gray",italic:!0,dimColor:!0},a.description)))})),dt.createElement(So,{paddingX:1,marginTop:1,marginBottom:1},dt.createElement(on,{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:()=>Pn,HISTORY_FILE:()=>Bn,LEDGER_FILE:()=>nn,LOGS_DIR:()=>bo,MEMORIES_FILE:()=>Pt,PATHS_FILE:()=>zr,SECRET_DIR:()=>eo,SETTINGS_FILE:()=>Zt,TEMP_MEM_CHAT_FILE:()=>_o,TEMP_MEM_FILE:()=>uo,USAGE_FILE:()=>Wt});import ic from"os";import Eo from"path";import oa from"fs";import na from"crypto";var Pn,Zt,ra,Vr,bo,eo,Bn,Wt,Pt,uo,_o,yn,nn,zr,to=ie(()=>{Pn=Eo.join(ic.homedir(),".fluxflow"),Zt=Eo.join(Pn,"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||Pn,bo=Eo.join(Vr,"logs"),eo=Eo.join(Vr,"secret"),Bn=Eo.join(eo,"history.json"),Wt=Eo.join(Pn,"usage.json"),Pt=Eo.join(eo,"memories.json"),uo=Eo.join(eo,"memory-temp.json"),_o=Eo.join(eo,"temp-memory-chat.json"),yn=Eo.join(Vr,"backups"),nn=Eo.join(eo,"ledger.json"),zr=Eo.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)=>`
|
|
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[]}},_=tn[a].id,K=D(_);Jl((I,A)=>{if(T){A.escape&&w(null);return}if(d==="categories")A.upArrow?f(v=>(v-1+tn.length)%tn.length):A.downArrow?f(v=>(v+1)%tn.length):A.return||A.rightArrow?tn[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")),tn.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},tn[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 po={...e,[T]:fe.trim(),sandboxPreset:"Custom"};o(po),r({systemSettings:po,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:Pn?"green":"yellow"},Pn?"\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},tn[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},tn[a].desc)))}var tn,Vi,Ds,zi=ie(async()=>{await xr();tn=[{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 Kn,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(Kn,{borderStyle:"round",borderColor:"gray",padding:0,marginTop:1,flexShrink:0,flexDirection:"column",width:"100%"},Do.createElement(Kn,{paddingX:1,marginBottom:1},Do.createElement(Gr,{color:"magenta",bold:!0},"\u{1F464} DEVELOPER PROFILE CONFIGURATION")),Do.createElement(Kn,{paddingX:1,flexDirection:"column"},Do.createElement(Kn,null,Do.createElement(Gr,{color:"cyan",bold:!0},d[n].label),Do.createElement(ec,{value:r,onChange:l,onSubmit:u})),Do.createElement(Kn,{marginTop:1},Do.createElement(Gr,{color:"gray",dimColor:!0,italic:!0},"Step ",n+1," of ",d.length))),Do.createElement(Kn,{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 Eo,Text as on,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(Eo,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},dt.createElement(Eo,{paddingX:1},dt.createElement(on,{color:"cyan",bold:!0},"\u{1F4AC} SUGGEST SOMETHING ELSE")),dt.createElement(Eo,{marginTop:1,paddingX:1},dt.createElement(on,{italic:!0,color:"gray"},"Replying to: ",e)),dt.createElement(Eo,{marginTop:1,paddingX:1,flexDirection:"row"},dt.createElement(on,{color:"cyan",bold:!0},"\u{1F4A0} "),dt.createElement(oc,{value:r,onChange:l,onSubmit:()=>t(r)})),dt.createElement(Eo,{marginTop:1,paddingX:1,marginBottom:1},dt.createElement(on,{color:"gray",dimColor:!0,italic:!0},"(Press Enter to send)"))):dt.createElement(Eo,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},dt.createElement(Eo,{paddingX:1,marginBottom:1},dt.createElement(on,{color:"cyan",bold:!0},"\u{1F4AC} AGENT REQUEST: ACTION REQUIRED")),dt.createElement(Eo,{paddingX:1,marginBottom:1},dt.createElement(on,{bold:!0,color:"white"},e)),dt.createElement(Eo,{flexDirection:"column",width:"100%"},d.map((a,f)=>{let p=f===c;return dt.createElement(Eo,{key:a.id,flexDirection:"column",width:"100%",backgroundColor:p?"#2a2a2a":void 0,paddingX:1,marginBottom:f===d.length-1?0:1},dt.createElement(on,{color:p?"cyan":"white",bold:p},p?"\u276F ":" ",a.label),a.description&&dt.createElement(Eo,{marginLeft:4},dt.createElement(on,{color:"gray",italic:!0,dimColor:!0},a.description)))})),dt.createElement(Eo,{paddingX:1,marginTop:1,marginBottom:1},dt.createElement(on,{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:()=>Fn,HISTORY_FILE:()=>Bn,LEDGER_FILE:()=>nn,LOGS_DIR:()=>Co,MEMORIES_FILE:()=>Ft,PATHS_FILE:()=>zr,SECRET_DIR:()=>eo,SETTINGS_FILE:()=>Zt,TEMP_MEM_CHAT_FILE:()=>_o,TEMP_MEM_FILE:()=>uo,USAGE_FILE:()=>Wt});import ic from"os";import bo from"path";import oa from"fs";import na from"crypto";var Fn,Zt,ra,Vr,Co,eo,Bn,Wt,Ft,uo,_o,yn,nn,zr,to=ie(()=>{Fn=bo.join(ic.homedir(),".fluxflow"),Zt=bo.join(Fn,"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||Fn,Co=bo.join(Vr,"logs"),eo=bo.join(Vr,"secret"),Bn=bo.join(eo,"history.json"),Wt=bo.join(Fn,"usage.json"),Ft=bo.join(eo,"memories.json"),uo=bo.join(eo,"memory-temp.json"),_o=bo.join(eo,"temp-memory-chat.json"),yn=bo.join(Vr,"backups"),nn=bo.join(eo,"ledger.json"),zr=bo.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)=>`
|
|
118
118
|
Your tool syntax is: '[tool:functions.ToolName(args...)]'
|
|
119
119
|
|
|
120
120
|
-- CHAT MANAGEMENT TOOLS (MUST CALL THESE 2 TOOLS ALWAYS) --
|
|
@@ -214,6 +214,10 @@ Check these first; These Files > Training Data. Safety rules apply
|
|
|
214
214
|
Identity: Flux Flow (by Kushal Roy Chowdhury). Conversational, Sassy${t==="Flux"?", Respectful":", Friendly, Humorous, Sarcastic"}, CLI Agent
|
|
215
215
|
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
216
|
|
|
217
|
+
-- AGENT LOOP RULES (PRIORITY: HIGH) --
|
|
218
|
+
- **MANDATORY: MUST END WITH [turn: finish] to END AGENT LOOP WHEN COMPLETED**
|
|
219
|
+
- Tool Called? No post tool chat in that turn
|
|
220
|
+
|
|
217
221
|
-- MARKERS --
|
|
218
222
|
- TOOL SYSTEM: [TOOL RESULT] (system priority)
|
|
219
223
|
- SYSTEM NOTIFICATION: [SYSTEM], [METADATA] in user turn
|
|
@@ -278,23 +282,23 @@ ${a}`}catch(c){if(i=c,l&&await l.close(),r<n){let m=Math.pow(2,r)*1e3;await new
|
|
|
278
282
|
|
|
279
283
|
${u}${d.length>3e4?`
|
|
280
284
|
|
|
281
|
-
[TRUNCATED AT 30K CHARS]`:""}`}catch(c){if(i=c,l&&await l.close(),r<n){let m=Math.pow(2,r)*1e3;await new Promise(d=>setTimeout(d,m))}}}return`ERROR: Scrape failed after ${n+1} attempts. Last error: ${i.message}`}});var kc,Js,Oa=ie(()=>{vo();to();kc=4*(1024*2),Js=async(e,o={})=>{let t=u=>{let a=new RegExp(`${u}\\s*[:=]\\s*(["'])(.*?)\\1(?=\\s*[,)]|\\s+\\w+\\s*[:=]|$)`,"s"),f=e.match(a);if(f)return f[2].trim();let p=new RegExp(`${u}\\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"),m=t("id"),d=t("chat-id")||o.chatId||o.sessionId||"default-session";if(n==="temp"){if(!r)return"ERROR: Missing 'content' for temp memory.";let u=we(uo,{});u[d]||(u[d]=[]),u[d].push(r),ke(uo,u);let a=u[d].reduce((f,p)=>f+p.length,0);return`SUCCESS: Temporary context saved for session [${d}]. (Size: ${a} chars)`}if(n==="user"){let u=we(
|
|
285
|
+
[TRUNCATED AT 30K CHARS]`:""}`}catch(c){if(i=c,l&&await l.close(),r<n){let m=Math.pow(2,r)*1e3;await new Promise(d=>setTimeout(d,m))}}}return`ERROR: Scrape failed after ${n+1} attempts. Last error: ${i.message}`}});var kc,Js,Oa=ie(()=>{vo();to();kc=4*(1024*2),Js=async(e,o={})=>{let t=u=>{let a=new RegExp(`${u}\\s*[:=]\\s*(["'])(.*?)\\1(?=\\s*[,)]|\\s+\\w+\\s*[:=]|$)`,"s"),f=e.match(a);if(f)return f[2].trim();let p=new RegExp(`${u}\\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"),m=t("id"),d=t("chat-id")||o.chatId||o.sessionId||"default-session";if(n==="temp"){if(!r)return"ERROR: Missing 'content' for temp memory.";let u=we(uo,{});u[d]||(u[d]=[]),u[d].push(r),ke(uo,u);let a=u[d].reduce((f,p)=>f+p.length,0);return`SUCCESS: Temporary context saved for session [${d}]. (Size: ${a} chars)`}if(n==="user"){let u=we(Ft,[]).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,f=`${a.getDate()}/${a.getMonth()+1}/${a.getFullYear()}`,p=r.includes("[Saved on:")?r:`${r.trim()} [Saved on: ${f}]`,h=kc,T=u.reduce((D,_)=>D+(_.memory?.length||0),0);for(;u.length>0&&T+p.length>h;){let D=u.shift();T-=D.memory?.length||0}let w=t("score"),E=w?parseFloat(w):.5,k={id:`mem-${Date.now().toString(36)}`,memory:p,score:Math.min(2,isNaN(E)?.5:E)};return u.push(k),ke(Ft,u),`SUCCESS: Memory added with ID [${k.id}] and score [${k.score}]. (Vault Size: ${T+p.length} chars)`}if(i==="update"){let a=m||c,f=l||r;if(!a||!f)return"ERROR: Missing 'id' or content for update.";let p=u.findIndex(E=>E.id===a);if(p===-1)return`ERROR: Memory ID [${a}] not found.`;let h=new Date,T=`${h.getDate()}/${h.getMonth()+1}/${h.getFullYear()}`,w=f.includes("[Saved on:")?f:`${f.trim()} [Saved on: ${T}]`;return u[p].memory=w,ke(Ft,u),`SUCCESS: Memory [${a}] updated.`}if(i==="delete"){let a=m||r;if(!a)return"ERROR: Missing 'id' for deletion.";let f=u.length,p=u.filter(h=>h.id!==a);return p.length===f?`ERROR: Memory ID [${a}] not found.`:(ke(Ft,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 Qs,Aa=ie(()=>{Er();Qt();Qs=async(e,o={})=>{let t=oe(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 ha(n,t),`SUCCESS: Chat title updated to [${t}] for session [${n}].`}catch(i){return`ERROR: Failed to update chat title: ${i.message}`}}});import rs from"fs";import La from"path";var Zs,Da=ie(()=>{Qt();Zs=async(e,o={})=>{let{path:t,StartLine:n,EndLine:i,start_line:r,end_line:l,startLine:c,endLine:m}=oe(e),d=parseInt(n||r||c),u=parseInt(i||l||m),a=d||1,f=u||(d?d+800:800);if(!t)return'ERROR: Missing "path" argument for view_file.';let p=La.resolve(process.cwd(),t);try{if(!rs.existsSync(p))return`ERROR: File [${t}] does not exist.`;if(rs.statSync(p).isDirectory())return`ERROR: Path [${t}] is a directory. Use list_files instead.`;let T=La.extname(t).toLowerCase();if([".mp4",".mkv",".avi",".mov",".webm",".flv",".wmv",".mpeg",".mpg"].includes(T))return`ERROR: Unable to read. Type ${T.slice(1).toUpperCase()} not supported`;let E={".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(E[T]){if(!(o.isMultiModal!==!1))return`ERROR: Multimodality is not supported for the current model. Unable to load [${t}].`;let le=rs.readFileSync(p).toString("base64"),U=E[T];return{text:`[BINARY FILE]: ${t} (${U}) - Loaded as multimodal part.`,binaryPart:{inlineData:{data:le,mimeType:U}}}}let k=rs.readFileSync(p,"utf8");k.startsWith("\uFEFF")&&(k=k.slice(1)),k=k.replace(/\r\n/g,`
|
|
282
286
|
`).replace(/\r/g,`
|
|
283
287
|
`);let D=k.split(`
|
|
284
|
-
`),_=D.length,K=Math.max(0,a-1),
|
|
288
|
+
`),_=D.length,K=Math.max(0,a-1),F=Math.min(_,f),I=D.slice(K,F),A=`File: [${t}] (Showing lines ${K+1}-${F} of ${_}).`,v=I.map((J,q)=>`${String(K+q+1).padStart(4)}: ${J}`).join(`
|
|
285
289
|
`);return`${A}
|
|
286
290
|
|
|
287
|
-
${v}`}catch(h){return`ERROR: Failed to read file [${t}]: ${h.message}`}}});import
|
|
291
|
+
${v}`}catch(h){return`ERROR: Failed to read file [${t}]: ${h.message}`}}});import qn from"fs";import va from"path";var ei,$a=ie(()=>{Qt();sn();ei=async(e,o={})=>{let{path:t,content:n}=oe(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,`
|
|
288
292
|
`).replace(/\r/g,`
|
|
289
|
-
`);let i=va.resolve(process.cwd(),t),r=va.dirname(i);try{await Et.recordFileChange(i);let l="";if(
|
|
290
|
-
${
|
|
293
|
+
`);let i=va.resolve(process.cwd(),t),r=va.dirname(i);try{await Et.recordFileChange(i);let l="";if(qn.existsSync(i))try{l=`Old File contents:
|
|
294
|
+
${qn.readFileSync(i,"utf8").split(/\r?\n/).map((k,D)=>`${D+1} | ${k}`).join(`
|
|
291
295
|
`)}
|
|
292
296
|
|
|
293
297
|
`}catch{l=`[Note: Could not read existing file for reversal reference]
|
|
294
298
|
|
|
295
|
-
`}
|
|
299
|
+
`}qn.existsSync(r)||qn.mkdirSync(r,{recursive:!0});let m=(w=>w.replace(/^```[\w]*\n?/,"").replace(/```\s*$/,"").replace(/\r\n/g,`
|
|
296
300
|
`).replace(/\r/g,`
|
|
297
|
-
`))(n),d=m.split(/\r?\n/).length,u=Buffer.byteLength(m,"utf8");
|
|
301
|
+
`))(n),d=m.split(/\r?\n/).length,u=Buffer.byteLength(m,"utf8");qn.writeFileSync(i,m,"utf8");let a=qn.readFileSync(i,"utf8"),f=Buffer.byteLength(a,"utf8"),p=a.split(/\r?\n/),h=p.length;if(f===0&&u>0)return a=null,`ERROR: CRITICAL FAILURE: Verification failed. File [${t}] is empty on disk despite success report!`;let T="";if(h<=200)T=p.join(`
|
|
298
302
|
`);else{let w=p.slice(0,100).join(`
|
|
299
303
|
`),E=p.slice(-100).join(`
|
|
300
304
|
`);T=`${w}
|
|
@@ -307,20 +311,20 @@ ${E}`}return a=null,`SUCCESS: File [${t}] saved.
|
|
|
307
311
|
${l}- Content Preview:
|
|
308
312
|
${T}
|
|
309
313
|
|
|
310
|
-
Check if Starting and Ending matches your write.`}catch(l){return`ERROR: Failed to write file [${t}]: ${l.message}`}}});import ti from"fs";import Ic from"path";var oi,
|
|
314
|
+
Check if Starting and Ending matches your write.`}catch(l){return`ERROR: Failed to write file [${t}]: ${l.message}`}}});import ti from"fs";import Ic from"path";var oi,Pa=ie(()=>{Qt();sn();$n();oi=async(e,o={})=>{let t=oe(e),n=t.path;if(!n)return'ERROR: Missing "path" argument for update_file.';let{patchPairs:i,error:r}=Nr(t);if(r)return`ERROR: ${r}`;if(i.length===0)return"ERROR: No valid replacement pairs found. Use replaceContent1, newContent1, etc.";let l=Ic.resolve(process.cwd(),n);try{if(!ti.existsSync(l))return`ERROR: File [${n}] does not exist. Use write_file instead.`;let c=o.forcedContent||ti.readFileSync(l,"utf8");c.startsWith("\uFEFF")&&(c=c.slice(1));let m=c.replace(/\r\n/g,`
|
|
311
315
|
`).replace(/\r/g,`
|
|
312
316
|
`),{content:d,results:u}=Ur(m,i),a=u.filter(p=>!p.success);if(a.length>0)return`ERROR: Patch Failed to apply to [${n}].
|
|
313
317
|
${a.map(p=>` \u2022 ${p.error}`).join(`
|
|
314
318
|
`)}`;await Et.recordFileChange(l,m),ti.writeFileSync(l,d,"utf8");let f=Rr(m,d,u,12);return`SUCCESS: File [${n}] updated. [${u.length}/${i.length}] blocks applied.
|
|
315
319
|
|
|
316
|
-
${f}`}catch(c){return`ERROR: Failed to update file [${n}]: ${c.message}`}}});import ss from"fs";import
|
|
320
|
+
${f}`}catch(c){return`ERROR: Failed to update file [${n}]: ${c.message}`}}});import ss from"fs";import Fa from"path";var ni,Ba=ie(()=>{Qt();ni=async e=>{let{path:o="."}=oe(e),t=Fa.resolve(process.cwd(),o);try{if(!ss.existsSync(t))return`ERROR: Path [${o}] does not exist.`;if(!ss.statSync(t).isDirectory())return`ERROR: Path [${o}] is a file, not a directory. Use view_file instead.`;let i=ss.readdirSync(t),r=i.length,l=100,c=i.slice(0,l),m=[];for(let f of c){let p=Fa.join(t,f),h="\u{1F4C4}",T={name:f,type:"unknown",size:"N/A",mtime:"N/A"};try{let w=ss.statSync(p);T={name:f,type:w.isDirectory()?"directory":"file",size:(w.size/1024).toFixed(1)+" KB",mtime:w.mtime.toLocaleString()}}catch{T.type="inaccessible"}m.push(T)}let d=m.map(f=>{let p=f.type==="directory"?"\u{1F4C1}":f.type==="file"?"\u{1F4C4}":"\u2753";return f.type==="directory"?`${p} ${f.name} - [DIR] - [Modified: ${f.mtime}]`:`${p} ${f.name} - [Size: ${f.size}] - [Modified: ${f.mtime}]`}).join(`
|
|
317
321
|
`),u=`
|
|
318
322
|
|
|
319
323
|
(Total items in folder: ${r})`;r>l&&(u=`
|
|
320
324
|
|
|
321
325
|
\u26A0\uFE0F TRUNCATED: Showing first ${l} of ${r} items.`);let a=`Detailed folder stats for [${o}]:
|
|
322
326
|
|
|
323
|
-
${d}${u}`;return i.length=0,c.length=0,m.length=0,a}catch(n){return`ERROR: Failed to read folder [${o}]: ${n.message}`}}});var ri,_a=ie(()=>{Qt();ri=async(e,o)=>{let t=oe(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,m]=l.split("::");i.push({id:r,label:c.trim(),description:m.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 Mc from"puppeteer";import
|
|
327
|
+
${d}${u}`;return i.length=0,c.length=0,m.length=0,a}catch(n){return`ERROR: Failed to read folder [${o}]: ${n.message}`}}});var ri,_a=ie(()=>{Qt();ri=async(e,o)=>{let t=oe(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,m]=l.split("::");i.push({id:r,label:c.trim(),description:m.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 Mc from"puppeteer";import Vn from"path";import Un from"fs-extra";import{PDFDocument as Oc}from"pdf-lib";var si,Na=ie(()=>{Qt();sn();si=async e=>{let{path:o,content:t,orientation:n="portrait",margin:i="0px"}=oe(e);if(!o)return'ERROR: Missing "path" argument for write_pdf.';if(!t)return'ERROR: Missing "content" (HTML/CSS) for write_pdf.';let r=Vn.resolve(process.cwd(),o),l=null;try{await Un.ensureDir(Vn.dirname(r)),await Et.recordFileChange(r),l=await Mc.launch({headless:!0,args:["--no-sandbox","--disable-setuid-sandbox","--disable-gpu","--disable-dev-shm-usage"]});let c=await l.newPage(),m=t,d={},u=async F=>{if(!F||F.startsWith("http://")||F.startsWith("https://")||F.startsWith("data:"))return null;try{let I=Vn.resolve(process.cwd(),F);if(await Un.pathExists(I)){let A=Vn.extname(I).toLowerCase().replace(".","")||"png",v=A==="jpg"?"jpeg":A==="svg"?"svg+xml":A,J=await Un.readFile(I,"base64");return`data:image/${v};base64,${J}`}}catch{}return null},a=/<link[^>]+href=["']([^"']+)["']/gi,f={},p;for(;(p=a.exec(t))!==null;){let F=p[1],I=p[0];if(F&&I.toLowerCase().includes("stylesheet")&&!F.startsWith("http://")&&!F.startsWith("https://")&&!F.startsWith("data:"))try{let A=Vn.resolve(process.cwd(),F);if(await Un.pathExists(A)){let v=await Un.readFile(A,"utf-8");f[I]=`<style>${v}</style>`}}catch{}}for(let[F,I]of Object.entries(f))m=m.split(F).join(I);let h=/<img[^>]+src=["']([^"']+)["']/gi;for(;(p=h.exec(m))!==null;){let F=p[1];if(F&&!d[F]){let I=await u(F);I&&(d[F]=I)}}let T=/url\(\s*['"]?([^'")]+?)['"]?\s*\)/gi;for(;(p=T.exec(m))!==null;){let F=p[1].trim();if(F&&!d[F]){let I=await u(F);I&&(d[F]=I)}}for(let[F,I]of Object.entries(d)){let A=F.replace(/[-\/\\^$*+?.()|[\]{}]/g,"\\$&"),v=new RegExp(`(src=["'])(${A})(["'])`,"gi");m=m.replace(v,`$1${I}$3`);let J=new RegExp(`url\\(\\s*(['"]?)(${A})\\1\\s*\\)`,"gi");m=m.replace(J,`url($1${I}$1)`)}let w=`
|
|
324
328
|
<style>
|
|
325
329
|
@page {
|
|
326
330
|
margin: ${i};
|
|
@@ -350,7 +354,7 @@ ${d}${u}`;return i.length=0,c.length=0,m.length=0,a}catch(n){return`ERROR: Faile
|
|
|
350
354
|
</style>
|
|
351
355
|
<div class="watermark">Generated by FluxFlow CLI (AI)</div>
|
|
352
356
|
${m}
|
|
353
|
-
`;await c.setContent(w,{waitUntil:"networkidle0",timeout:18e4});let E=await c.pdf({format:"A4",landscape:String(n).toLowerCase()==="landscape",margin:{top:i,right:i,bottom:i,left:i},printBackground:!0}),k=await Oc.load(E),D=
|
|
357
|
+
`;await c.setContent(w,{waitUntil:"networkidle0",timeout:18e4});let E=await c.pdf({format:"A4",landscape:String(n).toLowerCase()==="landscape",margin:{top:i,right:i,bottom:i,left:i},printBackground:!0}),k=await Oc.load(E),D=Vn.basename(o);k.setTitle(`FluxFlow_${D}`),k.setAuthor("FluxFlow CLI"),k.setSubject("Generated with Agentic AI System"),k.setKeywords(["FluxFlow","AI","Agentic","Automated"]),k.setCreator("FluxFlow PDF Engine"),k.setProducer("FluxFlow (Generative AI)");let _=await k.save();await Un.writeFile(r,_);let K=await Un.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 Ua from"fs-extra";import ii from"path";import Ac from"html-to-docx";var ai,Ra=ie(()=>{Qt();sn();ai=async e=>{let{path:o,content:t}=oe(e);if(!o)return'ERROR: Missing "path" argument for write_docx.';if(!t)return'ERROR: Missing "content" (HTML) for write_docx.';let n=ii.resolve(process.cwd(),o);try{await Ua.ensureDir(ii.dirname(n)),await Et.recordFileChange(n);let i=ii.basename(o),r=t.includes("<html")?t:`
|
|
354
358
|
<!DOCTYPE html>
|
|
355
359
|
<html lang="en">
|
|
356
360
|
<head>
|
|
@@ -365,25 +369,25 @@ ${d}${u}`;return i.length=0,c.length=0,m.length=0,a}catch(n){return`ERROR: Faile
|
|
|
365
369
|
- Size: ${(l.length/1024).toFixed(1)} KB`}catch(i){return`ERROR: Failed to generate DOCX [${o}]: ${i.message}`}}});import li from"fs/promises";import br from"path";async function Wa(e,o,t=e,n=1){if(n>12)return[];let i=[],r;try{r=await li.readdir(e,{withFileTypes:!0})}catch{return[]}for(let l of r){let c=br.join(e,l.name),m=br.relative(t,c),d=m.split(br.sep).map(a=>a.toLowerCase());if(!o.some(a=>d.includes(a.toLowerCase())))if(l.isDirectory()){let a=await Wa(c,o,t,n+1);i=i.concat(a)}else l.isFile()&&i.push({fullPath:c,relativePath:m})}return i}var ci,Ya=ie(()=>{Qt();ci=async e=>{let{keyword:o,file:t}=oe(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=br.resolve(l,t);try{(await li.stat(a)).isFile()&&r.push({fullPath:a,relativePath:br.relative(l,a)})}catch{return`ERROR: File not found: ${t}`}}else r=await Wa(l,n);let c=r.map(async a=>{try{let f=await li.readFile(a.fullPath,"utf-8");if(f.includes("\0"))return[];let p=f.split(/\r?\n/),h=[];for(let T=0;T<p.length;T++)if(p[T].includes(o)){let w=a.relativePath.replace(/\\/g,"/");h.push(`${w} \u2192 ${T+1}`)}return h}catch{return[]}}),d=(await Promise.all(c)).flat().slice(0,i);if(typeof global.gc=="function"&&global.gc(),d.length===0)return`Found 0 matches for keyword: "${o}"${t?` in file: ${t}`:". Try to specify files"}`;let u=`Found ${d.length} matches:
|
|
366
370
|
|
|
367
371
|
`;return u+=d.join(`
|
|
368
|
-
`),u}catch(r){return`ERROR: ${r.message}`}}});import Cr from"fs-extra";import di from"path";var Vn,kr,Lc,Rn,ui=ie(()=>{to();vo();Vn={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={...Vn};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={...Vn,...o,quotas:{...Vn.quotas,...o.quotas},systemSettings:{...Vn.systemSettings,...o.systemSettings},profileData:{...Vn.profileData,...o.profileData},imageSettings:{...Vn.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)}}},Rn=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();sn();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,Fe="";try{Fe=await _.text()}catch{}return G===402||Fe.includes("Insufficient balance")||Fe.includes("PAYMENT_REQUIRED")?"ERROR: Image Generation Currently unavailable. Try again later.":`ERROR: Image Generation failed with status [${G}]: ${Fe||"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 P=await _.arrayBuffer(),I=Buffer.from(P),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(uo,{}),l=we(_o,{});return l[n]=i,delete r[n],ke(_o,l),ke(uo,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 zn,qa=ie(()=>{vo();to();zn=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(Pt,[]),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(Pt,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();Fa();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:zn,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:zn,AddMemScore:zn,addMemoryScore:zn,AddMemoryScore:zn},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,Jn,$c,pi,Qn,za,hi,Ja,ls,Ro,cs,Mr,Qa,gi,Za,xi=ie(()=>{ao=null,Jn=!1,$c="ws://localhost:56832",pi=[],Qn=null,za="2.0.0",hi=e=>{za=e,Ja()},Ja=()=>{if(ao||Jn)return;Jn=!0;let e=new as($c);e.on("open",()=>{for(ao=e,Jn=!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"&&Qn&&(Qn(t.data),Qn=null)}catch{}}),e.on("error",()=>{Jn=!1,ao=null}),e.on("close",()=>{Jn=!1,ao=null})},ls=e=>{ao&&ao.readyState===as.OPEN?ao.send(JSON.stringify(e)):(pi.push(e),Jn||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}Qn=e,ao.send(JSON.stringify({command:"requestContext"})),setTimeout(()=>{Qn===e&&(e({cursor_line:0,selected:0,manual_edits:"",file_focused:"none",opened_editors:[]}),Qn=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 Fc,ThinkingLevel as Wo,HarmBlockThreshold as bn,HarmCategory as Cn}from"@google/genai";import Ie from"path";import Bt from"fs";var er,Zn,Pc,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();$n();to();sn();xi();er=null,Zn=!1,Pc=["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:Pc.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,P=_.inlineData.data;K.startsWith("image/")&&D.push({type:"image_url",image_url:{url:`data:${K};base64,${P}`}})}}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(`
|
|
369
|
-
`);f=D.pop();for(let _ of D){let K=_.trim();if(!(!K||!K.startsWith("data: "))){if(K==="data: [DONE]")break;try{let
|
|
370
|
-
`);h=K.pop();for(let
|
|
371
|
-
`),
|
|
372
|
+
`),u}catch(r){return`ERROR: ${r.message}`}}});import Cr from"fs-extra";import di from"path";var zn,kr,Lc,Rn,ui=ie(()=>{to();vo();zn={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={...zn};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={...zn,...o,quotas:{...zn.quotas,...o.quotas},systemSettings:{...zn.systemSettings,...o.systemSettings},profileData:{...zn.profileData,...o.profileData},imageSettings:{...zn.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)}}},Rn=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();sn();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(uo,{}),l=we(_o,{});return l[n]=i,delete r[n],ke(_o,l),ke(uo,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 Jn,qa=ie(()=>{vo();to();Jn=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:Jn,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:Jn,AddMemScore:Jn,addMemoryScore:Jn,AddMemoryScore:Jn},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,Qn,$c,pi,Zn,za,hi,Ja,ls,Ro,cs,Mr,Qa,gi,Za,xi=ie(()=>{ao=null,Qn=!1,$c="ws://localhost:56832",pi=[],Zn=null,za="2.0.0",hi=e=>{za=e,Ja()},Ja=()=>{if(ao||Qn)return;Qn=!0;let e=new as($c);e.on("open",()=>{for(ao=e,Qn=!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"&&Zn&&(Zn(t.data),Zn=null)}catch{}}),e.on("error",()=>{Qn=!1,ao=null}),e.on("close",()=>{Qn=!1,ao=null})},ls=e=>{ao&&ao.readyState===as.OPEN?ao.send(JSON.stringify(e)):(pi.push(e),Qn||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}Zn=e,ao.send(JSON.stringify({command:"requestContext"})),setTimeout(()=>{Zn===e&&(e({cursor_line:0,selected:0,manual_edits:"",file_focused:"none",opened_editors:[]}),Zn=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 tr,er,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();$n();to();sn();xi();tr=null,er=!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
|
+
`);f=D.pop();for(let _ of D){let K=_.trim();if(!(!K||!K.startsWith("data: "))){if(K==="data: [DONE]")break;try{let F=JSON.parse(K.substring(6)),I=F.choices?.[0]?.delta,A=F.usage;if(A&&(h={totalTokenCount:A.total_tokens||A.prompt_tokens+A.completion_tokens,promptTokenCount:A.prompt_tokens||0,candidatesTokenCount:A.completion_tokens||0,cachedContentTokenCount:A.prompt_tokens_details?.cached_tokens||0,thoughtsTokenCount:A.completion_tokens_details?.reasoning_tokens||0},w=!0),I){let v=I.reasoning_content||null;v&&(p.push({text:v,thought:!0}),w=!0),I.content&&(p.push({text:I.content}),w=!0)}}catch{}}}Date.now()-T>=150&&w&&(yield{candidates:p.length>0?[{content:{parts:[...p]}}]:[],usageMetadata:h},p=[],T=Date.now(),w=!1)}},Si=async function*(e,o,t,n,i,r,l){let c=[];n&&c.push({role:"system",content:n});for(let D of t){let _=D.role==="user"?"user":"assistant",K=[];if(Array.isArray(D.parts)){for(let F of D.parts)if(F.text)K.push({type:"text",text:F.text});else if(F.inlineData&&l){let I=F.inlineData.mimeType,A=F.inlineData.data;I.startsWith("image/")?K.push({type:"image_url",image_url:{url:`data:${I};base64,${A}`}}):K.push({type:"file",file:{filename:F.filename||"file",file_data:`data:${I};base64,${A}`}})}}else{let F=D.text||"";F&&K.push({type:"text",text:F})}c.push({role:_,content:K.length===1&&K[0].type==="text"?K[0].text:K})}let m={Low:"low",Medium:"medium",High:"high",xHigh:"high"},d={model:o,messages:c,stream:!0,temperature:r==="Flux"?1:1.4},u=m[i];u&&i!=="Fast"&&(d.reasoning_effort=u);let a=await ol("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(d)});if(!a.ok){let D=await a.json().catch(()=>({}));throw new Error(`OpenRouter Error (${a.status}): ${D.error?.message||a.statusText}`)}let f=a.body.getReader(),p=new TextDecoder,h="",T=[],w=null,E=Date.now(),k=!1;for(;;){let{done:D,value:_}=await f.read();if(D){k&&(T.length>0||w)&&(yield{candidates:T.length>0?[{content:{parts:T}}]:[],usageMetadata:w});break}h+=p.decode(_,{stream:!0});let K=h.split(`
|
|
374
|
+
`);h=K.pop();for(let F of K){let I=F.trim();if(!(!I||!I.startsWith("data: "))){if(I==="data: [DONE]")break;try{let A=JSON.parse(I.substring(6)),v=A.choices?.[0]?.delta,J=A.usage;if(J&&(w={totalTokenCount:J.total_tokens||J.prompt_tokens+J.completion_tokens,promptTokenCount:J.prompt_tokens||0,candidatesTokenCount:J.completion_tokens||0,cachedContentTokenCount:J.prompt_tokens_details?.cached_tokens||0,thoughtsTokenCount:J.completion_tokens_details?.reasoning_tokens||0},k=!0),v){let q=v.reasoning||(v.reasoning_details?v.reasoning_details.map(le=>le.text).join(""):null);q&&(T.push({text:q,thought:!0}),k=!0),v.content&&(T.push({text:v.content}),k=!0)}}catch{}}}Date.now()-E>=150&&k&&(yield{candidates:T.length>0?[{content:{parts:[...T]}}]:[],usageMetadata:w},T=[],E=Date.now(),k=!1)}},nl=()=>{er=!0},el={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"},_c=(e,o)=>{try{let t=oe(o),n=t.path||t.targetFile||t.TargetFile||t.directory;return n?Ie.basename(n.replace(/["']/g,"").replace(/\\/g,"/")):null}catch{return null}},rl=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:m,onBackgroundIncrement:d}=i,{profile:u,thinkingLevel:a,mode:f,janitorModel:p,chatId:h,systemSettings:T,sessionStats:w,aiProvider:E="Google",apiKey:k}=e,D=T?.memory!==!1,K=we(Ft,[]).map(pe=>`- [${pe.id}]: ${pe.memory}`).join(`
|
|
375
|
+
`),F=n.slice(0,-1).filter(pe=>pe.text&&!pe.text.includes("[TOOL RESULT]")&&!pe.text.includes("OBSERVATION:")&&!pe.text.startsWith("[TERMINAL_RECORD]")&&!pe.isTerminalRecord&&!pe.isMeta&&!pe.isLogo&&!String(pe.id).startsWith("welcome")&&!String(pe.id).startsWith("logo")).slice(-14).map(pe=>{let ut=Bc(pe.text).replace(/\[tool:functions\..*?\]/g,"").replace(/(?:<think>|\[think\])[\s\S]*?(?:<\/think>|\[\/think\])/g,"").replace(/\[Prompted on:.*?\]/g,"").replace(/\[METADATA \(PRIORITY: DYNAMIC\)\] Time: ([^|\n]+)/g,(Je,fe)=>`[METADATA (PRIORITY: DYNAMIC)] Time: ${fe.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,`
|
|
372
376
|
`).replace(/\n\n/g,`
|
|
373
377
|
`).replace(/\\n\\n/g,"").trim(),Ve=pe.role==="user"?r:l,ze=ut.substring(0,Ve);ut.length>Ve&&(ze+=`
|
|
374
378
|
... (truncated) ...`);let _e=pe.role==="user"?ze.startsWith("[USER]")?"":"[USER]: ":ze.startsWith("[AGENT]")?"":"[AGENT]: ";return{role:pe.role==="user"?"user":"model",parts:[{text:`${_e}${ze}`}]}}),I=n.filter(pe=>pe.role==="user").length===1,A=o.includes("[TITLE-UPDATE]"),v=Math.random()<.8,J=I||A||v,q=t.replace(/(?:<think>|\[think\])[\s\S]*?(?:<\/think>|\[\/think\])/g,"").trim(),le=ma(K,D,J),U=`${q.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)}`;U.length>l&&(U+=`
|
|
375
379
|
... (truncated) ...`);let G=o.replace(/\[Prompted on:.*?\]/g,"").trim();U=U.replace(/\r?\n\r?\n/g,`
|
|
376
380
|
`).replace(/\n\n/g,`
|
|
377
|
-
`).replace(/\\n\\n/g,"").trim();let
|
|
381
|
+
`).replace(/\\n\\n/g,"").trim();let Pe=`[USER]: ${G.substring(0,r)}
|
|
378
382
|
${G.length>r?`... (truncated) ...
|
|
379
383
|
|
|
380
384
|
`:""}
|
|
381
|
-
[AGENT (current turn)]: ${U}`;
|
|
385
|
+
[AGENT (current turn)]: ${U}`;F.push({role:"user",parts:[{text:Pe}]});let ce="",De=0,nt=D?12:-1;for(;De<=nt;){process.stdout.isTTY&&(process.stdout.write(`\x1B]0;Retrying Finalizing... (${De+1})...\x07`),process.stdout.write(`\x1B]633;P;TerminalTitle=Retrying Finalizing... (${De+1})...\x07`));try{if(!await Ks("background",e))return;let pe="",ut=null;try{let _e=new Promise((no,ve)=>setTimeout(()=>ve(new Error("JANITOR_TIMEOUT")),6e4)),Je=(async()=>{if(E==="OpenRouter"){let yt=Si(k,"google/gemma-4-26b-a4b-it:free",F,le,"Fast",f)[Symbol.asyncIterator](),Xo=await yt.next();return{iterator:yt,firstResult:Xo}}else if(E==="DeepSeek"){let ve=Ti(k,"deepseek-chat",F,le,"Fast",f,!1)[Symbol.asyncIterator](),yt=await ve.next();return{iterator:ve,firstResult:yt}}else{let ve=(await tr.models.generateContentStream({model:p||"gemma-4-26b-a4b-it",contents:F,config:{systemInstruction:le,maxOutputTokens:512,temperature:.3,safetySettings:[{category:Cn.HARM_CATEGORY_HARASSMENT,threshold:bn.BLOCK_NONE},{category:Cn.HARM_CATEGORY_HATE_SPEECH,threshold:bn.BLOCK_NONE},{category:Cn.HARM_CATEGORY_SEXUALLY_EXPLICIT,threshold:bn.BLOCK_NONE},{category:Cn.HARM_CATEGORY_DANGEROUS_CONTENT,threshold:bn.BLOCK_NONE}],thinkingConfig:{includeThoughts:!1,thinkingLevel:Wo.MINIMAL}}}))[Symbol.asyncIterator](),yt=await ve.next();return{iterator:ve,firstResult:yt}}})(),{iterator:fe,firstResult:po}=await Promise.race([Je,_e]),{value:ho,done:dn}=po;if(!dn&&ho){let no=ho.candidates?.[0]?.content?.parts,ve=no?.[1]?.text||no?.[0]?.text||(typeof ho.text=="function"?ho.text():"");ve&&(pe+=ve),ut=ho.usageMetadata;for await(let yt of{[Symbol.asyncIterator]:()=>fe}){let Xo=yt.candidates?.[0]?.content?.parts,Ko=Xo?.[1]?.text||Xo?.[0]?.text||(typeof yt.text=="function"?yt.text():"");Ko&&(pe+=Ko),ut=yt.usageMetadata}}}catch(_e){throw _e}if(pe)ce=pe,ut&&await fo("tokens",ut.totalTokenCount||0);else throw new Error("No synthesis generated by Janitor.");d&&(d(),await Nn("background"));let Ve=Ei(ce),ze=!1;for(let _e of Ve){let Je=_e.toolName;["addMemScore","add_mem_score","AddMemScore","addMemoryScore","AddMemoryScore"].includes(Je)&&(ze=!0);let fe={chatId:h,sessionId:h,history:n},po=await is(Je,_e.args,fe);Je.toLowerCase()==="memory"&&(_e.args.includes("action='user'")||_e.args.includes('action="user"'))&&!po.startsWith("ERROR")&&(m&&m(),process.stdout.isTTY&&(process.stdout.write("\x1B]0;Memory Updated\x07"),process.stdout.write("\x1B]633;P;TerminalTitle=Memory Updated\x07")),await new Promise(dn=>setTimeout(dn,3e3)))}if(!ze)try{let _e=we(Ft,[]);if(_e.length>0){let Je=[];for(let fe of _e)fe.score===void 0&&(fe.score=.5),fe.score*=.9995,fe.score<.05&&(fe.score=0),fe.score=Math.round(fe.score*1e5)/1e5,fe.score>0&&Je.push(fe);ke(Ft,Je)}}catch{}break}catch(pe){De++;let ut=new Date().toLocaleString();process.stdout.isTTY&&process.stdout.write("\x1B]0;Finalizing Error\x07"),await new Promise(_e=>setTimeout(_e,1e3));let Ve=Ie.join(Co,"janitor");if(Bt.existsSync(Ve)||Bt.mkdirSync(Ve,{recursive:!0}),Bt.appendFileSync(Ie.join(Ve,"error.log"),`ERROR [Attempt ${De}/${nt+1}] [${ut}]: ${String(pe)}
|
|
382
386
|
|
|
383
|
-
`),De>nt)break;let ze=Math.min(1e3*Math.pow(2,De-1),8e3);await new Promise(_e=>setTimeout(_e,ze))}}if(De){let pe=Ie.join(
|
|
387
|
+
`),De>nt)break;let ze=Math.min(1e3*Math.pow(2,De-1),8e3);await new Promise(_e=>setTimeout(_e,ze))}}if(De){let pe=Ie.join(Co,"janitor");Bt.appendFileSync(Ie.join(pe,"error.log"),`-----------------------------------------------------------------------------
|
|
384
388
|
|
|
385
389
|
|
|
386
|
-
`),De>=nt&&(process.stdout.isTTY&&process.stdout.write(`\x1B]0;${D?"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"))},Nc=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 m=n;m<e.length;m++){let d=e[m];if(!r&&(d==='"'||d==="'"||d==="`")?(r=d,l=!1):r&&d===r&&!l&&(r=null),!r&&(d==="("?i++:d===")"&&i--,i===0)){let u=m+1;for(;u<e.length&&/\s/.test(e[u]);)u++;if(u<e.length&&e[u]==="]"){c=!0,o.lastIndex=u+1;break}}d==="\\"?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}},sl=(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,m=0,d=null,u=-1;for(let a=c;a<e.length;a++){let f=e[a];if(d){if(f===d){let p=0;for(let h=a-1;h>=0&&e[h]==="\\";h--)p++;p%2===0&&(d=null)}}else if(f==='"'||f==="'"||f==="`")d=f;else if(f==="(")m++;else if(f===")"&&(m--,m===0)){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)n+="[tool:functions."+r[1]+"()]",i=u+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},Uc=(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 m=l.index+l[0].length-1,d=0,u=null,a=-1;for(let f=m;f<e.length;f++){let p=e[f];if(u){if(p===u){let h=0;for(let T=f-1;T>=0&&e[T]==="\\";T--)h++;h%2===0&&(u=null)}}else if(p==='"'||p==="'"||p==="`")u=p;else if(p==="(")d++;else if(p===")"&&(d--,d===0)){let h=f+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},tl=e=>sl(e,!0),Ei=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,m=-1,d=-1;for(let u=r;u<e.length;u++){let a=e[u];if(c){if(a===c){let f=0;for(let p=u-1;p>=0&&e[p]==="\\";p--)f++;f%2===0&&(c=null)}}else if(a==='"'||a==="'"||a==="`")c=a;else if(a==="(")l++;else if(a===")"&&(l--,l===0)){d=u;let f=u+1;for(;f<e.length&&/\s/.test(e[f]);)f++;if(f<e.length&&e[f]==="]"){m=f;break}}}if(m!==-1){let u=e.substring(r+1,d),a=e.substring(n.index,m+1);o.push({fullMatch:a,toolName:i.trim(),args:u.trim()}),t.lastIndex=m+1}}return o},Or=e=>e?(
|
|
390
|
+
`),De>=nt&&(process.stdout.isTTY&&process.stdout.write(`\x1B]0;${D?"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"))},Nc=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 m=n;m<e.length;m++){let d=e[m];if(!r&&(d==='"'||d==="'"||d==="`")?(r=d,l=!1):r&&d===r&&!l&&(r=null),!r&&(d==="("?i++:d===")"&&i--,i===0)){let u=m+1;for(;u<e.length&&/\s/.test(e[u]);)u++;if(u<e.length&&e[u]==="]"){c=!0,o.lastIndex=u+1;break}}d==="\\"?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}},sl=(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,m=0,d=null,u=-1;for(let a=c;a<e.length;a++){let f=e[a];if(d){if(f===d){let p=0;for(let h=a-1;h>=0&&e[h]==="\\";h--)p++;p%2===0&&(d=null)}}else if(f==='"'||f==="'"||f==="`")d=f;else if(f==="(")m++;else if(f===")"&&(m--,m===0)){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)n+="[tool:functions."+r[1]+"()]",i=u+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},Uc=(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 m=l.index+l[0].length-1,d=0,u=null,a=-1;for(let f=m;f<e.length;f++){let p=e[f];if(u){if(p===u){let h=0;for(let T=f-1;T>=0&&e[T]==="\\";T--)h++;h%2===0&&(u=null)}}else if(p==='"'||p==="'"||p==="`")u=p;else if(p==="(")d++;else if(p===")"&&(d--,d===0)){let h=f+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},tl=e=>sl(e,!0),Ei=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,m=-1,d=-1;for(let u=r;u<e.length;u++){let a=e[u];if(c){if(a===c){let f=0;for(let p=u-1;p>=0&&e[p]==="\\";p--)f++;f%2===0&&(c=null)}}else if(a==='"'||a==="'"||a==="`")c=a;else if(a==="(")l++;else if(a===")"&&(l--,l===0)){d=u;let f=u+1;for(;f<e.length&&/\s/.test(e[f]);)f++;if(f<e.length&&e[f]==="]"){m=f;break}}}if(m!==-1){let u=e.substring(r+1,d),a=e.substring(n.index,m+1);o.push({fullMatch:a,toolName:i.trim(),args:u.trim()}),t.lastIndex=m+1}}return o},Or=e=>e?(tr=new Pc({apiKey:e}),tr):null,wi=async(e,o,t,n,i="Fast")=>{let{aiProvider:r="Google",apiKey:l,mode:c}=e,m="",d=null,u;r==="OpenRouter"?u=Si(l,o,t,n,i,c,!1):r==="DeepSeek"?u=Ti(l,o,t,n,i,c,!1):u=await tr.models.generateContentStream({model:o,contents:t,config:{systemInstruction:n,maxOutputTokens:2048,temperature:.3,thinkingConfig:{includeThoughts:!1,thinkingLevel:Wo.MINIMAL}}});for await(let a of u){if(a.candidates?.[0]?.content?.parts)for(let f of a.candidates[0].content.parts)f.text&&!f.thought&&(m+=f.text);a.usageMetadata&&(d=a.usageMetadata)}return{text:m,usageMetadata:d}},Rc=async(e,o)=>{try{let{aiProvider:t="Google"}=o,n=we(uo,{});if(Object.values(n).flat().length<=2)return;let r=Object.keys(n).filter(f=>f!==e&&Array.isArray(n[f])&&n[f].length>2);if(r.length===0)return;let l=`You are a silent background process for the FluxFlow CLI Agent.
|
|
387
391
|
Your task is to summarize or merge temporary context memories from one or more past conversation sessions.
|
|
388
392
|
For each Chat ID provided, you must output a tool call to save the consolidated summary.
|
|
389
393
|
|
|
@@ -407,8 +411,8 @@ ${h}
|
|
|
407
411
|
`):l+=`-- Individual Memories:
|
|
408
412
|
${h}
|
|
409
413
|
|
|
410
|
-
`}let m=0,d=5,u=!1,a="gemma-4-26b-a4b-it";for(t==="OpenRouter"&&(a="google/gemma-4-26b-a4b-it:free"),t==="DeepSeek"&&(a="deepseek-v4-flash");m<=d&&!u;){m++;try{let f=await wi(o,a,l,null,"Fast"),p=f.text||"",h=Ei(p);if(h.length===0)throw new Error("No tool calls detected in synthesis response");for(let T of h){let w=T.toolName;["saveSummary","saveSumary","SaveSummary","SaveSumary"].includes(w)&&await is(w,T.args,{chatId:e})}f.usageMetadata&&await fo("tokens",f.usageMetadata.totalTokenCount||0),u=!0}catch(f){if(m>=d)throw new Error(`Failed after ${d} attempts. Last error: ${f.message}`)}}}catch(t){let n=Ie.join(
|
|
411
|
-
`)}},il=async function*(e,o,t,n,i){let{profile:r,thinkingLevel:l,mode:c,janitorModel:m,chatId:d,systemSettings:u,sessionStats:a,aiProvider:f="Google",apiTier:p}=t,h=yi(e);if(!
|
|
414
|
+
`}let m=0,d=5,u=!1,a="gemma-4-26b-a4b-it";for(t==="OpenRouter"&&(a="google/gemma-4-26b-a4b-it:free"),t==="DeepSeek"&&(a="deepseek-v4-flash");m<=d&&!u;){m++;try{let f=await wi(o,a,l,null,"Fast"),p=f.text||"",h=Ei(p);if(h.length===0)throw new Error("No tool calls detected in synthesis response");for(let T of h){let w=T.toolName;["saveSummary","saveSumary","SaveSummary","SaveSumary"].includes(w)&&await is(w,T.args,{chatId:e})}f.usageMetadata&&await fo("tokens",f.usageMetadata.totalTokenCount||0),u=!0}catch(f){if(m>=d)throw new Error(`Failed after ${d} attempts. Last error: ${f.message}`)}}}catch(t){let n=Ie.join(Co,"janitor");Bt.existsSync(n)||Bt.mkdirSync(n,{recursive:!0}),Bt.appendFileSync(Ie.join(n,"error.log"),`[${new Date().toLocaleString()}] Past memory batch consolidation error: ${t.message}
|
|
415
|
+
`)}},il=async function*(e,o,t,n,i){let{profile:r,thinkingLevel:l,mode:c,janitorModel:m,chatId:d,systemSettings:u,sessionStats:a,aiProvider:f="Google",apiTier:p}=t,h=yi(e);if(!tr&&f==="Google")throw new Error("AI not initialized");let T=u?.memory!==!1,w=o[o.length-1].text,E=Ie.join(eo,"chat-summaries.json"),k=!1,D=o.filter(I=>I.role==="user").length===1,_=w.includes("[TITLE-UPDATE]"),K=D||_,F=w.replace(/\[TITLE-UPDATE\]/g,"").trim();F=F.replace(/\s*\[Prompted on:.*?\]/g,"").trim(),await Et.startTransaction(d,F);try{let I=[...o.slice(0,-1)],A=252e3,v=254e3;if((f==="DeepSeek"||f==="Google"&&p==="Paid")&&(A=396e3,v=4e5),u?.compression===0&&(a?.tokens||0)>A){yield{type:"status_history",content:"Context Limit Reached. Condensing session history..."};let Q=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(`
|
|
412
416
|
|
|
413
417
|
`),Me=async(wt,ft)=>{let je="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.",de=ft?`Here is the previous summary:
|
|
414
418
|
${ft}
|
|
@@ -419,10 +423,10 @@ ${wt}
|
|
|
419
423
|
Provide a new consolidated summary of the entire session.`:`Here is the conversation history:
|
|
420
424
|
${wt}
|
|
421
425
|
|
|
422
|
-
Provide a consolidated summary of the entire session.`,Nt="gemma-4-26b-a4b-it";f==="OpenRouter"&&(Nt="google/gemma-4-26b-a4b-it:free"),f==="DeepSeek"&&(Nt="deepseek-v4-flash");let it=0,co=!1,pt=null;for(;it<=3&&!co;){it++;try{pt=await wi(t,Nt,de,je,"Fast"),co=!0}catch{if(it>3){if(f==="Google")try{return(await wi(t,"gemini-3.1-flash-lite",de,je,"Fast")).text||""}catch{return""}return""}}}return pt&&pt.text||""},rt=Q(I),ne=we(E,{}),xe=ne[d]||{summary:"",historyLength:0};typeof xe=="string"&&(xe={summary:xe,historyLength:0});let he=I.filter(wt=>(wt.role==="user"||wt.role==="agent"||wt.role==="system")&&!String(wt.id).startsWith("welcome")&&!wt.isMeta).length;xe.historyLength&&he<xe.historyLength&&(xe.summary="",xe.historyLength=0,ne[d]=xe,ke(E,ne));let st=xe.summary||"",
|
|
423
|
-
`),ce=we(
|
|
426
|
+
Provide a consolidated summary of the entire session.`,Nt="gemma-4-26b-a4b-it";f==="OpenRouter"&&(Nt="google/gemma-4-26b-a4b-it:free"),f==="DeepSeek"&&(Nt="deepseek-v4-flash");let it=0,co=!1,pt=null;for(;it<=3&&!co;){it++;try{pt=await wi(t,Nt,de,je,"Fast"),co=!0}catch{if(it>3){if(f==="Google")try{return(await wi(t,"gemini-3.1-flash-lite",de,je,"Fast")).text||""}catch{return""}return""}}}return pt&&pt.text||""},rt=Q(I),ne=we(E,{}),xe=ne[d]||{summary:"",historyLength:0};typeof xe=="string"&&(xe={summary:xe,historyLength:0});let he=I.filter(wt=>(wt.role==="user"||wt.role==="agent"||wt.role==="system")&&!String(wt.id).startsWith("welcome")&&!wt.isMeta).length;xe.historyLength&&he<xe.historyLength&&(xe.summary="",xe.historyLength=0,ne[d]=xe,ke(E,ne));let st=xe.summary||"",Po=await Me(rt,st);Po&&(xe.summary=Po,ne[d]=xe,ke(E,ne),I=[],k=!0)}D&&T&&(yield{type:"status",content:"Condensing past chat memories..."},await Rc(d,t));let J=we(uo,{}),q=we(_o,{}),le=Object.entries(J).filter(([Q])=>Q!==d).flatMap(([Q,Me])=>Me),G=[...Object.entries(q).filter(([Q])=>Q!==d).slice(-20).map(([Q,Me])=>`[Chat Summary]: ${Me}`),...le].map(Q=>`- ${Q}`).join(`
|
|
427
|
+
`),ce=we(Ft,[]).map(Q=>`- ${Q.memory}`).join(`
|
|
424
428
|
`),De=(a?.tokens||0)>=24e3,nt=da(G,ce,T,De),pe=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"],Ve=Q=>{try{return Bt.readdirSync(Q,{withFileTypes:!0})}catch{return[]}},ze=(Q,Me={value:0},rt=1)=>{if(Me.value>6200||rt>7)return Me.value;let ne=Ve(Q);for(let xe of ne){if(Me.value>6200)break;ut.includes(xe.name)||xe.isDirectory()&&(Me.value++,ze(Ie.join(Q,xe.name),Me,rt+1))}return Me.value},_e=(Q,Me,rt="",ne=1)=>{let xe=Ve(Q),he=Ie.sep;if(xe.length>100)return`${rt}\u2514\u2500\u2500 ${Ie.basename(Q)}${he} ...100+ files...
|
|
425
|
-
`;let st="",
|
|
429
|
+
`;let st="",Po=ut,wt=xe.filter(de=>!Po.includes(de.name)),ft=xe.filter(de=>Po.includes(de.name)).map(de=>de.name).sort();wt.sort((de,Nt)=>de.isDirectory()&&!Nt.isDirectory()?-1:!de.isDirectory()&&Nt.isDirectory()?1:de.name.localeCompare(Nt.name));let je=[...wt.map(de=>({name:de.name,isDir:de.isDirectory()})),...ft.map(de=>({name:de,isDir:!0,isCollapsed:!0}))];return je.forEach((de,Nt)=>{let it=Nt===je.length-1,co=Ie.join(Q,de.name),pt=it?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 ",un=rt+(it?" ":"\u2502 ");if(de.isCollapsed){st+=`${rt}${pt}${de.name}${he}...
|
|
426
430
|
`;return}de.isDir?ne>Me?st+=`${rt}${pt}${de.name}${he} ...depth exceeded...
|
|
427
431
|
`:Ve(co).length>80?st+=`${rt}${pt}${de.name}${he} ...80+ files...
|
|
428
432
|
`:(st+=`${rt}${pt}${de.name}${he}
|
|
@@ -443,7 +447,7 @@ ${ne}
|
|
|
443
447
|
`}Me.length>0&&(He+=`All Opened Editors: ${Me.join(", ")}`),Y.diagnostics&&(He+=`
|
|
444
448
|
**ACTIVE FILE ERRORS**:
|
|
445
449
|
${Y.diagnostics}
|
|
446
|
-
`),(
|
|
450
|
+
`),(F.toLowerCase().includes("lint")||F.toLowerCase().includes("warning"))&&Y.warnings&&(He+=`
|
|
447
451
|
**LINT WARNINGS**:
|
|
448
452
|
${Y.warnings}
|
|
449
453
|
`)}else He+="No file currently focused.";let Lr=`[SYSTEM METADATA (PRIORITY: DYNAMIC), Chat Context >> Metadata] Time: ${pe}
|
|
@@ -451,17 +455,17 @@ CWD: ${process.cwd()}${dn?` (WARNING: CWD Mismatch! Previous Path: ${ho})`:""}
|
|
|
451
455
|
**DIRECTORY STRUCTURE**
|
|
452
456
|
${Ht}${Ko}${nt}${He}
|
|
453
457
|
${l!="Fast"&&f==="Google"?`${e.toLowerCase().startsWith("gemma")?`[SYSTEM] **STRICTLY FOLLOW THINKING POLICY AS CRITICAL PRIORITY. DO NOT START A RESPONSE WITHOUT <think> ... </think>**
|
|
454
|
-
`:""}`:""}[USER] ${
|
|
458
|
+
`:""}`:""}[USER] ${F.replace(/\s*\[Prompted on:.*?\]/g,"").trim()}`.trim();I.push({role:"user",text:Lr});let jt=null,Yn=c==="Flux"?70:7,mt=16;yield{type:"status",content:"Connecting..."},er=!1;let ko=[],_t=!1;I.forEach(Q=>{Q.text&&Q.role==="agent"&&(Q.text=Q.text.replace(/(?:<(think|thought)>|\[(think|thought)\])[\s\S]*?(?:<\/(think|thought)>|\[\/(think|thought)\])/gi,"").trim())});for(let Q=0;Q<=Yn;Q++){if(_t=!1,u?.compression===0&&(a?.tokens||0)>v&&(I=ya(I,6)),Q>0&&(yield{type:"status",content:"Processed. Reconnecting..."}),er){yield{type:"status",content:"Termination Signal Received."},await new Promise(re=>setTimeout(re,1500));break}if(n){let re=await n();re&&(I.length>0&&I[I.length-1].role==="user"?I[I.length-1].text+=`
|
|
455
459
|
|
|
456
460
|
[STEERING HINT]: ${re}`:I.push({role:"user",text:`${l!="Fast"&&f==="Google"?`${e.toLowerCase().startsWith("gemma")?`[SYSTEM] **STRICTLY FOLLOW THINKING POLICY AS CRITICAL PRIORITY. DO NOT START A RESPONSE WITHOUT <think> ... </think>**
|
|
457
|
-
`:""}`:""}[STEERING HINT]: ${re}`}),yield{type:"status",content:"Steering Hint Injected."})}let Me,rt=!1,ne=1,xe=1,he="",st=null,
|
|
458
|
-
[SYSTEM] Tool result received. Analyze output and proceed with your turn${l!="Fast"&&f==="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+=
|
|
459
|
-
[SYSTEM] WARNING, Turn Limit Impending: Step ${ot}/${Yn}. Wrap up quickly/prompt user to continue & use [turn:finish] quickly.`)}let Tt=Ue;f==="OpenRouter"?Me=Si(t.apiKey,Gt,Tt,qo,l,c,h):f==="DeepSeek"?Me=Ti(t.apiKey,Gt,Tt,qo,l,c,h):Me=await
|
|
460
|
-
`).length;$=ue,X=Math.min(O,ue)}}catch{}let S=se.toLowerCase(),L=S.endsWith(".pdf"),
|
|
461
|
+
`:""}`:""}[STEERING HINT]: ${re}`}),yield{type:"status",content:"Steering Hint Injected."})}let Me,rt=!1,ne=1,xe=1,he="",st=null,Po=null,wt=null,ft=0,je=[],de=0,Nt=!1,it=!1,co=!1,pt=!1,un=!0,et="",at="",Ut=!1,Gt=e,qo="";for(;ne<=mt&&xe<=mt&&!rt&&!er;){let re=!1;try{he="",un&&(process.stdout.isTTY&&process.stdout.write("\x1B]0;Working...\x07"),yield{type:"turn_reset",content:!0},yield{type:"spinner",content:!0},un=!1,xe===1&&(et=""));let Ue=I.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 We=[{text:Se.text}];return Se.binaryPart&&yi(Gt)&&qt.slice(ot+1).filter(mn=>mn.role==="user"&&!mn.text?.startsWith("[TOOL RESULT]")).length<=2&&We.push(Se.binaryPart),{role:Se.role==="user"||Se.role==="system"?"user":"model",parts:We}});if(!await Ks("agent",t))throw new Error("Error: Quota Exausted for Agent");Gt=e,f==="DeepSeek"&&l==="Fast"&&(Gt="deepseek-chat"),ne===mt-1?(Gt=f==="DeepSeek"?"deepseek-v4-flash":"gemini-3-flash-preview",yield{type:"model_update",content:"Trying with fallback model"}):ne===mt?(Gt=f==="DeepSeek"?"deepseek-v4-pro":"gemini-3.5-flash",yield{type:"model_update",content:"Trying with fallback model"}):ne>12&&ne<mt-2&&t.apiKey!=="custom"?(Gt="gemma-4-31b-it",yield{type:"model_update",content:"Trying with fallback Gemma Model"}):ne>0&&(yield{type:"model_update",content:null}),qo=ua(r,(Gt||"gemma").toLowerCase().startsWith("gemma")?l:"GEM",c,u,T,D,f,h);let Re=e&&e.toLowerCase().startsWith("gemma"),lt=Ue[Ue.length-1];if(Re){let Se=`
|
|
462
|
+
[SYSTEM] Tool result received. Analyze output and proceed with your turn${l!="Fast"&&f==="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(Re){let Se=Math.floor(Yn*(c==="Flux"?.98:.7)),ot=Q+1;ot>=Se&<&<.parts?.[0]&&(lt.parts[0].text+=`
|
|
463
|
+
[SYSTEM] WARNING, Turn Limit Impending: Step ${ot}/${Yn}. Wrap up quickly/prompt user to continue & use [turn:finish] quickly.`)}let Tt=Ue;f==="OpenRouter"?Me=Si(t.apiKey,Gt,Tt,qo,l,c,h):f==="DeepSeek"?Me=Ti(t.apiKey,Gt,Tt,qo,l,c,h):Me=await tr.models.generateContentStream({model:Gt||"gemma-4-31b-it",contents:Tt,config:{systemInstruction:qo,temperature:c==="Flux"?1:1.4,maxOutputTokens:32768,mediaResolution:"MEDIA_RESOLUTION_MEDIUM",safetySettings:[{category:Cn.HARM_CATEGORY_HARASSMENT,threshold:bn.BLOCK_NONE},{category:Cn.HARM_CATEGORY_HATE_SPEECH,threshold:bn.BLOCK_NONE},{category:Cn.HARM_CATEGORY_SEXUALLY_EXPLICIT,threshold:bn.BLOCK_NONE},{category:Cn.HARM_CATEGORY_DANGEROUS_CONTENT,threshold:bn.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:Wo.MINIMAL}:{includeThoughts:!0,thinkingLevel:{Fast:Se.includes("pro")?Wo.LOW:Wo.MINIMAL,Low:Wo.LOW,Medium:Wo.MEDIUM,High:Wo.HIGH,xHigh:Wo.HIGH}[l]||Wo.MEDIUM};{let We={Fast:0,Low:512,Medium:2048,High:16384,xHigh:24576}[l]||2048;return We===0?{includeThoughts:!1}:{includeThoughts:!0,thinkingBudget:We}}})()}}),he="",st=null,wt=null,je=[],de=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 Me){if(er){yield{type:"status",content:"Termination Signal Received."},await new Promise(We=>setTimeout(We,1500));break}let ot="",qt=Se.candidates?.[0]?.content?.parts;if(qt&&qt.length>0)for(let We of qt)We.thought?We.text&&(re||(ot+="<think>",re=!0),ot+=We.text):We.text&&(re&&(ot+="</think>",re=!1),ot+=We.text);else{let We=Se.text||"";We&&re&&(ot+="</think>",re=!1),ot+=We}if(ot){if(Ut){if(at+=ot,at.length>=30){let z=0,ct=Math.min(et.length,at.length);for(let H=ct;H>0;H--)if(et.endsWith(at.substring(0,H))){z=H;break}let ht=at.substring(z);if(ht){let St=/(?:<(think|thought)>|\[(think|thought)\])(?:(?!(?:<\/(?:think|thought)>|\[\/(?:think|thought)\]))[\s\S])*$/i.test(et)?ht.replace(/^\s*(?:<(think|thought)>|\[(think|thought)\])\s*/gi,""):ht.replace(/^\s*(?:<(think|thought)>|\[(think|thought)\])[\s\S]*?(?:<\/(think|thought)>|\[\/(think|thought)\])\s*/gi,"").replace(/^\s*(?:<(think|thought)>|\[(think|thought)\])\s*/gi,"");St&&(he+=St,f==="Google"?tt+=St:yield{type:"text",content:St})}Ut=!1,at=""}continue}else he+=ot,f==="Google"?tt+=ot:yield{type:"text",content:ot};let We=tl(he),Io=Nc(he);if(Io.inside){wt||(wt=Date.now());let z=Io.toolName,ht={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"}[z]||z,H=Io.args||"",St=null;if(["write_file","update_file","view_file","read_folder","write_pdf","write_docx","search_keyword","generate_image"].includes(ht)){let Ne=oe(H),yo=Ne.path||Ne.targetFile||Ne.TargetFile||Ne.directory,Dn=Ne.keyword;if(Dn)St=Dn.replace(/["']/g,"");else if(yo)St=Ie.basename(yo.replace(/["']/g,"").replace(/\\/g,"/"));else{let vn=H.match(/(?:path|targetFile|TargetFile|directory|keyword)\s*=\s*\\?["']?([^\\"' \),]+)/);if(vn){let Oe=vn[1].replace(/["']/g,"");St=ht==="search_keyword"?Oe:Ie.basename(Oe.replace(/\\/g,"/"))}}}let Mt=`${el[ht]||ht}${St?` (${St})`:""}`;if((ht!==st||St!==Po)&&(st=ht,Po=St,yield{type:"status",content:`${Mt}...`},process.stdout.isTTY)){let yo={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"}[ht]||"Working";process.stdout.write(`\x1B]0;${yo}...\x07`)}}let mn=sl(he,!1),An=(mn.match(/(?:<think>|\[think\])([\s\S]*?)(?:<\/think>|\[\/think\]|$)/gi)||[]).join("").trim(),Vo=An.split(/[.!?]\s+/),$r=new Set(Vo),ir=Vo.length>10?(Vo.length-$r.size)/Vo.length:0,zo=An.split(/\s+/).filter(z=>z.length>0).length,ar=.4,lr=.6,Ln=!1;if((Gt||"").toLowerCase().startsWith("gemma")){let ct={low:256,medium:768,high:2048,max:4096,xhigh:4096}[l?.toLowerCase()]||2500;Ln=zo>ct}if(ir>ar||Ln){yield{type:"status",content:`${ir>ar?"Reasoning Loop Detected":"Thinking Budget Exceeded"}. Re-centering...`},it=!0,await new Promise(ct=>setTimeout(ct,3e3));break}let Mo=We.trim().split(/[.!?]\s+/),cr=new Set(Mo);if((Mo.length>10?(Mo.length-cr.size)/Mo.length:0)>lr){yield{type:"status",content:"Response Loop Detected. Re-centering..."},it=!1,pt=!0,await new Promise(z=>setTimeout(z,3e3));break}let Oo=mn.toLowerCase().split(/\s+/).filter(z=>z.length>0),Jo=!1;if(Oo.length>5)for(let z=1;z<=15;z++){let ct=Math.max(3,Math.ceil(8/z));if(Oo.length<z*ct)continue;let ht=!0,St=Oo.slice(Oo.length-z).join(" ");for(let Mt=1;Mt<ct;Mt++)if(Oo.slice(Oo.length-z*(Mt+1),Oo.length-z*Mt).join(" ")!==St){ht=!1;break}if(ht){Jo=!0;break}}if(!Jo){let z=mn.toLowerCase().replace(/[^a-z0-9]/gi,"");if(z.length>=10)for(let ct=1;ct<=10;ct++){let ht=Math.max(4,Math.ceil(12/ct));if(z.length<ct*ht)continue;let H=z.substring(z.length-ct),St=!0;for(let Mt=1;Mt<ht;Mt++)if(z.substring(z.length-ct*(Mt+1),z.length-ct*Mt)!==H){St=!1;break}if(St){Jo=!0;break}}}if(Jo){yield{type:"status",content:"Stuttering Detected. Re-centering..."},it=!1,co=!0,await new Promise(z=>setTimeout(z,3e3));break}let ws=he.replace(/(?:<(think|thought|thoughts)>|\[(think|thought|thoughts)\])[\s\S]*?(?:<\/(think|thought|thoughts)>|\[\/(think|thought|thoughts)\]|$)/gi,""),dr=Ei(ws);for(;dr.length>de;){let z=dr[de],ct=Date.now(),H={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"}[z.toolName]||z.toolName,St=el[H]||z.toolName,Mt=_c(H,z.args);yield{type:"status",content:`${St}${Mt?` (${Mt})`:""}...`};let Ne="";if(H==="web_search"){let{query:se,limit:Ae=10}=oe(z.args);Ne=`\u{1F50D} Searched: ${se}`}else if(H==="web_scrape")Ne=`\u{1F4D6} Visited: ${oe(z.args).url||"..."}`;else if(H==="view_file"){let{path:se,StartLine:Ae,EndLine:Qe,start_line:Ge,end_line:Ee,startLine:bt,endLine:x}=oe(z.args),g=Ae||Ge||bt,M=Qe||Ee||x,B=parseInt(g)||1,O=parseInt(M)||(g?B+800:800),$="...",X=O;try{let te=Ie.resolve(process.cwd(),se);if(Bt.existsSync(te)){let ue=Bt.readFileSync(te,"utf8").split(`
|
|
464
|
+
`).length;$=ue,X=Math.min(O,ue)}}catch{}let S=se.toLowerCase(),L=S.endsWith(".pdf"),P=S.endsWith(".docx")||S.endsWith(".doc")||S.endsWith(".ppt")||S.endsWith(".pptx")||S.endsWith(".xls")||S.endsWith(".xlsx"),j=/\.(png|jpg|jpeg|webp|gif|bmp)$/.test(S);L||P?Ne=`\u{1F4C4} Viewed: ${se}`:j?Ne=`\u{1F4F8} Viewed: ${se}`:Ne=`\u{1F4C4} Read: ${se} \u2192 Lines ${B} - ${X} of ${$}`}else if(H==="list_files"||H==="read_folder"){let se=H==="list_files"?"List":"Viewed",Ae=oe(z.args).path;Ne=`\u{1F4C2} ${se}: ${Ae==="."?"./":Ae}`}else if(H==="write_file"||H==="update_file")Ne=`\u{1F4BE} ${H==="write_file"?"Created":"Edited"}: ${oe(z.args).path||"..."}`;else if(H==="write_pdf")Ne=`\u{1F4D1} Created: ${oe(z.args).path||"..."}`;else if(H==="write_docx")Ne=`\u{1F4DD} Created: ${oe(z.args).path||"..."}`;else if(H==="search_keyword")Ne="";else if(H==="generate_image"){let{path:se,outputPath:Ae,output:Qe}=oe(z.args);Ne=`\u{1F3A8} Generated: ${se||Ae||Qe||"generated_image.png"}`}else H==="exec_command"||H==="ask"?Ne="":Ne=`Executed: ${z.toolName}`;if(H==="exec_command"){let{command:se}=oe(z.args);if(se&&t.systemSettings&&t.systemSettings.allowExternalAccess===!1){let Ae=[/[a-zA-Z]:[\\\/]/i,/^\//,/\.\.[\\\/]/,/\/etc\//,/\/var\//,/\/root\//,/\/bin\//,/\/usr\//],Qe=Ie.resolve(process.cwd()).substring(0,3).toLowerCase();if(Ae.some(Ee=>{if(Ee.source==="[a-zA-Z]:[\\\\\\/]"){let bt=se.match(/[a-zA-Z]:[\\\/]/i);return bt&&bt[0].toLowerCase()!==Qe}return Ee.test(se)})){let Ee='Access Denied. Terminal is prohibited from accessing system drives (C://) or external directories while "External Workspace Access" is disabled.';t.onExecStart&&t.onExecStart(se||"Unknown"),yield{type:"exec_start"},await new Promise(bt=>setTimeout(bt,50)),t.onExecChunk&&t.onExecChunk(`ERROR: ${Ee}`),await new Promise(bt=>setTimeout(bt,50)),t.onExecEnd&&t.onExecEnd(),je.push({role:"user",text:`[TOOL RESULT]: ERROR: ${Ee}`}),yield{type:"tool_result",content:`[TOOL RESULT]: ERROR: ${Ee}`},de++;continue}}t.onExecStart&&t.onExecStart(se||"Unknown"),yield{type:"exec_start"}}let yo=oe(z.args),Dn=yo.path||yo.targetPath||null;if(Dn){let se=t.systemSettings&&t.systemSettings.allowExternalAccess===!1,Ae=Ie.resolve(Dn),Qe=Ie.resolve(process.cwd());if(se&&!Ae.startsWith(Qe)){let Ge="Access Denied. You are not allowed to access files outside the current workspace.";if(H==="write_file"||H==="update_file"){let bt=`\u{1F4BE} ${H==="write_file"?"Write Canceled":"Edit Canceled"}: ${yo.path||"..."}`,x=Math.min(bt.length+4,115),g=`\u256D${"\u2500".repeat(x)}\u256E`,M=`\u2502 ${bt.padEnd(x-2).substring(0,x-2)} \u2502`,B=`\u2570${"\u2500".repeat(x)}\u256F`;yield{type:"visual_feedback",content:`${g}
|
|
461
465
|
${M}
|
|
462
|
-
${B}`}}je.push({role:"user",text:`[TOOL RESULT]: ERROR: ${Ge}`}),yield{type:"tool_result",content:`[TOOL RESULT]: ERROR: ${Ge}`},de++;continue}}if(t.onToolApproval&&(H==="write_file"||H==="update_file"||H==="exec_command")){let Ae=t.systemSettings||{},Qe=Ae.autoExec,Ge=null,Ee=!1,bt=!1,x=!1;if(H==="exec_command"){let{command:S}=oe(z.args),L=(S||"").trim(),
|
|
466
|
+
${B}`}}je.push({role:"user",text:`[TOOL RESULT]: ERROR: ${Ge}`}),yield{type:"tool_result",content:`[TOOL RESULT]: ERROR: ${Ge}`},de++;continue}}if(t.onToolApproval&&(H==="write_file"||H==="update_file"||H==="exec_command")){let Ae=t.systemSettings||{},Qe=Ae.autoExec,Ge=null,Ee=!1,bt=!1,x=!1;if(H==="exec_command"){let{command:S}=oe(z.args),L=(S||"").trim(),P=(be,ue)=>{if(!ue)return!1;let Fe=ue.split(",").map($e=>$e.trim().toLowerCase()).filter(Boolean),Be=be.toLowerCase();return Fe.some($e=>Be.startsWith($e))},j=P(L,Ae.alwaysAskCommands),te=P(L,Ae.autoApproveCommands);bt=P(L,Ae.autoDisallowCommands),j?Ee=!0:(te||Ae.autoApproveGit&&/^git\s+commit\b/i.test(L))&&(Ge="allow"),!Ee&&!Ge&&(Ae.networkAccess===!1&&/\b(curl|wget|npm|yarn|pnpm|pip|pip3|ssh|docker|git\s+(clone|push|pull|fetch))\b/i.test(L)&&(Ge="deny",x=!0),!Ge&&bt&&(Ge="deny")),!Ee&&!Ge&&Qe&&(Ge="allow")}else Qe&&(Ge="allow");let g=Ge,M="";Ge==="deny"&&(x?M="network":bt?M="settings":M="prohibited");let B=!1,O="",$=[],X=0;if(!g){if(H==="write_file"||H==="update_file")try{let S=oe(z.args),{path:L}=S;if(L){let P=Ie.resolve(process.cwd(),L),j=$e=>$e?$e.toLowerCase().replace(/\\/g,"/").replace(/^[a-z]:/,Vt=>Vt.toUpperCase()):"",te=j(P),be="",ue=!1,Fe=await Mr(),Be=j(Fe?.file_focused);if(Fe&&Be===te&&Fe.full_content?(be=Fe.full_content,ue=!0):Bt.existsSync(P)&&(be=Bt.readFileSync(P,"utf8"),ue=!0),O=be,await Et.recordFileChange(P,be),ue){let $e=be;if(H==="write_file")$e=S.content||S.newContent||"";else{let{patchPairs:Vt,error:Qo}=Nr(S);if(Qo){let Ot=`[TOOL RESULT]: ERROR: ${Qo}`;je.push({role:"user",text:Ot}),yield{type:"tool_result",content:Ot,toolName:H},de++;continue}X=Vt.length;let Ao=Ur(be,Vt);$e=Ao.content,$=Ao.results;let Fo=$.filter(Ot=>!Ot.success);if(Fo.length>0){let Ot=`[TOOL RESULT]: ERROR: Failed to apply patches to [${Ie.basename(P)}].\\n${Fo.map(Le=>` \u2022 ${Le.error}`).join("\\n")}`,mr=`\u{1F4BE} Edited: ${Ie.basename(P)}`.toUpperCase(),Zo=Math.min(mr.length+4,115),R=`\u256D${"\u2500".repeat(Zo)}\u256E`,ae=`\u2502 ${mr.padEnd(Zo-2).substring(0,Zo-2)} \u2502`,ge=`\u2570${"\u2500".repeat(Zo)}\u256F`;yield{type:"visual_feedback",content:`${R}
|
|
463
467
|
${ae}
|
|
464
|
-
${ge}`},je.push({role:"user",text:Ot}),yield{type:"tool_result",content:Ot,toolName:H},de++;continue}}yield{type:"status",content:`Opening Diff in IDE: ${Ie.basename(
|
|
468
|
+
${ge}`},je.push({role:"user",text:Ot}),yield{type:"tool_result",content:Ot,toolName:H},de++;continue}}yield{type:"status",content:`Opening Diff in IDE: ${Ie.basename(P)}...`},gi(P,be,$e),B=!0,await new Promise(Vt=>setTimeout(Vt,50))}else if(H==="write_file"){let $e=S.content||S.newContent||"";yield{type:"status",content:`Opening New File Diff in IDE: ${Ie.basename(P)}...`},gi(P,"",$e),B=!0,await new Promise(Vt=>setTimeout(Vt,50))}}}catch(S){console.error("Simulation/Diff Error:",S)}if(g=await t.onToolApproval(H,z.args),H==="write_file"||H==="update_file"){let{path:S}=oe(z.args);if(S){let L=Ie.resolve(process.cwd(),S);Za(L,g)}}g==="deny"&&(M="user")}if(g==="allow"&&B&&Ro()){let{path:S}=oe(z.args),L=Ie.resolve(process.cwd(),S),P=await Mr(),j="";P&&P.file_focused===L&&P.full_content?j=P.full_content:Bt.existsSync(L)&&(j=Bt.readFileSync(L,"utf8"));let te=j.split(/\r?\n/),be=te.length,ue=Buffer.byteLength(j,"utf8"),Fe="";O&&(Fe=`Old File contents:
|
|
465
469
|
${O.split(/\r?\n/).map((ge,Le)=>`${Le+1} | ${ge}`).join(`
|
|
466
470
|
`)}
|
|
467
471
|
|
|
@@ -491,16 +495,16 @@ ${Xe}`}$e=`SUCCESS: File [${S}] saved via IDE Companion (May have user edits).
|
|
|
491
495
|
${vt}- Content Preview:
|
|
492
496
|
${me}
|
|
493
497
|
|
|
494
|
-
Check if Starting and Ending matches your write.`}let Qo=`\u{1F4BE} ${H==="write_file"?"Written":"Edited"}: ${S||"..."}`,Ao=Math.min(Qo.length+4,115),
|
|
498
|
+
Check if Starting and Ending matches your write.`}let Qo=`\u{1F4BE} ${H==="write_file"?"Written":"Edited"}: ${S||"..."}`,Ao=Math.min(Qo.length+4,115),Fo=`\u256D${"\u2500".repeat(Ao)}\u256E`,Ot=`\u2502 ${Qo.padEnd(Ao-2).substring(0,Ao-2)} \u2502`,mr=`\u2570${"\u2500".repeat(Ao)}\u256F`;yield{type:"visual_feedback",content:`${Fo}
|
|
495
499
|
${Ot}
|
|
496
|
-
${mr}`};let Zo=Date.now();ft=Zo,yield{type:"tool_time",content:Zo-ct};let R=`[TOOL RESULT]: ${$e}`;je.push({role:"user",text:R}),Nt=!0,yield{type:"tool_result",content:$e,aiContent:R,toolName:H},de++;continue}if(g==="deny"){let S=`Permission Denied: Prohibited ${H==="exec_command"?"Command":"file edit"}.`;if(M==="user"?S="Permission Denied by User":M==="settings"?S="Permission Denied by User Policy":M==="network"?S="Permission Denied: Sandbox Network Access Disabled by User Policy.":M==="prohibited"&&H==="exec_command"&&(S="Permission Denied: Prohibited Command"),H==="write_file"||H==="update_file"){let
|
|
500
|
+
${mr}`};let Zo=Date.now();ft=Zo,yield{type:"tool_time",content:Zo-ct};let R=`[TOOL RESULT]: ${$e}`;je.push({role:"user",text:R}),Nt=!0,yield{type:"tool_result",content:$e,aiContent:R,toolName:H},de++;continue}if(g==="deny"){let S=`Permission Denied: Prohibited ${H==="exec_command"?"Command":"file edit"}.`;if(M==="user"?S="Permission Denied by User":M==="settings"?S="Permission Denied by User Policy":M==="network"?S="Permission Denied: Sandbox Network Access Disabled by User Policy.":M==="prohibited"&&H==="exec_command"&&(S="Permission Denied: Prohibited Command"),H==="write_file"||H==="update_file"){let P=`\u{1F4BE} ${H==="write_file"?"WRITE DENIED":"UPDATE DENIED"}: ${oe(z.args).path||"..."}`.toUpperCase(),j=Math.min(P.length+4,115),te=`\u256D${"\u2500".repeat(j)}\u256E`,be=`\u2502 ${P.padEnd(j-2).substring(0,j-2)} \u2502`,ue=`\u2570${"\u2500".repeat(j)}\u256F`;yield{type:"visual_feedback",content:`${te}
|
|
497
501
|
${be}
|
|
498
502
|
${ue}`}}H==="exec_command"&&(await new Promise(L=>setTimeout(L,50)),t.onExecChunk&&t.onExecChunk(`ERROR: ${S}`),await new Promise(L=>setTimeout(L,50)),t.onExecEnd&&t.onExecEnd()),je.push({role:"user",text:`[TOOL RESULT]: DENIED: ${S}`}),yield{type:"tool_result",content:`[TOOL RESULT]: DENIED: ${S}`},await Nn("toolDenied"),t.onToolResult&&t.onToolResult("denied",H),de++;continue}}if(Ne){let se=Math.min(Ne.length+4,115),Ae=`\u256D${"\u2500".repeat(se)}\u256E`,Qe=`\u2502 ${Ne.padEnd(se-2).substring(0,se-2)} \u2502`,Ge=`\u2570${"\u2500".repeat(se)}\u256F`;yield{type:"visual_feedback",content:`${Ae}
|
|
499
503
|
${Qe}
|
|
500
|
-
${Ge}`}}if(ft>0){let se=Date.now()-ft;se<1e3&&await new Promise(Ae=>setTimeout(Ae,1e3-se))}yield{type:"spinner",content:!1};let vn={chatId:d,history:o,onChunk:se=>t.onExecChunk?t.onExecChunk(se):null,onAskUser:t.onAskUser,systemSettings:t.systemSettings,mode:c,isMultiModal:yi(Gt)};if(H==="write_file"||H==="update_file")try{let{path:se}=oe(z.args);if(se){let Ae=Ie.resolve(process.cwd(),se),Qe=await Mr();Qe&&Qe.file_focused===Ae&&Qe.full_content&&(vn.forcedContent=Qe.full_content)}}catch{}let Oe=await is(H,z.args,vn);if(yield{type:"spinner",content:!0},H==="write_file"&&Oe.startsWith("SUCCESS")){let{path:se}=oe(z.args);se&&Qa(se)}process.stdout.isTTY&&process.stdout.write("\x1B]0;Working...\x07");let N=Date.now();ft=N,yield{type:"tool_time",content:N-ct},wt=N;let
|
|
504
|
+
${Ge}`}}if(ft>0){let se=Date.now()-ft;se<1e3&&await new Promise(Ae=>setTimeout(Ae,1e3-se))}yield{type:"spinner",content:!1};let vn={chatId:d,history:o,onChunk:se=>t.onExecChunk?t.onExecChunk(se):null,onAskUser:t.onAskUser,systemSettings:t.systemSettings,mode:c,isMultiModal:yi(Gt)};if(H==="write_file"||H==="update_file")try{let{path:se}=oe(z.args);if(se){let Ae=Ie.resolve(process.cwd(),se),Qe=await Mr();Qe&&Qe.file_focused===Ae&&Qe.full_content&&(vn.forcedContent=Qe.full_content)}}catch{}let Oe=await is(H,z.args,vn);if(yield{type:"spinner",content:!0},H==="write_file"&&Oe.startsWith("SUCCESS")){let{path:se}=oe(z.args);se&&Qa(se)}process.stdout.isTTY&&process.stdout.write("\x1B]0;Working...\x07");let N=Date.now();ft=N,yield{type:"tool_time",content:N-ct},wt=N;let wo=null;if(typeof Oe=="object"&&Oe.binaryPart&&(wo=Oe.binaryPart,Oe=Oe.text),H==="search_keyword"){let{keyword:se,file:Ae}=oe(z.args),Qe=0;if(Oe){let M=Oe.match(/Found (\d+) matches/i);M&&(Qe=parseInt(M[1]))}let Ge=`\u{1F50E} Searched: "${se}" in ${Ae?`"${Ae}"`:"./"} \u2192 ${Qe} Match${Qe===1?"":"es"}`,Ee=Math.min(Ge.length+4,115),bt=`\u256D${"\u2500".repeat(Ee)}\u256E`,x=`\u2502 ${Ge.padEnd(Ee-2).substring(0,Ee-2)} \u2502`,g=`\u2570${"\u2500".repeat(Ee)}\u256F`;yield{type:"visual_feedback",content:`${bt}
|
|
501
505
|
${x}
|
|
502
|
-
${g}`}}H==="exec_command"&&t.onExecEnd&&(await new Promise(se=>setTimeout(se,800)),t.onExecEnd());let ur=Oe&&Oe.startsWith("DENIED:");Oe&&!Oe.startsWith("ERROR:")&&!ur?(await Nn("toolSuccess"),t.onToolResult&&t.onToolResult("success",H)):ur||(await Nn("toolFailure"),t.onToolResult&&t.onToolResult("failure",H));let
|
|
503
|
-
`)}`;je.push({role:"user",text:
|
|
506
|
+
${g}`}}H==="exec_command"&&t.onExecEnd&&(await new Promise(se=>setTimeout(se,800)),t.onExecEnd());let ur=Oe&&Oe.startsWith("DENIED:");Oe&&!Oe.startsWith("ERROR:")&&!ur?(await Nn("toolSuccess"),t.onToolResult&&t.onToolResult("success",H)):ur||(await Nn("toolFailure"),t.onToolResult&&t.onToolResult("failure",H));let Pr=`[TOOL RESULT]: ${(Oe||"").toString().split(/\r?\n/).filter(se=>!se.includes("[UI_CONTEXT]")).join(`
|
|
507
|
+
`)}`;je.push({role:"user",text:Pr,binaryPart:wo}),Nt=!0;let Fr=`[TOOL RESULT]: ${Oe||""}`;(H==="view_file"||H==="web_scrape")&&(Fr=`[TOOL RESULT]: ${Ne} (Context Locked for UI Clarity)`),yield{type:"tool_result",content:Fr,aiContent:Pr,binaryPart:wo,toolName:H},H==="memory"&&Oe.includes("SUCCESS")&&(yield{type:"memory_updated"}),de++}f==="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(re&&(re=!1,Ut?at+="</think>":(he+="</think>",f==="Google"?tt+="</think>":yield{type:"text",content:"</think>"})),Ut&&at.length>0){let Se=0,ot=Math.min(et.length,at.length);for(let We=ot;We>0;We--)if(et.endsWith(at.substring(0,We))){Se=We;break}let qt=at.substring(Se);if(qt){let Io=/(?:<(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,"");Io&&(he+=Io,f==="Google"?tt+=Io:yield{type:"text",content:Io})}Ut=!1,at=""}if(f==="Google"&&tt&&(yield{type:"text",content:tt},tt=""),er)break;let go=(he||"").trim(),Kt=/\[\s*(turn\s*:)?\s*finish\s*\]/i.test(go.toLowerCase()),Dt=/\[\s*(turn\s*:)?\s*continue\s*\]/i.test(go.toLowerCase()),ro=je.length>0||st!==null,xo=go.replace(/(?:<think>|\[think\])[\s\S]*?(?:<\/think>|\[\/think\])/gi,"").trim(),On=/(\p{Emoji_Presentation}|\p{Extended_Pictographic})$/u.test(xo),vr=/[.!?}"'`’“”]$|```$/s.test(xo)||xo.endsWith('."')||On;if(!Kt&&!Dt&&!ro&&go.length>0&&!vr&&!it&&!co&&!pt)throw new Error("Silent stream cutoff (500): Model stream closed cleanly but cut off mid-sentence without signals.");rt=!0,await Nn("agent")}catch(Ue){if(String(Ue).includes("Incomplete JSON segment at the end")){re&&(re=!1,Ut?at+="</think>":(he+="</think>",yield{type:"text",content:"</think>"})),rt=!0,await Nn("agent");break}if(re&&(re=!1,Ut?at+="</think>":he+="</think>"),Ut&&at.length>0){let Kt=0,Dt=Math.min(et.length,at.length);for(let xo=Dt;xo>0;xo--)if(et.endsWith(at.substring(0,xo))){Kt=xo;break}let ro=at.substring(Kt);if(ro){let On=/(?:<(think|thought)>|\[(think|thought)\])(?:(?!(?:<\/(?:think|thought)>|\[\/(?:think|thought)\]))[\s\S])*$/i.test(et)?ro.replace(/^\s*(?:<(think|thought)>|\[(think|thought)\])\s*/gi,""):ro.replace(/^\s*(?:<(think|thought)>|\[(think|thought)\])[\s\S]*?(?:<\/(think|thought)>|\[\/(think|thought)\])\s*/gi,"").replace(/^\s*(?:<(think|thought)>|\[(think|thought)\])\s*/gi,"");On&&(he+=On)}Ut=!1,at=""}let Re=Ue.status||Ue.error&&Ue.error.message||String(Ue),lt=String(Ue),Tt=new Date().toLocaleString(),tt=Ie.join(Co,"agent");Bt.existsSync(tt)||Bt.mkdirSync(tt,{recursive:!0}),Bt.appendFileSync(Ie.join(tt,"error.log"),`ERROR [${Tt}]: ${lt}
|
|
504
508
|
|
|
505
509
|
----------------------------------------------------------------------
|
|
506
510
|
|
|
@@ -509,45 +513,45 @@ ${g}`}}H==="exec_command"&&t.onExecEnd&&(await new Promise(se=>setTimeout(se,800
|
|
|
509
513
|
- NO REPETITION: Do not repeat any text already written
|
|
510
514
|
- NO RE-THINK: Do not restart or open <think> if reasoning already started. Continue the thinking and close thinking block with </think> if opened
|
|
511
515
|
- MID-TOOL SAFETY: If cutoff was mid-tool call, restart that tool call from start
|
|
512
|
-
- STEALTH: Do not mention/apologize for cutoff`;je.length>0?je.forEach((ro,
|
|
516
|
+
- STEALTH: Do not mention/apologize for cutoff`;je.length>0?je.forEach((ro,xo)=>{xo===je.length-1?I.push({...ro,text:`${ro.text}
|
|
513
517
|
|
|
514
518
|
${Dt}`}):I.push(ro)}):I.push({role:"user",text:Dt}),et+=he}for(let Dt=Kt/1e3;Dt>0;Dt--)yield{type:"status",content:`Error Occured. Recovering Stream (${xe}/${mt}) [Retrying in ${Dt}s]...`},await new Promise(ro=>setTimeout(ro,1e3));yield{type:"status",content:"Error Occured. Recovering Stream..."}}else throw new Error(`Stream collapsed too many times. (Failed to resolve ${mt} times)
|
|
515
|
-
Error Log can be found in ${Ie.join(
|
|
516
|
-
Error Log can be found in ${Ie.join(
|
|
517
|
-
`),Ue=re.replace(/(?:<think>|\[think\])[\s\S]*?(?:<\/think>|\[\/think\])/g,"").trim();yield{type:"interactive_turn_finished",data:{agentText:
|
|
519
|
+
Error Log can be found in ${Ie.join(Co,"agent","error.log")}`);else if(ne<=mt){ne++,xe=1,et="";let Kt=Math.min(1e3*Math.pow(2,ne-1),32e3);un=!0,yield{type:"status",content:`Trying to reach ${e} (${ne}/${mt}) [Retrying in ${(Kt/1e3).toFixed(0)}s]...`};for(let Dt=Kt/1e3;Dt>0;Dt--)yield{type:"status",content:`Trying to reach ${e} (${ne}/${mt}) [Retrying in ${Dt}s]...`},await new Promise(ro=>setTimeout(ro,1e3));yield{type:"status",content:`Trying to reach ${e}...`}}else throw new Error(`Model ${e} cannot be reached. (Failed ${mt} times)
|
|
520
|
+
Error Log can be found in ${Ie.join(Co,"agent","error.log")}`)}}if(jt){let re=jt.totalTokenCount||0,Ue=jt.cachedContentTokenCount||0,Re=(jt.candidatesTokenCount||0)+(jt.thoughtsTokenCount||0);await fo("tokens",re),Ue>0&&await fo("cachedTokens",Ue),Re>0&&await fo("candidateTokens",Re),yield{type:"usage",content:jt}}ko.push(he);let hs=he;he.match(/(?:<think>|\[think\])([\s\S]*?)(?:<\/think>|\[\/think\])/i)&&(hs=he.replace(/(?:<think>|\[think\])[\s\S]*?(?:<\/think>|\[\/think\])/i,""));let Dr=tl(he),Hn=/\[\s*(turn\s*:)?\s*finish\s*\]/i.test(Dr.toLowerCase()),Li=/\[\s*(turn\s*:)?\s*continue\s*\]/i.test(Dr.toLowerCase()),rr=de>0;yield{type:"status",content:"Working..."};let gs=Uc(he,/\[\s*(turn\s*:)?\s*(continue|finish)\s*\]/gi,"").trim(),sr=(Hn||je.length===0)&&!it&&!co&&!pt;if(sr){let re=ko.join(`
|
|
521
|
+
`),Ue=re.replace(/(?:<think>|\[think\])[\s\S]*?(?:<\/think>|\[\/think\])/g,"").trim();yield{type:"interactive_turn_finished",data:{agentText:F,fullAgentTextRaw:re,history:[...I],needTitle:K}},I.length>0&&I[I.length-1].role==="agent"?I[I.length-1].text=Ue:I.push({role:"agent",text:Ue});try{let Re=we(E,{}),lt=Re[d]||{summary:"",historyLength:0};typeof lt=="string"&&(lt={summary:lt,historyLength:0});let Tt=I.filter(tt=>(tt.role==="user"||tt.role==="agent"||tt.role==="system")&&!String(tt.id).startsWith("welcome")&&!tt.isMeta).length;k?lt.historyLength=(lt.historyLength||0)+Tt:lt.historyLength=Tt,Re[d]=lt,ke(E,Re)}catch{}}if(sr)break;let xs=gs.trim()||"*Working...*";if(I.push({role:"agent",text:xs}),je.length>0||Nt){if(je.length>0){let re=je.map(Re=>Re.text).join(`
|
|
518
522
|
|
|
519
523
|
`),Ue=je.find(Re=>Re.binaryPart)?.binaryPart||null;I.push({role:"user",text:re,binaryPart:Ue})}}else _t?I.push({role:"user",text:"[SYSTEM] Failed to verify tool execution, Verify tool syntax, proper escaping or ask user if tool worked if unsure"}):I.push({role:"user",text:`[SYSTEM] ${co&&!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 the execution/output":"If you have finished your task use [turn: finish] else continue"}`}`}),it=!1,co=!1,pt=!1;_t=de>0||Nt}e&&e.toLowerCase().startsWith("gemma")&&I.forEach(Q=>{if(Q.role==="user"&&Q.text&&Q.text.startsWith("[TOOL RESULT]")){let Me=`
|
|
520
524
|
[SYSTEM] Tool result received. Analyze output and proceed with your turn`,rt=`
|
|
521
|
-
[SYSTEM] Tool result received. Analyze output and proceed with your turn. **STRICTLY MAINTAIN THINKING POLICY. DO NOT START A RESPONSE WITHOUT <think> ... </think>}**`;Q.text=Q.text.replace(rt,"").replace(Me,"").trim()}})}finally{await Et.commitTransaction()}yield{type:"status",content:null}}});import Lt,{useState as bi,useEffect as Wc}from"react";import{Box as Yo,Text as kn,useInput as Yc}from"ink";function Ci({onSelect:e,onDelete:o,onClose:t}){let[n,i]=bi({}),[r,l]=bi([]),[c,m]=bi(0);Wc(()=>{(async()=>{let h=await $o();i(h),l(Object.keys(h).sort((T,w)=>(h[w].updatedAt||0)-(h[T].updatedAt||0)))})()},[]),Yc((p,h)=>{if(h.escape&&t(),h.upArrow&&m(T=>Math.max(0,T-1)),h.downArrow&&m(T=>Math.min(r.length-1,T+1)),h.return&&r[c]&&e(r[c]),p==="x"&&r[c]){let T=r[c];o(T).then(w=>{let E=w||{};i(E);let k=Object.keys(E).sort((D,_)=>(E[_]?.updatedAt||0)-(E[D]?.updatedAt||0));l(k),m(D=>Math.max(0,Math.min(k.length-1,D)))})}});let d=Ce(2),u=15,a=0;if(r.length>u){let p=Math.floor(u/2);a=c-p,a<0?a=0:a+u>r.length&&(a=r.length-u)}let f=r.slice(a,a+u);return Lt.createElement(Yo,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},Lt.createElement(Yo,{paddingX:1,marginBottom:1},Lt.createElement(kn,{color:"cyan",bold:!0},"\u{1F4A0} CHAT HISTORY: RESUME CONVERSATION")),r.length===0?Lt.createElement(Yo,{paddingX:2,paddingY:1},Lt.createElement(kn,{italic:!0,color:"gray"},"No saved chats found.")):Lt.createElement(Yo,{flexDirection:"column",width:"100%"},a>0&&Lt.createElement(Yo,{paddingX:2,marginBottom:1},Lt.createElement(kn,{color:"gray",dimColor:!0},"\u25B2 (+",a," more chats above)")),f.map((p,h)=>{let T=n[p],E=a+h===c,k=Hc(T?.updatedAt);return Lt.createElement(Yo,{key:p,paddingX:1,backgroundColor:E?"#2a2a2a":void 0,width:"100%"},Lt.createElement(Yo,{flexGrow:1},Lt.createElement(kn,{color:E?"cyan":"white",bold:E},E?"\u276F ":" ",T?.name||p,Lt.createElement(kn,{color:"gray",dimColor:!E}," [",k," \u2022 ",p.slice(5),"]"))),E&&Lt.createElement(Yo,{flexShrink:0},Lt.createElement(kn,{color:"red",bold:!0},"[X] DELETE ")))}),a+u<r.length&&Lt.createElement(Yo,{paddingX:2,marginTop:1},Lt.createElement(kn,{color:"gray",dimColor:!0},"\u25BC (+",r.length-(a+u)," more chats below)"))),Lt.createElement(Yo,{marginTop:1,paddingX:1,borderStyle:"single",borderLeft:!1,borderRight:!1,borderBottom:!1,borderColor:"gray"},Lt.createElement(kn,{dimColor:!0,italic:!0},"\u2191\u2193 navigate \u2022 Enter select \u2022 x delete \u2022 Esc close")))}function Hc(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 ll=ie(()=>{Er();hn()});import kt,{useState as ki,useEffect as jc}from"react";import{Box as Ho,Text as ln,useInput as Gc}from"ink";function Ii({onClose:e}){let[o,t]=ki([]),[n,i]=ki(0),[r,l]=ki(!0),c=()=>{let E=we(
|
|
525
|
+
[SYSTEM] Tool result received. Analyze output and proceed with your turn. **STRICTLY MAINTAIN THINKING POLICY. DO NOT START A RESPONSE WITHOUT <think> ... </think>}**`;Q.text=Q.text.replace(rt,"").replace(Me,"").trim()}})}finally{await Et.commitTransaction()}yield{type:"status",content:null}}});import Lt,{useState as bi,useEffect as Wc}from"react";import{Box as Yo,Text as kn,useInput as Yc}from"ink";function Ci({onSelect:e,onDelete:o,onClose:t}){let[n,i]=bi({}),[r,l]=bi([]),[c,m]=bi(0);Wc(()=>{(async()=>{let h=await $o();i(h),l(Object.keys(h).sort((T,w)=>(h[w].updatedAt||0)-(h[T].updatedAt||0)))})()},[]),Yc((p,h)=>{if(h.escape&&t(),h.upArrow&&m(T=>Math.max(0,T-1)),h.downArrow&&m(T=>Math.min(r.length-1,T+1)),h.return&&r[c]&&e(r[c]),p==="x"&&r[c]){let T=r[c];o(T).then(w=>{let E=w||{};i(E);let k=Object.keys(E).sort((D,_)=>(E[_]?.updatedAt||0)-(E[D]?.updatedAt||0));l(k),m(D=>Math.max(0,Math.min(k.length-1,D)))})}});let d=Ce(2),u=15,a=0;if(r.length>u){let p=Math.floor(u/2);a=c-p,a<0?a=0:a+u>r.length&&(a=r.length-u)}let f=r.slice(a,a+u);return Lt.createElement(Yo,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},Lt.createElement(Yo,{paddingX:1,marginBottom:1},Lt.createElement(kn,{color:"cyan",bold:!0},"\u{1F4A0} CHAT HISTORY: RESUME CONVERSATION")),r.length===0?Lt.createElement(Yo,{paddingX:2,paddingY:1},Lt.createElement(kn,{italic:!0,color:"gray"},"No saved chats found.")):Lt.createElement(Yo,{flexDirection:"column",width:"100%"},a>0&&Lt.createElement(Yo,{paddingX:2,marginBottom:1},Lt.createElement(kn,{color:"gray",dimColor:!0},"\u25B2 (+",a," more chats above)")),f.map((p,h)=>{let T=n[p],E=a+h===c,k=Hc(T?.updatedAt);return Lt.createElement(Yo,{key:p,paddingX:1,backgroundColor:E?"#2a2a2a":void 0,width:"100%"},Lt.createElement(Yo,{flexGrow:1},Lt.createElement(kn,{color:E?"cyan":"white",bold:E},E?"\u276F ":" ",T?.name||p,Lt.createElement(kn,{color:"gray",dimColor:!E}," [",k," \u2022 ",p.slice(5),"]"))),E&&Lt.createElement(Yo,{flexShrink:0},Lt.createElement(kn,{color:"red",bold:!0},"[X] DELETE ")))}),a+u<r.length&&Lt.createElement(Yo,{paddingX:2,marginTop:1},Lt.createElement(kn,{color:"gray",dimColor:!0},"\u25BC (+",r.length-(a+u)," more chats below)"))),Lt.createElement(Yo,{marginTop:1,paddingX:1,borderStyle:"single",borderLeft:!1,borderRight:!1,borderBottom:!1,borderColor:"gray"},Lt.createElement(kn,{dimColor:!0,italic:!0},"\u2191\u2193 navigate \u2022 Enter select \u2022 x delete \u2022 Esc close")))}function Hc(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 ll=ie(()=>{Er();hn()});import kt,{useState as ki,useEffect as jc}from"react";import{Box as Ho,Text as ln,useInput as Gc}from"ink";function Ii({onClose:e}){let[o,t]=ki([]),[n,i]=ki(0),[r,l]=ki(!0),c=()=>{let E=we(Ft,[]);t(E);try{let D=Kr(Zt,{}).systemSettings?.memory!==!1;l(D)}catch{l(!0)}};jc(()=>{c()},[]),Gc((E,k)=>{if(k.escape&&e(),k.upArrow&&i(D=>Math.max(0,D-1)),k.downArrow&&i(D=>Math.min(o.length-1,D+1)),E==="x"&&o.length>0){let D=o[n].id,_=o.filter(K=>K.id!==D);ke(Ft,_),t(_),n>=_.length&&_.length>0&&i(_.length-1)}});let m=E=>E?E.replace(/\[Saved on: .*?\]/g,"").replace(/\\+'/g,"'").trim():"",d=4*1024*2,u=o.reduce((E,k)=>E+(k.memory?.length||0),0),a=Math.min(100,Math.round(u/d*100)),f=12,p=Math.round(a/100*f),h="\u2588".repeat(p)+"\u2591".repeat(Math.max(0,f-p)),T=()=>a<50?"green":a<90?"yellow":"red",w=Ce(2);return kt.createElement(Ho,{flexDirection:"column",borderStyle:"round",borderColor:"gray",padding:0,width:"100%"},kt.createElement(Ho,{paddingX:1,marginBottom:1,justifyContent:"space-between"},kt.createElement(ln,{color:"cyan",bold:!0},"\u{1F9E0} AGENT MEMORY: LONG-TERM KNOWLEDGE"),kt.createElement(Ho,null,kt.createElement(ln,{color:"gray"},"Vault: "),kt.createElement(ln,{color:T()},h),kt.createElement(ln,{color:"white",bold:!0}," ",a,"%"))),!r&&o.length>0?kt.createElement(Ho,{paddingX:2,paddingY:1},kt.createElement(ln,{italic:!0,color:"gray"},"Memory is currently Off...")):o.length===0?kt.createElement(Ho,{paddingX:2,paddingY:1},kt.createElement(ln,{italic:!0,color:"gray"},r?"Learning...":"Memory not available...")):kt.createElement(Ho,{flexDirection:"column"},o.map((E,k)=>{let D=k===n;return kt.createElement(Ho,{key:E.id,paddingX:1,backgroundColor:D?"#2a2a2a":void 0,width:"100%"},kt.createElement(Ho,{flexGrow:1},kt.createElement(ln,{color:D?"cyan":"white",bold:D},D?"\u276F ":" ",k+1,". ",m(E.memory))),D&&kt.createElement(Ho,{flexShrink:0},kt.createElement(ln,{color:"red",bold:!0},"[X] WIPE ")))})),kt.createElement(Ho,{marginTop:1,paddingX:1,borderStyle:"single",borderLeft:!1,borderRight:!1,borderBottom:!1,borderColor:"gray"},kt.createElement(ln,{dimColor:!0,italic:!0},"\u2191\u2193 navigate \u2022 x wipe memory \u2022 Esc close")))}var cl=ie(()=>{vo();to();hn()});import Ze,{useState as ds,useEffect as dl}from"react";import{Box as In,Text as Yt}from"ink";import{spawn as ul}from"child_process";var us,ml,Xc,fl,pl=ie(async()=>{us=null;try{let e=await import("node-pty");us=e.default||e,us=!1}catch{}ml=["\u280B","\u2819","\u2839","\u2838","\u283C","\u2834","\u2826","\u2827","\u2807","\u280F"],Xc=({latest:e,current:o,settings:t,onClose:n,onUpdateSettings:i,onSuccess:r})=>{let[l,c]=ds("initializing"),[m,d]=ds(""),[u,a]=ds(null),[f,p]=ds(0);if(dl(()=>{let h=setInterval(()=>{p(T=>(T+1)%1e3)},33);return()=>clearInterval(h)},[]),dl(()=>{let h;return(async()=>{let w=t.updateManager||"npm";if(!t.updateManager){i();return}let E="";w==="pnpm"?E=`pnpm add -g fluxflow-cli@${e}`:w==="bun"?E=`bun add -g fluxflow-cli@${e}`:w==="yarn"?E=`yarn global add fluxflow-cli@${e}`:w==="custom"?E=t.customUpdateCommand:E=`npm install -g fluxflow-cli@${e}`,c("downloading"),d(`Running: ${E}...`);let k=process.platform==="win32",D=K=>new Promise(F=>{let I=k?K?"powershell.exe":"cmd.exe":process.env.SHELL||"bash",A=k?K?["-NoProfile","-Command",E]:["/c",E]:["-c",E],v=q=>{let U=q.toString().replace(/\x1B\[[0-?]*[ -/]*[@-~]|\x1B\][^\x07\x1B]*[\x07\x1B]|\b|\x07/g,"").replace(/\r/g,"").trim();U&&d(G=>(G+`
|
|
522
526
|
`+U).split(`
|
|
523
527
|
`).slice(-5).join(`
|
|
524
|
-
`))};if(us)try{let q=us.spawn(I,A,{name:"xterm-256color",cols:80,rows:30,cwd:process.cwd(),env:process.env});h=q,q.onData(v),q.onExit(({exitCode:le})=>{h=null,
|
|
528
|
+
`))};if(us)try{let q=us.spawn(I,A,{name:"xterm-256color",cols:80,rows:30,cwd:process.cwd(),env:process.env});h=q,q.onData(v),q.onExit(({exitCode:le})=>{h=null,F(le!==0?{error:`Process exited with code ${le}`}:{success:!0})});return}catch(q){if(k&&K&&q.code==="ENOENT"){F({retryCmd:!0});return}}let J=k?ul(I,A,{cwd:process.cwd(),env:process.env}):ul(E,{shell:!0,cwd:process.cwd(),env:process.env});h=J,J.stdout.on("data",v),J.stderr.on("data",v),J.on("close",q=>{h=null,F(q!==0?{error:`Process exited with code ${q}`}:{success:!0})}),J.on("error",q=>{k&&K&&q.code==="ENOENT"?F({retryCmd:!0}):(h=null,F({error:q.message}))})}),_={};k?(_=await D(!0),_.retryCmd&&(_=await D(!1))):_=await D(!1),_.error?(a(_.error),c("error")):_.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=ml[Math.floor(f/3)%ml.length];return Ze.createElement(In,{flexDirection:"column",borderStyle:"round",borderColor:"cyan",paddingX:2,paddingY:1},Ze.createElement(In,null,Ze.createElement(Yt,{color:"magenta"},h),Ze.createElement(Yt,{marginLeft:1,bold:!0}," Updating Flux Flow to v",e,"...")),Ze.createElement(In,{marginTop:1,paddingX:1,borderStyle:"single",borderColor:"#333"},Ze.createElement(Yt,{color:"gray",italic:!0},m||"Preparing environment...")),Ze.createElement(Yt,{marginTop:1,dimColor:!0},"(Please do not close the terminal)"))}return l==="success"?Ze.createElement(In,{flexDirection:"column",borderStyle:"round",borderColor:"green",paddingX:2,paddingY:1},Ze.createElement(Yt,{color:"green",bold:!0},"\u2705 UPDATE SUCCESSFUL!"),Ze.createElement(Yt,{marginTop:1},"Flux Flow has been updated to ",Ze.createElement(Yt,{color:"cyan"},"v",e),"."),Ze.createElement(Yt,{marginTop:1,color:"yellow",bold:!0},"Please restart your terminal session to apply changes."),Ze.createElement(In,{marginTop:1},Ze.createElement(Yt,{dimColor:!0},"(Press ESC to return to chat)"))):l==="error"?Ze.createElement(In,{flexDirection:"column",borderStyle:"round",borderColor:"red",paddingX:2,paddingY:1},Ze.createElement(Yt,{color:"red",bold:!0},"\u274C UPDATE FAILED"),Ze.createElement(In,{marginTop:1,paddingX:1,borderStyle:"single",borderColor:"red"},Ze.createElement(Yt,{color:"red"},u)),Ze.createElement(Yt,{marginTop:1},"Possible causes:"),Ze.createElement(Yt,null,"\u2022 Missing permissions (Try running as Administrator/Sudo)"),Ze.createElement(Yt,null,"\u2022 Package manager (",t.updateManager,") not found"),Ze.createElement(Yt,null,"\u2022 Network failure"),Ze.createElement(In,{marginTop:1},Ze.createElement(Yt,{dimColor:!0},"(Press ESC to return to chat)"))):null},fl=Xc});import It,{useState as Kc}from"react";import{Box as jo,Text as cn,useInput as qc}from"ink";function Mi({prompts:e,onSelect:o,onClose:t}){let[n,i]=Kc(0);qc((d,u)=>{u.escape&&t(),u.upArrow&&i(a=>Math.max(0,a-1)),u.downArrow&&i(a=>Math.min(e.length-1,a+1)),u.return&&e[n]&&o(e[n].id)});let r=Ce(2),l=10,c=0;if(e.length>l){let d=Math.floor(l/2);c=n-d,c<0?c=0:c+l>e.length&&(c=e.length-l)}let m=e.slice(c,c+l);return It.createElement(jo,{flexDirection:"column",borderStyle:"round",borderColor:"cyan",padding:0,width:"100%"},It.createElement(jo,{paddingX:1,marginBottom:1},It.createElement(cn,{color:"cyan",bold:!0},"\u{1F504} CODEBASE TIME TRAVEL: SELECT UNDO POINT")),It.createElement(jo,{paddingX:2,marginBottom:1},It.createElement(cn,null,"Select a prompt to revert the codebase back to the state ",It.createElement(cn,{bold:!0,color:"blue"},"immediately before")," it was executed:")),e.length===0?It.createElement(jo,{paddingX:2,paddingY:1},It.createElement(cn,{italic:!0,color:"gray"},"No prompt checkpoints found for this session.")):It.createElement(jo,{flexDirection:"column",width:"100%"},c>0&&It.createElement(jo,{paddingX:2,marginBottom:1},It.createElement(cn,{color:"gray",dimColor:!0},"\u25B2 (+",c," more prompts above)")),m.map((d,u)=>{let f=c+u===n,p=zc(d.timestamp),h=d.changes?d.changes.length:0;return It.createElement(jo,{key:d.id,paddingX:1,backgroundColor:f?"#1a2a3a":void 0,width:"100%"},It.createElement(jo,{flexGrow:1},It.createElement(cn,{color:f?"cyan":"white",bold:f},f?"\u276F ":" ",'"',Vc(d.prompt),'"',It.createElement(cn,{color:"gray",dimColor:!f}," [",p," \u2022 ",h," file(s) changed]"))))}),c+l<e.length&&It.createElement(jo,{paddingX:2,marginTop:1},It.createElement(cn,{color:"gray",dimColor:!0},"\u25BC (+",e.length-(c+l)," more prompts below)"))),It.createElement(jo,{marginTop:1,paddingX:1,borderStyle:"single",borderLeft:!1,borderRight:!1,borderBottom:!1,borderColor:"cyan"},It.createElement(cn,{dimColor:!0,italic:!0},"\u2191\u2193 navigate \u2022 Enter select undo point \u2022 Esc close")))}function Vc(e){if(!e)return"";let t=(e.split(`
|
|
525
529
|
`)[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(`
|
|
526
|
-
`)?t+"...":t}function zc(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 hl=ie(()=>{hn()});import Jc from"puppeteer";import{exec as Qc}from"child_process";import{promisify as Zc}from"util";import ed from"fs";var gl,xl,yl,wl=ie(()=>{gl=Zc(Qc),xl=()=>{try{let e=Jc.executablePath();if(e&&ed.existsSync(e))return!0}catch{return!1}return!1},yl=async e=>{e&&e("\u{1F4E5} Downloading Chromium engine (chrome@148)...");try{try{await gl("pnpm exec puppeteer browsers install chrome@148")}catch{await gl("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 Ml={};Ss(Ml,{default:()=>Il});import Tl from"os";import s,{useState as V,useEffect as lo,useRef as Go,useMemo as Ar}from"react";import{Box as C,Text as y,useInput as td,useStdout as od}from"ink";import oo from"fs-extra";import Wn from"path";import{exec as Oi}from"child_process";import{fileURLToPath as nd}from"url";import Sl from"ink-text-input";import rd from"gradient-string";function Il({args:e=[]}){let[o,t]=V(!1),[n,i]=V(10),{stdout:r}=od(),[l,c]=V(""),[m,d]=V(0),[u,a]=V(!1),[f,p]=V("Flux"),[h,T]=V({columns:r?.columns||80,rows:r?.rows||24}),[w,E]=V(0),[k,D]=V(!1),[_,K]=V(!1),[
|
|
530
|
+
`)?t+"...":t}function zc(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 hl=ie(()=>{hn()});import Jc from"puppeteer";import{exec as Qc}from"child_process";import{promisify as Zc}from"util";import ed from"fs";var gl,xl,yl,wl=ie(()=>{gl=Zc(Qc),xl=()=>{try{let e=Jc.executablePath();if(e&&ed.existsSync(e))return!0}catch{return!1}return!1},yl=async e=>{e&&e("\u{1F4E5} Downloading Chromium engine (chrome@148)...");try{try{await gl("pnpm exec puppeteer browsers install chrome@148")}catch{await gl("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 Ml={};Ss(Ml,{default:()=>Il});import Tl from"os";import s,{useState as V,useEffect as lo,useRef as Go,useMemo as Ar}from"react";import{Box as C,Text as y,useInput as td,useStdout as od}from"ink";import oo from"fs-extra";import Wn from"path";import{exec as Oi}from"child_process";import{fileURLToPath as nd}from"url";import Sl from"ink-text-input";import rd from"gradient-string";function Il({args:e=[]}){let[o,t]=V(!1),[n,i]=V(10),{stdout:r}=od(),[l,c]=V(""),[m,d]=V(0),[u,a]=V(!1),[f,p]=V("Flux"),[h,T]=V({columns:r?.columns||80,rows:r?.rows||24}),[w,E]=V(0),[k,D]=V(!1),[_,K]=V(!1),[F,I]=V(0),A=Go(null);lo(()=>{let x=ps(),g=!["Terminal","Windows Terminal"].includes(x)||!!process.env.VSC_TERMINAL_URL,M=setTimeout(()=>{g&&!Ro()&&K(!0)},500),B=setInterval(()=>{Ro()&&K(!1)},1e3);return()=>{clearTimeout(M),clearInterval(B)}},[]);let v=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 O=e[g+1].toLowerCase();if(["flux","flow"].includes(O)){let $="Flux";O==="flux"?$="Flux":O==="flow"&&($="Flow"),x.mode=$}g++}else if(M==="--thinking"&&e[g+1]){let O=e[g+1].toLowerCase();if(["fast","low","medium","high","xhigh"].includes(O)){let $="Medium";O==="fast"?$="Fast":O==="low"?$="Low":O==="medium"?$="Medium":O==="high"?$="High":O==="xhigh"&&($="xHigh"),x.thinking=$}g++}}return x},[e]),J=async(x=!1,g=null)=>{let M=g||_t;x&&N(B=>(ee(B.length+1),[...B,{id:"check-"+Date.now(),role:"system",text:"\u{1F50D} Checking for updates...",isMeta:!0}]));try{let O=await(await fetch("https://registry.npmjs.org/fluxflow-cli",{cache:"no-store"})).json(),$=O["dist-tags"]?.latest,X=O["dist-tags"]?.stable;if($&&nt($),$&&$!==Mn){let S=$===X?`v${$}-stable`:`v${$}`;!x&&M.autoUpdate?Y("update"):N(L=>{let P=[...L],j=x?P.length:Math.min(P.length,3);return P.splice(j,0,{id:"update-"+Date.now(),role:"system",text:`A new version (${S}) is here.
|
|
527
531
|
|
|
528
532
|
\u2022 Type \`/update latest\` to apply the update.
|
|
529
|
-
\u2022 Type \`/changelog\` to view the release notes.`,isUpdateNotification:!0,isMeta:!0}),
|
|
533
|
+
\u2022 Type \`/changelog\` to view the release notes.`,isUpdateNotification:!0,isMeta:!0}),P})}else x&&N(S=>{ee(S.length+1);let L=$&&$===X?`${Mn}-stable`:Mn;return[...S,{id:"uptodate-"+Date.now(),role:"system",text:`\u2705 [SYSTEM] Flux Flow is already up to date (${L}).`,isMeta:!0}]})}catch(B){x&&N(O=>(ee(O.length+1),[...O,{id:"check-err-"+Date.now(),role:"system",text:`\u274C ERROR: Failed to check for updates: ${B.message}`,isMeta:!0}]))}};lo(()=>{let x=()=>{r.write("\x1B[2J\x1B[3J\x1B[H"),T({columns:r.columns,rows:r.rows})};return r.on("resize",x),()=>{r.off("resize",x)}},[r]);let[q,le]=V("Medium"),[U,G]=V("Google"),[Pe,ce]=V(0),[De,nt]=V(null),[pe,ut]=V(!1),[Ve,ze]=V("gemma-4-31b-it"),[_e,Je]=V("gemma-4-26b-a4b-it"),[fe,po]=V(!0),[ho,dn]=V(!0),no=Go(0),[ve,yt]=V(null),[Xo,Ko]=V(""),[Ht,Y]=V("chat"),[He,Lr]=V("Free"),[jt,Yn]=V({agentLimit:999999,backgroundLimit:999999,searchLimit:100,customModelId:"",customLimit:0}),[mt,ko]=V(null),[_t,Q]=V({memory:!0,compression:0,autoExec:!1,autoDeleteHistory:"7d",autoUpdate:!1,updateManager:"npm",customUpdateCommand:""}),[Me,rt]=V({name:null,nickname:null,instructions:null}),[ne,xe]=V({keyType:"Default",quality:"Low-High",apiKey:""}),[he,st]=V({tokens:0}),[Po,wt]=V(0),[ft,je]=V(0),[de,Nt]=V(0),[it,co]=V(0),[pt,un]=V(0),[et,at]=V(0),[Ut,Gt]=V(0),[qo,hs]=V(0),[nr,Dr]=V(0),[Hn,Li]=V(0),[rr,gs]=V(0),[sr,xs]=V(0),[re,Ue]=V(null),[Re,lt]=V(Ys()),[Tt,tt]=V(null),[Xt,go]=V(""),[Kt,Dt]=V(!1),[ro,xo]=V(0),On=Go(!0),vr=Go(!0),Se=Go(!0);lo(()=>{if(!ve)return;if(On.current){On.current=!1,setTimeout(()=>{vr.current=!1,setTimeout(()=>{Se.current=!1},1e3)},2e3);return}if(vr.current||Se.current)return;let x=Ce(2),g="",M="";He==="Free"?U==="Google"?(g="gemma-4-31b-it",M="Gemma 4 (Free default)"):U==="DeepSeek"?(g="deepseek-v4-flash",M="DeepSeek Flash (Free default)"):(g="google/gemma-4-31b-it:free",M="Gemma 4 (Free default)"):U==="Google"?(g="gemini-3-flash-preview",M="Gemini 3 Flash"):U==="DeepSeek"?(g="deepseek-v4-flash",M="DeepSeek Flash"):(g="deepseek/deepseek-v4-flash",M="DeepSeek Flash"),ze(g),Rn({apiTier:He,activeModel:g}),N(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}]))},[He,U,ve]);let ot=Ar(()=>{let x=ps(),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=Go(null),We=Go("");lo(()=>{qt.current=Tt},[Tt]),lo(()=>{We.current=Xt},[Xt]);let[Io,mn]=V(!1),[jn,An]=V(null),[Vo,$r]=V(null),ir=x=>{let g=Math.floor(x/3600),M=Math.floor(x%3600/60),B=x%60,O=[];return g>0&&O.push(`${g}h`),(M>0||g>0)&&O.push(`${M}m`),O.push(`${B}s`),O.join(" ")},zo=x=>x<1e3?`${x}ms`:ir(Math.floor(x/1e3)),[ar,lr]=V(null),[Ln,Di]=V(!0),[Mo,cr]=V(!1),[ys,Oo]=V(!1),[Jo,ws]=V(null),[dr,z]=V(0),[ct,ht]=V([]),H=Go(null),[St,Mt]=V(null),[Ne,yo]=V(null),[Dn,vn]=V(null);lo(()=>z(0),[l]);let[Oe,N]=V(()=>{let x={id:"logo-"+Date.now(),role:"system",text:or,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()===Tl.homedir(),B=(()=>{let $=process.cwd().toLowerCase();if(process.platform==="win32"){let X=process.env.SystemRoot?.toLowerCase()||"c:\\windows",S=process.env.ProgramFiles?.toLowerCase()||"c:\\program files",L=process.env["ProgramFiles(x86)"]?.toLowerCase()||"c:\\program files (x86)";return $.startsWith(X)||$.startsWith(S)||$.startsWith(L)}else return $==="/"||["/bin","/sbin","/etc","/usr","/var","/root"].some(S=>$.startsWith(S))})(),O=[x,g];return B?O.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&&O.push({id:"home-warning",role:"system",text:"[SECURITY ALERT] HOME DIRECTORY DETECTED",subText:`You are currently in ${Tl.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}),O}),wo=Go(null),[ur,ee]=V(Oe.length),Pr=Ar(()=>{let g=h.columns||80,M=0,B=0;for(let O=Oe.length-1;O>=0;O--){let $=Oe[O];if(!$)continue;let X=$.text||"",S=X.split(/\r?\n/).length;if(X.split(/\r?\n/).forEach(L=>{S+=Math.floor(L.length/g)}),$.isHelpRecord&&(S=15),$.isUpdateNotification&&(S=8),$.isTerminalRecord&&(S=10),S+=$.role==="think"?3:2,M+S>2e3){B=O+1;break}M+=S}return{items:Oe.slice(B,ur),isTruncated:B>0}},[Oe,h.columns,h.rows]),Fr=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]);td((x,g)=>{if(!(x==="\x1B[I"||x==="\x1B[O"||x==="[I"||x==="[O")){if(_){let M=ps(),B=Cl(M);if(g.upArrow)I(O=>O>0?O-1:B.length-1);else if(g.downArrow)I(O=>O<B.length-1?O+1:0);else if(g.return){let O=B[F];if(O.action==="dismiss")K(!1);else if(O.url){let $=process.platform==="win32"?`start ${O.url}`:process.platform==="darwin"?`open ${O.url}`:`xdg-open ${O.url}`;Oi($),K(!1)}}return}if(g.tab&&Tt){Dt(M=>!M);return}if(Kt&&Tt){if(g.return){let M=process.platform==="win32";So(M?`\r
|
|
530
534
|
`:`
|
|
531
|
-
`),
|
|
532
|
-
`)}else if(g.backspace||g.delete)
|
|
533
|
-
`)}}),lo(()=>{process.stdout.write("\x1B[?1004h");let x=g=>{let M=g.toString();M.includes("\x1B[I")?(dn(!0),no.current=Date.now()):M.includes("\x1B[O")&&(dn(!1),no.current=Date.now())};return process.stdin.on("data",x),()=>{process.stdout.write("\x1B[?1004l"),process.stdin.off("data",x)}},[]),lo(()=>{async function x(){try{let $=JSON.parse(oo.readFileSync(Wn.join(process.cwd(),"package.json"),"utf8"));hi(Mn||$.version||"2.0.0")}catch{hi("2.0.0")}process.stdout.isTTY&&(process.stdout.write("\x1B]0;FluxFlow\x07"),process.stdout.write("\x1B]633;P;TerminalTitle=FluxFlow\x07")),xl()||(N($=>(ee($.length+1),[...$,{id:"setup-"+Date.now(),role:"system",text:"\u{1F527} [SYSTEM] Installing Required dependencies... (One-time setup)",isMeta:!0}])),await yl(),N($=>(ee($.length+1),[...$,{id:"setup-done-"+Date.now(),role:"system",text:"\u2705 [SYSTEM] All dependencies installed successfully.",isMeta:!0}])));let g=await kr();v.mode?p(v.mode):p(g.mode),v.thinking?le(v.thinking):le(g.thinkingLevel),G(g.aiProvider||"Google"),A.current=g.activeModel,v.model?ze(v.model):ze(g.activeModel),ut(g.showFullThinking),Lr(g.apiTier||"Free"),Yn(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||{}};v.memory==="on"?M.memory=!0:v.memory==="off"&&(M.memory=!1),v.package&&(M.updateManager=v.package),v.autoDel&&(M.autoDeleteHistory=v.autoDel),v.autoExec==="on"?M.autoExec=!0:v.autoExec==="off"&&(M.autoExec=!1),v.externalAccess==="on"?M.allowExternalAccess=!0:v.externalAccess==="off"&&(M.allowExternalAccess=!1),Q(M),rt(g.profileData),xe(g.imageSettings||{keyType:"Default",quality:"Low-High",apiKey:""});let B=g.aiProvider||"Google",O=await Jr(B);if(O&&(yt(O),Or(O)),g.systemSettings?.autoDeleteHistory&&ga(g.systemSettings.autoDeleteHistory),xa(
|
|
535
|
+
`),To||go(B=>B+`
|
|
536
|
+
`)}else if(g.backspace||g.delete)To?So("\x7F"):(So("\b \b"),go(M=>M.slice(0,-1)));else if(g.upArrow)So(g.shift?"\x1B[1;2A":"\x1B[A");else if(g.downArrow)So(g.shift?"\x1B[1;2B":"\x1B[B");else if(g.rightArrow)So(g.shift?"\x1B[1;2C":"\x1B[C");else if(g.leftArrow)So(g.shift?"\x1B[1;2D":"\x1B[D");else if(g.escape)So("\x1B");else if(g.ctrl&&x){let M=x.toLowerCase().charCodeAt(0);M>=97&&M<=122?So(String.fromCharCode(M-96)):So(x)}else x&&(So(x),To||go(M=>M+x));return}if(g.escape){if(Ee.length>0&&Ht==="chat"){D(!0);return}if(o){t(!1);return}if(Mo||Tt)ys?(nl(),Ki(),Oo(!1),Jo&&clearTimeout(Jo)):(Oo(!0),Jo&&clearTimeout(Jo),ws(setTimeout(()=>Oo(!1),3e3)));else if(Ht==="revert")Y("chat"),z(0);else if(Ht!=="chat"&&Ht!=="settings")Y("chat");else{if(!ve&&Pe===1){ce(0),Ko("");return}z(M=>{let B=M+1;return B===1?(H.current&&clearTimeout(H.current),H.current=setTimeout(()=>z(0),2e3)):B===2&&(H.current&&clearTimeout(H.current),z(0),l.length>0?c(""):Et.getChatHistory(Re).then(O=>{O.length>0?(ht(O.reverse()),Y("revert")):N($=>(ee($.length+1),[...$,{id:"revert-empty-"+Date.now(),role:"system",text:"\u{1F6C8} No revert checkpoints found for this session.",isMeta:!0}]))})),B})}}if(Ee.length>0&&Ht==="chat"){if(g.upArrow){E(M=>M>0?M-1:Ee.length-1);return}if(g.downArrow){E(M=>M<Ee.length-1?M+1:0);return}if(g.return)return}if(g.tab,g.ctrl&&x==="c"&&Ht!=="exit"){if(l.length>0){c("");return}if(g.shift){Y("exit"),t(!1);return}o?(Y("exit"),t(!1)):t(!0)}g.return&&(g.shift||g.ctrl||g.meta||g.leftAlt||g.rightAlt)&&c(M=>M.replace(/\\\r?$/,"").replace(/\r?$/,"")+`
|
|
537
|
+
`)}}),lo(()=>{process.stdout.write("\x1B[?1004h");let x=g=>{let M=g.toString();M.includes("\x1B[I")?(dn(!0),no.current=Date.now()):M.includes("\x1B[O")&&(dn(!1),no.current=Date.now())};return process.stdin.on("data",x),()=>{process.stdout.write("\x1B[?1004l"),process.stdin.off("data",x)}},[]),lo(()=>{async function x(){try{let $=JSON.parse(oo.readFileSync(Wn.join(process.cwd(),"package.json"),"utf8"));hi(Mn||$.version||"2.0.0")}catch{hi("2.0.0")}process.stdout.isTTY&&(process.stdout.write("\x1B]0;FluxFlow\x07"),process.stdout.write("\x1B]633;P;TerminalTitle=FluxFlow\x07")),xl()||(N($=>(ee($.length+1),[...$,{id:"setup-"+Date.now(),role:"system",text:"\u{1F527} [SYSTEM] Installing Required dependencies... (One-time setup)",isMeta:!0}])),await yl(),N($=>(ee($.length+1),[...$,{id:"setup-done-"+Date.now(),role:"system",text:"\u2705 [SYSTEM] All dependencies installed successfully.",isMeta:!0}])));let g=await kr();v.mode?p(v.mode):p(g.mode),v.thinking?le(v.thinking):le(g.thinkingLevel),G(g.aiProvider||"Google"),A.current=g.activeModel,v.model?ze(v.model):ze(g.activeModel),ut(g.showFullThinking),Lr(g.apiTier||"Free"),Yn(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||{}};v.memory==="on"?M.memory=!0:v.memory==="off"&&(M.memory=!1),v.package&&(M.updateManager=v.package),v.autoDel&&(M.autoDeleteHistory=v.autoDel),v.autoExec==="on"?M.autoExec=!0:v.autoExec==="off"&&(M.autoExec=!1),v.externalAccess==="on"?M.allowExternalAccess=!0:v.externalAccess==="off"&&(M.allowExternalAccess=!1),Q(M),rt(g.profileData),xe(g.imageSettings||{keyType:"Default",quality:"Low-High",apiKey:""});let B=g.aiProvider||"Google",O=await Jr(B);if(O&&(yt(O),Or(O)),g.systemSettings?.autoDeleteHistory&&ga(g.systemSettings.autoDeleteHistory),xa(Co),v.update==="check"?J(!0,M):v.update==="latest"?(Y("update"),J(!0,M)):J(!1,M),await Sa(),v.resume){let $=await $o(),X=v.resume;if($[X]){lt(X);let S=[...$[X].messages];S[0]?.text?.includes("\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2557")||S.unshift({id:"welcome-"+Date.now(),role:"system",text:or+`
|
|
534
538
|
|
|
535
|
-
\u{1F30A}\u26A1 Resuming Flux Flow Session...`,isMeta:!0}),N(S),Y("chat"),N(
|
|
539
|
+
\u{1F30A}\u26A1 Resuming Flux Flow Session...`,isMeta:!0}),N(S),Y("chat"),N(P=>{let j=[...P,{id:"sys-"+Date.now(),role:"system",text:`\u{1F4E1} SESSION RESUMED VIA CLI: [${X}]`,isMeta:!0}];return ee(j.length),j})}else N(S=>[...S,{id:"sys-err-"+Date.now(),role:"system",text:`\u274C ERROR: Chat session [${X}] not found. Started new session.`,isMeta:!0}])}po(!1)}x()},[]),lo(()=>{let x;return o&&(i(10),x=setInterval(()=>{i(g=>g<=1?(t(!1),0):g-1)},1e3)),()=>{x&&clearInterval(x)}},[o]),lo(()=>{if(!fe){let x=v.model&&Ve===v.model?A.current:Ve;Rn({mode:f,thinkingLevel:q,aiProvider:U,activeModel:x||Ve,showFullThinking:pe,systemSettings:_t,profileData:Me,imageSettings:ne,apiTier:He})}},[f,q,U,Ve,pe,_t,Me,ne,fe,v,He]);let se=async x=>{let g=x.trim(),M=30;if(U==="OpenRouter"&&(M=10),U==="DeepSeek"&&(M=20),g.length>=M){await Qr(U,g),yt(g),Or(g);let B="gemma-4-31b-it";U==="OpenRouter"?B="google/gemma-4-31b-it:free":U==="DeepSeek"&&(B="deepseek-v4-flash"),ze(B),N(O=>[...O,{role:"system",text:`\u2705 ${U} API Key saved successfully! Model set to ${B}. Initialization complete.`,isMeta:!0}])}else N(B=>[...B,{role:"system",text:`\u274C INVALID KEY: ${U} API keys must be at least ${M} characters.`,isMeta:!0}]),Ko("")},Ae=Go(Ai);lo(()=>{if(Ht==="exit"){(async()=>{let M=Date.now(),B=Math.floor((M-Ae.current)/1e3);B>=1&&(await fo("duration",B),Ae.current+=B*1e3),await Ea()})();let g=setTimeout(()=>{process.exit(0)},1700);return()=>clearTimeout(g)}},[Ht]),lo(()=>{let x=setInterval(async()=>{if(!fe){let g=Date.now(),M=Math.floor((g-Ae.current)/1e3);M>=1&&(await fo("duration",M),Ae.current+=M*1e3)}},1500);return()=>clearInterval(x)},[fe]);let Qe=[{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:ne?.keyType==="Custom"?"(0.001/img)":"(1/img)"},{cmd:"low-high",desc:ne?.keyType==="Custom"?"(0.002/img)":"(2/img)"},{cmd:"medium",desc:ne?.keyType==="Custom"?"(0.008/img)":"(8/img)"},{cmd:"medium-high",desc:ne?.keyType==="Custom"?"(0.01/img)":"(10/img)"},{cmd:"high",desc:ne?.keyType==="Custom"?"(0.045/img)":"(45/img)"},{cmd:"ultra",desc:ne?.keyType==="Custom"?"(0.0488/img)":"(49/img)"},{cmd:"premium",desc:ne?.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:U==="DeepSeek"?[{cmd:"Fast",desc:"Fastest"},{cmd:"Standard",desc:"Standard Reasoning"},{cmd:"xHigh",desc:"Extended Reasoning"}]:U==="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"}]:Ve&&Ve.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:U==="OpenRouter"?He==="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"}]:U==="DeepSeek"?[{cmd:"deepseek-v4-flash",desc:"Fast & Efficient"},{cmd:"deepseek-v4-pro",desc:"High-Intelligence Reasoning"}]:He==="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"}]}],Ge=async(x,g=!1)=>{if(!g&&Ee.length>0){let O=Ee[w]||Ee[0],$=x.split(" ");if($.length===1)c(O.cmd+" ");else{let X=$.slice(0,-1);c(X.join(" ")+" "+O.cmd+" ")}E(0),d(X=>X+1);return}let M=x.replace(/\r\n/g,`
|
|
536
540
|
`).replace(/\r/g,`
|
|
537
541
|
`).trimEnd();if(M.endsWith("\\")){c(M.slice(0,-1)+`
|
|
538
542
|
`);return}let B=M.replace(/\\\s*\n/g,`
|
|
539
543
|
`).split(/\r?\n/).map(O=>O.replace(/\\$/,"")).join(`
|
|
540
|
-
`);if(B.trim()){if(Mo){let O=B.trim();if(O.startsWith("/")){N($=>(ee($.length+1),[...$,{id:"hint-err-"+Date.now(),role:"system",text:"\u274C [RESTRICTED] Steering Hints cannot start with /",isMeta:!0}])),c("");return}Mt(O),
|
|
541
|
-
${O}`,color:"magenta"}])),c("");return}if(!ve){se(B),Ko("");return}if(B.startsWith("/")){let O=B.split(" "),$=O[0]?.toLowerCase();switch($){case"/quit":{Y("exit");break}case"/resume":{if(O[1]){let S=O[1];(async()=>{let
|
|
544
|
+
`);if(B.trim()){if(Mo){let O=B.trim();if(O.startsWith("/")){N($=>(ee($.length+1),[...$,{id:"hint-err-"+Date.now(),role:"system",text:"\u274C [RESTRICTED] Steering Hints cannot start with /",isMeta:!0}])),c("");return}Mt(O),wo.current=O,N($=>(ee($.length+1),[...$,{id:"hint-"+Date.now(),role:"user",text:`[STEERING HINT: QUEUED]
|
|
545
|
+
${O}`,color:"magenta"}])),c("");return}if(!ve){se(B),Ko("");return}if(B.startsWith("/")){let O=B.split(" "),$=O[0]?.toLowerCase();switch($){case"/quit":{Y("exit");break}case"/resume":{if(O[1]){let S=O[1];(async()=>{let P=await $o(),j=P[S]||Object.values(P).find(te=>te.name.toLowerCase()===S.toLowerCase());if(j){r.write("\x1B[2J\x1B[3J\x1B[H"),lt(S);let te=[...j.messages];te[0]?.text?.includes("\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2557")||(te.unshift({id:"welcome-"+Date.now(),role:"system",text:"\u{1F30A}\u26A1 Resuming Flux Flow Session...",isMeta:!0}),te.unshift({id:"logo-"+Date.now(),role:"system",text:or,isLogo:!0,isMeta:!0})),N(te),N(ue=>[...ue,{id:"sys-"+Date.now(),role:"system",text:`\u{1F4E1} SESSION RESUMED: [${S}]`,isMeta:!0}]),ee(0)}else N(te=>[...te,{id:"err-"+Date.now(),role:"system",text:`\u274C ERROR: Session [${S}] not found.`}])})()}else Y("resume");break}case"/clear":{N([{id:"logo-"+Date.now(),role:"system",text:or,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(Ys()),st({tokens:0}),a(!1);break}case"/revert":{Et.getChatHistory(Re).then(S=>{if(S.length>0)ht(S.reverse()),Y("revert");else{let L=Ce(2);N(P=>(ee(P.length+1),[...P,{id:"revert-empty-"+Date.now(),role:"system",text:"No revert checkpoints found for this session.",isMeta:!0}]))}});break}case"/mode":{if(O[1]){let S=O[1].toLowerCase()==="flow"?"Flow":"Flux";p(S),S==="Flow"?le("Fast"):S==="Flux"&&le("High");let L=Ce(2);N(P=>(ee(P.length+1),[...P,{id:Date.now(),role:"system",text:`\u{1F527}${L}[SYSTEM] Mode switched to ${S}`,isMeta:!0}]))}else Y("mode");break}case"/image":{if(O[1]?.toLowerCase()==="stats"){let S=Ce(2);if(ne.keyType==="Custom")N(L=>(ee(L.length+1),[...L,{id:Date.now(),role:"system",text:`\u{1F517}${S}[SYSTEM] Key strategy is Custom. Redirecting to Pollinations dashboard (https://enter.pollinations.ai/#pollen)...`,isMeta:!0}])),Oi("start https://enter.pollinations.ai/#pollen");else try{let L=await os();N(P=>(ee(P.length+1),[...P,{id:Date.now(),role:"system",isImageStats:!0,text:`\u2022 Hourly Limit: ${Number((L.limit*1e3).toFixed(0))} credits
|
|
542
546
|
\u2022 Spent (Last 1hr): ${Number((L.totalSpent*1e3).toFixed(0))} credits
|
|
543
547
|
\u2022 Remaining: ${Number((L.remaining*1e3).toFixed(0))} credits
|
|
544
548
|
\u2022 Requests (Last 1hr): ${L.activeCallsCount} requests
|
|
545
|
-
`+(L.nextResetMin>0?`\u2022 Refreshes in: ${L.nextResetMin}m`:""),isMeta:!0}]))}catch{N(
|
|
546
|
-
`);try{oo.writeFileSync(L,te,"utf8"),N(be=>(ee(be.length+1),[...be,{id:Date.now(),role:"system",text:`\u{1F4E4} [EXPORT] Chat exported successfully to "${S}"`,isMeta:!0}]))}catch(be){N(ue=>(ee(ue.length+1),[...ue,{id:Date.now(),role:"system",text:`\u274C [EXPORT ERROR] Failed to export chat: ${be.message}`,isMeta:!0}]))}break}case"/chats":{(async()=>{let L=await $o(),
|
|
549
|
+
`+(L.nextResetMin>0?`\u2022 Refreshes in: ${L.nextResetMin}m`:""),isMeta:!0}]))}catch{N(P=>(ee(P.length+1),[...P,{id:Date.now(),role:"system",text:"\u274C [SYSTEM] Failed to load image quota stats.",isMeta:!0}]))}}else if(O[1]?.toLowerCase()==="setup")if(O[2]?.toLowerCase()==="key")if(O[3]){let S=["default","custom"].find(L=>L===O[3].toLowerCase());if(S){let L=S==="default"?"Default":"Custom";xe(j=>({...j,keyType:L}));let P=Ce(2);N(j=>(ee(j.length+1),[...j,{id:Date.now(),role:"system",text:`\u{1F527}${P}[SYSTEM] Image key strategy set to ${L}`,isMeta:!0}])),L==="Custom"&&(ko({label:"Enter Pollinations API key (starting with sk_):",note:"Get a key from https://enter.pollinations.ai",key:"imageSettings",subKey:"apiKey",value:ne.apiKey||"",returnView:"chat"}),Y("input"))}else{let L=Ce(2);N(P=>(ee(P.length+1),[...P,{id:Date.now(),role:"system",text:"\u274C [SYSTEM] Invalid key option. Choose: Default or Custom.",isMeta:!0}]))}}else{let S=Ce(2);N(L=>(ee(L.length+1),[...L,{id:Date.now(),role:"system",text:"\u274C [SYSTEM] Usage: /image setup Key <Default|Custom>",isMeta:!0}]))}else if(O[2]?.toLowerCase()==="quality")if(O[3]){let S=["low","low-high","medium","medium-high","high","ultra","premium"].find(L=>L===O[3].toLowerCase());if(S){let P={low:"Low","low-high":"Low-High",medium:"Medium","medium-high":"Medium-High",high:"High",ultra:"Ultra",premium:"Premium"}[S];xe(te=>({...te,quality:P}));let j=Ce(2);N(te=>(ee(te.length+1),[...te,{id:Date.now(),role:"system",text:`\u{1F527}${j}[SYSTEM] Image quality set to ${P}`,isMeta:!0}]))}else{let L=Ce(2);N(P=>(ee(P.length+1),[...P,{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 S=Ce(2);N(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 S=Ce(2);N(L=>(ee(L.length+1),[...L,{id:Date.now(),role:"system",text:"\u274C [SYSTEM] Usage: /image setup <Key|Quality> ...",isMeta:!0}]))}else{let S=Ce(2);N(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 S;if(O[1]){let L=O[1].toLowerCase(),P=O.includes("--bypass");if(S=L.charAt(0).toUpperCase()+L.slice(1),L==="xhigh"&&(S="xHigh"),!P&&f==="Flow"&&(S==="Medium"||S==="High"||S==="xHigh"))N(j=>(ee(j.length+1),[...j,{id:Date.now(),role:"system",text:`\u274C [RESTRICTED] "${S}" is restricted in Flow mode. Switch to Flux to enable Higher Thinking Levels.`,isMeta:!0}]));else{le(S);let j=Ce(1);N(te=>(ee(te.length+1),[...te,{id:Date.now(),role:"system",text:`\u{1F527} [SYSTEM] Thinking level set to ${S}${P?` (Bypass Activated \u{1F575}\uFE0F${j})`:""}`,isMeta:!0}]))}}else Y("thinking");break}case"/model":{if(O[1]){let S=O.slice(1).join(" ");if(S==="gemma-4-31b-it"&&He!=="Free"&&U==="Google")N(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}])),ze("gemini-3-flash-preview");else{ze(S);let L=Ce(2);N(P=>(ee(P.length+1),[...P,{id:Date.now(),role:"system",text:`\u{1F527}${L}[SYSTEM] Model switched to ${S}`,isMeta:!0}]))}}else Y("model");break}case"/settings":{Y("settings");break}case"/key":{Y("key");break}case"/profile":{Y("profile");break}case"/stats":{(async()=>{let L=await En();Ue(L),Y("stats")})();break}case"/save":{let S=O.slice(1).join(" ")||`Session ${new Date().toLocaleTimeString()}`;es(Re,S,Oe),N(L=>(ee(L.length+1),[...L,{id:Date.now(),role:"system",text:`\u{1F4BE} [MEMORY] Chat saved as "${S}" (ID: ${Re})`,isMeta:!0}]));break}case"/export":{let S=`export-fluxflow-${Re}.txt`,L=Wn.join(process.cwd(),S),P=[],j=!1;for(let be=0;be<Oe.length;be++){let ue=Oe[be];if(ue&&!(ue.role==="system"||ue.isMeta||ue.isLogo||String(ue.id).startsWith("welcome"))){if(ue.role==="user"){let Fe=ue.text||"";Fe=Fe.replace(/\s*\[Prompted on:.*?\]/g,"").trim(),P.length>0&&P.push(""),P.push("[USER]"),P.push(Fe),j=!1}else if(ue.role==="think"){j||(P.push(""),P.push("[AGENT]"),j=!0);let Fe=(ue.text||"").replace(/\[turn:\s*continue\]/gi,"").replace(/\[turn:\s*finish\]/gi,"").replace(/\[TOOL RESULTS\]/gi,"").trim();Fe&&(P.push("[thoughts]"),P.push(Fe))}else if(ue.role==="agent"){j||(P.push(""),P.push("[AGENT]"),j=!0);let Fe=dd(ue.text||"");for(let Be of Fe)if(Be.type==="output"){let $e=Be.content.replace(/\[turn:\s*continue\]/gi,"").replace(/\[turn:\s*finish\]/gi,"").replace(/\[TOOL RESULTS\]/gi,"").trim();$e&&(P.push("[output]"),P.push($e))}else Be.type==="tool"&&(P.push("[tool]"),P.push(`${Be.toolName} ${Be.args}`))}}}let te=P.join(`
|
|
550
|
+
`);try{oo.writeFileSync(L,te,"utf8"),N(be=>(ee(be.length+1),[...be,{id:Date.now(),role:"system",text:`\u{1F4E4} [EXPORT] Chat exported successfully to "${S}"`,isMeta:!0}]))}catch(be){N(ue=>(ee(ue.length+1),[...ue,{id:Date.now(),role:"system",text:`\u274C [EXPORT ERROR] Failed to export chat: ${be.message}`,isMeta:!0}]))}break}case"/chats":{(async()=>{let L=await $o(),P=Object.entries(L).map(([j,te])=>`\u2022 ${j}: ${te.name}`).join(`
|
|
547
551
|
`);N(j=>(ee(j.length+1),[...j,{id:Date.now(),role:"system",text:`\u{1F5C3}\uFE0F [HISTORY] Saved Chats:
|
|
548
|
-
${
|
|
552
|
+
${P||"No saved chats found."}`,isMeta:!0}]))})();break}case"/memory":{Y("memory");break}case"/reset":{(async()=>{try{N(L=>(ee(L.length+1),[...L,{id:Date.now(),role:"system",text:"\u2622\uFE0F [NUCLEAR] Initiating reset...",isMeta:!0}])),oo.existsSync(Co)&&oo.removeSync(Co),oo.existsSync(eo)&&oo.removeSync(eo),oo.existsSync(Zt)&&oo.removeSync(Zt);try{oo.readdirSync(Fn).length===0&&oo.removeSync(Fn)}catch{}setTimeout(()=>{Y("exit"),setTimeout(()=>process.exit(0),500)},500)}catch(L){N(P=>(ee(P.length+1),[...P,{id:Date.now(),role:"system",text:`\u274C [RESET ERROR] Failed to purge data: ${L.message}`}]))}})();break}case"/about":{let S=Ce(2),L=`\u{1F539} FluxFlow Version: v${Mn}
|
|
549
553
|
\u{1F539} Status: ${De&&De!==Mn?`Update Available [v${De}]`:"Up to date"}
|
|
550
|
-
\u{1F539} Released on: ${ad}`;N(
|
|
554
|
+
\u{1F539} Released on: ${ad}`;N(P=>(ee(P.length+1),[...P,{id:"about-"+Date.now(),role:"system",text:L,isAboutRecord:!0,isMeta:!0}]));break}case"/changelog":{let S=process.platform;Oi(`${S==="win32"?"start":S==="darwin"?"open":"xdg-open"} ${El}`),N(P=>(ee(P.length+1),[...P,{id:Date.now(),role:"system",text:`\u{1F310} [BROWSER] Opening changelog: ${El}`,isMeta:!0}]));break}case"/fluxflow":{if(O.slice(1)[0]==="init"){let L=`# FluxFlow Configuration
|
|
551
555
|
# This file defines project-specific instructions for the Flux Flow Agent.
|
|
552
556
|
|
|
553
557
|
# IDENTITY & TONE
|
|
@@ -562,30 +566,30 @@ ${F||"No saved chats found."}`,isMeta:!0}]))})();break}case"/memory":{Y("memory"
|
|
|
562
566
|
|
|
563
567
|
# SKILLS & WORKFLOWS
|
|
564
568
|
- [Define custom step-by-step recipes for this project here]
|
|
565
|
-
`,
|
|
569
|
+
`,P=Wn.join(process.cwd(),"FluxFlow.md");if(oo.pathExistsSync(P))N(j=>(ee(j.length+1),[...j,{id:"init-err-"+Date.now(),role:"system",text:"\u274C ERROR: FluxFlow.md already exists in this directory.",isMeta:!0}]));else try{oo.writeFileSync(P,L),N(j=>(ee(j.length+1),[...j,{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(j){N(te=>(ee(te.length+1),[...te,{id:"init-err-"+Date.now(),role:"system",text:`\u274C ERROR: Failed to initialize FluxFlow.md: ${j.message}`,isMeta:!0}]))}}else N(L=>(ee(L.length+1),[...L,{id:"ff-err-"+Date.now(),role:"system",text:"\u2753 Usage: /fluxflow init",isMeta:!0}]));break}case"/update":{if(O[1]?.toLowerCase()==="check"){J(!0);break}let L=O.includes("--latest");Y("update");break}case"/help":{N(S=>(ee(S.length+1),[...S,{id:Date.now(),role:"system",isHelpRecord:!0,isMeta:!0}]));break}default:let X=Ce(2);N(S=>(ee(S.length+1),[...S,{id:Date.now(),role:"system",text:`\u{1F527}${X}[SYSTEM] Unknown command: ${$}`,isMeta:!0}]))}}else{let O=`[Prompted on: ${new Date().toLocaleString()}]`,$={id:"user-"+Date.now(),role:"user",text:`${B}
|
|
566
570
|
|
|
567
|
-
${O}`};N(S=>(ee(S.length+1),[...S,$])),(async()=>{let S=!1;cr(!0),a(!1);let L=Date.now(),
|
|
571
|
+
${O}`};N(S=>(ee(S.length+1),[...S,$])),(async()=>{let S=!1;cr(!0),a(!1);let L=Date.now(),P=!0;try{let j=[...Oe,$].filter(R=>R.role!=="think"&&!R.isVisualFeedback&&!R.isMeta&&!String(R.id).startsWith("welcome")),te=[];j.forEach((R,ae)=>{let ge=R.fullText||R.text;if(R.role==="user"&&ae<j.length-1){let Le=ge.lastIndexOf("[USER]");Le!==-1&&(ge=ge.substring(Le+6).trim())}if(R.role==="system"&&ge?.startsWith("[TOOL RESULT]")){let Le=te[te.length-1];if(Le&&Le.role==="system"&&Le.text?.startsWith("[TOOL RESULT]")){Le.text+=`
|
|
568
572
|
|
|
569
|
-
`+ge;return}}te.push({...R,text:ge})});let be=il(Ve,te,{profile:Me,thinkingLevel:q,mode:f,systemSettings:_t,janitorModel:_e,sessionStats:he,chatId:Re,aiProvider:U,apiKey:ve,apiTier:He,cols:h.columns-6,rows:30,onExecStart:R=>{tt(R),go("")},onExecChunk:R=>{go(ae=>ae+R)},onExecEnd:()=>{N(R=>{if(!qt.current)return R;let ae=We.current||"",ge="";if(
|
|
573
|
+
`+ge;return}}te.push({...R,text:ge})});let be=il(Ve,te,{profile:Me,thinkingLevel:q,mode:f,systemSettings:_t,janitorModel:_e,sessionStats:he,chatId:Re,aiProvider:U,apiKey:ve,apiTier:He,cols:h.columns-6,rows:30,onExecStart:R=>{tt(R),go("")},onExecChunk:R=>{go(ae=>ae+R)},onExecEnd:()=>{N(R=>{if(!qt.current)return R;let ae=We.current||"",ge="";if(To){let vt=/\x1b\[H|\x1b\[2J|\x1b\[3J|\x1bc/g,me=[...ae.matchAll(vt)],ye=ae;if(me.length>0){let Ke=me[me.length-1];ye=ae.substring(Ke.index+Ke[0].length)}ge=ye.replace(/\r+\n/g,`
|
|
570
574
|
`).split(`
|
|
571
575
|
`).map(Ke=>{let gt=Ke.split("\r");return gt[gt.length-1]}).join(`
|
|
572
576
|
`)}else ge=ae.replace(/\r\n/g,`
|
|
573
577
|
`);let Le=`[TERMINAL_RECORD]
|
|
574
578
|
COMMAND: ${qt.current}
|
|
575
|
-
PTY: ${
|
|
579
|
+
PTY: ${To}
|
|
576
580
|
OUTPUT: ${ge.replace(/\n{3,}/g,`
|
|
577
581
|
|
|
578
582
|
`)}`;return[...R,{id:"term-"+Date.now(),role:"system",text:Le,isTerminalRecord:!0}]}),tt(null),Dt(!1),go("")},onToolResult:(R,ae)=>{if(R==="success"){if(at(ge=>ge+1),ae==="generate_image"){gs(vt=>vt+1);let Le={Low:.001,"Low-High":.002,Medium:.008,"Medium-High":.01,High:.045,Ultra:.0488,Premium:.1}[ne.quality]||.002;xs(vt=>vt+Le)}}else R==="denied"?hs(ge=>ge+1):Gt(ge=>ge+1)},onToolApproval:async(R,ae)=>{let ge=Io||_t.autoExec;if(R==="exec_command"){let{command:Le}=oe(ae||"{}");return ge||Le&&/^(echo|ls|dir|pwd|cd|git status|git log|git diff|type|cat|help)\b/i.test(Le.trim())?"allow":new Promise(me=>{An({tool:R,args:ae,resolve:me}),Y("terminalApproval")})}return ge?"allow":new Promise(Le=>{An({tool:R,args:ae,resolve:Le}),Y("approval")})},onAskUser:async(R,ae)=>new Promise(ge=>{$r({question:R,options:ae,resolve:Le=>{N(vt=>[...vt,{id:"ask-"+Date.now(),role:"system",text:`\u{1F4AC} **Ask User**
|
|
579
|
-
Selection: ${Le}`,isAskRecord:!0}]),ge(Le)}}),Y("ask")})},async()=>{if(
|
|
583
|
+
Selection: ${Le}`,isAskRecord:!0}]),ge(Le)}}),Y("ask")})},async()=>{if(wo.current){let R=wo.current;return Mt(null),wo.current=null,N(ae=>{let ge=[...ae].reverse().findIndex(Le=>Le.text?.includes("[STEERING HINT: QUEUED]"));if(ge!==-1){let Le=ae.length-1-ge,vt=[...ae];return vt[Le]={...vt[Le],text:vt[Le].text.replace("[STEERING HINT: QUEUED]","[STEERING HINT: INJECTED]"),color:"cyan"},vt}return ae}),R}return null},Mn),ue=!1,Fe=null,Be=null,$e=!1,Vt=!1,Qo=!1,Ao=!1,Fo=0,Ot=null,mr=/\[?\s*turn\s*:\s*.*?\s*\]?/gi;for await(let R of be){if(P&&R.type==="text"&&(L=Date.now(),P=!1),R.type==="status"){lr(R.content),Ro()&&cs(R.content);continue}if(R.type==="status_history"){lr(R.content),Ro()&&cs(R.content),N(me=>[...me,{id:"condense-"+Date.now(),role:"system",text:`\u2699\uFE0F [SYSTEM] ${R.content}`,isMeta:!0}]);continue}if(R.type==="spinner"){Di(R.content);continue}if(R.type==="model_update"){vn(R.content);continue}if(R.type==="turn_reset"){Fe=null,Be=null,ue=!1,$e=!1,Vt=!1,Ao=!1,Qo=!1;continue}if(R.type==="interactive_turn_finished"){cr(!1),Ro()&&cs(null),S=!0,rl({profile:Me,thinkingLevel:q,mode:f,janitorModel:_e,chatId:Re,systemSettings:_t,sessionStats:he,aiProvider:U,apiKey:ve},R.data.agentText,R.data.fullAgentTextRaw,R.data.history,{onMemoryUpdated:()=>N(me=>{let ye=[...me];return ye.length>0&&(ye[ye.length-1].memoryUpdated=!0),ye}),onBackgroundIncrement:()=>je(me=>me+1)});continue}if(R.type==="visual_feedback"){N(me=>[...me,{id:"feedback-"+Date.now(),role:"system",text:R.content,isVisualFeedback:!0}]);continue}if(R.type==="exec_start")continue;if(R.type==="liveTokens"){st({tokens:R.content});continue}if(R.type==="usage"){let me=R.content.totalTokenCount||0,ye=R.content.cachedContentTokenCount||0,Xe=R.content.candidatesTokenCount||0;st({tokens:me}),Nt(Ke=>Ke+me),ye>0&&co(Ke=>Ke+ye),Xe>0&&un(Ke=>Ke+Xe),wt(Ke=>Ke+1);continue}if(R.type==="tool_time"){Li(me=>me+R.content);continue}if(R.type==="tool_result"){if(N(me=>[...me,{id:"tool-"+Date.now(),role:"system",text:R.content,fullText:R.aiContent,binaryPart:R.binaryPart,toolName:R.toolName}]),R.toolName==="update_file"&&R.aiContent){let me=R.aiContent.split(`
|
|
580
584
|
`),ye=0,Xe=0,Ke=!1;for(let gt of me){if(gt.includes("[DIFF_START]")){Ke=!0;continue}if(gt.includes("[DIFF_END]")){Ke=!1;continue}Ke&&(/^\+\d+/.test(gt)?ye++:/^\-\d+/.test(gt)&&Xe++)}ms+=ye,fs+=Xe,fo("linesAdded",ye),fo("linesRemoved",Xe)}else if(R.toolName==="write_file"&&R.aiContent){let me=R.aiContent.match(/- Stats: \[(\d+) lines/),ye=me?parseInt(me[1]):0,Xe=0;if(R.aiContent.includes("Old File contents:")){let Ke=R.aiContent.split(`
|
|
581
|
-
`),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,fo("linesAdded",ye),fo("linesRemoved",Xe)}continue}let ae=R.content,ge=ae.toLowerCase();if(ae.includes("```")&&($e=!$e),ge.includes("tool:functions.")&&(Vt=!0,Po=0,Ot=null,ae.includes("[tool:functions.")&&(Po=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==="["?Po++:(ye===")"||ye==="]")&&Po--)}Po<=0&&!Ot&&(Vt=!1)}if((ge.includes("<think")||ge.includes("<thought"))&&(!ue&&!$e&&!Vt&&!Qo)&&(ue=!0,Qo=!0,ae=ae.replace(/<(think|thought)>[\s\S]*?<\/(think|thought)>/gi,"").replace(/<(think|thought)>/gi,""),Pe="think-"+Date.now(),N(me=>[...me,{id:Pe,role:"think",text:"",isStreaming:!0,startTime:Date.now()}])),(ge.includes("</think>")||ge.includes("</thought>"))&&Pe){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===Pe&&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&&Pe)N(me=>{let ye=!1,Xe="",Ke=me.map(gt=>{if(gt.id===Pe){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 Zo=Date.now();Dr(R=>R+(Zo-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")),yo.current){xo(yo.current),Mt(null);let j=yo.current;yo.current=null,N(te=>{let be=[...te],ue=be.reverse().find(Pe=>Pe.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(),Pe=ue.filter(Be=>!String(Be.id).startsWith("welcome")&&!Be.isMeta);return es(Re,null,Pe),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 F=L.relativePath.replace(/\\/g,"/");return{cmd:"@["+(F.startsWith(".")?F:"./"+F)+$+"]",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:He,setActiveView:Y,setInputConfig:Co,saveSettings:Rn,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),Rn({aiProvider:g,activeModel:B,apiTier:He,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 Co({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: ",He.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"?(Co({label:"Enter Agent daily budget (requests made):",key:"quotas",subKey:"agentLimit",value:String(jt.agentLimit)}),Y("input")):(Rn({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=>Co(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,Yn(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(F=>(ee(F.length+1),[...F,{id:Date.now(),role:"system",text:`\u2705 ${S} API Key saved successfully! Model set to ${L}.`,isMeta:!0}]))}B?Co(B(g==="quotas"?O:x)):(Rn({...$,apiTier:He,quotas:O,imageSettings:$.imageSettings||ne}),Co(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"},zo(Date.now()-Ai))),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Agent Interactions:")),s.createElement(y,{color:"white"},Fo)),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"},zo(or))),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"},zo(nr))),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)))),rr>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"},rr)),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Image Credits:")),s.createElement(y,{color:"white"},Number(((sr||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:Vo?.question,options:Vo?.options,onResolve:x=>{Vo?.resolve&&Vo.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(`
|
|
582
|
-
`).length>2);let $=O.filter(S=>!String(S.id).startsWith("welcome")&&!S.isMeta);await es(Re,null,$);let X=Ce(2);N(S=>{let L=[...S,{id:"revert-ok-"+Date.now(),role:"system",text:`\u{1F504}${X}[TIME TRAVEL] Codebase rolled back successfully! Reverted prompt loaded to input box.`,isMeta:!0}];return ee(L.length),L}),Y("chat")}}catch(g){let M=Ce(2);N(B=>{let O=[...B,{id:"revert-err-"+Date.now(),role:"system",text:`\u274C${M}[TIME TRAVEL ERROR] Failed to rollback: ${g.message}`,isMeta:!0}];return ee(O.length),O}),Y("chat")}},onClose:()=>Y("chat")}));case"resume":return s.createElement(C,{width:"100%",alignItems:"center",justifyContent:"center"},s.createElement(Ci,{onSelect:async x=>{let g=await $o();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:
|
|
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,fo("linesAdded",ye),fo("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&&!Qo)&&(ue=!0,Qo=!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 Zo=Date.now();Dr(R=>R+(Zo-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")),wo.current){yo(wo.current),Mt(null);let j=wo.current;wo.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(Re,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:He,setActiveView:Y,setInputConfig:ko,saveSettings:Rn,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),Rn({aiProvider:g,activeModel:B,apiTier:He,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 ko({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: ",He.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"?(ko({label:"Enter Agent daily budget (requests made):",key:"quotas",subKey:"agentLimit",value:String(jt.agentLimit)}),Y("input")):(Rn({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=>ko(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,Yn(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?ko(B(g==="quotas"?O:x)):(Rn({...$,apiTier:He,quotas:O,imageSettings:$.imageSettings||ne}),ko(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"},zo(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"},zo(nr))),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"},zo(Hn))),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)))),rr>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"},rr)),s.createElement(C,null,s.createElement(C,{width:25},s.createElement(y,{color:"blue"},"Image Credits:")),s.createElement(y,{color:"white"},Number(((sr||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:Vo?.question,options:Vo?.options,onResolve:x=>{Vo?.resolve&&Vo.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 $=O.filter(S=>!String(S.id).startsWith("welcome")&&!S.isMeta);await es(Re,null,$);let X=Ce(2);N(S=>{let L=[...S,{id:"revert-ok-"+Date.now(),role:"system",text:`\u{1F504}${X}[TIME TRAVEL] Codebase rolled back successfully! Reverted prompt loaded to input box.`,isMeta:!0}];return ee(L.length),L}),Y("chat")}}catch(g){let M=Ce(2);N(B=>{let O=[...B,{id:"revert-err-"+Date.now(),role:"system",text:`\u274C${M}[TIME TRAVEL ERROR] Failed to rollback: ${g.message}`,isMeta:!0}];return ee(O.length),O}),Y("chat")}},onClose:()=>Y("chat")}));case"resume":return s.createElement(C,{width:"100%",alignItems:"center",justifyContent:"center"},s.createElement(Ci,{onSelect:async x=>{let g=await $o();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:or+`
|
|
583
587
|
|
|
584
|
-
\u{1F30A}\u26A1 Resuming Flux Flow Session...`,isMeta:!0}),N(M),Y("chat"),N(O=>{let $=[...O,{id:"sys-"+Date.now(),role:"system",text:`\u{1F4E1} SESSION RESUMED: [${x}]`,isMeta:!0}];return ee($.length),$})}},onDelete:async x=>await Ws(x),onClose:()=>Y("chat")}));case"memory":return s.createElement(C,{width:"100%",alignItems:"center",justifyContent:"center"},s.createElement(Ii,{onClose:()=>Y("chat")}));case"profile":return s.createElement(
|
|
585
|
-
\u{1F680} **Restart Flux Flow to see changes.**`,isMeta:!0}])),Y("chat")},onUpdateSettings:x=>{Y("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},oe(
|
|
588
|
+
\u{1F30A}\u26A1 Resuming Flux Flow Session...`,isMeta:!0}),N(M),Y("chat"),N(O=>{let $=[...O,{id:"sys-"+Date.now(),role:"system",text:`\u{1F4E1} SESSION RESUMED: [${x}]`,isMeta:!0}];return ee($.length),$})}},onDelete:async x=>await Ws(x),onClose:()=>Y("chat")}));case"memory":return s.createElement(C,{width:"100%",alignItems:"center",justifyContent:"center"},s.createElement(Ii,{onClose:()=>Y("chat")}));case"profile":return s.createElement(Ps,{initialData:Me,onSave:x=>{rt(x),N(g=>[...g,{id:Date.now(),role:"system",text:`\u2705 Profile updated: ${x.name} (${x.nickname})`}]),Y("chat")},onCancel:()=>Y("chat")});case"resolution":return s.createElement(C,{width:"100%",alignItems:"center",justifyContent:"center"},s.createElement(cd,{data:Ne,onResolve:x=>{yo(null),Y("chat"),setTimeout(()=>{Ge(x,!0)},500)},onEdit:x=>{yo(null),Y("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"},oe(jn?.args||"{}").path||"Unknown File")),Ro()?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=oe(jn?.args||"{}"),g=[],M=new Set;if(Object.keys(x).forEach($=>{let X=$.match(/^(replaceContent|newContent|content_to_replace|content_to_add|TargetContent|ReplacementContent|replacementContent)(\d+)?$/);if(X){let S=X[2]?parseInt(X[2]):1;M.add(S)}}),Array.from(M).sort(($,X)=>$-X).forEach($=>{let X,S;$===1?(X=x.replaceContent1??x.content_to_replace1??x.replaceContent??x.content_to_replace??x.TargetContent??null,S=x.newContent1??x.content_to_add1??x.newContent??x.content_to_add??x.ReplacementContent??x.replacementContent??null):(X=x[`replaceContent${$}`]??x[`content_to_replace${$}`]??null,S=x[`newContent${$}`]??x[`content_to_add${$}`]??null),(X!==null||S!==null)&&g.push({replace:X,new:S})}),g.length>0)return s.createElement(C,{flexDirection:"column",marginTop:1},g.map(($,X)=>{let S=$.replace!==null,L=$.new!==null;return s.createElement(C,{key:X,flexDirection:"column",marginTop:X>0?1:0},g.length>1&&s.createElement(y,{color:"gray"},"Block ",X+1,":"),S&&s.createElement(C,null,s.createElement(y,{color:"red",wrap:"anywhere",bold:!0},"- ",$.replace)),L&&s.createElement(C,{marginTop:S?1:0},s.createElement(y,{color:"green",wrap:"anywhere",bold:!0},"+ ",$.new.replace(/\[\/n\]?/g,"\\n"))))}));let O=x.content||x.ReplacementContent||x.content_to_add||x.replacementContent||x.newContent||null;return s.createElement(y,{color:"white",wrap:"anywhere"},(O?O.replace(/\[\/n\]?/g,"\\n"):null)||"Updating file content...")})()),s.createElement(C,{marginTop:1},s.createElement(io,{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"&&mn(!0);let g=x.value==="deny"?"deny":"allow";jn.resolve(g),An(null),Y("chat")}})));case"updateManager":return s.createElement(io,{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"){Y("settings");return}x.value==="custom"?(ko({label:"Enter Custom Update Command (Global install recommended):",key:"customUpdateCommand",value:_t.customUpdateCommand,next:g=>(Q(M=>({...M,updateManager:"custom",customUpdateCommand:g})),null)}),Y("input")):(Q(g=>({...g,updateManager:x.value})),Y("settings"))}});case"update":return s.createElement(fl,{latest:De,current:Mn,settings:_t,onClose:()=>Y("chat"),onSuccess:()=>{N(x=>(ee(x.length+1),[...x,{id:"update-success-"+Date.now(),role:"system",text:`\u2728 **[UPDATE COMPLETED]** Flux Flow successfully upgraded to v${De}.
|
|
589
|
+
\u{1F680} **Restart Flux Flow to see changes.**`,isMeta:!0}])),Y("chat")},onUpdateSettings:x=>{Y("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},oe(jn?.args||"{}").command||"Unknown Command"))),s.createElement(C,{marginTop:1},s.createElement(io,{title:"Risk Assessment Required",items:[{label:"\u{1F680} Run",value:"allow"},{label:"\u274C Deny",value:"deny"}],onSelect:x=>{jn.resolve(x.value),An(null),Y("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,ar?s.createElement(C,null,Ln&&!Ln&&s.createElement(ld,null),s.createElement(y,{color:"magenta",bold:!0,italic:!0},Ln&&!Ln?" ":"",ar.toUpperCase())):s.createElement(y,{color:"cyan",dimColor:!0,italic:!0}," ",l.length>0&&dr?"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"},Dn||Ve),s.createElement(y,{color:"gray",bold:!0}," ]"))),s.createElement(C,{borderStyle:"round",borderColor:Mo?"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:Mo?"magenta":"cyan",bold:!0},Mo?"\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"},Fr?" 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..."):dr===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"},ys?" Press ESC again to cancel the request.":Mo?" Enter a prompt to steer the agent.":` Send message or /cmd ... (${ot.shortcut} for newline), @file`)),s.createElement(Pi,{key:`input-${m}`,focus:!Kt,showCursor:ho,lastFocusEventTime:no.current,value:l,columns:h.columns,onChange:x=>{let g=x.replace(/\r\n/g,`
|
|
586
590
|
`).replace(/\r/g,`
|
|
587
591
|
`).replace(/\\\s*\n/g,`
|
|
588
|
-
`);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:P}):s.createElement(s.Fragment,null,s.createElement(C,{flexDirection:"column",width:"100%",flexGrow:1},Fr.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:wo}))),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"},Fe===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},Fe===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:Re,isMemoryEnabled:_t.memory,apiTier:He,aiProvider:U})),Ht==="exit"&&(()=>{let x=Date.now()-Ai,g=et+Ut,M=g>0?(et/g*100).toFixed(1):"0.0",B=or+nr,O=B>0?(or/B*100).toFixed(1):"0.0",$=B>0?(nr/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"},Re)),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)))),rr>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"},rr)),s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Image Credits:")),s.createElement(y,{color:"white"},Number(((sr||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"},zo(x))),s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Agent Active:")),s.createElement(y,{color:"white"},zo(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"},zo(or)," (",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"},zo(nr)," (",$,"%)"))))})(),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")&&He==="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"&&He!=="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,tr,dd,ud,Ol=ie(async()=>{Pi();Yi();ji();Gi();await zi();Ji();Zi();Sr();await al();ui();Er();ll();cl();await pl();sn();hl();ns();ks();Qt();to();hn();await xr();wl();$n();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,tr)),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=Wn.join(Wn.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)}}))),tr=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
|
|
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:To}))),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:Re,isMemoryEnabled:_t.memory,apiTier:He,aiProvider:U})),Ht==="exit"&&(()=>{let x=Date.now()-Ai,g=et+Ut,M=g>0?(et/g*100).toFixed(1):"0.0",B=nr+Hn,O=B>0?(nr/B*100).toFixed(1):"0.0",$=B>0?(Hn/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"},Re)),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)))),rr>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"},rr)),s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Image Credits:")),s.createElement(y,{color:"white"},Number(((sr||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"},zo(x))),s.createElement(C,null,s.createElement(C,{width:20},s.createElement(y,{color:"blue"},"Agent Active:")),s.createElement(y,{color:"white"},zo(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"},zo(nr)," (",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"},zo(Hn)," (",$,"%)"))))})(),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")&&He==="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"&&He!=="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,or,dd,ud,Ol=ie(async()=>{Fi();Yi();ji();Gi();await zi();Ji();Zi();Sr();await al();ui();Er();ll();cl();await pl();sn();hl();ns();ks();Qt();to();hn();await xr();wl();$n();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,or)),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=Wn.join(Wn.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)}}))),or=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
|
|
589
593
|
\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
|
|
590
594
|
\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
|
|
591
595
|
\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
|