command-code 0.20.1 → 0.21.0

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/index.mjs CHANGED
@@ -290,4 +290,4 @@ import*as e from"path";import t,{join as n,dirname as r,parse as o,relative as s
290
290
  ░█▀▀░█▀▄▀█░█▀▄░
291
291
  ░█░░░█░▀░█░█░█░
292
292
  ░▀▀▀░▀░░░▀░▀▀░░
293
- `,v_=getMaxLineWidth(C_),k_=S_,T_=__name(e=>{const t=e??getTerminalWidth();return t>=w_?"full":t>=k_?"compact":"minimal"},"getHeaderLayout");dv(),Ht(),hr();var __=__name(({children:e})=>{const t=[];let n="",r=!0;const o=__name(()=>{0!==n.length&&(t.push({text:n,panel:r}),n="")},"flush");for(const t of e){const e="░"===t;0===n.length?r=e:e!==r&&(o(),r=e),n+=t}return o(),K.createElement(re,null,t.map((e,t)=>K.createElement(re,{key:t,color:e.panel?mr.BG:mr.TEXT},e.text)))},"CommandLogoBanner");Ht(),hr();var x_=__name(({title:e,hashPrefix:t=!1,subPrefix:n=!1,suffix:r,padding:o=0,titleColor:s=zn.GRAY,dividerChar:i="─",dividerColor:a=zn.GRAY,boxProps:l})=>{const u=Math.max(0,(process.stdout.columns??80)-2*o),d=t?`# ${i}${i} `:n?`${i}${i} `:"",m=e?`${e} `:"",g=r?` ${r}`:"",h=d.length+m.length+g.length,f=i.repeat(Math.max(0,u-h));return K.createElement(ne,{paddingLeft:o,paddingRight:o,marginBottom:1,...l},(t||n)&&K.createElement(re,{color:a},d),e&&K.createElement(re,{color:s},m),K.createElement(re,{color:a},f),r&&K.createElement(re,{color:zn.DIM},g))},"Divider");Iv(),hr(),Ht(),hr();var A_=[{type:"user",text:"I always prefer pnpm",duration:2e3},{type:"learned",text:"Learned: pnpm (95% preference)",details:".commandcode/taste/taste.md",duration:2e3},{type:"user",text:"I prefer commander over meow",duration:2e3},{type:"updated",text:"Updated: commander boosted (60% → 95%), meow adjusted (90% → 35%)",details:".commandcode/taste/cli/taste.md",duration:2e3},{type:"user",text:"I prefer TypeScript for Node CLIs",duration:2e3},{type:"learned",text:"Learned: TypeScript for CLIs (90% preference)",details:".commandcode/taste/cli/taste.md",duration:2e3}],P_=__name(({onComplete:e,onExit:t})=>{const[n,r]=J(0),[o,s]=J(!1),i=n>=A_.length;return Z(()=>{if(n>=A_.length)return;if(o)return;const e=A_[n],t=setTimeout(()=>{r(e=>Math.min(e+1,A_.length))},e.duration);return()=>clearTimeout(t)},[n,o]),ie((n,o)=>{""===n||o.ctrl&&"c"===n?t?t():e():o.escape?e():i?(o.return||" "===n)&&e():" "===n?s(e=>!e):o.return&&r(e=>Math.min(e+1,A_.length))}),K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,K.createElement(re,{bold:!0},"Meet Your Coding Taste")),K.createElement(ne,null,K.createElement(re,{color:zn.DIM},"Command Code learns your coding style as you work.")),K.createElement(ne,null,K.createElement(re,{color:zn.DIM},"Here's how your preferences evolve in real-time:")),K.createElement(ne,{flexDirection:"column",marginY:1},A_.slice(0,n).map((e,t)=>"user"===e.type?K.createElement(ne,{key:t},K.createElement(re,null,_e.pointer," ",e.text)):K.createElement(ne,{key:t,flexDirection:"column",marginBottom:1,marginLeft:1},K.createElement(ne,null,K.createElement(re,{color:zn.DIM},"⎿ "),K.createElement(re,{color:Gn.TEXT},e.text)),e.details&&K.createElement(ne,{marginLeft:3},K.createElement(re,{color:zn.DIM},"Saved(",e.details,")"))))),i?K.createElement(ne,{flexDirection:"column",marginY:1},K.createElement(ne,null,K.createElement(re,{bold:!0,color:Gn.TEXT},"Demo Complete!")),K.createElement(ne,null,K.createElement(re,null,"Command Code will now use these preferences to generate")),K.createElement(ne,null,K.createElement(re,null,"better suggestions tailored to your coding style. The")),K.createElement(ne,null,K.createElement(re,null,"more you code, the smarter it gets.")),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Press Enter to get started →"))):K.createElement(ne,null,K.createElement(re,{color:zn.DIM},"[SPACE: pause] [ENTER: next] [ESC: skip]"+(o?" (paused)":""))))},"TasteDemoComponent"),I_=__name(({onClose:e,onExit:t})=>{const[n,r]=J(cv.getEvents()),[o,s]=J(0);ie((n,r)=>{""===n||r.ctrl&&"c"===n?t():r.ctrl&&"t"===n&&e()},{isActive:!0}),Z(()=>{const e=__name(()=>{r(cv.getEvents())},"handleNewEvent"),t=__name(()=>{r([])},"handleCleared");return cv.on("new-event",e),cv.on("cleared",t),()=>{cv.off("new-event",e),cv.off("cleared",t)}},[]),Z(()=>{const e=__name(()=>{xv(),s(e=>e+1)},"handleResize");return process.stdout.on("resize",e),()=>{process.stdout.off("resize",e)}},[]);const i=__name(e=>["learned","refactored"].includes(e),"isLearningEvent"),a=__name(e=>{const t=e.match(/^(learned|upgraded|downgraded|refactored|moved):\s*(.*)$/i);if(t){const e=t[1].toLowerCase();let n=t[2];const r=n.match(/^(.+?)\.?\s+Confidence:\s*(\d+\.?\d*)$/);let o=n,s=null;if(r){o=r[1].trim();const e=(100*parseFloat(r[2])).toFixed(2);s=`confidence: ${parseFloat(e).toString()}%`}const i={learned:"Learned",upgraded:"Reinforced",downgraded:"Downgraded",refactored:"Refactored",moved:"Moved"}[e]||e.charAt(0).toUpperCase()+e.slice(1);return{type:e,label:i,content:o,confidence:s}}return{type:null,label:null,content:e,confidence:null}},"formatLearningMessage"),l=__name(e=>{const t=e.match(/^(.+?)\s*\((\d+)%\s*(?:→|->)\s*(\d+)%\)$/);if(!t)return null;const n=t[1].trim(),r=parseInt(t[2],10),o=parseInt(t[3],10);return{text:n,oldPercent:r,newPercent:o,diff:o-r}},"parsePercentageChange"),u=__name(e=>{if(!e)return null;const t=e.match(/moved to (.+)/);if(!t)return null;const n=t[1],r=n.split("/"),o=r[r.length-1];return{category:r.slice(0,-1).join("/"),oldPath:o,newPath:n,fullPath:`.commandcode/taste/${n}`}},"formatMovedDetails"),d=ee(()=>(process.stdout.rows??24)-1,[o]);return K.createElement(ne,{flexDirection:"column",width:"100%",height:d,justifyContent:"flex-start",alignItems:"flex-start",padding:0,margin:0},K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(__,null,b_())),K.createElement(x_,{hashPrefix:!0,title:"Taste Feed",titleColor:"white",suffix:"ctrl+t to close"}),K.createElement(ne,{flexDirection:"column"},0===n.length?K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(ne,null,K.createElement(re,null,"Start using Command Code and it will begin recording your coding taste.")),K.createElement(ne,null,K.createElement(re,{color:zn.DIM},"Your preferences, patterns, and style will appear here in real-time."))),K.createElement(ce,{count:2}),K.createElement(x_,{title:"DEMO",titleColor:"white",subPrefix:!0}),K.createElement(P_,{onComplete:()=>{e()},onExit:t})):K.createElement(ne,{flexDirection:"column"},n.map(e=>{if(i(e.type)){const{type:t,label:n,content:r,confidence:o}=a(e.message),s="moved"===t?u(e.details):null,i="upgraded"===t||"downgraded"===t?l(r):null;return K.createElement(ne,{key:e.id,marginBottom:1},K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:Gn.BADGE_BG,color:Gn.BADGE_FG,bold:!0},`${Qk}${n}${Qk}`)),s?K.createElement(re,{color:zn.DIM}," ","(",s.fullPath,")"):e.details?K.createElement(re,{color:zn.DIM}," ","(",e.details,")"):null),K.createElement(ne,{marginLeft:1},K.createElement(re,{color:zn.DIM},"⎿"," "),s?K.createElement(K.Fragment,null,K.createElement(re,null," ",s.category," ","package ("),K.createElement(re,{color:zn.DIM},s.oldPath),K.createElement(re,null," ",_e.arrowRight," ",s.newPath),K.createElement(re,null,")")):i?K.createElement(K.Fragment,null,K.createElement(re,null," ",i.text," ","("),K.createElement(re,{color:zn.DIM},"confidence:"," "),K.createElement(re,{color:zn.DIM},i.oldPercent,"%"),K.createElement(re,null," ",_e.arrowRight," "),K.createElement(re,{color:i.diff>0?zn.GREEN:zn.RED},i.newPercent,"%"),K.createElement(re,null,")")):K.createElement(K.Fragment,null,K.createElement(re,null," ",r),o&&K.createElement(re,{color:zn.DIM}," ","(",o,")")))))}return K.createElement(ne,{key:e.id,marginBottom:1},K.createElement(re,{color:zn.DIM},_e.pointerSmall," ",e.message))}))))},"LearningFeedFull");function LearningView({setShowLearningFeed:e,setStaticKey:t,onExit:n}){return K.createElement(I_,{onClose:()=>{xv(),e(!1),t(e=>e+1)},onExit:n})}__name(LearningView,"LearningView"),Ht(),hr(),Ht(),hr(),Iv(),Pr();var N_=__name(({onClose:e,onSettingsChange:t,staticKey:n})=>{const[r,o]=J(!1),[s,i]=J(!0);Z(()=>{__name(async()=>{try{const e=await isTasteLearningEnabled();o(e)}catch(e){}finally{i(!1)}},"loadSettings")()},[]),ie((t,n)=>{if(!n.return&&" "!==t)return n.escape?(xv(),void e()):void 0;a()});const a=__name(async()=>{const e=!r;o(e);try{await setTasteLearning({tasteLearning:e}),t?.()}catch(t){o(!e)}},"toggleTasteLearning");return s?K.createElement(ne,{key:n,borderStyle:"single",borderColor:zn.BLUE,padding:1,flexDirection:"column"},K.createElement(re,{color:zn.BLUE,bold:!0},"Taste Settings"),K.createElement(re,{color:zn.DIM},"Loading configuration...")):K.createElement(ne,{key:n,borderStyle:"single",borderColor:zn.GRAY,padding:1,flexDirection:"column"},K.createElement(re,{bold:!0},"Taste Learning"),K.createElement(re,{color:zn.DIM},"Configure taste learning preferences for this project"),K.createElement(ne,{marginTop:1}),K.createElement(ne,{justifyContent:"space-between"},K.createElement(re,null,"Taste learning",K.createElement(re,{color:zn.DIM}," - Learn from your interactions")),K.createElement(re,{color:r?zn.GREEN:zn.GRAY},r?"enabled":"disabled")),K.createElement(ne,{marginTop:1}),K.createElement(re,{color:zn.DIM},"Taste data stored in .commandcode/taste/taste.md"),K.createElement(re,{color:zn.DIM},"Enter/Space to toggle • Esc to close"))},"TasteConfig");function TasteConfigView({staticKey:e,setShowTasteConfig:t,loadTasteStatus:n}){return K.createElement(K.Fragment,null,K.createElement(XT,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(ne,{marginBottom:1},K.createElement(re,{color:zn.DIM},"Press Esc to return to conversation")),K.createElement(N_,{onClose:()=>t(!1),onSettingsChange:n,staticKey:e})))}__name(TasteConfigView,"TasteConfigView"),Ht(),Ht(),Yt(),kw(),Iv(),hr();var R_=__name(e=>Math.ceil(e.length/4),"estimateTokens"),M_=__name(e=>e.includes("/.agents/skills/")||e.includes("\\.agents\\skills\\"),"isAgentsSkill"),$_=__name(({onClose:e})=>{const[t,n]=J([]),[r,o]=J(!0),[s,i]=J(null),[a,l]=J(0);Z(()=>{__name(async()=>{try{const{global:e,project:t}=await loadAllSkillSummaries(),r=[...e.map(e=>({label:e.name,value:e.filePath,location:"user",description:e.description,filePath:e.filePath})),...t.map(e=>({label:e.name,value:e.filePath,location:"project",description:e.description,filePath:e.filePath}))];n(r)}catch(e){i(e instanceof Error?e.message:"Failed to load skills")}finally{o(!1)}},"loadSkills")()},[]);const u=t.filter(e=>"project"===e.location),d=t.filter(e=>"user"===e.location),m=[...u,...d],g=__name(async t=>{try{await it([{file:t.filePath,line:1}]),xv(),e()}catch(e){e instanceof Error&&e.message.includes("$EDITOR environment variable")?i(h()):i(e instanceof Error?e.message:"Failed to open skill in editor")}},"handleSelectSkill");ie((t,n)=>{if(n.escape)return xv(),void e();if(n.upArrow)l(e=>Math.max(0,e-1));else if(n.downArrow)l(e=>Math.min(m.length-1,e+1));else if(n.return){const e=m[a];e&&g(e)}});const h=__name(()=>{const e=process.platform;return"win32"===e?'No editor found. Set $EDITOR: setx EDITOR "code"':"No editor found. Set $EDITOR: echo 'export EDITOR=\"code\"' >> "+("darwin"===e?"~/.zshrc":"~/.bashrc")},"getEditorSetupMessage");return r?K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(re,{color:Wn,bold:!0},"Agent Skills"),K.createElement(re,{color:zn.DIM},"Loading skills...")):s?K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(re,{color:zn.RED,bold:!0},"Agent Skills"),K.createElement(re,{color:zn.DIM},s),K.createElement(ne,{marginTop:1}),K.createElement(re,{color:zn.DIM},"Press ",K.createElement(re,{bold:!0},"Esc")," to close")):0===t.length?K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(re,{color:Wn,bold:!0},"Agent Skills"),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:zn.DIM},"No skills found")),K.createElement(re,{color:zn.DIM},"Create skills in:"),K.createElement(re,{color:zn.DIM}," ","~/",".commandcode","/","skills","/ (user)"),K.createElement(re,{color:zn.DIM}," ","~/.agents/","skills","/ (user, .agents)"),K.createElement(re,{color:zn.DIM}," ",".commandcode","/","skills","/ (project)"),K.createElement(re,{color:zn.DIM}," ",".agents/","skills","/ (project, .agents)"),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Press ",K.createElement(re,{bold:!0},"Esc")," to close"))):K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:Wn,bold:!0},"Skills"," "),K.createElement(re,{color:zn.DIM},m.length," skills")),u.length>0&&K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(ne,null,K.createElement(re,{color:er,bold:!0},"Project skills"," "),K.createElement(re,{color:er},"(",".commandcode","/","skills"," or .agents/","skills",")")),u.map((e,t)=>{const n=a===t,r=M_(e.filePath);return K.createElement(ne,{key:e.value},K.createElement(re,{color:n?zn.GREEN:zn.WHITE},e.label),r&&K.createElement(re,{color:zn.DIM}," [.agents]"),K.createElement(re,{color:zn.DIM}," · ~",R_(e.description)," description tokens"))})),d.length>0&&K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(ne,null,K.createElement(re,{color:er,bold:!0},"User skills"," "),K.createElement(re,{color:er},"(~/",".commandcode","/","skills"," or ~/.agents/","skills",")")),d.map((e,t)=>{const n=a===u.length+t,r=M_(e.filePath);return K.createElement(ne,{key:e.value},K.createElement(re,{color:n?zn.GREEN:zn.WHITE},e.label),r&&K.createElement(re,{color:zn.DIM}," [.agents]"),K.createElement(re,{color:zn.DIM}," · ~",R_(e.description)," description tokens"))})),K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(re,{dimColor:!0},"Add skills: ",K.createElement(re,{color:zn.CYAN},"cmd skills add ","<owner/repo>")),K.createElement(re,{color:zn.DIM},"Press ",K.createElement(re,{bold:!0},"Esc")," to close")))},"SkillsConfig");function SkillsConfigView({staticKey:e,setShowSkillsConfig:t}){return K.createElement(K.Fragment,null,K.createElement(XT,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement($_,{onClose:()=>t(!1),staticKey:e})))}function useTerminalWidth(){const{stdout:e}=se(),[t,n]=J(()=>e.columns??80);return Z(()=>{const t=__name(()=>n(e.columns??80),"onResize");return e.on("resize",t),()=>{e.off("resize",t)}},[e]),t}function getUsageColor(e){return e>=80?zn.RED:e>=50?zn.YELLOW:zn.GREEN}function buildProgressBar({percentage:e,width:t}){const n=Math.max(0,Math.min(100,e)),r=Math.round(n/100*t),o=t-r;return{filled:"━".repeat(r),empty:"━".repeat(o)}}__name(SkillsConfigView,"SkillsConfigView"),Ht(),Ht(),hr(),Ir(),Ht(),__name(useTerminalWidth,"useTerminalWidth"),Ht(),hr(),__name(getUsageColor,"getUsageColor"),__name(buildProgressBar,"buildProgressBar"),Iv();var L_="https://commandcode.ai/settings/usage";function getLayoutSizes({terminalWidth:e}){return e<50?{labelWidth:14,progressBarWidth:Math.max(10,e-10),showTwoColumn:!1}:e<70?{labelWidth:16,progressBarWidth:Math.max(15,e-15),showTwoColumn:!1}:{labelWidth:22,progressBarWidth:Math.min(30,e-15),showTwoColumn:!0}}function getSuccessColor(e){return e>=90?zn.GREEN:e>=70?zn.YELLOW:zn.RED}function getDaysColor(e){if(null!==e)return e<3?zn.RED:e<7?zn.YELLOW:void 0}__name(getLayoutSizes,"getLayoutSizes"),__name(getSuccessColor,"getSuccessColor"),__name(getDaysColor,"getDaysColor");var D_=__name(({plan:e,status:t})=>K.createElement(ne,{marginBottom:0},K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:zn.BLUE,color:"#f4f4f4",bold:!0},`${Qk}USAGE${Qk}`)),e&&K.createElement(K.Fragment,null,K.createElement(re,null," "),K.createElement(re,{color:zn.GRAY},e.name)),t&&K.createElement(K.Fragment,null,K.createElement(re,{color:zn.DIM}," · "),K.createElement(re,{color:"active"===t?zn.GREEN:zn.YELLOW},t))),"UsageBadge"),O_=__name(({label:e,labelWidth:t,children:n})=>K.createElement(re,null,K.createElement(re,{dimColor:!0},e.padEnd(t)),n),"Row"),F_=__name(({showRetry:e})=>K.createElement(ne,{marginTop:1},e&&K.createElement(re,{color:zn.DIM},K.createElement(re,{bold:!0},"r")," to retry · "),K.createElement(re,{color:zn.DIM},"Press ",K.createElement(re,{bold:!0},"Esc")," to close")),"UsageFooter");function getCallsLabel(e){if(!e)return"Calls";const t=new Date(e);return Number.isNaN(t.getTime())?"Calls":`Calls (since ${t.toLocaleDateString("en-US",{month:"short",day:"numeric"})})`}function buildDataRows({credits:e,summary:t,sub:n}){const r=e?.freeCredits??0,o=getCallsLabel(n?.currentPeriodStart);return{left:[{label:"Purchased",value:K.createElement(re,null,formatCredits(e?.purchasedCredits??0))},...r>0?[{label:"Free",value:K.createElement(re,null,formatCredits(r))}]:[],{label:"Renews",value:K.createElement(re,null,n?formatDateCompact(n.currentPeriodEnd):"—")}],right:[{label:o,value:K.createElement(re,null,t?t.totalCount.toLocaleString():"—")},{label:"Success",value:t?K.createElement(re,{color:getSuccessColor(t.successRate)},formatPercent(t.successRate)):K.createElement(re,null,"—")}]}}__name(getCallsLabel,"getCallsLabel"),__name(buildDataRows,"buildDataRows");var q_=__name(({onClose:e})=>{const[t,n]=J("loading"),[r,o]=J(null),[s,i]=J(!1),a=useTerminalWidth(),l=ee(()=>getLayoutSizes({terminalWidth:a}),[a]),u=te(async e=>{try{i(!1);const t=await fetchUsageData();if(e.aborted)return;if(!t.whoami)return i(t.errors.includes("Not authenticated")),void n("error");o(t),n("loaded")}catch{if(e.aborted)return;n("error")}},[]),d=K.useRef(null);ie((r,o)=>{if(o.escape&&(xv(),e()),"r"===r&&"error"===t){n("loading"),d.current?.abort();const e=new AbortController;d.current=e,u(e.signal)}}),Z(()=>{const e=new AbortController;return d.current=e,u(e.signal),()=>e.abort()},[u]);const m=r?.subscription?.data??null,g=m?getPlanInfo({planId:m.planId??""}):null;if("loading"===t)return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(D_,{plan:g,status:m?.status??null}),K.createElement(re,{color:zn.DIM},"Loading…"),K.createElement(F_,null));if("error"===t)return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(D_,{plan:g,status:m?.status??null}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},s?"Not authenticated. Run /login to connect your account.":"Something went wrong.")),K.createElement(F_,{showRetry:!s}));if(!r)return null;if(!r.credits&&!r.subscription)return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(D_,{plan:g,status:m?.status??null}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"No billing data found. Visit "),K.createElement(xr,{url:L_,text:"Studio",color:zn.CYAN}),K.createElement(re,{color:zn.DIM}," for usage details.")),K.createElement(F_,null));const h=r.credits?.credits,f=r.summary,y=g?.monthlyCredits??0,w=Math.max(0,h?.monthlyCredits??0),S=getUsagePercent({used:Math.max(0,y-w),total:y}),E=(h?.purchasedCredits??0)>0||(h?.freeCredits??0)>0||w>0,C=m?.currentPeriodEnd?getDaysRemaining(m.currentPeriodEnd):null,v=getUsageColor(S),k=buildProgressBar({percentage:S,width:l.progressBarWidth}),T=getCircleGauge(S),_=getDaysColor(C),{labelWidth:x,showTwoColumn:A}=l,P=buildDataRows({credits:h,summary:f,sub:m});return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,{marginBottom:1},K.createElement(D_,{plan:g,status:m?.status??null})),y>0?K.createElement(K.Fragment,null,K.createElement(ne,null,K.createElement(re,{color:v},k.filled),K.createElement(re,{color:er},k.empty),K.createElement(re,{bold:!0,color:v},` ${Math.round(S)}%`)),K.createElement(ne,null,K.createElement(re,{color:v},T),K.createElement(re,{bold:!0}," ",formatPercent(S)),K.createElement(re,{color:zn.GRAY}," used"),null!==C&&K.createElement(K.Fragment,null,K.createElement(re,{color:zn.DIM}," · "),K.createElement(re,{color:_},0===C?"expires today":`${C} day${1===C?"":"s"} left`)))):E?null:K.createElement(re,{color:zn.DIM},"Plan details unavailable"),A?K.createElement(ne,{flexDirection:"column",marginTop:1},Array.from({length:Math.max(P.left.length,P.right.length)}).map((e,t)=>{const n=P.left[t],r=P.right[t];return K.createElement(ne,{key:`row-${n?.label??""}-${r?.label??""}`},K.createElement(re,{dimColor:!0},(n?.label??"").padEnd(x)),K.createElement(ne,{width:23},n?.value??K.createElement(re,null)),r&&K.createElement(K.Fragment,null,K.createElement(re,{dimColor:!0},r.label.padEnd(14)),r.value))})):K.createElement(ne,{flexDirection:"column",marginTop:1},[...P.left,...P.right].map(e=>K.createElement(O_,{key:e.label,label:e.label,labelWidth:x},e.value))),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Full breakdown at "),K.createElement(xr,{url:L_,text:"commandcode.ai/settings/usage",color:zn.CYAN})),K.createElement(F_,null))},"UsageOverlay");function UsageView({staticKey:e,setShowUsageOverlay:t}){return K.createElement(K.Fragment,null,K.createElement(XT,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(q_,{onClose:()=>t(!1)})))}function countMessagesByRole({messages:e}){let t=0,n=0;for(const r of e)"user"===r.message.role&&t++,"assistant"===r.message.role&&n++;return{user:t,assistant:n}}function countToolCalls({messages:e}){let t=0,n=0;for(const r of e){const e=r.message.content;if(Array.isArray(e))for(const r of e)"tool-call"===r.type&&t++,"tool-result"===r.type&&n++}return{calls:t,results:n}}function countImages({messages:e}){let t=0;for(const n of e){const e=n.message.content;if(Array.isArray(e))for(const n of e)"image"===n.type&&t++}return t}function findCompactions({messages:e}){const t=[];for(const n of e)n.meta.isSummary&&t.push({type:"auto",timestamp:n.meta.timestamp});return t}function estimateConversationTokens({messages:e}){let t=0;for(const n of e)t+=estimateTokens(n.message);return t}function buildAutoCompactStatus({tokensUsed:e,tokenLimit:t}){const n=e/t,r=[{tier:1,threshold:zt.TIER_1_THRESHOLD,description:`Prune to last ${zt.TIER_1_KEEP_COUNT} tool calls`},{tier:2,threshold:zt.TIER_2_THRESHOLD,description:`Prune to last ${zt.TIER_2_KEEP_COUNT} tool calls`},{tier:3,threshold:zt.TIER_3_THRESHOLD,description:"Full summarization"}];let o=0;const s=r.map(r=>{const s=Math.round(r.threshold*t),i=Math.max(0,s-e);let a="upcoming";return n>=r.threshold&&(a="passed",o=r.tier),{tier:r.tier,threshold:r.threshold,tokensAt:s,description:r.description,status:a,tokensAway:i}}),i=s.findIndex(e=>"upcoming"===e.status);return{tiers:-1!==i?s.map((e,t)=>t===i?{...e,status:"current"}:e):s,currentTier:o,keepRecentTokens:zt.KEEP_RECENT_TOKENS}}function generateTips({percentage:e,conversationTokens:t,totalTokens:n,mcpToolCount:r,messageCount:o,imageCount:s}){const i=[];if(0===n)return i;const a=n>0?Math.round(t/n*100):0;e>=90&&i.push("Tier 3 auto-compact imminent — /compact now to control what gets summarized"),e>=80&&e<90&&i.push("Auto-compact Tier 3 triggers at 90% — /compact to free space before it kicks in");const l=a>60&&e>40;return l&&i.push(`${a}% is conversation — /compact to reclaim tokens`),r>0&&e>30&&i.push(`${r} MCP tools loaded — disconnect unused servers to save tokens`),s>0&&i.push(`${s} image${s>1?"s":""} in context — images use ~1.5k tokens each`),e>=50&&e<80&&!l&&i.push("/compact to free space · /model to switch models"),o>50&&e>40&&i.push(`${o} messages — consider starting a new session for a fresh context`),i}async function collectMemoryItems(){const e=(await discoverMemoryFiles(process.cwd())).filter(e=>e.exists),t=[];for(const n of e){const e=await loadMemoryFile(n.path),r=e?estimateTokens(e):0,o=process.env.HOME??"",s=o&&n.path.startsWith(o)?`~${n.path.slice(o.length)}`:n.path;t.push({name:n.description,tokens:r,source:s})}return t}function collectBuiltInTools(){const e=[];for(const t of YC){const n=JSON.stringify(t.input_schema??{}),r=estimateTokens(`${t.name} ${t.description??""} ${n}`);e.push({name:t.name,tokens:r})}for(const t of JC){const n=estimateTokens(`${t.name} ${t.type}`);e.push({name:t.name,tokens:n})}return e}function collectMcpTools(){const e=getMcpConnectionManager().getConnectedServers(),t=[];for(const n of e)if("connected"===n.status)for(const e of n.tools){const r=JSON.stringify(e.inputSchema??{}),o=estimateTokens(`${e.name} ${e.description??""} ${r}`);t.push({name:e.name,tokens:o,source:n.name})}return t}async function collectSkillItems(){const e=await loadAllSkillSummaries(),t=[];for(const n of e.project){const e=estimateTokens(`${n.name} ${n.description}`);t.push({name:n.name,tokens:e,source:"project"})}for(const n of e.global){const e=estimateTokens(`${n.name} ${n.description}`);t.push({name:n.name,tokens:e,source:"user"})}return t}async function collectAgentItems(){const e=await loadAllAgents(),t=[];for(const n of e.project){const e=estimateTokens(`${n.name} ${n.description} ${n.systemPrompt}`);t.push({name:n.name,tokens:e,source:"project"})}for(const n of e.personal){const e=estimateTokens(`${n.name} ${n.description} ${n.systemPrompt}`);t.push({name:n.name,tokens:e,source:"user"})}return t}function sumTokens(e){let t=0;for(const n of e)t+=n.tokens;return t}async function analyzeContext({contextEngine:e}){const t=e.getContextTokensUsed(),n=ES,r=getConfiguredModel(),o=e.getHistory(),s=countMessagesByRole({messages:o}),i=countToolCalls({messages:o}),a=countImages({messages:o}),l=findCompactions({messages:o}),u=e.getCompactionCount(),d=Math.max(u,l.length),m=estimateConversationTokens({messages:o}),g=collectBuiltInTools(),h=collectMcpTools(),[f,y,w]=await Promise.all([collectSkillItems(),collectAgentItems(),collectMemoryItems()]),S=sumTokens(g),E=sumTokens(h),C=S+E+sumTokens(f)+sumTokens(y)+sumTokens(w),v=t>0,k=v?t:m+C,T=!v&&o.length>0,_=Math.min(k/n*100,100),x=Math.max(0,n-k),A=Math.max(0,k-m-C),P=[];if(k>0){m>0&&P.push({name:"Conversation",tokens:m,percentage:Math.round(m/k*100),detail:`${s.user+s.assistant} messages`}),A>0&&P.push({name:"System prompt",tokens:A,percentage:Math.round(A/k*100),detail:"identity, taste, skills"});const e=S+E;if(e>0){const t=g.length,n=h.length,r=n>0?`${t} built-in + ${n} MCP`:`${t} built-in`;P.push({name:"Tool schemas",tokens:e,percentage:Math.round(e/k*100),detail:r})}}P.sort((e,t)=>t.tokens-e.tokens);const I=o.length>0?o[0]?.meta.timestamp??null:null;return{tokensUsed:k,tokenLimit:n,percentage:_,tokensRemaining:x,isEstimated:T,model:r,breakdown:P,autoCompact:buildAutoCompactStatus({tokensUsed:k,tokenLimit:n}),stats:{messageCount:o.length,userMessages:s.user,assistantMessages:s.assistant,toolCalls:i.calls,toolResults:i.results,imageCount:a,compactionCount:d,sessionStartTime:I},compactions:l,tips:generateTips({percentage:_,conversationTokens:m,totalTokens:k,mcpToolCount:h.length,messageCount:o.length,imageCount:a})}}function getLayoutSizes2({terminalWidth:e}){const t=e;return t<50?{labelWidth:14,progressBarWidth:Math.max(10,t-10),breakdownBarWidth:0,showBreakdownBars:!1,showBreakdownDetail:!1}:t<70?{labelWidth:16,progressBarWidth:Math.max(15,t-15),breakdownBarWidth:8,showBreakdownBars:!0,showBreakdownDetail:!1}:{labelWidth:22,progressBarWidth:Math.min(30,t-15),breakdownBarWidth:16,showBreakdownBars:!0,showBreakdownDetail:!0}}function formatDuration(e){if(!e)return"N/A";const t=new Date(e).getTime();if(isNaN(t))return"N/A";const n=Date.now(),r=Math.round((n-t)/6e4);return r<1?"<1m":r<60?`${r}m`:`${Math.floor(r/60)}h ${r%60}m`}function ContextProgress({analysis:e,progressBarWidth:t}){const n=getUsageColor(e.percentage),r=buildProgressBar({percentage:e.percentage,width:t});return K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(ne,{marginBottom:0},K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:zn.BLUE,color:"#f4f4f4",bold:!0},`${Qk}CONTEXT${Qk}`)),K.createElement(re,null," "),K.createElement(re,{color:zn.GRAY},e.model)),K.createElement(ne,null,K.createElement(re,{color:n},r.filled),K.createElement(re,{color:er},r.empty),K.createElement(re,{bold:!0,color:n},` ${e.percentage.toFixed(1)}%`)),K.createElement(ne,null,K.createElement(re,null,formatTokens(e.tokensUsed)),K.createElement(re,{color:zn.GRAY},` / ${formatTokens(e.tokenLimit)}`),K.createElement(re,{color:zn.DIM}," · "),K.createElement(re,{color:n},formatTokens(e.tokensRemaining)),K.createElement(re,{color:zn.GRAY}," remaining"),e.isEstimated&&K.createElement(re,{color:zn.DIM}," (estimated)")),K.createElement(CompactionDistance,{analysis:e}))}function BreakdownRow({item:e,maxTokens:t,labelWidth:n,barWidth:r,showBar:o,showDetail:s}){const i=o&&t>0?Math.round(e.tokens/t*r):0,a="█".repeat(i),l="░".repeat(r-i);return K.createElement(ne,null,K.createElement(re,null,e.name.padEnd(n)),o&&K.createElement(K.Fragment,null,K.createElement(re,{color:zn.CYAN},a),K.createElement(re,{color:er},l)),K.createElement(re,{bold:!0},` ${formatTokens(e.tokens)}`),K.createElement(re,{color:zn.GRAY},` ${e.percentage}%`),s&&e.detail&&K.createElement(re,{color:zn.DIM},` ${e.detail}`))}function ContextBreakdown({analysis:e,labelWidth:t,breakdownBarWidth:n,showBreakdownBars:r,showBreakdownDetail:o}){return 0===e.breakdown.length?null:K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{color:er,bold:!0},"Breakdown"),e.breakdown.map(s=>K.createElement(BreakdownRow,{key:s.name,item:s,maxTokens:e.tokensUsed,labelWidth:t,barWidth:n,showBar:r,showDetail:o})))}function CompactionDistance({analysis:e}){const t=e.autoCompact.tiers.find(e=>3===e.tier);if(!t||"passed"===t.status)return null;const n=Math.round(100*t.threshold)-Math.round(e.percentage),r=n<=10?zn.RED:n<=25?zn.YELLOW:zn.GRAY;return K.createElement(ne,null,K.createElement(re,{color:zn.DIM},"Full summarization"),K.createElement(re,{color:r},` ${n}% away`))}function ContextSession({analysis:e,labelWidth:t}){return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:er,bold:!0},"Session"),K.createElement(ne,null,K.createElement(re,null,"Messages".padEnd(t)),K.createElement(re,{color:zn.GRAY},`${e.stats.messageCount} (${e.stats.userMessages} user, ${e.stats.assistantMessages} assistant)`)),K.createElement(ne,null,K.createElement(re,null,"Tool calls".padEnd(t)),K.createElement(re,{color:zn.GRAY},`${e.stats.toolCalls} calls · ${e.stats.toolResults} results`)),e.stats.imageCount>0&&K.createElement(ne,null,K.createElement(re,null,"Images".padEnd(t)),K.createElement(re,{color:zn.GRAY},`${e.stats.imageCount}`)),K.createElement(ne,null,K.createElement(re,null,"Duration".padEnd(t)),K.createElement(re,{color:zn.GRAY},formatDuration(e.stats.sessionStartTime))))}function ContextTips({tips:e}){return 0===e.length?null:K.createElement(ne,{flexDirection:"column"},e.map(e=>K.createElement(ne,{key:e},K.createElement(re,{color:zn.CYAN},_e.pointer),K.createElement(re,{color:zn.GRAY}," ",e))))}function ContextHints(){return K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(ne,null,K.createElement(re,{color:zn.GRAY},">"," "),K.createElement(re,{color:zn.GRAY},"Auto-compact kicks in when context reaches its limit")),K.createElement(ne,null,K.createElement(re,{color:zn.GRAY},">"," "),K.createElement(re,{color:zn.GRAY},"Run /compact to manually summarize your conversation and free up context")))}function ContextMessage({analysis:e}){const t=getLayoutSizes2({terminalWidth:useTerminalWidth()});return K.createElement(ne,{flexDirection:"column",paddingTop:1},K.createElement(ContextProgress,{analysis:e,progressBarWidth:t.progressBarWidth}),K.createElement(ContextBreakdown,{analysis:e,labelWidth:t.labelWidth,breakdownBarWidth:t.breakdownBarWidth,showBreakdownBars:t.showBreakdownBars,showBreakdownDetail:t.showBreakdownDetail}),K.createElement(ContextSession,{analysis:e,labelWidth:t.labelWidth}),K.createElement(ContextTips,{tips:e.tips}),K.createElement(ContextHints,null))}function ContextConfigView({staticKey:e,contextEngineRef:t,setShowContextView:n,setInput:r}){const[o,s]=J(null),[i,a]=J(null);return Z(()=>{let e=!0;return __name(async()=>{if(t.current)try{const n=await analyzeContext({contextEngine:t.current});e&&s(n)}catch{e&&a("Failed to analyze context.")}else e&&a("No active conversation. Start chatting first.")},"load")(),()=>{e=!1}},[t]),ie((e,t)=>{t.escape&&(xv(),r(""),n(!1))}),K.createElement(K.Fragment,null,K.createElement(XT,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},i?K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:Wn,bold:!0},"Context"),K.createElement(re,{color:zn.DIM},i)):o?K.createElement(ContextMessage,{analysis:o}):K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:Wn,bold:!0},"Context"),K.createElement(re,{color:zn.DIM},"Loading context analysis...")),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Press Esc to return to conversation"))))}__name(UsageView,"UsageView"),Ht(),Ht(),Yt(),TE(),ME(),bw(),rv(),hw(),AS(),Pr(),__name(countMessagesByRole,"countMessagesByRole"),__name(countToolCalls,"countToolCalls"),__name(countImages,"countImages"),__name(findCompactions,"findCompactions"),__name(estimateConversationTokens,"estimateConversationTokens"),__name(buildAutoCompactStatus,"buildAutoCompactStatus"),__name(generateTips,"generateTips"),__name(collectMemoryItems,"collectMemoryItems"),__name(collectBuiltInTools,"collectBuiltInTools"),__name(collectMcpTools,"collectMcpTools"),__name(collectSkillItems,"collectSkillItems"),__name(collectAgentItems,"collectAgentItems"),__name(sumTokens,"sumTokens"),__name(analyzeContext,"analyzeContext"),Iv(),Ht(),hr(),qr(),__name(getLayoutSizes2,"getLayoutSizes"),__name(formatDuration,"formatDuration"),__name(ContextProgress,"ContextProgress"),__name(BreakdownRow,"BreakdownRow"),__name(ContextBreakdown,"ContextBreakdown"),__name(CompactionDistance,"CompactionDistance"),__name(ContextSession,"ContextSession"),__name(ContextTips,"ContextTips"),__name(ContextHints,"ContextHints"),__name(ContextMessage,"ContextMessage"),hr(),__name(ContextConfigView,"ContextConfigView"),Ht(),Ht(),Yt(),zo(),ME(),bw(),Kr(),Fr(),Pr();var j_="https://commandcode.ai/studio";function getVersionStatus(){try{return{current:getPackageJson().version,updateAvailable:null}}catch{return{current:"Unknown",updateAvailable:null}}}async function getAuthStatus(){try{const e=await checkAuthStatus(),t=e.userName||null;return{authenticated:e.authenticated,username:t}}catch{return{authenticated:!1,username:null}}}async function getModelStatus(){try{const e=await getSelectedModel(),t=getProviderDisplayName((await loadUserConfig()).provider||null);return{id:e,displayName:getModelDisplayName(e),provider:t}}catch{return{id:"Unknown",displayName:"Unknown",provider:"Unknown"}}}async function getSkillsAgentsStatus(){let e=0,t=0,n=0,r=0;try{const n=await loadAllSkillSummaries();e=n.global.length,t=n.project.length}catch{}try{const e=await loadAllAgents();n=e.personal.length,r=e.project.length}catch{}return{personalSkills:e,projectSkills:t,personalAgents:n,projectAgents:r}}function execGitAsync(e){return new Promise(t=>{L("git",e,{encoding:"utf8",cwd:process.cwd(),timeout:3e3},(e,n)=>{t(e?null:n.trim()||null)})})}async function getGitStatus2(){const e=await execGitAsync(["rev-parse","--abbrev-ref","HEAD"]);if(!e)return{branch:null,worktreePath:null,remoteUrl:null,remoteHttpUrl:null};const[t,n]=await Promise.all([execGitAsync(["rev-parse","--show-toplevel"]),execGitAsync(["remote","get-url","origin"])]);return{branch:e,worktreePath:t,remoteUrl:n?formatRemoteUrl(n):null,remoteHttpUrl:n?buildHttpUrl(n):null}}function parseSSHUrl(e){const t=e.match(/@([^:]+):(.+?)(?:\.git)?$/);return t?.[1]&&t[2]?{host:t[1],path:t[2]}:null}function formatRemoteUrl(e){const t=parseSSHUrl(e);if(t)return t.path;const n=e.match(/\/\/[^/]+\/(.+?)(?:\.git)?$/);return n?.[1]?n[1]:e}function buildHttpUrl(e){const t=parseSSHUrl(e);if(t)return`https://${t.host}/${t.path}`;const n=e.match(/^ssh:\/\/[^@]+@([^/]+)\/(.+?)(?:\.git)?$/);return n?.[1]&&n[2]?`https://${n[1]}/${n[2]}`:/^https?:\/\//.test(e)?e.replace(/\.git$/,""):e}function getPrStatus(e){try{const t=getCachedPR(e);return t?{number:t.number,url:t.url,state:t.state}:null}catch{return null}}async function hasTasteMdFiles(e){if(!v(e))return!1;try{return(await U(e,{recursive:!0,encoding:"utf-8"})).some(e=>e.endsWith(".md"))}catch{return!1}}async function getTasteStatus(){const e=t.join(process.cwd(),".commandcode","taste"),n=t.join(e,"taste.md"),r=v(n),o=r||await hasTasteMdFiles(e);let s=!0;try{s=await isTasteLearningEnabled()}catch{}return{fileExists:o,filePath:r?n:e,learningEnabled:s}}function detectProxy(){const e=process.env.HTTPS_PROXY||process.env.https_proxy||process.env.HTTP_PROXY||process.env.http_proxy;return e?sanitizeProxyUrl(e):null}function sanitizeProxyUrl(e){try{const t=new URL(e);return t.username="",t.password="",t.toString().replace(/\/$/,"")}catch{return"[malformed proxy URL]"}}function getSystemStatus(){let e,t,n,r;try{e=xT(w.platform()),t=BT(),n=UT(),r=zT()}catch{e="Unknown",t="Unknown",n="Unknown",r="N/A"}return{cwd:process.cwd(),os:e,arch:w.arch(),shell:n,terminal:t,nodeVersion:process.version,ide:"N/A"!==r?r:null,proxy:detectProxy()}}async function gatherStatusData(){const e=safeSync(getVersionStatus,{current:"Unknown",updateAvailable:null}),t=safeSync(getSystemStatus,{cwd:process.cwd(),os:"Unknown",arch:w.arch(),shell:"Unknown",terminal:"Unknown",nodeVersion:process.version,ide:null,proxy:null}),[n,r,o,s,i]=await Promise.all([safeAsync(getAuthStatus,{authenticated:!1,username:null}),safeAsync(getModelStatus,{id:"Unknown",displayName:"Unknown",provider:"Unknown"}),safeAsync(getTasteStatus,{fileExists:!1,filePath:"",learningEnabled:!1}),safeAsync(getSkillsAgentsStatus,{personalSkills:0,projectSkills:0,personalAgents:0,projectAgents:0}),safeAsync(getGitStatus2,{branch:null,worktreePath:null,remoteUrl:null,remoteHttpUrl:null})]),a=safeSync(()=>getPrStatus(i.branch),null);return{version:e,auth:n,model:r,git:i,pr:a,taste:o,skillsAgents:s,system:t}}function safeSync(e,t){try{return e()}catch{return t}}async function safeAsync(e,t){try{return await e()}catch{return t}}function formatCountValue(e,t){const n=e+t;return 0===n?"None":`${n} (${e} user, ${t} project)`}function formatSystemValue({system:e}){const t=[`${e.os} ${e.arch}`];return e.ide&&t.push(e.ide),!e.terminal||e.ide&&e.ide.toLowerCase().startsWith(e.terminal.toLowerCase())||t.push(e.terminal),t.push(e.shell),t.push(`Node ${e.nodeVersion}`),t.join(" · ")}__name(getVersionStatus,"getVersionStatus"),__name(getAuthStatus,"getAuthStatus"),__name(getModelStatus,"getModelStatus"),__name(getSkillsAgentsStatus,"getSkillsAgentsStatus"),__name(execGitAsync,"execGitAsync"),__name(getGitStatus2,"getGitStatus"),__name(parseSSHUrl,"parseSSHUrl"),__name(formatRemoteUrl,"formatRemoteUrl"),__name(buildHttpUrl,"buildHttpUrl"),__name(getPrStatus,"getPrStatus"),__name(hasTasteMdFiles,"hasTasteMdFiles"),__name(getTasteStatus,"getTasteStatus"),__name(detectProxy,"detectProxy"),__name(sanitizeProxyUrl,"sanitizeProxyUrl"),__name(getSystemStatus,"getSystemStatus"),__name(gatherStatusData,"gatherStatusData"),__name(safeSync,"safeSync"),__name(safeAsync,"safeAsync"),Ht(),Yt(),SC(),hr(),Ir(),__name(formatCountValue,"formatCountValue"),__name(formatSystemValue,"formatSystemValue");var B_=__name(({label:e,value:t,valueColor:n,dimValue:r})=>K.createElement(ne,null,K.createElement(re,{dimColor:!0},`${e}:`.padEnd(14)),r?K.createElement(re,{dimColor:!0},t):K.createElement(re,{color:n},t)),"Row");function StatusMessage({statusData:e}){const t=e,n=t.version.updateAvailable?`v${t.version.current} → v${t.version.updateAvailable} available`:`v${t.version.current}`,r=`${t.model.provider} · ${t.model.displayName}`,o=t.git.branch||"N/A",s=t.git.worktreePath?toRelativePath(t.git.worktreePath):null,i=t.auth.authenticated?_e.tick:_e.cross,a=t.auth.authenticated?zn.WHITE:Xn.ERROR,l=t.skillsAgents.personalSkills+t.skillsAgents.projectSkills,u=t.skillsAgents.personalAgents+t.skillsAgents.projectAgents,d=t.taste.fileExists?"Active · "+(t.taste.learningEnabled?"Learning on":"Learning off"):"No taste.md";return K.createElement(ne,{flexDirection:"column",paddingX:0},K.createElement(ne,null,K.createElement(re,{color:Wn,bold:!0},"Command Code"," "),K.createElement(re,{dimColor:!0},n)),K.createElement(ne,null,K.createElement(re,{dimColor:!0},"Visit "),K.createElement(xr,{url:j_,text:j_,color:zn.CYAN}),K.createElement(re,{dimColor:!0}," for usage and billing")),K.createElement(ne,{marginTop:1},K.createElement(re,{dimColor:!0},"Account:".padEnd(14)),t.auth.authenticated&&t.auth.username?K.createElement(K.Fragment,null,K.createElement(xr,{url:`https://commandcode.ai/${t.auth.username}/`,text:t.auth.username,color:zn.CYAN}),K.createElement(re,{color:a}," ",i)):t.auth.authenticated?K.createElement(K.Fragment,null,K.createElement(re,null,"Authenticated"),K.createElement(re,{color:a}," ",i)):K.createElement(K.Fragment,null,K.createElement(re,{color:Xn.WARNING},"Not signed in"),K.createElement(re,{color:a}," ",i),K.createElement(re,{dimColor:!0}," — run "),K.createElement(re,{bold:!0},"/login"))),K.createElement(B_,{label:"Model",value:r}),K.createElement(B_,{label:"Branch",value:o,dimValue:!t.git.branch}),s?K.createElement(B_,{label:"Worktree",value:s}):null,t.git.remoteUrl?K.createElement(ne,null,K.createElement(re,{dimColor:!0},"Repository:".padEnd(14)),K.createElement(xr,{url:t.git.remoteHttpUrl||`https://github.com/${t.git.remoteUrl}`,text:t.git.remoteUrl,color:zn.CYAN}),t.pr?K.createElement(K.Fragment,null,K.createElement(re,{dimColor:!0}," · "),K.createElement(xr,{url:t.pr.url,text:`#${t.pr.number}`,color:"OPEN"===t.pr.state?zn.CYAN:zn.GRAY}),K.createElement(re,{dimColor:!0}," (",t.pr.state.toLowerCase(),")")):null):t.pr?K.createElement(ne,null,K.createElement(re,{dimColor:!0},"Pull Request:".padEnd(14)),K.createElement(xr,{url:t.pr.url,text:`#${t.pr.number}`,color:"OPEN"===t.pr.state?zn.CYAN:zn.GRAY}),K.createElement(re,{dimColor:!0}," (",t.pr.state.toLowerCase(),")")):null,K.createElement(B_,{label:"Taste",value:d,dimValue:!t.taste.fileExists}),K.createElement(B_,{label:"Directory",value:toRelativePath(t.system.cwd)}),K.createElement(B_,{label:"Skills",value:formatCountValue(t.skillsAgents.personalSkills,t.skillsAgents.projectSkills),dimValue:0===l}),K.createElement(B_,{label:"Agents",value:formatCountValue(t.skillsAgents.personalAgents,t.skillsAgents.projectAgents),dimValue:0===u}),K.createElement(B_,{label:"System",value:formatSystemValue({system:t.system})}),t.system.proxy?K.createElement(B_,{label:"Proxy",value:t.system.proxy}):null)}function StatusConfigView({staticKey:e,setShowStatusView:t,setInput:n}){const[r,o]=J({phase:"loading"});return Z(()=>{let e=!1;return gatherStatusData().then(t=>{e||o({phase:"ready",data:t})}).catch(t=>{if(e)return;const n=t instanceof Error?t.message:"Failed to gather status";o({phase:"error",message:n})}),()=>{e=!0}},[]),ie((e,r)=>{r.escape&&(n(""),t(!1))}),K.createElement(K.Fragment,null,K.createElement(XT,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},"ready"===r.phase?K.createElement(StatusMessage,{statusData:r.data}):"error"===r.phase?K.createElement(re,{dimColor:!0},"Could not load status: ",r.message):K.createElement(re,{dimColor:!0},"Gathering status…"),K.createElement(ne,{marginTop:1},K.createElement(re,{dimColor:!0},"Press Esc to return to conversation"))))}function moveFocusDown(e,t){const{suggestionCount:n,activeDirCount:r}=t;return"input"===e.zone?n>0?{...e,zone:"suggestions",suggestionIndex:0}:r>0?{...e,zone:"active-dir",activeDirIndex:0}:e:"suggestions"===e.zone?e.suggestionIndex<n-1?{...e,suggestionIndex:e.suggestionIndex+1}:r>0?{...e,zone:"active-dir",activeDirIndex:0}:{...e,zone:"input"}:e.activeDirIndex<r-1?{...e,activeDirIndex:e.activeDirIndex+1}:{...e,zone:"input"}}function moveFocusUp(e,t){const{suggestionCount:n,activeDirCount:r}=t;return"input"===e.zone?r>0?{...e,zone:"active-dir",activeDirIndex:r-1}:n>0?{...e,zone:"suggestions",suggestionIndex:n-1}:e:"suggestions"===e.zone?e.suggestionIndex>0?{...e,suggestionIndex:e.suggestionIndex-1}:{...e,zone:"input"}:e.activeDirIndex>0?{...e,activeDirIndex:e.activeDirIndex-1}:n>0?{...e,zone:"suggestions",suggestionIndex:n-1}:{...e,zone:"input"}}function getAdjustedSuggestionOffset(e){const{selectedIndex:t,currentOffset:n,maxVisible:r,totalSuggestions:o}=e;return o<=r?0:t<n?t:t>=n+r?t-r+1:n}function getSuggestionBase(e){const n=resolveDirectoryPath(e),r=/[\\/]$/.test(e),o=e.replace(/\\/g,"/");if(o.endsWith("/."))return{searchDirectory:n,prefix:".",outputPrefix:`${o.slice(0,-1)}`};if(r)return{searchDirectory:n,prefix:"",outputPrefix:o};const s=o.lastIndexOf("/");return-1===s?{searchDirectory:t.dirname(n),prefix:t.basename(n),outputPrefix:""}:{searchDirectory:t.dirname(n),prefix:t.basename(n),outputPrefix:o.slice(0,s+1)}}function getDirectorySuggestions(e){const t=e.trim();if(!t)return[];try{const{searchDirectory:e,prefix:n,outputPrefix:r}=getSuggestionBase(t),o=n.startsWith(".")||r.includes("/.");return C.readdirSync(e,{withFileTypes:!0}).filter(e=>e.isDirectory()).filter(e=>!!o||!e.name.startsWith(".")).filter(e=>!n||e.name.toLowerCase().startsWith(n.toLowerCase())).sort((e,t)=>e.name.localeCompare(t.name)).map(e=>`${r}${e.name}/`)}catch(e){const t=e.code;return"ENOENT"!==t&&"ENOTDIR"!==t&&console.error(`Warning: Could not list directory suggestions: ${t}`),[]}}function getFooterText(e){return"active-dir"===e.focusZone?"[Del] Remove [↑↓] Navigate [Tab] Autocomplete [Esc] Close":"[Enter] Add [↑↓] Navigate [Tab] Autocomplete [Esc] Close"}__name(StatusMessage,"StatusMessage"),__name(StatusConfigView,"StatusConfigView"),Ht(),Ht(),tn(),Ht(),tn(),__name(function createInitialFocusState(){return{zone:"input",suggestionIndex:0,activeDirIndex:0}},"createInitialFocusState"),__name(moveFocusDown,"moveFocusDown"),__name(moveFocusUp,"moveFocusUp"),__name(getAdjustedSuggestionOffset,"getAdjustedSuggestionOffset"),__name(getSuggestionBase,"getSuggestionBase"),__name(getDirectorySuggestions,"getDirectorySuggestions"),__name(getFooterText,"getFooterText"),hr(),wr();var U_=__name(({onClose:e})=>{const[t,n]=J(""),[r,o]=J(null),[s,i]=J([]),[a,l]=J(getAdditionalDirectories()),[u,d]=J({zone:"input",suggestionIndex:0,activeDirIndex:0}),[m,g]=J(0);Z(()=>{i(t?getDirectorySuggestions(t):[]),d(e=>({...e,zone:"input"})),g(0)},[t]),Z(()=>{if(!r||"success"!==r.tone)return;const e=setTimeout(()=>{o(null)},5e3);return()=>clearTimeout(e)},[r]);const h=__name(e=>{const t=addDirectory(e);"error"!==t.status?"skipped"!==t.status?(o({tone:"success",text:`Added ${t.displayPath} to directory scope`}),n(""),l(getAdditionalDirectories()),d({zone:"input",suggestionIndex:0,activeDirIndex:0})):o({tone:"warning",text:t.message}):o({tone:"error",text:t.message})},"submitPath"),f=__name(e=>{if(!removeAdditionalDirectory(e))return o({tone:"error",text:`${formatDirectoryForDisplay(e)} is no longer in workspace scope`}),void l(getAdditionalDirectories());o({tone:"success",text:`Removed ${formatDirectoryForDisplay(e)} from directory scope`}),l(getAdditionalDirectories()),d(e=>{if("active-dir"!==e.zone)return e;const t=Math.max(0,e.activeDirIndex-1);return{...e,activeDirIndex:t}})},"handleRemove");ie((t,r)=>{if(r.escape)e();else{if(r.return)return"suggestions"===u.zone&&s[u.suggestionIndex]?void h(s[u.suggestionIndex]):void 0;if((r.delete||r.backspace)&&"active-dir"===u.zone&&a[u.activeDirIndex])f(a[u.activeDirIndex]);else{if(r.tab&&s.length>0){const e=s[u.suggestionIndex]??s[0];return void(e&&(n(e),d(e=>({...e,zone:"input"})),o(null)))}r.downArrow?d(e=>moveFocusDown(e,{suggestionCount:s.length,activeDirCount:a.length})):r.upArrow&&d(e=>moveFocusUp(e,{suggestionCount:s.length,activeDirCount:a.length}))}}}),Z(()=>{"suggestions"===u.zone&&g(e=>getAdjustedSuggestionOffset({selectedIndex:u.suggestionIndex,currentOffset:e,maxVisible:8,totalSuggestions:s.length}))},[u,s.length]),Z(()=>{d(e=>"suggestions"===e.zone&&e.suggestionIndex>=s.length?{...e,zone:"input",suggestionIndex:Math.max(0,s.length-1)}:"active-dir"===e.zone&&e.activeDirIndex>=a.length?{...e,zone:"input",activeDirIndex:Math.max(0,a.length-1)}:e)},[s.length,a.length]);const y=s.slice(m,m+8),w=getFooterText({focusZone:u.zone});return K.createElement(ne,{flexDirection:"column",borderStyle:"single",borderColor:zn.CYAN,paddingX:1,paddingY:0},K.createElement(re,{bold:!0,color:zn.CYAN},"Add directory to workspace"),K.createElement(re,{color:zn.GRAY},"Command Code will be able to read files in this directory and make edits when accept edits mode is on."),K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(re,{color:zn.GRAY},"Added directories"),0===a.length?K.createElement(re,{color:zn.GRAY}," None yet"):a.map((e,t)=>{const n="active-dir"===u.zone&&u.activeDirIndex===t;return K.createElement(re,{key:e,color:n?zn.YELLOW:zn.GREEN,bold:n},n?` ${_e.pointer} `:" ",formatDirectoryForDisplay(e))})),K.createElement(ne,{marginTop:1},K.createElement(re,{bold:!0,color:zn.WHITE},"Path")),K.createElement(ne,null,K.createElement(TextInput,{value:t,focus:"input"===u.zone,prefix:`${"input"===u.zone?_e.pointer:" "} `,prefixColor:"input"===u.zone?zn.CYAN:zn.GRAY,onChange:e=>{n(e),o(null)},onSubmit:h})),!t&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.GRAY},"Examples: ../shared ~/docs /abs/path")),r&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:{error:zn.RED,warning:zn.YELLOW,success:zn.GREEN}[r.tone]},r.text)),s.length>0&&K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(re,{color:zn.GRAY},"Suggestions"),y.map((e,t)=>{const n=m+t,r="suggestions"===u.zone&&u.suggestionIndex===n;return K.createElement(re,{key:e,color:r?zn.CYAN:zn.GRAY,bold:r},r?` ${_e.pointer} `:" ",e)})),K.createElement(ne,{marginTop:1},K.createElement(BracketedText,{text:w,color:zn.DIM})))},"AddDirModal");Ht(),Ht(),Yt(),Ht(),Ht(),Yt(),rv(),hr();var z_=__name(()=>t.join(w.homedir(),".commandcode","agents"),"getRootAgentDir"),W_=__name(()=>t.join(process.cwd(),".commandcode","agents"),"getLocalAgentDir"),G_=__name(({config:e,onSaveComplete:n,viewOnly:r=!1})=>{const[o,s]=J("idle"),[i,a]=J(""),l=[...YC.map(e=>e.name),...JC.map(e=>e.name)],u=__name(async()=>{if(!e.agentType||!e.sysPrompt)return s("error"),void a("Agent configuration is incomplete");s("saving");try{const r="personal"===e.location?z_():W_();await O.mkdir(r,{recursive:!0});const o=`${e.agentType}.md`,s=t.join(r,o),i=Array.from(e.selectedTools).map(e=>ev[e]||e).join(", "),a=0===e.selectedTools.size?"none":e.selectedTools.size===l.length?'"*"':JSON.stringify(i),u=`---\nname: "${e.agentType}"\ndescription: ${JSON.stringify(e.ccToolDefinition)}\ntools: ${a}\n---\n\n${e.sysPrompt}\n`;await O.writeFile(s,u,"utf-8"),n(e.agentType)}catch(e){console.error("Error saving agent:",e),s("error"),a(e instanceof Error?e.message:"Unknown error occurred")}},"handleSaveAgent");ie((e,t)=>{r||!t.return||"idle"!==o&&"error"!==o||u()});const d=Array.from(e.selectedTools).map(e=>ev[e]||e).join(", "),m="personal"===e.location?`~/.commandcode/agents/${e.agentType}`:`.commandcode/agents/${e.agentType}`;return K.createElement(ne,{flexDirection:"column",gap:1},K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{gap:1},K.createElement(re,{color:zn.WHITE,bold:!0},"Name:"),K.createElement(re,{color:zn.GRAY},e.agentType)),K.createElement(ne,{gap:1},K.createElement(re,{color:zn.WHITE,bold:!0},"Location:"),K.createElement(re,{color:zn.GRAY},m)),K.createElement(ne,{gap:1},K.createElement(re,{color:zn.WHITE,bold:!0},"Tools:"),K.createElement(re,{color:zn.GRAY},0===e.selectedTools.size?"None":e.selectedTools.size===l.length?"*":d))),K.createElement(ne,{gap:1},K.createElement(re,{color:zn.WHITE,bold:!0},"Description"),K.createElement(re,{color:zn.GRAY},"(Tells ","Command Code"," when to use this agent):")),K.createElement(re,{color:zn.GRAY},e.ccToolDefinition),K.createElement(ne,{gap:1},K.createElement(re,{color:zn.WHITE,bold:!0},"System Prompt:")),K.createElement(re,{color:zn.GRAY},e.sysPrompt),!r&&K.createElement(ne,{marginTop:1},"idle"===o&&K.createElement(ne,{gap:1},K.createElement(re,{color:zn.GREEN,dimColor:!0},"Press"),K.createElement(re,{color:zn.GREEN,bold:!0},"Enter"),K.createElement(re,{color:zn.GREEN,dimColor:!0},"to save • Esc to cancel")),"saving"===o&&K.createElement(re,{color:zn.YELLOW},"Saving agent..."),"saved"===o&&K.createElement(re,{color:zn.GREEN},_e.tick," ",i),"error"===o&&K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.RED},_e.cross," Error: ",i),K.createElement(re,{color:zn.GRAY},"Press Enter to retry"))))},"AgentSummary");rv(),hr();var H_=__name(({agent:e,onBack:t,setRevalidateAgent:n,isReadOnly:r=!1})=>{const[o,s]=J("menu"),i=[...YC.map(e=>e.name),...JC.map(e=>e.name)];let a=new Set;if("*"===e.tools||'"*"'===e.tools)a=new Set(i);else if(e.tools&&"none"!==e.tools){const t=e.tools.replace(/^"|"$/g,"").split(",").map(e=>e.trim()).map(e=>tv[e]||e);a=new Set(t)}const l={location:e.location,method:"manual",agentType:e.name,sysPrompt:e.sysPrompt,ccToolDefinition:e.description,recommendedMethodDescription:"",selectedTools:a},u=[{label:"1. View agent",value:"view"},...r?[]:[{label:"2. Delete agent",value:"delete"}],{label:r?"2. Back":"3. Back",value:"back"}],d=__name(e=>{"back"===e.value?t():"view"===e.value?s("view"):"edit"===e.value?s("edit"):"delete"===e.value&&s("delete")},"handleMenuSelect");if(ie((e,n)=>{n.escape&&("menu"===o?t():s("menu")),n.return&&"view"===o&&s("menu")}),"view"===o)return K.createElement(ne,{flexDirection:"column"},K.createElement(G_,{config:l,onSaveComplete:()=>s("menu"),viewOnly:!0}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.GRAY},"Press Enter to go back")));if("edit"===o)return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.YELLOW},"Edit functionality coming soon..."),K.createElement(re,{color:zn.GRAY},"Press Esc to go back"));if("delete"===o){const r=[{label:"1. Yes, delete",value:"confirm-delete"},{label:"2. No, cancel",value:"cancel"}],o=__name(async r=>{if("confirm-delete"===r.value)try{await O.unlink(e.filePath),n(!0),t()}catch(e){console.error(`Failed to delete agent: ${e}`),s("menu")}else s("menu")},"handleDeleteSelect");return K.createElement(ne,{flexDirection:"column",gap:1},K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.RED},"Delete agent"),K.createElement(re,{color:zn.GRAY},"Are you sure you want to delete the agent ",e.name,"?")),K.createElement(ne,null,K.createElement(nt,{items:r,onSelect:o,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:zn.WHITE},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?zn.WHITE:zn.GRAY},` ${t}`)})))}return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.WHITE,bold:!0},e.name),K.createElement(ne,{marginTop:1},K.createElement(nt,{items:u,onSelect:d,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:zn.WHITE},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?zn.WHITE:zn.GRAY},` ${t}`)})),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.GRAY},"Press ↑↓ to navigate · Enter to select · Esc to go back")))},"AgentDetails");PE(),hr();var V_=__name(({handleSelect:e,createdAgentName:n})=>{const[r,o]=J([]),[s,i]=J([]),[a,l]=J([]),[u,d]=J(!0),[m,g]=J(!1),[h,f]=J(null),[y,S]=J(!1),E=__name(()=>t.join(w.homedir(),".commandcode","agents"),"getRootAgentDir"),C=__name(()=>t.join(process.cwd(),".commandcode","agents"),"getLocalAgentDir"),v=__name(async(e,n)=>{try{g(!1);const r=(await O.readdir(e)).filter(e=>e.endsWith(".md"));return(await Promise.all(r.map(async r=>{try{const o=t.join(e,r),s=await O.readFile(o,"utf-8"),{data:i,content:a}=Me(s);let l=i.tools||"";return"*"!==l&&'"*"'!==l||(l="*"),{name:i.name||r.replace(".md",""),description:i.description||"",tools:l,sysPrompt:a.trim(),location:n,filePath:o}}catch(e){return console.error(`Error loading agent from ${r}:`,e),null}}))).filter(e=>null!==e)}catch{return[]}},"loadAgentsFromDirectory");Z(()=>{__name(async()=>{d(!0);const[e,t]=await Promise.all([v(E(),"personal"),v(C(),"project")]),n=xE.map(e=>({name:e.name,description:e.description,tools:Array.isArray(e.tools)?e.tools.join(", "):e.tools,sysPrompt:e.systemPrompt,location:"personal",filePath:`__builtin__:${e.name}`}));o(e),i(t),l(n),d(!1)},"loadAgents")()},[m]);const k=[{label:"Create new agent",value:"create_new_agent"}];r.forEach(e=>{k.push({label:e.name,value:e.filePath})}),s.forEach(e=>{k.push({label:e.name,value:e.filePath})});const T=r.length+s.length,_=__name(t=>{if("create_new_agent"===t.value)e(t);else{const e=[...r,...s].find(e=>e.filePath===t.value);e&&(f(e),S(!0))}},"handleAgentSelect");if(u)return K.createElement(re,{color:zn.GRAY},"Loading agents...");if(y&&h){const e=h.filePath.startsWith("__builtin__:");return K.createElement(H_,{agent:h,onBack:()=>{S(!1),f(null)},setRevalidateAgent:g,isReadOnly:e})}const x=__name(({isSelected:e,label:t})=>{const n=k.find(e=>e.label===t),o=n?.value||"",i=r[0]?.filePath===o,a=s[0]?.filePath===o;return K.createElement(ne,{flexDirection:"column"},i&&r.length>0&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.GRAY,bold:!0},"User agents")),a&&s.length>0&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.GRAY,bold:!0},"Project agents")),K.createElement(ne,null,K.createElement(re,{color:zn.WHITE},e?">":" "),K.createElement(re,{color:e?zn.WHITE:zn.GRAY}," ",t)))},"CustomItemComponent");return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{marginBottom:1},K.createElement(re,{color:zn.WHITE,bold:!0},"Agents"),T>0?K.createElement(re,{color:zn.GRAY}," ","(",T," agent",T>1?"s":"",")"):K.createElement(re,{color:zn.GRAY}," (No custom agents)")),n&&K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{color:zn.GREEN,dimColor:!0},"Created agent: ",n)),K.createElement(nt,{items:k,onSelect:_,indicatorComponent:()=>null,itemComponent:x}),a.length>0&&K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(re,{color:zn.GRAY,bold:!0},"Default agents"),a.map(e=>K.createElement(re,{key:e.filePath,color:zn.GRAY}," ",e.name.charAt(0).toUpperCase()+e.name.slice(1)))),K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(re,{color:zn.GRAY},"Create specialized subagents that Command Code can delegate to."),K.createElement(re,{color:zn.GRAY},"Each subagent has its own context window, custom system prompt, and specific tools.")))},"ManageAgents");Ht(),Yt(),Qo(),hr(),rv(),Ht(),Ht(),Yt(),hr();var Q_=__name(({onSelect:e})=>K.createElement(nt,{items:[{label:"1. Project (.commandcode/agents/)",value:"project"},{label:"2. Personal (~/.commandcode/agents/)",value:"personal"}],onSelect:t=>{"project"!==t.value&&"personal"!==t.value||e(t.value)},indicatorComponent:({isSelected:e})=>K.createElement(re,{color:e?zn.WHITE:zn.GRAY},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?zn.WHITE:zn.GRAY},` ${t}`)}),"LocationSelector");Ht(),wr(),Yt(),rv(),Er(),_r(),IE(),hr();var K_=__name(({step:e,agentType:t,sysPrompt:n,ccToolDefinition:r,onAgentTypeChange:o,onSysPromptChange:s,onCCToolDefinitionChange:i,onAgentTypeSubmit:a,onSysPromptSubmit:l,onCCToolDefinitionSubmit:u})=>{const[d,m]=J(!1),[g,h]=J(!1),f=te(async e=>{const t=processBracketedPaste(e);if(!t.isPasteStart||d){if(!d||t.isPasteEnd){if(d&&t.isPasteEnd){m(!1);const e=await detectClipboardText();return void(e?s(e):t.cleanedContent&&s(t.cleanedContent))}s(e)}}else if(m(!0),t.isPasteEnd){m(!1);const e=await detectClipboardText();return void(e?s(e):t.cleanedContent&&s(t.cleanedContent))}},[d,s]),y=te(async e=>{const t=processBracketedPaste(e);if(!t.isPasteStart||g){if(!g||t.isPasteEnd){if(g&&t.isPasteEnd){h(!1);const e=await detectClipboardText();return void(e?i(e):t.cleanedContent&&i(t.cleanedContent))}i(e)}}else if(h(!0),t.isPasteEnd){h(!1);const e=await detectClipboardText();return void(e?i(e):t.cleanedContent&&i(t.cleanedContent))}},[g,i]);return"agentType"===e?K.createElement(K.Fragment,null,K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.WHITE},"Enter a unique identifier for your agent:"),t&&(Object.values(ev).some(e=>Oe(e)===Oe(t))||Object.keys(ev).some(e=>Oe(e)===Oe(t)))&&K.createElement(re,{color:zn.RED},_e.warning," This name conflicts with an existing tool name. Please choose a different name."),t&&isReservedAgentName(Oe(t))&&K.createElement(re,{color:zn.RED},_e.warning," This name is reserved. Reserved names:"," ",_E.join(", "))),K.createElement(TextInput,{showCursor:!0,value:t||"",onSubmit:()=>{if(null===t||0===t.trim().length)return;const e=Oe(t);Object.values(ev).some(t=>Oe(t)===e)||Object.keys(ev).some(t=>Oe(t)===e)||isReservedAgentName(e)||a()},onChange:o,placeholder:"e.g. code-reviewer, unit-tester"})):"sysPrompt"===e?K.createElement(K.Fragment,null,K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.WHITE},"Enter the system prompt for your agent:"),K.createElement(re,{color:zn.GRAY},"Be comprehensive for best results.")),K.createElement(TextInput,{showCursor:!0,value:n||"",onSubmit:()=>{null!==n&&0!==n.trim().length&&l()},onChange:f,placeholder:"You are a helpful coding reviewer..."})):"ccToolDefinition"===e?K.createElement(K.Fragment,null,K.createElement(re,{color:zn.WHITE},"When should ","Command Code"," use this agent?"),K.createElement(TextInput,{showCursor:!0,value:r,onSubmit:()=>{0!==r.trim().length&&u()},onChange:y,placeholder:"e.g., Use this agent when you are done writing code..."})):null},"ManualFlow");Ht(),hr();var Y_=__name(({onSelect:e})=>K.createElement(nt,{items:[{label:"1. Generate with Command Code (recommended)",value:"recommended"},{label:"2. Manual configuration",value:"manual"}],onSelect:t=>{"recommended"!==t.value&&"manual"!==t.value||e(t.value)},indicatorComponent:({isSelected:e})=>K.createElement(re,{color:e?zn.WHITE:zn.GRAY},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?zn.WHITE:zn.GRAY},` ${t}`)}),"MethodSelector");Ht(),wr(),Ht(),hr();var J_=["·","○","◇","☆","✧","☆","◇","○","⌘"],X_=[12,5,4,4,4,4,4,5,16],Z_=[5,4,4,4,4,4,5];function getWaveSymbol(e){const t=e%88;let n=0;for(let e=0;e<X_.length;e++)if(n+=X_[e],t<n)return J_[e];const r=t-58;n=0;for(let e=0;e<Z_.length;e++)if(n+=Z_[e],r<n)return J_[7-e];return J_[0]}function ShimmerText({text:e,offset:t,bg:n}){const r=ee(()=>e.split(""),[e]),o=__name(e=>{const n=e-(t-5);return n>=0&&n<cr.length?cr[n]:ur},"getCharColor");return K.createElement(re,null,r.map((e,t)=>K.createElement(re,{key:`${t}:${e}`,color:o(t),backgroundColor:n},e)))}function CMDIcon({frame:e,color:t}){return K.createElement(re,{color:t??Wn,bold:!0},`${getWaveSymbol(e)} `)}function formatToken(e){return e<1e3?`${e}`:`${(e/1e3).toFixed(1)}k`}function formatTime3(e){return e<6e4?`${Math.floor(e/1e3)}s`:`${Math.floor(e/6e4)}m ${Math.floor(e%6e4/1e3)}s`}__name(getWaveSymbol,"getWaveSymbol"),__name(ShimmerText,"ShimmerText"),__name(CMDIcon,"CMDIcon"),__name(formatToken,"formatToken"),__name(formatTime3,"formatTime");var ex=__name(({status:e,timeElapsed:t,tokens:n})=>{const[r,o]=J(0),[s,i]=J(0),a=X(n);a.current=n;const l=getTerminalWidth(),[u,d]=J(()=>l>=72?"all":l>=42?"medium":"none");Z(()=>{d(e=>"all"===e?l<68?l>=42?"medium":"none":"all":"medium"===e?l>=72?"all":l<38?"none":"medium":l>=72?"all":l>=42?"medium":"none")},[l]),Z(()=>{const e=setInterval(()=>{o(e=>(e+1)%88),i(e=>{const t=a.current;if(e===t)return e;const n=t-e,r=e+Math.sign(n)*Math.max(1,Math.ceil(Math.abs(n)/10));return n>0?Math.min(r,t):Math.max(r,t)})},80);return()=>clearInterval(e)},[]);const m=r%(e.length+10),g="all"===u,h="medium"===u;return K.createElement(ne,{width:l,height:1,paddingLeft:0,marginLeft:0},K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:Yn.BG,color:Yn.FG}," "),K.createElement(re,{backgroundColor:Yn.BG},K.createElement(CMDIcon,{frame:4*r})),K.createElement(ShimmerText,{text:e,offset:m,bg:Yn.BG}),K.createElement(re,{backgroundColor:Yn.BG,color:Yn.FG}," ")),g&&K.createElement(ne,{columnGap:1,marginLeft:1},K.createElement(re,{bold:!0,color:zn.GRAY},"esc"),K.createElement(re,{color:zn.DIM},"to interrupt"),K.createElement(re,{color:zn.DIM},"•"),K.createElement(re,{color:zn.DIM},formatTime3(t)),K.createElement(re,{color:zn.DIM},"•"),K.createElement(re,{color:zn.GRAY},_e.arrowDown),K.createElement(re,{color:zn.DIM},formatToken(Math.round(s)))),h&&K.createElement(ne,{marginLeft:1},K.createElement(re,{color:zn.DIM},formatToken(Math.round(s)))))},"Status");_r(),Er(),hr();var tx=__name(({description:e,onChange:t,onSubmit:n,loading:r,errorMessage:o})=>{const[s,i]=J(!1),[a,l]=J(0),[u,d]=J(0);Z(()=>{if(!r)return;const e=setInterval(()=>d(e=>e+1),50);return()=>clearInterval(e)},[r]);const m=te(()=>{0!==e.trim().length&&n()},[e,n]),g=te(async e=>{const n=processBracketedPaste(e);if(!n.isPasteStart||s){if(!s||n.isPasteEnd){if(s&&n.isPasteEnd){i(!1);const e=await detectClipboardText();return void(e?(l(e=>e+1),t(e)):n.cleanedContent&&(l(e=>e+1),t(n.cleanedContent)))}t(e)}}else if(i(!0),n.isPasteEnd){i(!1);const e=await detectClipboardText();return void(e?(l(e=>e+1),t(e)):n.cleanedContent&&(l(e=>e+1),t(n.cleanedContent)))}},[s,t]);return K.createElement(ne,{flexDirection:"column"},r?K.createElement(ne,null,K.createElement(CMDIcon,{frame:u}),K.createElement(re,{color:zn.WHITE},"Generating agent from description...")):K.createElement(TextInput,{key:a,showCursor:!0,value:e,placeholder:"e.g. Help me review my code...",onChange:g,onSubmit:m}),o&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.RED},`${_e.warning} ${o}`)))},"RecommendedFlow");Ht(),rv(),hr();var nx=__name(({selectedTools:e,onToggleTool:t,onToggleCategory:n,onComplete:r})=>{const[o,s]=J(!1),[i,a]=J(0),l=ee(()=>[...YC.map(e=>e.name),...JC.map(e=>e.name)],[]),u=ee(()=>[{name:"All tools",tools:l},{name:"Read-only tools",tools:l.filter(e=>"read_file"===e||"read_directory"===e||"read_multiple_files"===e||"grep"===e)},{name:"Edit tools",tools:l.filter(e=>"edit_file"===e||"write_file"===e)},{name:"Execution tools",tools:l.filter(e=>"shell_command"===e)},{name:"Search tools",tools:l.filter(e=>"web_search"===e||"web_fetch"===e)},{name:"Other tools",tools:l.filter(e=>!["read_file","read_directory","read_multiple_files","grep","edit_file","write_file","shell_command","web_search","web_fetch"].includes(e))}].filter(e=>e.tools.length>0),[l]),d=ee(()=>{const e=[];return e.push({type:"continue",value:"continue"}),e.push({type:"divider",value:"divider-1"}),o?(u.forEach(t=>{e.push({type:"category",value:t.name})}),e.push({type:"divider",value:"divider-3"}),e.push({type:"toggle",value:"hide-advanced"}),e.push({type:"spacer",value:"spacer-1"}),e.push({type:"label",value:"Individual Tools:"}),l.forEach(t=>{e.push({type:"tool",value:t})})):(u.forEach(t=>{e.push({type:"category",value:t.name})}),e.push({type:"divider",value:"divider-2"}),e.push({type:"toggle",value:"show-advanced"})),e},[o,u,e,l]),m=d.map((t,n)=>{if("divider"===t.type)return{label:"─".repeat(30),value:n,type:"divider"};if("spacer"===t.type)return{label:"",value:n,type:"spacer"};if("label"===t.type)return{label:t.value,value:n,type:"label"};if("continue"===t.type)return{label:"[ Continue ]",value:n,type:"continue"};if("toggle"===t.type)return{label:"show-advanced"===t.value?"[ Show advanced options ]":"[ Hide advanced options ]",value:n,type:"toggle"};if("category"===t.type){const r=u.find(e=>e.name===t.value),o=r?.tools.every(t=>e.has(t));return r?.tools.some(t=>e.has(t)),{label:`${o?"[x]":"[ ]"} ${t.value}`,value:n,type:"category"}}return"tool"===t.type?{label:` ${e.has(t.value)?"[x]":"[ ]"} ${ev[t.value]||t.value}`,value:n,type:"tool"}:{label:"",value:n,type:"unknown"}}),g=m.filter(e=>"divider"!==e.type&&"spacer"!==e.type&&"label"!==e.type);return ie((e,l)=>{if(l.upArrow)a(e=>{const t=e-1;return t<0?g.length-1:t});else if(l.downArrow)a(e=>{const t=e+1;return t>=g.length?0:t});else if(l.return||" "===e){const e=g[i];if(e){const i=d[e.value];if(!i)return;"continue"===i.type?r():"toggle"===i.type?(s(!o),a(0)):"category"===i.type?n(i.value):"tool"===i.type&&t(i.value)}}}),K.createElement(ne,{flexDirection:"column"},m.map((e,t)=>{const n=g.findIndex(t=>t.value===e.value),r=-1!==n&&n===i;if("divider"===e.type)return K.createElement(ne,{key:`divider-${t}`},K.createElement(re,{color:zn.GRAY}," ",e.label));if("spacer"===e.type)return K.createElement(ne,{key:`spacer-${t}`,height:1});if("label"===e.type)return K.createElement(ne,{key:`label-${t}`},K.createElement(re,{color:zn.GRAY}," ",e.label));const o="continue"===e.type;return K.createElement(ne,{key:`item-${t}`},K.createElement(re,{color:r?zn.WHITE:zn.GRAY,bold:o&&r},r?">":" "," ",e.label))}),K.createElement(ne,{marginTop:1},e.size===l.length&&K.createElement(re,{color:zn.GRAY},"All tools selected"),e.size>0&&e.size<l.length&&K.createElement(re,{color:zn.GRAY},e.size," tools selected"),0===e.size&&K.createElement(re,{color:zn.GRAY},"No tools selected")))},"ToolsSelector");qr(),iw(),Xy(),Wo(),yk(),Pr();var rx=__name(({onComplete:e})=>{const[t,n]=J("location"),[r,o]=J(!1),[s,i]=J(null),[a,l]=J("agentType"),u=ee(()=>[...YC.map(e=>e.name),...JC.map(e=>e.name)],[]),d=__name(()=>({location:null,method:null,agentType:null,sysPrompt:null,ccToolDefinition:"",recommendedMethodDescription:"",selectedTools:new Set(u)}),"getInitialConfig"),[m,g]=J(d()),h=__name(t=>{n("location"),l("agentType"),g(d()),e(t)},"resetToDefaults"),f=__name(()=>{if("location"===t)return"Choose location";if("method"===t)return"Creation method";if("configuration"===t){if("recommended"===m.method)return"Describe what this agent should do and when it should be used (be comprehensive for best results)";if("agentType"===a)return"Agent type (identifier)";if("sysPrompt"===a)return"System prompt";if("ccToolDefinition"===a)return"Description (Tell Command Code when to use this agent)"}return"tools"===t?"Select tools":"summary"===t?"Confirm and save":""},"getSubText"),y=__name(e=>{g({...m,location:e}),n("method")},"handleLocationSelect"),w=__name(e=>{g({...m,method:e}),n("configuration")},"handleMethodSelect"),S=__name(async()=>{try{i(null),o(!0);const e=await getConfiguredProvider(),t=await isOAuthEnforced(),{token:r,oauthProvider:s}=await getOAuthCredentials({provider:e});validateOAuthToken({token:r,provider:e});const a={[vt.INTERNAL_TEAM_FLAG_HEADER]:t.toString()};r&&(a[vt.OAUTH_TOKEN]=`Bearer ${r}`,s&&(a[vt.OAUTH_PROVIDER]=s));const l=getApiBaseUrl(),u=new Ly({baseUrl:l}),d=parseModelString(getConfiguredModel()).modelId,h=await u.post({headers:a,endpoint:kt.ALPHA.AGENT.GENERATE,body:{description:m.recommendedMethodDescription,model:d}});g({...m,agentType:Oe(h.agentName),sysPrompt:h.systemPrompt,ccToolDefinition:h.toolDescription}),n("tools")}catch(e){if(e instanceof $o&&400===e.status&&e.message?.toLowerCase().includes("insufficient credits")){const e=await getBillingLink({billingLink:null,setBillingLink:__name(()=>{},"setBillingLink")})??"https://commandcode.ai/settings/billing";i(`You have insufficient credits to make this request. Please purchase more credits to continue using Command Code: ${e}`)}else i("An error occurred while generating the agent. Please try again.")}finally{o(!1)}},"handleRecommendedSubmit"),E=__name(()=>{g({...m,agentType:Oe(m.agentType)}),l("sysPrompt")},"handleManualAgentTypeSubmit"),C=__name(()=>{l("ccToolDefinition")},"handleManualSysPromptSubmit"),v=__name(()=>{n("tools")},"handleManualCCToolDefinitionSubmit"),k=__name(()=>{n("summary")},"handleToolsComplete"),T=__name(e=>{const t=new Set(m.selectedTools);t.has(e)?t.delete(e):t.add(e),g({...m,selectedTools:t})},"handleToggleTool"),_=__name(e=>{const t=[{name:"All tools",tools:u},{name:"Read-only tools",tools:u.filter(e=>"read_file"===e||"read_directory"===e||"read_multiple_files"===e||"grep"===e)},{name:"Edit tools",tools:u.filter(e=>"edit_file"===e||"write_file"===e)},{name:"Execution tools",tools:u.filter(e=>"shell_command"===e)},{name:"Search tools",tools:u.filter(e=>"web_search"===e||"web_fetch"===e)},{name:"Other tools",tools:u.filter(e=>!["read_file","read_directory","read_multiple_files","grep","edit_file","write_file","shell_command","web_search","web_fetch"].includes(e))}].find(t=>t.name===e);if(!t)return;const n=new Set(m.selectedTools);t.tools.every(e=>n.has(e))?t.tools.forEach(e=>n.delete(e)):t.tools.forEach(e=>n.add(e)),g({...m,selectedTools:n})},"handleToggleCategory");return K.createElement(ne,{flexDirection:"column",gap:1},K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.WHITE,bold:!0},"Create new agent"),K.createElement(re,{color:zn.GRAY},f())),K.createElement(ne,null,"location"===t&&K.createElement(Q_,{onSelect:y}),"method"===t&&K.createElement(Y_,{onSelect:w}),"configuration"===t&&"recommended"===m.method&&K.createElement(tx,{description:m.recommendedMethodDescription,onChange:e=>g({...m,recommendedMethodDescription:e}),loading:r,errorMessage:s,onSubmit:S}),"configuration"===t&&"manual"===m.method&&K.createElement(ne,{flexDirection:"column",gap:1},K.createElement(K_,{step:a,agentType:m.agentType,sysPrompt:m.sysPrompt,ccToolDefinition:m.ccToolDefinition,onAgentTypeChange:e=>g({...m,agentType:e}),onSysPromptChange:e=>g({...m,sysPrompt:e}),onCCToolDefinitionChange:e=>g({...m,ccToolDefinition:e}),onAgentTypeSubmit:E,onSysPromptSubmit:C,onCCToolDefinitionSubmit:v})),"tools"===t&&K.createElement(nx,{selectedTools:m.selectedTools,onToggleTool:T,onToggleCategory:_,onComplete:k}),"summary"===t&&K.createElement(G_,{config:m,onSaveComplete:h})))},"AgentNew");hr();var ox=__name(({onCancel:e})=>{const[t,n]=J(null),[r,o]=J(null),s=__name(e=>{n(e.value),o(null)},"handleSelect");return ie((t,n)=>{n.escape&&e()}),K.createElement(ne,{gap:1,paddingLeft:1,paddingRight:1,width:"100%",borderColor:zn.GRAY,borderStyle:"single",flexDirection:"column"},null===t&&K.createElement(V_,{handleSelect:s,createdAgentName:r}),"create_new_agent"===t&&K.createElement(rx,{onComplete:e=>{o(e),n(null)}}))},"AgentsConfig");hr(),Ht(),Pr(),hr();var sx=[{label:"Compact Normal (default)",value:"default",description:"Summarize session when context limit reached."},{label:"Compact Fast",value:"fast",description:"Fast tiered compaction. Higher quality, uses more tokens."}],ix=__name(({onSelect:e,onCancel:t})=>{const[n,r]=J(null);Z(()=>{loadUserConfig().then(e=>{r(e.compactMode??"default")})},[]);const o=__name(t=>{e(t.value)},"handleSelect");if(ie((e,n)=>{n.escape&&t()}),null===n)return null;const s=sx.findIndex(e=>e.value===n);return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:Wn,bold:!0},"Select a compact mode to compact sessions")),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:zn.DIM},"Choose how Command Code handles automatic context compaction.")),K.createElement(nt,{items:sx,onSelect:o,initialIndex:s>=0?s:0,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:zn.CYAN},e?_e.pointer:" "),itemComponent:({isSelected:e,label:t})=>{const r=sx.find(e=>e.label===t),o=r?.value===n,s=sx.findIndex(e=>e.label===t);return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,K.createElement(re,{color:e?zn.CYAN:o?zn.GREEN:zn.WHITE},` ${s+1}. ${r?.label??t}`),o&&K.createElement(re,{color:zn.GREEN}," ",_e.tick)),K.createElement(re,{color:zn.DIM},` ${r?.description??""}`))}}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Press "),K.createElement(re,{color:zn.DIM,bold:!0},"Esc"),K.createElement(re,{color:zn.DIM}," to cancel")))},"CompactModeSelector");Ht(),hr(),Ht(),wr(),Yt(),Er(),Tn(),Ht();var ax=n(S(),"commandcode-images"),lx={"image/png":".png","image/jpeg":".jpg","image/gif":".gif","image/webp":".webp"};function saveTempImage(e,t){try{v(ax)||T(ax,{recursive:!0});const r=lx[e.mediaType]||".png",o=`image-${t}-${Date.now()}${r}`,s=n(ax,o),i=Buffer.from(e.data,"base64");return _(s,i),s}catch{return null}}function accumulateDelta(e,t,n){const r=n+t;return e===t||e===r?t:r&&e.startsWith(r)?t+e.slice(r.length):t&&e.startsWith(t)?t+e.slice(t.length):t+e}function useBracketedPaste(e){const{input:t,detectedContent:n,setInput:r,setDetectedImages:o,setDetectedContent:s,incrementInputKey:i}=e,a=te((e,t)=>{o(t=>[...t,e]),r(t),i()},[o,r,i]),l=X(!1),u=X(""),d=X(null),m=X(""),g=te(async(e,t)=>{let o=e.replace(/\r\n/g,"\n").replace(/\r/g,"\n");const l=await detectDroppedImageFile(o);if(l)return void a(l,t);const u=await detectClipboardImage();if(u)return void a(u,t);let d=o;if(!d.trim()){const e=await detectClipboardText();d=e?e.replace(/\r\n/g,"\n").replace(/\r/g,"\n"):""}if(d){if(d.length>300){const e=`[Text#${n.length+1}]`;s(e=>[...e,d]),r(t+e)}else r(t+d);i()}},[a,n.length,s,r,i]),h=te(()=>{d.current&&clearTimeout(d.current),d.current=setTimeout(async()=>{if(l.current){const e=u.current,t=m.current;u.current="",m.current="",l.current=!1,d.current=null,e&&await g(e,t)}},500)},[g]);return{handlePaste:te(async e=>{const n=processBracketedPaste(e);if(n.isPasteStart&&n.isPasteEnd)return l.current&&(l.current=!1,u.current="",m.current="",d.current&&(clearTimeout(d.current),d.current=null)),await g(n.pastedContent??n.cleanedContent,n.textBeforePaste??""),!0;if(n.isPasteStart&&!l.current)return l.current=!0,m.current=n.textBeforePaste??t,u.current=n.pastedContent??n.cleanedContent,h(),!0;if(l.current&&!n.isPasteEnd)return void 0!==n.pastedContent?u.current=n.pastedContent:n.cleanedContent&&(u.current=accumulateDelta(n.cleanedContent,u.current,m.current)),h(),!0;if(l.current&&n.isPasteEnd){d.current&&(clearTimeout(d.current),d.current=null),void 0!==n.pastedContent?u.current=n.pastedContent:n.cleanedContent&&(u.current=accumulateDelta(n.cleanedContent,u.current,m.current));const e=u.current,t=m.current;return u.current="",m.current="",l.current=!1,await g(e,t),!0}if(n.isPasteEnd&&!n.isPasteStart&&!l.current)return!0;const r=e.slice(t.length);if(r.length>0){const e=await detectDroppedImageFile(r);if(e)return a(e,t),!0}return!1},[t,g,h,a]),resetPasteState:te(()=>{l.current=!1,u.current="",m.current="",d.current&&(clearTimeout(d.current),d.current=null)},[]),isPasting:te(()=>l.current,[])}}__name(saveTempImage,"saveTempImage"),On(),qr(),Ht(),_r(),Er(),__name(accumulateDelta,"accumulateDelta"),__name(useBracketedPaste,"useBracketedPaste"),_r(),Ht(),Ht();var cx=["code --wait","cursor --wait","nano"],ux=["code","cursor","subl","atom","zed"];function ensureWaitFlag(e){const t=e.split(" ").filter(e=>e.length>0),n=t[0];return ux.some(e=>n===e||n.endsWith(`/${e}`))?t.some(e=>"--wait"===e||"-w"===e)?e:`${n} --wait ${t.slice(1).join(" ")}`.trim():e}function isCommandAvailable(e){try{const t=e.split(" ")[0],n="win32"===process.platform?"where":"command -v";return M(`${n} ${t}`,{stdio:"ignore",encoding:"utf-8"}),!0}catch{return!1}}function findFallbackEditor(){for(const e of cx)if(isCommandAvailable(e))return e;return null}__name(ensureWaitFlag,"ensureWaitFlag"),__name(isCommandAvailable,"isCommandAvailable"),__name(findFallbackEditor,"findFallbackEditor");var dx=class extends Error{static{__name(this,"NoEditorError")}constructor(){super("No editor configured"),this.name="NoEditorError"}};async function openInEditor2(e){let t=process.env.EDITOR||process.env.VISUAL||null;if(!t&&("true"===process.env.COMMAND_CODE_DISABLE_EDITOR_FALLBACK||(t=findFallbackEditor()),!t))throw new dx;t=ensureWaitFlag(t);const r=n(S(),`commandcode-${Date.now()}.md`);return await q(r,e),new Promise((e,n)=>{const o=t.split(" ").filter(e=>e.length>0),s=o[0],i=o.slice(1),a=$(s,[...i,r],{stdio:"inherit"});a.on("close",async()=>{try{const t=await j(r,"utf-8");await B(r),e(t.trimEnd())}catch(e){n(e)}}),a.on("error",async e=>{try{await B(r)}catch{}n(e)})})}function useExternalEditor({input:e,setInput:t,setInputKey:n,onEditorClose:r}){const[o,s]=J(!1),[i,a]=J(null),l=te(async()=>{if(!o){s(!0),a(null);try{const o=e.replace(/\n+$/,""),s=await openInEditor2(o);t(s),n(e=>e+1),r?.()}catch(e){a(e instanceof dx?"No text editor found. Set your EDITOR environment variable.\n\nSee: https://commandcode.ai/core-concepts/interactive-mode#setting-up-your-editor":`Editor error: ${e instanceof Error?e.message:String(e)}`)}finally{s(!1)}}},[e,t,r,o]),u=te(()=>{a(null)},[]);return{isEditorOpen:o,editorError:i,handleOpenInEditor:l,clearEditorError:u}}__name(function getNoEditorMessage(){return"No text editor found. Set your EDITOR environment variable.\n\nSee: https://commandcode.ai/core-concepts/interactive-mode#setting-up-your-editor"},"getNoEditorMessage"),__name(openInEditor2,"openInEditor"),__name(useExternalEditor,"useExternalEditor"),Ht();var mx=__name((e={})=>{const{enabled:t=!0}=e,[n,r]=J(null),o=X(!1);return Z(()=>{if(!t||o.current)return;let e=!0;return o.current=!0,tT().then(t=>{e&&r(t)}),()=>{e=!1}},[t]),{pr:n}},"usePRDetection");function loadGitignore(e){const t=at(),r=n(e,".gitignore");if(v(r))try{const e=k(r,"utf8");t.add(e)}catch{}return t.add(".git"),t}hr(),Ht(),hr(),__name(loadGitignore,"loadGitignore");var px=__name(({onSelectFile:e,onClose:t,searchQuery:o=""})=>{const[a,l]=J(process.cwd()),[u,d]=J([]),[m,g]=J(0),[h,f]=J(0),y=o.trim()?15:10,w=te((e,t=process.cwd())=>{if(!e.trim())return[];const r=loadGitignore(t);if(e.endsWith("/")){const o=n(t,e);try{const e=x(o),i=[];return e.forEach(e=>{const a=n(o,e);try{const e=A(a),n=s(t,a);if(r.ignores(n))return;i.push({name:n,path:a,isDirectory:e.isDirectory()})}catch{}}),i.sort((e,t)=>e.isDirectory&&!t.isDirectory?-1:!e.isDirectory&&t.isDirectory?1:e.name.localeCompare(t.name)),i.slice(0,50)}catch{}}if(e.includes("/")){const o=e.split("/"),i=o.pop()||"",a=n(t,o.join("/"));try{const e=x(a),o=[],l=i.toLowerCase();return e.forEach(e=>{const u=e.toLowerCase();if(!i||u.includes(l)){const i=n(a,e);try{const e=A(i),n=s(t,i);if(r.ignores(n))return;o.push({name:n,path:i,isDirectory:e.isDirectory()})}catch{}}}),o.sort((e,t)=>e.isDirectory&&!t.isDirectory?-1:!e.isDirectory&&t.isDirectory?1:e.name.localeCompare(t.name)),o.slice(0,50)}catch{}}const o=[],i=e.toLowerCase(),a=__name((e,l=0)=>{if(!(l>8))try{x(e).forEach(u=>{const d=n(e,u);try{const e=A(d),n=s(t,d);if(r.ignores(n))return;const m=n.toLowerCase();(u.toLowerCase().includes(i)||m.includes(i))&&o.push({name:n,path:d,isDirectory:e.isDirectory()}),e.isDirectory()&&"node_modules"!==u&&a(d,l+1)}catch(e){}})}catch(e){}},"searchRecursively");return a(t),o.sort((e,t)=>{const n=e.name.toLowerCase(),r=t.name.toLowerCase(),o=n===i,s=r===i;if(o&&!s)return-1;if(!o&&s)return 1;const a=n.split("/").pop()||"",l=r.split("/").pop()||"",u=a.includes(i),d=l.includes(i);if(u&&!d)return-1;if(!u&&d)return 1;const m=e.name.split("/").length,g=t.name.split("/").length;return m!==g?m-g:e.name.localeCompare(t.name)}),o.slice(0,50)},[]),S=te(e=>{try{const t=x(e),o=[],i=process.cwd(),a=loadGitignore(i);"/"!==e&&o.push({name:"..",path:r(e),isDirectory:!0}),t.forEach(t=>{const r=n(e,t);try{const e=A(r),n=s(i,r);if(a.ignores(n))return;o.push({name:t,path:r,isDirectory:e.isDirectory()})}catch{}}),o.sort((e,t)=>e.isDirectory&&!t.isDirectory?-1:!e.isDirectory&&t.isDirectory?1:e.name.localeCompare(t.name)),d(o),g(0),f(0)}catch{}},[]);Z(()=>{if(o.trim()){const e=w(o);d(e),g(0),f(0)}else S(a)},[a,S,o,w]),ie((n,r)=>{if(r.escape)t();else if(r.upArrow)g(e=>{const t=Math.max(0,e-1);return t<h&&f(t),t});else if(r.downArrow)g(e=>{const t=Math.min(u.length-1,e+1);return t>=h+y&&f(t-y+1),t});else{if(r.rightArrow){const e=u[m];if(!e)return;return void(e.isDirectory&&!o.trim()&&l(i(e.path)))}if(r.return){const t=u[m];if(!t)return;return void e(t.path)}}});const E=u.slice(h,h+y);return K.createElement(ne,{flexDirection:"column",paddingLeft:1},K.createElement(ne,{marginBottom:1,flexDirection:"column"},K.createElement(re,{color:zn.DIM},o.trim()?`Searching for: "${o}"`:`Files: ${a}`),K.createElement(re,{color:zn.DIM},o.trim()?"↑↓ navigate • Enter to select • Esc to close":"↑↓ navigate • → to open folder • Enter to select • Esc to close")),0===E.length?K.createElement(re,{color:zn.DIM},o.trim()?`No files found matching "${o}"`:"No files found in this directory"):E.map((e,t)=>{const n=h+t,r=e.name,o=n===m;return K.createElement(re,{key:e.path,color:o?zn.GREEN:zn.DIM},e.isDirectory?`${r}/`:r)}))},"FileList");Ht(),Yt(),Fr(),hr(),Ht(),hr();var gx=__name(({usage:e})=>{if(!e)return null;const t=Math.min(e.current/e.limit*100,100),n=Math.max(0,Math.round(90-t));if(n>20)return null;const r=__name(e=>e>=90?zn.RED:e>=70?zn.YELLOW:zn.DIM,"getColor"),o=t>=90?6:Math.round(t/100*6),s=6-o,i=_e.square.repeat(o),a=_e.squareLightShade.repeat(s),l=r(t);return K.createElement(ne,{paddingRight:3},K.createElement(re,{color:l},`Context left before auto-compact ${n}% `),K.createElement(re,{color:l},i),s>0&&K.createElement(re,{color:zn.DIM},a))},"ContextUsage");Ht(),dv(),vo(),hr();var hx=__name(()=>{const[e,t]=J("continuous learning"),[n,r]=J(!1),[o,s]=J(!1),i=X([]),a=X(0),l=X(null),u=X(!1);Z(()=>{const e=__name(e=>"analyzing"===e.type?(u.current=!0,r(!0),s(!1),i.current=[],a.current=0,l.current&&(clearTimeout(l.current),l.current=null),void t(e.message)):u.current&&"analyzed"!==e.type?void i.current.push(e):"analyzed"===e.type?(u.current=!1,void(i.current.length>0?(a.current=0,n()):(r(!1),s(!1),t("continuous learning")))):void 0,"handleNewEvent"),n=__name(()=>{if(a.current>=i.current.length)return r(!1),s(!1),t("continuous learning"),void(i.current=[]);const e=i.current[a.current];t(e.message);const o="learned"===e.type||"refactored"===e.type;s(o);const u="learned"===e.type||"refactored"===e.type||"no_learnings"===e.type||"error"===e.type?15e3:2e3;l.current=setTimeout(()=>{a.current++,n()},u)},"cycleThroughNextEvent");return cv.on("new-event",e),()=>{cv.off("new-event",e),l.current&&clearTimeout(l.current)}},[]);const d=` ${n?_e.squareSmallFilled:_e.squareSmall} TASTE`,m=9+e.length+d.length>po;let g=e;g=truncateString(m?{text:e,maxChars:po}:{text:e,maxChars:po-d.length-9-10});const h=o?void 0:zn.DIM;return K.createElement(ne,{paddingRight:2},!m&&K.createElement(K.Fragment,null,K.createElement(BracketWrap,{color:zn.DIM},"ctrl+t"),K.createElement(re,{color:zn.DIM}," ")),K.createElement(re,{color:h},g),!m&&K.createElement(re,{color:Gn.TEXT},d))},"LearningFeedMini");Ht(),hr();var fx=__name(({mode:e,pendingExitKey:t})=>t?K.createElement(re,{color:zn.DIM},"Press Ctrl+C again to exit"):"auto-accept"===e?K.createElement(ne,{flexDirection:"row"},K.createElement(re,{color:sr},"» accept edits on "),K.createElement(BracketWrap,{color:zn.DIM},"shift+tab")):"plan"===e?K.createElement(ne,{flexDirection:"row"},K.createElement(re,{color:rr},"plan mode "),K.createElement(BracketWrap,{color:zn.DIM},"shift+tab")):K.createElement(re,{color:zn.DIM},"? for shortcuts"),"ModeIndicator");Ht(),hr(),Ir();var yx=__name(({prInfo:e,showSeparator:t=!0})=>{if(!e)return null;if("OPEN"!==e.state&&"MERGED"!==e.state)return null;const n="OPEN"===e.state?zn.DIM:ir.MERGED;return K.createElement(K.Fragment,null,t&&K.createElement(re,{color:zn.DIM}," · "),K.createElement(re,{color:n},"PR "),K.createElement(xr,{url:e.url,text:`#${e.number}`,color:n}))},"PRLinkBadge"),wx=__name(({indicator:e,showSeparator:t=!0})=>e?.visible?K.createElement(K.Fragment,null,t&&K.createElement(re,{color:zn.DIM}," · "),K.createElement(re,{color:"connected"===e.type?zn.GREEN:zn.YELLOW},e.message)):null,"ConnectionIndicatorBadge"),Sx=__name(({termWidth:e,indicatorText:t,isIDEIndicator:n,permissionMode:r="standard",prInfo:o,tasteLearning:s,contextUsage:i,connectionIndicator:a,pendingExitKey:l,updateStatus:u,updateFailedInfo:d,currentProvider:m,showProviderInfo:g,isBashMode:h,shareInfo:f,showShareNotification:y,unshareNotificationMessage:w,tasteNotificationMessage:S,creditWarning:E})=>{const C=e>=60;return K.createElement(K.Fragment,null,K.createElement(ne,{flexDirection:"column",paddingLeft:2},"auto-accept"!==r&&"plan"!==r||l?K.createElement(ne,{flexDirection:"row",justifyContent:"space-between",width:e-1},K.createElement(ne,{flexDirection:"row",columnGap:0},n&&!l?K.createElement(re,{color:Zn},t):K.createElement(fx,{mode:r,pendingExitKey:l}),!l&&K.createElement(yx,{prInfo:o}),!l&&K.createElement(wx,{indicator:a})),C&&K.createElement(ne,{flexDirection:"column",alignItems:"flex-end"},s&&K.createElement(hx,null),i&&K.createElement(gx,{usage:i}))):K.createElement(K.Fragment,null,K.createElement(ne,{flexDirection:"row",justifyContent:"space-between",width:e-1},K.createElement(fx,{mode:r}),C&&s&&K.createElement(hx,null)),K.createElement(ne,{flexDirection:"row",justifyContent:"space-between",width:e-1},K.createElement(ne,{flexDirection:"row",columnGap:0},K.createElement(re,{color:n?Zn:zn.DIM},t),K.createElement(yx,{prInfo:o}),K.createElement(wx,{indicator:a})),C&&i&&K.createElement(gx,{usage:i}))),(u||d||g&&m)&&K.createElement(ne,{flexDirection:"row",columnGap:1},u&&K.createElement(re,null,_e.tick," ","Command Code"," updated:"," ",K.createElement(re,{color:zn.DIM},"v",u.updatedFrom),K.createElement(re,{color:zn.DIM}," ",_e.arrowRight," "),K.createElement(re,null,"v",u.updatedTo)),!u&&d&&K.createElement(re,{color:zn.YELLOW,dimColor:!0},_e.info," Update available:"," ",d.currentVersion," ",_e.arrowRight," ",d.latestVersion),g&&m&&K.createElement(re,{color:zn.GREEN,dimColor:!0},_e.bullet," Provider:"," ",getProviderDisplayName(m)))),h&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:zn.GREEN},"! for bash mode")),y&&f&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:Wn},"SHARED: ",f.url," (copied to clipboard)")),w&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:w.includes("NOT SHARED")?zn.RED:Wn},w)),S&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:Wn},S)),E&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:zn.YELLOW},_e.warning," ",E)))},"BottomIndicator");Ht(),RC(),vo(),hr();var bx=12,Ex=__name(e=>{const t=new Date(e),n=(new Date).getTime()-t.getTime(),r=Math.floor(n/6e4),o=Math.floor(n/36e5),s=Math.floor(n/864e5);return r<1?"just now":r<60?`${r} min ago`:o<24?`${o}h ago`:`${s}d ago`},"formatRelativeTime"),Cx=__name(e=>e.replace(/\s+/g," ").trim(),"normalizeSummary"),vx=__name(e=>truncateString({text:Cx(e),maxChars:mo}),"truncateMessage"),kx=__name(e=>e.title?Cx(e.title):vx(e.firstMessage),"getSessionSummary"),Tx=__name(({onSelectSession:e,onClose:t})=>{const[n,r]=J([]),[o,s]=J(0),[i,a]=J(0),[l,u]=J(!0),[d,m]=J(!1),[g]=J(()=>getCurrentGitBranch());Z(()=>{__name(async()=>{u(!0);const e=await vC.listSessions();r(e),u(!1)},"loadSessions")()},[]);const h=d&&g?n.filter(e=>e.gitBranch===g):n;if(ie((n,r)=>{if(!r.escape)return r.ctrl&&"b"===n?(m(e=>!e),s(0),void a(0)):void(r.upArrow?s(e=>{const t=Math.max(0,e-1);return t<i&&a(t),t}):r.downArrow?s(e=>{const t=Math.min(h.length-1,e+1);return t>=i+bx&&a(t-bx+1),t}):r.return&&h.length>0&&o<h.length&&e(h[o].id));t()}),l)return K.createElement(ne,{flexDirection:"column",paddingLeft:2},K.createElement(re,{color:zn.GRAY},"Loading sessions..."));if(0===h.length)return K.createElement(ne,{flexDirection:"column",paddingLeft:2},K.createElement(re,{color:zn.GRAY},d&&g?`No sessions found for branch "${g}"`:"No previous sessions found"),K.createElement(re,{color:zn.DIM},d?"Press ctrl+b to show all branches, ESC to cancel":"Press ESC to go back"));const f=h.slice(i,i+bx);return K.createElement(ne,{flexDirection:"column",paddingLeft:1,width:"100%"},K.createElement(re,{color:zn.CYAN,bold:!0},"Resume Session"),K.createElement(ne,{marginTop:1}),K.createElement(ne,{columnGap:2,marginBottom:1},K.createElement(ne,{width:5},K.createElement(re,{color:zn.GRAY}," ")),K.createElement(ne,{width:13},K.createElement(re,{color:zn.GRAY},"Modified")),K.createElement(ne,{width:20},K.createElement(re,{color:zn.GRAY},"Git Branch")),K.createElement(ne,{width:11},K.createElement(re,{color:zn.GRAY},"# Messages")),K.createElement(ne,null,K.createElement(re,{color:zn.GRAY},"Summary"))),K.createElement(ne,{columnGap:2},K.createElement(ne,{flexDirection:"column",width:5},f.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`sel-${n}`,color:o===n?zn.WHITE:zn.GRAY},o===n?`${_e.pointer} ${n+1}.`:` ${n+1}.`)})),K.createElement(ne,{flexDirection:"column",width:13},f.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`mod-${e.id}`,color:o===n?zn.WHITE:zn.GRAY},Ex(e.lastModified))})),K.createElement(ne,{flexDirection:"column",width:20},f.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`branch-${e.id}`,color:o===n?zn.WHITE:zn.GRAY,wrap:"truncate-end"},e.gitBranch||"-")})),K.createElement(ne,{flexDirection:"column",width:11},f.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`msg-${e.id}`,color:o===n?zn.WHITE:zn.GRAY},e.messageCount)})),K.createElement(ne,{flexDirection:"column"},f.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`summary-${e.id}`,color:o===n?zn.WHITE:zn.GRAY,wrap:"truncate-end"},kx(e))}))),K.createElement(ne,{marginTop:1}),h.length>bx&&K.createElement(re,{color:zn.DIM},"Showing ",i+1,"–",Math.min(i+bx,h.length)," ","of ",h.length,i>0?" · ↑ more":"",i+bx<h.length?" · ↓ more":""),K.createElement(re,{color:zn.DIM},"↑↓ navigate · Enter select · ctrl+b ",d?`[branch: ${g??"unknown"}]`:"branch filter"," · ESC cancel"))},"SessionsResumeTable");function getImageHintText({selectedIndex:e,imageCount:t,inHistory:n}){return-1!==e?t>1?"← → · Delete to remove · Esc to deselect":"Delete to remove · Esc to deselect":n?"↓ · ↑ imgs":"↑ to select"}function buildImageRows({imageCount:e,rowWidth:t}){const n=[];let r=[],o=0;for(let s=0;s<e;s++){const e=`[Image #${s+1}]`.length,i=e+(r.length>0?1:0);r.length>0&&o+i>t?(n.push(r),r=[s],o=e):(r.push(s),o+=i)}return r.length>0&&n.push(r),n}function shouldSelectImageOnUpArrow({isOnFirstLine:e,imageCount:t,selectedImageIndex:n,historyIndex:r}){return e&&t>0&&-1===n&&-1===r}function nextImageIndex({currentIndex:e,imageCount:t}){return e===t-1?0:e+1}function prevImageIndex({currentIndex:e,imageCount:t}){return 0===e?t-1:e-1}function removeImageAt({images:e,index:t}){const n=e.filter((e,n)=>n!==t);return{remainingImages:n,nextSelectedIndex:n.length>0?n.length-1:-1}}function ImageLabel({index:e,isSelected:t,filePath:n,showSpaceBefore:r}){const o=`[Image #${e+1}]`,s=n?createOSC8Link(`file://${n}`,o,!1):o;return K.createElement(re,null,r?" ":"",t?K.createElement(re,{inverse:!0},o):s)}function ImageRowsDisplay({detectedImages:e,selectedImageIndex:t,imageTempPaths:n,termWidth:r,inHistory:o}){if(0===e.length)return null;const s=getImageHintText({selectedIndex:t,imageCount:e.length,inHistory:o}),i=Math.max(1,r-(s.length+2)),a=buildImageRows({imageCount:e.length,rowWidth:i});return K.createElement(ne,{flexDirection:"column",width:"100%",alignItems:"flex-end"},a.map((e,r)=>K.createElement(ne,{key:r,flexDirection:"row"},K.createElement(ne,{flexShrink:0,marginRight:1},0===r&&K.createElement(re,{color:zn.DIM},s)),K.createElement(ne,{flexDirection:"row"},e.map((e,r)=>K.createElement(ImageLabel,{key:e,index:e,isSelected:e===t,filePath:n[e],showSpaceBefore:r>0}))))))}Ht(),hr(),Ht(),__name(getImageHintText,"getImageHintText"),__name(buildImageRows,"buildImageRows"),__name(shouldSelectImageOnUpArrow,"shouldSelectImageOnUpArrow"),__name(nextImageIndex,"nextImageIndex"),__name(prevImageIndex,"prevImageIndex"),__name(removeImageAt,"removeImageAt"),Lr(),__name(ImageLabel,"ImageLabel"),__name(ImageRowsDisplay,"ImageRowsDisplay"),Ht(),Db();var _x=__name((e={})=>{const{enabled:t=!0,paused:n=!1}=e,[r,o]=J(null),[s,i]=J(!1),a=X(!1),l=X(null),[u,d]=J(!1),[m,g]=J("connected"),h=X(null),f=X(null),y=te((e,t)=>{f.current&&(clearTimeout(f.current),f.current=null),g(e),d(!0),void 0!==t&&(f.current=setTimeout(()=>{d(!1)},t))},[]),w=te(()=>{f.current&&(clearTimeout(f.current),f.current=null)},[]),S=te(async(e=!1)=>{if(!a.current){a.current=!0;try{let t=l.current,n=t?.isConnected??!1;if(!n){t?.disconnect(),t=new Ab,l.current=t;const r=e?200:500;n=await t.connect(r)}const r=h.current;if(null===r?n&&y("connected",3e3):r!==n&&(n?y("connected",2e3):y("disconnected",5e3)),h.current=n,i(n),n&&t){const n=e?500:1e3,r=await t.getContext(n);null!==r||t.isConnected||(t.disconnect(),l.current=null),o(r)}else o(null)}catch{!0===h.current&&y("disconnected",5e3),h.current=!1,i(!1),o(null),l.current?.disconnect(),l.current=null}finally{a.current=!1}}},[y]);Z(()=>{if(!t||n)return;S(!0);const e=setInterval(()=>S(!1),500);return()=>{clearInterval(e),w(),l.current?.disconnect(),l.current=null}},[t,n,S,w]);const E={visible:u,message:"connected"===m?`IDE ${_e.tick}`:"IDE disconnected",type:m};return{context:r,connected:s,refresh:S,connectionIndicator:E}},"useVSCodeContext");Ht();var xx=__name(e=>{if(!e.activeFile&&!e.selection)return"";const t=["<ide-context>"];if(e.activeFile){const{relativePath:n,language:r,cursor:o}=e.activeFile;t.push(`File: ${n} (${r}, line ${o.line})`)}if(e.selection){const{text:n,startLine:r,endLine:o}=e.selection,s=e.activeFile?.language??"";t.push(`Selected lines ${r}-${o}:`),t.push(`\`\`\`${s}`);const i=n.replace(/```/g,"` ` `").replace(/<\/ide-context>/gi,"&lt;/ide-context&gt;");t.push(i),t.push("```")}return t.push("</ide-context>"),t.join("\n")+"\n"},"formatContextForPrompt");Ht();var Ax=__name((e,t)=>!(!e||!t?.selection&&!t?.activeFile?.relativePath),"hasIDEContext"),Px=__name((e,t,n)=>{const r=e?t?.selection:null;if(r)return`${r.lineCount} lines selected`;const o=e?t?.activeFile:null;if(o?.relativePath){const e=o.relativePath.split("/").pop()||"",t=n<80?15:n<120?25:40;return`In ${e.length>t?e.slice(0,t-1)+"…":e}`}return"? for shortcuts"},"getIndicatorText"),Ix=["","","[118;5u"];function removeAltPCharacter(e){return e.includes("π")?e.replace(/π/g,""):null}function isPrecededByWhitespace(e){return!e||" "===e||"\n"===e||"\t"===e}__name(removeAltPCharacter,"removeAltPCharacter"),__name(isPrecededByWhitespace,"isPrecededByWhitespace");var Nx=__name(()=>K.createElement(ne,{flexDirection:"column",paddingLeft:1},K.createElement(re,{color:zn.DIM,bold:!0},"Available Shortcuts:"),K.createElement(ne,{columnGap:4},K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.DIM},"! for bash mode"),K.createElement(re,{color:zn.DIM},"/ for commands"),K.createElement(re,{color:zn.DIM},"@ for file paths"),K.createElement(re,{color:zn.DIM},"shift + tab to toggle auto-accept")),K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.DIM},"double tap esc to clear input"),K.createElement(re,{color:zn.DIM},"ctrl + j / shift + ⏎ for newline"),K.createElement(re,{color:zn.DIM},"ctrl + g to open in editor"),K.createElement(re,{color:zn.DIM},"ctrl + z to suspend")))),"ShortcutMenu"),Rx=__name(({input:e,onSubmit:t,setInput:n,showCursor:r=!0,placeholder:o="Enter your input…",showFileList:i,setShowFileList:a,fileSearchQuery:l,setFileSearchQuery:u,onCommand:d,contextUsage:m,tasteLearning:g=!1,tasteUsage:h=!1,shareInfo:f,showShareNotification:y,unshareNotificationMessage:w,tasteNotificationMessage:S,creditWarning:E,updateStatus:C,updateFailedInfo:v,currentProvider:k,showProviderInfo:T,permissionMode:_="standard",onToggleAutoAccept:x,hintMessage:A,historyManager:P,pendingExitKey:I=null,onOverlayVisibilityChange:N,onDoubleEscapeEmpty:R,onAltP:M,isProcessing:$=!1,ideContextEnabled:L=!0})=>{const[D,O]=J(0),[F,q]=J(!1),[j,B]=J(!1),[U,z]=J(!1),[W,G]=J(!1),[H,V]=J(""),[Q,Y]=J(!1),oe=X(0),ae=X(0),[le,ce]=J([]),[ue,de]=J([]),[me,pe]=J(-1),[ge,he]=J(""),fe=X(!1),ye=X(!1),we=X(void 0),[Se,be]=J(-1),[Ee,Ce]=J(""),ve=X(0),{isEditorOpen:ke,editorError:Te,handleOpenInEditor:xe,clearEditorError:Ae}=useExternalEditor({input:e,setInput:n,setInputKey:O,onEditorClose:__name(()=>{fe.current=!1},"onEditorClose")}),{handlePaste:Pe,resetPasteState:Ie,isPasting:Ne}=useBracketedPaste({input:e,detectedContent:le,setInput:n,setDetectedImages:de,setDetectedContent:ce,incrementInputKey:__name(()=>O(e=>e+1),"incrementInputKey")}),{context:Re,connected:Me,refresh:$e,connectionIndicator:Le}=_x({enabled:L,paused:$}),{stdout:De}=se(),Oe=De?.columns??80,{pr:Fe}=mx();Z(()=>{const e=i||W||Q;N?.(e)},[i,W,Q,N]);const qe=te(()=>{de([]),pe(-1)},[]),je=te(()=>{n(""),B(!1),G(!1),V(""),Y(!1),ce([]),qe(),he(""),Ie(),be(-1),Ce(""),O(e=>e+1)},[n,Ie,qe]),Be=te(()=>{fe.current=!0;const{text:t,cursor:r}=insertTextAt(e,ve.current,"\n");n(t),we.current=r,O(e=>e+1),setTimeout(()=>{fe.current=!1},0)},[e,n]);ie(async(t,r)=>{if(-1!==me&&r.leftArrow)return void pe(prevImageIndex({currentIndex:me,imageCount:ue.length}));if(-1!==me&&r.rightArrow)return void pe(nextImageIndex({currentIndex:me,imageCount:ue.length}));if(r.upArrow){if(i||W||Q)return;const t=e.indexOf("\n"),r=-1===t||ve.current<=t;if(shouldSelectImageOnUpArrow({isOnFirstLine:r,imageCount:ue.length,selectedImageIndex:me,historyIndex:Se}))return void pe(ue.length-1);if(-1!==me&&pe(-1),0!==e.length&&-1===Se&&!r)return;const o=P?.count()??0;if(0===o)return;-1===Se&&Ce(e);const s=Math.min(Se+1,o-1);return void(s!==Se&&(be(s),n(P?.getAt(s)||""),O(e=>e+1)))}if(r.downArrow){if(i||W||Q)return;if(-1===Se)return;const t=e.lastIndexOf("\n");if(!(-1===t||ve.current>t))return;const r=Se-1;return be(r),n(-1===r?Ee:P?.getAt(r)||""),void O(e=>e+1)}if(""===t||r.ctrl&&"c"===t)return void qe();if(isCtrlKey({inputChar:t,key:r,letter:"g",ctrlCode:7}))return fe.current=!0,void xe();if(getIsExpandToolShortcut(r,t))return fe.current=!0,n(e),O(e=>e+1),void setTimeout(()=>{fe.current=!1},0);if(isNewlineShortcutKey({inputChar:t,key:r,isPasting:Ne()}))return ye.current=!0,Be(),void setTimeout(()=>{ye.current=!1},0);if(r.meta&&r.backspace)return void je();if(r.meta&&"w"===t)return fe.current=!0,void je();const o=r.ctrl&&"v"===t||Ix.includes(t),s=r.meta&&"v"===t;if(o||s){if(o&&"darwin"===process.platform){const t=e;fe.current=!0;const r=await detectClipboardImage();return r&&(de(e=>[...e,r]),n(t),O(e=>e+1)),void(fe.current=!1)}}else if(!r.ctrl&&!r.meta||"u"!==t){if(r.ctrl&&"z"===t?.toLowerCase())return z(!0),void setTimeout(()=>{process.kill(process.pid,"SIGTSTP")},100);if(-1!==me&&(r.delete||r.backspace)){const{remainingImages:e,nextSelectedIndex:t}=removeImageAt({images:ue,index:me});return de([...e]),void pe(t)}if(r.escape){if(-1!==me)return void pe(-1);if(W)return;if(Q)return Y(!1),n(ge),void O(e=>e+1);const t=Date.now();return t-oe.current<500?(e.length>0?je():R?.(),oe.current=0,ae.current=0):(oe.current=t,F||j||(ae.current=t)),q(!1),void B(!1)}F&&(r.backspace||r.delete)&&0===e.length&&q(!1)}});const Ue=te(async t=>{if(ke)return;const r=removeAltPCharacter(t);if(null!==r)return n(r),void M?.();const o=processBracketedPaste(t);if((o.isPasteStart||o.isPasteEnd||Ne())&&await Pe(t))return;if(fe.current)return void(fe.current=!1);-1!==Se&&be(-1);const s=1===t.length,l=t.slice(-1);if(s){if("?"===l&&!F)return q(!0),n(""),void O(e=>e+1);if("!"===l&&!j)return q(!1),B(!0),n(""),void O(e=>e+1)}if("/"!==l||W||"/"!==t||(G(!0),V("")),W&&!t.startsWith("/")&&(G(!1),V("")),W&&t.startsWith("/")){const e=t.substring(1);e.includes(" ")?(G(!1),V("")):V(e)}"@"!==l||i||isPrecededByWhitespace(t.length>1?t[t.length-2]:"")&&(a(!0),u(""));const d=t.lastIndexOf("@");if(t.length<e.length&&-1!==d&&" "===e.charAt(e.length-1)&&" "!==t.charAt(t.length-1)){const e=t.substring(d+1),n=!e.includes(" "),r=d>0?t[d-1]:"";n&&isPrecededByWhitespace(r)&&(a(!0),u(e))}if(i)if(t.length<e.length){const e=t.lastIndexOf("@");if(-1===e)a(!1),u("");else{const n=t.substring(e+1);u(n)}}else{const e=t.lastIndexOf("@");if(-1!==e){const n=t.substring(e+1),r=n.indexOf(" ");if(-1!==r){const e=n.substring(0,r);u(e),a(!1)}else u(n)}}F&&(t!==e||t.length<e.length)&&q(!1),Te&&Ae(),0===t.length&&(B(!1),G(!1),V(""),Y(!1),ce([]),u(""),he(""),Ie()),n(t)},[F,e,n,i,a,W,j,ue,Se,Pe,Ie,M,Te,Ae,ke]),ze=te(async()=>{if($e(),ae.current=0,F)return void q(!1);let n=e.trim();if(!j&&n.startsWith("/")&&d&&"handled"===(await d(n)).status)return P?.add(n),B(!1),G(!1),V(""),qe(),ce([]),be(-1),void Ce("");be(-1),Ce("");let r=[];const o=ue.length>0,s=le.length>0;if(!j&&o&&(r=[...ue]),!j&&s){let e=n;le.forEach((t,n)=>{const r=`[Text#${n+1}]`;e.includes(r)&&(e=e.replace(r,t))}),n=e}n.length>0&&P?.add(n),t({input:n,role:j?"bash":"user",images:r,ideContext:Re?xx(Re):void 0}),B(!1),G(!1),V(""),qe(),ce([])},[t,d,F,e,j,ue,le,P,$e,qe]),We=te(t=>{const r=s(process.cwd(),t);let o;if(i&&""!==l){const t=e.lastIndexOf("@");o=-1!==t?e.substring(0,t+1)+r+" ":r+" "}else o=`${e}${r} `;n(o),a(!1),u(""),O(e=>e+1)},[n,a,e,i,l,u]),Ge=te(()=>{a(!1),u("")},[a,u]),He=te(t=>{if("/resume"===t)P?.add(t),be(-1),Ce(""),he(e),G(!1),V(""),Y(!0),n(""),O(e=>e+1);else{const e=Object.values(vT).includes(t),r=kT.has(t);G(!1),V(""),e&&r?(P?.add(t),be(-1),Ce(""),n(""),O(e=>e+1),d&&d(t)):(n(t+" "),O(e=>e+1))}},[d,n,e,P]),Ve=te(e=>{G(!1),V(""),n(e+" "),O(e=>e+1)},[n]),Qe=te(()=>{G(!1),V(""),n(""),be(-1),Ce(""),O(e=>e+1)},[n]),Ke=te(e=>{Y(!1),n(""),he(""),be(-1),Ce(""),O(e=>e+1),d&&d(`/resume:${e}`)},[d,n]),Ye=te(()=>{Y(!1),n(ge),be(-1),Ce(""),O(e=>e+1)},[ge,n]),Je=te(e=>{ve.current=e,we.current=void 0},[]),Xe=ee(()=>{const t=Fe&&("OPEN"===Fe.state||"MERGED"===Fe.state);return"auto-accept"===_||"plan"===_||Me||t?!F&&!Q:!F&&0===e.length&&!j&&!Q},[F,e,j,Q,_,Me,Fe]),Ze=X(new Map),et=ee(()=>ue.map((e,t)=>{if(Ze.current.has(e))return Ze.current.get(e)??null;const n=saveTempImage(e,t+1);return Ze.current.set(e,n),n}),[ue]),tt=__name(()=>F||i||W||Q||U?0:Xe||I||j?3:4,"getBottomMargin");return K.createElement(ne,{width:"100%",flexDirection:"column",marginBottom:tt()},!Q&&K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(ImageRowsDisplay,{detectedImages:ue,selectedImageIndex:me,imageTempPaths:et,termWidth:Oe,inHistory:-1!==Se}),K.createElement(re,{color:j?zn.GREEN:zn.GRAY},_e.line.repeat(Oe)),K.createElement(TextInput,{key:D,value:e,placeholder:ke?"Save and close the editor to continue...":o,onChange:Ue,onSubmit:()=>{if(!ye.current)return Date.now()-ae.current<100?(ae.current=0,void Be()):void(i||W||Q||ke||ze());ye.current=!1},showCursor:!ke&&r&&-1===me,onCursorChange:Je,initialCursor:we.current,prefix:`${j?"!":_e.pointer} `,prefixColor:j?zn.GREEN:zn.WHITE}),K.createElement(re,{color:j?zn.GREEN:zn.GRAY},_e.line.repeat(Oe))),F&&K.createElement(Nx,null),U&&K.createElement(ne,{paddingTop:1},K.createElement(re,{color:zn.YELLOW},"Command Code has been suspended. Run `fg` to bring\n\t\t\t\t\t\tCommand Code back.")),i&&K.createElement(px,{onSelectFile:We,onClose:Ge,searchQuery:l}),W&&K.createElement(_T,{onSelectCommand:He,onInsertCommand:Ve,onClose:Qe,searchQuery:H}),Q&&K.createElement(Tx,{onSelectSession:Ke,onClose:Ye}),!W&&(Xe||I)&&K.createElement(Sx,{termWidth:Oe,indicatorText:Px(Me,Re,Oe),isIDEIndicator:Ax(Me,Re),permissionMode:_,prInfo:Fe,tasteLearning:g,contextUsage:m,connectionIndicator:Le,pendingExitKey:I,updateStatus:C,updateFailedInfo:v,currentProvider:k,showProviderInfo:T,isBashMode:j,shareInfo:f,showShareNotification:y,unshareNotificationMessage:w,tasteNotificationMessage:S,creditWarning:E}),Te&&K.createElement(ne,{paddingLeft:1,flexDirection:"column"},K.createElement(re,{color:zn.YELLOW},Te)))},"InputBox");Ht(),vo(),hr();var Mx=__name(({messages:e})=>0===e.length?null:K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(ne,{marginBottom:0},K.createElement(re,{color:Vn,inverse:!0},` Queued (${e.length}) `)),e.map((e,t)=>K.createElement(ne,{key:t},K.createElement(re,{color:zn.DIM},_e.pointerSmall," "),K.createElement(re,{color:zn.DIM},truncateString({text:e.displayMessage??e.input,maxChars:80}))))),"QueuedMessages"),$x=K.memo(({queuedMessages:e,isProcessing:t,executionState:n,status:r,input:o,setInput:s,onSubmit:i,showFileList:a,setShowFileList:l,fileSearchQuery:u,setFileSearchQuery:d,onCommand:m,outputTokens:g=0,contextUsage:h,tasteLearning:f,tasteUsage:y,shareInfo:w,showShareNotification:S,unshareNotificationMessage:E,tasteNotificationMessage:C,updateStatus:v,updateFailedInfo:k,creditWarning:T,currentProvider:_,showProviderInfo:x,permissionMode:A,onToggleAutoAccept:P,hintMessage:I,historyManager:N,pendingExitKey:R,onResetPendingExitKey:M,onDoubleEscapeEmpty:$,retryAttempt:L,onAltP:D})=>{const[O,F]=J(0),q=X(o);return Z(()=>{R&&o!==q.current&&o.length>0&&M?.(),q.current=o},[o,R,M]),Z(()=>{if(!t)return void F(0);const e=setInterval(()=>{F(e=>e+1e3)},1e3);return()=>{clearInterval(e)}},[t]),K.createElement(ne,{flexDirection:"column"},K.createElement(Mx,{messages:e}),K.createElement(ne,{flexDirection:"row",justifyContent:"space-between"},K.createElement(ne,{flexDirection:"column"},(t||n.isExecuting)&&null===L&&K.createElement(ex,{tokens:g,timeElapsed:O,status:n.isExecuting?`Executing: ${n.currentCommand}`:r}),I&&K.createElement(ne,{marginLeft:1},K.createElement(re,{color:zn.DIM}," ","⎿"," ","Tip: ",I)))),K.createElement(Rx,{input:o,setInput:s,onSubmit:i,placeholder:"Ask your question...",showFileList:a,setShowFileList:l,fileSearchQuery:u,setFileSearchQuery:d,onCommand:m,contextUsage:h,tasteLearning:f,tasteUsage:y,shareInfo:w,showShareNotification:S,unshareNotificationMessage:E,tasteNotificationMessage:C,updateStatus:v,updateFailedInfo:k,creditWarning:T,currentProvider:_,showProviderInfo:x,permissionMode:A,onToggleAutoAccept:P,hintMessage:I,historyManager:N,pendingExitKey:!R||t||n.isExecuting?null:R,onDoubleEscapeEmpty:$,onAltP:D,isProcessing:t}))});Ht(),Ov(),Uv(),Nr(),Fr();var Lx=__name(({onComplete:e,onCancel:t})=>{const[n,r]=J(!1),[o,s]=J(""),{authState:i,statusMessage:a,browserUrl:l,apiKeyInput:u,setApiKeyInput:d,handleApiKeySubmit:m,cancel:g}=useAuthFlow({onSuccess:__name((t,n)=>{const o=t.userName&&"API Key"!==t.userName&&"Manual API Key"!==t.userName?t.userName:"";s(o),isInternalTeamFlagEnforced()?r(!0):e(!0,o?`Logged in as ${o}`:"Logged in successfully")},"onSuccess"),onFailure:__name((t,n)=>{e(!1,n)},"onFailure"),onCancel:__name(()=>{t()},"onCancel")});return ie((t,r)=>{if(r.ctrl&&"c"===t){if(n)return void e(!0,o?`Logged in as ${o}. Note: Anthropic authentication skipped.`:"Logged in successfully. Note: Anthropic authentication skipped.");g()}}),n?K.createElement(Ar,{onSuccess:()=>{e(!0,o?`Logged in as ${o} with Anthropic`:"Logged in successfully with Anthropic")},onCancel:()=>{e(!0,o?`Logged in as ${o}. Note: Anthropic authentication skipped.`:"Logged in successfully. Note: Anthropic authentication skipped.")},onFailure:t=>{e(!0,o?`Logged in as ${o}. Anthropic auth failed: ${t}`:`Logged in successfully. Anthropic auth failed: ${t}`)}}):K.createElement(qv,{authState:i,statusMessage:a,browserUrl:l,apiKeyInput:u,setApiKeyInput:d,handleApiKeySubmit:m})},"LoginOverlay");async function discoverOAuthMetadata(e){const t=new m(e),n=`${t.protocol}//${t.host}`;try{const e=`${n}/.well-known/oauth-authorization-server`,t=await fetchWithTimeout(e,{method:"GET",headers:{Accept:"application/json"}});if(t.ok){const e=await t.json();if(e.authorization_endpoint&&e.token_endpoint)return{authorizationEndpoint:e.authorization_endpoint,tokenEndpoint:e.token_endpoint,registrationEndpoint:e.registration_endpoint,scopes:e.scopes_supported}}}catch(e){dlog("[MCP] OAuth discovery endpoint not available",e)}try{const e=`${n}/.well-known/openid-configuration`,t=await fetchWithTimeout(e,{method:"GET",headers:{Accept:"application/json"}});if(t.ok){const e=await t.json();if(e.authorization_endpoint&&e.token_endpoint)return{authorizationEndpoint:e.authorization_endpoint,tokenEndpoint:e.token_endpoint,registrationEndpoint:e.registration_endpoint,scopes:e.scopes_supported}}}catch(e){dlog("[MCP] OIDC discovery not available",e)}return null}async function checkServerAuthRequirements(e){try{const t=await fetchWithTimeout(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({jsonrpc:"2.0",method:"initialize",id:0,params:{protocolVersion:Xb,capabilities:{},clientInfo:Zb}})});return 401===t.status||403===t.status?{requiresAuth:!0,metadata:await discoverOAuthMetadata(e)||void 0}:{requiresAuth:!1}}catch(e){return{requiresAuth:!1,error:`Server unreachable: ${e instanceof Error?e.message:String(e)}`}}}async function registerOAuthClient({registrationEndpoint:e,clientName:t,redirectUris:n}){try{const r=await fetchWithTimeout(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({client_name:t,redirect_uris:n,token_endpoint_auth_method:"none",grant_types:["authorization_code","refresh_token"],response_types:["code"]})});if(r.ok){const e=await r.json();return{clientId:e.client_id,clientSecret:e.client_secret}}}catch(e){dlog("[MCP] OAuth client registration failed",e)}return null}Ht(),Ht(),uE(),rE(),gE(),dE(),hE(),kE(),TE(),AE(),Ht(),TE(),AE(),cE(),vE(),Ht(),wE(),rE(),Rn(),__name(discoverOAuthMetadata,"discoverOAuthMetadata"),__name(checkServerAuthRequirements,"checkServerAuthRequirements"),__name(registerOAuthClient,"registerOAuthClient"),hr();var Dx=__name(({onClose:e})=>{const[t,n]=J([]),[r,o]=J(!0),[s,i]=J(0),[a,l]=J("list"),[u,d]=J(null),m=te(async()=>{o(!0);try{const e=await listMcpServers(),t=getMcpConnectionManager().getConnectedServers(),r=await Promise.all(e.map(async e=>{const n=t.find(t=>t.name===e.name);let r,o,s="disconnected";return!1===e.config.enabled?s="disabled":n&&"connected"===n.status?(s="connected",r=n.tools.length):n&&"error"===n.status?(s="error",o=n.error):e.config.oauth&&(s=await hasTokens(e.name)?"authenticated":"requires_auth"),{name:e.name,config:e.config,scope:e.scope,status:s,toolCount:r,error:o}}));n(r)}catch{}finally{o(!1)}},[]);Z(()=>{m()},[m]);const g=ee(()=>{const e=[];for(const n of["local","project","user"])e.push(...t.filter(e=>e.scope===n));return e},[t]),h=g[s]??null;ie((t,n)=>{if(n.ctrl&&"c"===t)e();else if(n.escape)"actions"===a||"confirm-remove"===a?(l("list"),d(null)):e();else if("list"===a){if(n.upArrow&&(i(e=>Math.max(0,e-1)),d(null)),n.downArrow){if(0===g.length)return;const e=Math.max(0,g.length-1);i(t=>Math.min(e,t+1)),d(null)}n.return&&h&&(l("actions"),d(null))}});const f=__name(e=>{switch(e){case"connected":return K.createElement(re,{color:zn.GREEN},_e.tick);case"authenticated":return K.createElement(re,{color:zn.CYAN},_e.tick);case"requires_auth":return K.createElement(re,{color:zn.YELLOW},_e.warning);case"error":return K.createElement(re,{color:zn.RED},_e.cross);default:return K.createElement(re,{color:zn.GRAY},_e.circle)}},"getStatusIcon"),y=__name(e=>{switch(e.status){case"connected":return"connected"+(void 0!==e.toolCount?` · ${e.toolCount} tools`:"");case"authenticated":return"authenticated · not connected";case"requires_auth":return"requires authentication";case"error":return e.error||"error";case"disabled":return"disabled";default:return"not connected"}},"getStatusText"),w=__name(e=>{switch(e){case"local":return"Local MCPs";case"project":return"Project MCPs";case"user":return"User MCPs"}},"getScopeLabel"),S=__name(e=>{switch(e){case"local":return"~/.commandcode/projects/*/mcp.json";case"project":return".mcp.json";case"user":return"~/.commandcode/mcp.json"}},"getScopePath"),E=__name(async e=>{if(h)if("back"!==e.value)if("connected"!==e.value)if("authenticated"!==e.value)if("connect"!==e.value)if("auth"!==e.value)if("remove"!==e.value)if("disable"!==e.value)if("enable"!==e.value);else{d({text:`Enabling ${h.name}...`,color:zn.CYAN,loading:!0});try{if(!await updateMcpServerStatus({name:h.name,enabled:!0,scope:h.scope}))return void d({text:`${_e.cross} Failed to enable ${h.name}, server may no longer exist in ${h.scope} scope`,color:zn.YELLOW});await m(),d({text:`${_e.tick} Enabled ${h.name}`,color:zn.GREEN})}catch(e){d({text:`${_e.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:zn.RED})}}else{d({text:`Disabling ${h.name}...`,color:zn.CYAN,loading:!0});try{const e=getMcpConnectionManager();if(!await updateMcpServerStatus({name:h.name,enabled:!1,scope:h.scope}))return void d({text:`${_e.cross} Failed to disable ${h.name}, server may no longer exist in ${h.scope} scope`,color:zn.YELLOW});await e.disconnectServer(h.name),await m(),d({text:`${_e.tick} Disabled ${h.name}`,color:zn.GREEN})}catch(e){d({text:`${_e.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:zn.RED})}}else l("confirm-remove");else{if(!h.config.oauth)return void d({text:"No OAuth configured for this server",color:zn.YELLOW});d({text:`Authenticating ${h.name}...`,color:zn.CYAN,loading:!0});try{const e={authorizationUrl:h.config.oauth.authorizationUrl,tokenUrl:h.config.oauth.tokenUrl,clientId:h.config.oauth.clientId,clientSecret:h.config.oauth.clientSecret,scopes:h.config.oauth.scopes},t=await performOAuthFlow(h.name,e,{onStatus:__name(()=>{},"onStatus")});if(t.success){d({text:`${_e.tick} Authenticated with ${h.name}`,color:zn.GREEN});try{const e=getMcpConnectionManager();await e.ensureServerConnection(h.name)}catch{}await m()}else d({text:`${_e.cross} Auth failed: ${t.error}`,color:zn.RED})}catch(e){d({text:`${_e.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:zn.RED})}}else{d({text:`Connecting ${h.name}...`,color:zn.CYAN,loading:!0});try{const e=getMcpConnectionManager();await e.ensureServerConnection(h.name),d({text:`${_e.tick} Connected to ${h.name}`,color:zn.GREEN}),await m()}catch(e){d({text:`${_e.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:zn.RED})}}else d({text:"Already authenticated",color:zn.GREEN});else d({text:"Already connected",color:zn.GREEN});else l("list")},"handleActionSelect"),C=__name(async e=>{if(h)if("yes"===e.value)try{const e=getMcpConnectionManager();"connected"===h.status&&await e.disconnectServer(h.name),await removeMcpServer({name:h.name,scope:h.scope}),l("list"),await m(),i(e=>Math.min(e,Math.max(0,g.length-2)))}catch(e){d({text:`${_e.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:zn.RED}),l("actions")}else l("actions")},"handleRemoveConfirm");if(r)return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:Wn,bold:!0},"Manage MCP servers"),K.createElement(re,{color:zn.DIM},"Loading..."));if("confirm-remove"===a&&h)return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.RED,bold:!0},"Remove ",h.name,"?"),K.createElement(re,{color:zn.DIM},"This will remove the server from ",h.scope," config."),K.createElement(ne,{marginTop:1},K.createElement(nt,{items:[{label:"Yes, remove",value:"yes"},{label:"Cancel",value:"no"}],onSelect:C,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:zn.WHITE},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?zn.WHITE:zn.GRAY}," ",t)})),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"↑↓ navigate · Enter to select · Esc to cancel")));if("actions"===a&&h){const e=[],t="disabled"===h.status,n="connected"===h.status,r="authenticated"===h.status||n;return t&&e.push({label:"Enable",value:"enable"}),!t&&n&&e.push({label:"Connected",value:"connected"}),t||n||e.push({label:"Connect",value:"connect"}),!t&&h.config.oauth&&r&&e.push({label:"Authenticated",value:"authenticated"}),t||!h.config.oauth||r||e.push({label:"Authenticate",value:"auth"}),t||e.push({label:"Disable",value:"disable"}),e.push({label:"Remove",value:"remove"}),e.push({label:"Back",value:"back"}),K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:Wn,bold:!0},h.name),K.createElement(ne,null,f(h.status),K.createElement(re,{color:zn.DIM}," ",y(h))),K.createElement(ne,{marginTop:1},K.createElement(nt,{items:e,onSelect:E,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:zn.WHITE},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?zn.WHITE:zn.GRAY}," ",t)})),u&&K.createElement(ne,{marginTop:1},u.loading&&K.createElement(re,{color:u.color},K.createElement(qe,{type:"dots"})," "),K.createElement(re,{color:u.color},u.text)),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"↑↓ navigate · Enter to select · Esc to go back")))}let v=null;return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:Wn,bold:!0},"Manage MCP servers"),K.createElement(re,{color:zn.DIM},t.length," ",1===t.length?"server":"servers"),0===t.length?K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(re,{color:zn.DIM},"No MCP servers configured."),K.createElement(re,{color:zn.DIM},'Use "cmd mcp add" to add a server.'),K.createElement(re,{color:zn.DIM},"Docs: https://commandcode.ai/docs/mcp")):K.createElement(ne,{marginTop:1,flexDirection:"column"},g.map((e,t)=>{const n=e.scope!==v;v=e.scope;const r=t===s;return K.createElement(K.Fragment,{key:e.name},n&&K.createElement(ne,{marginTop:0===t?0:1},K.createElement(re,{bold:!0},w(e.scope)),K.createElement(re,{color:zn.DIM}," (",S(e.scope),")")),K.createElement(ne,{paddingLeft:1},K.createElement(re,{color:r?zn.WHITE:zn.GRAY},r?"› ":" "),K.createElement(re,{color:r?zn.WHITE:void 0,bold:r},e.name),K.createElement(re,{color:zn.DIM}," · "),f(e.status),K.createElement(re,{color:"connected"===e.status?zn.GREEN:"authenticated"===e.status?zn.CYAN:"requires_auth"===e.status?zn.YELLOW:zn.GRAY}," ",y(e))))})),u&&K.createElement(ne,{marginTop:1},u.loading&&K.createElement(re,{color:u.color},K.createElement(qe,{type:"dots"})," "),K.createElement(re,{color:u.color},u.text)),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"↑↓ navigate · Enter to select · Esc to close")))},"McpManager");Ht(),hw(),Yt(),xn(),hr();var Ox=__name(({onClose:e})=>{const[t,n]=J([]),[r,o]=J(0),[s,i]=J(!0),[a,l]=J(null);Z(()=>{__name(async()=>{try{const e=await discoverMemoryFiles(process.cwd());n(e),i(!1)}catch(e){l(e instanceof Error?e.message:"Failed to discover memory files"),i(!1)}},"loadMemoryFiles")()},[]);const u=__name(async t=>{try{await openInEditor(t.path),e()}catch(t){console.error("Error opening memory file. Please ensure you have an editor set up."),e()}},"handleOpenInEditor"),d=t.filter(e=>"project"===e.type||"user"===e.type);if(ie((t,n)=>{n.escape?e():n.upArrow?o(e=>Math.max(0,e-1)):n.downArrow?o(e=>Math.min(d.length-1,e+1)):(n.return&&d[r]&&u(d[r]),"1"===t&&d[0]&&u(d[0]),"2"===t&&d[1]&&u(d[1]))}),s)return K.createElement(ne,{paddingLeft:1,paddingTop:1},K.createElement(re,{color:zn.DIM},"Loading memory files..."));if(a)return K.createElement(ne,{paddingLeft:1,paddingTop:1},K.createElement(re,{color:zn.RED},_e.cross," ",a));const m=d.map((e,t)=>{const n=t+1;let r="",o="";return"project"===e.type?(r=`${n}. Project memory`,o=e.exists?"Checked in at ./AGENTS.md":"Not found at ./AGENTS.md"):"user"===e.type&&(r=`${n}. User memory`,o=e.exists?"Saved in ~/.commandcode/AGENTS.md":"Not found in ~/.commandcode/AGENTS.md"),{label:r,value:e.path,description:o}});return K.createElement(ne,{flexDirection:"column",width:"100%",borderStyle:"single",borderColor:zn.GRAY,paddingTop:1,paddingBottom:1,paddingLeft:2,paddingRight:2},K.createElement(ne,null,K.createElement(re,{color:zn.WHITE,bold:!0},"Select memory to edit:")),K.createElement(ne,{columnGap:4,marginTop:1},K.createElement(ne,{flexDirection:"column"},m.map((e,t)=>K.createElement(re,{key:t,color:r===t?zn.WHITE:zn.DIM},r===t?`${Sn} `:" ",e.label))),K.createElement(ne,{flexDirection:"column"},m.map((e,t)=>K.createElement(re,{key:t,color:r===t?zn.WHITE:zn.DIM},e.description)))))},"MemorySelector");Ht(),Yt(),EC(),Kr(),Fr(),hr(),Ht(),hr();var Fx=lt()?"⠶":"#";function AssistantMessage({content:e}){return K.createElement(ne,null,K.createElement(re,{color:nr},Fx),K.createElement(ne,{marginLeft:1,flexGrow:1,flexShrink:1,minWidth:0},K.createElement(Markdown,null,e)))}function BashMessage({command:e,output:t,isPending:n=!1,hasError:r=!1}){let o=zn.GREEN,s=_e.tick,i="default",a=t||"(No output)";n&&(o=zn.YELLOW,s=_e.arrowRight,i=zn.YELLOW,a="Executing…"),r&&(o=zn.RED,s=_e.cross,i=zn.RED);const l=ee(()=>buildTreeConnectors(a),[a]);return K.createElement(ne,null,K.createElement(re,{color:o},s),K.createElement(ne,{flexDirection:"column",marginLeft:1},K.createElement(ne,null,K.createElement(re,{color:zn.GRAY},"$ "),K.createElement(re,{color:o,bold:!0},e)),K.createElement(ne,{columnGap:1,marginLeft:1},K.createElement(re,{color:dr},l),K.createElement(re,{color:i,wrap:"wrap"},a))))}function CommandResultMessage({message:e,details:t,hasError:n=!1}){const r=n?zn.YELLOW:void 0,o=ee(()=>buildTreeConnectors(e),[e]);return K.createElement(ne,{flexDirection:"column",marginBottom:0,marginTop:-1},K.createElement(ne,{columnGap:1},K.createElement(re,{color:dr},o),K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:r},e))),t&&K.createElement(ne,{marginLeft:3},K.createElement(re,{color:zn.DIM},"See ",t)))}function ErrorMessage({content:e}){const t=e.includes("Interrupted by user");return K.createElement(ne,null,K.createElement(re,{color:zn.RED},t?_e.pointer:_e.warning),K.createElement(ne,{marginLeft:1,flexGrow:1,flexShrink:1,minWidth:0},t?K.createElement(re,{color:zn.RED,wrap:"wrap"},e):K.createElement(Markdown,{color:zn.RED},e)))}function IDEStatusMessage({status:e,ide:t,details:n}){return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,"connected"===e&&K.createElement(re,null,K.createElement(re,{color:zn.GREEN},_e.tick),K.createElement(re,null," Connected to "),K.createElement(re,{color:zn.CYAN},t)),"installed"===e&&K.createElement(re,null,K.createElement(re,{color:zn.GREEN},_e.tick),K.createElement(re,null," Installed for "),K.createElement(re,{color:zn.CYAN},t)),"needs_reload"===e&&K.createElement(re,null,K.createElement(re,{color:zn.YELLOW},_e.circle),K.createElement(re,null," "),K.createElement(re,{color:zn.CYAN},t),K.createElement(re,null," extension needs reload")),"failed"===e&&K.createElement(re,null,K.createElement(re,{color:zn.RED},_e.cross),K.createElement(re,null," Install failed")),"not_in_ide"===e&&K.createElement(re,null,K.createElement(re,{color:zn.YELLOW},_e.circle),K.createElement(re,null," Not in IDE"))),n?.map((e,t)=>K.createElement(re,{key:t,color:zn.DIM}," ",e)))}function AutoCompactMessage({content:e}){return K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:zn.DIM},_e.bullet," ",e))}function TasteSkipMessage(){return K.createElement(ne,null,K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:Gn.BADGE_BG,color:Gn.BADGE_FG,bold:!0},Kk)),K.createElement(re,{color:zn.DIM}," Skipped. Run "),K.createElement(re,{color:lr.CODE},"/learn-taste"),K.createElement(re,{color:zn.DIM}," or "),K.createElement(re,{color:lr.CODE},"cmd learn-taste"),K.createElement(re,{color:zn.DIM}," anytime."))}function InfoMessage({content:e,metadata:t}){return t?.isTasteSkip?K.createElement(TasteSkipMessage,null):t?.isAutoCompact?K.createElement(AutoCompactMessage,{content:e}):K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:zn.DIM},_e.bullet," ",e))}__name(AssistantMessage,"AssistantMessage"),Ht(),hr(),__name(BashMessage,"BashMessage"),Ht(),hr(),__name(CommandResultMessage,"CommandResultMessage"),Ht(),hr(),__name(ErrorMessage,"ErrorMessage"),Ht(),hr(),__name(IDEStatusMessage,"IDEStatusMessage"),Ht(),hr(),__name(AutoCompactMessage,"AutoCompactMessage"),__name(TasteSkipMessage,"TasteSkipMessage"),__name(InfoMessage,"InfoMessage"),Ht(),Ht(),Yt();hr(),Yb(),Ht(),Kr();var qx="cmd";function getBinNames(){const e=getPackageJson();return e.bin&&"object"==typeof e.bin?Object.keys(e.bin):e.bin&&"string"==typeof e.bin?[e.name]:[qx]}function getInvokedCommandName(){try{const e=getBinNames(),n=process.argv[1];if(!n)return e[0]||qx;const r=t.basename(n).replace(/\.(m?[jt]s|cjs)$/,"");return e.includes(r)?r:e[0]||qx}catch{return qx}}function HelpMessage(){const e=getInvokedCommandName(),t=ee(()=>zb.filter(e=>!("/provider"===e.key&&!isInternalTeamFlagEnforced())),[]);return K.createElement(ne,{flexDirection:"column",paddingY:1},K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(ne,null,K.createElement(re,{bold:!0},"Command Code"),K.createElement(re,{color:zn.GRAY}," v","0.20.1")),K.createElement(re,{color:zn.GRAY},qb)),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Usage"),K.createElement(ne,{paddingLeft:2},K.createElement(re,null,e," <command> [options]"))),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Options"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},Ub.map(t=>K.createElement(ne,{key:t.key},K.createElement(re,null,t.key.replace(/^cmd/,e).padEnd(jb)),K.createElement(re,{color:zn.GRAY},t.description))))),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Commands"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},Wb.map(t=>K.createElement(ne,{key:t.key},K.createElement(re,null,t.key.replace(/^cmd/,e).padEnd(jb)),K.createElement(re,{color:zn.GRAY},t.description))))),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Slash Commands"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},t.map(e=>K.createElement(ne,{key:e.key},K.createElement(re,null,e.key.padEnd(jb)),K.createElement(re,{color:zn.GRAY},e.description))))),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Keyboard Shortcuts"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},Bb.map(e=>K.createElement(ne,{key:e.key},K.createElement(re,null,e.key.padEnd(jb)),K.createElement(re,{color:zn.GRAY},e.description))))),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Examples"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},Hb.map(t=>K.createElement(ne,{key:t.key},K.createElement(re,null,t.key.replace(/^cmd/,e).padEnd(jb)),K.createElement(re,{color:zn.GRAY},t.description))))),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:zn.CYAN},_e.pointer),K.createElement(re,{color:zn.GRAY}," ",Vb.replace(/cmd/,e))),K.createElement(ne,{flexDirection:"column"},K.createElement(re,{bold:!0},"Links"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},Gb.map(e=>K.createElement(ne,{key:e.key},K.createElement(re,null,e.key.padEnd(jb)),K.createElement(re,{color:zn.CYAN},e.description))))))}function SystemMessage({content:e,metadata:t}){if(e.includes("KEYBOARD SHORTCUTS")&&e.includes("COMMANDS"))return K.createElement(HelpMessage,null);if("CONTEXT"===e){const e=t?.analysis;if(e)return K.createElement(ContextMessage,{analysis:e})}return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{wrap:"wrap"},K.createElement(Markdown,null,e)))}__name(getBinNames,"getBinNames"),__name(getInvokedCommandName,"getInvokedCommandName"),Fr(),__name(HelpMessage,"HelpMessage"),__name(SystemMessage,"SystemMessage"),Ht(),xn(),Lr(),hr();var jx={"Interrupted by user":"Interrupted by user","Insufficient credits":yn};function UserMessage({content:e,images:t,imageCount:n=0}){const r="Interrupted by user"===e,o="Insufficient credits"===e,s=e.startsWith("Error:"),i=r||o||s,a=i&&jx[e]||e,l=null!=t?t.length:n,u=X(null);null===u.current&&t&&t.length>0&&(u.current=t.map((e,t)=>saveTempImage(e,t+1)));const d=u.current??[];return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{backgroundColor:i?void 0:tr.BG,paddingRight:1},K.createElement(re,{color:i?zn.RED:tr.POINTER,bold:!i},_e.pointer),K.createElement(ne,{marginLeft:1},K.createElement(re,{color:i?zn.RED:zn.WHITE,wrap:"wrap"},a))),l>0&&K.createElement(ne,{marginLeft:1},K.createElement(re,{color:zn.DIM},"⎿"," ",Array.from({length:l},(e,t)=>{const n=d[t],r=`[Image #${t+1}]`;return null!=n?createOSC8Link(`file://${n}`,r,!1):r}).join(" "))))}function renderFeedEntry(e,t){if("user"===e.role){const t=Array.isArray(e.metadata?.images)?e.metadata.images:void 0;return K.createElement(UserMessage,{content:e.input,images:t})}return"assistant"===e.role?K.createElement(AssistantMessage,{content:e.input}):"tool"===e.role?K.createElement(ToolMessage,{name:hC(e.name||""),input:e.input,output:e.output||"",isPending:mC(e),hasError:dC(e),metadata:e.metadata,expandedOutput:t}):"bash"===e.role?K.createElement(BashMessage,{command:e.command||"",output:e.output||"",isPending:mC(e),hasError:dC(e)}):"system"===e.role?K.createElement(SystemMessage,{content:e.input,metadata:e.metadata}):"info"===e.role?K.createElement(InfoMessage,{content:e.input,metadata:e.metadata}):"error"===e.role?K.createElement(ErrorMessage,{content:e.input}):"command-result"===e.role?K.createElement(CommandResultMessage,{message:e.input,details:e.details,hasError:e.hasError??!1}):"ide-status"===e.role?K.createElement(IDEStatusMessage,{status:e.status,ide:e.ide,details:e.details}):null}function getModelShortName(e){const t=Object.values(Ot).find(t=>t.id===e);return t?t.name.toLowerCase().replace(" ","-"):e.includes("sonnet-4-6")?"sonnet-4.6":e.includes("sonnet")?"sonnet-4.5":e.includes("opus-4-7")?"opus-4.7":e.includes("opus-4-6")?"opus-4.6":e.includes("opus")?"opus-4.5":"sonnet-4.6"}function TranscriptDivider({count:e,width:t}){const n=` ${e} hidden messages [ctrl+e to expand more] `,r=Math.max(0,Math.floor((t-n.length)/2)),o="─".repeat(r);return K.createElement(ne,{marginBottom:1},K.createElement(re,{color:er},o),K.createElement(BracketedText,{text:n,color:er}),K.createElement(re,{color:er},o))}__name(UserMessage,"UserMessage"),__name(renderFeedEntry,"renderFeedEntry"),__name(getModelShortName,"getModelShortName"),__name(TranscriptDivider,"TranscriptDivider");var Bx=K.memo(({feed:e,showHeader:t=!1,staticKey:n,expandedToolOutput:r=!1,currentModel:o,hiddenCount:s=0})=>{const i=s>0?{role:"transcript-divider",count:s}:null,a=[...t?["header"]:[],...i?[i]:[],...e],l=useTerminalWidth(),u=ee(()=>b_(l),[l]),d=ee(()=>T_(l),[l]),m=ee(()=>getPackageJson().version||"0.0.0",[]),g=ee(()=>getGitHeaderInfo(),[]),h=ee(()=>{const e=process.cwd(),t=process.env.HOME??process.env.USERPROFILE??"";return e.replace(t,"~")},[]),f=o?getModelShortName(o):"sonnet-4.6",y="taste-1",w=isInternalTeamFlagEnforced()&&!process.env.CMD_DEMO?" · co":"";return K.createElement(oe,{items:a,key:n,style:{width:"100%"}},e=>{if("object"==typeof e&&"transcript-divider"===e.role)return K.createElement(TranscriptDivider,{key:"transcript-divider",count:e.count,width:l});if("header"===e)return"compact"===d?K.createElement(ne,{key:"header",marginBottom:1,flexDirection:"row"},K.createElement(ne,{width:v_,flexShrink:0},K.createElement(__,null,C_)),K.createElement(ne,{flexDirection:"column",marginLeft:2},K.createElement(ne,null,K.createElement(re,{bold:!0},"Command Code"),K.createElement(re,{color:er}," ","v",m)),K.createElement(re,{color:er},"models: ",f," · ",y,w),K.createElement(re,{color:er},h,g&&g.isLocal&&g.branch&&` (${g.branch})`))):K.createElement(ne,{key:"header",marginBottom:1,flexDirection:"column"},K.createElement(__,null,u.trimEnd()),K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(ne,null,K.createElement(re,{color:er},"# "),K.createElement(re,{bold:!0},"Command Code"),K.createElement(re,{color:er}," v",m)),K.createElement(re,{color:er},"# models: ",f," · ",y,w),K.createElement(ne,null,K.createElement(re,{color:er},"# ",h,g&&g.isLocal&&g.branch&&K.createElement(re,{color:er}," ","(branch:"," ",g.branch,")")))));const t=e,n=renderFeedEntry(t,r);return K.createElement(ne,{key:t.id,paddingBottom:1,width:"90%"},n)})});Ht(),EC(),qr(),hr();var Ux=Y(__name(function LiveAgentStatusInner2({entry:e}){const t=hC(e.name||"Agent"),n=e.input||"",r=n.split(/[.\n]/)[0],o=r?r+(n.includes(".")||n.includes("\n")?".":""):n,s=e.metadata?.tokensUsed||0,i=e.metadata?.elapsedSeconds||0,a=e.metadata?.recentTools||[],[l,u]=J(".");return Z(()=>{const e=setInterval(()=>{u(e=>"..."===e?".":e+".")},500);return()=>clearInterval(e)},[]),K.createElement(ne,{flexDirection:"column",marginBottom:1,width:"90%"},K.createElement(ne,null,K.createElement(re,{backgroundColor:Jn.BG,color:Jn.FG,bold:!0},` ${t} `),o&&K.createElement(re,null," ","(",o,")")),K.createElement(ne,{columnGap:1,marginLeft:1},K.createElement(re,null,"⎿"," "),K.createElement(re,{color:zn.GRAY},"Running (",formatTime2(i)," | ",formatTokens(s),")",l)),a.length>0&&K.createElement(ne,{flexDirection:"column",marginLeft:1},a.map((e,t)=>{const n=hC(e.name);return K.createElement(ne,{key:t,columnGap:1},K.createElement(re,{color:zn.GRAY},"⎿"),K.createElement(re,{color:zn.GRAY}," ",n),e.input&&K.createElement(re,{color:zn.GRAY},"(",e.input,")"))})))},"LiveAgentStatusInner")),zx=Y(__name(function LiveAgentStatus2({entry:e}){return"tool"!==e.role?null:K.createElement(Ux,{entry:e})},"LiveAgentStatus"));Ht(),Yt(),Pr(),qr(),hr();var Wx=Object.values(Ot),Gx=Object.keys(jt),Hx=__name(({onSelect:e,onCancel:t,currentModel:n})=>{const[r,o]=J(""),[s,i]=J(0),[a,l]=J(null),[u,d]=J(null),m=ee(()=>{if(!r.trim())return Wx;const e=r.toLowerCase().split(""),t=__name(t=>{let n=0;for(const r of t)if(r===e[n]&&(n++,n===e.length))return!0;return!1},"fuzzyMatch");return Wx.map(e=>{const n=e.name.toLowerCase(),r=e.label.toLowerCase(),o=e.provider.toLowerCase(),s=(e.description||"").toLowerCase();let i=0;return t(n)&&(i+=100),t(r)&&(i+=50),t(o)&&(i+=25),t(s)&&(i+=10),{model:e,score:i}}).filter(({score:e})=>e>0).sort((e,t)=>t.score-e.score).map(({model:e})=>e)},[r]);Z(()=>{i(0)},[r]),Z(()=>{if(n&&!r){const e=m.findIndex(e=>e.id===n);e>=0&&i(e)}},[n,m,r]),Z(()=>{(async()=>{await isOAuthEnforced()&&d(await getConfiguredProvider())})()},[]),ie((n,a)=>{if(a.escape&&r)o("");else if(a.escape)t();else if(a.backspace||a.delete)o(e=>e.slice(0,-1));else{if(a.upArrow)return l(null),void i(e=>e>0?e-1:m.length-1);if(a.downArrow)return l(null),void i(e=>e<m.length-1?e+1:0);if(a.return){const t=m[s];if(!t)return;if(u){const e=Bt[u];if(e&&!e.includes(t.provider)){const e=jt[u]||u;return void l(`${e} OAuth does not support ${t.provider} models. Switch to GitHub Copilot via /provider.`)}}return void e(t.id)}!a.ctrl&&!a.meta&&!a.tab&&n&&1===n.length&&n>=" "&&o(e=>e+n)}});const g=ee(()=>{const e=new Set(m.map(e=>e.provider));return Gx.filter(t=>e.has(t))},[m]);return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:Wn,bold:!0},"Select model")),K.createElement(ne,{marginBottom:1},K.createElement(re,{dimColor:!0},"Switch between Command Code models. Applies to this session and future sessions.")),K.createElement(ne,{marginBottom:2,flexDirection:"column",width:"100%"},K.createElement(ne,{width:"100%"},K.createElement(re,{color:zn.GRAY},_e.pointerSmall),K.createElement(re,null," "),K.createElement(re,{color:r?zn.WHITE:zn.GRAY},r||"Type to search models..."),r&&K.createElement(re,{dimColor:!0}," (",m.length," found)"))),0===m.length?K.createElement(ne,{marginY:1},K.createElement(re,{color:zn.GRAY},'No models match "',r,'"')):g.map((e,t)=>{const r=m.filter(t=>t.provider===e);return 0===r.length?null:K.createElement(ne,{key:e,flexDirection:"column",marginBottom:t<g.length-1?1:0},K.createElement(re,{dimColor:!0,bold:!0},jt[e]),r.map(e=>{const t=m.indexOf(e)===s,r=e.id===n;return K.createElement(ne,{key:e.id},K.createElement(re,{color:t?zn.CYAN:zn.GRAY},t?`${_e.pointer} `:" "),K.createElement(re,{color:t?zn.CYAN:r?zn.GREEN:zn.WHITE},e.label.padEnd(24)),e.description&&K.createElement(re,{color:zn.DIM},e.description),r&&K.createElement(re,{color:zn.GREEN}," ",_e.tick))}))}),a&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.RED},a)),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"type to search . up/down navigate . Enter to select"),r?K.createElement(re,{color:zn.DIM}," . Esc to clear"):K.createElement(re,{color:zn.DIM}," . Esc to cancel")))},"ModelSelector");Ht(),Fr(),hr();var Vx=__name(({onSelect:e,onCancel:t,currentProvider:n})=>{const r=getProviderOptions(),o=__name(t=>{e(t.value)},"handleSelect");ie((e,n)=>{n.escape&&t()});const s=n?r.findIndex(e=>e.value===n):0,i=n&&-1===s;return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,{marginBottom:1,flexDirection:"row",justifyContent:"space-between"},K.createElement(ne,null,K.createElement(re,{bold:!0},"Select AI Provider")),n&&K.createElement(ne,{flexDirection:"row"},K.createElement(re,{color:zn.DIM},"Current: "),K.createElement(re,{color:zn.GREEN},getProviderDisplayName(n)),i&&K.createElement(re,{color:zn.YELLOW}," [OAuth enforced]"))),K.createElement(ne,{marginBottom:0},K.createElement(re,{color:zn.DIM},"Available Providers:")),K.createElement(nt,{items:r,onSelect:o,initialIndex:s>=0?s:0,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:e?zn.CYAN:zn.GRAY,bold:e},e?_e.triangleRightSmall:" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?zn.CYAN:zn.GRAY,bold:e},` ${t}`)}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Press ESC to cancel")))},"ProviderSelector");function RetryMessage({attempt:e}){const[t,n]=J(0);if(Z(()=>{if(null===e)return;const t=setInterval(()=>{n(e=>(e+1)%4)},500);return()=>clearInterval(t)},[e]),null===e)return null;const r=".".repeat(t).padEnd(3," ");return K.createElement(ne,{marginBottom:1},K.createElement(re,{color:ar,dimColor:!0},"Connection Issue. Retrying (attempt ",e,")",r))}Ht(),hr(),__name(RetryMessage,"RetryMessage"),Ht(),Ww(),vo(),xn(),hr();var Qx=[{mode:"both",label:"Both",description:"Restore conversation and code (recommended)"},{mode:"conversation",label:"Conversation only",description:"Rewind conversation, keep current code"},{mode:"files",label:"Code only",description:"Restore code, keep conversation"}],Kx=__name(({checkpoints:e,onSelect:t,onCancel:n})=>{const r=ee(()=>[...e].sort((e,t)=>new Date(e.timestamp).getTime()-new Date(t.timestamp).getTime()),[e]),[o,s]=J(Math.max(0,r.length-1)),[i,a]=J(Math.max(0,r.length-8)),[l,u]=J("checkpoint"),[d,m]=J(null),[g,h]=J(0),f=ee(()=>{if(!d)return!0;const e=r.findIndex(e=>e.messageId===d.messageId);if(-1===e)return!0;for(let t=e;t<r.length;t++)if(r[t].filesModified.length>0)return!0;return!1},[d,r]),y=ee(()=>f?Qx:Qx.filter(e=>"conversation"===e.mode),[f]);if(Z(()=>{if(r.length>0){const e=r.length-1;s(e),a(Math.max(0,r.length-8))}},[r.length,8]),ie((e,f)=>{f.escape?"mode"===l?(u("checkpoint"),m(null),h(0)):n():"checkpoint"===l?f.upArrow?s(e=>{const t=Math.max(0,e-1);return t<i&&a(t),t}):f.downArrow?s(e=>{const t=Math.min(r.length-1,e+1);return t>=i+8&&a(t-8+1),t}):f.return&&r.length>0&&(m(r[o]),u("mode"),h(0)):"mode"===l&&(f.upArrow?h(e=>Math.max(0,e-1)):f.downArrow?h(e=>Math.min(y.length-1,e+1)):f.return&&d&&y[g]&&t({messageId:d.messageId,mode:y[g].mode}))}),0===r.length)return K.createElement(ne,{flexDirection:"column",paddingLeft:2,paddingTop:1},K.createElement(re,{color:Wn,bold:!0},"Rewind"),K.createElement(re,{color:zn.DIM},"No checkpoints available. Start a conversation to create checkpoints."),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Press "),K.createElement(re,{color:zn.DIM,bold:!0},"Esc"),K.createElement(re,{color:zn.DIM}," to close")));if("mode"===l&&d)return K.createElement(ne,{flexDirection:"column",paddingLeft:2,paddingTop:1},K.createElement(re,{color:Wn,bold:!0},"Rewind"),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:zn.DIM},"Restore to: "),K.createElement(re,{color:zn.WHITE},truncateString({text:d.userPrompt||"checkpoint",maxChars:50}))),K.createElement(ne,{flexDirection:"column"},y.map((e,t)=>{const n=g===t,r=t===y.length-1;return K.createElement(ne,{key:e.mode,flexDirection:"column"},K.createElement(ne,{flexDirection:"row"},K.createElement(re,{color:n?Wn:void 0},n?`${Sn} `:" "),K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:n?Wn:zn.WHITE},e.label),K.createElement(re,{color:zn.DIM},e.description))),!r&&K.createElement(re,null," "))})),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Press "),K.createElement(re,{color:zn.DIM,bold:!0},"Enter"),K.createElement(re,{color:zn.DIM}," to confirm, "),K.createElement(re,{color:zn.DIM,bold:!0},"Esc"),K.createElement(re,{color:zn.DIM}," to go back")));const w=r.slice(i,i+8);return K.createElement(ne,{flexDirection:"column",paddingLeft:2,paddingTop:1},K.createElement(re,{color:Wn,bold:!0},"Rewind"),K.createElement(re,{color:zn.DIM},"Select a checkpoint to restore your session"),r.length>8&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Showing ",i+1,"-",Math.min(i+8,r.length)," ","of ",r.length)),K.createElement(ne,{marginTop:1}),K.createElement(ne,{flexDirection:"column"},w.map((e,t)=>{const n=i+t,s=o===n,a=e.filesModified.length,l=t===w.length-1,u=n===r.length-1;return K.createElement(ne,{key:e.messageId,flexDirection:"column"},K.createElement(ne,{flexDirection:"row"},K.createElement(re,{color:s?Wn:void 0},s?`${Sn} `:" "),K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,K.createElement(re,{color:s?Wn:zn.WHITE},truncateString({text:e.userPrompt||"(no prompt)",maxChars:60})),K.createElement(re,{color:zn.DIM}," • "),K.createElement(re,{color:zn.DIM},getRelativeTimeString({timestamp:e.timestamp}),u&&" (latest)")),K.createElement(re,{color:zn.DIM},a>0?`${a} file${a>1?"s":""} changed`:"No code changes"))),!l&&K.createElement(re,null," "))})),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Press "),K.createElement(re,{color:zn.DIM,bold:!0},"Enter"),K.createElement(re,{color:zn.DIM}," to select, "),K.createElement(re,{color:zn.DIM,bold:!0},"Esc"),K.createElement(re,{color:zn.DIM}," to cancel")))},"RewindSelector");Ht(),Rn(),Ht(),Ht(),dv();var Yx=__name(e=>{const[t,n]=J(e),[r,o]=J(null);return Z(()=>{const t=__name(()=>{n(e.map(e=>({...e,active:!1,complete:!1,items:[],insights:[],message:""}))),o(null)},"handleReset"),r=__name(e=>{"error"!==e.type?n(t=>{if("step_start"===e.type){const n=t.findIndex(t=>t.id===e.step);return n<0?t:t.map((t,r)=>r<n?{...t,active:!1,complete:!0}:r===n?{...t,active:!0,message:e.message||"",...e.label&&{label:e.label},..."complete"===e.step&&{complete:!0},...void 0!==e.learningCount&&void 0!==e.categories&&void 0!==e.storage&&t.summary&&{summary:{learningCount:e.learningCount,categories:e.categories,storage:e.storage}}}:t)}if("progress"===e.type){const n=t.findIndex(e=>e.active);return n<0?t:t.map((t,r)=>r===n?{...t,items:[...t.items,e.message]}:t)}if("insight"===e.type){const n=t.findIndex(e=>"learning"===e.id);return n<0?t:t.map((t,r)=>r===n?{...t,insights:[...t.insights,e.message]}:t)}return t}):o(e.message)},"handleNewEvent");return cv.on("reset",t),cv.on("new-event",r),()=>{cv.off("reset",t),cv.off("new-event",r)}},[e]),{steps:t,importError:r,setImportError:o}},"useProgressEvents");async function createRequestClient(){const e=getApiBaseUrl(),t=new Ly({baseUrl:e}),n=await getConfiguredProvider(),r=await isOAuthEnforced();let o,s;try{const e=await getOAuthCredentials({provider:n});o=e.token,s=e.oauthProvider,validateOAuthToken({token:o,provider:n})}catch(e){dlog("Failed to get or validate OAuth token:",e instanceof Error?e.message:String(e))}const i={[vt.PROJECT_SLUG]:vC.getCurrentProjectDirName(),[vt.INTERNAL_TEAM_FLAG_HEADER]:r.toString()};return o&&(i[vt.OAUTH_TOKEN]=`Bearer ${o}`,s&&(i[vt.OAUTH_PROVIDER]=s)),{request:t,headers:i}}function splitPromptsIntoBatches(e){const t=[];let n=[],r=0;for(const o of e){const e=estimateTokens(o);e>2e3?(n.length>0&&(t.push(n),n=[],r=0),t.push([o])):r+e>2e3?(n.length>0&&t.push(n),n=[o],r=e):(n.push(o),r+=e)}return n.length>0&&t.push(n),t}Ht(),Ht(),Sv(),Xy(),iw(),AS(),Rn(),dv(),Ht(),Rn(),dv(),AS(),Ht(),Ht(),Yt(),Xy(),iw(),RC(),Rn(),Pr(),qr(),__name(createRequestClient,"createRequestClient"),Ht(),AS(),__name(splitPromptsIntoBatches,"splitPromptsIntoBatches"),__name(function calculateObservationsPerBatch(e){return 4},"calculateObservationsPerBatch"),Ht(),Ht(),Rn(),hn(),dv(),Ht();var Jx="claude-haiku-4-5-20251001";function buildObserverPrompt(e,t){return`Scan prompts. ${t} casual observations like a dev friend glancing at your work.\n\nPLAIN TEXT ONLY. No markdown, no formatting.\n\nBe natural and VARIED. Don't repeat the same sentence starters.\n\nGood (notice the variety):\npnpm over npm, nice\ndebugging that auth flow\nreact + typescript stack\ncircular deps came up\ntui flicker stuff\nah the classic memory leak\nsession persistence wip\nfighting with imports again\nhaiku model issues huh\n\nBad (too repetitive - NEVER do this):\nI see you prefer pnpm\nI see debugging auth\nI see react stack\nI see circular deps\noh, TUI issues\noh, memory leak\n\nRules:\n- plain text, lowercase is fine\n- vary your sentence starts - mix it up\n- max 6 words\n- sound human, not robotic\n\nPrompts:\n${e.map((e,t)=>`${t+1}. ${e}`).join("\n")}\n\nVaried observations:`}function createInsightEmitter(){let e="",t=0;const n=__name(()=>{if(e.includes("\n")){const t=e.split("\n");for(let e=0;e<t.length-1;e++){const n=t[e].trim();n&&(dlog(`[ObserverAPI] emitting insight: ${n}`),cv.addEvent({type:"insight",message:n}))}e=t[t.length-1]}},"emitCompletedLines");return{addText:__name(r=>{t++,dlog(`[ObserverAPI] text chunk ${t}: "${r.substring(0,50)}..."`),e+=r,n()},"addText"),emitRemaining:__name(()=>{e.trim()&&(dlog(`[ObserverAPI] emitting final insight: ${e.trim()}`),cv.addEvent({type:"insight",message:e.trim()}))},"emitRemaining"),getChunkCount:__name(()=>t,"getChunkCount")}}async function callObserverAPI(e,t,n){dlog(`[ObserverAPI] calling ${kt.ALPHA.GENERATE} with model: ${Jx}`);const r={config:getEnvironmentContext(),memory:"",taste:"",skills:"",params:{tools:[],messages:[{role:"user",content:n}],model:Jx,max_tokens:200,temperature:.7,stream:!0},threadId:ve()},o=await e.post({endpoint:kt.ALPHA.GENERATE,body:r,headers:t,stream:!0});dlog("[ObserverAPI] got response stream");const s=createInsightEmitter();await consumeSSEStream(o,{onText:__name(e=>{s.addText(e)},"onText")}),dlog(`[ObserverAPI] stream complete, ${s.getChunkCount()} chunks received`),s.emitRemaining(),dlog("[ObserverAPI] done")}async function processBatch(e,t,n,r,o){let s=0;for(const e of n)s+=estimateTokens(e);dlog(`[Observer] batch ${r}/${o}: ${n.length} prompts`);const i=buildObserverPrompt(n,4);await callObserverAPI(e,t,i)}async function observeSessionPrompts(e){if(cv.observerHasRun)return;cv.markObserverRun();const{prompts:t}=e;try{const{request:e,headers:n}=await createRequestClient(),r=splitPromptsIntoBatches(t);dlog(`[Observer] ${t.length} prompts → ${r.length} batches`);const o=Math.min(r.length,6);for(let t=0;t<o;t++){if(cv.learningComplete){dlog(`[Observer] stopped at batch ${t} (learning complete)`);break}const o=r[t];try{await processBatch(e,n,o,t+1,r.length)}catch{}}dlog("[Observer] done")}catch(e){dlog(`[Observer] failed (non-critical): ${e instanceof Error?e.message:String(e)}`),cv.addEvent({type:"progress",message:"Continuing without live observations..."})}}Yt(),FE(),__name(buildObserverPrompt,"buildObserverPrompt"),__name(createInsightEmitter,"createInsightEmitter"),__name(callObserverAPI,"callObserverAPI"),__name(processBatch,"processBatch"),__name(observeSessionPrompts,"observeSessionPrompts");var Xx=class{static{__name(this,"SessionImporter")}static async findClaudeCodeSessions(t=0){const n=[];try{const r=e.join(y.homedir(),".claude","projects");await D.access(r);const o=process.cwd().replace(/\//g,"-");dlog(`[Import] scanning project: ${o}`);const s=(await D.readdir(r)).filter(e=>e===o);for(const o of s){const s=e.join(r,o);try{if(!(await D.stat(s)).isDirectory())continue;const r=(await D.readdir(s)).filter(e=>e.endsWith(".jsonl")&&!e.includes(".checkpoints"));dlog(`[Import] found ${r.length} sessions`);for(const o of r){const r=e.join(s,o),i=await D.stat(r),a=o.replace(".jsonl","");if(n.push({id:a,filePath:r,createdAt:i.birthtime,lastModified:i.mtime,messageCount:0,agent:"claude-code"}),t>0&&n.length>=t)break}if(t>0&&n.length>=t)break}catch{continue}}}catch{dlog("[Import] no claude sessions dir")}return n}static async findCodexSessions(e=0,t){try{cv.addEvent({type:"progress",message:"Scanning Codex sessions..."});const n=await findCodexSessions(process.cwd(),e=>{t?.(e),"reading"===e.phase&&cv.addEvent({type:"progress",message:`Scanning Codex: ${e.processedFiles}/${e.totalFiles} files (${e.matchedSessions} matched)`})},e);return dlog(`[Import] found ${n.length} Codex sessions`),n}catch(e){return dlog("[Import] no codex sessions",e),[]}}static async findCursorSessions(e=0){try{cv.addEvent({type:"progress",message:"Scanning Cursor sessions..."});const t=await findCursorSessions(process.cwd(),e);return dlog(`[Import] found ${t.length} Cursor sessions`),t}catch(e){return dlog("[Import] no cursor sessions",e),[]}}static async extractUserPrompts(e){const t=[];try{const n=(await D.readFile(e,"utf-8")).trim().split("\n");for(const e of n)if(e.trim())try{const n=JSON.parse(e);if("user"===n.type&&n.message){const e=n.message;let r="";e.content&&"string"==typeof e.content&&(r=e.content),r.trim()&&t.push(r.trim())}}catch{continue}t.length>0&&dlog(`[Import] extracted ${t.length} prompts from session`)}catch(t){dlog(`[Import] failed: ${e}`,t)}return t}static splitPromptsIntoBatches(e,t=15e4){const n=[];let r=[],o=0;for(const s of e){const e=estimateTokens(s);if(e>t){r.length>0&&(n.push(r),r=[],o=0);const e=this.splitLargePrompt(s,t);for(const t of e)n.push([t])}else o+e<=t?(r.push(s),o+=e):(r.length>0&&n.push(r),r=[s],o=e)}return r.length>0&&n.push(r),n}static splitLargePrompt(e,t){const n=[],r=e.split("\n");let o="",s=0;for(const e of r){const r=estimateTokens(e);s+r<=t?(o+=(o?"\n":"")+e,s+=r):(o&&n.push(o),o=e,s=r)}return o&&n.push(o),n}static async importAndLearn(){const e=[],t=[],n=[],r=[],o=[];try{cv.addEvent({type:"step_start",step:"importing",label:"Started Learning Taste",message:"Scanning for coding sessions..."});const s=await loadProjectSettings(),i=s.tasteOnboarding?.learnedSessions||{},a=i["claude-code"]?.length||0,l=i.codex?.length||0,u=i.cursor?.length||0;dlog(`[Import] loaded settings: claude-code=${a} learned, codex=${l} learned, cursor=${u} learned`);const d=await findNewSessions(i),m=d["claude-code"]||[],g=d.codex||[],h=d.cursor||[],f=m.length+g.length+h.length;if(dlog(`[Import] findNewSessions returned: claude-code=${m.length} new, codex=${g.length} new, cursor=${h.length} new`),0===f){const e=await this.findClaudeCodeSessions(),t=await findCodexSessions(process.cwd()),n=await findCursorSessions(process.cwd()),r=e.length+t.length+n.length,o=[{name:"Claude Code",count:e.length},{name:"Codex",count:t.length},{name:"Cursor",count:n.length}].filter(e=>e.count>0).sort((e,t)=>t.count-e.count).map(e=>`${e.count} ${e.name}`);cv.addEvent({type:"step_start",step:"complete",label:"Taste Already Learned",message:r>0?`From ${o.join(" + ")} sessions`:"No sessions found for this project"});const s=[];return e.length>0&&s.push({agent:"claude-code",sessionIds:e.map(e=>e.id),displayName:"Claude Code"}),t.length>0&&s.push({agent:"codex",sessionIds:t.map(e=>e.id),displayName:"Codex"}),n.length>0&&s.push({agent:"cursor",sessionIds:n.map(e=>e.id),displayName:"Cursor"}),{success:!1,totalPrompts:0,preferencesLearned:0,errors:[],totalSessions:r,learnedSessions:a+l+u,agentSessions:s,status:"already-learned"}}if(m.length>0){const e=(await this.findClaudeCodeSessions()).filter(e=>m.includes(e.id));n.push(...e)}if(g.length>0){const e=(await this.findCodexSessions()).filter(e=>g.includes(e.id));r.push(...e)}if(h.length>0){const e=(await this.findCursorSessions()).filter(e=>h.includes(e.id));o.push(...e)}const y=n.length+r.length+o.length;dlog(`[Import] total sessions: ${y} (claude-code: ${n.length}, codex: ${r.length}, cursor: ${o.length})`),cv.addEvent({type:"step_start",step:"batching",label:"Organizing your sessions",message:""});const w=[{name:"Claude Code",sessions:n,extractPrompts:this.extractUserPrompts},{name:"Codex",sessions:r,extractPrompts:extractCodexPrompts},{name:"Cursor",sessions:o,extractPrompts:extractCursorPrompts}].filter(e=>e.sessions.length>0).sort((e,t)=>t.sessions.length-e.sessions.length);for(const n of w){cv.addEvent({type:"progress",message:`${n.name}: ${n.sessions.length} sessions`});for(const r of n.sessions)try{const e=await n.extractPrompts(r.filePath);e.length>0&&t.push(...e)}catch(t){e.push(`${n.name} import failed: ${t instanceof Error?t.message:String(t)}`)}}if(0===t.length)return{success:!1,totalPrompts:0,preferencesLearned:0,errors:["No prompts found in sessions"]};const S=this.splitPromptsIntoBatches(t);dlog(`[Import] batched: ${t.length} prompts → ${S.length} batches`);const E=observeSessionPrompts({prompts:t}).catch(e=>{dlog(`[Import] observer error: ${e instanceof Error?e.message:String(e)}`)});cv.addEvent({type:"step_start",step:"learning",label:"Learning your coding taste",message:`Processing ${S.length} batch${1===S.length?"":"es"}`});try{const s=getApiBaseUrl(),i=new Ly({baseUrl:s});let a=!0;for(let e=0;e<S.length;e++){const t=S[e],n=e+1,r=S.length;r>1&&cv.addEvent({type:"progress",message:`Processing batch ${n}/${r}...`});const o=this.formatBatchLearning(t),s=new pv({request:i,sessionId:crypto.randomUUID(),projectRoot:process.cwd()}),l=[{role:"user",content:o}];dlog(`[Import] batch ${n}/${r}: ${t.length} prompts`),(await s.checkAndProcess({messages:l})).success||(a=!1,dlog(`[Import] batch ${n}/${r} failed`))}if(dlog(`[Import] all batches complete, success: ${a}`),cv.markLearningComplete(),await E,a){if(n.length>0){const e=n.map(e=>e.id);await markSessionsAsLearned("claude-code",e),dlog(`[Import] marked ${e.length} claude-code sessions as learned`)}if(r.length>0){const e=r.map(e=>e.id);await markSessionsAsLearned("codex",e),dlog(`[Import] marked ${e.length} codex sessions as learned`)}if(o.length>0){const e=o.map(e=>e.id);await markSessionsAsLearned("cursor",e),dlog(`[Import] marked ${e.length} cursor sessions as learned`)}}else dlog("[Import] NOT marking sessions as learned due to batch failures");const l=await this.extractLearningSummary(),u=[];if(n.length>0&&u.push(`Claude Code (${n.length})`),r.length>0&&u.push(`Codex (${r.length})`),o.length>0&&u.push(`Cursor (${o.length})`),!a){const s="Learning failed - sessions not marked as learned";return e.push(s),cv.addEvent({type:"error",message:s}),{success:!1,totalPrompts:t.length,preferencesLearned:l.totalLearnings,errors:e,totalSessions:y,agentSessions:[...n.length>0?[{agent:"claude-code",sessionIds:n.map(e=>e.id),displayName:"Claude Code"}]:[],...r.length>0?[{agent:"codex",sessionIds:r.map(e=>e.id),displayName:"Codex"}]:[],...o.length>0?[{agent:"cursor",sessionIds:o.map(e=>e.id),displayName:"Cursor"}]:[]]}}return cv.addEvent({type:"step_start",step:"complete",label:"Learning Complete",message:`Learned from ${u.join(" + ")}`,learningCount:l.totalLearnings,categories:l.categories,storage:".commandcode/taste/taste.md"}),{success:!0,totalPrompts:t.length,preferencesLearned:l.totalLearnings,errors:e,totalSessions:y,agentSessions:[...n.length>0?[{agent:"claude-code",sessionIds:n.map(e=>e.id),displayName:"Claude Code"}]:[],...r.length>0?[{agent:"codex",sessionIds:r.map(e=>e.id),displayName:"Codex"}]:[],...o.length>0?[{agent:"cursor",sessionIds:o.map(e=>e.id),displayName:"Cursor"}]:[]]}}catch(n){const r=`Learning agent failed: ${n instanceof Error?n.message:String(n)}`;return e.push(r),cv.addEvent({type:"error",message:r}),{success:!1,totalPrompts:t.length,preferencesLearned:0,errors:e}}}catch(t){const n=t instanceof Error?t.message:String(t);return e.push(n),{success:!1,totalPrompts:0,preferencesLearned:0,errors:e}}}static async extractLearningSummary(){try{const t=e.join(process.cwd(),".commandcode","taste","taste.md"),n=await D.readFile(t,"utf-8"),r=n.match(/^- .+Confidence:/gm),o=r?r.length:0;return{totalLearnings:o,categories:n.split("\n").filter(e=>e.startsWith("# ")).map(e=>e.replace(/^# /,"").trim()).filter(e=>e&&!e.toLowerCase().startsWith("taste"))}}catch{return{totalLearnings:0,categories:[]}}}static formatBatchLearning(e){return e.map((e,t)=>`${t+1}. ${e}`).join("\n\n")}};dv();var Zx=__name(e=>new Promise((t,n)=>setTimeout(()=>n(new Error("Learning timed out. Try again with /learn-taste")),e)),"createTimeout"),eA=__name(e=>{const[t,n]=J({isImporting:!0,waitingForInput:!1,alreadyLearned:!1,learnedSessionCount:0,totalSessionCount:0,agentSessions:[],error:null});return Z(()=>{cv.reset(),cv.markImportStarted(),(async()=>{try{const t=await Promise.race([Xx.importAndLearn(),Zx(12e4)]);if(t.success)return void n(e=>({...e,isImporting:!1,waitingForInput:!0}));if("already-learned"===t.status)return void n(e=>({...e,isImporting:!1,alreadyLearned:!0,learnedSessionCount:t.learnedSessions||0,totalSessionCount:t.totalSessions||0,agentSessions:t.agentSessions||[],waitingForInput:!0}));const r=t.errors.join("\n");n(e=>({...e,isImporting:!1,waitingForInput:!0,error:r})),e&&e(r)}catch(t){const r=t instanceof Error?t.message:String(t);n(e=>({...e,isImporting:!1,waitingForInput:!0,error:r})),e&&e(r)}})()},[e]),t},"useImportProcess");Ht();var tA=__name(({onEscape:e,onEnter:t,enabled:n=!0})=>{ie((r,o)=>{n&&(o.escape&&e(),(o.return||"\n"===r)&&t())})},"useKeyboardInput");Ht(),Rn();var nA=__name(({autoLearn:e,onShouldSkip:t})=>{const[n,r]=J(null),[o,s]=J(null),i=X(!1);return Z(()=>{if(i.current)return;let n=null;return(async()=>{try{i.current=!0,dlog("[Hook:Conditions] loading...");const n=await checkOnboardingConditions();r(n),n.shouldTrigger||e?dlog(`[Hook:Conditions] result: ${n.reason}, sessions: ${n.sessionCount}`):(dlog("[Hook:Conditions] no trigger, skipping"),t())}catch(e){const r=e instanceof Error?e.message:String(e);dlog("[Hook:Conditions] error",r),s(r),n=setTimeout(()=>t(),2e3)}})(),()=>{n&&clearTimeout(n)}},[e,t]),{conditions:n,error:o,isLoading:!n&&!o}},"useOnboardingConditions");async function completeOnboarding(e){try{await markOnboardingCompleted(),dlog("[Helper] onboarding marked complete")}catch(e){dlog(`[Helper] complete error: ${e instanceof Error?e.message:String(e)}`)}finally{cv.reset(),e()}}async function skipOnboarding(e){try{await markOnboardingSkipped(),dlog("[Helper] onboarding marked skipped")}catch(e){dlog(`[Helper] skip error: ${e instanceof Error?e.message:String(e)}`)}finally{cv.reset(),e()}}Ht(),Rn(),Ht(),Rn(),dv(),__name(completeOnboarding,"completeOnboarding"),__name(skipOnboarding,"skipOnboarding");var rA=__name(({onStepChange:e,onError:t,onCompleteCallback:n})=>{const r=X(n),o=te(()=>{dlog("[Handler] import started → learning"),e("learning")},[e]),s=te(async()=>{dlog("[Handler] import complete → done"),e("done"),await completeOnboarding(()=>r.current())},[e]),i=te(e=>{dlog(`[Handler] import error: ${e}`),t(e)},[t]),a=te(async()=>{dlog("[Handler] error dismissed by user → done"),e("done"),await skipOnboarding(()=>r.current({skipped:!0}))},[e]),l=te(async()=>{dlog("[Handler] skipped → done"),e("done"),await skipOnboarding(()=>r.current({skipped:!0}))},[e]);return n!==r.current&&(r.current=n),{handleImportStart:o,handleImportComplete:s,handleImportError:i,handleErrorDismiss:a,handleSkip:l}},"useOnboardingHandlers");Ht(),Rn();var oA=__name(({conditions:e,autoLearn:t})=>{const[n,r]=J("checking"),o=X(!1);return Z(()=>{if(e&&!o.current){if(o.current=!0,t)return dlog("[Flow] autoLearn → learning"),void r("learning");dlog(`[Flow] → asking (${e.reason})`),r("asking")}},[e,t]),Z(()=>{dlog(`[Flow] step: ${n}`)},[n]),{step:n,setStep:r}},"useOnboardingFlow");Ht(),Ht(),hr();var sA=__name(({error:e})=>K.createElement(ne,{padding:1},K.createElement(ne,{flexDirection:"column",borderColor:zn.RED,padding:1},K.createElement(ne,{marginBottom:1},K.createElement(re,null,"Error initializing onboarding: ",e)),K.createElement(ne,null,K.createElement(re,null,"Continuing without onboarding...")))),"OnboardingError");Ht(),Ht(),Yt(),hr();var iA=__name(()=>`(run /${Mt.LEARN_TASTE} anytime)`,"getSkipHint"),aA=__name(()=>K.createElement(re,null,"Skip for now"," ",K.createElement(re,{color:zn.DIM},iA())),"SkipOptionText"),lA=__name(({sessionCount:e,agentSessions:t,onImport:n,onSkip:r})=>{const[o,s]=J(1);return ie((e,t)=>{t.escape?r():t.upArrow||t.downArrow?s(e=>1===e?2:1):"1"!==e?"2"!==e?t.return&&(1===o?n():r()):r():n()}),K.createElement(ne,{flexDirection:"column",borderStyle:"single",borderColor:Gn.TEXT,paddingX:1,paddingY:0},K.createElement(re,{color:Gn.TEXT,bold:!0},"Build Your Coding Taste"),K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(re,null,"Found"," ",1===e?"one session":`${e} sessions`," ","from"," ",t.map(e=>e.displayName).join(", ")," ","for this project."),K.createElement(ne,{marginTop:1},K.createElement(re,null,"Want me to analyze"," ",1===e?"that session":"those sessions"," ","and build your coding taste profile?"))),K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(ne,null,K.createElement(re,{color:1===o?Gn.TEXT:zn.GRAY},1===o?_e.pointer:" "," 1. Yes, learn from my sessions (recommended)")),K.createElement(ne,null,K.createElement(re,{color:2===o?Gn.TEXT:zn.GRAY},2===o?_e.pointer:" "," 2."," ",K.createElement(aA,null)))),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Use arrow keys or numbers to select, Enter to confirm")))},"ImportChoice");Ht(),Ht(),hr();var cA=__name(({error:e})=>K.createElement(ne,{flexDirection:"column",borderStyle:"single",borderColor:zn.RED,paddingX:2,paddingY:1,marginBottom:2},K.createElement(re,{color:zn.RED,bold:!0},"Oops, something went wrong:"),K.createElement(ne,{marginTop:1},K.createElement(re,null,e))),"ErrorSection");Ht(),Ht(),hr(),Ht(),Ht(),Ht(),hr(),Ht(),hr();var uA=__name(()=>K.createElement(re,{backgroundColor:Gn.BADGE_BG,color:Gn.BADGE_FG},Kk),"TasteBadge");Ht(),hr(),Ht();var dA=["percolating","excavating","deciphering","triangulating","osmosing","metabolizing","grokking","spelunking","interpolating","marinating","crystallizing","synthesizing","calibrating","fermenting","coalescing","transmuting","simmering","distilling","ruminating","perusing","assimilating","untangling","decoding","absorbing","harmonizing","digesting","contemplating","extrapolating","materializing","finalizing"],mA="⎿",pA=__name(()=>{const[e,t]=J(()=>Math.floor(Math.random()*dA.length));return Z(()=>{const e=setInterval(()=>{t(Math.floor(Math.random()*dA.length))},2e3);return()=>clearInterval(e)},[]),K.createElement(re,{color:zn.YELLOW},dA[e],"...")},"PulsingText");Ht(),hr();var gA=[_e.bullet,_e.squareSmallFilled,_e.lozenge,_e.star,_e.triangleRight,_e.triangleUp,_e.circleFilled,_e.pointer],hA=__name(e=>String(e).padStart(3," "),"padNum"),fA=__name(e=>gA[e%gA.length],"getSymbol"),yA=__name((e,t,n,r)=>r?`${e} observations (↑↓ scroll)`:`↑${hA(t)} ↓${hA(n)} (↑↓ scroll)`,"buildStatusLine"),wA=__name(({insights:e})=>{const[t,n]=J(0),[r,o]=J(!0),s=e.length,i=s>10,a=Math.max(0,s-10);if(Z(()=>{r&&i&&n(a)},[s,r,i,a]),ie((e,t)=>{if(i)return t.upArrow?(o(!1),void n(e=>Math.max(0,e-1))):void(t.downArrow&&n(e=>{const t=Math.min(a,e+1);return t===a&&o(!0),t}))}),0===s)return null;const l=e.slice(t,t+10),u=t,d=s-t-10;return K.createElement(ne,{flexDirection:"column",marginLeft:4,marginBottom:0},i&&K.createElement(re,{color:zn.DIM},yA(s,u,d,r)),l.map((e,n)=>{const r=t+n;return K.createElement(ne,{key:r,marginBottom:0},K.createElement(re,{color:zn.DIM},fA(r)," ",e))}))},"ScrollableInsights");Ht(),hr();var SA=__name(()=>{const[e,t]=J(!0);return Z(()=>{const e=setInterval(()=>{t(e=>!e)},500);return()=>clearInterval(e)},[]),K.createElement(re,{color:zn.YELLOW},e?_e.circleFilled:_e.circle)},"PulsingDot"),bA=__name(({label:e,message:t,active:n,complete:r,items:o,insights:s,isIntro:i,isAllComplete:a,summary:l})=>{if(i)return K.createElement(ne,{flexDirection:"column",marginBottom:0},K.createElement(uA,null),K.createElement(ne,{marginTop:0},K.createElement(re,{color:zn.DIM},mA),K.createElement(ne,{marginLeft:2},a?K.createElement(re,{color:Gn.TEXT},"learned your coding taste"):K.createElement(pA,null))));const u=__name(()=>r?K.createElement(re,{color:Kn.BG},_e.square):n?K.createElement(SA,null):K.createElement(re,{color:zn.DIM},_e.circle),"getStatusIcon"),d=o.length>0||s.length>0||t||l&&l.learningCount>0;return!r||n||d?K.createElement(ne,{flexDirection:"column",marginBottom:0},(n||r)&&K.createElement(ne,{marginBottom:0},K.createElement(ne,{marginRight:1},u()),K.createElement(re,{color:r?zn.WHITE:n?zn.YELLOW:zn.DIM},e)),r&&t&&(!l||0===l.learningCount)&&K.createElement(ne,{marginLeft:3,marginBottom:0},K.createElement(re,{color:zn.DIM},t)),o.length>0&&K.createElement(ne,{flexDirection:"column",marginLeft:1,marginBottom:0},o.map((e,t)=>K.createElement(re,{key:t,color:zn.DIM},`${_e.bullet} ${e}`))),s.length>0&&K.createElement(wA,{insights:s}),r&&l&&l.learningCount>0&&K.createElement(ne,{flexDirection:"column",marginLeft:1,marginBottom:0},K.createElement(ne,{marginBottom:1,flexDirection:"row"},K.createElement(re,null,mA),K.createElement(ne,{marginLeft:2},K.createElement(re,{color:Gn.TEXT},"Learned ",l.learningCount," preference",1===l.learningCount?"":"s",l.categories.length>0?` across ${l.categories.length} ${1===l.categories.length?"category":"categories"}`:""))),K.createElement(ne,{flexDirection:"column",marginLeft:1},K.createElement(re,{color:zn.DIM},_e.pointerSmall," Stored in"," ",l.storage),K.createElement(re,{color:zn.DIM},"Command Code automatically uses & updates taste files.")))):null},"StepItem"),EA=__name(({steps:e})=>{const t=e.find(e=>"complete"===e.id)?.complete??!1;return K.createElement(ne,{flexDirection:"column",marginBottom:1},e.map((e,n)=>K.createElement(ne,{key:e.id,marginLeft:0===n?0:3},K.createElement(bA,{label:e.label,message:e.message,active:e.active,complete:e.complete,items:e.items,insights:e.insights,summary:e.summary,isIntro:0===n,isAllComplete:t}))))},"StepsSection"),CA=__name(({steps:e})=>K.createElement(EA,{steps:e}),"ProgressSection");Ht(),hr();var vA=__name(({isImporting:e=!1,waitingForInput:t=!1})=>K.createElement(K.Fragment,null,e&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"ESC to cancel")),t&&K.createElement(ne,{marginTop:1},K.createElement(re,{bold:!0},"Press ENTER to continue"))),"HelpTextSection");Ht();var kA=[{id:"importing",label:"Initializing Taste Profile",message:"",active:!1,complete:!1,items:[],insights:[]},{id:"batching",label:"Organizing your sessions",message:"",active:!1,complete:!1,items:[],insights:[]},{id:"learning",label:"Learning your coding taste",message:"",active:!1,complete:!1,items:[],insights:[]},{id:"complete",label:"Learned your coding taste!",message:"",active:!1,complete:!1,items:[],insights:[],summary:{learningCount:0,categories:[],storage:".commandcode/taste/taste.md"}}],TA=__name(({onComplete:e,onError:t,onErrorDismiss:n})=>{const{steps:r,importError:o}=Yx(kA),{isImporting:s,waitingForInput:i,error:a}=eA(t);return tA({onEscape:e,onEnter:__name(()=>{i&&(a&&n?n():e())},"onEnter"),enabled:s||i}),K.createElement(ne,{flexDirection:"column",padding:1},o&&K.createElement(cA,{error:o}),!o&&K.createElement(CA,{steps:r}),K.createElement(vA,{isImporting:s,waitingForInput:i}))},"ImportProgress"),_A=__name(({step:e,conditions:t,onImportStart:n,onImportComplete:r,onImportError:o,onErrorDismiss:s,onSkip:i})=>"asking"===e?t&&"has_sessions"===t.reason?K.createElement(lA,{sessionCount:t.sessionCount,agentSessions:t.agentSessions,onImport:n,onSkip:i}):null:"learning"===e?K.createElement(TA,{onComplete:r,onError:o,onErrorDismiss:s}):null,"OnboardingStepRenderer"),xA=__name(({onComplete:e,autoLearn:t=!1})=>{Z(()=>(dlog("[UI:Onboarding] mounted"),()=>{dlog("[UI:Onboarding] unmounted")}),[]);const{conditions:n,error:r,isLoading:o}=nA({autoLearn:t,onShouldSkip:e}),{step:s,setStep:i}=oA({conditions:n,autoLearn:t}),{handleImportStart:a,handleImportComplete:l,handleImportError:u,handleErrorDismiss:d,handleSkip:m}=rA({onStepChange:__name(e=>{i(e)},"onStepChange"),onError:__name(()=>{},"onError"),onCompleteCallback:e});return dlog(`[UI:Onboarding] render: ${s}${n?.reason?` (${n.reason})`:""}${r?" ERROR":""}`),o?null:r?K.createElement(sA,{error:r}):"done"===s?null:K.createElement(_A,{step:s,conditions:n,onImportStart:a,onImportComplete:l,onImportError:u,onErrorDismiss:d,onSkip:m})},"TasteOnboarding");function getEntryCharCount(e){return("input"in e?e.input??"":"").length+("output"in e?e.output??"":"").length+("command"in e?e.command??"":"").length}function getBudgetedFeed(e,t){if(0===e.length)return[];const n=[...e].reverse();let r=t;const o=[];for(const e of n)if(o.unshift(e),r-=getEntryCharCount(e),r<=0)break;return o}__name(getEntryCharCount,"getEntryCharCount"),__name(getBudgetedFeed,"getBudgetedFeed");var AA=Y(__name(function MainView2({feed:e,liveEntries:t,queuedMessages:n,isCmdCodeBusy:r,staticKey:o,transcriptMode:s,tasteOnboardingEntryId:i,autoLearnTaste:a,retryAttempt:l,input:u,setInput:d,fileSearchQuery:m,setFileSearchQuery:g,showFileList:h,setShowFileList:f,showProviderSelector:y,showModelSelector:w,showMemorySelector:S,showMcpManager:E,showAgentsConfig:C,showRewindSelector:v,showLoginOverlay:k,showUsageOverlay:T,showAddDirModal:_,showCompactModeSelector:x,authComponentInfo:A,status:P,currentProvider:I,currentModel:N,showProviderNotification:R,shareInfo:M,showShareNotification:$,unshareNotificationMessage:L,updateStatus:D,updateFailedInfo:O,creditWarning:F,permissionMode:q,hintMessage:j,pendingExitKey:B,tasteLearningEnabled:U,interactionTokens:z,contextUsage:W,historyManagerRef:G,executionState:H,contextEngineRef:V,onSubmit:Q,onCommand:Y,onToggleAutoAccept:J,onResetPendingExitKey:X,onDoubleEscapeEmpty:Z,onTasteOnboardingComplete:oe,permissionPanel:se,questionPanel:ie,onRewindSelect:ae,onRewindCancel:le,onLoginComplete:ce,onLoginCancel:ue,setShowProviderSelector:de,setShowModelSelector:me,setShowMemorySelector:pe,setShowMcpManager:ge,setShowAgentsConfig:he,setShowAddDirModal:fe,setShowUsageOverlay:ye,handleProviderSelect:we,handleProviderCancel:Se,handleModelSelect:be,handleModelCancel:Ee,handleCompactModeSelect:Ce,handleCompactModeCancel:ve,handleAuthSuccess:ke,handleAuthCancel:Te}){const _e=ee(()=>e.filter(e=>"taste-onboarding"!==e.role),[e]),xe=useTerminalWidth(),Ae=ee(()=>"off"===s?_e:getBudgetedFeed(_e,"limited"===s?15e3:5e4),[_e,s]),Pe=ee(()=>"off"===s?0:Math.max(0,_e.length-Ae.length),[_e.length,Ae.length,s]),Ie=ee(()=>0===Pe?Ae:Ae.filter(e=>"user"!==e.role),[Ae,Pe]),Ne=te(()=>he(!1),[he]),Re=te(()=>pe(!1),[pe]),Me=te(()=>ge(!1),[ge]),$e=te(()=>fe(!1),[fe]),Le=te(()=>me(!0),[me]),De=!("off"!==s||se||ie||y||w||A||S||E||C||v||k||T||_||x||i);return K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(Bx,{staticKey:o,feed:Ie,showHeader:!0,expandedToolOutput:"off"!==s,currentModel:N,hiddenCount:Pe}),i&&K.createElement(xA,{onComplete:oe,autoLearn:a}),t.map(e=>e.metadata?.isAgent?K.createElement(zx,{key:e.id,entry:e}):K.createElement(ne,{key:e.id,marginBottom:1,width:"90%"},renderFeedEntry(e,"off"!==s))),K.createElement(RetryMessage,{attempt:l}),ie,se,"off"!==s&&K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(ne,null,K.createElement(re,{color:zn.DIM},"─".repeat(xe))),K.createElement(ne,{paddingRight:1},K.createElement(re,{backgroundColor:Kn.BG,color:Kn.FG,bold:!0},`${Qk}DETAILED TRANSCRIPT${Qk}`),K.createElement(re,{color:zn.DIM}," · "),K.createElement(re,{bold:!0},"ctrl+o"),K.createElement(re,{color:zn.DIM}," to toggle"),K.createElement(re,{color:zn.DIM}," · "),K.createElement(re,{bold:!0},"ctrl+e"),K.createElement(re,{color:zn.DIM}," ","to"," ","limited"===s?"show all":"collapse"))),De&&K.createElement($x,{queuedMessages:n,isProcessing:r,executionState:H,status:P,input:u,setInput:d,onSubmit:Q,showFileList:h,setShowFileList:f,fileSearchQuery:m,setFileSearchQuery:g,onCommand:Y,outputTokens:z,contextUsage:W,tasteLearning:U,shareInfo:M,showShareNotification:$,unshareNotificationMessage:L,updateStatus:D,updateFailedInfo:O,creditWarning:F,currentProvider:I,showProviderInfo:R,permissionMode:q,onToggleAutoAccept:J,hintMessage:j,historyManager:G.current,pendingExitKey:B,onResetPendingExitKey:X,onDoubleEscapeEmpty:Z,retryAttempt:l,onAltP:Le}),y&&K.createElement(ne,{marginY:1},K.createElement(Vx,{onSelect:we,onCancel:Se,currentProvider:I})),w&&K.createElement(ne,{marginY:1},K.createElement(Hx,{onSelect:be,onCancel:Ee,currentModel:N})),x&&K.createElement(ne,{marginY:1},K.createElement(ix,{onSelect:Ce,onCancel:ve})),C&&K.createElement(ne,{marginY:1},K.createElement(ox,{onCancel:Ne})),S&&K.createElement(ne,{marginY:1},K.createElement(Ox,{onClose:Re})),E&&K.createElement(ne,{marginY:1},K.createElement(Dx,{onClose:Me})),v&&V.current&&K.createElement(ne,{marginY:1},K.createElement(Kx,{checkpoints:V.current.listCheckpoints(),onSelect:ae,onCancel:le})),A&&K.createElement(ne,{marginY:1},K.createElement(A.Component,{onSuccess:ke,onCancel:Te})),k&&K.createElement(ne,{marginY:1},K.createElement(Lx,{onComplete:ce,onCancel:ue})),_&&K.createElement(ne,{marginY:1},K.createElement(U_,{onClose:$e})))},"MainView"));function renderView({feedState:e,sessionState:t,statusState:n,authState:r,uiOverlays:o,onboarding:s,exitState:i,pendingOps:a,permissionState:l,contextEngineRef:u,historyManagerRef:d,executionState:m,actionCallbacks:g,onSubmit:h,onCommand:f,input:y,setInput:w,fileSearchQuery:S,setFileSearchQuery:E,updateFailedInfo:C,creditWarning:v,handleTrust:k,handleNoTrust:T,handleToggleAutoAccept:_,handleDoubleEscapeEmpty:x,handleTasteOnboardingComplete:A,loadTasteStatus:P}){if(i.shouldExit)return null;if(s.checkingProject)return null;if(s.showTrustPrompt)return K.createElement(e_,{staticKey:o.staticKey,onTrust:k,onExit:T});if(o.showSessionSelector)return K.createElement(n_,{onSelectSession:g.onSelectSession,onNewSession:g.onNewSession});if(!s.projectTrusted)return null;const I=a.pendingQuestion?K.createElement(QuestionView,{pendingQuestion:a.pendingQuestion,permissionMode:l.permissionMode,setPermissionMode:l.setPermissionMode,setPendingQuestion:a.setPendingQuestion,setStatus:n.setStatus,setStaticKey:o.setStaticKey}):null,N=a.pendingPermission?K.createElement(p_,{pendingPermission:a.pendingPermission,permissionMode:l.permissionMode,setPendingPermission:a.setPendingPermission,setStatus:n.setStatus,respondToPrompt:l.respondToPrompt,showHintMessage:n.showHintMessage,handleToggleAutoAccept:_}):null;return o.showLearningFeed?K.createElement(LearningView,{setShowLearningFeed:o.setShowLearningFeed,setStaticKey:o.setStaticKey,onExit:()=>i.setShouldExit(!0)}):o.showTasteConfig?K.createElement(TasteConfigView,{staticKey:o.staticKey,setShowTasteConfig:o.setShowTasteConfig,loadTasteStatus:P}):o.showSkillsConfig?K.createElement(SkillsConfigView,{staticKey:o.staticKey,setShowSkillsConfig:o.setShowSkillsConfig}):o.showUsageOverlay?K.createElement(UsageView,{staticKey:o.staticKey,setShowUsageOverlay:o.setShowUsageOverlay}):o.showContextView?K.createElement(ContextConfigView,{staticKey:o.staticKey,contextEngineRef:u,setShowContextView:o.setShowContextView,setInput:w}):o.showStatusView?K.createElement(StatusConfigView,{staticKey:o.staticKey,setShowStatusView:o.setShowStatusView,setInput:w}):K.createElement(AA,{feed:e.feed,liveEntries:e.liveEntries,queuedMessages:e.queuedMessages,isCmdCodeBusy:e.isCmdCodeBusy,staticKey:o.staticKey,transcriptMode:o.transcriptMode,tasteOnboardingEntryId:s.tasteOnboardingEntryId,autoLearnTaste:s.autoLearnTaste,retryAttempt:n.retryAttempt,input:y,setInput:w,fileSearchQuery:S,setFileSearchQuery:E,showFileList:o.showFileList,setShowFileList:o.setShowFileList,showProviderSelector:o.showProviderSelector,showModelSelector:o.showModelSelector,showMemorySelector:o.showMemorySelector,showMcpManager:o.showMcpManager,showAgentsConfig:o.showAgentsConfig,showRewindSelector:o.showRewindSelector,showLoginOverlay:o.showLoginOverlay,showUsageOverlay:o.showUsageOverlay,setShowUsageOverlay:o.setShowUsageOverlay,showAddDirModal:o.showAddDirModal,showCompactModeSelector:o.showCompactModeSelector,authComponentInfo:r.authComponentInfo,status:n.status,currentProvider:r.currentProvider,currentModel:r.currentModel,showProviderNotification:r.showProviderNotification,shareInfo:n.shareInfo,showShareNotification:n.showShareNotification,unshareNotificationMessage:n.unshareNotificationMessage,updateStatus:n.updateStatus,updateFailedInfo:C,creditWarning:v,permissionMode:l.permissionMode,hintMessage:n.hintMessage,pendingExitKey:i.pendingExitKey,tasteLearningEnabled:n.tasteLearningEnabled,interactionTokens:n.interactionTokens,contextUsage:n.contextUsage,historyManagerRef:d,executionState:m,contextEngineRef:u,onSubmit:h,onCommand:f,onToggleAutoAccept:_,onResetPendingExitKey:i.resetPendingExitKey,onDoubleEscapeEmpty:x,onTasteOnboardingComplete:A,permissionPanel:N,questionPanel:I,onRewindSelect:g.onRewindSelect,onRewindCancel:g.onRewindCancel,onLoginComplete:g.onLoginComplete,onLoginCancel:g.onLoginCancel,setShowProviderSelector:o.setShowProviderSelector,setShowModelSelector:o.setShowModelSelector,setShowMemorySelector:o.setShowMemorySelector,setShowMcpManager:o.setShowMcpManager,setShowAgentsConfig:o.setShowAgentsConfig,setShowRewindSelector:o.setShowRewindSelector,setShowLoginOverlay:o.setShowLoginOverlay,setShowAddDirModal:o.setShowAddDirModal,handleProviderSelect:g.handleProviderSelect,handleProviderCancel:g.handleProviderCancel,handleModelSelect:g.handleModelSelect,handleModelCancel:g.handleModelCancel,handleCompactModeSelect:g.handleCompactModeSelect,handleCompactModeCancel:g.handleCompactModeCancel,handleAuthSuccess:g.handleAuthSuccess,handleAuthCancel:g.handleAuthCancel})}__name(renderView,"renderView");var PA=__name(({resume:e=!1,resumeSessionId:t,continue:n=!1,trust:r=!1,dangerouslySkipPermissions:o=!1,updateStatus:s,updateFailedInfo:i,initialPrompt:a,skipOnboarding:l=!1,initialPermissionMode:u,sessionTitleHolder:d})=>{const{exit:m}=le(),{stdout:g}=se(),[h,f]=J(""),[y,w]=J(""),S=X(!1),E=X(!1),C=X(null),v=X(null),k=useUiOverlays(),T=useFeed(),_=useSession(),x=useStatus(s),A=useAuth(),P=usePendingOps(),I=useOnboarding(),N=useExit(),{executeBash:R,executionState:M}=Ok(),$=usePermissionMode({initialPermissionMode:u,dangerouslySkipPermissions:o,setPendingPermission:P.setPendingPermission,setStatus:x.setStatus,contextEngineRef:v}),{createContextEngineCallbacks:L}=useContextEngine({sessionId:_.sessionId,sessionLoaded:_.sessionLoaded,showSessionSelector:k.showSessionSelector,projectTrusted:I.projectTrusted,setFeed:T.setFeed,setLiveEntries:T.setLiveEntries,setQueuedMessages:T.setQueuedMessages,queuedMessagesRef:T.queuedMessagesRef,setStatus:x.setStatus,pinnedStatusRef:x.pinnedStatusRef,setRetryAttempt:x.setRetryAttempt,setInteractionTokens:x.setInteractionTokens,setContextUsage:x.setContextUsage,setCurrentProvider:A.setCurrentProvider,shareInfoRef:x.shareInfoRef,permissionsService:$.permissionsService,permissionModeRef:$.permissionModeRef,setPendingQuestion:P.setPendingQuestion,contextEngineRef:v}),{onCommand:D}=useCommandCtx({feedState:T,sessionState:_,statusState:x,authState:A,uiOverlays:k,onboarding:I,exitState:N,permissionState:$,contextEngineRef:v,isSubmittingRef:S,executeBash:R,createContextEngineCallbacks:L,setInput:f}),{loadTasteStatus:O,loadCurrentProvider:F,onSubmit:q}=useStartup({resume:e,resumeSessionId:t,continueLatest:n,trust:r,initialPrompt:a,stdout:g,feedState:T,sessionState:_,statusState:x,authState:A,onboarding:I,uiOverlays:k,permissionState:$,contextEngineRef:v,isSubmittingRef:S,initialPromptSubmittedRef:E,historyManagerRef:C,executeBash:R,createContextEngineCallbacks:L,setInput:f,onCommand:D});useLifecycle({exit:m,feedState:T,exitState:N,statusState:x,authState:A,onboarding:I,uiOverlays:k,skipOnboarding:l,contextEngineRef:v,sessionTitleHolder:d});const{handleToggleAutoAccept:j,handleDoubleEscapeEmpty:B,handleTasteOnboardingComplete:U,handleTrust:z,handleNoTrust:W}=useHandlers({resume:e,feedState:T,onboarding:I,uiOverlays:k,exitState:N,pendingOps:P,permissionState:$,statusState:x,authState:A,contextEngineRef:v,loadTasteStatus:O,loadCurrentProvider:F,setInput:__name(e=>f(e),"setInput")}),G=useMainActionCallbacks({feedState:T,sessionState:_,statusState:x,authState:A,uiOverlays:k,permissionState:$,contextEngineRef:v,createContextEngineCallbacks:L,setInput:f}),{creditWarning:H}=useCreditWarning({interactionTokens:x.interactionTokens});return renderView({feedState:T,sessionState:_,statusState:x,authState:A,uiOverlays:k,onboarding:I,exitState:N,pendingOps:P,permissionState:$,contextEngineRef:v,historyManagerRef:C,executionState:M,actionCallbacks:G,onSubmit:q,onCommand:D,input:h,setInput:f,fileSearchQuery:y,setFileSearchQuery:w,updateFailedInfo:i,creditWarning:H,handleTrust:z,handleNoTrust:W,handleToggleAutoAccept:j,handleDoubleEscapeEmpty:B,handleTasteOnboardingComplete:U,loadTasteStatus:O})},"InteractiveCLI");_r(),Un(),RC(),hr();var IA=__name(e=>e.replace(/\x1B\[[0-9;]*[A-Za-z]/g,"").replace(/[\x00-\x1F\x7F]/g," ").trim(),"sanitizeTitleForOutput"),NA=ue.hex(zn.DIM),RA=__name(e=>{const t=getInvokedCommandName(),n=De([e]);return`${NA("To continue this session, run:")}\n${NA(`${t} --resume ${n}`)}\n`},"formatResumeHint"),MA=__name(e=>e?{isValid:!0}:{isValid:!1,errorMessage:["Error: Interactive mode requires a TTY terminal.","Please run this command directly in your terminal, not through a pipe or redirect."].join("\n")},"validateTtyEnvironment"),$A=__name(e=>Boolean(e.resume||e.continue),"shouldValidateSessions"),LA=__name(({isInitialized:e,sessionCount:t})=>e&&0===t?{canProceed:!1,exitCode:0,message:"No conversations found to resume."}:{canProceed:!0},"validateSessionAvailability"),DA=__name(({options:e,resumeSessionId:t,sessionTitleHolder:n})=>{let r;return e.permissionMode?r=e.permissionMode:e.plan&&(r="plan"),{resume:"boolean"==typeof e.resume?e.resume:void 0,resumeSessionId:t,continue:e.continue,trust:e.trust,dangerouslySkipPermissions:e.dangerouslySkipPermissions,initialPrompt:e.initialPrompt,skipOnboarding:e.skipOnboarding,initialPermissionMode:r,sessionTitleHolder:n}},"buildInteractiveCLIProps"),OA=__name(()=>({stdin:process.stdin,stdout:process.stdout,stderr:process.stderr,exitOnCtrlC:!1}),"getInkRenderOptions"),FA=__name(()=>{enableBracketedPasteMode(),process.on("exit",()=>{disableBracketedPasteMode()})},"setupBracketedPasteMode"),qA=__name(()=>{FA()},"initializeTerminal"),jA=__name(async(e={})=>{const t=MA(process.stdin.isTTY);let n;if(t.isValid||(console.error(t.errorMessage),process.exit(1)),qA(),"string"==typeof e.resume){const t=e.resume;await vC.isProjectInitialized()||(console.error("Project not initialized. Run cmd to start a conversation first."),process.exit(1));const r=await vC.findSessionByName(t);r||(console.error(`No session named "${t}" found.`),process.exit(1)),n=r.id}if($A(e)&&!n){const e=await vC.isProjectInitialized(),t=e?await vC.listSessions():[],n=LA({isInitialized:e,sessionCount:t.length});n.canProceed||(console.log(n.message),process.exit(n.exitCode))}startEarlyInputCapture();const r={},o=DA({options:e,resumeSessionId:n,sessionTitleHolder:r}),s=OA(),{waitUntilExit:i}=ae(K.createElement(PA,{...o}),s);await i();const a=await(r.loadTitle?.());if(a){const e=IA(a);e&&process.stdout.write(RA(e))}},"interactiveMode");tn(),Ht(),Yt(),pk(),ok();var BA=__name(async()=>{try{return await runLogin(),!!await getAuthKey()||(console.error(`${_e.cross} Authentication failed. Please try again with: cmd login`),!1)}catch(e){return isUserCancellation(e)||(console.error(`${_e.cross} Login failed: ${getErrorMessage(e)}`),console.error("Please try again with: cmd login")),!1}},"attemptLogin");async function ensureAuthenticated(){try{return!!await getAuthKey()||BA()}catch(e){return console.error("Error checking authentication:",e),!1}}__name(ensureAuthenticated,"ensureAuthenticated");var UA=__name(e=>e&&!e.startsWith("-")?e:void 0,"parsePrompt"),zA=__name(async()=>{await ensureAuthenticated()||process.exit(1)},"requireAuth"),WA=__name(e=>{const t={};return e.trust&&(t.trust=!0),e.dangerouslySkipPermissions&&(t.dangerouslySkipPermissions=!0,t.trust=!0),e.skipOnboarding&&(t.skipOnboarding=!0),e.plan&&(t.plan=!0),e.permissionMode&&(t.permissionMode=e.permissionMode),t},"buildRuntimeOptions"),GA=__name(({options:e,runtimeOptions:t,initialPrompt:n})=>e.resume?{resume:e.resume,...t}:e.continue?{continue:!0,...t}:{...t,initialPrompt:n},"getInteractiveConfig"),HA=__name((e,t)=>"string"==typeof e.print&&e.print.trim()?e.print:t&&!t.startsWith("-")?t:"","extractPrintQuery");async function interactiveModeAction(e,t){if(t.addDir&&t.addDir.length>0)for(const e of t.addDir)addDirectory(e);if(void 0!==t.print){const n=HA(t,e);return void await printMode({query:n,dangerouslySkipPermissions:t.dangerouslySkipPermissions,maxTurns:t.maxTurns,verbose:t.verbose,model:t.model,benchmarkOutput:t.benchmarkOutput})}const n=UA(e);await zA();const r=WA(t),o=GA({options:t,runtimeOptions:r,initialPrompt:n});await jA(o)}__name(interactiveModeAction,"interactiveModeAction"),Ht(),Rn(),No(),Pr(),nk(),pk(),globalThis.COMMAND_CODE_CWD=process.cwd();var VA=__name(()=>process.cwd(),"getCwd"),QA=__name(()=>process.argv.slice(2),"getArgs"),KA=__name(e=>e.includes("--local")?"local":e.includes("--staging")?"staging":"production","getEnv"),YA=__name(()=>{const e=VA(),t=QA(),n=KA(t);dlog(`[Startup] cwd: ${e}`),dlog(`[Startup] args: ${t.join(" ")}`),dlog(`[Startup] env: ${n}`),dlog(`[Startup] traceId: ${getTraceId()??"unavailable"}`)},"logStartupInfo");async function preRun(){YA(),process.argv.includes("--ide-setup")&&(formatSetupResult(await runIDESetup()).forEach(e=>console.log(e)),process.exit(0)),await maybeRunPendingUpdate(),await migrateDeprecatedModel(),await getAuthKey()&&detectAndTrackFirstInstall().catch(()=>{}),checkForUpdateAsync(),setTimeout(()=>ensureExtensionInstalled().catch(()=>{}),100)}__name(preRun,"preRun"),Ht(),Yt(),Rn(),Kr(),Yb(),Fr();var JA=getPackageJson(),XA=__name((e,t=[])=>[...t,e],"collectAddDir");function displayCustomHelp(){const e=JA.version,t=getInvokedCommandName(),n=zb.filter(e=>!("/provider"===e.key&&!isInternalTeamFlagEnforced()));console.log(),console.log(ue.bold("Command Code")+ue.gray(` v${e}`)),console.log(ue.gray(qb)),console.log(),console.log(ue.bold("Usage")),console.log(` ${t} <command> [options]`),console.log(),console.log(ue.bold("Options"));for(const e of Ub){const n=e.key.replace(/^cmd/,t);console.log(" "+n.padEnd(jb)+ue.gray(e.description))}console.log(),console.log(ue.bold("Commands"));for(const e of Wb){const n=e.key.replace(/^cmd/,t);console.log(" "+n.padEnd(jb)+ue.gray(e.description))}console.log(),console.log(ue.bold("Slash Commands"));for(const e of n)console.log(" "+e.key.padEnd(jb)+ue.gray(e.description));console.log(),console.log(ue.bold("Keyboard Shortcuts"));for(const e of Bb)console.log(" "+e.key.padEnd(jb)+ue.gray(e.description));console.log(),console.log(ue.bold("Examples"));for(const e of Hb){const n=e.key.replace(/^cmd/,t);console.log(" "+n.padEnd(jb)+ue.gray(e.description))}console.log(),console.log(ue.cyan("❯")+" "+ue.gray(Vb.replace(/cmd/,t))),console.log(),console.log(ue.bold("Links"));for(const e of Gb)console.log(" "+e.key.padEnd(jb)+ue.cyan(e.description));console.log()}function createProgram(){const e=new ke;return e.name(getInvokedCommandName()).description("Command Code with your coding taste.").version(JA.version,"-v, --version","display the version number").argument("[prompt]","Your prompt to run in interactive mode").option("-r, --resume [name]","Resume a session by name, or pick from history").option("-c, --continue"," Continue the most recent session in the current directory").option("-t, --trust","Trust the project (skip initial trust permission prompt)").addOption(new Te("--dangerously-skip-permissions","Bypass all permission prompts (use with caution)").hideHelp()).addOption(new Te("--yolo","Bypass all permission prompts (alias for --dangerously-skip-permissions)").implies({dangerouslySkipPermissions:!0})).option("--plan","Start in plan mode (read-only exploration and planning)").addOption(new Te("--auto-accept","Start in auto-accept mode").implies({permissionMode:"auto-accept"})).addOption(new Te("--permission-mode <mode>","Set permission mode").choices(["standard","plan","auto-accept"])).option("--skip-onboarding","Skip taste onboarding (for non-interactive/automated runs)").option("-p, --print [query]","Run in non-interactive mode, output response and exit").option("--max-turns <number>","Maximum conversation turns in print mode (default: 10)",e=>{const t=parseInt(e,10);if(isNaN(t)||t<1)throw new Error("--max-turns must be a positive integer");return t}).option("--verbose","Stream tool execution progress to stderr in print mode").option("--ide-setup","Setup extension to fetch IDE context").option("--add-dir <directory>","Add directory to workspace context",XA,[]).addOption(new Te("--model <model>","Override model for this run").hideHelp()).addOption(new Te("--benchmark-output <path>","Path to write benchmark metrics JSON").hideHelp()).addOption(new Te("--experimental","Enable experimental features").hideHelp()).addOption(new Te(Et).hideHelp()).addOption(new Te(Ct).hideHelp()).addOption(new Te("-d, --debug","Enable debug mode").hideHelp()).addOption(new Te("--local","Use local server").hideHelp()).addOption(new Te("--staging","Use staging server").hideHelp()).helpOption("-h, --help","Display help message").allowUnknownOption(),e.configureHelp({formatHelp:__name(()=>(displayCustomHelp(),""),"formatHelp")}),e}function setupCommanderHooks(e){e.hook("preAction",(e,t)=>{dlogSection("cmd");const n=t.name(),r=t.parent?.name();dlog(`[cmd] ${r&&r!==n?"subcommand":"running"}: ${n}`);const o=t.opts(),s=Object.entries(o).filter(([,e])=>void 0!==e&&!1!==e).map(([e,t])=>!0===t?`--${e}`:`--${e}=${t}`).join(" ");s&&dlog(`[cmd] options: ${s}`);const i=t.args;i.length>0&&dlog(`[cmd] arguments: ${i.join(" ")}`)}),e.hook("postAction",()=>{dlogSection("Done")})}function isTTY(){return Boolean(process.stdout.isTTY&&process.stdin.isTTY&&!process.env.CI)}__name(displayCustomHelp,"displayCustomHelp"),__name(createProgram,"createProgram"),__name(setupCommanderHooks,"setupCommanderHooks"),Ht(),No(),no(),Dv(),gk(),av(),Kr(),pk(),Ht(),__name(isTTY,"isTTY");var ZA=!1;function setupTelemetry(){initTelemetry()&&(startSession(),trackSystemInfo(),trackCliSessionExistsEvent(),registerCleanupHandlers())}async function trackSystemInfo(){try{const e=process.version,t=y.platform(),n=y.arch();let r,o,s,i;try{const e=await getAuthenticatedEntity();e.success&&(r=e.user?.userName,o=e.user?.id,s=e.org?.login,i=e.org?.id)}catch{}if(!o)try{const e=await loadCredentials();o=e?.userId}catch{}systemInfo({userName:r,userId:o,orgLogin:s,orgId:i,nodeVersion:e,platform:t,arch:n})}catch{}}function registerCleanupHandlers(){process.on("beforeExit",async()=>{await shutdownTelemetry()}),process.on("exit",()=>{shutdownTelemetrySync()}),process.on("SIGINT",handleShutdownSignal),process.on("SIGTERM",handleShutdownSignal)}function handleShutdownSignal(){ZA||(ZA=!0,shutdownTelemetry().finally(()=>{process.exit(0)}))}async function trackCliSessionExistsEvent(){try{if(!await getAuthKey())return;const e=getSessionId();if(!e)return;const t=getPackageJson().version||"unknown",n=y.platform(),r=y.arch(),o=isTTY()?"interactive":"non-interactive";await trackLifecycleEvent({eventType:"cli_session_exists",metadata:{sessionId:e,cliVersion:t,mode:o,os:`${n}-${r}`}})}catch{}}async function openGitHubIssue(e){const t=buildGitHubIssueUrl(e),n=xe("Opening GitHub issues...").start();try{await ge(t,{wait:!1,background:!0}),n.succeed(`Opened ${createOSC8Link(t,"GitHub issue")} in your browser`),console.log("")}catch(e){n.fail("Failed to open browser"),console.log(""),console.log(createOSC8Link(t,"Open GitHub issue manually")),console.log("")}}__name(setupTelemetry,"setupTelemetry"),__name(trackSystemInfo,"trackSystemInfo"),__name(registerCleanupHandlers,"registerCleanupHandlers"),__name(handleShutdownSignal,"handleShutdownSignal"),__name(trackCliSessionExistsEvent,"trackCliSessionExistsEvent"),pk(),Ht(),Lr(),__name(openGitHubIssue,"openGitHubIssue");var eP=new ke("feedback").description("Open GitHub issues to share feedback or report bugs").argument("[title]","Optional issue title").action(openGitHubIssue);Ht();var tP=new ke("help").description("Display help information").allowUnknownOption().allowExcessArguments().action(function(){this.parent?.help()});async function runInfo(e){const{waitUntilExit:t}=ae(K.createElement(OT,{verbose:e.verbose,text:e.text}));await t()}Ht(),Ht(),__name(runInfo,"runInfo");var nP=new ke("info").description("Display system information").option("--verbose","Show detailed CPU and network information").option("--text","Print plain text without colors").allowUnknownOption().allowExcessArguments().action(async e=>{await runInfo(e)});function runLearnTaste(){const{unmount:e}=ae(K.createElement(TA,{onComplete:__name(()=>{e(),process.exit(0)},"onComplete"),onError:__name(()=>{e(),process.exit(1)},"onError")}))}Ht(),Yt(),Ht(),__name(runLearnTaste,"runLearnTaste"),Rn(),No();var rP=new ke(Mt.LEARN_TASTE).description("Learn from your previous sessions - updates your taste profile").allowUnknownOption().allowExcessArguments().action(async()=>{try{runLearnTaste()}catch(e){trackError({error:sanitizeErrorForTelemetry({error:e instanceof Error?e:new Error(String(e)),label:"learn_taste_render_failed"}),context:{component:To.LEARN_TASTE_COMMAND,heading:"Learn taste render failed"}}),dlog(`[/learn-taste] render failed: ${e instanceof Error?e.message:String(e)}`),await shutdownTelemetry(),process.exit(1)}});function addMcpCommand(){const e=new ke("add");return e.description("Add an MCP server").argument("<name>","Server name (unique identifier)").argument("[url]","Server URL (required for http transport)").option("-t, --transport <type>","Transport type (stdio or http)","stdio").addOption(new Te("-s, --scope <scope>","Configuration scope").choices(["local","project","user"]).default("local")).option("-e, --env <KEY=value>","Environment variable (repeatable)",collectKeyValue,{}).option("-H, --header <header>","HTTP header (repeatable, http only)",collectHeaders,{}).allowUnknownOption().allowExcessArguments().action(async(e,t,n,r)=>{const o=getInvokedCommandName();try{let s;/^[a-zA-Z0-9][a-zA-Z0-9_-]*$/.test(e)&&!e.includes("__")||(console.error(ue.red(`Error: Invalid server name '${e}'`)),console.error(ue.gray("Names must start with a letter or number, contain only letters, numbers, hyphens, and single underscores")),process.exit(1)),"stdio"!==n.transport&&"http"!==n.transport&&(console.error(ue.red(`Error: Invalid transport type '${n.transport}'`)),console.error(ue.gray("Valid options: stdio, http")),process.exit(1));let i=!1;if("http"===n.transport){t||(console.error(ue.red("Error: URL is required for http transport")),console.error(ue.gray("Usage: cmd mcp add --transport http <name> <url>")),process.exit(1));try{new URL(t)}catch{console.error(ue.red(`Error: Invalid URL '${t}'`)),process.exit(1)}s={transport:"http",enabled:!0,url:t,...Object.keys(n.header).length>0&&{headers:n.header},...Object.keys(n.env).length>0&&{env:n.env}},console.log(ue.gray("Checking server authentication requirements..."));const r=await checkServerAuthRequirements(t);if(r.error&&console.log(ue.yellow(`Warning: ${r.error}`)),r.requiresAuth&&r.metadata){console.log(ue.cyan("Server requires OAuth authentication."));let t,n="command-code";if(r.metadata.registrationEndpoint){console.log(ue.gray("Registering OAuth client..."));const e=await registerOAuthClient({registrationEndpoint:r.metadata.registrationEndpoint,clientName:"Command Code CLI",redirectUris:[`http://127.0.0.1:${fE}/callback`]});e&&(n=e.clientId,t=e.clientSecret)}s.oauth={authorizationUrl:r.metadata.authorizationEndpoint,tokenUrl:r.metadata.tokenEndpoint,clientId:n,clientSecret:t,scopes:r.metadata.scopes},console.log(ue.gray("A browser window will open for authentication.\n"));const o=await performOAuthFlow(e,{authorizationUrl:r.metadata.authorizationEndpoint,tokenUrl:r.metadata.tokenEndpoint,clientId:n,clientSecret:t,scopes:r.metadata.scopes},{onStatus:__name(e=>{console.log(ue.gray(` ${e}`))},"onStatus")});o.success?console.log(ue.green("✓ Successfully authenticated")):(i=!0,console.log(ue.yellow(`Warning: Authentication failed: ${o.error}`)),console.log(ue.gray("You can retry with: cmd mcp auth "+e)),console.log(ue.gray("Or authenticate via the /mcp menu in a session")))}}else{const o=r.args,i=process.argv.indexOf("--");let a,l=[];if(-1!==i){const e=process.argv.slice(i+1);0===e.length&&(console.error(ue.red("Error: Command is required for stdio transport")),console.error(ue.gray("Usage: cmd mcp add --transport stdio <name> -- <command> [args...]")),process.exit(1)),a=e[0],l=e.slice(1)}else if(t){a=t;const n=o.indexOf(e);-1!==n&&o.length>n+2&&(l=o.slice(n+2))}else console.error(ue.red("Error: Command is required for stdio transport")),console.error(ue.gray("Usage: cmd mcp add --transport stdio <name> -- <command> [args...]")),console.error(ue.gray(" or: cmd mcp add <name> <command> [args...]")),process.exit(1);s={transport:"stdio",enabled:!0,command:a,...l.length>0&&{args:l},...Object.keys(n.env).length>0&&{env:n.env}}}await addMcpServer({name:e,serverConfig:s,scope:n.scope});const a="user"===n.scope?"global":"project"===n.scope?"project":"local";if(i?console.log(ue.yellow(`✓ Added MCP server '${e}' to ${a} config (authentication pending)`)):console.log(ue.green(`✓ Added MCP server '${e}' to ${a} config`)),"http"===s.transport)console.log(ue.gray(` URL: ${s.url}`));else{const e=[s.command,...s.args||[]].join(" ");console.log(ue.gray(` Command: ${e}`))}console.log(""),console.log(ue.cyan("Next steps:")),console.log(ue.gray(`Start ${o} and run /mcp to manage configured MCP servers.`))}catch(e){console.error(ue.red(`Error: ${e instanceof Error?e.message:String(e)}`)),process.exit(1)}}),e}function collectKeyValue(e,t){const[n,...r]=e.split("=");return n&&0!==r.length||(console.error(ue.red(`Error: Invalid format '${e}', expected KEY=value`)),process.exit(1)),t[n]=r.join("="),t}function collectHeaders(e,t){const n=e.indexOf(":");-1===n&&(console.error(ue.red(`Error: Invalid header format '${e}', expected 'Header: value'`)),process.exit(1));const r=e.substring(0,n).trim(),o=e.substring(n+1).trim();return r||(console.error(ue.red(`Error: Empty header name in '${e}'`)),process.exit(1)),t[r]=o,t}function listMcpCommand(){const e=new ke("list");return e.description("List configured MCP servers").action(async()=>{try{const e=await listMcpServers();if(0===e.length)return console.log(ue.yellow("\nNo MCP servers configured\n")),console.log(ue.gray("Add a server with:")),console.log(ue.gray(" cmd mcp add --transport http <name> <url>")),console.log(ue.gray(" cmd mcp add --transport stdio <name> -- <command>")),void console.log(ue.gray("\nDocs: https://commandcode.ai/docs/mcp"));console.log(ue.hex("#E4CCFF").bold("\nMCP Servers\n"));const t=Math.max(4,...e.map(e=>e.name.length)),n=5,r=7;console.log(ue.dim(` ${"NAME".padEnd(t)} ${"TYPE".padEnd(n)} ${"SCOPE".padEnd(r)} AUTH STATUS`));for(const o of e){const e=o.config.enabled?ue.green("enabled"):ue.gray("disabled");let s;s=o.config.oauth?await hasTokens(o.name)?ue.green(_e.tick):ue.red(_e.cross):o.config.headers||o.config.env?ue.green(_e.tick):ue.gray("-"),console.log(` ${ue.white(o.name.padEnd(t))} ${ue.cyan(o.config.transport.padEnd(n))} ${ue.gray(o.scope.padEnd(r))} ${s} ${e}`)}console.log(ue.dim(`\nTotal: ${e.length} server${1!==e.length?"s":""}\n`))}catch(e){console.error(ue.red(`Error: ${e instanceof Error?e.message:String(e)}`)),process.exit(1)}}),e}function getMcpCommand(){const e=new ke("get");return e.description("Show details for an MCP server").argument("<name>","Server name").action(async e=>{try{const t=await getMcpServer({name:e});t||(console.error(ue.red(`Error: MCP server '${e}' not found`)),process.exit(1));const{config:n,scope:r}=t;if(console.log(ue.hex("#E4CCFF").bold(`\nMCP Server: ${e}\n`)),console.log(` ${ue.dim("Scope:")} ${r}`),console.log(` ${ue.dim("Transport:")} ${n.transport}`),console.log(` ${ue.dim("Status:")} ${n.enabled?ue.green("enabled"):ue.gray("disabled")}`),"http"===n.transport){if(console.log(` ${ue.dim("URL:")} ${n.url}`),n.headers&&Object.keys(n.headers).length>0){console.log(` ${ue.dim("Headers:")}`);for(const[e,t]of Object.entries(n.headers)){const n=e.toLowerCase().includes("auth")||e.toLowerCase().includes("token")||e.toLowerCase().includes("key")?"***":t;console.log(` ${e}: ${n}`)}}}else console.log(` ${ue.dim("Command:")} ${n.command}`),n.args&&n.args.length>0&&console.log(` ${ue.dim("Args:")} ${n.args.join(" ")}`);if(n.env&&Object.keys(n.env).length>0){console.log(` ${ue.dim("Environment:")}`);for(const[e,t]of Object.entries(n.env)){const n=e.toLowerCase().includes("key")||e.toLowerCase().includes("secret")||e.toLowerCase().includes("token")||e.toLowerCase().includes("password")?"***":t;console.log(` ${e}=${n}`)}}console.log("")}catch(e){console.error(ue.red(`Error: ${e instanceof Error?e.message:String(e)}`)),process.exit(1)}}),e}function removeMcpCommand(){const e=new ke("remove");return e.description("Remove an MCP server").argument("<name>","Server name").addOption(new Te("-s, --scope <scope>","Scope to remove from (auto-detects if not specified)").choices(["local","project","user"])).action(async(e,t)=>{try{const n=await getMcpServer({name:e});n||(console.error(ue.red(`Error: MCP server '${e}' not found`)),process.exit(1));const r=t.scope||n.scope;t.scope&&t.scope!==n.scope&&(console.error(ue.red(`Error: Server '${e}' is defined in '${n.scope}' scope, not '${t.scope}'`)),process.exit(1)),await removeMcpServer({name:e,scope:r})||(console.error(ue.red(`Error: Failed to remove server '${e}'`)),process.exit(1));const o="user"===r?"global":"project"===r?"project":"local";console.log(ue.green(`✓ Removed MCP server '${e}' from ${o} config`))}catch(e){console.error(ue.red(`Error: ${e instanceof Error?e.message:String(e)}`)),process.exit(1)}}),e}function addJsonMcpCommand(){const e=new ke("add-json");return e.description("Add an MCP server from JSON configuration").argument("<name>","Server name (unique identifier)").argument("<json>","Server configuration as JSON string").addOption(new Te("-s, --scope <scope>","Configuration scope").choices(["local","project","user"]).default("local")).option("--client-secret <secret>","OAuth client secret (injected into oauth config)").action(async(e,t,n)=>{const r=getInvokedCommandName();try{let o,s;/^[a-zA-Z0-9][a-zA-Z0-9_-]*$/.test(e)&&!e.includes("__")||(console.error(ue.red(`Error: Invalid server name '${e}'`)),console.error(ue.gray("Names must start with a letter or number, contain only letters, numbers, hyphens, and single underscores")),process.exit(1));try{o=JSON.parse(t)}catch{console.error(ue.red("Error: Invalid JSON")),console.error(ue.gray("Make sure to quote the JSON string properly")),console.error(ue.gray(`Example: ${r} mcp add-json github '{"type":"stdio","command":"npx"}'`)),process.exit(1)}o&&"object"==typeof o&&"type"in o&&!("transport"in o)&&(o.transport=o.type,delete o.type),o?.oauth?.callbackPort&&(s=o.oauth.callbackPort,delete o.oauth.callbackPort),n.clientSecret&&o?.oauth&&(o.oauth.clientSecret=n.clientSecret);const i=sE.safeParse(o);if(!i.success){console.error(ue.red("Error: Invalid server configuration"));for(const e of i.error.issues)console.error(ue.gray(` ${e.path.join(".")}: ${e.message}`));process.exit(1)}const a=i.data;let l=!1;if("http"!==a.transport||a.url||(console.error(ue.red("Error: URL is required for http type")),process.exit(1)),"stdio"!==a.transport||a.command||(console.error(ue.red("Error: Command is required for stdio type")),process.exit(1)),await addMcpServer({name:e,serverConfig:a,scope:n.scope}),a.oauth){console.log(ue.cyan("Starting OAuth authentication...")),console.log(ue.gray("A browser window will open for authentication.\n"));const t={authorizationUrl:a.oauth.authorizationUrl,tokenUrl:a.oauth.tokenUrl,clientId:a.oauth.clientId,clientSecret:a.oauth.clientSecret,scopes:a.oauth.scopes},n=await performOAuthFlow(e,t,{...s&&{port:s},onStatus:__name(e=>{console.log(ue.gray(` ${e}`))},"onStatus")});n.success?console.log(ue.green(`\n✓ Successfully authenticated with '${e}'`)):(l=!0,console.error(ue.yellow(`\nWarning: Authentication failed: ${n.error}`)),console.error(ue.gray(`You can retry with: ${r} mcp auth ${e}`)),console.error(ue.gray("Or authenticate via the /mcp menu in a session")))}const u="user"===n.scope?"global":"project"===n.scope?"project":"local";if(l?console.log(ue.yellow(`✓ Added MCP server '${e}' to ${u} config (authentication pending)`)):console.log(ue.green(`✓ Added MCP server '${e}' to ${u} config`)),"http"===a.transport)console.log(ue.gray(` URL: ${a.url}`));else{const e=[a.command,...a.args||[]].join(" ");console.log(ue.gray(` Command: ${e}`))}console.log(""),console.log(ue.cyan("Next steps:")),console.log(ue.gray(`Start ${r} and run /mcp to manage configured MCP servers.`))}catch(e){console.error(ue.red(`Error: ${e instanceof Error?e.message:String(e)}`)),process.exit(1)}}),e}function authMcpCommand(){const e=new ke("auth");return e.description("Manage OAuth authentication for MCP servers").argument("[server]","Server name to authenticate").option("--status","Check authentication status").option("--clear","Clear stored authentication").option("--list","List servers with stored authentication").action(async(e,t)=>{const n=getInvokedCommandName();try{if(t.list){const e=await listServersWithTokens();if(0===e.length)return void console.log(ue.yellow("No servers with stored authentication."));console.log(ue.hex("#E4CCFF").bold("\nAuthenticated MCP Servers\n"));for(const t of e){const e=await getTokens(t),n=!e||isTokenExpired(e)?ue.yellow("expired"):ue.green("valid");console.log(` ${t}: ${n}`)}return void console.log("")}if(e||(console.error(ue.red("Error: Server name is required")),console.error(ue.gray(`Usage: ${n} mcp auth <server>`)),console.error(ue.gray(` ${n} mcp auth --list`)),process.exit(1)),t.status){if(!await hasTokens(e))return void console.log(ue.yellow(`No authentication stored for '${e}'`));const t=await getTokens(e);if(!t)return void console.log(ue.yellow(`No authentication stored for '${e}'`));if(isTokenExpired(t))console.log(ue.yellow(`Authentication for '${e}' has expired`)),t.refreshToken&&console.log(ue.gray(" A refresh token is available for re-authentication"));else{if(console.log(ue.green(`Authentication for '${e}' is valid`)),t.expiresAt){const e=Math.round((t.expiresAt-Date.now())/1e3/60);console.log(ue.gray(` Expires in ${e} minutes`))}t.scope&&console.log(ue.gray(` Scopes: ${t.scope}`))}return}if(t.clear)return void(await deleteTokens(e)?console.log(ue.green(`✓ Cleared authentication for '${e}'`)):console.log(ue.yellow(`No authentication stored for '${e}'`)));const r=await getMcpServer({name:e});r||(console.error(ue.red(`Error: MCP server '${e}' not found`)),console.error(ue.gray(`Use "${n} mcp list" to see configured servers`)),process.exit(1)),r.config.oauth||(console.error(ue.red(`Error: Server '${e}' does not have OAuth configured`)),console.error(ue.gray(`Add OAuth config using "${n} mcp add-json" with oauth field`)),process.exit(1));const o={authorizationUrl:r.config.oauth.authorizationUrl,tokenUrl:r.config.oauth.tokenUrl,clientId:r.config.oauth.clientId,clientSecret:r.config.oauth.clientSecret,scopes:r.config.oauth.scopes};console.log(ue.cyan(`Authenticating with '${e}'...`)),console.log(ue.gray("A browser window will open for authentication.\n"));const s=await performOAuthFlow(e,o,{onStatus:__name(e=>{console.log(ue.gray(` ${e}`))},"onStatus")});if(s.success)return console.log(ue.green(`\n✓ Successfully authenticated with '${e}'`)),void console.log(ue.gray("Restart the session to connect with the authenticated server."));console.error(ue.red(`\nError: Authentication failed: ${s.error}`)),console.log(ue.gray(`Try again with "${n} mcp auth ${e}"`)),process.exit(1)}catch(e){console.error(ue.red(`Error: ${e instanceof Error?e.message:String(e)}`)),process.exit(1)}}),e}function createMcpCommand(){const e=new ke("mcp");return e.description("Manage MCP (Model Context Protocol) servers").allowUnknownOption().allowExcessArguments(),e.addCommand(addMcpCommand()),e.addCommand(listMcpCommand()),e.addCommand(getMcpCommand()),e.addCommand(removeMcpCommand()),e.addCommand(addJsonMcpCommand()),e.addCommand(authMcpCommand()),e}async function runCommand(e){return new Promise((t,n)=>{const r=$(e.cmd,e.args,{stdio:["ignore","pipe","pipe"],env:process.env});let o="",s="";r.stdout.on("data",e=>{o+=String(e)}),r.stderr.on("data",e=>{s+=String(e)}),r.on("error",n),r.on("close",r=>{0!==r?n(new Error(`${e.cmd} ${e.args.join(" ")} failed${s?`: ${s.trim()}`:""}`)):t({stdout:o,stderr:s})})})}async function detectDefaultBranch(e){try{const{stdout:t}=await runCommand({cmd:"git",args:["-C",e.repoDir,"symbolic-ref","refs/remotes/origin/HEAD","--short"]}),n=t.trim().replace(/^origin\//,"");if(n)return n}catch{}for(const t of["main","master"])try{return await runCommand({cmd:"git",args:["-C",e.repoDir,"rev-parse","--verify",t]}),t}catch{}try{const{stdout:t}=await runCommand({cmd:"git",args:["-C",e.repoDir,"rev-parse","--abbrev-ref","HEAD"]});return t.trim()}catch{return"main"}}async function findGitRoot4(e){try{const{stdout:t}=await runCommand({cmd:"git",args:["-C",e.dir,"rev-parse","--show-toplevel"]});return t.trim()}catch{return null}}async function countLearnings(e){try{return(await D.readFile(e,"utf-8")).split("\n").filter(e=>e.trim().startsWith("- ")&&e.includes("Confidence:")).length}catch{return 0}}async function resolveSource(t){const n=t.source.trim(),r=e.resolve(n);try{if(!(await D.stat(r)).isDirectory())throw new Error(`Source must be a repository directory: ${n}`);return{type:"local",displayName:r,repoDir:r,repoName:e.basename(r),github:await inferGitHubRepo({repoDir:r})}}catch(e){if(e instanceof Error&&e.message.startsWith("Source must be"))throw e}const o=parseGitHubSource({source:n});if(!o){const e=n.startsWith("git@")?" SSH URLs are not supported. Use HTTPS or owner/repo instead.":"";throw new Error(`Unsupported source '${n}'.${e} Use a local path, GitHub HTTPS URL, or owner/repo.`)}const s=String(t.maxCommits??200),i=`https://github.com/${o.owner}/${o.repo}.git`,a=await D.mkdtemp(e.join(y.tmpdir(),"taste-learn-"));try{await runCommand({cmd:"git",args:["clone","--depth",s,"--single-branch",...t.branch?["--branch",t.branch]:[],"--",i,a]})}catch{throw await D.rm(a,{recursive:!0,force:!0}).catch(()=>{}),new Error(`Repository not found: ${o.owner}/${o.repo}. Check the owner and repo name, or verify it's a public repository.`)}return{type:"github",displayName:`${o.owner}/${o.repo}`,repoDir:a,repoName:o.repo,github:o,cleanup:__name(async()=>{await D.rm(a,{recursive:!0,force:!0})},"cleanup")}}function getTastePathForDir(t){return e.join(t.projectRoot,".commandcode","taste")}async function resolveDisplayName(t){if(t.startsWith("/")||t.startsWith(".")){const n=e.resolve(t),r=await findGitRoot4({dir:n});return r?e.basename(r):e.basename(n)}return t}function parseGitHubSource(e){const t=e.source.match(/^([\w.-]+)\/([\w.-]+)$/);if(t)return{owner:t[1],repo:t[2].replace(/\.git$/,"")};try{const t=new URL(e.source);if("github.com"!==t.hostname)return null;const n=t.pathname.split("/").filter(Boolean);return n.length<2?null:{owner:n[0],repo:n[1].replace(/\.git$/,"")}}catch{return null}}async function inferGitHubRepo(e){try{const{stdout:t}=await runCommand({cmd:"git",args:["-C",e.repoDir,"remote","get-url","origin"]});return parseGitHubSource({source:t.trim()})??void 0}catch{return}}async function feedToLearningAgent(e){const t=await getConfiguredProvider(),n=await getOAuthCredentials({provider:t});if(await isOAuthEnforced()&&!n?.token)throw new Error("Authentication required. Run: cmd login");n?.token&&validateOAuthToken({token:n.token,provider:t});const r=getApiBaseUrl(),o=new Ly({baseUrl:r}),s=new pv({request:o,sessionId:crypto.randomUUID(),projectRoot:e.outputDir}),i=[{role:"user",content:e.compiledContext}];await s.checkAndProcess({messages:i})}function logLearnSummary(e){const{summary:t}=e;console.log(ue.cyan("\n ─── Results ───\n")),console.log(` Source: ${t.sourceName}`),console.log(` Signals: ${t.signalCount} extracted`),console.log(` Context: ${t.contextLength} chars compiled`),console.log(` Taste dir: ${t.tasteDir}`),console.log("")}function shouldContinueExtraction(e){return!(e.offset>=e.commitsLength||e.signalCount>=e.signalCap||e.commitsWithDiffs>=50)}async function extractAllSignals(e){e.onProgress?.("Collecting commits");const t=await collectCommits(e);if(0===t.length)return e.onProgress?.("No commits found"),{signals:[],commitCount:0};e.onProgress?.(`Found ${t.length} commits to analyze`);const n=e.maxSignals??50,r=[];let o=0;for(let s=0;shouldContinueExtraction({offset:s,commitsLength:t.length,signalCount:r.length,signalCap:n,commitsWithDiffs:o});s+=10){const i=t.slice(s,s+10);if(0===i.length)break;const a=await runBounded(5,i,async t=>({commit:t,subs:await getSubstitutions(e.repoDir,t.hash)}));for(const{commit:e,subs:t}of a){if(0===t.length)continue;o++;const s=groupCrossFilePatterns(t);for(const t of s.slice(0,5)){if(t.removed.length>200||t.added.length>200)continue;const o=[`Commit: ${e.subject}`];o.push(`File: ${t.file}`),t.context&&o.push(`In: ${t.context}`);const s=buildSnippet(t.codeBefore,t.added,t.codeAfter);if(s&&o.push(s),r.push({text:`${truncate2(t.removed,60)} → ${truncate2(t.added,60)}`,evidence:o,category:inferCategory(t.removed,t.added)}),r.length>=n)break}if(r.length>=n)break}}return e.onProgress?.(`Extracted ${r.length} diff signals from ${o} commits`),{signals:r,commitCount:t.length}}async function collectCommits(e){const t=buildAuthorPattern(e.author,e.authorAliases),n=t?.includes("|")??!1,r=t?[...n?["--extended-regexp"]:[],"--author",t,"--regexp-ignore-case"]:[],o=e.branch?[e.branch]:[],s=e.author?e.maxCommits:3*e.maxCommits,{stdout:i}=await runCommand({cmd:"git",args:["-C",e.repoDir,"log",...o,"--no-merges",...r,"--pretty=format:%H%x1f%aI%x1f%aN%x1f%s%x1e","-n",String(s)]});return i.split("").map(e=>e.trim()).filter(Boolean).map(e=>{const[t="",n="",r="",o=""]=e.split("");return{hash:t.trim(),subject:o.trim(),authorDate:n.trim(),authorName:r.trim()}}).filter(e=>!isDependencyBot(e.authorName,e.subject)).slice(0,e.maxCommits)}async function getSubstitutions(e,t){try{const{stdout:n}=await runCommand({cmd:"git",args:["-C",e,"show","--format=","-U3","--diff-algorithm=histogram","-b","--ignore-blank-lines","-M",t]}),r=[];let o="",s="",i=[],a=[],l=[];const u=2;let d=null;const m=__name(()=>{d&&(r.push({removed:d.removed,added:d.added,file:d.file,context:d.context,codeBefore:d.codeBefore.length>0?d.codeBefore:void 0,codeAfter:d.codeAfter.length>0?d.codeAfter:void 0}),d=null)},"commitPending"),g=__name(()=>{if(i.length>0&&a.length>0){const e=i.join("\n").trim(),t=a.join("\n").trim();e===t||isVersionBump(e,t)||isTrivialChange(e,t)||(m(),d={removed:e,added:t,file:o,context:s||void 0,codeBefore:[...l],codeAfter:[]})}i=[],a=[]},"flush");for(const e of n.split("\n")){if(e.startsWith("diff --git")){g(),m(),o=e.match(/b\/(.+)$/)?.[1]??"",s="",l=[],isNoiseFile(o)&&(o="");continue}if(e.startsWith("@@")){g(),m(),s=e.match(/@@ .+ @@\s*(.+)/)?.[1]?.trim()??"",l=[];continue}if(!o)continue;if(e.startsWith("-")&&!e.startsWith("---")){a.length>0&&g(),i.push(e.slice(1));continue}if(e.startsWith("+")&&!e.startsWith("+++")){a.push(e.slice(1));continue}g();const t=e.startsWith(" ")?e.slice(1):e;if(!t.trim())continue;const n=d;null!==n&&n.codeAfter.length<u&&(n.codeAfter.push(t),n.codeAfter.length>=u&&m()),l.push(t),l.length>u&&l.shift()}return g(),m(),r}catch(e){return process.env.DEBUG&&console.error(`[taste-learn] getSubstitutions failed for ${t}:`,e instanceof Error?e.message:e),[]}}function groupCrossFilePatterns(e){const t=new Map;for(const n of e){const e=`${n.removed.trim()}\0${n.added.trim()}`,r=t.get(e)??[];r.push(n),t.set(e,r)}const n=[];for(const[,e]of t)if(e.length>=2){const t=e.map(e=>e.file).join(", ");n.push({...e[0],file:t,context:`Same change across ${e.length} files`})}else n.push(e[0]);return n}Ht(),Ht(),__name(addMcpCommand,"addMcpCommand"),__name(collectKeyValue,"collectKeyValue"),__name(collectHeaders,"collectHeaders"),Ht(),__name(listMcpCommand,"listMcpCommand"),Ht(),__name(getMcpCommand,"getMcpCommand"),Ht(),__name(removeMcpCommand,"removeMcpCommand"),Ht(),__name(addJsonMcpCommand,"addJsonMcpCommand"),Ht(),__name(authMcpCommand,"authMcpCommand"),__name(createMcpCommand,"createMcpCommand"),Ht(),Yt(),Ht(),Iv(),Ht(),Yt(),Ht(),__name(runCommand,"runCommand"),Ht(),__name(detectDefaultBranch,"detectDefaultBranch"),__name(findGitRoot4,"findGitRoot"),__name(countLearnings,"countLearnings"),__name(resolveSource,"resolveSource"),__name(getTastePathForDir,"getTastePathForDir"),__name(resolveDisplayName,"resolveDisplayName"),__name(parseGitHubSource,"parseGitHubSource"),__name(inferGitHubRepo,"inferGitHubRepo"),Ht(),Sv(),Xy(),iw(),Pr(),qr(),__name(feedToLearningAgent,"feedToLearningAgent"),__name(logLearnSummary,"logLearnSummary"),Ht(),dv(),Ht(),__name(shouldContinueExtraction,"shouldContinueExtraction"),__name(extractAllSignals,"extractAllSignals"),__name(collectCommits,"collectCommits"),__name(getSubstitutions,"getSubstitutions"),__name(groupCrossFilePatterns,"groupCrossFilePatterns");var oP=5,sP=3;function buildSnippet(e,t,n){const r=e??[],o=n??[],s=t.split("\n").map(e=>e.trimEnd());if(0===s.length&&0===r.length&&0===o.length)return;let i,a=0;s.length>sP?(i=s.slice(0,sP-1),a=s.length-i.length):i=s;const l=i.length+(a>0?1:0),u=Math.max(0,oP-l),d=Math.min(r.length,Math.ceil(u/2)),m=Math.min(o.length,u-d),g=[];for(const e of r.slice(-d))g.push(` ${e.trimEnd()}`);for(const e of i)g.push(`→ ${e}`);a>0&&g.push(`→ ... (+${a} more changed ${1===a?"line":"lines"})`);for(const e of o.slice(0,m))g.push(` ${e.trimEnd()}`);return 0!==g.length?`Snippet:\n${g.join("\n")}`:void 0}__name(buildSnippet,"buildSnippet");var iP=[/package-lock\.json$/,/pnpm-lock\.yaml$/,/yarn\.lock$/,/CHANGELOG\.(md|yml|yaml)$/i,/\.versionbot\//,/\.min\.(js|css)$/,/dist\//,/\.map$/];function isNoiseFile(e){return iP.some(t=>t.test(e))}function isTrivialChange(e,t){return e.trim().length<3&&t.trim().length<3}function isVersionBump(e,t){const n=/^"?version"?\s*:\s*"?\d+\.\d+/;return n.test(e.trim())&&n.test(t.trim())}function inferCategory(e,t){const n=`${e} ${t}`.toLowerCase();return/import|require|from\s+['"]/.test(n)?"imports":/function|=>|async|return/.test(n)?"code-style":/class|interface|type\s+/.test(n)?"types":/test|describe|it\(|expect/.test(n)?"testing":/console|log|debug|error/.test(n)?"logging":/try|catch|throw|Error/.test(n)?"error-handling":"code-style"}function buildAuthorPattern(e,t){return t&&t.length>0?t.map(e=>e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")).join("|"):e??void 0}__name(isNoiseFile,"isNoiseFile"),__name(isTrivialChange,"isTrivialChange"),__name(isVersionBump,"isVersionBump"),__name(inferCategory,"inferCategory"),__name(buildAuthorPattern,"buildAuthorPattern");var aP=new Set(["renovate[bot]","renovate","dependabot[bot]","dependabot","greenkeeper[bot]","snyk-bot"]),lP=[/^update .+ digest to /i,/^update .+ action to /i,/^update .+ to v?\d/i,/^update lock file maintenance/i,/^update dependency .+ to /i,/^chore\(deps\)/i,/^bump .+ from .+ to /i,/^lock file maintenance/i];function isDependencyBot(e,t){const n=e.toLowerCase();return!!aP.has(n)||!(!n.includes("[bot]")||!lP.some(e=>e.test(t)))}function truncate2(e,t){const n=e.replace(/\n/g," ").trim();return n.length<=t?n:`${n.slice(0,t-3)}...`}async function runBounded(e,t,n){const r=[];let o=0;const s=__name(async()=>{for(;o<t.length;){const e=o++;r[e]=await n(t[e])}},"next");return await Promise.all(Array.from({length:Math.min(e,t.length)},()=>s())),r}function compileTasteContext(e){const{signals:t,repoName:n,author:r,commitCount:o}=e,s=r?`Target author: ${r}\n`:"",i=[];if(i.push(`# Dynamic Taste Analysis — Code Change Patterns\n\nRepository: ${n}\n${s}Commits analyzed: ${o}\nSignals extracted: ${t.length}\n\nThis analysis was generated by examining actual code changes (diffs, substitutions, refactoring patterns) rather than static file contents. Every signal below comes from real commits.`),t.length>0){const e=["## Correction Diffs — What Wrong→Right Looks Like"];for(const n of t.slice(0,50)){e.push(`\n**${n.text}**`);for(const t of n.evidence)e.push(`- ${t}`)}i.push(e.join("\n"))}const a=r?` for ${r}`:"";return i.push(`## Instructions for Taste Learning\n\nYou are analyzing code change patterns from a real repository${a}. Based on the correction diffs above, generate deeply personal and opinionated coding taste.\n\n**Critical guidelines:**\n\n1. **Be specific, not generic.** Instead of "Use TypeScript", write "Use branded types for IDs and explicit return types on every function. Prefer \`readonly\` arrays and objects by default."\n\n2. **Extract the WHY from patterns.** If you see verbose names being replaced with concise ones, don't just say "use short names" — say "Prefer concise variable names that derive meaning from context rather than encoding type information."\n\n3. **Look for recurring themes.** If multiple substitutions show the same pattern (e.g., nested if→guard clauses), that's a strong taste signal worth capturing.\n\n4. **Make it actionable.** Every taste entry should be specific enough that another developer could follow it and produce code that looks like it belongs in this repository.\n\n5. **Prioritize quality corrections** — these are the purest taste signals (wrong→right pairs with explicit WHY context from commit messages).\n\n6. **Capture anti-patterns too.** If you see code being removed in refactors, note what the developer avoids: "Never nest deeper than 2 levels — flatten with early returns."\n\n7. **Don't repeat generic tool preferences** like "Use pnpm" or "Use TypeScript" unless the substitutions show something specific about HOW they use those tools.\n\n8. **Prioritize opinionated preferences.** The goal is taste that makes someone's code distinctly theirs — not industry best practices.\n\nWrite the taste entries to the taste.md file using the standard format with confidence scores.`),i.join("\n\n")}async function runLearnPipeline(t){const n=__name(()=>({outputDir:"",tasteDir:"",sourceName:t.source,signalCount:0,contextLength:0}),"abortedResult");if(t.needsAuth){cv.addEvent({type:"auth_required",step:"auth",message:"Login to synthesize your taste profile",label:"Signing in"});try{await cv.waitForAuth()}catch{return cv.emitStepStart({step:"complete",label:"Login skipped",message:"Login skipped",learningCount:0,storage:""}),cv.markLearningComplete(),{summary:n()}}}t.isLocalSource||cv.emitStepStart({step:"cloning",label:"Cloning repository",message:`Cloning ${t.source}`});const r=await resolveSource({source:t.source,maxCommits:t.maxCommits});if(t.signal.aborted)return{summary:n(),resolved:r};const o="github"===r.type,s=r.repoName,i=await findGitRoot4({dir:r.repoDir});if(!i)throw new Error(`Not a git repository: ${r.repoDir}. Run inside a git repo or pass the path: npx taste learn /path/to/repo`);const a=o?e.resolve(process.cwd(),s):i;o&&cv.emitStepStart({step:"collecting",label:"Collecting commits",message:`Cloned ${r.displayName} → ${a}`});const l=t.branch??await detectDefaultBranch({repoDir:i});await D.mkdir(a,{recursive:!0}),cv.emitStepStart({step:"collecting",label:"Collecting commits",message:`Fetching up to ${t.maxCommits} commits from ${l}`});const{signals:u,commitCount:d}=await extractAllSignals({repoDir:i,maxCommits:t.maxCommits,maxSignals:t.maxSignals,branch:l,onProgress:__name(e=>{cv.emitProgress({step:"extracting",message:e})},"onProgress")});if(t.signal.aborted)return{summary:n(),resolved:r};if(0===u.length)throw new Error("No signals extracted. Check the repository has commit history.");cv.emitStepStart({step:"extracting",label:"Extracting taste signals",message:`${u.length} before/after code changes extracted`}),cv.emitStepStart({step:"compiling",label:"Compiling taste context",message:`Formatting ${u.length} signals for the learning agent`});const m=compileTasteContext({signals:u,repoName:s,commitCount:d});if(t.signal.aborted)return{summary:n(),resolved:r};cv.emitStepStart({step:"learning",label:"Learning taste",message:"Interpreting code change patterns with AI"}),await feedToLearningAgent({compiledContext:m,outputDir:a});const g=getTastePathForDir({projectRoot:a}),h=e.join(g,"taste.md"),f=await countLearnings(h);return cv.emitStepStart({step:"complete",label:"Taste learned",message:"Taste learned",learningCount:f,storage:h}),cv.markLearningComplete(),{summary:{outputDir:a,tasteDir:g,sourceName:r.displayName,signalCount:u.length,contextLength:m.length},resolved:r}}__name(isDependencyBot,"isDependencyBot"),__name(truncate2,"truncate"),__name(runBounded,"runBounded"),Ht(),__name(compileTasteContext,"compileTasteContext"),__name(runLearnPipeline,"runLearnPipeline"),Ht(),Ht(),dv(),Ht();var cP=[/MallocStackLogging: can't turn off malloc stack logging because it was not enabled/i];function shouldIgnoreChunk(e){return cP.some(t=>t.test(e))}function chunkToString(e){return"string"==typeof e?e:Buffer.isBuffer(e)?e.toString("utf-8"):""}async function withFilteredStderrNoise(e){const t=process.stderr.write.bind(process.stderr);process.stderr.write=(e,...n)=>{const r=chunkToString(e);return!(!r||!shouldIgnoreChunk(r))||("function"==typeof n[0]?t(e,n[0]):t(e,n[0],n[1]))};try{return await e()}finally{process.stderr.write=t}}function toRepoLearnErrorMessage(e){return e instanceof Error?e.message:String(e)}function isRepoLearnMetricLikeText(e){const t=e.trim().toLowerCase();return/^\d+\s/.test(t)||/^saved\s/.test(t)||/^output\s/.test(t)||/^target\s/.test(t)||/\bcandidates\b/.test(t)||/\bevidence records\b/.test(t)||/\bhistory and review signals\b/.test(t)}function truncateRepoLearnPanelText(e,t=12){return truncateString({text:e,maxChars:Math.min(96,getEffectiveWidth({padding:t}))})}__name(shouldIgnoreChunk,"shouldIgnoreChunk"),__name(chunkToString,"chunkToString"),__name(withFilteredStderrNoise,"withFilteredStderrNoise"),Ht(),vo(),__name(toRepoLearnErrorMessage,"toRepoLearnErrorMessage"),__name(isRepoLearnMetricLikeText,"isRepoLearnMetricLikeText"),__name(truncateRepoLearnPanelText,"truncateRepoLearnPanelText"),Ht(),dv(),Ht();var uP=[{id:"collecting",label:"Collecting commits from repository"},{id:"extracting",label:"Extracting taste signals from diffs"},{id:"compiling",label:"Compiling taste context"},{id:"learning",label:"Learning taste from change patterns"},{id:"complete",label:"Taste learned"}],dP=[{id:"cloning",label:"Cloning repository"},...uP],mP=[_e.bullet,_e.squareSmallFilled,_e.lozenge,_e.star,_e.triangleRight,_e.triangleUp];function createInitialRepoLearnSteps(e){return(e??uP).map(e=>({...e,status:"pending"}))}__name(createInitialRepoLearnSteps,"createInitialRepoLearnSteps"),Ht(),dv();var pP={learningCount:0,storage:"",topLearnings:[]};function getStepStatus(e,t){return e<t?"complete":e===t?"active":"pending"}function deriveStepStates(e,t){return e.map((e,n)=>({...e,status:getStepStatus(n,t)}))}function parseSummaryMetric(e){if(e.startsWith("Maintainer: "))return{maintainerLabel:e.replace(/^Maintainer:\s+/,"")};const t=e.match(/^(\d+)\s+maintainer-specific preferences$/);if(t)return{maintainerCount:Number(t[1])};const n=e.match(/^(\d+)\s+repository conventions$/);return n?{repoCount:Number(n[1])}:null}__name(getStepStatus,"getStepStatus"),__name(deriveStepStates,"deriveStepStates"),__name(parseSummaryMetric,"parseSummaryMetric");var gP=__name(e=>e.map(e=>({...e,status:"complete"})),"markAllStepsComplete"),hP=__name(e=>e??pP,"withBase");function useRepoLearnState(e){const t=e??uP,[n,r]=J(()=>createInitialRepoLearnSteps(t)),[o,s]=J(""),[i,a]=J([]),[l,u]=J(null),[d,m]=J(!1),[g,h]=J(!1),[f,y]=J(null),[w,S]=J(0),E=X(null),[C,v]=J(null),k=te(()=>{E.current=Date.now()},[]);return Z(()=>{const e=__name(()=>{r(createInitialRepoLearnSteps(t)),s(""),a([]),u(null),h(!1),y(null),S(0),E.current=null,v(null),m(!1)},"handleReset"),n=__name(e=>{if("error"===e.type)return y(e.message),h(!0),r(gP),void s("");if("auth_required"!==e.type){if("step_start"===e.type&&e.step){const n=t.findIndex(t=>t.id===e.step);return n>=0&&r(deriveStepStates(t,n)),s(e.message||e.label||""),void("complete"===e.step&&u(t=>{const n=hP(t);return{...n,learningCount:e.learningCount??n.learningCount,storage:e.storage??n.storage}}))}"progress"!==e.type||"complete"!==e.step?"progress"!==e.type?"insight"===e.type&&(isRepoLearnMetricLikeText(e.message)||("complete"!==e.step?(S(e=>e+1),a(t=>[...t,e.message].slice(-4))):u(t=>{const n=hP(t);return{...n,topLearnings:[...n.topLearnings,e.message].slice(0,3)}}))):s(e.message):u(t=>{const n=hP(t),r=parseSummaryMetric(e.message);return r?{...n,...r}:n})}else m(!0)},"handleEvent"),o=__name(()=>{h(e=>e||(r(gP),!0)),s(""),E.current&&v(Math.round((Date.now()-E.current)/1e3))},"handleComplete");return cv.on("reset",e),cv.on("new-event",n),cv.on("learning-complete",o),()=>{cv.off("reset",e),cv.off("new-event",n),cv.off("learning-complete",o)}},[t]),{steps:n,currentMessage:o,insights:i,insightCount:w,summary:l,done:g,error:f,showLogin:d,setShowLogin:m,elapsedSeconds:C,markStarted:k}}__name(useRepoLearnState,"useRepoLearnState"),Ht(),Ht(),hr();var fP=__name(({isComplete:e,hasError:t})=>K.createElement(ne,{flexDirection:"column",marginTop:1,marginBottom:0},K.createElement(uA,null),K.createElement(ne,{marginTop:0},K.createElement(re,{color:zn.DIM},mA),K.createElement(ne,{marginLeft:2},t?K.createElement(re,{color:zn.DIM},"learning interrupted"):e?K.createElement(re,{color:Gn.TEXT},"learned your coding taste"):K.createElement(pA,null)))),"RepoLearnTastePill");Ht(),hr();var yP=__name(({status:e})=>"active"===e?K.createElement(ne,null,K.createElement(re,{color:zn.YELLOW},K.createElement(qe,{type:"dots"})),K.createElement(re,null," ")):"complete"===e?K.createElement(re,{color:Kn.BG},_e.square," "):K.createElement(re,{color:zn.DIM},_e.circle," "),"StepStatusIndicator"),wP=__name(({steps:e,currentMessage:t})=>K.createElement(ne,{flexDirection:"column",marginTop:1},e.map(e=>{const n="active"===e.status;return K.createElement(ne,{key:e.id,flexDirection:"column",marginBottom:0,marginLeft:3},K.createElement(ne,null,K.createElement(ne,{marginRight:1},K.createElement(yP,{status:e.status})),K.createElement(re,{bold:n,color:"complete"===e.status?zn.WHITE:n?zn.YELLOW:zn.DIM},e.label)),n&&t?K.createElement(ne,{marginLeft:3},K.createElement(re,{color:zn.DIM},truncateRepoLearnPanelText(t))):null)})),"RepoLearnStepList");Ht(),hr();var SP=__name(({insights:e,insightCount:t})=>0===e.length?null:K.createElement(ne,{flexDirection:"column",marginTop:1,marginLeft:4},K.createElement(re,{color:zn.CYAN},t>0?`Recent signals · ${t} ${1===t?"preference":"preferences"} learned`:"Recent signals"),e.map((e,t)=>K.createElement(re,{key:`${t}-${e}`,color:zn.DIM},mP[t%mP.length]," ",truncateRepoLearnPanelText(e,14)))),"RepoLearnRollingInsights");Ht(),hr();var bP=__name(({message:e})=>K.createElement(ne,{flexDirection:"column",borderStyle:"single",borderColor:zn.RED,paddingX:2,paddingY:1,marginTop:1},K.createElement(re,{color:zn.RED,bold:!0},"Oops, something went wrong:"),K.createElement(ne,{marginTop:1},K.createElement(re,null,e))),"RepoLearnErrorPanel");Ht(),hr(),Ir();var EP=__name(({summary:e,elapsedSeconds:n})=>{if(!e)return null;const r=t.relative(process.cwd(),e.storage),o=e.learningCount>0;return K.createElement(ne,{flexDirection:"column",marginLeft:3},K.createElement(ne,{marginBottom:1,flexDirection:"row"},K.createElement(re,{color:zn.DIM},mA),K.createElement(ne,{marginLeft:2},K.createElement(re,{color:Gn.TEXT},o?`Learned ${e.learningCount} ${1===e.learningCount?"preference":"preferences"}`:"Taste profile initialized",n?` in ${n} ${1===n?"second":"seconds"}`:""))),K.createElement(ne,{flexDirection:"column",marginLeft:1},K.createElement(ne,null,K.createElement(re,{color:zn.DIM},_e.pointerSmall," Taste stored in"," "),K.createElement(xr,{url:`file://${e.storage}`,text:r||".commandcode/taste/taste.md",color:zn.CYAN})),K.createElement(ne,null,K.createElement(re,{color:zn.DIM},_e.pointerSmall," Share your coding taste: ",K.createElement(re,{color:zn.CYAN},"npx taste push --all")))),K.createElement(ne,{marginTop:1,marginLeft:1},K.createElement(re,{color:zn.DIM},o?"Command Code automatically uses & updates taste files as you code.":"Command Code will learn your preferences as you code.")))},"RepoLearnCompletionSummary");Ht(),hr();var CP=__name(({done:e,error:t})=>t?K.createElement(ne,{marginTop:1},K.createElement(re,{bold:!0},"Press ESC to exit")):e?K.createElement(ne,{marginTop:1},K.createElement(re,{bold:!0},"Press ENTER to continue")):K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"ESC to cancel")),"RepoLearnFooter");Ht(),hr();var vP=__name(({text:e,repoName:t})=>{const n=useTerminalWidth(),r=ee(()=>b_(n),[n]);return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(__,null,r.trimEnd())),e?K.createElement(re,{color:zn.WHITE},e):K.createElement(K.Fragment,null,K.createElement(re,{color:zn.WHITE},"Learning your coding taste from ",K.createElement(re,{bold:!0,color:zn.CYAN},t??"repository")),K.createElement(re,{color:zn.DIM},"This may take a few minutes depending on repository size")))},"RepoLearnHeader");function StatusPanel({error:e,done:t,summary:n,elapsedSeconds:r,insights:o,insightCount:s}){return e?K.createElement(bP,{message:e}):t?K.createElement(EP,{summary:n,elapsedSeconds:r}):K.createElement(SP,{insights:o,insightCount:s})}function RepoLearnProgressApp({runTask:e,onExit:t,stepOrder:n,headerText:r,repoName:o}){const s=useRepoLearnState(n),i=X(!1);return Z(()=>{i.current||(i.current=!0,s.markStarted(),e().catch(()=>{}))},[e,s.markStarted]),ie((e,n)=>{if(s.showLogin)return;const r=n.escape||""===e,o=n.return||"\n"===e||"\r"===e;r?t({published:!1,cancelled:!0}):(s.done||s.error)&&o&&t({published:!1,cancelled:!!s.error})}),s.showLogin?K.createElement(ne,{flexDirection:"column"},K.createElement(vP,{text:r,repoName:o}),K.createElement(Lx,{onComplete:(e,t)=>{s.setShowLogin(!1),e?cv.resolveAuth():cv.rejectAuth(t)},onCancel:()=>{s.setShowLogin(!1),cv.rejectAuth("Login cancelled"),t({published:!1,cancelled:!0})}})):K.createElement(ne,{flexDirection:"column"},K.createElement(vP,{text:r,repoName:o}),K.createElement(fP,{isComplete:s.done&&!s.error,hasError:Boolean(s.error)}),K.createElement(wP,{steps:s.steps,currentMessage:s.currentMessage}),K.createElement(StatusPanel,{error:s.error,done:s.done,summary:s.summary,elapsedSeconds:s.elapsedSeconds,insights:s.insights,insightCount:s.insightCount}),K.createElement(CP,{done:s.done,error:s.error}))}async function runRepoLearnProgress(e){return withFilteredStderrNoise(()=>renderProgressUI(e))}function renderProgressUI(e){return new Promise((t,n)=>{cv.reset();const r=new AbortController;let o,s,i=!1,a=!1;const l=__name(async()=>{try{o=await e.runTask(r.signal)}catch(e){r.signal.aborted||(s=e,cv.addEvent({type:"error",message:toRepoLearnErrorMessage(e)}),cv.markLearningComplete())}},"handleRunTask"),u=__name(({published:e,cancelled:l})=>{a||(a=!0,i=e,r.abort(),d.unmount(),cv.reset(),s?n(s):t({result:o,published:i,cancelled:l}))},"handleExit"),d=ae(K.createElement(RepoLearnProgressApp,{stepOrder:e.stepOrder,headerText:e.headerText,repoName:e.repoName,runTask:l,onExit:u}));d.waitUntilExit().catch(e=>{cv.reset(),n(e)})})}__name(StatusPanel,"StatusPanel"),__name(RepoLearnProgressApp,"RepoLearnProgressApp"),__name(runRepoLearnProgress,"runRepoLearnProgress"),__name(renderProgressUI,"renderProgressUI"),pk();var kP=__name(e=>t=>{const n=parseInt(t,10);if(isNaN(n)||n<1)throw new Error(`${e} must be a positive integer`);return n},"parsePositiveInt");function createLearnCommand(){return new ke("learn").description("Learn coding taste from repository change history").argument("[source]","Local path, GitHub URL, or owner/repo (defaults to current directory)").option("--max-commits <number>","Maximum commits to analyze",kP("--max-commits"),200).addOption(new Te("--max-signals <number>","Maximum diff signals to extract").default(50).argParser(kP("--max-signals")).hideHelp()).option("--branch <name>","Branch to analyze (defaults to main/master)").action(async(e,t)=>{try{await learnTaste({source:e??".",maxCommits:t.maxCommits??200,maxSignals:t.maxSignals??50,branch:t.branch})}catch(e){const t=e instanceof Error?e.message:String(e);console.error(`Error: ${t}`),process.exit(1)}})}async function learnTaste(t){const n=await D.stat(e.resolve(t.source)).then(e=>e.isDirectory()).catch(()=>!1),r=isTTY(),o=await resolveDisplayName(t.source),s=!await getAuthKey();if(s&&!r)return console.log(""),console.log(" Login required to learn taste."),console.log(""),console.log(" Run: cmd login"),console.log(` Then: npx taste learn ${t.source}`),void console.log("");let i;const a=__name(()=>{i?.().finally(()=>process.exit(130))},"sigintHandler");process.once("SIGINT",a);let l=!1;try{const e=__name(async e=>{const{summary:r,resolved:o}=await runLearnPipeline({...t,isLocalSource:n,needsAuth:s,signal:e});return i=o?.cleanup,r},"runTask");if(r){const t=n?void 0:[...dP];({cancelled:l}=await runRepoLearnProgress({runTask:e,repoName:o,stepOrder:t}))}else logLearnSummary({summary:await e((new AbortController).signal)})}finally{process.off("SIGINT",a),i&&await i()}r&&!l||process.exit(0),xv(),await jA({skipOnboarding:!0})}function getTastePath(t){const{target:n}=t;if("local-project"===n)return e.join(process.cwd(),".commandcode","taste");if("local-global"===n)return e.join(y.homedir(),".commandcode","taste");throw new Error(`Remote storage not yet implemented: ${n}`)}function getRootTasteFile(t){const{target:n}=t;return e.join(getTastePath({target:n}),"taste.md")}function getCategoryPath(t){const{target:n,category:r}=t;return e.join(getTastePath({target:n}),r)}function getCategoryTasteFile(t){const{target:n,category:r}=t;return e.join(getCategoryPath({target:n,category:r}),"taste.md")}__name(createLearnCommand,"createLearnCommand"),__name(learnTaste,"learnTaste"),Ht(),Ht(),fw(),Ht(),Yt(),__name(getTastePath,"getTastePath"),__name(getRootTasteFile,"getRootTasteFile"),__name(getCategoryPath,"getCategoryPath"),__name(getCategoryTasteFile,"getCategoryTasteFile"),Ht(),Ht();var TP=/confidence:/i;function findLookaheadEnd(e,t){const n=e.slice(t),r=n.findIndex(e=>{const t=e.trim();return t.startsWith("#")||t.startsWith("-")||TP.test(t)});if(-1===r)return{endIdx:e.length,inclusive:!1};const o=n[r].trim();return{endIdx:t+r,inclusive:TP.test(o)&&!o.startsWith("#")&&!o.startsWith("-")}}function joinMultiLineLearning(e,t,n){const{endIdx:r,inclusive:o}=findLookaheadEnd(e,t),s=o?r+1:r;return{combined:[n,...e.slice(t,s).map(e=>e.trim()).filter(e=>e.length>0)].join(" "),nextIdx:s}}function processRawLine(e,t){const n=e[t],r=t+1,o=n.trim();if(!o.startsWith("-"))return{entry:{text:n,originalLineNum:r},nextIdx:t+1};if(TP.test(o))return{entry:{text:n,originalLineNum:r},nextIdx:t+1};const{combined:s,nextIdx:i}=joinMultiLineLearning(e,t+1,n);return{entry:{text:s,originalLineNum:r},nextIdx:i}}function preprocessLines(e){const t=[];let n=0;for(;n<e.length;){const{entry:r,nextIdx:o}=processRawLine(e,n);t.push(r),n=o}return t}function validateLearningLine(e){const{line:t,lineNum:n}=e,r=[],o=t.substring(1).trim();if(!TP.test(o))return r.push({line:n,severity:"error",message:'Learning is missing "Confidence:" field',suggestion:'Format: "- Learning text. Confidence: 0.95" (value between 0.0 and 1.0)'}),r;const s=Array.from(o.matchAll(/confidence:\s*(\S+)/gi)),i=s.length>0?s[s.length-1]:null;if(!i)return r.push({line:n,severity:"error",message:"Confidence field is present but has no value",suggestion:'Add a number after "Confidence:" (e.g., Confidence: 0.95)'}),r;const a=i[1],l=parseFloat(a);if(isNaN(l))return r.push({line:n,severity:"error",message:`Confidence value "${a}" is not a valid number`,suggestion:"Use a decimal number between 0.0 and 1.0 (e.g., 0.95)"}),r;(l<0||l>1)&&r.push({line:n,severity:"error",message:`Confidence value ${l} is out of range`,suggestion:"Confidence must be between 0.0 and 1.0"}),l>=0&&l<=1&&0===l&&r.push({line:n,severity:"warning",message:"Confidence is 0.0 - this learning may not be useful",suggestion:"Consider removing learnings with 0 confidence"});const u=void 0!==i.index?o.substring(0,i.index).trim():o.trim();return u&&0!==u.length?(u.length<3&&r.push({line:n,severity:"warning",message:"Learning text is very short",suggestion:"Provide more descriptive text for clarity"}),r):(r.push({line:n,severity:"error",message:'Learning has no text before "Confidence:"',suggestion:'Add descriptive text (e.g., "Use pnpm for package management")'}),r)}function hasReferenceAfterCategory(e){const{lines:t,categoryLineIndex:n}=e,r=t.slice(n+1,n+4),o=r.findIndex(e=>e.trim().startsWith("# "));return(-1===o?r:r.slice(0,o)).some(e=>e.includes("See [")&&e.includes("taste.md"))}function buildResult(e){const{issues:t,filePath:n}=e,r=t.filter(e=>"error"===e.severity),o=t.filter(e=>"warning"===e.severity),s=0===r.length;if(0===t.length)return{valid:s,issues:[...t],summary:`${_e.tick} ${n} is valid`};const i=[];r.length>0&&i.push(`${r.length} error${r.length>1?"s":""}`),o.length>0&&i.push(`${o.length} warning${o.length>1?"s":""}`);const a=r.length>0?_e.cross:_e.warning;return{valid:s,issues:[...t],summary:`${a} ${n} has ${i.join(", ")}`}}function formatSingleIssue(e,t){const n=[`${e.line?ue.dim(` Line ${e.line}: `):" "}${t(e.message)}`];return e.suggestion&&n.push(ue.dim(` → ${e.suggestion}`)),n}function formatIssueGroup(e,t,n){return 0===e.length?[]:[n,...e.flatMap(e=>formatSingleIssue(e,t)),""]}function formatValidationIssues(e){const{result:t,verbose:n=!0}=e;if(0===t.issues.length){const e=t.summary.charAt(0),n=t.summary.substring(2);return`${ue.green(e)} ${ue.dim(n)}`}if(!n)return t.summary;const r=t.issues.filter(e=>"error"===e.severity),o=t.issues.filter(e=>"warning"===e.severity);return[r.length>0?ue.red(t.summary):ue.yellow(t.summary),"",...formatIssueGroup(r,ue.red,ue.bold(ue.red("Errors:"))),...formatIssueGroup(o,ue.yellow,ue.bold(ue.yellow("Warnings:")))].join("\n").trim()}__name(findLookaheadEnd,"findLookaheadEnd"),__name(joinMultiLineLearning,"joinMultiLineLearning"),__name(processRawLine,"processRawLine"),__name(preprocessLines,"preprocessLines"),__name(validateLearningLine,"validateLearningLine"),__name(hasReferenceAfterCategory,"hasReferenceAfterCategory"),__name(buildResult,"buildResult"),Ht(),__name(formatSingleIssue,"formatSingleIssue"),__name(formatIssueGroup,"formatIssueGroup"),__name(formatValidationIssues,"formatValidationIssues");var _P=new Set(["# Taste (Continuously Learned by [CommandCode][cmd])","# Taste (Continuously Learned by CommandCode.ai)","# Taste (Continuously Learned by CommandCode)"]);function warnIfEmptyCategory(e,t){!e.currentCategory||e.learningsInCurrentCategory>0||hasReferenceAfterCategory({lines:t,categoryLineIndex:e.categoryLineNumber-1})||e.issues.push({line:e.categoryLineNumber,severity:"warning",message:`Category '${e.currentCategory}' has no learnings`,suggestion:"Add at least one learning or remove this category"})}function processHeading(e){const{line:t,lineNum:n,state:r,rawLines:o}=e;_P.has(t.trim())||(r.hasAnyCategory=!0,warnIfEmptyCategory(r,o),r.currentCategory=t.trim().substring(2).trim(),r.categoryLineNumber=n,r.learningsInCurrentCategory=0)}function processLearning(e){const{line:t,lineNum:n,state:r}=e;r.currentCategory?(r.learningsInCurrentCategory++,r.issues.push(...validateLearningLine({line:t.trim(),lineNum:n}))):r.issues.push({line:n,severity:"error",message:"Learning found outside of any category",suggestion:'Add a category header (e.g., "# cli") before this learning'})}__name(warnIfEmptyCategory,"warnIfEmptyCategory"),__name(processHeading,"processHeading"),__name(processLearning,"processLearning");var xP=/^see \[[^\]]+\/taste\.md\]\([^\)]+\/taste\.md\)$/i,AP=/^\[cmd\]: https:\/\/commandcode\.ai\/$/i;function processLine(e){const{line:t,lineNum:n,state:r,rawLines:o}=e,s=t.trim();s&&(s.startsWith("# ")?processHeading({line:t,lineNum:n,state:r,rawLines:o}):s.startsWith("-")?processLearning({line:t,lineNum:n,state:r}):xP.test(s)||AP.test(s)||r.issues.push({line:n,severity:"error",message:"Invalid content - must be a category header (# name) or learning (- text)",suggestion:"Remove this line or format it as a category (# name) or learning (- text. Confidence: 0.XX)"}))}function checkFinalCategory(e){const{state:t,rawLines:n}=e;!t.currentCategory||t.learningsInCurrentCategory>0||!t.categoryLineNumber||hasReferenceAfterCategory({lines:n,categoryLineIndex:t.categoryLineNumber-1})||t.issues.push({line:t.categoryLineNumber,severity:"warning",message:`Category '${t.currentCategory}' has no learnings`,suggestion:"Add at least one learning or remove this category"})}function validateTasteFile(e){const{content:t,filePath:n}=e,r=[];if(!t.trim())return r.push({severity:"error",message:"File is empty",suggestion:"Add at least one category with learnings"}),buildResult({issues:r,filePath:n});const o=t.split("\n"),s=preprocessLines(o),i={currentCategory:null,categoryLineNumber:null,learningsInCurrentCategory:0,hasAnyCategory:!1,issues:r};for(const{text:e,originalLineNum:t}of s)processLine({line:e,lineNum:t,state:i,rawLines:o});return checkFinalCategory({state:i,rawLines:o}),buildResult({issues:r,filePath:n})}__name(processLine,"processLine"),__name(checkFinalCategory,"checkFinalCategory"),__name(validateTasteFile,"validateTasteFile");var PP=__name(e=>"local-global"===e?"global":"project","locationLabel"),IP=__name(({file:e,error:t})=>({success:!1,filesLinted:[],errors:[{file:e,error:t}],totalErrors:0,totalWarnings:0}),"failResult");function resolvePackageFile(e,t){const n=getCategoryTasteFile({target:t,category:e});return v(n)?{result:{path:n,displayName:`${e}/taste.md`}}:{error:{file:e,error:`Taste package '${e}' not found in ${PP(t)}`}}}function collectSpecificFiles(e){const{packages:t,target:n}=e,r=t.map(e=>resolvePackageFile(e,n));return{files:r.filter(e=>"result"in e).map(e=>e.result),errors:r.filter(e=>"error"in e).map(e=>e.error)}}async function collectAllFiles(e){const{tastePath:t,target:n}=e,r=[],o=getRootTasteFile({target:n});v(o)&&r.push({path:o,displayName:"taste.md"});const s=(await D.readdir(t,{withFileTypes:!0})).filter(e=>e.isDirectory()).map(e=>({entry:e,categoryFile:getCategoryTasteFile({target:n,category:e.name})})).filter(({categoryFile:e})=>v(e)).map(({entry:e,categoryFile:t})=>({path:t,displayName:`${e.name}/taste.md`}));return r.push(...s),r}async function lintFile(e){let t=await D.readFile(e.path,"utf-8");const n=migrateHeader({content:t});n!==t&&(await D.writeFile(e.path,n,"utf-8"),t=n);const r=validateTasteFile({content:t,filePath:e.displayName}),o=r.issues.filter(e=>"error"===e.severity).length,s=r.issues.filter(e=>"warning"===e.severity).length,i=formatValidationIssues({result:r});return{file:e.displayName,valid:r.valid,errors:o,warnings:s,formatted:i}}async function lintSpecificPackages(e){const{packages:t,target:n}=e,{files:r,errors:o}=collectSpecificFiles({packages:t,target:n});if(0===r.length&&o.length>0)return{success:!1,filesLinted:[],errors:o,totalErrors:0,totalWarnings:0};if(0===r.length)return IP({file:"all",error:`No taste files found in ${PP(n)}`});const s=await Promise.all(r.map(lintFile)),i=s.reduce((e,t)=>e+t.errors,0),a=s.reduce((e,t)=>e+t.warnings,0);return{success:s.every(e=>e.valid)&&0===o.length,filesLinted:s,errors:o,totalErrors:i,totalWarnings:a}}async function lintAllFiles(e){const{tastePath:t,target:n}=e,r=await collectAllFiles({tastePath:t,target:n});if(0===r.length)return IP({file:"all",error:`No taste files found in ${PP(n)}`});const o=await Promise.all(r.map(lintFile)),s=o.reduce((e,t)=>e+t.errors,0),i=o.reduce((e,t)=>e+t.warnings,0);return{success:o.every(e=>e.valid),filesLinted:o,errors:[],totalErrors:s,totalWarnings:i}}async function lint(e){const{packages:t,target:n}=e,r=getTastePath({target:n});return v(r)?t.length>0?lintSpecificPackages({packages:t,target:n}):lintAllFiles({tastePath:r,target:n}):IP({file:"all",error:`No taste directory found in ${PP(n)}`})}function resolveConflictStrategy(e){const t=[e.skip&&"skip",e.merge&&"merge",e.overwrite&&"overwrite"].filter(Boolean);return t.length>1&&exitWithError(`Cannot combine --${t[0]} and --${t[1]}. Choose one conflict strategy.`),t[0]}__name(resolvePackageFile,"resolvePackageFile"),__name(collectSpecificFiles,"collectSpecificFiles"),__name(collectAllFiles,"collectAllFiles"),__name(lintFile,"lintFile"),__name(lintSpecificPackages,"lintSpecificPackages"),__name(lintAllFiles,"lintAllFiles"),__name(lint,"lint"),Ht(),No(),__name(resolveConflictStrategy,"resolveConflictStrategy");var NP=ue.bgGreen.black.bold(" TASTE ");function shortenPath(e){const t=process.env.HOME??process.env.USERPROFILE??"";return t&&e.startsWith(t)?`~${e.slice(t.length)}`:e}function exitWithError(e){console.error(`${ue.red("Error:")} ${e.replace(/^Error:\s*/i,"")}`),process.exit(1)}function formatUsageLine(e){const t=e.match(/^(\s*(?:Usage:|or:)?\s*)(cmd)(\s+.+?)(\s+\(.*\))?$/);return t?`${ue.dim(t[1])}${ue.green(t[2])}${ue.white(t[3]??"")}${t[4]?ue.dim(t[4]):""}`:ue.dim(e)}function exitWithUsage({message:e,usage:t}){console.error(`${ue.red("Error:")} ${e.replace(/^Error:\s*/i,"")}`);for(const e of t)console.error(formatUsageLine(e));process.exit(1)}function resolveRemoteDefault(e){return e.global||e.remote?e:{...e,remote:!0}}__name(shortenPath,"shortenPath"),__name(exitWithError,"exitWithError"),__name(formatUsageLine,"formatUsageLine"),__name(exitWithUsage,"exitWithUsage"),__name(resolveRemoteDefault,"resolveRemoteDefault");var RP=__name((e,t)=>t,"linkFallback");function getPackageLink({owner:e,packageName:t}){return ut(`commandcode.ai/${e}/${t}`,`https://commandcode.ai/${e}/${t}`,{fallback:RP})}function getProfileLink(e){return ut(`commandcode.ai/${e}`,`https://commandcode.ai/${e}`,{fallback:RP})}function wrapLine(e,t=0){const n=(process.stdout.columns||80)-t;return ct(e,n,{trim:!1})}function formatMergeParts(e){const t=[];return e.added>0&&t.push(`${e.added} ${1===e.added?"learning":"learnings"} added`),e.updated>0&&t.push(`${e.updated} ${1===e.updated?"learning":"learnings"} updated`),e.unchanged>0&&t.push(`${e.unchanged} ${1===e.unchanged?"learning":"learnings"} unchanged`),t}function hasMergeConflictRisk(e){return(e.added>0||e.updated>0)&&e.unchanged>0}function hasMergeConflictRiskInRecord(e){return Object.values(e).some(hasMergeConflictRisk)}function logMergeReviewTip(){console.log(ue.yellow("\nTip: Review merged learnings to ensure no conflicting rules."))}function parseOwnerPackage(e){if(!e.includes("/"))return;const[t,n]=e.split("/");return t&&n?{owner:t,packageName:n}:void 0}function handleResultErrors(e){for(const t of e){const e=t.error.replace(/^Taste package(?: '.*?')? /,`Taste package '${t.pkg}' `);console.error(`${ue.red("Error:")} ${e}`)}process.exit(1)}function getTimeAgo(e){const t=Date.now()-e.getTime(),n=Math.floor(t/6e4),r=Math.floor(t/36e5),o=Math.floor(t/864e5);return n<1?"just now":n<60?`${n} minute${n>1?"s":""} ago`:r<24?`${r} hour${r>1?"s":""} ago`:`${o} day${o>1?"s":""} ago`}async function flushAndExit(e){await Promise.race([shutdownTelemetry(),new Promise(e=>setTimeout(e,500))]).catch(()=>{}),process.exit(e)}function withErrorHandler(e){return async(...t)=>{try{await e(...t),await flushAndExit(0)}catch(e){const t=e instanceof Error?e.message:String(e);console.error(ue.red(`Error: ${t}`)),await flushAndExit(1)}}}function createLintCommand(){return new ke("lint").argument("[package]","Taste package name").option("-g, --global","Validate taste packages from global storage (~/.commandcode)").option("--all","Validate all taste packages").description(`Validate taste package format ${ue.dim("(structure, style, etc.)")}`).action(withErrorHandler(async(e,t)=>runLint({packageName:e,options:t})))}function validateLintOptions({packageName:e,options:t}){e||t.all||exitWithUsage({message:"Specify a taste package name or use --all to validate everything",usage:["cmd taste lint <package> validate a taste package","cmd taste lint --all validate all taste packages"]}),e&&t.all&&exitWithError("Use either a package name or --all, not both")}function logLintResults(e){for(const t of e.filesLinted)console.log(t.formatted);e.filesLinted.length>1&&logLintSummary(e),e.success||process.exit(1)}function logLintSummary({filesLinted:e,totalErrors:t,totalWarnings:n}){if(console.log(""),0===t&&0===n)return void console.log(`${ue.green(_e.tick)} All ${ue.green(e.length)} taste files are valid`);const r=[];t>0&&r.push(ue.red(`${t} error${t>1?"s":""}`)),n>0&&r.push(ue.yellow(`${n} warning${n>1?"s":""}`)),console.log(`Summary: ${r.join(", ")} across ${e.length} files`)}async function runLint({packageName:e,options:t}){console.log(""),validateLintOptions({packageName:e,options:t});const n=await lint({packages:e?[e]:[],target:t.global?"local-global":"local-project"});if(n.errors.length>0){for(const e of n.errors)console.error(ue.red(`Error: ${e.error}`));process.exit(1)}logLintResults(n)}function parseSection(e){const{section:t,sourcePath:n}=e,r=t.split("\n"),o=r[0].trim(),s=r.map(e=>parseLearning({line:e})).filter(e=>null!==e);return 0===s.length?null:{category:normalizeCategory({category:o}),learnings:s,sourcePath:n}}function parsePackages(e){const{content:t,sourcePath:n}=e;return t.split(/^# /gm).filter(e=>e.trim()).filter(e=>!e.includes("See [")).map(e=>parseSection({section:e,sourcePath:n})).filter(e=>null!==e)}function parseLearning(e){const{line:t}=e,n=t.match(/^-?\s*(.+?)[\.:,]?\s*confidence:\s*(\d*\.?\d+)/i);if(!n)return null;const r=parseFloat(n[2]);return isNaN(r)||r<0||r>1?null:{text:n[1].trim(),confidence:r}}function normalizeCategory(e){const{category:t}=e;return t.toLowerCase().replace(/\s+/g,"-")}function denormalizeCategory(e){const{slug:t}=e;return t.split("-").map(e=>e.charAt(0).toUpperCase()+e.slice(1)).join(" ")}function formatPackage(e){const{pkg:t}=e;let n=`# ${denormalizeCategory({slug:t.category})}\n`;for(const e of t.learnings)n+=`- ${e.text}. Confidence: ${e.confidence.toFixed(2)}\n`;return n}async function readAndMigrateFile(e){const{filePath:t}=e,n=await D.readFile(t,"utf-8"),r=migrateHeader({content:n});return r===n?n:(await D.writeFile(t,r,"utf-8"),r)}function trimTrailingBlanks(e){const{lines:t,until:n}=e;let r=e.from;for(;r>n&&""===t[r].trim();)r--;return r}function findCategoryRange(e){const{lines:t,pattern:n}=e,r=t.findIndex(e=>n.test(e));if(-1===r)return null;const o=t.findIndex((e,t)=>t>r&&e.startsWith("# "));if(-1===o)return{start:r,end:t.length-1};const s=trimTrailingBlanks({lines:t,from:o-1,until:r});return{start:r,end:s}}function ensureHeader(e){if(!e)return uw+"\n\n";const t=e.trim();return t.startsWith(lw)||t.startsWith(dw)||t.startsWith(mw)?e:uw+"\n\n"+e}function ensureTrailingNewlines(e){return e?e.endsWith("\n\n")?e:e.endsWith("\n")?e+"\n":e+"\n\n":e}__name(getPackageLink,"getPackageLink"),__name(getProfileLink,"getProfileLink"),__name(wrapLine,"wrapLine"),__name(formatMergeParts,"formatMergeParts"),__name(hasMergeConflictRisk,"hasMergeConflictRisk"),__name(hasMergeConflictRiskInRecord,"hasMergeConflictRiskInRecord"),__name(logMergeReviewTip,"logMergeReviewTip"),__name(parseOwnerPackage,"parseOwnerPackage"),__name(handleResultErrors,"handleResultErrors"),__name(getTimeAgo,"getTimeAgo"),__name(flushAndExit,"flushAndExit"),__name(withErrorHandler,"withErrorHandler"),__name(createLintCommand,"createLintCommand"),__name(validateLintOptions,"validateLintOptions"),__name(logLintResults,"logLintResults"),__name(logLintSummary,"logLintSummary"),__name(runLint,"runLint"),Ht(),zo(),Ht(),Ht(),Ht(),__name(parseSection,"parseSection"),__name(parsePackages,"parsePackages"),__name(parseLearning,"parseLearning"),__name(normalizeCategory,"normalizeCategory"),__name(denormalizeCategory,"denormalizeCategory"),Ht(),__name(formatPackage,"formatPackage"),Ht(),fw(),__name(readAndMigrateFile,"readAndMigrateFile"),__name(trimTrailingBlanks,"trimTrailingBlanks"),__name(findCategoryRange,"findCategoryRange"),__name(ensureHeader,"ensureHeader"),__name(ensureTrailingNewlines,"ensureTrailingNewlines");var MP="local-global";async function loadCategoryPackages(e){if(!e.isDirectory())return[];const t=getCategoryTasteFile({target:MP,category:e.name});return v(t)?parsePackages({content:await readAndMigrateFile({filePath:t}),sourcePath:t}).map(t=>({...t,category:e.name})):[]}async function getPackageInfo(e){try{const t=await D.stat(e.sourcePath);return{category:e.category,learningCount:e.learnings.length,lastUpdated:t.mtime,filePath:e.sourcePath}}catch{return{category:e.category,learningCount:e.learnings.length,lastUpdated:new Date,filePath:e.sourcePath}}}async function getAllPackages(){const e=getTastePath({target:MP});if(!v(e))return[];const t=await D.readdir(e,{withFileTypes:!0});return(await Promise.all(t.map(loadCategoryPackages))).flat()}async function getPackage(e){const{category:t}=e,n=getCategoryTasteFile({target:MP,category:t});return v(n)&&parsePackages({content:await readAndMigrateFile({filePath:n}),sourcePath:n})[0]||null}async function writePackage(t){const{pkg:n}=t,r=getTastePath({target:MP});await D.mkdir(r,{recursive:!0});const o=getCategoryTasteFile({target:MP,category:n.category}),s=e.dirname(o);await D.mkdir(s,{recursive:!0});const i=formatPackage({pkg:n});await D.writeFile(o,i,"utf-8")}async function listPackages(){const e=await getAllPackages();return await Promise.all(e.map(getPackageInfo))}__name(loadCategoryPackages,"loadCategoryPackages"),__name(getPackageInfo,"getPackageInfo"),__name(getAllPackages,"getAllPackages"),__name(getPackage,"getPackage"),__name(writePackage,"writePackage"),__name(listPackages,"listPackages"),Ht(),Ht(),fw();var $P="local-project";async function removeCategoryFromRoot(e){const{category:t,rootFile:n}=e;if(!v(n))return null;const r=migrateHeader({content:await D.readFile(n,"utf-8")}).split("\n"),o=findCategoryRange({lines:r,pattern:new RegExp(`^# ${t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}$`,"i")});if(!o)return null;const s=r.slice(0,o.start),i=o.end<r.length-1?r.slice(o.end+1):[],a={before:s.join("\n").trim(),after:i.join("\n").trim()},l=[...s,...i].join("\n").trim();return""===l&&await D.rm(n,{force:!0}),""!==l&&await D.writeFile(n,l+"\n","utf-8"),a}async function removePackage(t){const{category:n}=t,r=getRootTasteFile({target:$P}),o=await removeCategoryFromRoot({category:n,rootFile:r}),s=getCategoryTasteFile({target:$P,category:n}),i=e.dirname(s);return v(i)&&await D.rm(i,{recursive:!0,force:!0}),o}async function writeToRoot(e){const{pkg:t,rootFile:n,categoryPosition:r}=e,o=formatPackage({pkg:t});if(r){let e=ensureHeader(migrateHeader({content:r.before}));e=ensureTrailingNewlines(e);const t=r.after?"\n\n"+r.after:"";return e+=o.trim()+t,void await D.writeFile(n,e.trim()+"\n","utf-8")}let s="";v(n)&&(s=await D.readFile(n,"utf-8"),s=migrateHeader({content:s})),s=ensureHeader(s),s=ensureTrailingNewlines(s),s+=o,await D.writeFile(n,s.trim()+"\n","utf-8")}async function writeToSubdirectory(t){const{pkg:n,rootFile:r,categoryPosition:o}=t,s=getCategoryTasteFile({target:$P,category:n.category}),i=e.dirname(s);await D.mkdir(i,{recursive:!0});const a=formatPackage({pkg:n});await D.writeFile(s,a,"utf-8");const l=`# ${n.category}\nSee [${n.category}/taste.md](${n.category}/taste.md)\n`;if(o){let e=ensureHeader(migrateHeader({content:o.before}));e=ensureTrailingNewlines(e);const t=o.after?"\n\n"+o.after:"";return e+=l.trim()+t,void await D.writeFile(r,e.trim()+"\n","utf-8")}let u="";v(r)&&(u=await D.readFile(r,"utf-8"),u=migrateHeader({content:u})),u=ensureHeader(u),u=ensureTrailingNewlines(u),u+=l,await D.writeFile(r,u.trim()+"\n","utf-8")}__name(removeCategoryFromRoot,"removeCategoryFromRoot"),__name(removePackage,"removePackage"),__name(writeToRoot,"writeToRoot"),__name(writeToSubdirectory,"writeToSubdirectory");var LP="local-project";async function loadCategoryPackages2(e){if(!e.isDirectory())return[];const t=getCategoryTasteFile({target:LP,category:e.name});return v(t)?parsePackages({content:await readAndMigrateFile({filePath:t}),sourcePath:t}).map(t=>({...t,category:e.name})):[]}async function getAllPackages2(){const e=getTastePath({target:LP});if(!v(e))return[];const t=[],n=getRootTasteFile({target:LP});if(v(n)){const e=parsePackages({content:await readAndMigrateFile({filePath:n}),sourcePath:n});t.push(...e)}const r=await D.readdir(e,{withFileTypes:!0}),o=(await Promise.all(r.map(loadCategoryPackages2))).flat();return t.push(...o),t}async function getPackage2(e){const{category:t}=e;return(await getAllPackages2()).find(e=>e.category===t)||null}async function writePackage2(e){const{pkg:t}=e,n=getTastePath({target:LP});await D.mkdir(n,{recursive:!0});const r=getRootTasteFile({target:LP}),o=await removePackage({category:t.category});t.learnings.length<=5?await writeToRoot({pkg:t,rootFile:r,categoryPosition:o}):await writeToSubdirectory({pkg:t,rootFile:r,categoryPosition:o})}function exists2(){const e=getTastePath({target:LP});return v(e)}async function appendCategoryFile(e,t){const n=getCategoryTasteFile({target:"local-project",category:t.category});if(!v(n))return;const r=await D.readFile(n,"utf-8"),o=new Blob([r],{type:"text/markdown"}),s=new File([o],"taste.md",{type:"text/markdown"});e.append(`files[${t.category}/taste.md]`,s)}async function prepareUploadFormData(t){const{packageName:n,pkg:r,description:o,type:s="category",isPublic:i=!1,overwrite:a=!1}=t,l=new FormData;l.append("name",n),o&&l.append("description",o),l.append("type",s),l.append("isPublic",String(i)),l.append("overwrite",String(a));const u=formatPackage({pkg:r}),d=new Blob([u],{type:"text/markdown"}),m=new File([d],"taste.md",{type:"text/markdown"});if(l.append("files[taste.md]",m),"category"===s)return l;const g=getTastePath({target:"local-project"}),h=e.join(g,r.category);if(!v(h))return l;const f=getCategoryTasteFile({target:"local-project",category:r.category});if(!v(f))return l;const y=await D.readFile(f,"utf-8"),w=new Blob([y],{type:"text/markdown"}),S=new File([w],"taste.md",{type:"text/markdown"});return l.append(`files[${r.category}/taste.md]`,S),l}async function prepareMultiplePackagesUpload(e){const{pkgs:t,projectName:n,description:r,isPublic:o=!1,overwrite:s=!1}=e,i=new FormData;i.append("name",n),r&&i.append("description",r),i.append("type","project"),i.append("isPublic",String(o)),i.append("overwrite",String(s));const a=getRootTasteFile({target:"local-project"});if(v(a)){const e=await D.readFile(a,"utf-8"),t=new Blob([e],{type:"text/markdown"}),n=new File([t],"taste.md",{type:"text/markdown"});i.append("files[taste.md]",n)}const l=t.map(e=>appendCategoryFile(i,e));return await Promise.all(l),i}function parseLearningLine(e){const t=e.match(/^-\s+(.+?)\.\s+Confidence:\s+([\d.]+)/);if(!t)return null;const n=t[1].trim(),r=parseFloat(t[2]);return!n||isNaN(r)?null:{text:n,confidence:r}}function parseTasteContent(e){return e.split("\n").filter(e=>{const t=e.trim();return t&&!t.startsWith("#")&&t.startsWith("-")}).map(e=>parseLearningLine(e.trim())).filter(e=>null!==e)}async function parseApiError(e){const{response:t,fallback:n}=e;try{const e=await t.json();return e.error?.message||e.message||n}catch{return n}}function throwTrackedError(e){const{message:t,label:n,heading:r,status:o,extra:s}=e,i=new Error(t);throw trackError({error:sanitizeErrorForTelemetry({error:i,label:n}),context:{component:To.TASTE_REMOTE_STORAGE,heading:r,"http.status":o,...s}}),i}async function requireAuthKey(){const e=await getAuthKey();if(!e)throw new Error("No API key found. Please authenticate with: cmd login");return e}async function downloadPackage(e){const{owner:t,packageName:n}=e,r=getApiBaseUrl(),o=await tryPublicDownload({baseUrl:r,owner:t,packageName:n});if(o)return o;const s=await getAuthKey();if(!s)throw new Error("Package not found. If this is a private package, please authenticate with `cmd login`");return tryAuthenticatedDownload({baseUrl:r,owner:t,packageName:n,apiKey:s})}async function tryPublicDownload(e){const{baseUrl:t,owner:n,packageName:r}=e,o=`${t}${kt.INTERNAL.PROFILE.PACKAGE_DOWNLOAD.replace(":login",n).replace(":packageName",r)}`;let s;try{s=await fetch(o,{method:"GET"})}catch{return null}if(s.ok){const{data:e}=await s.json();return{type:e.type||"category",files:e.files||[],isPublic:!0}}if(404===s.status)return null;throwTrackedError({message:await parseApiError({response:s,fallback:`Failed to download taste package (${s.status})`}),label:"download_public_error",heading:"Failed to download taste package (public)",status:s.status})}async function tryAuthenticatedDownload(e){const{baseUrl:t,owner:n,packageName:r,apiKey:o}=e,s=`${t}${kt.BETA.TASTE.PACKAGES.DOWNLOAD.replace(":namespace",n).replace(":packageName",r)}`,i=await fetch(s,{method:"GET",headers:{Authorization:`Bearer ${o}`}});if(i.ok){const{data:e}=await i.json();return{type:e.type||"category",files:e.files||[],isPublic:e.isPublic??!1}}if(404===i.status)return null;throwTrackedError({message:await parseApiError({response:i,fallback:"Failed to download taste package"}),label:"download_auth_error",heading:"Failed to download taste package (authenticated)",status:i.status})}async function fetchSinglePackage(e){try{return await getPackage3({category:e.name})}catch(t){const n=t instanceof Error?t:new Error(String(t));return trackError({error:sanitizeErrorForTelemetry({error:n,label:"download_package_error"}),context:{component:To.TASTE_REMOTE_STORAGE,heading:"Failed to download package","package.name":e.name}}),console.warn(`Warning: Failed to download package '${e.name}': ${n.message}`),null}}async function getAllPackages3(){const e=await requireAuthKey(),t=`${getApiBaseUrl()}${kt.BETA.TASTE.PACKAGES.LIST}`,n=await fetch(t,{method:"GET",headers:{Authorization:`Bearer ${e}`}});n.ok||throwTrackedError({message:await parseApiError({response:n,fallback:"Failed to list taste packages"}),label:"list_packages_error",heading:"Failed to list taste packages",status:n.status});const{data:r}=await n.json(),o=r.packages||[];if(0===o.length)return[];const s=[];for(let e=0;e<o.length;e+=5){const t=o.slice(e,e+5),n=await Promise.all(t.map(fetchSinglePackage));s.push(...n.filter(e=>null!==e))}return s}async function getPackage3(e){const{category:t}=e;let n;await requireAuthKey();try{n=await getAuthenticatedEntity()}catch(e){const n=e instanceof Error?e:new Error(String(e));throw dlog(`[Auth] getPackage: entity endpoint unavailable — ${n.message}`),trackError({error:sanitizeErrorForTelemetry({error:n,label:"get_entity_error"}),context:{component:To.TASTE_REMOTE_STORAGE,heading:"getAuthenticatedEntity failed in getPackage"}}),new Error(`Could not resolve your account to fetch '${t}'. Check your connection and try again.`)}if(!n.success||!n.user?.userName)throw new Error("Failed to get authenticated user information");return downloadRemotePackage({owner:n.user.userName,packageName:t})}async function downloadRemotePackage(e){const{owner:t,packageName:n}=e,r=await downloadPackage({owner:t,packageName:n});if(!r)return null;const o=r.files||[];if(0===o.length)return null;const s=o.find(e=>"taste.md"===e.file);if(!s)throw new Error(`No taste.md file found in package '${n}'`);return{category:n,learnings:parseTasteContent(s.content),sourcePath:`remote:${n}`,isPublic:r.isPublic??!1}}async function writePackage3(e){const{pkg:t,owner:n,isPublic:r=!1,overwrite:o=!1}=e,s=await requireAuthKey(),i=await prepareUploadFormData({packageName:t.category,pkg:t,type:"category",isPublic:r,overwrite:o}),a=`${getApiBaseUrl()}${kt.BETA.TASTE.PACKAGES.UPLOAD.replace(":namespace",n)}`,l=await fetch(a,{method:"POST",headers:{Authorization:`Bearer ${s}`},body:i});l.ok||throwTrackedError({message:await parseApiError({response:l,fallback:"Failed to upload taste package"}),label:"upload_package_error",heading:"Failed to upload taste package",status:l.status}),await l.json()}async function writePackages(e){const{packages:t,projectName:n,owner:r,isPublic:o=!1,overwrite:s=!1}=e,i=await requireAuthKey(),a=await prepareMultiplePackagesUpload({pkgs:t,projectName:n,isPublic:o,overwrite:s}),l=`${getApiBaseUrl()}${kt.BETA.TASTE.PACKAGES.UPLOAD.replace(":namespace",r)}`,u=await fetch(l,{method:"POST",headers:{Authorization:`Bearer ${i}`},body:a});u.ok||throwTrackedError({message:await parseApiError({response:u,fallback:"Failed to upload taste packages"}),label:"upload_packages_error",heading:"Failed to upload taste packages",status:u.status,extra:{"package.count":t.length}}),await u.json()}async function listPackages2(){const e=await requireAuthKey(),t=`${getApiBaseUrl()}${kt.BETA.TASTE.PACKAGES.LIST}`,n=await fetch(t,{method:"GET",headers:{Authorization:`Bearer ${e}`}});n.ok||throwTrackedError({message:await parseApiError({response:n,fallback:"Failed to list taste packages"}),label:"list_packages_error",heading:"Failed to list packages",status:n.status});const{data:r}=await n.json();return(r.packages||[]).map(e=>({category:e.name,learningCount:e.learningCount||0,lastUpdated:e.createdAt?new Date(e.createdAt):new Date,filePath:"",isPublic:e.isPublic??!1,starCount:e.starCount??0,downloadCount:e.downloadCount??0,type:e.type??"category"}))}async function list(e){const{location:t}=e;if("local-global"===t)return listPackages();if("remote-project"===t||"remote-user"===t)return listPackages2();if("local-project"===t){const e=getRootTasteFile({target:"local-project"}),t=await getAllPackages2();return Promise.all(t.map(async t=>{let n;if(t.sourcePath!==e)try{n=(await D.stat(t.sourcePath)).mtime}catch{}return{category:t.category,learningCount:t.learnings.length,lastUpdated:n,filePath:t.sourcePath}}))}throw new Error(`Invalid location: ${t}`)}function createListCommand(){return new ke("list").alias("ls").option("-g, --global","List global packages").addOption(new Te("-l, --local","Use local server").hideHelp()).option("--remote","List remote packages").addOption(new Te("--staging","Use staging environment").hideHelp()).description(`List available packages ${ue.dim("(project, global, or remote)")}`).action(withErrorHandler(async e=>runList({options:e})))}__name(loadCategoryPackages2,"loadCategoryPackages"),__name(getAllPackages2,"getAllPackages"),__name(getPackage2,"getPackage"),__name(writePackage2,"writePackage"),__name(exists2,"exists"),Ht(),iw(),Ht(),__name(appendCategoryFile,"appendCategoryFile"),__name(prepareUploadFormData,"prepareUploadFormData"),__name(prepareMultiplePackagesUpload,"prepareMultiplePackagesUpload"),Yt(),Ht(),__name(parseLearningLine,"parseLearningLine"),__name(parseTasteContent,"parseTasteContent"),gk(),No(),Ht(),pk(),No(),__name(parseApiError,"parseApiError"),__name(throwTrackedError,"throwTrackedError"),__name(requireAuthKey,"requireAuthKey"),Ht(),iw(),pk(),Yt(),__name(downloadPackage,"downloadPackage"),__name(tryPublicDownload,"tryPublicDownload"),__name(tryAuthenticatedDownload,"tryAuthenticatedDownload"),Rn(),__name(fetchSinglePackage,"fetchSinglePackage"),__name(getAllPackages3,"getAllPackages"),__name(getPackage3,"getPackage"),__name(downloadRemotePackage,"downloadRemotePackage"),__name(writePackage3,"writePackage"),__name(writePackages,"writePackages"),__name(listPackages2,"listPackages"),__name(list,"list"),__name(createListCommand,"createListCommand");var DP={remote:{location:"remote-project",name:"remote",subtitle:"commandcode.ai account"},global:{location:"local-global",name:"global",subtitle:"~/.commandcode/taste"},project:{location:"local-project",name:"project",subtitle:".commandcode/taste"}};function resolveStorage(e){return e.remote?DP.remote:e.global?DP.global:DP.project}function getPackageDisplayLength(e){let t=e.category.length;return e.isPublic&&(t+=9),e.isPublic&&e.starCount&&(t+=` ${_e.star}${e.starCount}`.length),e.downloadCount&&(t+=` ${_e.arrowDown}${e.downloadCount}`.length),t}function formatPackageLine({pkg:e,maxLen:t}){const n=" ".repeat(t-getPackageDisplayLength(e)+2),r=e.lastUpdated?getTimeAgo(e.lastUpdated):null,o=r?`, updated ${r}`:"";return` ${ue.white(e.category)}${e.isPublic?ue.green(" [public]"):""}${e.isPublic&&e.starCount?ue.yellow(` ${_e.star}${e.starCount}`):""}${e.downloadCount?ue.gray(` ${_e.arrowDown}${e.downloadCount}`):""}${n}${ue.dim.gray(`(${e.learningCount} learnings${o})`)}`}function validateListOptions(e){e.global&&e.remote&&exitWithError("Error: Cannot specify both --global and --remote flags")}async function fetchPackages({options:e}){const t=resolveStorage(e),n=e.remote?xe(`Fetching ${t.name} packages`).start():null,r=await list({location:t.location});return n?.stop(),{packages:r,storage:t}}async function getStorageLabel({options:e,fallback:t}){if(!e.remote)return t;const n=await getUserName();return n?getProfileLink(n):t}function printPackageTable({packages:e,subtitle:t}){console.log(`\n${NP} Packages`),console.log(`${ue.gray("⎿")} ${ue.dim(t)}\n`);const n=Math.max(...e.map(getPackageDisplayLength));let r=0;for(const t of e)r+=t.learningCount,console.log(formatPackageLine({pkg:t,maxLen:n}));console.log(ue.dim(`\nTotal: ${e.length} packages, ${r} learnings\n`))}async function runList({options:e}){console.log(""),validateListOptions(e);const{packages:t,storage:n}=await fetchPackages({options:e});0!==t.length?printPackageTable({packages:t,subtitle:await getStorageLabel({options:e,fallback:n.subtitle})}):console.log(ue.yellow(`No taste packages found in ${n.name}`))}async function fetchAllPackages(e){const{target:t}=e;return"local-project"===t?getAllPackages2():"local-global"===t?getAllPackages():getAllPackages3()}function handleOpenError(e){return e instanceof Error&&e.message.includes("$EDITOR environment variable")?{success:!1,error:getEditorSetupInstructions()}:{success:!1,error:e instanceof Error?e.message:String(e)}}async function readCategoryLineNumber(t){const{filePath:n,category:r}=t,o=await D.readFile(n,"utf-8");if("taste.md"===e.basename(n)&&e.basename(e.dirname(n))===r)return 1;const s=o.split("\n").findIndex(e=>e.trim().toLowerCase()===`# ${r.toLowerCase()}`);return s>=0?s+1:1}async function findCategoryLineNumber(e){try{return await readCategoryLineNumber(e)}catch{return 1}}async function openPackage(e){const{packageName:t,target:n}=e,r=(await fetchAllPackages({target:n})).find(e=>e.category===t);if(!r){let e="project";return"local-global"===n&&(e="global"),"remote-project"!==n&&"remote-user"!==n||(e="remote"),{success:!1,error:`Taste package '${t}' not found in ${e}`}}const o=r.sourcePath,s=await findCategoryLineNumber({filePath:o,category:t});return await it([{file:o,line:s}]),{success:!0,filePath:o,lineNumber:s}}__name(resolveStorage,"resolveStorage"),__name(getPackageDisplayLength,"getPackageDisplayLength"),__name(formatPackageLine,"formatPackageLine"),__name(validateListOptions,"validateListOptions"),__name(fetchPackages,"fetchPackages"),__name(getStorageLabel,"getStorageLabel"),__name(printPackageTable,"printPackageTable"),__name(runList,"runList"),Ht(),Ht(),__name(fetchAllPackages,"fetchAllPackages"),__name(handleOpenError,"handleOpenError"),__name(readCategoryLineNumber,"readCategoryLineNumber"),__name(findCategoryLineNumber,"findCategoryLineNumber"),__name(openPackage,"openPackage");var OP=new Set(["local-project","local-global","remote-project","remote-user"]);async function open11(e){const{package:t,target:n}=e;if(!OP.has(n))return{success:!1,error:`Invalid target: ${n}`};try{return await openPackage({packageName:t,target:n})}catch(e){return handleOpenError(e)}}function getEditorSetupInstructions(){const e=dt.platform;if("win32"===e)return'Error: No default editor found\n\nTo permanently set your default editor, run one of these commands:\n\nCommand Prompt (as Administrator):\n setx EDITOR "code" # VS Code\n setx EDITOR "notepad" # Notepad\n setx EDITOR "vim" # Vim (if installed via WSL/Git Bash)\n\nPowerShell:\n [Environment]::SetEnvironmentVariable("EDITOR", "code", "User")\n\nThen restart your terminal.';const t="darwin"===e?"~/.zshrc":"~/.bashrc";return`Error: No default editor found\n\nTo permanently set your default editor, run one of these commands:\n echo 'export EDITOR="code"' >> ${t} # VS Code\n echo 'export EDITOR="vim"' >> ${t} # Vim\n echo 'export EDITOR="nano"' >> ${t} # Nano\n echo 'export EDITOR="subl"' >> ${t} # Sublime Text\n\nFor bash users ${"darwin"===e?"(or ~/.bash_profile for bash)":"(or ~/.zshrc for zsh)"}, replace ${t} with the appropriate file.\n\nThen restart your terminal or run: source ${t}`}function createOpenCommand(){return new ke("open").argument("[package]","Taste package name, or owner/package to open in browser").option("-g, --global","Open taste package from global storage (~/.commandcode)").description(`Open a taste package in your editor ${ue.dim("(use owner/package to open in browser)")}`).action(withErrorHandler(async(e,t)=>runOpen({packageName:e,options:t})))}function validateOpenOptions(e){e||exitWithUsage({message:"Specify a taste package name to open",usage:["cmd taste open <package> open taste package in editor","cmd taste open <package> -g open global taste package in editor","cmd taste open owner/package open package page in browser"]})}async function runOpen({packageName:e,options:t}){console.log(""),validateOpenOptions(e);const n=parseOwnerPackage(e);n?await openInBrowser(n):await openInEditor3({packageName:e,options:t})}async function openInBrowser(e){const t=`https://commandcode.ai/${e.owner}/${e.packageName}`;await ge(t);const n=getPackageLink({owner:e.owner,packageName:e.packageName});console.log(`${ue.green(_e.tick)} Opened ${n} in browser`)}async function openInEditor3({packageName:e,options:t}){const n=t.global?"local-global":"local-project",r=await open11({package:e,target:n});r.success||exitWithError(r.error??"Unknown error"),console.log(`${ue.green(_e.tick)} Opened ${ue.green(`'${e}'`)} taste package from ${t.global?"global":"project"}`)}__name(open11,"open"),__name(getEditorSetupInstructions,"getEditorSetupInstructions"),__name(createOpenCommand,"createOpenCommand"),__name(validateOpenOptions,"validateOpenOptions"),__name(runOpen,"runOpen"),__name(openInBrowser,"openInBrowser"),__name(openInEditor3,"openInEditor"),Ht(),Ht(),Ht(),Ht();var FP=null,qP=!1;function setActiveSpinner(e){FP=e}function stopActiveSpinner(e){FP&&(FP.stop(e),FP=null)}function setPrompted(e){qP=e}function wasPrompted(){return qP}function beginPrompt(e,t){stopActiveSpinner(),je.intro(ue.dim(e)),t&&je.log.message(ue.dim(t)),setPrompted(!0)}function handleCancel(e){je.isCancel(e)&&(je.cancel("Operation cancelled"),process.exit(0))}function startStrategySpinner(e){if("skip"===e){const e=je.spinner();return e.start("Skipping"),void e.stop("Skipped")}const t="merge"===e?"Merging":"Overwriting",n="merge"===e?"Merged":"Overwritten",r=je.spinner();r.start(t),setActiveSpinner({stop:__name(e=>r.stop(e??n),"stop"),cancel:__name(e=>r.cancel(e),"cancel"),error:__name(e=>r.error(e),"error")})}async function promptMergeStrategy(e){const{packageName:t,owner:n,localPkg:r,remoteLearningsCount:o}=e,s="This package already exists locally";if(!process.stdout.isTTY||!process.stdin.isTTY)return stopActiveSpinner(s),setPrompted(!0),je.log.warn("Non-interactive terminal detected, using default merge strategy"),"merge";beginPrompt(`Pulling ${ue.green(`'${t}'`)} from ${n}`,s),je.log.message(`Local: ${r.learnings.length} learnings\nRemote: ${o} learnings ${ue.dim(`(from ${n})`)}`);const i=await je.select({message:"What would you like to do?",options:[{value:"merge",label:"Merge",hint:"Combine both versions intelligently (default)"},{value:"overwrite",label:"Overwrite",hint:`Replace local with remote (${r.learnings.length} → ${o} learnings)`},{value:"skip",label:"Skip",hint:"Keep local version, ignore remote"}],initialValue:"merge"});handleCancel(i);const a=i;return startStrategySpinner(a),a}async function promptGlobalPushStrategy(e){const{packageName:t,localLearningsCount:n,globalPkg:r}=e,o="This package already exists in global storage";if(!process.stdout.isTTY||!process.stdin.isTTY)return stopActiveSpinner(o),setPrompted(!0),je.log.warn("Non-interactive terminal detected, using default merge strategy"),"merge";beginPrompt(`Pushing ${ue.green(`'${t}'`)} to global`,o),je.log.message(`Local: ${n} learnings\nGlobal: ${r.learnings.length} learnings`);const s=await je.select({message:"What would you like to do?",options:[{value:"merge",label:"Merge",hint:"Combine both versions intelligently (default)"},{value:"overwrite",label:"Overwrite",hint:`Replace global with local (${r.learnings.length} → ${n} learnings)`},{value:"skip",label:"Skip",hint:"Keep global version, cancel push"}],initialValue:"merge"});handleCancel(s);const i=s;return startStrategySpinner(i),i}async function promptGlobalPullStrategy(e){const{packageName:t,localPkg:n,globalLearningsCount:r}=e,o="This package already exists locally";if(!process.stdout.isTTY||!process.stdin.isTTY)return stopActiveSpinner(o),setPrompted(!0),je.log.warn("Non-interactive terminal detected, using default merge strategy"),"merge";beginPrompt(`Pulling ${ue.green(`'${t}'`)} from global`,o),je.log.message(`Local: ${n.learnings.length} learnings\nGlobal: ${r} learnings`);const s=await je.select({message:"What would you like to do?",options:[{value:"merge",label:"Merge",hint:"Combine both versions intelligently (default)"},{value:"overwrite",label:"Overwrite",hint:`Replace local with global (${n.learnings.length} → ${r} learnings)`},{value:"skip",label:"Skip",hint:"Keep local version, ignore global"}],initialValue:"merge"});handleCancel(s);const i=s;return startStrategySpinner(i),i}async function promptTypeMismatchStrategy(e){const{packageName:t,owner:n,localLearningsCount:r,remoteLearningsCount:o}=e,s=`Pushing local project taste to individual package '${t}'`;if(!process.stdout.isTTY||!process.stdin.isTTY)return stopActiveSpinner(s),setPrompted(!0),je.log.warn("Non-interactive terminal detected, skipping push"),"skip";const i=ut(`commandcode.ai/${n}/${t}`,`https://commandcode.ai/${n}/${t}`,{fallback:__name((e,t)=>t,"fallback")});beginPrompt(`Pushing ${ue.green(`'${t}'`)} to ${n}`,s),je.log.message(`Local: ${t} (${r} learnings)\nRemote: ${t} (${o} learnings) in ${n}`),je.log.info(`Current package: ${ue.cyan(i)} ${ue.dim("(review)")}`);const a=await je.select({message:"What would you like to do?",options:[{value:"skip",label:"Skip",hint:"Keep remote version, cancel push"},{value:"overwrite",label:"Overwrite",hint:"Replace individual remote package with local project taste"}],initialValue:"skip"});handleCancel(a);const l=a;return startStrategySpinner(l),l}async function promptSameTypeStrategy(e){const{packageName:t,owner:n,localLearningsCount:r,remoteLearningsCount:o}=e,s=`This package already exists in ${n}`;if(!process.stdout.isTTY||!process.stdin.isTTY)return stopActiveSpinner(s),setPrompted(!0),je.log.warn("Non-interactive terminal detected, skipping push"),"skip";const i=ut(`commandcode.ai/${n}/${t}`,`https://commandcode.ai/${n}/${t}`,{fallback:__name((e,t)=>t,"fallback")});beginPrompt(`Pushing ${ue.green(`'${t}'`)} to ${n}`,s),je.log.message(`Local: ${r} learnings\nRemote: ${o} learnings`),je.log.info(`Current package: ${ue.cyan(i)} ${ue.dim("(review)")}`);const a=await je.select({message:"What would you like to do?",options:[{value:"skip",label:"Skip",hint:"Keep remote version, cancel push"},{value:"overwrite",label:"Overwrite",hint:`Replace remote with local (${o} → ${r} learnings)`}],initialValue:"skip"});handleCancel(a);const l=a;return startStrategySpinner(l),l}function mergeSingleLearning(e,t,n,r){const o=t.get(e.text);return o?e.confidence>o.confidence?(n.set(e.text,e),void r.updated++):void r.unchanged++:(n.set(e.text,e),void r.added++)}function mergePackages(e){const{source:t,target:n}=e,r={added:0,updated:0,unchanged:0},o=new Map(n.map(e=>[e.text,e])),s=new Map(o);for(const e of t)mergeSingleLearning(e,o,s,r);const i=new Set(t.map(e=>e.text)),a=n.filter(e=>!i.has(e.text)).length;return r.unchanged+=a,{merged:Array.from(s.values()),details:r}}function validateSinglePackage(e,t){const n=validateTasteFile({content:formatPackage({pkg:e}),filePath:`${e.category}/taste.md`});if(!n.valid){const r=formatValidationIssues({result:n,verbose:!0});return{pkg:e.category,error:`Validation failed for taste package in ${t}:\n${r}`}}return n.issues.filter(e=>"warning"===e.severity).length>0&&(console.warn(`\nWarning: Taste package '${e.category}' in ${t} has validation warnings:\n`),console.warn(formatValidationIssues({result:n,verbose:!0})+"\n")),null}function validateSingleRemoteFile(e,t){const n=validateTasteFile({content:e.content,filePath:e.file});if(!n.valid){const r=formatValidationIssues({result:n,verbose:!0});return{pkg:t,error:`Validation failed for ${e.file}:\n${r}`}}return n.issues.filter(e=>"warning"===e.severity).length>0&&(console.warn(`\nWarning: File '${e.file}' has validation warnings:\n`),console.warn(formatValidationIssues({result:n,verbose:!0})+"\n")),null}function validatePackages(e){const{packages:t,label:n}=e;return t.map(e=>validateSinglePackage(e,n)).filter(e=>null!==e)}function validateRemoteFiles(e){const{files:t,packageName:n}=e;return t.map(e=>validateSingleRemoteFile(e,n)).filter(e=>null!==e)}function mergeOrKeep(e){const{source:t,existing:n}=e;if(!n)return{pkg:t,details:{added:t.learnings.length,updated:0,unchanged:0}};const r=mergePackages({source:t.learnings,target:n.learnings});return{pkg:{...t,learnings:r.merged},details:r.details}}async function resolveRemotePullStrategy(e){const{flagStrategy:t,overwrite:n,existingPkg:r,tastePkg:o,owner:s}=e;return"skip"===t?r?"skip":"merge":"merge"===t?"merge":"overwrite"===t||n?"overwrite":r?promptMergeStrategy({packageName:o.category,owner:s,localPkg:r,remoteLearningsCount:o.learnings.length}):"merge"}async function executePackageStrategy(e){const{tastePkg:t,owner:n,overwrite:r,flagStrategy:o,result:s}=e,i=await getPackage2({category:t.category}),a=await resolveRemotePullStrategy({flagStrategy:o,overwrite:r,existingPkg:i,tastePkg:t,owner:n});if("skip"===a)return void s.skipped?.push(t.category);if("overwrite"===a&&(await writePackage2({pkg:t}),s.packagesPulled.push(t.category),s.overwritten.push(t.category)),"merge"===a){const{pkg:e,details:n}=mergeOrKeep({source:t,existing:i});await writePackage2({pkg:e}),s.packagesPulled.push(t.category),s.mergeDetails[t.category]=n}const l=getCategoryTasteFile({target:"local-project",category:t.category});s.filePaths[t.category]=l}async function processPackage(e){const{tastePkg:t,result:n}=e;try{await executePackageStrategy(e)}catch(e){n.success=!1,n.errors.push({pkg:t.category,error:e instanceof Error?e.message:String(e)})}}async function pullProjectPackage(e){const{files:t,packageName:n,owner:r,overwrite:o,flagStrategy:s,result:i}=e,a=t.find(e=>"taste.md"===e.file);if(a){const e=parsePackages({content:a.content,sourcePath:`remote:${n}/taste.md`});for(const t of e)await processPackage({tastePkg:t,owner:r,overwrite:o,flagStrategy:s,result:i})}const l=t.filter(e=>"taste.md"!==e.file);for(const e of l){const t=e.file.replace("/taste.md",""),a={category:t,learnings:parseTasteContent(e.content),sourcePath:`remote:${n}/${t}`};await processPackage({tastePkg:a,owner:r,overwrite:o,flagStrategy:s,result:i})}}async function pullCategoryPackage(e){const{files:t,packageName:n,owner:r,overwrite:o,flagStrategy:s,result:i}=e,a=t.find(e=>"taste.md"===e.file);if(!a)return i.success=!1,void i.errors.push({pkg:n,error:"No taste.md file found in category package"});const l={category:n,learnings:parseTasteContent(a.content),sourcePath:`remote:${n}`};await processPackage({tastePkg:l,owner:r,overwrite:o,flagStrategy:s,result:i})}__name(setActiveSpinner,"setActiveSpinner"),__name(stopActiveSpinner,"stopActiveSpinner"),__name(setPrompted,"setPrompted"),__name(wasPrompted,"wasPrompted"),__name(beginPrompt,"beginPrompt"),__name(handleCancel,"handleCancel"),__name(startStrategySpinner,"startStrategySpinner"),__name(promptMergeStrategy,"promptMergeStrategy"),__name(promptGlobalPushStrategy,"promptGlobalPushStrategy"),__name(promptGlobalPullStrategy,"promptGlobalPullStrategy"),__name(promptTypeMismatchStrategy,"promptTypeMismatchStrategy"),__name(promptSameTypeStrategy,"promptSameTypeStrategy"),Ht(),Ht(),__name(mergeSingleLearning,"mergeSingleLearning"),__name(mergePackages,"mergePackages"),__name(validateSinglePackage,"validateSinglePackage"),__name(validateSingleRemoteFile,"validateSingleRemoteFile"),__name(validatePackages,"validatePackages"),__name(validateRemoteFiles,"validateRemoteFiles"),__name(mergeOrKeep,"mergeOrKeep"),Ht(),__name(resolveRemotePullStrategy,"resolveRemotePullStrategy"),__name(executePackageStrategy,"executePackageStrategy"),__name(processPackage,"processPackage"),__name(pullProjectPackage,"pullProjectPackage"),__name(pullCategoryPackage,"pullCategoryPackage");var jP=__name(({pkg:e,error:t})=>({success:!1,packagesPulled:[],errors:[{pkg:e,error:t}],mergeDetails:{},overwritten:[],filePaths:{}}),"fail"),BP=__name(()=>({success:!0,packagesPulled:[],skipped:[],errors:[],mergeDetails:{},overwritten:[],filePaths:{}}),"emptyResult"),UP=__name(e=>"local-global"===e?"global":"remote-project"===e?"remote project":"remote-user"===e?"remote":"source","sourceName");async function resolvePullStrategy(e){const{flagStrategy:t,overwrite:n,existingPkg:r,source:o,tastePkg:s}=e;return"skip"===t?r?"skip":"merge":"merge"===t?"merge":"overwrite"===t||n?"overwrite":r&&"local-global"===o?promptGlobalPullStrategy({packageName:s.category,localPkg:r,globalLearningsCount:s.learnings.length}):"merge"}async function executePullStrategy(e){const{tastePkg:t,source:n,flagStrategy:r,overwrite:o,result:s}=e,i=await getPackage2({category:t.category}),a=await resolvePullStrategy({flagStrategy:r,overwrite:o,existingPkg:i,source:n,tastePkg:t});if("skip"===a)return void s.skipped.push(t.category);if("overwrite"===a&&(await writePackage2({pkg:t}),s.packagesPulled.push(t.category),s.overwritten.push(t.category)),"merge"===a){const{pkg:e,details:n}=mergeOrKeep({source:t,existing:i});await writePackage2({pkg:e}),s.packagesPulled.push(t.category),s.mergeDetails[t.category]=n}const l=getCategoryTasteFile({target:"local-project",category:t.category});s.filePaths[t.category]=l}async function pullSinglePackage(e){const{tastePkg:t,result:n}=e;try{await executePullStrategy(e)}catch(e){n.success=!1,n.errors.push({pkg:t.category,error:e instanceof Error?e.message:String(e)})}}async function pull(e){const{packages:t,source:n,overwrite:r=!1,strategy:o}=e;if("local-global"!==n&&"remote-project"!==n&&"remote-user"!==n)return jP({pkg:"all",error:`Invalid source: ${n}`});const s=UP(n);let i;try{i="local-global"===n?await getAllPackages():await getAllPackages3()}catch(e){return jP({pkg:"all",error:e instanceof Error?e.message:String(e)})}if(0===i.length)return jP({pkg:"all",error:`No taste packages found in ${s}`});const a=validatePackages({packages:i,label:s});if(a.length>0)return{success:!1,packagesPulled:[],errors:[...a],mergeDetails:{},overwritten:[],filePaths:{}};const l=t.length>0?i.filter(e=>t.includes(e.category)):i;if(t.length>0&&0===l.length)return{success:!1,packagesPulled:[],errors:t.map(e=>({pkg:e,error:`Taste package not found in ${s}`})),mergeDetails:{},overwritten:[],filePaths:{}};const u=BP();for(const e of l)await pullSinglePackage({tastePkg:e,source:n,flagStrategy:o,overwrite:r,result:u});return u}async function executePullRemote(e){const{owner:t,packageName:n,overwrite:r,flagStrategy:o,result:s}=e,i=await downloadPackage({owner:t,packageName:n});if(!i)return jP({pkg:n,error:"Taste package not found in remote"});const{type:a,files:l}=i,u=validateRemoteFiles({files:l,packageName:n});if(u.length>0)return{success:!1,packagesPulled:[],errors:[...u],mergeDetails:{},overwritten:[],filePaths:{}};const d={files:l,packageName:n,owner:t,overwrite:r,flagStrategy:o,result:s};return"project"===a?(await pullProjectPackage(d),s):(await pullCategoryPackage(d),s)}async function pullRemote(e){const{owner:t,packageName:n,overwrite:r=!1,strategy:o}=e,s=BP();try{return await executePullRemote({owner:t,packageName:n,overwrite:r,flagStrategy:o,result:s})}catch(e){return jP({pkg:n,error:e instanceof Error?e.message:String(e)})}}function logResult(e){if(wasPrompted())return je.outro(e),void setPrompted(!1);console.log(e)}function buildPullMessage(e){const{pkgName:t,sourceName:n,filePath:r,options:o,mergeDetails:s}=e,i=wasPrompted()?"":`${_e.tick} `,a=r?ue.dim(`\n ${shortenPath(r)}`):"";if(o.overwrite)return`${ue.green(i)}Replaced ${ue.green(`'${t}'`)} taste package in project`+a;if(s){const e=formatMergeParts(s);return`${ue.green(i)}Pulled ${ue.green(`'${t}'`)} taste package from ${n} ${ue.gray(`(${e.join(", ")})`)}`+a}return`${ue.green(i)}Pulled ${ue.green(`'${t}'`)} taste package from ${n}`+a}function logPullSingleSuccess(e){const{result:t,sourceName:n,options:r}=e;if(1!==t.packagesPulled.length)return!1;const o=t.packagesPulled[0],s=t.filePaths?.[o],i=t.mergeDetails?.[o];return logResult(buildPullMessage({pkgName:o,sourceName:n,filePath:s,options:r,mergeDetails:i})),!r.overwrite&&!!i&&hasMergeConflictRisk(i)}function logPullSummary(e){const{result:t,sourceName:n}=e,r=t.overwritten??[],o=t.skipped??[],s=t.packagesPulled.filter(e=>!r.includes(e)),i=t.packagesPulled.length+o.length,a=`${i} ${1===i?"package":"packages"}`,l=[];return s.length>0&&l.push(wrapLine(`${ue.green("Pulled")} (${s.length}) ${s.join(", ")}`,wasPrompted()?4:0)),r.length>0&&l.push(wrapLine(`${ue.yellow("Overwritten")} (${r.length}) ${r.join(", ")}`,wasPrompted()?4:0)),o.length>0&&l.push(wrapLine(`${ue.dim("Skipped")} (${o.length}) ${ue.dim(o.join(", "))}`,wasPrompted()?4:0)),wasPrompted()?(l.length>0&&je.log.message(l.join("\n")),je.outro(`${a} from ${n}`),setPrompted(!1),hasMergeConflictRiskInRecord(t.mergeDetails??{})):(console.log(`${ue.green(_e.tick)} ${a} from ${n}`),l.length>0&&console.log(l.join("\n")),hasMergeConflictRiskInRecord(t.mergeDetails??{}))}function logPullSuccess(e){const{result:t,sourceName:n,options:r}=e,o=t.skipped??[];t.packagesPulled.length+o.length>1?logPullSummary({result:t,sourceName:n})&&logMergeReviewTip():o.length>0?logResult(ue.yellow(`Skipped '${o[0]}' — kept local version`)):logPullSingleSuccess({result:t,sourceName:n,options:r})&&logMergeReviewTip()}function createPullCommand(){return new ke("pull").argument("[package]","Taste package name, or owner/package to pull from remote").option("-g, --global","Pull taste package from global storage (~/.commandcode)").addOption(new Te("--local","Use local server").hideHelp()).option("--remote","Pull taste package from commandcode.ai remote").option("--all","Pull all taste packages from global").option("--overwrite","Replace local package without prompting").option("--skip","Keep local package, skip conflicting pull").option("--merge","Auto-merge conflicting learnings without prompting").addOption(new Te("--staging","Use staging environment").hideHelp()).description(`Pull taste packages from remote or global into the project ${ue.dim("(prompts on conflicts)")}`).action(withErrorHandler(async(e,t)=>{setPrompted(!1);const n=resolveRemoteDefault(t),{result:r,owner:o}=await runPull({packageName:e,options:n});r.success||handleResultErrors(r.errors),logPullSuccess({result:r,sourceName:n.remote?o??"remote":"global",options:n})}))}function validatePullOptions(e){const{packageName:t,options:n}=e;n.global&&n.remote&&exitWithError("--global and --remote are mutually exclusive — pick one source"),n.remote&&n.all&&exitWithUsage({message:"--all is not supported for remote pull — specify a package instead",usage:["cmd taste pull <owner>/<package> pull a taste package from remote"]}),n.remote&&!t&&exitWithUsage({message:"Specify a taste package to pull from remote",usage:["cmd taste pull <owner>/<package> pull a taste package from remote","cmd taste pull <package> -g pull a taste package from global","cmd taste pull --all -g pull all taste packages from global"]}),n.remote&&t&&!t.includes("/")&&exitWithUsage({message:`Remote pull requires owner/package format — got '${t}'`,usage:["cmd taste pull <owner>/<package> e.g. cmd taste pull ahmadawais/code-style"]}),t||n.all||exitWithUsage({message:"Specify a taste package name or use --all to pull everything",usage:["cmd taste pull <owner>/<package> pull a taste package from remote","cmd taste pull <package> -g pull a taste package from global","cmd taste pull --all -g pull all taste packages from global"]}),t&&n.all&&exitWithError("Use either a package name or --all, not both"),resolveConflictStrategy(n)}async function runPull(e){const{packageName:t,options:n}=e;console.log("");const r=resolveRemoteDefault(n);validatePullOptions({packageName:t,options:r});const o=resolveConflictStrategy(r);return r.remote&&t?pullRemoteSingle({packageName:t,options:r,strategy:o}):pullGlobal({packageName:t,options:r,strategy:o})}async function pullRemoteSingle(e){const{packageName:t,options:n,strategy:r}=e,o=parseOwnerPackage(t);o||exitWithError("Invalid format — use owner/package (e.g. ahmadawais/code-style)"),setActiveSpinner(xe("Pulling taste package").start());const s=await pullRemote({owner:o.owner,packageName:o.packageName,overwrite:n.overwrite,strategy:r});return stopActiveSpinner(),{result:s,owner:o.owner}}async function pullGlobal(e){const{packageName:t,options:n,strategy:r}=e;setActiveSpinner(xe("Pulling taste package").start());const o=n.all||!t?[]:[t],s=await pull({packages:o,source:"local-global",overwrite:n.overwrite,strategy:r});return stopActiveSpinner(),{result:s}}async function fetchUserNamespaces(){const e=getApiBaseUrl(),t=new Ly({baseUrl:e}),n=await t.get({endpoint:kt.ALPHA.NAMESPACES});if(!n.success)throw new Error("Failed to fetch namespaces");if("org"===n.type)return{userName:n.org.login,orgs:[]};const r=n.orgs.map(e=>({id:e.id,login:e.login,name:e.name}));return{userName:n.user.userName,orgs:r}}function logResult2(e){if(wasPrompted())return je.outro(e),void setPrompted(!1);console.log(e)}function logPushAllSuccess(t){const{result:n,options:r}=t;if(!r.all)return!1;if(0===n.packagesPushed.length){const e=n.skipped?.length??0;if(e>0){const t=wasPrompted()?"":`${_e.tick} `,n=`${e} ${1===e?"package":"packages"}`;logResult2(`${ue.green(t)}Skipped ${n}`)}return!1}const o=n.packagesPushed.length,s=`${o} ${1===o?"package":"packages"}`,i=n.filePaths?.[n.packagesPushed[0]],a=r.global&&i?shortenPath(e.dirname(e.dirname(i))):i,l=wasPrompted()?"":`${_e.tick} `;if(!a)return logResult2(`${ue.green(l)}Pushed ${s} to remote`),!1;if(r.overwrite||Boolean(n.overwritten?.length)){let e=0;if(n.mergeDetails)for(const t of Object.values(n.mergeDetails))e+=t.updated??0;const t=e>0?` ${ue.gray(`(${e} ${1===e?"learning":"learnings"} replaced)`)}`:"";return logResult2(`${ue.green(l)}Replaced ${s} in ${a}${t}`),!1}if(!n.mergeDetails||0===Object.keys(n.mergeDetails).length)return logResult2(`${ue.green(l)}Pushed ${s} to ${a}`),!1;let u=0,d=0,m=0;for(const e of Object.values(n.mergeDetails))u+=e.added??0,d+=e.updated??0,m+=e.unchanged??0;const g=formatMergeParts({added:u,updated:d,unchanged:m}),h=g.length>0?` ${ue.gray(`(${g.join(", ")})`)}`:"";return logResult2(`${ue.green(l)}Pushed ${s} to ${a}${h}`),(u>0||d>0)&&m>0}function logPushSingleSuccess(e){const{result:t,options:n}=e;if(n.all)return!1;if(1!==t.packagesPushed.length)return!1;const r=t.packagesPushed[0],o=t.filePaths?.[r],s=n.remote&&o,i=s?o:"global",a=wasPrompted()?"":`${_e.tick} `,l=!s&&o?ue.dim(`\n ${shortenPath(o)}`):"";if(n.overwrite)return logResult2(`${ue.green(a)}Replaced ${ue.green(`'${r}'`)} taste package in ${i}`+l),!1;if(t.mergeDetails?.[r]){const e=t.mergeDetails[r],n=formatMergeParts(e);return logResult2(`${ue.green(a)}Pushed ${ue.green(`'${r}'`)} taste package to ${i} ${ue.gray(`(${n.join(", ")})`)}`+l),hasMergeConflictRisk(e)}return logResult2(`${ue.green(a)}Pushed ${ue.green(`'${r}'`)} taste package to ${i}`+l),!1}function logPushMultiSuccess(e){const{result:t,options:n}=e;if(n.all)return!1;if(t.packagesPushed.length<=1)return!1;const r=n.remote?"remote":"global",o=wasPrompted()?"":`${_e.tick} `;return logResult2(wrapLine(`${ue.green(o)}Pushed ${ue.green(t.packagesPushed.length)} taste packages ${ue.green(`(${t.packagesPushed.join(", ")})`)} to ${r}`)),!(n.overwrite||!t.mergeDetails)&&hasMergeConflictRiskInRecord(t.mergeDetails)}function logPushUrls(e){const{result:t,options:n}=e;if(!n.remote||!t.filePaths)return;const r=new Set;for(const e of t.packagesPushed){const n=t.filePaths[e];if(!n||!n.includes("/"))continue;const[o,s]=n.split("/");if(!o||!s)continue;const i=getPackageLink({owner:o,packageName:s});r.has(i)||(r.add(i),console.log(ue.gray(` ${i}`)))}}function logConflictSummary(e){const{result:t}=e,n=t.overwritten??[],r=t.skipped??[],o=t.packagesPushed.filter(e=>!n.includes(e)),s=t.packagesPushed.length+r.length,i=[];o.length>0&&i.push(wrapLine(`${ue.green("Merged")} (${o.length}) ${o.join(", ")}`,4)),n.length>0&&i.push(wrapLine(`${ue.yellow("Overwritten")} (${n.length}) ${n.join(", ")}`,4)),r.length>0&&i.push(wrapLine(`${ue.dim("Skipped")} (${r.length}) ${ue.dim(r.join(", "))}`,4)),i.length>0&&je.log.message(i.join("\n"));const a=`${s} ${1===s?"package":"packages"}`;je.outro(a)}function logPushBreakdown(e){const t=e.overwritten??[],n=e.skipped??[];if(0===n.length&&0===t.length)return;const r=e.packagesPushed.filter(e=>!t.includes(e)),o=[];r.length>0&&o.push(wrapLine(`${ue.green("Pushed")} (${r.length}) ${r.join(", ")}`)),t.length>0&&o.push(wrapLine(`${ue.yellow("Overwritten")} (${t.length}) ${t.join(", ")}`)),n.length>0&&o.push(wrapLine(`${ue.dim("Skipped")} (${n.length}) ${ue.dim(n.join(", "))}`)),o.length>0&&console.log(o.join("\n"))}function logPushSuccess(e){const{result:t,options:n}=e;if(wasPrompted())return setPrompted(!1),logConflictSummary({result:t}),void logPushUrls({result:t,options:n});const r=logPushAllSuccess({result:t,options:n})||logPushSingleSuccess({result:t,options:n})||logPushMultiSuccess({result:t,options:n});n.all&&logPushBreakdown(t),logPushUrls({result:t,options:n}),r&&logMergeReviewTip()}__name(resolvePullStrategy,"resolvePullStrategy"),__name(executePullStrategy,"executePullStrategy"),__name(pullSinglePackage,"pullSinglePackage"),__name(pull,"pull"),__name(executePullRemote,"executePullRemote"),__name(pullRemote,"pullRemote"),Ht(),__name(logResult,"logResult"),__name(buildPullMessage,"buildPullMessage"),__name(logPullSingleSuccess,"logPullSingleSuccess"),__name(logPullSummary,"logPullSummary"),__name(logPullSuccess,"logPullSuccess"),__name(createPullCommand,"createPullCommand"),__name(validatePullOptions,"validatePullOptions"),__name(runPull,"runPull"),__name(pullRemoteSingle,"pullRemoteSingle"),__name(pullGlobal,"pullGlobal"),Ht(),Rn(),Ht(),iw(),Xy(),Yt(),__name(fetchUserNamespaces,"fetchUserNamespaces"),Ht(),__name(logResult2,"logResult"),__name(logPushAllSuccess,"logPushAllSuccess"),__name(logPushSingleSuccess,"logPushSingleSuccess"),__name(logPushMultiSuccess,"logPushMultiSuccess"),__name(logPushUrls,"logPushUrls"),__name(logConflictSummary,"logConflictSummary"),__name(logPushBreakdown,"logPushBreakdown"),__name(logPushSuccess,"logPushSuccess"),Ht(),gk(),Ht();var zP=__name(({pkg:e,error:t})=>({success:!1,packagesPushed:[],skipped:[],errors:[{pkg:e,error:t}],mergeDetails:{},overwritten:[],filePaths:{}}),"fail"),WP=__name(e=>e.reduce((e,t)=>t.file.endsWith("taste.md")?e+parseTasteContent(t.content).length:e,0),"countRemoteLearnings");async function resolvePushAllStrategy(e){const{flagStrategy:t,overwrite:n,existingProject:r,packagesToPush:o,projectName:s,owner:i}=e;if("skip"===t)return"skip";if("overwrite"===t||n)return"overwrite";if("merge"===t)return"overwrite";if(!r)return"overwrite";const a=r.type??"category",l=o.reduce((e,t)=>e+t.learnings.length,0),u=WP(r.files);return"project"!==a?promptTypeMismatchStrategy({packageName:s,owner:i,localLearningsCount:l,remoteLearningsCount:u}):promptSameTypeStrategy({packageName:s,owner:i,localLearningsCount:l,remoteLearningsCount:u})}async function executePushAllRemote(t){const{packagesToPush:n,owner:r,overwrite:o,isPublic:s,isPublicExplicitlySet:i,flagStrategy:a}=t,l=e.basename(process.cwd()),u={success:!0,packagesPushed:[],skipped:[],errors:[],mergeDetails:{},overwritten:[],filePaths:{}},d=await downloadPackage({owner:r,packageName:l}),m=await resolvePushAllStrategy({flagStrategy:a,overwrite:o,existingProject:d,packagesToPush:n,projectName:l,owner:r});if("skip"===m)return u.skipped.push(...n.map(e=>e.category)),u;await writePackages({packages:n,projectName:l,owner:r,isPublic:i?s:d?.isPublic??!1,overwrite:"overwrite"===m});for(const e of n)u.packagesPushed.push(e.category),u.filePaths[e.category]=`${r}/${l}`,u.mergeDetails[e.category]={added:e.learnings.length,updated:0,unchanged:0};return d&&u.overwritten.push(...n.map(e=>e.category)),u}async function pushAllRemote(e){try{return await executePushAllRemote(e)}catch(e){return zP({pkg:"all",error:e instanceof Error?e.message:String(e)})}}__name(resolvePushAllStrategy,"resolvePushAllStrategy"),__name(executePushAllRemote,"executePushAllRemote"),__name(pushAllRemote,"pushAllRemote");var GP=__name(({pkg:e,error:t})=>({success:!1,packagesPushed:[],skipped:[],errors:[{pkg:e,error:t}],mergeDetails:{},overwritten:[],filePaths:{}}),"fail"),HP=__name(()=>({success:!0,packagesPushed:[],skipped:[],errors:[],mergeDetails:{},overwritten:[],filePaths:{}}),"emptyResult");async function writePkg(e){const{pkg:t,target:n,owner:r,isPublic:o,overwrite:s}=e;if("local-global"!==n){if(!r)throw new Error("Failed to get owner for remote push");await writePackage3({pkg:t,owner:r,isPublic:o,overwrite:s})}else await writePackage({pkg:t})}__name(writePkg,"writePkg");var VP=__name(e=>{const{target:t,category:n,owner:r}=e;return"local-global"===t?getCategoryTasteFile({target:"local-global",category:n}):"remote-project"!==t&&"remote-user"!==t||!r?void 0:`${r}/${n}`},"getDestPath");async function getUserOwner(){try{const e=await getAuthenticatedEntity();if(e.success&&e.user?.userName)return e.user.userName}catch{}}async function resolveSinglePushStrategy(e){const{flagStrategy:t,overwrite:n,existingPkg:r,target:o,tastePkg:s}=e;return"skip"===t?r?"skip":"merge":"merge"===t?"merge":"overwrite"===t||n?"overwrite":r&&"local-global"===o?promptGlobalPushStrategy({packageName:s.category,localLearningsCount:s.learnings.length,globalPkg:r}):"merge"}async function executePushStrategy(e){const{tastePkg:t,target:n,flagStrategy:r,overwrite:o,userOwner:s,isPublic:i,result:a}=e,l="local-global"===n?await getPackage({category:t.category}):await getPackage3({category:t.category}),u=await resolveSinglePushStrategy({flagStrategy:r,overwrite:o,existingPkg:l,target:n,tastePkg:t});if("skip"===u)return void a.skipped.push(t.category);if("overwrite"===u&&(await writePkg({pkg:t,target:n,owner:s,isPublic:i,overwrite:!0}),a.packagesPushed.push(t.category),a.overwritten.push(t.category),a.mergeDetails[t.category]={added:0,updated:t.learnings.length,unchanged:0}),"merge"===u){const{pkg:e,details:r}=mergeOrKeep({source:t,existing:l});await writePkg({pkg:e,target:n,owner:s,isPublic:i}),a.packagesPushed.push(t.category),a.mergeDetails[t.category]=r}const d=VP({target:n,category:t.category,owner:s});d&&(a.filePaths[t.category]=d)}async function pushSinglePackage(e){const{tastePkg:t,result:n}=e;try{await executePushStrategy(e)}catch(e){n.success=!1,n.errors.push({pkg:t.category,error:e instanceof Error?e.message:String(e)})}}async function push(e){const t=void 0!==e.isPublic,{packages:n,target:r,overwrite:o=!1,isPublic:s=!1,strategy:i}=e;if(!exists2())return GP({pkg:"all",error:"No taste directory found in project"});const a=await getAllPackages2();if(0===a.length)return GP({pkg:"all",error:"No taste packages found in project"});const l=validatePackages({packages:a,label:"project"});if(l.length>0)return{success:!1,packagesPushed:[],skipped:[],errors:[...l],mergeDetails:{},overwritten:[],filePaths:{}};const u=n.length>0?a.filter(e=>n.includes(e.category)):a;if(n.length>0&&0===u.length)return{success:!1,packagesPushed:[],skipped:[],errors:n.map(e=>({pkg:e,error:"Taste package not found in project"})),mergeDetails:{},overwritten:[],filePaths:{}};const d="remote-project"===r||"remote-user"===r?e.owner??await getUserOwner():void 0;if("remote-project"===r&&0===n.length)return d?pushAllRemote({packagesToPush:u,owner:d,overwrite:o,isPublic:s,isPublicExplicitlySet:t,flagStrategy:i}):GP({pkg:"all",error:"Failed to get owner for remote push"});if("local-global"!==r&&"remote-project"!==r&&"remote-user"!==r)return GP({pkg:"all",error:`Invalid target: ${r}`});const m=HP();for(const e of u)await pushSinglePackage({tastePkg:e,target:r,flagStrategy:i,overwrite:o,userOwner:d,isPublic:s,result:m});return m}async function executeRemotePush(e){const t=void 0!==e.isPublic,{owner:n,packageName:r,overwrite:o=!1,isPublic:s=!1,strategy:i}=e,a=await getPackage2({category:r});if(!a)return GP({pkg:r,error:`Taste package '${r}' not found in local project`});const l=validateTasteFile({content:formatPackage({pkg:a}),filePath:`${a.category}/taste.md`});if(!l.valid){const e=formatValidationIssues({result:l,verbose:!0});return GP({pkg:r,error:`Validation failed:\n${e}`})}l.issues.filter(e=>"warning"===e.severity).length>0&&(console.warn(`\nWarning: Taste package '${r}' has validation warnings:\n`),console.warn(formatValidationIssues({result:l,verbose:!0})+"\n"));const u=await downloadRemotePackage({owner:n,packageName:r}),d=await resolveSinglePushStrategy({flagStrategy:i,overwrite:o,existingPkg:u,target:"remote-project",tastePkg:a}),m=t?s:u?.isPublic??!1,g=HP();if("skip"===d)return g.skipped.push(r),g;if("overwrite"===d&&(await writePackage3({pkg:a,owner:n,isPublic:m,overwrite:!0}),g.packagesPushed.push(r),g.overwritten.push(r)),"merge"===d){const{pkg:e,details:t}=mergeOrKeep({source:a,existing:u});await writePackage3({pkg:e,owner:n,isPublic:m}),g.packagesPushed.push(r),g.mergeDetails[r]=t}return g.filePaths[r]=`${n}/${r}`,g}async function pushRemote(e){const{packageName:t}=e;if(!exists2())return GP({pkg:t,error:"No taste directory found in project"});try{return await executeRemotePush(e)}catch(e){return GP({pkg:t,error:e instanceof Error?e.message:String(e)})}}async function promptOwnerSelection(e){const{userName:t,orgs:n}=e;if(0===n.length)return t;const r=[{value:t,label:t,hint:"Personal"},...n.map(e=>({value:e.login,label:e.name||e.login,hint:"Organization"}))],o=await je.select({message:"Owner",options:r,initialValue:t});return je.isCancel(o)&&(je.cancel("Operation cancelled"),process.exit(0)),o}function createPushCommand(){return new ke("push").description(`Push taste packages to remote ${ue.dim("(commandcode.ai)")} or global ${ue.dim("(~/.commandcode)")}`).argument("[package]","Taste package name to push (omit with --all)").option("--all","Push all taste packages to remote").option("--remote","Push to commandcode.ai remote (default)").option("-g, --global","Push to local global storage (~/.commandcode)").addOption(new Te("--local","Use local server").hideHelp()).option("--public","Make package publicly discoverable on commandcode.ai").option("--private","Make package private (not publicly discoverable)").option("--owner <owner>","Push under a specific owner or organization").option("--overwrite","Replace existing package without prompting").option("--skip","Keep existing package, skip conflicting push").option("--merge","Auto-merge conflicting learnings without prompting").addOption(new Te("--staging","Push to staging environment").hideHelp()).action(withErrorHandler(async(e,t)=>{setPrompted(!1);const n=resolveRemoteDefault(t),r=await runPush({packageName:e,options:n});r.success||handleResultErrors(r.errors),logPushSuccess({result:r,options:n})}))}function validatePushOptions(e){const{packageName:t,options:n}=e;n.global&&n.remote&&exitWithError("--global and --remote are mutually exclusive — pick one destination"),n.public&&n.private&&exitWithError("--public and --private are mutually exclusive — pick one visibility"),n.owner&&n.global&&exitWithError("--owner only applies to remote pushes, not --global"),t||n.all||exitWithUsage({message:"Specify a taste package name or use --all to push everything",usage:["cmd taste push <package> push a taste package to remote (default)","cmd taste push --all push all taste packages to remote","cmd taste push <package> -g push a taste package to global (~/.commandcode)"]}),t&&n.all&&exitWithError("Use either a package name or --all, not both"),resolveConflictStrategy(n)}__name(getUserOwner,"getUserOwner"),__name(resolveSinglePushStrategy,"resolveSinglePushStrategy"),__name(executePushStrategy,"executePushStrategy"),__name(pushSinglePackage,"pushSinglePackage"),__name(push,"push"),__name(executeRemotePush,"executeRemotePush"),__name(pushRemote,"pushRemote"),Ht(),__name(promptOwnerSelection,"promptOwnerSelection"),__name(createPushCommand,"createPushCommand"),__name(validatePushOptions,"validatePushOptions");var QP=__name(e=>!!e.public||!e.private&&void 0,"resolveVisibility");async function validateOwnerAccess(e){let t;try{t=await fetchUserNamespaces()}catch(e){return void dlog(`[Auth] validateOwnerAccess: namespace service unavailable, skipping — ${e instanceof Error?e.message:String(e)}`)}const n=[t.userName,...t.orgs.map(e=>e.login)];n.includes(e)||exitWithError(`No push access to '${e}'. Available: ${n.join(", ")}`)}async function resolveOwnerForPush(e){const{packageName:t,owner:n}=e,r=parseOwnerPackage(t);if(r)return await validateOwnerAccess(r.owner),r;if(n)return await validateOwnerAccess(n),{owner:n,packageName:t};je.intro(ue.dim(`pushing ${t}`)),setPrompted(!0);const o=je.spinner();o.start("Resolving"),(await list({location:"local-project"})).some(e=>e.category===t)||(o.error("Failed"),je.outro(ue.red(`Taste package '${t}' not found in project`)),process.exit(1));const s=await fetchUserNamespaces();return o.stop(s.orgs.length>0?"Select owner to push to":""),{owner:s.orgs.length>0?await promptOwnerSelection(s):s.userName,packageName:t}}async function runPush(e){const{packageName:t,options:n}=e;console.log("");const r=resolveRemoteDefault(n);validatePushOptions({packageName:t,options:r});const o=resolveConflictStrategy(r);return r.remote&&r.all?pushRemoteAll({options:r,strategy:o}):r.remote?pushRemoteSingle({packageName:t,options:r,strategy:o}):pushGlobal({packageName:t,options:r,strategy:o})}async function pushRemoteAll(t){const{options:n,strategy:r}=t;n.owner&&await validateOwnerAccess(n.owner);const o=(await getAllPackages2()).length,s=`${o} ${1===o?"package":"packages"}`,i=e.basename(process.cwd()),a=resolveStrategyLabel({strategy:r,isRemote:!0});console.log(ue.dim(` Pushing ${s} to ${i} (remote)${a}`)),console.log(""),setActiveSpinner(xe("Pushing taste packages").start());const l=await push({packages:[],target:"remote-project",overwrite:n.overwrite,isPublic:QP(n),strategy:r,owner:n.owner});return stopActiveSpinner(),l}async function pushRemoteSingle(e){const{packageName:t,options:n,strategy:r}=e,{owner:o,packageName:s}=await resolveOwnerForPush({packageName:t,owner:n.owner});startPushSpinner({owner:o,pkgName:s});const i=await pushRemote({owner:o,packageName:s,overwrite:n.overwrite,isPublic:QP(n),strategy:r});return stopActiveSpinner(`Pushed to ${o}/${s}`),i}function resolveStrategyLabel(e){const{strategy:t,isRemote:n=!1}=e;return"overwrite"===t?" · overwrite":"skip"===t?" · skip conflicts":"merge"===t?" · auto-merge":n?"":" · will prompt on conflicts"}function startPushSpinner(e){const{owner:t,pkgName:n}=e;if(wasPrompted()){const e=je.spinner();return e.start(`Pushing to ${t}/${n}`),void setActiveSpinner(e)}setActiveSpinner(xe("Pushing taste package").start())}async function pushGlobal(e){const{packageName:t,options:n,strategy:r}=e,o=n.all||!t?[]:[t],s=await getAllPackages2(),i=o.length>0?o.length:s.length,a=`${i} ${1===i?"package":"packages"}`,l=shortenPath(getTastePath({target:"local-global"})),u=resolveStrategyLabel({strategy:r});console.log(ue.dim(` Pushing ${a} to ${l}${u}`)),console.log(""),setActiveSpinner(xe("Pushing taste packages").start());const d=await push({packages:o,target:"local-global",overwrite:n.overwrite,strategy:r});return stopActiveSpinner(),d}function createTasteCommand(){const e=new ke(Mt.TASTE);return e.description("Manage taste learning packages").allowUnknownOption().allowExcessArguments(),e.addCommand(createPushCommand()),e.addCommand(createPullCommand()),e.addCommand(createListCommand()),e.addCommand(createLintCommand()),e.addCommand(createOpenCommand()),isExperimentalEnabled()&&e.addCommand(createLearnCommand()),e}function formatVersion(e,t,n=!1){const r=n?de.bold(de.green(t)):de.white(t);return`${de.dim(e)} ${r}`}function showVersionDetails(e){console.log(formatVersion("Current:",e.currentVersion)),console.log(formatVersion("Latest: ",e.latestVersion,!0)),console.log(""),console.log(`Run ${de.bold(de.green("cmd update"))} to install.`)}function showUpdateSuccessHint(){console.log(de.dim(`Run ${de.cyan("cmd")} to start using the new version.`))}function showManualUpdateHint(e){console.log(de.dim("Try updating manually:")),console.log(de.cyan(`npm i -g command-code@${e}`))}function showCheckFailure(){console.log(de.dim("Please check your internet connection or try again later."))}async function checkAction(){const e=xe("Checking for updates...").start(),t=await checkForUpdateAvailable();if(!t)return e.fail("Failed to check for updates"),void showCheckFailure();t.updateAvailable?(e.stop(),console.log(""),console.log(`${de.green(_e.tick)} Update available`),showVersionDetails(t)):e.succeed(`Up to date ${de.dim(`(${t.currentVersion})`)}`)}async function performUpdateAction(){const e=xe("Checking for updates...").start(),t=await checkForUpdateAvailable();if(!t)return e.fail("Failed to check for updates"),void showCheckFailure();t.updateAvailable?(e.text=`Updating ${t.currentVersion} ${_e.arrowRight} ${t.latestVersion}...`,(await performAutoUpdate({silent:!0,updateInfo:t})).success||(e.fail("Update failed"),trackError({error:sanitizeErrorForTelemetry({error:new Error("Update failed"),label:"cli_update_failed"}),context:{component:To.UPDATE_COMMAND,heading:"CLI update failed","update.current_version":t.currentVersion,"update.target_version":t.latestVersion}}),showManualUpdateHint(t.latestVersion),await shutdownTelemetry(),process.exit(1)),e.succeed(`Updated to v${t.latestVersion}`),showUpdateSuccessHint()):e.succeed(`Up to date ${de.dim(`(${t.currentVersion})`)}`)}async function updateAction(e){e.checkOnly?await checkAction():await performUpdateAction()}__name(validateOwnerAccess,"validateOwnerAccess"),__name(resolveOwnerForPush,"resolveOwnerForPush"),__name(runPush,"runPush"),__name(pushRemoteAll,"pushRemoteAll"),__name(pushRemoteSingle,"pushRemoteSingle"),__name(resolveStrategyLabel,"resolveStrategyLabel"),__name(startPushSpinner,"startPushSpinner"),__name(pushGlobal,"pushGlobal"),Pr(),__name(createTasteCommand,"createTasteCommand"),Ht(),Yt(),No(),__name(formatVersion,"formatVersion"),__name(showVersionDetails,"showVersionDetails"),__name(showUpdateSuccessHint,"showUpdateSuccessHint"),__name(showManualUpdateHint,"showManualUpdateHint"),__name(showCheckFailure,"showCheckFailure"),__name(checkAction,"checkAction"),__name(performUpdateAction,"performUpdateAction"),__name(updateAction,"updateAction");var KP=new ke("update").description("Update Command Code to the latest version").option("--check-only","Check for updates without installing").allowUnknownOption().allowExcessArguments().action(updateAction);Ht(),pk(),gk();var YP=__name((e,t)=>`${_e.info} ${e}: ${de.cyan(t)}`,"formatInfoLine"),JP=__name(e=>de.bold(`${e}:`),"formatSectionHeader"),XP=__name(e=>de.red(e),"formatError"),ZP=__name(e=>e instanceof Error?e.message:"Unknown error","formatErrorMessage"),eI=__name(e=>["",JP("User Information"),YP("Name",e.name),YP("Email",e.email),YP("Username",e.userName)],"buildUserOutput"),tI=__name(e=>["",JP("Organization"),YP("Name",e.name),YP("Login",e.login)],"buildOrgOutput"),nI=__name(e=>{e.forEach(e=>console.log(e))},"printLines"),rI=__name((e,t)=>{nI(eI(e)),t&&nI(tI(t)),console.log("")},"displayUserInfo"),oI=__name(e=>null!==e&&e.length>0,"validateApiKey"),sI=__name(e=>e.success&&null!==e.user,"validateUserData");async function whoamiAction(){const e=xe("Fetching user information...").start();try{const t=await getAuthKey();oI(t)||(e.fail(XP('Not authenticated. Please login using "cmd auth login"')),process.exit(1));const n=await getAuthenticatedEntity();sI(n)||(e.fail(XP("Failed to fetch user info")),process.exit(1)),e.succeed("User information loaded"),rI(n.user,n.org)}catch(t){e.fail(XP(`Error: ${ZP(t)}`)),process.exit(1)}}__name(whoamiAction,"whoamiAction");var iI=new ke("whoami").description("Display current user information").allowUnknownOption().allowExcessArguments().action(whoamiAction);function normalizeGitUrl(e){let t=e.trim();const n=t.match(/^git@([^:]+):(.+?)(?:\.git)?$/);return n?`https://${n[1]}/${n[2]}`:(t=t.replace(/\.git$/,""),t)}function validateGitRepo(){try{if("true"!==M("git rev-parse --is-inside-work-tree",{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim())throw new Error("Not inside a git repository.")}catch{throw new Error("Sandbox requires a git repository with a GitHub remote.")}let e;try{e=M("git remote get-url origin",{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim()}catch{throw new Error("No GitHub remote found. Add one with: git remote add origin https://github.com/you/repo")}const t=normalizeGitUrl(e);let n;try{n=M("git branch --show-current",{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim()}catch{throw new Error("Failed to determine current branch.")}if(!n)throw new Error("Detached HEAD state. Please checkout a branch first.");if(!/^[\w./-]+$/.test(n))throw new Error("Branch name contains invalid characters. Please use a simpler branch name.");try{if(!M(`git ls-remote --heads origin ${n}`,{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim())throw new Error(`Branch "${n}" not found on remote. Push it first: git push -u origin ${n}`)}catch(e){if(e instanceof Error&&e.message.includes("not found on remote"))throw e;throw new Error(`Branch "${n}" not found on remote. Push it first: git push -u origin ${n}`)}return{repoUrl:t,branch:n,isClean:""===M("git status --porcelain",{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim()}}function getGitHubToken(){const e=process.env.GITHUB_TOKEN;if(e)return e;try{return M("gh auth token",{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim()}catch{throw new Error("GitHub authentication required.\nEither set GITHUB_TOKEN or run: gh auth login")}}Ht(),Ht(),Yt(),Xy(),iw(),en(),Fr(),Ht(),__name(normalizeGitUrl,"normalizeGitUrl"),__name(validateGitRepo,"validateGitRepo"),Ht(),__name(getGitHubToken,"getGitHubToken"),Ht(),iw(),pk(),Ht();var aI=["completed","failed","cancelled","timed_out"];function isTerminalStatus(e){return aI.includes(e)}__name(isTerminalStatus,"isTerminalStatus");var lI={setting_up:"Setting up sandbox...",cloning:"Cloning repository..."};function stopAllSpinners({state:e}){e.workingSpinner&&(e.workingSpinner.stop(),e.workingSpinner=null),e.currentSpinner&&(e.currentSpinner.stop(),e.currentSpinner=null)}function renderStatusEvent({event:e,state:t}){const n=e.data.status,r=lI[n],o="setup"===t.phase;if(t.isResume&&o&&!isTerminalStatus(n)&&"running"!==n)r&&t.workingSpinner&&(t.workingSpinner.text=r);else{if(r&&o&&(t.currentSpinner&&t.currentSpinner.succeed(),t.currentSpinner=xe({stream:process.stderr,text:r}).start()),"running"===n)return t.currentSpinner&&(t.currentSpinner.succeed(),t.currentSpinner=null),t.phase="running",void(t.workingSpinner||(t.workingSpinner=xe({stream:process.stderr}).start()));if("completed"===n){t.workingSpinner&&(t.workingSpinner.succeed("Session completed"),t.workingSpinner=null),t.currentSpinner&&(t.currentSpinner.succeed(),t.currentSpinner=null),t.phase="done";const n=e.data.prUrl;return void(n&&console.error(`PR: ${de.cyan(n)}`))}if("failed"===n){t.workingSpinner&&(t.workingSpinner.fail("Session failed"),t.workingSpinner=null),t.currentSpinner&&(t.currentSpinner.fail(),t.currentSpinner=null),t.phase="done";const n=e.data.message||"Unknown error";return void console.error(`${_e.cross} ${de.red(n)}`)}if("timed_out"===n)return t.workingSpinner&&(t.workingSpinner.fail("Session timed out"),t.workingSpinner=null),t.currentSpinner&&(t.currentSpinner.fail("Timed out"),t.currentSpinner=null),void(t.phase="done");"cancelled"===n&&(stopAllSpinners({state:t}),t.phase="done",console.error(`\n${de.yellow("Cancelled.")}`))}}function renderEvent({event:e,state:t}){if("status"!==e.type){if("pty"===e.type){const n=e.data.content;return void(n&&(t.workingSpinner&&t.workingSpinner.stop(),process.stdout.write(n),t.workingSpinner&&t.workingSpinner.start()))}if("error"===e.type){t.currentSpinner&&(t.currentSpinner.fail(),t.currentSpinner=null);const n=e.data.message;console.error(`${_e.cross} ${de.red(n)}`)}}else renderStatusEvent({event:e,state:t})}function setupInputHandling({callbacks:e}){const t=__name(t=>{3===t[0]?e.onCancel():4===t[0]&&e.onDetach()},"onStdinData"),n=process.rawListeners("SIGINT").slice();return process.removeAllListeners("SIGINT"),process.stdin.isTTY?(process.stdin.setRawMode(!0),process.stdin.resume(),process.stdin.on("data",t),process.on("SIGINT",()=>{})):process.on("SIGINT",()=>e.onCancel()),()=>{process.stdin.isTTY&&(process.stdin.removeListener("data",t),process.stdin.setRawMode(!1),process.stdin.pause()),process.removeAllListeners("SIGINT");for(const e of n)process.on("SIGINT",e)}}function setupResizeForwarding({ws:e}){const t=__name(()=>{e.readyState===WebSocket.OPEN&&e.send(JSON.stringify({action:"resize",cols:process.stdout.columns,rows:process.stdout.rows}))},"onResize");return process.stdout.on("resize",t),()=>process.stdout.removeListener("resize",t)}function sendTerminalSize({ws:e}){e.send(JSON.stringify({action:"resize",cols:process.stdout.columns||120,rows:process.stdout.rows||30}))}async function streamSession({sessionId:e,prompt:t,lastEventId:n=0,isResume:r=!1}){const o=getApiBaseUrl().replace(/^http/,"ws"),s=await getAuthKey();if(!s)throw new Error("Not authenticated. Run: cmd login");const i=new URLSearchParams({token:s,...n>0?{lastEventId:String(n)}:{}}),a=`${o}/alpha/sandbox/stream/${e}?${i.toString()}`;return new Promise((t,o)=>{const s=new WebSocket(a),i={currentSpinner:null,workingSpinner:null,phase:"setup",lastEventId:n,isResume:r};r&&(i.currentSpinner=xe({stream:process.stderr,text:"Reconnecting..."}).start());const l=__name(()=>{i.phase="done",stopAllSpinners({state:i}),s.close(),console.error(`\n${de.yellow("Detached.")} Session still running.`),console.error(`Resume with: ${de.cyan(`cmd --experimental sandbox --id ${e}`)}`),g(),t()},"detach"),u=__name(()=>{i.phase="done",stopAllSpinners({state:i}),s.readyState===WebSocket.OPEN&&s.send(JSON.stringify({action:"cancel"})),s.close(),console.error(`\n${de.yellow("Sandbox stopped.")}`),g(),t()},"cancelSandbox"),d=setupResizeForwarding({ws:s}),m=setupInputHandling({callbacks:{onCancel:u,onDetach:l}});process.once("SIGTERM",l);const g=__name(()=>{d(),m(),process.removeListener("SIGTERM",l)},"teardown");s.addEventListener("open",()=>{sendTerminalSize({ws:s}),i.currentSpinner&&(i.currentSpinner.stop(),i.currentSpinner=null),console.error(""),console.error(`${de.yellow("[Ctrl+C]")} ${de.dim("stop")} ${de.yellow("[Ctrl+D]")} ${de.dim("detach")}`),console.error(`${de.dim("Session:")} ${de.gray(e)}`),console.error(""),r&&(i.workingSpinner=xe({stream:process.stderr}).start())}),s.addEventListener("message",e=>{try{const n="string"==typeof e.data?e.data:e.data.toString(),r=JSON.parse(n);renderEvent({event:r,state:i}),void 0!==r.id&&(i.lastEventId=r.id),"status"===r.type&&isTerminalStatus(r.data.status)&&(s.close(),g(),t())}catch{}}),s.addEventListener("error",()=>{g(),i.currentSpinner&&(i.currentSpinner.fail("Connection error"),i.currentSpinner=null),o(new Error("WebSocket connection failed"))}),s.addEventListener("close",()=>{"done"!==i.phase&&(i.phase="done",stopAllSpinners({state:i}),g(),console.error(`\n${de.yellow("Disconnected.")} Session still running.`),console.error(`Resume with: ${de.cyan(`cmd --experimental sandbox --id ${e}`)}`),t())})})}function readLocalConfigFiles(){let e="",t="";try{e=E.readFileSync(getAuthFile(),"utf-8")}catch{}try{t=E.readFileSync(getConfigFile(),"utf-8")}catch{}return{auth:e,config:t}}async function askQuestion(e){const t=Xe.createInterface({input:process.stdin,output:process.stderr});return new Promise(n=>{t.question(e,e=>{t.close(),n(e)})})}async function startSandboxSession({repoUrl:e,branch:t,prompt:n,ghToken:r,isInternalTeam:o,configFiles:s}){return new Ly({baseUrl:getApiBaseUrl()}).post({endpoint:kt.ALPHA.SANDBOX.START,body:{repoUrl:e,branch:t,prompt:n,ghToken:r,isInternalTeam:o,configFiles:s}})}async function sandboxMode({prompt:e,resume:t}){t&&(await streamSession({sessionId:t,isResume:!0}),process.exit(0)),await ensureAuthenticated()||process.exit(1);const n=validateGitRepo();n.isClean||console.error(de.yellow("Warning: You have uncommitted changes. The sandbox clones from remote, so local changes won't be included."));const r=getGitHubToken(),o=isInternalTeamFlagPresent(),s=readLocalConfigFiles(),i=e||await askQuestion(`${de.bold("What do you want to do?")}\n${de.cyan(">")} `);if(!i.trim())return void console.error(de.yellow("No prompt provided. Aborting."));const a=i.trim().slice(0,$t.MAX_PROMPT_CHARS),l=xe({stream:process.stderr,text:"Starting sandbox session..."}).start();try{const e=await startSandboxSession({repoUrl:n.repoUrl,branch:n.branch,prompt:a,ghToken:r,isInternalTeam:o,configFiles:s});l.succeed("Sandbox started"),await streamSession({sessionId:e.sessionId,prompt:a}),process.exit(0)}catch(e){l.fail("Failed to start session");const t=e instanceof Error?e.message:"Unknown error";t.includes("401")||t.toLowerCase().includes("unauthorized")?console.error(de.red("Authentication failed. Try logging in again: cmd login")):console.error(de.red(t)),process.exit(1)}}function createSandboxCommand(){return new ke("sandbox").description("Run a task autonomously in a sandbox").argument("[prompt]","Task description").option("--id <sessionId>","Resume an existing sandbox session").enablePositionalOptions().action(async(e,t)=>{try{await sandboxMode({prompt:e,resume:t.id})}catch(e){const t=e instanceof Error?e.message:"Unknown error";console.error(de.red(t)),process.exit(1)}})}function validateSafeString(e,t){if(e.includes("..")||e.includes("\\"))throw new Error(`Invalid ${t}: path traversal sequences are not allowed.\nExpected format: owner/repo or owner/repo/path`);if(!/^[a-zA-Z0-9._/-]+$/.test(e))throw new Error(`Invalid ${t}: contains unsupported characters.\nOnly letters, numbers, hyphens, underscores, dots, and slashes are allowed.`)}function parseGitHubRepo(e){let t,n=e.replace(/^https?:\/\/github\.com\//,"");const r=n.lastIndexOf("@");r>0&&r<n.length-1&&(t=n.slice(r+1),n=n.slice(0,r),validateSafeString(t,"branch name"));const o=n.split("/");if(o.length<2)throw new Error("Invalid GitHub repository format. Expected: owner/repo or owner/repo/path");const[s,i,...a]=o;validateSafeString(s,"owner"),validateSafeString(i,"repository");const l=a.length>0?a.join("/"):void 0;return l&&validateSafeString(l,"path"),{owner:s,repo:i,path:l,branch:t}}function buildGigetSource(e){const{owner:t,repo:n,path:r,branch:o}=e;let s=`gh:${t}/${n}`;return r&&(s+=`/${r}`),o&&(s+=`#${o}`),s}async function fetchSkillFromGitHub(e){await cleanupStaleTempDirectories();const n=parseGitHubRepo(e),{owner:r,repo:o,path:s}=n;let i;if(s){const e=s.split("/").filter(Boolean);i=e[e.length-1]}else i=o;const a=t.join(w.tmpdir(),`commandcode-skill-${H()}`);await O.mkdir(a,{recursive:!0});try{const e=buildGigetSource(n),{downloadTemplate:s}=await import("giget");try{await s(e,{dir:a,force:!0,silent:!0})}catch(t){if(!isCorruptedArchiveError(t))throw t;await clearGigetCache(r,o),await s(e,{dir:a,force:!0,silent:!0})}const l=t.join(a,"SKILL.md"),u=t.join(a,"skill.md");let d=!1;try{await O.access(l),d=!0}catch{}if(!d)try{await O.access(u),d=!0}catch{}if(!d)throw new Error(`SKILL.md not found in ${e}. Make sure the repository contains a SKILL.md file.`);return{tempDir:a,skillName:i}}catch(e){if(await O.rm(a,{recursive:!0,force:!0}).catch(()=>{}),e instanceof Error&&e.message.includes("SKILL.md not found"))throw e;throw wrapFetchError(e,r,o)}}async function discoverSkillsInRepo(e,t){const n=parseGitHubRepo(e),{owner:r,repo:o,path:s,branch:i}=n,{keepTempDir:a=!1}=t||{},{discoverSkillsLocally:l}=await Promise.resolve().then(()=>(Ck(),Ek)),u=await l({owner:r,repo:o,path:s,branch:i,keepTempDir:a});if(0===u.skills.length)throw new Error(`No skills found in repository ${r}/${o}${s?` at path "${s}"`:""}. Ensure the repository contains SKILL.md files.`);return u}async function resolveSkillMdPath(e){const n=t.join(e,"SKILL.md");try{return await O.access(n),n}catch{}const r=t.join(e,"skill.md");try{return await O.access(r),r}catch{}throw new Error(`SKILL.md not found in ${e}`)}function validateSkillName(e){const t=e.trim();if(!t||0===t.length)throw new Error("Invalid skill name: name cannot be empty");if(t.includes("/")||t.includes("\\"))throw new Error(`Invalid skill name: "${e}". Skill names cannot contain path separators (/ or \\).`);if(t.includes(".."))throw new Error(`Invalid skill name: "${e}". Skill names cannot contain parent directory references (..).`);if(t.startsWith("."))throw new Error(`Invalid skill name: "${e}". Skill names cannot start with a dot.`);if(!/^[a-z0-9-]+$/.test(t))throw new Error(`Invalid skill name: "${e}". Skill names must contain only lowercase letters, numbers, and hyphens.`);return t}async function validateSkillContent(e){const t=await resolveSkillMdPath(e),n=await O.readFile(t,"utf-8"),{data:r}=Me(n),o=lh.parse(r);return{name:validateSkillName(o.name),description:o.description}}async function skillExists(e){const{skillName:n,location:r}=e,o="global"===r?getGlobalSkillsDir():getProjectSkillsDir(),s=t.join(o,n);try{return await O.access(s),!0}catch{return!1}}async function discoverSkills(e,t){return discoverSkillsInRepo(e,t)}async function installSkill(e){const{repoInput:n,options:r={}}=e,{global:o=!1,force:s=!1,skillName:i,discoveredSkill:a,cachedTempDir:l}=r;let u,d,m=n;if(i){let e;if(a)e=a;else{const t=await discoverSkillsInRepo(n);if(0===t.skills.length)throw new Error(`No skills found in repository: ${n}`);const r=t.skills.find(e=>e.name.toLowerCase()===i.toLowerCase());if(!r){const e=t.skills.map(e=>e.name).join(", ");throw new Error(`Skill "${i}" not found in repository. Available skills: ${e}`)}e=r}const t=parseGitHubRepo(n),r=[t.path,e.path&&"."!==e.path?e.path:void 0].filter(Boolean).join("/"),o=r?`${t.owner}/${t.repo}/${r}`:`${t.owner}/${t.repo}`;m=t.branch?`${o}@${t.branch}`:o}if(l&&a){u=a.path&&"."!==a.path?t.join(l,a.path):l,d=!1;try{await resolveSkillMdPath(u)}catch{const e=a.path&&"."!==a.path?`at ${a.path}`:"at root";throw new Error(`SKILL.md not found in cached directory ${e}. Make sure the repository contains a SKILL.md file.`)}}else u=(await fetchSkillFromGitHub(m)).tempDir,d=!0;try{const{name:e,description:n}=await validateSkillContent(u),r=e,i=o?"global":"project",a="global"===i?getGlobalSkillsDir():getProjectSkillsDir(),l=await skillExists({skillName:r,location:i});if(l&&!s)throw new Error(`Skill "${r}" already exists in ${"global"===i?"~/.commandcode/skills/":".commandcode/skills/"}. Use --force to overwrite.`);await O.mkdir(a,{recursive:!0});const d=t.join(a,r),{randomUUID:m}=await import("crypto"),g=t.join(a,`.${r}.tmp.${m()}`);try{await O.cp(u,g,{recursive:!0,force:!0,dereference:!1}),l&&s&&await O.rm(d,{recursive:!0,force:!0}),await O.rename(g,d)}catch(e){if(await O.rm(g,{recursive:!0,force:!0}).catch(()=>{}),e instanceof Error&&"code"in e&&("EEXIST"===e.code||"ENOTEMPTY"===e.code))throw new Error(`Skill "${r}" was created by another process during installation. Use --force to overwrite.`);throw e}let h;try{h=await resolveSkillMdPath(d)}catch{h=t.join(d,"SKILL.md")}return{name:r,description:n,location:i,path:h}}finally{d&&await O.rm(u,{recursive:!0,force:!0}).catch(()=>{})}}async function removeSkill(e){const{global:n=!1}=e,r=validateSkillName(e.skillName),o=n?"global":"project",s="global"===o?getGlobalSkillsDir():getProjectSkillsDir(),i=t.join(s,r);if(!await skillExists({skillName:r,location:o}))throw new Error(`Skill "${r}" not found in ${"global"===o?"global (~/.commandcode/skills/)":"project (.commandcode/skills/)"} skills.${"global"===o?"":" Use -g/--global to check global skills."}`);await O.rm(i,{recursive:!0,force:!0})}async function listSkills(){const{global:e,project:t}=await loadAllSkillSummaries();return{global:e.map(e=>({name:e.name,description:e.description,location:"global",path:e.filePath})),project:t.map(e=>({name:e.name,description:e.description,location:"project",path:e.filePath}))}}__name(stopAllSpinners,"stopAllSpinners"),__name(renderStatusEvent,"renderStatusEvent"),__name(renderEvent,"renderEvent"),__name(setupInputHandling,"setupInputHandling"),__name(setupResizeForwarding,"setupResizeForwarding"),__name(sendTerminalSize,"sendTerminalSize"),__name(streamSession,"streamSession"),__name(readLocalConfigFiles,"readLocalConfigFiles"),__name(askQuestion,"askQuestion"),__name(startSandboxSession,"startSandboxSession"),__name(sandboxMode,"sandboxMode"),__name(createSandboxCommand,"createSandboxCommand"),Pr(),Ht(),Ht(),Ht(),Ht(),bk(),__name(validateSafeString,"validateSafeString"),__name(parseGitHubRepo,"parseGitHubRepo"),__name(buildGigetSource,"buildGigetSource"),__name(fetchSkillFromGitHub,"fetchSkillFromGitHub"),__name(discoverSkillsInRepo,"discoverSkillsInRepo"),bw(),vh(),__name(resolveSkillMdPath,"resolveSkillMdPath"),__name(validateSkillName,"validateSkillName"),__name(validateSkillContent,"validateSkillContent"),__name(skillExists,"skillExists"),__name(discoverSkills,"discoverSkills"),__name(installSkill,"installSkill"),__name(removeSkill,"removeSkill"),__name(listSkills,"listSkills"),Yt();var cI=[`${de.dim("Usage:")}`,` ${de.cyan("cmd skills add")} ${de.white("<owner/repo>")}`,"",`${de.dim("Examples:")}`,` ${de.cyan("cmd skills add")} ${de.white("acme/my-skills")} ${de.dim("# single-skill repo")}`,` ${de.cyan("cmd skills add")} ${de.white("acme/skills/path/to/skill")} ${de.dim("# specific path in repo")}`,` ${de.cyan("cmd skills add")} ${de.white("acme/multi-skills -s my-skill")} ${de.dim("# pick one from multi-skill repo")}`,` ${de.cyan("cmd skills add")} ${de.white("acme/repo@branch")} ${de.dim("# specific branch")}`,` ${de.cyan("cmd skills add")} ${de.white("acme/repo --global")} ${de.dim("# install to ~/.commandcode/skills/")}`],uI=__name((e,t)=>`${de.green(_e.tick)} Installed ${de.cyan(e)} ${de.dim(`${_e.arrowRight} ${t}/`)}`,"formatInstalled"),dI=__name(e=>`${de.red(_e.cross)} ${e}`,"formatError");async function cleanupAndExit(e,t){e&&await F(e,{recursive:!0,force:!0}).catch(()=>{}),process.exit(t)}function validateRepoFormat(e){(e.startsWith(".")||e.startsWith("/")||e.startsWith("~"))&&(console.error(dI("Local paths are not supported. Skills must be installed from GitHub.")),console.log(""),cI.forEach(e=>console.log(e)),process.exit(1));const t=e.replace(/^https?:\/\/github\.com\//,""),n=t.lastIndexOf("@");(n>0?t.slice(0,n):t).split("/").filter(Boolean).length<2&&(console.error(dI(`Invalid repository: "${e}"`)),console.log(""),console.log(`Expected format: ${de.cyan("owner/repo")} or ${de.cyan("owner/repo/path")}`),console.log(""),cI.forEach(e=>console.log(e)),process.exit(1))}async function addAction(e,t){const n=process.stdout.isTTY&&process.stdin.isTTY,r=t.global?"~/.commandcode/skills":".commandcode/skills";let o;validateRepoFormat(e);const s=xe({text:`Fetching ${de.cyan(e)}...`,color:"cyan"});try{let i=[];s.start();const a=await discoverSkills(e,{keepTempDir:!0}),{skills:l,tempDir:u}=a;if(o=u,s.stop(),0===l.length&&(console.error(dI(`No skills found in ${de.cyan(e)}`)),console.log(de.dim("The repository must contain at least one SKILL.md file.")),await cleanupAndExit(o,1)),t.skill){const n=l.find(e=>e.name.toLowerCase()===t.skill.toLowerCase());n||(console.error(dI(`Skill "${t.skill}" not found in ${de.cyan(e)}`)),console.log(""),console.log(de.dim("Available skills:")),l.forEach(e=>console.log(` ${de.cyan(e.name)}`)),await cleanupAndExit(o,1)),i=[n]}else if(1===l.length)i=[l[0]];else if(n){const t=await Be({message:`Select skills to install from ${e}`,options:l.map(e=>({value:e.name,label:e.name})),required:!0});"symbol"==typeof t&&(console.log(de.dim("Cancelled")),await cleanupAndExit(o,0));const n=t;i=l.filter(e=>n.includes(e.name))}else i=l;let d=0;for(const n of i)try{const s=xe({text:`Installing ${de.cyan(n.name)}...`,color:"cyan"});s.start();const i=await installSkill({repoInput:e,options:{global:t.global,force:t.force,skillName:n.name,discoveredSkill:n,cachedTempDir:o}});s.stop(),console.log(uI(i.name,r))}catch(e){d++;const t=e instanceof Error?e.message:String(e);console.error(dI(`Failed to install "${n.name}"`)),console.log(de.dim(` ${t}`))}await cleanupAndExit(o,d>0?1:0)}catch(e){s.stop();const t=e instanceof Error?e.message:String(e);console.error(dI(t)),await cleanupAndExit(o,1)}}__name(cleanupAndExit,"cleanupAndExit"),__name(validateRepoFormat,"validateRepoFormat"),__name(addAction,"addAction");var mI=new ke("add").description("Install a skill from a GitHub repository").argument("<repo>","GitHub repository (owner/repo or owner/repo/path)").option("-g, --global","Install to global skills (~/.commandcode/skills/)").option("-f, --force","Overwrite if skill already exists").option("-s, --skill <name>","Specific skill name to install from repo").addHelpText("after",`\n${cI.join("\n")}`).configureOutput({outputError:__name((e,t)=>{e.includes("missing required argument")?(console.error(dI("No repository specified.")),console.log(""),cI.forEach(e=>console.log(e))):t(e)},"outputError")}).action(addAction);Ht(),Yt();var pI=__name((e,t)=>`${de.green(_e.tick)} Removed ${de.cyan(e)} from ${t} skills`,"formatRemoved"),gI=__name(e=>`${de.red(_e.cross)} ${e}`,"formatError");function validateSkillNameEarly(e){return e.includes("/")||e.includes("\\")?`"${e}" is not a valid skill name — it cannot contain path separators.`:e.includes("..")?`"${e}" is not a valid skill name — it cannot contain "..".`:e.startsWith(".")?`"${e}" is not a valid skill name — it cannot start with a dot.`:/^[a-z0-9-]+$/.test(e.trim())?null:`"${e}" is not a valid skill name — use only lowercase letters, numbers, and hyphens.`}async function removeAction(e,t){try{const n=process.stdout.isTTY&&process.stdin.isTTY,r=t.global?"global":"project",o=validateSkillNameEarly(e);if(o&&(console.error(gI(o)),console.log(de.dim(`Run ${de.cyan("cmd skills list")} to see installed skills.`)),process.exit(1)),!t.yes&&n){const t=await Ue({message:`Remove ${de.cyan(e)} from ${r} skills?`});"symbol"!=typeof t&&t||(console.log(de.dim("Cancelled")),process.exit(0))}await removeSkill({skillName:e,global:t.global}),console.log(pI(e,r)),process.exit(0)}catch(n){const r=n instanceof Error?n.message:"Failed to remove skill";r.includes("not found")?(console.error(gI(`Skill "${e}" not found in ${t.global?"global":"project"} skills`)),t.global||console.log(de.dim(`Try ${de.cyan(`cmd skills remove ${e} --global`)} to check global skills.`)),console.log(de.dim(`Run ${de.cyan("cmd skills list")} to see installed skills.`))):console.error(gI(r)),process.exit(1)}}__name(validateSkillNameEarly,"validateSkillNameEarly"),__name(removeAction,"removeAction");var hI=new ke("remove").description("Remove an installed skill").argument("<skill-name>","Name of the skill to remove").option("-g, --global","Remove from global skills (~/.commandcode/skills/)").option("-y, --yes","Skip confirmation prompt").action(removeAction);Ht(),bw(),Wv(),Yt();var fI=__name((e,t)=>{const n=t.length>60?t.substring(0,57)+"...":t;return` ${de.cyan(e)} ${de.dim(`· ${n}`)}`},"formatSkillLine"),yI=__name((e,t)=>`${de.bold(de.white(e))} ${de.dim(`(${t})`)}`,"formatSectionHeader"),wI=__name(()=>["",de.dim("No skills installed."),"",de.dim("Looking in:"),de.dim(` ${getGlobalSkillsDir()} ${de.white("(global)")}`),de.dim(` ${getProjectSkillsDir()} ${de.white("(project)")}`),de.dim(` ${getGlobalAgentsCompatSkillsDir()} ${de.white("(global, .agents)")}`),de.dim(` ${getProjectAgentsCompatSkillsDir()} ${de.white("(project, .agents)")}`),"",`Install a skill: ${de.cyan("cmd skills add")} ${de.dim("<owner/repo>")}`,""],"formatEmptyHint"),SI=__name(e=>{e.forEach(e=>console.log(e))},"printLines");async function listAction(){try{const{global:e,project:t}=await listSkills(),n=e.length+t.length;0===n&&(SI(wI()),process.exit(0)),console.log(""),console.log(heading({text:"Skills",sub:de.dim(`${n} installed`)})),t.length>0&&(console.log(""),console.log(yI("Project",t.length)),t.forEach(e=>{console.log(fI(e.name,e.description))})),e.length>0&&(console.log(""),console.log(yI("Global",e.length)),e.forEach(e=>{console.log(fI(e.name,e.description))})),console.log(""),process.exit(0)}catch(e){const t=e instanceof Error?e.message:"Unknown error";console.error(`${de.red(_e.cross)} Failed to list skills: ${t}`),process.exit(1)}}__name(listAction,"listAction");var bI=new ke("list").description("List all installed skills").action(listAction),EI=new ke("skills").description("Manage skills from GitHub repositories").addCommand(mI).addCommand(hI).addCommand(bI);handleUnhandledErrors(),setupTelemetry(),await preRun();var CI=createProgram();CI.action(interactiveModeAction),CI.addCommand(tP),CI.addCommand(nP),CI.addCommand(iI),CI.addCommand(KP),CI.addCommand(eP),CI.addCommand(createTasteCommand()),CI.addCommand(createMcpCommand()),CI.addCommand(rP),CI.addCommand(Io),CI.addCommand(tk),CI.addCommand(uk),CI.addCommand(EI),isExperimentalEnabled()&&CI.addCommand(createSandboxCommand()),setupCommanderHooks(CI),CI.parse();
293
+ `,v_=getMaxLineWidth(C_),k_=S_,T_=__name(e=>{const t=e??getTerminalWidth();return t>=w_?"full":t>=k_?"compact":"minimal"},"getHeaderLayout");dv(),Ht(),hr();var __=__name(({children:e})=>{const t=[];let n="",r=!0;const o=__name(()=>{0!==n.length&&(t.push({text:n,panel:r}),n="")},"flush");for(const t of e){const e="░"===t;0===n.length?r=e:e!==r&&(o(),r=e),n+=t}return o(),K.createElement(re,null,t.map((e,t)=>K.createElement(re,{key:t,color:e.panel?mr.BG:mr.TEXT},e.text)))},"CommandLogoBanner");Ht(),hr();var x_=__name(({title:e,hashPrefix:t=!1,subPrefix:n=!1,suffix:r,padding:o=0,titleColor:s=zn.GRAY,dividerChar:i="─",dividerColor:a=zn.GRAY,boxProps:l})=>{const u=Math.max(0,(process.stdout.columns??80)-2*o),d=t?`# ${i}${i} `:n?`${i}${i} `:"",m=e?`${e} `:"",g=r?` ${r}`:"",h=d.length+m.length+g.length,f=i.repeat(Math.max(0,u-h));return K.createElement(ne,{paddingLeft:o,paddingRight:o,marginBottom:1,...l},(t||n)&&K.createElement(re,{color:a},d),e&&K.createElement(re,{color:s},m),K.createElement(re,{color:a},f),r&&K.createElement(re,{color:zn.DIM},g))},"Divider");Iv(),hr(),Ht(),hr();var A_=[{type:"user",text:"I always prefer pnpm",duration:2e3},{type:"learned",text:"Learned: pnpm (95% preference)",details:".commandcode/taste/taste.md",duration:2e3},{type:"user",text:"I prefer commander over meow",duration:2e3},{type:"updated",text:"Updated: commander boosted (60% → 95%), meow adjusted (90% → 35%)",details:".commandcode/taste/cli/taste.md",duration:2e3},{type:"user",text:"I prefer TypeScript for Node CLIs",duration:2e3},{type:"learned",text:"Learned: TypeScript for CLIs (90% preference)",details:".commandcode/taste/cli/taste.md",duration:2e3}],P_=__name(({onComplete:e,onExit:t})=>{const[n,r]=J(0),[o,s]=J(!1),i=n>=A_.length;return Z(()=>{if(n>=A_.length)return;if(o)return;const e=A_[n],t=setTimeout(()=>{r(e=>Math.min(e+1,A_.length))},e.duration);return()=>clearTimeout(t)},[n,o]),ie((n,o)=>{""===n||o.ctrl&&"c"===n?t?t():e():o.escape?e():i?(o.return||" "===n)&&e():" "===n?s(e=>!e):o.return&&r(e=>Math.min(e+1,A_.length))}),K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,K.createElement(re,{bold:!0},"Meet Your Coding Taste")),K.createElement(ne,null,K.createElement(re,{color:zn.DIM},"Command Code learns your coding style as you work.")),K.createElement(ne,null,K.createElement(re,{color:zn.DIM},"Here's how your preferences evolve in real-time:")),K.createElement(ne,{flexDirection:"column",marginY:1},A_.slice(0,n).map((e,t)=>"user"===e.type?K.createElement(ne,{key:t},K.createElement(re,null,_e.pointer," ",e.text)):K.createElement(ne,{key:t,flexDirection:"column",marginBottom:1,marginLeft:1},K.createElement(ne,null,K.createElement(re,{color:zn.DIM},"⎿ "),K.createElement(re,{color:Gn.TEXT},e.text)),e.details&&K.createElement(ne,{marginLeft:3},K.createElement(re,{color:zn.DIM},"Saved(",e.details,")"))))),i?K.createElement(ne,{flexDirection:"column",marginY:1},K.createElement(ne,null,K.createElement(re,{bold:!0,color:Gn.TEXT},"Demo Complete!")),K.createElement(ne,null,K.createElement(re,null,"Command Code will now use these preferences to generate")),K.createElement(ne,null,K.createElement(re,null,"better suggestions tailored to your coding style. The")),K.createElement(ne,null,K.createElement(re,null,"more you code, the smarter it gets.")),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Press Enter to get started →"))):K.createElement(ne,null,K.createElement(re,{color:zn.DIM},"[SPACE: pause] [ENTER: next] [ESC: skip]"+(o?" (paused)":""))))},"TasteDemoComponent"),I_=__name(({onClose:e,onExit:t})=>{const[n,r]=J(cv.getEvents()),[o,s]=J(0);ie((n,r)=>{""===n||r.ctrl&&"c"===n?t():r.ctrl&&"t"===n&&e()},{isActive:!0}),Z(()=>{const e=__name(()=>{r(cv.getEvents())},"handleNewEvent"),t=__name(()=>{r([])},"handleCleared");return cv.on("new-event",e),cv.on("cleared",t),()=>{cv.off("new-event",e),cv.off("cleared",t)}},[]),Z(()=>{const e=__name(()=>{xv(),s(e=>e+1)},"handleResize");return process.stdout.on("resize",e),()=>{process.stdout.off("resize",e)}},[]);const i=__name(e=>["learned","refactored"].includes(e),"isLearningEvent"),a=__name(e=>{const t=e.match(/^(learned|upgraded|downgraded|refactored|moved):\s*(.*)$/i);if(t){const e=t[1].toLowerCase();let n=t[2];const r=n.match(/^(.+?)\.?\s+Confidence:\s*(\d+\.?\d*)$/);let o=n,s=null;if(r){o=r[1].trim();const e=(100*parseFloat(r[2])).toFixed(2);s=`confidence: ${parseFloat(e).toString()}%`}const i={learned:"Learned",upgraded:"Reinforced",downgraded:"Downgraded",refactored:"Refactored",moved:"Moved"}[e]||e.charAt(0).toUpperCase()+e.slice(1);return{type:e,label:i,content:o,confidence:s}}return{type:null,label:null,content:e,confidence:null}},"formatLearningMessage"),l=__name(e=>{const t=e.match(/^(.+?)\s*\((\d+)%\s*(?:→|->)\s*(\d+)%\)$/);if(!t)return null;const n=t[1].trim(),r=parseInt(t[2],10),o=parseInt(t[3],10);return{text:n,oldPercent:r,newPercent:o,diff:o-r}},"parsePercentageChange"),u=__name(e=>{if(!e)return null;const t=e.match(/moved to (.+)/);if(!t)return null;const n=t[1],r=n.split("/"),o=r[r.length-1];return{category:r.slice(0,-1).join("/"),oldPath:o,newPath:n,fullPath:`.commandcode/taste/${n}`}},"formatMovedDetails"),d=ee(()=>(process.stdout.rows??24)-1,[o]);return K.createElement(ne,{flexDirection:"column",width:"100%",height:d,justifyContent:"flex-start",alignItems:"flex-start",padding:0,margin:0},K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(__,null,b_())),K.createElement(x_,{hashPrefix:!0,title:"Taste Feed",titleColor:"white",suffix:"ctrl+t to close"}),K.createElement(ne,{flexDirection:"column"},0===n.length?K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(ne,null,K.createElement(re,null,"Start using Command Code and it will begin recording your coding taste.")),K.createElement(ne,null,K.createElement(re,{color:zn.DIM},"Your preferences, patterns, and style will appear here in real-time."))),K.createElement(ce,{count:2}),K.createElement(x_,{title:"DEMO",titleColor:"white",subPrefix:!0}),K.createElement(P_,{onComplete:()=>{e()},onExit:t})):K.createElement(ne,{flexDirection:"column"},n.map(e=>{if(i(e.type)){const{type:t,label:n,content:r,confidence:o}=a(e.message),s="moved"===t?u(e.details):null,i="upgraded"===t||"downgraded"===t?l(r):null;return K.createElement(ne,{key:e.id,marginBottom:1},K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:Gn.BADGE_BG,color:Gn.BADGE_FG,bold:!0},`${Qk}${n}${Qk}`)),s?K.createElement(re,{color:zn.DIM}," ","(",s.fullPath,")"):e.details?K.createElement(re,{color:zn.DIM}," ","(",e.details,")"):null),K.createElement(ne,{marginLeft:1},K.createElement(re,{color:zn.DIM},"⎿"," "),s?K.createElement(K.Fragment,null,K.createElement(re,null," ",s.category," ","package ("),K.createElement(re,{color:zn.DIM},s.oldPath),K.createElement(re,null," ",_e.arrowRight," ",s.newPath),K.createElement(re,null,")")):i?K.createElement(K.Fragment,null,K.createElement(re,null," ",i.text," ","("),K.createElement(re,{color:zn.DIM},"confidence:"," "),K.createElement(re,{color:zn.DIM},i.oldPercent,"%"),K.createElement(re,null," ",_e.arrowRight," "),K.createElement(re,{color:i.diff>0?zn.GREEN:zn.RED},i.newPercent,"%"),K.createElement(re,null,")")):K.createElement(K.Fragment,null,K.createElement(re,null," ",r),o&&K.createElement(re,{color:zn.DIM}," ","(",o,")")))))}return K.createElement(ne,{key:e.id,marginBottom:1},K.createElement(re,{color:zn.DIM},_e.pointerSmall," ",e.message))}))))},"LearningFeedFull");function LearningView({setShowLearningFeed:e,setStaticKey:t,onExit:n}){return K.createElement(I_,{onClose:()=>{xv(),e(!1),t(e=>e+1)},onExit:n})}__name(LearningView,"LearningView"),Ht(),hr(),Ht(),hr(),Iv(),Pr();var N_=__name(({onClose:e,onSettingsChange:t,staticKey:n})=>{const[r,o]=J(!1),[s,i]=J(!0);Z(()=>{__name(async()=>{try{const e=await isTasteLearningEnabled();o(e)}catch(e){}finally{i(!1)}},"loadSettings")()},[]),ie((t,n)=>{if(!n.return&&" "!==t)return n.escape?(xv(),void e()):void 0;a()});const a=__name(async()=>{const e=!r;o(e);try{await setTasteLearning({tasteLearning:e}),t?.()}catch(t){o(!e)}},"toggleTasteLearning");return s?K.createElement(ne,{key:n,borderStyle:"single",borderColor:zn.BLUE,padding:1,flexDirection:"column"},K.createElement(re,{color:zn.BLUE,bold:!0},"Taste Settings"),K.createElement(re,{color:zn.DIM},"Loading configuration...")):K.createElement(ne,{key:n,borderStyle:"single",borderColor:zn.GRAY,padding:1,flexDirection:"column"},K.createElement(re,{bold:!0},"Taste Learning"),K.createElement(re,{color:zn.DIM},"Configure taste learning preferences for this project"),K.createElement(ne,{marginTop:1}),K.createElement(ne,{justifyContent:"space-between"},K.createElement(re,null,"Taste learning",K.createElement(re,{color:zn.DIM}," - Learn from your interactions")),K.createElement(re,{color:r?zn.GREEN:zn.GRAY},r?"enabled":"disabled")),K.createElement(ne,{marginTop:1}),K.createElement(re,{color:zn.DIM},"Taste data stored in .commandcode/taste/taste.md"),K.createElement(re,{color:zn.DIM},"Enter/Space to toggle • Esc to close"))},"TasteConfig");function TasteConfigView({staticKey:e,setShowTasteConfig:t,loadTasteStatus:n}){return K.createElement(K.Fragment,null,K.createElement(XT,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(ne,{marginBottom:1},K.createElement(re,{color:zn.DIM},"Press Esc to return to conversation")),K.createElement(N_,{onClose:()=>t(!1),onSettingsChange:n,staticKey:e})))}__name(TasteConfigView,"TasteConfigView"),Ht(),Ht(),Yt(),kw(),Iv(),hr();var R_=__name(e=>Math.ceil(e.length/4),"estimateTokens"),M_=__name(e=>e.includes("/.agents/skills/")||e.includes("\\.agents\\skills\\"),"isAgentsSkill"),$_=__name(({onClose:e})=>{const[t,n]=J([]),[r,o]=J(!0),[s,i]=J(null),[a,l]=J(0);Z(()=>{__name(async()=>{try{const{global:e,project:t}=await loadAllSkillSummaries(),r=[...e.map(e=>({label:e.name,value:e.filePath,location:"user",description:e.description,filePath:e.filePath})),...t.map(e=>({label:e.name,value:e.filePath,location:"project",description:e.description,filePath:e.filePath}))];n(r)}catch(e){i(e instanceof Error?e.message:"Failed to load skills")}finally{o(!1)}},"loadSkills")()},[]);const u=t.filter(e=>"project"===e.location),d=t.filter(e=>"user"===e.location),m=[...u,...d],g=__name(async t=>{try{await it([{file:t.filePath,line:1}]),xv(),e()}catch(e){e instanceof Error&&e.message.includes("$EDITOR environment variable")?i(h()):i(e instanceof Error?e.message:"Failed to open skill in editor")}},"handleSelectSkill");ie((t,n)=>{if(n.escape)return xv(),void e();if(n.upArrow)l(e=>Math.max(0,e-1));else if(n.downArrow)l(e=>Math.min(m.length-1,e+1));else if(n.return){const e=m[a];e&&g(e)}});const h=__name(()=>{const e=process.platform;return"win32"===e?'No editor found. Set $EDITOR: setx EDITOR "code"':"No editor found. Set $EDITOR: echo 'export EDITOR=\"code\"' >> "+("darwin"===e?"~/.zshrc":"~/.bashrc")},"getEditorSetupMessage");return r?K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(re,{color:Wn,bold:!0},"Agent Skills"),K.createElement(re,{color:zn.DIM},"Loading skills...")):s?K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(re,{color:zn.RED,bold:!0},"Agent Skills"),K.createElement(re,{color:zn.DIM},s),K.createElement(ne,{marginTop:1}),K.createElement(re,{color:zn.DIM},"Press ",K.createElement(re,{bold:!0},"Esc")," to close")):0===t.length?K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(re,{color:Wn,bold:!0},"Agent Skills"),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:zn.DIM},"No skills found")),K.createElement(re,{color:zn.DIM},"Create skills in:"),K.createElement(re,{color:zn.DIM}," ","~/",".commandcode","/","skills","/ (user)"),K.createElement(re,{color:zn.DIM}," ","~/.agents/","skills","/ (user, .agents)"),K.createElement(re,{color:zn.DIM}," ",".commandcode","/","skills","/ (project)"),K.createElement(re,{color:zn.DIM}," ",".agents/","skills","/ (project, .agents)"),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Press ",K.createElement(re,{bold:!0},"Esc")," to close"))):K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:Wn,bold:!0},"Skills"," "),K.createElement(re,{color:zn.DIM},m.length," skills")),u.length>0&&K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(ne,null,K.createElement(re,{color:er,bold:!0},"Project skills"," "),K.createElement(re,{color:er},"(",".commandcode","/","skills"," or .agents/","skills",")")),u.map((e,t)=>{const n=a===t,r=M_(e.filePath);return K.createElement(ne,{key:e.value},K.createElement(re,{color:n?zn.GREEN:zn.WHITE},e.label),r&&K.createElement(re,{color:zn.DIM}," [.agents]"),K.createElement(re,{color:zn.DIM}," · ~",R_(e.description)," description tokens"))})),d.length>0&&K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(ne,null,K.createElement(re,{color:er,bold:!0},"User skills"," "),K.createElement(re,{color:er},"(~/",".commandcode","/","skills"," or ~/.agents/","skills",")")),d.map((e,t)=>{const n=a===u.length+t,r=M_(e.filePath);return K.createElement(ne,{key:e.value},K.createElement(re,{color:n?zn.GREEN:zn.WHITE},e.label),r&&K.createElement(re,{color:zn.DIM}," [.agents]"),K.createElement(re,{color:zn.DIM}," · ~",R_(e.description)," description tokens"))})),K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(re,{dimColor:!0},"Add skills: ",K.createElement(re,{color:zn.CYAN},"cmd skills add ","<owner/repo>")),K.createElement(re,{color:zn.DIM},"Press ",K.createElement(re,{bold:!0},"Esc")," to close")))},"SkillsConfig");function SkillsConfigView({staticKey:e,setShowSkillsConfig:t}){return K.createElement(K.Fragment,null,K.createElement(XT,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement($_,{onClose:()=>t(!1),staticKey:e})))}function useTerminalWidth(){const{stdout:e}=se(),[t,n]=J(()=>e.columns??80);return Z(()=>{const t=__name(()=>n(e.columns??80),"onResize");return e.on("resize",t),()=>{e.off("resize",t)}},[e]),t}function getUsageColor(e){return e>=80?zn.RED:e>=50?zn.YELLOW:zn.GREEN}function buildProgressBar({percentage:e,width:t}){const n=Math.max(0,Math.min(100,e)),r=Math.round(n/100*t),o=t-r;return{filled:"━".repeat(r),empty:"━".repeat(o)}}__name(SkillsConfigView,"SkillsConfigView"),Ht(),Ht(),hr(),Ir(),Ht(),__name(useTerminalWidth,"useTerminalWidth"),Ht(),hr(),__name(getUsageColor,"getUsageColor"),__name(buildProgressBar,"buildProgressBar"),Iv();var L_="https://commandcode.ai/settings/usage";function getLayoutSizes({terminalWidth:e}){return e<50?{labelWidth:14,progressBarWidth:Math.max(10,e-10),showTwoColumn:!1}:e<70?{labelWidth:16,progressBarWidth:Math.max(15,e-15),showTwoColumn:!1}:{labelWidth:22,progressBarWidth:Math.min(30,e-15),showTwoColumn:!0}}function getSuccessColor(e){return e>=90?zn.GREEN:e>=70?zn.YELLOW:zn.RED}function getDaysColor(e){if(null!==e)return e<3?zn.RED:e<7?zn.YELLOW:void 0}__name(getLayoutSizes,"getLayoutSizes"),__name(getSuccessColor,"getSuccessColor"),__name(getDaysColor,"getDaysColor");var D_=__name(({plan:e,status:t})=>K.createElement(ne,{marginBottom:0},K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:zn.BLUE,color:"#f4f4f4",bold:!0},`${Qk}USAGE${Qk}`)),e&&K.createElement(K.Fragment,null,K.createElement(re,null," "),K.createElement(re,{color:zn.GRAY},e.name)),t&&K.createElement(K.Fragment,null,K.createElement(re,{color:zn.DIM}," · "),K.createElement(re,{color:"active"===t?zn.GREEN:zn.YELLOW},t))),"UsageBadge"),O_=__name(({label:e,labelWidth:t,children:n})=>K.createElement(re,null,K.createElement(re,{dimColor:!0},e.padEnd(t)),n),"Row"),F_=__name(({showRetry:e})=>K.createElement(ne,{marginTop:1},e&&K.createElement(re,{color:zn.DIM},K.createElement(re,{bold:!0},"r")," to retry · "),K.createElement(re,{color:zn.DIM},"Press ",K.createElement(re,{bold:!0},"Esc")," to close")),"UsageFooter");function getCallsLabel(e){if(!e)return"Calls";const t=new Date(e);return Number.isNaN(t.getTime())?"Calls":`Calls (since ${t.toLocaleDateString("en-US",{month:"short",day:"numeric"})})`}function buildDataRows({credits:e,summary:t,sub:n}){const r=e?.freeCredits??0,o=getCallsLabel(n?.currentPeriodStart);return{left:[{label:"Purchased",value:K.createElement(re,null,formatCredits(e?.purchasedCredits??0))},...r>0?[{label:"Free",value:K.createElement(re,null,formatCredits(r))}]:[],{label:"Renews",value:K.createElement(re,null,n?formatDateCompact(n.currentPeriodEnd):"—")}],right:[{label:o,value:K.createElement(re,null,t?t.totalCount.toLocaleString():"—")},{label:"Success",value:t?K.createElement(re,{color:getSuccessColor(t.successRate)},formatPercent(t.successRate)):K.createElement(re,null,"—")}]}}__name(getCallsLabel,"getCallsLabel"),__name(buildDataRows,"buildDataRows");var q_=__name(({onClose:e})=>{const[t,n]=J("loading"),[r,o]=J(null),[s,i]=J(!1),a=useTerminalWidth(),l=ee(()=>getLayoutSizes({terminalWidth:a}),[a]),u=te(async e=>{try{i(!1);const t=await fetchUsageData();if(e.aborted)return;if(!t.whoami)return i(t.errors.includes("Not authenticated")),void n("error");o(t),n("loaded")}catch{if(e.aborted)return;n("error")}},[]),d=K.useRef(null);ie((r,o)=>{if(o.escape&&(xv(),e()),"r"===r&&"error"===t){n("loading"),d.current?.abort();const e=new AbortController;d.current=e,u(e.signal)}}),Z(()=>{const e=new AbortController;return d.current=e,u(e.signal),()=>e.abort()},[u]);const m=r?.subscription?.data??null,g=m?getPlanInfo({planId:m.planId??""}):null;if("loading"===t)return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(D_,{plan:g,status:m?.status??null}),K.createElement(re,{color:zn.DIM},"Loading…"),K.createElement(F_,null));if("error"===t)return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(D_,{plan:g,status:m?.status??null}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},s?"Not authenticated. Run /login to connect your account.":"Something went wrong.")),K.createElement(F_,{showRetry:!s}));if(!r)return null;if(!r.credits&&!r.subscription)return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(D_,{plan:g,status:m?.status??null}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"No billing data found. Visit "),K.createElement(xr,{url:L_,text:"Studio",color:zn.CYAN}),K.createElement(re,{color:zn.DIM}," for usage details.")),K.createElement(F_,null));const h=r.credits?.credits,f=r.summary,y=g?.monthlyCredits??0,w=Math.max(0,h?.monthlyCredits??0),S=getUsagePercent({used:Math.max(0,y-w),total:y}),E=(h?.purchasedCredits??0)>0||(h?.freeCredits??0)>0||w>0,C=m?.currentPeriodEnd?getDaysRemaining(m.currentPeriodEnd):null,v=getUsageColor(S),k=buildProgressBar({percentage:S,width:l.progressBarWidth}),T=getCircleGauge(S),_=getDaysColor(C),{labelWidth:x,showTwoColumn:A}=l,P=buildDataRows({credits:h,summary:f,sub:m});return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,{marginBottom:1},K.createElement(D_,{plan:g,status:m?.status??null})),y>0?K.createElement(K.Fragment,null,K.createElement(ne,null,K.createElement(re,{color:v},k.filled),K.createElement(re,{color:er},k.empty),K.createElement(re,{bold:!0,color:v},` ${Math.round(S)}%`)),K.createElement(ne,null,K.createElement(re,{color:v},T),K.createElement(re,{bold:!0}," ",formatPercent(S)),K.createElement(re,{color:zn.GRAY}," used"),null!==C&&K.createElement(K.Fragment,null,K.createElement(re,{color:zn.DIM}," · "),K.createElement(re,{color:_},0===C?"expires today":`${C} day${1===C?"":"s"} left`)))):E?null:K.createElement(re,{color:zn.DIM},"Plan details unavailable"),A?K.createElement(ne,{flexDirection:"column",marginTop:1},Array.from({length:Math.max(P.left.length,P.right.length)}).map((e,t)=>{const n=P.left[t],r=P.right[t];return K.createElement(ne,{key:`row-${n?.label??""}-${r?.label??""}`},K.createElement(re,{dimColor:!0},(n?.label??"").padEnd(x)),K.createElement(ne,{width:23},n?.value??K.createElement(re,null)),r&&K.createElement(K.Fragment,null,K.createElement(re,{dimColor:!0},r.label.padEnd(14)),r.value))})):K.createElement(ne,{flexDirection:"column",marginTop:1},[...P.left,...P.right].map(e=>K.createElement(O_,{key:e.label,label:e.label,labelWidth:x},e.value))),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Full breakdown at "),K.createElement(xr,{url:L_,text:"commandcode.ai/settings/usage",color:zn.CYAN})),K.createElement(F_,null))},"UsageOverlay");function UsageView({staticKey:e,setShowUsageOverlay:t}){return K.createElement(K.Fragment,null,K.createElement(XT,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(q_,{onClose:()=>t(!1)})))}function countMessagesByRole({messages:e}){let t=0,n=0;for(const r of e)"user"===r.message.role&&t++,"assistant"===r.message.role&&n++;return{user:t,assistant:n}}function countToolCalls({messages:e}){let t=0,n=0;for(const r of e){const e=r.message.content;if(Array.isArray(e))for(const r of e)"tool-call"===r.type&&t++,"tool-result"===r.type&&n++}return{calls:t,results:n}}function countImages({messages:e}){let t=0;for(const n of e){const e=n.message.content;if(Array.isArray(e))for(const n of e)"image"===n.type&&t++}return t}function findCompactions({messages:e}){const t=[];for(const n of e)n.meta.isSummary&&t.push({type:"auto",timestamp:n.meta.timestamp});return t}function estimateConversationTokens({messages:e}){let t=0;for(const n of e)t+=estimateTokens(n.message);return t}function buildAutoCompactStatus({tokensUsed:e,tokenLimit:t}){const n=e/t,r=[{tier:1,threshold:zt.TIER_1_THRESHOLD,description:`Prune to last ${zt.TIER_1_KEEP_COUNT} tool calls`},{tier:2,threshold:zt.TIER_2_THRESHOLD,description:`Prune to last ${zt.TIER_2_KEEP_COUNT} tool calls`},{tier:3,threshold:zt.TIER_3_THRESHOLD,description:"Full summarization"}];let o=0;const s=r.map(r=>{const s=Math.round(r.threshold*t),i=Math.max(0,s-e);let a="upcoming";return n>=r.threshold&&(a="passed",o=r.tier),{tier:r.tier,threshold:r.threshold,tokensAt:s,description:r.description,status:a,tokensAway:i}}),i=s.findIndex(e=>"upcoming"===e.status);return{tiers:-1!==i?s.map((e,t)=>t===i?{...e,status:"current"}:e):s,currentTier:o,keepRecentTokens:zt.KEEP_RECENT_TOKENS}}function generateTips({percentage:e,conversationTokens:t,totalTokens:n,mcpToolCount:r,messageCount:o,imageCount:s}){const i=[];if(0===n)return i;const a=n>0?Math.round(t/n*100):0;e>=90&&i.push("Tier 3 auto-compact imminent — /compact now to control what gets summarized"),e>=80&&e<90&&i.push("Auto-compact Tier 3 triggers at 90% — /compact to free space before it kicks in");const l=a>60&&e>40;return l&&i.push(`${a}% is conversation — /compact to reclaim tokens`),r>0&&e>30&&i.push(`${r} MCP tools loaded — disconnect unused servers to save tokens`),s>0&&i.push(`${s} image${s>1?"s":""} in context — images use ~1.5k tokens each`),e>=50&&e<80&&!l&&i.push("/compact to free space · /model to switch models"),o>50&&e>40&&i.push(`${o} messages — consider starting a new session for a fresh context`),i}async function collectMemoryItems(){const e=(await discoverMemoryFiles(process.cwd())).filter(e=>e.exists),t=[];for(const n of e){const e=await loadMemoryFile(n.path),r=e?estimateTokens(e):0,o=process.env.HOME??"",s=o&&n.path.startsWith(o)?`~${n.path.slice(o.length)}`:n.path;t.push({name:n.description,tokens:r,source:s})}return t}function collectBuiltInTools(){const e=[];for(const t of YC){const n=JSON.stringify(t.input_schema??{}),r=estimateTokens(`${t.name} ${t.description??""} ${n}`);e.push({name:t.name,tokens:r})}for(const t of JC){const n=estimateTokens(`${t.name} ${t.type}`);e.push({name:t.name,tokens:n})}return e}function collectMcpTools(){const e=getMcpConnectionManager().getConnectedServers(),t=[];for(const n of e)if("connected"===n.status)for(const e of n.tools){const r=JSON.stringify(e.inputSchema??{}),o=estimateTokens(`${e.name} ${e.description??""} ${r}`);t.push({name:e.name,tokens:o,source:n.name})}return t}async function collectSkillItems(){const e=await loadAllSkillSummaries(),t=[];for(const n of e.project){const e=estimateTokens(`${n.name} ${n.description}`);t.push({name:n.name,tokens:e,source:"project"})}for(const n of e.global){const e=estimateTokens(`${n.name} ${n.description}`);t.push({name:n.name,tokens:e,source:"user"})}return t}async function collectAgentItems(){const e=await loadAllAgents(),t=[];for(const n of e.project){const e=estimateTokens(`${n.name} ${n.description} ${n.systemPrompt}`);t.push({name:n.name,tokens:e,source:"project"})}for(const n of e.personal){const e=estimateTokens(`${n.name} ${n.description} ${n.systemPrompt}`);t.push({name:n.name,tokens:e,source:"user"})}return t}function sumTokens(e){let t=0;for(const n of e)t+=n.tokens;return t}async function analyzeContext({contextEngine:e}){const t=e.getContextTokensUsed(),n=ES,r=getConfiguredModel(),o=e.getHistory(),s=countMessagesByRole({messages:o}),i=countToolCalls({messages:o}),a=countImages({messages:o}),l=findCompactions({messages:o}),u=e.getCompactionCount(),d=Math.max(u,l.length),m=estimateConversationTokens({messages:o}),g=collectBuiltInTools(),h=collectMcpTools(),[f,y,w]=await Promise.all([collectSkillItems(),collectAgentItems(),collectMemoryItems()]),S=sumTokens(g),E=sumTokens(h),C=S+E+sumTokens(f)+sumTokens(y)+sumTokens(w),v=t>0,k=v?t:m+C,T=!v&&o.length>0,_=Math.min(k/n*100,100),x=Math.max(0,n-k),A=Math.max(0,k-m-C),P=[];if(k>0){m>0&&P.push({name:"Conversation",tokens:m,percentage:Math.round(m/k*100),detail:`${s.user+s.assistant} messages`}),A>0&&P.push({name:"System prompt",tokens:A,percentage:Math.round(A/k*100),detail:"identity, taste, skills"});const e=S+E;if(e>0){const t=g.length,n=h.length,r=n>0?`${t} built-in + ${n} MCP`:`${t} built-in`;P.push({name:"Tool schemas",tokens:e,percentage:Math.round(e/k*100),detail:r})}}P.sort((e,t)=>t.tokens-e.tokens);const I=o.length>0?o[0]?.meta.timestamp??null:null;return{tokensUsed:k,tokenLimit:n,percentage:_,tokensRemaining:x,isEstimated:T,model:r,breakdown:P,autoCompact:buildAutoCompactStatus({tokensUsed:k,tokenLimit:n}),stats:{messageCount:o.length,userMessages:s.user,assistantMessages:s.assistant,toolCalls:i.calls,toolResults:i.results,imageCount:a,compactionCount:d,sessionStartTime:I},compactions:l,tips:generateTips({percentage:_,conversationTokens:m,totalTokens:k,mcpToolCount:h.length,messageCount:o.length,imageCount:a})}}function getLayoutSizes2({terminalWidth:e}){const t=e;return t<50?{labelWidth:14,progressBarWidth:Math.max(10,t-10),breakdownBarWidth:0,showBreakdownBars:!1,showBreakdownDetail:!1}:t<70?{labelWidth:16,progressBarWidth:Math.max(15,t-15),breakdownBarWidth:8,showBreakdownBars:!0,showBreakdownDetail:!1}:{labelWidth:22,progressBarWidth:Math.min(30,t-15),breakdownBarWidth:16,showBreakdownBars:!0,showBreakdownDetail:!0}}function formatDuration(e){if(!e)return"N/A";const t=new Date(e).getTime();if(isNaN(t))return"N/A";const n=Date.now(),r=Math.round((n-t)/6e4);return r<1?"<1m":r<60?`${r}m`:`${Math.floor(r/60)}h ${r%60}m`}function ContextProgress({analysis:e,progressBarWidth:t}){const n=getUsageColor(e.percentage),r=buildProgressBar({percentage:e.percentage,width:t});return K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(ne,{marginBottom:0},K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:zn.BLUE,color:"#f4f4f4",bold:!0},`${Qk}CONTEXT${Qk}`)),K.createElement(re,null," "),K.createElement(re,{color:zn.GRAY},e.model)),K.createElement(ne,null,K.createElement(re,{color:n},r.filled),K.createElement(re,{color:er},r.empty),K.createElement(re,{bold:!0,color:n},` ${e.percentage.toFixed(1)}%`)),K.createElement(ne,null,K.createElement(re,null,formatTokens(e.tokensUsed)),K.createElement(re,{color:zn.GRAY},` / ${formatTokens(e.tokenLimit)}`),K.createElement(re,{color:zn.DIM}," · "),K.createElement(re,{color:n},formatTokens(e.tokensRemaining)),K.createElement(re,{color:zn.GRAY}," remaining"),e.isEstimated&&K.createElement(re,{color:zn.DIM}," (estimated)")),K.createElement(CompactionDistance,{analysis:e}))}function BreakdownRow({item:e,maxTokens:t,labelWidth:n,barWidth:r,showBar:o,showDetail:s}){const i=o&&t>0?Math.round(e.tokens/t*r):0,a="█".repeat(i),l="░".repeat(r-i);return K.createElement(ne,null,K.createElement(re,null,e.name.padEnd(n)),o&&K.createElement(K.Fragment,null,K.createElement(re,{color:zn.CYAN},a),K.createElement(re,{color:er},l)),K.createElement(re,{bold:!0},` ${formatTokens(e.tokens)}`),K.createElement(re,{color:zn.GRAY},` ${e.percentage}%`),s&&e.detail&&K.createElement(re,{color:zn.DIM},` ${e.detail}`))}function ContextBreakdown({analysis:e,labelWidth:t,breakdownBarWidth:n,showBreakdownBars:r,showBreakdownDetail:o}){return 0===e.breakdown.length?null:K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{color:er,bold:!0},"Breakdown"),e.breakdown.map(s=>K.createElement(BreakdownRow,{key:s.name,item:s,maxTokens:e.tokensUsed,labelWidth:t,barWidth:n,showBar:r,showDetail:o})))}function CompactionDistance({analysis:e}){const t=e.autoCompact.tiers.find(e=>3===e.tier);if(!t||"passed"===t.status)return null;const n=Math.round(100*t.threshold)-Math.round(e.percentage),r=n<=10?zn.RED:n<=25?zn.YELLOW:zn.GRAY;return K.createElement(ne,null,K.createElement(re,{color:zn.DIM},"Full summarization"),K.createElement(re,{color:r},` ${n}% away`))}function ContextSession({analysis:e,labelWidth:t}){return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:er,bold:!0},"Session"),K.createElement(ne,null,K.createElement(re,null,"Messages".padEnd(t)),K.createElement(re,{color:zn.GRAY},`${e.stats.messageCount} (${e.stats.userMessages} user, ${e.stats.assistantMessages} assistant)`)),K.createElement(ne,null,K.createElement(re,null,"Tool calls".padEnd(t)),K.createElement(re,{color:zn.GRAY},`${e.stats.toolCalls} calls · ${e.stats.toolResults} results`)),e.stats.imageCount>0&&K.createElement(ne,null,K.createElement(re,null,"Images".padEnd(t)),K.createElement(re,{color:zn.GRAY},`${e.stats.imageCount}`)),K.createElement(ne,null,K.createElement(re,null,"Duration".padEnd(t)),K.createElement(re,{color:zn.GRAY},formatDuration(e.stats.sessionStartTime))))}function ContextTips({tips:e}){return 0===e.length?null:K.createElement(ne,{flexDirection:"column"},e.map(e=>K.createElement(ne,{key:e},K.createElement(re,{color:zn.CYAN},_e.pointer),K.createElement(re,{color:zn.GRAY}," ",e))))}function ContextHints(){return K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(ne,null,K.createElement(re,{color:zn.GRAY},">"," "),K.createElement(re,{color:zn.GRAY},"Auto-compact kicks in when context reaches its limit")),K.createElement(ne,null,K.createElement(re,{color:zn.GRAY},">"," "),K.createElement(re,{color:zn.GRAY},"Run /compact to manually summarize your conversation and free up context")))}function ContextMessage({analysis:e}){const t=getLayoutSizes2({terminalWidth:useTerminalWidth()});return K.createElement(ne,{flexDirection:"column",paddingTop:1},K.createElement(ContextProgress,{analysis:e,progressBarWidth:t.progressBarWidth}),K.createElement(ContextBreakdown,{analysis:e,labelWidth:t.labelWidth,breakdownBarWidth:t.breakdownBarWidth,showBreakdownBars:t.showBreakdownBars,showBreakdownDetail:t.showBreakdownDetail}),K.createElement(ContextSession,{analysis:e,labelWidth:t.labelWidth}),K.createElement(ContextTips,{tips:e.tips}),K.createElement(ContextHints,null))}function ContextConfigView({staticKey:e,contextEngineRef:t,setShowContextView:n,setInput:r}){const[o,s]=J(null),[i,a]=J(null);return Z(()=>{let e=!0;return __name(async()=>{if(t.current)try{const n=await analyzeContext({contextEngine:t.current});e&&s(n)}catch{e&&a("Failed to analyze context.")}else e&&a("No active conversation. Start chatting first.")},"load")(),()=>{e=!1}},[t]),ie((e,t)=>{t.escape&&(xv(),r(""),n(!1))}),K.createElement(K.Fragment,null,K.createElement(XT,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},i?K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:Wn,bold:!0},"Context"),K.createElement(re,{color:zn.DIM},i)):o?K.createElement(ContextMessage,{analysis:o}):K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:Wn,bold:!0},"Context"),K.createElement(re,{color:zn.DIM},"Loading context analysis...")),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Press Esc to return to conversation"))))}__name(UsageView,"UsageView"),Ht(),Ht(),Yt(),TE(),ME(),bw(),rv(),hw(),AS(),Pr(),__name(countMessagesByRole,"countMessagesByRole"),__name(countToolCalls,"countToolCalls"),__name(countImages,"countImages"),__name(findCompactions,"findCompactions"),__name(estimateConversationTokens,"estimateConversationTokens"),__name(buildAutoCompactStatus,"buildAutoCompactStatus"),__name(generateTips,"generateTips"),__name(collectMemoryItems,"collectMemoryItems"),__name(collectBuiltInTools,"collectBuiltInTools"),__name(collectMcpTools,"collectMcpTools"),__name(collectSkillItems,"collectSkillItems"),__name(collectAgentItems,"collectAgentItems"),__name(sumTokens,"sumTokens"),__name(analyzeContext,"analyzeContext"),Iv(),Ht(),hr(),qr(),__name(getLayoutSizes2,"getLayoutSizes"),__name(formatDuration,"formatDuration"),__name(ContextProgress,"ContextProgress"),__name(BreakdownRow,"BreakdownRow"),__name(ContextBreakdown,"ContextBreakdown"),__name(CompactionDistance,"CompactionDistance"),__name(ContextSession,"ContextSession"),__name(ContextTips,"ContextTips"),__name(ContextHints,"ContextHints"),__name(ContextMessage,"ContextMessage"),hr(),__name(ContextConfigView,"ContextConfigView"),Ht(),Ht(),Yt(),zo(),ME(),bw(),Kr(),Fr(),Pr();var j_="https://commandcode.ai/studio";function getVersionStatus(){try{return{current:getPackageJson().version,updateAvailable:null}}catch{return{current:"Unknown",updateAvailable:null}}}async function getAuthStatus(){try{const e=await checkAuthStatus(),t=e.userName||null;return{authenticated:e.authenticated,username:t}}catch{return{authenticated:!1,username:null}}}async function getModelStatus(){try{const e=await getSelectedModel(),t=getProviderDisplayName((await loadUserConfig()).provider||null);return{id:e,displayName:getModelDisplayName(e),provider:t}}catch{return{id:"Unknown",displayName:"Unknown",provider:"Unknown"}}}async function getSkillsAgentsStatus(){let e=0,t=0,n=0,r=0;try{const n=await loadAllSkillSummaries();e=n.global.length,t=n.project.length}catch{}try{const e=await loadAllAgents();n=e.personal.length,r=e.project.length}catch{}return{personalSkills:e,projectSkills:t,personalAgents:n,projectAgents:r}}function execGitAsync(e){return new Promise(t=>{L("git",e,{encoding:"utf8",cwd:process.cwd(),timeout:3e3},(e,n)=>{t(e?null:n.trim()||null)})})}async function getGitStatus2(){const e=await execGitAsync(["rev-parse","--abbrev-ref","HEAD"]);if(!e)return{branch:null,worktreePath:null,remoteUrl:null,remoteHttpUrl:null};const[t,n]=await Promise.all([execGitAsync(["rev-parse","--show-toplevel"]),execGitAsync(["remote","get-url","origin"])]);return{branch:e,worktreePath:t,remoteUrl:n?formatRemoteUrl(n):null,remoteHttpUrl:n?buildHttpUrl(n):null}}function parseSSHUrl(e){const t=e.match(/@([^:]+):(.+?)(?:\.git)?$/);return t?.[1]&&t[2]?{host:t[1],path:t[2]}:null}function formatRemoteUrl(e){const t=parseSSHUrl(e);if(t)return t.path;const n=e.match(/\/\/[^/]+\/(.+?)(?:\.git)?$/);return n?.[1]?n[1]:e}function buildHttpUrl(e){const t=parseSSHUrl(e);if(t)return`https://${t.host}/${t.path}`;const n=e.match(/^ssh:\/\/[^@]+@([^/]+)\/(.+?)(?:\.git)?$/);return n?.[1]&&n[2]?`https://${n[1]}/${n[2]}`:/^https?:\/\//.test(e)?e.replace(/\.git$/,""):e}function getPrStatus(e){try{const t=getCachedPR(e);return t?{number:t.number,url:t.url,state:t.state}:null}catch{return null}}async function hasTasteMdFiles(e){if(!v(e))return!1;try{return(await U(e,{recursive:!0,encoding:"utf-8"})).some(e=>e.endsWith(".md"))}catch{return!1}}async function getTasteStatus(){const e=t.join(process.cwd(),".commandcode","taste"),n=t.join(e,"taste.md"),r=v(n),o=r||await hasTasteMdFiles(e);let s=!0;try{s=await isTasteLearningEnabled()}catch{}return{fileExists:o,filePath:r?n:e,learningEnabled:s}}function detectProxy(){const e=process.env.HTTPS_PROXY||process.env.https_proxy||process.env.HTTP_PROXY||process.env.http_proxy;return e?sanitizeProxyUrl(e):null}function sanitizeProxyUrl(e){try{const t=new URL(e);return t.username="",t.password="",t.toString().replace(/\/$/,"")}catch{return"[malformed proxy URL]"}}function getSystemStatus(){let e,t,n,r;try{e=xT(w.platform()),t=BT(),n=UT(),r=zT()}catch{e="Unknown",t="Unknown",n="Unknown",r="N/A"}return{cwd:process.cwd(),os:e,arch:w.arch(),shell:n,terminal:t,nodeVersion:process.version,ide:"N/A"!==r?r:null,proxy:detectProxy()}}async function gatherStatusData(){const e=safeSync(getVersionStatus,{current:"Unknown",updateAvailable:null}),t=safeSync(getSystemStatus,{cwd:process.cwd(),os:"Unknown",arch:w.arch(),shell:"Unknown",terminal:"Unknown",nodeVersion:process.version,ide:null,proxy:null}),[n,r,o,s,i]=await Promise.all([safeAsync(getAuthStatus,{authenticated:!1,username:null}),safeAsync(getModelStatus,{id:"Unknown",displayName:"Unknown",provider:"Unknown"}),safeAsync(getTasteStatus,{fileExists:!1,filePath:"",learningEnabled:!1}),safeAsync(getSkillsAgentsStatus,{personalSkills:0,projectSkills:0,personalAgents:0,projectAgents:0}),safeAsync(getGitStatus2,{branch:null,worktreePath:null,remoteUrl:null,remoteHttpUrl:null})]),a=safeSync(()=>getPrStatus(i.branch),null);return{version:e,auth:n,model:r,git:i,pr:a,taste:o,skillsAgents:s,system:t}}function safeSync(e,t){try{return e()}catch{return t}}async function safeAsync(e,t){try{return await e()}catch{return t}}function formatCountValue(e,t){const n=e+t;return 0===n?"None":`${n} (${e} user, ${t} project)`}function formatSystemValue({system:e}){const t=[`${e.os} ${e.arch}`];return e.ide&&t.push(e.ide),!e.terminal||e.ide&&e.ide.toLowerCase().startsWith(e.terminal.toLowerCase())||t.push(e.terminal),t.push(e.shell),t.push(`Node ${e.nodeVersion}`),t.join(" · ")}__name(getVersionStatus,"getVersionStatus"),__name(getAuthStatus,"getAuthStatus"),__name(getModelStatus,"getModelStatus"),__name(getSkillsAgentsStatus,"getSkillsAgentsStatus"),__name(execGitAsync,"execGitAsync"),__name(getGitStatus2,"getGitStatus"),__name(parseSSHUrl,"parseSSHUrl"),__name(formatRemoteUrl,"formatRemoteUrl"),__name(buildHttpUrl,"buildHttpUrl"),__name(getPrStatus,"getPrStatus"),__name(hasTasteMdFiles,"hasTasteMdFiles"),__name(getTasteStatus,"getTasteStatus"),__name(detectProxy,"detectProxy"),__name(sanitizeProxyUrl,"sanitizeProxyUrl"),__name(getSystemStatus,"getSystemStatus"),__name(gatherStatusData,"gatherStatusData"),__name(safeSync,"safeSync"),__name(safeAsync,"safeAsync"),Ht(),Yt(),SC(),hr(),Ir(),__name(formatCountValue,"formatCountValue"),__name(formatSystemValue,"formatSystemValue");var B_=__name(({label:e,value:t,valueColor:n,dimValue:r})=>K.createElement(ne,null,K.createElement(re,{dimColor:!0},`${e}:`.padEnd(14)),r?K.createElement(re,{dimColor:!0},t):K.createElement(re,{color:n},t)),"Row");function StatusMessage({statusData:e}){const t=e,n=t.version.updateAvailable?`v${t.version.current} → v${t.version.updateAvailable} available`:`v${t.version.current}`,r=`${t.model.provider} · ${t.model.displayName}`,o=t.git.branch||"N/A",s=t.git.worktreePath?toRelativePath(t.git.worktreePath):null,i=t.auth.authenticated?_e.tick:_e.cross,a=t.auth.authenticated?zn.WHITE:Xn.ERROR,l=t.skillsAgents.personalSkills+t.skillsAgents.projectSkills,u=t.skillsAgents.personalAgents+t.skillsAgents.projectAgents,d=t.taste.fileExists?"Active · "+(t.taste.learningEnabled?"Learning on":"Learning off"):"No taste.md";return K.createElement(ne,{flexDirection:"column",paddingX:0},K.createElement(ne,null,K.createElement(re,{color:Wn,bold:!0},"Command Code"," "),K.createElement(re,{dimColor:!0},n)),K.createElement(ne,null,K.createElement(re,{dimColor:!0},"Visit "),K.createElement(xr,{url:j_,text:j_,color:zn.CYAN}),K.createElement(re,{dimColor:!0}," for usage and billing")),K.createElement(ne,{marginTop:1},K.createElement(re,{dimColor:!0},"Account:".padEnd(14)),t.auth.authenticated&&t.auth.username?K.createElement(K.Fragment,null,K.createElement(xr,{url:`https://commandcode.ai/${t.auth.username}/`,text:t.auth.username,color:zn.CYAN}),K.createElement(re,{color:a}," ",i)):t.auth.authenticated?K.createElement(K.Fragment,null,K.createElement(re,null,"Authenticated"),K.createElement(re,{color:a}," ",i)):K.createElement(K.Fragment,null,K.createElement(re,{color:Xn.WARNING},"Not signed in"),K.createElement(re,{color:a}," ",i),K.createElement(re,{dimColor:!0}," — run "),K.createElement(re,{bold:!0},"/login"))),K.createElement(B_,{label:"Model",value:r}),K.createElement(B_,{label:"Branch",value:o,dimValue:!t.git.branch}),s?K.createElement(B_,{label:"Worktree",value:s}):null,t.git.remoteUrl?K.createElement(ne,null,K.createElement(re,{dimColor:!0},"Repository:".padEnd(14)),K.createElement(xr,{url:t.git.remoteHttpUrl||`https://github.com/${t.git.remoteUrl}`,text:t.git.remoteUrl,color:zn.CYAN}),t.pr?K.createElement(K.Fragment,null,K.createElement(re,{dimColor:!0}," · "),K.createElement(xr,{url:t.pr.url,text:`#${t.pr.number}`,color:"OPEN"===t.pr.state?zn.CYAN:zn.GRAY}),K.createElement(re,{dimColor:!0}," (",t.pr.state.toLowerCase(),")")):null):t.pr?K.createElement(ne,null,K.createElement(re,{dimColor:!0},"Pull Request:".padEnd(14)),K.createElement(xr,{url:t.pr.url,text:`#${t.pr.number}`,color:"OPEN"===t.pr.state?zn.CYAN:zn.GRAY}),K.createElement(re,{dimColor:!0}," (",t.pr.state.toLowerCase(),")")):null,K.createElement(B_,{label:"Taste",value:d,dimValue:!t.taste.fileExists}),K.createElement(B_,{label:"Directory",value:toRelativePath(t.system.cwd)}),K.createElement(B_,{label:"Skills",value:formatCountValue(t.skillsAgents.personalSkills,t.skillsAgents.projectSkills),dimValue:0===l}),K.createElement(B_,{label:"Agents",value:formatCountValue(t.skillsAgents.personalAgents,t.skillsAgents.projectAgents),dimValue:0===u}),K.createElement(B_,{label:"System",value:formatSystemValue({system:t.system})}),t.system.proxy?K.createElement(B_,{label:"Proxy",value:t.system.proxy}):null)}function StatusConfigView({staticKey:e,setShowStatusView:t,setInput:n}){const[r,o]=J({phase:"loading"});return Z(()=>{let e=!1;return gatherStatusData().then(t=>{e||o({phase:"ready",data:t})}).catch(t=>{if(e)return;const n=t instanceof Error?t.message:"Failed to gather status";o({phase:"error",message:n})}),()=>{e=!0}},[]),ie((e,r)=>{r.escape&&(n(""),t(!1))}),K.createElement(K.Fragment,null,K.createElement(XT,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},"ready"===r.phase?K.createElement(StatusMessage,{statusData:r.data}):"error"===r.phase?K.createElement(re,{dimColor:!0},"Could not load status: ",r.message):K.createElement(re,{dimColor:!0},"Gathering status…"),K.createElement(ne,{marginTop:1},K.createElement(re,{dimColor:!0},"Press Esc to return to conversation"))))}function moveFocusDown(e,t){const{suggestionCount:n,activeDirCount:r}=t;return"input"===e.zone?n>0?{...e,zone:"suggestions",suggestionIndex:0}:r>0?{...e,zone:"active-dir",activeDirIndex:0}:e:"suggestions"===e.zone?e.suggestionIndex<n-1?{...e,suggestionIndex:e.suggestionIndex+1}:r>0?{...e,zone:"active-dir",activeDirIndex:0}:{...e,zone:"input"}:e.activeDirIndex<r-1?{...e,activeDirIndex:e.activeDirIndex+1}:{...e,zone:"input"}}function moveFocusUp(e,t){const{suggestionCount:n,activeDirCount:r}=t;return"input"===e.zone?r>0?{...e,zone:"active-dir",activeDirIndex:r-1}:n>0?{...e,zone:"suggestions",suggestionIndex:n-1}:e:"suggestions"===e.zone?e.suggestionIndex>0?{...e,suggestionIndex:e.suggestionIndex-1}:{...e,zone:"input"}:e.activeDirIndex>0?{...e,activeDirIndex:e.activeDirIndex-1}:n>0?{...e,zone:"suggestions",suggestionIndex:n-1}:{...e,zone:"input"}}function getAdjustedSuggestionOffset(e){const{selectedIndex:t,currentOffset:n,maxVisible:r,totalSuggestions:o}=e;return o<=r?0:t<n?t:t>=n+r?t-r+1:n}function getSuggestionBase(e){const n=resolveDirectoryPath(e),r=/[\\/]$/.test(e),o=e.replace(/\\/g,"/");if(o.endsWith("/."))return{searchDirectory:n,prefix:".",outputPrefix:`${o.slice(0,-1)}`};if(r)return{searchDirectory:n,prefix:"",outputPrefix:o};const s=o.lastIndexOf("/");return-1===s?{searchDirectory:t.dirname(n),prefix:t.basename(n),outputPrefix:""}:{searchDirectory:t.dirname(n),prefix:t.basename(n),outputPrefix:o.slice(0,s+1)}}function getDirectorySuggestions(e){const t=e.trim();if(!t)return[];try{const{searchDirectory:e,prefix:n,outputPrefix:r}=getSuggestionBase(t),o=n.startsWith(".")||r.includes("/.");return C.readdirSync(e,{withFileTypes:!0}).filter(e=>e.isDirectory()).filter(e=>!!o||!e.name.startsWith(".")).filter(e=>!n||e.name.toLowerCase().startsWith(n.toLowerCase())).sort((e,t)=>e.name.localeCompare(t.name)).map(e=>`${r}${e.name}/`)}catch(e){const t=e.code;return"ENOENT"!==t&&"ENOTDIR"!==t&&console.error(`Warning: Could not list directory suggestions: ${t}`),[]}}function getFooterText(e){return"active-dir"===e.focusZone?"[Del] Remove [↑↓] Navigate [Tab] Autocomplete [Esc] Close":"[Enter] Add [↑↓] Navigate [Tab] Autocomplete [Esc] Close"}__name(StatusMessage,"StatusMessage"),__name(StatusConfigView,"StatusConfigView"),Ht(),Ht(),tn(),Ht(),tn(),__name(function createInitialFocusState(){return{zone:"input",suggestionIndex:0,activeDirIndex:0}},"createInitialFocusState"),__name(moveFocusDown,"moveFocusDown"),__name(moveFocusUp,"moveFocusUp"),__name(getAdjustedSuggestionOffset,"getAdjustedSuggestionOffset"),__name(getSuggestionBase,"getSuggestionBase"),__name(getDirectorySuggestions,"getDirectorySuggestions"),__name(getFooterText,"getFooterText"),hr(),wr();var U_=__name(({onClose:e})=>{const[t,n]=J(""),[r,o]=J(null),[s,i]=J([]),[a,l]=J(getAdditionalDirectories()),[u,d]=J({zone:"input",suggestionIndex:0,activeDirIndex:0}),[m,g]=J(0);Z(()=>{i(t?getDirectorySuggestions(t):[]),d(e=>({...e,zone:"input"})),g(0)},[t]),Z(()=>{if(!r||"success"!==r.tone)return;const e=setTimeout(()=>{o(null)},5e3);return()=>clearTimeout(e)},[r]);const h=__name(e=>{const t=addDirectory(e);"error"!==t.status?"skipped"!==t.status?(o({tone:"success",text:`Added ${t.displayPath} to directory scope`}),n(""),l(getAdditionalDirectories()),d({zone:"input",suggestionIndex:0,activeDirIndex:0})):o({tone:"warning",text:t.message}):o({tone:"error",text:t.message})},"submitPath"),f=__name(e=>{if(!removeAdditionalDirectory(e))return o({tone:"error",text:`${formatDirectoryForDisplay(e)} is no longer in workspace scope`}),void l(getAdditionalDirectories());o({tone:"success",text:`Removed ${formatDirectoryForDisplay(e)} from directory scope`}),l(getAdditionalDirectories()),d(e=>{if("active-dir"!==e.zone)return e;const t=Math.max(0,e.activeDirIndex-1);return{...e,activeDirIndex:t}})},"handleRemove");ie((t,r)=>{if(r.escape)e();else{if(r.return)return"suggestions"===u.zone&&s[u.suggestionIndex]?void h(s[u.suggestionIndex]):void 0;if((r.delete||r.backspace)&&"active-dir"===u.zone&&a[u.activeDirIndex])f(a[u.activeDirIndex]);else{if(r.tab&&s.length>0){const e=s[u.suggestionIndex]??s[0];return void(e&&(n(e),d(e=>({...e,zone:"input"})),o(null)))}r.downArrow?d(e=>moveFocusDown(e,{suggestionCount:s.length,activeDirCount:a.length})):r.upArrow&&d(e=>moveFocusUp(e,{suggestionCount:s.length,activeDirCount:a.length}))}}}),Z(()=>{"suggestions"===u.zone&&g(e=>getAdjustedSuggestionOffset({selectedIndex:u.suggestionIndex,currentOffset:e,maxVisible:8,totalSuggestions:s.length}))},[u,s.length]),Z(()=>{d(e=>"suggestions"===e.zone&&e.suggestionIndex>=s.length?{...e,zone:"input",suggestionIndex:Math.max(0,s.length-1)}:"active-dir"===e.zone&&e.activeDirIndex>=a.length?{...e,zone:"input",activeDirIndex:Math.max(0,a.length-1)}:e)},[s.length,a.length]);const y=s.slice(m,m+8),w=getFooterText({focusZone:u.zone});return K.createElement(ne,{flexDirection:"column",borderStyle:"single",borderColor:zn.CYAN,paddingX:1,paddingY:0},K.createElement(re,{bold:!0,color:zn.CYAN},"Add directory to workspace"),K.createElement(re,{color:zn.GRAY},"Command Code will be able to read files in this directory and make edits when accept edits mode is on."),K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(re,{color:zn.GRAY},"Added directories"),0===a.length?K.createElement(re,{color:zn.GRAY}," None yet"):a.map((e,t)=>{const n="active-dir"===u.zone&&u.activeDirIndex===t;return K.createElement(re,{key:e,color:n?zn.YELLOW:zn.GREEN,bold:n},n?` ${_e.pointer} `:" ",formatDirectoryForDisplay(e))})),K.createElement(ne,{marginTop:1},K.createElement(re,{bold:!0,color:zn.WHITE},"Path")),K.createElement(ne,null,K.createElement(TextInput,{value:t,focus:"input"===u.zone,prefix:`${"input"===u.zone?_e.pointer:" "} `,prefixColor:"input"===u.zone?zn.CYAN:zn.GRAY,onChange:e=>{n(e),o(null)},onSubmit:h})),!t&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.GRAY},"Examples: ../shared ~/docs /abs/path")),r&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:{error:zn.RED,warning:zn.YELLOW,success:zn.GREEN}[r.tone]},r.text)),s.length>0&&K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(re,{color:zn.GRAY},"Suggestions"),y.map((e,t)=>{const n=m+t,r="suggestions"===u.zone&&u.suggestionIndex===n;return K.createElement(re,{key:e,color:r?zn.CYAN:zn.GRAY,bold:r},r?` ${_e.pointer} `:" ",e)})),K.createElement(ne,{marginTop:1},K.createElement(BracketedText,{text:w,color:zn.DIM})))},"AddDirModal");Ht(),Ht(),Yt(),Ht(),Ht(),Yt(),rv(),hr();var z_=__name(()=>t.join(w.homedir(),".commandcode","agents"),"getRootAgentDir"),W_=__name(()=>t.join(process.cwd(),".commandcode","agents"),"getLocalAgentDir"),G_=__name(({config:e,onSaveComplete:n,viewOnly:r=!1})=>{const[o,s]=J("idle"),[i,a]=J(""),l=[...YC.map(e=>e.name),...JC.map(e=>e.name)],u=__name(async()=>{if(!e.agentType||!e.sysPrompt)return s("error"),void a("Agent configuration is incomplete");s("saving");try{const r="personal"===e.location?z_():W_();await O.mkdir(r,{recursive:!0});const o=`${e.agentType}.md`,s=t.join(r,o),i=Array.from(e.selectedTools).map(e=>ev[e]||e).join(", "),a=0===e.selectedTools.size?"none":e.selectedTools.size===l.length?'"*"':JSON.stringify(i),u=`---\nname: "${e.agentType}"\ndescription: ${JSON.stringify(e.ccToolDefinition)}\ntools: ${a}\n---\n\n${e.sysPrompt}\n`;await O.writeFile(s,u,"utf-8"),n(e.agentType)}catch(e){console.error("Error saving agent:",e),s("error"),a(e instanceof Error?e.message:"Unknown error occurred")}},"handleSaveAgent");ie((e,t)=>{r||!t.return||"idle"!==o&&"error"!==o||u()});const d=Array.from(e.selectedTools).map(e=>ev[e]||e).join(", "),m="personal"===e.location?`~/.commandcode/agents/${e.agentType}`:`.commandcode/agents/${e.agentType}`;return K.createElement(ne,{flexDirection:"column",gap:1},K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{gap:1},K.createElement(re,{color:zn.WHITE,bold:!0},"Name:"),K.createElement(re,{color:zn.GRAY},e.agentType)),K.createElement(ne,{gap:1},K.createElement(re,{color:zn.WHITE,bold:!0},"Location:"),K.createElement(re,{color:zn.GRAY},m)),K.createElement(ne,{gap:1},K.createElement(re,{color:zn.WHITE,bold:!0},"Tools:"),K.createElement(re,{color:zn.GRAY},0===e.selectedTools.size?"None":e.selectedTools.size===l.length?"*":d))),K.createElement(ne,{gap:1},K.createElement(re,{color:zn.WHITE,bold:!0},"Description"),K.createElement(re,{color:zn.GRAY},"(Tells ","Command Code"," when to use this agent):")),K.createElement(re,{color:zn.GRAY},e.ccToolDefinition),K.createElement(ne,{gap:1},K.createElement(re,{color:zn.WHITE,bold:!0},"System Prompt:")),K.createElement(re,{color:zn.GRAY},e.sysPrompt),!r&&K.createElement(ne,{marginTop:1},"idle"===o&&K.createElement(ne,{gap:1},K.createElement(re,{color:zn.GREEN,dimColor:!0},"Press"),K.createElement(re,{color:zn.GREEN,bold:!0},"Enter"),K.createElement(re,{color:zn.GREEN,dimColor:!0},"to save • Esc to cancel")),"saving"===o&&K.createElement(re,{color:zn.YELLOW},"Saving agent..."),"saved"===o&&K.createElement(re,{color:zn.GREEN},_e.tick," ",i),"error"===o&&K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.RED},_e.cross," Error: ",i),K.createElement(re,{color:zn.GRAY},"Press Enter to retry"))))},"AgentSummary");rv(),hr();var H_=__name(({agent:e,onBack:t,setRevalidateAgent:n,isReadOnly:r=!1})=>{const[o,s]=J("menu"),i=[...YC.map(e=>e.name),...JC.map(e=>e.name)];let a=new Set;if("*"===e.tools||'"*"'===e.tools)a=new Set(i);else if(e.tools&&"none"!==e.tools){const t=e.tools.replace(/^"|"$/g,"").split(",").map(e=>e.trim()).map(e=>tv[e]||e);a=new Set(t)}const l={location:e.location,method:"manual",agentType:e.name,sysPrompt:e.sysPrompt,ccToolDefinition:e.description,recommendedMethodDescription:"",selectedTools:a},u=[{label:"1. View agent",value:"view"},...r?[]:[{label:"2. Delete agent",value:"delete"}],{label:r?"2. Back":"3. Back",value:"back"}],d=__name(e=>{"back"===e.value?t():"view"===e.value?s("view"):"edit"===e.value?s("edit"):"delete"===e.value&&s("delete")},"handleMenuSelect");if(ie((e,n)=>{n.escape&&("menu"===o?t():s("menu")),n.return&&"view"===o&&s("menu")}),"view"===o)return K.createElement(ne,{flexDirection:"column"},K.createElement(G_,{config:l,onSaveComplete:()=>s("menu"),viewOnly:!0}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.GRAY},"Press Enter to go back")));if("edit"===o)return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.YELLOW},"Edit functionality coming soon..."),K.createElement(re,{color:zn.GRAY},"Press Esc to go back"));if("delete"===o){const r=[{label:"1. Yes, delete",value:"confirm-delete"},{label:"2. No, cancel",value:"cancel"}],o=__name(async r=>{if("confirm-delete"===r.value)try{await O.unlink(e.filePath),n(!0),t()}catch(e){console.error(`Failed to delete agent: ${e}`),s("menu")}else s("menu")},"handleDeleteSelect");return K.createElement(ne,{flexDirection:"column",gap:1},K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.RED},"Delete agent"),K.createElement(re,{color:zn.GRAY},"Are you sure you want to delete the agent ",e.name,"?")),K.createElement(ne,null,K.createElement(nt,{items:r,onSelect:o,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:zn.WHITE},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?zn.WHITE:zn.GRAY},` ${t}`)})))}return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.WHITE,bold:!0},e.name),K.createElement(ne,{marginTop:1},K.createElement(nt,{items:u,onSelect:d,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:zn.WHITE},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?zn.WHITE:zn.GRAY},` ${t}`)})),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.GRAY},"Press ↑↓ to navigate · Enter to select · Esc to go back")))},"AgentDetails");PE(),hr();var V_=__name(({handleSelect:e,createdAgentName:n})=>{const[r,o]=J([]),[s,i]=J([]),[a,l]=J([]),[u,d]=J(!0),[m,g]=J(!1),[h,f]=J(null),[y,S]=J(!1),E=__name(()=>t.join(w.homedir(),".commandcode","agents"),"getRootAgentDir"),C=__name(()=>t.join(process.cwd(),".commandcode","agents"),"getLocalAgentDir"),v=__name(async(e,n)=>{try{g(!1);const r=(await O.readdir(e)).filter(e=>e.endsWith(".md"));return(await Promise.all(r.map(async r=>{try{const o=t.join(e,r),s=await O.readFile(o,"utf-8"),{data:i,content:a}=Me(s);let l=i.tools||"";return"*"!==l&&'"*"'!==l||(l="*"),{name:i.name||r.replace(".md",""),description:i.description||"",tools:l,sysPrompt:a.trim(),location:n,filePath:o}}catch(e){return console.error(`Error loading agent from ${r}:`,e),null}}))).filter(e=>null!==e)}catch{return[]}},"loadAgentsFromDirectory");Z(()=>{__name(async()=>{d(!0);const[e,t]=await Promise.all([v(E(),"personal"),v(C(),"project")]),n=xE.map(e=>({name:e.name,description:e.description,tools:Array.isArray(e.tools)?e.tools.join(", "):e.tools,sysPrompt:e.systemPrompt,location:"personal",filePath:`__builtin__:${e.name}`}));o(e),i(t),l(n),d(!1)},"loadAgents")()},[m]);const k=[{label:"Create new agent",value:"create_new_agent"}];r.forEach(e=>{k.push({label:e.name,value:e.filePath})}),s.forEach(e=>{k.push({label:e.name,value:e.filePath})});const T=r.length+s.length,_=__name(t=>{if("create_new_agent"===t.value)e(t);else{const e=[...r,...s].find(e=>e.filePath===t.value);e&&(f(e),S(!0))}},"handleAgentSelect");if(u)return K.createElement(re,{color:zn.GRAY},"Loading agents...");if(y&&h){const e=h.filePath.startsWith("__builtin__:");return K.createElement(H_,{agent:h,onBack:()=>{S(!1),f(null)},setRevalidateAgent:g,isReadOnly:e})}const x=__name(({isSelected:e,label:t})=>{const n=k.find(e=>e.label===t),o=n?.value||"",i=r[0]?.filePath===o,a=s[0]?.filePath===o;return K.createElement(ne,{flexDirection:"column"},i&&r.length>0&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.GRAY,bold:!0},"User agents")),a&&s.length>0&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.GRAY,bold:!0},"Project agents")),K.createElement(ne,null,K.createElement(re,{color:zn.WHITE},e?">":" "),K.createElement(re,{color:e?zn.WHITE:zn.GRAY}," ",t)))},"CustomItemComponent");return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{marginBottom:1},K.createElement(re,{color:zn.WHITE,bold:!0},"Agents"),T>0?K.createElement(re,{color:zn.GRAY}," ","(",T," agent",T>1?"s":"",")"):K.createElement(re,{color:zn.GRAY}," (No custom agents)")),n&&K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{color:zn.GREEN,dimColor:!0},"Created agent: ",n)),K.createElement(nt,{items:k,onSelect:_,indicatorComponent:()=>null,itemComponent:x}),a.length>0&&K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(re,{color:zn.GRAY,bold:!0},"Default agents"),a.map(e=>K.createElement(re,{key:e.filePath,color:zn.GRAY}," ",e.name.charAt(0).toUpperCase()+e.name.slice(1)))),K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(re,{color:zn.GRAY},"Create specialized subagents that Command Code can delegate to."),K.createElement(re,{color:zn.GRAY},"Each subagent has its own context window, custom system prompt, and specific tools.")))},"ManageAgents");Ht(),Yt(),Qo(),hr(),rv(),Ht(),Ht(),Yt(),hr();var Q_=__name(({onSelect:e})=>K.createElement(nt,{items:[{label:"1. Project (.commandcode/agents/)",value:"project"},{label:"2. Personal (~/.commandcode/agents/)",value:"personal"}],onSelect:t=>{"project"!==t.value&&"personal"!==t.value||e(t.value)},indicatorComponent:({isSelected:e})=>K.createElement(re,{color:e?zn.WHITE:zn.GRAY},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?zn.WHITE:zn.GRAY},` ${t}`)}),"LocationSelector");Ht(),wr(),Yt(),rv(),Er(),_r(),IE(),hr();var K_=__name(({step:e,agentType:t,sysPrompt:n,ccToolDefinition:r,onAgentTypeChange:o,onSysPromptChange:s,onCCToolDefinitionChange:i,onAgentTypeSubmit:a,onSysPromptSubmit:l,onCCToolDefinitionSubmit:u})=>{const[d,m]=J(!1),[g,h]=J(!1),f=te(async e=>{const t=processBracketedPaste(e);if(!t.isPasteStart||d){if(!d||t.isPasteEnd){if(d&&t.isPasteEnd){m(!1);const e=await detectClipboardText();return void(e?s(e):t.cleanedContent&&s(t.cleanedContent))}s(e)}}else if(m(!0),t.isPasteEnd){m(!1);const e=await detectClipboardText();return void(e?s(e):t.cleanedContent&&s(t.cleanedContent))}},[d,s]),y=te(async e=>{const t=processBracketedPaste(e);if(!t.isPasteStart||g){if(!g||t.isPasteEnd){if(g&&t.isPasteEnd){h(!1);const e=await detectClipboardText();return void(e?i(e):t.cleanedContent&&i(t.cleanedContent))}i(e)}}else if(h(!0),t.isPasteEnd){h(!1);const e=await detectClipboardText();return void(e?i(e):t.cleanedContent&&i(t.cleanedContent))}},[g,i]);return"agentType"===e?K.createElement(K.Fragment,null,K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.WHITE},"Enter a unique identifier for your agent:"),t&&(Object.values(ev).some(e=>Oe(e)===Oe(t))||Object.keys(ev).some(e=>Oe(e)===Oe(t)))&&K.createElement(re,{color:zn.RED},_e.warning," This name conflicts with an existing tool name. Please choose a different name."),t&&isReservedAgentName(Oe(t))&&K.createElement(re,{color:zn.RED},_e.warning," This name is reserved. Reserved names:"," ",_E.join(", "))),K.createElement(TextInput,{showCursor:!0,value:t||"",onSubmit:()=>{if(null===t||0===t.trim().length)return;const e=Oe(t);Object.values(ev).some(t=>Oe(t)===e)||Object.keys(ev).some(t=>Oe(t)===e)||isReservedAgentName(e)||a()},onChange:o,placeholder:"e.g. code-reviewer, unit-tester"})):"sysPrompt"===e?K.createElement(K.Fragment,null,K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.WHITE},"Enter the system prompt for your agent:"),K.createElement(re,{color:zn.GRAY},"Be comprehensive for best results.")),K.createElement(TextInput,{showCursor:!0,value:n||"",onSubmit:()=>{null!==n&&0!==n.trim().length&&l()},onChange:f,placeholder:"You are a helpful coding reviewer..."})):"ccToolDefinition"===e?K.createElement(K.Fragment,null,K.createElement(re,{color:zn.WHITE},"When should ","Command Code"," use this agent?"),K.createElement(TextInput,{showCursor:!0,value:r,onSubmit:()=>{0!==r.trim().length&&u()},onChange:y,placeholder:"e.g., Use this agent when you are done writing code..."})):null},"ManualFlow");Ht(),hr();var Y_=__name(({onSelect:e})=>K.createElement(nt,{items:[{label:"1. Generate with Command Code (recommended)",value:"recommended"},{label:"2. Manual configuration",value:"manual"}],onSelect:t=>{"recommended"!==t.value&&"manual"!==t.value||e(t.value)},indicatorComponent:({isSelected:e})=>K.createElement(re,{color:e?zn.WHITE:zn.GRAY},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?zn.WHITE:zn.GRAY},` ${t}`)}),"MethodSelector");Ht(),wr(),Ht(),hr();var J_=["·","○","◇","☆","✧","☆","◇","○","⌘"],X_=[12,5,4,4,4,4,4,5,16],Z_=[5,4,4,4,4,4,5];function getWaveSymbol(e){const t=e%88;let n=0;for(let e=0;e<X_.length;e++)if(n+=X_[e],t<n)return J_[e];const r=t-58;n=0;for(let e=0;e<Z_.length;e++)if(n+=Z_[e],r<n)return J_[7-e];return J_[0]}function ShimmerText({text:e,offset:t,bg:n}){const r=ee(()=>e.split(""),[e]),o=__name(e=>{const n=e-(t-5);return n>=0&&n<cr.length?cr[n]:ur},"getCharColor");return K.createElement(re,null,r.map((e,t)=>K.createElement(re,{key:`${t}:${e}`,color:o(t),backgroundColor:n},e)))}function CMDIcon({frame:e,color:t}){return K.createElement(re,{color:t??Wn,bold:!0},`${getWaveSymbol(e)} `)}function formatToken(e){return e<1e3?`${e}`:`${(e/1e3).toFixed(1)}k`}function formatTime3(e){return e<6e4?`${Math.floor(e/1e3)}s`:`${Math.floor(e/6e4)}m ${Math.floor(e%6e4/1e3)}s`}__name(getWaveSymbol,"getWaveSymbol"),__name(ShimmerText,"ShimmerText"),__name(CMDIcon,"CMDIcon"),__name(formatToken,"formatToken"),__name(formatTime3,"formatTime");var ex=__name(({status:e,timeElapsed:t,tokens:n})=>{const[r,o]=J(0),[s,i]=J(0),a=X(n);a.current=n;const l=getTerminalWidth(),[u,d]=J(()=>l>=72?"all":l>=42?"medium":"none");Z(()=>{d(e=>"all"===e?l<68?l>=42?"medium":"none":"all":"medium"===e?l>=72?"all":l<38?"none":"medium":l>=72?"all":l>=42?"medium":"none")},[l]),Z(()=>{const e=setInterval(()=>{o(e=>(e+1)%88),i(e=>{const t=a.current;if(e===t)return e;const n=t-e,r=e+Math.sign(n)*Math.max(1,Math.ceil(Math.abs(n)/10));return n>0?Math.min(r,t):Math.max(r,t)})},80);return()=>clearInterval(e)},[]);const m=r%(e.length+10),g="all"===u,h="medium"===u;return K.createElement(ne,{width:l,height:1,paddingLeft:0,marginLeft:0},K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:Yn.BG,color:Yn.FG}," "),K.createElement(re,{backgroundColor:Yn.BG},K.createElement(CMDIcon,{frame:4*r})),K.createElement(ShimmerText,{text:e,offset:m,bg:Yn.BG}),K.createElement(re,{backgroundColor:Yn.BG,color:Yn.FG}," ")),g&&K.createElement(ne,{columnGap:1,marginLeft:1},K.createElement(re,{bold:!0,color:zn.GRAY},"esc"),K.createElement(re,{color:zn.DIM},"to interrupt"),K.createElement(re,{color:zn.DIM},"•"),K.createElement(re,{color:zn.DIM},formatTime3(t)),K.createElement(re,{color:zn.DIM},"•"),K.createElement(re,{color:zn.GRAY},_e.arrowDown),K.createElement(re,{color:zn.DIM},formatToken(Math.round(s)))),h&&K.createElement(ne,{marginLeft:1},K.createElement(re,{color:zn.DIM},formatToken(Math.round(s)))))},"Status");_r(),Er(),hr();var tx=__name(({description:e,onChange:t,onSubmit:n,loading:r,errorMessage:o})=>{const[s,i]=J(!1),[a,l]=J(0),[u,d]=J(0);Z(()=>{if(!r)return;const e=setInterval(()=>d(e=>e+1),50);return()=>clearInterval(e)},[r]);const m=te(()=>{0!==e.trim().length&&n()},[e,n]),g=te(async e=>{const n=processBracketedPaste(e);if(!n.isPasteStart||s){if(!s||n.isPasteEnd){if(s&&n.isPasteEnd){i(!1);const e=await detectClipboardText();return void(e?(l(e=>e+1),t(e)):n.cleanedContent&&(l(e=>e+1),t(n.cleanedContent)))}t(e)}}else if(i(!0),n.isPasteEnd){i(!1);const e=await detectClipboardText();return void(e?(l(e=>e+1),t(e)):n.cleanedContent&&(l(e=>e+1),t(n.cleanedContent)))}},[s,t]);return K.createElement(ne,{flexDirection:"column"},r?K.createElement(ne,null,K.createElement(CMDIcon,{frame:u}),K.createElement(re,{color:zn.WHITE},"Generating agent from description...")):K.createElement(TextInput,{key:a,showCursor:!0,value:e,placeholder:"e.g. Help me review my code...",onChange:g,onSubmit:m}),o&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.RED},`${_e.warning} ${o}`)))},"RecommendedFlow");Ht(),rv(),hr();var nx=__name(({selectedTools:e,onToggleTool:t,onToggleCategory:n,onComplete:r})=>{const[o,s]=J(!1),[i,a]=J(0),l=ee(()=>[...YC.map(e=>e.name),...JC.map(e=>e.name)],[]),u=ee(()=>[{name:"All tools",tools:l},{name:"Read-only tools",tools:l.filter(e=>"read_file"===e||"read_directory"===e||"read_multiple_files"===e||"grep"===e)},{name:"Edit tools",tools:l.filter(e=>"edit_file"===e||"write_file"===e)},{name:"Execution tools",tools:l.filter(e=>"shell_command"===e)},{name:"Search tools",tools:l.filter(e=>"web_search"===e||"web_fetch"===e)},{name:"Other tools",tools:l.filter(e=>!["read_file","read_directory","read_multiple_files","grep","edit_file","write_file","shell_command","web_search","web_fetch"].includes(e))}].filter(e=>e.tools.length>0),[l]),d=ee(()=>{const e=[];return e.push({type:"continue",value:"continue"}),e.push({type:"divider",value:"divider-1"}),o?(u.forEach(t=>{e.push({type:"category",value:t.name})}),e.push({type:"divider",value:"divider-3"}),e.push({type:"toggle",value:"hide-advanced"}),e.push({type:"spacer",value:"spacer-1"}),e.push({type:"label",value:"Individual Tools:"}),l.forEach(t=>{e.push({type:"tool",value:t})})):(u.forEach(t=>{e.push({type:"category",value:t.name})}),e.push({type:"divider",value:"divider-2"}),e.push({type:"toggle",value:"show-advanced"})),e},[o,u,e,l]),m=d.map((t,n)=>{if("divider"===t.type)return{label:"─".repeat(30),value:n,type:"divider"};if("spacer"===t.type)return{label:"",value:n,type:"spacer"};if("label"===t.type)return{label:t.value,value:n,type:"label"};if("continue"===t.type)return{label:"[ Continue ]",value:n,type:"continue"};if("toggle"===t.type)return{label:"show-advanced"===t.value?"[ Show advanced options ]":"[ Hide advanced options ]",value:n,type:"toggle"};if("category"===t.type){const r=u.find(e=>e.name===t.value),o=r?.tools.every(t=>e.has(t));return r?.tools.some(t=>e.has(t)),{label:`${o?"[x]":"[ ]"} ${t.value}`,value:n,type:"category"}}return"tool"===t.type?{label:` ${e.has(t.value)?"[x]":"[ ]"} ${ev[t.value]||t.value}`,value:n,type:"tool"}:{label:"",value:n,type:"unknown"}}),g=m.filter(e=>"divider"!==e.type&&"spacer"!==e.type&&"label"!==e.type);return ie((e,l)=>{if(l.upArrow)a(e=>{const t=e-1;return t<0?g.length-1:t});else if(l.downArrow)a(e=>{const t=e+1;return t>=g.length?0:t});else if(l.return||" "===e){const e=g[i];if(e){const i=d[e.value];if(!i)return;"continue"===i.type?r():"toggle"===i.type?(s(!o),a(0)):"category"===i.type?n(i.value):"tool"===i.type&&t(i.value)}}}),K.createElement(ne,{flexDirection:"column"},m.map((e,t)=>{const n=g.findIndex(t=>t.value===e.value),r=-1!==n&&n===i;if("divider"===e.type)return K.createElement(ne,{key:`divider-${t}`},K.createElement(re,{color:zn.GRAY}," ",e.label));if("spacer"===e.type)return K.createElement(ne,{key:`spacer-${t}`,height:1});if("label"===e.type)return K.createElement(ne,{key:`label-${t}`},K.createElement(re,{color:zn.GRAY}," ",e.label));const o="continue"===e.type;return K.createElement(ne,{key:`item-${t}`},K.createElement(re,{color:r?zn.WHITE:zn.GRAY,bold:o&&r},r?">":" "," ",e.label))}),K.createElement(ne,{marginTop:1},e.size===l.length&&K.createElement(re,{color:zn.GRAY},"All tools selected"),e.size>0&&e.size<l.length&&K.createElement(re,{color:zn.GRAY},e.size," tools selected"),0===e.size&&K.createElement(re,{color:zn.GRAY},"No tools selected")))},"ToolsSelector");qr(),iw(),Xy(),Wo(),yk(),Pr();var rx=__name(({onComplete:e})=>{const[t,n]=J("location"),[r,o]=J(!1),[s,i]=J(null),[a,l]=J("agentType"),u=ee(()=>[...YC.map(e=>e.name),...JC.map(e=>e.name)],[]),d=__name(()=>({location:null,method:null,agentType:null,sysPrompt:null,ccToolDefinition:"",recommendedMethodDescription:"",selectedTools:new Set(u)}),"getInitialConfig"),[m,g]=J(d()),h=__name(t=>{n("location"),l("agentType"),g(d()),e(t)},"resetToDefaults"),f=__name(()=>{if("location"===t)return"Choose location";if("method"===t)return"Creation method";if("configuration"===t){if("recommended"===m.method)return"Describe what this agent should do and when it should be used (be comprehensive for best results)";if("agentType"===a)return"Agent type (identifier)";if("sysPrompt"===a)return"System prompt";if("ccToolDefinition"===a)return"Description (Tell Command Code when to use this agent)"}return"tools"===t?"Select tools":"summary"===t?"Confirm and save":""},"getSubText"),y=__name(e=>{g({...m,location:e}),n("method")},"handleLocationSelect"),w=__name(e=>{g({...m,method:e}),n("configuration")},"handleMethodSelect"),S=__name(async()=>{try{i(null),o(!0);const e=await getConfiguredProvider(),t=await isOAuthEnforced(),{token:r,oauthProvider:s}=await getOAuthCredentials({provider:e});validateOAuthToken({token:r,provider:e});const a={[vt.INTERNAL_TEAM_FLAG_HEADER]:t.toString()};r&&(a[vt.OAUTH_TOKEN]=`Bearer ${r}`,s&&(a[vt.OAUTH_PROVIDER]=s));const l=getApiBaseUrl(),u=new Ly({baseUrl:l}),d=parseModelString(getConfiguredModel()).modelId,h=await u.post({headers:a,endpoint:kt.ALPHA.AGENT.GENERATE,body:{description:m.recommendedMethodDescription,model:d}});g({...m,agentType:Oe(h.agentName),sysPrompt:h.systemPrompt,ccToolDefinition:h.toolDescription}),n("tools")}catch(e){if(e instanceof $o&&400===e.status&&e.message?.toLowerCase().includes("insufficient credits")){const e=await getBillingLink({billingLink:null,setBillingLink:__name(()=>{},"setBillingLink")})??"https://commandcode.ai/settings/billing";i(`You have insufficient credits to make this request. Please purchase more credits to continue using Command Code: ${e}`)}else i("An error occurred while generating the agent. Please try again.")}finally{o(!1)}},"handleRecommendedSubmit"),E=__name(()=>{g({...m,agentType:Oe(m.agentType)}),l("sysPrompt")},"handleManualAgentTypeSubmit"),C=__name(()=>{l("ccToolDefinition")},"handleManualSysPromptSubmit"),v=__name(()=>{n("tools")},"handleManualCCToolDefinitionSubmit"),k=__name(()=>{n("summary")},"handleToolsComplete"),T=__name(e=>{const t=new Set(m.selectedTools);t.has(e)?t.delete(e):t.add(e),g({...m,selectedTools:t})},"handleToggleTool"),_=__name(e=>{const t=[{name:"All tools",tools:u},{name:"Read-only tools",tools:u.filter(e=>"read_file"===e||"read_directory"===e||"read_multiple_files"===e||"grep"===e)},{name:"Edit tools",tools:u.filter(e=>"edit_file"===e||"write_file"===e)},{name:"Execution tools",tools:u.filter(e=>"shell_command"===e)},{name:"Search tools",tools:u.filter(e=>"web_search"===e||"web_fetch"===e)},{name:"Other tools",tools:u.filter(e=>!["read_file","read_directory","read_multiple_files","grep","edit_file","write_file","shell_command","web_search","web_fetch"].includes(e))}].find(t=>t.name===e);if(!t)return;const n=new Set(m.selectedTools);t.tools.every(e=>n.has(e))?t.tools.forEach(e=>n.delete(e)):t.tools.forEach(e=>n.add(e)),g({...m,selectedTools:n})},"handleToggleCategory");return K.createElement(ne,{flexDirection:"column",gap:1},K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.WHITE,bold:!0},"Create new agent"),K.createElement(re,{color:zn.GRAY},f())),K.createElement(ne,null,"location"===t&&K.createElement(Q_,{onSelect:y}),"method"===t&&K.createElement(Y_,{onSelect:w}),"configuration"===t&&"recommended"===m.method&&K.createElement(tx,{description:m.recommendedMethodDescription,onChange:e=>g({...m,recommendedMethodDescription:e}),loading:r,errorMessage:s,onSubmit:S}),"configuration"===t&&"manual"===m.method&&K.createElement(ne,{flexDirection:"column",gap:1},K.createElement(K_,{step:a,agentType:m.agentType,sysPrompt:m.sysPrompt,ccToolDefinition:m.ccToolDefinition,onAgentTypeChange:e=>g({...m,agentType:e}),onSysPromptChange:e=>g({...m,sysPrompt:e}),onCCToolDefinitionChange:e=>g({...m,ccToolDefinition:e}),onAgentTypeSubmit:E,onSysPromptSubmit:C,onCCToolDefinitionSubmit:v})),"tools"===t&&K.createElement(nx,{selectedTools:m.selectedTools,onToggleTool:T,onToggleCategory:_,onComplete:k}),"summary"===t&&K.createElement(G_,{config:m,onSaveComplete:h})))},"AgentNew");hr();var ox=__name(({onCancel:e})=>{const[t,n]=J(null),[r,o]=J(null),s=__name(e=>{n(e.value),o(null)},"handleSelect");return ie((t,n)=>{n.escape&&e()}),K.createElement(ne,{gap:1,paddingLeft:1,paddingRight:1,width:"100%",borderColor:zn.GRAY,borderStyle:"single",flexDirection:"column"},null===t&&K.createElement(V_,{handleSelect:s,createdAgentName:r}),"create_new_agent"===t&&K.createElement(rx,{onComplete:e=>{o(e),n(null)}}))},"AgentsConfig");hr(),Ht(),Pr(),hr();var sx=[{label:"Compact Normal (default)",value:"default",description:"Summarize session when context limit reached."},{label:"Compact Fast",value:"fast",description:"Fast tiered compaction. Higher quality, uses more tokens."}],ix=__name(({onSelect:e,onCancel:t})=>{const[n,r]=J(null);Z(()=>{loadUserConfig().then(e=>{r(e.compactMode??"default")})},[]);const o=__name(t=>{e(t.value)},"handleSelect");if(ie((e,n)=>{n.escape&&t()}),null===n)return null;const s=sx.findIndex(e=>e.value===n);return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:Wn,bold:!0},"Select a compact mode to compact sessions")),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:zn.DIM},"Choose how Command Code handles automatic context compaction.")),K.createElement(nt,{items:sx,onSelect:o,initialIndex:s>=0?s:0,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:zn.CYAN},e?_e.pointer:" "),itemComponent:({isSelected:e,label:t})=>{const r=sx.find(e=>e.label===t),o=r?.value===n,s=sx.findIndex(e=>e.label===t);return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,K.createElement(re,{color:e?zn.CYAN:o?zn.GREEN:zn.WHITE},` ${s+1}. ${r?.label??t}`),o&&K.createElement(re,{color:zn.GREEN}," ",_e.tick)),K.createElement(re,{color:zn.DIM},` ${r?.description??""}`))}}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Press "),K.createElement(re,{color:zn.DIM,bold:!0},"Esc"),K.createElement(re,{color:zn.DIM}," to cancel")))},"CompactModeSelector");Ht(),hr(),Ht(),wr(),Yt(),Er(),Tn(),Ht();var ax=n(S(),"commandcode-images"),lx={"image/png":".png","image/jpeg":".jpg","image/gif":".gif","image/webp":".webp"};function saveTempImage(e,t){try{v(ax)||T(ax,{recursive:!0});const r=lx[e.mediaType]||".png",o=`image-${t}-${Date.now()}${r}`,s=n(ax,o),i=Buffer.from(e.data,"base64");return _(s,i),s}catch{return null}}function accumulateDelta(e,t,n){const r=n+t;return e===t||e===r?t:r&&e.startsWith(r)?t+e.slice(r.length):t&&e.startsWith(t)?t+e.slice(t.length):t+e}function useBracketedPaste(e){const{input:t,detectedContent:n,setInput:r,setDetectedImages:o,setDetectedContent:s,incrementInputKey:i}=e,a=te((e,t)=>{o(t=>[...t,e]),r(t),i()},[o,r,i]),l=X(!1),u=X(""),d=X(null),m=X(""),g=te(async(e,t)=>{let o=e.replace(/\r\n/g,"\n").replace(/\r/g,"\n");const l=await detectDroppedImageFile(o);if(l)return void a(l,t);const u=await detectClipboardImage();if(u)return void a(u,t);let d=o;if(!d.trim()){const e=await detectClipboardText();d=e?e.replace(/\r\n/g,"\n").replace(/\r/g,"\n"):""}if(d){if(d.length>300){const e=`[Text#${n.length+1}]`;s(e=>[...e,d]),r(t+e)}else r(t+d);i()}},[a,n.length,s,r,i]),h=te(()=>{d.current&&clearTimeout(d.current),d.current=setTimeout(async()=>{if(l.current){const e=u.current,t=m.current;u.current="",m.current="",l.current=!1,d.current=null,e&&await g(e,t)}},500)},[g]);return{handlePaste:te(async e=>{const n=processBracketedPaste(e);if(n.isPasteStart&&n.isPasteEnd)return l.current&&(l.current=!1,u.current="",m.current="",d.current&&(clearTimeout(d.current),d.current=null)),await g(n.pastedContent??n.cleanedContent,n.textBeforePaste??""),!0;if(n.isPasteStart&&!l.current)return l.current=!0,m.current=n.textBeforePaste??t,u.current=n.pastedContent??n.cleanedContent,h(),!0;if(l.current&&!n.isPasteEnd)return void 0!==n.pastedContent?u.current=n.pastedContent:n.cleanedContent&&(u.current=accumulateDelta(n.cleanedContent,u.current,m.current)),h(),!0;if(l.current&&n.isPasteEnd){d.current&&(clearTimeout(d.current),d.current=null),void 0!==n.pastedContent?u.current=n.pastedContent:n.cleanedContent&&(u.current=accumulateDelta(n.cleanedContent,u.current,m.current));const e=u.current,t=m.current;return u.current="",m.current="",l.current=!1,await g(e,t),!0}if(n.isPasteEnd&&!n.isPasteStart&&!l.current)return!0;const r=e.slice(t.length);if(r.length>0){const e=await detectDroppedImageFile(r);if(e)return a(e,t),!0}return!1},[t,g,h,a]),resetPasteState:te(()=>{l.current=!1,u.current="",m.current="",d.current&&(clearTimeout(d.current),d.current=null)},[]),isPasting:te(()=>l.current,[])}}__name(saveTempImage,"saveTempImage"),On(),qr(),Ht(),_r(),Er(),__name(accumulateDelta,"accumulateDelta"),__name(useBracketedPaste,"useBracketedPaste"),_r(),Ht(),Ht();var cx=["code --wait","cursor --wait","nano"],ux=["code","cursor","subl","atom","zed"];function ensureWaitFlag(e){const t=e.split(" ").filter(e=>e.length>0),n=t[0];return ux.some(e=>n===e||n.endsWith(`/${e}`))?t.some(e=>"--wait"===e||"-w"===e)?e:`${n} --wait ${t.slice(1).join(" ")}`.trim():e}function isCommandAvailable(e){try{const t=e.split(" ")[0],n="win32"===process.platform?"where":"command -v";return M(`${n} ${t}`,{stdio:"ignore",encoding:"utf-8"}),!0}catch{return!1}}function findFallbackEditor(){for(const e of cx)if(isCommandAvailable(e))return e;return null}__name(ensureWaitFlag,"ensureWaitFlag"),__name(isCommandAvailable,"isCommandAvailable"),__name(findFallbackEditor,"findFallbackEditor");var dx=class extends Error{static{__name(this,"NoEditorError")}constructor(){super("No editor configured"),this.name="NoEditorError"}};async function openInEditor2(e){let t=process.env.EDITOR||process.env.VISUAL||null;if(!t&&("true"===process.env.COMMAND_CODE_DISABLE_EDITOR_FALLBACK||(t=findFallbackEditor()),!t))throw new dx;t=ensureWaitFlag(t);const r=n(S(),`commandcode-${Date.now()}.md`);return await q(r,e),new Promise((e,n)=>{const o=t.split(" ").filter(e=>e.length>0),s=o[0],i=o.slice(1),a=$(s,[...i,r],{stdio:"inherit"});a.on("close",async()=>{try{const t=await j(r,"utf-8");await B(r),e(t.trimEnd())}catch(e){n(e)}}),a.on("error",async e=>{try{await B(r)}catch{}n(e)})})}function useExternalEditor({input:e,setInput:t,setInputKey:n,onEditorClose:r}){const[o,s]=J(!1),[i,a]=J(null),l=te(async()=>{if(!o){s(!0),a(null);try{const o=e.replace(/\n+$/,""),s=await openInEditor2(o);t(s),n(e=>e+1),r?.()}catch(e){a(e instanceof dx?"No text editor found. Set your EDITOR environment variable.\n\nSee: https://commandcode.ai/core-concepts/interactive-mode#setting-up-your-editor":`Editor error: ${e instanceof Error?e.message:String(e)}`)}finally{s(!1)}}},[e,t,r,o]),u=te(()=>{a(null)},[]);return{isEditorOpen:o,editorError:i,handleOpenInEditor:l,clearEditorError:u}}__name(function getNoEditorMessage(){return"No text editor found. Set your EDITOR environment variable.\n\nSee: https://commandcode.ai/core-concepts/interactive-mode#setting-up-your-editor"},"getNoEditorMessage"),__name(openInEditor2,"openInEditor"),__name(useExternalEditor,"useExternalEditor"),Ht();var mx=__name((e={})=>{const{enabled:t=!0}=e,[n,r]=J(null),o=X(!1);return Z(()=>{if(!t||o.current)return;let e=!0;return o.current=!0,tT().then(t=>{e&&r(t)}),()=>{e=!1}},[t]),{pr:n}},"usePRDetection");function loadGitignore(e){const t=at(),r=n(e,".gitignore");if(v(r))try{const e=k(r,"utf8");t.add(e)}catch{}return t.add(".git"),t}hr(),Ht(),hr(),__name(loadGitignore,"loadGitignore");var px=__name(({onSelectFile:e,onClose:t,searchQuery:o=""})=>{const[a,l]=J(process.cwd()),[u,d]=J([]),[m,g]=J(0),[h,f]=J(0),y=o.trim()?15:10,w=te((e,t=process.cwd())=>{if(!e.trim())return[];const r=loadGitignore(t);if(e.endsWith("/")){const o=n(t,e);try{const e=x(o),i=[];return e.forEach(e=>{const a=n(o,e);try{const e=A(a),n=s(t,a);if(r.ignores(n))return;i.push({name:n,path:a,isDirectory:e.isDirectory()})}catch{}}),i.sort((e,t)=>e.isDirectory&&!t.isDirectory?-1:!e.isDirectory&&t.isDirectory?1:e.name.localeCompare(t.name)),i.slice(0,50)}catch{}}if(e.includes("/")){const o=e.split("/"),i=o.pop()||"",a=n(t,o.join("/"));try{const e=x(a),o=[],l=i.toLowerCase();return e.forEach(e=>{const u=e.toLowerCase();if(!i||u.includes(l)){const i=n(a,e);try{const e=A(i),n=s(t,i);if(r.ignores(n))return;o.push({name:n,path:i,isDirectory:e.isDirectory()})}catch{}}}),o.sort((e,t)=>e.isDirectory&&!t.isDirectory?-1:!e.isDirectory&&t.isDirectory?1:e.name.localeCompare(t.name)),o.slice(0,50)}catch{}}const o=[],i=e.toLowerCase(),a=__name((e,l=0)=>{if(!(l>8))try{x(e).forEach(u=>{const d=n(e,u);try{const e=A(d),n=s(t,d);if(r.ignores(n))return;const m=n.toLowerCase();(u.toLowerCase().includes(i)||m.includes(i))&&o.push({name:n,path:d,isDirectory:e.isDirectory()}),e.isDirectory()&&"node_modules"!==u&&a(d,l+1)}catch(e){}})}catch(e){}},"searchRecursively");return a(t),o.sort((e,t)=>{const n=e.name.toLowerCase(),r=t.name.toLowerCase(),o=n===i,s=r===i;if(o&&!s)return-1;if(!o&&s)return 1;const a=n.split("/").pop()||"",l=r.split("/").pop()||"",u=a.includes(i),d=l.includes(i);if(u&&!d)return-1;if(!u&&d)return 1;const m=e.name.split("/").length,g=t.name.split("/").length;return m!==g?m-g:e.name.localeCompare(t.name)}),o.slice(0,50)},[]),S=te(e=>{try{const t=x(e),o=[],i=process.cwd(),a=loadGitignore(i);"/"!==e&&o.push({name:"..",path:r(e),isDirectory:!0}),t.forEach(t=>{const r=n(e,t);try{const e=A(r),n=s(i,r);if(a.ignores(n))return;o.push({name:t,path:r,isDirectory:e.isDirectory()})}catch{}}),o.sort((e,t)=>e.isDirectory&&!t.isDirectory?-1:!e.isDirectory&&t.isDirectory?1:e.name.localeCompare(t.name)),d(o),g(0),f(0)}catch{}},[]);Z(()=>{if(o.trim()){const e=w(o);d(e),g(0),f(0)}else S(a)},[a,S,o,w]),ie((n,r)=>{if(r.escape)t();else if(r.upArrow)g(e=>{const t=Math.max(0,e-1);return t<h&&f(t),t});else if(r.downArrow)g(e=>{const t=Math.min(u.length-1,e+1);return t>=h+y&&f(t-y+1),t});else{if(r.rightArrow){const e=u[m];if(!e)return;return void(e.isDirectory&&!o.trim()&&l(i(e.path)))}if(r.return){const t=u[m];if(!t)return;return void e(t.path)}}});const E=u.slice(h,h+y);return K.createElement(ne,{flexDirection:"column",paddingLeft:1},K.createElement(ne,{marginBottom:1,flexDirection:"column"},K.createElement(re,{color:zn.DIM},o.trim()?`Searching for: "${o}"`:`Files: ${a}`),K.createElement(re,{color:zn.DIM},o.trim()?"↑↓ navigate • Enter to select • Esc to close":"↑↓ navigate • → to open folder • Enter to select • Esc to close")),0===E.length?K.createElement(re,{color:zn.DIM},o.trim()?`No files found matching "${o}"`:"No files found in this directory"):E.map((e,t)=>{const n=h+t,r=e.name,o=n===m;return K.createElement(re,{key:e.path,color:o?zn.GREEN:zn.DIM},e.isDirectory?`${r}/`:r)}))},"FileList");Ht(),Yt(),Fr(),hr(),Ht(),hr();var gx=__name(({usage:e})=>{if(!e)return null;const t=Math.min(e.current/e.limit*100,100),n=Math.max(0,Math.round(90-t));if(n>20)return null;const r=__name(e=>e>=90?zn.RED:e>=70?zn.YELLOW:zn.DIM,"getColor"),o=t>=90?6:Math.round(t/100*6),s=6-o,i=_e.square.repeat(o),a=_e.squareLightShade.repeat(s),l=r(t);return K.createElement(ne,{paddingRight:3},K.createElement(re,{color:l},`Context left before auto-compact ${n}% `),K.createElement(re,{color:l},i),s>0&&K.createElement(re,{color:zn.DIM},a))},"ContextUsage");Ht(),dv(),vo(),hr();var hx=__name(()=>{const[e,t]=J("continuous learning"),[n,r]=J(!1),[o,s]=J(!1),i=X([]),a=X(0),l=X(null),u=X(!1);Z(()=>{const e=__name(e=>"analyzing"===e.type?(u.current=!0,r(!0),s(!1),i.current=[],a.current=0,l.current&&(clearTimeout(l.current),l.current=null),void t(e.message)):u.current&&"analyzed"!==e.type?void i.current.push(e):"analyzed"===e.type?(u.current=!1,void(i.current.length>0?(a.current=0,n()):(r(!1),s(!1),t("continuous learning")))):void 0,"handleNewEvent"),n=__name(()=>{if(a.current>=i.current.length)return r(!1),s(!1),t("continuous learning"),void(i.current=[]);const e=i.current[a.current];t(e.message);const o="learned"===e.type||"refactored"===e.type;s(o);const u="learned"===e.type||"refactored"===e.type||"no_learnings"===e.type||"error"===e.type?15e3:2e3;l.current=setTimeout(()=>{a.current++,n()},u)},"cycleThroughNextEvent");return cv.on("new-event",e),()=>{cv.off("new-event",e),l.current&&clearTimeout(l.current)}},[]);const d=` ${n?_e.squareSmallFilled:_e.squareSmall} TASTE`,m=9+e.length+d.length>po;let g=e;g=truncateString(m?{text:e,maxChars:po}:{text:e,maxChars:po-d.length-9-10});const h=o?void 0:zn.DIM;return K.createElement(ne,{paddingRight:2},!m&&K.createElement(K.Fragment,null,K.createElement(BracketWrap,{color:zn.DIM},"ctrl+t"),K.createElement(re,{color:zn.DIM}," ")),K.createElement(re,{color:h},g),!m&&K.createElement(re,{color:Gn.TEXT},d))},"LearningFeedMini");Ht(),hr();var fx=__name(({mode:e,pendingExitKey:t})=>t?K.createElement(re,{color:zn.DIM},"Press Ctrl+C again to exit"):"auto-accept"===e?K.createElement(ne,{flexDirection:"row"},K.createElement(re,{color:sr},"» accept edits on "),K.createElement(BracketWrap,{color:zn.DIM},"shift+tab")):"plan"===e?K.createElement(ne,{flexDirection:"row"},K.createElement(re,{color:rr},"plan mode "),K.createElement(BracketWrap,{color:zn.DIM},"shift+tab")):K.createElement(re,{color:zn.DIM},"? for shortcuts"),"ModeIndicator");Ht(),hr(),Ir();var yx=__name(({prInfo:e,showSeparator:t=!0})=>{if(!e)return null;if("OPEN"!==e.state&&"MERGED"!==e.state)return null;const n="OPEN"===e.state?zn.DIM:ir.MERGED;return K.createElement(K.Fragment,null,t&&K.createElement(re,{color:zn.DIM}," · "),K.createElement(re,{color:n},"PR "),K.createElement(xr,{url:e.url,text:`#${e.number}`,color:n}))},"PRLinkBadge"),wx=__name(({indicator:e,showSeparator:t=!0})=>e?.visible?K.createElement(K.Fragment,null,t&&K.createElement(re,{color:zn.DIM}," · "),K.createElement(re,{color:"connected"===e.type?zn.GREEN:zn.YELLOW},e.message)):null,"ConnectionIndicatorBadge"),Sx=__name(({termWidth:e,indicatorText:t,isIDEIndicator:n,permissionMode:r="standard",prInfo:o,tasteLearning:s,contextUsage:i,connectionIndicator:a,pendingExitKey:l,updateStatus:u,updateFailedInfo:d,currentProvider:m,showProviderInfo:g,isBashMode:h,shareInfo:f,showShareNotification:y,unshareNotificationMessage:w,tasteNotificationMessage:S,creditWarning:E})=>{const C=e>=60;return K.createElement(K.Fragment,null,K.createElement(ne,{flexDirection:"column",paddingLeft:2},"auto-accept"!==r&&"plan"!==r||l?K.createElement(ne,{flexDirection:"row",justifyContent:"space-between",width:e-1},K.createElement(ne,{flexDirection:"row",columnGap:0},n&&!l?K.createElement(re,{color:Zn},t):K.createElement(fx,{mode:r,pendingExitKey:l}),!l&&K.createElement(yx,{prInfo:o}),!l&&K.createElement(wx,{indicator:a})),C&&K.createElement(ne,{flexDirection:"column",alignItems:"flex-end"},s&&K.createElement(hx,null),i&&K.createElement(gx,{usage:i}))):K.createElement(K.Fragment,null,K.createElement(ne,{flexDirection:"row",justifyContent:"space-between",width:e-1},K.createElement(fx,{mode:r}),C&&s&&K.createElement(hx,null)),K.createElement(ne,{flexDirection:"row",justifyContent:"space-between",width:e-1},K.createElement(ne,{flexDirection:"row",columnGap:0},K.createElement(re,{color:n?Zn:zn.DIM},t),K.createElement(yx,{prInfo:o}),K.createElement(wx,{indicator:a})),C&&i&&K.createElement(gx,{usage:i}))),(u||d||g&&m)&&K.createElement(ne,{flexDirection:"row",columnGap:1},u&&K.createElement(re,null,_e.tick," ","Command Code"," updated:"," ",K.createElement(re,{color:zn.DIM},"v",u.updatedFrom),K.createElement(re,{color:zn.DIM}," ",_e.arrowRight," "),K.createElement(re,null,"v",u.updatedTo)),!u&&d&&K.createElement(re,{color:zn.YELLOW,dimColor:!0},_e.info," Update available:"," ",d.currentVersion," ",_e.arrowRight," ",d.latestVersion),g&&m&&K.createElement(re,{color:zn.GREEN,dimColor:!0},_e.bullet," Provider:"," ",getProviderDisplayName(m)))),h&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:zn.GREEN},"! for bash mode")),y&&f&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:Wn},"SHARED: ",f.url," (copied to clipboard)")),w&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:w.includes("NOT SHARED")?zn.RED:Wn},w)),S&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:Wn},S)),E&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:zn.YELLOW},_e.warning," ",E)))},"BottomIndicator");Ht(),RC(),vo(),hr();var bx=12,Ex=__name(e=>{const t=new Date(e),n=(new Date).getTime()-t.getTime(),r=Math.floor(n/6e4),o=Math.floor(n/36e5),s=Math.floor(n/864e5);return r<1?"just now":r<60?`${r} min ago`:o<24?`${o}h ago`:`${s}d ago`},"formatRelativeTime"),Cx=__name(e=>e.replace(/\s+/g," ").trim(),"normalizeSummary"),vx=__name(e=>truncateString({text:Cx(e),maxChars:mo}),"truncateMessage"),kx=__name(e=>e.title?Cx(e.title):vx(e.firstMessage),"getSessionSummary"),Tx=__name(({onSelectSession:e,onClose:t})=>{const[n,r]=J([]),[o,s]=J(0),[i,a]=J(0),[l,u]=J(!0),[d,m]=J(!1),[g]=J(()=>getCurrentGitBranch());Z(()=>{__name(async()=>{u(!0);const e=await vC.listSessions();r(e),u(!1)},"loadSessions")()},[]);const h=d&&g?n.filter(e=>e.gitBranch===g):n;if(ie((n,r)=>{if(!r.escape)return r.ctrl&&"b"===n?(m(e=>!e),s(0),void a(0)):void(r.upArrow?s(e=>{const t=Math.max(0,e-1);return t<i&&a(t),t}):r.downArrow?s(e=>{const t=Math.min(h.length-1,e+1);return t>=i+bx&&a(t-bx+1),t}):r.return&&h.length>0&&o<h.length&&e(h[o].id));t()}),l)return K.createElement(ne,{flexDirection:"column",paddingLeft:2},K.createElement(re,{color:zn.GRAY},"Loading sessions..."));if(0===h.length)return K.createElement(ne,{flexDirection:"column",paddingLeft:2},K.createElement(re,{color:zn.GRAY},d&&g?`No sessions found for branch "${g}"`:"No previous sessions found"),K.createElement(re,{color:zn.DIM},d?"Press ctrl+b to show all branches, ESC to cancel":"Press ESC to go back"));const f=h.slice(i,i+bx);return K.createElement(ne,{flexDirection:"column",paddingLeft:1,width:"100%"},K.createElement(re,{color:zn.CYAN,bold:!0},"Resume Session"),K.createElement(ne,{marginTop:1}),K.createElement(ne,{columnGap:2,marginBottom:1},K.createElement(ne,{width:5},K.createElement(re,{color:zn.GRAY}," ")),K.createElement(ne,{width:13},K.createElement(re,{color:zn.GRAY},"Modified")),K.createElement(ne,{width:20},K.createElement(re,{color:zn.GRAY},"Git Branch")),K.createElement(ne,{width:11},K.createElement(re,{color:zn.GRAY},"# Messages")),K.createElement(ne,null,K.createElement(re,{color:zn.GRAY},"Summary"))),K.createElement(ne,{columnGap:2},K.createElement(ne,{flexDirection:"column",width:5},f.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`sel-${n}`,color:o===n?zn.WHITE:zn.GRAY},o===n?`${_e.pointer} ${n+1}.`:` ${n+1}.`)})),K.createElement(ne,{flexDirection:"column",width:13},f.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`mod-${e.id}`,color:o===n?zn.WHITE:zn.GRAY},Ex(e.lastModified))})),K.createElement(ne,{flexDirection:"column",width:20},f.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`branch-${e.id}`,color:o===n?zn.WHITE:zn.GRAY,wrap:"truncate-end"},e.gitBranch||"-")})),K.createElement(ne,{flexDirection:"column",width:11},f.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`msg-${e.id}`,color:o===n?zn.WHITE:zn.GRAY},e.messageCount)})),K.createElement(ne,{flexDirection:"column"},f.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`summary-${e.id}`,color:o===n?zn.WHITE:zn.GRAY,wrap:"truncate-end"},kx(e))}))),K.createElement(ne,{marginTop:1}),h.length>bx&&K.createElement(re,{color:zn.DIM},"Showing ",i+1,"–",Math.min(i+bx,h.length)," ","of ",h.length,i>0?" · ↑ more":"",i+bx<h.length?" · ↓ more":""),K.createElement(re,{color:zn.DIM},"↑↓ navigate · Enter select · ctrl+b ",d?`[branch: ${g??"unknown"}]`:"branch filter"," · ESC cancel"))},"SessionsResumeTable");function getImageHintText({selectedIndex:e,imageCount:t,inHistory:n}){return-1!==e?t>1?"← → · Delete to remove · Esc to deselect":"Delete to remove · Esc to deselect":n?"↓ · ↑ imgs":"↑ to select"}function buildImageRows({imageCount:e,rowWidth:t}){const n=[];let r=[],o=0;for(let s=0;s<e;s++){const e=`[Image #${s+1}]`.length,i=e+(r.length>0?1:0);r.length>0&&o+i>t?(n.push(r),r=[s],o=e):(r.push(s),o+=i)}return r.length>0&&n.push(r),n}function shouldSelectImageOnUpArrow({isOnFirstLine:e,imageCount:t,selectedImageIndex:n,historyIndex:r}){return e&&t>0&&-1===n&&-1===r}function nextImageIndex({currentIndex:e,imageCount:t}){return e===t-1?0:e+1}function prevImageIndex({currentIndex:e,imageCount:t}){return 0===e?t-1:e-1}function removeImageAt({images:e,index:t}){const n=e.filter((e,n)=>n!==t);return{remainingImages:n,nextSelectedIndex:n.length>0?n.length-1:-1}}function ImageLabel({index:e,isSelected:t,filePath:n,showSpaceBefore:r}){const o=`[Image #${e+1}]`,s=n?createOSC8Link(`file://${n}`,o,!1):o;return K.createElement(re,null,r?" ":"",t?K.createElement(re,{inverse:!0},o):s)}function ImageRowsDisplay({detectedImages:e,selectedImageIndex:t,imageTempPaths:n,termWidth:r,inHistory:o}){if(0===e.length)return null;const s=getImageHintText({selectedIndex:t,imageCount:e.length,inHistory:o}),i=Math.max(1,r-(s.length+2)),a=buildImageRows({imageCount:e.length,rowWidth:i});return K.createElement(ne,{flexDirection:"column",width:"100%",alignItems:"flex-end"},a.map((e,r)=>K.createElement(ne,{key:r,flexDirection:"row"},K.createElement(ne,{flexShrink:0,marginRight:1},0===r&&K.createElement(re,{color:zn.DIM},s)),K.createElement(ne,{flexDirection:"row"},e.map((e,r)=>K.createElement(ImageLabel,{key:e,index:e,isSelected:e===t,filePath:n[e],showSpaceBefore:r>0}))))))}Ht(),hr(),Ht(),__name(getImageHintText,"getImageHintText"),__name(buildImageRows,"buildImageRows"),__name(shouldSelectImageOnUpArrow,"shouldSelectImageOnUpArrow"),__name(nextImageIndex,"nextImageIndex"),__name(prevImageIndex,"prevImageIndex"),__name(removeImageAt,"removeImageAt"),Lr(),__name(ImageLabel,"ImageLabel"),__name(ImageRowsDisplay,"ImageRowsDisplay"),Ht(),Db();var _x=__name((e={})=>{const{enabled:t=!0,paused:n=!1}=e,[r,o]=J(null),[s,i]=J(!1),a=X(!1),l=X(null),[u,d]=J(!1),[m,g]=J("connected"),h=X(null),f=X(null),y=te((e,t)=>{f.current&&(clearTimeout(f.current),f.current=null),g(e),d(!0),void 0!==t&&(f.current=setTimeout(()=>{d(!1)},t))},[]),w=te(()=>{f.current&&(clearTimeout(f.current),f.current=null)},[]),S=te(async(e=!1)=>{if(!a.current){a.current=!0;try{let t=l.current,n=t?.isConnected??!1;if(!n){t?.disconnect(),t=new Ab,l.current=t;const r=e?200:500;n=await t.connect(r)}const r=h.current;if(null===r?n&&y("connected",3e3):r!==n&&(n?y("connected",2e3):y("disconnected",5e3)),h.current=n,i(n),n&&t){const n=e?500:1e3,r=await t.getContext(n);null!==r||t.isConnected||(t.disconnect(),l.current=null),o(r)}else o(null)}catch{!0===h.current&&y("disconnected",5e3),h.current=!1,i(!1),o(null),l.current?.disconnect(),l.current=null}finally{a.current=!1}}},[y]);Z(()=>{if(!t||n)return;S(!0);const e=setInterval(()=>S(!1),500);return()=>{clearInterval(e),w(),l.current?.disconnect(),l.current=null}},[t,n,S,w]);const E={visible:u,message:"connected"===m?`IDE ${_e.tick}`:"IDE disconnected",type:m};return{context:r,connected:s,refresh:S,connectionIndicator:E}},"useVSCodeContext");Ht();var xx=__name(e=>{if(!e.activeFile&&!e.selection)return"";const t=["<ide-context>"];if(e.activeFile){const{relativePath:n,language:r,cursor:o}=e.activeFile;t.push(`File: ${n} (${r}, line ${o.line})`)}if(e.selection){const{text:n,startLine:r,endLine:o}=e.selection,s=e.activeFile?.language??"";t.push(`Selected lines ${r}-${o}:`),t.push(`\`\`\`${s}`);const i=n.replace(/```/g,"` ` `").replace(/<\/ide-context>/gi,"&lt;/ide-context&gt;");t.push(i),t.push("```")}return t.push("</ide-context>"),t.join("\n")+"\n"},"formatContextForPrompt");Ht();var Ax=__name((e,t)=>!(!e||!t?.selection&&!t?.activeFile?.relativePath),"hasIDEContext"),Px=__name((e,t,n)=>{const r=e?t?.selection:null;if(r)return`${r.lineCount} lines selected`;const o=e?t?.activeFile:null;if(o?.relativePath){const e=o.relativePath.split("/").pop()||"",t=n<80?15:n<120?25:40;return`In ${e.length>t?e.slice(0,t-1)+"…":e}`}return"? for shortcuts"},"getIndicatorText"),Ix=["","","[118;5u"];function removeAltPCharacter(e){return e.includes("π")?e.replace(/π/g,""):null}function isPrecededByWhitespace(e){return!e||" "===e||"\n"===e||"\t"===e}__name(removeAltPCharacter,"removeAltPCharacter"),__name(isPrecededByWhitespace,"isPrecededByWhitespace");var Nx=__name(()=>K.createElement(ne,{flexDirection:"column",paddingLeft:1},K.createElement(re,{color:zn.DIM,bold:!0},"Available Shortcuts:"),K.createElement(ne,{columnGap:4},K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.DIM},"! for bash mode"),K.createElement(re,{color:zn.DIM},"/ for commands"),K.createElement(re,{color:zn.DIM},"@ for file paths"),K.createElement(re,{color:zn.DIM},"shift + tab to toggle auto-accept")),K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.DIM},"double tap esc to clear input"),K.createElement(re,{color:zn.DIM},"ctrl + j / shift + ⏎ for newline"),K.createElement(re,{color:zn.DIM},"ctrl + g to open in editor"),K.createElement(re,{color:zn.DIM},"ctrl + z to suspend")))),"ShortcutMenu"),Rx=__name(({input:e,onSubmit:t,setInput:n,showCursor:r=!0,placeholder:o="Enter your input…",showFileList:i,setShowFileList:a,fileSearchQuery:l,setFileSearchQuery:u,onCommand:d,contextUsage:m,tasteLearning:g=!1,tasteUsage:h=!1,shareInfo:f,showShareNotification:y,unshareNotificationMessage:w,tasteNotificationMessage:S,creditWarning:E,updateStatus:C,updateFailedInfo:v,currentProvider:k,showProviderInfo:T,permissionMode:_="standard",onToggleAutoAccept:x,hintMessage:A,historyManager:P,pendingExitKey:I=null,onOverlayVisibilityChange:N,onDoubleEscapeEmpty:R,onAltP:M,isProcessing:$=!1,ideContextEnabled:L=!0})=>{const[D,O]=J(0),[F,q]=J(!1),[j,B]=J(!1),[U,z]=J(!1),[W,G]=J(!1),[H,V]=J(""),[Q,Y]=J(!1),oe=X(0),ae=X(0),[le,ce]=J([]),[ue,de]=J([]),[me,pe]=J(-1),[ge,he]=J(""),fe=X(!1),ye=X(!1),we=X(void 0),[Se,be]=J(-1),[Ee,Ce]=J(""),ve=X(0),{isEditorOpen:ke,editorError:Te,handleOpenInEditor:xe,clearEditorError:Ae}=useExternalEditor({input:e,setInput:n,setInputKey:O,onEditorClose:__name(()=>{fe.current=!1},"onEditorClose")}),{handlePaste:Pe,resetPasteState:Ie,isPasting:Ne}=useBracketedPaste({input:e,detectedContent:le,setInput:n,setDetectedImages:de,setDetectedContent:ce,incrementInputKey:__name(()=>O(e=>e+1),"incrementInputKey")}),{context:Re,connected:Me,refresh:$e,connectionIndicator:Le}=_x({enabled:L,paused:$}),{stdout:De}=se(),Oe=De?.columns??80,{pr:Fe}=mx();Z(()=>{const e=i||W||Q;N?.(e)},[i,W,Q,N]);const qe=te(()=>{de([]),pe(-1)},[]),je=te(()=>{n(""),B(!1),G(!1),V(""),Y(!1),ce([]),qe(),he(""),Ie(),be(-1),Ce(""),O(e=>e+1)},[n,Ie,qe]),Be=te(()=>{fe.current=!0;const{text:t,cursor:r}=insertTextAt(e,ve.current,"\n");n(t),we.current=r,O(e=>e+1),setTimeout(()=>{fe.current=!1},0)},[e,n]);ie(async(t,r)=>{if(-1!==me&&r.leftArrow)return void pe(prevImageIndex({currentIndex:me,imageCount:ue.length}));if(-1!==me&&r.rightArrow)return void pe(nextImageIndex({currentIndex:me,imageCount:ue.length}));if(r.upArrow){if(i||W||Q)return;const t=e.indexOf("\n"),r=-1===t||ve.current<=t;if(shouldSelectImageOnUpArrow({isOnFirstLine:r,imageCount:ue.length,selectedImageIndex:me,historyIndex:Se}))return void pe(ue.length-1);if(-1!==me&&pe(-1),0!==e.length&&-1===Se&&!r)return;const o=P?.count()??0;if(0===o)return;-1===Se&&Ce(e);const s=Math.min(Se+1,o-1);return void(s!==Se&&(be(s),n(P?.getAt(s)||""),O(e=>e+1)))}if(r.downArrow){if(i||W||Q)return;if(-1===Se)return;const t=e.lastIndexOf("\n");if(!(-1===t||ve.current>t))return;const r=Se-1;return be(r),n(-1===r?Ee:P?.getAt(r)||""),void O(e=>e+1)}if(""===t||r.ctrl&&"c"===t)return void qe();if(isCtrlKey({inputChar:t,key:r,letter:"g",ctrlCode:7}))return fe.current=!0,void xe();if(getIsExpandToolShortcut(r,t))return fe.current=!0,n(e),O(e=>e+1),void setTimeout(()=>{fe.current=!1},0);if(isNewlineShortcutKey({inputChar:t,key:r,isPasting:Ne()}))return ye.current=!0,Be(),void setTimeout(()=>{ye.current=!1},0);if(r.meta&&r.backspace)return void je();if(r.meta&&"w"===t)return fe.current=!0,void je();const o=r.ctrl&&"v"===t||Ix.includes(t),s=r.meta&&"v"===t;if(o||s){if(o&&"darwin"===process.platform){const t=e;fe.current=!0;const r=await detectClipboardImage();return r&&(de(e=>[...e,r]),n(t),O(e=>e+1)),void(fe.current=!1)}}else if(!r.ctrl&&!r.meta||"u"!==t){if(r.ctrl&&"z"===t?.toLowerCase())return z(!0),void setTimeout(()=>{process.kill(process.pid,"SIGTSTP")},100);if(-1!==me&&(r.delete||r.backspace)){const{remainingImages:e,nextSelectedIndex:t}=removeImageAt({images:ue,index:me});return de([...e]),void pe(t)}if(r.escape){if(-1!==me)return void pe(-1);if(W)return;if(Q)return Y(!1),n(ge),void O(e=>e+1);const t=Date.now();return t-oe.current<500?(e.length>0?je():R?.(),oe.current=0,ae.current=0):(oe.current=t,F||j||(ae.current=t)),q(!1),void B(!1)}F&&(r.backspace||r.delete)&&0===e.length&&q(!1)}});const Ue=te(async t=>{if(ke)return;const r=removeAltPCharacter(t);if(null!==r)return n(r),void M?.();const o=processBracketedPaste(t);if((o.isPasteStart||o.isPasteEnd||Ne())&&await Pe(t))return;if(fe.current)return void(fe.current=!1);-1!==Se&&be(-1);const s=1===t.length,l=t.slice(-1);if(s){if("?"===l&&!F)return q(!0),n(""),void O(e=>e+1);if("!"===l&&!j)return q(!1),B(!0),n(""),void O(e=>e+1)}if("/"!==l||W||"/"!==t||(G(!0),V("")),W&&!t.startsWith("/")&&(G(!1),V("")),W&&t.startsWith("/")){const e=t.substring(1);e.includes(" ")?(G(!1),V("")):V(e)}"@"!==l||i||isPrecededByWhitespace(t.length>1?t[t.length-2]:"")&&(a(!0),u(""));const d=t.lastIndexOf("@");if(t.length<e.length&&-1!==d&&" "===e.charAt(e.length-1)&&" "!==t.charAt(t.length-1)){const e=t.substring(d+1),n=!e.includes(" "),r=d>0?t[d-1]:"";n&&isPrecededByWhitespace(r)&&(a(!0),u(e))}if(i)if(t.length<e.length){const e=t.lastIndexOf("@");if(-1===e)a(!1),u("");else{const n=t.substring(e+1);u(n)}}else{const e=t.lastIndexOf("@");if(-1!==e){const n=t.substring(e+1),r=n.indexOf(" ");if(-1!==r){const e=n.substring(0,r);u(e),a(!1)}else u(n)}}F&&(t!==e||t.length<e.length)&&q(!1),Te&&Ae(),0===t.length&&(B(!1),G(!1),V(""),Y(!1),ce([]),u(""),he(""),Ie()),n(t)},[F,e,n,i,a,W,j,ue,Se,Pe,Ie,M,Te,Ae,ke]),ze=te(async()=>{if($e(),ae.current=0,F)return void q(!1);let n=e.trim();if(!j&&n.startsWith("/")&&d&&"handled"===(await d(n)).status)return P?.add(n),B(!1),G(!1),V(""),qe(),ce([]),be(-1),void Ce("");be(-1),Ce("");let r=[];const o=ue.length>0,s=le.length>0;if(!j&&o&&(r=[...ue]),!j&&s){let e=n;le.forEach((t,n)=>{const r=`[Text#${n+1}]`;e.includes(r)&&(e=e.replace(r,t))}),n=e}n.length>0&&P?.add(n),t({input:n,role:j?"bash":"user",images:r,ideContext:Re?xx(Re):void 0}),B(!1),G(!1),V(""),qe(),ce([])},[t,d,F,e,j,ue,le,P,$e,qe]),We=te(t=>{const r=s(process.cwd(),t);let o;if(i&&""!==l){const t=e.lastIndexOf("@");o=-1!==t?e.substring(0,t+1)+r+" ":r+" "}else o=`${e}${r} `;n(o),a(!1),u(""),O(e=>e+1)},[n,a,e,i,l,u]),Ge=te(()=>{a(!1),u("")},[a,u]),He=te(t=>{if("/resume"===t)P?.add(t),be(-1),Ce(""),he(e),G(!1),V(""),Y(!0),n(""),O(e=>e+1);else{const e=Object.values(vT).includes(t),r=kT.has(t);G(!1),V(""),e&&r?(P?.add(t),be(-1),Ce(""),n(""),O(e=>e+1),d&&d(t)):(n(t+" "),O(e=>e+1))}},[d,n,e,P]),Ve=te(e=>{G(!1),V(""),n(e+" "),O(e=>e+1)},[n]),Qe=te(()=>{G(!1),V(""),n(""),be(-1),Ce(""),O(e=>e+1)},[n]),Ke=te(e=>{Y(!1),n(""),he(""),be(-1),Ce(""),O(e=>e+1),d&&d(`/resume:${e}`)},[d,n]),Ye=te(()=>{Y(!1),n(ge),be(-1),Ce(""),O(e=>e+1)},[ge,n]),Je=te(e=>{ve.current=e,we.current=void 0},[]),Xe=ee(()=>{const t=Fe&&("OPEN"===Fe.state||"MERGED"===Fe.state);return"auto-accept"===_||"plan"===_||Me||t?!F&&!Q:!F&&0===e.length&&!j&&!Q},[F,e,j,Q,_,Me,Fe]),Ze=X(new Map),et=ee(()=>ue.map((e,t)=>{if(Ze.current.has(e))return Ze.current.get(e)??null;const n=saveTempImage(e,t+1);return Ze.current.set(e,n),n}),[ue]),tt=__name(()=>F||i||W||Q||U?0:Xe||I||j?3:4,"getBottomMargin");return K.createElement(ne,{width:"100%",flexDirection:"column",marginBottom:tt()},!Q&&K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(ImageRowsDisplay,{detectedImages:ue,selectedImageIndex:me,imageTempPaths:et,termWidth:Oe,inHistory:-1!==Se}),K.createElement(re,{color:j?zn.GREEN:zn.GRAY},_e.line.repeat(Oe)),K.createElement(TextInput,{key:D,value:e,placeholder:ke?"Save and close the editor to continue...":o,onChange:Ue,onSubmit:()=>{if(!ye.current)return Date.now()-ae.current<100?(ae.current=0,void Be()):void(i||W||Q||ke||ze());ye.current=!1},showCursor:!ke&&r&&-1===me,onCursorChange:Je,initialCursor:we.current,prefix:`${j?"!":_e.pointer} `,prefixColor:j?zn.GREEN:zn.WHITE}),K.createElement(re,{color:j?zn.GREEN:zn.GRAY},_e.line.repeat(Oe))),F&&K.createElement(Nx,null),U&&K.createElement(ne,{paddingTop:1},K.createElement(re,{color:zn.YELLOW},"Command Code has been suspended. Run `fg` to bring\n\t\t\t\t\t\tCommand Code back.")),i&&K.createElement(px,{onSelectFile:We,onClose:Ge,searchQuery:l}),W&&K.createElement(_T,{onSelectCommand:He,onInsertCommand:Ve,onClose:Qe,searchQuery:H}),Q&&K.createElement(Tx,{onSelectSession:Ke,onClose:Ye}),!W&&(Xe||I)&&K.createElement(Sx,{termWidth:Oe,indicatorText:Px(Me,Re,Oe),isIDEIndicator:Ax(Me,Re),permissionMode:_,prInfo:Fe,tasteLearning:g,contextUsage:m,connectionIndicator:Le,pendingExitKey:I,updateStatus:C,updateFailedInfo:v,currentProvider:k,showProviderInfo:T,isBashMode:j,shareInfo:f,showShareNotification:y,unshareNotificationMessage:w,tasteNotificationMessage:S,creditWarning:E}),Te&&K.createElement(ne,{paddingLeft:1,flexDirection:"column"},K.createElement(re,{color:zn.YELLOW},Te)))},"InputBox");Ht(),vo(),hr();var Mx=__name(({messages:e})=>0===e.length?null:K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(ne,{marginBottom:0},K.createElement(re,{color:Vn,inverse:!0},` Queued (${e.length}) `)),e.map((e,t)=>K.createElement(ne,{key:t},K.createElement(re,{color:zn.DIM},_e.pointerSmall," "),K.createElement(re,{color:zn.DIM},truncateString({text:e.displayMessage??e.input,maxChars:80}))))),"QueuedMessages"),$x=K.memo(({queuedMessages:e,isProcessing:t,executionState:n,status:r,input:o,setInput:s,onSubmit:i,showFileList:a,setShowFileList:l,fileSearchQuery:u,setFileSearchQuery:d,onCommand:m,outputTokens:g=0,contextUsage:h,tasteLearning:f,tasteUsage:y,shareInfo:w,showShareNotification:S,unshareNotificationMessage:E,tasteNotificationMessage:C,updateStatus:v,updateFailedInfo:k,creditWarning:T,currentProvider:_,showProviderInfo:x,permissionMode:A,onToggleAutoAccept:P,hintMessage:I,historyManager:N,pendingExitKey:R,onResetPendingExitKey:M,onDoubleEscapeEmpty:$,retryAttempt:L,onAltP:D})=>{const[O,F]=J(0),q=X(o);return Z(()=>{R&&o!==q.current&&o.length>0&&M?.(),q.current=o},[o,R,M]),Z(()=>{if(!t)return void F(0);const e=setInterval(()=>{F(e=>e+1e3)},1e3);return()=>{clearInterval(e)}},[t]),K.createElement(ne,{flexDirection:"column"},K.createElement(Mx,{messages:e}),K.createElement(ne,{flexDirection:"row",justifyContent:"space-between"},K.createElement(ne,{flexDirection:"column"},(t||n.isExecuting)&&null===L&&K.createElement(ex,{tokens:g,timeElapsed:O,status:n.isExecuting?`Executing: ${n.currentCommand}`:r}),I&&K.createElement(ne,{marginLeft:1},K.createElement(re,{color:zn.DIM}," ","⎿"," ","Tip: ",I)))),K.createElement(Rx,{input:o,setInput:s,onSubmit:i,placeholder:"Ask your question...",showFileList:a,setShowFileList:l,fileSearchQuery:u,setFileSearchQuery:d,onCommand:m,contextUsage:h,tasteLearning:f,tasteUsage:y,shareInfo:w,showShareNotification:S,unshareNotificationMessage:E,tasteNotificationMessage:C,updateStatus:v,updateFailedInfo:k,creditWarning:T,currentProvider:_,showProviderInfo:x,permissionMode:A,onToggleAutoAccept:P,hintMessage:I,historyManager:N,pendingExitKey:!R||t||n.isExecuting?null:R,onDoubleEscapeEmpty:$,onAltP:D,isProcessing:t}))});Ht(),Ov(),Uv(),Nr(),Fr();var Lx=__name(({onComplete:e,onCancel:t})=>{const[n,r]=J(!1),[o,s]=J(""),{authState:i,statusMessage:a,browserUrl:l,apiKeyInput:u,setApiKeyInput:d,handleApiKeySubmit:m,cancel:g}=useAuthFlow({onSuccess:__name((t,n)=>{const o=t.userName&&"API Key"!==t.userName&&"Manual API Key"!==t.userName?t.userName:"";s(o),isInternalTeamFlagEnforced()?r(!0):e(!0,o?`Logged in as ${o}`:"Logged in successfully")},"onSuccess"),onFailure:__name((t,n)=>{e(!1,n)},"onFailure"),onCancel:__name(()=>{t()},"onCancel")});return ie((t,r)=>{if(r.ctrl&&"c"===t){if(n)return void e(!0,o?`Logged in as ${o}. Note: Anthropic authentication skipped.`:"Logged in successfully. Note: Anthropic authentication skipped.");g()}}),n?K.createElement(Ar,{onSuccess:()=>{e(!0,o?`Logged in as ${o} with Anthropic`:"Logged in successfully with Anthropic")},onCancel:()=>{e(!0,o?`Logged in as ${o}. Note: Anthropic authentication skipped.`:"Logged in successfully. Note: Anthropic authentication skipped.")},onFailure:t=>{e(!0,o?`Logged in as ${o}. Anthropic auth failed: ${t}`:`Logged in successfully. Anthropic auth failed: ${t}`)}}):K.createElement(qv,{authState:i,statusMessage:a,browserUrl:l,apiKeyInput:u,setApiKeyInput:d,handleApiKeySubmit:m})},"LoginOverlay");async function discoverOAuthMetadata(e){const t=new m(e),n=`${t.protocol}//${t.host}`;try{const e=`${n}/.well-known/oauth-authorization-server`,t=await fetchWithTimeout(e,{method:"GET",headers:{Accept:"application/json"}});if(t.ok){const e=await t.json();if(e.authorization_endpoint&&e.token_endpoint)return{authorizationEndpoint:e.authorization_endpoint,tokenEndpoint:e.token_endpoint,registrationEndpoint:e.registration_endpoint,scopes:e.scopes_supported}}}catch(e){dlog("[MCP] OAuth discovery endpoint not available",e)}try{const e=`${n}/.well-known/openid-configuration`,t=await fetchWithTimeout(e,{method:"GET",headers:{Accept:"application/json"}});if(t.ok){const e=await t.json();if(e.authorization_endpoint&&e.token_endpoint)return{authorizationEndpoint:e.authorization_endpoint,tokenEndpoint:e.token_endpoint,registrationEndpoint:e.registration_endpoint,scopes:e.scopes_supported}}}catch(e){dlog("[MCP] OIDC discovery not available",e)}return null}async function checkServerAuthRequirements(e){try{const t=await fetchWithTimeout(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({jsonrpc:"2.0",method:"initialize",id:0,params:{protocolVersion:Xb,capabilities:{},clientInfo:Zb}})});return 401===t.status||403===t.status?{requiresAuth:!0,metadata:await discoverOAuthMetadata(e)||void 0}:{requiresAuth:!1}}catch(e){return{requiresAuth:!1,error:`Server unreachable: ${e instanceof Error?e.message:String(e)}`}}}async function registerOAuthClient({registrationEndpoint:e,clientName:t,redirectUris:n}){try{const r=await fetchWithTimeout(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({client_name:t,redirect_uris:n,token_endpoint_auth_method:"none",grant_types:["authorization_code","refresh_token"],response_types:["code"]})});if(r.ok){const e=await r.json();return{clientId:e.client_id,clientSecret:e.client_secret}}}catch(e){dlog("[MCP] OAuth client registration failed",e)}return null}Ht(),Ht(),uE(),rE(),gE(),dE(),hE(),kE(),TE(),AE(),Ht(),TE(),AE(),cE(),vE(),Ht(),wE(),rE(),Rn(),__name(discoverOAuthMetadata,"discoverOAuthMetadata"),__name(checkServerAuthRequirements,"checkServerAuthRequirements"),__name(registerOAuthClient,"registerOAuthClient"),hr();var Dx=__name(({onClose:e})=>{const[t,n]=J([]),[r,o]=J(!0),[s,i]=J(0),[a,l]=J("list"),[u,d]=J(null),m=te(async()=>{o(!0);try{const e=await listMcpServers(),t=getMcpConnectionManager().getConnectedServers(),r=await Promise.all(e.map(async e=>{const n=t.find(t=>t.name===e.name);let r,o,s="disconnected";return!1===e.config.enabled?s="disabled":n&&"connected"===n.status?(s="connected",r=n.tools.length):n&&"error"===n.status?(s="error",o=n.error):e.config.oauth&&(s=await hasTokens(e.name)?"authenticated":"requires_auth"),{name:e.name,config:e.config,scope:e.scope,status:s,toolCount:r,error:o}}));n(r)}catch{}finally{o(!1)}},[]);Z(()=>{m()},[m]);const g=ee(()=>{const e=[];for(const n of["local","project","user"])e.push(...t.filter(e=>e.scope===n));return e},[t]),h=g[s]??null;ie((t,n)=>{if(n.ctrl&&"c"===t)e();else if(n.escape)"actions"===a||"confirm-remove"===a?(l("list"),d(null)):e();else if("list"===a){if(n.upArrow&&(i(e=>Math.max(0,e-1)),d(null)),n.downArrow){if(0===g.length)return;const e=Math.max(0,g.length-1);i(t=>Math.min(e,t+1)),d(null)}n.return&&h&&(l("actions"),d(null))}});const f=__name(e=>{switch(e){case"connected":return K.createElement(re,{color:zn.GREEN},_e.tick);case"authenticated":return K.createElement(re,{color:zn.CYAN},_e.tick);case"requires_auth":return K.createElement(re,{color:zn.YELLOW},_e.warning);case"error":return K.createElement(re,{color:zn.RED},_e.cross);default:return K.createElement(re,{color:zn.GRAY},_e.circle)}},"getStatusIcon"),y=__name(e=>{switch(e.status){case"connected":return"connected"+(void 0!==e.toolCount?` · ${e.toolCount} tools`:"");case"authenticated":return"authenticated · not connected";case"requires_auth":return"requires authentication";case"error":return e.error||"error";case"disabled":return"disabled";default:return"not connected"}},"getStatusText"),w=__name(e=>{switch(e){case"local":return"Local MCPs";case"project":return"Project MCPs";case"user":return"User MCPs"}},"getScopeLabel"),S=__name(e=>{switch(e){case"local":return"~/.commandcode/projects/*/mcp.json";case"project":return".mcp.json";case"user":return"~/.commandcode/mcp.json"}},"getScopePath"),E=__name(async e=>{if(h)if("back"!==e.value)if("connected"!==e.value)if("authenticated"!==e.value)if("connect"!==e.value)if("auth"!==e.value)if("remove"!==e.value)if("disable"!==e.value)if("enable"!==e.value);else{d({text:`Enabling ${h.name}...`,color:zn.CYAN,loading:!0});try{if(!await updateMcpServerStatus({name:h.name,enabled:!0,scope:h.scope}))return void d({text:`${_e.cross} Failed to enable ${h.name}, server may no longer exist in ${h.scope} scope`,color:zn.YELLOW});await m(),d({text:`${_e.tick} Enabled ${h.name}`,color:zn.GREEN})}catch(e){d({text:`${_e.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:zn.RED})}}else{d({text:`Disabling ${h.name}...`,color:zn.CYAN,loading:!0});try{const e=getMcpConnectionManager();if(!await updateMcpServerStatus({name:h.name,enabled:!1,scope:h.scope}))return void d({text:`${_e.cross} Failed to disable ${h.name}, server may no longer exist in ${h.scope} scope`,color:zn.YELLOW});await e.disconnectServer(h.name),await m(),d({text:`${_e.tick} Disabled ${h.name}`,color:zn.GREEN})}catch(e){d({text:`${_e.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:zn.RED})}}else l("confirm-remove");else{if(!h.config.oauth)return void d({text:"No OAuth configured for this server",color:zn.YELLOW});d({text:`Authenticating ${h.name}...`,color:zn.CYAN,loading:!0});try{const e={authorizationUrl:h.config.oauth.authorizationUrl,tokenUrl:h.config.oauth.tokenUrl,clientId:h.config.oauth.clientId,clientSecret:h.config.oauth.clientSecret,scopes:h.config.oauth.scopes},t=await performOAuthFlow(h.name,e,{onStatus:__name(()=>{},"onStatus")});if(t.success){d({text:`${_e.tick} Authenticated with ${h.name}`,color:zn.GREEN});try{const e=getMcpConnectionManager();await e.ensureServerConnection(h.name)}catch{}await m()}else d({text:`${_e.cross} Auth failed: ${t.error}`,color:zn.RED})}catch(e){d({text:`${_e.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:zn.RED})}}else{d({text:`Connecting ${h.name}...`,color:zn.CYAN,loading:!0});try{const e=getMcpConnectionManager();await e.ensureServerConnection(h.name),d({text:`${_e.tick} Connected to ${h.name}`,color:zn.GREEN}),await m()}catch(e){d({text:`${_e.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:zn.RED})}}else d({text:"Already authenticated",color:zn.GREEN});else d({text:"Already connected",color:zn.GREEN});else l("list")},"handleActionSelect"),C=__name(async e=>{if(h)if("yes"===e.value)try{const e=getMcpConnectionManager();"connected"===h.status&&await e.disconnectServer(h.name),await removeMcpServer({name:h.name,scope:h.scope}),l("list"),await m(),i(e=>Math.min(e,Math.max(0,g.length-2)))}catch(e){d({text:`${_e.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:zn.RED}),l("actions")}else l("actions")},"handleRemoveConfirm");if(r)return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:Wn,bold:!0},"Manage MCP servers"),K.createElement(re,{color:zn.DIM},"Loading..."));if("confirm-remove"===a&&h)return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:zn.RED,bold:!0},"Remove ",h.name,"?"),K.createElement(re,{color:zn.DIM},"This will remove the server from ",h.scope," config."),K.createElement(ne,{marginTop:1},K.createElement(nt,{items:[{label:"Yes, remove",value:"yes"},{label:"Cancel",value:"no"}],onSelect:C,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:zn.WHITE},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?zn.WHITE:zn.GRAY}," ",t)})),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"↑↓ navigate · Enter to select · Esc to cancel")));if("actions"===a&&h){const e=[],t="disabled"===h.status,n="connected"===h.status,r="authenticated"===h.status||n;return t&&e.push({label:"Enable",value:"enable"}),!t&&n&&e.push({label:"Connected",value:"connected"}),t||n||e.push({label:"Connect",value:"connect"}),!t&&h.config.oauth&&r&&e.push({label:"Authenticated",value:"authenticated"}),t||!h.config.oauth||r||e.push({label:"Authenticate",value:"auth"}),t||e.push({label:"Disable",value:"disable"}),e.push({label:"Remove",value:"remove"}),e.push({label:"Back",value:"back"}),K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:Wn,bold:!0},h.name),K.createElement(ne,null,f(h.status),K.createElement(re,{color:zn.DIM}," ",y(h))),K.createElement(ne,{marginTop:1},K.createElement(nt,{items:e,onSelect:E,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:zn.WHITE},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?zn.WHITE:zn.GRAY}," ",t)})),u&&K.createElement(ne,{marginTop:1},u.loading&&K.createElement(re,{color:u.color},K.createElement(qe,{type:"dots"})," "),K.createElement(re,{color:u.color},u.text)),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"↑↓ navigate · Enter to select · Esc to go back")))}let v=null;return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:Wn,bold:!0},"Manage MCP servers"),K.createElement(re,{color:zn.DIM},t.length," ",1===t.length?"server":"servers"),0===t.length?K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(re,{color:zn.DIM},"No MCP servers configured."),K.createElement(re,{color:zn.DIM},'Use "cmd mcp add" to add a server.'),K.createElement(re,{color:zn.DIM},"Docs: https://commandcode.ai/docs/mcp")):K.createElement(ne,{marginTop:1,flexDirection:"column"},g.map((e,t)=>{const n=e.scope!==v;v=e.scope;const r=t===s;return K.createElement(K.Fragment,{key:e.name},n&&K.createElement(ne,{marginTop:0===t?0:1},K.createElement(re,{bold:!0},w(e.scope)),K.createElement(re,{color:zn.DIM}," (",S(e.scope),")")),K.createElement(ne,{paddingLeft:1},K.createElement(re,{color:r?zn.WHITE:zn.GRAY},r?"› ":" "),K.createElement(re,{color:r?zn.WHITE:void 0,bold:r},e.name),K.createElement(re,{color:zn.DIM}," · "),f(e.status),K.createElement(re,{color:"connected"===e.status?zn.GREEN:"authenticated"===e.status?zn.CYAN:"requires_auth"===e.status?zn.YELLOW:zn.GRAY}," ",y(e))))})),u&&K.createElement(ne,{marginTop:1},u.loading&&K.createElement(re,{color:u.color},K.createElement(qe,{type:"dots"})," "),K.createElement(re,{color:u.color},u.text)),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"↑↓ navigate · Enter to select · Esc to close")))},"McpManager");Ht(),hw(),Yt(),xn(),hr();var Ox=__name(({onClose:e})=>{const[t,n]=J([]),[r,o]=J(0),[s,i]=J(!0),[a,l]=J(null);Z(()=>{__name(async()=>{try{const e=await discoverMemoryFiles(process.cwd());n(e),i(!1)}catch(e){l(e instanceof Error?e.message:"Failed to discover memory files"),i(!1)}},"loadMemoryFiles")()},[]);const u=__name(async t=>{try{await openInEditor(t.path),e()}catch(t){console.error("Error opening memory file. Please ensure you have an editor set up."),e()}},"handleOpenInEditor"),d=t.filter(e=>"project"===e.type||"user"===e.type);if(ie((t,n)=>{n.escape?e():n.upArrow?o(e=>Math.max(0,e-1)):n.downArrow?o(e=>Math.min(d.length-1,e+1)):(n.return&&d[r]&&u(d[r]),"1"===t&&d[0]&&u(d[0]),"2"===t&&d[1]&&u(d[1]))}),s)return K.createElement(ne,{paddingLeft:1,paddingTop:1},K.createElement(re,{color:zn.DIM},"Loading memory files..."));if(a)return K.createElement(ne,{paddingLeft:1,paddingTop:1},K.createElement(re,{color:zn.RED},_e.cross," ",a));const m=d.map((e,t)=>{const n=t+1;let r="",o="";return"project"===e.type?(r=`${n}. Project memory`,o=e.exists?"Checked in at ./AGENTS.md":"Not found at ./AGENTS.md"):"user"===e.type&&(r=`${n}. User memory`,o=e.exists?"Saved in ~/.commandcode/AGENTS.md":"Not found in ~/.commandcode/AGENTS.md"),{label:r,value:e.path,description:o}});return K.createElement(ne,{flexDirection:"column",width:"100%",borderStyle:"single",borderColor:zn.GRAY,paddingTop:1,paddingBottom:1,paddingLeft:2,paddingRight:2},K.createElement(ne,null,K.createElement(re,{color:zn.WHITE,bold:!0},"Select memory to edit:")),K.createElement(ne,{columnGap:4,marginTop:1},K.createElement(ne,{flexDirection:"column"},m.map((e,t)=>K.createElement(re,{key:t,color:r===t?zn.WHITE:zn.DIM},r===t?`${Sn} `:" ",e.label))),K.createElement(ne,{flexDirection:"column"},m.map((e,t)=>K.createElement(re,{key:t,color:r===t?zn.WHITE:zn.DIM},e.description)))))},"MemorySelector");Ht(),Yt(),EC(),Kr(),Fr(),hr(),Ht(),hr();var Fx=lt()?"⠶":"#";function AssistantMessage({content:e}){return K.createElement(ne,null,K.createElement(re,{color:nr},Fx),K.createElement(ne,{marginLeft:1,flexGrow:1,flexShrink:1,minWidth:0},K.createElement(Markdown,null,e)))}function BashMessage({command:e,output:t,isPending:n=!1,hasError:r=!1}){let o=zn.GREEN,s=_e.tick,i="default",a=t||"(No output)";n&&(o=zn.YELLOW,s=_e.arrowRight,i=zn.YELLOW,a="Executing…"),r&&(o=zn.RED,s=_e.cross,i=zn.RED);const l=ee(()=>buildTreeConnectors(a),[a]);return K.createElement(ne,null,K.createElement(re,{color:o},s),K.createElement(ne,{flexDirection:"column",marginLeft:1},K.createElement(ne,null,K.createElement(re,{color:zn.GRAY},"$ "),K.createElement(re,{color:o,bold:!0},e)),K.createElement(ne,{columnGap:1,marginLeft:1},K.createElement(re,{color:dr},l),K.createElement(re,{color:i,wrap:"wrap"},a))))}function CommandResultMessage({message:e,details:t,hasError:n=!1}){const r=n?zn.YELLOW:void 0,o=ee(()=>buildTreeConnectors(e),[e]);return K.createElement(ne,{flexDirection:"column",marginBottom:0,marginTop:-1},K.createElement(ne,{columnGap:1},K.createElement(re,{color:dr},o),K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:r},e))),t&&K.createElement(ne,{marginLeft:3},K.createElement(re,{color:zn.DIM},"See ",t)))}function ErrorMessage({content:e}){const t=e.includes("Interrupted by user");return K.createElement(ne,null,K.createElement(re,{color:zn.RED},t?_e.pointer:_e.warning),K.createElement(ne,{marginLeft:1,flexGrow:1,flexShrink:1,minWidth:0},t?K.createElement(re,{color:zn.RED,wrap:"wrap"},e):K.createElement(Markdown,{color:zn.RED},e)))}function IDEStatusMessage({status:e,ide:t,details:n}){return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,"connected"===e&&K.createElement(re,null,K.createElement(re,{color:zn.GREEN},_e.tick),K.createElement(re,null," Connected to "),K.createElement(re,{color:zn.CYAN},t)),"installed"===e&&K.createElement(re,null,K.createElement(re,{color:zn.GREEN},_e.tick),K.createElement(re,null," Installed for "),K.createElement(re,{color:zn.CYAN},t)),"needs_reload"===e&&K.createElement(re,null,K.createElement(re,{color:zn.YELLOW},_e.circle),K.createElement(re,null," "),K.createElement(re,{color:zn.CYAN},t),K.createElement(re,null," extension needs reload")),"failed"===e&&K.createElement(re,null,K.createElement(re,{color:zn.RED},_e.cross),K.createElement(re,null," Install failed")),"not_in_ide"===e&&K.createElement(re,null,K.createElement(re,{color:zn.YELLOW},_e.circle),K.createElement(re,null," Not in IDE"))),n?.map((e,t)=>K.createElement(re,{key:t,color:zn.DIM}," ",e)))}function AutoCompactMessage({content:e}){return K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:zn.DIM},_e.bullet," ",e))}function TasteSkipMessage(){return K.createElement(ne,null,K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:Gn.BADGE_BG,color:Gn.BADGE_FG,bold:!0},Kk)),K.createElement(re,{color:zn.DIM}," Skipped. Run "),K.createElement(re,{color:lr.CODE},"/learn-taste"),K.createElement(re,{color:zn.DIM}," or "),K.createElement(re,{color:lr.CODE},"cmd learn-taste"),K.createElement(re,{color:zn.DIM}," anytime."))}function InfoMessage({content:e,metadata:t}){return t?.isTasteSkip?K.createElement(TasteSkipMessage,null):t?.isAutoCompact?K.createElement(AutoCompactMessage,{content:e}):K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:zn.DIM},_e.bullet," ",e))}__name(AssistantMessage,"AssistantMessage"),Ht(),hr(),__name(BashMessage,"BashMessage"),Ht(),hr(),__name(CommandResultMessage,"CommandResultMessage"),Ht(),hr(),__name(ErrorMessage,"ErrorMessage"),Ht(),hr(),__name(IDEStatusMessage,"IDEStatusMessage"),Ht(),hr(),__name(AutoCompactMessage,"AutoCompactMessage"),__name(TasteSkipMessage,"TasteSkipMessage"),__name(InfoMessage,"InfoMessage"),Ht(),Ht(),Yt();hr(),Yb(),Ht(),Kr();var qx="cmd";function getBinNames(){const e=getPackageJson();return e.bin&&"object"==typeof e.bin?Object.keys(e.bin):e.bin&&"string"==typeof e.bin?[e.name]:[qx]}function getInvokedCommandName(){try{const e=getBinNames(),n=process.argv[1];if(!n)return e[0]||qx;const r=t.basename(n).replace(/\.(m?[jt]s|cjs)$/,"");return e.includes(r)?r:e[0]||qx}catch{return qx}}function HelpMessage(){const e=getInvokedCommandName(),t=ee(()=>zb.filter(e=>!("/provider"===e.key&&!isInternalTeamFlagEnforced())),[]);return K.createElement(ne,{flexDirection:"column",paddingY:1},K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(ne,null,K.createElement(re,{bold:!0},"Command Code"),K.createElement(re,{color:zn.GRAY}," v","0.21.0")),K.createElement(re,{color:zn.GRAY},qb)),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Usage"),K.createElement(ne,{paddingLeft:2},K.createElement(re,null,e," <command> [options]"))),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Options"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},Ub.map(t=>K.createElement(ne,{key:t.key},K.createElement(re,null,t.key.replace(/^cmd/,e).padEnd(jb)),K.createElement(re,{color:zn.GRAY},t.description))))),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Commands"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},Wb.map(t=>K.createElement(ne,{key:t.key},K.createElement(re,null,t.key.replace(/^cmd/,e).padEnd(jb)),K.createElement(re,{color:zn.GRAY},t.description))))),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Slash Commands"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},t.map(e=>K.createElement(ne,{key:e.key},K.createElement(re,null,e.key.padEnd(jb)),K.createElement(re,{color:zn.GRAY},e.description))))),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Keyboard Shortcuts"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},Bb.map(e=>K.createElement(ne,{key:e.key},K.createElement(re,null,e.key.padEnd(jb)),K.createElement(re,{color:zn.GRAY},e.description))))),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Examples"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},Hb.map(t=>K.createElement(ne,{key:t.key},K.createElement(re,null,t.key.replace(/^cmd/,e).padEnd(jb)),K.createElement(re,{color:zn.GRAY},t.description))))),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:zn.CYAN},_e.pointer),K.createElement(re,{color:zn.GRAY}," ",Vb.replace(/cmd/,e))),K.createElement(ne,{flexDirection:"column"},K.createElement(re,{bold:!0},"Links"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},Gb.map(e=>K.createElement(ne,{key:e.key},K.createElement(re,null,e.key.padEnd(jb)),K.createElement(re,{color:zn.CYAN},e.description))))))}function SystemMessage({content:e,metadata:t}){if(e.includes("KEYBOARD SHORTCUTS")&&e.includes("COMMANDS"))return K.createElement(HelpMessage,null);if("CONTEXT"===e){const e=t?.analysis;if(e)return K.createElement(ContextMessage,{analysis:e})}return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{wrap:"wrap"},K.createElement(Markdown,null,e)))}__name(getBinNames,"getBinNames"),__name(getInvokedCommandName,"getInvokedCommandName"),Fr(),__name(HelpMessage,"HelpMessage"),__name(SystemMessage,"SystemMessage"),Ht(),xn(),Lr(),hr();var jx={"Interrupted by user":"Interrupted by user","Insufficient credits":yn};function UserMessage({content:e,images:t,imageCount:n=0}){const r="Interrupted by user"===e,o="Insufficient credits"===e,s=e.startsWith("Error:"),i=r||o||s,a=i&&jx[e]||e,l=null!=t?t.length:n,u=X(null);null===u.current&&t&&t.length>0&&(u.current=t.map((e,t)=>saveTempImage(e,t+1)));const d=u.current??[];return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{backgroundColor:i?void 0:tr.BG,paddingRight:1},K.createElement(re,{color:i?zn.RED:tr.POINTER,bold:!i},_e.pointer),K.createElement(ne,{marginLeft:1},K.createElement(re,{color:i?zn.RED:zn.WHITE,wrap:"wrap"},a))),l>0&&K.createElement(ne,{marginLeft:1},K.createElement(re,{color:zn.DIM},"⎿"," ",Array.from({length:l},(e,t)=>{const n=d[t],r=`[Image #${t+1}]`;return null!=n?createOSC8Link(`file://${n}`,r,!1):r}).join(" "))))}function renderFeedEntry(e,t){if("user"===e.role){const t=Array.isArray(e.metadata?.images)?e.metadata.images:void 0;return K.createElement(UserMessage,{content:e.input,images:t})}return"assistant"===e.role?K.createElement(AssistantMessage,{content:e.input}):"tool"===e.role?K.createElement(ToolMessage,{name:hC(e.name||""),input:e.input,output:e.output||"",isPending:mC(e),hasError:dC(e),metadata:e.metadata,expandedOutput:t}):"bash"===e.role?K.createElement(BashMessage,{command:e.command||"",output:e.output||"",isPending:mC(e),hasError:dC(e)}):"system"===e.role?K.createElement(SystemMessage,{content:e.input,metadata:e.metadata}):"info"===e.role?K.createElement(InfoMessage,{content:e.input,metadata:e.metadata}):"error"===e.role?K.createElement(ErrorMessage,{content:e.input}):"command-result"===e.role?K.createElement(CommandResultMessage,{message:e.input,details:e.details,hasError:e.hasError??!1}):"ide-status"===e.role?K.createElement(IDEStatusMessage,{status:e.status,ide:e.ide,details:e.details}):null}function getModelShortName(e){const t=Object.values(Ot).find(t=>t.id===e);return t?t.name.toLowerCase().replace(" ","-"):e.includes("sonnet-4-6")?"sonnet-4.6":e.includes("sonnet")?"sonnet-4.5":e.includes("opus-4-7")?"opus-4.7":e.includes("opus-4-6")?"opus-4.6":e.includes("opus")?"opus-4.5":"sonnet-4.6"}function TranscriptDivider({count:e,width:t}){const n=` ${e} hidden messages [ctrl+e to expand more] `,r=Math.max(0,Math.floor((t-n.length)/2)),o="─".repeat(r);return K.createElement(ne,{marginBottom:1},K.createElement(re,{color:er},o),K.createElement(BracketedText,{text:n,color:er}),K.createElement(re,{color:er},o))}__name(UserMessage,"UserMessage"),__name(renderFeedEntry,"renderFeedEntry"),__name(getModelShortName,"getModelShortName"),__name(TranscriptDivider,"TranscriptDivider");var Bx=K.memo(({feed:e,showHeader:t=!1,staticKey:n,expandedToolOutput:r=!1,currentModel:o,hiddenCount:s=0})=>{const i=s>0?{role:"transcript-divider",count:s}:null,a=[...t?["header"]:[],...i?[i]:[],...e],l=useTerminalWidth(),u=ee(()=>b_(l),[l]),d=ee(()=>T_(l),[l]),m=ee(()=>getPackageJson().version||"0.0.0",[]),g=ee(()=>getGitHeaderInfo(),[]),h=ee(()=>{const e=process.cwd(),t=process.env.HOME??process.env.USERPROFILE??"";return e.replace(t,"~")},[]),f=o?getModelShortName(o):"sonnet-4.6",y="taste-1",w=isInternalTeamFlagEnforced()&&!process.env.CMD_DEMO?" · co":"";return K.createElement(oe,{items:a,key:n,style:{width:"100%"}},e=>{if("object"==typeof e&&"transcript-divider"===e.role)return K.createElement(TranscriptDivider,{key:"transcript-divider",count:e.count,width:l});if("header"===e)return"compact"===d?K.createElement(ne,{key:"header",marginBottom:1,flexDirection:"row"},K.createElement(ne,{width:v_,flexShrink:0},K.createElement(__,null,C_)),K.createElement(ne,{flexDirection:"column",marginLeft:2},K.createElement(ne,null,K.createElement(re,{bold:!0},"Command Code"),K.createElement(re,{color:er}," ","v",m)),K.createElement(re,{color:er},"models: ",f," · ",y,w),K.createElement(re,{color:er},h,g&&g.isLocal&&g.branch&&` (${g.branch})`))):K.createElement(ne,{key:"header",marginBottom:1,flexDirection:"column"},K.createElement(__,null,u.trimEnd()),K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(ne,null,K.createElement(re,{color:er},"# "),K.createElement(re,{bold:!0},"Command Code"),K.createElement(re,{color:er}," v",m)),K.createElement(re,{color:er},"# models: ",f," · ",y,w),K.createElement(ne,null,K.createElement(re,{color:er},"# ",h,g&&g.isLocal&&g.branch&&K.createElement(re,{color:er}," ","(branch:"," ",g.branch,")")))));const t=e,n=renderFeedEntry(t,r);return K.createElement(ne,{key:t.id,paddingBottom:1,width:"90%"},n)})});Ht(),EC(),qr(),hr();var Ux=Y(__name(function LiveAgentStatusInner2({entry:e}){const t=hC(e.name||"Agent"),n=e.input||"",r=n.split(/[.\n]/)[0],o=r?r+(n.includes(".")||n.includes("\n")?".":""):n,s=e.metadata?.tokensUsed||0,i=e.metadata?.elapsedSeconds||0,a=e.metadata?.recentTools||[],[l,u]=J(".");return Z(()=>{const e=setInterval(()=>{u(e=>"..."===e?".":e+".")},500);return()=>clearInterval(e)},[]),K.createElement(ne,{flexDirection:"column",marginBottom:1,width:"90%"},K.createElement(ne,null,K.createElement(re,{backgroundColor:Jn.BG,color:Jn.FG,bold:!0},` ${t} `),o&&K.createElement(re,null," ","(",o,")")),K.createElement(ne,{columnGap:1,marginLeft:1},K.createElement(re,null,"⎿"," "),K.createElement(re,{color:zn.GRAY},"Running (",formatTime2(i)," | ",formatTokens(s),")",l)),a.length>0&&K.createElement(ne,{flexDirection:"column",marginLeft:1},a.map((e,t)=>{const n=hC(e.name);return K.createElement(ne,{key:t,columnGap:1},K.createElement(re,{color:zn.GRAY},"⎿"),K.createElement(re,{color:zn.GRAY}," ",n),e.input&&K.createElement(re,{color:zn.GRAY},"(",e.input,")"))})))},"LiveAgentStatusInner")),zx=Y(__name(function LiveAgentStatus2({entry:e}){return"tool"!==e.role?null:K.createElement(Ux,{entry:e})},"LiveAgentStatus"));Ht(),Yt(),Pr(),qr(),hr();var Wx=Object.values(Ot),Gx=Object.keys(jt),Hx=__name(({onSelect:e,onCancel:t,currentModel:n})=>{const[r,o]=J(""),[s,i]=J(0),[a,l]=J(null),[u,d]=J(null),m=ee(()=>{if(!r.trim())return Wx;const e=r.toLowerCase().split(""),t=__name(t=>{let n=0;for(const r of t)if(r===e[n]&&(n++,n===e.length))return!0;return!1},"fuzzyMatch");return Wx.map(e=>{const n=e.name.toLowerCase(),r=e.label.toLowerCase(),o=e.provider.toLowerCase(),s=(e.description||"").toLowerCase();let i=0;return t(n)&&(i+=100),t(r)&&(i+=50),t(o)&&(i+=25),t(s)&&(i+=10),{model:e,score:i}}).filter(({score:e})=>e>0).sort((e,t)=>t.score-e.score).map(({model:e})=>e)},[r]);Z(()=>{i(0)},[r]),Z(()=>{if(n&&!r){const e=m.findIndex(e=>e.id===n);e>=0&&i(e)}},[n,m,r]),Z(()=>{(async()=>{await isOAuthEnforced()&&d(await getConfiguredProvider())})()},[]),ie((n,a)=>{if(a.escape&&r)o("");else if(a.escape)t();else if(a.backspace||a.delete)o(e=>e.slice(0,-1));else{if(a.upArrow)return l(null),void i(e=>e>0?e-1:m.length-1);if(a.downArrow)return l(null),void i(e=>e<m.length-1?e+1:0);if(a.return){const t=m[s];if(!t)return;if(u){const e=Bt[u];if(e&&!e.includes(t.provider)){const e=jt[u]||u;return void l(`${e} OAuth does not support ${t.provider} models. Switch to GitHub Copilot via /provider.`)}}return void e(t.id)}!a.ctrl&&!a.meta&&!a.tab&&n&&1===n.length&&n>=" "&&o(e=>e+n)}});const g=ee(()=>{const e=new Set(m.map(e=>e.provider));return Gx.filter(t=>e.has(t))},[m]);return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:Wn,bold:!0},"Select model")),K.createElement(ne,{marginBottom:1},K.createElement(re,{dimColor:!0},"Switch between Command Code models. Applies to this session and future sessions.")),K.createElement(ne,{marginBottom:2,flexDirection:"column",width:"100%"},K.createElement(ne,{width:"100%"},K.createElement(re,{color:zn.GRAY},_e.pointerSmall),K.createElement(re,null," "),K.createElement(re,{color:r?zn.WHITE:zn.GRAY},r||"Type to search models..."),r&&K.createElement(re,{dimColor:!0}," (",m.length," found)"))),0===m.length?K.createElement(ne,{marginY:1},K.createElement(re,{color:zn.GRAY},'No models match "',r,'"')):g.map((e,t)=>{const r=m.filter(t=>t.provider===e);return 0===r.length?null:K.createElement(ne,{key:e,flexDirection:"column",marginBottom:t<g.length-1?1:0},K.createElement(re,{dimColor:!0,bold:!0},jt[e]),r.map(e=>{const t=m.indexOf(e)===s,r=e.id===n;return K.createElement(ne,{key:e.id},K.createElement(re,{color:t?zn.CYAN:zn.GRAY},t?`${_e.pointer} `:" "),K.createElement(re,{color:t?zn.CYAN:r?zn.GREEN:zn.WHITE},e.label.padEnd(24)),e.description&&K.createElement(re,{color:zn.DIM},e.description),r&&K.createElement(re,{color:zn.GREEN}," ",_e.tick))}))}),a&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.RED},a)),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"type to search . up/down navigate . Enter to select"),r?K.createElement(re,{color:zn.DIM}," . Esc to clear"):K.createElement(re,{color:zn.DIM}," . Esc to cancel")))},"ModelSelector");Ht(),Fr(),hr();var Vx=__name(({onSelect:e,onCancel:t,currentProvider:n})=>{const r=getProviderOptions(),o=__name(t=>{e(t.value)},"handleSelect");ie((e,n)=>{n.escape&&t()});const s=n?r.findIndex(e=>e.value===n):0,i=n&&-1===s;return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,{marginBottom:1,flexDirection:"row",justifyContent:"space-between"},K.createElement(ne,null,K.createElement(re,{bold:!0},"Select AI Provider")),n&&K.createElement(ne,{flexDirection:"row"},K.createElement(re,{color:zn.DIM},"Current: "),K.createElement(re,{color:zn.GREEN},getProviderDisplayName(n)),i&&K.createElement(re,{color:zn.YELLOW}," [OAuth enforced]"))),K.createElement(ne,{marginBottom:0},K.createElement(re,{color:zn.DIM},"Available Providers:")),K.createElement(nt,{items:r,onSelect:o,initialIndex:s>=0?s:0,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:e?zn.CYAN:zn.GRAY,bold:e},e?_e.triangleRightSmall:" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?zn.CYAN:zn.GRAY,bold:e},` ${t}`)}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Press ESC to cancel")))},"ProviderSelector");function RetryMessage({attempt:e}){const[t,n]=J(0);if(Z(()=>{if(null===e)return;const t=setInterval(()=>{n(e=>(e+1)%4)},500);return()=>clearInterval(t)},[e]),null===e)return null;const r=".".repeat(t).padEnd(3," ");return K.createElement(ne,{marginBottom:1},K.createElement(re,{color:ar,dimColor:!0},"Connection Issue. Retrying (attempt ",e,")",r))}Ht(),hr(),__name(RetryMessage,"RetryMessage"),Ht(),Ww(),vo(),xn(),hr();var Qx=[{mode:"both",label:"Both",description:"Restore conversation and code (recommended)"},{mode:"conversation",label:"Conversation only",description:"Rewind conversation, keep current code"},{mode:"files",label:"Code only",description:"Restore code, keep conversation"}],Kx=__name(({checkpoints:e,onSelect:t,onCancel:n})=>{const r=ee(()=>[...e].sort((e,t)=>new Date(e.timestamp).getTime()-new Date(t.timestamp).getTime()),[e]),[o,s]=J(Math.max(0,r.length-1)),[i,a]=J(Math.max(0,r.length-8)),[l,u]=J("checkpoint"),[d,m]=J(null),[g,h]=J(0),f=ee(()=>{if(!d)return!0;const e=r.findIndex(e=>e.messageId===d.messageId);if(-1===e)return!0;for(let t=e;t<r.length;t++)if(r[t].filesModified.length>0)return!0;return!1},[d,r]),y=ee(()=>f?Qx:Qx.filter(e=>"conversation"===e.mode),[f]);if(Z(()=>{if(r.length>0){const e=r.length-1;s(e),a(Math.max(0,r.length-8))}},[r.length,8]),ie((e,f)=>{f.escape?"mode"===l?(u("checkpoint"),m(null),h(0)):n():"checkpoint"===l?f.upArrow?s(e=>{const t=Math.max(0,e-1);return t<i&&a(t),t}):f.downArrow?s(e=>{const t=Math.min(r.length-1,e+1);return t>=i+8&&a(t-8+1),t}):f.return&&r.length>0&&(m(r[o]),u("mode"),h(0)):"mode"===l&&(f.upArrow?h(e=>Math.max(0,e-1)):f.downArrow?h(e=>Math.min(y.length-1,e+1)):f.return&&d&&y[g]&&t({messageId:d.messageId,mode:y[g].mode}))}),0===r.length)return K.createElement(ne,{flexDirection:"column",paddingLeft:2,paddingTop:1},K.createElement(re,{color:Wn,bold:!0},"Rewind"),K.createElement(re,{color:zn.DIM},"No checkpoints available. Start a conversation to create checkpoints."),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Press "),K.createElement(re,{color:zn.DIM,bold:!0},"Esc"),K.createElement(re,{color:zn.DIM}," to close")));if("mode"===l&&d)return K.createElement(ne,{flexDirection:"column",paddingLeft:2,paddingTop:1},K.createElement(re,{color:Wn,bold:!0},"Rewind"),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:zn.DIM},"Restore to: "),K.createElement(re,{color:zn.WHITE},truncateString({text:d.userPrompt||"checkpoint",maxChars:50}))),K.createElement(ne,{flexDirection:"column"},y.map((e,t)=>{const n=g===t,r=t===y.length-1;return K.createElement(ne,{key:e.mode,flexDirection:"column"},K.createElement(ne,{flexDirection:"row"},K.createElement(re,{color:n?Wn:void 0},n?`${Sn} `:" "),K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:n?Wn:zn.WHITE},e.label),K.createElement(re,{color:zn.DIM},e.description))),!r&&K.createElement(re,null," "))})),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Press "),K.createElement(re,{color:zn.DIM,bold:!0},"Enter"),K.createElement(re,{color:zn.DIM}," to confirm, "),K.createElement(re,{color:zn.DIM,bold:!0},"Esc"),K.createElement(re,{color:zn.DIM}," to go back")));const w=r.slice(i,i+8);return K.createElement(ne,{flexDirection:"column",paddingLeft:2,paddingTop:1},K.createElement(re,{color:Wn,bold:!0},"Rewind"),K.createElement(re,{color:zn.DIM},"Select a checkpoint to restore your session"),r.length>8&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Showing ",i+1,"-",Math.min(i+8,r.length)," ","of ",r.length)),K.createElement(ne,{marginTop:1}),K.createElement(ne,{flexDirection:"column"},w.map((e,t)=>{const n=i+t,s=o===n,a=e.filesModified.length,l=t===w.length-1,u=n===r.length-1;return K.createElement(ne,{key:e.messageId,flexDirection:"column"},K.createElement(ne,{flexDirection:"row"},K.createElement(re,{color:s?Wn:void 0},s?`${Sn} `:" "),K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,K.createElement(re,{color:s?Wn:zn.WHITE},truncateString({text:e.userPrompt||"(no prompt)",maxChars:60})),K.createElement(re,{color:zn.DIM}," • "),K.createElement(re,{color:zn.DIM},getRelativeTimeString({timestamp:e.timestamp}),u&&" (latest)")),K.createElement(re,{color:zn.DIM},a>0?`${a} file${a>1?"s":""} changed`:"No code changes"))),!l&&K.createElement(re,null," "))})),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Press "),K.createElement(re,{color:zn.DIM,bold:!0},"Enter"),K.createElement(re,{color:zn.DIM}," to select, "),K.createElement(re,{color:zn.DIM,bold:!0},"Esc"),K.createElement(re,{color:zn.DIM}," to cancel")))},"RewindSelector");Ht(),Rn(),Ht(),Ht(),dv();var Yx=__name(e=>{const[t,n]=J(e),[r,o]=J(null);return Z(()=>{const t=__name(()=>{n(e.map(e=>({...e,active:!1,complete:!1,items:[],insights:[],message:""}))),o(null)},"handleReset"),r=__name(e=>{"error"!==e.type?n(t=>{if("step_start"===e.type){const n=t.findIndex(t=>t.id===e.step);return n<0?t:t.map((t,r)=>r<n?{...t,active:!1,complete:!0}:r===n?{...t,active:!0,message:e.message||"",...e.label&&{label:e.label},..."complete"===e.step&&{complete:!0},...void 0!==e.learningCount&&void 0!==e.categories&&void 0!==e.storage&&t.summary&&{summary:{learningCount:e.learningCount,categories:e.categories,storage:e.storage}}}:t)}if("progress"===e.type){const n=t.findIndex(e=>e.active);return n<0?t:t.map((t,r)=>r===n?{...t,items:[...t.items,e.message]}:t)}if("insight"===e.type){const n=t.findIndex(e=>"learning"===e.id);return n<0?t:t.map((t,r)=>r===n?{...t,insights:[...t.insights,e.message]}:t)}return t}):o(e.message)},"handleNewEvent");return cv.on("reset",t),cv.on("new-event",r),()=>{cv.off("reset",t),cv.off("new-event",r)}},[e]),{steps:t,importError:r,setImportError:o}},"useProgressEvents");async function createRequestClient(){const e=getApiBaseUrl(),t=new Ly({baseUrl:e}),n=await getConfiguredProvider(),r=await isOAuthEnforced();let o,s;try{const e=await getOAuthCredentials({provider:n});o=e.token,s=e.oauthProvider,validateOAuthToken({token:o,provider:n})}catch(e){dlog("Failed to get or validate OAuth token:",e instanceof Error?e.message:String(e))}const i={[vt.PROJECT_SLUG]:vC.getCurrentProjectDirName(),[vt.INTERNAL_TEAM_FLAG_HEADER]:r.toString()};return o&&(i[vt.OAUTH_TOKEN]=`Bearer ${o}`,s&&(i[vt.OAUTH_PROVIDER]=s)),{request:t,headers:i}}function splitPromptsIntoBatches(e){const t=[];let n=[],r=0;for(const o of e){const e=estimateTokens(o);e>2e3?(n.length>0&&(t.push(n),n=[],r=0),t.push([o])):r+e>2e3?(n.length>0&&t.push(n),n=[o],r=e):(n.push(o),r+=e)}return n.length>0&&t.push(n),t}Ht(),Ht(),Sv(),Xy(),iw(),AS(),Rn(),dv(),Ht(),Rn(),dv(),AS(),Ht(),Ht(),Yt(),Xy(),iw(),RC(),Rn(),Pr(),qr(),__name(createRequestClient,"createRequestClient"),Ht(),AS(),__name(splitPromptsIntoBatches,"splitPromptsIntoBatches"),__name(function calculateObservationsPerBatch(e){return 4},"calculateObservationsPerBatch"),Ht(),Ht(),Rn(),hn(),dv(),Ht();var Jx="claude-haiku-4-5-20251001";function buildObserverPrompt(e,t){return`Scan prompts. ${t} casual observations like a dev friend glancing at your work.\n\nPLAIN TEXT ONLY. No markdown, no formatting.\n\nBe natural and VARIED. Don't repeat the same sentence starters.\n\nGood (notice the variety):\npnpm over npm, nice\ndebugging that auth flow\nreact + typescript stack\ncircular deps came up\ntui flicker stuff\nah the classic memory leak\nsession persistence wip\nfighting with imports again\nhaiku model issues huh\n\nBad (too repetitive - NEVER do this):\nI see you prefer pnpm\nI see debugging auth\nI see react stack\nI see circular deps\noh, TUI issues\noh, memory leak\n\nRules:\n- plain text, lowercase is fine\n- vary your sentence starts - mix it up\n- max 6 words\n- sound human, not robotic\n\nPrompts:\n${e.map((e,t)=>`${t+1}. ${e}`).join("\n")}\n\nVaried observations:`}function createInsightEmitter(){let e="",t=0;const n=__name(()=>{if(e.includes("\n")){const t=e.split("\n");for(let e=0;e<t.length-1;e++){const n=t[e].trim();n&&(dlog(`[ObserverAPI] emitting insight: ${n}`),cv.addEvent({type:"insight",message:n}))}e=t[t.length-1]}},"emitCompletedLines");return{addText:__name(r=>{t++,dlog(`[ObserverAPI] text chunk ${t}: "${r.substring(0,50)}..."`),e+=r,n()},"addText"),emitRemaining:__name(()=>{e.trim()&&(dlog(`[ObserverAPI] emitting final insight: ${e.trim()}`),cv.addEvent({type:"insight",message:e.trim()}))},"emitRemaining"),getChunkCount:__name(()=>t,"getChunkCount")}}async function callObserverAPI(e,t,n){dlog(`[ObserverAPI] calling ${kt.ALPHA.GENERATE} with model: ${Jx}`);const r={config:getEnvironmentContext(),memory:"",taste:"",skills:"",params:{tools:[],messages:[{role:"user",content:n}],model:Jx,max_tokens:200,temperature:.7,stream:!0},threadId:ve()},o=await e.post({endpoint:kt.ALPHA.GENERATE,body:r,headers:t,stream:!0});dlog("[ObserverAPI] got response stream");const s=createInsightEmitter();await consumeSSEStream(o,{onText:__name(e=>{s.addText(e)},"onText")}),dlog(`[ObserverAPI] stream complete, ${s.getChunkCount()} chunks received`),s.emitRemaining(),dlog("[ObserverAPI] done")}async function processBatch(e,t,n,r,o){let s=0;for(const e of n)s+=estimateTokens(e);dlog(`[Observer] batch ${r}/${o}: ${n.length} prompts`);const i=buildObserverPrompt(n,4);await callObserverAPI(e,t,i)}async function observeSessionPrompts(e){if(cv.observerHasRun)return;cv.markObserverRun();const{prompts:t}=e;try{const{request:e,headers:n}=await createRequestClient(),r=splitPromptsIntoBatches(t);dlog(`[Observer] ${t.length} prompts → ${r.length} batches`);const o=Math.min(r.length,6);for(let t=0;t<o;t++){if(cv.learningComplete){dlog(`[Observer] stopped at batch ${t} (learning complete)`);break}const o=r[t];try{await processBatch(e,n,o,t+1,r.length)}catch{}}dlog("[Observer] done")}catch(e){dlog(`[Observer] failed (non-critical): ${e instanceof Error?e.message:String(e)}`),cv.addEvent({type:"progress",message:"Continuing without live observations..."})}}Yt(),FE(),__name(buildObserverPrompt,"buildObserverPrompt"),__name(createInsightEmitter,"createInsightEmitter"),__name(callObserverAPI,"callObserverAPI"),__name(processBatch,"processBatch"),__name(observeSessionPrompts,"observeSessionPrompts");var Xx=class{static{__name(this,"SessionImporter")}static async findClaudeCodeSessions(t=0){const n=[];try{const r=e.join(y.homedir(),".claude","projects");await D.access(r);const o=process.cwd().replace(/\//g,"-");dlog(`[Import] scanning project: ${o}`);const s=(await D.readdir(r)).filter(e=>e===o);for(const o of s){const s=e.join(r,o);try{if(!(await D.stat(s)).isDirectory())continue;const r=(await D.readdir(s)).filter(e=>e.endsWith(".jsonl")&&!e.includes(".checkpoints"));dlog(`[Import] found ${r.length} sessions`);for(const o of r){const r=e.join(s,o),i=await D.stat(r),a=o.replace(".jsonl","");if(n.push({id:a,filePath:r,createdAt:i.birthtime,lastModified:i.mtime,messageCount:0,agent:"claude-code"}),t>0&&n.length>=t)break}if(t>0&&n.length>=t)break}catch{continue}}}catch{dlog("[Import] no claude sessions dir")}return n}static async findCodexSessions(e=0,t){try{cv.addEvent({type:"progress",message:"Scanning Codex sessions..."});const n=await findCodexSessions(process.cwd(),e=>{t?.(e),"reading"===e.phase&&cv.addEvent({type:"progress",message:`Scanning Codex: ${e.processedFiles}/${e.totalFiles} files (${e.matchedSessions} matched)`})},e);return dlog(`[Import] found ${n.length} Codex sessions`),n}catch(e){return dlog("[Import] no codex sessions",e),[]}}static async findCursorSessions(e=0){try{cv.addEvent({type:"progress",message:"Scanning Cursor sessions..."});const t=await findCursorSessions(process.cwd(),e);return dlog(`[Import] found ${t.length} Cursor sessions`),t}catch(e){return dlog("[Import] no cursor sessions",e),[]}}static async extractUserPrompts(e){const t=[];try{const n=(await D.readFile(e,"utf-8")).trim().split("\n");for(const e of n)if(e.trim())try{const n=JSON.parse(e);if("user"===n.type&&n.message){const e=n.message;let r="";e.content&&"string"==typeof e.content&&(r=e.content),r.trim()&&t.push(r.trim())}}catch{continue}t.length>0&&dlog(`[Import] extracted ${t.length} prompts from session`)}catch(t){dlog(`[Import] failed: ${e}`,t)}return t}static splitPromptsIntoBatches(e,t=15e4){const n=[];let r=[],o=0;for(const s of e){const e=estimateTokens(s);if(e>t){r.length>0&&(n.push(r),r=[],o=0);const e=this.splitLargePrompt(s,t);for(const t of e)n.push([t])}else o+e<=t?(r.push(s),o+=e):(r.length>0&&n.push(r),r=[s],o=e)}return r.length>0&&n.push(r),n}static splitLargePrompt(e,t){const n=[],r=e.split("\n");let o="",s=0;for(const e of r){const r=estimateTokens(e);s+r<=t?(o+=(o?"\n":"")+e,s+=r):(o&&n.push(o),o=e,s=r)}return o&&n.push(o),n}static async importAndLearn(){const e=[],t=[],n=[],r=[],o=[];try{cv.addEvent({type:"step_start",step:"importing",label:"Started Learning Taste",message:"Scanning for coding sessions..."});const s=await loadProjectSettings(),i=s.tasteOnboarding?.learnedSessions||{},a=i["claude-code"]?.length||0,l=i.codex?.length||0,u=i.cursor?.length||0;dlog(`[Import] loaded settings: claude-code=${a} learned, codex=${l} learned, cursor=${u} learned`);const d=await findNewSessions(i),m=d["claude-code"]||[],g=d.codex||[],h=d.cursor||[],f=m.length+g.length+h.length;if(dlog(`[Import] findNewSessions returned: claude-code=${m.length} new, codex=${g.length} new, cursor=${h.length} new`),0===f){const e=await this.findClaudeCodeSessions(),t=await findCodexSessions(process.cwd()),n=await findCursorSessions(process.cwd()),r=e.length+t.length+n.length,o=[{name:"Claude Code",count:e.length},{name:"Codex",count:t.length},{name:"Cursor",count:n.length}].filter(e=>e.count>0).sort((e,t)=>t.count-e.count).map(e=>`${e.count} ${e.name}`);cv.addEvent({type:"step_start",step:"complete",label:"Taste Already Learned",message:r>0?`From ${o.join(" + ")} sessions`:"No sessions found for this project"});const s=[];return e.length>0&&s.push({agent:"claude-code",sessionIds:e.map(e=>e.id),displayName:"Claude Code"}),t.length>0&&s.push({agent:"codex",sessionIds:t.map(e=>e.id),displayName:"Codex"}),n.length>0&&s.push({agent:"cursor",sessionIds:n.map(e=>e.id),displayName:"Cursor"}),{success:!1,totalPrompts:0,preferencesLearned:0,errors:[],totalSessions:r,learnedSessions:a+l+u,agentSessions:s,status:"already-learned"}}if(m.length>0){const e=(await this.findClaudeCodeSessions()).filter(e=>m.includes(e.id));n.push(...e)}if(g.length>0){const e=(await this.findCodexSessions()).filter(e=>g.includes(e.id));r.push(...e)}if(h.length>0){const e=(await this.findCursorSessions()).filter(e=>h.includes(e.id));o.push(...e)}const y=n.length+r.length+o.length;dlog(`[Import] total sessions: ${y} (claude-code: ${n.length}, codex: ${r.length}, cursor: ${o.length})`),cv.addEvent({type:"step_start",step:"batching",label:"Organizing your sessions",message:""});const w=[{name:"Claude Code",sessions:n,extractPrompts:this.extractUserPrompts},{name:"Codex",sessions:r,extractPrompts:extractCodexPrompts},{name:"Cursor",sessions:o,extractPrompts:extractCursorPrompts}].filter(e=>e.sessions.length>0).sort((e,t)=>t.sessions.length-e.sessions.length);for(const n of w){cv.addEvent({type:"progress",message:`${n.name}: ${n.sessions.length} sessions`});for(const r of n.sessions)try{const e=await n.extractPrompts(r.filePath);e.length>0&&t.push(...e)}catch(t){e.push(`${n.name} import failed: ${t instanceof Error?t.message:String(t)}`)}}if(0===t.length)return{success:!1,totalPrompts:0,preferencesLearned:0,errors:["No prompts found in sessions"]};const S=this.splitPromptsIntoBatches(t);dlog(`[Import] batched: ${t.length} prompts → ${S.length} batches`);const E=observeSessionPrompts({prompts:t}).catch(e=>{dlog(`[Import] observer error: ${e instanceof Error?e.message:String(e)}`)});cv.addEvent({type:"step_start",step:"learning",label:"Learning your coding taste",message:`Processing ${S.length} batch${1===S.length?"":"es"}`});try{const s=getApiBaseUrl(),i=new Ly({baseUrl:s});let a=!0;for(let e=0;e<S.length;e++){const t=S[e],n=e+1,r=S.length;r>1&&cv.addEvent({type:"progress",message:`Processing batch ${n}/${r}...`});const o=this.formatBatchLearning(t),s=new pv({request:i,sessionId:crypto.randomUUID(),projectRoot:process.cwd()}),l=[{role:"user",content:o}];dlog(`[Import] batch ${n}/${r}: ${t.length} prompts`),(await s.checkAndProcess({messages:l})).success||(a=!1,dlog(`[Import] batch ${n}/${r} failed`))}if(dlog(`[Import] all batches complete, success: ${a}`),cv.markLearningComplete(),await E,a){if(n.length>0){const e=n.map(e=>e.id);await markSessionsAsLearned("claude-code",e),dlog(`[Import] marked ${e.length} claude-code sessions as learned`)}if(r.length>0){const e=r.map(e=>e.id);await markSessionsAsLearned("codex",e),dlog(`[Import] marked ${e.length} codex sessions as learned`)}if(o.length>0){const e=o.map(e=>e.id);await markSessionsAsLearned("cursor",e),dlog(`[Import] marked ${e.length} cursor sessions as learned`)}}else dlog("[Import] NOT marking sessions as learned due to batch failures");const l=await this.extractLearningSummary(),u=[];if(n.length>0&&u.push(`Claude Code (${n.length})`),r.length>0&&u.push(`Codex (${r.length})`),o.length>0&&u.push(`Cursor (${o.length})`),!a){const s=cv.getEvents().some(e=>"error"===e.type&&e.message?.toLowerCase().includes("insufficient credits")),i="Learning failed - sessions not marked as learned";return e.push(i),s||cv.addEvent({type:"error",message:i}),{success:!1,totalPrompts:t.length,preferencesLearned:l.totalLearnings,errors:e,totalSessions:y,agentSessions:[...n.length>0?[{agent:"claude-code",sessionIds:n.map(e=>e.id),displayName:"Claude Code"}]:[],...r.length>0?[{agent:"codex",sessionIds:r.map(e=>e.id),displayName:"Codex"}]:[],...o.length>0?[{agent:"cursor",sessionIds:o.map(e=>e.id),displayName:"Cursor"}]:[]]}}return cv.addEvent({type:"step_start",step:"complete",label:"Learning Complete",message:`Learned from ${u.join(" + ")}`,learningCount:l.totalLearnings,categories:l.categories,storage:".commandcode/taste/taste.md"}),{success:!0,totalPrompts:t.length,preferencesLearned:l.totalLearnings,errors:e,totalSessions:y,agentSessions:[...n.length>0?[{agent:"claude-code",sessionIds:n.map(e=>e.id),displayName:"Claude Code"}]:[],...r.length>0?[{agent:"codex",sessionIds:r.map(e=>e.id),displayName:"Codex"}]:[],...o.length>0?[{agent:"cursor",sessionIds:o.map(e=>e.id),displayName:"Cursor"}]:[]]}}catch(n){const r=`Learning agent failed: ${n instanceof Error?n.message:String(n)}`;return e.push(r),cv.addEvent({type:"error",message:r}),{success:!1,totalPrompts:t.length,preferencesLearned:0,errors:e}}}catch(t){const n=t instanceof Error?t.message:String(t);return e.push(n),{success:!1,totalPrompts:0,preferencesLearned:0,errors:e}}}static async extractLearningSummary(){try{const t=e.join(process.cwd(),".commandcode","taste","taste.md"),n=await D.readFile(t,"utf-8"),r=n.match(/^- .+Confidence:/gm),o=r?r.length:0;return{totalLearnings:o,categories:n.split("\n").filter(e=>e.startsWith("# ")).map(e=>e.replace(/^# /,"").trim()).filter(e=>e&&!e.toLowerCase().startsWith("taste"))}}catch{return{totalLearnings:0,categories:[]}}}static formatBatchLearning(e){return e.map((e,t)=>`${t+1}. ${e}`).join("\n\n")}};dv();var Zx=__name(e=>new Promise((t,n)=>setTimeout(()=>n(new Error("Learning timed out. Try again with /learn-taste")),e)),"createTimeout"),eA=__name(e=>{const[t,n]=J({isImporting:!0,waitingForInput:!1,alreadyLearned:!1,learnedSessionCount:0,totalSessionCount:0,agentSessions:[],error:null});return Z(()=>{cv.reset(),cv.markImportStarted(),(async()=>{try{const t=await Promise.race([Xx.importAndLearn(),Zx(12e4)]);if(t.success)return void n(e=>({...e,isImporting:!1,waitingForInput:!0}));if("already-learned"===t.status)return void n(e=>({...e,isImporting:!1,alreadyLearned:!0,learnedSessionCount:t.learnedSessions||0,totalSessionCount:t.totalSessions||0,agentSessions:t.agentSessions||[],waitingForInput:!0}));const r=t.errors.join("\n");n(e=>({...e,isImporting:!1,waitingForInput:!0,error:r})),e&&e(r)}catch(t){const r=t instanceof Error?t.message:String(t);n(e=>({...e,isImporting:!1,waitingForInput:!0,error:r})),e&&e(r)}})()},[e]),t},"useImportProcess");Ht();var tA=__name(({onEscape:e,onEnter:t,enabled:n=!0})=>{ie((r,o)=>{n&&(o.escape&&e(),(o.return||"\n"===r)&&t())})},"useKeyboardInput");Ht(),Rn();var nA=__name(({autoLearn:e,onShouldSkip:t})=>{const[n,r]=J(null),[o,s]=J(null),i=X(!1);return Z(()=>{if(i.current)return;let n=null;return(async()=>{try{i.current=!0,dlog("[Hook:Conditions] loading...");const n=await checkOnboardingConditions();r(n),n.shouldTrigger||e?dlog(`[Hook:Conditions] result: ${n.reason}, sessions: ${n.sessionCount}`):(dlog("[Hook:Conditions] no trigger, skipping"),t())}catch(e){const r=e instanceof Error?e.message:String(e);dlog("[Hook:Conditions] error",r),s(r),n=setTimeout(()=>t(),2e3)}})(),()=>{n&&clearTimeout(n)}},[e,t]),{conditions:n,error:o,isLoading:!n&&!o}},"useOnboardingConditions");async function completeOnboarding(e){try{await markOnboardingCompleted(),dlog("[Helper] onboarding marked complete")}catch(e){dlog(`[Helper] complete error: ${e instanceof Error?e.message:String(e)}`)}finally{cv.reset(),e()}}async function skipOnboarding(e){try{await markOnboardingSkipped(),dlog("[Helper] onboarding marked skipped")}catch(e){dlog(`[Helper] skip error: ${e instanceof Error?e.message:String(e)}`)}finally{cv.reset(),e()}}Ht(),Rn(),Ht(),Rn(),dv(),__name(completeOnboarding,"completeOnboarding"),__name(skipOnboarding,"skipOnboarding");var rA=__name(({onStepChange:e,onError:t,onCompleteCallback:n})=>{const r=X(n),o=te(()=>{dlog("[Handler] import started → learning"),e("learning")},[e]),s=te(async()=>{dlog("[Handler] import complete → done"),e("done"),await completeOnboarding(()=>r.current())},[e]),i=te(e=>{dlog(`[Handler] import error: ${e}`),t(e)},[t]),a=te(async()=>{dlog("[Handler] error dismissed by user → done"),e("done"),await skipOnboarding(()=>r.current({skipped:!0}))},[e]),l=te(async()=>{dlog("[Handler] skipped → done"),e("done"),await skipOnboarding(()=>r.current({skipped:!0}))},[e]);return n!==r.current&&(r.current=n),{handleImportStart:o,handleImportComplete:s,handleImportError:i,handleErrorDismiss:a,handleSkip:l}},"useOnboardingHandlers");Ht(),Rn();var oA=__name(({conditions:e,autoLearn:t})=>{const[n,r]=J("checking"),o=X(!1);return Z(()=>{if(e&&!o.current){if(o.current=!0,t)return dlog("[Flow] autoLearn → learning"),void r("learning");dlog(`[Flow] → asking (${e.reason})`),r("asking")}},[e,t]),Z(()=>{dlog(`[Flow] step: ${n}`)},[n]),{step:n,setStep:r}},"useOnboardingFlow");Ht(),Ht(),hr();var sA=__name(({error:e})=>K.createElement(ne,{padding:1},K.createElement(ne,{flexDirection:"column",borderColor:zn.RED,padding:1},K.createElement(ne,{marginBottom:1},K.createElement(re,null,"Error initializing onboarding: ",e)),K.createElement(ne,null,K.createElement(re,null,"Continuing without onboarding...")))),"OnboardingError");Ht(),Ht(),Yt(),hr();var iA=__name(()=>`(run /${Mt.LEARN_TASTE} anytime)`,"getSkipHint"),aA=__name(()=>K.createElement(re,null,"Skip for now"," ",K.createElement(re,{color:zn.DIM},iA())),"SkipOptionText"),lA=__name(({sessionCount:e,agentSessions:t,onImport:n,onSkip:r})=>{const[o,s]=J(1);return ie((e,t)=>{t.escape?r():t.upArrow||t.downArrow?s(e=>1===e?2:1):"1"!==e?"2"!==e?t.return&&(1===o?n():r()):r():n()}),K.createElement(ne,{flexDirection:"column",borderStyle:"single",borderColor:Gn.TEXT,paddingX:1,paddingY:0},K.createElement(re,{color:Gn.TEXT,bold:!0},"Build Your Coding Taste"),K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(re,null,"Found"," ",1===e?"one session":`${e} sessions`," ","from"," ",t.map(e=>e.displayName).join(", ")," ","for this project."),K.createElement(ne,{marginTop:1},K.createElement(re,null,"Want me to analyze"," ",1===e?"that session":"those sessions"," ","and build your coding taste profile?"))),K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(ne,null,K.createElement(re,{color:1===o?Gn.TEXT:zn.GRAY},1===o?_e.pointer:" "," 1. Yes, learn from my sessions (recommended)")),K.createElement(ne,null,K.createElement(re,{color:2===o?Gn.TEXT:zn.GRAY},2===o?_e.pointer:" "," 2."," ",K.createElement(aA,null)))),K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"Use arrow keys or numbers to select, Enter to confirm")))},"ImportChoice");Ht(),Ht(),hr();var cA=__name(({error:e})=>K.createElement(ne,{flexDirection:"column",borderStyle:"single",borderColor:zn.RED,paddingX:2,paddingY:1,marginBottom:2},K.createElement(re,{color:zn.RED,bold:!0},"Oops, something went wrong:"),K.createElement(ne,{marginTop:1},K.createElement(re,null,e))),"ErrorSection");Ht(),Ht(),hr(),Ht(),Ht(),Ht(),hr(),Ht(),hr();var uA=__name(()=>K.createElement(re,{backgroundColor:Gn.BADGE_BG,color:Gn.BADGE_FG},Kk),"TasteBadge");Ht(),hr(),Ht();var dA=["percolating","excavating","deciphering","triangulating","osmosing","metabolizing","grokking","spelunking","interpolating","marinating","crystallizing","synthesizing","calibrating","fermenting","coalescing","transmuting","simmering","distilling","ruminating","perusing","assimilating","untangling","decoding","absorbing","harmonizing","digesting","contemplating","extrapolating","materializing","finalizing"],mA="⎿",pA=__name(()=>{const[e,t]=J(()=>Math.floor(Math.random()*dA.length));return Z(()=>{const e=setInterval(()=>{t(Math.floor(Math.random()*dA.length))},2e3);return()=>clearInterval(e)},[]),K.createElement(re,{color:zn.YELLOW},dA[e],"...")},"PulsingText");Ht(),hr();var gA=[_e.bullet,_e.squareSmallFilled,_e.lozenge,_e.star,_e.triangleRight,_e.triangleUp,_e.circleFilled,_e.pointer],hA=__name(e=>String(e).padStart(3," "),"padNum"),fA=__name(e=>gA[e%gA.length],"getSymbol"),yA=__name((e,t,n,r)=>r?`${e} observations (↑↓ scroll)`:`↑${hA(t)} ↓${hA(n)} (↑↓ scroll)`,"buildStatusLine"),wA=__name(({insights:e})=>{const[t,n]=J(0),[r,o]=J(!0),s=e.length,i=s>10,a=Math.max(0,s-10);if(Z(()=>{r&&i&&n(a)},[s,r,i,a]),ie((e,t)=>{if(i)return t.upArrow?(o(!1),void n(e=>Math.max(0,e-1))):void(t.downArrow&&n(e=>{const t=Math.min(a,e+1);return t===a&&o(!0),t}))}),0===s)return null;const l=e.slice(t,t+10),u=t,d=s-t-10;return K.createElement(ne,{flexDirection:"column",marginLeft:4,marginBottom:0},i&&K.createElement(re,{color:zn.DIM},yA(s,u,d,r)),l.map((e,n)=>{const r=t+n;return K.createElement(ne,{key:r,marginBottom:0},K.createElement(re,{color:zn.DIM},fA(r)," ",e))}))},"ScrollableInsights");Ht(),hr();var SA=__name(()=>{const[e,t]=J(!0);return Z(()=>{const e=setInterval(()=>{t(e=>!e)},500);return()=>clearInterval(e)},[]),K.createElement(re,{color:zn.YELLOW},e?_e.circleFilled:_e.circle)},"PulsingDot"),bA=__name(({label:e,message:t,active:n,complete:r,items:o,insights:s,isIntro:i,isAllComplete:a,summary:l})=>{if(i)return K.createElement(ne,{flexDirection:"column",marginBottom:0},K.createElement(uA,null),K.createElement(ne,{marginTop:0},K.createElement(re,{color:zn.DIM},mA),K.createElement(ne,{marginLeft:2},a?K.createElement(re,{color:Gn.TEXT},"learned your coding taste"):K.createElement(pA,null))));const u=__name(()=>r?K.createElement(re,{color:Kn.BG},_e.square):n?K.createElement(SA,null):K.createElement(re,{color:zn.DIM},_e.circle),"getStatusIcon"),d=o.length>0||s.length>0||t||l&&l.learningCount>0;return!r||n||d?K.createElement(ne,{flexDirection:"column",marginBottom:0},(n||r)&&K.createElement(ne,{marginBottom:0},K.createElement(ne,{marginRight:1},u()),K.createElement(re,{color:r?zn.WHITE:n?zn.YELLOW:zn.DIM},e)),r&&t&&(!l||0===l.learningCount)&&K.createElement(ne,{marginLeft:3,marginBottom:0},K.createElement(re,{color:zn.DIM},t)),o.length>0&&K.createElement(ne,{flexDirection:"column",marginLeft:1,marginBottom:0},o.map((e,t)=>K.createElement(re,{key:t,color:zn.DIM},`${_e.bullet} ${e}`))),s.length>0&&K.createElement(wA,{insights:s}),r&&l&&l.learningCount>0&&K.createElement(ne,{flexDirection:"column",marginLeft:1,marginBottom:0},K.createElement(ne,{marginBottom:1,flexDirection:"row"},K.createElement(re,null,mA),K.createElement(ne,{marginLeft:2},K.createElement(re,{color:Gn.TEXT},"Learned ",l.learningCount," preference",1===l.learningCount?"":"s",l.categories.length>0?` across ${l.categories.length} ${1===l.categories.length?"category":"categories"}`:""))),K.createElement(ne,{flexDirection:"column",marginLeft:1},K.createElement(re,{color:zn.DIM},_e.pointerSmall," Stored in"," ",l.storage),K.createElement(re,{color:zn.DIM},"Command Code automatically uses & updates taste files.")))):null},"StepItem"),EA=__name(({steps:e})=>{const t=e.find(e=>"complete"===e.id)?.complete??!1;return K.createElement(ne,{flexDirection:"column",marginBottom:1},e.map((e,n)=>K.createElement(ne,{key:e.id,marginLeft:0===n?0:3},K.createElement(bA,{label:e.label,message:e.message,active:e.active,complete:e.complete,items:e.items,insights:e.insights,summary:e.summary,isIntro:0===n,isAllComplete:t}))))},"StepsSection"),CA=__name(({steps:e})=>K.createElement(EA,{steps:e}),"ProgressSection");Ht(),hr();var vA=__name(({isImporting:e=!1,waitingForInput:t=!1})=>K.createElement(K.Fragment,null,e&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"ESC to cancel")),t&&K.createElement(ne,{marginTop:1},K.createElement(re,{bold:!0},"Press ENTER to continue"))),"HelpTextSection");Ht();var kA=[{id:"importing",label:"Initializing Taste Profile",message:"",active:!1,complete:!1,items:[],insights:[]},{id:"batching",label:"Organizing your sessions",message:"",active:!1,complete:!1,items:[],insights:[]},{id:"learning",label:"Learning your coding taste",message:"",active:!1,complete:!1,items:[],insights:[]},{id:"complete",label:"Learned your coding taste!",message:"",active:!1,complete:!1,items:[],insights:[],summary:{learningCount:0,categories:[],storage:".commandcode/taste/taste.md"}}],TA=__name(({onComplete:e,onError:t,onErrorDismiss:n})=>{const{steps:r,importError:o}=Yx(kA),{isImporting:s,waitingForInput:i,error:a}=eA(t);return tA({onEscape:__name(()=>{i&&((a||o)&&n?n():e())},"onEscape"),onEnter:__name(()=>{i&&((a||o)&&n?n():e())},"onEnter"),enabled:s||i}),K.createElement(ne,{flexDirection:"column",padding:1},o&&K.createElement(cA,{error:o}),!o&&K.createElement(CA,{steps:r}),K.createElement(vA,{isImporting:s,waitingForInput:i}))},"ImportProgress"),_A=__name(({step:e,conditions:t,onImportStart:n,onImportComplete:r,onImportError:o,onErrorDismiss:s,onSkip:i})=>"asking"===e?t&&"has_sessions"===t.reason?K.createElement(lA,{sessionCount:t.sessionCount,agentSessions:t.agentSessions,onImport:n,onSkip:i}):null:"learning"===e?K.createElement(TA,{onComplete:r,onError:o,onErrorDismiss:s}):null,"OnboardingStepRenderer"),xA=__name(({onComplete:e,autoLearn:t=!1})=>{Z(()=>(dlog("[UI:Onboarding] mounted"),()=>{dlog("[UI:Onboarding] unmounted")}),[]);const{conditions:n,error:r,isLoading:o}=nA({autoLearn:t,onShouldSkip:e}),{step:s,setStep:i}=oA({conditions:n,autoLearn:t}),{handleImportStart:a,handleImportComplete:l,handleImportError:u,handleErrorDismiss:d,handleSkip:m}=rA({onStepChange:__name(e=>{i(e)},"onStepChange"),onError:__name(()=>{},"onError"),onCompleteCallback:e});return dlog(`[UI:Onboarding] render: ${s}${n?.reason?` (${n.reason})`:""}${r?" ERROR":""}`),o?null:r?K.createElement(sA,{error:r}):"done"===s?null:K.createElement(_A,{step:s,conditions:n,onImportStart:a,onImportComplete:l,onImportError:u,onErrorDismiss:d,onSkip:m})},"TasteOnboarding");function getEntryCharCount(e){return("input"in e?e.input??"":"").length+("output"in e?e.output??"":"").length+("command"in e?e.command??"":"").length}function getBudgetedFeed(e,t){if(0===e.length)return[];const n=[...e].reverse();let r=t;const o=[];for(const e of n)if(o.unshift(e),r-=getEntryCharCount(e),r<=0)break;return o}__name(getEntryCharCount,"getEntryCharCount"),__name(getBudgetedFeed,"getBudgetedFeed");var AA=Y(__name(function MainView2({feed:e,liveEntries:t,queuedMessages:n,isCmdCodeBusy:r,staticKey:o,transcriptMode:s,tasteOnboardingEntryId:i,autoLearnTaste:a,retryAttempt:l,input:u,setInput:d,fileSearchQuery:m,setFileSearchQuery:g,showFileList:h,setShowFileList:f,showProviderSelector:y,showModelSelector:w,showMemorySelector:S,showMcpManager:E,showAgentsConfig:C,showRewindSelector:v,showLoginOverlay:k,showUsageOverlay:T,showAddDirModal:_,showCompactModeSelector:x,authComponentInfo:A,status:P,currentProvider:I,currentModel:N,showProviderNotification:R,shareInfo:M,showShareNotification:$,unshareNotificationMessage:L,updateStatus:D,updateFailedInfo:O,creditWarning:F,permissionMode:q,hintMessage:j,pendingExitKey:B,tasteLearningEnabled:U,interactionTokens:z,contextUsage:W,historyManagerRef:G,executionState:H,contextEngineRef:V,onSubmit:Q,onCommand:Y,onToggleAutoAccept:J,onResetPendingExitKey:X,onDoubleEscapeEmpty:Z,onTasteOnboardingComplete:oe,permissionPanel:se,questionPanel:ie,onRewindSelect:ae,onRewindCancel:le,onLoginComplete:ce,onLoginCancel:ue,setShowProviderSelector:de,setShowModelSelector:me,setShowMemorySelector:pe,setShowMcpManager:ge,setShowAgentsConfig:he,setShowAddDirModal:fe,setShowUsageOverlay:ye,handleProviderSelect:we,handleProviderCancel:Se,handleModelSelect:be,handleModelCancel:Ee,handleCompactModeSelect:Ce,handleCompactModeCancel:ve,handleAuthSuccess:ke,handleAuthCancel:Te}){const _e=ee(()=>e.filter(e=>"taste-onboarding"!==e.role),[e]),xe=useTerminalWidth(),Ae=ee(()=>"off"===s?_e:getBudgetedFeed(_e,"limited"===s?15e3:5e4),[_e,s]),Pe=ee(()=>"off"===s?0:Math.max(0,_e.length-Ae.length),[_e.length,Ae.length,s]),Ie=ee(()=>0===Pe?Ae:Ae.filter(e=>"user"!==e.role),[Ae,Pe]),Ne=te(()=>he(!1),[he]),Re=te(()=>pe(!1),[pe]),Me=te(()=>ge(!1),[ge]),$e=te(()=>fe(!1),[fe]),Le=te(()=>me(!0),[me]),De=!("off"!==s||se||ie||y||w||A||S||E||C||v||k||T||_||x||i);return K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(Bx,{staticKey:o,feed:Ie,showHeader:!0,expandedToolOutput:"off"!==s,currentModel:N,hiddenCount:Pe}),i&&K.createElement(xA,{onComplete:oe,autoLearn:a}),t.map(e=>e.metadata?.isAgent?K.createElement(zx,{key:e.id,entry:e}):K.createElement(ne,{key:e.id,marginBottom:1,width:"90%"},renderFeedEntry(e,"off"!==s))),K.createElement(RetryMessage,{attempt:l}),ie,se,"off"!==s&&K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(ne,null,K.createElement(re,{color:zn.DIM},"─".repeat(xe))),K.createElement(ne,{paddingRight:1},K.createElement(re,{backgroundColor:Kn.BG,color:Kn.FG,bold:!0},`${Qk}DETAILED TRANSCRIPT${Qk}`),K.createElement(re,{color:zn.DIM}," · "),K.createElement(re,{bold:!0},"ctrl+o"),K.createElement(re,{color:zn.DIM}," to toggle"),K.createElement(re,{color:zn.DIM}," · "),K.createElement(re,{bold:!0},"ctrl+e"),K.createElement(re,{color:zn.DIM}," ","to"," ","limited"===s?"show all":"collapse"))),De&&K.createElement($x,{queuedMessages:n,isProcessing:r,executionState:H,status:P,input:u,setInput:d,onSubmit:Q,showFileList:h,setShowFileList:f,fileSearchQuery:m,setFileSearchQuery:g,onCommand:Y,outputTokens:z,contextUsage:W,tasteLearning:U,shareInfo:M,showShareNotification:$,unshareNotificationMessage:L,updateStatus:D,updateFailedInfo:O,creditWarning:F,currentProvider:I,showProviderInfo:R,permissionMode:q,onToggleAutoAccept:J,hintMessage:j,historyManager:G.current,pendingExitKey:B,onResetPendingExitKey:X,onDoubleEscapeEmpty:Z,retryAttempt:l,onAltP:Le}),y&&K.createElement(ne,{marginY:1},K.createElement(Vx,{onSelect:we,onCancel:Se,currentProvider:I})),w&&K.createElement(ne,{marginY:1},K.createElement(Hx,{onSelect:be,onCancel:Ee,currentModel:N})),x&&K.createElement(ne,{marginY:1},K.createElement(ix,{onSelect:Ce,onCancel:ve})),C&&K.createElement(ne,{marginY:1},K.createElement(ox,{onCancel:Ne})),S&&K.createElement(ne,{marginY:1},K.createElement(Ox,{onClose:Re})),E&&K.createElement(ne,{marginY:1},K.createElement(Dx,{onClose:Me})),v&&V.current&&K.createElement(ne,{marginY:1},K.createElement(Kx,{checkpoints:V.current.listCheckpoints(),onSelect:ae,onCancel:le})),A&&K.createElement(ne,{marginY:1},K.createElement(A.Component,{onSuccess:ke,onCancel:Te})),k&&K.createElement(ne,{marginY:1},K.createElement(Lx,{onComplete:ce,onCancel:ue})),_&&K.createElement(ne,{marginY:1},K.createElement(U_,{onClose:$e})))},"MainView"));function renderView({feedState:e,sessionState:t,statusState:n,authState:r,uiOverlays:o,onboarding:s,exitState:i,pendingOps:a,permissionState:l,contextEngineRef:u,historyManagerRef:d,executionState:m,actionCallbacks:g,onSubmit:h,onCommand:f,input:y,setInput:w,fileSearchQuery:S,setFileSearchQuery:E,updateFailedInfo:C,creditWarning:v,handleTrust:k,handleNoTrust:T,handleToggleAutoAccept:_,handleDoubleEscapeEmpty:x,handleTasteOnboardingComplete:A,loadTasteStatus:P}){if(i.shouldExit)return null;if(s.checkingProject)return null;if(s.showTrustPrompt)return K.createElement(e_,{staticKey:o.staticKey,onTrust:k,onExit:T});if(o.showSessionSelector)return K.createElement(n_,{onSelectSession:g.onSelectSession,onNewSession:g.onNewSession});if(!s.projectTrusted)return null;const I=a.pendingQuestion?K.createElement(QuestionView,{pendingQuestion:a.pendingQuestion,permissionMode:l.permissionMode,setPermissionMode:l.setPermissionMode,setPendingQuestion:a.setPendingQuestion,setStatus:n.setStatus,setStaticKey:o.setStaticKey}):null,N=a.pendingPermission?K.createElement(p_,{pendingPermission:a.pendingPermission,permissionMode:l.permissionMode,setPendingPermission:a.setPendingPermission,setStatus:n.setStatus,respondToPrompt:l.respondToPrompt,showHintMessage:n.showHintMessage,handleToggleAutoAccept:_}):null;return o.showLearningFeed?K.createElement(LearningView,{setShowLearningFeed:o.setShowLearningFeed,setStaticKey:o.setStaticKey,onExit:()=>i.setShouldExit(!0)}):o.showTasteConfig?K.createElement(TasteConfigView,{staticKey:o.staticKey,setShowTasteConfig:o.setShowTasteConfig,loadTasteStatus:P}):o.showSkillsConfig?K.createElement(SkillsConfigView,{staticKey:o.staticKey,setShowSkillsConfig:o.setShowSkillsConfig}):o.showUsageOverlay?K.createElement(UsageView,{staticKey:o.staticKey,setShowUsageOverlay:o.setShowUsageOverlay}):o.showContextView?K.createElement(ContextConfigView,{staticKey:o.staticKey,contextEngineRef:u,setShowContextView:o.setShowContextView,setInput:w}):o.showStatusView?K.createElement(StatusConfigView,{staticKey:o.staticKey,setShowStatusView:o.setShowStatusView,setInput:w}):K.createElement(AA,{feed:e.feed,liveEntries:e.liveEntries,queuedMessages:e.queuedMessages,isCmdCodeBusy:e.isCmdCodeBusy,staticKey:o.staticKey,transcriptMode:o.transcriptMode,tasteOnboardingEntryId:s.tasteOnboardingEntryId,autoLearnTaste:s.autoLearnTaste,retryAttempt:n.retryAttempt,input:y,setInput:w,fileSearchQuery:S,setFileSearchQuery:E,showFileList:o.showFileList,setShowFileList:o.setShowFileList,showProviderSelector:o.showProviderSelector,showModelSelector:o.showModelSelector,showMemorySelector:o.showMemorySelector,showMcpManager:o.showMcpManager,showAgentsConfig:o.showAgentsConfig,showRewindSelector:o.showRewindSelector,showLoginOverlay:o.showLoginOverlay,showUsageOverlay:o.showUsageOverlay,setShowUsageOverlay:o.setShowUsageOverlay,showAddDirModal:o.showAddDirModal,showCompactModeSelector:o.showCompactModeSelector,authComponentInfo:r.authComponentInfo,status:n.status,currentProvider:r.currentProvider,currentModel:r.currentModel,showProviderNotification:r.showProviderNotification,shareInfo:n.shareInfo,showShareNotification:n.showShareNotification,unshareNotificationMessage:n.unshareNotificationMessage,updateStatus:n.updateStatus,updateFailedInfo:C,creditWarning:v,permissionMode:l.permissionMode,hintMessage:n.hintMessage,pendingExitKey:i.pendingExitKey,tasteLearningEnabled:n.tasteLearningEnabled,interactionTokens:n.interactionTokens,contextUsage:n.contextUsage,historyManagerRef:d,executionState:m,contextEngineRef:u,onSubmit:h,onCommand:f,onToggleAutoAccept:_,onResetPendingExitKey:i.resetPendingExitKey,onDoubleEscapeEmpty:x,onTasteOnboardingComplete:A,permissionPanel:N,questionPanel:I,onRewindSelect:g.onRewindSelect,onRewindCancel:g.onRewindCancel,onLoginComplete:g.onLoginComplete,onLoginCancel:g.onLoginCancel,setShowProviderSelector:o.setShowProviderSelector,setShowModelSelector:o.setShowModelSelector,setShowMemorySelector:o.setShowMemorySelector,setShowMcpManager:o.setShowMcpManager,setShowAgentsConfig:o.setShowAgentsConfig,setShowRewindSelector:o.setShowRewindSelector,setShowLoginOverlay:o.setShowLoginOverlay,setShowAddDirModal:o.setShowAddDirModal,handleProviderSelect:g.handleProviderSelect,handleProviderCancel:g.handleProviderCancel,handleModelSelect:g.handleModelSelect,handleModelCancel:g.handleModelCancel,handleCompactModeSelect:g.handleCompactModeSelect,handleCompactModeCancel:g.handleCompactModeCancel,handleAuthSuccess:g.handleAuthSuccess,handleAuthCancel:g.handleAuthCancel})}__name(renderView,"renderView");var PA=__name(({resume:e=!1,resumeSessionId:t,continue:n=!1,trust:r=!1,dangerouslySkipPermissions:o=!1,updateStatus:s,updateFailedInfo:i,initialPrompt:a,skipOnboarding:l=!1,initialPermissionMode:u,sessionTitleHolder:d})=>{const{exit:m}=le(),{stdout:g}=se(),[h,f]=J(""),[y,w]=J(""),S=X(!1),E=X(!1),C=X(null),v=X(null),k=useUiOverlays(),T=useFeed(),_=useSession(),x=useStatus(s),A=useAuth(),P=usePendingOps(),I=useOnboarding(),N=useExit(),{executeBash:R,executionState:M}=Ok(),$=usePermissionMode({initialPermissionMode:u,dangerouslySkipPermissions:o,setPendingPermission:P.setPendingPermission,setStatus:x.setStatus,contextEngineRef:v}),{createContextEngineCallbacks:L}=useContextEngine({sessionId:_.sessionId,sessionLoaded:_.sessionLoaded,showSessionSelector:k.showSessionSelector,projectTrusted:I.projectTrusted,setFeed:T.setFeed,setLiveEntries:T.setLiveEntries,setQueuedMessages:T.setQueuedMessages,queuedMessagesRef:T.queuedMessagesRef,setStatus:x.setStatus,pinnedStatusRef:x.pinnedStatusRef,setRetryAttempt:x.setRetryAttempt,setInteractionTokens:x.setInteractionTokens,setContextUsage:x.setContextUsage,setCurrentProvider:A.setCurrentProvider,shareInfoRef:x.shareInfoRef,permissionsService:$.permissionsService,permissionModeRef:$.permissionModeRef,setPendingQuestion:P.setPendingQuestion,contextEngineRef:v}),{onCommand:D}=useCommandCtx({feedState:T,sessionState:_,statusState:x,authState:A,uiOverlays:k,onboarding:I,exitState:N,permissionState:$,contextEngineRef:v,isSubmittingRef:S,executeBash:R,createContextEngineCallbacks:L,setInput:f}),{loadTasteStatus:O,loadCurrentProvider:F,onSubmit:q}=useStartup({resume:e,resumeSessionId:t,continueLatest:n,trust:r,initialPrompt:a,stdout:g,feedState:T,sessionState:_,statusState:x,authState:A,onboarding:I,uiOverlays:k,permissionState:$,contextEngineRef:v,isSubmittingRef:S,initialPromptSubmittedRef:E,historyManagerRef:C,executeBash:R,createContextEngineCallbacks:L,setInput:f,onCommand:D});useLifecycle({exit:m,feedState:T,exitState:N,statusState:x,authState:A,onboarding:I,uiOverlays:k,skipOnboarding:l,contextEngineRef:v,sessionTitleHolder:d});const{handleToggleAutoAccept:j,handleDoubleEscapeEmpty:B,handleTasteOnboardingComplete:U,handleTrust:z,handleNoTrust:W}=useHandlers({resume:e,feedState:T,onboarding:I,uiOverlays:k,exitState:N,pendingOps:P,permissionState:$,statusState:x,authState:A,contextEngineRef:v,loadTasteStatus:O,loadCurrentProvider:F,setInput:__name(e=>f(e),"setInput")}),G=useMainActionCallbacks({feedState:T,sessionState:_,statusState:x,authState:A,uiOverlays:k,permissionState:$,contextEngineRef:v,createContextEngineCallbacks:L,setInput:f}),{creditWarning:H}=useCreditWarning({interactionTokens:x.interactionTokens});return renderView({feedState:T,sessionState:_,statusState:x,authState:A,uiOverlays:k,onboarding:I,exitState:N,pendingOps:P,permissionState:$,contextEngineRef:v,historyManagerRef:C,executionState:M,actionCallbacks:G,onSubmit:q,onCommand:D,input:h,setInput:f,fileSearchQuery:y,setFileSearchQuery:w,updateFailedInfo:i,creditWarning:H,handleTrust:z,handleNoTrust:W,handleToggleAutoAccept:j,handleDoubleEscapeEmpty:B,handleTasteOnboardingComplete:U,loadTasteStatus:O})},"InteractiveCLI");_r(),Un(),RC(),hr();var IA=__name(e=>e.replace(/\x1B\[[0-9;]*[A-Za-z]/g,"").replace(/[\x00-\x1F\x7F]/g," ").trim(),"sanitizeTitleForOutput"),NA=ue.hex(zn.DIM),RA=__name(e=>{const t=getInvokedCommandName(),n=De([e]);return`${NA("To continue this session, run:")}\n${NA(`${t} --resume ${n}`)}\n`},"formatResumeHint"),MA=__name(e=>e?{isValid:!0}:{isValid:!1,errorMessage:["Error: Interactive mode requires a TTY terminal.","Please run this command directly in your terminal, not through a pipe or redirect."].join("\n")},"validateTtyEnvironment"),$A=__name(e=>Boolean(e.resume||e.continue),"shouldValidateSessions"),LA=__name(({isInitialized:e,sessionCount:t})=>e&&0===t?{canProceed:!1,exitCode:0,message:"No conversations found to resume."}:{canProceed:!0},"validateSessionAvailability"),DA=__name(({options:e,resumeSessionId:t,sessionTitleHolder:n})=>{let r;return e.permissionMode?r=e.permissionMode:e.plan&&(r="plan"),{resume:"boolean"==typeof e.resume?e.resume:void 0,resumeSessionId:t,continue:e.continue,trust:e.trust,dangerouslySkipPermissions:e.dangerouslySkipPermissions,initialPrompt:e.initialPrompt,skipOnboarding:e.skipOnboarding,initialPermissionMode:r,sessionTitleHolder:n}},"buildInteractiveCLIProps"),OA=__name(()=>({stdin:process.stdin,stdout:process.stdout,stderr:process.stderr,exitOnCtrlC:!1}),"getInkRenderOptions"),FA=__name(()=>{enableBracketedPasteMode(),process.on("exit",()=>{disableBracketedPasteMode()})},"setupBracketedPasteMode"),qA=__name(()=>{FA()},"initializeTerminal"),jA=__name(async(e={})=>{const t=MA(process.stdin.isTTY);let n;if(t.isValid||(console.error(t.errorMessage),process.exit(1)),qA(),"string"==typeof e.resume){const t=e.resume;await vC.isProjectInitialized()||(console.error("Project not initialized. Run cmd to start a conversation first."),process.exit(1));const r=await vC.findSessionByName(t);r||(console.error(`No session named "${t}" found.`),process.exit(1)),n=r.id}if($A(e)&&!n){const e=await vC.isProjectInitialized(),t=e?await vC.listSessions():[],n=LA({isInitialized:e,sessionCount:t.length});n.canProceed||(console.log(n.message),process.exit(n.exitCode))}startEarlyInputCapture();const r={},o=DA({options:e,resumeSessionId:n,sessionTitleHolder:r}),s=OA(),{waitUntilExit:i}=ae(K.createElement(PA,{...o}),s);await i();const a=await(r.loadTitle?.());if(a){const e=IA(a);e&&process.stdout.write(RA(e))}},"interactiveMode");tn(),Ht(),Yt(),pk(),ok();var BA=__name(async()=>{try{return await runLogin(),!!await getAuthKey()||(console.error(`${_e.cross} Authentication failed. Please try again with: cmd login`),!1)}catch(e){return isUserCancellation(e)||(console.error(`${_e.cross} Login failed: ${getErrorMessage(e)}`),console.error("Please try again with: cmd login")),!1}},"attemptLogin");async function ensureAuthenticated(){try{return!!await getAuthKey()||BA()}catch(e){return console.error("Error checking authentication:",e),!1}}__name(ensureAuthenticated,"ensureAuthenticated");var UA=__name(e=>e&&!e.startsWith("-")?e:void 0,"parsePrompt"),zA=__name(async()=>{await ensureAuthenticated()||process.exit(1)},"requireAuth"),WA=__name(e=>{const t={};return e.trust&&(t.trust=!0),e.dangerouslySkipPermissions&&(t.dangerouslySkipPermissions=!0,t.trust=!0),e.skipOnboarding&&(t.skipOnboarding=!0),e.plan&&(t.plan=!0),e.permissionMode&&(t.permissionMode=e.permissionMode),t},"buildRuntimeOptions"),GA=__name(({options:e,runtimeOptions:t,initialPrompt:n})=>e.resume?{resume:e.resume,...t}:e.continue?{continue:!0,...t}:{...t,initialPrompt:n},"getInteractiveConfig"),HA=__name((e,t)=>"string"==typeof e.print&&e.print.trim()?e.print:t&&!t.startsWith("-")?t:"","extractPrintQuery");async function interactiveModeAction(e,t){if(t.addDir&&t.addDir.length>0)for(const e of t.addDir)addDirectory(e);if(void 0!==t.print){const n=HA(t,e);return void await printMode({query:n,dangerouslySkipPermissions:t.dangerouslySkipPermissions,maxTurns:t.maxTurns,verbose:t.verbose,model:t.model,benchmarkOutput:t.benchmarkOutput})}const n=UA(e);await zA();const r=WA(t),o=GA({options:t,runtimeOptions:r,initialPrompt:n});await jA(o)}__name(interactiveModeAction,"interactiveModeAction"),Ht(),Rn(),No(),Pr(),nk(),pk(),globalThis.COMMAND_CODE_CWD=process.cwd();var VA=__name(()=>process.cwd(),"getCwd"),QA=__name(()=>process.argv.slice(2),"getArgs"),KA=__name(e=>e.includes("--local")?"local":e.includes("--staging")?"staging":"production","getEnv"),YA=__name(()=>{const e=VA(),t=QA(),n=KA(t);dlog(`[Startup] cwd: ${e}`),dlog(`[Startup] args: ${t.join(" ")}`),dlog(`[Startup] env: ${n}`),dlog(`[Startup] traceId: ${getTraceId()??"unavailable"}`)},"logStartupInfo");async function preRun(){YA(),process.argv.includes("--ide-setup")&&(formatSetupResult(await runIDESetup()).forEach(e=>console.log(e)),process.exit(0)),await maybeRunPendingUpdate(),await migrateDeprecatedModel(),await getAuthKey()&&detectAndTrackFirstInstall().catch(()=>{}),checkForUpdateAsync(),setTimeout(()=>ensureExtensionInstalled().catch(()=>{}),100)}__name(preRun,"preRun"),Ht(),Yt(),Rn(),Kr(),Yb(),Fr();var JA=getPackageJson(),XA=__name((e,t=[])=>[...t,e],"collectAddDir");function displayCustomHelp(){const e=JA.version,t=getInvokedCommandName(),n=zb.filter(e=>!("/provider"===e.key&&!isInternalTeamFlagEnforced()));console.log(),console.log(ue.bold("Command Code")+ue.gray(` v${e}`)),console.log(ue.gray(qb)),console.log(),console.log(ue.bold("Usage")),console.log(` ${t} <command> [options]`),console.log(),console.log(ue.bold("Options"));for(const e of Ub){const n=e.key.replace(/^cmd/,t);console.log(" "+n.padEnd(jb)+ue.gray(e.description))}console.log(),console.log(ue.bold("Commands"));for(const e of Wb){const n=e.key.replace(/^cmd/,t);console.log(" "+n.padEnd(jb)+ue.gray(e.description))}console.log(),console.log(ue.bold("Slash Commands"));for(const e of n)console.log(" "+e.key.padEnd(jb)+ue.gray(e.description));console.log(),console.log(ue.bold("Keyboard Shortcuts"));for(const e of Bb)console.log(" "+e.key.padEnd(jb)+ue.gray(e.description));console.log(),console.log(ue.bold("Examples"));for(const e of Hb){const n=e.key.replace(/^cmd/,t);console.log(" "+n.padEnd(jb)+ue.gray(e.description))}console.log(),console.log(ue.cyan("❯")+" "+ue.gray(Vb.replace(/cmd/,t))),console.log(),console.log(ue.bold("Links"));for(const e of Gb)console.log(" "+e.key.padEnd(jb)+ue.cyan(e.description));console.log()}function createProgram(){const e=new ke;return e.name(getInvokedCommandName()).description("Command Code with your coding taste.").version(JA.version,"-v, --version","display the version number").argument("[prompt]","Your prompt to run in interactive mode").option("-r, --resume [name]","Resume a session by name, or pick from history").option("-c, --continue"," Continue the most recent session in the current directory").option("-t, --trust","Trust the project (skip initial trust permission prompt)").addOption(new Te("--dangerously-skip-permissions","Bypass all permission prompts (use with caution)").hideHelp()).addOption(new Te("--yolo","Bypass all permission prompts (alias for --dangerously-skip-permissions)").implies({dangerouslySkipPermissions:!0})).option("--plan","Start in plan mode (read-only exploration and planning)").addOption(new Te("--auto-accept","Start in auto-accept mode").implies({permissionMode:"auto-accept"})).addOption(new Te("--permission-mode <mode>","Set permission mode").choices(["standard","plan","auto-accept"])).option("--skip-onboarding","Skip taste onboarding (for non-interactive/automated runs)").option("-p, --print [query]","Run in non-interactive mode, output response and exit").option("--max-turns <number>","Maximum conversation turns in print mode (default: 10)",e=>{const t=parseInt(e,10);if(isNaN(t)||t<1)throw new Error("--max-turns must be a positive integer");return t}).option("--verbose","Stream tool execution progress to stderr in print mode").option("--ide-setup","Setup extension to fetch IDE context").option("--add-dir <directory>","Add directory to workspace context",XA,[]).addOption(new Te("--model <model>","Override model for this run").hideHelp()).addOption(new Te("--benchmark-output <path>","Path to write benchmark metrics JSON").hideHelp()).addOption(new Te("--experimental","Enable experimental features").hideHelp()).addOption(new Te(Et).hideHelp()).addOption(new Te(Ct).hideHelp()).addOption(new Te("-d, --debug","Enable debug mode").hideHelp()).addOption(new Te("--local","Use local server").hideHelp()).addOption(new Te("--staging","Use staging server").hideHelp()).helpOption("-h, --help","Display help message").allowUnknownOption(),e.configureHelp({formatHelp:__name(()=>(displayCustomHelp(),""),"formatHelp")}),e}function setupCommanderHooks(e){e.hook("preAction",(e,t)=>{dlogSection("cmd");const n=t.name(),r=t.parent?.name();dlog(`[cmd] ${r&&r!==n?"subcommand":"running"}: ${n}`);const o=t.opts(),s=Object.entries(o).filter(([,e])=>void 0!==e&&!1!==e).map(([e,t])=>!0===t?`--${e}`:`--${e}=${t}`).join(" ");s&&dlog(`[cmd] options: ${s}`);const i=t.args;i.length>0&&dlog(`[cmd] arguments: ${i.join(" ")}`)}),e.hook("postAction",()=>{dlogSection("Done")})}function isTTY(){return Boolean(process.stdout.isTTY&&process.stdin.isTTY&&!process.env.CI)}__name(displayCustomHelp,"displayCustomHelp"),__name(createProgram,"createProgram"),__name(setupCommanderHooks,"setupCommanderHooks"),Ht(),No(),no(),Dv(),gk(),av(),Kr(),pk(),Ht(),__name(isTTY,"isTTY");var ZA=!1;function setupTelemetry(){initTelemetry()&&(startSession(),trackSystemInfo(),trackCliSessionExistsEvent(),registerCleanupHandlers())}async function trackSystemInfo(){try{const e=process.version,t=y.platform(),n=y.arch();let r,o,s,i;try{const e=await getAuthenticatedEntity();e.success&&(r=e.user?.userName,o=e.user?.id,s=e.org?.login,i=e.org?.id)}catch{}if(!o)try{const e=await loadCredentials();o=e?.userId}catch{}systemInfo({userName:r,userId:o,orgLogin:s,orgId:i,nodeVersion:e,platform:t,arch:n})}catch{}}function registerCleanupHandlers(){process.on("beforeExit",async()=>{await shutdownTelemetry()}),process.on("exit",()=>{shutdownTelemetrySync()}),process.on("SIGINT",handleShutdownSignal),process.on("SIGTERM",handleShutdownSignal)}function handleShutdownSignal(){ZA||(ZA=!0,shutdownTelemetry().finally(()=>{process.exit(0)}))}async function trackCliSessionExistsEvent(){try{if(!await getAuthKey())return;const e=getSessionId();if(!e)return;const t=getPackageJson().version||"unknown",n=y.platform(),r=y.arch(),o=isTTY()?"interactive":"non-interactive";await trackLifecycleEvent({eventType:"cli_session_exists",metadata:{sessionId:e,cliVersion:t,mode:o,os:`${n}-${r}`}})}catch{}}async function openGitHubIssue(e){const t=buildGitHubIssueUrl(e),n=xe("Opening GitHub issues...").start();try{await ge(t,{wait:!1,background:!0}),n.succeed(`Opened ${createOSC8Link(t,"GitHub issue")} in your browser`),console.log("")}catch(e){n.fail("Failed to open browser"),console.log(""),console.log(createOSC8Link(t,"Open GitHub issue manually")),console.log("")}}__name(setupTelemetry,"setupTelemetry"),__name(trackSystemInfo,"trackSystemInfo"),__name(registerCleanupHandlers,"registerCleanupHandlers"),__name(handleShutdownSignal,"handleShutdownSignal"),__name(trackCliSessionExistsEvent,"trackCliSessionExistsEvent"),pk(),Ht(),Lr(),__name(openGitHubIssue,"openGitHubIssue");var eP=new ke("feedback").description("Open GitHub issues to share feedback or report bugs").argument("[title]","Optional issue title").action(openGitHubIssue);Ht();var tP=new ke("help").description("Display help information").allowUnknownOption().allowExcessArguments().action(function(){this.parent?.help()});async function runInfo(e){const{waitUntilExit:t}=ae(K.createElement(OT,{verbose:e.verbose,text:e.text}));await t()}Ht(),Ht(),__name(runInfo,"runInfo");var nP=new ke("info").description("Display system information").option("--verbose","Show detailed CPU and network information").option("--text","Print plain text without colors").allowUnknownOption().allowExcessArguments().action(async e=>{await runInfo(e)});function runLearnTaste(){const{unmount:e}=ae(K.createElement(TA,{onComplete:__name(()=>{e(),process.exit(0)},"onComplete"),onErrorDismiss:__name(()=>{e(),process.exit(1)},"onErrorDismiss")}))}Ht(),Yt(),Ht(),__name(runLearnTaste,"runLearnTaste"),Rn(),No();var rP=new ke(Mt.LEARN_TASTE).description("Learn from your previous sessions - updates your taste profile").allowUnknownOption().allowExcessArguments().action(async()=>{try{runLearnTaste()}catch(e){trackError({error:sanitizeErrorForTelemetry({error:e instanceof Error?e:new Error(String(e)),label:"learn_taste_render_failed"}),context:{component:To.LEARN_TASTE_COMMAND,heading:"Learn taste render failed"}}),dlog(`[/learn-taste] render failed: ${e instanceof Error?e.message:String(e)}`),await shutdownTelemetry(),process.exit(1)}});function addMcpCommand(){const e=new ke("add");return e.description("Add an MCP server").argument("<name>","Server name (unique identifier)").argument("[url]","Server URL (required for http transport)").option("-t, --transport <type>","Transport type (stdio or http)","stdio").addOption(new Te("-s, --scope <scope>","Configuration scope").choices(["local","project","user"]).default("local")).option("-e, --env <KEY=value>","Environment variable (repeatable)",collectKeyValue,{}).option("-H, --header <header>","HTTP header (repeatable, http only)",collectHeaders,{}).allowUnknownOption().allowExcessArguments().action(async(e,t,n,r)=>{const o=getInvokedCommandName();try{let s;/^[a-zA-Z0-9][a-zA-Z0-9_-]*$/.test(e)&&!e.includes("__")||(console.error(ue.red(`Error: Invalid server name '${e}'`)),console.error(ue.gray("Names must start with a letter or number, contain only letters, numbers, hyphens, and single underscores")),process.exit(1)),"stdio"!==n.transport&&"http"!==n.transport&&(console.error(ue.red(`Error: Invalid transport type '${n.transport}'`)),console.error(ue.gray("Valid options: stdio, http")),process.exit(1));let i=!1;if("http"===n.transport){t||(console.error(ue.red("Error: URL is required for http transport")),console.error(ue.gray("Usage: cmd mcp add --transport http <name> <url>")),process.exit(1));try{new URL(t)}catch{console.error(ue.red(`Error: Invalid URL '${t}'`)),process.exit(1)}s={transport:"http",enabled:!0,url:t,...Object.keys(n.header).length>0&&{headers:n.header},...Object.keys(n.env).length>0&&{env:n.env}},console.log(ue.gray("Checking server authentication requirements..."));const r=await checkServerAuthRequirements(t);if(r.error&&console.log(ue.yellow(`Warning: ${r.error}`)),r.requiresAuth&&r.metadata){console.log(ue.cyan("Server requires OAuth authentication."));let t,n="command-code";if(r.metadata.registrationEndpoint){console.log(ue.gray("Registering OAuth client..."));const e=await registerOAuthClient({registrationEndpoint:r.metadata.registrationEndpoint,clientName:"Command Code CLI",redirectUris:[`http://127.0.0.1:${fE}/callback`]});e&&(n=e.clientId,t=e.clientSecret)}s.oauth={authorizationUrl:r.metadata.authorizationEndpoint,tokenUrl:r.metadata.tokenEndpoint,clientId:n,clientSecret:t,scopes:r.metadata.scopes},console.log(ue.gray("A browser window will open for authentication.\n"));const o=await performOAuthFlow(e,{authorizationUrl:r.metadata.authorizationEndpoint,tokenUrl:r.metadata.tokenEndpoint,clientId:n,clientSecret:t,scopes:r.metadata.scopes},{onStatus:__name(e=>{console.log(ue.gray(` ${e}`))},"onStatus")});o.success?console.log(ue.green("✓ Successfully authenticated")):(i=!0,console.log(ue.yellow(`Warning: Authentication failed: ${o.error}`)),console.log(ue.gray("You can retry with: cmd mcp auth "+e)),console.log(ue.gray("Or authenticate via the /mcp menu in a session")))}}else{const o=r.args,i=process.argv.indexOf("--");let a,l=[];if(-1!==i){const e=process.argv.slice(i+1);0===e.length&&(console.error(ue.red("Error: Command is required for stdio transport")),console.error(ue.gray("Usage: cmd mcp add --transport stdio <name> -- <command> [args...]")),process.exit(1)),a=e[0],l=e.slice(1)}else if(t){a=t;const n=o.indexOf(e);-1!==n&&o.length>n+2&&(l=o.slice(n+2))}else console.error(ue.red("Error: Command is required for stdio transport")),console.error(ue.gray("Usage: cmd mcp add --transport stdio <name> -- <command> [args...]")),console.error(ue.gray(" or: cmd mcp add <name> <command> [args...]")),process.exit(1);s={transport:"stdio",enabled:!0,command:a,...l.length>0&&{args:l},...Object.keys(n.env).length>0&&{env:n.env}}}await addMcpServer({name:e,serverConfig:s,scope:n.scope});const a="user"===n.scope?"global":"project"===n.scope?"project":"local";if(i?console.log(ue.yellow(`✓ Added MCP server '${e}' to ${a} config (authentication pending)`)):console.log(ue.green(`✓ Added MCP server '${e}' to ${a} config`)),"http"===s.transport)console.log(ue.gray(` URL: ${s.url}`));else{const e=[s.command,...s.args||[]].join(" ");console.log(ue.gray(` Command: ${e}`))}console.log(""),console.log(ue.cyan("Next steps:")),console.log(ue.gray(`Start ${o} and run /mcp to manage configured MCP servers.`))}catch(e){console.error(ue.red(`Error: ${e instanceof Error?e.message:String(e)}`)),process.exit(1)}}),e}function collectKeyValue(e,t){const[n,...r]=e.split("=");return n&&0!==r.length||(console.error(ue.red(`Error: Invalid format '${e}', expected KEY=value`)),process.exit(1)),t[n]=r.join("="),t}function collectHeaders(e,t){const n=e.indexOf(":");-1===n&&(console.error(ue.red(`Error: Invalid header format '${e}', expected 'Header: value'`)),process.exit(1));const r=e.substring(0,n).trim(),o=e.substring(n+1).trim();return r||(console.error(ue.red(`Error: Empty header name in '${e}'`)),process.exit(1)),t[r]=o,t}function listMcpCommand(){const e=new ke("list");return e.description("List configured MCP servers").action(async()=>{try{const e=await listMcpServers();if(0===e.length)return console.log(ue.yellow("\nNo MCP servers configured\n")),console.log(ue.gray("Add a server with:")),console.log(ue.gray(" cmd mcp add --transport http <name> <url>")),console.log(ue.gray(" cmd mcp add --transport stdio <name> -- <command>")),void console.log(ue.gray("\nDocs: https://commandcode.ai/docs/mcp"));console.log(ue.hex("#E4CCFF").bold("\nMCP Servers\n"));const t=Math.max(4,...e.map(e=>e.name.length)),n=5,r=7;console.log(ue.dim(` ${"NAME".padEnd(t)} ${"TYPE".padEnd(n)} ${"SCOPE".padEnd(r)} AUTH STATUS`));for(const o of e){const e=o.config.enabled?ue.green("enabled"):ue.gray("disabled");let s;s=o.config.oauth?await hasTokens(o.name)?ue.green(_e.tick):ue.red(_e.cross):o.config.headers||o.config.env?ue.green(_e.tick):ue.gray("-"),console.log(` ${ue.white(o.name.padEnd(t))} ${ue.cyan(o.config.transport.padEnd(n))} ${ue.gray(o.scope.padEnd(r))} ${s} ${e}`)}console.log(ue.dim(`\nTotal: ${e.length} server${1!==e.length?"s":""}\n`))}catch(e){console.error(ue.red(`Error: ${e instanceof Error?e.message:String(e)}`)),process.exit(1)}}),e}function getMcpCommand(){const e=new ke("get");return e.description("Show details for an MCP server").argument("<name>","Server name").action(async e=>{try{const t=await getMcpServer({name:e});t||(console.error(ue.red(`Error: MCP server '${e}' not found`)),process.exit(1));const{config:n,scope:r}=t;if(console.log(ue.hex("#E4CCFF").bold(`\nMCP Server: ${e}\n`)),console.log(` ${ue.dim("Scope:")} ${r}`),console.log(` ${ue.dim("Transport:")} ${n.transport}`),console.log(` ${ue.dim("Status:")} ${n.enabled?ue.green("enabled"):ue.gray("disabled")}`),"http"===n.transport){if(console.log(` ${ue.dim("URL:")} ${n.url}`),n.headers&&Object.keys(n.headers).length>0){console.log(` ${ue.dim("Headers:")}`);for(const[e,t]of Object.entries(n.headers)){const n=e.toLowerCase().includes("auth")||e.toLowerCase().includes("token")||e.toLowerCase().includes("key")?"***":t;console.log(` ${e}: ${n}`)}}}else console.log(` ${ue.dim("Command:")} ${n.command}`),n.args&&n.args.length>0&&console.log(` ${ue.dim("Args:")} ${n.args.join(" ")}`);if(n.env&&Object.keys(n.env).length>0){console.log(` ${ue.dim("Environment:")}`);for(const[e,t]of Object.entries(n.env)){const n=e.toLowerCase().includes("key")||e.toLowerCase().includes("secret")||e.toLowerCase().includes("token")||e.toLowerCase().includes("password")?"***":t;console.log(` ${e}=${n}`)}}console.log("")}catch(e){console.error(ue.red(`Error: ${e instanceof Error?e.message:String(e)}`)),process.exit(1)}}),e}function removeMcpCommand(){const e=new ke("remove");return e.description("Remove an MCP server").argument("<name>","Server name").addOption(new Te("-s, --scope <scope>","Scope to remove from (auto-detects if not specified)").choices(["local","project","user"])).action(async(e,t)=>{try{const n=await getMcpServer({name:e});n||(console.error(ue.red(`Error: MCP server '${e}' not found`)),process.exit(1));const r=t.scope||n.scope;t.scope&&t.scope!==n.scope&&(console.error(ue.red(`Error: Server '${e}' is defined in '${n.scope}' scope, not '${t.scope}'`)),process.exit(1)),await removeMcpServer({name:e,scope:r})||(console.error(ue.red(`Error: Failed to remove server '${e}'`)),process.exit(1));const o="user"===r?"global":"project"===r?"project":"local";console.log(ue.green(`✓ Removed MCP server '${e}' from ${o} config`))}catch(e){console.error(ue.red(`Error: ${e instanceof Error?e.message:String(e)}`)),process.exit(1)}}),e}function addJsonMcpCommand(){const e=new ke("add-json");return e.description("Add an MCP server from JSON configuration").argument("<name>","Server name (unique identifier)").argument("<json>","Server configuration as JSON string").addOption(new Te("-s, --scope <scope>","Configuration scope").choices(["local","project","user"]).default("local")).option("--client-secret <secret>","OAuth client secret (injected into oauth config)").action(async(e,t,n)=>{const r=getInvokedCommandName();try{let o,s;/^[a-zA-Z0-9][a-zA-Z0-9_-]*$/.test(e)&&!e.includes("__")||(console.error(ue.red(`Error: Invalid server name '${e}'`)),console.error(ue.gray("Names must start with a letter or number, contain only letters, numbers, hyphens, and single underscores")),process.exit(1));try{o=JSON.parse(t)}catch{console.error(ue.red("Error: Invalid JSON")),console.error(ue.gray("Make sure to quote the JSON string properly")),console.error(ue.gray(`Example: ${r} mcp add-json github '{"type":"stdio","command":"npx"}'`)),process.exit(1)}o&&"object"==typeof o&&"type"in o&&!("transport"in o)&&(o.transport=o.type,delete o.type),o?.oauth?.callbackPort&&(s=o.oauth.callbackPort,delete o.oauth.callbackPort),n.clientSecret&&o?.oauth&&(o.oauth.clientSecret=n.clientSecret);const i=sE.safeParse(o);if(!i.success){console.error(ue.red("Error: Invalid server configuration"));for(const e of i.error.issues)console.error(ue.gray(` ${e.path.join(".")}: ${e.message}`));process.exit(1)}const a=i.data;let l=!1;if("http"!==a.transport||a.url||(console.error(ue.red("Error: URL is required for http type")),process.exit(1)),"stdio"!==a.transport||a.command||(console.error(ue.red("Error: Command is required for stdio type")),process.exit(1)),await addMcpServer({name:e,serverConfig:a,scope:n.scope}),a.oauth){console.log(ue.cyan("Starting OAuth authentication...")),console.log(ue.gray("A browser window will open for authentication.\n"));const t={authorizationUrl:a.oauth.authorizationUrl,tokenUrl:a.oauth.tokenUrl,clientId:a.oauth.clientId,clientSecret:a.oauth.clientSecret,scopes:a.oauth.scopes},n=await performOAuthFlow(e,t,{...s&&{port:s},onStatus:__name(e=>{console.log(ue.gray(` ${e}`))},"onStatus")});n.success?console.log(ue.green(`\n✓ Successfully authenticated with '${e}'`)):(l=!0,console.error(ue.yellow(`\nWarning: Authentication failed: ${n.error}`)),console.error(ue.gray(`You can retry with: ${r} mcp auth ${e}`)),console.error(ue.gray("Or authenticate via the /mcp menu in a session")))}const u="user"===n.scope?"global":"project"===n.scope?"project":"local";if(l?console.log(ue.yellow(`✓ Added MCP server '${e}' to ${u} config (authentication pending)`)):console.log(ue.green(`✓ Added MCP server '${e}' to ${u} config`)),"http"===a.transport)console.log(ue.gray(` URL: ${a.url}`));else{const e=[a.command,...a.args||[]].join(" ");console.log(ue.gray(` Command: ${e}`))}console.log(""),console.log(ue.cyan("Next steps:")),console.log(ue.gray(`Start ${r} and run /mcp to manage configured MCP servers.`))}catch(e){console.error(ue.red(`Error: ${e instanceof Error?e.message:String(e)}`)),process.exit(1)}}),e}function authMcpCommand(){const e=new ke("auth");return e.description("Manage OAuth authentication for MCP servers").argument("[server]","Server name to authenticate").option("--status","Check authentication status").option("--clear","Clear stored authentication").option("--list","List servers with stored authentication").action(async(e,t)=>{const n=getInvokedCommandName();try{if(t.list){const e=await listServersWithTokens();if(0===e.length)return void console.log(ue.yellow("No servers with stored authentication."));console.log(ue.hex("#E4CCFF").bold("\nAuthenticated MCP Servers\n"));for(const t of e){const e=await getTokens(t),n=!e||isTokenExpired(e)?ue.yellow("expired"):ue.green("valid");console.log(` ${t}: ${n}`)}return void console.log("")}if(e||(console.error(ue.red("Error: Server name is required")),console.error(ue.gray(`Usage: ${n} mcp auth <server>`)),console.error(ue.gray(` ${n} mcp auth --list`)),process.exit(1)),t.status){if(!await hasTokens(e))return void console.log(ue.yellow(`No authentication stored for '${e}'`));const t=await getTokens(e);if(!t)return void console.log(ue.yellow(`No authentication stored for '${e}'`));if(isTokenExpired(t))console.log(ue.yellow(`Authentication for '${e}' has expired`)),t.refreshToken&&console.log(ue.gray(" A refresh token is available for re-authentication"));else{if(console.log(ue.green(`Authentication for '${e}' is valid`)),t.expiresAt){const e=Math.round((t.expiresAt-Date.now())/1e3/60);console.log(ue.gray(` Expires in ${e} minutes`))}t.scope&&console.log(ue.gray(` Scopes: ${t.scope}`))}return}if(t.clear)return void(await deleteTokens(e)?console.log(ue.green(`✓ Cleared authentication for '${e}'`)):console.log(ue.yellow(`No authentication stored for '${e}'`)));const r=await getMcpServer({name:e});r||(console.error(ue.red(`Error: MCP server '${e}' not found`)),console.error(ue.gray(`Use "${n} mcp list" to see configured servers`)),process.exit(1)),r.config.oauth||(console.error(ue.red(`Error: Server '${e}' does not have OAuth configured`)),console.error(ue.gray(`Add OAuth config using "${n} mcp add-json" with oauth field`)),process.exit(1));const o={authorizationUrl:r.config.oauth.authorizationUrl,tokenUrl:r.config.oauth.tokenUrl,clientId:r.config.oauth.clientId,clientSecret:r.config.oauth.clientSecret,scopes:r.config.oauth.scopes};console.log(ue.cyan(`Authenticating with '${e}'...`)),console.log(ue.gray("A browser window will open for authentication.\n"));const s=await performOAuthFlow(e,o,{onStatus:__name(e=>{console.log(ue.gray(` ${e}`))},"onStatus")});if(s.success)return console.log(ue.green(`\n✓ Successfully authenticated with '${e}'`)),void console.log(ue.gray("Restart the session to connect with the authenticated server."));console.error(ue.red(`\nError: Authentication failed: ${s.error}`)),console.log(ue.gray(`Try again with "${n} mcp auth ${e}"`)),process.exit(1)}catch(e){console.error(ue.red(`Error: ${e instanceof Error?e.message:String(e)}`)),process.exit(1)}}),e}function createMcpCommand(){const e=new ke("mcp");return e.description("Manage MCP (Model Context Protocol) servers").allowUnknownOption().allowExcessArguments(),e.addCommand(addMcpCommand()),e.addCommand(listMcpCommand()),e.addCommand(getMcpCommand()),e.addCommand(removeMcpCommand()),e.addCommand(addJsonMcpCommand()),e.addCommand(authMcpCommand()),e}async function runCommand(e){return new Promise((t,n)=>{const r=$(e.cmd,e.args,{stdio:["ignore","pipe","pipe"],env:process.env});let o="",s="";r.stdout.on("data",e=>{o+=String(e)}),r.stderr.on("data",e=>{s+=String(e)}),r.on("error",n),r.on("close",r=>{0!==r?n(new Error(`${e.cmd} ${e.args.join(" ")} failed${s?`: ${s.trim()}`:""}`)):t({stdout:o,stderr:s})})})}async function detectDefaultBranch(e){try{const{stdout:t}=await runCommand({cmd:"git",args:["-C",e.repoDir,"symbolic-ref","refs/remotes/origin/HEAD","--short"]}),n=t.trim().replace(/^origin\//,"");if(n)return n}catch{}for(const t of["main","master"])try{return await runCommand({cmd:"git",args:["-C",e.repoDir,"rev-parse","--verify",t]}),t}catch{}try{const{stdout:t}=await runCommand({cmd:"git",args:["-C",e.repoDir,"rev-parse","--abbrev-ref","HEAD"]});return t.trim()}catch{return"main"}}async function findGitRoot4(e){try{const{stdout:t}=await runCommand({cmd:"git",args:["-C",e.dir,"rev-parse","--show-toplevel"]});return t.trim()}catch{return null}}async function countLearnings(e){try{return(await D.readFile(e,"utf-8")).split("\n").filter(e=>e.trim().startsWith("- ")&&e.includes("Confidence:")).length}catch{return 0}}async function resolveSource(t){const n=t.source.trim(),r=e.resolve(n);try{if(!(await D.stat(r)).isDirectory())throw new Error(`Source must be a repository directory: ${n}`);return{type:"local",displayName:r,repoDir:r,repoName:e.basename(r),github:await inferGitHubRepo({repoDir:r})}}catch(e){if(e instanceof Error&&e.message.startsWith("Source must be"))throw e}const o=parseGitHubSource({source:n});if(!o){const e=n.startsWith("git@")?" SSH URLs are not supported. Use HTTPS or owner/repo instead.":"";throw new Error(`Unsupported source '${n}'.${e} Use a local path, GitHub HTTPS URL, or owner/repo.`)}const s=String(t.maxCommits??200),i=`https://github.com/${o.owner}/${o.repo}.git`,a=await D.mkdtemp(e.join(y.tmpdir(),"taste-learn-"));try{await runCommand({cmd:"git",args:["clone","--depth",s,"--single-branch",...t.branch?["--branch",t.branch]:[],"--",i,a]})}catch{throw await D.rm(a,{recursive:!0,force:!0}).catch(()=>{}),new Error(`Repository not found: ${o.owner}/${o.repo}. Check the owner and repo name, or verify it's a public repository.`)}return{type:"github",displayName:`${o.owner}/${o.repo}`,repoDir:a,repoName:o.repo,github:o,cleanup:__name(async()=>{await D.rm(a,{recursive:!0,force:!0})},"cleanup")}}function getTastePathForDir(t){return e.join(t.projectRoot,".commandcode","taste")}async function resolveDisplayName(t){if(t.startsWith("/")||t.startsWith(".")){const n=e.resolve(t),r=await findGitRoot4({dir:n});return r?e.basename(r):e.basename(n)}return t}function parseGitHubSource(e){const t=e.source.match(/^([\w.-]+)\/([\w.-]+)$/);if(t)return{owner:t[1],repo:t[2].replace(/\.git$/,"")};try{const t=new URL(e.source);if("github.com"!==t.hostname)return null;const n=t.pathname.split("/").filter(Boolean);return n.length<2?null:{owner:n[0],repo:n[1].replace(/\.git$/,"")}}catch{return null}}async function inferGitHubRepo(e){try{const{stdout:t}=await runCommand({cmd:"git",args:["-C",e.repoDir,"remote","get-url","origin"]});return parseGitHubSource({source:t.trim()})??void 0}catch{return}}async function feedToLearningAgent(e){const t=await getConfiguredProvider(),n=await getOAuthCredentials({provider:t});if(await isOAuthEnforced()&&!n?.token)throw new Error("Authentication required. Run: cmd login");n?.token&&validateOAuthToken({token:n.token,provider:t});const r=getApiBaseUrl(),o=new Ly({baseUrl:r}),s=new pv({request:o,sessionId:crypto.randomUUID(),projectRoot:e.outputDir}),i=[{role:"user",content:e.compiledContext}];await s.checkAndProcess({messages:i})}function logLearnSummary(e){const{summary:t}=e;console.log(ue.cyan("\n ─── Results ───\n")),console.log(` Source: ${t.sourceName}`),console.log(` Signals: ${t.signalCount} extracted`),console.log(` Context: ${t.contextLength} chars compiled`),console.log(` Taste dir: ${t.tasteDir}`),console.log("")}function shouldContinueExtraction(e){return!(e.offset>=e.commitsLength||e.signalCount>=e.signalCap||e.commitsWithDiffs>=50)}async function extractAllSignals(e){e.onProgress?.("Collecting commits");const t=await collectCommits(e);if(0===t.length)return e.onProgress?.("No commits found"),{signals:[],commitCount:0};e.onProgress?.(`Found ${t.length} commits to analyze`);const n=e.maxSignals??50,r=[];let o=0;for(let s=0;shouldContinueExtraction({offset:s,commitsLength:t.length,signalCount:r.length,signalCap:n,commitsWithDiffs:o});s+=10){const i=t.slice(s,s+10);if(0===i.length)break;const a=await runBounded(5,i,async t=>({commit:t,subs:await getSubstitutions(e.repoDir,t.hash)}));for(const{commit:e,subs:t}of a){if(0===t.length)continue;o++;const s=groupCrossFilePatterns(t);for(const t of s.slice(0,5)){if(t.removed.length>200||t.added.length>200)continue;const o=[`Commit: ${e.subject}`];o.push(`File: ${t.file}`),t.context&&o.push(`In: ${t.context}`);const s=buildSnippet(t.codeBefore,t.added,t.codeAfter);if(s&&o.push(s),r.push({text:`${truncate2(t.removed,60)} → ${truncate2(t.added,60)}`,evidence:o,category:inferCategory(t.removed,t.added)}),r.length>=n)break}if(r.length>=n)break}}return e.onProgress?.(`Extracted ${r.length} diff signals from ${o} commits`),{signals:r,commitCount:t.length}}async function collectCommits(e){const t=buildAuthorPattern(e.author,e.authorAliases),n=t?.includes("|")??!1,r=t?[...n?["--extended-regexp"]:[],"--author",t,"--regexp-ignore-case"]:[],o=e.branch?[e.branch]:[],s=e.author?e.maxCommits:3*e.maxCommits,{stdout:i}=await runCommand({cmd:"git",args:["-C",e.repoDir,"log",...o,"--no-merges",...r,"--pretty=format:%H%x1f%aI%x1f%aN%x1f%s%x1e","-n",String(s)]});return i.split("").map(e=>e.trim()).filter(Boolean).map(e=>{const[t="",n="",r="",o=""]=e.split("");return{hash:t.trim(),subject:o.trim(),authorDate:n.trim(),authorName:r.trim()}}).filter(e=>!isDependencyBot(e.authorName,e.subject)).slice(0,e.maxCommits)}async function getSubstitutions(e,t){try{const{stdout:n}=await runCommand({cmd:"git",args:["-C",e,"show","--format=","-U3","--diff-algorithm=histogram","-b","--ignore-blank-lines","-M",t]}),r=[];let o="",s="",i=[],a=[],l=[];const u=2;let d=null;const m=__name(()=>{d&&(r.push({removed:d.removed,added:d.added,file:d.file,context:d.context,codeBefore:d.codeBefore.length>0?d.codeBefore:void 0,codeAfter:d.codeAfter.length>0?d.codeAfter:void 0}),d=null)},"commitPending"),g=__name(()=>{if(i.length>0&&a.length>0){const e=i.join("\n").trim(),t=a.join("\n").trim();e===t||isVersionBump(e,t)||isTrivialChange(e,t)||(m(),d={removed:e,added:t,file:o,context:s||void 0,codeBefore:[...l],codeAfter:[]})}i=[],a=[]},"flush");for(const e of n.split("\n")){if(e.startsWith("diff --git")){g(),m(),o=e.match(/b\/(.+)$/)?.[1]??"",s="",l=[],isNoiseFile(o)&&(o="");continue}if(e.startsWith("@@")){g(),m(),s=e.match(/@@ .+ @@\s*(.+)/)?.[1]?.trim()??"",l=[];continue}if(!o)continue;if(e.startsWith("-")&&!e.startsWith("---")){a.length>0&&g(),i.push(e.slice(1));continue}if(e.startsWith("+")&&!e.startsWith("+++")){a.push(e.slice(1));continue}g();const t=e.startsWith(" ")?e.slice(1):e;if(!t.trim())continue;const n=d;null!==n&&n.codeAfter.length<u&&(n.codeAfter.push(t),n.codeAfter.length>=u&&m()),l.push(t),l.length>u&&l.shift()}return g(),m(),r}catch(e){return process.env.DEBUG&&console.error(`[taste-learn] getSubstitutions failed for ${t}:`,e instanceof Error?e.message:e),[]}}function groupCrossFilePatterns(e){const t=new Map;for(const n of e){const e=`${n.removed.trim()}\0${n.added.trim()}`,r=t.get(e)??[];r.push(n),t.set(e,r)}const n=[];for(const[,e]of t)if(e.length>=2){const t=e.map(e=>e.file).join(", ");n.push({...e[0],file:t,context:`Same change across ${e.length} files`})}else n.push(e[0]);return n}Ht(),Ht(),__name(addMcpCommand,"addMcpCommand"),__name(collectKeyValue,"collectKeyValue"),__name(collectHeaders,"collectHeaders"),Ht(),__name(listMcpCommand,"listMcpCommand"),Ht(),__name(getMcpCommand,"getMcpCommand"),Ht(),__name(removeMcpCommand,"removeMcpCommand"),Ht(),__name(addJsonMcpCommand,"addJsonMcpCommand"),Ht(),__name(authMcpCommand,"authMcpCommand"),__name(createMcpCommand,"createMcpCommand"),Ht(),Yt(),Ht(),Iv(),Ht(),Yt(),Ht(),__name(runCommand,"runCommand"),Ht(),__name(detectDefaultBranch,"detectDefaultBranch"),__name(findGitRoot4,"findGitRoot"),__name(countLearnings,"countLearnings"),__name(resolveSource,"resolveSource"),__name(getTastePathForDir,"getTastePathForDir"),__name(resolveDisplayName,"resolveDisplayName"),__name(parseGitHubSource,"parseGitHubSource"),__name(inferGitHubRepo,"inferGitHubRepo"),Ht(),Sv(),Xy(),iw(),Pr(),qr(),__name(feedToLearningAgent,"feedToLearningAgent"),__name(logLearnSummary,"logLearnSummary"),Ht(),dv(),Ht(),__name(shouldContinueExtraction,"shouldContinueExtraction"),__name(extractAllSignals,"extractAllSignals"),__name(collectCommits,"collectCommits"),__name(getSubstitutions,"getSubstitutions"),__name(groupCrossFilePatterns,"groupCrossFilePatterns");var oP=5,sP=3;function buildSnippet(e,t,n){const r=e??[],o=n??[],s=t.split("\n").map(e=>e.trimEnd());if(0===s.length&&0===r.length&&0===o.length)return;let i,a=0;s.length>sP?(i=s.slice(0,sP-1),a=s.length-i.length):i=s;const l=i.length+(a>0?1:0),u=Math.max(0,oP-l),d=Math.min(r.length,Math.ceil(u/2)),m=Math.min(o.length,u-d),g=[];for(const e of r.slice(-d))g.push(` ${e.trimEnd()}`);for(const e of i)g.push(`→ ${e}`);a>0&&g.push(`→ ... (+${a} more changed ${1===a?"line":"lines"})`);for(const e of o.slice(0,m))g.push(` ${e.trimEnd()}`);return 0!==g.length?`Snippet:\n${g.join("\n")}`:void 0}__name(buildSnippet,"buildSnippet");var iP=[/package-lock\.json$/,/pnpm-lock\.yaml$/,/yarn\.lock$/,/CHANGELOG\.(md|yml|yaml)$/i,/\.versionbot\//,/\.min\.(js|css)$/,/dist\//,/\.map$/];function isNoiseFile(e){return iP.some(t=>t.test(e))}function isTrivialChange(e,t){return e.trim().length<3&&t.trim().length<3}function isVersionBump(e,t){const n=/^"?version"?\s*:\s*"?\d+\.\d+/;return n.test(e.trim())&&n.test(t.trim())}function inferCategory(e,t){const n=`${e} ${t}`.toLowerCase();return/import|require|from\s+['"]/.test(n)?"imports":/function|=>|async|return/.test(n)?"code-style":/class|interface|type\s+/.test(n)?"types":/test|describe|it\(|expect/.test(n)?"testing":/console|log|debug|error/.test(n)?"logging":/try|catch|throw|Error/.test(n)?"error-handling":"code-style"}function buildAuthorPattern(e,t){return t&&t.length>0?t.map(e=>e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")).join("|"):e??void 0}__name(isNoiseFile,"isNoiseFile"),__name(isTrivialChange,"isTrivialChange"),__name(isVersionBump,"isVersionBump"),__name(inferCategory,"inferCategory"),__name(buildAuthorPattern,"buildAuthorPattern");var aP=new Set(["renovate[bot]","renovate","dependabot[bot]","dependabot","greenkeeper[bot]","snyk-bot"]),lP=[/^update .+ digest to /i,/^update .+ action to /i,/^update .+ to v?\d/i,/^update lock file maintenance/i,/^update dependency .+ to /i,/^chore\(deps\)/i,/^bump .+ from .+ to /i,/^lock file maintenance/i];function isDependencyBot(e,t){const n=e.toLowerCase();return!!aP.has(n)||!(!n.includes("[bot]")||!lP.some(e=>e.test(t)))}function truncate2(e,t){const n=e.replace(/\n/g," ").trim();return n.length<=t?n:`${n.slice(0,t-3)}...`}async function runBounded(e,t,n){const r=[];let o=0;const s=__name(async()=>{for(;o<t.length;){const e=o++;r[e]=await n(t[e])}},"next");return await Promise.all(Array.from({length:Math.min(e,t.length)},()=>s())),r}function compileTasteContext(e){const{signals:t,repoName:n,author:r,commitCount:o}=e,s=r?`Target author: ${r}\n`:"",i=[];if(i.push(`# Dynamic Taste Analysis — Code Change Patterns\n\nRepository: ${n}\n${s}Commits analyzed: ${o}\nSignals extracted: ${t.length}\n\nThis analysis was generated by examining actual code changes (diffs, substitutions, refactoring patterns) rather than static file contents. Every signal below comes from real commits.`),t.length>0){const e=["## Correction Diffs — What Wrong→Right Looks Like"];for(const n of t.slice(0,50)){e.push(`\n**${n.text}**`);for(const t of n.evidence)e.push(`- ${t}`)}i.push(e.join("\n"))}const a=r?` for ${r}`:"";return i.push(`## Instructions for Taste Learning\n\nYou are analyzing code change patterns from a real repository${a}. Based on the correction diffs above, generate deeply personal and opinionated coding taste.\n\n**Critical guidelines:**\n\n1. **Be specific, not generic.** Instead of "Use TypeScript", write "Use branded types for IDs and explicit return types on every function. Prefer \`readonly\` arrays and objects by default."\n\n2. **Extract the WHY from patterns.** If you see verbose names being replaced with concise ones, don't just say "use short names" — say "Prefer concise variable names that derive meaning from context rather than encoding type information."\n\n3. **Look for recurring themes.** If multiple substitutions show the same pattern (e.g., nested if→guard clauses), that's a strong taste signal worth capturing.\n\n4. **Make it actionable.** Every taste entry should be specific enough that another developer could follow it and produce code that looks like it belongs in this repository.\n\n5. **Prioritize quality corrections** — these are the purest taste signals (wrong→right pairs with explicit WHY context from commit messages).\n\n6. **Capture anti-patterns too.** If you see code being removed in refactors, note what the developer avoids: "Never nest deeper than 2 levels — flatten with early returns."\n\n7. **Don't repeat generic tool preferences** like "Use pnpm" or "Use TypeScript" unless the substitutions show something specific about HOW they use those tools.\n\n8. **Prioritize opinionated preferences.** The goal is taste that makes someone's code distinctly theirs — not industry best practices.\n\nWrite the taste entries to the taste.md file using the standard format with confidence scores.`),i.join("\n\n")}async function runLearnPipeline(t){const n=__name(()=>({outputDir:"",tasteDir:"",sourceName:t.source,signalCount:0,contextLength:0}),"abortedResult");if(t.needsAuth){cv.addEvent({type:"auth_required",step:"auth",message:"Login to synthesize your taste profile",label:"Signing in"});try{await cv.waitForAuth()}catch{return cv.emitStepStart({step:"complete",label:"Login skipped",message:"Login skipped",learningCount:0,storage:""}),cv.markLearningComplete(),{summary:n()}}}t.isLocalSource||cv.emitStepStart({step:"cloning",label:"Cloning repository",message:`Cloning ${t.source}`});const r=await resolveSource({source:t.source,maxCommits:t.maxCommits});if(t.signal.aborted)return{summary:n(),resolved:r};const o="github"===r.type,s=r.repoName,i=await findGitRoot4({dir:r.repoDir});if(!i)throw new Error(`Not a git repository: ${r.repoDir}. Run inside a git repo or pass the path: npx taste learn /path/to/repo`);const a=o?e.resolve(process.cwd(),s):i;o&&cv.emitStepStart({step:"collecting",label:"Collecting commits",message:`Cloned ${r.displayName} → ${a}`});const l=t.branch??await detectDefaultBranch({repoDir:i});await D.mkdir(a,{recursive:!0}),cv.emitStepStart({step:"collecting",label:"Collecting commits",message:`Fetching up to ${t.maxCommits} commits from ${l}`});const{signals:u,commitCount:d}=await extractAllSignals({repoDir:i,maxCommits:t.maxCommits,maxSignals:t.maxSignals,branch:l,onProgress:__name(e=>{cv.emitProgress({step:"extracting",message:e})},"onProgress")});if(t.signal.aborted)return{summary:n(),resolved:r};if(0===u.length)throw new Error("No signals extracted. Check the repository has commit history.");cv.emitStepStart({step:"extracting",label:"Extracting taste signals",message:`${u.length} before/after code changes extracted`}),cv.emitStepStart({step:"compiling",label:"Compiling taste context",message:`Formatting ${u.length} signals for the learning agent`});const m=compileTasteContext({signals:u,repoName:s,commitCount:d});if(t.signal.aborted)return{summary:n(),resolved:r};cv.emitStepStart({step:"learning",label:"Learning taste",message:"Interpreting code change patterns with AI"}),await feedToLearningAgent({compiledContext:m,outputDir:a});const g=getTastePathForDir({projectRoot:a}),h=e.join(g,"taste.md"),f=await countLearnings(h);return cv.emitStepStart({step:"complete",label:"Taste learned",message:"Taste learned",learningCount:f,storage:h}),cv.markLearningComplete(),{summary:{outputDir:a,tasteDir:g,sourceName:r.displayName,signalCount:u.length,contextLength:m.length},resolved:r}}__name(isDependencyBot,"isDependencyBot"),__name(truncate2,"truncate"),__name(runBounded,"runBounded"),Ht(),__name(compileTasteContext,"compileTasteContext"),__name(runLearnPipeline,"runLearnPipeline"),Ht(),Ht(),dv(),Ht();var cP=[/MallocStackLogging: can't turn off malloc stack logging because it was not enabled/i];function shouldIgnoreChunk(e){return cP.some(t=>t.test(e))}function chunkToString(e){return"string"==typeof e?e:Buffer.isBuffer(e)?e.toString("utf-8"):""}async function withFilteredStderrNoise(e){const t=process.stderr.write.bind(process.stderr);process.stderr.write=(e,...n)=>{const r=chunkToString(e);return!(!r||!shouldIgnoreChunk(r))||("function"==typeof n[0]?t(e,n[0]):t(e,n[0],n[1]))};try{return await e()}finally{process.stderr.write=t}}function toRepoLearnErrorMessage(e){return e instanceof Error?e.message:String(e)}function isRepoLearnMetricLikeText(e){const t=e.trim().toLowerCase();return/^\d+\s/.test(t)||/^saved\s/.test(t)||/^output\s/.test(t)||/^target\s/.test(t)||/\bcandidates\b/.test(t)||/\bevidence records\b/.test(t)||/\bhistory and review signals\b/.test(t)}function truncateRepoLearnPanelText(e,t=12){return truncateString({text:e,maxChars:Math.min(96,getEffectiveWidth({padding:t}))})}__name(shouldIgnoreChunk,"shouldIgnoreChunk"),__name(chunkToString,"chunkToString"),__name(withFilteredStderrNoise,"withFilteredStderrNoise"),Ht(),vo(),__name(toRepoLearnErrorMessage,"toRepoLearnErrorMessage"),__name(isRepoLearnMetricLikeText,"isRepoLearnMetricLikeText"),__name(truncateRepoLearnPanelText,"truncateRepoLearnPanelText"),Ht(),dv(),Ht();var uP=[{id:"collecting",label:"Collecting commits from repository"},{id:"extracting",label:"Extracting taste signals from diffs"},{id:"compiling",label:"Compiling taste context"},{id:"learning",label:"Learning taste from change patterns"},{id:"complete",label:"Taste learned"}],dP=[{id:"cloning",label:"Cloning repository"},...uP],mP=[_e.bullet,_e.squareSmallFilled,_e.lozenge,_e.star,_e.triangleRight,_e.triangleUp];function createInitialRepoLearnSteps(e){return(e??uP).map(e=>({...e,status:"pending"}))}__name(createInitialRepoLearnSteps,"createInitialRepoLearnSteps"),Ht(),dv();var pP={learningCount:0,storage:"",topLearnings:[]};function getStepStatus(e,t){return e<t?"complete":e===t?"active":"pending"}function deriveStepStates(e,t){return e.map((e,n)=>({...e,status:getStepStatus(n,t)}))}function parseSummaryMetric(e){if(e.startsWith("Maintainer: "))return{maintainerLabel:e.replace(/^Maintainer:\s+/,"")};const t=e.match(/^(\d+)\s+maintainer-specific preferences$/);if(t)return{maintainerCount:Number(t[1])};const n=e.match(/^(\d+)\s+repository conventions$/);return n?{repoCount:Number(n[1])}:null}__name(getStepStatus,"getStepStatus"),__name(deriveStepStates,"deriveStepStates"),__name(parseSummaryMetric,"parseSummaryMetric");var gP=__name(e=>e.map(e=>({...e,status:"complete"})),"markAllStepsComplete"),hP=__name(e=>e??pP,"withBase");function useRepoLearnState(e){const t=e??uP,[n,r]=J(()=>createInitialRepoLearnSteps(t)),[o,s]=J(""),[i,a]=J([]),[l,u]=J(null),[d,m]=J(!1),[g,h]=J(!1),[f,y]=J(null),[w,S]=J(0),E=X(null),[C,v]=J(null),k=te(()=>{E.current=Date.now()},[]);return Z(()=>{const e=__name(()=>{r(createInitialRepoLearnSteps(t)),s(""),a([]),u(null),h(!1),y(null),S(0),E.current=null,v(null),m(!1)},"handleReset"),n=__name(e=>{if("error"===e.type)return y(e.message),h(!0),r(gP),void s("");if("auth_required"!==e.type){if("step_start"===e.type&&e.step){const n=t.findIndex(t=>t.id===e.step);return n>=0&&r(deriveStepStates(t,n)),s(e.message||e.label||""),void("complete"===e.step&&u(t=>{const n=hP(t);return{...n,learningCount:e.learningCount??n.learningCount,storage:e.storage??n.storage}}))}"progress"!==e.type||"complete"!==e.step?"progress"!==e.type?"insight"===e.type&&(isRepoLearnMetricLikeText(e.message)||("complete"!==e.step?(S(e=>e+1),a(t=>[...t,e.message].slice(-4))):u(t=>{const n=hP(t);return{...n,topLearnings:[...n.topLearnings,e.message].slice(0,3)}}))):s(e.message):u(t=>{const n=hP(t),r=parseSummaryMetric(e.message);return r?{...n,...r}:n})}else m(!0)},"handleEvent"),o=__name(()=>{h(e=>e||(r(gP),!0)),s(""),E.current&&v(Math.round((Date.now()-E.current)/1e3))},"handleComplete");return cv.on("reset",e),cv.on("new-event",n),cv.on("learning-complete",o),()=>{cv.off("reset",e),cv.off("new-event",n),cv.off("learning-complete",o)}},[t]),{steps:n,currentMessage:o,insights:i,insightCount:w,summary:l,done:g,error:f,showLogin:d,setShowLogin:m,elapsedSeconds:C,markStarted:k}}__name(useRepoLearnState,"useRepoLearnState"),Ht(),Ht(),hr();var fP=__name(({isComplete:e,hasError:t})=>K.createElement(ne,{flexDirection:"column",marginTop:1,marginBottom:0},K.createElement(uA,null),K.createElement(ne,{marginTop:0},K.createElement(re,{color:zn.DIM},mA),K.createElement(ne,{marginLeft:2},t?K.createElement(re,{color:zn.DIM},"learning interrupted"):e?K.createElement(re,{color:Gn.TEXT},"learned your coding taste"):K.createElement(pA,null)))),"RepoLearnTastePill");Ht(),hr();var yP=__name(({status:e})=>"active"===e?K.createElement(ne,null,K.createElement(re,{color:zn.YELLOW},K.createElement(qe,{type:"dots"})),K.createElement(re,null," ")):"complete"===e?K.createElement(re,{color:Kn.BG},_e.square," "):K.createElement(re,{color:zn.DIM},_e.circle," "),"StepStatusIndicator"),wP=__name(({steps:e,currentMessage:t})=>K.createElement(ne,{flexDirection:"column",marginTop:1},e.map(e=>{const n="active"===e.status;return K.createElement(ne,{key:e.id,flexDirection:"column",marginBottom:0,marginLeft:3},K.createElement(ne,null,K.createElement(ne,{marginRight:1},K.createElement(yP,{status:e.status})),K.createElement(re,{bold:n,color:"complete"===e.status?zn.WHITE:n?zn.YELLOW:zn.DIM},e.label)),n&&t?K.createElement(ne,{marginLeft:3},K.createElement(re,{color:zn.DIM},truncateRepoLearnPanelText(t))):null)})),"RepoLearnStepList");Ht(),hr();var SP=__name(({insights:e,insightCount:t})=>0===e.length?null:K.createElement(ne,{flexDirection:"column",marginTop:1,marginLeft:4},K.createElement(re,{color:zn.CYAN},t>0?`Recent signals · ${t} ${1===t?"preference":"preferences"} learned`:"Recent signals"),e.map((e,t)=>K.createElement(re,{key:`${t}-${e}`,color:zn.DIM},mP[t%mP.length]," ",truncateRepoLearnPanelText(e,14)))),"RepoLearnRollingInsights");Ht(),hr();var bP=__name(({message:e})=>K.createElement(ne,{flexDirection:"column",borderStyle:"single",borderColor:zn.RED,paddingX:2,paddingY:1,marginTop:1},K.createElement(re,{color:zn.RED,bold:!0},"Oops, something went wrong:"),K.createElement(ne,{marginTop:1},K.createElement(re,null,e))),"RepoLearnErrorPanel");Ht(),hr(),Ir();var EP=__name(({summary:e,elapsedSeconds:n})=>{if(!e)return null;const r=t.relative(process.cwd(),e.storage),o=e.learningCount>0;return K.createElement(ne,{flexDirection:"column",marginLeft:3},K.createElement(ne,{marginBottom:1,flexDirection:"row"},K.createElement(re,{color:zn.DIM},mA),K.createElement(ne,{marginLeft:2},K.createElement(re,{color:Gn.TEXT},o?`Learned ${e.learningCount} ${1===e.learningCount?"preference":"preferences"}`:"Taste profile initialized",n?` in ${n} ${1===n?"second":"seconds"}`:""))),K.createElement(ne,{flexDirection:"column",marginLeft:1},K.createElement(ne,null,K.createElement(re,{color:zn.DIM},_e.pointerSmall," Taste stored in"," "),K.createElement(xr,{url:`file://${e.storage}`,text:r||".commandcode/taste/taste.md",color:zn.CYAN})),K.createElement(ne,null,K.createElement(re,{color:zn.DIM},_e.pointerSmall," Share your coding taste: ",K.createElement(re,{color:zn.CYAN},"npx taste push --all")))),K.createElement(ne,{marginTop:1,marginLeft:1},K.createElement(re,{color:zn.DIM},o?"Command Code automatically uses & updates taste files as you code.":"Command Code will learn your preferences as you code.")))},"RepoLearnCompletionSummary");Ht(),hr();var CP=__name(({done:e,error:t})=>t?K.createElement(ne,{marginTop:1},K.createElement(re,{bold:!0},"Press ESC to exit")):e?K.createElement(ne,{marginTop:1},K.createElement(re,{bold:!0},"Press ENTER to continue")):K.createElement(ne,{marginTop:1},K.createElement(re,{color:zn.DIM},"ESC to cancel")),"RepoLearnFooter");Ht(),hr();var vP=__name(({text:e,repoName:t})=>{const n=useTerminalWidth(),r=ee(()=>b_(n),[n]);return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(__,null,r.trimEnd())),e?K.createElement(re,{color:zn.WHITE},e):K.createElement(K.Fragment,null,K.createElement(re,{color:zn.WHITE},"Learning your coding taste from ",K.createElement(re,{bold:!0,color:zn.CYAN},t??"repository")),K.createElement(re,{color:zn.DIM},"This may take a few minutes depending on repository size")))},"RepoLearnHeader");function StatusPanel({error:e,done:t,summary:n,elapsedSeconds:r,insights:o,insightCount:s}){return e?K.createElement(bP,{message:e}):t?K.createElement(EP,{summary:n,elapsedSeconds:r}):K.createElement(SP,{insights:o,insightCount:s})}function RepoLearnProgressApp({runTask:e,onExit:t,stepOrder:n,headerText:r,repoName:o}){const s=useRepoLearnState(n),i=X(!1);return Z(()=>{i.current||(i.current=!0,s.markStarted(),e().catch(()=>{}))},[e,s.markStarted]),ie((e,n)=>{if(s.showLogin)return;const r=n.escape||""===e,o=n.return||"\n"===e||"\r"===e;r?t({published:!1,cancelled:!0}):(s.done||s.error)&&o&&t({published:!1,cancelled:!!s.error})}),s.showLogin?K.createElement(ne,{flexDirection:"column"},K.createElement(vP,{text:r,repoName:o}),K.createElement(Lx,{onComplete:(e,t)=>{s.setShowLogin(!1),e?cv.resolveAuth():cv.rejectAuth(t)},onCancel:()=>{s.setShowLogin(!1),cv.rejectAuth("Login cancelled"),t({published:!1,cancelled:!0})}})):K.createElement(ne,{flexDirection:"column"},K.createElement(vP,{text:r,repoName:o}),K.createElement(fP,{isComplete:s.done&&!s.error,hasError:Boolean(s.error)}),K.createElement(wP,{steps:s.steps,currentMessage:s.currentMessage}),K.createElement(StatusPanel,{error:s.error,done:s.done,summary:s.summary,elapsedSeconds:s.elapsedSeconds,insights:s.insights,insightCount:s.insightCount}),K.createElement(CP,{done:s.done,error:s.error}))}async function runRepoLearnProgress(e){return withFilteredStderrNoise(()=>renderProgressUI(e))}function renderProgressUI(e){return new Promise((t,n)=>{cv.reset();const r=new AbortController;let o,s,i=!1,a=!1;const l=__name(async()=>{try{o=await e.runTask(r.signal)}catch(e){r.signal.aborted||(s=e,cv.addEvent({type:"error",message:toRepoLearnErrorMessage(e)}),cv.markLearningComplete())}},"handleRunTask"),u=__name(({published:e,cancelled:l})=>{a||(a=!0,i=e,r.abort(),d.unmount(),cv.reset(),s?n(s):t({result:o,published:i,cancelled:l}))},"handleExit"),d=ae(K.createElement(RepoLearnProgressApp,{stepOrder:e.stepOrder,headerText:e.headerText,repoName:e.repoName,runTask:l,onExit:u}));d.waitUntilExit().catch(e=>{cv.reset(),n(e)})})}__name(StatusPanel,"StatusPanel"),__name(RepoLearnProgressApp,"RepoLearnProgressApp"),__name(runRepoLearnProgress,"runRepoLearnProgress"),__name(renderProgressUI,"renderProgressUI"),pk();var kP=__name(e=>t=>{const n=parseInt(t,10);if(isNaN(n)||n<1)throw new Error(`${e} must be a positive integer`);return n},"parsePositiveInt");function createLearnCommand(){return new ke("learn").description("Learn coding taste from repository change history").argument("[source]","Local path, GitHub URL, or owner/repo (defaults to current directory)").option("--max-commits <number>","Maximum commits to analyze",kP("--max-commits"),200).addOption(new Te("--max-signals <number>","Maximum diff signals to extract").default(50).argParser(kP("--max-signals")).hideHelp()).option("--branch <name>","Branch to analyze (defaults to main/master)").action(async(e,t)=>{try{await learnTaste({source:e??".",maxCommits:t.maxCommits??200,maxSignals:t.maxSignals??50,branch:t.branch})}catch(e){const t=e instanceof Error?e.message:String(e);console.error(`Error: ${t}`),process.exit(1)}})}async function learnTaste(t){const n=await D.stat(e.resolve(t.source)).then(e=>e.isDirectory()).catch(()=>!1),r=isTTY(),o=await resolveDisplayName(t.source),s=!await getAuthKey();if(s&&!r)return console.log(""),console.log(" Login required to learn taste."),console.log(""),console.log(" Run: cmd login"),console.log(` Then: npx taste learn ${t.source}`),void console.log("");let i;const a=__name(()=>{i?.().finally(()=>process.exit(130))},"sigintHandler");process.once("SIGINT",a);let l=!1;try{const e=__name(async e=>{const{summary:r,resolved:o}=await runLearnPipeline({...t,isLocalSource:n,needsAuth:s,signal:e});return i=o?.cleanup,r},"runTask");if(r){const t=n?void 0:[...dP];({cancelled:l}=await runRepoLearnProgress({runTask:e,repoName:o,stepOrder:t}))}else logLearnSummary({summary:await e((new AbortController).signal)})}finally{process.off("SIGINT",a),i&&await i()}r&&!l||process.exit(0),xv(),await jA({skipOnboarding:!0})}function getTastePath(t){const{target:n}=t;if("local-project"===n)return e.join(process.cwd(),".commandcode","taste");if("local-global"===n)return e.join(y.homedir(),".commandcode","taste");throw new Error(`Remote storage not yet implemented: ${n}`)}function getRootTasteFile(t){const{target:n}=t;return e.join(getTastePath({target:n}),"taste.md")}function getCategoryPath(t){const{target:n,category:r}=t;return e.join(getTastePath({target:n}),r)}function getCategoryTasteFile(t){const{target:n,category:r}=t;return e.join(getCategoryPath({target:n,category:r}),"taste.md")}__name(createLearnCommand,"createLearnCommand"),__name(learnTaste,"learnTaste"),Ht(),Ht(),fw(),Ht(),Yt(),__name(getTastePath,"getTastePath"),__name(getRootTasteFile,"getRootTasteFile"),__name(getCategoryPath,"getCategoryPath"),__name(getCategoryTasteFile,"getCategoryTasteFile"),Ht(),Ht();var TP=/confidence:/i;function findLookaheadEnd(e,t){const n=e.slice(t),r=n.findIndex(e=>{const t=e.trim();return t.startsWith("#")||t.startsWith("-")||TP.test(t)});if(-1===r)return{endIdx:e.length,inclusive:!1};const o=n[r].trim();return{endIdx:t+r,inclusive:TP.test(o)&&!o.startsWith("#")&&!o.startsWith("-")}}function joinMultiLineLearning(e,t,n){const{endIdx:r,inclusive:o}=findLookaheadEnd(e,t),s=o?r+1:r;return{combined:[n,...e.slice(t,s).map(e=>e.trim()).filter(e=>e.length>0)].join(" "),nextIdx:s}}function processRawLine(e,t){const n=e[t],r=t+1,o=n.trim();if(!o.startsWith("-"))return{entry:{text:n,originalLineNum:r},nextIdx:t+1};if(TP.test(o))return{entry:{text:n,originalLineNum:r},nextIdx:t+1};const{combined:s,nextIdx:i}=joinMultiLineLearning(e,t+1,n);return{entry:{text:s,originalLineNum:r},nextIdx:i}}function preprocessLines(e){const t=[];let n=0;for(;n<e.length;){const{entry:r,nextIdx:o}=processRawLine(e,n);t.push(r),n=o}return t}function validateLearningLine(e){const{line:t,lineNum:n}=e,r=[],o=t.substring(1).trim();if(!TP.test(o))return r.push({line:n,severity:"error",message:'Learning is missing "Confidence:" field',suggestion:'Format: "- Learning text. Confidence: 0.95" (value between 0.0 and 1.0)'}),r;const s=Array.from(o.matchAll(/confidence:\s*(\S+)/gi)),i=s.length>0?s[s.length-1]:null;if(!i)return r.push({line:n,severity:"error",message:"Confidence field is present but has no value",suggestion:'Add a number after "Confidence:" (e.g., Confidence: 0.95)'}),r;const a=i[1],l=parseFloat(a);if(isNaN(l))return r.push({line:n,severity:"error",message:`Confidence value "${a}" is not a valid number`,suggestion:"Use a decimal number between 0.0 and 1.0 (e.g., 0.95)"}),r;(l<0||l>1)&&r.push({line:n,severity:"error",message:`Confidence value ${l} is out of range`,suggestion:"Confidence must be between 0.0 and 1.0"}),l>=0&&l<=1&&0===l&&r.push({line:n,severity:"warning",message:"Confidence is 0.0 - this learning may not be useful",suggestion:"Consider removing learnings with 0 confidence"});const u=void 0!==i.index?o.substring(0,i.index).trim():o.trim();return u&&0!==u.length?(u.length<3&&r.push({line:n,severity:"warning",message:"Learning text is very short",suggestion:"Provide more descriptive text for clarity"}),r):(r.push({line:n,severity:"error",message:'Learning has no text before "Confidence:"',suggestion:'Add descriptive text (e.g., "Use pnpm for package management")'}),r)}function hasReferenceAfterCategory(e){const{lines:t,categoryLineIndex:n}=e,r=t.slice(n+1,n+4),o=r.findIndex(e=>e.trim().startsWith("# "));return(-1===o?r:r.slice(0,o)).some(e=>e.includes("See [")&&e.includes("taste.md"))}function buildResult(e){const{issues:t,filePath:n}=e,r=t.filter(e=>"error"===e.severity),o=t.filter(e=>"warning"===e.severity),s=0===r.length;if(0===t.length)return{valid:s,issues:[...t],summary:`${_e.tick} ${n} is valid`};const i=[];r.length>0&&i.push(`${r.length} error${r.length>1?"s":""}`),o.length>0&&i.push(`${o.length} warning${o.length>1?"s":""}`);const a=r.length>0?_e.cross:_e.warning;return{valid:s,issues:[...t],summary:`${a} ${n} has ${i.join(", ")}`}}function formatSingleIssue(e,t){const n=[`${e.line?ue.dim(` Line ${e.line}: `):" "}${t(e.message)}`];return e.suggestion&&n.push(ue.dim(` → ${e.suggestion}`)),n}function formatIssueGroup(e,t,n){return 0===e.length?[]:[n,...e.flatMap(e=>formatSingleIssue(e,t)),""]}function formatValidationIssues(e){const{result:t,verbose:n=!0}=e;if(0===t.issues.length){const e=t.summary.charAt(0),n=t.summary.substring(2);return`${ue.green(e)} ${ue.dim(n)}`}if(!n)return t.summary;const r=t.issues.filter(e=>"error"===e.severity),o=t.issues.filter(e=>"warning"===e.severity);return[r.length>0?ue.red(t.summary):ue.yellow(t.summary),"",...formatIssueGroup(r,ue.red,ue.bold(ue.red("Errors:"))),...formatIssueGroup(o,ue.yellow,ue.bold(ue.yellow("Warnings:")))].join("\n").trim()}__name(findLookaheadEnd,"findLookaheadEnd"),__name(joinMultiLineLearning,"joinMultiLineLearning"),__name(processRawLine,"processRawLine"),__name(preprocessLines,"preprocessLines"),__name(validateLearningLine,"validateLearningLine"),__name(hasReferenceAfterCategory,"hasReferenceAfterCategory"),__name(buildResult,"buildResult"),Ht(),__name(formatSingleIssue,"formatSingleIssue"),__name(formatIssueGroup,"formatIssueGroup"),__name(formatValidationIssues,"formatValidationIssues");var _P=new Set(["# Taste (Continuously Learned by [CommandCode][cmd])","# Taste (Continuously Learned by CommandCode.ai)","# Taste (Continuously Learned by CommandCode)"]);function warnIfEmptyCategory(e,t){!e.currentCategory||e.learningsInCurrentCategory>0||hasReferenceAfterCategory({lines:t,categoryLineIndex:e.categoryLineNumber-1})||e.issues.push({line:e.categoryLineNumber,severity:"warning",message:`Category '${e.currentCategory}' has no learnings`,suggestion:"Add at least one learning or remove this category"})}function processHeading(e){const{line:t,lineNum:n,state:r,rawLines:o}=e;_P.has(t.trim())||(r.hasAnyCategory=!0,warnIfEmptyCategory(r,o),r.currentCategory=t.trim().substring(2).trim(),r.categoryLineNumber=n,r.learningsInCurrentCategory=0)}function processLearning(e){const{line:t,lineNum:n,state:r}=e;r.currentCategory?(r.learningsInCurrentCategory++,r.issues.push(...validateLearningLine({line:t.trim(),lineNum:n}))):r.issues.push({line:n,severity:"error",message:"Learning found outside of any category",suggestion:'Add a category header (e.g., "# cli") before this learning'})}__name(warnIfEmptyCategory,"warnIfEmptyCategory"),__name(processHeading,"processHeading"),__name(processLearning,"processLearning");var xP=/^see \[[^\]]+\/taste\.md\]\([^\)]+\/taste\.md\)$/i,AP=/^\[cmd\]: https:\/\/commandcode\.ai\/$/i;function processLine(e){const{line:t,lineNum:n,state:r,rawLines:o}=e,s=t.trim();s&&(s.startsWith("# ")?processHeading({line:t,lineNum:n,state:r,rawLines:o}):s.startsWith("-")?processLearning({line:t,lineNum:n,state:r}):xP.test(s)||AP.test(s)||r.issues.push({line:n,severity:"error",message:"Invalid content - must be a category header (# name) or learning (- text)",suggestion:"Remove this line or format it as a category (# name) or learning (- text. Confidence: 0.XX)"}))}function checkFinalCategory(e){const{state:t,rawLines:n}=e;!t.currentCategory||t.learningsInCurrentCategory>0||!t.categoryLineNumber||hasReferenceAfterCategory({lines:n,categoryLineIndex:t.categoryLineNumber-1})||t.issues.push({line:t.categoryLineNumber,severity:"warning",message:`Category '${t.currentCategory}' has no learnings`,suggestion:"Add at least one learning or remove this category"})}function validateTasteFile(e){const{content:t,filePath:n}=e,r=[];if(!t.trim())return r.push({severity:"error",message:"File is empty",suggestion:"Add at least one category with learnings"}),buildResult({issues:r,filePath:n});const o=t.split("\n"),s=preprocessLines(o),i={currentCategory:null,categoryLineNumber:null,learningsInCurrentCategory:0,hasAnyCategory:!1,issues:r};for(const{text:e,originalLineNum:t}of s)processLine({line:e,lineNum:t,state:i,rawLines:o});return checkFinalCategory({state:i,rawLines:o}),buildResult({issues:r,filePath:n})}__name(processLine,"processLine"),__name(checkFinalCategory,"checkFinalCategory"),__name(validateTasteFile,"validateTasteFile");var PP=__name(e=>"local-global"===e?"global":"project","locationLabel"),IP=__name(({file:e,error:t})=>({success:!1,filesLinted:[],errors:[{file:e,error:t}],totalErrors:0,totalWarnings:0}),"failResult");function resolvePackageFile(e,t){const n=getCategoryTasteFile({target:t,category:e});return v(n)?{result:{path:n,displayName:`${e}/taste.md`}}:{error:{file:e,error:`Taste package '${e}' not found in ${PP(t)}`}}}function collectSpecificFiles(e){const{packages:t,target:n}=e,r=t.map(e=>resolvePackageFile(e,n));return{files:r.filter(e=>"result"in e).map(e=>e.result),errors:r.filter(e=>"error"in e).map(e=>e.error)}}async function collectAllFiles(e){const{tastePath:t,target:n}=e,r=[],o=getRootTasteFile({target:n});v(o)&&r.push({path:o,displayName:"taste.md"});const s=(await D.readdir(t,{withFileTypes:!0})).filter(e=>e.isDirectory()).map(e=>({entry:e,categoryFile:getCategoryTasteFile({target:n,category:e.name})})).filter(({categoryFile:e})=>v(e)).map(({entry:e,categoryFile:t})=>({path:t,displayName:`${e.name}/taste.md`}));return r.push(...s),r}async function lintFile(e){let t=await D.readFile(e.path,"utf-8");const n=migrateHeader({content:t});n!==t&&(await D.writeFile(e.path,n,"utf-8"),t=n);const r=validateTasteFile({content:t,filePath:e.displayName}),o=r.issues.filter(e=>"error"===e.severity).length,s=r.issues.filter(e=>"warning"===e.severity).length,i=formatValidationIssues({result:r});return{file:e.displayName,valid:r.valid,errors:o,warnings:s,formatted:i}}async function lintSpecificPackages(e){const{packages:t,target:n}=e,{files:r,errors:o}=collectSpecificFiles({packages:t,target:n});if(0===r.length&&o.length>0)return{success:!1,filesLinted:[],errors:o,totalErrors:0,totalWarnings:0};if(0===r.length)return IP({file:"all",error:`No taste files found in ${PP(n)}`});const s=await Promise.all(r.map(lintFile)),i=s.reduce((e,t)=>e+t.errors,0),a=s.reduce((e,t)=>e+t.warnings,0);return{success:s.every(e=>e.valid)&&0===o.length,filesLinted:s,errors:o,totalErrors:i,totalWarnings:a}}async function lintAllFiles(e){const{tastePath:t,target:n}=e,r=await collectAllFiles({tastePath:t,target:n});if(0===r.length)return IP({file:"all",error:`No taste files found in ${PP(n)}`});const o=await Promise.all(r.map(lintFile)),s=o.reduce((e,t)=>e+t.errors,0),i=o.reduce((e,t)=>e+t.warnings,0);return{success:o.every(e=>e.valid),filesLinted:o,errors:[],totalErrors:s,totalWarnings:i}}async function lint(e){const{packages:t,target:n}=e,r=getTastePath({target:n});return v(r)?t.length>0?lintSpecificPackages({packages:t,target:n}):lintAllFiles({tastePath:r,target:n}):IP({file:"all",error:`No taste directory found in ${PP(n)}`})}function resolveConflictStrategy(e){const t=[e.skip&&"skip",e.merge&&"merge",e.overwrite&&"overwrite"].filter(Boolean);return t.length>1&&exitWithError(`Cannot combine --${t[0]} and --${t[1]}. Choose one conflict strategy.`),t[0]}__name(resolvePackageFile,"resolvePackageFile"),__name(collectSpecificFiles,"collectSpecificFiles"),__name(collectAllFiles,"collectAllFiles"),__name(lintFile,"lintFile"),__name(lintSpecificPackages,"lintSpecificPackages"),__name(lintAllFiles,"lintAllFiles"),__name(lint,"lint"),Ht(),No(),__name(resolveConflictStrategy,"resolveConflictStrategy");var NP=ue.bgGreen.black.bold(" TASTE ");function shortenPath(e){const t=process.env.HOME??process.env.USERPROFILE??"";return t&&e.startsWith(t)?`~${e.slice(t.length)}`:e}function exitWithError(e){console.error(`${ue.red("Error:")} ${e.replace(/^Error:\s*/i,"")}`),process.exit(1)}function formatUsageLine(e){const t=e.match(/^(\s*(?:Usage:|or:)?\s*)(cmd)(\s+.+?)(\s+\(.*\))?$/);return t?`${ue.dim(t[1])}${ue.green(t[2])}${ue.white(t[3]??"")}${t[4]?ue.dim(t[4]):""}`:ue.dim(e)}function exitWithUsage({message:e,usage:t}){console.error(`${ue.red("Error:")} ${e.replace(/^Error:\s*/i,"")}`);for(const e of t)console.error(formatUsageLine(e));process.exit(1)}function resolveRemoteDefault(e){return e.global||e.remote?e:{...e,remote:!0}}__name(shortenPath,"shortenPath"),__name(exitWithError,"exitWithError"),__name(formatUsageLine,"formatUsageLine"),__name(exitWithUsage,"exitWithUsage"),__name(resolveRemoteDefault,"resolveRemoteDefault");var RP=__name((e,t)=>t,"linkFallback");function getPackageLink({owner:e,packageName:t}){return ut(`commandcode.ai/${e}/${t}`,`https://commandcode.ai/${e}/${t}`,{fallback:RP})}function getProfileLink(e){return ut(`commandcode.ai/${e}`,`https://commandcode.ai/${e}`,{fallback:RP})}function wrapLine(e,t=0){const n=(process.stdout.columns||80)-t;return ct(e,n,{trim:!1})}function formatMergeParts(e){const t=[];return e.added>0&&t.push(`${e.added} ${1===e.added?"learning":"learnings"} added`),e.updated>0&&t.push(`${e.updated} ${1===e.updated?"learning":"learnings"} updated`),e.unchanged>0&&t.push(`${e.unchanged} ${1===e.unchanged?"learning":"learnings"} unchanged`),t}function hasMergeConflictRisk(e){return(e.added>0||e.updated>0)&&e.unchanged>0}function hasMergeConflictRiskInRecord(e){return Object.values(e).some(hasMergeConflictRisk)}function logMergeReviewTip(){console.log(ue.yellow("\nTip: Review merged learnings to ensure no conflicting rules."))}function parseOwnerPackage(e){if(!e.includes("/"))return;const[t,n]=e.split("/");return t&&n?{owner:t,packageName:n}:void 0}function handleResultErrors(e){for(const t of e){const e=t.error.replace(/^Taste package(?: '.*?')? /,`Taste package '${t.pkg}' `);console.error(`${ue.red("Error:")} ${e}`)}process.exit(1)}function getTimeAgo(e){const t=Date.now()-e.getTime(),n=Math.floor(t/6e4),r=Math.floor(t/36e5),o=Math.floor(t/864e5);return n<1?"just now":n<60?`${n} minute${n>1?"s":""} ago`:r<24?`${r} hour${r>1?"s":""} ago`:`${o} day${o>1?"s":""} ago`}async function flushAndExit(e){await Promise.race([shutdownTelemetry(),new Promise(e=>setTimeout(e,500))]).catch(()=>{}),process.exit(e)}function withErrorHandler(e){return async(...t)=>{try{await e(...t),await flushAndExit(0)}catch(e){const t=e instanceof Error?e.message:String(e);console.error(ue.red(`Error: ${t}`)),await flushAndExit(1)}}}function createLintCommand(){return new ke("lint").argument("[package]","Taste package name").option("-g, --global","Validate taste packages from global storage (~/.commandcode)").option("--all","Validate all taste packages").description(`Validate taste package format ${ue.dim("(structure, style, etc.)")}`).action(withErrorHandler(async(e,t)=>runLint({packageName:e,options:t})))}function validateLintOptions({packageName:e,options:t}){e||t.all||exitWithUsage({message:"Specify a taste package name or use --all to validate everything",usage:["cmd taste lint <package> validate a taste package","cmd taste lint --all validate all taste packages"]}),e&&t.all&&exitWithError("Use either a package name or --all, not both")}function logLintResults(e){for(const t of e.filesLinted)console.log(t.formatted);e.filesLinted.length>1&&logLintSummary(e),e.success||process.exit(1)}function logLintSummary({filesLinted:e,totalErrors:t,totalWarnings:n}){if(console.log(""),0===t&&0===n)return void console.log(`${ue.green(_e.tick)} All ${ue.green(e.length)} taste files are valid`);const r=[];t>0&&r.push(ue.red(`${t} error${t>1?"s":""}`)),n>0&&r.push(ue.yellow(`${n} warning${n>1?"s":""}`)),console.log(`Summary: ${r.join(", ")} across ${e.length} files`)}async function runLint({packageName:e,options:t}){console.log(""),validateLintOptions({packageName:e,options:t});const n=await lint({packages:e?[e]:[],target:t.global?"local-global":"local-project"});if(n.errors.length>0){for(const e of n.errors)console.error(ue.red(`Error: ${e.error}`));process.exit(1)}logLintResults(n)}function parseSection(e){const{section:t,sourcePath:n}=e,r=t.split("\n"),o=r[0].trim(),s=r.map(e=>parseLearning({line:e})).filter(e=>null!==e);return 0===s.length?null:{category:normalizeCategory({category:o}),learnings:s,sourcePath:n}}function parsePackages(e){const{content:t,sourcePath:n}=e;return t.split(/^# /gm).filter(e=>e.trim()).filter(e=>!e.includes("See [")).map(e=>parseSection({section:e,sourcePath:n})).filter(e=>null!==e)}function parseLearning(e){const{line:t}=e,n=t.match(/^-?\s*(.+?)[\.:,]?\s*confidence:\s*(\d*\.?\d+)/i);if(!n)return null;const r=parseFloat(n[2]);return isNaN(r)||r<0||r>1?null:{text:n[1].trim(),confidence:r}}function normalizeCategory(e){const{category:t}=e;return t.toLowerCase().replace(/\s+/g,"-")}function denormalizeCategory(e){const{slug:t}=e;return t.split("-").map(e=>e.charAt(0).toUpperCase()+e.slice(1)).join(" ")}function formatPackage(e){const{pkg:t}=e;let n=`# ${denormalizeCategory({slug:t.category})}\n`;for(const e of t.learnings)n+=`- ${e.text}. Confidence: ${e.confidence.toFixed(2)}\n`;return n}async function readAndMigrateFile(e){const{filePath:t}=e,n=await D.readFile(t,"utf-8"),r=migrateHeader({content:n});return r===n?n:(await D.writeFile(t,r,"utf-8"),r)}function trimTrailingBlanks(e){const{lines:t,until:n}=e;let r=e.from;for(;r>n&&""===t[r].trim();)r--;return r}function findCategoryRange(e){const{lines:t,pattern:n}=e,r=t.findIndex(e=>n.test(e));if(-1===r)return null;const o=t.findIndex((e,t)=>t>r&&e.startsWith("# "));if(-1===o)return{start:r,end:t.length-1};const s=trimTrailingBlanks({lines:t,from:o-1,until:r});return{start:r,end:s}}function ensureHeader(e){if(!e)return uw+"\n\n";const t=e.trim();return t.startsWith(lw)||t.startsWith(dw)||t.startsWith(mw)?e:uw+"\n\n"+e}function ensureTrailingNewlines(e){return e?e.endsWith("\n\n")?e:e.endsWith("\n")?e+"\n":e+"\n\n":e}__name(getPackageLink,"getPackageLink"),__name(getProfileLink,"getProfileLink"),__name(wrapLine,"wrapLine"),__name(formatMergeParts,"formatMergeParts"),__name(hasMergeConflictRisk,"hasMergeConflictRisk"),__name(hasMergeConflictRiskInRecord,"hasMergeConflictRiskInRecord"),__name(logMergeReviewTip,"logMergeReviewTip"),__name(parseOwnerPackage,"parseOwnerPackage"),__name(handleResultErrors,"handleResultErrors"),__name(getTimeAgo,"getTimeAgo"),__name(flushAndExit,"flushAndExit"),__name(withErrorHandler,"withErrorHandler"),__name(createLintCommand,"createLintCommand"),__name(validateLintOptions,"validateLintOptions"),__name(logLintResults,"logLintResults"),__name(logLintSummary,"logLintSummary"),__name(runLint,"runLint"),Ht(),zo(),Ht(),Ht(),Ht(),__name(parseSection,"parseSection"),__name(parsePackages,"parsePackages"),__name(parseLearning,"parseLearning"),__name(normalizeCategory,"normalizeCategory"),__name(denormalizeCategory,"denormalizeCategory"),Ht(),__name(formatPackage,"formatPackage"),Ht(),fw(),__name(readAndMigrateFile,"readAndMigrateFile"),__name(trimTrailingBlanks,"trimTrailingBlanks"),__name(findCategoryRange,"findCategoryRange"),__name(ensureHeader,"ensureHeader"),__name(ensureTrailingNewlines,"ensureTrailingNewlines");var MP="local-global";async function loadCategoryPackages(e){if(!e.isDirectory())return[];const t=getCategoryTasteFile({target:MP,category:e.name});return v(t)?parsePackages({content:await readAndMigrateFile({filePath:t}),sourcePath:t}).map(t=>({...t,category:e.name})):[]}async function getPackageInfo(e){try{const t=await D.stat(e.sourcePath);return{category:e.category,learningCount:e.learnings.length,lastUpdated:t.mtime,filePath:e.sourcePath}}catch{return{category:e.category,learningCount:e.learnings.length,lastUpdated:new Date,filePath:e.sourcePath}}}async function getAllPackages(){const e=getTastePath({target:MP});if(!v(e))return[];const t=await D.readdir(e,{withFileTypes:!0});return(await Promise.all(t.map(loadCategoryPackages))).flat()}async function getPackage(e){const{category:t}=e,n=getCategoryTasteFile({target:MP,category:t});return v(n)&&parsePackages({content:await readAndMigrateFile({filePath:n}),sourcePath:n})[0]||null}async function writePackage(t){const{pkg:n}=t,r=getTastePath({target:MP});await D.mkdir(r,{recursive:!0});const o=getCategoryTasteFile({target:MP,category:n.category}),s=e.dirname(o);await D.mkdir(s,{recursive:!0});const i=formatPackage({pkg:n});await D.writeFile(o,i,"utf-8")}async function listPackages(){const e=await getAllPackages();return await Promise.all(e.map(getPackageInfo))}__name(loadCategoryPackages,"loadCategoryPackages"),__name(getPackageInfo,"getPackageInfo"),__name(getAllPackages,"getAllPackages"),__name(getPackage,"getPackage"),__name(writePackage,"writePackage"),__name(listPackages,"listPackages"),Ht(),Ht(),fw();var $P="local-project";async function removeCategoryFromRoot(e){const{category:t,rootFile:n}=e;if(!v(n))return null;const r=migrateHeader({content:await D.readFile(n,"utf-8")}).split("\n"),o=findCategoryRange({lines:r,pattern:new RegExp(`^# ${t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}$`,"i")});if(!o)return null;const s=r.slice(0,o.start),i=o.end<r.length-1?r.slice(o.end+1):[],a={before:s.join("\n").trim(),after:i.join("\n").trim()},l=[...s,...i].join("\n").trim();return""===l&&await D.rm(n,{force:!0}),""!==l&&await D.writeFile(n,l+"\n","utf-8"),a}async function removePackage(t){const{category:n}=t,r=getRootTasteFile({target:$P}),o=await removeCategoryFromRoot({category:n,rootFile:r}),s=getCategoryTasteFile({target:$P,category:n}),i=e.dirname(s);return v(i)&&await D.rm(i,{recursive:!0,force:!0}),o}async function writeToRoot(e){const{pkg:t,rootFile:n,categoryPosition:r}=e,o=formatPackage({pkg:t});if(r){let e=ensureHeader(migrateHeader({content:r.before}));e=ensureTrailingNewlines(e);const t=r.after?"\n\n"+r.after:"";return e+=o.trim()+t,void await D.writeFile(n,e.trim()+"\n","utf-8")}let s="";v(n)&&(s=await D.readFile(n,"utf-8"),s=migrateHeader({content:s})),s=ensureHeader(s),s=ensureTrailingNewlines(s),s+=o,await D.writeFile(n,s.trim()+"\n","utf-8")}async function writeToSubdirectory(t){const{pkg:n,rootFile:r,categoryPosition:o}=t,s=getCategoryTasteFile({target:$P,category:n.category}),i=e.dirname(s);await D.mkdir(i,{recursive:!0});const a=formatPackage({pkg:n});await D.writeFile(s,a,"utf-8");const l=`# ${n.category}\nSee [${n.category}/taste.md](${n.category}/taste.md)\n`;if(o){let e=ensureHeader(migrateHeader({content:o.before}));e=ensureTrailingNewlines(e);const t=o.after?"\n\n"+o.after:"";return e+=l.trim()+t,void await D.writeFile(r,e.trim()+"\n","utf-8")}let u="";v(r)&&(u=await D.readFile(r,"utf-8"),u=migrateHeader({content:u})),u=ensureHeader(u),u=ensureTrailingNewlines(u),u+=l,await D.writeFile(r,u.trim()+"\n","utf-8")}__name(removeCategoryFromRoot,"removeCategoryFromRoot"),__name(removePackage,"removePackage"),__name(writeToRoot,"writeToRoot"),__name(writeToSubdirectory,"writeToSubdirectory");var LP="local-project";async function loadCategoryPackages2(e){if(!e.isDirectory())return[];const t=getCategoryTasteFile({target:LP,category:e.name});return v(t)?parsePackages({content:await readAndMigrateFile({filePath:t}),sourcePath:t}).map(t=>({...t,category:e.name})):[]}async function getAllPackages2(){const e=getTastePath({target:LP});if(!v(e))return[];const t=[],n=getRootTasteFile({target:LP});if(v(n)){const e=parsePackages({content:await readAndMigrateFile({filePath:n}),sourcePath:n});t.push(...e)}const r=await D.readdir(e,{withFileTypes:!0}),o=(await Promise.all(r.map(loadCategoryPackages2))).flat();return t.push(...o),t}async function getPackage2(e){const{category:t}=e;return(await getAllPackages2()).find(e=>e.category===t)||null}async function writePackage2(e){const{pkg:t}=e,n=getTastePath({target:LP});await D.mkdir(n,{recursive:!0});const r=getRootTasteFile({target:LP}),o=await removePackage({category:t.category});t.learnings.length<=5?await writeToRoot({pkg:t,rootFile:r,categoryPosition:o}):await writeToSubdirectory({pkg:t,rootFile:r,categoryPosition:o})}function exists2(){const e=getTastePath({target:LP});return v(e)}async function appendCategoryFile(e,t){const n=getCategoryTasteFile({target:"local-project",category:t.category});if(!v(n))return;const r=await D.readFile(n,"utf-8"),o=new Blob([r],{type:"text/markdown"}),s=new File([o],"taste.md",{type:"text/markdown"});e.append(`files[${t.category}/taste.md]`,s)}async function prepareUploadFormData(t){const{packageName:n,pkg:r,description:o,type:s="category",isPublic:i=!1,overwrite:a=!1}=t,l=new FormData;l.append("name",n),o&&l.append("description",o),l.append("type",s),l.append("isPublic",String(i)),l.append("overwrite",String(a));const u=formatPackage({pkg:r}),d=new Blob([u],{type:"text/markdown"}),m=new File([d],"taste.md",{type:"text/markdown"});if(l.append("files[taste.md]",m),"category"===s)return l;const g=getTastePath({target:"local-project"}),h=e.join(g,r.category);if(!v(h))return l;const f=getCategoryTasteFile({target:"local-project",category:r.category});if(!v(f))return l;const y=await D.readFile(f,"utf-8"),w=new Blob([y],{type:"text/markdown"}),S=new File([w],"taste.md",{type:"text/markdown"});return l.append(`files[${r.category}/taste.md]`,S),l}async function prepareMultiplePackagesUpload(e){const{pkgs:t,projectName:n,description:r,isPublic:o=!1,overwrite:s=!1}=e,i=new FormData;i.append("name",n),r&&i.append("description",r),i.append("type","project"),i.append("isPublic",String(o)),i.append("overwrite",String(s));const a=getRootTasteFile({target:"local-project"});if(v(a)){const e=await D.readFile(a,"utf-8"),t=new Blob([e],{type:"text/markdown"}),n=new File([t],"taste.md",{type:"text/markdown"});i.append("files[taste.md]",n)}const l=t.map(e=>appendCategoryFile(i,e));return await Promise.all(l),i}function parseLearningLine(e){const t=e.match(/^-\s+(.+?)\.\s+Confidence:\s+([\d.]+)/);if(!t)return null;const n=t[1].trim(),r=parseFloat(t[2]);return!n||isNaN(r)?null:{text:n,confidence:r}}function parseTasteContent(e){return e.split("\n").filter(e=>{const t=e.trim();return t&&!t.startsWith("#")&&t.startsWith("-")}).map(e=>parseLearningLine(e.trim())).filter(e=>null!==e)}async function parseApiError(e){const{response:t,fallback:n}=e;try{const e=await t.json();return e.error?.message||e.message||n}catch{return n}}function throwTrackedError(e){const{message:t,label:n,heading:r,status:o,extra:s}=e,i=new Error(t);throw trackError({error:sanitizeErrorForTelemetry({error:i,label:n}),context:{component:To.TASTE_REMOTE_STORAGE,heading:r,"http.status":o,...s}}),i}async function requireAuthKey(){const e=await getAuthKey();if(!e)throw new Error("No API key found. Please authenticate with: cmd login");return e}async function downloadPackage(e){const{owner:t,packageName:n}=e,r=getApiBaseUrl(),o=await tryPublicDownload({baseUrl:r,owner:t,packageName:n});if(o)return o;const s=await getAuthKey();if(!s)throw new Error("Package not found. If this is a private package, please authenticate with `cmd login`");return tryAuthenticatedDownload({baseUrl:r,owner:t,packageName:n,apiKey:s})}async function tryPublicDownload(e){const{baseUrl:t,owner:n,packageName:r}=e,o=`${t}${kt.INTERNAL.PROFILE.PACKAGE_DOWNLOAD.replace(":login",n).replace(":packageName",r)}`;let s;try{s=await fetch(o,{method:"GET"})}catch{return null}if(s.ok){const{data:e}=await s.json();return{type:e.type||"category",files:e.files||[],isPublic:!0}}if(404===s.status)return null;throwTrackedError({message:await parseApiError({response:s,fallback:`Failed to download taste package (${s.status})`}),label:"download_public_error",heading:"Failed to download taste package (public)",status:s.status})}async function tryAuthenticatedDownload(e){const{baseUrl:t,owner:n,packageName:r,apiKey:o}=e,s=`${t}${kt.BETA.TASTE.PACKAGES.DOWNLOAD.replace(":namespace",n).replace(":packageName",r)}`,i=await fetch(s,{method:"GET",headers:{Authorization:`Bearer ${o}`}});if(i.ok){const{data:e}=await i.json();return{type:e.type||"category",files:e.files||[],isPublic:e.isPublic??!1}}if(404===i.status)return null;throwTrackedError({message:await parseApiError({response:i,fallback:"Failed to download taste package"}),label:"download_auth_error",heading:"Failed to download taste package (authenticated)",status:i.status})}async function fetchSinglePackage(e){try{return await getPackage3({category:e.name})}catch(t){const n=t instanceof Error?t:new Error(String(t));return trackError({error:sanitizeErrorForTelemetry({error:n,label:"download_package_error"}),context:{component:To.TASTE_REMOTE_STORAGE,heading:"Failed to download package","package.name":e.name}}),console.warn(`Warning: Failed to download package '${e.name}': ${n.message}`),null}}async function getAllPackages3(){const e=await requireAuthKey(),t=`${getApiBaseUrl()}${kt.BETA.TASTE.PACKAGES.LIST}`,n=await fetch(t,{method:"GET",headers:{Authorization:`Bearer ${e}`}});n.ok||throwTrackedError({message:await parseApiError({response:n,fallback:"Failed to list taste packages"}),label:"list_packages_error",heading:"Failed to list taste packages",status:n.status});const{data:r}=await n.json(),o=r.packages||[];if(0===o.length)return[];const s=[];for(let e=0;e<o.length;e+=5){const t=o.slice(e,e+5),n=await Promise.all(t.map(fetchSinglePackage));s.push(...n.filter(e=>null!==e))}return s}async function getPackage3(e){const{category:t}=e;let n;await requireAuthKey();try{n=await getAuthenticatedEntity()}catch(e){const n=e instanceof Error?e:new Error(String(e));throw dlog(`[Auth] getPackage: entity endpoint unavailable — ${n.message}`),trackError({error:sanitizeErrorForTelemetry({error:n,label:"get_entity_error"}),context:{component:To.TASTE_REMOTE_STORAGE,heading:"getAuthenticatedEntity failed in getPackage"}}),new Error(`Could not resolve your account to fetch '${t}'. Check your connection and try again.`)}if(!n.success||!n.user?.userName)throw new Error("Failed to get authenticated user information");return downloadRemotePackage({owner:n.user.userName,packageName:t})}async function downloadRemotePackage(e){const{owner:t,packageName:n}=e,r=await downloadPackage({owner:t,packageName:n});if(!r)return null;const o=r.files||[];if(0===o.length)return null;const s=o.find(e=>"taste.md"===e.file);if(!s)throw new Error(`No taste.md file found in package '${n}'`);return{category:n,learnings:parseTasteContent(s.content),sourcePath:`remote:${n}`,isPublic:r.isPublic??!1}}async function writePackage3(e){const{pkg:t,owner:n,isPublic:r=!1,overwrite:o=!1}=e,s=await requireAuthKey(),i=await prepareUploadFormData({packageName:t.category,pkg:t,type:"category",isPublic:r,overwrite:o}),a=`${getApiBaseUrl()}${kt.BETA.TASTE.PACKAGES.UPLOAD.replace(":namespace",n)}`,l=await fetch(a,{method:"POST",headers:{Authorization:`Bearer ${s}`},body:i});l.ok||throwTrackedError({message:await parseApiError({response:l,fallback:"Failed to upload taste package"}),label:"upload_package_error",heading:"Failed to upload taste package",status:l.status}),await l.json()}async function writePackages(e){const{packages:t,projectName:n,owner:r,isPublic:o=!1,overwrite:s=!1}=e,i=await requireAuthKey(),a=await prepareMultiplePackagesUpload({pkgs:t,projectName:n,isPublic:o,overwrite:s}),l=`${getApiBaseUrl()}${kt.BETA.TASTE.PACKAGES.UPLOAD.replace(":namespace",r)}`,u=await fetch(l,{method:"POST",headers:{Authorization:`Bearer ${i}`},body:a});u.ok||throwTrackedError({message:await parseApiError({response:u,fallback:"Failed to upload taste packages"}),label:"upload_packages_error",heading:"Failed to upload taste packages",status:u.status,extra:{"package.count":t.length}}),await u.json()}async function listPackages2(){const e=await requireAuthKey(),t=`${getApiBaseUrl()}${kt.BETA.TASTE.PACKAGES.LIST}`,n=await fetch(t,{method:"GET",headers:{Authorization:`Bearer ${e}`}});n.ok||throwTrackedError({message:await parseApiError({response:n,fallback:"Failed to list taste packages"}),label:"list_packages_error",heading:"Failed to list packages",status:n.status});const{data:r}=await n.json();return(r.packages||[]).map(e=>({category:e.name,learningCount:e.learningCount||0,lastUpdated:e.createdAt?new Date(e.createdAt):new Date,filePath:"",isPublic:e.isPublic??!1,starCount:e.starCount??0,downloadCount:e.downloadCount??0,type:e.type??"category"}))}async function list(e){const{location:t}=e;if("local-global"===t)return listPackages();if("remote-project"===t||"remote-user"===t)return listPackages2();if("local-project"===t){const e=getRootTasteFile({target:"local-project"}),t=await getAllPackages2();return Promise.all(t.map(async t=>{let n;if(t.sourcePath!==e)try{n=(await D.stat(t.sourcePath)).mtime}catch{}return{category:t.category,learningCount:t.learnings.length,lastUpdated:n,filePath:t.sourcePath}}))}throw new Error(`Invalid location: ${t}`)}function createListCommand(){return new ke("list").alias("ls").option("-g, --global","List global packages").addOption(new Te("-l, --local","Use local server").hideHelp()).option("--remote","List remote packages").addOption(new Te("--staging","Use staging environment").hideHelp()).description(`List available packages ${ue.dim("(project, global, or remote)")}`).action(withErrorHandler(async e=>runList({options:e})))}__name(loadCategoryPackages2,"loadCategoryPackages"),__name(getAllPackages2,"getAllPackages"),__name(getPackage2,"getPackage"),__name(writePackage2,"writePackage"),__name(exists2,"exists"),Ht(),iw(),Ht(),__name(appendCategoryFile,"appendCategoryFile"),__name(prepareUploadFormData,"prepareUploadFormData"),__name(prepareMultiplePackagesUpload,"prepareMultiplePackagesUpload"),Yt(),Ht(),__name(parseLearningLine,"parseLearningLine"),__name(parseTasteContent,"parseTasteContent"),gk(),No(),Ht(),pk(),No(),__name(parseApiError,"parseApiError"),__name(throwTrackedError,"throwTrackedError"),__name(requireAuthKey,"requireAuthKey"),Ht(),iw(),pk(),Yt(),__name(downloadPackage,"downloadPackage"),__name(tryPublicDownload,"tryPublicDownload"),__name(tryAuthenticatedDownload,"tryAuthenticatedDownload"),Rn(),__name(fetchSinglePackage,"fetchSinglePackage"),__name(getAllPackages3,"getAllPackages"),__name(getPackage3,"getPackage"),__name(downloadRemotePackage,"downloadRemotePackage"),__name(writePackage3,"writePackage"),__name(writePackages,"writePackages"),__name(listPackages2,"listPackages"),__name(list,"list"),__name(createListCommand,"createListCommand");var DP={remote:{location:"remote-project",name:"remote",subtitle:"commandcode.ai account"},global:{location:"local-global",name:"global",subtitle:"~/.commandcode/taste"},project:{location:"local-project",name:"project",subtitle:".commandcode/taste"}};function resolveStorage(e){return e.remote?DP.remote:e.global?DP.global:DP.project}function getPackageDisplayLength(e){let t=e.category.length;return e.isPublic&&(t+=9),e.isPublic&&e.starCount&&(t+=` ${_e.star}${e.starCount}`.length),e.downloadCount&&(t+=` ${_e.arrowDown}${e.downloadCount}`.length),t}function formatPackageLine({pkg:e,maxLen:t}){const n=" ".repeat(t-getPackageDisplayLength(e)+2),r=e.lastUpdated?getTimeAgo(e.lastUpdated):null,o=r?`, updated ${r}`:"";return` ${ue.white(e.category)}${e.isPublic?ue.green(" [public]"):""}${e.isPublic&&e.starCount?ue.yellow(` ${_e.star}${e.starCount}`):""}${e.downloadCount?ue.gray(` ${_e.arrowDown}${e.downloadCount}`):""}${n}${ue.dim.gray(`(${e.learningCount} learnings${o})`)}`}function validateListOptions(e){e.global&&e.remote&&exitWithError("Error: Cannot specify both --global and --remote flags")}async function fetchPackages({options:e}){const t=resolveStorage(e),n=e.remote?xe(`Fetching ${t.name} packages`).start():null,r=await list({location:t.location});return n?.stop(),{packages:r,storage:t}}async function getStorageLabel({options:e,fallback:t}){if(!e.remote)return t;const n=await getUserName();return n?getProfileLink(n):t}function printPackageTable({packages:e,subtitle:t}){console.log(`\n${NP} Packages`),console.log(`${ue.gray("⎿")} ${ue.dim(t)}\n`);const n=Math.max(...e.map(getPackageDisplayLength));let r=0;for(const t of e)r+=t.learningCount,console.log(formatPackageLine({pkg:t,maxLen:n}));console.log(ue.dim(`\nTotal: ${e.length} packages, ${r} learnings\n`))}async function runList({options:e}){console.log(""),validateListOptions(e);const{packages:t,storage:n}=await fetchPackages({options:e});0!==t.length?printPackageTable({packages:t,subtitle:await getStorageLabel({options:e,fallback:n.subtitle})}):console.log(ue.yellow(`No taste packages found in ${n.name}`))}async function fetchAllPackages(e){const{target:t}=e;return"local-project"===t?getAllPackages2():"local-global"===t?getAllPackages():getAllPackages3()}function handleOpenError(e){return e instanceof Error&&e.message.includes("$EDITOR environment variable")?{success:!1,error:getEditorSetupInstructions()}:{success:!1,error:e instanceof Error?e.message:String(e)}}async function readCategoryLineNumber(t){const{filePath:n,category:r}=t,o=await D.readFile(n,"utf-8");if("taste.md"===e.basename(n)&&e.basename(e.dirname(n))===r)return 1;const s=o.split("\n").findIndex(e=>e.trim().toLowerCase()===`# ${r.toLowerCase()}`);return s>=0?s+1:1}async function findCategoryLineNumber(e){try{return await readCategoryLineNumber(e)}catch{return 1}}async function openPackage(e){const{packageName:t,target:n}=e,r=(await fetchAllPackages({target:n})).find(e=>e.category===t);if(!r){let e="project";return"local-global"===n&&(e="global"),"remote-project"!==n&&"remote-user"!==n||(e="remote"),{success:!1,error:`Taste package '${t}' not found in ${e}`}}const o=r.sourcePath,s=await findCategoryLineNumber({filePath:o,category:t});return await it([{file:o,line:s}]),{success:!0,filePath:o,lineNumber:s}}__name(resolveStorage,"resolveStorage"),__name(getPackageDisplayLength,"getPackageDisplayLength"),__name(formatPackageLine,"formatPackageLine"),__name(validateListOptions,"validateListOptions"),__name(fetchPackages,"fetchPackages"),__name(getStorageLabel,"getStorageLabel"),__name(printPackageTable,"printPackageTable"),__name(runList,"runList"),Ht(),Ht(),__name(fetchAllPackages,"fetchAllPackages"),__name(handleOpenError,"handleOpenError"),__name(readCategoryLineNumber,"readCategoryLineNumber"),__name(findCategoryLineNumber,"findCategoryLineNumber"),__name(openPackage,"openPackage");var OP=new Set(["local-project","local-global","remote-project","remote-user"]);async function open11(e){const{package:t,target:n}=e;if(!OP.has(n))return{success:!1,error:`Invalid target: ${n}`};try{return await openPackage({packageName:t,target:n})}catch(e){return handleOpenError(e)}}function getEditorSetupInstructions(){const e=dt.platform;if("win32"===e)return'Error: No default editor found\n\nTo permanently set your default editor, run one of these commands:\n\nCommand Prompt (as Administrator):\n setx EDITOR "code" # VS Code\n setx EDITOR "notepad" # Notepad\n setx EDITOR "vim" # Vim (if installed via WSL/Git Bash)\n\nPowerShell:\n [Environment]::SetEnvironmentVariable("EDITOR", "code", "User")\n\nThen restart your terminal.';const t="darwin"===e?"~/.zshrc":"~/.bashrc";return`Error: No default editor found\n\nTo permanently set your default editor, run one of these commands:\n echo 'export EDITOR="code"' >> ${t} # VS Code\n echo 'export EDITOR="vim"' >> ${t} # Vim\n echo 'export EDITOR="nano"' >> ${t} # Nano\n echo 'export EDITOR="subl"' >> ${t} # Sublime Text\n\nFor bash users ${"darwin"===e?"(or ~/.bash_profile for bash)":"(or ~/.zshrc for zsh)"}, replace ${t} with the appropriate file.\n\nThen restart your terminal or run: source ${t}`}function createOpenCommand(){return new ke("open").argument("[package]","Taste package name, or owner/package to open in browser").option("-g, --global","Open taste package from global storage (~/.commandcode)").description(`Open a taste package in your editor ${ue.dim("(use owner/package to open in browser)")}`).action(withErrorHandler(async(e,t)=>runOpen({packageName:e,options:t})))}function validateOpenOptions(e){e||exitWithUsage({message:"Specify a taste package name to open",usage:["cmd taste open <package> open taste package in editor","cmd taste open <package> -g open global taste package in editor","cmd taste open owner/package open package page in browser"]})}async function runOpen({packageName:e,options:t}){console.log(""),validateOpenOptions(e);const n=parseOwnerPackage(e);n?await openInBrowser(n):await openInEditor3({packageName:e,options:t})}async function openInBrowser(e){const t=`https://commandcode.ai/${e.owner}/${e.packageName}`;await ge(t);const n=getPackageLink({owner:e.owner,packageName:e.packageName});console.log(`${ue.green(_e.tick)} Opened ${n} in browser`)}async function openInEditor3({packageName:e,options:t}){const n=t.global?"local-global":"local-project",r=await open11({package:e,target:n});r.success||exitWithError(r.error??"Unknown error"),console.log(`${ue.green(_e.tick)} Opened ${ue.green(`'${e}'`)} taste package from ${t.global?"global":"project"}`)}__name(open11,"open"),__name(getEditorSetupInstructions,"getEditorSetupInstructions"),__name(createOpenCommand,"createOpenCommand"),__name(validateOpenOptions,"validateOpenOptions"),__name(runOpen,"runOpen"),__name(openInBrowser,"openInBrowser"),__name(openInEditor3,"openInEditor"),Ht(),Ht(),Ht(),Ht();var FP=null,qP=!1;function setActiveSpinner(e){FP=e}function stopActiveSpinner(e){FP&&(FP.stop(e),FP=null)}function setPrompted(e){qP=e}function wasPrompted(){return qP}function beginPrompt(e,t){stopActiveSpinner(),je.intro(ue.dim(e)),t&&je.log.message(ue.dim(t)),setPrompted(!0)}function handleCancel(e){je.isCancel(e)&&(je.cancel("Operation cancelled"),process.exit(0))}function startStrategySpinner(e){if("skip"===e){const e=je.spinner();return e.start("Skipping"),void e.stop("Skipped")}const t="merge"===e?"Merging":"Overwriting",n="merge"===e?"Merged":"Overwritten",r=je.spinner();r.start(t),setActiveSpinner({stop:__name(e=>r.stop(e??n),"stop"),cancel:__name(e=>r.cancel(e),"cancel"),error:__name(e=>r.error(e),"error")})}async function promptMergeStrategy(e){const{packageName:t,owner:n,localPkg:r,remoteLearningsCount:o}=e,s="This package already exists locally";if(!process.stdout.isTTY||!process.stdin.isTTY)return stopActiveSpinner(s),setPrompted(!0),je.log.warn("Non-interactive terminal detected, using default merge strategy"),"merge";beginPrompt(`Pulling ${ue.green(`'${t}'`)} from ${n}`,s),je.log.message(`Local: ${r.learnings.length} learnings\nRemote: ${o} learnings ${ue.dim(`(from ${n})`)}`);const i=await je.select({message:"What would you like to do?",options:[{value:"merge",label:"Merge",hint:"Combine both versions intelligently (default)"},{value:"overwrite",label:"Overwrite",hint:`Replace local with remote (${r.learnings.length} → ${o} learnings)`},{value:"skip",label:"Skip",hint:"Keep local version, ignore remote"}],initialValue:"merge"});handleCancel(i);const a=i;return startStrategySpinner(a),a}async function promptGlobalPushStrategy(e){const{packageName:t,localLearningsCount:n,globalPkg:r}=e,o="This package already exists in global storage";if(!process.stdout.isTTY||!process.stdin.isTTY)return stopActiveSpinner(o),setPrompted(!0),je.log.warn("Non-interactive terminal detected, using default merge strategy"),"merge";beginPrompt(`Pushing ${ue.green(`'${t}'`)} to global`,o),je.log.message(`Local: ${n} learnings\nGlobal: ${r.learnings.length} learnings`);const s=await je.select({message:"What would you like to do?",options:[{value:"merge",label:"Merge",hint:"Combine both versions intelligently (default)"},{value:"overwrite",label:"Overwrite",hint:`Replace global with local (${r.learnings.length} → ${n} learnings)`},{value:"skip",label:"Skip",hint:"Keep global version, cancel push"}],initialValue:"merge"});handleCancel(s);const i=s;return startStrategySpinner(i),i}async function promptGlobalPullStrategy(e){const{packageName:t,localPkg:n,globalLearningsCount:r}=e,o="This package already exists locally";if(!process.stdout.isTTY||!process.stdin.isTTY)return stopActiveSpinner(o),setPrompted(!0),je.log.warn("Non-interactive terminal detected, using default merge strategy"),"merge";beginPrompt(`Pulling ${ue.green(`'${t}'`)} from global`,o),je.log.message(`Local: ${n.learnings.length} learnings\nGlobal: ${r} learnings`);const s=await je.select({message:"What would you like to do?",options:[{value:"merge",label:"Merge",hint:"Combine both versions intelligently (default)"},{value:"overwrite",label:"Overwrite",hint:`Replace local with global (${n.learnings.length} → ${r} learnings)`},{value:"skip",label:"Skip",hint:"Keep local version, ignore global"}],initialValue:"merge"});handleCancel(s);const i=s;return startStrategySpinner(i),i}async function promptTypeMismatchStrategy(e){const{packageName:t,owner:n,localLearningsCount:r,remoteLearningsCount:o}=e,s=`Pushing local project taste to individual package '${t}'`;if(!process.stdout.isTTY||!process.stdin.isTTY)return stopActiveSpinner(s),setPrompted(!0),je.log.warn("Non-interactive terminal detected, skipping push"),"skip";const i=ut(`commandcode.ai/${n}/${t}`,`https://commandcode.ai/${n}/${t}`,{fallback:__name((e,t)=>t,"fallback")});beginPrompt(`Pushing ${ue.green(`'${t}'`)} to ${n}`,s),je.log.message(`Local: ${t} (${r} learnings)\nRemote: ${t} (${o} learnings) in ${n}`),je.log.info(`Current package: ${ue.cyan(i)} ${ue.dim("(review)")}`);const a=await je.select({message:"What would you like to do?",options:[{value:"skip",label:"Skip",hint:"Keep remote version, cancel push"},{value:"overwrite",label:"Overwrite",hint:"Replace individual remote package with local project taste"}],initialValue:"skip"});handleCancel(a);const l=a;return startStrategySpinner(l),l}async function promptSameTypeStrategy(e){const{packageName:t,owner:n,localLearningsCount:r,remoteLearningsCount:o}=e,s=`This package already exists in ${n}`;if(!process.stdout.isTTY||!process.stdin.isTTY)return stopActiveSpinner(s),setPrompted(!0),je.log.warn("Non-interactive terminal detected, skipping push"),"skip";const i=ut(`commandcode.ai/${n}/${t}`,`https://commandcode.ai/${n}/${t}`,{fallback:__name((e,t)=>t,"fallback")});beginPrompt(`Pushing ${ue.green(`'${t}'`)} to ${n}`,s),je.log.message(`Local: ${r} learnings\nRemote: ${o} learnings`),je.log.info(`Current package: ${ue.cyan(i)} ${ue.dim("(review)")}`);const a=await je.select({message:"What would you like to do?",options:[{value:"skip",label:"Skip",hint:"Keep remote version, cancel push"},{value:"overwrite",label:"Overwrite",hint:`Replace remote with local (${o} → ${r} learnings)`}],initialValue:"skip"});handleCancel(a);const l=a;return startStrategySpinner(l),l}function mergeSingleLearning(e,t,n,r){const o=t.get(e.text);return o?e.confidence>o.confidence?(n.set(e.text,e),void r.updated++):void r.unchanged++:(n.set(e.text,e),void r.added++)}function mergePackages(e){const{source:t,target:n}=e,r={added:0,updated:0,unchanged:0},o=new Map(n.map(e=>[e.text,e])),s=new Map(o);for(const e of t)mergeSingleLearning(e,o,s,r);const i=new Set(t.map(e=>e.text)),a=n.filter(e=>!i.has(e.text)).length;return r.unchanged+=a,{merged:Array.from(s.values()),details:r}}function validateSinglePackage(e,t){const n=validateTasteFile({content:formatPackage({pkg:e}),filePath:`${e.category}/taste.md`});if(!n.valid){const r=formatValidationIssues({result:n,verbose:!0});return{pkg:e.category,error:`Validation failed for taste package in ${t}:\n${r}`}}return n.issues.filter(e=>"warning"===e.severity).length>0&&(console.warn(`\nWarning: Taste package '${e.category}' in ${t} has validation warnings:\n`),console.warn(formatValidationIssues({result:n,verbose:!0})+"\n")),null}function validateSingleRemoteFile(e,t){const n=validateTasteFile({content:e.content,filePath:e.file});if(!n.valid){const r=formatValidationIssues({result:n,verbose:!0});return{pkg:t,error:`Validation failed for ${e.file}:\n${r}`}}return n.issues.filter(e=>"warning"===e.severity).length>0&&(console.warn(`\nWarning: File '${e.file}' has validation warnings:\n`),console.warn(formatValidationIssues({result:n,verbose:!0})+"\n")),null}function validatePackages(e){const{packages:t,label:n}=e;return t.map(e=>validateSinglePackage(e,n)).filter(e=>null!==e)}function validateRemoteFiles(e){const{files:t,packageName:n}=e;return t.map(e=>validateSingleRemoteFile(e,n)).filter(e=>null!==e)}function mergeOrKeep(e){const{source:t,existing:n}=e;if(!n)return{pkg:t,details:{added:t.learnings.length,updated:0,unchanged:0}};const r=mergePackages({source:t.learnings,target:n.learnings});return{pkg:{...t,learnings:r.merged},details:r.details}}async function resolveRemotePullStrategy(e){const{flagStrategy:t,overwrite:n,existingPkg:r,tastePkg:o,owner:s}=e;return"skip"===t?r?"skip":"merge":"merge"===t?"merge":"overwrite"===t||n?"overwrite":r?promptMergeStrategy({packageName:o.category,owner:s,localPkg:r,remoteLearningsCount:o.learnings.length}):"merge"}async function executePackageStrategy(e){const{tastePkg:t,owner:n,overwrite:r,flagStrategy:o,result:s}=e,i=await getPackage2({category:t.category}),a=await resolveRemotePullStrategy({flagStrategy:o,overwrite:r,existingPkg:i,tastePkg:t,owner:n});if("skip"===a)return void s.skipped?.push(t.category);if("overwrite"===a&&(await writePackage2({pkg:t}),s.packagesPulled.push(t.category),s.overwritten.push(t.category)),"merge"===a){const{pkg:e,details:n}=mergeOrKeep({source:t,existing:i});await writePackage2({pkg:e}),s.packagesPulled.push(t.category),s.mergeDetails[t.category]=n}const l=getCategoryTasteFile({target:"local-project",category:t.category});s.filePaths[t.category]=l}async function processPackage(e){const{tastePkg:t,result:n}=e;try{await executePackageStrategy(e)}catch(e){n.success=!1,n.errors.push({pkg:t.category,error:e instanceof Error?e.message:String(e)})}}async function pullProjectPackage(e){const{files:t,packageName:n,owner:r,overwrite:o,flagStrategy:s,result:i}=e,a=t.find(e=>"taste.md"===e.file);if(a){const e=parsePackages({content:a.content,sourcePath:`remote:${n}/taste.md`});for(const t of e)await processPackage({tastePkg:t,owner:r,overwrite:o,flagStrategy:s,result:i})}const l=t.filter(e=>"taste.md"!==e.file);for(const e of l){const t=e.file.replace("/taste.md",""),a={category:t,learnings:parseTasteContent(e.content),sourcePath:`remote:${n}/${t}`};await processPackage({tastePkg:a,owner:r,overwrite:o,flagStrategy:s,result:i})}}async function pullCategoryPackage(e){const{files:t,packageName:n,owner:r,overwrite:o,flagStrategy:s,result:i}=e,a=t.find(e=>"taste.md"===e.file);if(!a)return i.success=!1,void i.errors.push({pkg:n,error:"No taste.md file found in category package"});const l={category:n,learnings:parseTasteContent(a.content),sourcePath:`remote:${n}`};await processPackage({tastePkg:l,owner:r,overwrite:o,flagStrategy:s,result:i})}__name(setActiveSpinner,"setActiveSpinner"),__name(stopActiveSpinner,"stopActiveSpinner"),__name(setPrompted,"setPrompted"),__name(wasPrompted,"wasPrompted"),__name(beginPrompt,"beginPrompt"),__name(handleCancel,"handleCancel"),__name(startStrategySpinner,"startStrategySpinner"),__name(promptMergeStrategy,"promptMergeStrategy"),__name(promptGlobalPushStrategy,"promptGlobalPushStrategy"),__name(promptGlobalPullStrategy,"promptGlobalPullStrategy"),__name(promptTypeMismatchStrategy,"promptTypeMismatchStrategy"),__name(promptSameTypeStrategy,"promptSameTypeStrategy"),Ht(),Ht(),__name(mergeSingleLearning,"mergeSingleLearning"),__name(mergePackages,"mergePackages"),__name(validateSinglePackage,"validateSinglePackage"),__name(validateSingleRemoteFile,"validateSingleRemoteFile"),__name(validatePackages,"validatePackages"),__name(validateRemoteFiles,"validateRemoteFiles"),__name(mergeOrKeep,"mergeOrKeep"),Ht(),__name(resolveRemotePullStrategy,"resolveRemotePullStrategy"),__name(executePackageStrategy,"executePackageStrategy"),__name(processPackage,"processPackage"),__name(pullProjectPackage,"pullProjectPackage"),__name(pullCategoryPackage,"pullCategoryPackage");var jP=__name(({pkg:e,error:t})=>({success:!1,packagesPulled:[],errors:[{pkg:e,error:t}],mergeDetails:{},overwritten:[],filePaths:{}}),"fail"),BP=__name(()=>({success:!0,packagesPulled:[],skipped:[],errors:[],mergeDetails:{},overwritten:[],filePaths:{}}),"emptyResult"),UP=__name(e=>"local-global"===e?"global":"remote-project"===e?"remote project":"remote-user"===e?"remote":"source","sourceName");async function resolvePullStrategy(e){const{flagStrategy:t,overwrite:n,existingPkg:r,source:o,tastePkg:s}=e;return"skip"===t?r?"skip":"merge":"merge"===t?"merge":"overwrite"===t||n?"overwrite":r&&"local-global"===o?promptGlobalPullStrategy({packageName:s.category,localPkg:r,globalLearningsCount:s.learnings.length}):"merge"}async function executePullStrategy(e){const{tastePkg:t,source:n,flagStrategy:r,overwrite:o,result:s}=e,i=await getPackage2({category:t.category}),a=await resolvePullStrategy({flagStrategy:r,overwrite:o,existingPkg:i,source:n,tastePkg:t});if("skip"===a)return void s.skipped.push(t.category);if("overwrite"===a&&(await writePackage2({pkg:t}),s.packagesPulled.push(t.category),s.overwritten.push(t.category)),"merge"===a){const{pkg:e,details:n}=mergeOrKeep({source:t,existing:i});await writePackage2({pkg:e}),s.packagesPulled.push(t.category),s.mergeDetails[t.category]=n}const l=getCategoryTasteFile({target:"local-project",category:t.category});s.filePaths[t.category]=l}async function pullSinglePackage(e){const{tastePkg:t,result:n}=e;try{await executePullStrategy(e)}catch(e){n.success=!1,n.errors.push({pkg:t.category,error:e instanceof Error?e.message:String(e)})}}async function pull(e){const{packages:t,source:n,overwrite:r=!1,strategy:o}=e;if("local-global"!==n&&"remote-project"!==n&&"remote-user"!==n)return jP({pkg:"all",error:`Invalid source: ${n}`});const s=UP(n);let i;try{i="local-global"===n?await getAllPackages():await getAllPackages3()}catch(e){return jP({pkg:"all",error:e instanceof Error?e.message:String(e)})}if(0===i.length)return jP({pkg:"all",error:`No taste packages found in ${s}`});const a=validatePackages({packages:i,label:s});if(a.length>0)return{success:!1,packagesPulled:[],errors:[...a],mergeDetails:{},overwritten:[],filePaths:{}};const l=t.length>0?i.filter(e=>t.includes(e.category)):i;if(t.length>0&&0===l.length)return{success:!1,packagesPulled:[],errors:t.map(e=>({pkg:e,error:`Taste package not found in ${s}`})),mergeDetails:{},overwritten:[],filePaths:{}};const u=BP();for(const e of l)await pullSinglePackage({tastePkg:e,source:n,flagStrategy:o,overwrite:r,result:u});return u}async function executePullRemote(e){const{owner:t,packageName:n,overwrite:r,flagStrategy:o,result:s}=e,i=await downloadPackage({owner:t,packageName:n});if(!i)return jP({pkg:n,error:"Taste package not found in remote"});const{type:a,files:l}=i,u=validateRemoteFiles({files:l,packageName:n});if(u.length>0)return{success:!1,packagesPulled:[],errors:[...u],mergeDetails:{},overwritten:[],filePaths:{}};const d={files:l,packageName:n,owner:t,overwrite:r,flagStrategy:o,result:s};return"project"===a?(await pullProjectPackage(d),s):(await pullCategoryPackage(d),s)}async function pullRemote(e){const{owner:t,packageName:n,overwrite:r=!1,strategy:o}=e,s=BP();try{return await executePullRemote({owner:t,packageName:n,overwrite:r,flagStrategy:o,result:s})}catch(e){return jP({pkg:n,error:e instanceof Error?e.message:String(e)})}}function logResult(e){if(wasPrompted())return je.outro(e),void setPrompted(!1);console.log(e)}function buildPullMessage(e){const{pkgName:t,sourceName:n,filePath:r,options:o,mergeDetails:s}=e,i=wasPrompted()?"":`${_e.tick} `,a=r?ue.dim(`\n ${shortenPath(r)}`):"";if(o.overwrite)return`${ue.green(i)}Replaced ${ue.green(`'${t}'`)} taste package in project`+a;if(s){const e=formatMergeParts(s);return`${ue.green(i)}Pulled ${ue.green(`'${t}'`)} taste package from ${n} ${ue.gray(`(${e.join(", ")})`)}`+a}return`${ue.green(i)}Pulled ${ue.green(`'${t}'`)} taste package from ${n}`+a}function logPullSingleSuccess(e){const{result:t,sourceName:n,options:r}=e;if(1!==t.packagesPulled.length)return!1;const o=t.packagesPulled[0],s=t.filePaths?.[o],i=t.mergeDetails?.[o];return logResult(buildPullMessage({pkgName:o,sourceName:n,filePath:s,options:r,mergeDetails:i})),!r.overwrite&&!!i&&hasMergeConflictRisk(i)}function logPullSummary(e){const{result:t,sourceName:n}=e,r=t.overwritten??[],o=t.skipped??[],s=t.packagesPulled.filter(e=>!r.includes(e)),i=t.packagesPulled.length+o.length,a=`${i} ${1===i?"package":"packages"}`,l=[];return s.length>0&&l.push(wrapLine(`${ue.green("Pulled")} (${s.length}) ${s.join(", ")}`,wasPrompted()?4:0)),r.length>0&&l.push(wrapLine(`${ue.yellow("Overwritten")} (${r.length}) ${r.join(", ")}`,wasPrompted()?4:0)),o.length>0&&l.push(wrapLine(`${ue.dim("Skipped")} (${o.length}) ${ue.dim(o.join(", "))}`,wasPrompted()?4:0)),wasPrompted()?(l.length>0&&je.log.message(l.join("\n")),je.outro(`${a} from ${n}`),setPrompted(!1),hasMergeConflictRiskInRecord(t.mergeDetails??{})):(console.log(`${ue.green(_e.tick)} ${a} from ${n}`),l.length>0&&console.log(l.join("\n")),hasMergeConflictRiskInRecord(t.mergeDetails??{}))}function logPullSuccess(e){const{result:t,sourceName:n,options:r}=e,o=t.skipped??[];t.packagesPulled.length+o.length>1?logPullSummary({result:t,sourceName:n})&&logMergeReviewTip():o.length>0?logResult(ue.yellow(`Skipped '${o[0]}' — kept local version`)):logPullSingleSuccess({result:t,sourceName:n,options:r})&&logMergeReviewTip()}function createPullCommand(){return new ke("pull").argument("[package]","Taste package name, or owner/package to pull from remote").option("-g, --global","Pull taste package from global storage (~/.commandcode)").addOption(new Te("--local","Use local server").hideHelp()).option("--remote","Pull taste package from commandcode.ai remote").option("--all","Pull all taste packages from global").option("--overwrite","Replace local package without prompting").option("--skip","Keep local package, skip conflicting pull").option("--merge","Auto-merge conflicting learnings without prompting").addOption(new Te("--staging","Use staging environment").hideHelp()).description(`Pull taste packages from remote or global into the project ${ue.dim("(prompts on conflicts)")}`).action(withErrorHandler(async(e,t)=>{setPrompted(!1);const n=resolveRemoteDefault(t),{result:r,owner:o}=await runPull({packageName:e,options:n});r.success||handleResultErrors(r.errors),logPullSuccess({result:r,sourceName:n.remote?o??"remote":"global",options:n})}))}function validatePullOptions(e){const{packageName:t,options:n}=e;n.global&&n.remote&&exitWithError("--global and --remote are mutually exclusive — pick one source"),n.remote&&n.all&&exitWithUsage({message:"--all is not supported for remote pull — specify a package instead",usage:["cmd taste pull <owner>/<package> pull a taste package from remote"]}),n.remote&&!t&&exitWithUsage({message:"Specify a taste package to pull from remote",usage:["cmd taste pull <owner>/<package> pull a taste package from remote","cmd taste pull <package> -g pull a taste package from global","cmd taste pull --all -g pull all taste packages from global"]}),n.remote&&t&&!t.includes("/")&&exitWithUsage({message:`Remote pull requires owner/package format — got '${t}'`,usage:["cmd taste pull <owner>/<package> e.g. cmd taste pull ahmadawais/code-style"]}),t||n.all||exitWithUsage({message:"Specify a taste package name or use --all to pull everything",usage:["cmd taste pull <owner>/<package> pull a taste package from remote","cmd taste pull <package> -g pull a taste package from global","cmd taste pull --all -g pull all taste packages from global"]}),t&&n.all&&exitWithError("Use either a package name or --all, not both"),resolveConflictStrategy(n)}async function runPull(e){const{packageName:t,options:n}=e;console.log("");const r=resolveRemoteDefault(n);validatePullOptions({packageName:t,options:r});const o=resolveConflictStrategy(r);return r.remote&&t?pullRemoteSingle({packageName:t,options:r,strategy:o}):pullGlobal({packageName:t,options:r,strategy:o})}async function pullRemoteSingle(e){const{packageName:t,options:n,strategy:r}=e,o=parseOwnerPackage(t);o||exitWithError("Invalid format — use owner/package (e.g. ahmadawais/code-style)"),setActiveSpinner(xe("Pulling taste package").start());const s=await pullRemote({owner:o.owner,packageName:o.packageName,overwrite:n.overwrite,strategy:r});return stopActiveSpinner(),{result:s,owner:o.owner}}async function pullGlobal(e){const{packageName:t,options:n,strategy:r}=e;setActiveSpinner(xe("Pulling taste package").start());const o=n.all||!t?[]:[t],s=await pull({packages:o,source:"local-global",overwrite:n.overwrite,strategy:r});return stopActiveSpinner(),{result:s}}async function fetchUserNamespaces(){const e=getApiBaseUrl(),t=new Ly({baseUrl:e}),n=await t.get({endpoint:kt.ALPHA.NAMESPACES});if(!n.success)throw new Error("Failed to fetch namespaces");if("org"===n.type)return{userName:n.org.login,orgs:[]};const r=n.orgs.map(e=>({id:e.id,login:e.login,name:e.name}));return{userName:n.user.userName,orgs:r}}function logResult2(e){if(wasPrompted())return je.outro(e),void setPrompted(!1);console.log(e)}function logPushAllSuccess(t){const{result:n,options:r}=t;if(!r.all)return!1;if(0===n.packagesPushed.length){const e=n.skipped?.length??0;if(e>0){const t=wasPrompted()?"":`${_e.tick} `,n=`${e} ${1===e?"package":"packages"}`;logResult2(`${ue.green(t)}Skipped ${n}`)}return!1}const o=n.packagesPushed.length,s=`${o} ${1===o?"package":"packages"}`,i=n.filePaths?.[n.packagesPushed[0]],a=r.global&&i?shortenPath(e.dirname(e.dirname(i))):i,l=wasPrompted()?"":`${_e.tick} `;if(!a)return logResult2(`${ue.green(l)}Pushed ${s} to remote`),!1;if(r.overwrite||Boolean(n.overwritten?.length)){let e=0;if(n.mergeDetails)for(const t of Object.values(n.mergeDetails))e+=t.updated??0;const t=e>0?` ${ue.gray(`(${e} ${1===e?"learning":"learnings"} replaced)`)}`:"";return logResult2(`${ue.green(l)}Replaced ${s} in ${a}${t}`),!1}if(!n.mergeDetails||0===Object.keys(n.mergeDetails).length)return logResult2(`${ue.green(l)}Pushed ${s} to ${a}`),!1;let u=0,d=0,m=0;for(const e of Object.values(n.mergeDetails))u+=e.added??0,d+=e.updated??0,m+=e.unchanged??0;const g=formatMergeParts({added:u,updated:d,unchanged:m}),h=g.length>0?` ${ue.gray(`(${g.join(", ")})`)}`:"";return logResult2(`${ue.green(l)}Pushed ${s} to ${a}${h}`),(u>0||d>0)&&m>0}function logPushSingleSuccess(e){const{result:t,options:n}=e;if(n.all)return!1;if(1!==t.packagesPushed.length)return!1;const r=t.packagesPushed[0],o=t.filePaths?.[r],s=n.remote&&o,i=s?o:"global",a=wasPrompted()?"":`${_e.tick} `,l=!s&&o?ue.dim(`\n ${shortenPath(o)}`):"";if(n.overwrite)return logResult2(`${ue.green(a)}Replaced ${ue.green(`'${r}'`)} taste package in ${i}`+l),!1;if(t.mergeDetails?.[r]){const e=t.mergeDetails[r],n=formatMergeParts(e);return logResult2(`${ue.green(a)}Pushed ${ue.green(`'${r}'`)} taste package to ${i} ${ue.gray(`(${n.join(", ")})`)}`+l),hasMergeConflictRisk(e)}return logResult2(`${ue.green(a)}Pushed ${ue.green(`'${r}'`)} taste package to ${i}`+l),!1}function logPushMultiSuccess(e){const{result:t,options:n}=e;if(n.all)return!1;if(t.packagesPushed.length<=1)return!1;const r=n.remote?"remote":"global",o=wasPrompted()?"":`${_e.tick} `;return logResult2(wrapLine(`${ue.green(o)}Pushed ${ue.green(t.packagesPushed.length)} taste packages ${ue.green(`(${t.packagesPushed.join(", ")})`)} to ${r}`)),!(n.overwrite||!t.mergeDetails)&&hasMergeConflictRiskInRecord(t.mergeDetails)}function logPushUrls(e){const{result:t,options:n}=e;if(!n.remote||!t.filePaths)return;const r=new Set;for(const e of t.packagesPushed){const n=t.filePaths[e];if(!n||!n.includes("/"))continue;const[o,s]=n.split("/");if(!o||!s)continue;const i=getPackageLink({owner:o,packageName:s});r.has(i)||(r.add(i),console.log(ue.gray(` ${i}`)))}}function logConflictSummary(e){const{result:t}=e,n=t.overwritten??[],r=t.skipped??[],o=t.packagesPushed.filter(e=>!n.includes(e)),s=t.packagesPushed.length+r.length,i=[];o.length>0&&i.push(wrapLine(`${ue.green("Merged")} (${o.length}) ${o.join(", ")}`,4)),n.length>0&&i.push(wrapLine(`${ue.yellow("Overwritten")} (${n.length}) ${n.join(", ")}`,4)),r.length>0&&i.push(wrapLine(`${ue.dim("Skipped")} (${r.length}) ${ue.dim(r.join(", "))}`,4)),i.length>0&&je.log.message(i.join("\n"));const a=`${s} ${1===s?"package":"packages"}`;je.outro(a)}function logPushBreakdown(e){const t=e.overwritten??[],n=e.skipped??[];if(0===n.length&&0===t.length)return;const r=e.packagesPushed.filter(e=>!t.includes(e)),o=[];r.length>0&&o.push(wrapLine(`${ue.green("Pushed")} (${r.length}) ${r.join(", ")}`)),t.length>0&&o.push(wrapLine(`${ue.yellow("Overwritten")} (${t.length}) ${t.join(", ")}`)),n.length>0&&o.push(wrapLine(`${ue.dim("Skipped")} (${n.length}) ${ue.dim(n.join(", "))}`)),o.length>0&&console.log(o.join("\n"))}function logPushSuccess(e){const{result:t,options:n}=e;if(wasPrompted())return setPrompted(!1),logConflictSummary({result:t}),void logPushUrls({result:t,options:n});const r=logPushAllSuccess({result:t,options:n})||logPushSingleSuccess({result:t,options:n})||logPushMultiSuccess({result:t,options:n});n.all&&logPushBreakdown(t),logPushUrls({result:t,options:n}),r&&logMergeReviewTip()}__name(resolvePullStrategy,"resolvePullStrategy"),__name(executePullStrategy,"executePullStrategy"),__name(pullSinglePackage,"pullSinglePackage"),__name(pull,"pull"),__name(executePullRemote,"executePullRemote"),__name(pullRemote,"pullRemote"),Ht(),__name(logResult,"logResult"),__name(buildPullMessage,"buildPullMessage"),__name(logPullSingleSuccess,"logPullSingleSuccess"),__name(logPullSummary,"logPullSummary"),__name(logPullSuccess,"logPullSuccess"),__name(createPullCommand,"createPullCommand"),__name(validatePullOptions,"validatePullOptions"),__name(runPull,"runPull"),__name(pullRemoteSingle,"pullRemoteSingle"),__name(pullGlobal,"pullGlobal"),Ht(),Rn(),Ht(),iw(),Xy(),Yt(),__name(fetchUserNamespaces,"fetchUserNamespaces"),Ht(),__name(logResult2,"logResult"),__name(logPushAllSuccess,"logPushAllSuccess"),__name(logPushSingleSuccess,"logPushSingleSuccess"),__name(logPushMultiSuccess,"logPushMultiSuccess"),__name(logPushUrls,"logPushUrls"),__name(logConflictSummary,"logConflictSummary"),__name(logPushBreakdown,"logPushBreakdown"),__name(logPushSuccess,"logPushSuccess"),Ht(),gk(),Ht();var zP=__name(({pkg:e,error:t})=>({success:!1,packagesPushed:[],skipped:[],errors:[{pkg:e,error:t}],mergeDetails:{},overwritten:[],filePaths:{}}),"fail"),WP=__name(e=>e.reduce((e,t)=>t.file.endsWith("taste.md")?e+parseTasteContent(t.content).length:e,0),"countRemoteLearnings");async function resolvePushAllStrategy(e){const{flagStrategy:t,overwrite:n,existingProject:r,packagesToPush:o,projectName:s,owner:i}=e;if("skip"===t)return"skip";if("overwrite"===t||n)return"overwrite";if("merge"===t)return"overwrite";if(!r)return"overwrite";const a=r.type??"category",l=o.reduce((e,t)=>e+t.learnings.length,0),u=WP(r.files);return"project"!==a?promptTypeMismatchStrategy({packageName:s,owner:i,localLearningsCount:l,remoteLearningsCount:u}):promptSameTypeStrategy({packageName:s,owner:i,localLearningsCount:l,remoteLearningsCount:u})}async function executePushAllRemote(t){const{packagesToPush:n,owner:r,overwrite:o,isPublic:s,isPublicExplicitlySet:i,flagStrategy:a}=t,l=e.basename(process.cwd()),u={success:!0,packagesPushed:[],skipped:[],errors:[],mergeDetails:{},overwritten:[],filePaths:{}},d=await downloadPackage({owner:r,packageName:l}),m=await resolvePushAllStrategy({flagStrategy:a,overwrite:o,existingProject:d,packagesToPush:n,projectName:l,owner:r});if("skip"===m)return u.skipped.push(...n.map(e=>e.category)),u;await writePackages({packages:n,projectName:l,owner:r,isPublic:i?s:d?.isPublic??!1,overwrite:"overwrite"===m});for(const e of n)u.packagesPushed.push(e.category),u.filePaths[e.category]=`${r}/${l}`,u.mergeDetails[e.category]={added:e.learnings.length,updated:0,unchanged:0};return d&&u.overwritten.push(...n.map(e=>e.category)),u}async function pushAllRemote(e){try{return await executePushAllRemote(e)}catch(e){return zP({pkg:"all",error:e instanceof Error?e.message:String(e)})}}__name(resolvePushAllStrategy,"resolvePushAllStrategy"),__name(executePushAllRemote,"executePushAllRemote"),__name(pushAllRemote,"pushAllRemote");var GP=__name(({pkg:e,error:t})=>({success:!1,packagesPushed:[],skipped:[],errors:[{pkg:e,error:t}],mergeDetails:{},overwritten:[],filePaths:{}}),"fail"),HP=__name(()=>({success:!0,packagesPushed:[],skipped:[],errors:[],mergeDetails:{},overwritten:[],filePaths:{}}),"emptyResult");async function writePkg(e){const{pkg:t,target:n,owner:r,isPublic:o,overwrite:s}=e;if("local-global"!==n){if(!r)throw new Error("Failed to get owner for remote push");await writePackage3({pkg:t,owner:r,isPublic:o,overwrite:s})}else await writePackage({pkg:t})}__name(writePkg,"writePkg");var VP=__name(e=>{const{target:t,category:n,owner:r}=e;return"local-global"===t?getCategoryTasteFile({target:"local-global",category:n}):"remote-project"!==t&&"remote-user"!==t||!r?void 0:`${r}/${n}`},"getDestPath");async function getUserOwner(){try{const e=await getAuthenticatedEntity();if(e.success&&e.user?.userName)return e.user.userName}catch{}}async function resolveSinglePushStrategy(e){const{flagStrategy:t,overwrite:n,existingPkg:r,target:o,tastePkg:s}=e;return"skip"===t?r?"skip":"merge":"merge"===t?"merge":"overwrite"===t||n?"overwrite":r&&"local-global"===o?promptGlobalPushStrategy({packageName:s.category,localLearningsCount:s.learnings.length,globalPkg:r}):"merge"}async function executePushStrategy(e){const{tastePkg:t,target:n,flagStrategy:r,overwrite:o,userOwner:s,isPublic:i,result:a}=e,l="local-global"===n?await getPackage({category:t.category}):await getPackage3({category:t.category}),u=await resolveSinglePushStrategy({flagStrategy:r,overwrite:o,existingPkg:l,target:n,tastePkg:t});if("skip"===u)return void a.skipped.push(t.category);if("overwrite"===u&&(await writePkg({pkg:t,target:n,owner:s,isPublic:i,overwrite:!0}),a.packagesPushed.push(t.category),a.overwritten.push(t.category),a.mergeDetails[t.category]={added:0,updated:t.learnings.length,unchanged:0}),"merge"===u){const{pkg:e,details:r}=mergeOrKeep({source:t,existing:l});await writePkg({pkg:e,target:n,owner:s,isPublic:i}),a.packagesPushed.push(t.category),a.mergeDetails[t.category]=r}const d=VP({target:n,category:t.category,owner:s});d&&(a.filePaths[t.category]=d)}async function pushSinglePackage(e){const{tastePkg:t,result:n}=e;try{await executePushStrategy(e)}catch(e){n.success=!1,n.errors.push({pkg:t.category,error:e instanceof Error?e.message:String(e)})}}async function push(e){const t=void 0!==e.isPublic,{packages:n,target:r,overwrite:o=!1,isPublic:s=!1,strategy:i}=e;if(!exists2())return GP({pkg:"all",error:"No taste directory found in project"});const a=await getAllPackages2();if(0===a.length)return GP({pkg:"all",error:"No taste packages found in project"});const l=validatePackages({packages:a,label:"project"});if(l.length>0)return{success:!1,packagesPushed:[],skipped:[],errors:[...l],mergeDetails:{},overwritten:[],filePaths:{}};const u=n.length>0?a.filter(e=>n.includes(e.category)):a;if(n.length>0&&0===u.length)return{success:!1,packagesPushed:[],skipped:[],errors:n.map(e=>({pkg:e,error:"Taste package not found in project"})),mergeDetails:{},overwritten:[],filePaths:{}};const d="remote-project"===r||"remote-user"===r?e.owner??await getUserOwner():void 0;if("remote-project"===r&&0===n.length)return d?pushAllRemote({packagesToPush:u,owner:d,overwrite:o,isPublic:s,isPublicExplicitlySet:t,flagStrategy:i}):GP({pkg:"all",error:"Failed to get owner for remote push"});if("local-global"!==r&&"remote-project"!==r&&"remote-user"!==r)return GP({pkg:"all",error:`Invalid target: ${r}`});const m=HP();for(const e of u)await pushSinglePackage({tastePkg:e,target:r,flagStrategy:i,overwrite:o,userOwner:d,isPublic:s,result:m});return m}async function executeRemotePush(e){const t=void 0!==e.isPublic,{owner:n,packageName:r,overwrite:o=!1,isPublic:s=!1,strategy:i}=e,a=await getPackage2({category:r});if(!a)return GP({pkg:r,error:`Taste package '${r}' not found in local project`});const l=validateTasteFile({content:formatPackage({pkg:a}),filePath:`${a.category}/taste.md`});if(!l.valid){const e=formatValidationIssues({result:l,verbose:!0});return GP({pkg:r,error:`Validation failed:\n${e}`})}l.issues.filter(e=>"warning"===e.severity).length>0&&(console.warn(`\nWarning: Taste package '${r}' has validation warnings:\n`),console.warn(formatValidationIssues({result:l,verbose:!0})+"\n"));const u=await downloadRemotePackage({owner:n,packageName:r}),d=await resolveSinglePushStrategy({flagStrategy:i,overwrite:o,existingPkg:u,target:"remote-project",tastePkg:a}),m=t?s:u?.isPublic??!1,g=HP();if("skip"===d)return g.skipped.push(r),g;if("overwrite"===d&&(await writePackage3({pkg:a,owner:n,isPublic:m,overwrite:!0}),g.packagesPushed.push(r),g.overwritten.push(r)),"merge"===d){const{pkg:e,details:t}=mergeOrKeep({source:a,existing:u});await writePackage3({pkg:e,owner:n,isPublic:m}),g.packagesPushed.push(r),g.mergeDetails[r]=t}return g.filePaths[r]=`${n}/${r}`,g}async function pushRemote(e){const{packageName:t}=e;if(!exists2())return GP({pkg:t,error:"No taste directory found in project"});try{return await executeRemotePush(e)}catch(e){return GP({pkg:t,error:e instanceof Error?e.message:String(e)})}}async function promptOwnerSelection(e){const{userName:t,orgs:n}=e;if(0===n.length)return t;const r=[{value:t,label:t,hint:"Personal"},...n.map(e=>({value:e.login,label:e.name||e.login,hint:"Organization"}))],o=await je.select({message:"Owner",options:r,initialValue:t});return je.isCancel(o)&&(je.cancel("Operation cancelled"),process.exit(0)),o}function createPushCommand(){return new ke("push").description(`Push taste packages to remote ${ue.dim("(commandcode.ai)")} or global ${ue.dim("(~/.commandcode)")}`).argument("[package]","Taste package name to push (omit with --all)").option("--all","Push all taste packages to remote").option("--remote","Push to commandcode.ai remote (default)").option("-g, --global","Push to local global storage (~/.commandcode)").addOption(new Te("--local","Use local server").hideHelp()).option("--public","Make package publicly discoverable on commandcode.ai").option("--private","Make package private (not publicly discoverable)").option("--owner <owner>","Push under a specific owner or organization").option("--overwrite","Replace existing package without prompting").option("--skip","Keep existing package, skip conflicting push").option("--merge","Auto-merge conflicting learnings without prompting").addOption(new Te("--staging","Push to staging environment").hideHelp()).action(withErrorHandler(async(e,t)=>{setPrompted(!1);const n=resolveRemoteDefault(t),r=await runPush({packageName:e,options:n});r.success||handleResultErrors(r.errors),logPushSuccess({result:r,options:n})}))}function validatePushOptions(e){const{packageName:t,options:n}=e;n.global&&n.remote&&exitWithError("--global and --remote are mutually exclusive — pick one destination"),n.public&&n.private&&exitWithError("--public and --private are mutually exclusive — pick one visibility"),n.owner&&n.global&&exitWithError("--owner only applies to remote pushes, not --global"),t||n.all||exitWithUsage({message:"Specify a taste package name or use --all to push everything",usage:["cmd taste push <package> push a taste package to remote (default)","cmd taste push --all push all taste packages to remote","cmd taste push <package> -g push a taste package to global (~/.commandcode)"]}),t&&n.all&&exitWithError("Use either a package name or --all, not both"),resolveConflictStrategy(n)}__name(getUserOwner,"getUserOwner"),__name(resolveSinglePushStrategy,"resolveSinglePushStrategy"),__name(executePushStrategy,"executePushStrategy"),__name(pushSinglePackage,"pushSinglePackage"),__name(push,"push"),__name(executeRemotePush,"executeRemotePush"),__name(pushRemote,"pushRemote"),Ht(),__name(promptOwnerSelection,"promptOwnerSelection"),__name(createPushCommand,"createPushCommand"),__name(validatePushOptions,"validatePushOptions");var QP=__name(e=>!!e.public||!e.private&&void 0,"resolveVisibility");async function validateOwnerAccess(e){let t;try{t=await fetchUserNamespaces()}catch(e){return void dlog(`[Auth] validateOwnerAccess: namespace service unavailable, skipping — ${e instanceof Error?e.message:String(e)}`)}const n=[t.userName,...t.orgs.map(e=>e.login)];n.includes(e)||exitWithError(`No push access to '${e}'. Available: ${n.join(", ")}`)}async function resolveOwnerForPush(e){const{packageName:t,owner:n}=e,r=parseOwnerPackage(t);if(r)return await validateOwnerAccess(r.owner),r;if(n)return await validateOwnerAccess(n),{owner:n,packageName:t};je.intro(ue.dim(`pushing ${t}`)),setPrompted(!0);const o=je.spinner();o.start("Resolving"),(await list({location:"local-project"})).some(e=>e.category===t)||(o.error("Failed"),je.outro(ue.red(`Taste package '${t}' not found in project`)),process.exit(1));const s=await fetchUserNamespaces();return o.stop(s.orgs.length>0?"Select owner to push to":""),{owner:s.orgs.length>0?await promptOwnerSelection(s):s.userName,packageName:t}}async function runPush(e){const{packageName:t,options:n}=e;console.log("");const r=resolveRemoteDefault(n);validatePushOptions({packageName:t,options:r});const o=resolveConflictStrategy(r);return r.remote&&r.all?pushRemoteAll({options:r,strategy:o}):r.remote?pushRemoteSingle({packageName:t,options:r,strategy:o}):pushGlobal({packageName:t,options:r,strategy:o})}async function pushRemoteAll(t){const{options:n,strategy:r}=t;n.owner&&await validateOwnerAccess(n.owner);const o=(await getAllPackages2()).length,s=`${o} ${1===o?"package":"packages"}`,i=e.basename(process.cwd()),a=resolveStrategyLabel({strategy:r,isRemote:!0});console.log(ue.dim(` Pushing ${s} to ${i} (remote)${a}`)),console.log(""),setActiveSpinner(xe("Pushing taste packages").start());const l=await push({packages:[],target:"remote-project",overwrite:n.overwrite,isPublic:QP(n),strategy:r,owner:n.owner});return stopActiveSpinner(),l}async function pushRemoteSingle(e){const{packageName:t,options:n,strategy:r}=e,{owner:o,packageName:s}=await resolveOwnerForPush({packageName:t,owner:n.owner});startPushSpinner({owner:o,pkgName:s});const i=await pushRemote({owner:o,packageName:s,overwrite:n.overwrite,isPublic:QP(n),strategy:r});return stopActiveSpinner(`Pushed to ${o}/${s}`),i}function resolveStrategyLabel(e){const{strategy:t,isRemote:n=!1}=e;return"overwrite"===t?" · overwrite":"skip"===t?" · skip conflicts":"merge"===t?" · auto-merge":n?"":" · will prompt on conflicts"}function startPushSpinner(e){const{owner:t,pkgName:n}=e;if(wasPrompted()){const e=je.spinner();return e.start(`Pushing to ${t}/${n}`),void setActiveSpinner(e)}setActiveSpinner(xe("Pushing taste package").start())}async function pushGlobal(e){const{packageName:t,options:n,strategy:r}=e,o=n.all||!t?[]:[t],s=await getAllPackages2(),i=o.length>0?o.length:s.length,a=`${i} ${1===i?"package":"packages"}`,l=shortenPath(getTastePath({target:"local-global"})),u=resolveStrategyLabel({strategy:r});console.log(ue.dim(` Pushing ${a} to ${l}${u}`)),console.log(""),setActiveSpinner(xe("Pushing taste packages").start());const d=await push({packages:o,target:"local-global",overwrite:n.overwrite,strategy:r});return stopActiveSpinner(),d}function createTasteCommand(){const e=new ke(Mt.TASTE);return e.description("Manage taste learning packages").allowUnknownOption().allowExcessArguments(),e.addCommand(createPushCommand()),e.addCommand(createPullCommand()),e.addCommand(createListCommand()),e.addCommand(createLintCommand()),e.addCommand(createOpenCommand()),isExperimentalEnabled()&&e.addCommand(createLearnCommand()),e}function formatVersion(e,t,n=!1){const r=n?de.bold(de.green(t)):de.white(t);return`${de.dim(e)} ${r}`}function showVersionDetails(e){console.log(formatVersion("Current:",e.currentVersion)),console.log(formatVersion("Latest: ",e.latestVersion,!0)),console.log(""),console.log(`Run ${de.bold(de.green("cmd update"))} to install.`)}function showUpdateSuccessHint(){console.log(de.dim(`Run ${de.cyan("cmd")} to start using the new version.`))}function showManualUpdateHint(e){console.log(de.dim("Try updating manually:")),console.log(de.cyan(`npm i -g command-code@${e}`))}function showCheckFailure(){console.log(de.dim("Please check your internet connection or try again later."))}async function checkAction(){const e=xe("Checking for updates...").start(),t=await checkForUpdateAvailable();if(!t)return e.fail("Failed to check for updates"),void showCheckFailure();t.updateAvailable?(e.stop(),console.log(""),console.log(`${de.green(_e.tick)} Update available`),showVersionDetails(t)):e.succeed(`Up to date ${de.dim(`(${t.currentVersion})`)}`)}async function performUpdateAction(){const e=xe("Checking for updates...").start(),t=await checkForUpdateAvailable();if(!t)return e.fail("Failed to check for updates"),void showCheckFailure();t.updateAvailable?(e.text=`Updating ${t.currentVersion} ${_e.arrowRight} ${t.latestVersion}...`,(await performAutoUpdate({silent:!0,updateInfo:t})).success||(e.fail("Update failed"),trackError({error:sanitizeErrorForTelemetry({error:new Error("Update failed"),label:"cli_update_failed"}),context:{component:To.UPDATE_COMMAND,heading:"CLI update failed","update.current_version":t.currentVersion,"update.target_version":t.latestVersion}}),showManualUpdateHint(t.latestVersion),await shutdownTelemetry(),process.exit(1)),e.succeed(`Updated to v${t.latestVersion}`),showUpdateSuccessHint()):e.succeed(`Up to date ${de.dim(`(${t.currentVersion})`)}`)}async function updateAction(e){e.checkOnly?await checkAction():await performUpdateAction()}__name(validateOwnerAccess,"validateOwnerAccess"),__name(resolveOwnerForPush,"resolveOwnerForPush"),__name(runPush,"runPush"),__name(pushRemoteAll,"pushRemoteAll"),__name(pushRemoteSingle,"pushRemoteSingle"),__name(resolveStrategyLabel,"resolveStrategyLabel"),__name(startPushSpinner,"startPushSpinner"),__name(pushGlobal,"pushGlobal"),Pr(),__name(createTasteCommand,"createTasteCommand"),Ht(),Yt(),No(),__name(formatVersion,"formatVersion"),__name(showVersionDetails,"showVersionDetails"),__name(showUpdateSuccessHint,"showUpdateSuccessHint"),__name(showManualUpdateHint,"showManualUpdateHint"),__name(showCheckFailure,"showCheckFailure"),__name(checkAction,"checkAction"),__name(performUpdateAction,"performUpdateAction"),__name(updateAction,"updateAction");var KP=new ke("update").description("Update Command Code to the latest version").option("--check-only","Check for updates without installing").allowUnknownOption().allowExcessArguments().action(updateAction);Ht(),pk(),gk();var YP=__name((e,t)=>`${_e.info} ${e}: ${de.cyan(t)}`,"formatInfoLine"),JP=__name(e=>de.bold(`${e}:`),"formatSectionHeader"),XP=__name(e=>de.red(e),"formatError"),ZP=__name(e=>e instanceof Error?e.message:"Unknown error","formatErrorMessage"),eI=__name(e=>["",JP("User Information"),YP("Name",e.name),YP("Email",e.email),YP("Username",e.userName)],"buildUserOutput"),tI=__name(e=>["",JP("Organization"),YP("Name",e.name),YP("Login",e.login)],"buildOrgOutput"),nI=__name(e=>{e.forEach(e=>console.log(e))},"printLines"),rI=__name((e,t)=>{nI(eI(e)),t&&nI(tI(t)),console.log("")},"displayUserInfo"),oI=__name(e=>null!==e&&e.length>0,"validateApiKey"),sI=__name(e=>e.success&&null!==e.user,"validateUserData");async function whoamiAction(){const e=xe("Fetching user information...").start();try{const t=await getAuthKey();oI(t)||(e.fail(XP('Not authenticated. Please login using "cmd auth login"')),process.exit(1));const n=await getAuthenticatedEntity();sI(n)||(e.fail(XP("Failed to fetch user info")),process.exit(1)),e.succeed("User information loaded"),rI(n.user,n.org)}catch(t){e.fail(XP(`Error: ${ZP(t)}`)),process.exit(1)}}__name(whoamiAction,"whoamiAction");var iI=new ke("whoami").description("Display current user information").allowUnknownOption().allowExcessArguments().action(whoamiAction);function normalizeGitUrl(e){let t=e.trim();const n=t.match(/^git@([^:]+):(.+?)(?:\.git)?$/);return n?`https://${n[1]}/${n[2]}`:(t=t.replace(/\.git$/,""),t)}function validateGitRepo(){try{if("true"!==M("git rev-parse --is-inside-work-tree",{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim())throw new Error("Not inside a git repository.")}catch{throw new Error("Sandbox requires a git repository with a GitHub remote.")}let e;try{e=M("git remote get-url origin",{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim()}catch{throw new Error("No GitHub remote found. Add one with: git remote add origin https://github.com/you/repo")}const t=normalizeGitUrl(e);let n;try{n=M("git branch --show-current",{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim()}catch{throw new Error("Failed to determine current branch.")}if(!n)throw new Error("Detached HEAD state. Please checkout a branch first.");if(!/^[\w./-]+$/.test(n))throw new Error("Branch name contains invalid characters. Please use a simpler branch name.");try{if(!M(`git ls-remote --heads origin ${n}`,{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim())throw new Error(`Branch "${n}" not found on remote. Push it first: git push -u origin ${n}`)}catch(e){if(e instanceof Error&&e.message.includes("not found on remote"))throw e;throw new Error(`Branch "${n}" not found on remote. Push it first: git push -u origin ${n}`)}return{repoUrl:t,branch:n,isClean:""===M("git status --porcelain",{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim()}}function getGitHubToken(){const e=process.env.GITHUB_TOKEN;if(e)return e;try{return M("gh auth token",{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim()}catch{throw new Error("GitHub authentication required.\nEither set GITHUB_TOKEN or run: gh auth login")}}Ht(),Ht(),Yt(),Xy(),iw(),en(),Fr(),Ht(),__name(normalizeGitUrl,"normalizeGitUrl"),__name(validateGitRepo,"validateGitRepo"),Ht(),__name(getGitHubToken,"getGitHubToken"),Ht(),iw(),pk(),Ht();var aI=["completed","failed","cancelled","timed_out"];function isTerminalStatus(e){return aI.includes(e)}__name(isTerminalStatus,"isTerminalStatus");var lI={setting_up:"Setting up sandbox...",cloning:"Cloning repository..."};function stopAllSpinners({state:e}){e.workingSpinner&&(e.workingSpinner.stop(),e.workingSpinner=null),e.currentSpinner&&(e.currentSpinner.stop(),e.currentSpinner=null)}function renderStatusEvent({event:e,state:t}){const n=e.data.status,r=lI[n],o="setup"===t.phase;if(t.isResume&&o&&!isTerminalStatus(n)&&"running"!==n)r&&t.workingSpinner&&(t.workingSpinner.text=r);else{if(r&&o&&(t.currentSpinner&&t.currentSpinner.succeed(),t.currentSpinner=xe({stream:process.stderr,text:r}).start()),"running"===n)return t.currentSpinner&&(t.currentSpinner.succeed(),t.currentSpinner=null),t.phase="running",void(t.workingSpinner||(t.workingSpinner=xe({stream:process.stderr}).start()));if("completed"===n){t.workingSpinner&&(t.workingSpinner.succeed("Session completed"),t.workingSpinner=null),t.currentSpinner&&(t.currentSpinner.succeed(),t.currentSpinner=null),t.phase="done";const n=e.data.prUrl;return void(n&&console.error(`PR: ${de.cyan(n)}`))}if("failed"===n){t.workingSpinner&&(t.workingSpinner.fail("Session failed"),t.workingSpinner=null),t.currentSpinner&&(t.currentSpinner.fail(),t.currentSpinner=null),t.phase="done";const n=e.data.message||"Unknown error";return void console.error(`${_e.cross} ${de.red(n)}`)}if("timed_out"===n)return t.workingSpinner&&(t.workingSpinner.fail("Session timed out"),t.workingSpinner=null),t.currentSpinner&&(t.currentSpinner.fail("Timed out"),t.currentSpinner=null),void(t.phase="done");"cancelled"===n&&(stopAllSpinners({state:t}),t.phase="done",console.error(`\n${de.yellow("Cancelled.")}`))}}function renderEvent({event:e,state:t}){if("status"!==e.type){if("pty"===e.type){const n=e.data.content;return void(n&&(t.workingSpinner&&t.workingSpinner.stop(),process.stdout.write(n),t.workingSpinner&&t.workingSpinner.start()))}if("error"===e.type){t.currentSpinner&&(t.currentSpinner.fail(),t.currentSpinner=null);const n=e.data.message;console.error(`${_e.cross} ${de.red(n)}`)}}else renderStatusEvent({event:e,state:t})}function setupInputHandling({callbacks:e}){const t=__name(t=>{3===t[0]?e.onCancel():4===t[0]&&e.onDetach()},"onStdinData"),n=process.rawListeners("SIGINT").slice();return process.removeAllListeners("SIGINT"),process.stdin.isTTY?(process.stdin.setRawMode(!0),process.stdin.resume(),process.stdin.on("data",t),process.on("SIGINT",()=>{})):process.on("SIGINT",()=>e.onCancel()),()=>{process.stdin.isTTY&&(process.stdin.removeListener("data",t),process.stdin.setRawMode(!1),process.stdin.pause()),process.removeAllListeners("SIGINT");for(const e of n)process.on("SIGINT",e)}}function setupResizeForwarding({ws:e}){const t=__name(()=>{e.readyState===WebSocket.OPEN&&e.send(JSON.stringify({action:"resize",cols:process.stdout.columns,rows:process.stdout.rows}))},"onResize");return process.stdout.on("resize",t),()=>process.stdout.removeListener("resize",t)}function sendTerminalSize({ws:e}){e.send(JSON.stringify({action:"resize",cols:process.stdout.columns||120,rows:process.stdout.rows||30}))}async function streamSession({sessionId:e,prompt:t,lastEventId:n=0,isResume:r=!1}){const o=getApiBaseUrl().replace(/^http/,"ws"),s=await getAuthKey();if(!s)throw new Error("Not authenticated. Run: cmd login");const i=new URLSearchParams({token:s,...n>0?{lastEventId:String(n)}:{}}),a=`${o}/alpha/sandbox/stream/${e}?${i.toString()}`;return new Promise((t,o)=>{const s=new WebSocket(a),i={currentSpinner:null,workingSpinner:null,phase:"setup",lastEventId:n,isResume:r};r&&(i.currentSpinner=xe({stream:process.stderr,text:"Reconnecting..."}).start());const l=__name(()=>{i.phase="done",stopAllSpinners({state:i}),s.close(),console.error(`\n${de.yellow("Detached.")} Session still running.`),console.error(`Resume with: ${de.cyan(`cmd --experimental sandbox --id ${e}`)}`),g(),t()},"detach"),u=__name(()=>{i.phase="done",stopAllSpinners({state:i}),s.readyState===WebSocket.OPEN&&s.send(JSON.stringify({action:"cancel"})),s.close(),console.error(`\n${de.yellow("Sandbox stopped.")}`),g(),t()},"cancelSandbox"),d=setupResizeForwarding({ws:s}),m=setupInputHandling({callbacks:{onCancel:u,onDetach:l}});process.once("SIGTERM",l);const g=__name(()=>{d(),m(),process.removeListener("SIGTERM",l)},"teardown");s.addEventListener("open",()=>{sendTerminalSize({ws:s}),i.currentSpinner&&(i.currentSpinner.stop(),i.currentSpinner=null),console.error(""),console.error(`${de.yellow("[Ctrl+C]")} ${de.dim("stop")} ${de.yellow("[Ctrl+D]")} ${de.dim("detach")}`),console.error(`${de.dim("Session:")} ${de.gray(e)}`),console.error(""),r&&(i.workingSpinner=xe({stream:process.stderr}).start())}),s.addEventListener("message",e=>{try{const n="string"==typeof e.data?e.data:e.data.toString(),r=JSON.parse(n);renderEvent({event:r,state:i}),void 0!==r.id&&(i.lastEventId=r.id),"status"===r.type&&isTerminalStatus(r.data.status)&&(s.close(),g(),t())}catch{}}),s.addEventListener("error",()=>{g(),i.currentSpinner&&(i.currentSpinner.fail("Connection error"),i.currentSpinner=null),o(new Error("WebSocket connection failed"))}),s.addEventListener("close",()=>{"done"!==i.phase&&(i.phase="done",stopAllSpinners({state:i}),g(),console.error(`\n${de.yellow("Disconnected.")} Session still running.`),console.error(`Resume with: ${de.cyan(`cmd --experimental sandbox --id ${e}`)}`),t())})})}function readLocalConfigFiles(){let e="",t="";try{e=E.readFileSync(getAuthFile(),"utf-8")}catch{}try{t=E.readFileSync(getConfigFile(),"utf-8")}catch{}return{auth:e,config:t}}async function askQuestion(e){const t=Xe.createInterface({input:process.stdin,output:process.stderr});return new Promise(n=>{t.question(e,e=>{t.close(),n(e)})})}async function startSandboxSession({repoUrl:e,branch:t,prompt:n,ghToken:r,isInternalTeam:o,configFiles:s}){return new Ly({baseUrl:getApiBaseUrl()}).post({endpoint:kt.ALPHA.SANDBOX.START,body:{repoUrl:e,branch:t,prompt:n,ghToken:r,isInternalTeam:o,configFiles:s}})}async function sandboxMode({prompt:e,resume:t}){t&&(await streamSession({sessionId:t,isResume:!0}),process.exit(0)),await ensureAuthenticated()||process.exit(1);const n=validateGitRepo();n.isClean||console.error(de.yellow("Warning: You have uncommitted changes. The sandbox clones from remote, so local changes won't be included."));const r=getGitHubToken(),o=isInternalTeamFlagPresent(),s=readLocalConfigFiles(),i=e||await askQuestion(`${de.bold("What do you want to do?")}\n${de.cyan(">")} `);if(!i.trim())return void console.error(de.yellow("No prompt provided. Aborting."));const a=i.trim().slice(0,$t.MAX_PROMPT_CHARS),l=xe({stream:process.stderr,text:"Starting sandbox session..."}).start();try{const e=await startSandboxSession({repoUrl:n.repoUrl,branch:n.branch,prompt:a,ghToken:r,isInternalTeam:o,configFiles:s});l.succeed("Sandbox started"),await streamSession({sessionId:e.sessionId,prompt:a}),process.exit(0)}catch(e){l.fail("Failed to start session");const t=e instanceof Error?e.message:"Unknown error";t.includes("401")||t.toLowerCase().includes("unauthorized")?console.error(de.red("Authentication failed. Try logging in again: cmd login")):console.error(de.red(t)),process.exit(1)}}function createSandboxCommand(){return new ke("sandbox").description("Run a task autonomously in a sandbox").argument("[prompt]","Task description").option("--id <sessionId>","Resume an existing sandbox session").enablePositionalOptions().action(async(e,t)=>{try{await sandboxMode({prompt:e,resume:t.id})}catch(e){const t=e instanceof Error?e.message:"Unknown error";console.error(de.red(t)),process.exit(1)}})}function validateSafeString(e,t){if(e.includes("..")||e.includes("\\"))throw new Error(`Invalid ${t}: path traversal sequences are not allowed.\nExpected format: owner/repo or owner/repo/path`);if(!/^[a-zA-Z0-9._/-]+$/.test(e))throw new Error(`Invalid ${t}: contains unsupported characters.\nOnly letters, numbers, hyphens, underscores, dots, and slashes are allowed.`)}function parseGitHubRepo(e){let t,n=e.replace(/^https?:\/\/github\.com\//,"");const r=n.lastIndexOf("@");r>0&&r<n.length-1&&(t=n.slice(r+1),n=n.slice(0,r),validateSafeString(t,"branch name"));const o=n.split("/");if(o.length<2)throw new Error("Invalid GitHub repository format. Expected: owner/repo or owner/repo/path");const[s,i,...a]=o;validateSafeString(s,"owner"),validateSafeString(i,"repository");const l=a.length>0?a.join("/"):void 0;return l&&validateSafeString(l,"path"),{owner:s,repo:i,path:l,branch:t}}function buildGigetSource(e){const{owner:t,repo:n,path:r,branch:o}=e;let s=`gh:${t}/${n}`;return r&&(s+=`/${r}`),o&&(s+=`#${o}`),s}async function fetchSkillFromGitHub(e){await cleanupStaleTempDirectories();const n=parseGitHubRepo(e),{owner:r,repo:o,path:s}=n;let i;if(s){const e=s.split("/").filter(Boolean);i=e[e.length-1]}else i=o;const a=t.join(w.tmpdir(),`commandcode-skill-${H()}`);await O.mkdir(a,{recursive:!0});try{const e=buildGigetSource(n),{downloadTemplate:s}=await import("giget");try{await s(e,{dir:a,force:!0,silent:!0})}catch(t){if(!isCorruptedArchiveError(t))throw t;await clearGigetCache(r,o),await s(e,{dir:a,force:!0,silent:!0})}const l=t.join(a,"SKILL.md"),u=t.join(a,"skill.md");let d=!1;try{await O.access(l),d=!0}catch{}if(!d)try{await O.access(u),d=!0}catch{}if(!d)throw new Error(`SKILL.md not found in ${e}. Make sure the repository contains a SKILL.md file.`);return{tempDir:a,skillName:i}}catch(e){if(await O.rm(a,{recursive:!0,force:!0}).catch(()=>{}),e instanceof Error&&e.message.includes("SKILL.md not found"))throw e;throw wrapFetchError(e,r,o)}}async function discoverSkillsInRepo(e,t){const n=parseGitHubRepo(e),{owner:r,repo:o,path:s,branch:i}=n,{keepTempDir:a=!1}=t||{},{discoverSkillsLocally:l}=await Promise.resolve().then(()=>(Ck(),Ek)),u=await l({owner:r,repo:o,path:s,branch:i,keepTempDir:a});if(0===u.skills.length)throw new Error(`No skills found in repository ${r}/${o}${s?` at path "${s}"`:""}. Ensure the repository contains SKILL.md files.`);return u}async function resolveSkillMdPath(e){const n=t.join(e,"SKILL.md");try{return await O.access(n),n}catch{}const r=t.join(e,"skill.md");try{return await O.access(r),r}catch{}throw new Error(`SKILL.md not found in ${e}`)}function validateSkillName(e){const t=e.trim();if(!t||0===t.length)throw new Error("Invalid skill name: name cannot be empty");if(t.includes("/")||t.includes("\\"))throw new Error(`Invalid skill name: "${e}". Skill names cannot contain path separators (/ or \\).`);if(t.includes(".."))throw new Error(`Invalid skill name: "${e}". Skill names cannot contain parent directory references (..).`);if(t.startsWith("."))throw new Error(`Invalid skill name: "${e}". Skill names cannot start with a dot.`);if(!/^[a-z0-9-]+$/.test(t))throw new Error(`Invalid skill name: "${e}". Skill names must contain only lowercase letters, numbers, and hyphens.`);return t}async function validateSkillContent(e){const t=await resolveSkillMdPath(e),n=await O.readFile(t,"utf-8"),{data:r}=Me(n),o=lh.parse(r);return{name:validateSkillName(o.name),description:o.description}}async function skillExists(e){const{skillName:n,location:r}=e,o="global"===r?getGlobalSkillsDir():getProjectSkillsDir(),s=t.join(o,n);try{return await O.access(s),!0}catch{return!1}}async function discoverSkills(e,t){return discoverSkillsInRepo(e,t)}async function installSkill(e){const{repoInput:n,options:r={}}=e,{global:o=!1,force:s=!1,skillName:i,discoveredSkill:a,cachedTempDir:l}=r;let u,d,m=n;if(i){let e;if(a)e=a;else{const t=await discoverSkillsInRepo(n);if(0===t.skills.length)throw new Error(`No skills found in repository: ${n}`);const r=t.skills.find(e=>e.name.toLowerCase()===i.toLowerCase());if(!r){const e=t.skills.map(e=>e.name).join(", ");throw new Error(`Skill "${i}" not found in repository. Available skills: ${e}`)}e=r}const t=parseGitHubRepo(n),r=[t.path,e.path&&"."!==e.path?e.path:void 0].filter(Boolean).join("/"),o=r?`${t.owner}/${t.repo}/${r}`:`${t.owner}/${t.repo}`;m=t.branch?`${o}@${t.branch}`:o}if(l&&a){u=a.path&&"."!==a.path?t.join(l,a.path):l,d=!1;try{await resolveSkillMdPath(u)}catch{const e=a.path&&"."!==a.path?`at ${a.path}`:"at root";throw new Error(`SKILL.md not found in cached directory ${e}. Make sure the repository contains a SKILL.md file.`)}}else u=(await fetchSkillFromGitHub(m)).tempDir,d=!0;try{const{name:e,description:n}=await validateSkillContent(u),r=e,i=o?"global":"project",a="global"===i?getGlobalSkillsDir():getProjectSkillsDir(),l=await skillExists({skillName:r,location:i});if(l&&!s)throw new Error(`Skill "${r}" already exists in ${"global"===i?"~/.commandcode/skills/":".commandcode/skills/"}. Use --force to overwrite.`);await O.mkdir(a,{recursive:!0});const d=t.join(a,r),{randomUUID:m}=await import("crypto"),g=t.join(a,`.${r}.tmp.${m()}`);try{await O.cp(u,g,{recursive:!0,force:!0,dereference:!1}),l&&s&&await O.rm(d,{recursive:!0,force:!0}),await O.rename(g,d)}catch(e){if(await O.rm(g,{recursive:!0,force:!0}).catch(()=>{}),e instanceof Error&&"code"in e&&("EEXIST"===e.code||"ENOTEMPTY"===e.code))throw new Error(`Skill "${r}" was created by another process during installation. Use --force to overwrite.`);throw e}let h;try{h=await resolveSkillMdPath(d)}catch{h=t.join(d,"SKILL.md")}return{name:r,description:n,location:i,path:h}}finally{d&&await O.rm(u,{recursive:!0,force:!0}).catch(()=>{})}}async function removeSkill(e){const{global:n=!1}=e,r=validateSkillName(e.skillName),o=n?"global":"project",s="global"===o?getGlobalSkillsDir():getProjectSkillsDir(),i=t.join(s,r);if(!await skillExists({skillName:r,location:o}))throw new Error(`Skill "${r}" not found in ${"global"===o?"global (~/.commandcode/skills/)":"project (.commandcode/skills/)"} skills.${"global"===o?"":" Use -g/--global to check global skills."}`);await O.rm(i,{recursive:!0,force:!0})}async function listSkills(){const{global:e,project:t}=await loadAllSkillSummaries();return{global:e.map(e=>({name:e.name,description:e.description,location:"global",path:e.filePath})),project:t.map(e=>({name:e.name,description:e.description,location:"project",path:e.filePath}))}}__name(stopAllSpinners,"stopAllSpinners"),__name(renderStatusEvent,"renderStatusEvent"),__name(renderEvent,"renderEvent"),__name(setupInputHandling,"setupInputHandling"),__name(setupResizeForwarding,"setupResizeForwarding"),__name(sendTerminalSize,"sendTerminalSize"),__name(streamSession,"streamSession"),__name(readLocalConfigFiles,"readLocalConfigFiles"),__name(askQuestion,"askQuestion"),__name(startSandboxSession,"startSandboxSession"),__name(sandboxMode,"sandboxMode"),__name(createSandboxCommand,"createSandboxCommand"),Pr(),Ht(),Ht(),Ht(),Ht(),bk(),__name(validateSafeString,"validateSafeString"),__name(parseGitHubRepo,"parseGitHubRepo"),__name(buildGigetSource,"buildGigetSource"),__name(fetchSkillFromGitHub,"fetchSkillFromGitHub"),__name(discoverSkillsInRepo,"discoverSkillsInRepo"),bw(),vh(),__name(resolveSkillMdPath,"resolveSkillMdPath"),__name(validateSkillName,"validateSkillName"),__name(validateSkillContent,"validateSkillContent"),__name(skillExists,"skillExists"),__name(discoverSkills,"discoverSkills"),__name(installSkill,"installSkill"),__name(removeSkill,"removeSkill"),__name(listSkills,"listSkills"),Yt();var cI=[`${de.dim("Usage:")}`,` ${de.cyan("cmd skills add")} ${de.white("<owner/repo>")}`,"",`${de.dim("Examples:")}`,` ${de.cyan("cmd skills add")} ${de.white("acme/my-skills")} ${de.dim("# single-skill repo")}`,` ${de.cyan("cmd skills add")} ${de.white("acme/skills/path/to/skill")} ${de.dim("# specific path in repo")}`,` ${de.cyan("cmd skills add")} ${de.white("acme/multi-skills -s my-skill")} ${de.dim("# pick one from multi-skill repo")}`,` ${de.cyan("cmd skills add")} ${de.white("acme/repo@branch")} ${de.dim("# specific branch")}`,` ${de.cyan("cmd skills add")} ${de.white("acme/repo --global")} ${de.dim("# install to ~/.commandcode/skills/")}`],uI=__name((e,t)=>`${de.green(_e.tick)} Installed ${de.cyan(e)} ${de.dim(`${_e.arrowRight} ${t}/`)}`,"formatInstalled"),dI=__name(e=>`${de.red(_e.cross)} ${e}`,"formatError");async function cleanupAndExit(e,t){e&&await F(e,{recursive:!0,force:!0}).catch(()=>{}),process.exit(t)}function validateRepoFormat(e){(e.startsWith(".")||e.startsWith("/")||e.startsWith("~"))&&(console.error(dI("Local paths are not supported. Skills must be installed from GitHub.")),console.log(""),cI.forEach(e=>console.log(e)),process.exit(1));const t=e.replace(/^https?:\/\/github\.com\//,""),n=t.lastIndexOf("@");(n>0?t.slice(0,n):t).split("/").filter(Boolean).length<2&&(console.error(dI(`Invalid repository: "${e}"`)),console.log(""),console.log(`Expected format: ${de.cyan("owner/repo")} or ${de.cyan("owner/repo/path")}`),console.log(""),cI.forEach(e=>console.log(e)),process.exit(1))}async function addAction(e,t){const n=process.stdout.isTTY&&process.stdin.isTTY,r=t.global?"~/.commandcode/skills":".commandcode/skills";let o;validateRepoFormat(e);const s=xe({text:`Fetching ${de.cyan(e)}...`,color:"cyan"});try{let i=[];s.start();const a=await discoverSkills(e,{keepTempDir:!0}),{skills:l,tempDir:u}=a;if(o=u,s.stop(),0===l.length&&(console.error(dI(`No skills found in ${de.cyan(e)}`)),console.log(de.dim("The repository must contain at least one SKILL.md file.")),await cleanupAndExit(o,1)),t.skill){const n=l.find(e=>e.name.toLowerCase()===t.skill.toLowerCase());n||(console.error(dI(`Skill "${t.skill}" not found in ${de.cyan(e)}`)),console.log(""),console.log(de.dim("Available skills:")),l.forEach(e=>console.log(` ${de.cyan(e.name)}`)),await cleanupAndExit(o,1)),i=[n]}else if(1===l.length)i=[l[0]];else if(n){const t=await Be({message:`Select skills to install from ${e}`,options:l.map(e=>({value:e.name,label:e.name})),required:!0});"symbol"==typeof t&&(console.log(de.dim("Cancelled")),await cleanupAndExit(o,0));const n=t;i=l.filter(e=>n.includes(e.name))}else i=l;let d=0;for(const n of i)try{const s=xe({text:`Installing ${de.cyan(n.name)}...`,color:"cyan"});s.start();const i=await installSkill({repoInput:e,options:{global:t.global,force:t.force,skillName:n.name,discoveredSkill:n,cachedTempDir:o}});s.stop(),console.log(uI(i.name,r))}catch(e){d++;const t=e instanceof Error?e.message:String(e);console.error(dI(`Failed to install "${n.name}"`)),console.log(de.dim(` ${t}`))}await cleanupAndExit(o,d>0?1:0)}catch(e){s.stop();const t=e instanceof Error?e.message:String(e);console.error(dI(t)),await cleanupAndExit(o,1)}}__name(cleanupAndExit,"cleanupAndExit"),__name(validateRepoFormat,"validateRepoFormat"),__name(addAction,"addAction");var mI=new ke("add").description("Install a skill from a GitHub repository").argument("<repo>","GitHub repository (owner/repo or owner/repo/path)").option("-g, --global","Install to global skills (~/.commandcode/skills/)").option("-f, --force","Overwrite if skill already exists").option("-s, --skill <name>","Specific skill name to install from repo").addHelpText("after",`\n${cI.join("\n")}`).configureOutput({outputError:__name((e,t)=>{e.includes("missing required argument")?(console.error(dI("No repository specified.")),console.log(""),cI.forEach(e=>console.log(e))):t(e)},"outputError")}).action(addAction);Ht(),Yt();var pI=__name((e,t)=>`${de.green(_e.tick)} Removed ${de.cyan(e)} from ${t} skills`,"formatRemoved"),gI=__name(e=>`${de.red(_e.cross)} ${e}`,"formatError");function validateSkillNameEarly(e){return e.includes("/")||e.includes("\\")?`"${e}" is not a valid skill name — it cannot contain path separators.`:e.includes("..")?`"${e}" is not a valid skill name — it cannot contain "..".`:e.startsWith(".")?`"${e}" is not a valid skill name — it cannot start with a dot.`:/^[a-z0-9-]+$/.test(e.trim())?null:`"${e}" is not a valid skill name — use only lowercase letters, numbers, and hyphens.`}async function removeAction(e,t){try{const n=process.stdout.isTTY&&process.stdin.isTTY,r=t.global?"global":"project",o=validateSkillNameEarly(e);if(o&&(console.error(gI(o)),console.log(de.dim(`Run ${de.cyan("cmd skills list")} to see installed skills.`)),process.exit(1)),!t.yes&&n){const t=await Ue({message:`Remove ${de.cyan(e)} from ${r} skills?`});"symbol"!=typeof t&&t||(console.log(de.dim("Cancelled")),process.exit(0))}await removeSkill({skillName:e,global:t.global}),console.log(pI(e,r)),process.exit(0)}catch(n){const r=n instanceof Error?n.message:"Failed to remove skill";r.includes("not found")?(console.error(gI(`Skill "${e}" not found in ${t.global?"global":"project"} skills`)),t.global||console.log(de.dim(`Try ${de.cyan(`cmd skills remove ${e} --global`)} to check global skills.`)),console.log(de.dim(`Run ${de.cyan("cmd skills list")} to see installed skills.`))):console.error(gI(r)),process.exit(1)}}__name(validateSkillNameEarly,"validateSkillNameEarly"),__name(removeAction,"removeAction");var hI=new ke("remove").description("Remove an installed skill").argument("<skill-name>","Name of the skill to remove").option("-g, --global","Remove from global skills (~/.commandcode/skills/)").option("-y, --yes","Skip confirmation prompt").action(removeAction);Ht(),bw(),Wv(),Yt();var fI=__name((e,t)=>{const n=t.length>60?t.substring(0,57)+"...":t;return` ${de.cyan(e)} ${de.dim(`· ${n}`)}`},"formatSkillLine"),yI=__name((e,t)=>`${de.bold(de.white(e))} ${de.dim(`(${t})`)}`,"formatSectionHeader"),wI=__name(()=>["",de.dim("No skills installed."),"",de.dim("Looking in:"),de.dim(` ${getGlobalSkillsDir()} ${de.white("(global)")}`),de.dim(` ${getProjectSkillsDir()} ${de.white("(project)")}`),de.dim(` ${getGlobalAgentsCompatSkillsDir()} ${de.white("(global, .agents)")}`),de.dim(` ${getProjectAgentsCompatSkillsDir()} ${de.white("(project, .agents)")}`),"",`Install a skill: ${de.cyan("cmd skills add")} ${de.dim("<owner/repo>")}`,""],"formatEmptyHint"),SI=__name(e=>{e.forEach(e=>console.log(e))},"printLines");async function listAction(){try{const{global:e,project:t}=await listSkills(),n=e.length+t.length;0===n&&(SI(wI()),process.exit(0)),console.log(""),console.log(heading({text:"Skills",sub:de.dim(`${n} installed`)})),t.length>0&&(console.log(""),console.log(yI("Project",t.length)),t.forEach(e=>{console.log(fI(e.name,e.description))})),e.length>0&&(console.log(""),console.log(yI("Global",e.length)),e.forEach(e=>{console.log(fI(e.name,e.description))})),console.log(""),process.exit(0)}catch(e){const t=e instanceof Error?e.message:"Unknown error";console.error(`${de.red(_e.cross)} Failed to list skills: ${t}`),process.exit(1)}}__name(listAction,"listAction");var bI=new ke("list").description("List all installed skills").action(listAction),EI=new ke("skills").description("Manage skills from GitHub repositories").addCommand(mI).addCommand(hI).addCommand(bI);handleUnhandledErrors(),setupTelemetry(),await preRun();var CI=createProgram();CI.action(interactiveModeAction),CI.addCommand(tP),CI.addCommand(nP),CI.addCommand(iI),CI.addCommand(KP),CI.addCommand(eP),CI.addCommand(createTasteCommand()),CI.addCommand(createMcpCommand()),CI.addCommand(rP),CI.addCommand(Io),CI.addCommand(tk),CI.addCommand(uk),CI.addCommand(EI),isExperimentalEnabled()&&CI.addCommand(createSandboxCommand()),setupCommanderHooks(CI),CI.parse();