command-code 0.32.5 → 0.33.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 +1 -1
- package/package.json +1 -1
- package/vsix/commandcode-vscode.vsix +0 -0
package/dist/index.mjs
CHANGED
|
@@ -321,4 +321,4 @@ import*as e from"path";import t,{join as n,dirname as r,parse as o,relative as s
|
|
|
321
321
|
░█▀▀░█▀▄▀█░█▀▄░
|
|
322
322
|
░█░░░█░▀░█░█░█░
|
|
323
323
|
░▀▀▀░▀░░░▀░▀▀░░
|
|
324
|
-
`,Zx=getMaxLineWidth(Xx),eA=Kx,tA=__name(e=>{const t=e??getTerminalWidth();return t>=Qx?"full":t>=eA?"compact":"minimal"},"getHeaderLayout");Ft(),Or();var nA=__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?$r.BG:$r.TEXT},e.text)))},"CommandLogoBanner");Ft(),Or();var rA=__name(({title:e,hashPrefix:t=!1,subPrefix:n=!1,suffix:r,padding:o=0,titleColor:s=mr.GRAY,dividerChar:i="─",dividerColor:a=mr.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:mr.DIM},g))},"Divider");qE(),Or(),Ft(),Or();var oA=[{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}],sA=__name(({onComplete:e,onExit:t})=>{const[n,r]=J(0),[o,s]=J(!1),i=n>=oA.length;return Z(()=>{if(n>=oA.length)return;if(o)return;const e=oA[n],t=setTimeout(()=>{r(e=>Math.min(e+1,oA.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,oA.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:mr.DIM},"Command Code learns your coding style as you work.")),K.createElement(ne,null,K.createElement(re,{color:mr.DIM},"Here's how your preferences evolve in real-time:")),K.createElement(ne,{flexDirection:"column",marginY:1},oA.slice(0,n).map((e,t)=>"user"===e.type?K.createElement(ne,{key:t},K.createElement(re,null,Ie.pointer," ",e.text)):K.createElement(ne,{key:t,flexDirection:"column",marginBottom:1,marginLeft:1},K.createElement(ne,null,K.createElement(re,{color:mr.DIM},"⎿ "),K.createElement(re,{color:gr.TEXT},e.text)),e.details&&K.createElement(ne,{marginLeft:3},K.createElement(re,{color:mr.DIM},"Saved(",e.details,")"))))),i?K.createElement(ne,{flexDirection:"column",marginY:1},K.createElement(ne,null,K.createElement(re,{bold:!0,color:gr.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:mr.DIM},"Press Enter to get started →"))):K.createElement(ne,null,K.createElement(re,{color:mr.DIM},"[SPACE: pause] [ENTER: next] [ESC: skip]"+(o?" (paused)":""))))},"TasteDemoComponent"),iA=__name(({onClose:e,onExit:t})=>{const[n,r]=J(xT.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(xT.getEvents())},"handleNewEvent"),t=__name(()=>{r([])},"handleCleared");return xT.on("new-event",e),xT.on("cleared",t),()=>{xT.off("new-event",e),xT.off("cleared",t)}},[]),Z(()=>{const e=__name(()=>{UE(),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=ee(()=>n.find(e=>"analyzing"===e.type),[n]),l=ee(()=>n.find(e=>"analyzed"===e.type),[n]),u=ee(()=>n.find(e=>"no_learnings"===e.type),[n]),d=ee(()=>n.find(e=>"learned"===e.type||"refactored"===e.type),[n]),m=u?n.indexOf(u):1/0,g=d?n.indexOf(d):1/0,h=!!u&&m<g,f=!!a||!!l||h,y=ee(()=>n.filter(e=>"analyzing"!==e.type&&"analyzed"!==e.type&&"no_learnings"!==e.type),[n]),w=ee(()=>[...y].reverse(),[y]),S=__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"),E=__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"),v=__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"),C=ee(()=>(process.stdout.rows??24)-1,[o]);return K.createElement(ne,{flexDirection:"column",width:"100%",height:C,justifyContent:"flex-start",alignItems:"flex-start",padding:0,margin:0},K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(nA,null,Yx())),K.createElement(rA,{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:mr.DIM},"Your preferences, patterns, and style will appear here in real-time."))),K.createElement(ce,{count:2}),K.createElement(rA,{title:"DEMO",titleColor:"white",subPrefix:!0}),K.createElement(sA,{onComplete:()=>{e()},onExit:t})):K.createElement(ne,{flexDirection:"column"},y.length>0&&K.createElement(ne,{flexDirection:"column",gap:1},w.map(e=>{if(i(e.type)){const{type:t,label:n,content:r,confidence:o}=S(e.message),s="moved"===t?v(e.details):null,i="upgraded"===t||"downgraded"===t?E(r):null,a=s?.fullPath??e.details;let l=K.createElement(K.Fragment,null,K.createElement(re,null," ",r),o&&K.createElement(re,{color:mr.DIM}," ","(",o,")"));return i&&(l=K.createElement(K.Fragment,null,K.createElement(re,null," ",i.text," ("),K.createElement(re,{color:mr.DIM},"confidence:"," "),K.createElement(re,{color:mr.DIM},i.oldPercent,"%"),K.createElement(re,null," ",Ie.arrowRight," "),K.createElement(re,{color:i.diff>0?mr.GREEN:mr.RED},i.newPercent,"%"),K.createElement(re,null,")"))),s&&(l=K.createElement(K.Fragment,null,K.createElement(re,null," ",s.category," ","package ("),K.createElement(re,{color:mr.DIM},s.oldPath),K.createElement(re,null," ",Ie.arrowRight," ",s.newPath),K.createElement(re,null,")"))),K.createElement(ne,{key:e.id},K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:gr.BADGE_BG,color:gr.BADGE_FG,bold:!0},`${ZT}${n}${ZT}`)),a&&K.createElement(re,{color:mr.DIM}," ","(",a,")")),K.createElement(ne,{marginLeft:1},K.createElement(re,{color:mr.DIM},"⎿"," "),l)))}return K.createElement(ne,{key:e.id},K.createElement(re,{color:mr.DIM},Ie.pointerSmall," ",e.message))})),f&&K.createElement(ne,{flexDirection:"column",marginTop:y.length>0?1:0},a&&K.createElement(ne,null,K.createElement(re,{color:mr.DIM},Ie.pointerSmall," ",a.message)),l&&K.createElement(ne,null,K.createElement(re,{color:mr.DIM},Ie.pointerSmall," ",l.message)),h&&u&&K.createElement(ne,null,K.createElement(re,{color:mr.DIM},Ie.pointerSmall," ",u.message))))))},"LearningFeedFull");function LearningView({setShowLearningFeed:e,setStaticKey:t,onExit:n}){return K.createElement(iA,{onClose:()=>{UE(),e(!1),t(e=>e+1)},onExit:n})}__name(LearningView,"LearningView"),Ft(),Or(),Ft(),Or(),qE(),so();var aA=__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?(UE(),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:mr.BLUE,padding:1,flexDirection:"column"},K.createElement(re,{color:mr.BLUE,bold:!0},"Taste Settings"),K.createElement(re,{color:mr.DIM},"Loading configuration...")):K.createElement(ne,{key:n,borderStyle:"single",borderColor:mr.GRAY,padding:1,flexDirection:"column"},K.createElement(re,{bold:!0},"Taste Learning"),K.createElement(re,{color:mr.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:mr.DIM}," ","- Learn from your interactions")),K.createElement(re,{color:r?mr.GREEN:mr.GRAY},r?"enabled":"disabled")),K.createElement(ne,{marginTop:1}),K.createElement(re,{color:mr.DIM},"Taste data stored in .commandcode/taste/taste.md"),K.createElement(re,{color:mr.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(_x,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.DIM},"Press Esc to return to conversation")),K.createElement(aA,{onClose:()=>t(!1),onSettingsChange:n,staticKey:e})))}function fuzzyMatch(e,t){let n=0;for(const r of e)if(r===t[n]&&(n++,n===t.length))return!0;return!1}function fuzzyScore(e,t){let n=0;for(const r of e)fuzzyMatch(r.text.toLowerCase(),t)&&(n+=r.weight);return n}function fuzzyFilter(e,t,n){if(!t.trim())return e;const r=t.toLowerCase().split("");return e.map(e=>({item:e,score:fuzzyScore(n(e),r)})).filter(({score:e})=>e>0).sort((e,t)=>t.score-e.score).map(({item:e})=>e)}__name(TasteConfigView,"TasteConfigView"),Ft(),Ft(),Cn(),Ft(),__name(fuzzyMatch,"fuzzyMatch"),__name(fuzzyScore,"fuzzyScore"),__name(fuzzyFilter,"fuzzyFilter"),qE(),Or(),Ft(),Or();var lA=__name(({query:e,resultCount:t,placeholder:n="Type to search..."})=>K.createElement(ne,{width:"100%"},K.createElement(re,{color:mr.GRAY},Ie.pointerSmall," "),K.createElement(re,{color:e?mr.WHITE:mr.GRAY},e||n),e&&void 0!==t&&K.createElement(re,{dimColor:!0}," (",t," found)")),"SearchInput");function useListNavigation({items:e,onSelect:t,onCancel:n,validate:r,initialIndex:o=0,searchCursorIndex:s=0,searchQuery:i,onSearchChange:a,isActive:l=!0,disableSearch:u=!1,onReset:d}){const[m,g]=J(o),[h,f]=J(null);Z(()=>{i||g(o)},[o,i]);const y=e.length-1,w=__name(e=>{a(e),g(s)},"updateSearch");return ie((o,s)=>{if(s.escape)return!u&&i?void w(""):void n();if(u||!s.backspace&&!s.delete){if(u&&d&&"r"===o&&!s.ctrl&&!s.meta){const t=e[m];return void(t&&d(t))}if(0!==e.length){if(s.upArrow)return f(null),void g(e=>e>0?e-1:y);if(s.downArrow)return f(null),void g(e=>e<y?e+1:0);if(s.return){const n=e[m];if(!n)return;if(r){const e=r(n);if(e)return void f(e)}return void t(n)}!u&&!s.ctrl&&!s.meta&&!s.tab&&o&&1===o.length&&o>=" "&&w(i+o)}}else w(i.slice(0,-1))},{isActive:l}),{cursor:m,error:h,setError:f}}function skillIdentifier(e){const n=t.basename(e);return"skill.md"===n.toLowerCase()?t.basename(t.dirname(e)):n}Ft(),__name(useListNavigation,"useListNavigation"),Ft(),Cn(),Or(),Ft(),qE(),Or(),io(),Ft(),__name(skillIdentifier,"skillIdentifier");var cA=new Set(["Invalid YAML","Missing fields","Missing SKILL.md"]);function categoryColor(e){return cA.has(e)?mr.RED:mr.YELLOW}function formatWarningsAsMarkdown(e){const t=groupWarnings(e),n=[`# Skipped skills (${e.length})`,""];for(const e of t){n.push(`## ${e.category} (${e.items.length})`,"");for(const t of e.items)n.push(`- \`${skillIdentifier(t.path)}\` — \`${t.path}\``),n.push(` - ${t.reason}`);n.push("")}return n.join("\n").replace(/\n+$/,"")+"\n"}async function copyAllWarnings(e,t){try{const{isClipboardAvailable:n}=await Promise.resolve().then(()=>(Hr(),Wr));if(!n())return void t({text:"Clipboard unavailable — copy the skipped skill paths manually",color:mr.YELLOW});const r=await import("@crosscopy/clipboard");await r.default.setText(formatWarningsAsMarkdown(e));const o=e.length;t({text:`Copied ${o} issue${1===o?"":"s"} to clipboard`,color:mr.GREEN})}catch{t({text:"Clipboard write failed",color:mr.YELLOW})}}__name(categoryColor,"categoryColor"),__name(formatWarningsAsMarkdown,"formatWarningsAsMarkdown"),__name(copyAllWarnings,"copyAllWarnings");var uA=__name(({warnings:e,onClose:t,isActive:n=!0})=>{const r=groupWarnings(e),o=e.length>0,[s,i]=J(null),a=X(null),l=X(!0);Z(()=>()=>{l.current=!1,a.current&&(clearTimeout(a.current),a.current=null)},[]);const u=__name(e=>{l.current&&(a.current&&clearTimeout(a.current),i(e),a.current=setTimeout(()=>{l.current&&(i(null),a.current=null)},3e3))},"showStatus");return ie((n,r)=>r.escape||" "===n&&o?(UE(),void t()):void("c"===n&&o&©AllWarnings(e,u)),{isActive:n}),K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:pr,bold:!0},"Skills"," "),K.createElement(re,{color:mr.DIM},"› "),K.createElement(re,{color:pr,bold:!0},"Skipped"," "),K.createElement(re,{color:mr.WHITE},e.length)),o&&K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.DIM},"Press c to copy all issues")),o?K.createElement(ne,{flexDirection:"column"},r.map(e=>K.createElement(ne,{key:e.category,flexDirection:"column"},K.createElement(ne,null,K.createElement(re,{color:categoryColor(e.category)},e.category)),e.items.map(e=>K.createElement(ne,{key:e.path,flexDirection:"column",marginBottom:1},K.createElement(ne,{paddingLeft:2},K.createElement(ro,{url:m(e.path).href,text:skillIdentifier(e.path),color:mr.WHITE})),K.createElement(ne,{paddingLeft:4},K.createElement(re,{color:mr.WHITE},e.reason))))))):K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"No issues — every skill loaded.")),s&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:s.color},s.text)),K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(re,{color:mr.DIM},o?"c copy all issues · esc back to skills":"esc back to skills")))},"SkillsConfigIssues"),dA=__name(({warnings:e=[],onClose:t})=>{const[n,r]=J("list");return ie((o,s)=>{"list"===n&&(s.escape&&t?t():" "===o&&!s.ctrl&&!s.meta&&e.length>0&&r("issues"))},{isActive:"list"===n}),"issues"===n?K.createElement(uA,{warnings:e,onClose:()=>r("list"),isActive:!0}):K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:pr,bold:!0},"Skills"),e.length>0&&K.createElement(K.Fragment,null,K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{color:mr.YELLOW},e.length," skipped"))),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.DIM},"No skills found")),K.createElement(re,{color:mr.DIM},"Create skills in:"),K.createElement(re,{color:mr.DIM}," ","~/",".commandcode","/","skills","/ (user)"),K.createElement(re,{color:mr.DIM}," ","~/.agents/","skills","/ (user, .agents)"),K.createElement(re,{color:mr.DIM}," ",".commandcode","/","skills","/ (project)"),K.createElement(re,{color:mr.DIM}," ",".agents/","skills","/ (project, .agents)"),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},e.length>0&&"space to view issues · ","Press ",K.createElement(re,{bold:!0},"Esc")," to close")))},"SkillsConfigEmpty");Ft();var mA=__name(e=>Math.ceil(e.length/4),"estimateTokens"),pA=__name(e=>e.includes("/.agents/skills/")||e.includes("\\.agents\\skills\\"),"isAgentsSkill"),gA={user:"user settings",projectShared:"project shared",projectLocal:"project local"},hA=__name(()=>"win32"===process.platform?'No editor found. Set $EDITOR: setx EDITOR "code"':"No editor found. Set $EDITOR: echo 'export EDITOR=\"code\"' >> "+("darwin"===process.platform?"~/.zshrc":"~/.bashrc"),"getEditorSetupMessage");Ft(),Or();var fA=__name(({title:e,subtitle:t,skills:n,baseIndex:r,cursor:o,disabled:s})=>K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(ne,null,K.createElement(re,{color:Cr,bold:!0},e," "),K.createElement(re,{color:Cr},t)),n.map((e,t)=>{const n=r+t===o,i=s.has(e.label),a=pA(e.filePath);return K.createElement(ne,{key:e.filePath},K.createElement(re,{color:mr.GREEN},n?"▸ ":" "),K.createElement(re,{color:i?mr.DIM:mr.GREEN},i?"[off] ":"[on] "),K.createElement(re,{color:i?mr.DIM:mr.WHITE},e.label),a&&K.createElement(re,{color:mr.DIM}," [.agents]"),K.createElement(re,{color:mr.DIM}," · ~",mA(e.description)," tokens"))})),"SkillSection");Ft();var yA=__name(e=>[{text:e.label,weight:100}],"SKILL_SEARCH_FIELDS"),wA=__name(({onClose:e})=>{const[t,n]=J([]),[r,o]=J([]),[s,i]=J(!0),[a,l]=J(null),[u,d]=J(""),[m,g]=J(new Set),[h,f]=J(new Map),[y,w]=J(!1),[S,E]=J(null),[v,C]=J("list"),k=X(!1);Z(()=>{__name(async()=>{try{const e=findGitRoot(),t=getBundledSkillsDir(),[{global:r,project:s,warnings:i},a]=await Promise.all([loadAllSkillSummariesWithWarnings(),loadDisabledSkills({projectRoot:e})]),l=__name(e=>isBundledSkillPath({filePath:e,bundledDir:t}),"isBundled"),u=[...s.map(e=>({label:e.name,location:"project",description:e.description,filePath:e.filePath})),...r.filter(e=>!l(e.filePath)).map(e=>({label:e.name,location:"user",description:e.description,filePath:e.filePath})),...r.filter(e=>l(e.filePath)).map(e=>({label:e.name,location:"bundled",description:e.description,filePath:e.filePath}))];u.sort((e,t)=>{if(e.location!==t.location){const n={project:0,user:1,bundled:2};return n[e.location]-n[t.location]}return e.label.localeCompare(t.label)}),n(u),o(i),g(new Set(a.names)),f(new Map(a.bySkill)),w(a.noProjectRoot)}catch(e){l(e instanceof Error?e.message:"Failed to load skills")}finally{i(!1)}},"load")()},[]);const T=ee(()=>fuzzyFilter(t.filter(e=>"project"===e.location),u,yA),[t,u]),_=ee(()=>fuzzyFilter(t.filter(e=>"user"===e.location),u,yA),[t,u]),x=ee(()=>fuzzyFilter(t.filter(e=>"bundled"===e.location),u,yA),[t,u]),A=ee(()=>[...T,..._,...x],[T,_,x]),P=__name(async e=>{if(k.current)return;const t=m.has(e.label),n=h.get(e.label);if(t&&void 0!==n&&"projectLocal"!==n&&!y)return void E(`Cannot enable: "${e.label}" is disabled in ${gA[n]}. Edit that file to override.`);k.current=!0;const r=new Set(m);t&&r.delete(e.label),t||r.add(e.label),g(r),E(null);try{const n=findGitRoot(),r=await setSkillEnabled(e.label,t,{projectRoot:n}),o=new Map(h);t&&o.delete(e.label),t||o.set(e.label,r),f(o),"user"===r&&E("Saved to user settings — no project found.")}catch(e){g(m),E(`Failed to save: ${e instanceof Error?e.message:String(e)}`)}finally{k.current=!1}},"toggleSkill");Z(()=>{"issues"===v&&d("")},[v]);const I="list"===v&&t.length>0,{cursor:M}=useListNavigation({items:A,onSelect:P,onCancel:__name(()=>{UE(),e()},"onCancel"),searchQuery:u,onSearchChange:d,initialIndex:0,isActive:I});if(ie((t,n)=>{if(!n.tab)return;const r=A[M];r&&(async()=>{try{await wt([{file:r.filePath,line:1}]),UE(),e()}catch(e){if(e instanceof Error&&e.message.includes("$EDITOR environment variable"))return void l(hA());l(e instanceof Error?e.message:"Failed to open skill in editor")}})()},{isActive:I}),ie((e,n)=>{"list"===v&&0!==t.length&&" "===e&&!n.ctrl&&!n.meta&&r.length>0&&0===u.length&&C("issues")},{isActive:"list"===v&&t.length>0}),s)return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(re,{color:pr,bold:!0},"Skills"),K.createElement(re,{color:mr.DIM},"Loading skills..."));if(a)return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(re,{color:mr.RED,bold:!0},"Skills"),K.createElement(re,{color:mr.DIM},a),K.createElement(ne,{marginTop:1}),K.createElement(re,{color:mr.DIM},"Press ",K.createElement(re,{bold:!0},"Esc")," to close"));if(0===t.length)return K.createElement(dA,{warnings:r,onClose:()=>{UE(),e()}});if("issues"===v)return K.createElement(uA,{warnings:r,onClose:()=>C("list"),isActive:!0});const N=t.filter(e=>m.has(e.label)).length;return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:pr,bold:!0},"Skills"," "),K.createElement(re,{color:mr.DIM},t.length," skill",1===t.length?"":"s"),N>0&&K.createElement(K.Fragment,null,K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{color:mr.YELLOW},N," off")),r.length>0&&K.createElement(K.Fragment,null,K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{color:mr.YELLOW},r.length," skipped"))),K.createElement(ne,{marginBottom:1},K.createElement(re,{dimColor:!0},y?"No project found — toggles will be saved to user settings.":"Toggle skills on or off for this project.")),K.createElement(ne,{marginBottom:1,flexDirection:"column",width:"100%"},K.createElement(lA,{query:u,resultCount:u?A.length:void 0,placeholder:"Type to search skills..."})),0===A.length?K.createElement(ne,{marginY:1},K.createElement(re,{color:mr.GRAY},'No skills match "',u,'"')):K.createElement(K.Fragment,null,T.length>0&&K.createElement(fA,{title:"Project skills",subtitle:"(.commandcode/skills or .agents/skills)",skills:T,baseIndex:0,cursor:M,disabled:m}),_.length>0&&K.createElement(fA,{title:"User skills",subtitle:"(~/.commandcode/skills or ~/.agents/skills)",skills:_,baseIndex:T.length,cursor:M,disabled:m}),x.length>0&&K.createElement(fA,{title:"Bundled skills",subtitle:"(ships with Command Code)",skills:x,baseIndex:T.length+_.length,cursor:M,disabled:m})),S&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.YELLOW},S)),K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(re,{color:mr.DIM},"type to search · ↑/↓ navigate · enter to toggle · tab to edit",r.length>0&&!u&&K.createElement(K.Fragment,null," · space to view issues"),u?" · esc to clear":" · esc to close"),K.createElement(re,{color:mr.DIM},"add skills:"," ",K.createElement(re,{color:mr.CYAN},"cmd skills add ","<owner/repo>"))))},"SkillsConfig");function SkillsConfigView({staticKey:e,setShowSkillsConfig:t}){return K.createElement(K.Fragment,null,K.createElement(_x,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(wA,{onClose:()=>t(!1),staticKey:e})))}function getUsageColor(e){return e>=80?mr.RED:e>=50?mr.YELLOW:mr.GREEN}function buildBlockBar({percentage:e,width:t}){const n=Math.max(0,Math.min(100,e));let r=Math.round(n/100*t);n>.5&&0===r&&(r=1),n<99.5&&r===t&&(r=t-1);const o=t-r;return{filled:"█".repeat(r),empty:"░".repeat(o)}}function getStudioUsageUrl(e){const t=e?.org?.login??e?.user?.userName;return t?`https://commandcode.ai/${t}/settings/usage`:null}__name(SkillsConfigView,"SkillsConfigView"),Ft(),Ft(),no(),qE(),Or(),Ft(),Or(),__name(getUsageColor,"getUsageColor"),__name(buildBlockBar,"buildBlockBar"),io(),__name(getStudioUsageUrl,"getStudioUsageUrl");var SA=__name(e=>e.replace(/^https?:\/\//,""),"stripScheme");function getProgressBarWidth({terminalWidth:e}){return e<50?Math.max(10,e-10):e<70?Math.max(15,e-15):Math.min(30,e-15)}function getDaysColor(e){if(null!==e)return e<3?mr.RED:e<7?mr.YELLOW:void 0}__name(getProgressBarWidth,"getProgressBarWidth"),__name(getDaysColor,"getDaysColor");var bA=__name(({plan:e,status:t})=>K.createElement(ne,{marginBottom:0},K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:mr.BLUE,color:"#f4f4f4",bold:!0},`${ZT}USAGE${ZT}`)),e&&K.createElement(K.Fragment,null,K.createElement(re,null," "),K.createElement(re,{color:mr.GRAY},`${e.name} Plan`)),t&&K.createElement(K.Fragment,null,K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{color:"active"===t?mr.GREEN:mr.YELLOW},t))),"UsageBadge"),EA=__name(({showRetry:e})=>K.createElement(ne,{marginTop:1},e&&K.createElement(re,{color:mr.DIM},K.createElement(re,{bold:!0},"r")," to retry · "),K.createElement(re,{color:mr.DIM},"Press ",K.createElement(re,{bold:!0},"Esc")," to close")),"UsageFooter"),vA=__name(({models:e,grandTotal:t})=>{if(0===e.length)return null;const n=e.map(e=>({...e,displayName:getModelDisplayName(e.model),costLabel:formatCredits(e.totalCost)})),r=Math.max(...n.map(e=>e.displayName.length)),o=Math.min(24,Math.max(10,r)),s=Math.max(...n.map(e=>e.costLabel.length)),i=Math.max(8,s+2);return K.createElement(ne,{flexDirection:"column",marginTop:1},n.map(({model:e,displayName:n,costLabel:r,totalCost:s})=>{const a=t>0?Math.round(s/t*100):0,l=n.length>o?n.slice(0,o-1)+"…":n;return K.createElement(ne,{key:e},K.createElement(re,null,l.padEnd(o+2)),K.createElement(re,null,r.padEnd(i)),K.createElement(re,{color:mr.DIM},`${a}%`))}))},"ModelBreakdownRows"),CA=__name(({onClose:e})=>{const[t,n]=J("loading"),[r,o]=J(null),[s,i]=J(!1),a=getProgressBarWidth({terminalWidth:useTerminalWidth()}),l=te(async e=>{try{i(!1);const t=await fetchUsageData();if(e.aborted)return;if(!t.whoami){const e=t.errors.some(isAuthErrorMessage);return i(e),void n("error")}o(t),n("loaded")}catch{if(e.aborted)return;n("error")}},[]),u=K.useRef(null);ie((r,o)=>{if(o.escape&&(UE(),e()),"r"===r&&"error"===t){n("loading"),u.current?.abort();const e=new AbortController;u.current=e,l(e.signal)}}),Z(()=>{const e=new AbortController;return u.current=e,l(e.signal),()=>e.abort()},[l]);const d=r?.subscription?.data??null,m=d?getPlanInfo({planId:d.planId??""}):null;if("loading"===t)return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(bA,{plan:m,status:d?.status??null}),K.createElement(re,{color:mr.DIM},"Loading…"),K.createElement(EA,null));if("error"===t)return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(bA,{plan:m,status:d?.status??null}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},s?"Not authenticated. Run /login to connect your account.":"Something went wrong.")),K.createElement(EA,{showRetry:!s}));if(!r)return null;const g=r.credits||r.subscription,h=getStudioUsageUrl(r.whoami);if(!g)return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(bA,{plan:m,status:d?.status??null}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"No billing data found."),h&&K.createElement(K.Fragment,null,K.createElement(re,{color:mr.DIM}," Visit "),K.createElement(ro,{url:h,text:"Studio",color:mr.CYAN}),K.createElement(re,{color:mr.DIM}," for usage details."))),K.createElement(EA,null));const f=r.credits?.credits,y=r.summary,w=r.modelBreakdown,S=null!=w&&w.length>0,E=Math.max(0,f?.monthlyCredits??0)+Math.max(0,f?.purchasedCredits??0)+Math.max(0,f?.freeCredits??0),v=Math.max(0,y?.totalCost??0),C=getUsagePercent({used:v,total:v+E}),k=E>0||v>0,T=d?.currentPeriodEnd?getDaysRemaining(d.currentPeriodEnd):null,_=getDaysColor(T),x=getUsageColor(C),A=buildBlockBar({percentage:C,width:a}),P=S?w.reduce((e,t)=>e+t.totalCost,0):0;return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,{marginBottom:1},K.createElement(bA,{plan:m,status:d?.status??null})),k?K.createElement(ne,null,K.createElement(re,{color:x},A.filled),K.createElement(re,{color:Cr},A.empty),K.createElement(re,{bold:!0,color:x},` ${Math.round(C)}% used`)):K.createElement(re,{color:mr.DIM},"Plan details unavailable"),k&&K.createElement(ne,null,d?.currentPeriodEnd&&K.createElement(re,{color:mr.DIM},"Cycle: "),K.createElement(re,null,formatCredits(E)),K.createElement(re,{color:mr.DIM}," left"),y&&K.createElement(K.Fragment,null,K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,null,y.totalCount.toLocaleString()),K.createElement(re,{color:mr.DIM}," requests")),null!==T&&K.createElement(K.Fragment,null,K.createElement(re,{color:mr.DIM}," · "),0===T?K.createElement(re,{color:_},"renewal today"):K.createElement(K.Fragment,null,K.createElement(re,{color:_},`${T} day${1===T?"":"s"}`),K.createElement(re,{color:mr.DIM}," to renewal")))),S&&K.createElement(vA,{models:w,grandTotal:P}),h&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"Full breakdown at "),K.createElement(ro,{url:h,text:SA(h),color:mr.CYAN})),K.createElement(EA,null))},"UsageOverlay");function UsageView({staticKey:e,setShowUsageOverlay:t}){return K.createElement(K.Fragment,null,K.createElement(_x,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(CA,{onClose:()=>t(!1)})))}__name(UsageView,"UsageView"),Ft(),Ft(),Cn(),lb(),LS(),so();var kA="System prompt",TA="Messages";function countMessagesByRole({messages:e}){let t=0,n=0;for(const r of e)"user"===r.message.role&&!isHiddenTranscriptMessage({message:r})&&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){if(isHiddenTranscriptMessage({message:r}))continue;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){if(isHiddenTranscriptMessage({message:n}))continue;const e=n.message.content;if(Array.isArray(e))for(const n of e)"image"===n.type&&t++}return t}function estimateConversationTokens({messages:e}){let t=0;for(const n of e)isHiddenTranscriptMessage({message:n})||(t+=estimateTokens(n.message));return t}function buildAutoCompactStatus({tokensUsed:e,tokenLimit:t}){const n=e/t,r=[{tier:1,threshold:bn.TIER_1_THRESHOLD,description:`Prune to last ${bn.TIER_1_KEEP_COUNT} tool calls`},{tier:2,threshold:bn.TIER_2_THRESHOLD,description:`Prune to last ${bn.TIER_2_KEEP_COUNT} tool calls`},{tier:3,threshold:bn.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:bn.KEEP_RECENT_TOKENS}}function getPrimaryTip({percentage:e,conversationPct:t}){return e>=90?"Tier 3 auto-compact imminent — /compact now to control what gets summarized":e>=80?"Auto-compact Tier 3 triggers at 90% — /compact to free space before it kicks in":t>60&&e>40?`${t}% is conversation — /compact to reclaim tokens`:e>=50?"/compact to free space · /model to switch models":null}function getSecondaryTip({mcpToolCount:e,imageCount:t,messageCount:n,percentage:r}){return e>0&&r>30?`${e} MCP tools loaded — disconnect unused servers to save tokens`:t>0&&r>30?`${t} image${t>1?"s":""} in context — images use ~1.5k tokens each`:n>50&&r>40?`${n} messages — consider starting a new session for a fresh context`:null}function generateTips({percentage:e,conversationTokens:t,totalTokens:n,mcpToolCount:r,messageCount:o,imageCount:s}){if(0===n)return[];const i=getPrimaryTip({percentage:e,conversationPct:Math.min(100,Math.round(t/n*100))}),a=getSecondaryTip({mcpToolCount:r,imageCount:s,messageCount:o,percentage:e}),l=[];return i&&l.push(i),a&&l.push(a),0===l.length&&l.push("/compact to summarize and free context · /model to switch models"),l}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 Zk){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 eT){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=e.getSystemPromptBreakdown(),r=getConfiguredModel(),o=getContextLimit(r),s=e.getHistory(),i=countMessagesByRole({messages:s}),a=countToolCalls({messages:s}),l=countImages({messages:s}),u=estimateConversationTokens({messages:s}),d=collectBuiltInTools(),m=collectMcpTools(),[g,h,f]=await Promise.all([collectSkillItems(),collectAgentItems(),collectMemoryItems()]),y=sumTokens(d),w=sumTokens(m),S=sumTokens(g),E=sumTokens(h),v=sumTokens(f),C=t>0,k=n?n.memory:v,T=null!==n&&Math.abs(v-n.memory)>50,_=n?n.taste:0,x=y+w+S+E,A=C?t:u+x+k+_,P=!C&&s.length>0,I=Math.min(A/o*100,100),M=Math.max(0,o-A),N=[];if(A>0){const e=n?n.systemPrompt:Math.max(0,A-u-x-k-_);if(e>0&&N.push({name:kA,tokens:e,detail:n?"identity":"identity + taste"}),k>0&&N.push({name:"Memory",tokens:k,detail:T?"memory files (modified, refreshes next request)":"memory files"}),_>0&&N.push({name:"Taste",tokens:_,detail:"taste.md"}),y>0&&N.push({name:"System tools",tokens:y,detail:`${d.length} built-in`}),w>0){const e=Array.from(new Set(m.map(e=>e.source).filter(e=>"string"==typeof e)));let t=`${m.length} tools`;e.length>3&&(t=`${e.length} servers`),e.length>=1&&e.length<=3&&(t=e.join(", ")),N.push({name:"MCP",tokens:w,detail:t})}S>0&&N.push({name:"Skills",tokens:S,detail:`${g.length} loaded`}),E>0&&N.push({name:"Subagents",tokens:E,detail:`${h.length} loaded`});const r=e+k+_+x,o=C?Math.max(0,t-r):u;o>0&&N.push({name:TA,tokens:o,detail:`${i.user} user · ${i.assistant} assistant`})}N.sort((e,t)=>e.name===kA?-1:t.name===kA||e.name===TA?1:t.name===TA?-1:t.tokens-e.tokens);const R=s.length>0?s[0]?.meta.timestamp??null:null;return{tokensUsed:A,tokenLimit:o,percentage:I,tokensRemaining:M,isEstimated:P,model:r,breakdown:N,autoCompact:buildAutoCompactStatus({tokensUsed:A,tokenLimit:o}),stats:{messageCount:s.length,userMessages:i.user,assistantMessages:i.assistant,toolCalls:a.calls,toolResults:a.results,imageCount:l,sessionStartTime:R},tips:generateTips({percentage:I,conversationTokens:u,totalTokens:A,mcpToolCount:m.length,messageCount:s.length,imageCount:l})}}function formatK(e){if(e<1e3)return String(e);if(e>=1e6){const t=Math.round(e/1e5)/10;return Number.isInteger(t)?`${t}M`:`${t.toFixed(1)}M`}const t=e/1e3;return Number.isInteger(t)?`${t}k`:`${t.toFixed(1)}k`}function formatBreakdownValue(e){return e<1e3?String(e):`${(e/1e3).toFixed(1)}k`}function getLayoutSizes({terminalWidth:e}){const t=Math.max(20,e),n=Math.min(50,Math.max(30,Math.floor(.5*t)));return{labelWidth:16,progressBarWidth:Math.max(10,Math.min(n,t-10)),showBreakdownDetail:t>=70}}function ContextProgress({analysis:e,progressBarWidth:t}){const n=getUsageColor(e.percentage),r=buildBlockBar({percentage:e.percentage,width:t});return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{marginBottom:1},K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:mr.BLUE,color:"#f4f4f4",bold:!0},`${ZT}CONTEXT${ZT}`)),K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{color:mr.GRAY},getModelDisplayName(e.model))),K.createElement(ne,null,K.createElement(re,{color:n},r.filled),K.createElement(re,{color:Cr},r.empty),K.createElement(re,{bold:!0,color:n},` ${e.percentage.toFixed(1)}%`)),K.createElement(ne,null,K.createElement(re,null,formatK(e.tokensUsed)),K.createElement(re,{color:mr.GRAY},` / ${formatK(e.tokenLimit)}`),K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{color:n},formatK(e.tokensRemaining)),K.createElement(re,{color:mr.GRAY}," remaining"),e.isEstimated&&K.createElement(re,{color:mr.DIM}," (estimated)")))}function CompactionDistance({analysis:e}){if(e.percentage<40)return null;const t=e.autoCompact.tiers.find(e=>3===e.tier);if(!t||"passed"===t.status)return null;const{tokensAway:n}=t;let r=mr.GRAY;return n<=5e4&&(r=mr.YELLOW),n<=2e4&&(r=mr.RED),K.createElement(ne,{marginTop:1},K.createElement(re,{color:r},`~${formatK(n)}`),K.createElement(re,{color:mr.DIM}," until auto-compact"))}function BreakdownRow({item:e,labelWidth:t,numWidth:n,showDetail:r}){return K.createElement(ne,null,K.createElement(re,null,e.name.padEnd(t)),K.createElement(re,{bold:!0},formatBreakdownValue(e.tokens).padStart(n)),K.createElement(re,{color:mr.GRAY}," tokens"),r&&e.detail&&K.createElement(re,{color:mr.DIM},` · ${e.detail}`))}function ContextBreakdown({analysis:e,labelWidth:t,showBreakdownDetail:n}){const r=e.breakdown.filter(e=>e.tokens>0);if(0===r.length)return null;const o=Math.max(4,...r.map(e=>formatBreakdownValue(e.tokens).length));return K.createElement(ne,{flexDirection:"column",marginTop:1},r.map(e=>K.createElement(BreakdownRow,{key:e.name,item:e,labelWidth:t,numWidth:o,showDetail:n})))}function ContextTips({tips:e}){return 0===e.length?null:K.createElement(ne,{flexDirection:"column",marginTop:1},e.map(e=>K.createElement(ne,{key:e},K.createElement(re,{color:mr.CYAN},Ie.pointer),K.createElement(re,{color:mr.GRAY}," ",e))))}function ContextMessage({analysis:e}){const t=getLayoutSizes({terminalWidth:useTerminalWidth()});return K.createElement(ne,{flexDirection:"column",paddingTop:1},K.createElement(ContextProgress,{analysis:e,progressBarWidth:t.progressBarWidth}),K.createElement(CompactionDistance,{analysis:e}),K.createElement(ContextBreakdown,{analysis:e,labelWidth:t.labelWidth,showBreakdownDetail:t.showBreakdownDetail}),K.createElement(ContextTips,{tips:e.tips}))}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&&(UE(),r(""),n(!1))}),K.createElement(K.Fragment,null,K.createElement(_x,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},i?K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:pr,bold:!0},"Context"),K.createElement(re,{color:mr.DIM},i)):o?K.createElement(ContextMessage,{analysis:o}):K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:pr,bold:!0},"Context"),K.createElement(re,{color:mr.DIM},"Loading context analysis...")),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"Press Esc to return to conversation"))))}__name(countMessagesByRole,"countMessagesByRole"),__name(countToolCalls,"countToolCalls"),__name(countImages,"countImages"),__name(estimateConversationTokens,"estimateConversationTokens"),__name(buildAutoCompactStatus,"buildAutoCompactStatus"),__name(getPrimaryTip,"getPrimaryTip"),__name(getSecondaryTip,"getSecondaryTip"),__name(generateTips,"generateTips"),__name(collectMemoryItems,"collectMemoryItems"),__name(collectBuiltInTools,"collectBuiltInTools"),__name(collectMcpTools,"collectMcpTools"),__name(collectSkillItems,"collectSkillItems"),__name(collectAgentItems,"collectAgentItems"),__name(sumTokens,"sumTokens"),__name(analyzeContext,"analyzeContext"),qE(),Ft(),no(),Or(),__name(formatK,"formatK"),__name(formatBreakdownValue,"formatBreakdownValue"),__name(getLayoutSizes,"getLayoutSizes"),__name(ContextProgress,"ContextProgress"),__name(CompactionDistance,"CompactionDistance"),__name(BreakdownRow,"BreakdownRow"),__name(ContextBreakdown,"ContextBreakdown"),__name(ContextTips,"ContextTips"),__name(ContextMessage,"ContextMessage"),Or(),__name(ContextConfigView,"ContextConfigView"),Ft(),Ft(),Cn(),qs(),LS(),Io(),fo(),so();var _A="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=>{ke("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(!O(e))return!1;try{return(await I(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=O(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=b_(S.platform()),t=D_(),n=O_(),r=F_()}catch{e="Unknown",t="Unknown",n="Unknown",r="N/A"}return{cwd:process.cwd(),os:e,arch:S.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:S.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"),Ft(),Cn(),Gb(),Or(),io(),__name(formatCountValue,"formatCountValue"),__name(formatSystemValue,"formatSystemValue");var xA=__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?Ie.tick:Ie.cross,a=t.auth.authenticated?mr.WHITE:Er.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:pr,bold:!0},"Command Code"," "),K.createElement(re,{dimColor:!0},n)),K.createElement(ne,null,K.createElement(re,{dimColor:!0},"Visit "),K.createElement(ro,{url:_A,text:_A,color:mr.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(ro,{url:`https://commandcode.ai/${t.auth.username}/`,text:t.auth.username,color:mr.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:Er.WARNING},"Not signed in"),K.createElement(re,{color:a}," ",i),K.createElement(re,{dimColor:!0}," — run "),K.createElement(re,{bold:!0},"/login"))),K.createElement(xA,{label:"Model",value:r}),K.createElement(xA,{label:"Branch",value:o,dimValue:!t.git.branch}),s?K.createElement(xA,{label:"Worktree",value:s}):null,t.git.remoteUrl?K.createElement(ne,null,K.createElement(re,{dimColor:!0},"Repository:".padEnd(14)),K.createElement(ro,{url:t.git.remoteHttpUrl||`https://github.com/${t.git.remoteUrl}`,text:t.git.remoteUrl,color:mr.CYAN}),t.pr?K.createElement(K.Fragment,null,K.createElement(re,{dimColor:!0}," · "),K.createElement(ro,{url:t.pr.url,text:`#${t.pr.number}`,color:"OPEN"===t.pr.state?mr.CYAN:mr.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(ro,{url:t.pr.url,text:`#${t.pr.number}`,color:"OPEN"===t.pr.state?mr.CYAN:mr.GRAY}),K.createElement(re,{dimColor:!0}," (",t.pr.state.toLowerCase(),")")):null,K.createElement(xA,{label:"Taste",value:d,dimValue:!t.taste.fileExists}),K.createElement(xA,{label:"Directory",value:toRelativePath(t.system.cwd)}),K.createElement(xA,{label:"Skills",value:formatCountValue(t.skillsAgents.personalSkills,t.skillsAgents.projectSkills),dimValue:0===l}),K.createElement(xA,{label:"Agents",value:formatCountValue(t.skillsAgents.personalAgents,t.skillsAgents.projectAgents),dimValue:0===u}),K.createElement(xA,{label:"System",value:formatSystemValue({system:t.system})}),t.system.proxy?K.createElement(xA,{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(_x,{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 D.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"),Ft(),Ft(),Do(),Ft(),Do(),__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"),Or(),jr();var AA=__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:mr.CYAN,paddingX:1,paddingY:0},K.createElement(re,{bold:!0,color:mr.CYAN},"Add directory to workspace"),K.createElement(re,{color:mr.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:mr.GRAY},"Added directories"),0===a.length?K.createElement(re,{color:mr.GRAY}," None yet"):a.map((e,t)=>{const n="active-dir"===u.zone&&u.activeDirIndex===t;return K.createElement(re,{key:e,color:n?mr.YELLOW:mr.GREEN,bold:n},n?` ${Ie.pointer} `:" ",formatDirectoryForDisplay(e))})),K.createElement(ne,{marginTop:1},K.createElement(re,{bold:!0,color:mr.WHITE},"Path")),K.createElement(ne,null,K.createElement(TextInput,{value:t,focus:"input"===u.zone,prefix:`${"input"===u.zone?Ie.pointer:" "} `,prefixColor:"input"===u.zone?mr.CYAN:mr.GRAY,onChange:e=>{n(e),o(null)},onSubmit:h})),!t&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.GRAY},"Examples: ../shared ~/docs /abs/path")),r&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:{error:mr.RED,warning:mr.YELLOW,success:mr.GREEN}[r.tone]},r.text)),s.length>0&&K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(re,{color:mr.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?mr.CYAN:mr.GRAY,bold:r},r?` ${Ie.pointer} `:" ",e)})),K.createElement(ne,{marginTop:1},K.createElement(BracketedText,{text:w,color:mr.DIM})))},"AddDirModal");Ft(),Ft(),Cn(),Ft(),Ft(),Cn(),Or();var PA=__name(()=>t.join(S.homedir(),".commandcode","agents"),"getRootAgentDir"),IA=__name(()=>t.join(process.cwd(),".commandcode","agents"),"getLocalAgentDir"),MA=__name(({config:e,onSaveComplete:n,viewOnly:r=!1})=>{const[o,s]=J("idle"),[i,a]=J(""),l=[...Zk.map(e=>e.name),...eT.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?PA():IA();await k.mkdir(r,{recursive:!0});const o=`${e.agentType}.md`,s=t.join(r,o),i=Array.from(e.selectedTools).map(e=>rT[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 k.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=>rT[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:mr.WHITE,bold:!0},"Name:"),K.createElement(re,{color:mr.GRAY},e.agentType)),K.createElement(ne,{gap:1},K.createElement(re,{color:mr.WHITE,bold:!0},"Location:"),K.createElement(re,{color:mr.GRAY},m)),K.createElement(ne,{gap:1},K.createElement(re,{color:mr.WHITE,bold:!0},"Tools:"),K.createElement(re,{color:mr.GRAY},0===e.selectedTools.size?"None":e.selectedTools.size===l.length?"*":d))),K.createElement(ne,{gap:1},K.createElement(re,{color:mr.WHITE,bold:!0},"Description"),K.createElement(re,{color:mr.GRAY},"(Tells ","Command Code"," when to use this agent):")),K.createElement(re,{color:mr.GRAY},e.ccToolDefinition),K.createElement(ne,{gap:1},K.createElement(re,{color:mr.WHITE,bold:!0},"System Prompt:")),K.createElement(re,{color:mr.GRAY},e.sysPrompt),!r&&K.createElement(ne,{marginTop:1},"idle"===o&&K.createElement(ne,{gap:1},K.createElement(re,{color:mr.GREEN,dimColor:!0},"Press"),K.createElement(re,{color:mr.GREEN,bold:!0},"Enter"),K.createElement(re,{color:mr.GREEN,dimColor:!0},"to save • Esc to cancel")),"saving"===o&&K.createElement(re,{color:mr.YELLOW},"Saving agent..."),"saved"===o&&K.createElement(re,{color:mr.GREEN},Ie.tick," ",i),"error"===o&&K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:mr.RED},Ie.cross," Error: ",i),K.createElement(re,{color:mr.GRAY},"Press Enter to retry"))))},"AgentSummary");Or();var NA=__name(({agent:e,onBack:t,setRevalidateAgent:n,isReadOnly:r=!1})=>{const[o,s]=J("menu"),i=[...Zk.map(e=>e.name),...eT.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=>oT[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(MA,{config:l,onSaveComplete:()=>s("menu"),viewOnly:!0}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.GRAY},"Press Enter to go back")));if("edit"===o)return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:mr.YELLOW},"Edit functionality coming soon..."),K.createElement(re,{color:mr.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 k.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:mr.RED},"Delete agent"),K.createElement(re,{color:mr.GRAY},"Are you sure you want to delete the agent ",e.name,"?")),K.createElement(ne,null,K.createElement(pt,{items:r,onSelect:o,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:mr.WHITE},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?mr.WHITE:mr.GRAY},` ${t}`)})))}return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:mr.WHITE,bold:!0},e.name),K.createElement(ne,{marginTop:1},K.createElement(pt,{items:u,onSelect:d,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:mr.WHITE},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?mr.WHITE:mr.GRAY},` ${t}`)})),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.GRAY},"Press ↑↓ to navigate · Enter to select · Esc to go back")))},"AgentDetails");Or();var RA=__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,w]=J(!1),E=__name(()=>t.join(S.homedir(),".commandcode","agents"),"getRootAgentDir"),v=__name(()=>t.join(process.cwd(),".commandcode","agents"),"getLocalAgentDir"),C=__name(async(e,n)=>{try{g(!1);const r=(await k.readdir(e)).filter(e=>e.endsWith(".md"));return(await Promise.all(r.map(async r=>{try{const o=t.join(e,r),s=await k.readFile(o,"utf-8"),{data:i,content:a}=Ue(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([C(E(),"personal"),C(v(),"project")]),n=Ak.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 T=[{label:"Create new agent",value:"create_new_agent"}];r.forEach(e=>{T.push({label:e.name,value:e.filePath})}),s.forEach(e=>{T.push({label:e.name,value:e.filePath})});const _=r.length+s.length,x=__name(t=>{if("create_new_agent"===t.value)e(t);else{const e=[...r,...s].find(e=>e.filePath===t.value);e&&(f(e),w(!0))}},"handleAgentSelect");if(u)return K.createElement(re,{color:mr.GRAY},"Loading agents...");if(y&&h){const e=h.filePath.startsWith("__builtin__:");return K.createElement(NA,{agent:h,onBack:()=>{w(!1),f(null)},setRevalidateAgent:g,isReadOnly:e})}const A=__name(({isSelected:e,label:t})=>{const n=T.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:mr.GRAY,bold:!0},"User agents")),a&&s.length>0&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.GRAY,bold:!0},"Project agents")),K.createElement(ne,null,K.createElement(re,{color:mr.WHITE},e?">":" "),K.createElement(re,{color:e?mr.WHITE:mr.GRAY}," ",t)))},"CustomItemComponent");return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.WHITE,bold:!0},"Agents"),_>0?K.createElement(re,{color:mr.GRAY}," ","(",_," agent",_>1?"s":"",")"):K.createElement(re,{color:mr.GRAY}," (No custom agents)")),n&&K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{color:mr.GREEN,dimColor:!0},"Created agent: ",n)),K.createElement(pt,{items:T,onSelect:x,indicatorComponent:()=>null,itemComponent:A}),a.length>0&&K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(re,{color:mr.GRAY,bold:!0},"Default agents"),a.map(e=>K.createElement(re,{key:e.filePath,color:mr.GRAY}," ",e.name.charAt(0).toUpperCase()+e.name.slice(1)))),K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(re,{color:mr.GRAY},"Create specialized subagents that Command Code can delegate to."),K.createElement(re,{color:mr.GRAY},"Each subagent has its own context window, custom system prompt, and specific tools.")))},"ManageAgents");Ft(),Cn(),Gs(),Or(),Ft(),Ft(),Cn(),Or();var $A=__name(({onSelect:e})=>K.createElement(pt,{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?mr.WHITE:mr.GRAY},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?mr.WHITE:mr.GRAY},` ${t}`)}),"LocationSelector");Ft(),jr(),Cn(),Hr(),Kr(),Or();var LA=__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:mr.WHITE},"Enter a unique identifier for your agent:"),t&&(Object.values(rT).some(e=>je(e)===je(t))||Object.keys(rT).some(e=>je(e)===je(t)))&&K.createElement(re,{color:mr.RED},Ie.warning," This name conflicts with an existing tool name. Please choose a different name."),t&&isReservedAgentName(je(t))&&K.createElement(re,{color:mr.RED},Ie.warning," This name is reserved. Reserved names: ",xk.join(", "))),K.createElement(TextInput,{showCursor:!0,value:t||"",onSubmit:()=>{if(null===t||0===t.trim().length)return;const e=je(t);Object.values(rT).some(t=>je(t)===e)||Object.keys(rT).some(t=>je(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:mr.WHITE},"Enter the system prompt for your agent:"),K.createElement(re,{color:mr.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:mr.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");Ft(),Or();var DA=__name(({onSelect:e})=>K.createElement(pt,{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?mr.WHITE:mr.GRAY},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?mr.WHITE:mr.GRAY},` ${t}`)}),"MethodSelector");Ft(),jr(),Ft(),jE(),Or();var OA=["·","○","◇","☆","✧","☆","◇","○","⌘"],FA=[12,5,4,4,4,4,4,5,16],UA=[5,4,4,4,4,4,5];function getWaveSymbol(e){const t=e%88;let n=0;for(let e=0;e<FA.length;e++)if(n+=FA[e],t<n)return OA[e];const r=t-58;n=0;for(let e=0;e<UA.length;e++)if(n+=UA[e],r<n)return OA[7-e];return OA[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<Mr.length?Mr[n]:Nr},"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??pr,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 jA=__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 DE.statusRender({width:l,layoutMode:u,status:e,frame:r}),K.createElement(ne,{width:l,height:1,paddingLeft:0,marginLeft:0},K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:Sr.BG,color:Sr.FG}," "),K.createElement(re,{backgroundColor:Sr.BG},K.createElement(CMDIcon,{frame:4*r})),K.createElement(ShimmerText,{text:e,offset:m,bg:Sr.BG}),K.createElement(re,{backgroundColor:Sr.BG,color:Sr.FG}," ")),g&&K.createElement(ne,{columnGap:1,marginLeft:1},K.createElement(re,{bold:!0,color:mr.GRAY},"esc"),K.createElement(re,{color:mr.DIM},"to interrupt"),K.createElement(re,{color:mr.DIM},"•"),K.createElement(re,{color:mr.DIM},formatTime3(t)),K.createElement(re,{color:mr.DIM},"•"),K.createElement(re,{color:mr.GRAY},Ie.arrowDown),K.createElement(re,{color:mr.DIM},formatToken(Math.round(s)))),h&&K.createElement(ne,{marginLeft:1},K.createElement(re,{color:mr.DIM},formatToken(Math.round(s)))))},"Status");Kr(),Hr(),Or();var qA=__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:mr.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:mr.RED},`${Ie.warning} ${o}`)))},"RecommendedFlow");Ft(),Or();var BA=__name(({selectedTools:e,onToggleTool:t,onToggleCategory:n,onComplete:r})=>{const[o,s]=J(!1),[i,a]=J(0),l=ee(()=>[...Zk.map(e=>e.name),...eT.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]":"[ ]"} ${rT[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:mr.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:mr.GRAY}," ",e.label));const o="continue"===e.type;return K.createElement(ne,{key:`item-${t}`},K.createElement(re,{color:r?mr.WHITE:mr.GRAY,bold:o&&r},r?">":" "," ",e.label))}),K.createElement(ne,{marginTop:1},e.size===l.length&&K.createElement(re,{color:mr.GRAY},"All tools selected"),e.size>0&&e.size<l.length&&K.createElement(re,{color:mr.GRAY},e.size," tools selected"),0===e.size&&K.createElement(re,{color:mr.GRAY},"No tools selected")))},"ToolsSelector");yo(),IS(),yS(),Bs(),HE(),so();var zA=__name(({onComplete:e})=>{const[t,n]=J("location"),[r,o]=J(!1),[s,i]=J(null),[a,l]=J("agentType"),u=ee(()=>[...Zk.map(e=>e.name),...eT.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={[Bt.INTERNAL_TEAM_FLAG_HEADER]:t.toString()};r&&(a[Bt.OAUTH_TOKEN]=`Bearer ${r}`,s&&(a[Bt.OAUTH_PROVIDER]=s));const l=getApiBaseUrl(),u=new Xw({baseUrl:l}),d=parseModelString(getConfiguredModel()).modelId,h=await u.post({headers:a,endpoint:zt.ALPHA.AGENT.GENERATE,body:{description:m.recommendedMethodDescription,model:d}});g({...m,agentType:je(h.agentName),sysPrompt:h.systemPrompt,ccToolDefinition:h.toolDescription}),n("tools")}catch(e){if(e instanceof Ms&&400===e.status&&e.message?.toLowerCase().includes("insufficient credits")){const e=await getBillingLink({billingLink:null,setBillingLink:__name(()=>{},"setBillingLink")})??"https://commandcode.ai/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:je(m.agentType)}),l("sysPrompt")},"handleManualAgentTypeSubmit"),v=__name(()=>{l("ccToolDefinition")},"handleManualSysPromptSubmit"),C=__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:mr.WHITE,bold:!0},"Create new agent"),K.createElement(re,{color:mr.GRAY},f())),K.createElement(ne,null,"location"===t&&K.createElement($A,{onSelect:y}),"method"===t&&K.createElement(DA,{onSelect:w}),"configuration"===t&&"recommended"===m.method&&K.createElement(qA,{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(LA,{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:v,onCCToolDefinitionSubmit:C})),"tools"===t&&K.createElement(BA,{selectedTools:m.selectedTools,onToggleTool:T,onToggleCategory:_,onComplete:k}),"summary"===t&&K.createElement(MA,{config:m,onSaveComplete:h})))},"AgentNew");Or();var WA=__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:mr.GRAY,borderStyle:"single",flexDirection:"column"},null===t&&K.createElement(RA,{handleSelect:s,createdAgentName:r}),"create_new_agent"===t&&K.createElement(zA,{onComplete:e=>{o(e),n(null)}}))},"AgentsConfig");Or(),Ft(),so(),Or();var HA=[{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."}],GA=__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=HA.findIndex(e=>e.value===n);return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:pr,bold:!0},"Select a compact mode to compact sessions")),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.DIM},"Choose how Command Code handles automatic context compaction.")),K.createElement(pt,{items:HA,onSelect:o,initialIndex:s>=0?s:0,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:mr.CYAN},e?Ie.pointer:" "),itemComponent:({isSelected:e,label:t})=>{const r=HA.find(e=>e.label===t),o=r?.value===n,s=HA.findIndex(e=>e.label===t);return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,K.createElement(re,{color:e?mr.CYAN:o?mr.GREEN:mr.WHITE},` ${s+1}. ${r?.label??t}`),o&&K.createElement(re,{color:mr.GREEN}," ",Ie.tick)),K.createElement(re,{color:mr.DIM},` ${r?.description??""}`))}}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"Press "),K.createElement(re,{color:mr.DIM,bold:!0},"Esc"),K.createElement(re,{color:mr.DIM}," to cancel")))},"CompactModeSelector");Ft(),Cn(),no(),fo(),so(),mo(),Ft(),Cn(),Or();var VA=__name(({model:e,providerId:t,isHighlighted:n,isCurrent:r,showProviderLabel:o})=>{const s=fn[t],i=o??s?.showProviderLabelInSelector??!1,a=e.vendorLabel??gn[e.provider],l=e.id===pn,u="free"===e.badge,d=l?`${e.label} (default)`:e.label,m=u?" (FREE)":"",g=" ".repeat(Math.max(0,32-d.length-m.length));return K.createElement(ne,null,K.createElement(re,{color:n?mr.CYAN:mr.GRAY},n?`${Ie.pointer} `:" "),K.createElement(re,{color:n?mr.CYAN:r?mr.GREEN:mr.WHITE},d),u&&K.createElement(re,{color:mr.GREEN,bold:!0},m),K.createElement(re,null,g),i&&K.createElement(re,{color:mr.DIM},a),e.description&&K.createElement(re,{color:mr.DIM},i?" · ":"",e.description),r&&K.createElement(re,{color:mr.GREEN}," ",Ie.tick))},"ModelRow");Or();var QA=__name(e=>[{text:e.name,weight:100},{text:e.label,weight:50},{text:e.provider,weight:25},{text:e.description||"",weight:10}],"MODEL_SEARCH_FIELDS");function searchGroups(e,t){if(!t.trim())return e;const n=[];for(const r of e){const e=fuzzyFilter(r.models,t,QA);e.length>0&&n.push({...r,models:e})}return n}function groupByModelProvider(e,t){return groupModelsByDisplayOrder(e).map(e=>({providerId:t,label:e.label,models:e.models}))}__name(searchGroups,"searchGroups"),__name(groupByModelProvider,"groupByModelProvider");var KA=__name(({featureLabel:e,defaultLabel:t,currentModelId:n,onPick:r,onBack:o})=>{const[s,i]=J(""),a=ee(()=>isInternalTeamFlagEnforced(),[]),[l,u]=J(()=>getCachedBillingContext());Z(()=>{if(l)return;let e=!0;return getBillingContext().then(t=>{e&&u(t)}),()=>{e=!1}},[l]);const d=null!==l,m=ee(()=>a?yn:groupByModelProvider(wn.flatMap(e=>e.models),fn["command-code"].id),[a]),g=ee(()=>l?m.map(e=>({...e,models:e.models.filter(e=>checkModelAccess({model:{id:e.id,provider:e.provider,name:e.name},planId:l.planId,purchasedCredits:l.purchasedCredits,freeCredits:l.freeCredits}).allowed)})).filter(e=>e.models.length>0):[],[m,l]),h=ee(()=>searchGroups(g,s),[g,s]),f=ee(()=>{const e=[];for(const t of h)for(const n of t.models)e.push({kind:"model",providerId:t.providerId,model:n});return[{kind:"reset"},...e]},[h]),y=ee(()=>{if(!n)return 0;const e=f.findIndex(e=>"model"===e.kind&&e.model.id===n);return e>=0?e:0},[f,n]),{cursor:w}=useListNavigation({items:f,initialIndex:y,searchCursorIndex:1,searchQuery:s,onSearchChange:i,onSelect:__name(e=>{d&&r("reset"===e.kind?void 0:e.model.id)},"onSelect"),onCancel:o});let S=1;return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:pr,bold:!0},e," › select model")),K.createElement(ne,{marginBottom:1},K.createElement(re,{dimColor:!0},"Pick a model for this task, or reset it to the default.")),K.createElement(ne,{marginBottom:2,flexDirection:"column",width:"100%"},K.createElement(lA,{query:s,resultCount:s?f.length-1:void 0,placeholder:"Type to search models..."})),d?K.createElement(K.Fragment,null,K.createElement(ne,null,K.createElement(re,{color:0===w?mr.CYAN:mr.GRAY},0===w?`${Ie.pointer} `:" "),K.createElement(re,{color:0===w?mr.CYAN:mr.WHITE},"↺ Use default (",t,")")),h.map(e=>{const t=S;return S+=e.models.length,K.createElement(ne,{key:`${e.providerId}-${e.label}`,flexDirection:"column",marginTop:1},K.createElement(re,{bold:!0,dimColor:!0},e.label),e.models.map((r,o)=>K.createElement(VA,{key:`${e.providerId}-${e.label}-${r.id}`,model:r,providerId:e.providerId,isHighlighted:t+o===w,isCurrent:r.id===n,showProviderLabel:!!a&&void 0})))})):K.createElement(ne,null,K.createElement(re,{color:mr.DIM},"Loading available models…")),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"type to search · ↑/↓ navigate · enter select"),s?K.createElement(re,{color:mr.DIM}," · esc to clear"):K.createElement(re,{color:mr.DIM}," · esc back")))},"FeatureModelPicker"),YA=__name(({onClose:e})=>{const[t,n]=J(null),[r,o]=J(null),[s,i]=J(null);Z(()=>{loadUserConfig().then(e=>{n(e.featureModels??{})})},[]);const a=r?"picker":"list",{cursor:l}=useListNavigation({items:qk,initialIndex:0,searchQuery:"",onSearchChange:__name(()=>{},"onSearchChange"),disableSearch:!0,isActive:"list"===a&&null!==t,onSelect:__name(e=>{i(null),o(e.key)},"onSelect"),onCancel:e,onReset:__name(async e=>{try{await setFeatureModel({feature:e.key,model:void 0}),n(t=>{const n={...t??{}};return delete n[e.key],n}),i({text:`${e.label} reset to default`})}catch{i({text:`Couldn't reset ${e.label} — try again`,error:!0})}},"onReset")});if(null===t)return null;const u=qk.find(e=>e.key===r)??null;return"picker"===a&&u?K.createElement(KA,{featureLabel:u.label,defaultLabel:getFeatureDefaultLabel(u),currentModelId:t[u.key],onBack:()=>o(null),onPick:async e=>{try{await setFeatureModel({feature:u.key,model:e}),n(t=>{const n={...t??{}};return void 0===e?delete n[u.key]:n[u.key]=e,n}),i({text:void 0===e?`${u.label} reset to default`:`${u.label} → ${getModelDisplayName(e)}`})}catch{i({text:`Couldn't save ${u.label} — try again`,error:!0})}o(null)}}):K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:pr,bold:!0},"Configure models")),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.DIM},"Pick a model for each task. Applies to all sessions."," ",createOSC8Link("https://commandcode.ai/docs/troubleshooting/faqs#why-do-i-see-small-background-requests","Why background requests?",!1))),qk.map((e,n)=>{const r=t[e.key],o=e.defaultLabel?`Default (${getFeatureDefaultLabel(e)})`:`Uses current model (${getFeatureDefaultLabel(e)})`,s=r?getModelDisplayName(r):o,i=n===l;return K.createElement(ne,{key:e.key},K.createElement(re,{color:i?mr.CYAN:mr.GRAY},i?`${Ie.pointer} `:" "),K.createElement(re,{color:i?mr.CYAN:mr.WHITE},e.label.padEnd(20)),K.createElement(re,{color:r?mr.GREEN:mr.DIM},s))}),s&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:s.error?mr.RED:mr.GREEN},s.text)),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"↑/↓ navigate · enter to change · r to reset · esc to close")))},"ConfigureModelsSelector");function settingsFilePaths(e){return[getProjectLocalPath(e),getProjectSharedPath(e),getUserSettingsPath()]}function readInputSettings(e){try{const t=L.readFileSync(e,"utf-8");return parseJSON(t)?.input}catch{return}}function shouldCollapsePastedText(e=process.cwd()){for(const t of settingsFilePaths(e)){const e=readInputSettings(t)?.collapsePastedText;if("boolean"==typeof e)return e}return!0}Ft(),Or(),Ft(),jr(),Cn(),Hr(),Ft(),yo(),__name(settingsFilePaths,"settingsFilePaths"),__name(readInputSettings,"readInputSettings"),__name(shouldCollapsePastedText,"shouldCollapsePastedText"),Vn(),Ft();var JA=n(E(),"commandcode-images"),XA={"image/png":".png","image/jpeg":".jpg","image/gif":".gif","image/webp":".webp"};function saveTempImage(e,t){try{O(JA)||q(JA,{recursive:!0});const r=XA[e.mediaType]||".png",o=`image-${t}-${Date.now()}${r}`,s=n(JA,o),i=Buffer.from(e.data,"base64");return B(s,i),s}catch{return null}}function stripInputAfterSuffix(e,t){return t&&e.endsWith(t)?e.slice(0,e.length-t.length):e}function extractAppendedChunk(e,t,n){const r=t+n;return e.length>=r.length&&e.startsWith(r)?e.slice(r.length):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,setInitialCursor:a,collapsePastedText:l=!0}=e,u=te((e,t,n="")=>{o(t=>[...t,e]),r(t+n),a(t.length),i()},[o,r,a,i]),d=X(!1),m=X(""),g=X(null),h=X(""),f=X(""),y=te(async(e,t,o)=>{let d=e.replace(/\r\n/g,"\n").replace(/\r/g,"\n");const m=await detectDroppedImageFile(d);if(m)return void u(m,t,o);const g=await detectClipboardImage();if(g)return void u(g,t,o);let h=d;if(0===h.length){const e=await detectClipboardText();h=e?e.replace(/\r\n/g,"\n").replace(/\r/g,"\n"):""}if(!h&&!o)return;if(!h)return r(t+o),a(t.length),void i();if(l&&h.length>300){const e=t+`[Text#${n.length+1}]`;return s(e=>[...e,h]),r(e+o),a(e.length),void i()}const f=t+h;r(f+o),a(f.length),i()},[u,n.length,s,r,a,i,l]),w=te(()=>{g.current&&clearTimeout(g.current),g.current=setTimeout(async()=>{if(d.current){const e=m.current,t=h.current,n=f.current;m.current="",h.current="",f.current="",d.current=!1,g.current=null,e?await y(e,t,n):n&&await y("",t,n)}},500)},[y]);return{handlePaste:te(async e=>{const n=processBracketedPaste(e);if(n.isPasteStart&&n.isPasteEnd)return d.current&&(d.current=!1,m.current="",h.current="",f.current="",g.current&&(clearTimeout(g.current),g.current=null)),await y(n.pastedContent??n.cleanedContent,n.textBeforePaste??"",n.textAfterPaste??""),!0;if(n.isPasteStart&&!d.current){d.current=!0;const e=n.textBeforePaste??t,r=t.slice(e.length);h.current=e,f.current=r;const o=n.pastedContent??n.cleanedContent;return m.current=stripInputAfterSuffix(o,r),w(),!0}if(d.current&&!n.isPasteEnd){const e=h.current,t=f.current;if(void 0!==n.pastedContent)m.current=stripInputAfterSuffix(n.pastedContent,t);else if(n.cleanedContent){const r=extractAppendedChunk(n.cleanedContent,e,t);m.current=null!==r?m.current+r:accumulateDelta(n.cleanedContent,m.current,e)}return w(),!0}if(d.current&&n.isPasteEnd){g.current&&(clearTimeout(g.current),g.current=null);const e=h.current,t=f.current,r=n.textAfterPaste??"";let o=n.cleanedContent??"";if(r&&o.endsWith(r)&&(o=o.slice(0,o.length-r.length)),void 0!==n.pastedContent)m.current=stripInputAfterSuffix(n.pastedContent,t);else if(o){const n=extractAppendedChunk(o,e,t);m.current=null!==n?m.current+n:accumulateDelta(o,m.current,e)}const s=m.current,i=e,a=r||t;return m.current="",h.current="",f.current="",d.current=!1,await y(s,i,a),!0}if(n.isPasteEnd&&!n.isPasteStart&&!d.current)return!0;const r=e.slice(t.length);if(r.length>0){const e=await detectDroppedImageFile(r);if(e)return u(e,t),!0}return!1},[t,y,w,u]),resetPasteState:te(()=>{d.current=!1,m.current="",h.current="",f.current="",g.current&&(clearTimeout(g.current),g.current=null)},[]),isPasting:te(()=>d.current,[])}}function useExternalEditor({input:e,setInput:t,setInputKey:n,detectedContent:r,setDetectedContent:o,onEditorClose:s}){const[i,a]=J(!1),[l,u]=J(null),d=te(async()=>{if(!i){a(!0),u(null);try{let i=e.replace(/\n+$/,"");r.forEach((e,t)=>{const n=`[Text#${t+1}]`;i.includes(n)&&(i=i.replace(n,e))});const a=await openInEditor2(i);t(a),o([]),n(e=>e+1),s?.()}catch(e){u(e instanceof d_?"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{a(!1)}}},[e,t,n,r,o,s,i]),m=te(()=>{u(null)},[]);return{isEditorOpen:i,editorError:l,handleOpenInEditor:d,clearEditorError:m}}__name(saveTempImage,"saveTempImage"),ir(),yo(),Ft(),Kr(),Hr(),__name(stripInputAfterSuffix,"stripInputAfterSuffix"),__name(extractAppendedChunk,"extractAppendedChunk"),__name(accumulateDelta,"accumulateDelta"),__name(useBracketedPaste,"useBracketedPaste"),Kr(),Ft(),__name(useExternalEditor,"useExternalEditor"),Ft();var ZA=__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,l_().then(t=>{e&&r(t)}),()=>{e=!1}},[t]),{pr:n}},"usePRDetection");function loadGitignore(e){const t=rt(),r=n(e,".gitignore");if(O(r))try{const e=U(r,"utf8");t.add(e)}catch{}return t.add(".git"),t}Or(),Ft(),Or(),__name(loadGitignore,"loadGitignore");var eP=__name(({onSelectFile:e,onClose:t,searchQuery:o=""})=>{const[i,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=z(o),i=[];return e.forEach(e=>{const a=n(o,e);try{const e=W(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=z(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=W(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{z(e).forEach(u=>{const d=n(e,u);try{const e=W(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=z(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=W(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(i)},[i,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(a(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:mr.DIM},o.trim()?`Searching for: "${o}"`:`Files: ${i}`),K.createElement(re,{color:mr.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:mr.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?mr.GREEN:mr.DIM},e.isDirectory?`${r}/`:r)}))},"FileList");Ft(),Cn(),fo(),Or(),Ft(),Or();var tP=__name(e=>{if(e>=1e6){const t=e/1e6;return`${t%1==0?t.toFixed(0):t.toFixed(1)}M`}return`${Math.round(e/1e3)}k`},"formatTokens"),nP=__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&&e.current>=18e4)return K.createElement(ne,{paddingRight:3},K.createElement(re,{color:mr.DIM},"~",tP(e.current)," tokens in context · try"," "),K.createElement(re,{color:mr.DIM,bold:!0},"/compact"));if(n>20)return null;const r=__name(e=>e>=90?mr.RED:e>=70?mr.YELLOW:mr.DIM,"getColor"),o=t>=90?6:Math.round(t/100*6),s=6-o,i=Ie.square.repeat(o),a=Ie.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:mr.DIM},a))},"ContextUsage");Ft(),fs(),Or();var rP=__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 xT.on("new-event",e),()=>{xT.off("new-event",e),l.current&&clearTimeout(l.current)}},[]);const d=` ${n?Ie.squareSmallFilled:Ie.squareSmall} TASTE`,m=9+e.length+d.length>as;let g=e;g=truncateString(m?{text:e,maxChars:as}:{text:e,maxChars:as-d.length-9-10});const h=o?void 0:mr.DIM;return K.createElement(ne,{paddingRight:2},!m&&K.createElement(K.Fragment,null,K.createElement(BracketWrap,{color:mr.DIM},"ctrl+t"),K.createElement(re,{color:mr.DIM}," ")),K.createElement(re,{color:h},g),!m&&K.createElement(re,{color:gr.TEXT},d))},"LearningFeedMini");Ft(),Or();var oP=__name(({mode:e,pendingExitKey:t})=>t?K.createElement(re,{color:mr.DIM},"Press Ctrl+C again to exit"):"bypass"===e?K.createElement(ne,{flexDirection:"row"},K.createElement(re,{color:mr.RED},"» permission bypass on "),K.createElement(BracketWrap,{color:mr.DIM},"shift+tab")):"auto-accept"===e?K.createElement(ne,{flexDirection:"row"},K.createElement(re,{color:xr},"» accept edits on "),K.createElement(BracketWrap,{color:mr.DIM},"shift+tab")):"plan"===e?K.createElement(ne,{flexDirection:"row"},K.createElement(re,{color:_r},"plan mode "),K.createElement(BracketWrap,{color:mr.DIM},"shift+tab")):K.createElement(re,{color:mr.DIM},"? for shortcuts"),"ModeIndicator");Ft(),Or(),io();var sP=__name(({prInfo:e,showSeparator:t=!0})=>{if(!e)return null;if("OPEN"!==e.state&&"MERGED"!==e.state)return null;const n="OPEN"===e.state?mr.DIM:Ar.MERGED;return K.createElement(K.Fragment,null,t&&K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{color:n},"PR "),K.createElement(ro,{url:e.url,text:`#${e.number}`,color:n}))},"PRLinkBadge"),iP=__name(({indicator:e,showSeparator:t=!0})=>e?.visible?K.createElement(K.Fragment,null,t&&K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{color:"connected"===e.type?mr.GREEN:mr.YELLOW},e.message)):null,"ConnectionIndicatorBadge"),aP=__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 v=e>=60;return K.createElement(K.Fragment,null,K.createElement(ne,{flexDirection:"column",paddingLeft:2},"auto-accept"!==r&&"plan"!==r&&"bypass"!==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:vr},t):K.createElement(oP,{mode:r,pendingExitKey:l}),!l&&K.createElement(sP,{prInfo:o}),!l&&K.createElement(iP,{indicator:a})),v&&K.createElement(ne,{flexDirection:"column",alignItems:"flex-end"},s&&K.createElement(rP,null),i&&K.createElement(nP,{usage:i}))):K.createElement(K.Fragment,null,K.createElement(ne,{flexDirection:"row",justifyContent:"space-between",width:e-1},K.createElement(oP,{mode:r}),v&&s&&K.createElement(rP,null)),K.createElement(ne,{flexDirection:"row",justifyContent:"space-between",width:e-1},K.createElement(ne,{flexDirection:"row",columnGap:0},K.createElement(re,{color:n?vr:mr.DIM},t),K.createElement(sP,{prInfo:o}),K.createElement(iP,{indicator:a})),v&&i&&K.createElement(nP,{usage:i}))),(u||d||g&&m)&&K.createElement(ne,{flexDirection:"row",columnGap:1},u&&K.createElement(re,null,Ie.tick," ","Command Code"," updated:"," ",K.createElement(re,{color:mr.DIM},"v",u.updatedFrom),K.createElement(re,{color:mr.DIM}," ",Ie.arrowRight," "),K.createElement(re,null,"v",u.updatedTo)),!u&&d&&K.createElement(re,{color:mr.YELLOW,dimColor:!0},Ie.info," Update available:"," ",d.currentVersion," ",Ie.arrowRight," ",d.latestVersion),g&&m&&K.createElement(re,{color:mr.GREEN,dimColor:!0},Ie.bullet," Provider:"," ",getProviderDisplayName(m)))),h&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:mr.GREEN},"! for bash mode")),y&&f&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:pr},"SHARED: ",f.url," (copied to clipboard)")),w&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:w.includes("NOT SHARED")?mr.RED:pr},w)),S&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:pr},S)),E&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:mr.YELLOW},Ie.warning," ",E)))},"BottomIndicator");Ft(),fs(),Or();var lP=12,cP=__name(e=>e instanceof Error&&e.message?e.message:"Unknown error","getDeleteErrorMessage"),uP=__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"),dP=__name(e=>e.replace(/\s+/g," ").trim(),"normalizeSummary"),mP=__name(e=>truncateString({text:dP(e),maxChars:os}),"truncateMessage"),pP=__name(e=>e.title?dP(e.title):mP(e.firstMessage),"getSessionSummary"),gP=__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,h]=J(!1),[f,y]=J(null),[w]=J(()=>getCurrentGitBranch()),S=te(async()=>{u(!0);const e=await Rk.listSessions();r(e),u(!1)},[]);Z(()=>{S()},[S]);const E=te(async e=>{try{await Rk.deleteSession(e),h(!1),y(null),s(0),a(0),await S()}catch(e){h(!1),y(`Failed to delete session: ${cP(e)}`)}},[S]),v=d&&w?n.filter(e=>e.gitBranch===w):n;if(ie((n,r)=>{if(g)if(r.return){if(v.length>0&&o<v.length){const e=v[o];E(e.id)}}else h(!1);else if(r.delete||r.ctrl&&"d"===n)v.length>0&&(y(null),h(!0));else{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(v.length-1,e+1);return t>=i+lP&&a(t-lP+1),t}):r.return&&v.length>0&&o<v.length&&e(v[o].id));t()}}),l)return K.createElement(ne,{flexDirection:"column",paddingLeft:2},K.createElement(re,{color:mr.GRAY},"Loading sessions..."));if(0===v.length)return K.createElement(ne,{flexDirection:"column",paddingLeft:2},K.createElement(re,{color:mr.GRAY},d&&w?`No sessions found for branch "${w}"`:"No previous sessions found"),K.createElement(re,{color:mr.DIM},d?"Press ctrl+b to show all branches, ESC to cancel":"Press ESC to go back"));const C=v.slice(i,i+lP),k=o<v.length?v[o]:null,T=g&&k?`Delete "${pP(k)}"? Press Enter to confirm, any other key to cancel.`:null;return K.createElement(ne,{flexDirection:"column",paddingLeft:1,width:"100%"},K.createElement(re,{color:mr.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:mr.GRAY}," ")),K.createElement(ne,{width:13},K.createElement(re,{color:mr.GRAY},"Modified")),K.createElement(ne,{width:20},K.createElement(re,{color:mr.GRAY},"Git Branch")),K.createElement(ne,{width:11},K.createElement(re,{color:mr.GRAY},"# Messages")),K.createElement(ne,null,K.createElement(re,{color:mr.GRAY},"Summary"))),K.createElement(ne,{columnGap:2},K.createElement(ne,{flexDirection:"column",width:5},C.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`sel-${n}`,color:o===n?mr.WHITE:mr.GRAY},o===n?`${Ie.pointer} ${n+1}.`:` ${n+1}.`)})),K.createElement(ne,{flexDirection:"column",width:13},C.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`mod-${e.id}`,color:o===n?mr.WHITE:mr.GRAY},uP(e.lastModified))})),K.createElement(ne,{flexDirection:"column",width:20},C.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`branch-${e.id}`,color:o===n?mr.WHITE:mr.GRAY,wrap:"truncate-end"},e.gitBranch||"-")})),K.createElement(ne,{flexDirection:"column",width:11},C.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`msg-${e.id}`,color:o===n?mr.WHITE:mr.GRAY},e.messageCount)})),K.createElement(ne,{flexDirection:"column"},C.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`summary-${e.id}`,color:o===n?mr.WHITE:mr.GRAY,wrap:"truncate-end"},pP(e))}))),K.createElement(ne,{marginTop:1}),T&&K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.RED},T)),f&&K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.RED},f)),v.length>lP&&K.createElement(re,{color:mr.DIM},"Showing ",i+1,"–",Math.min(i+lP,v.length)," ","of ",v.length,i>0?" · ↑ more":"",i+lP<v.length?" · ↓ more":""),K.createElement(re,{color:mr.DIM},"↑↓ navigate · Enter select · Del delete · ctrl+b ",d?`[branch: ${w??"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:mr.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}))))))}Ft(),Or(),Ft(),__name(getImageHintText,"getImageHintText"),__name(buildImageRows,"buildImageRows"),__name(shouldSelectImageOnUpArrow,"shouldSelectImageOnUpArrow"),__name(nextImageIndex,"nextImageIndex"),__name(prevImageIndex,"prevImageIndex"),__name(removeImageAt,"removeImageAt"),mo(),__name(ImageLabel,"ImageLabel"),__name(ImageRowsDisplay,"ImageRowsDisplay"),Ft();var hP=__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=X(n),[d,m]=J(!1),[g,h]=J("connected"),f=X(null),y=X(null),w=te((e,t)=>{y.current&&(clearTimeout(y.current),y.current=null),h(e),m(!0),void 0!==t&&(y.current=setTimeout(()=>{m(!1)},t))},[]),S=te(()=>{y.current&&(clearTimeout(y.current),y.current=null)},[]),E=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 mk,l.current=t;const r=e?200:500;n=await t.connect(r)}const r=f.current;if(null===r?n&&w("connected",3e3):r!==n&&(n?w("connected",2e3):w("disconnected",5e3)),f.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===f.current&&w("disconnected",5e3),f.current=!1,i(!1),o(null),l.current?.disconnect(),l.current=null}finally{a.current=!1}}},[w]);Z(()=>{const e=u.current;u.current=n,e&&!n&&t&&null!==nk()&&E(!1)},[n,t,E]),Z(()=>{if(!t)return;if(null===nk())return;let e=null,n=!1,r=0;function schedule(t){n||(e=setTimeout(()=>{tick(!1)},t))}async function tick(e){if(u.current)return void schedule(500);if(await E(e),n)return;if(l.current?.isConnected)return r=0,void schedule(500);r+=1;const t=Math.min(r,6);schedule(Math.min(3e4,500*2**t)+250*Math.random())}return __name(schedule,"schedule"),__name(tick,"tick"),tick(!0),()=>{n=!0,e&&clearTimeout(e),S(),l.current?.disconnect(),l.current=null}},[t,E,S]);const v=nk(),C={visible:d,message:"connected"===g?`${v?y_[v]??"IDE":"IDE"} ${Ie.tick}`:"run /ide",type:g};return{context:r,connected:s,refresh:E,connectionIndicator:C}},"useVSCodeContext");Ft();var fP=__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,"</ide-context>").replace(/[\u202A-\u202E\u2066-\u2069\u200B-\u200D\uFEFF]/g,"");t.push(i),t.push("```")}return t.push("</ide-context>"),t.join("\n")+"\n"},"formatContextForPrompt");Ft();var yP=__name((e,t)=>!(!e||!t?.selection&&!t?.activeFile?.relativePath),"hasIDEContext"),wP=__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");function getModelHintLayout(e){const{currentModel:t,terminalWidth:n}=e,r=getCommandMenuDescriptionWidth(n);return{descriptionWidth:r,text:truncateString({text:`${getModelDisplayName(t)} (current)`,maxChars:r})}}Ft(),no(),fs(),__name(getModelHintLayout,"getModelHintLayout");var SP=["","[118;5u","[118;5u"];function removeAltPCharacter(e){return e.includes("π")?e.replace(/π/g,""):null}function isPrecededByWhitespace(e){return!e||" "===e||"\n"===e||"\t"===e}function getCommandMenuStateFromQuery(e){return isDesignSubmenu(e)?{showMenu:!0,query:e}:e.includes(" ")?{showMenu:!1,query:""}:{showMenu:!0,query:e}}__name(removeAltPCharacter,"removeAltPCharacter"),__name(isPrecededByWhitespace,"isPrecededByWhitespace"),__name(getCommandMenuStateFromQuery,"getCommandMenuStateFromQuery");var bP=__name(()=>K.createElement(ne,{flexDirection:"column",paddingLeft:1},K.createElement(re,{color:mr.DIM,bold:!0},"Available Shortcuts:"),K.createElement(ne,{columnGap:4},K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:mr.DIM},"! for bash mode"),K.createElement(re,{color:mr.DIM},"/ for commands"),K.createElement(re,{color:mr.DIM},"@ for file paths"),K.createElement(re,{color:mr.DIM},"shift + tab to toggle auto-accept")),K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:mr.DIM},"double tap esc to clear input"),K.createElement(re,{color:mr.DIM},"ctrl + j / shift + ⏎ for newline"),K.createElement(re,{color:mr.DIM},"ctrl + g to open in editor"),K.createElement(re,{color:mr.DIM},"ctrl + z to suspend")))),"ShortcutMenu"),EP=__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:v,updateFailedInfo:C,currentProvider:k,currentModel:T,showProviderInfo:_,permissionMode:x="standard",onToggleAutoAccept:A,hintMessage:P,historyManager:I,pendingExitKey:M=null,onOverlayVisibilityChange:N,onDoubleEscapeEmpty:R,onAltP:$,isProcessing:L=!1,ideContextEnabled:D=!0})=>{const[O,F]=J(0),[U,j]=J(!1),[q,B]=J(!1),[z,W]=J(!1),[H,G]=J(!1),[V,Q]=J(""),[Y,oe]=J(null),[ae,le]=J(!1),ce=X(0),ue=X(0),[de,me]=J([]),[pe,ge]=J([]),[he,fe]=J(-1),[ye,we]=J(""),Se=X(!1),be=X(!1),Ee=X(void 0),[ve,Ce]=J(-1),[ke,Te]=J(""),_e=X(0),{isEditorOpen:xe,editorError:Ae,handleOpenInEditor:Pe,clearEditorError:Me}=useExternalEditor({input:e,setInput:n,setInputKey:F,detectedContent:de,setDetectedContent:me,onEditorClose:__name(()=>{Se.current=!1},"onEditorClose")}),Ne=ee(()=>shouldCollapsePastedText(),[]),{handlePaste:Re,resetPasteState:$e,isPasting:Le}=useBracketedPaste({input:e,detectedContent:de,setInput:n,setDetectedImages:ge,setDetectedContent:me,incrementInputKey:__name(()=>F(e=>e+1),"incrementInputKey"),setInitialCursor:__name(e=>{Ee.current=e},"setInitialCursor"),collapsePastedText:Ne}),{context:De,connected:Oe,refresh:Fe,connectionIndicator:Ue}=hP({enabled:D,paused:L}),{stdout:je}=se(),qe=je?.columns??80,{pr:Be}=ZA();Z(()=>{const e=i||H||ae;N?.(e)},[i,H,ae,N]);const ze=te(()=>{ge([]),fe(-1)},[]),We=te(()=>{G(!1),oe(null)},[]),He=te(()=>{n(""),B(!1),We(),Q(""),le(!1),me([]),ze(),we(""),$e(),Ce(-1),Te(""),F(e=>e+1)},[n,$e,ze,We]),Ge=te(()=>{Se.current=!0;const{text:t,cursor:r}=insertTextAt(e,_e.current,"\n");n(t),Ee.current=r,F(e=>e+1),setTimeout(()=>{Se.current=!1},0)},[e,n]);ie(async(t,r)=>{if(-1!==he&&r.leftArrow)return void fe(prevImageIndex({currentIndex:he,imageCount:pe.length}));if(-1!==he&&r.rightArrow)return void fe(nextImageIndex({currentIndex:he,imageCount:pe.length}));if(r.upArrow){if(i||H||ae)return;const t=e.indexOf("\n"),r=-1===t||_e.current<=t;if(shouldSelectImageOnUpArrow({isOnFirstLine:r,imageCount:pe.length,selectedImageIndex:he,historyIndex:ve}))return void fe(pe.length-1);if(-1!==he&&fe(-1),0!==e.length&&-1===ve&&!r)return;const o=I?.count()??0;if(0===o)return;-1===ve&&Te(e);const s=Math.min(ve+1,o-1);return void(s!==ve&&(Ce(s),n(I?.getAt(s)||""),F(e=>e+1)))}if(r.downArrow){if(i||H||ae)return;if(-1===ve)return;const t=e.lastIndexOf("\n");if(!(-1===t||_e.current>t))return;const r=ve-1;return Ce(r),n(-1===r?ke:I?.getAt(r)||""),void F(e=>e+1)}if(""===t||r.ctrl&&"c"===t)return void ze();if(isCtrlKey({inputChar:t,key:r,letter:"g",ctrlCode:7}))return Se.current=!0,void Pe();if(getIsExpandToolShortcut(r,t))return Se.current=!0,n(e),F(e=>e+1),void setTimeout(()=>{Se.current=!1},0);if(isNewlineShortcutKey({inputChar:t,key:r,isPasting:Le()}))return be.current=!0,Ge(),void setTimeout(()=>{be.current=!1},0);if(r.meta&&r.backspace)return void He();if(r.meta&&"w"===t)return Se.current=!0,void He();const o=r.ctrl&&"v"===t||SP.includes(t),s=r.meta&&"v"===t;if(o||s){if(o&&"darwin"===process.platform){const t=e;Se.current=!0;const r=await detectClipboardImage();return r&&(ge(e=>[...e,r]),n(t),F(e=>e+1)),void(Se.current=!1)}}else if(!r.ctrl&&!r.meta||"u"!==t){if(r.ctrl&&"z"===t?.toLowerCase())return W(!0),void setTimeout(()=>{process.kill(process.pid,"SIGTSTP")},100);if(-1!==he&&(r.delete||r.backspace)){const{remainingImages:e,nextSelectedIndex:t}=removeImageAt({images:pe,index:he});return ge([...e]),void fe(t)}if(r.escape){if(-1!==he)return void fe(-1);if(H)return;if(ae)return le(!1),n(ye),void F(e=>e+1);const t=Date.now();return t-ce.current<500?(e.length>0?He():R?.(),ce.current=0,ue.current=0):(ce.current=t,U||q||(ue.current=t)),j(!1),void B(!1)}U&&(r.backspace||r.delete)&&0===e.length&&j(!1)}});const Ve=te(async t=>{if(xe)return;const r=removeAltPCharacter(t);if(null!==r)return n(r),void $?.();const o=processBracketedPaste(t);if((o.isPasteStart||o.isPasteEnd||Le())&&await Re(t))return;if(Se.current)return void(Se.current=!1);-1!==ve&&Ce(-1);const s=1===t.length,l=t.slice(-1);if(s){if("?"===l&&!U)return j(!0),n(""),void F(e=>e+1);if("!"===l&&!q)return j(!1),B(!0),n(""),void F(e=>e+1)}if("/"!==l||H||"/"!==t||(G(!0),Q("")),H)if(t.startsWith("/")){const e=t.substring(1),{showMenu:n,query:r}=getCommandMenuStateFromQuery(e);n?G(!0):We(),Q(r)}else We(),Q("");"@"!==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)}}U&&(t!==e||t.length<e.length)&&j(!1),Ae&&Me(),0===t.length&&(B(!1),We(),Q(""),le(!1),me([]),u(""),we(""),$e()),n(t)},[U,e,n,i,a,H,q,pe,ve,Re,$e,$,Ae,Me,xe,We]),Qe=te(async()=>{if(Fe(),ue.current=0,U)return void j(!1);let n=e.trim();if(!q&&n.startsWith("/")&&d&&"handled"===(await d(n)).status)return I?.add(n),B(!1),We(),Q(""),ze(),me([]),Ce(-1),void Te("");Ce(-1),Te("");let r=[];const o=pe.length>0,s=de.length>0;if(!q&&o&&(r=[...pe]),!q&&s){let e=n;de.forEach((t,n)=>{const r=`[Text#${n+1}]`;e.includes(r)&&(e=e.replace(r,t))}),n=e}n.length>0&&I?.add(n);const i=De?.selection?{lines:De.selection.lineCount,file:De.activeFile?.relativePath?.split("/").pop()??De.activeFile?.path?.split("/").pop()??"unknown",ide:y_[nk()??""]??"IDE"}:void 0;t({input:n,role:q?"bash":"user",images:r,ideContext:De?fP(De):void 0,ideHint:i}),B(!1),We(),Q(""),ze(),me([])},[t,d,U,e,q,pe,de,I,Fe,ze,We]),Ke=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(""),F(e=>e+1)},[n,a,e,i,l,u]),Ye=te(()=>{a(!1),u("")},[a,u]),Je=te(e=>{const t=gx.has(e),r="/design"===e.trimEnd();if(t||r){const t=e.trimEnd();n(t+" "),Q(t.substring(1)+" ")}else We(),Q(""),n(e+" ");F(e=>e+1)},[n,We]),Xe=te(t=>{if("/resume"===t)return I?.add(t),Ce(-1),Te(""),we(e),We(),Q(""),le(!0),n(""),void F(e=>e+1);if("/design help"===t)return We(),Q(""),n(""),F(e=>e+1),I?.add(t),void d?.("/design help");if(px.has(t))return We(),Q(""),I?.add(t),Ce(-1),Te(""),n(""),F(e=>e+1),void d?.(t);const r=gx.has(t),o=hx.has(t);r?Je(t):(We(),Q(""),o?(I?.add(t),Ce(-1),Te(""),n(""),F(e=>e+1),d?.(t)):(n(t+" "),F(e=>e+1)))},[d,n,e,I,Je,We]),Ze=te(()=>{We(),Q(""),n(""),Ce(-1),Te(""),F(e=>e+1)},[n,We]),et=te(e=>{le(!1),n(""),we(""),Ce(-1),Te(""),F(e=>e+1),d&&d(`/resume:${e}`)},[d,n]),tt=te(()=>{le(!1),n(ye),Ce(-1),Te(""),F(e=>e+1)},[ye,n]),nt=te(e=>{_e.current=e,Ee.current=void 0},[]),rt=ee(()=>{const t=Be&&("OPEN"===Be.state||"MERGED"===Be.state);return"auto-accept"===x||"plan"===x||"bypass"===x||Oe||t?!U&&!ae:!U&&0===e.length&&!q&&!ae},[U,e,q,ae,x,Oe,Be]),ot=X(new Map),st=ee(()=>pe.map((e,t)=>{if(ot.current.has(e))return ot.current.get(e)??null;const n=saveTempImage(e,t+1);return ot.current.set(e,n),n}),[pe]),it=__name(()=>U||i||H||ae||z?0:rt||M||q?3:4,"getBottomMargin");return K.createElement(ne,{width:"100%",flexDirection:"column",marginBottom:it()},!ae&&K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(ImageRowsDisplay,{detectedImages:pe,selectedImageIndex:he,imageTempPaths:st,termWidth:qe,inHistory:-1!==ve}),K.createElement(re,{color:q?mr.GREEN:mr.GRAY},Ie.line.repeat(qe)),(()=>{const t=__name(()=>{if(!be.current)return Date.now()-ue.current<100?(ue.current=0,void Ge()):void(i||H||ae||xe||Qe());be.current=!1},"handleTextInputSubmit"),n=__name(n=>K.createElement(TextInput,{key:O,value:e,placeholder:xe?"Save and close the editor to continue...":o,onChange:Ve,onSubmit:t,showCursor:!xe&&r&&-1===he,onCursorChange:nt,initialCursor:Ee.current,prefix:`${q?"!":Ie.pointer} `,prefixColor:q?mr.GREEN:mr.WHITE,singleLine:n?.singleLine,maxWidth:n?.maxWidth}),"renderTextInput");if(H&&T&&"/model"===Y){const e=getModelHintLayout({currentModel:T,terminalWidth:qe});return K.createElement(ne,{flexDirection:"row",width:"100%"},K.createElement(ne,{width:25},n({singleLine:!0,maxWidth:25})),K.createElement(ne,{width:e.descriptionWidth},K.createElement(re,{color:mr.DIM,wrap:"truncate"},e.text)))}return n()})(),K.createElement(re,{color:q?mr.GREEN:mr.GRAY},Ie.line.repeat(qe))),U&&K.createElement(bP,null),z&&K.createElement(ne,{paddingTop:1},K.createElement(re,{color:mr.YELLOW},"Command Code has been suspended. Run `fg` to bring\n\t\t\t\t\t\tCommand Code back.")),i&&K.createElement(eP,{onSelectFile:Ke,onClose:Ye,searchQuery:l}),H&&K.createElement(wx,{onSelectCommand:Xe,onInsertCommand:Je,onClose:Ze,searchQuery:V,onSelectedCommandChange:oe}),ae&&K.createElement(gP,{onSelectSession:et,onClose:tt}),!H&&(rt||M)&&K.createElement(aP,{termWidth:qe,indicatorText:wP(Oe,De,qe),isIDEIndicator:yP(Oe,De),permissionMode:x,prInfo:Be,tasteLearning:g,contextUsage:m,connectionIndicator:Ue,pendingExitKey:M,updateStatus:v,updateFailedInfo:C,currentProvider:k,showProviderInfo:_,isBashMode:q,shareInfo:f,showShareNotification:y,unshareNotificationMessage:w,tasteNotificationMessage:S,creditWarning:E}),Ae&&K.createElement(ne,{paddingLeft:1,flexDirection:"column"},K.createElement(re,{color:mr.YELLOW},Ae)))},"InputBox");Ft(),fs(),Or();var vP=__name(({messages:e})=>0===e.length?null:K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(ne,{marginBottom:0},K.createElement(re,{color:fr,inverse:!0},` Queued (${e.length}) `)),e.map((e,t)=>K.createElement(ne,{key:t},K.createElement(re,{color:mr.DIM},Ie.pointerSmall," "),K.createElement(re,{color:mr.DIM},truncateString({text:e.displayMessage??e.input,maxChars:80}))))),"QueuedMessages"),CP=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:v,updateStatus:C,updateFailedInfo:k,creditWarning:T,currentProvider:_,currentModel:x,showProviderInfo:A,permissionMode:P,onToggleAutoAccept:I,hintMessage:M,historyManager:N,pendingExitKey:R,onResetPendingExitKey:$,onDoubleEscapeEmpty:L,retryAttempt:D,onAltP:O})=>{const[F,U]=J(0),j=X(o);return Z(()=>{R&&o!==j.current&&o.length>0&&$?.(),j.current=o},[o,R,$]),Z(()=>{if(!t)return void U(0);const e=setInterval(()=>{U(e=>e+1e3)},1e3);return()=>{clearInterval(e)}},[t]),K.createElement(ne,{flexDirection:"column"},K.createElement(vP,{messages:e}),K.createElement(ne,{flexDirection:"row",justifyContent:"space-between"},K.createElement(ne,{flexDirection:"column"},(t||n.isExecuting)&&null===D&&K.createElement(jA,{tokens:g,timeElapsed:F,status:n.isExecuting?`Executing: ${n.currentCommand}`:r}),M&&K.createElement(ne,{marginLeft:1},K.createElement(re,{color:mr.DIM}," ","⎿"," ","Tip: ",M)))),K.createElement(EP,{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:v,updateStatus:C,updateFailedInfo:k,creditWarning:T,currentProvider:_,currentModel:x,showProviderInfo:A,permissionMode:P,onToggleAutoAccept:I,hintMessage:M,historyManager:N,pendingExitKey:!R||t||n.isExecuting?null:R,onDoubleEscapeEmpty:L,onAltP:O,isProcessing:t}))});Ft(),tE(),iE(),ao(),fo();var kP=__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(oo,{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(rE,{authState:i,statusMessage:a,browserUrl:l,apiKeyInput:u,setApiKeyInput:d,handleApiKeySubmit:m})},"LoginOverlay");function buildOAuthMetadataUrl(e){const t=new g(e),n="/"===t.pathname?"":t.pathname.replace(/\/+$/,"");return t.pathname=`/.well-known/oauth-authorization-server${n}`,t.search="",t.hash="",t.toString()}function buildOidcMetadataUrl(e){const t=new g(e),n=t.pathname.replace(/\/+$/,"");return t.pathname=`${n}/.well-known/openid-configuration`,t.search="",t.hash="",t.toString()}async function tryFetchAsMetadata(e){try{const t=await fetchWithTimeout(e,{method:"GET",headers:{Accept:"application/json"}});if(!t.ok)return null;const n=await t.json();return n.authorization_endpoint&&n.token_endpoint?{authorizationEndpoint:n.authorization_endpoint,tokenEndpoint:n.token_endpoint,registrationEndpoint:n.registration_endpoint,scopes:n.scopes_supported}:null}catch(t){return dlog(`[MCP] OAuth metadata fetch failed for ${e}`,t),null}}async function discoverOAuthMetadataFromIssuer(e){return await tryFetchAsMetadata(buildOAuthMetadataUrl(e))||await tryFetchAsMetadata(buildOidcMetadataUrl(e))}async function discoverOAuthMetadata(e){const t=new g(e),n=`${t.protocol}//${t.host}`;return await tryFetchAsMetadata(`${n}/.well-known/oauth-authorization-server`)||await tryFetchAsMetadata(`${n}/.well-known/openid-configuration`)}function parseResourceMetadataUrl(e){if(!e)return null;const t=e.match(/resource_metadata\s*=\s*"([^"]+)"|resource_metadata\s*=\s*([^\s,]+)/i);return t?t[1]??t[2]??null:null}async function fetchProtectedResourceMetadata(e){try{const t=await fetchWithTimeout(e,{method:"GET",headers:{Accept:"application/json"}});if(!t.ok)return null;const n=await t.json();return{authorizationServers:n.authorization_servers,scopesSupported:n.scopes_supported}}catch(e){return dlog("[MCP] Protected resource metadata fetch failed",e),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:NS,capabilities:{},clientInfo:RS}})});if(401===t.status||403===t.status){const n=parseResourceMetadataUrl(t.headers?.get?.("www-authenticate")??null);if(n){const e=await fetchProtectedResourceMetadata(n),t=e?.authorizationServers?.[0];if(t){const n=await discoverOAuthMetadataFromIssuer(t);if(n)return e?.scopesSupported&&(n.scopes=e.scopesSupported),{requiresAuth:!0,metadata:n}}}return{requiresAuth:!0,metadata:await discoverOAuthMetadata(e)||void 0}}return{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}async function discoverAndAuthenticate({serverName:e,serverUrl:t,onStatus:n}){const r=n??(()=>{});r("Probing server for OAuth requirements...");const o=await checkServerAuthRequirements(t);if(o.error)return{success:!1,error:o.error};if(!o.requiresAuth)return{success:!1,error:"Server does not require authentication"};if(!o.metadata)return{success:!1,error:"Server returned 401 but did not advertise OAuth metadata. Add `oauth` config manually via `mcp add-json`."};const{authorizationEndpoint:s,tokenEndpoint:i,registrationEndpoint:a,scopes:l}=o.metadata;if(!a)return{success:!1,error:"Server requires pre-registered OAuth credentials (no Dynamic Client Registration endpoint advertised). Register an OAuth client with the server, then add it via `mcp add-json` with an `oauth.clientId` field."};const u=`http://${XS}:${JS}/callback`;r("Registering OAuth client...");const d=await registerOAuthClient({registrationEndpoint:a,clientName:RS.name,redirectUris:[u]});if(!d)return{success:!1,error:"Dynamic client registration failed at "+a};const m={authorizationUrl:s,tokenUrl:i,clientId:d.clientId,clientSecret:d.clientSecret,scopes:l},g=await performOAuthFlow(e,t,m,{onStatus:n});return g.success&&(await storeDiscoveredClient(e,{authorizationUrl:s,tokenUrl:i,clientId:d.clientId,scopes:l}),d.clientSecret?await storeClientSecret(e,d.clientSecret):await deleteClientSecret(e)),g}Ft(),Ft(),zS(),DS(),GS(),WS(),QS(),ob(),lb(),cb(),Ft(),lb(),cb(),jS(),rb(),Ft(),YS(),DS(),er(),__name(buildOAuthMetadataUrl,"buildOAuthMetadataUrl"),__name(buildOidcMetadataUrl,"buildOidcMetadataUrl"),__name(tryFetchAsMetadata,"tryFetchAsMetadata"),__name(discoverOAuthMetadataFromIssuer,"discoverOAuthMetadataFromIssuer"),__name(discoverOAuthMetadata,"discoverOAuthMetadata"),__name(parseResourceMetadataUrl,"parseResourceMetadataUrl"),__name(fetchProtectedResourceMetadata,"fetchProtectedResourceMetadata"),__name(checkServerAuthRequirements,"checkServerAuthRequirements"),__name(registerOAuthClient,"registerOAuthClient"),Ft(),DS(),rb(),jS(),__name(discoverAndAuthenticate,"discoverAndAuthenticate"),Or(),io();var TP=__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||"http"===e.config.transport)&&(await hasTokens(e.name)?s="authenticated":e.config.oauth&&(s="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:mr.GREEN},Ie.tick);case"authenticated":return K.createElement(re,{color:mr.CYAN},Ie.tick);case"requires_auth":return K.createElement(re,{color:mr.YELLOW},Ie.warning);case"error":return K.createElement(re,{color:mr.RED},Ie.cross);default:return K.createElement(re,{color:mr.GRAY},Ie.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:mr.CYAN,loading:!0});try{if(!await updateMcpServerStatus({name:h.name,enabled:!0,scope:h.scope}))return void d({text:`${Ie.cross} Failed to enable ${h.name}, server may no longer exist in ${h.scope} scope`,color:mr.YELLOW});await m(),d({text:`${Ie.tick} Enabled ${h.name}`,color:mr.GREEN})}catch(e){d({text:`${Ie.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:mr.RED})}}else{d({text:`Disabling ${h.name}...`,color:mr.CYAN,loading:!0});try{const e=getMcpConnectionManager();if(!await updateMcpServerStatus({name:h.name,enabled:!1,scope:h.scope}))return void d({text:`${Ie.cross} Failed to disable ${h.name}, server may no longer exist in ${h.scope} scope`,color:mr.YELLOW});await e.disconnectServer(h.name),await m(),d({text:`${Ie.tick} Disabled ${h.name}`,color:mr.GREEN})}catch(e){d({text:`${Ie.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:mr.RED})}}else l("confirm-remove");else{if(!(h.config.oauth||"http"===h.config.transport&&h.config.url))return void d({text:"Authentication requires an http server with a url",color:mr.YELLOW});d({text:`Authenticating ${h.name}...`,color:mr.CYAN,loading:!0});try{let e;if(h.config.oauth){const t={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};e=await performOAuthFlow(h.name,h.config.url??"",t,{onStatus:__name(()=>{},"onStatus")})}else e=await discoverAndAuthenticate({serverName:h.name,serverUrl:h.config.url});if(e.success){d({text:`${Ie.tick} Authenticated with ${h.name}`,color:mr.GREEN});try{const e=getMcpConnectionManager();await e.ensureServerConnection(h.name)}catch{}await m()}else d({text:`${Ie.cross} Auth failed: ${e.error}`,color:mr.RED})}catch(e){d({text:`${Ie.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:mr.RED})}}else{d({text:`Connecting ${h.name}...`,color:mr.CYAN,loading:!0});try{const e=getMcpConnectionManager();await e.ensureServerConnection(h.name),d({text:`${Ie.tick} Connected to ${h.name}`,color:mr.GREEN}),await m()}catch(e){d({text:`${Ie.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:mr.RED})}}else d({text:"Already authenticated",color:mr.GREEN});else d({text:"Already connected",color:mr.GREEN});else l("list")},"handleActionSelect"),v=__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:`${Ie.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:mr.RED}),l("actions")}else l("actions")},"handleRemoveConfirm");if(r)return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:pr,bold:!0},"Manage MCP servers"),K.createElement(re,{color:mr.DIM},"Loading..."));if("confirm-remove"===a&&h)return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:mr.RED,bold:!0},"Remove ",h.name,"?"),K.createElement(re,{color:mr.DIM},"This will remove the server from ",h.scope," ","config."),K.createElement(ne,{marginTop:1},K.createElement(pt,{items:[{label:"Yes, remove",value:"yes"},{label:"Cancel",value:"no"}],onSelect:v,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:mr.WHITE},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?mr.WHITE:mr.GRAY}," ",t)})),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.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;t&&e.push({label:"Enable",value:"enable"}),!t&&n&&e.push({label:"Connected",value:"connected"}),t||n||e.push({label:"Connect",value:"connect"});const o=!t&&(h.config.oauth||"http"===h.config.transport);return o&&r&&e.push({label:"Authenticated",value:"authenticated"}),o&&!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:pr,bold:!0},h.name),K.createElement(ne,null,f(h.status),K.createElement(re,{color:mr.DIM}," ",y(h))),K.createElement(ne,{marginTop:1},K.createElement(pt,{items:e,onSelect:E,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:mr.WHITE},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?mr.WHITE:mr.GRAY}," ",t)})),u&&K.createElement(ne,{marginTop:1},u.loading&&K.createElement(re,{color:u.color},K.createElement(Be,{type:"dots"})," "),K.createElement(re,{color:u.color},u.text)),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"↑↓ navigate · Enter to select · Esc to go back")))}let C=null;return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:pr,bold:!0},"Manage MCP servers"),K.createElement(re,{color:mr.DIM},t.length," ",1===t.length?"server":"servers"),0===t.length?K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(re,{color:mr.DIM},"No MCP servers configured."),K.createElement(re,{color:mr.DIM},'Use "cmd mcp add" to add a server.'),K.createElement(ro,{url:"https://commandcode.ai/docs/mcp",text:"View MCP Docs ↗",color:mr.CYAN,dimColor:!0})):K.createElement(ne,{marginTop:1,flexDirection:"column"},g.map((e,t)=>{const n=e.scope!==C;C=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:mr.DIM}," ","(",S(e.scope),")")),K.createElement(ne,{paddingLeft:1},K.createElement(re,{color:r?mr.WHITE:mr.GRAY},r?"› ":" "),K.createElement(re,{color:r?mr.WHITE:void 0,bold:r},e.name),K.createElement(re,{color:mr.DIM}," · "),f(e.status),K.createElement(re,{color:"connected"===e.status?mr.GREEN:"authenticated"===e.status?mr.CYAN:"requires_auth"===e.status?mr.YELLOW:mr.GRAY}," ",y(e))))})),u&&K.createElement(ne,{marginTop:1},u.loading&&K.createElement(re,{color:u.color},K.createElement(Be,{type:"dots"})," "),K.createElement(re,{color:u.color},u.text)),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},0===t.length?"Esc to close":"↑↓ navigate · Enter to select · Esc to close")))},"McpManager");Ft(),Cn(),Kn(),Or();var _P=__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:mr.DIM},"Loading memory files..."));if(a)return K.createElement(ne,{paddingLeft:1,paddingTop:1},K.createElement(re,{color:mr.RED},Ie.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:mr.GRAY,paddingTop:1,paddingBottom:1,paddingLeft:2,paddingRight:2},K.createElement(ne,null,K.createElement(re,{color:mr.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?mr.WHITE:mr.DIM},r===t?`${qn} `:" ",e.label))),K.createElement(ne,{flexDirection:"column"},m.map((e,t)=>K.createElement(re,{key:t,color:r===t?mr.WHITE:mr.DIM},e.description)))))},"MemorySelector");function AutoCompactMessage({content:e}){return K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:mr.DIM},Ie.bullet," ",e))}function TasteSkipMessage(){return K.createElement(ne,{marginTop:1,marginBottom:1},K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:gr.BADGE_BG,color:gr.BADGE_FG,bold:!0},e_)),K.createElement(re,{color:mr.DIM}," Skipped. Run "),K.createElement(re,{color:Ir.CODE},"/learn-taste"),K.createElement(re,{color:mr.DIM}," or "),K.createElement(re,{color:Ir.CODE},"cmd learn-taste"),K.createElement(re,{color:mr.DIM}," anytime."))}function HookWarningMessage({content:e}){return K.createElement(ne,null,K.createElement(re,{color:mr.YELLOW},Ie.warning),K.createElement(ne,{marginLeft:1,flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:mr.YELLOW},e)))}function HookLineMessage({content:e}){return K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:mr.DIM},` ${e}`))}function HookLineContinuationMessage({content:e}){return K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:mr.DIM},` ${e}`))}function HookFrameMessage({lines:e,header:t}){return K.createElement(ne,{flexDirection:"column"},void 0!==t&&K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:mr.DIM},` ${t}`)),e.map((e,t)=>K.createElement(ne,{key:t,flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:mr.DIM},e.primary?` └ ${e.text}`:` ${e.text}`))))}function InfoMessage({content:e,metadata:t}){return t?.isTasteSkip?K.createElement(TasteSkipMessage,null):t?.isAutoCompact?K.createElement(AutoCompactMessage,{content:e}):t?.hookFrame&&t.hookFrame.length>0?K.createElement(HookFrameMessage,{lines:t.hookFrame,header:t.hookFrameHeader}):t?.isHookLine?K.createElement(HookLineMessage,{content:e}):t?.isHookLineContinuation?K.createElement(HookLineContinuationMessage,{content:e}):t?.isHookWarning?K.createElement(HookWarningMessage,{content:e}):t?.isSuccess?K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:mr.GREEN},Ie.tick," ",e)):K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:mr.DIM},Ie.bullet," ",e))}Ft(),Or(),__name(AutoCompactMessage,"AutoCompactMessage"),__name(TasteSkipMessage,"TasteSkipMessage"),__name(HookWarningMessage,"HookWarningMessage"),__name(HookLineMessage,"HookLineMessage"),__name(HookLineContinuationMessage,"HookLineContinuationMessage"),__name(HookFrameMessage,"HookFrameMessage"),__name(InfoMessage,"InfoMessage"),Ft(),Cn(),no(),Qb(),Io(),fo(),so(),Or(),Ft(),Or();var xP=yt()?"⠶":"#";function AssistantMessage({content:e}){return K.createElement(ne,null,K.createElement(re,{color:Tr},xP),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=mr.GREEN,s=Ie.tick,i="default",a=t||"(No output)";n&&(o=mr.YELLOW,s=Ie.arrowRight,i=mr.YELLOW,a="Executing…"),r&&(o=mr.RED,s=Ie.cross,i=mr.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:mr.GRAY},"$ "),K.createElement(re,{color:o,bold:!0},e)),K.createElement(ne,{columnGap:1,marginLeft:1},K.createElement(re,{color:Rr},l),K.createElement(re,{color:i,wrap:"wrap"},a))))}function CommandResultMessage({message:e,details:t,hasError:n=!1}){const r=n?mr.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:Rr},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:mr.DIM},"See ",t)))}function ErrorMessage({content:e}){const t=e.includes("Interrupted by user");return K.createElement(ne,null,K.createElement(re,{color:mr.RED},t?Ie.pointer:Ie.warning),K.createElement(ne,{marginLeft:1,flexGrow:1,flexShrink:1,minWidth:0},t?K.createElement(re,{color:mr.RED,wrap:"wrap"},e):K.createElement(Markdown,{color:mr.RED},e)))}__name(AssistantMessage,"AssistantMessage"),Ft(),Or(),__name(BashMessage,"BashMessage"),Ft(),Or(),__name(CommandResultMessage,"CommandResultMessage"),Ft(),Or(),__name(ErrorMessage,"ErrorMessage"),Ft(),Or();var AP={connected:{char:Ie.tick,color:mr.GREEN},installed:{char:Ie.tick,color:mr.GREEN},up_to_date:{char:Ie.tick,color:mr.GREEN},needs_reload:{char:Ie.circle,color:mr.YELLOW},failed:{char:Ie.cross,color:mr.RED},not_in_ide:{char:Ie.circle,color:mr.YELLOW}};function IDEStatusMessage({status:e,ide:t,details:n}){const{prefix:r,ide:o,suffix:s}=getStatusHeadline(e,t),i=AP[e];return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,K.createElement(re,null,K.createElement(re,{color:i.color},i.char),K.createElement(re,null," ",r),o&&K.createElement(re,{color:mr.CYAN},o),s&&K.createElement(re,null,s))),n?.map((e,t)=>K.createElement(re,{key:t,color:mr.DIM}," ",e)))}function ReasoningMessage({content:e,expandedOutput:t,expandKey:n,isStreaming:r=!1}){const o=e?Math.max(1,Math.round(e.length/500)):1,s=Boolean(e),i=(s?e.split("\n"):[]).length,a=`${r?"Thinking…":`Thought for ${o} second${1!==o?"s":""}`}${r&&!t&&i>0?` (${i} line${1!==i?"s":""})`:""}`,l=t&&s,u=!t&&s,d=r&&t&&e.length>560,m=d?e.length-560:0,g=80*Math.floor(m/80),h=d?(e.slice(0,g).match(/\n/g)??[]).length:0,f=d?e.slice(g):e;return K.createElement(ne,{flexDirection:"column",width:"90%"},K.createElement(ne,null,K.createElement(re,{color:hr},"✻"," "),K.createElement(re,{color:hr},u?`${a} `:a),u&&K.createElement(BracketWrap,{color:mr.DIM},`${n}+o to expand`)),l&&d&&K.createElement(ne,{marginLeft:2},K.createElement(re,{color:mr.DIM},h>0?`… (${h} more line${1!==h?"s":""})`:"…")),l&&K.createElement(ne,{marginLeft:2,flexDirection:"column"},K.createElement(re,{color:hr,wrap:"wrap",italic:!0},f)))}__name(IDEStatusMessage,"IDEStatusMessage"),Ft(),Or(),__name(ReasoningMessage,"ReasoningMessage"),Ft(),Ft(),Cn();function HelpMessage(){const e=getInvokedCommandName(),t=ee(()=>Ek.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:mr.GRAY}," v","0.32.5")),K.createElement(re,{color:mr.GRAY},fk)),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},bk.map(t=>K.createElement(ne,{key:t.key},K.createElement(re,null,t.key.replace(/^cmd/,e).padEnd(yk)),K.createElement(re,{color:mr.GRAY},t.description))))),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Commands"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},vk.map(t=>K.createElement(ne,{key:t.key},K.createElement(re,null,t.key.replace(/^cmd/,e).padEnd(yk)),K.createElement(re,{color:mr.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(yk)),K.createElement(re,{color:mr.GRAY},e.description))))),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Keyboard Shortcuts"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},Sk.map(e=>K.createElement(ne,{key:e.key},K.createElement(re,null,e.key.padEnd(yk)),K.createElement(re,{color:mr.GRAY},e.description))))),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Examples"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},kk.map(t=>K.createElement(ne,{key:t.key},K.createElement(re,null,t.key.replace(/^cmd/,e).padEnd(yk)),K.createElement(re,{color:mr.GRAY},t.description))))),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.CYAN},Ie.pointer),K.createElement(re,{color:mr.GRAY}," ",Tk.replace(/cmd/,e))),K.createElement(ne,{flexDirection:"column"},K.createElement(re,{bold:!0},"Links"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},Ck.map(e=>K.createElement(ne,{key:e.key},K.createElement(re,null,e.key.padEnd(yk)),K.createElement(re,{color:mr.CYAN},e.description))))))}function SystemMessage({content:e}){return e.includes("KEYBOARD SHORTCUTS")&&e.includes("COMMANDS")?K.createElement(HelpMessage,null):K.createElement(ne,{flexDirection:"column"},K.createElement(re,{wrap:"wrap"},K.createElement(Markdown,null,e)))}Or(),ZS(),fo(),__name(HelpMessage,"HelpMessage"),__name(SystemMessage,"SystemMessage"),Ft(),Kn(),mo(),Or();var PP={"Interrupted by user":"Interrupted by user","Insufficient credits":Un};function UserMessage({content:e,images:t,imageCount:n=0,ideHint:r}){const o="Interrupted by user"===e,s="Insufficient credits"===e,i=e.startsWith("Error:"),a=o||s||i,l=a&&PP[e]||e,u=null!=t?t.length:n,d=X(null);null===d.current&&t&&t.length>0&&(d.current=t.map((e,t)=>saveTempImage(e,t+1)));const m=d.current??[];return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{backgroundColor:a?void 0:kr.BG,paddingRight:1},K.createElement(re,{color:a?mr.RED:kr.POINTER,bold:!a},Ie.pointer),K.createElement(ne,{marginLeft:1},K.createElement(re,{color:a?mr.RED:mr.WHITE,wrap:"wrap"},l))),u>0&&K.createElement(ne,{marginLeft:1},K.createElement(re,{color:mr.DIM},"⎿"," ",Array.from({length:u},(e,t)=>{const n=m[t],r=`[Image #${t+1}]`;return null!=n?createOSC8Link(`file://${n}`,r,!1):r}).join(" "))),r&&!a&&K.createElement(ne,{marginLeft:2},K.createElement(re,{color:Rr},JT),K.createElement(re,{color:mr.DIM}," ","Selected ",r.lines," ",1===r.lines?"line":"lines"," from"," ",r.file," in ",r.ide)))}function renderFeedEntry(e,t){if("user"===e.role){const t=Array.isArray(e.metadata?.images)?e.metadata.images:void 0,n=e.metadata?.ideHint;return K.createElement(UserMessage,{content:e.input,images:t,ideHint:n})}return"assistant"===e.role?K.createElement(AssistantMessage,{content:e.input}):"reasoning"===e.role?K.createElement(ReasoningMessage,{content:e.input,expandedOutput:t,expandKey:"ctrl",isStreaming:"running"===e.metadata?.status}):"tool"===e.role?K.createElement(ToolMessage,{name:Bb(e.name||""),input:e.input,output:e.output||"",isPending:Ub(e),hasError:Fb(e),metadata:e.metadata,expandedOutput:t}):"bash"===e.role?K.createElement(BashMessage,{command:e.command||"",output:e.output||"",isPending:Ub(e),hasError:Fb(e)}):"system"===e.role?K.createElement(SystemMessage,{content:e.input}):"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=findModelById(e);if(t){const e=t.name.toLowerCase().replaceAll(" ","-");return"free"===t.badge?`${e} (free)`:e}return e}function getProviderShortName(e){return e?fn[e]?.shortLabel??e.slice(0,4):""}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:Cr},o),K.createElement(BracketedText,{text:n,color:Cr}),K.createElement(re,{color:Cr},o))}__name(UserMessage,"UserMessage"),__name(renderFeedEntry,"renderFeedEntry"),__name(getModelShortName,"getModelShortName"),__name(getProviderShortName,"getProviderShortName"),__name(TranscriptDivider,"TranscriptDivider");var IP=K.memo(({feed:e,showHeader:t=!1,staticKey:n,expandedToolOutput:r=!1,currentModel:o,currentProvider:s,hiddenCount:i=0})=>{const a=i>0?{role:"transcript-divider",count:i}:null,l=[...t?["header"]:[],...a?[a]:[],...e],u=useTerminalWidth(),d=ee(()=>Yx(u),[u]),m=ee(()=>tA(u),[u]),g=ee(()=>getPackageJson().version||"0.0.0",[]),h=ee(()=>getGitHeaderInfo(),[]),f=ee(()=>{const e=process.cwd(),t=process.env.HOME??process.env.USERPROFILE??"";return e.replace(t,"~")},[]),y=o?getModelShortName(o):"sonnet-4.6",w="taste-1",S=ee(()=>{if(!o)return"";if(!modelSupportsReasoningEffort(o))return"";const e=getReasoningEffort(o);return e?` with ${e} effort`:""},[o,n]),E=isInternalTeamFlagEnforced()&&!process.env.CMD_DEMO,v=E?" · co":"",C=E&&s?` · ${getProviderShortName(s)}`:"";return K.createElement(oe,{items:l,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:u});if("header"===e)return"compact"===m?K.createElement(ne,{key:"header",marginBottom:1,flexDirection:"row"},K.createElement(ne,{width:Zx,flexShrink:0},K.createElement(nA,null,Xx)),K.createElement(ne,{flexDirection:"column",marginLeft:2},K.createElement(ne,null,K.createElement(re,{bold:!0},"Command Code"),K.createElement(re,{color:Cr}," ","v",g)),K.createElement(re,{color:Cr},"models: ",y,S," ·"," ",w,v),K.createElement(re,{color:Cr},f,h&&h.isLocal&&h.branch&&` (${h.branch})`))):K.createElement(ne,{key:"header",marginBottom:1,flexDirection:"column"},K.createElement(nA,null,d.trimEnd()),K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(ne,null,K.createElement(re,{color:Cr},"# "),K.createElement(re,{bold:!0},"Command Code"),K.createElement(re,{color:Cr}," v",g)),K.createElement(re,{color:Cr},"# models: ",y,S," · ",w,C,v),K.createElement(ne,null,K.createElement(re,{color:Cr},"# ",f,h&&h.isLocal&&h.branch&&K.createElement(re,{color:Cr}," ","(branch:"," ",h.branch,")")))));const t=e,n=renderFeedEntry(t,r);return K.createElement(ne,{key:t.id,paddingBottom:1,width:"90%"},n)})});Ft(),Qb(),yo(),Or();var MP=Y(__name(function LiveAgentStatusInner2({entry:e}){const t=Bb(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:br.BG,color:br.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:mr.GRAY},"Running (",formatTime2(i)," |"," ",formatTokens(s),")",l)),a.length>0&&K.createElement(ne,{flexDirection:"column",marginLeft:1},a.map((e,t)=>{const n=Bb(e.name);return K.createElement(ne,{key:t,columnGap:1},K.createElement(re,{color:mr.GRAY},"⎿"),K.createElement(re,{color:mr.GRAY}," ",n),e.input&&K.createElement(re,{color:mr.GRAY},"(",e.input,")"))})))},"LiveAgentStatusInner")),NP=Y(__name(function LiveAgentStatus2({entry:e}){return"tool"!==e.role?null:K.createElement(MP,{entry:e})},"LiveAgentStatus"));Ft(),Cn(),no(),so(),yo(),fo(),Or(),Ft(),Or();var RP={low:"Fast responses with lighter reasoning",medium:"Balances speed and reasoning depth for everyday tasks",high:"Greater reasoning depth for complex problems",xhigh:"Extra reasoning depth for complex problems",max:"Maximum reasoning budget for the hardest problems"},$P={value:void 0,label:"Default",description:"Use the provider default reasoning level"},LP=__name(({modelLabel:e,supportedEfforts:t,currentEffort:n,onSelect:r,onCancel:o})=>{const s=ee(()=>[$P,...t.map(e=>({value:e,label:e,description:RP[e]}))],[t]),i=ee(()=>{if(void 0===n)return 0;const e=s.findIndex(e=>e.value===n);return e>=0?e:0},[s,n]),a=__name((e,t)=>`${e+1}. ${t}`,"labelText"),l=ee(()=>Math.max(...s.map((e,t)=>a(t,e.label).length))+4,[s]),{cursor:u}=useListNavigation({items:s,onSelect:__name(e=>r(e.value),"onSelect"),onCancel:o,initialIndex:i,searchQuery:"",onSearchChange:__name(()=>{},"onSearchChange"),disableSearch:!0});return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,{marginBottom:1},K.createElement(re,{color:pr,bold:!0},`Select reasoning effort for ${e}`)),K.createElement(ne,{flexDirection:"column"},s.map((e,t)=>{const r=t===u,o=e.value===n;return K.createElement(ne,{key:e.label},K.createElement(re,{color:mr.CYAN},r?`${Ie.pointer} `:" "),K.createElement(re,{color:r?mr.CYAN:o?mr.GREEN:mr.WHITE},a(t,e.label).padEnd(l)),K.createElement(re,{color:mr.DIM},e.description),o&&K.createElement(re,{color:mr.GREEN}," ",Ie.tick))})),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"↑/↓ navigate · enter to select · esc to go back")))},"ReasoningEffortSelector");er();var DP="Loading plan info…",OP=__name(e=>[{text:e.name,weight:100},{text:e.label,weight:50},{text:e.provider,weight:25},{text:e.description||"",weight:10}],"MODEL_SEARCH_FIELDS");function searchGroups2(e,t){if(!t.trim())return e;const n=[];for(const r of e){const e=fuzzyFilter(r.models,t,OP);e.length>0&&n.push({...r,models:e})}return n}function flattenGroups(e){const t=[];for(const n of e)for(const e of n.models)t.push({providerId:n.providerId,model:e});return t}function groupByModelProvider2(e,t){return groupModelsByDisplayOrder(e).map(e=>({providerId:t,label:e.label,models:e.models}))}__name(searchGroups2,"searchGroups"),__name(flattenGroups,"flattenGroups"),__name(groupByModelProvider2,"groupByModelProvider");var FP=__name(({onSelect:e,onCancel:t,currentModel:n,currentProvider:r,planId:o,purchasedCredits:s=0,freeCredits:i=0,refreshBanner:a})=>{const[l,u]=J(""),[d,m]=J(null),[g,h]=J(()=>new Set),f=ee(()=>isInternalTeamFlagEnforced(),[]),y=ee(()=>f?yn:groupByModelProvider2(wn.flatMap(e=>e.models),fn["command-code"].id),[f]),w=ee(()=>searchGroups2(y,l),[y,l]),S=ee(()=>flattenGroups(w),[w]),E=void 0!==o,v=ee(()=>E?null:getCachedBillingContext(),[E]),[C,k]=J(v),[T,_]=J(!E&&!v);Z(()=>{if(E)return;if(C)return;let e=!0;return getBillingContext().then(t=>{e&&(k(t),_(!1))}),()=>{e=!1}},[E,C]);const x=!E&&!0===C?.fetchFailed,A=E?o:C?.planId??null,P=E?s:C?.purchasedCredits??0,I=E?i:C?.freeCredits??0,M=f?fn.anthropic.id:fn["command-code"].id,N=r??M,R=n?Math.max(0,S.findIndex(e=>e.model.id===n&&e.providerId===N)):0,[$,L]=J("model"),[D,O]=J(null),{cursor:F,error:U,setError:j}=useListNavigation({items:S,onSelect:__name(t=>{const n=getSupportedEfforts(t.model.id);if(n&&n.length>0)return O(t),void L("effort");e(t.model.id,t.providerId)},"onSelect"),onCancel:t,initialIndex:R,searchQuery:l,onSearchChange:u,isActive:"model"===$,validate:__name(e=>{if(g.has(e.providerId))return`Run /provider to authenticate with ${getProviderConfig(e.providerId)?.displayName??e.providerId} first`;if(d&&!f){const t=fn[d]?.supportedModelProviders;if(t&&!t.includes(e.model.provider))return`${fn[d]?.label??d} does not support ${e.model.provider} models. Switch provider via /provider.`}if(T)return DP;const t=checkModelAccess({model:{id:e.model.id,provider:e.model.provider,name:e.model.name},planId:A,purchasedCredits:P,freeCredits:I});return t.allowed?null:t.errorMessage??"Model not available for your plan"},"validate")}),q=X(!1),B=__name(t=>{if(!D||q.current)return;q.current=!0;const{model:r,providerId:o}=D,s=getReasoningEffort(r.id),i=t!==s,l=r.id===n;(async()=>{try{i&&(await setReasoningEffort({modelId:r.id,effort:t}),l&&a?.())}catch(e){dlog(`[Model] Failed to persist reasoning effort: ${e}`)}finally{e(r.id,o)}})()},"handleEffortSelect"),z=__name(()=>{q.current||(O(null),L("model"))},"handleEffortCancel");if(Z(()=>{if(T)return;if(U!==DP)return;const e=S[F];if(!e||x)return void j(null);const t=checkModelAccess({model:{id:e.model.id,provider:e.model.provider,name:e.model.name},planId:A,purchasedCredits:P,freeCredits:I});j(t.allowed?null:t.errorMessage??"Model not available for your plan")},[T,x,U,j,S,F,A,P,I]),Z(()=>{(async()=>{await isOAuthEnforced()&&m(await getConfiguredProvider())})()},[]),Z(()=>{(async()=>{const e=new Set(y.map(e=>e.providerId)),t=new Set;for(const n of e){const e=getProviderConfig(n);e?.requiresAuth&&e.checkAuth&&(await e.checkAuth()||t.add(n))}h(t)})()},[y]),"effort"===$&&D){const e=getSupportedEfforts(D.model.id)??[];return K.createElement(LP,{modelLabel:D.model.label,supportedEfforts:e,currentEffort:getReasoningEffort(D.model.id),onSelect:B,onCancel:z})}let W=0;return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:pr,bold:!0},"Select model")),K.createElement(ne,{marginBottom:1},K.createElement(re,{dimColor:!0},f?"Select a model and provider. Sets the default for new sessions; other open sessions are unaffected. Provider is saved.":"Switch between Command Code models. Sets the default for new sessions; other open sessions are unaffected.")),K.createElement(ne,{marginBottom:2,flexDirection:"column",width:"100%"},K.createElement(lA,{query:l,resultCount:l?S.length:void 0,placeholder:"Type to search models..."})),0===S.length?K.createElement(ne,{marginY:1},K.createElement(re,{color:mr.GRAY},'No models match "',l,'"')):K.createElement(ne,{flexDirection:"column"},w.map((e,t)=>{const r=W;return W+=e.models.length,K.createElement(ne,{key:`${e.providerId}-${e.label}`,flexDirection:"column",marginTop:t>0?1:0},f?K.createElement(re,{bold:!0,color:pr},e.label):K.createElement(re,{bold:!0,dimColor:!0},e.label),e.models.map((t,o)=>K.createElement(VA,{key:`${e.providerId}-${e.label}-${t.id}`,model:t,providerId:e.providerId,isHighlighted:r+o===F,isCurrent:t.id===n&&e.providerId===N,showProviderLabel:!!f&&void 0})))})),U&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.GRAY},U)),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"type to search · ↑/↓ navigate · enter to select"),l?K.createElement(re,{color:mr.DIM}," · esc to clear"):K.createElement(re,{color:mr.DIM}," · esc to cancel")))},"ModelSelector");Ft(),no(),so(),er();var UP=__name(({currentModel:e,onClose:t,refreshBanner:n})=>{const r=getSupportedEfforts(e)??[],o=findModelById(e)?.label??getModelDisplayName(e),s=X(!1),i=__name(r=>{if(s.current)return;s.current=!0;const o=r!==getReasoningEffort(e);(async()=>{try{o&&(await setReasoningEffort({modelId:e,effort:r}),n())}catch(e){dlog(`[Effort] Failed to persist reasoning effort: ${e}`)}finally{t()}})()},"handleSelect"),a=__name(()=>{s.current||t()},"handleCancel");return K.createElement(LP,{modelLabel:o,supportedEfforts:r,currentEffort:getReasoningEffort(e),onSelect:i,onCancel:a})},"EffortSelector");Ft(),fo(),Or();var jP=__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:mr.DIM},"Current: "),K.createElement(re,{color:mr.GREEN},getProviderDisplayName(n)),i&&K.createElement(re,{color:mr.YELLOW}," ","[OAuth enforced]"))),K.createElement(ne,{marginBottom:0},K.createElement(re,{color:mr.DIM},"Available Providers:")),K.createElement(pt,{items:r,onSelect:o,initialIndex:s>=0?s:0,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:e?mr.CYAN:mr.GRAY,bold:e},e?Ie.triangleRightSmall:" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?mr.CYAN:mr.GRAY,bold:e},` ${t}`)}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.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:Pr,dimColor:!0},"Connection Issue. Retrying (attempt ",e,")",r))}Ft(),Or(),__name(RetryMessage,"RetryMessage"),Ft(),fs(),Kn(),Or();var qP=[{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"}],BP=__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?qP:qP.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:pr,bold:!0},"Rewind"),K.createElement(re,{color:mr.DIM},"No checkpoints available. Start a conversation to create checkpoints."),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"Press "),K.createElement(re,{color:mr.DIM,bold:!0},"Esc"),K.createElement(re,{color:mr.DIM}," to close")));if("mode"===l&&d)return K.createElement(ne,{flexDirection:"column",paddingLeft:2,paddingTop:1},K.createElement(re,{color:pr,bold:!0},"Rewind"),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.DIM},"Restore to: "),K.createElement(re,{color:mr.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?pr:void 0},n?`${qn} `:" "),K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:n?pr:mr.WHITE},e.label),K.createElement(re,{color:mr.DIM},e.description))),!r&&K.createElement(re,null," "))})),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"Press "),K.createElement(re,{color:mr.DIM,bold:!0},"Enter"),K.createElement(re,{color:mr.DIM}," to confirm, "),K.createElement(re,{color:mr.DIM,bold:!0},"Esc"),K.createElement(re,{color:mr.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:pr,bold:!0},"Rewind"),K.createElement(re,{color:mr.DIM},"Select a checkpoint to restore your session"),r.length>8&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.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?pr:void 0},s?`${qn} `:" "),K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,K.createElement(re,{color:s?pr:mr.WHITE},truncateString({text:e.userPrompt||"(no prompt)",maxChars:60})),K.createElement(re,{color:mr.DIM}," • "),K.createElement(re,{color:mr.DIM},getRelativeTimeString({timestamp:e.timestamp}),u&&" (latest)")),K.createElement(re,{color:mr.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:mr.DIM},"Press "),K.createElement(re,{color:mr.DIM,bold:!0},"Enter"),K.createElement(re,{color:mr.DIM}," to select, "),K.createElement(re,{color:mr.DIM,bold:!0},"Esc"),K.createElement(re,{color:mr.DIM}," to cancel")))},"RewindSelector");Ft(),Or();var zP=[{label:"Complete brief",desc:"If the target, goal, audience, or artifact is clear, act without asking."},{label:"Composition",desc:"Choose layout from the work pattern: monitor, operate, compare, configure, learn, decide, or explore."},{label:"Scope",desc:"Broad prompts get the full mode pass. Narrow prompts stay narrow."},{label:"Truth",desc:"Only claim changes that exist in files and are visible or verifiable."},{label:"Templates",desc:"design-html and report-html are documentation templates, not UI inspiration."},{label:"Reports",desc:"Follow-up modes read markdown reports, apply relevant findings, then still run their own full mode pass."}],WP=['/design redesign "Make this dashboard feel like an operator console"','/design motion "Animate the whole page and add missing interactions"','/design checkup "Audit this UI and generate the design report"','/design "Build a landing page for a privacy-first contract review tool"'],HP=__name(({onCancel:e})=>(ie((t,n)=>{n.escape&&e()}),K.createElement(ne,{flexDirection:"column",paddingLeft:2,paddingRight:2},K.createElement(ne,{marginBottom:1,flexDirection:"column"},K.createElement(re,{bold:!0,color:pr},"Use"),K.createElement(ne,{paddingLeft:2,flexDirection:"column"},K.createElement(re,{color:mr.DIM},'/design <mode> "target or request"'),K.createElement(re,{color:mr.DIM},'/design "freeform request" also works. The closest mode is inferred.'))),K.createElement(ne,{marginBottom:1,flexDirection:"column"},K.createElement(re,{bold:!0,color:pr},"Modes"),K.createElement(ne,{paddingLeft:2,flexDirection:"column"},cx.map(e=>K.createElement(ne,{key:e.name,columnGap:2},K.createElement(ne,{width:18,flexShrink:0},K.createElement(re,{color:mr.CYAN},"/design ",e.name)),K.createElement(ne,null,K.createElement(re,{color:mr.DIM},e.description)))))),K.createElement(ne,{marginBottom:1,marginTop:1,flexDirection:"column"},K.createElement(re,{bold:!0,color:pr},"Working rules"),K.createElement(ne,{paddingLeft:2,flexDirection:"column"},zP.map(e=>K.createElement(ne,{key:e.label,columnGap:2},K.createElement(ne,{width:16,flexShrink:0},K.createElement(re,{color:mr.CYAN},e.label)),K.createElement(ne,null,K.createElement(re,{color:mr.DIM},e.desc)))))),K.createElement(ne,{marginBottom:1,marginTop:1,flexDirection:"column"},K.createElement(re,{bold:!0,color:pr},"Quick examples:"),K.createElement(ne,{paddingLeft:2,flexDirection:"column"},WP.map(e=>K.createElement(re,{key:e,color:mr.DIM},e)))),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"Press Esc to close. Type /design help anytime to return.")))),"DesignGuide");Ft(),er(),Ft(),Ft();var GP=__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 xT.on("reset",t),xT.on("new-event",r),()=>{xT.off("reset",t),xT.off("new-event",r)}},[e]),{steps:t,importError:r,setImportError:o}},"useProgressEvents");async function createRequestClient(){const e=getApiBaseUrl(),t=new Xw({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={[Bt.PROJECT_SLUG]:Rk.getCurrentProjectDirName(),[Bt.INTERNAL_TEAM_FLAG_HEADER]:r.toString()};return o&&(i[Bt.OAUTH_TOKEN]=`Bearer ${o}`,s&&(i[Bt.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}function buildObserverPrompt(e,t){return`Produce ${t} varied observations for these prompts:\n\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}`),xT.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()}`),xT.addEvent({type:"insight",message:e.trim()}))},"emitRemaining"),getChunkCount:__name(()=>t,"getChunkCount")}}async function callObserverAPI(e,t,n){const r=getTasteObserverModel();dlog(`[ObserverAPI] calling ${zt.ALPHA.GENERATE} with model: ${r}`);const o={config:getEnvironmentContext(),memory:"",taste:"",skills:"",params:{tools:[],messages:[{role:"user",content:n}],model:r,system:"You scan prompts and produce casual observations like a dev friend glancing at someone's 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 per observation\n- one observation per line\n- sound human, not robotic\n- output only the observations, no preamble",max_tokens:200,temperature:.7,stream:!0},threadId:Pe()},s=await e.post({endpoint:zt.ALPHA.GENERATE,body:o,headers:t,stream:!0});dlog("[ObserverAPI] got response stream");const i=createInsightEmitter();await consumeSSEStream(s,{onText:__name(e=>{i.addText(e)},"onText")}),dlog(`[ObserverAPI] stream complete, ${i.getChunkCount()} chunks received`),i.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(xT.observerHasRun)return;xT.markObserverRun();const{prompts:t}=e;try{const{request:e,headers:n}=await createRequestClient(),r={...n,[Bt.SESSION_ID]:`observer-${Pe()}`},o=splitPromptsIntoBatches(t);dlog(`[Observer] ${t.length} prompts → ${o.length} batches`);const s=Math.min(o.length,6);for(let t=0;t<s;t++){if(xT.learningComplete){dlog(`[Observer] stopped at batch ${t} (learning complete)`);break}const n=o[t];try{await processBatch(e,r,n,t+1,o.length)}catch{}}dlog("[Observer] done")}catch(e){dlog(`[Observer] failed (non-critical): ${e instanceof Error?e.message:String(e)}`),xT.addEvent({type:"progress",message:"Continuing without live observations..."})}}Ft(),Ft(),yS(),IS(),er(),Ft(),Cn(),er(),Ft(),Ft(),Cn(),yS(),IS(),er(),so(),yo(),__name(createRequestClient,"createRequestClient"),Ft(),__name(splitPromptsIntoBatches,"splitPromptsIntoBatches"),__name(function calculateObservationsPerBatch(e){return 4},"calculateObservationsPerBatch"),Ft(),Ft(),er(),Bo(),Ft(),Cn(),__name(buildObserverPrompt,"buildObserverPrompt"),__name(createInsightEmitter,"createInsightEmitter"),__name(callObserverAPI,"callObserverAPI"),__name(processBatch,"processBatch"),__name(observeSessionPrompts,"observeSessionPrompts");var VP=class{static{__name(this,"SessionImporter")}static async findClaudeCodeSessions(t=0){const n=[];try{const r=e.join(w.homedir(),".claude","projects");await C.access(r);const o=process.cwd().replace(/\//g,"-");dlog(`[Import] scanning project: ${o}`);const s=(await C.readdir(r)).filter(e=>e===o);for(const o of s){const s=e.join(r,o);try{if(!(await C.stat(s)).isDirectory())continue;const r=(await C.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 C.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{xT.addEvent({type:"progress",message:"Scanning Codex sessions..."});const n=await findCodexSessions(process.cwd(),e=>{t?.(e),"reading"===e.phase&&xT.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{xT.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 C.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{xT.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}`);xT.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})`),xT.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){xT.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)}`)});xT.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 Xw({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&&xT.addEvent({type:"progress",message:`Processing batch ${n}/${r}...`});const o=this.formatBatchLearning(t),s=new MT({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}`),xT.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=xT.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||xT.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 xT.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),xT.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 C.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")}},QP=__name(e=>new Promise((t,n)=>setTimeout(()=>n(new Error("Learning timed out. Try again with /learn-taste")),e)),"createTimeout"),KP=__name(e=>{const[t,n]=J({isImporting:!0,waitingForInput:!1,alreadyLearned:!1,learnedSessionCount:0,totalSessionCount:0,agentSessions:[],error:null});return Z(()=>{xT.reset(),xT.markImportStarted(),(async()=>{try{const t=await Promise.race([VP.importAndLearn(),QP(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");Ft();var YP=__name(({onEscape:e,onEnter:t,enabled:n=!0})=>{ie((r,o)=>{n&&(o.escape&&e(),(o.return||"\n"===r)&&t())})},"useKeyboardInput");Ft(),er();var JP=__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{xT.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{xT.reset(),e()}}Ft(),er(),Ft(),er(),__name(completeOnboarding,"completeOnboarding"),__name(skipOnboarding,"skipOnboarding");var XP=__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");Ft(),er();var ZP=__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");Ft(),Ft(),Or();var eI=__name(({error:e})=>K.createElement(ne,{padding:1},K.createElement(ne,{flexDirection:"column",borderColor:mr.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");Ft(),Ft(),Or();var tI=__name(()=>K.createElement(re,null,"Skip"),"SkipOptionText"),nI=__name(({sessionCount:e,agentSessions:t,onImport:n,onSkip:r})=>{const[o,s]=J(1);return ie((e,t)=>{t.escape?r():"n"!==e&&"N"!==e?t.upArrow||t.downArrow?s(e=>1===e?2:1):"1"!==e?"2"!==e?t.return&&(1===o?n():r()):r():n():dismissOnboardingForeverForProject().then(()=>r())}),K.createElement(ne,{flexDirection:"column",borderStyle:"single",borderColor:gr.TEXT,paddingX:1,paddingY:0},K.createElement(re,{color:gr.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,"Analyze"," ",1===e?"that session":"those sessions"," ","to build your coding taste package?"))),K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(ne,null,K.createElement(re,{color:1===o?gr.TEXT:mr.GRAY},1===o?Ie.pointer:" "," 1. Yes, learn (recommended)")),K.createElement(ne,null,K.createElement(re,{color:2===o?gr.TEXT:mr.GRAY},2===o?Ie.pointer:" "," 2."," ",K.createElement(tI,null)))),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"↑↓ · "),K.createElement(re,{color:Ir.CODE},"enter"),K.createElement(re,{color:mr.DIM}," ok · "),K.createElement(re,{color:Ir.CODE},"esc"),K.createElement(re,{color:mr.DIM}," skip · "),K.createElement(re,{color:Ir.CODE},"n"),K.createElement(re,{color:mr.DIM}," never")))},"ImportChoice");Ft(),Ft(),Or();var rI=__name(({error:e})=>K.createElement(ne,{flexDirection:"column",borderStyle:"single",borderColor:mr.RED,paddingX:2,paddingY:1,marginBottom:2},K.createElement(re,{color:mr.RED,bold:!0},"Oops, something went wrong:"),K.createElement(ne,{marginTop:1},K.createElement(re,null,e))),"ErrorSection");Ft(),Ft(),Or(),Ft(),Ft(),Ft(),Or(),Ft(),Or();var oI=__name(()=>K.createElement(re,{backgroundColor:gr.BADGE_BG,color:gr.BADGE_FG},e_),"TasteBadge");Ft(),Or(),Ft();var sI=["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"],iI="⎿",aI=__name(()=>{const[e,t]=J(()=>Math.floor(Math.random()*sI.length));return Z(()=>{const e=setInterval(()=>{t(Math.floor(Math.random()*sI.length))},2e3);return()=>clearInterval(e)},[]),K.createElement(re,{color:mr.YELLOW},sI[e],"...")},"PulsingText");Ft(),Or();var lI=[Ie.bullet,Ie.squareSmallFilled,Ie.lozenge,Ie.star,Ie.triangleRight,Ie.triangleUp,Ie.circleFilled,Ie.pointer],cI=__name(e=>String(e).padStart(3," "),"padNum"),uI=__name(e=>lI[e%lI.length],"getSymbol"),dI=__name((e,t,n,r)=>r?`${e} observations (↑↓ scroll)`:`↑${cI(t)} ↓${cI(n)} (↑↓ scroll)`,"buildStatusLine"),mI=__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:mr.DIM},dI(s,u,d,r)),l.map((e,n)=>{const r=t+n;return K.createElement(ne,{key:r,marginBottom:0},K.createElement(re,{color:mr.DIM},uI(r)," ",e))}))},"ScrollableInsights");Ft(),Or();var pI=__name(()=>{const[e,t]=J(!0);return Z(()=>{const e=setInterval(()=>{t(e=>!e)},500);return()=>clearInterval(e)},[]),K.createElement(re,{color:mr.YELLOW},e?Ie.circleFilled:Ie.circle)},"PulsingDot"),gI=__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(oI,null),K.createElement(ne,{marginTop:0},K.createElement(re,{color:mr.DIM},iI),K.createElement(ne,{marginLeft:2},a?K.createElement(re,{color:gr.TEXT},"learned your coding taste"):K.createElement(aI,null))));const u=__name(()=>r?K.createElement(re,{color:wr.BG},Ie.square):n?K.createElement(pI,null):K.createElement(re,{color:mr.DIM},Ie.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?mr.WHITE:n?mr.YELLOW:mr.DIM},e)),r&&t&&(!l||0===l.learningCount)&&K.createElement(ne,{marginLeft:3,marginBottom:0},K.createElement(re,{color:mr.DIM},t)),o.length>0&&K.createElement(ne,{flexDirection:"column",marginLeft:1,marginBottom:0},o.map((e,t)=>K.createElement(re,{key:t,color:mr.DIM},`${Ie.bullet} ${e}`))),s.length>0&&K.createElement(mI,{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,iI),K.createElement(ne,{marginLeft:2},K.createElement(re,{color:gr.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:mr.DIM},Ie.pointerSmall," Stored in ",l.storage),K.createElement(re,{color:mr.DIM},"Command Code automatically uses & updates taste files.")))):null},"StepItem"),hI=__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(gI,{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"),fI=__name(({steps:e})=>K.createElement(hI,{steps:e}),"ProgressSection");Ft(),Or();var yI=__name(({isImporting:e=!1,waitingForInput:t=!1})=>K.createElement(K.Fragment,null,e&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"ESC to cancel")),t&&K.createElement(ne,{marginTop:1},K.createElement(re,{bold:!0},"Press ENTER to continue"))),"HelpTextSection");Ft();var wI=[{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"}}],SI=__name(({onComplete:e,onError:t,onErrorDismiss:n})=>{const{steps:r,importError:o}=GP(wI),{isImporting:s,waitingForInput:i,error:a}=KP(t);return YP({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(rI,{error:o}),!o&&K.createElement(fI,{steps:r}),K.createElement(yI,{isImporting:s,waitingForInput:i}))},"ImportProgress"),bI=__name(({step:e,conditions:t,onImportStart:n,onImportComplete:r,onImportError:o,onErrorDismiss:s,onSkip:i})=>"asking"===e?t&&"has_sessions"===t.reason?K.createElement(nI,{sessionCount:t.sessionCount,agentSessions:t.agentSessions,onImport:n,onSkip:i}):null:"learning"===e?K.createElement(SI,{onComplete:r,onError:o,onErrorDismiss:s}):null,"OnboardingStepRenderer"),EI=__name(({onComplete:e,autoLearn:t=!1})=>{Z(()=>(dlog("[UI:Onboarding] mounted"),()=>{dlog("[UI:Onboarding] unmounted")}),[]);const{conditions:n,error:r,isLoading:o}=JP({autoLearn:t,onShouldSkip:e}),{step:s,setStep:i}=ZP({conditions:n,autoLearn:t}),{handleImportStart:a,handleImportComplete:l,handleImportError:u,handleErrorDismiss:d,handleSkip:m}=XP({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(eI,{error:r}):"done"===s?null:K.createElement(bI,{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 vI=Y(__name(function MainView2({feed:e,liveEntries:t,queuedMessages:n,isCmdCodeBusy:r,staticKey:o,setStaticKey:s,transcriptMode:i,tasteOnboardingEntryId:a,autoLearnTaste:l,showTasteSkipBanner:u,retryAttempt:d,input:m,setInput:g,fileSearchQuery:h,setFileSearchQuery:f,showFileList:y,setShowFileList:w,showProviderSelector:S,showModelSelector:E,showEffortSelector:v,showMemorySelector:C,showMcpManager:k,showAgentsConfig:T,showRewindSelector:_,showLoginOverlay:x,showUsageOverlay:A,showAddDirModal:P,showCompactModeSelector:I,showConfigureModels:M,setShowConfigureModels:N,authComponentInfo:R,status:$,currentProvider:L,currentModel:D,showProviderNotification:O,shareInfo:F,showShareNotification:U,unshareNotificationMessage:j,updateStatus:q,updateFailedInfo:B,creditWarning:z,permissionMode:W,hintMessage:H,pendingExitKey:G,tasteLearningEnabled:V,interactionTokens:Q,contextUsage:Y,historyManagerRef:J,executionState:X,contextEngineRef:Z,onSubmit:oe,onCommand:se,onToggleAutoAccept:ie,onResetPendingExitKey:ae,onDoubleEscapeEmpty:le,onTasteOnboardingComplete:ce,permissionPanel:ue,questionPanel:de,designSuggestionPanel:me,onRewindSelect:pe,onRewindCancel:ge,onLoginComplete:he,onLoginCancel:fe,setShowProviderSelector:ye,setShowModelSelector:we,setShowEffortSelector:Se,setShowMemorySelector:be,setShowMcpManager:Ee,setShowAgentsConfig:ve,setShowAddDirModal:Ce,setShowUsageOverlay:ke,handleProviderSelect:Te,handleProviderCancel:_e,handleModelSelect:xe,handleModelCancel:Ae,handleCompactModeSelect:Pe,handleCompactModeCancel:Ie,handleAuthSuccess:Me,handleAuthCancel:Ne,showDesignGuide:Re,setShowDesignGuide:$e}){const Le=ee(()=>e.filter(e=>"taste-onboarding"!==e.role),[e]),De=te(()=>$e(!1),[$e]),Oe=useTerminalWidth(),Fe=ee(()=>"off"===i?Le:getBudgetedFeed(Le,"limited"===i?15e3:5e4),[Le,i]),Ue=ee(()=>"off"===i?0:Math.max(0,Le.length-Fe.length),[Le.length,Fe.length,i]),je=ee(()=>0===Ue?Fe:Fe.filter(e=>"user"!==e.role),[Fe,Ue]),qe=te(()=>ve(!1),[ve]),Be=te(()=>be(!1),[be]),ze=te(()=>Ee(!1),[Ee]),We=te(()=>Ce(!1),[Ce]),He=te(()=>we(!0),[we]),Ge=te(()=>Se(!1),[Se]),Ve=te(()=>{hardResetForResize(),s(e=>e+1)},[s]),Qe=!("off"!==i||ue||de||me||S||E||v||R||C||k||T||_||x||A||P||I||M||Re||a);return K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(IP,{staticKey:o,feed:je,showHeader:!0,expandedToolOutput:"off"!==i,currentModel:D,currentProvider:L,hiddenCount:Ue}),a&&K.createElement(EI,{onComplete:ce,autoLearn:l}),u&&K.createElement(TasteSkipMessage,null),t.map(e=>e.metadata?.isAgent?K.createElement(NP,{key:e.id,entry:e}):K.createElement(ne,{key:e.id,marginBottom:1,width:"90%"},renderFeedEntry(e,"off"!==i))),K.createElement(RetryMessage,{attempt:d}),me,de,ue,"off"!==i&&K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(ne,null,K.createElement(re,{color:mr.DIM},"─".repeat(Oe))),K.createElement(ne,{paddingRight:1},K.createElement(re,{backgroundColor:wr.BG,color:wr.FG,bold:!0},`${ZT}DETAILED TRANSCRIPT${ZT}`),K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{bold:!0},"ctrl+o"),K.createElement(re,{color:mr.DIM}," to toggle"),K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{bold:!0},"ctrl+e"),K.createElement(re,{color:mr.DIM}," ","to"," ","limited"===i?"show all":"collapse"))),Qe&&K.createElement(CP,{queuedMessages:n,isProcessing:r,executionState:X,status:$,input:m,setInput:g,onSubmit:oe,showFileList:y,setShowFileList:w,fileSearchQuery:h,setFileSearchQuery:f,onCommand:se,outputTokens:Q,contextUsage:Y,tasteLearning:V,shareInfo:F,showShareNotification:U,unshareNotificationMessage:j,updateStatus:q,updateFailedInfo:B,creditWarning:z,currentProvider:L,currentModel:D,showProviderInfo:O,permissionMode:W,onToggleAutoAccept:ie,hintMessage:H,historyManager:J.current,pendingExitKey:G,onResetPendingExitKey:ae,onDoubleEscapeEmpty:le,retryAttempt:d,onAltP:He}),S&&K.createElement(ne,{marginY:1},K.createElement(jP,{onSelect:Te,onCancel:_e,currentProvider:L})),E&&K.createElement(ne,{marginY:1},K.createElement(FP,{onSelect:xe,onCancel:Ae,currentModel:D,currentProvider:L,refreshBanner:Ve})),v&&K.createElement(ne,{marginY:1},K.createElement(UP,{currentModel:D,onClose:Ge,refreshBanner:Ve})),Re&&K.createElement(ne,{marginY:1},K.createElement(HP,{onCancel:De})),I&&K.createElement(ne,{marginY:1},K.createElement(GA,{onSelect:Pe,onCancel:Ie})),M&&K.createElement(ne,{marginY:1},K.createElement(YA,{onClose:()=>N(!1)})),T&&K.createElement(ne,{marginY:1},K.createElement(WA,{onCancel:qe})),C&&K.createElement(ne,{marginY:1},K.createElement(_P,{onClose:Be})),k&&K.createElement(ne,{marginY:1},K.createElement(TP,{onClose:ze})),_&&Z.current&&K.createElement(ne,{marginY:1},K.createElement(BP,{checkpoints:Z.current.listCheckpoints(),onSelect:pe,onCancel:ge})),R&&K.createElement(ne,{marginY:1},K.createElement(R.Component,{onSuccess:Me,onCancel:Ne})),x&&K.createElement(ne,{marginY:1},K.createElement(kP,{onComplete:he,onCancel:fe})),P&&K.createElement(ne,{marginY:1},K.createElement(AA,{onClose:We})))},"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:v,creditWarning:C,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(Ax,{staticKey:o.staticKey,onTrust:k,onExit:T});if(o.showSessionSelector)return K.createElement(Mx,{onSelectSession:g.onSelectSession,onNewSession:g.onNewSession});if(!s.projectTrusted)return null;const I=o.pendingDesignSuggestion?K.createElement(Tx,{suggestion:o.pendingDesignSuggestion,onSelect:e=>{f(`/design ${e}`)},onClose:()=>o.setPendingDesignSuggestion(null)}):null,M=a.pendingQuestion?K.createElement(QuestionView,{pendingQuestion:a.pendingQuestion,permissionMode:l.permissionMode,setPermissionMode:l.setPermissionMode,dangerouslySkipPermissions:l.dangerouslySkipPermissions,setPendingQuestion:a.setPendingQuestion,setStatus:n.setStatus,setStaticKey:o.setStaticKey}):null,N=a.pendingPermission?K.createElement(zx,{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(vI,{feed:e.feed,liveEntries:e.liveEntries,queuedMessages:e.queuedMessages,isCmdCodeBusy:e.isCmdCodeBusy,staticKey:o.staticKey,setStaticKey:o.setStaticKey,transcriptMode:o.transcriptMode,tasteOnboardingEntryId:s.tasteOnboardingEntryId,autoLearnTaste:s.autoLearnTaste,showTasteSkipBanner:o.showTasteSkipBanner,retryAttempt:n.retryAttempt,input:y,setInput:w,fileSearchQuery:S,setFileSearchQuery:E,showFileList:o.showFileList,setShowFileList:o.setShowFileList,showProviderSelector:o.showProviderSelector,showModelSelector:o.showModelSelector,showEffortSelector:o.showEffortSelector,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,showConfigureModels:o.showConfigureModels,setShowConfigureModels:o.setShowConfigureModels,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:v,creditWarning:C,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:M,designSuggestionPanel:I,onRewindSelect:g.onRewindSelect,onRewindCancel:g.onRewindCancel,onLoginComplete:g.onLoginComplete,onLoginCancel:g.onLoginCancel,setShowProviderSelector:o.setShowProviderSelector,setShowModelSelector:o.setShowModelSelector,setShowEffortSelector:o.setShowEffortSelector,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,showDesignGuide:o.showDesignGuide,setShowDesignGuide:o.setShowDesignGuide})}__name(renderView,"renderView");var CI=__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();Z(()=>{prefetchBillingContext()},[]);const[h,f]=J(""),[y,w]=J(""),S=X(!1),E=X(!1),v=X(null),C=X(null),k=useUiOverlays(),T=useFeed(),_=useSession(),x=useStatus(s),A=useAuth(),P=usePendingOps(),I=useOnboarding(),M=useExit(),{executeBash:N,executionState:R}=gT(),$=usePermissionMode({initialPermissionMode:u,dangerouslySkipPermissions:o,setPendingPermission:P.setPendingPermission,setStatus:x.setStatus,contextEngineRef:C}),{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:C}),{onCommand:D}=useCommandCtx({feedState:T,sessionState:_,statusState:x,authState:A,uiOverlays:k,onboarding:I,exitState:M,permissionState:$,contextEngineRef:C,isSubmittingRef:S,executeBash:N,createContextEngineCallbacks:L,setInput:f}),{loadTasteStatus:O,loadCurrentProvider:F,onSubmit:U}=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:C,isSubmittingRef:S,initialPromptSubmittedRef:E,historyManagerRef:v,executeBash:N,createContextEngineCallbacks:L,setInput:f,onCommand:D});useLifecycle({exit:m,feedState:T,exitState:M,statusState:x,authState:A,onboarding:I,uiOverlays:k,skipOnboarding:l,contextEngineRef:C,sessionTitleHolder:d});const{handleToggleAutoAccept:j,handleDoubleEscapeEmpty:q,handleTasteOnboardingComplete:B,handleTrust:z,handleNoTrust:W}=useHandlers({resume:e,feedState:T,onboarding:I,uiOverlays:k,exitState:M,pendingOps:P,permissionState:$,statusState:x,authState:A,contextEngineRef:C,loadTasteStatus:O,loadCurrentProvider:F,setInput:__name(e=>f(e),"setInput")}),H=useMainActionCallbacks({feedState:T,sessionState:_,statusState:x,authState:A,uiOverlays:k,permissionState:$,contextEngineRef:C,createContextEngineCallbacks:L,setInput:f}),{creditWarning:G}=useCreditWarning({interactionTokens:x.interactionTokens});return renderView({feedState:T,sessionState:_,statusState:x,authState:A,uiOverlays:k,onboarding:I,exitState:M,pendingOps:P,permissionState:$,contextEngineRef:C,historyManagerRef:v,executionState:R,actionCallbacks:H,onSubmit:U,onCommand:D,input:h,setInput:f,fileSearchQuery:y,setFileSearchQuery:w,updateFailedInfo:i,creditWarning:G,handleTrust:z,handleNoTrust:W,handleToggleAutoAccept:j,handleDoubleEscapeEmpty:q,handleTasteOnboardingComplete:B,loadTasteStatus:O})},"InteractiveCLI");Kr(),ZS(),dr(),Or();var kI=__name(e=>e.replace(/\x1B\[[0-9;]*[A-Za-z]/g,"").replace(/[\x00-\x1F\x7F]/g," ").trim(),"sanitizeTitleForOutput"),TI=ue.hex(mr.DIM),_I=__name(e=>{const t=getInvokedCommandName(),n=nt([e]);return`${TI("To continue this session, run:")}\n${TI(`${t} --resume ${n}`)}\n`},"formatResumeHint"),xI=__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"),AI=__name(e=>Boolean(e.resume||e.continue),"shouldValidateSessions"),PI=__name(({isInitialized:e,sessionCount:t})=>e&&0===t?{canProceed:!1,exitCode:0,message:"No conversations found to resume."}:{canProceed:!0},"validateSessionAvailability"),II=__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"),MI=__name(()=>({stdin:process.stdin,stdout:process.stdout,stderr:process.stderr,exitOnCtrlC:!1}),"getInkRenderOptions"),NI=__name(()=>{enableBracketedPasteMode(),process.on("exit",()=>{disableBracketedPasteMode()})},"setupBracketedPasteMode"),RI=__name(()=>{NI()},"initializeTerminal"),$I=__name(async(e={})=>{const t=xI(process.stdin.isTTY);let n;if(t.isValid||(console.error(t.errorMessage),process.exit(1)),RI(),"string"==typeof e.resume){const t=e.resume;await Rk.isProjectInitialized()||(console.error("Project not initialized. Run cmd to start a conversation first."),process.exit(1));const r=await Rk.findSessionByName(t);r||(console.error(`No session named "${t}" found.`),process.exit(1)),n=r.id}if(AI(e)&&!n){const e=await Rk.isProjectInitialized(),t=e?await Rk.listSessions():[],n=PI({isInitialized:e,sessionCount:t.length});n.canProceed||(console.log(n.message),process.exit(n.exitCode))}startEarlyInputCapture();const r={},o=II({options:e,resumeSessionId:n,sessionTitleHolder:r}),s=MI(),i=ae(K.createElement(CI,{...o}),s);registerInkControl({clear:i.clear,stdout:process.stdout,instance:await resolveInkInstance(process.stdout)}),await i.waitUntilExit();const a=await(r.loadTitle?.());if(a){const e=kI(a);e&&process.stdout.write(_I(e))}},"interactiveMode");Do(),Ft(),Cn(),FE(),CE();var LI=__name(async()=>{try{return await runLogin(),!!await getAuthKey()||(console.error(`${Ie.cross} Authentication failed. Please try again with: cmd login`),!1)}catch(e){return isUserCancellation(e)||(console.error(`${Ie.cross} Login failed: ${getErrorMessage2(e)}`),console.error("Please try again with: cmd login")),!1}},"attemptLogin");async function ensureAuthenticated(){try{return!!await getAuthKey()||LI()}catch(e){return console.error("Error checking authentication:",e),!1}}__name(ensureAuthenticated,"ensureAuthenticated"),so(),Ft(),Cn(),no();var DI={bold:__name((e,t)=>t?`[1m${e}[0m`:e,"bold"),dim:__name((e,t)=>t?`[2m${e}[0m`:e,"dim"),green:__name((e,t)=>t?`[32m${e}[0m`:e,"green")};function modelNameOf(e){const t=e.lastIndexOf("/");return(-1===t?e:e.slice(t+1)).toLowerCase()}function displayModelId(e){return e.replace(Vr,"")}function resolveModelFlag({model:e}){const t=resolveKnownModelId(e);if(t)return t;const n=modelNameOf(e),r=getAllModelOptions().filter(e=>modelNameOf(e.id)===n);return 1===r.length?r[0].id:void 0}function editDistance(e,t){const n=e.length+1,r=t.length+1;let o=Array.from({length:r},(e,t)=>t);for(let s=1;s<n;s++){const n=[s];for(let i=1;i<r;i++){const r=e[s-1]===t[i-1]?0:1;n[i]=Math.min(o[i]+1,n[i-1]+1,o[i-1]+r)}o=n}return o[r-1]}function suggestModel(e){const t=e.trim().toLowerCase();if(!t)return;let n;for(const e of getAllModelOptions()){const r=displayModelId(e.id),o=Math.min(editDistance(t,r.toLowerCase()),editDistance(t,modelNameOf(r)));(!n||o<n.distance)&&(n={id:r,distance:o})}if(!n)return;const r=Math.min(4,Math.ceil(t.length/3));return n.distance<=r?n.id:void 0}function formatModelList(e={}){const t=e.color??!1,n=getModelGroupsInOrder(),r=n.flatMap(e=>e.models),o=Math.max(...r.map(e=>displayModelId(e.id).length)),s=n.map(e=>{const n=e.models.map(e=>{const n=displayModelId(e.id).padEnd(o),r=DI.dim(e.description,t);return`${n} ${"free"===e.badge?`${DI.green("FREE",t)} `:""}${r}${e.id===pn?` ${DI.green("(default)",t)}`:""}`});return[DI.bold(e.label,t),"",...n].join("\n")});return[`${DI.bold("Available models",t)} ${DI.dim(`· ${r.length} models`,t)}`,"",s.join("\n\n"),"",DI.dim('Pass the full id, or just the short name after the last "/":',t),"cmd --model moonshotai/Kimi-K2.5","cmd --model kimi-k2.5","","Docs: https://commandcode.ai/docs/reference/cli/models"].join("\n")}function printModelList(){const e=Boolean(process.stdout.isTTY)&&void 0===process.env.NO_COLOR;process.stdout.write(`${formatModelList({color:e})}\n`)}function resolveModelFlagOrExit({model:e}){const t=resolveModelFlag({model:e});if(t)return t;const n=suggestModel(e),r=n?` Did you mean "${n}"?`:"";process.stderr.write(`Error: unknown model "${e}".${r}\nRun "cmd --list-models" to see all available models\n`),process.exit(1)}__name(modelNameOf,"modelNameOf"),__name(displayModelId,"displayModelId"),__name(resolveModelFlag,"resolveModelFlag"),__name(editDistance,"editDistance"),__name(suggestModel,"suggestModel"),__name(formatModelList,"formatModelList"),__name(printModelList,"printModelList"),__name(resolveModelFlagOrExit,"resolveModelFlagOrExit");var OI=__name(e=>e&&!e.startsWith("-")?e:void 0,"parsePrompt"),FI=__name(async()=>{await ensureAuthenticated()||process.exit(1)},"requireAuth"),UI=__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"),jI=__name(({options:e,runtimeOptions:t,initialPrompt:n})=>e.resume?{resume:e.resume,...t}:e.continue?{continue:!0,...t}:{...t,initialPrompt:n},"getInteractiveConfig"),qI=__name((e,t)=>"string"==typeof e.print&&e.print.trim()?e.print:t&&!t.startsWith("-")?t:"","extractPrintQuery");async function interactiveModeAction(e,t){if(t.listModels)return void printModelList();if(t.addDir&&t.addDir.length>0)for(const e of t.addDir)addDirectory(e);const n=t.model?resolveModelFlagOrExit({model:t.model}):void 0;if(void 0!==t.print){const r=qI(t,e);return void await printMode({query:r,dangerouslySkipPermissions:t.dangerouslySkipPermissions,maxTurns:t.maxTurns,verbose:t.verbose,model:n,benchmarkOutput:t.benchmarkOutput})}n&&setModelOverride(n);const r=OI(e);await FI();const o=UI(t),s=jI({options:t,runtimeOptions:o,initialPrompt:r});await $I(s)}__name(interactiveModeAction,"interactiveModeAction"),Ft(),er(),Ts(),so(),EE(),FE();var BI=new Set(["update"]),zI=__name(()=>process.argv.slice(2).find(e=>!e.startsWith("-")),"getInvokedCommand");globalThis.COMMAND_CODE_CWD=process.cwd();var WI=__name(()=>process.cwd(),"getCwd"),HI=__name(()=>process.argv.slice(2),"getArgs"),GI=__name(e=>e.includes("--local")?"local":e.includes("--staging")?"staging":"production","getEnv"),VI=__name(()=>{const e=WI(),t=HI(),n=GI(t);dlog(`[Startup] cwd: ${e}`),dlog(`[Startup] args: ${t.join(" ")}`),dlog(`[Startup] env: ${n}`),dlog(`[Startup] traceId: ${getTraceId()??"unavailable"}`)},"logStartupInfo");async function preRun(){if(VI(),process.argv.includes("--ide-setup")){const e=await runIDESetup();formatSetupResult(e).forEach(e=>console.log(e)),process.exit("failed"===e.status?1:0)}const e=BI.has(zI()??"");e||(notifyCompletedUpdate(),maybeRunPendingUpdate()),await migrateDeprecatedModel(),await getAuthKey()&&detectAndTrackFirstInstall().catch(()=>{}),e||checkForUpdateAsync(),setTimeout(()=>ensureExtensionInstalled().catch(()=>{}),100).unref()}__name(preRun,"preRun"),Ft(),Cn(),er(),Io(),ZS(),fo();var QI=getPackageJson(),KI=__name((e,t=[])=>[...t,e],"collectAddDir");function displayCustomHelp(){const e=QI.version,t=getInvokedCommandName(),n=Ek.filter(e=>!("/provider"===e.key&&!isInternalTeamFlagEnforced()));console.log(),console.log(ue.bold("Command Code")+ue.gray(` v${e}`)),console.log(ue.gray(fk)),console.log(),console.log(ue.bold("Usage")),console.log(` ${t} <command> [options]`),console.log(),console.log(ue.bold("Options"));for(const e of bk){const n=e.key.replace(/^cmd/,t);console.log(" "+n.padEnd(yk)+ue.gray(e.description))}console.log(),console.log(ue.bold("Commands"));for(const e of vk){const n=e.key.replace(/^cmd/,t);console.log(" "+n.padEnd(yk)+ue.gray(e.description))}console.log(),console.log(ue.bold("Slash Commands"));for(const e of n)console.log(" "+e.key.padEnd(yk)+ue.gray(e.description));console.log(),console.log(ue.bold("Keyboard Shortcuts"));for(const e of Sk)console.log(" "+e.key.padEnd(yk)+ue.gray(e.description));console.log(),console.log(ue.bold("Examples"));for(const e of kk){const n=e.key.replace(/^cmd/,t);console.log(" "+n.padEnd(yk)+ue.gray(e.description))}console.log(),console.log(ue.cyan("❯")+" "+ue.gray(Tk.replace(/cmd/,t))),console.log(),console.log(ue.bold("Links"));for(const e of Ck)console.log(" "+e.key.padEnd(yk)+ue.cyan(e.description));console.log()}function createProgram(){const e=new Me;return e.name(getInvokedCommandName()).description("Command Code with your coding taste.").version(QI.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 Ne("--dangerously-skip-permissions","Bypass all permission prompts (use with caution)").hideHelp()).addOption(new Ne("--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 Ne("--auto-accept","Start in auto-accept mode").implies({permissionMode:"auto-accept"})).addOption(new Ne("--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",wk).option("--add-dir <directory>","Add directory to workspace context",KI,[]).option("-m, --model <model>","Run on a specific model this session (e.g. claude-sonnet-4-6, kimi-k2.5). Unknown ids are rejected; see --list-models.").option("--list-models","List the models available for use").addOption(new Ne("--benchmark-output <path>","Path to write benchmark metrics JSON").hideHelp()).addOption(new Ne("--experimental","Enable experimental features").hideHelp()).addOption(new Ne(jt).hideHelp()).addOption(new Ne(qt).hideHelp()).addOption(new Ne("-d, --debug","Enable debug mode").hideHelp()).addOption(new Ne("--local","Use local server").hideHelp()).addOption(new Ne("--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"),Ft(),Ts(),Ho(),eE(),BE(),pE(),Io(),FE(),Ft(),__name(isTTY,"isTTY");var YI=!1;function setupTelemetry(){initTelemetry()&&(startSession(),registerStartupTask(trackSystemInfo()),trackCliSessionExistsEvent(),registerCleanupHandlers())}async function trackSystemInfo(){try{const e=w.platform(),t=w.arch();let n,r,o,s;try{const e=await getAuthenticatedEntity();e.success&&(n=e.user?.userName,r=e.user?.id,o=e.org?.login,s=e.org?.id)}catch{}if(!r)try{const e=await loadCredentials();r=e?.userId}catch{}systemInfo({userName:n,userId:r,orgLogin:o,orgId:s,platform:e,arch:t})}catch{}}function registerCleanupHandlers(){process.on("beforeExit",async()=>{await shutdownTelemetry()}),process.on("exit",()=>{shutdownTelemetrySync()}),process.on("SIGINT",handleShutdownSignal),process.on("SIGTERM",handleShutdownSignal)}function handleShutdownSignal(){YI||(YI=!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=w.platform(),r=w.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=Re("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"),FE(),Ft(),mo(),__name(openGitHubIssue,"openGitHubIssue");var JI=new Me("feedback").description("Open GitHub issues to share feedback or report bugs").argument("[title]","Optional issue title").action(openGitHubIssue);Ft();var XI=new Me("help").description("Display help information").allowUnknownOption().allowExcessArguments().action(function(){this.parent?.help()});async function runInfo(e){const t=getSystemInfo(),{waitUntilExit:n}=ae(K.createElement(I_,{verbose:e.verbose,text:e.text,systemInfo:t}));await n()}Ft(),Ft(),__name(runInfo,"runInfo");var ZI=new Me("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(SI,{onComplete:__name(()=>{e(),process.exit(0)},"onComplete"),onErrorDismiss:__name(()=>{e(),process.exit(1)},"onErrorDismiss")}))}Ft(),Cn(),Ft(),__name(runLearnTaste,"runLearnTaste"),er(),Ts();var eM=new Me(rn.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:ws.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 Me("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 Ne("-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.")),isSecureOrLoopback(t)||(console.error(ue.red(`Error: Server '${e}' requires OAuth, but URL '${t}' is not secure.`)),console.error(ue.gray("OAuth requires https:// (http:// is only allowed for loopback hosts: localhost, 127.0.0.1, [::1]).")),console.error(ue.gray("Switch the URL to https:// or use a non-OAuth server.")),process.exit(1));let n,o="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:${JS}/callback`]});e&&(o=e.clientId,n=e.clientSecret)}s.oauth={authorizationUrl:r.metadata.authorizationEndpoint,tokenUrl:r.metadata.tokenEndpoint,clientId:o,clientSecret:n,scopes:r.metadata.scopes},console.log(ue.gray("A browser window will open for authentication.\n"));const a=await performOAuthFlow(e,t,{authorizationUrl:r.metadata.authorizationEndpoint,tokenUrl:r.metadata.tokenEndpoint,clientId:o,clientSecret:n,scopes:r.metadata.scopes},{onStatus:__name(e=>{console.log(ue.gray(` ${e}`))},"onStatus")});a.success?console.log(ue.green("✓ Successfully authenticated")):(i=!0,console.log(ue.yellow(`Warning: Authentication failed: ${a.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);looksLikeHttpUrl2(a)&&(console.error(ue.red(`Error: '${a}' looks like a URL, not a local command.`)),console.error(ue.gray(`Did you mean: cmd mcp add --transport http ${e} ${a}`)),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 looksLikeHttpUrl2(e){try{const t=new URL(e);return"http:"===t.protocol||"https:"===t.protocol}catch{return!1}}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 Me("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(Ie.tick):ue.red(Ie.cross):o.config.headers||o.config.env?ue.green(Ie.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 Me("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 Me("remove");return e.description("Remove an MCP server").argument("<name>","Server name").addOption(new Ne("-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 Me("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 Ne("-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?.oauth?.callbackPort&&(s=o.oauth.callbackPort,delete o.oauth.callbackPort),n.clientSecret&&o?.oauth&&(o.oauth.clientSecret=n.clientSecret);const i=US.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,a.url??"",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 Me("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)),console.log(ue.cyan(`Authenticating with '${e}'...`)),console.log(ue.gray("A browser window will open for authentication.\n"));const o=__name(e=>{console.log(ue.gray(` ${e}`))},"onStatus");let s;if(r.config.oauth){const t={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};s=await performOAuthFlow(e,r.config.url??"",t,{onStatus:o})}else"http"===r.config.transport&&r.config.url||(console.error(ue.red("Error: Discovery-based auth requires an http server with a url")),process.exit(1)),s=await discoverAndAuthenticate({serverName:e,serverUrl:r.config.url,onStatus:o});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 Me("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=ve(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 C.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 C.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 C.mkdtemp(e.join(w.tmpdir(),"taste-learn-"));try{await runCommand({cmd:"git",args:["clone","--depth",s,"--single-branch",...t.branch?["--branch",t.branch]:[],"--",i,a]})}catch{throw await C.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 C.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 Xw({baseUrl:r}),s=new MT({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:`${truncate3(t.removed,60)} → ${truncate3(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}Ft(),Ft(),ZS(),__name(addMcpCommand,"addMcpCommand"),__name(looksLikeHttpUrl2,"looksLikeHttpUrl"),__name(collectKeyValue,"collectKeyValue"),__name(collectHeaders,"collectHeaders"),Ft(),__name(listMcpCommand,"listMcpCommand"),Ft(),__name(getMcpCommand,"getMcpCommand"),Ft(),__name(removeMcpCommand,"removeMcpCommand"),Ft(),ZS(),__name(addJsonMcpCommand,"addJsonMcpCommand"),Ft(),ZS(),__name(authMcpCommand,"authMcpCommand"),__name(createMcpCommand,"createMcpCommand"),Ft(),Cn(),Ft(),qE(),Ft(),Cn(),Ft(),__name(runCommand,"runCommand"),Ft(),__name(detectDefaultBranch,"detectDefaultBranch"),__name(findGitRoot4,"findGitRoot"),__name(countLearnings,"countLearnings"),__name(resolveSource,"resolveSource"),__name(getTastePathForDir,"getTastePathForDir"),__name(resolveDisplayName,"resolveDisplayName"),__name(parseGitHubSource,"parseGitHubSource"),__name(inferGitHubRepo,"inferGitHubRepo"),Ft(),yS(),IS(),so(),yo(),__name(feedToLearningAgent,"feedToLearningAgent"),__name(logLearnSummary,"logLearnSummary"),Ft(),Ft(),__name(shouldContinueExtraction,"shouldContinueExtraction"),__name(extractAllSignals,"extractAllSignals"),__name(collectCommits,"collectCommits"),__name(getSubstitutions,"getSubstitutions"),__name(groupCrossFilePatterns,"groupCrossFilePatterns");var tM=5,nM=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>nM?(i=s.slice(0,nM-1),a=s.length-i.length):i=s;const l=i.length+(a>0?1:0),u=Math.max(0,tM-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 rM=[/package-lock\.json$/,/pnpm-lock\.yaml$/,/yarn\.lock$/,/CHANGELOG\.(md|yml|yaml)$/i,/\.versionbot\//,/\.min\.(js|css)$/,/dist\//,/\.map$/];function isNoiseFile(e){return rM.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 oM=new Set(["renovate[bot]","renovate","dependabot[bot]","dependabot","greenkeeper[bot]","snyk-bot"]),sM=[/^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!!oM.has(n)||!(!n.includes("[bot]")||!sM.some(e=>e.test(t)))}function truncate3(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){xT.addEvent({type:"auth_required",step:"auth",message:"Login to synthesize your taste profile",label:"Signing in"});try{await xT.waitForAuth()}catch{return xT.emitStepStart({step:"complete",label:"Login skipped",message:"Login skipped",learningCount:0,storage:""}),xT.markLearningComplete(),{summary:n()}}}t.isLocalSource||xT.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&&xT.emitStepStart({step:"collecting",label:"Collecting commits",message:`Cloned ${r.displayName} → ${a}`});const l=t.branch??await detectDefaultBranch({repoDir:i});await C.mkdir(a,{recursive:!0}),xT.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=>{xT.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.");xT.emitStepStart({step:"extracting",label:"Extracting taste signals",message:`${u.length} before/after code changes extracted`}),xT.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};xT.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 xT.emitStepStart({step:"complete",label:"Taste learned",message:"Taste learned",learningCount:f,storage:h}),xT.markLearningComplete(),{summary:{outputDir:a,tasteDir:g,sourceName:r.displayName,signalCount:u.length,contextLength:m.length},resolved:r}}__name(isDependencyBot,"isDependencyBot"),__name(truncate3,"truncate"),__name(runBounded,"runBounded"),Ft(),__name(compileTasteContext,"compileTasteContext"),__name(runLearnPipeline,"runLearnPipeline"),Ft(),Ft(),Ft();var iM=[/MallocStackLogging: can't turn off malloc stack logging because it was not enabled/i];function shouldIgnoreChunk(e){return iM.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"),Ft(),fs(),__name(toRepoLearnErrorMessage,"toRepoLearnErrorMessage"),__name(isRepoLearnMetricLikeText,"isRepoLearnMetricLikeText"),__name(truncateRepoLearnPanelText,"truncateRepoLearnPanelText"),Ft(),Ft();var aM=[{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"}],lM=[{id:"cloning",label:"Cloning repository"},...aM],cM=[Ie.bullet,Ie.squareSmallFilled,Ie.lozenge,Ie.star,Ie.triangleRight,Ie.triangleUp];function createInitialRepoLearnSteps(e){return(e??aM).map(e=>({...e,status:"pending"}))}__name(createInitialRepoLearnSteps,"createInitialRepoLearnSteps"),Ft();var uM={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 dM=__name(e=>e.map(e=>({...e,status:"complete"})),"markAllStepsComplete"),mM=__name(e=>e??uM,"withBase");function useRepoLearnState(e){const t=e??aM,[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),[v,C]=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,C(null),m(!1)},"handleReset"),n=__name(e=>{if("error"===e.type)return y(e.message),h(!0),r(dM),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=mM(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=mM(t);return{...n,topLearnings:[...n.topLearnings,e.message].slice(0,3)}}))):s(e.message):u(t=>{const n=mM(t),r=parseSummaryMetric(e.message);return r?{...n,...r}:n})}else m(!0)},"handleEvent"),o=__name(()=>{h(e=>e||(r(dM),!0)),s(""),E.current&&C(Math.round((Date.now()-E.current)/1e3))},"handleComplete");return xT.on("reset",e),xT.on("new-event",n),xT.on("learning-complete",o),()=>{xT.off("reset",e),xT.off("new-event",n),xT.off("learning-complete",o)}},[t]),{steps:n,currentMessage:o,insights:i,insightCount:w,summary:l,done:g,error:f,showLogin:d,setShowLogin:m,elapsedSeconds:v,markStarted:k}}__name(useRepoLearnState,"useRepoLearnState"),Ft(),Ft(),Or();var pM=__name(({isComplete:e,hasError:t})=>K.createElement(ne,{flexDirection:"column",marginTop:1,marginBottom:0},K.createElement(oI,null),K.createElement(ne,{marginTop:0},K.createElement(re,{color:mr.DIM},iI),K.createElement(ne,{marginLeft:2},t?K.createElement(re,{color:mr.DIM},"learning interrupted"):e?K.createElement(re,{color:gr.TEXT},"learned your coding taste"):K.createElement(aI,null)))),"RepoLearnTastePill");Ft(),Or();var gM=__name(({status:e})=>"active"===e?K.createElement(ne,null,K.createElement(re,{color:mr.YELLOW},K.createElement(Be,{type:"dots"})),K.createElement(re,null," ")):"complete"===e?K.createElement(re,{color:wr.BG},Ie.square," "):K.createElement(re,{color:mr.DIM},Ie.circle," "),"StepStatusIndicator"),hM=__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(gM,{status:e.status})),K.createElement(re,{bold:n,color:"complete"===e.status?mr.WHITE:n?mr.YELLOW:mr.DIM},e.label)),n&&t?K.createElement(ne,{marginLeft:3},K.createElement(re,{color:mr.DIM},truncateRepoLearnPanelText(t))):null)})),"RepoLearnStepList");Ft(),Or();var fM=__name(({insights:e,insightCount:t})=>0===e.length?null:K.createElement(ne,{flexDirection:"column",marginTop:1,marginLeft:4},K.createElement(re,{color:mr.CYAN},t>0?`Recent signals · ${t} ${1===t?"preference":"preferences"} learned`:"Recent signals"),e.map((e,t)=>K.createElement(re,{key:`${t}-${e}`,color:mr.DIM},cM[t%cM.length]," ",truncateRepoLearnPanelText(e,14)))),"RepoLearnRollingInsights");Ft(),Or();var yM=__name(({message:e})=>K.createElement(ne,{flexDirection:"column",borderStyle:"single",borderColor:mr.RED,paddingX:2,paddingY:1,marginTop:1},K.createElement(re,{color:mr.RED,bold:!0},"Oops, something went wrong:"),K.createElement(ne,{marginTop:1},K.createElement(re,null,e))),"RepoLearnErrorPanel");Ft(),Or(),io();var wM=__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:mr.DIM},iI),K.createElement(ne,{marginLeft:2},K.createElement(re,{color:gr.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:mr.DIM},Ie.pointerSmall," Taste stored in"," "),K.createElement(ro,{url:`file://${e.storage}`,text:r||".commandcode/taste/taste.md",color:mr.CYAN})),K.createElement(ne,null,K.createElement(re,{color:mr.DIM},Ie.pointerSmall," Share your coding taste:"," ",K.createElement(re,{color:mr.CYAN},"npx taste push --all")))),K.createElement(ne,{marginTop:1,marginLeft:1},K.createElement(re,{color:mr.DIM},o?"Command Code automatically uses & updates taste files as you code.":"Command Code will learn your preferences as you code.")))},"RepoLearnCompletionSummary");Ft(),Or();var SM=__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:mr.DIM},"ESC to cancel")),"RepoLearnFooter");Ft(),Or();var bM=__name(({text:e,repoName:t})=>{const n=useTerminalWidth(),r=ee(()=>Yx(n),[n]);return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(nA,null,r.trimEnd())),e?K.createElement(re,{color:mr.WHITE},e):K.createElement(K.Fragment,null,K.createElement(re,{color:mr.WHITE},"Learning your coding taste from"," ",K.createElement(re,{bold:!0,color:mr.CYAN},t??"repository")),K.createElement(re,{color:mr.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(yM,{message:e}):t?K.createElement(wM,{summary:n,elapsedSeconds:r}):K.createElement(fM,{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(bM,{text:r,repoName:o}),K.createElement(kP,{onComplete:(e,t)=>{s.setShowLogin(!1),e?xT.resolveAuth():xT.rejectAuth(t)},onCancel:()=>{s.setShowLogin(!1),xT.rejectAuth("Login cancelled"),t({published:!1,cancelled:!0})}})):K.createElement(ne,{flexDirection:"column"},K.createElement(bM,{text:r,repoName:o}),K.createElement(pM,{isComplete:s.done&&!s.error,hasError:Boolean(s.error)}),K.createElement(hM,{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(SM,{done:s.done,error:s.error}))}async function runRepoLearnProgress(e){return withFilteredStderrNoise(()=>renderProgressUI(e))}function renderProgressUI(e){return new Promise((t,n)=>{xT.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,xT.addEvent({type:"error",message:toRepoLearnErrorMessage(e)}),xT.markLearningComplete())}},"handleRunTask"),u=__name(({published:e,cancelled:l})=>{a||(a=!0,i=e,r.abort(),d.unmount(),xT.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=>{xT.reset(),n(e)})})}__name(StatusPanel,"StatusPanel"),__name(RepoLearnProgressApp,"RepoLearnProgressApp"),__name(runRepoLearnProgress,"runRepoLearnProgress"),__name(renderProgressUI,"renderProgressUI"),FE();var EM=__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 Me("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",EM("--max-commits"),200).addOption(new Ne("--max-signals <number>","Maximum diff signals to extract").default(50).argParser(EM("--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 C.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:[...lM];({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),UE(),await $I({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(w.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"),Ft(),Ft(),Ft(),Cn(),__name(getTastePath,"getTastePath"),__name(getRootTasteFile,"getRootTasteFile"),__name(getCategoryPath,"getCategoryPath"),__name(getCategoryTasteFile,"getCategoryTasteFile"),Ft(),Ft();var vM=/confidence:/i;function findLookaheadEnd(e,t){const n=e.slice(t),r=n.findIndex(e=>{const t=e.trim();return t.startsWith("#")||t.startsWith("-")||vM.test(t)});if(-1===r)return{endIdx:e.length,inclusive:!1};const o=n[r].trim();return{endIdx:t+r,inclusive:vM.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(vM.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(!vM.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:`${Ie.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?Ie.cross:Ie.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"),Ft(),__name(formatSingleIssue,"formatSingleIssue"),__name(formatIssueGroup,"formatIssueGroup"),__name(formatValidationIssues,"formatValidationIssues");var CM=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;CM.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 kM=/^see \[[^\]]+\/taste\.md\]\([^\)]+\/taste\.md\)$/i,TM=/^\[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}):kM.test(s)||TM.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 _M=__name(e=>"local-global"===e?"global":"project","locationLabel"),xM=__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 O(n)?{result:{path:n,displayName:`${e}/taste.md`}}:{error:{file:e,error:`Taste package '${e}' not found in ${_M(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});O(o)&&r.push({path:o,displayName:"taste.md"});const s=(await C.readdir(t,{withFileTypes:!0})).filter(e=>e.isDirectory()).map(e=>({entry:e,categoryFile:getCategoryTasteFile({target:n,category:e.name})})).filter(({categoryFile:e})=>O(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 C.readFile(e.path,"utf-8");const n=migrateHeader({content:t});n!==t&&(await C.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 xM({file:"all",error:`No taste files found in ${_M(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 xM({file:"all",error:`No taste files found in ${_M(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 O(r)?t.length>0?lintSpecificPackages({packages:t,target:n}):lintAllFiles({tastePath:r,target:n}):xM({file:"all",error:`No taste directory found in ${_M(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"),Ft(),Ts(),__name(resolveConflictStrategy,"resolveConflictStrategy");var AM=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 PM=__name((e,t)=>t,"linkFallback");function getPackageLink({owner:e,packageName:t}){return bt(`commandcode.ai/${e}/${t}`,`https://commandcode.ai/${e}/${t}`,{fallback:PM})}function getProfileLink(e){return bt(`commandcode.ai/${e}`,`https://commandcode.ai/${e}`,{fallback:PM})}function wrapLine(e,t=0){const n=(process.stdout.columns||80)-t;return St(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 Me("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(Ie.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 C.readFile(t,"utf-8"),r=migrateHeader({content:n});return r===n?n:(await C.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 ov+"\n\n";const t=e.trim();return t.startsWith(nv)||t.startsWith(sv)||t.startsWith(iv)?e:ov+"\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"),Ft(),qs(),Ft(),Ft(),Ft(),__name(parseSection,"parseSection"),__name(parsePackages,"parsePackages"),__name(parseLearning,"parseLearning"),__name(normalizeCategory,"normalizeCategory"),__name(denormalizeCategory,"denormalizeCategory"),Ft(),__name(formatPackage,"formatPackage"),Ft(),__name(readAndMigrateFile,"readAndMigrateFile"),__name(trimTrailingBlanks,"trimTrailingBlanks"),__name(findCategoryRange,"findCategoryRange"),__name(ensureHeader,"ensureHeader"),__name(ensureTrailingNewlines,"ensureTrailingNewlines");var IM="local-global";async function loadCategoryPackages(e){if(!e.isDirectory())return[];const t=getCategoryTasteFile({target:IM,category:e.name});return O(t)?parsePackages({content:await readAndMigrateFile({filePath:t}),sourcePath:t}).map(t=>({...t,category:e.name})):[]}async function getPackageInfo(e){try{const t=await C.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:IM});if(!O(e))return[];const t=await C.readdir(e,{withFileTypes:!0});return(await Promise.all(t.map(loadCategoryPackages))).flat()}async function getPackage(e){const{category:t}=e,n=getCategoryTasteFile({target:IM,category:t});return O(n)&&parsePackages({content:await readAndMigrateFile({filePath:n}),sourcePath:n})[0]||null}async function writePackage(t){const{pkg:n}=t,r=getTastePath({target:IM});await C.mkdir(r,{recursive:!0});const o=getCategoryTasteFile({target:IM,category:n.category}),s=e.dirname(o);await C.mkdir(s,{recursive:!0});const i=formatPackage({pkg:n});await C.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"),Ft(),Ft();var MM="local-project";async function removeCategoryFromRoot(e){const{category:t,rootFile:n}=e;if(!O(n))return null;const r=migrateHeader({content:await C.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 C.rm(n,{force:!0}),""!==l&&await C.writeFile(n,l+"\n","utf-8"),a}async function removePackage(t){const{category:n}=t,r=getRootTasteFile({target:MM}),o=await removeCategoryFromRoot({category:n,rootFile:r}),s=getCategoryTasteFile({target:MM,category:n}),i=e.dirname(s);return O(i)&&await C.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 C.writeFile(n,e.trim()+"\n","utf-8")}let s="";O(n)&&(s=await C.readFile(n,"utf-8"),s=migrateHeader({content:s})),s=ensureHeader(s),s=ensureTrailingNewlines(s),s+=o,await C.writeFile(n,s.trim()+"\n","utf-8")}async function writeToSubdirectory(t){const{pkg:n,rootFile:r,categoryPosition:o}=t,s=getCategoryTasteFile({target:MM,category:n.category}),i=e.dirname(s);await C.mkdir(i,{recursive:!0});const a=formatPackage({pkg:n});await C.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 C.writeFile(r,e.trim()+"\n","utf-8")}let u="";O(r)&&(u=await C.readFile(r,"utf-8"),u=migrateHeader({content:u})),u=ensureHeader(u),u=ensureTrailingNewlines(u),u+=l,await C.writeFile(r,u.trim()+"\n","utf-8")}__name(removeCategoryFromRoot,"removeCategoryFromRoot"),__name(removePackage,"removePackage"),__name(writeToRoot,"writeToRoot"),__name(writeToSubdirectory,"writeToSubdirectory");var NM="local-project";async function loadCategoryPackages2(e){if(!e.isDirectory())return[];const t=getCategoryTasteFile({target:NM,category:e.name});return O(t)?parsePackages({content:await readAndMigrateFile({filePath:t}),sourcePath:t}).map(t=>({...t,category:e.name})):[]}async function getAllPackages2(){const e=getTastePath({target:NM});if(!O(e))return[];const t=[],n=getRootTasteFile({target:NM});if(O(n)){const e=parsePackages({content:await readAndMigrateFile({filePath:n}),sourcePath:n});t.push(...e)}const r=await C.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:NM});await C.mkdir(n,{recursive:!0});const r=getRootTasteFile({target:NM}),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:NM});return O(e)}async function appendCategoryFile(e,t){const n=getCategoryTasteFile({target:"local-project",category:t.category});if(!O(n))return;const r=await C.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(!O(h))return l;const f=getCategoryTasteFile({target:"local-project",category:r.category});if(!O(f))return l;const y=await C.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(O(a)){const e=await C.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:ws.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}${zt.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}${zt.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:ws.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()}${zt.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:ws.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()}${zt.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()}${zt.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()}${zt.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 C.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 Me("list").alias("ls").option("-g, --global","List global packages").addOption(new Ne("-l, --local","Use local server").hideHelp()).option("--remote","List remote packages").addOption(new Ne("--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"),Ft(),IS(),Ft(),__name(appendCategoryFile,"appendCategoryFile"),__name(prepareUploadFormData,"prepareUploadFormData"),__name(prepareMultiplePackagesUpload,"prepareMultiplePackagesUpload"),Cn(),Ft(),__name(parseLearningLine,"parseLearningLine"),__name(parseTasteContent,"parseTasteContent"),BE(),Ts(),Ft(),FE(),Ts(),__name(parseApiError,"parseApiError"),__name(throwTrackedError,"throwTrackedError"),__name(requireAuthKey,"requireAuthKey"),Ft(),IS(),FE(),Cn(),__name(downloadPackage,"downloadPackage"),__name(tryPublicDownload,"tryPublicDownload"),__name(tryAuthenticatedDownload,"tryAuthenticatedDownload"),er(),__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 RM={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?RM.remote:e.global?RM.global:RM.project}function getPackageDisplayLength(e){let t=e.category.length;return e.isPublic&&(t+=9),e.isPublic&&e.starCount&&(t+=` ${Ie.star}${e.starCount}`.length),e.downloadCount&&(t+=` ${Ie.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(` ${Ie.star}${e.starCount}`):""}${e.downloadCount?ue.gray(` ${Ie.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?Re(`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${AM} 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 C.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 wt([{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"),Ft(),Ft(),__name(fetchAllPackages,"fetchAllPackages"),__name(handleOpenError,"handleOpenError"),__name(readCategoryLineNumber,"readCategoryLineNumber"),__name(findCategoryLineNumber,"findCategoryLineNumber"),__name(openPackage,"openPackage");var $M=new Set(["local-project","local-global","remote-project","remote-user"]);async function open11(e){const{package:t,target:n}=e;if(!$M.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=Et.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 Me("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(Ie.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(Ie.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"),Ft(),Ft(),Ft(),Ft();var LM=null,DM=!1;function setActiveSpinner(e){LM=e}function stopActiveSpinner(e){LM&&(LM.stop(e),LM=null)}function setPrompted(e){DM=e}function wasPrompted(){return DM}function beginPrompt(e,t){stopActiveSpinner(),ze.intro(ue.dim(e)),t&&ze.log.message(ue.dim(t)),setPrompted(!0)}function handleCancel(e){ze.isCancel(e)&&(ze.cancel("Operation cancelled"),process.exit(0))}function startStrategySpinner(e){if("skip"===e){const e=ze.spinner();return e.start("Skipping"),void e.stop("Skipped")}const t="merge"===e?"Merging":"Overwriting",n="merge"===e?"Merged":"Overwritten",r=ze.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),ze.log.warn("Non-interactive terminal detected, using default merge strategy"),"merge";beginPrompt(`Pulling ${ue.green(`'${t}'`)} from ${n}`,s),ze.log.message(`Local: ${r.learnings.length} learnings\nRemote: ${o} learnings ${ue.dim(`(from ${n})`)}`);const i=await ze.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),ze.log.warn("Non-interactive terminal detected, using default merge strategy"),"merge";beginPrompt(`Pushing ${ue.green(`'${t}'`)} to global`,o),ze.log.message(`Local: ${n} learnings\nGlobal: ${r.learnings.length} learnings`);const s=await ze.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),ze.log.warn("Non-interactive terminal detected, using default merge strategy"),"merge";beginPrompt(`Pulling ${ue.green(`'${t}'`)} from global`,o),ze.log.message(`Local: ${n.learnings.length} learnings\nGlobal: ${r} learnings`);const s=await ze.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),ze.log.warn("Non-interactive terminal detected, skipping push"),"skip";const i=bt(`commandcode.ai/${n}/${t}`,`https://commandcode.ai/${n}/${t}`,{fallback:__name((e,t)=>t,"fallback")});beginPrompt(`Pushing ${ue.green(`'${t}'`)} to ${n}`,s),ze.log.message(`Local: ${t} (${r} learnings)\nRemote: ${t} (${o} learnings) in ${n}`),ze.log.info(`Current package: ${ue.cyan(i)} ${ue.dim("(review)")}`);const a=await ze.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),ze.log.warn("Non-interactive terminal detected, skipping push"),"skip";const i=bt(`commandcode.ai/${n}/${t}`,`https://commandcode.ai/${n}/${t}`,{fallback:__name((e,t)=>t,"fallback")});beginPrompt(`Pushing ${ue.green(`'${t}'`)} to ${n}`,s),ze.log.message(`Local: ${r} learnings\nRemote: ${o} learnings`),ze.log.info(`Current package: ${ue.cyan(i)} ${ue.dim("(review)")}`);const a=await ze.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"),Ft(),Ft(),__name(mergeSingleLearning,"mergeSingleLearning"),__name(mergePackages,"mergePackages"),__name(validateSinglePackage,"validateSinglePackage"),__name(validateSingleRemoteFile,"validateSingleRemoteFile"),__name(validatePackages,"validatePackages"),__name(validateRemoteFiles,"validateRemoteFiles"),__name(mergeOrKeep,"mergeOrKeep"),Ft(),__name(resolveRemotePullStrategy,"resolveRemotePullStrategy"),__name(executePackageStrategy,"executePackageStrategy"),__name(processPackage,"processPackage"),__name(pullProjectPackage,"pullProjectPackage"),__name(pullCategoryPackage,"pullCategoryPackage");var OM=__name(({pkg:e,error:t})=>({success:!1,packagesPulled:[],errors:[{pkg:e,error:t}],mergeDetails:{},overwritten:[],filePaths:{}}),"fail"),FM=__name(()=>({success:!0,packagesPulled:[],skipped:[],errors:[],mergeDetails:{},overwritten:[],filePaths:{}}),"emptyResult"),UM=__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 OM({pkg:"all",error:`Invalid source: ${n}`});const s=UM(n);let i;try{i="local-global"===n?await getAllPackages():await getAllPackages3()}catch(e){return OM({pkg:"all",error:e instanceof Error?e.message:String(e)})}if(0===i.length)return OM({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=FM();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 OM({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=FM();try{return await executePullRemote({owner:t,packageName:n,overwrite:r,flagStrategy:o,result:s})}catch(e){return OM({pkg:n,error:e instanceof Error?e.message:String(e)})}}function logResult(e){if(wasPrompted())return ze.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()?"":`${Ie.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&&ze.log.message(l.join("\n")),ze.outro(`${a} from ${n}`),setPrompted(!1),hasMergeConflictRiskInRecord(t.mergeDetails??{})):(console.log(`${ue.green(Ie.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 Me("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 Ne("--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 Ne("--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(Re("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(Re("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 Xw({baseUrl:e}),n=await t.get({endpoint:zt.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 ze.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()?"":`${Ie.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()?"":`${Ie.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()?"":`${Ie.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()?"":`${Ie.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&&ze.log.message(i.join("\n"));const a=`${s} ${1===s?"package":"packages"}`;ze.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"),Ft(),__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"),Ft(),er(),Ft(),IS(),yS(),Cn(),__name(fetchUserNamespaces,"fetchUserNamespaces"),Ft(),__name(logResult2,"logResult"),__name(logPushAllSuccess,"logPushAllSuccess"),__name(logPushSingleSuccess,"logPushSingleSuccess"),__name(logPushMultiSuccess,"logPushMultiSuccess"),__name(logPushUrls,"logPushUrls"),__name(logConflictSummary,"logConflictSummary"),__name(logPushBreakdown,"logPushBreakdown"),__name(logPushSuccess,"logPushSuccess"),Ft(),BE(),Ft();var jM=__name(({pkg:e,error:t})=>({success:!1,packagesPushed:[],skipped:[],errors:[{pkg:e,error:t}],mergeDetails:{},overwritten:[],filePaths:{}}),"fail"),qM=__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=qM(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 jM({pkg:"all",error:e instanceof Error?e.message:String(e)})}}__name(resolvePushAllStrategy,"resolvePushAllStrategy"),__name(executePushAllRemote,"executePushAllRemote"),__name(pushAllRemote,"pushAllRemote");var BM=__name(({pkg:e,error:t})=>({success:!1,packagesPushed:[],skipped:[],errors:[{pkg:e,error:t}],mergeDetails:{},overwritten:[],filePaths:{}}),"fail"),zM=__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 WM=__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=WM({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 BM({pkg:"all",error:"No taste directory found in project"});const a=await getAllPackages2();if(0===a.length)return BM({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}):BM({pkg:"all",error:"Failed to get owner for remote push"});if("local-global"!==r&&"remote-project"!==r&&"remote-user"!==r)return BM({pkg:"all",error:`Invalid target: ${r}`});const m=zM();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 BM({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 BM({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=zM();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 BM({pkg:t,error:"No taste directory found in project"});try{return await executeRemotePush(e)}catch(e){return BM({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 ze.select({message:"Owner",options:r,initialValue:t});return ze.isCancel(o)&&(ze.cancel("Operation cancelled"),process.exit(0)),o}function createPushCommand(){return new Me("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 Ne("--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 Ne("--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"),Ft(),__name(promptOwnerSelection,"promptOwnerSelection"),__name(createPushCommand,"createPushCommand"),__name(validatePushOptions,"validatePushOptions");var HM=__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};ze.intro(ue.dim(`pushing ${t}`)),setPrompted(!0);const o=ze.spinner();o.start("Resolving"),(await list({location:"local-project"})).some(e=>e.category===t)||(o.error("Failed"),ze.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(Re("Pushing taste packages").start());const l=await push({packages:[],target:"remote-project",overwrite:n.overwrite,isPublic:HM(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:HM(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=ze.spinner();return e.start(`Pushing to ${t}/${n}`),void setActiveSpinner(e)}setActiveSpinner(Re("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(Re("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 Me(rn.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=Re("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(Ie.tick)} Update available`),showVersionDetails(t)):e.succeed(`Up to date ${de.dim(`(${t.currentVersion})`)}`)}async function performUpdateAction(){const e=Re("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} ${Ie.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:ws.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"),so(),__name(createTasteCommand,"createTasteCommand"),Ft(),Cn(),Ts(),__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 GM=new Me("update").description("Update Command Code to the latest version").option("--check-only","Check for updates without installing").allowUnknownOption().allowExcessArguments().action(updateAction);Ft(),FE(),BE();var VM=__name((e,t)=>`${Ie.info} ${e}: ${de.cyan(t)}`,"formatInfoLine"),QM=__name(e=>de.bold(`${e}:`),"formatSectionHeader"),KM=__name(e=>de.red(e),"formatError"),YM=__name(e=>e instanceof Error?e.message:"Unknown error","formatErrorMessage"),JM=__name(e=>["",QM("User Information"),VM("Name",e.name),VM("Email",e.email),VM("Username",e.userName)],"buildUserOutput"),XM=__name(e=>["",QM("Organization"),VM("Name",e.name),VM("Login",e.login)],"buildOrgOutput"),ZM=__name(e=>{e.forEach(e=>console.log(e))},"printLines"),eN=__name((e,t)=>{ZM(JM(e)),t&&ZM(XM(t)),console.log("")},"displayUserInfo"),tN=__name(e=>null!==e&&e.length>0,"validateApiKey"),nN=__name(e=>e.success&&null!==e.user,"validateUserData");async function whoamiAction(){const e=Re("Fetching user information...").start();try{const t=await getAuthKey();tN(t)||(e.fail(KM('Not authenticated. Please login using "cmd auth login"')),process.exit(1));const n=await getAuthenticatedEntity();nN(n)||(e.fail(KM("Failed to fetch user info")),process.exit(1)),e.succeed("User information loaded"),eN(n.user,n.org)}catch(t){e.fail(KM(`Error: ${YM(t)}`)),process.exit(1)}}__name(whoamiAction,"whoamiAction");var rN=new Me("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"!==be("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=be("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=be("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(!be(`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:""===be("git status --porcelain",{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim()}}Ft(),Ft(),Cn(),yS(),Bs(),IS(),On(),fo(),Ft(),__name(normalizeGitUrl,"normalizeGitUrl"),__name(validateGitRepo,"validateGitRepo"),Ft(),IS(),FE(),Ft();var oN=["completed","failed","cancelled","timed_out"];function isTerminalStatus(e){return oN.includes(e)}__name(isTerminalStatus,"isTerminalStatus");var sN={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=sN[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=Re({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=Re({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){const n=e.data.message||"Unknown error";return t.workingSpinner&&(t.workingSpinner.fail(n),t.workingSpinner=null),t.currentSpinner&&(t.currentSpinner.fail(n),t.currentSpinner=null),void(t.phase="done")}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(`${Ie.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=Re({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=Re({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=L.readFileSync(getAuthFile(),"utf-8")}catch{}try{t=L.readFileSync(getConfigFile(),"utf-8")}catch{}return{auth:e,config:t}}async function askQuestion(e){const t=lt.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,isInternalTeam:r,configFiles:o}){return new Xw({baseUrl:getApiBaseUrl()}).post({endpoint:zt.ALPHA.SANDBOX.START,body:{repoUrl:e,branch:t,prompt:n,isInternalTeam:r,configFiles:o}})}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=isInternalTeamFlagPresent(),o=readLocalConfigFiles(),s=e||await askQuestion(`${de.bold("What do you want to do?")}\n${de.cyan(">")} `);if(!s.trim())return void console.error(de.yellow("No prompt provided. Aborting."));const i=s.trim().slice(0,on.MAX_PROMPT_CHARS),a=Re({stream:process.stderr,text:"Starting sandbox session..."}).start();try{const e=await startSandboxSession({repoUrl:n.repoUrl,branch:n.branch,prompt:i,isInternalTeam:r,configFiles:o});a.succeed("Sandbox started"),await streamSession({sessionId:e.sessionId,prompt:i}),process.exit(0)}catch(e){a.fail("Failed to start sandbox session");const t=e instanceof Ps,r=t?e.code:void 0;if(401===(t?e.status:void 0)||"UNAUTHORIZED"===r)console.error(de.red("\nAuthentication failed. Try logging in again: cmd login"));else if("GITHUB_APP_NOT_INSTALLED"===r){const e=de.cyan(de.underline(n.repoUrl)),t=de.cyan(de.underline("https://github.com/apps/command-code-ai/installations/new"));console.error(`\n${de.red("✖")} Command Code GitHub App isn't installed on ${e}`),console.error(` Install it here: ${t}`),console.error(de.dim(" Then run this command again."))}else{const n=t&&"string"==typeof e.message?e.message:"Something went wrong. Please try again.";console.error(de.red(`\n${n}`))}process.exit(1)}}function createSandboxCommand(){return new Me("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(S.tmpdir(),`commandcode-skill-${R()}`);await k.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 k.access(l),d=!0}catch{}if(!d)try{await k.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 k.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(()=>(YE(),KE)),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 k.access(n),n}catch{}const r=t.join(e,"skill.md");try{return await k.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 k.readFile(t,"utf-8"),{data:r}=Ue(n),o=_f.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 k.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 k.mkdir(a,{recursive:!0});const d=t.join(a,r),{randomUUID:m}=await import("crypto"),g=t.join(a,`.${r}.tmp.${m()}`);try{await k.cp(u,g,{recursive:!0,force:!0,dereference:!1}),l&&s&&await k.rm(d,{recursive:!0,force:!0}),await k.rename(g,d)}catch(e){if(await k.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 k.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 k.rm(i,{recursive:!0,force:!0})}async function listSkills(){const{global:e,project:t,warnings:n}=await loadAllSkillSummariesWithWarnings(),r=getBundledSkillsDir(),o=[],s=[];for(const t of e){const e={name:t.name,description:t.description,location:isBundledSkillPath({filePath:t.filePath,bundledDir:r})?"bundled":"global",path:t.filePath};("bundled"===e.location?o:s).push(e)}return{global:s,project:t.map(e=>({name:e.name,description:e.description,location:"project",path:e.filePath})),bundled:o,warnings:n}}__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"),so(),Ft(),Ft(),Ft(),Ft(),QE(),__name(validateSafeString,"validateSafeString"),__name(parseGitHubRepo,"parseGitHubRepo"),__name(buildGigetSource,"buildGigetSource"),__name(fetchSkillFromGitHub,"fetchSkillFromGitHub"),__name(discoverSkillsInRepo,"discoverSkillsInRepo"),LS(),zf(),__name(resolveSkillMdPath,"resolveSkillMdPath"),__name(validateSkillName,"validateSkillName"),__name(validateSkillContent,"validateSkillContent"),__name(skillExists,"skillExists"),__name(discoverSkills,"discoverSkills"),__name(installSkill,"installSkill"),__name(removeSkill,"removeSkill"),__name(listSkills,"listSkills"),Cn();var iN=[`${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/")}`],aN=__name((e,t)=>`${de.green(Ie.tick)} Installed ${de.cyan(e)} ${de.dim(`${Ie.arrowRight} ${t}/`)}`,"formatInstalled"),lN=__name(e=>`${de.red(Ie.cross)} ${e}`,"formatError");async function cleanupAndExit(e,t){e&&await x(e,{recursive:!0,force:!0}).catch(()=>{}),process.exit(t)}function validateRepoFormat(e){(e.startsWith(".")||e.startsWith("/")||e.startsWith("~"))&&(console.error(lN("Local paths are not supported. Skills must be installed from GitHub.")),console.log(""),iN.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(lN(`Invalid repository: "${e}"`)),console.log(""),console.log(`Expected format: ${de.cyan("owner/repo")} or ${de.cyan("owner/repo/path")}`),console.log(""),iN.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=Re({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(lN(`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(lN(`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 We({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=Re({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(aN(i.name,r))}catch(e){d++;const t=e instanceof Error?e.message:String(e);console.error(lN(`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(lN(t)),await cleanupAndExit(o,1)}}__name(cleanupAndExit,"cleanupAndExit"),__name(validateRepoFormat,"validateRepoFormat"),__name(addAction,"addAction");var cN=new Me("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${iN.join("\n")}`).configureOutput({outputError:__name((e,t)=>{e.includes("missing required argument")?(console.error(lN("No repository specified.")),console.log(""),iN.forEach(e=>console.log(e))):t(e)},"outputError")}).action(addAction);Ft(),Cn();var uN=__name((e,t)=>`${de.green(Ie.tick)} Removed ${de.cyan(e)} from ${t} skills`,"formatRemoved"),dN=__name(e=>`${de.red(Ie.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(dN(o)),console.log(de.dim(`Run ${de.cyan("cmd skills list")} to see installed skills.`)),process.exit(1)),!t.yes&&n){const t=await He({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(uN(e,r)),process.exit(0)}catch(n){const r=n instanceof Error?n.message:"Failed to remove skill";r.includes("not found")?(console.error(dN(`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(dN(r)),process.exit(1)}}__name(validateSkillNameEarly,"validateSkillNameEarly"),__name(removeAction,"removeAction");var mN=new Me("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);Ft(),LS(),lE(),Cn();var pN=__name((e,t)=>{const n=t.length>60?t.substring(0,57)+"...":t;return` ${de.cyan(e)} ${de.dim(`· ${n}`)}`},"formatSkillLine"),gN=__name((e,t)=>`${de.bold(de.white(e))} ${de.dim(`(${t})`)}`,"formatSectionHeader"),hN=__name(e=>{if(0===e.length)return;const t=groupWarnings(e);console.log(""),console.log(`${de.bold(de.yellow("Skipped"))} ${de.dim(`(${e.length})`)}`);for(const e of t){console.log(""),console.log(` ${de.bold(e.category)} ${de.dim(`(${e.items.length})`)}`);for(const t of e.items)console.log(` ${de.bold(skillIdentifier(t.path))}`),console.log(` ${de.dim(t.reason)}`)}},"printWarnings"),fN=__name(()=>{const e=process.cwd(),n=t.join(e,".commandcode","skills"),r=t.join(e,".agents","skills"),o=getProjectSkillsDir(),s=getProjectAgentsCompatSkillsDir(),i=["",de.dim("No skills installed."),"",de.dim("Looking in:"),de.dim(` ${getGlobalSkillsDir()} ${de.white("(global)")}`),de.dim(` ${getGlobalAgentsCompatSkillsDir()} ${de.white("(global, .agents)")}`)];return n!==o&&i.push(de.dim(` ${n} ${de.white("(cwd)")}`)),r!==s&&i.push(de.dim(` ${r} ${de.white("(cwd, .agents)")}`)),i.push(de.dim(` ${o} ${de.white("(project)")}`),de.dim(` ${s} ${de.white("(project, .agents)")}`),"",`Install a skill: ${de.cyan("cmd skills add")} ${de.dim("<owner/repo>")}`,""),i},"formatEmptyHint"),yN=__name(e=>{e.forEach(e=>console.log(e))},"printLines");async function listAction(){const e="true"===process.env.DEBUG;try{const{global:t,project:n,bundled:r,warnings:o}=await listSkills(),s=t.length+n.length,i=__name(()=>{e||0===o.length||(console.log(""),console.log(de.dim(`${o.length} skill${1===o.length?"":"s"} skipped · run with ${de.cyan("--debug")} to see issues`)))},"printDebugHint");0===s&&(yN(fN()),r.length>0&&(console.log(gN("Bundled",r.length)),r.forEach(e=>{console.log(pN(e.name,e.description))}),console.log("")),e&&(hN(o),o.length>0&&console.log("")),e||(i(),console.log("")),process.exit(0)),console.log(""),console.log(heading({text:"Skills",sub:de.dim(`${s} installed`)})),n.length>0&&(console.log(""),console.log(gN("Project",n.length)),n.forEach(e=>{console.log(pN(e.name,e.description))})),t.length>0&&(console.log(""),console.log(gN("Global",t.length)),t.forEach(e=>{console.log(pN(e.name,e.description))})),r.length>0&&(console.log(""),console.log(gN("Bundled",r.length)),r.forEach(e=>{console.log(pN(e.name,e.description))})),e&&hN(o),e||i(),console.log(""),process.exit(0)}catch(e){const t=e instanceof Error?e.message:"Unknown error";console.error(`${de.red(Ie.cross)} Failed to list skills: ${t}`),process.exit(1)}}__name(listAction,"listAction");var wN=new Me("list").description("List all installed skills. Run with -d/--debug to also see why any skills were skipped.").action(listAction),SN=new Me("skills").description("Manage skills from GitHub repositories").addCommand(cN).addCommand(mN).addCommand(wN);handleUnhandledErrors(),setupTelemetry(),await preRun();var bN=createProgram();bN.action(interactiveModeAction),bN.addCommand(XI),bN.addCommand(ZI),bN.addCommand(rN),bN.addCommand(GM),bN.addCommand(JI),bN.addCommand(createTasteCommand()),bN.addCommand(createMcpCommand()),bN.addCommand(eM),bN.addCommand(xs),bN.addCommand(bE),bN.addCommand(PE),bN.addCommand(SN),isExperimentalEnabled()&&bN.addCommand(createSandboxCommand()),setupCommanderHooks(bN),bN.parse();
|
|
324
|
+
`,Zx=getMaxLineWidth(Xx),eA=Kx,tA=__name(e=>{const t=e??getTerminalWidth();return t>=Qx?"full":t>=eA?"compact":"minimal"},"getHeaderLayout");Ft(),Or();var nA=__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?$r.BG:$r.TEXT},e.text)))},"CommandLogoBanner");Ft(),Or();var rA=__name(({title:e,hashPrefix:t=!1,subPrefix:n=!1,suffix:r,padding:o=0,titleColor:s=mr.GRAY,dividerChar:i="─",dividerColor:a=mr.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:mr.DIM},g))},"Divider");qE(),Or(),Ft(),Or();var oA=[{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}],sA=__name(({onComplete:e,onExit:t})=>{const[n,r]=J(0),[o,s]=J(!1),i=n>=oA.length;return Z(()=>{if(n>=oA.length)return;if(o)return;const e=oA[n],t=setTimeout(()=>{r(e=>Math.min(e+1,oA.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,oA.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:mr.DIM},"Command Code learns your coding style as you work.")),K.createElement(ne,null,K.createElement(re,{color:mr.DIM},"Here's how your preferences evolve in real-time:")),K.createElement(ne,{flexDirection:"column",marginY:1},oA.slice(0,n).map((e,t)=>"user"===e.type?K.createElement(ne,{key:t},K.createElement(re,null,Ie.pointer," ",e.text)):K.createElement(ne,{key:t,flexDirection:"column",marginBottom:1,marginLeft:1},K.createElement(ne,null,K.createElement(re,{color:mr.DIM},"⎿ "),K.createElement(re,{color:gr.TEXT},e.text)),e.details&&K.createElement(ne,{marginLeft:3},K.createElement(re,{color:mr.DIM},"Saved(",e.details,")"))))),i?K.createElement(ne,{flexDirection:"column",marginY:1},K.createElement(ne,null,K.createElement(re,{bold:!0,color:gr.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:mr.DIM},"Press Enter to get started →"))):K.createElement(ne,null,K.createElement(re,{color:mr.DIM},"[SPACE: pause] [ENTER: next] [ESC: skip]"+(o?" (paused)":""))))},"TasteDemoComponent"),iA=__name(({onClose:e,onExit:t})=>{const[n,r]=J(xT.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(xT.getEvents())},"handleNewEvent"),t=__name(()=>{r([])},"handleCleared");return xT.on("new-event",e),xT.on("cleared",t),()=>{xT.off("new-event",e),xT.off("cleared",t)}},[]),Z(()=>{const e=__name(()=>{UE(),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=ee(()=>n.find(e=>"analyzing"===e.type),[n]),l=ee(()=>n.find(e=>"analyzed"===e.type),[n]),u=ee(()=>n.find(e=>"no_learnings"===e.type),[n]),d=ee(()=>n.find(e=>"learned"===e.type||"refactored"===e.type),[n]),m=u?n.indexOf(u):1/0,g=d?n.indexOf(d):1/0,h=!!u&&m<g,f=!!a||!!l||h,y=ee(()=>n.filter(e=>"analyzing"!==e.type&&"analyzed"!==e.type&&"no_learnings"!==e.type),[n]),w=ee(()=>[...y].reverse(),[y]),S=__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"),E=__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"),v=__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"),C=ee(()=>(process.stdout.rows??24)-1,[o]);return K.createElement(ne,{flexDirection:"column",width:"100%",height:C,justifyContent:"flex-start",alignItems:"flex-start",padding:0,margin:0},K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(nA,null,Yx())),K.createElement(rA,{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:mr.DIM},"Your preferences, patterns, and style will appear here in real-time."))),K.createElement(ce,{count:2}),K.createElement(rA,{title:"DEMO",titleColor:"white",subPrefix:!0}),K.createElement(sA,{onComplete:()=>{e()},onExit:t})):K.createElement(ne,{flexDirection:"column"},y.length>0&&K.createElement(ne,{flexDirection:"column",gap:1},w.map(e=>{if(i(e.type)){const{type:t,label:n,content:r,confidence:o}=S(e.message),s="moved"===t?v(e.details):null,i="upgraded"===t||"downgraded"===t?E(r):null,a=s?.fullPath??e.details;let l=K.createElement(K.Fragment,null,K.createElement(re,null," ",r),o&&K.createElement(re,{color:mr.DIM}," ","(",o,")"));return i&&(l=K.createElement(K.Fragment,null,K.createElement(re,null," ",i.text," ("),K.createElement(re,{color:mr.DIM},"confidence:"," "),K.createElement(re,{color:mr.DIM},i.oldPercent,"%"),K.createElement(re,null," ",Ie.arrowRight," "),K.createElement(re,{color:i.diff>0?mr.GREEN:mr.RED},i.newPercent,"%"),K.createElement(re,null,")"))),s&&(l=K.createElement(K.Fragment,null,K.createElement(re,null," ",s.category," ","package ("),K.createElement(re,{color:mr.DIM},s.oldPath),K.createElement(re,null," ",Ie.arrowRight," ",s.newPath),K.createElement(re,null,")"))),K.createElement(ne,{key:e.id},K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:gr.BADGE_BG,color:gr.BADGE_FG,bold:!0},`${ZT}${n}${ZT}`)),a&&K.createElement(re,{color:mr.DIM}," ","(",a,")")),K.createElement(ne,{marginLeft:1},K.createElement(re,{color:mr.DIM},"⎿"," "),l)))}return K.createElement(ne,{key:e.id},K.createElement(re,{color:mr.DIM},Ie.pointerSmall," ",e.message))})),f&&K.createElement(ne,{flexDirection:"column",marginTop:y.length>0?1:0},a&&K.createElement(ne,null,K.createElement(re,{color:mr.DIM},Ie.pointerSmall," ",a.message)),l&&K.createElement(ne,null,K.createElement(re,{color:mr.DIM},Ie.pointerSmall," ",l.message)),h&&u&&K.createElement(ne,null,K.createElement(re,{color:mr.DIM},Ie.pointerSmall," ",u.message))))))},"LearningFeedFull");function LearningView({setShowLearningFeed:e,setStaticKey:t,onExit:n}){return K.createElement(iA,{onClose:()=>{UE(),e(!1),t(e=>e+1)},onExit:n})}__name(LearningView,"LearningView"),Ft(),Or(),Ft(),Or(),qE(),so();var aA=__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?(UE(),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:mr.BLUE,padding:1,flexDirection:"column"},K.createElement(re,{color:mr.BLUE,bold:!0},"Taste Settings"),K.createElement(re,{color:mr.DIM},"Loading configuration...")):K.createElement(ne,{key:n,borderStyle:"single",borderColor:mr.GRAY,padding:1,flexDirection:"column"},K.createElement(re,{bold:!0},"Taste Learning"),K.createElement(re,{color:mr.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:mr.DIM}," ","- Learn from your interactions")),K.createElement(re,{color:r?mr.GREEN:mr.GRAY},r?"enabled":"disabled")),K.createElement(ne,{marginTop:1}),K.createElement(re,{color:mr.DIM},"Taste data stored in .commandcode/taste/taste.md"),K.createElement(re,{color:mr.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(_x,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.DIM},"Press Esc to return to conversation")),K.createElement(aA,{onClose:()=>t(!1),onSettingsChange:n,staticKey:e})))}function fuzzyMatch(e,t){let n=0;for(const r of e)if(r===t[n]&&(n++,n===t.length))return!0;return!1}function fuzzyScore(e,t){let n=0;for(const r of e)fuzzyMatch(r.text.toLowerCase(),t)&&(n+=r.weight);return n}function fuzzyFilter(e,t,n){if(!t.trim())return e;const r=t.toLowerCase().split("");return e.map(e=>({item:e,score:fuzzyScore(n(e),r)})).filter(({score:e})=>e>0).sort((e,t)=>t.score-e.score).map(({item:e})=>e)}__name(TasteConfigView,"TasteConfigView"),Ft(),Ft(),Cn(),Ft(),__name(fuzzyMatch,"fuzzyMatch"),__name(fuzzyScore,"fuzzyScore"),__name(fuzzyFilter,"fuzzyFilter"),qE(),Or(),Ft(),Or();var lA=__name(({query:e,resultCount:t,placeholder:n="Type to search..."})=>K.createElement(ne,{width:"100%"},K.createElement(re,{color:mr.GRAY},Ie.pointerSmall," "),K.createElement(re,{color:e?mr.WHITE:mr.GRAY},e||n),e&&void 0!==t&&K.createElement(re,{dimColor:!0}," (",t," found)")),"SearchInput");function useListNavigation({items:e,onSelect:t,onCancel:n,validate:r,initialIndex:o=0,searchCursorIndex:s=0,searchQuery:i,onSearchChange:a,isActive:l=!0,disableSearch:u=!1,onReset:d}){const[m,g]=J(o),[h,f]=J(null);Z(()=>{i||g(o)},[o,i]);const y=e.length-1,w=__name(e=>{a(e),g(s)},"updateSearch");return ie((o,s)=>{if(s.escape)return!u&&i?void w(""):void n();if(u||!s.backspace&&!s.delete){if(u&&d&&"r"===o&&!s.ctrl&&!s.meta){const t=e[m];return void(t&&d(t))}if(0!==e.length){if(s.upArrow)return f(null),void g(e=>e>0?e-1:y);if(s.downArrow)return f(null),void g(e=>e<y?e+1:0);if(s.return){const n=e[m];if(!n)return;if(r){const e=r(n);if(e)return void f(e)}return void t(n)}!u&&!s.ctrl&&!s.meta&&!s.tab&&o&&1===o.length&&o>=" "&&w(i+o)}}else w(i.slice(0,-1))},{isActive:l}),{cursor:m,error:h,setError:f}}function skillIdentifier(e){const n=t.basename(e);return"skill.md"===n.toLowerCase()?t.basename(t.dirname(e)):n}Ft(),__name(useListNavigation,"useListNavigation"),Ft(),Cn(),Or(),Ft(),qE(),Or(),io(),Ft(),__name(skillIdentifier,"skillIdentifier");var cA=new Set(["Invalid YAML","Missing fields","Missing SKILL.md"]);function categoryColor(e){return cA.has(e)?mr.RED:mr.YELLOW}function formatWarningsAsMarkdown(e){const t=groupWarnings(e),n=[`# Skipped skills (${e.length})`,""];for(const e of t){n.push(`## ${e.category} (${e.items.length})`,"");for(const t of e.items)n.push(`- \`${skillIdentifier(t.path)}\` — \`${t.path}\``),n.push(` - ${t.reason}`);n.push("")}return n.join("\n").replace(/\n+$/,"")+"\n"}async function copyAllWarnings(e,t){try{const{isClipboardAvailable:n}=await Promise.resolve().then(()=>(Hr(),Wr));if(!n())return void t({text:"Clipboard unavailable — copy the skipped skill paths manually",color:mr.YELLOW});const r=await import("@crosscopy/clipboard");await r.default.setText(formatWarningsAsMarkdown(e));const o=e.length;t({text:`Copied ${o} issue${1===o?"":"s"} to clipboard`,color:mr.GREEN})}catch{t({text:"Clipboard write failed",color:mr.YELLOW})}}__name(categoryColor,"categoryColor"),__name(formatWarningsAsMarkdown,"formatWarningsAsMarkdown"),__name(copyAllWarnings,"copyAllWarnings");var uA=__name(({warnings:e,onClose:t,isActive:n=!0})=>{const r=groupWarnings(e),o=e.length>0,[s,i]=J(null),a=X(null),l=X(!0);Z(()=>()=>{l.current=!1,a.current&&(clearTimeout(a.current),a.current=null)},[]);const u=__name(e=>{l.current&&(a.current&&clearTimeout(a.current),i(e),a.current=setTimeout(()=>{l.current&&(i(null),a.current=null)},3e3))},"showStatus");return ie((n,r)=>r.escape||" "===n&&o?(UE(),void t()):void("c"===n&&o&©AllWarnings(e,u)),{isActive:n}),K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:pr,bold:!0},"Skills"," "),K.createElement(re,{color:mr.DIM},"› "),K.createElement(re,{color:pr,bold:!0},"Skipped"," "),K.createElement(re,{color:mr.WHITE},e.length)),o&&K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.DIM},"Press c to copy all issues")),o?K.createElement(ne,{flexDirection:"column"},r.map(e=>K.createElement(ne,{key:e.category,flexDirection:"column"},K.createElement(ne,null,K.createElement(re,{color:categoryColor(e.category)},e.category)),e.items.map(e=>K.createElement(ne,{key:e.path,flexDirection:"column",marginBottom:1},K.createElement(ne,{paddingLeft:2},K.createElement(ro,{url:m(e.path).href,text:skillIdentifier(e.path),color:mr.WHITE})),K.createElement(ne,{paddingLeft:4},K.createElement(re,{color:mr.WHITE},e.reason))))))):K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"No issues — every skill loaded.")),s&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:s.color},s.text)),K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(re,{color:mr.DIM},o?"c copy all issues · esc back to skills":"esc back to skills")))},"SkillsConfigIssues"),dA=__name(({warnings:e=[],onClose:t})=>{const[n,r]=J("list");return ie((o,s)=>{"list"===n&&(s.escape&&t?t():" "===o&&!s.ctrl&&!s.meta&&e.length>0&&r("issues"))},{isActive:"list"===n}),"issues"===n?K.createElement(uA,{warnings:e,onClose:()=>r("list"),isActive:!0}):K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:pr,bold:!0},"Skills"),e.length>0&&K.createElement(K.Fragment,null,K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{color:mr.YELLOW},e.length," skipped"))),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.DIM},"No skills found")),K.createElement(re,{color:mr.DIM},"Create skills in:"),K.createElement(re,{color:mr.DIM}," ","~/",".commandcode","/","skills","/ (user)"),K.createElement(re,{color:mr.DIM}," ","~/.agents/","skills","/ (user, .agents)"),K.createElement(re,{color:mr.DIM}," ",".commandcode","/","skills","/ (project)"),K.createElement(re,{color:mr.DIM}," ",".agents/","skills","/ (project, .agents)"),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},e.length>0&&"space to view issues · ","Press ",K.createElement(re,{bold:!0},"Esc")," to close")))},"SkillsConfigEmpty");Ft();var mA=__name(e=>Math.ceil(e.length/4),"estimateTokens"),pA=__name(e=>e.includes("/.agents/skills/")||e.includes("\\.agents\\skills\\"),"isAgentsSkill"),gA={user:"user settings",projectShared:"project shared",projectLocal:"project local"},hA=__name(()=>"win32"===process.platform?'No editor found. Set $EDITOR: setx EDITOR "code"':"No editor found. Set $EDITOR: echo 'export EDITOR=\"code\"' >> "+("darwin"===process.platform?"~/.zshrc":"~/.bashrc"),"getEditorSetupMessage");Ft(),Or();var fA=__name(({title:e,subtitle:t,skills:n,baseIndex:r,cursor:o,disabled:s})=>K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(ne,null,K.createElement(re,{color:Cr,bold:!0},e," "),K.createElement(re,{color:Cr},t)),n.map((e,t)=>{const n=r+t===o,i=s.has(e.label),a=pA(e.filePath);return K.createElement(ne,{key:e.filePath},K.createElement(re,{color:mr.GREEN},n?"▸ ":" "),K.createElement(re,{color:i?mr.DIM:mr.GREEN},i?"[off] ":"[on] "),K.createElement(re,{color:i?mr.DIM:mr.WHITE},e.label),a&&K.createElement(re,{color:mr.DIM}," [.agents]"),K.createElement(re,{color:mr.DIM}," · ~",mA(e.description)," tokens"))})),"SkillSection");Ft();var yA=__name(e=>[{text:e.label,weight:100}],"SKILL_SEARCH_FIELDS"),wA=__name(({onClose:e})=>{const[t,n]=J([]),[r,o]=J([]),[s,i]=J(!0),[a,l]=J(null),[u,d]=J(""),[m,g]=J(new Set),[h,f]=J(new Map),[y,w]=J(!1),[S,E]=J(null),[v,C]=J("list"),k=X(!1);Z(()=>{__name(async()=>{try{const e=findGitRoot(),t=getBundledSkillsDir(),[{global:r,project:s,warnings:i},a]=await Promise.all([loadAllSkillSummariesWithWarnings(),loadDisabledSkills({projectRoot:e})]),l=__name(e=>isBundledSkillPath({filePath:e,bundledDir:t}),"isBundled"),u=[...s.map(e=>({label:e.name,location:"project",description:e.description,filePath:e.filePath})),...r.filter(e=>!l(e.filePath)).map(e=>({label:e.name,location:"user",description:e.description,filePath:e.filePath})),...r.filter(e=>l(e.filePath)).map(e=>({label:e.name,location:"bundled",description:e.description,filePath:e.filePath}))];u.sort((e,t)=>{if(e.location!==t.location){const n={project:0,user:1,bundled:2};return n[e.location]-n[t.location]}return e.label.localeCompare(t.label)}),n(u),o(i),g(new Set(a.names)),f(new Map(a.bySkill)),w(a.noProjectRoot)}catch(e){l(e instanceof Error?e.message:"Failed to load skills")}finally{i(!1)}},"load")()},[]);const T=ee(()=>fuzzyFilter(t.filter(e=>"project"===e.location),u,yA),[t,u]),_=ee(()=>fuzzyFilter(t.filter(e=>"user"===e.location),u,yA),[t,u]),x=ee(()=>fuzzyFilter(t.filter(e=>"bundled"===e.location),u,yA),[t,u]),A=ee(()=>[...T,..._,...x],[T,_,x]),P=__name(async e=>{if(k.current)return;const t=m.has(e.label),n=h.get(e.label);if(t&&void 0!==n&&"projectLocal"!==n&&!y)return void E(`Cannot enable: "${e.label}" is disabled in ${gA[n]}. Edit that file to override.`);k.current=!0;const r=new Set(m);t&&r.delete(e.label),t||r.add(e.label),g(r),E(null);try{const n=findGitRoot(),r=await setSkillEnabled(e.label,t,{projectRoot:n}),o=new Map(h);t&&o.delete(e.label),t||o.set(e.label,r),f(o),"user"===r&&E("Saved to user settings — no project found.")}catch(e){g(m),E(`Failed to save: ${e instanceof Error?e.message:String(e)}`)}finally{k.current=!1}},"toggleSkill");Z(()=>{"issues"===v&&d("")},[v]);const I="list"===v&&t.length>0,{cursor:M}=useListNavigation({items:A,onSelect:P,onCancel:__name(()=>{UE(),e()},"onCancel"),searchQuery:u,onSearchChange:d,initialIndex:0,isActive:I});if(ie((t,n)=>{if(!n.tab)return;const r=A[M];r&&(async()=>{try{await wt([{file:r.filePath,line:1}]),UE(),e()}catch(e){if(e instanceof Error&&e.message.includes("$EDITOR environment variable"))return void l(hA());l(e instanceof Error?e.message:"Failed to open skill in editor")}})()},{isActive:I}),ie((e,n)=>{"list"===v&&0!==t.length&&" "===e&&!n.ctrl&&!n.meta&&r.length>0&&0===u.length&&C("issues")},{isActive:"list"===v&&t.length>0}),s)return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(re,{color:pr,bold:!0},"Skills"),K.createElement(re,{color:mr.DIM},"Loading skills..."));if(a)return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(re,{color:mr.RED,bold:!0},"Skills"),K.createElement(re,{color:mr.DIM},a),K.createElement(ne,{marginTop:1}),K.createElement(re,{color:mr.DIM},"Press ",K.createElement(re,{bold:!0},"Esc")," to close"));if(0===t.length)return K.createElement(dA,{warnings:r,onClose:()=>{UE(),e()}});if("issues"===v)return K.createElement(uA,{warnings:r,onClose:()=>C("list"),isActive:!0});const N=t.filter(e=>m.has(e.label)).length;return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:pr,bold:!0},"Skills"," "),K.createElement(re,{color:mr.DIM},t.length," skill",1===t.length?"":"s"),N>0&&K.createElement(K.Fragment,null,K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{color:mr.YELLOW},N," off")),r.length>0&&K.createElement(K.Fragment,null,K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{color:mr.YELLOW},r.length," skipped"))),K.createElement(ne,{marginBottom:1},K.createElement(re,{dimColor:!0},y?"No project found — toggles will be saved to user settings.":"Toggle skills on or off for this project.")),K.createElement(ne,{marginBottom:1,flexDirection:"column",width:"100%"},K.createElement(lA,{query:u,resultCount:u?A.length:void 0,placeholder:"Type to search skills..."})),0===A.length?K.createElement(ne,{marginY:1},K.createElement(re,{color:mr.GRAY},'No skills match "',u,'"')):K.createElement(K.Fragment,null,T.length>0&&K.createElement(fA,{title:"Project skills",subtitle:"(.commandcode/skills or .agents/skills)",skills:T,baseIndex:0,cursor:M,disabled:m}),_.length>0&&K.createElement(fA,{title:"User skills",subtitle:"(~/.commandcode/skills or ~/.agents/skills)",skills:_,baseIndex:T.length,cursor:M,disabled:m}),x.length>0&&K.createElement(fA,{title:"Bundled skills",subtitle:"(ships with Command Code)",skills:x,baseIndex:T.length+_.length,cursor:M,disabled:m})),S&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.YELLOW},S)),K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(re,{color:mr.DIM},"type to search · ↑/↓ navigate · enter to toggle · tab to edit",r.length>0&&!u&&K.createElement(K.Fragment,null," · space to view issues"),u?" · esc to clear":" · esc to close"),K.createElement(re,{color:mr.DIM},"add skills:"," ",K.createElement(re,{color:mr.CYAN},"cmd skills add ","<owner/repo>"))))},"SkillsConfig");function SkillsConfigView({staticKey:e,setShowSkillsConfig:t}){return K.createElement(K.Fragment,null,K.createElement(_x,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(wA,{onClose:()=>t(!1),staticKey:e})))}function getUsageColor(e){return e>=80?mr.RED:e>=50?mr.YELLOW:mr.GREEN}function buildBlockBar({percentage:e,width:t}){const n=Math.max(0,Math.min(100,e));let r=Math.round(n/100*t);n>.5&&0===r&&(r=1),n<99.5&&r===t&&(r=t-1);const o=t-r;return{filled:"█".repeat(r),empty:"░".repeat(o)}}function getStudioUsageUrl(e){const t=e?.org?.login??e?.user?.userName;return t?`https://commandcode.ai/${t}/settings/usage`:null}__name(SkillsConfigView,"SkillsConfigView"),Ft(),Ft(),no(),qE(),Or(),Ft(),Or(),__name(getUsageColor,"getUsageColor"),__name(buildBlockBar,"buildBlockBar"),io(),__name(getStudioUsageUrl,"getStudioUsageUrl");var SA=__name(e=>e.replace(/^https?:\/\//,""),"stripScheme");function getProgressBarWidth({terminalWidth:e}){return e<50?Math.max(10,e-10):e<70?Math.max(15,e-15):Math.min(30,e-15)}function getDaysColor(e){if(null!==e)return e<3?mr.RED:e<7?mr.YELLOW:void 0}__name(getProgressBarWidth,"getProgressBarWidth"),__name(getDaysColor,"getDaysColor");var bA=__name(({plan:e,status:t})=>K.createElement(ne,{marginBottom:0},K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:mr.BLUE,color:"#f4f4f4",bold:!0},`${ZT}USAGE${ZT}`)),e&&K.createElement(K.Fragment,null,K.createElement(re,null," "),K.createElement(re,{color:mr.GRAY},`${e.name} Plan`)),t&&K.createElement(K.Fragment,null,K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{color:"active"===t?mr.GREEN:mr.YELLOW},t))),"UsageBadge"),EA=__name(({showRetry:e})=>K.createElement(ne,{marginTop:1},e&&K.createElement(re,{color:mr.DIM},K.createElement(re,{bold:!0},"r")," to retry · "),K.createElement(re,{color:mr.DIM},"Press ",K.createElement(re,{bold:!0},"Esc")," to close")),"UsageFooter"),vA=__name(({models:e,grandTotal:t})=>{if(0===e.length)return null;const n=e.map(e=>({...e,displayName:getModelDisplayName(e.model),costLabel:formatCredits(e.totalCost)})),r=Math.max(...n.map(e=>e.displayName.length)),o=Math.min(24,Math.max(10,r)),s=Math.max(...n.map(e=>e.costLabel.length)),i=Math.max(8,s+2);return K.createElement(ne,{flexDirection:"column",marginTop:1},n.map(({model:e,displayName:n,costLabel:r,totalCost:s})=>{const a=t>0?Math.round(s/t*100):0,l=n.length>o?n.slice(0,o-1)+"…":n;return K.createElement(ne,{key:e},K.createElement(re,null,l.padEnd(o+2)),K.createElement(re,null,r.padEnd(i)),K.createElement(re,{color:mr.DIM},`${a}%`))}))},"ModelBreakdownRows"),CA=__name(({onClose:e})=>{const[t,n]=J("loading"),[r,o]=J(null),[s,i]=J(!1),a=getProgressBarWidth({terminalWidth:useTerminalWidth()}),l=te(async e=>{try{i(!1);const t=await fetchUsageData();if(e.aborted)return;if(!t.whoami){const e=t.errors.some(isAuthErrorMessage);return i(e),void n("error")}o(t),n("loaded")}catch{if(e.aborted)return;n("error")}},[]),u=K.useRef(null);ie((r,o)=>{if(o.escape&&(UE(),e()),"r"===r&&"error"===t){n("loading"),u.current?.abort();const e=new AbortController;u.current=e,l(e.signal)}}),Z(()=>{const e=new AbortController;return u.current=e,l(e.signal),()=>e.abort()},[l]);const d=r?.subscription?.data??null,m=d?getPlanInfo({planId:d.planId??""}):null;if("loading"===t)return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(bA,{plan:m,status:d?.status??null}),K.createElement(re,{color:mr.DIM},"Loading…"),K.createElement(EA,null));if("error"===t)return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(bA,{plan:m,status:d?.status??null}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},s?"Not authenticated. Run /login to connect your account.":"Something went wrong.")),K.createElement(EA,{showRetry:!s}));if(!r)return null;const g=r.credits||r.subscription,h=getStudioUsageUrl(r.whoami);if(!g)return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(bA,{plan:m,status:d?.status??null}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"No billing data found."),h&&K.createElement(K.Fragment,null,K.createElement(re,{color:mr.DIM}," Visit "),K.createElement(ro,{url:h,text:"Studio",color:mr.CYAN}),K.createElement(re,{color:mr.DIM}," for usage details."))),K.createElement(EA,null));const f=r.credits?.credits,y=r.summary,w=r.modelBreakdown,S=null!=w&&w.length>0,E=Math.max(0,f?.monthlyCredits??0)+Math.max(0,f?.purchasedCredits??0)+Math.max(0,f?.freeCredits??0),v=Math.max(0,y?.totalCost??0),C=getUsagePercent({used:v,total:v+E}),k=E>0||v>0,T=d?.currentPeriodEnd?getDaysRemaining(d.currentPeriodEnd):null,_=getDaysColor(T),x=getUsageColor(C),A=buildBlockBar({percentage:C,width:a}),P=S?w.reduce((e,t)=>e+t.totalCost,0):0;return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,{marginBottom:1},K.createElement(bA,{plan:m,status:d?.status??null})),k?K.createElement(ne,null,K.createElement(re,{color:x},A.filled),K.createElement(re,{color:Cr},A.empty),K.createElement(re,{bold:!0,color:x},` ${Math.round(C)}% used`)):K.createElement(re,{color:mr.DIM},"Plan details unavailable"),k&&K.createElement(ne,null,d?.currentPeriodEnd&&K.createElement(re,{color:mr.DIM},"Cycle: "),K.createElement(re,null,formatCredits(E)),K.createElement(re,{color:mr.DIM}," left"),y&&K.createElement(K.Fragment,null,K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,null,y.totalCount.toLocaleString()),K.createElement(re,{color:mr.DIM}," requests")),null!==T&&K.createElement(K.Fragment,null,K.createElement(re,{color:mr.DIM}," · "),0===T?K.createElement(re,{color:_},"renewal today"):K.createElement(K.Fragment,null,K.createElement(re,{color:_},`${T} day${1===T?"":"s"}`),K.createElement(re,{color:mr.DIM}," to renewal")))),S&&K.createElement(vA,{models:w,grandTotal:P}),h&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"Full breakdown at "),K.createElement(ro,{url:h,text:SA(h),color:mr.CYAN})),K.createElement(EA,null))},"UsageOverlay");function UsageView({staticKey:e,setShowUsageOverlay:t}){return K.createElement(K.Fragment,null,K.createElement(_x,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(CA,{onClose:()=>t(!1)})))}__name(UsageView,"UsageView"),Ft(),Ft(),Cn(),lb(),LS(),so();var kA="System prompt",TA="Messages";function countMessagesByRole({messages:e}){let t=0,n=0;for(const r of e)"user"===r.message.role&&!isHiddenTranscriptMessage({message:r})&&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){if(isHiddenTranscriptMessage({message:r}))continue;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){if(isHiddenTranscriptMessage({message:n}))continue;const e=n.message.content;if(Array.isArray(e))for(const n of e)"image"===n.type&&t++}return t}function estimateConversationTokens({messages:e}){let t=0;for(const n of e)isHiddenTranscriptMessage({message:n})||(t+=estimateTokens(n.message));return t}function buildAutoCompactStatus({tokensUsed:e,tokenLimit:t}){const n=e/t,r=[{tier:1,threshold:bn.TIER_1_THRESHOLD,description:`Prune to last ${bn.TIER_1_KEEP_COUNT} tool calls`},{tier:2,threshold:bn.TIER_2_THRESHOLD,description:`Prune to last ${bn.TIER_2_KEEP_COUNT} tool calls`},{tier:3,threshold:bn.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:bn.KEEP_RECENT_TOKENS}}function getPrimaryTip({percentage:e,conversationPct:t}){return e>=90?"Tier 3 auto-compact imminent — /compact now to control what gets summarized":e>=80?"Auto-compact Tier 3 triggers at 90% — /compact to free space before it kicks in":t>60&&e>40?`${t}% is conversation — /compact to reclaim tokens`:e>=50?"/compact to free space · /model to switch models":null}function getSecondaryTip({mcpToolCount:e,imageCount:t,messageCount:n,percentage:r}){return e>0&&r>30?`${e} MCP tools loaded — disconnect unused servers to save tokens`:t>0&&r>30?`${t} image${t>1?"s":""} in context — images use ~1.5k tokens each`:n>50&&r>40?`${n} messages — consider starting a new session for a fresh context`:null}function generateTips({percentage:e,conversationTokens:t,totalTokens:n,mcpToolCount:r,messageCount:o,imageCount:s}){if(0===n)return[];const i=getPrimaryTip({percentage:e,conversationPct:Math.min(100,Math.round(t/n*100))}),a=getSecondaryTip({mcpToolCount:r,imageCount:s,messageCount:o,percentage:e}),l=[];return i&&l.push(i),a&&l.push(a),0===l.length&&l.push("/compact to summarize and free context · /model to switch models"),l}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 Zk){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 eT){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=e.getSystemPromptBreakdown(),r=getConfiguredModel(),o=getContextLimit(r),s=e.getHistory(),i=countMessagesByRole({messages:s}),a=countToolCalls({messages:s}),l=countImages({messages:s}),u=estimateConversationTokens({messages:s}),d=collectBuiltInTools(),m=collectMcpTools(),[g,h,f]=await Promise.all([collectSkillItems(),collectAgentItems(),collectMemoryItems()]),y=sumTokens(d),w=sumTokens(m),S=sumTokens(g),E=sumTokens(h),v=sumTokens(f),C=t>0,k=n?n.memory:v,T=null!==n&&Math.abs(v-n.memory)>50,_=n?n.taste:0,x=y+w+S+E,A=C?t:u+x+k+_,P=!C&&s.length>0,I=Math.min(A/o*100,100),M=Math.max(0,o-A),N=[];if(A>0){const e=n?n.systemPrompt:Math.max(0,A-u-x-k-_);if(e>0&&N.push({name:kA,tokens:e,detail:n?"identity":"identity + taste"}),k>0&&N.push({name:"Memory",tokens:k,detail:T?"memory files (modified, refreshes next request)":"memory files"}),_>0&&N.push({name:"Taste",tokens:_,detail:"taste.md"}),y>0&&N.push({name:"System tools",tokens:y,detail:`${d.length} built-in`}),w>0){const e=Array.from(new Set(m.map(e=>e.source).filter(e=>"string"==typeof e)));let t=`${m.length} tools`;e.length>3&&(t=`${e.length} servers`),e.length>=1&&e.length<=3&&(t=e.join(", ")),N.push({name:"MCP",tokens:w,detail:t})}S>0&&N.push({name:"Skills",tokens:S,detail:`${g.length} loaded`}),E>0&&N.push({name:"Subagents",tokens:E,detail:`${h.length} loaded`});const r=e+k+_+x,o=C?Math.max(0,t-r):u;o>0&&N.push({name:TA,tokens:o,detail:`${i.user} user · ${i.assistant} assistant`})}N.sort((e,t)=>e.name===kA?-1:t.name===kA||e.name===TA?1:t.name===TA?-1:t.tokens-e.tokens);const R=s.length>0?s[0]?.meta.timestamp??null:null;return{tokensUsed:A,tokenLimit:o,percentage:I,tokensRemaining:M,isEstimated:P,model:r,breakdown:N,autoCompact:buildAutoCompactStatus({tokensUsed:A,tokenLimit:o}),stats:{messageCount:s.length,userMessages:i.user,assistantMessages:i.assistant,toolCalls:a.calls,toolResults:a.results,imageCount:l,sessionStartTime:R},tips:generateTips({percentage:I,conversationTokens:u,totalTokens:A,mcpToolCount:m.length,messageCount:s.length,imageCount:l})}}function formatK(e){if(e<1e3)return String(e);if(e>=1e6){const t=Math.round(e/1e5)/10;return Number.isInteger(t)?`${t}M`:`${t.toFixed(1)}M`}const t=e/1e3;return Number.isInteger(t)?`${t}k`:`${t.toFixed(1)}k`}function formatBreakdownValue(e){return e<1e3?String(e):`${(e/1e3).toFixed(1)}k`}function getLayoutSizes({terminalWidth:e}){const t=Math.max(20,e),n=Math.min(50,Math.max(30,Math.floor(.5*t)));return{labelWidth:16,progressBarWidth:Math.max(10,Math.min(n,t-10)),showBreakdownDetail:t>=70}}function ContextProgress({analysis:e,progressBarWidth:t}){const n=getUsageColor(e.percentage),r=buildBlockBar({percentage:e.percentage,width:t});return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{marginBottom:1},K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:mr.BLUE,color:"#f4f4f4",bold:!0},`${ZT}CONTEXT${ZT}`)),K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{color:mr.GRAY},getModelDisplayName(e.model))),K.createElement(ne,null,K.createElement(re,{color:n},r.filled),K.createElement(re,{color:Cr},r.empty),K.createElement(re,{bold:!0,color:n},` ${e.percentage.toFixed(1)}%`)),K.createElement(ne,null,K.createElement(re,null,formatK(e.tokensUsed)),K.createElement(re,{color:mr.GRAY},` / ${formatK(e.tokenLimit)}`),K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{color:n},formatK(e.tokensRemaining)),K.createElement(re,{color:mr.GRAY}," remaining"),e.isEstimated&&K.createElement(re,{color:mr.DIM}," (estimated)")))}function CompactionDistance({analysis:e}){if(e.percentage<40)return null;const t=e.autoCompact.tiers.find(e=>3===e.tier);if(!t||"passed"===t.status)return null;const{tokensAway:n}=t;let r=mr.GRAY;return n<=5e4&&(r=mr.YELLOW),n<=2e4&&(r=mr.RED),K.createElement(ne,{marginTop:1},K.createElement(re,{color:r},`~${formatK(n)}`),K.createElement(re,{color:mr.DIM}," until auto-compact"))}function BreakdownRow({item:e,labelWidth:t,numWidth:n,showDetail:r}){return K.createElement(ne,null,K.createElement(re,null,e.name.padEnd(t)),K.createElement(re,{bold:!0},formatBreakdownValue(e.tokens).padStart(n)),K.createElement(re,{color:mr.GRAY}," tokens"),r&&e.detail&&K.createElement(re,{color:mr.DIM},` · ${e.detail}`))}function ContextBreakdown({analysis:e,labelWidth:t,showBreakdownDetail:n}){const r=e.breakdown.filter(e=>e.tokens>0);if(0===r.length)return null;const o=Math.max(4,...r.map(e=>formatBreakdownValue(e.tokens).length));return K.createElement(ne,{flexDirection:"column",marginTop:1},r.map(e=>K.createElement(BreakdownRow,{key:e.name,item:e,labelWidth:t,numWidth:o,showDetail:n})))}function ContextTips({tips:e}){return 0===e.length?null:K.createElement(ne,{flexDirection:"column",marginTop:1},e.map(e=>K.createElement(ne,{key:e},K.createElement(re,{color:mr.CYAN},Ie.pointer),K.createElement(re,{color:mr.GRAY}," ",e))))}function ContextMessage({analysis:e}){const t=getLayoutSizes({terminalWidth:useTerminalWidth()});return K.createElement(ne,{flexDirection:"column",paddingTop:1},K.createElement(ContextProgress,{analysis:e,progressBarWidth:t.progressBarWidth}),K.createElement(CompactionDistance,{analysis:e}),K.createElement(ContextBreakdown,{analysis:e,labelWidth:t.labelWidth,showBreakdownDetail:t.showBreakdownDetail}),K.createElement(ContextTips,{tips:e.tips}))}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&&(UE(),r(""),n(!1))}),K.createElement(K.Fragment,null,K.createElement(_x,{staticKey:e}),K.createElement(ne,{flexDirection:"column",width:"100%"},i?K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:pr,bold:!0},"Context"),K.createElement(re,{color:mr.DIM},i)):o?K.createElement(ContextMessage,{analysis:o}):K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:pr,bold:!0},"Context"),K.createElement(re,{color:mr.DIM},"Loading context analysis...")),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"Press Esc to return to conversation"))))}__name(countMessagesByRole,"countMessagesByRole"),__name(countToolCalls,"countToolCalls"),__name(countImages,"countImages"),__name(estimateConversationTokens,"estimateConversationTokens"),__name(buildAutoCompactStatus,"buildAutoCompactStatus"),__name(getPrimaryTip,"getPrimaryTip"),__name(getSecondaryTip,"getSecondaryTip"),__name(generateTips,"generateTips"),__name(collectMemoryItems,"collectMemoryItems"),__name(collectBuiltInTools,"collectBuiltInTools"),__name(collectMcpTools,"collectMcpTools"),__name(collectSkillItems,"collectSkillItems"),__name(collectAgentItems,"collectAgentItems"),__name(sumTokens,"sumTokens"),__name(analyzeContext,"analyzeContext"),qE(),Ft(),no(),Or(),__name(formatK,"formatK"),__name(formatBreakdownValue,"formatBreakdownValue"),__name(getLayoutSizes,"getLayoutSizes"),__name(ContextProgress,"ContextProgress"),__name(CompactionDistance,"CompactionDistance"),__name(BreakdownRow,"BreakdownRow"),__name(ContextBreakdown,"ContextBreakdown"),__name(ContextTips,"ContextTips"),__name(ContextMessage,"ContextMessage"),Or(),__name(ContextConfigView,"ContextConfigView"),Ft(),Ft(),Cn(),qs(),LS(),Io(),fo(),so();var _A="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=>{ke("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(!O(e))return!1;try{return(await I(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=O(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=b_(S.platform()),t=D_(),n=O_(),r=F_()}catch{e="Unknown",t="Unknown",n="Unknown",r="N/A"}return{cwd:process.cwd(),os:e,arch:S.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:S.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"),Ft(),Cn(),Gb(),Or(),io(),__name(formatCountValue,"formatCountValue"),__name(formatSystemValue,"formatSystemValue");var xA=__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?Ie.tick:Ie.cross,a=t.auth.authenticated?mr.WHITE:Er.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:pr,bold:!0},"Command Code"," "),K.createElement(re,{dimColor:!0},n)),K.createElement(ne,null,K.createElement(re,{dimColor:!0},"Visit "),K.createElement(ro,{url:_A,text:_A,color:mr.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(ro,{url:`https://commandcode.ai/${t.auth.username}/`,text:t.auth.username,color:mr.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:Er.WARNING},"Not signed in"),K.createElement(re,{color:a}," ",i),K.createElement(re,{dimColor:!0}," — run "),K.createElement(re,{bold:!0},"/login"))),K.createElement(xA,{label:"Model",value:r}),K.createElement(xA,{label:"Branch",value:o,dimValue:!t.git.branch}),s?K.createElement(xA,{label:"Worktree",value:s}):null,t.git.remoteUrl?K.createElement(ne,null,K.createElement(re,{dimColor:!0},"Repository:".padEnd(14)),K.createElement(ro,{url:t.git.remoteHttpUrl||`https://github.com/${t.git.remoteUrl}`,text:t.git.remoteUrl,color:mr.CYAN}),t.pr?K.createElement(K.Fragment,null,K.createElement(re,{dimColor:!0}," · "),K.createElement(ro,{url:t.pr.url,text:`#${t.pr.number}`,color:"OPEN"===t.pr.state?mr.CYAN:mr.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(ro,{url:t.pr.url,text:`#${t.pr.number}`,color:"OPEN"===t.pr.state?mr.CYAN:mr.GRAY}),K.createElement(re,{dimColor:!0}," (",t.pr.state.toLowerCase(),")")):null,K.createElement(xA,{label:"Taste",value:d,dimValue:!t.taste.fileExists}),K.createElement(xA,{label:"Directory",value:toRelativePath(t.system.cwd)}),K.createElement(xA,{label:"Skills",value:formatCountValue(t.skillsAgents.personalSkills,t.skillsAgents.projectSkills),dimValue:0===l}),K.createElement(xA,{label:"Agents",value:formatCountValue(t.skillsAgents.personalAgents,t.skillsAgents.projectAgents),dimValue:0===u}),K.createElement(xA,{label:"System",value:formatSystemValue({system:t.system})}),t.system.proxy?K.createElement(xA,{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(_x,{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 D.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"),Ft(),Ft(),Do(),Ft(),Do(),__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"),Or(),jr();var AA=__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:mr.CYAN,paddingX:1,paddingY:0},K.createElement(re,{bold:!0,color:mr.CYAN},"Add directory to workspace"),K.createElement(re,{color:mr.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:mr.GRAY},"Added directories"),0===a.length?K.createElement(re,{color:mr.GRAY}," None yet"):a.map((e,t)=>{const n="active-dir"===u.zone&&u.activeDirIndex===t;return K.createElement(re,{key:e,color:n?mr.YELLOW:mr.GREEN,bold:n},n?` ${Ie.pointer} `:" ",formatDirectoryForDisplay(e))})),K.createElement(ne,{marginTop:1},K.createElement(re,{bold:!0,color:mr.WHITE},"Path")),K.createElement(ne,null,K.createElement(TextInput,{value:t,focus:"input"===u.zone,prefix:`${"input"===u.zone?Ie.pointer:" "} `,prefixColor:"input"===u.zone?mr.CYAN:mr.GRAY,onChange:e=>{n(e),o(null)},onSubmit:h})),!t&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.GRAY},"Examples: ../shared ~/docs /abs/path")),r&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:{error:mr.RED,warning:mr.YELLOW,success:mr.GREEN}[r.tone]},r.text)),s.length>0&&K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(re,{color:mr.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?mr.CYAN:mr.GRAY,bold:r},r?` ${Ie.pointer} `:" ",e)})),K.createElement(ne,{marginTop:1},K.createElement(BracketedText,{text:w,color:mr.DIM})))},"AddDirModal");Ft(),Ft(),Cn(),Ft(),Ft(),Cn(),Or();var PA=__name(()=>t.join(S.homedir(),".commandcode","agents"),"getRootAgentDir"),IA=__name(()=>t.join(process.cwd(),".commandcode","agents"),"getLocalAgentDir"),MA=__name(({config:e,onSaveComplete:n,viewOnly:r=!1})=>{const[o,s]=J("idle"),[i,a]=J(""),l=[...Zk.map(e=>e.name),...eT.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?PA():IA();await k.mkdir(r,{recursive:!0});const o=`${e.agentType}.md`,s=t.join(r,o),i=Array.from(e.selectedTools).map(e=>rT[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 k.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=>rT[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:mr.WHITE,bold:!0},"Name:"),K.createElement(re,{color:mr.GRAY},e.agentType)),K.createElement(ne,{gap:1},K.createElement(re,{color:mr.WHITE,bold:!0},"Location:"),K.createElement(re,{color:mr.GRAY},m)),K.createElement(ne,{gap:1},K.createElement(re,{color:mr.WHITE,bold:!0},"Tools:"),K.createElement(re,{color:mr.GRAY},0===e.selectedTools.size?"None":e.selectedTools.size===l.length?"*":d))),K.createElement(ne,{gap:1},K.createElement(re,{color:mr.WHITE,bold:!0},"Description"),K.createElement(re,{color:mr.GRAY},"(Tells ","Command Code"," when to use this agent):")),K.createElement(re,{color:mr.GRAY},e.ccToolDefinition),K.createElement(ne,{gap:1},K.createElement(re,{color:mr.WHITE,bold:!0},"System Prompt:")),K.createElement(re,{color:mr.GRAY},e.sysPrompt),!r&&K.createElement(ne,{marginTop:1},"idle"===o&&K.createElement(ne,{gap:1},K.createElement(re,{color:mr.GREEN,dimColor:!0},"Press"),K.createElement(re,{color:mr.GREEN,bold:!0},"Enter"),K.createElement(re,{color:mr.GREEN,dimColor:!0},"to save • Esc to cancel")),"saving"===o&&K.createElement(re,{color:mr.YELLOW},"Saving agent..."),"saved"===o&&K.createElement(re,{color:mr.GREEN},Ie.tick," ",i),"error"===o&&K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:mr.RED},Ie.cross," Error: ",i),K.createElement(re,{color:mr.GRAY},"Press Enter to retry"))))},"AgentSummary");Or();var NA=__name(({agent:e,onBack:t,setRevalidateAgent:n,isReadOnly:r=!1})=>{const[o,s]=J("menu"),i=[...Zk.map(e=>e.name),...eT.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=>oT[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(MA,{config:l,onSaveComplete:()=>s("menu"),viewOnly:!0}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.GRAY},"Press Enter to go back")));if("edit"===o)return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:mr.YELLOW},"Edit functionality coming soon..."),K.createElement(re,{color:mr.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 k.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:mr.RED},"Delete agent"),K.createElement(re,{color:mr.GRAY},"Are you sure you want to delete the agent ",e.name,"?")),K.createElement(ne,null,K.createElement(pt,{items:r,onSelect:o,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:mr.WHITE},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?mr.WHITE:mr.GRAY},` ${t}`)})))}return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:mr.WHITE,bold:!0},e.name),K.createElement(ne,{marginTop:1},K.createElement(pt,{items:u,onSelect:d,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:mr.WHITE},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?mr.WHITE:mr.GRAY},` ${t}`)})),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.GRAY},"Press ↑↓ to navigate · Enter to select · Esc to go back")))},"AgentDetails");Or();var RA=__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,w]=J(!1),E=__name(()=>t.join(S.homedir(),".commandcode","agents"),"getRootAgentDir"),v=__name(()=>t.join(process.cwd(),".commandcode","agents"),"getLocalAgentDir"),C=__name(async(e,n)=>{try{g(!1);const r=(await k.readdir(e)).filter(e=>e.endsWith(".md"));return(await Promise.all(r.map(async r=>{try{const o=t.join(e,r),s=await k.readFile(o,"utf-8"),{data:i,content:a}=Ue(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([C(E(),"personal"),C(v(),"project")]),n=Ak.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 T=[{label:"Create new agent",value:"create_new_agent"}];r.forEach(e=>{T.push({label:e.name,value:e.filePath})}),s.forEach(e=>{T.push({label:e.name,value:e.filePath})});const _=r.length+s.length,x=__name(t=>{if("create_new_agent"===t.value)e(t);else{const e=[...r,...s].find(e=>e.filePath===t.value);e&&(f(e),w(!0))}},"handleAgentSelect");if(u)return K.createElement(re,{color:mr.GRAY},"Loading agents...");if(y&&h){const e=h.filePath.startsWith("__builtin__:");return K.createElement(NA,{agent:h,onBack:()=>{w(!1),f(null)},setRevalidateAgent:g,isReadOnly:e})}const A=__name(({isSelected:e,label:t})=>{const n=T.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:mr.GRAY,bold:!0},"User agents")),a&&s.length>0&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.GRAY,bold:!0},"Project agents")),K.createElement(ne,null,K.createElement(re,{color:mr.WHITE},e?">":" "),K.createElement(re,{color:e?mr.WHITE:mr.GRAY}," ",t)))},"CustomItemComponent");return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.WHITE,bold:!0},"Agents"),_>0?K.createElement(re,{color:mr.GRAY}," ","(",_," agent",_>1?"s":"",")"):K.createElement(re,{color:mr.GRAY}," (No custom agents)")),n&&K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{color:mr.GREEN,dimColor:!0},"Created agent: ",n)),K.createElement(pt,{items:T,onSelect:x,indicatorComponent:()=>null,itemComponent:A}),a.length>0&&K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(re,{color:mr.GRAY,bold:!0},"Default agents"),a.map(e=>K.createElement(re,{key:e.filePath,color:mr.GRAY}," ",e.name.charAt(0).toUpperCase()+e.name.slice(1)))),K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(re,{color:mr.GRAY},"Create specialized subagents that Command Code can delegate to."),K.createElement(re,{color:mr.GRAY},"Each subagent has its own context window, custom system prompt, and specific tools.")))},"ManageAgents");Ft(),Cn(),Gs(),Or(),Ft(),Ft(),Cn(),Or();var $A=__name(({onSelect:e})=>K.createElement(pt,{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?mr.WHITE:mr.GRAY},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?mr.WHITE:mr.GRAY},` ${t}`)}),"LocationSelector");Ft(),jr(),Cn(),Hr(),Kr(),Or();var LA=__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:mr.WHITE},"Enter a unique identifier for your agent:"),t&&(Object.values(rT).some(e=>je(e)===je(t))||Object.keys(rT).some(e=>je(e)===je(t)))&&K.createElement(re,{color:mr.RED},Ie.warning," This name conflicts with an existing tool name. Please choose a different name."),t&&isReservedAgentName(je(t))&&K.createElement(re,{color:mr.RED},Ie.warning," This name is reserved. Reserved names: ",xk.join(", "))),K.createElement(TextInput,{showCursor:!0,value:t||"",onSubmit:()=>{if(null===t||0===t.trim().length)return;const e=je(t);Object.values(rT).some(t=>je(t)===e)||Object.keys(rT).some(t=>je(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:mr.WHITE},"Enter the system prompt for your agent:"),K.createElement(re,{color:mr.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:mr.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");Ft(),Or();var DA=__name(({onSelect:e})=>K.createElement(pt,{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?mr.WHITE:mr.GRAY},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?mr.WHITE:mr.GRAY},` ${t}`)}),"MethodSelector");Ft(),jr(),Ft(),jE(),Or();var OA=["·","○","◇","☆","✧","☆","◇","○","⌘"],FA=[12,5,4,4,4,4,4,5,16],UA=[5,4,4,4,4,4,5];function getWaveSymbol(e){const t=e%88;let n=0;for(let e=0;e<FA.length;e++)if(n+=FA[e],t<n)return OA[e];const r=t-58;n=0;for(let e=0;e<UA.length;e++)if(n+=UA[e],r<n)return OA[7-e];return OA[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<Mr.length?Mr[n]:Nr},"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??pr,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 jA=__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 DE.statusRender({width:l,layoutMode:u,status:e,frame:r}),K.createElement(ne,{width:l,height:1,paddingLeft:0,marginLeft:0},K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:Sr.BG,color:Sr.FG}," "),K.createElement(re,{backgroundColor:Sr.BG},K.createElement(CMDIcon,{frame:4*r})),K.createElement(ShimmerText,{text:e,offset:m,bg:Sr.BG}),K.createElement(re,{backgroundColor:Sr.BG,color:Sr.FG}," ")),g&&K.createElement(ne,{columnGap:1,marginLeft:1},K.createElement(re,{bold:!0,color:mr.GRAY},"esc"),K.createElement(re,{color:mr.DIM},"to interrupt"),K.createElement(re,{color:mr.DIM},"•"),K.createElement(re,{color:mr.DIM},formatTime3(t)),K.createElement(re,{color:mr.DIM},"•"),K.createElement(re,{color:mr.GRAY},Ie.arrowDown),K.createElement(re,{color:mr.DIM},formatToken(Math.round(s)))),h&&K.createElement(ne,{marginLeft:1},K.createElement(re,{color:mr.DIM},formatToken(Math.round(s)))))},"Status");Kr(),Hr(),Or();var qA=__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:mr.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:mr.RED},`${Ie.warning} ${o}`)))},"RecommendedFlow");Ft(),Or();var BA=__name(({selectedTools:e,onToggleTool:t,onToggleCategory:n,onComplete:r})=>{const[o,s]=J(!1),[i,a]=J(0),l=ee(()=>[...Zk.map(e=>e.name),...eT.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]":"[ ]"} ${rT[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:mr.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:mr.GRAY}," ",e.label));const o="continue"===e.type;return K.createElement(ne,{key:`item-${t}`},K.createElement(re,{color:r?mr.WHITE:mr.GRAY,bold:o&&r},r?">":" "," ",e.label))}),K.createElement(ne,{marginTop:1},e.size===l.length&&K.createElement(re,{color:mr.GRAY},"All tools selected"),e.size>0&&e.size<l.length&&K.createElement(re,{color:mr.GRAY},e.size," tools selected"),0===e.size&&K.createElement(re,{color:mr.GRAY},"No tools selected")))},"ToolsSelector");yo(),IS(),yS(),Bs(),HE(),so();var zA=__name(({onComplete:e})=>{const[t,n]=J("location"),[r,o]=J(!1),[s,i]=J(null),[a,l]=J("agentType"),u=ee(()=>[...Zk.map(e=>e.name),...eT.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={[Bt.INTERNAL_TEAM_FLAG_HEADER]:t.toString()};r&&(a[Bt.OAUTH_TOKEN]=`Bearer ${r}`,s&&(a[Bt.OAUTH_PROVIDER]=s));const l=getApiBaseUrl(),u=new Xw({baseUrl:l}),d=parseModelString(getConfiguredModel()).modelId,h=await u.post({headers:a,endpoint:zt.ALPHA.AGENT.GENERATE,body:{description:m.recommendedMethodDescription,model:d}});g({...m,agentType:je(h.agentName),sysPrompt:h.systemPrompt,ccToolDefinition:h.toolDescription}),n("tools")}catch(e){if(e instanceof Ms&&400===e.status&&e.message?.toLowerCase().includes("insufficient credits")){const e=await getBillingLink({billingLink:null,setBillingLink:__name(()=>{},"setBillingLink")})??"https://commandcode.ai/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:je(m.agentType)}),l("sysPrompt")},"handleManualAgentTypeSubmit"),v=__name(()=>{l("ccToolDefinition")},"handleManualSysPromptSubmit"),C=__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:mr.WHITE,bold:!0},"Create new agent"),K.createElement(re,{color:mr.GRAY},f())),K.createElement(ne,null,"location"===t&&K.createElement($A,{onSelect:y}),"method"===t&&K.createElement(DA,{onSelect:w}),"configuration"===t&&"recommended"===m.method&&K.createElement(qA,{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(LA,{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:v,onCCToolDefinitionSubmit:C})),"tools"===t&&K.createElement(BA,{selectedTools:m.selectedTools,onToggleTool:T,onToggleCategory:_,onComplete:k}),"summary"===t&&K.createElement(MA,{config:m,onSaveComplete:h})))},"AgentNew");Or();var WA=__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:mr.GRAY,borderStyle:"single",flexDirection:"column"},null===t&&K.createElement(RA,{handleSelect:s,createdAgentName:r}),"create_new_agent"===t&&K.createElement(zA,{onComplete:e=>{o(e),n(null)}}))},"AgentsConfig");Or(),Ft(),so(),Or();var HA=[{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."}],GA=__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=HA.findIndex(e=>e.value===n);return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:pr,bold:!0},"Select a compact mode to compact sessions")),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.DIM},"Choose how Command Code handles automatic context compaction.")),K.createElement(pt,{items:HA,onSelect:o,initialIndex:s>=0?s:0,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:mr.CYAN},e?Ie.pointer:" "),itemComponent:({isSelected:e,label:t})=>{const r=HA.find(e=>e.label===t),o=r?.value===n,s=HA.findIndex(e=>e.label===t);return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,K.createElement(re,{color:e?mr.CYAN:o?mr.GREEN:mr.WHITE},` ${s+1}. ${r?.label??t}`),o&&K.createElement(re,{color:mr.GREEN}," ",Ie.tick)),K.createElement(re,{color:mr.DIM},` ${r?.description??""}`))}}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"Press "),K.createElement(re,{color:mr.DIM,bold:!0},"Esc"),K.createElement(re,{color:mr.DIM}," to cancel")))},"CompactModeSelector");Ft(),Cn(),no(),fo(),so(),mo(),Ft(),Cn(),Or();var VA=__name(({model:e,providerId:t,isHighlighted:n,isCurrent:r,showProviderLabel:o})=>{const s=fn[t],i=o??s?.showProviderLabelInSelector??!1,a=e.vendorLabel??gn[e.provider],l=e.id===pn,u="free"===e.badge,d=l?`${e.label} (default)`:e.label,m=u?" (FREE)":"",g=" ".repeat(Math.max(0,32-d.length-m.length));return K.createElement(ne,null,K.createElement(re,{color:n?mr.CYAN:mr.GRAY},n?`${Ie.pointer} `:" "),K.createElement(re,{color:n?mr.CYAN:r?mr.GREEN:mr.WHITE},d),u&&K.createElement(re,{color:mr.GREEN,bold:!0},m),K.createElement(re,null,g),i&&K.createElement(re,{color:mr.DIM},a),e.description&&K.createElement(re,{color:mr.DIM},i?" · ":"",e.description),r&&K.createElement(re,{color:mr.GREEN}," ",Ie.tick))},"ModelRow");Or();var QA=__name(e=>[{text:e.name,weight:100},{text:e.label,weight:50},{text:e.provider,weight:25},{text:e.description||"",weight:10}],"MODEL_SEARCH_FIELDS");function searchGroups(e,t){if(!t.trim())return e;const n=[];for(const r of e){const e=fuzzyFilter(r.models,t,QA);e.length>0&&n.push({...r,models:e})}return n}function groupByModelProvider(e,t){return groupModelsByDisplayOrder(e).map(e=>({providerId:t,label:e.label,models:e.models}))}__name(searchGroups,"searchGroups"),__name(groupByModelProvider,"groupByModelProvider");var KA=__name(({featureLabel:e,defaultLabel:t,currentModelId:n,onPick:r,onBack:o})=>{const[s,i]=J(""),a=ee(()=>isInternalTeamFlagEnforced(),[]),[l,u]=J(()=>getCachedBillingContext());Z(()=>{if(l)return;let e=!0;return getBillingContext().then(t=>{e&&u(t)}),()=>{e=!1}},[l]);const d=null!==l,m=ee(()=>a?yn:groupByModelProvider(wn.flatMap(e=>e.models),fn["command-code"].id),[a]),g=ee(()=>l?m.map(e=>({...e,models:e.models.filter(e=>checkModelAccess({model:{id:e.id,provider:e.provider,name:e.name},planId:l.planId,purchasedCredits:l.purchasedCredits,freeCredits:l.freeCredits}).allowed)})).filter(e=>e.models.length>0):[],[m,l]),h=ee(()=>searchGroups(g,s),[g,s]),f=ee(()=>{const e=[];for(const t of h)for(const n of t.models)e.push({kind:"model",providerId:t.providerId,model:n});return[{kind:"reset"},...e]},[h]),y=ee(()=>{if(!n)return 0;const e=f.findIndex(e=>"model"===e.kind&&e.model.id===n);return e>=0?e:0},[f,n]),{cursor:w}=useListNavigation({items:f,initialIndex:y,searchCursorIndex:1,searchQuery:s,onSearchChange:i,onSelect:__name(e=>{d&&r("reset"===e.kind?void 0:e.model.id)},"onSelect"),onCancel:o});let S=1;return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:pr,bold:!0},e," › select model")),K.createElement(ne,{marginBottom:1},K.createElement(re,{dimColor:!0},"Pick a model for this task, or reset it to the default.")),K.createElement(ne,{marginBottom:2,flexDirection:"column",width:"100%"},K.createElement(lA,{query:s,resultCount:s?f.length-1:void 0,placeholder:"Type to search models..."})),d?K.createElement(K.Fragment,null,K.createElement(ne,null,K.createElement(re,{color:0===w?mr.CYAN:mr.GRAY},0===w?`${Ie.pointer} `:" "),K.createElement(re,{color:0===w?mr.CYAN:mr.WHITE},"↺ Use default (",t,")")),h.map(e=>{const t=S;return S+=e.models.length,K.createElement(ne,{key:`${e.providerId}-${e.label}`,flexDirection:"column",marginTop:1},K.createElement(re,{bold:!0,dimColor:!0},e.label),e.models.map((r,o)=>K.createElement(VA,{key:`${e.providerId}-${e.label}-${r.id}`,model:r,providerId:e.providerId,isHighlighted:t+o===w,isCurrent:r.id===n,showProviderLabel:!!a&&void 0})))})):K.createElement(ne,null,K.createElement(re,{color:mr.DIM},"Loading available models…")),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"type to search · ↑/↓ navigate · enter select"),s?K.createElement(re,{color:mr.DIM}," · esc to clear"):K.createElement(re,{color:mr.DIM}," · esc back")))},"FeatureModelPicker"),YA=__name(({onClose:e})=>{const[t,n]=J(null),[r,o]=J(null),[s,i]=J(null);Z(()=>{loadUserConfig().then(e=>{n(e.featureModels??{})})},[]);const a=r?"picker":"list",{cursor:l}=useListNavigation({items:qk,initialIndex:0,searchQuery:"",onSearchChange:__name(()=>{},"onSearchChange"),disableSearch:!0,isActive:"list"===a&&null!==t,onSelect:__name(e=>{i(null),o(e.key)},"onSelect"),onCancel:e,onReset:__name(async e=>{try{await setFeatureModel({feature:e.key,model:void 0}),n(t=>{const n={...t??{}};return delete n[e.key],n}),i({text:`${e.label} reset to default`})}catch{i({text:`Couldn't reset ${e.label} — try again`,error:!0})}},"onReset")});if(null===t)return null;const u=qk.find(e=>e.key===r)??null;return"picker"===a&&u?K.createElement(KA,{featureLabel:u.label,defaultLabel:getFeatureDefaultLabel(u),currentModelId:t[u.key],onBack:()=>o(null),onPick:async e=>{try{await setFeatureModel({feature:u.key,model:e}),n(t=>{const n={...t??{}};return void 0===e?delete n[u.key]:n[u.key]=e,n}),i({text:void 0===e?`${u.label} reset to default`:`${u.label} → ${getModelDisplayName(e)}`})}catch{i({text:`Couldn't save ${u.label} — try again`,error:!0})}o(null)}}):K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:pr,bold:!0},"Configure models")),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.DIM},"Pick a model for each task. Applies to all sessions."," ",createOSC8Link("https://commandcode.ai/docs/troubleshooting/faqs#why-do-i-see-small-background-requests","Why background requests?",!1))),qk.map((e,n)=>{const r=t[e.key],o=e.defaultLabel?`Default (${getFeatureDefaultLabel(e)})`:`Uses current model (${getFeatureDefaultLabel(e)})`,s=r?getModelDisplayName(r):o,i=n===l;return K.createElement(ne,{key:e.key},K.createElement(re,{color:i?mr.CYAN:mr.GRAY},i?`${Ie.pointer} `:" "),K.createElement(re,{color:i?mr.CYAN:mr.WHITE},e.label.padEnd(20)),K.createElement(re,{color:r?mr.GREEN:mr.DIM},s))}),s&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:s.error?mr.RED:mr.GREEN},s.text)),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"↑/↓ navigate · enter to change · r to reset · esc to close")))},"ConfigureModelsSelector");function settingsFilePaths(e){return[getProjectLocalPath(e),getProjectSharedPath(e),getUserSettingsPath()]}function readInputSettings(e){try{const t=L.readFileSync(e,"utf-8");return parseJSON(t)?.input}catch{return}}function shouldCollapsePastedText(e=process.cwd()){for(const t of settingsFilePaths(e)){const e=readInputSettings(t)?.collapsePastedText;if("boolean"==typeof e)return e}return!0}Ft(),Or(),Ft(),jr(),Cn(),Hr(),Ft(),yo(),__name(settingsFilePaths,"settingsFilePaths"),__name(readInputSettings,"readInputSettings"),__name(shouldCollapsePastedText,"shouldCollapsePastedText"),Vn(),Ft();var JA=n(E(),"commandcode-images"),XA={"image/png":".png","image/jpeg":".jpg","image/gif":".gif","image/webp":".webp"};function saveTempImage(e,t){try{O(JA)||q(JA,{recursive:!0});const r=XA[e.mediaType]||".png",o=`image-${t}-${Date.now()}${r}`,s=n(JA,o),i=Buffer.from(e.data,"base64");return B(s,i),s}catch{return null}}function stripInputAfterSuffix(e,t){return t&&e.endsWith(t)?e.slice(0,e.length-t.length):e}function extractAppendedChunk(e,t,n){const r=t+n;return e.length>=r.length&&e.startsWith(r)?e.slice(r.length):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,setInitialCursor:a,collapsePastedText:l=!0}=e,u=te((e,t,n="")=>{o(t=>[...t,e]),r(t+n),a(t.length),i()},[o,r,a,i]),d=X(!1),m=X(""),g=X(null),h=X(""),f=X(""),y=te(async(e,t,o)=>{let d=e.replace(/\r\n/g,"\n").replace(/\r/g,"\n");const m=await detectDroppedImageFile(d);if(m)return void u(m,t,o);const g=await detectClipboardImage();if(g)return void u(g,t,o);let h=d;if(0===h.length){const e=await detectClipboardText();h=e?e.replace(/\r\n/g,"\n").replace(/\r/g,"\n"):""}if(!h&&!o)return;if(!h)return r(t+o),a(t.length),void i();if(l&&h.length>300){const e=t+`[Text#${n.length+1}]`;return s(e=>[...e,h]),r(e+o),a(e.length),void i()}const f=t+h;r(f+o),a(f.length),i()},[u,n.length,s,r,a,i,l]),w=te(()=>{g.current&&clearTimeout(g.current),g.current=setTimeout(async()=>{if(d.current){const e=m.current,t=h.current,n=f.current;m.current="",h.current="",f.current="",d.current=!1,g.current=null,e?await y(e,t,n):n&&await y("",t,n)}},500)},[y]);return{handlePaste:te(async e=>{const n=processBracketedPaste(e);if(n.isPasteStart&&n.isPasteEnd)return d.current&&(d.current=!1,m.current="",h.current="",f.current="",g.current&&(clearTimeout(g.current),g.current=null)),await y(n.pastedContent??n.cleanedContent,n.textBeforePaste??"",n.textAfterPaste??""),!0;if(n.isPasteStart&&!d.current){d.current=!0;const e=n.textBeforePaste??t,r=t.slice(e.length);h.current=e,f.current=r;const o=n.pastedContent??n.cleanedContent;return m.current=stripInputAfterSuffix(o,r),w(),!0}if(d.current&&!n.isPasteEnd){const e=h.current,t=f.current;if(void 0!==n.pastedContent)m.current=stripInputAfterSuffix(n.pastedContent,t);else if(n.cleanedContent){const r=extractAppendedChunk(n.cleanedContent,e,t);m.current=null!==r?m.current+r:accumulateDelta(n.cleanedContent,m.current,e)}return w(),!0}if(d.current&&n.isPasteEnd){g.current&&(clearTimeout(g.current),g.current=null);const e=h.current,t=f.current,r=n.textAfterPaste??"";let o=n.cleanedContent??"";if(r&&o.endsWith(r)&&(o=o.slice(0,o.length-r.length)),void 0!==n.pastedContent)m.current=stripInputAfterSuffix(n.pastedContent,t);else if(o){const n=extractAppendedChunk(o,e,t);m.current=null!==n?m.current+n:accumulateDelta(o,m.current,e)}const s=m.current,i=e,a=r||t;return m.current="",h.current="",f.current="",d.current=!1,await y(s,i,a),!0}if(n.isPasteEnd&&!n.isPasteStart&&!d.current)return!0;const r=e.slice(t.length);if(r.length>0){const e=await detectDroppedImageFile(r);if(e)return u(e,t),!0}return!1},[t,y,w,u]),resetPasteState:te(()=>{d.current=!1,m.current="",h.current="",f.current="",g.current&&(clearTimeout(g.current),g.current=null)},[]),isPasting:te(()=>d.current,[])}}function useExternalEditor({input:e,setInput:t,setInputKey:n,detectedContent:r,setDetectedContent:o,onEditorClose:s}){const[i,a]=J(!1),[l,u]=J(null),d=te(async()=>{if(!i){a(!0),u(null);try{let i=e.replace(/\n+$/,"");r.forEach((e,t)=>{const n=`[Text#${t+1}]`;i.includes(n)&&(i=i.replace(n,e))});const a=await openInEditor2(i);t(a),o([]),n(e=>e+1),s?.()}catch(e){u(e instanceof d_?"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{a(!1)}}},[e,t,n,r,o,s,i]),m=te(()=>{u(null)},[]);return{isEditorOpen:i,editorError:l,handleOpenInEditor:d,clearEditorError:m}}__name(saveTempImage,"saveTempImage"),ir(),yo(),Ft(),Kr(),Hr(),__name(stripInputAfterSuffix,"stripInputAfterSuffix"),__name(extractAppendedChunk,"extractAppendedChunk"),__name(accumulateDelta,"accumulateDelta"),__name(useBracketedPaste,"useBracketedPaste"),Kr(),Ft(),__name(useExternalEditor,"useExternalEditor"),Ft();var ZA=__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,l_().then(t=>{e&&r(t)}),()=>{e=!1}},[t]),{pr:n}},"usePRDetection");function loadGitignore(e){const t=rt(),r=n(e,".gitignore");if(O(r))try{const e=U(r,"utf8");t.add(e)}catch{}return t.add(".git"),t}Or(),Ft(),Or(),__name(loadGitignore,"loadGitignore");var eP=__name(({onSelectFile:e,onClose:t,searchQuery:o=""})=>{const[i,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=z(o),i=[];return e.forEach(e=>{const a=n(o,e);try{const e=W(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=z(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=W(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{z(e).forEach(u=>{const d=n(e,u);try{const e=W(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=z(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=W(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(i)},[i,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(a(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:mr.DIM},o.trim()?`Searching for: "${o}"`:`Files: ${i}`),K.createElement(re,{color:mr.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:mr.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?mr.GREEN:mr.DIM},e.isDirectory?`${r}/`:r)}))},"FileList");Ft(),Cn(),fo(),Or(),Ft(),Or();var tP=__name(e=>{if(e>=1e6){const t=e/1e6;return`${t%1==0?t.toFixed(0):t.toFixed(1)}M`}return`${Math.round(e/1e3)}k`},"formatTokens"),nP=__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&&e.current>=18e4)return K.createElement(ne,{paddingRight:3},K.createElement(re,{color:mr.DIM},"~",tP(e.current)," tokens in context · try"," "),K.createElement(re,{color:mr.DIM,bold:!0},"/compact"));if(n>20)return null;const r=__name(e=>e>=90?mr.RED:e>=70?mr.YELLOW:mr.DIM,"getColor"),o=t>=90?6:Math.round(t/100*6),s=6-o,i=Ie.square.repeat(o),a=Ie.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:mr.DIM},a))},"ContextUsage");Ft(),fs(),Or();var rP=__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 xT.on("new-event",e),()=>{xT.off("new-event",e),l.current&&clearTimeout(l.current)}},[]);const d=` ${n?Ie.squareSmallFilled:Ie.squareSmall} TASTE`,m=9+e.length+d.length>as;let g=e;g=truncateString(m?{text:e,maxChars:as}:{text:e,maxChars:as-d.length-9-10});const h=o?void 0:mr.DIM;return K.createElement(ne,{paddingRight:2},!m&&K.createElement(K.Fragment,null,K.createElement(BracketWrap,{color:mr.DIM},"ctrl+t"),K.createElement(re,{color:mr.DIM}," ")),K.createElement(re,{color:h},g),!m&&K.createElement(re,{color:gr.TEXT},d))},"LearningFeedMini");Ft(),Or();var oP=__name(({mode:e,pendingExitKey:t})=>t?K.createElement(re,{color:mr.DIM},"Press Ctrl+C again to exit"):"bypass"===e?K.createElement(ne,{flexDirection:"row"},K.createElement(re,{color:mr.RED},"» permission bypass on "),K.createElement(BracketWrap,{color:mr.DIM},"shift+tab")):"auto-accept"===e?K.createElement(ne,{flexDirection:"row"},K.createElement(re,{color:xr},"» accept edits on "),K.createElement(BracketWrap,{color:mr.DIM},"shift+tab")):"plan"===e?K.createElement(ne,{flexDirection:"row"},K.createElement(re,{color:_r},"plan mode "),K.createElement(BracketWrap,{color:mr.DIM},"shift+tab")):K.createElement(re,{color:mr.DIM},"? for shortcuts"),"ModeIndicator");Ft(),Or(),io();var sP=__name(({prInfo:e,showSeparator:t=!0})=>{if(!e)return null;if("OPEN"!==e.state&&"MERGED"!==e.state)return null;const n="OPEN"===e.state?mr.DIM:Ar.MERGED;return K.createElement(K.Fragment,null,t&&K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{color:n},"PR "),K.createElement(ro,{url:e.url,text:`#${e.number}`,color:n}))},"PRLinkBadge"),iP=__name(({indicator:e,showSeparator:t=!0})=>e?.visible?K.createElement(K.Fragment,null,t&&K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{color:"connected"===e.type?mr.GREEN:mr.YELLOW},e.message)):null,"ConnectionIndicatorBadge"),aP=__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 v=e>=60;return K.createElement(K.Fragment,null,K.createElement(ne,{flexDirection:"column",paddingLeft:2},"auto-accept"!==r&&"plan"!==r&&"bypass"!==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:vr},t):K.createElement(oP,{mode:r,pendingExitKey:l}),!l&&K.createElement(sP,{prInfo:o}),!l&&K.createElement(iP,{indicator:a})),v&&K.createElement(ne,{flexDirection:"column",alignItems:"flex-end"},s&&K.createElement(rP,null),i&&K.createElement(nP,{usage:i}))):K.createElement(K.Fragment,null,K.createElement(ne,{flexDirection:"row",justifyContent:"space-between",width:e-1},K.createElement(oP,{mode:r}),v&&s&&K.createElement(rP,null)),K.createElement(ne,{flexDirection:"row",justifyContent:"space-between",width:e-1},K.createElement(ne,{flexDirection:"row",columnGap:0},K.createElement(re,{color:n?vr:mr.DIM},t),K.createElement(sP,{prInfo:o}),K.createElement(iP,{indicator:a})),v&&i&&K.createElement(nP,{usage:i}))),(u||d||g&&m)&&K.createElement(ne,{flexDirection:"row",columnGap:1},u&&K.createElement(re,null,Ie.tick," ","Command Code"," updated:"," ",K.createElement(re,{color:mr.DIM},"v",u.updatedFrom),K.createElement(re,{color:mr.DIM}," ",Ie.arrowRight," "),K.createElement(re,null,"v",u.updatedTo)),!u&&d&&K.createElement(re,{color:mr.YELLOW,dimColor:!0},Ie.info," Update available:"," ",d.currentVersion," ",Ie.arrowRight," ",d.latestVersion),g&&m&&K.createElement(re,{color:mr.GREEN,dimColor:!0},Ie.bullet," Provider:"," ",getProviderDisplayName(m)))),h&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:mr.GREEN},"! for bash mode")),y&&f&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:pr},"SHARED: ",f.url," (copied to clipboard)")),w&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:w.includes("NOT SHARED")?mr.RED:pr},w)),S&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:pr},S)),E&&K.createElement(ne,{paddingLeft:2},K.createElement(re,{color:mr.YELLOW},Ie.warning," ",E)))},"BottomIndicator");Ft(),fs(),Or();var lP=12,cP=__name(e=>e instanceof Error&&e.message?e.message:"Unknown error","getDeleteErrorMessage"),uP=__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"),dP=__name(e=>e.replace(/\s+/g," ").trim(),"normalizeSummary"),mP=__name(e=>truncateString({text:dP(e),maxChars:os}),"truncateMessage"),pP=__name(e=>e.title?dP(e.title):mP(e.firstMessage),"getSessionSummary"),gP=__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,h]=J(!1),[f,y]=J(null),[w]=J(()=>getCurrentGitBranch()),S=te(async()=>{u(!0);const e=await Rk.listSessions();r(e),u(!1)},[]);Z(()=>{S()},[S]);const E=te(async e=>{try{await Rk.deleteSession(e),h(!1),y(null),s(0),a(0),await S()}catch(e){h(!1),y(`Failed to delete session: ${cP(e)}`)}},[S]),v=d&&w?n.filter(e=>e.gitBranch===w):n;if(ie((n,r)=>{if(g)if(r.return){if(v.length>0&&o<v.length){const e=v[o];E(e.id)}}else h(!1);else if(r.delete||r.ctrl&&"d"===n)v.length>0&&(y(null),h(!0));else{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(v.length-1,e+1);return t>=i+lP&&a(t-lP+1),t}):r.return&&v.length>0&&o<v.length&&e(v[o].id));t()}}),l)return K.createElement(ne,{flexDirection:"column",paddingLeft:2},K.createElement(re,{color:mr.GRAY},"Loading sessions..."));if(0===v.length)return K.createElement(ne,{flexDirection:"column",paddingLeft:2},K.createElement(re,{color:mr.GRAY},d&&w?`No sessions found for branch "${w}"`:"No previous sessions found"),K.createElement(re,{color:mr.DIM},d?"Press ctrl+b to show all branches, ESC to cancel":"Press ESC to go back"));const C=v.slice(i,i+lP),k=o<v.length?v[o]:null,T=g&&k?`Delete "${pP(k)}"? Press Enter to confirm, any other key to cancel.`:null;return K.createElement(ne,{flexDirection:"column",paddingLeft:1,width:"100%"},K.createElement(re,{color:mr.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:mr.GRAY}," ")),K.createElement(ne,{width:13},K.createElement(re,{color:mr.GRAY},"Modified")),K.createElement(ne,{width:20},K.createElement(re,{color:mr.GRAY},"Git Branch")),K.createElement(ne,{width:11},K.createElement(re,{color:mr.GRAY},"# Messages")),K.createElement(ne,null,K.createElement(re,{color:mr.GRAY},"Summary"))),K.createElement(ne,{columnGap:2},K.createElement(ne,{flexDirection:"column",width:5},C.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`sel-${n}`,color:o===n?mr.WHITE:mr.GRAY},o===n?`${Ie.pointer} ${n+1}.`:` ${n+1}.`)})),K.createElement(ne,{flexDirection:"column",width:13},C.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`mod-${e.id}`,color:o===n?mr.WHITE:mr.GRAY},uP(e.lastModified))})),K.createElement(ne,{flexDirection:"column",width:20},C.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`branch-${e.id}`,color:o===n?mr.WHITE:mr.GRAY,wrap:"truncate-end"},e.gitBranch||"-")})),K.createElement(ne,{flexDirection:"column",width:11},C.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`msg-${e.id}`,color:o===n?mr.WHITE:mr.GRAY},e.messageCount)})),K.createElement(ne,{flexDirection:"column"},C.map((e,t)=>{const n=i+t;return K.createElement(re,{key:`summary-${e.id}`,color:o===n?mr.WHITE:mr.GRAY,wrap:"truncate-end"},pP(e))}))),K.createElement(ne,{marginTop:1}),T&&K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.RED},T)),f&&K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.RED},f)),v.length>lP&&K.createElement(re,{color:mr.DIM},"Showing ",i+1,"–",Math.min(i+lP,v.length)," ","of ",v.length,i>0?" · ↑ more":"",i+lP<v.length?" · ↓ more":""),K.createElement(re,{color:mr.DIM},"↑↓ navigate · Enter select · Del delete · ctrl+b ",d?`[branch: ${w??"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:mr.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}))))))}Ft(),Or(),Ft(),__name(getImageHintText,"getImageHintText"),__name(buildImageRows,"buildImageRows"),__name(shouldSelectImageOnUpArrow,"shouldSelectImageOnUpArrow"),__name(nextImageIndex,"nextImageIndex"),__name(prevImageIndex,"prevImageIndex"),__name(removeImageAt,"removeImageAt"),mo(),__name(ImageLabel,"ImageLabel"),__name(ImageRowsDisplay,"ImageRowsDisplay"),Ft();var hP=__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=X(n),[d,m]=J(!1),[g,h]=J("connected"),f=X(null),y=X(null),w=te((e,t)=>{y.current&&(clearTimeout(y.current),y.current=null),h(e),m(!0),void 0!==t&&(y.current=setTimeout(()=>{m(!1)},t))},[]),S=te(()=>{y.current&&(clearTimeout(y.current),y.current=null)},[]),E=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 mk,l.current=t;const r=e?200:500;n=await t.connect(r)}const r=f.current;if(null===r?n&&w("connected",3e3):r!==n&&(n?w("connected",2e3):w("disconnected",5e3)),f.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===f.current&&w("disconnected",5e3),f.current=!1,i(!1),o(null),l.current?.disconnect(),l.current=null}finally{a.current=!1}}},[w]);Z(()=>{const e=u.current;u.current=n,e&&!n&&t&&null!==nk()&&E(!1)},[n,t,E]),Z(()=>{if(!t)return;if(null===nk())return;let e=null,n=!1,r=0;function schedule(t){n||(e=setTimeout(()=>{tick(!1)},t))}async function tick(e){if(u.current)return void schedule(500);if(await E(e),n)return;if(l.current?.isConnected)return r=0,void schedule(500);r+=1;const t=Math.min(r,6);schedule(Math.min(3e4,500*2**t)+250*Math.random())}return __name(schedule,"schedule"),__name(tick,"tick"),tick(!0),()=>{n=!0,e&&clearTimeout(e),S(),l.current?.disconnect(),l.current=null}},[t,E,S]);const v=nk(),C={visible:d,message:"connected"===g?`${v?y_[v]??"IDE":"IDE"} ${Ie.tick}`:"run /ide",type:g};return{context:r,connected:s,refresh:E,connectionIndicator:C}},"useVSCodeContext");Ft();var fP=__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,"</ide-context>").replace(/[\u202A-\u202E\u2066-\u2069\u200B-\u200D\uFEFF]/g,"");t.push(i),t.push("```")}return t.push("</ide-context>"),t.join("\n")+"\n"},"formatContextForPrompt");Ft();var yP=__name((e,t)=>!(!e||!t?.selection&&!t?.activeFile?.relativePath),"hasIDEContext"),wP=__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");function getModelHintLayout(e){const{currentModel:t,terminalWidth:n}=e,r=getCommandMenuDescriptionWidth(n);return{descriptionWidth:r,text:truncateString({text:`${getModelDisplayName(t)} (current)`,maxChars:r})}}Ft(),no(),fs(),__name(getModelHintLayout,"getModelHintLayout");var SP=["","[118;5u","[118;5u"];function removeAltPCharacter(e){return e.includes("π")?e.replace(/π/g,""):null}function isPrecededByWhitespace(e){return!e||" "===e||"\n"===e||"\t"===e}function getCommandMenuStateFromQuery(e){return isDesignSubmenu(e)?{showMenu:!0,query:e}:e.includes(" ")?{showMenu:!1,query:""}:{showMenu:!0,query:e}}__name(removeAltPCharacter,"removeAltPCharacter"),__name(isPrecededByWhitespace,"isPrecededByWhitespace"),__name(getCommandMenuStateFromQuery,"getCommandMenuStateFromQuery");var bP=__name(()=>K.createElement(ne,{flexDirection:"column",paddingLeft:1},K.createElement(re,{color:mr.DIM,bold:!0},"Available Shortcuts:"),K.createElement(ne,{columnGap:4},K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:mr.DIM},"! for bash mode"),K.createElement(re,{color:mr.DIM},"/ for commands"),K.createElement(re,{color:mr.DIM},"@ for file paths"),K.createElement(re,{color:mr.DIM},"shift + tab to toggle auto-accept")),K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:mr.DIM},"double tap esc to clear input"),K.createElement(re,{color:mr.DIM},"ctrl + j / shift + ⏎ for newline"),K.createElement(re,{color:mr.DIM},"ctrl + g to open in editor"),K.createElement(re,{color:mr.DIM},"ctrl + z to suspend")))),"ShortcutMenu"),EP=__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:v,updateFailedInfo:C,currentProvider:k,currentModel:T,showProviderInfo:_,permissionMode:x="standard",onToggleAutoAccept:A,hintMessage:P,historyManager:I,pendingExitKey:M=null,onOverlayVisibilityChange:N,onDoubleEscapeEmpty:R,onAltP:$,isProcessing:L=!1,ideContextEnabled:D=!0})=>{const[O,F]=J(0),[U,j]=J(!1),[q,B]=J(!1),[z,W]=J(!1),[H,G]=J(!1),[V,Q]=J(""),[Y,oe]=J(null),[ae,le]=J(!1),ce=X(0),ue=X(0),[de,me]=J([]),[pe,ge]=J([]),[he,fe]=J(-1),[ye,we]=J(""),Se=X(!1),be=X(!1),Ee=X(void 0),[ve,Ce]=J(-1),[ke,Te]=J(""),_e=X(0),{isEditorOpen:xe,editorError:Ae,handleOpenInEditor:Pe,clearEditorError:Me}=useExternalEditor({input:e,setInput:n,setInputKey:F,detectedContent:de,setDetectedContent:me,onEditorClose:__name(()=>{Se.current=!1},"onEditorClose")}),Ne=ee(()=>shouldCollapsePastedText(),[]),{handlePaste:Re,resetPasteState:$e,isPasting:Le}=useBracketedPaste({input:e,detectedContent:de,setInput:n,setDetectedImages:ge,setDetectedContent:me,incrementInputKey:__name(()=>F(e=>e+1),"incrementInputKey"),setInitialCursor:__name(e=>{Ee.current=e},"setInitialCursor"),collapsePastedText:Ne}),{context:De,connected:Oe,refresh:Fe,connectionIndicator:Ue}=hP({enabled:D,paused:L}),{stdout:je}=se(),qe=je?.columns??80,{pr:Be}=ZA();Z(()=>{const e=i||H||ae;N?.(e)},[i,H,ae,N]);const ze=te(()=>{ge([]),fe(-1)},[]),We=te(()=>{G(!1),oe(null)},[]),He=te(()=>{n(""),B(!1),We(),Q(""),le(!1),me([]),ze(),we(""),$e(),Ce(-1),Te(""),F(e=>e+1)},[n,$e,ze,We]),Ge=te(()=>{Se.current=!0;const{text:t,cursor:r}=insertTextAt(e,_e.current,"\n");n(t),Ee.current=r,F(e=>e+1),setTimeout(()=>{Se.current=!1},0)},[e,n]);ie(async(t,r)=>{if(-1!==he&&r.leftArrow)return void fe(prevImageIndex({currentIndex:he,imageCount:pe.length}));if(-1!==he&&r.rightArrow)return void fe(nextImageIndex({currentIndex:he,imageCount:pe.length}));if(r.upArrow){if(i||H||ae)return;const t=e.indexOf("\n"),r=-1===t||_e.current<=t;if(shouldSelectImageOnUpArrow({isOnFirstLine:r,imageCount:pe.length,selectedImageIndex:he,historyIndex:ve}))return void fe(pe.length-1);if(-1!==he&&fe(-1),0!==e.length&&-1===ve&&!r)return;const o=I?.count()??0;if(0===o)return;-1===ve&&Te(e);const s=Math.min(ve+1,o-1);return void(s!==ve&&(Ce(s),n(I?.getAt(s)||""),F(e=>e+1)))}if(r.downArrow){if(i||H||ae)return;if(-1===ve)return;const t=e.lastIndexOf("\n");if(!(-1===t||_e.current>t))return;const r=ve-1;return Ce(r),n(-1===r?ke:I?.getAt(r)||""),void F(e=>e+1)}if(""===t||r.ctrl&&"c"===t)return void ze();if(isCtrlKey({inputChar:t,key:r,letter:"g",ctrlCode:7}))return Se.current=!0,void Pe();if(getIsExpandToolShortcut(r,t))return Se.current=!0,n(e),F(e=>e+1),void setTimeout(()=>{Se.current=!1},0);if(isNewlineShortcutKey({inputChar:t,key:r,isPasting:Le()}))return be.current=!0,Ge(),void setTimeout(()=>{be.current=!1},0);if(r.meta&&r.backspace)return void He();if(r.meta&&"w"===t)return Se.current=!0,void He();const o=r.ctrl&&"v"===t||SP.includes(t),s=r.meta&&"v"===t;if(o||s){if(o&&"darwin"===process.platform){const t=e;Se.current=!0;const r=await detectClipboardImage();return r&&(ge(e=>[...e,r]),n(t),F(e=>e+1)),void(Se.current=!1)}}else if(!r.ctrl&&!r.meta||"u"!==t){if(r.ctrl&&"z"===t?.toLowerCase())return W(!0),void setTimeout(()=>{process.kill(process.pid,"SIGTSTP")},100);if(-1!==he&&(r.delete||r.backspace)){const{remainingImages:e,nextSelectedIndex:t}=removeImageAt({images:pe,index:he});return ge([...e]),void fe(t)}if(r.escape){if(-1!==he)return void fe(-1);if(H)return;if(ae)return le(!1),n(ye),void F(e=>e+1);const t=Date.now();return t-ce.current<500?(e.length>0?He():R?.(),ce.current=0,ue.current=0):(ce.current=t,U||q||(ue.current=t)),j(!1),void B(!1)}U&&(r.backspace||r.delete)&&0===e.length&&j(!1)}});const Ve=te(async t=>{if(xe)return;const r=removeAltPCharacter(t);if(null!==r)return n(r),void $?.();const o=processBracketedPaste(t);if((o.isPasteStart||o.isPasteEnd||Le())&&await Re(t))return;if(Se.current)return void(Se.current=!1);-1!==ve&&Ce(-1);const s=1===t.length,l=t.slice(-1);if(s){if("?"===l&&!U)return j(!0),n(""),void F(e=>e+1);if("!"===l&&!q)return j(!1),B(!0),n(""),void F(e=>e+1)}if("/"!==l||H||"/"!==t||(G(!0),Q("")),H)if(t.startsWith("/")){const e=t.substring(1),{showMenu:n,query:r}=getCommandMenuStateFromQuery(e);n?G(!0):We(),Q(r)}else We(),Q("");"@"!==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)}}U&&(t!==e||t.length<e.length)&&j(!1),Ae&&Me(),0===t.length&&(B(!1),We(),Q(""),le(!1),me([]),u(""),we(""),$e()),n(t)},[U,e,n,i,a,H,q,pe,ve,Re,$e,$,Ae,Me,xe,We]),Qe=te(async()=>{if(Fe(),ue.current=0,U)return void j(!1);let n=e.trim();if(!q&&n.startsWith("/")&&d&&"handled"===(await d(n)).status)return I?.add(n),B(!1),We(),Q(""),ze(),me([]),Ce(-1),void Te("");Ce(-1),Te("");let r=[];const o=pe.length>0,s=de.length>0;if(!q&&o&&(r=[...pe]),!q&&s){let e=n;de.forEach((t,n)=>{const r=`[Text#${n+1}]`;e.includes(r)&&(e=e.replace(r,t))}),n=e}n.length>0&&I?.add(n);const i=De?.selection?{lines:De.selection.lineCount,file:De.activeFile?.relativePath?.split("/").pop()??De.activeFile?.path?.split("/").pop()??"unknown",ide:y_[nk()??""]??"IDE"}:void 0;t({input:n,role:q?"bash":"user",images:r,ideContext:De?fP(De):void 0,ideHint:i}),B(!1),We(),Q(""),ze(),me([])},[t,d,U,e,q,pe,de,I,Fe,ze,We]),Ke=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(""),F(e=>e+1)},[n,a,e,i,l,u]),Ye=te(()=>{a(!1),u("")},[a,u]),Je=te(e=>{const t=gx.has(e),r="/design"===e.trimEnd();if(t||r){const t=e.trimEnd();n(t+" "),Q(t.substring(1)+" ")}else We(),Q(""),n(e+" ");F(e=>e+1)},[n,We]),Xe=te(t=>{if("/resume"===t)return I?.add(t),Ce(-1),Te(""),we(e),We(),Q(""),le(!0),n(""),void F(e=>e+1);if("/design help"===t)return We(),Q(""),n(""),F(e=>e+1),I?.add(t),void d?.("/design help");if(px.has(t))return We(),Q(""),I?.add(t),Ce(-1),Te(""),n(""),F(e=>e+1),void d?.(t);const r=gx.has(t),o=hx.has(t);r?Je(t):(We(),Q(""),o?(I?.add(t),Ce(-1),Te(""),n(""),F(e=>e+1),d?.(t)):(n(t+" "),F(e=>e+1)))},[d,n,e,I,Je,We]),Ze=te(()=>{We(),Q(""),n(""),Ce(-1),Te(""),F(e=>e+1)},[n,We]),et=te(e=>{le(!1),n(""),we(""),Ce(-1),Te(""),F(e=>e+1),d&&d(`/resume:${e}`)},[d,n]),tt=te(()=>{le(!1),n(ye),Ce(-1),Te(""),F(e=>e+1)},[ye,n]),nt=te(e=>{_e.current=e,Ee.current=void 0},[]),rt=ee(()=>{const t=Be&&("OPEN"===Be.state||"MERGED"===Be.state);return"auto-accept"===x||"plan"===x||"bypass"===x||Oe||t?!U&&!ae:!U&&0===e.length&&!q&&!ae},[U,e,q,ae,x,Oe,Be]),ot=X(new Map),st=ee(()=>pe.map((e,t)=>{if(ot.current.has(e))return ot.current.get(e)??null;const n=saveTempImage(e,t+1);return ot.current.set(e,n),n}),[pe]),it=__name(()=>U||i||H||ae||z?0:rt||M||q?3:4,"getBottomMargin");return K.createElement(ne,{width:"100%",flexDirection:"column",marginBottom:it()},!ae&&K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(ImageRowsDisplay,{detectedImages:pe,selectedImageIndex:he,imageTempPaths:st,termWidth:qe,inHistory:-1!==ve}),K.createElement(re,{color:q?mr.GREEN:mr.GRAY},Ie.line.repeat(qe)),(()=>{const t=__name(()=>{if(!be.current)return Date.now()-ue.current<100?(ue.current=0,void Ge()):void(i||H||ae||xe||Qe());be.current=!1},"handleTextInputSubmit"),n=__name(n=>K.createElement(TextInput,{key:O,value:e,placeholder:xe?"Save and close the editor to continue...":o,onChange:Ve,onSubmit:t,showCursor:!xe&&r&&-1===he,onCursorChange:nt,initialCursor:Ee.current,prefix:`${q?"!":Ie.pointer} `,prefixColor:q?mr.GREEN:mr.WHITE,singleLine:n?.singleLine,maxWidth:n?.maxWidth}),"renderTextInput");if(H&&T&&"/model"===Y){const e=getModelHintLayout({currentModel:T,terminalWidth:qe});return K.createElement(ne,{flexDirection:"row",width:"100%"},K.createElement(ne,{width:25},n({singleLine:!0,maxWidth:25})),K.createElement(ne,{width:e.descriptionWidth},K.createElement(re,{color:mr.DIM,wrap:"truncate"},e.text)))}return n()})(),K.createElement(re,{color:q?mr.GREEN:mr.GRAY},Ie.line.repeat(qe))),U&&K.createElement(bP,null),z&&K.createElement(ne,{paddingTop:1},K.createElement(re,{color:mr.YELLOW},"Command Code has been suspended. Run `fg` to bring\n\t\t\t\t\t\tCommand Code back.")),i&&K.createElement(eP,{onSelectFile:Ke,onClose:Ye,searchQuery:l}),H&&K.createElement(wx,{onSelectCommand:Xe,onInsertCommand:Je,onClose:Ze,searchQuery:V,onSelectedCommandChange:oe}),ae&&K.createElement(gP,{onSelectSession:et,onClose:tt}),!H&&(rt||M)&&K.createElement(aP,{termWidth:qe,indicatorText:wP(Oe,De,qe),isIDEIndicator:yP(Oe,De),permissionMode:x,prInfo:Be,tasteLearning:g,contextUsage:m,connectionIndicator:Ue,pendingExitKey:M,updateStatus:v,updateFailedInfo:C,currentProvider:k,showProviderInfo:_,isBashMode:q,shareInfo:f,showShareNotification:y,unshareNotificationMessage:w,tasteNotificationMessage:S,creditWarning:E}),Ae&&K.createElement(ne,{paddingLeft:1,flexDirection:"column"},K.createElement(re,{color:mr.YELLOW},Ae)))},"InputBox");Ft(),fs(),Or();var vP=__name(({messages:e})=>0===e.length?null:K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(ne,{marginBottom:0},K.createElement(re,{color:fr,inverse:!0},` Queued (${e.length}) `)),e.map((e,t)=>K.createElement(ne,{key:t},K.createElement(re,{color:mr.DIM},Ie.pointerSmall," "),K.createElement(re,{color:mr.DIM},truncateString({text:e.displayMessage??e.input,maxChars:80}))))),"QueuedMessages"),CP=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:v,updateStatus:C,updateFailedInfo:k,creditWarning:T,currentProvider:_,currentModel:x,showProviderInfo:A,permissionMode:P,onToggleAutoAccept:I,hintMessage:M,historyManager:N,pendingExitKey:R,onResetPendingExitKey:$,onDoubleEscapeEmpty:L,retryAttempt:D,onAltP:O})=>{const[F,U]=J(0),j=X(o);return Z(()=>{R&&o!==j.current&&o.length>0&&$?.(),j.current=o},[o,R,$]),Z(()=>{if(!t)return void U(0);const e=setInterval(()=>{U(e=>e+1e3)},1e3);return()=>{clearInterval(e)}},[t]),K.createElement(ne,{flexDirection:"column"},K.createElement(vP,{messages:e}),K.createElement(ne,{flexDirection:"row",justifyContent:"space-between"},K.createElement(ne,{flexDirection:"column"},(t||n.isExecuting)&&null===D&&K.createElement(jA,{tokens:g,timeElapsed:F,status:n.isExecuting?`Executing: ${n.currentCommand}`:r}),M&&K.createElement(ne,{marginLeft:1},K.createElement(re,{color:mr.DIM}," ","⎿"," ","Tip: ",M)))),K.createElement(EP,{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:v,updateStatus:C,updateFailedInfo:k,creditWarning:T,currentProvider:_,currentModel:x,showProviderInfo:A,permissionMode:P,onToggleAutoAccept:I,hintMessage:M,historyManager:N,pendingExitKey:!R||t||n.isExecuting?null:R,onDoubleEscapeEmpty:L,onAltP:O,isProcessing:t}))});Ft(),tE(),iE(),ao(),fo();var kP=__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(oo,{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(rE,{authState:i,statusMessage:a,browserUrl:l,apiKeyInput:u,setApiKeyInput:d,handleApiKeySubmit:m})},"LoginOverlay");function buildOAuthMetadataUrl(e){const t=new g(e),n="/"===t.pathname?"":t.pathname.replace(/\/+$/,"");return t.pathname=`/.well-known/oauth-authorization-server${n}`,t.search="",t.hash="",t.toString()}function buildOidcMetadataUrl(e){const t=new g(e),n=t.pathname.replace(/\/+$/,"");return t.pathname=`${n}/.well-known/openid-configuration`,t.search="",t.hash="",t.toString()}async function tryFetchAsMetadata(e){try{const t=await fetchWithTimeout(e,{method:"GET",headers:{Accept:"application/json"}});if(!t.ok)return null;const n=await t.json();return n.authorization_endpoint&&n.token_endpoint?{authorizationEndpoint:n.authorization_endpoint,tokenEndpoint:n.token_endpoint,registrationEndpoint:n.registration_endpoint,scopes:n.scopes_supported}:null}catch(t){return dlog(`[MCP] OAuth metadata fetch failed for ${e}`,t),null}}async function discoverOAuthMetadataFromIssuer(e){return await tryFetchAsMetadata(buildOAuthMetadataUrl(e))||await tryFetchAsMetadata(buildOidcMetadataUrl(e))}async function discoverOAuthMetadata(e){const t=new g(e),n=`${t.protocol}//${t.host}`;return await tryFetchAsMetadata(`${n}/.well-known/oauth-authorization-server`)||await tryFetchAsMetadata(`${n}/.well-known/openid-configuration`)}function parseResourceMetadataUrl(e){if(!e)return null;const t=e.match(/resource_metadata\s*=\s*"([^"]+)"|resource_metadata\s*=\s*([^\s,]+)/i);return t?t[1]??t[2]??null:null}async function fetchProtectedResourceMetadata(e){try{const t=await fetchWithTimeout(e,{method:"GET",headers:{Accept:"application/json"}});if(!t.ok)return null;const n=await t.json();return{authorizationServers:n.authorization_servers,scopesSupported:n.scopes_supported}}catch(e){return dlog("[MCP] Protected resource metadata fetch failed",e),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:NS,capabilities:{},clientInfo:RS}})});if(401===t.status||403===t.status){const n=parseResourceMetadataUrl(t.headers?.get?.("www-authenticate")??null);if(n){const e=await fetchProtectedResourceMetadata(n),t=e?.authorizationServers?.[0];if(t){const n=await discoverOAuthMetadataFromIssuer(t);if(n)return e?.scopesSupported&&(n.scopes=e.scopesSupported),{requiresAuth:!0,metadata:n}}}return{requiresAuth:!0,metadata:await discoverOAuthMetadata(e)||void 0}}return{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}async function discoverAndAuthenticate({serverName:e,serverUrl:t,onStatus:n}){const r=n??(()=>{});r("Probing server for OAuth requirements...");const o=await checkServerAuthRequirements(t);if(o.error)return{success:!1,error:o.error};if(!o.requiresAuth)return{success:!1,error:"Server does not require authentication"};if(!o.metadata)return{success:!1,error:"Server returned 401 but did not advertise OAuth metadata. Add `oauth` config manually via `mcp add-json`."};const{authorizationEndpoint:s,tokenEndpoint:i,registrationEndpoint:a,scopes:l}=o.metadata;if(!a)return{success:!1,error:"Server requires pre-registered OAuth credentials (no Dynamic Client Registration endpoint advertised). Register an OAuth client with the server, then add it via `mcp add-json` with an `oauth.clientId` field."};const u=`http://${XS}:${JS}/callback`;r("Registering OAuth client...");const d=await registerOAuthClient({registrationEndpoint:a,clientName:RS.name,redirectUris:[u]});if(!d)return{success:!1,error:"Dynamic client registration failed at "+a};const m={authorizationUrl:s,tokenUrl:i,clientId:d.clientId,clientSecret:d.clientSecret,scopes:l},g=await performOAuthFlow(e,t,m,{onStatus:n});return g.success&&(await storeDiscoveredClient(e,{authorizationUrl:s,tokenUrl:i,clientId:d.clientId,scopes:l}),d.clientSecret?await storeClientSecret(e,d.clientSecret):await deleteClientSecret(e)),g}Ft(),Ft(),zS(),DS(),GS(),WS(),QS(),ob(),lb(),cb(),Ft(),lb(),cb(),jS(),rb(),Ft(),YS(),DS(),er(),__name(buildOAuthMetadataUrl,"buildOAuthMetadataUrl"),__name(buildOidcMetadataUrl,"buildOidcMetadataUrl"),__name(tryFetchAsMetadata,"tryFetchAsMetadata"),__name(discoverOAuthMetadataFromIssuer,"discoverOAuthMetadataFromIssuer"),__name(discoverOAuthMetadata,"discoverOAuthMetadata"),__name(parseResourceMetadataUrl,"parseResourceMetadataUrl"),__name(fetchProtectedResourceMetadata,"fetchProtectedResourceMetadata"),__name(checkServerAuthRequirements,"checkServerAuthRequirements"),__name(registerOAuthClient,"registerOAuthClient"),Ft(),DS(),rb(),jS(),__name(discoverAndAuthenticate,"discoverAndAuthenticate"),Or(),io();var TP=__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||"http"===e.config.transport)&&(await hasTokens(e.name)?s="authenticated":e.config.oauth&&(s="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:mr.GREEN},Ie.tick);case"authenticated":return K.createElement(re,{color:mr.CYAN},Ie.tick);case"requires_auth":return K.createElement(re,{color:mr.YELLOW},Ie.warning);case"error":return K.createElement(re,{color:mr.RED},Ie.cross);default:return K.createElement(re,{color:mr.GRAY},Ie.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:mr.CYAN,loading:!0});try{if(!await updateMcpServerStatus({name:h.name,enabled:!0,scope:h.scope}))return void d({text:`${Ie.cross} Failed to enable ${h.name}, server may no longer exist in ${h.scope} scope`,color:mr.YELLOW});await m(),d({text:`${Ie.tick} Enabled ${h.name}`,color:mr.GREEN})}catch(e){d({text:`${Ie.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:mr.RED})}}else{d({text:`Disabling ${h.name}...`,color:mr.CYAN,loading:!0});try{const e=getMcpConnectionManager();if(!await updateMcpServerStatus({name:h.name,enabled:!1,scope:h.scope}))return void d({text:`${Ie.cross} Failed to disable ${h.name}, server may no longer exist in ${h.scope} scope`,color:mr.YELLOW});await e.disconnectServer(h.name),await m(),d({text:`${Ie.tick} Disabled ${h.name}`,color:mr.GREEN})}catch(e){d({text:`${Ie.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:mr.RED})}}else l("confirm-remove");else{if(!(h.config.oauth||"http"===h.config.transport&&h.config.url))return void d({text:"Authentication requires an http server with a url",color:mr.YELLOW});d({text:`Authenticating ${h.name}...`,color:mr.CYAN,loading:!0});try{let e;if(h.config.oauth){const t={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};e=await performOAuthFlow(h.name,h.config.url??"",t,{onStatus:__name(()=>{},"onStatus")})}else e=await discoverAndAuthenticate({serverName:h.name,serverUrl:h.config.url});if(e.success){d({text:`${Ie.tick} Authenticated with ${h.name}`,color:mr.GREEN});try{const e=getMcpConnectionManager();await e.ensureServerConnection(h.name)}catch{}await m()}else d({text:`${Ie.cross} Auth failed: ${e.error}`,color:mr.RED})}catch(e){d({text:`${Ie.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:mr.RED})}}else{d({text:`Connecting ${h.name}...`,color:mr.CYAN,loading:!0});try{const e=getMcpConnectionManager();await e.ensureServerConnection(h.name),d({text:`${Ie.tick} Connected to ${h.name}`,color:mr.GREEN}),await m()}catch(e){d({text:`${Ie.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:mr.RED})}}else d({text:"Already authenticated",color:mr.GREEN});else d({text:"Already connected",color:mr.GREEN});else l("list")},"handleActionSelect"),v=__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:`${Ie.cross} Failed: ${e instanceof Error?e.message:String(e)}`,color:mr.RED}),l("actions")}else l("actions")},"handleRemoveConfirm");if(r)return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:pr,bold:!0},"Manage MCP servers"),K.createElement(re,{color:mr.DIM},"Loading..."));if("confirm-remove"===a&&h)return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:mr.RED,bold:!0},"Remove ",h.name,"?"),K.createElement(re,{color:mr.DIM},"This will remove the server from ",h.scope," ","config."),K.createElement(ne,{marginTop:1},K.createElement(pt,{items:[{label:"Yes, remove",value:"yes"},{label:"Cancel",value:"no"}],onSelect:v,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:mr.WHITE},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?mr.WHITE:mr.GRAY}," ",t)})),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.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;t&&e.push({label:"Enable",value:"enable"}),!t&&n&&e.push({label:"Connected",value:"connected"}),t||n||e.push({label:"Connect",value:"connect"});const o=!t&&(h.config.oauth||"http"===h.config.transport);return o&&r&&e.push({label:"Authenticated",value:"authenticated"}),o&&!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:pr,bold:!0},h.name),K.createElement(ne,null,f(h.status),K.createElement(re,{color:mr.DIM}," ",y(h))),K.createElement(ne,{marginTop:1},K.createElement(pt,{items:e,onSelect:E,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:mr.WHITE},e?">":" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?mr.WHITE:mr.GRAY}," ",t)})),u&&K.createElement(ne,{marginTop:1},u.loading&&K.createElement(re,{color:u.color},K.createElement(Be,{type:"dots"})," "),K.createElement(re,{color:u.color},u.text)),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"↑↓ navigate · Enter to select · Esc to go back")))}let C=null;return K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:pr,bold:!0},"Manage MCP servers"),K.createElement(re,{color:mr.DIM},t.length," ",1===t.length?"server":"servers"),0===t.length?K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(re,{color:mr.DIM},"No MCP servers configured."),K.createElement(re,{color:mr.DIM},'Use "cmd mcp add" to add a server.'),K.createElement(ro,{url:"https://commandcode.ai/docs/mcp",text:"View MCP Docs ↗",color:mr.CYAN,dimColor:!0})):K.createElement(ne,{marginTop:1,flexDirection:"column"},g.map((e,t)=>{const n=e.scope!==C;C=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:mr.DIM}," ","(",S(e.scope),")")),K.createElement(ne,{paddingLeft:1},K.createElement(re,{color:r?mr.WHITE:mr.GRAY},r?"› ":" "),K.createElement(re,{color:r?mr.WHITE:void 0,bold:r},e.name),K.createElement(re,{color:mr.DIM}," · "),f(e.status),K.createElement(re,{color:"connected"===e.status?mr.GREEN:"authenticated"===e.status?mr.CYAN:"requires_auth"===e.status?mr.YELLOW:mr.GRAY}," ",y(e))))})),u&&K.createElement(ne,{marginTop:1},u.loading&&K.createElement(re,{color:u.color},K.createElement(Be,{type:"dots"})," "),K.createElement(re,{color:u.color},u.text)),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},0===t.length?"Esc to close":"↑↓ navigate · Enter to select · Esc to close")))},"McpManager");Ft(),Cn(),Kn(),Or();var _P=__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:mr.DIM},"Loading memory files..."));if(a)return K.createElement(ne,{paddingLeft:1,paddingTop:1},K.createElement(re,{color:mr.RED},Ie.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:mr.GRAY,paddingTop:1,paddingBottom:1,paddingLeft:2,paddingRight:2},K.createElement(ne,null,K.createElement(re,{color:mr.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?mr.WHITE:mr.DIM},r===t?`${qn} `:" ",e.label))),K.createElement(ne,{flexDirection:"column"},m.map((e,t)=>K.createElement(re,{key:t,color:r===t?mr.WHITE:mr.DIM},e.description)))))},"MemorySelector");function AutoCompactMessage({content:e}){return K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:mr.DIM},Ie.bullet," ",e))}function TasteSkipMessage(){return K.createElement(ne,{marginTop:1,marginBottom:1},K.createElement(ne,{flexShrink:0},K.createElement(re,{backgroundColor:gr.BADGE_BG,color:gr.BADGE_FG,bold:!0},e_)),K.createElement(re,{color:mr.DIM}," Skipped. Run "),K.createElement(re,{color:Ir.CODE},"/learn-taste"),K.createElement(re,{color:mr.DIM}," or "),K.createElement(re,{color:Ir.CODE},"cmd learn-taste"),K.createElement(re,{color:mr.DIM}," anytime."))}function HookWarningMessage({content:e}){return K.createElement(ne,null,K.createElement(re,{color:mr.YELLOW},Ie.warning),K.createElement(ne,{marginLeft:1,flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:mr.YELLOW},e)))}function HookLineMessage({content:e}){return K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:mr.DIM},` ${e}`))}function HookLineContinuationMessage({content:e}){return K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:mr.DIM},` ${e}`))}function HookFrameMessage({lines:e,header:t}){return K.createElement(ne,{flexDirection:"column"},void 0!==t&&K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:mr.DIM},` ${t}`)),e.map((e,t)=>K.createElement(ne,{key:t,flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:mr.DIM},e.primary?` └ ${e.text}`:` ${e.text}`))))}function InfoMessage({content:e,metadata:t}){return t?.isTasteSkip?K.createElement(TasteSkipMessage,null):t?.isAutoCompact?K.createElement(AutoCompactMessage,{content:e}):t?.hookFrame&&t.hookFrame.length>0?K.createElement(HookFrameMessage,{lines:t.hookFrame,header:t.hookFrameHeader}):t?.isHookLine?K.createElement(HookLineMessage,{content:e}):t?.isHookLineContinuation?K.createElement(HookLineContinuationMessage,{content:e}):t?.isHookWarning?K.createElement(HookWarningMessage,{content:e}):t?.isSuccess?K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:mr.GREEN},Ie.tick," ",e)):K.createElement(ne,{flexGrow:1,flexShrink:1,minWidth:0},K.createElement(re,{color:mr.DIM},Ie.bullet," ",e))}Ft(),Or(),__name(AutoCompactMessage,"AutoCompactMessage"),__name(TasteSkipMessage,"TasteSkipMessage"),__name(HookWarningMessage,"HookWarningMessage"),__name(HookLineMessage,"HookLineMessage"),__name(HookLineContinuationMessage,"HookLineContinuationMessage"),__name(HookFrameMessage,"HookFrameMessage"),__name(InfoMessage,"InfoMessage"),Ft(),Cn(),no(),Qb(),Io(),fo(),so(),Or(),Ft(),Or();var xP=yt()?"⠶":"#";function AssistantMessage({content:e}){return K.createElement(ne,null,K.createElement(re,{color:Tr},xP),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=mr.GREEN,s=Ie.tick,i="default",a=t||"(No output)";n&&(o=mr.YELLOW,s=Ie.arrowRight,i=mr.YELLOW,a="Executing…"),r&&(o=mr.RED,s=Ie.cross,i=mr.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:mr.GRAY},"$ "),K.createElement(re,{color:o,bold:!0},e)),K.createElement(ne,{columnGap:1,marginLeft:1},K.createElement(re,{color:Rr},l),K.createElement(re,{color:i,wrap:"wrap"},a))))}function CommandResultMessage({message:e,details:t,hasError:n=!1}){const r=n?mr.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:Rr},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:mr.DIM},"See ",t)))}function ErrorMessage({content:e}){const t=e.includes("Interrupted by user");return K.createElement(ne,null,K.createElement(re,{color:mr.RED},t?Ie.pointer:Ie.warning),K.createElement(ne,{marginLeft:1,flexGrow:1,flexShrink:1,minWidth:0},t?K.createElement(re,{color:mr.RED,wrap:"wrap"},e):K.createElement(Markdown,{color:mr.RED},e)))}__name(AssistantMessage,"AssistantMessage"),Ft(),Or(),__name(BashMessage,"BashMessage"),Ft(),Or(),__name(CommandResultMessage,"CommandResultMessage"),Ft(),Or(),__name(ErrorMessage,"ErrorMessage"),Ft(),Or();var AP={connected:{char:Ie.tick,color:mr.GREEN},installed:{char:Ie.tick,color:mr.GREEN},up_to_date:{char:Ie.tick,color:mr.GREEN},needs_reload:{char:Ie.circle,color:mr.YELLOW},failed:{char:Ie.cross,color:mr.RED},not_in_ide:{char:Ie.circle,color:mr.YELLOW}};function IDEStatusMessage({status:e,ide:t,details:n}){const{prefix:r,ide:o,suffix:s}=getStatusHeadline(e,t),i=AP[e];return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,K.createElement(re,null,K.createElement(re,{color:i.color},i.char),K.createElement(re,null," ",r),o&&K.createElement(re,{color:mr.CYAN},o),s&&K.createElement(re,null,s))),n?.map((e,t)=>K.createElement(re,{key:t,color:mr.DIM}," ",e)))}function ReasoningMessage({content:e,expandedOutput:t,expandKey:n,isStreaming:r=!1}){const o=e?Math.max(1,Math.round(e.length/500)):1,s=Boolean(e),i=(s?e.split("\n"):[]).length,a=`${r?"Thinking…":`Thought for ${o} second${1!==o?"s":""}`}${r&&!t&&i>0?` (${i} line${1!==i?"s":""})`:""}`,l=t&&s,u=!t&&s,d=r&&t&&e.length>560,m=d?e.length-560:0,g=80*Math.floor(m/80),h=d?(e.slice(0,g).match(/\n/g)??[]).length:0,f=d?e.slice(g):e;return K.createElement(ne,{flexDirection:"column",width:"90%"},K.createElement(ne,null,K.createElement(re,{color:hr},"✻"," "),K.createElement(re,{color:hr},u?`${a} `:a),u&&K.createElement(BracketWrap,{color:mr.DIM},`${n}+o to expand`)),l&&d&&K.createElement(ne,{marginLeft:2},K.createElement(re,{color:mr.DIM},h>0?`… (${h} more line${1!==h?"s":""})`:"…")),l&&K.createElement(ne,{marginLeft:2,flexDirection:"column"},K.createElement(re,{color:hr,wrap:"wrap",italic:!0},f)))}__name(IDEStatusMessage,"IDEStatusMessage"),Ft(),Or(),__name(ReasoningMessage,"ReasoningMessage"),Ft(),Ft(),Cn();function HelpMessage(){const e=getInvokedCommandName(),t=ee(()=>Ek.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:mr.GRAY}," v","0.33.0")),K.createElement(re,{color:mr.GRAY},fk)),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},bk.map(t=>K.createElement(ne,{key:t.key},K.createElement(re,null,t.key.replace(/^cmd/,e).padEnd(yk)),K.createElement(re,{color:mr.GRAY},t.description))))),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Commands"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},vk.map(t=>K.createElement(ne,{key:t.key},K.createElement(re,null,t.key.replace(/^cmd/,e).padEnd(yk)),K.createElement(re,{color:mr.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(yk)),K.createElement(re,{color:mr.GRAY},e.description))))),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Keyboard Shortcuts"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},Sk.map(e=>K.createElement(ne,{key:e.key},K.createElement(re,null,e.key.padEnd(yk)),K.createElement(re,{color:mr.GRAY},e.description))))),K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(re,{bold:!0},"Examples"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},kk.map(t=>K.createElement(ne,{key:t.key},K.createElement(re,null,t.key.replace(/^cmd/,e).padEnd(yk)),K.createElement(re,{color:mr.GRAY},t.description))))),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.CYAN},Ie.pointer),K.createElement(re,{color:mr.GRAY}," ",Tk.replace(/cmd/,e))),K.createElement(ne,{flexDirection:"column"},K.createElement(re,{bold:!0},"Links"),K.createElement(ne,{flexDirection:"column",paddingLeft:2},Ck.map(e=>K.createElement(ne,{key:e.key},K.createElement(re,null,e.key.padEnd(yk)),K.createElement(re,{color:mr.CYAN},e.description))))))}function SystemMessage({content:e}){return e.includes("KEYBOARD SHORTCUTS")&&e.includes("COMMANDS")?K.createElement(HelpMessage,null):K.createElement(ne,{flexDirection:"column"},K.createElement(re,{wrap:"wrap"},K.createElement(Markdown,null,e)))}Or(),ZS(),fo(),__name(HelpMessage,"HelpMessage"),__name(SystemMessage,"SystemMessage"),Ft(),Kn(),mo(),Or();var PP={"Interrupted by user":"Interrupted by user","Insufficient credits":Un};function UserMessage({content:e,images:t,imageCount:n=0,ideHint:r}){const o="Interrupted by user"===e,s="Insufficient credits"===e,i=e.startsWith("Error:"),a=o||s||i,l=a&&PP[e]||e,u=null!=t?t.length:n,d=X(null);null===d.current&&t&&t.length>0&&(d.current=t.map((e,t)=>saveTempImage(e,t+1)));const m=d.current??[];return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{backgroundColor:a?void 0:kr.BG,paddingRight:1},K.createElement(re,{color:a?mr.RED:kr.POINTER,bold:!a},Ie.pointer),K.createElement(ne,{marginLeft:1},K.createElement(re,{color:a?mr.RED:mr.WHITE,wrap:"wrap"},l))),u>0&&K.createElement(ne,{marginLeft:1},K.createElement(re,{color:mr.DIM},"⎿"," ",Array.from({length:u},(e,t)=>{const n=m[t],r=`[Image #${t+1}]`;return null!=n?createOSC8Link(`file://${n}`,r,!1):r}).join(" "))),r&&!a&&K.createElement(ne,{marginLeft:2},K.createElement(re,{color:Rr},JT),K.createElement(re,{color:mr.DIM}," ","Selected ",r.lines," ",1===r.lines?"line":"lines"," from"," ",r.file," in ",r.ide)))}function renderFeedEntry(e,t){if("user"===e.role){const t=Array.isArray(e.metadata?.images)?e.metadata.images:void 0,n=e.metadata?.ideHint;return K.createElement(UserMessage,{content:e.input,images:t,ideHint:n})}return"assistant"===e.role?K.createElement(AssistantMessage,{content:e.input}):"reasoning"===e.role?K.createElement(ReasoningMessage,{content:e.input,expandedOutput:t,expandKey:"ctrl",isStreaming:"running"===e.metadata?.status}):"tool"===e.role?K.createElement(ToolMessage,{name:Bb(e.name||""),input:e.input,output:e.output||"",isPending:Ub(e),hasError:Fb(e),metadata:e.metadata,expandedOutput:t}):"bash"===e.role?K.createElement(BashMessage,{command:e.command||"",output:e.output||"",isPending:Ub(e),hasError:Fb(e)}):"system"===e.role?K.createElement(SystemMessage,{content:e.input}):"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=findModelById(e);if(t){const e=t.name.toLowerCase().replaceAll(" ","-");return"free"===t.badge?`${e} (free)`:e}return e}function getProviderShortName(e){return e?fn[e]?.shortLabel??e.slice(0,4):""}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:Cr},o),K.createElement(BracketedText,{text:n,color:Cr}),K.createElement(re,{color:Cr},o))}__name(UserMessage,"UserMessage"),__name(renderFeedEntry,"renderFeedEntry"),__name(getModelShortName,"getModelShortName"),__name(getProviderShortName,"getProviderShortName"),__name(TranscriptDivider,"TranscriptDivider");var IP=K.memo(({feed:e,showHeader:t=!1,staticKey:n,expandedToolOutput:r=!1,currentModel:o,currentProvider:s,hiddenCount:i=0})=>{const a=i>0?{role:"transcript-divider",count:i}:null,l=[...t?["header"]:[],...a?[a]:[],...e],u=useTerminalWidth(),d=ee(()=>Yx(u),[u]),m=ee(()=>tA(u),[u]),g=ee(()=>getPackageJson().version||"0.0.0",[]),h=ee(()=>getGitHeaderInfo(),[]),f=ee(()=>{const e=process.cwd(),t=process.env.HOME??process.env.USERPROFILE??"";return e.replace(t,"~")},[]),y=o?getModelShortName(o):"sonnet-4.6",w="taste-1",S=ee(()=>{if(!o)return"";if(!modelSupportsReasoningEffort(o))return"";const e=getReasoningEffort(o);return e?` with ${e} effort`:""},[o,n]),E=isInternalTeamFlagEnforced()&&!process.env.CMD_DEMO,v=E?" · co":"",C=E&&s?` · ${getProviderShortName(s)}`:"";return K.createElement(oe,{items:l,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:u});if("header"===e)return"compact"===m?K.createElement(ne,{key:"header",marginBottom:1,flexDirection:"row"},K.createElement(ne,{width:Zx,flexShrink:0},K.createElement(nA,null,Xx)),K.createElement(ne,{flexDirection:"column",marginLeft:2},K.createElement(ne,null,K.createElement(re,{bold:!0},"Command Code"),K.createElement(re,{color:Cr}," ","v",g)),K.createElement(re,{color:Cr},"models: ",y,S," ·"," ",w,v),K.createElement(re,{color:Cr},f,h&&h.isLocal&&h.branch&&` (${h.branch})`))):K.createElement(ne,{key:"header",marginBottom:1,flexDirection:"column"},K.createElement(nA,null,d.trimEnd()),K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(ne,null,K.createElement(re,{color:Cr},"# "),K.createElement(re,{bold:!0},"Command Code"),K.createElement(re,{color:Cr}," v",g)),K.createElement(re,{color:Cr},"# models: ",y,S," · ",w,C,v),K.createElement(ne,null,K.createElement(re,{color:Cr},"# ",f,h&&h.isLocal&&h.branch&&K.createElement(re,{color:Cr}," ","(branch:"," ",h.branch,")")))));const t=e,n=renderFeedEntry(t,r);return K.createElement(ne,{key:t.id,paddingBottom:1,width:"90%"},n)})});Ft(),Qb(),yo(),Or();var MP=Y(__name(function LiveAgentStatusInner2({entry:e}){const t=Bb(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:br.BG,color:br.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:mr.GRAY},"Running (",formatTime2(i)," |"," ",formatTokens(s),")",l)),a.length>0&&K.createElement(ne,{flexDirection:"column",marginLeft:1},a.map((e,t)=>{const n=Bb(e.name);return K.createElement(ne,{key:t,columnGap:1},K.createElement(re,{color:mr.GRAY},"⎿"),K.createElement(re,{color:mr.GRAY}," ",n),e.input&&K.createElement(re,{color:mr.GRAY},"(",e.input,")"))})))},"LiveAgentStatusInner")),NP=Y(__name(function LiveAgentStatus2({entry:e}){return"tool"!==e.role?null:K.createElement(MP,{entry:e})},"LiveAgentStatus"));Ft(),Cn(),no(),so(),yo(),fo(),Or(),Ft(),Or();var RP={low:"Fast responses with lighter reasoning",medium:"Balances speed and reasoning depth for everyday tasks",high:"Greater reasoning depth for complex problems",xhigh:"Extra reasoning depth for complex problems",max:"Maximum reasoning budget for the hardest problems"},$P={value:void 0,label:"Default",description:"Use the provider default reasoning level"},LP=__name(({modelLabel:e,supportedEfforts:t,currentEffort:n,onSelect:r,onCancel:o})=>{const s=ee(()=>[$P,...t.map(e=>({value:e,label:e,description:RP[e]}))],[t]),i=ee(()=>{if(void 0===n)return 0;const e=s.findIndex(e=>e.value===n);return e>=0?e:0},[s,n]),a=__name((e,t)=>`${e+1}. ${t}`,"labelText"),l=ee(()=>Math.max(...s.map((e,t)=>a(t,e.label).length))+4,[s]),{cursor:u}=useListNavigation({items:s,onSelect:__name(e=>r(e.value),"onSelect"),onCancel:o,initialIndex:i,searchQuery:"",onSearchChange:__name(()=>{},"onSearchChange"),disableSearch:!0});return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,{marginBottom:1},K.createElement(re,{color:pr,bold:!0},`Select reasoning effort for ${e}`)),K.createElement(ne,{flexDirection:"column"},s.map((e,t)=>{const r=t===u,o=e.value===n;return K.createElement(ne,{key:e.label},K.createElement(re,{color:mr.CYAN},r?`${Ie.pointer} `:" "),K.createElement(re,{color:r?mr.CYAN:o?mr.GREEN:mr.WHITE},a(t,e.label).padEnd(l)),K.createElement(re,{color:mr.DIM},e.description),o&&K.createElement(re,{color:mr.GREEN}," ",Ie.tick))})),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"↑/↓ navigate · enter to select · esc to go back")))},"ReasoningEffortSelector");er();var DP="Loading plan info…",OP=__name(e=>[{text:e.name,weight:100},{text:e.label,weight:50},{text:e.provider,weight:25},{text:e.description||"",weight:10}],"MODEL_SEARCH_FIELDS");function searchGroups2(e,t){if(!t.trim())return e;const n=[];for(const r of e){const e=fuzzyFilter(r.models,t,OP);e.length>0&&n.push({...r,models:e})}return n}function flattenGroups(e){const t=[];for(const n of e)for(const e of n.models)t.push({providerId:n.providerId,model:e});return t}function groupByModelProvider2(e,t){return groupModelsByDisplayOrder(e).map(e=>({providerId:t,label:e.label,models:e.models}))}__name(searchGroups2,"searchGroups"),__name(flattenGroups,"flattenGroups"),__name(groupByModelProvider2,"groupByModelProvider");var FP=__name(({onSelect:e,onCancel:t,currentModel:n,currentProvider:r,planId:o,purchasedCredits:s=0,freeCredits:i=0,refreshBanner:a})=>{const[l,u]=J(""),[d,m]=J(null),[g,h]=J(()=>new Set),f=ee(()=>isInternalTeamFlagEnforced(),[]),y=ee(()=>f?yn:groupByModelProvider2(wn.flatMap(e=>e.models),fn["command-code"].id),[f]),w=ee(()=>searchGroups2(y,l),[y,l]),S=ee(()=>flattenGroups(w),[w]),E=void 0!==o,v=ee(()=>E?null:getCachedBillingContext(),[E]),[C,k]=J(v),[T,_]=J(!E&&!v);Z(()=>{if(E)return;if(C)return;let e=!0;return getBillingContext().then(t=>{e&&(k(t),_(!1))}),()=>{e=!1}},[E,C]);const x=!E&&!0===C?.fetchFailed,A=E?o:C?.planId??null,P=E?s:C?.purchasedCredits??0,I=E?i:C?.freeCredits??0,M=f?fn.anthropic.id:fn["command-code"].id,N=r??M,R=n?Math.max(0,S.findIndex(e=>e.model.id===n&&e.providerId===N)):0,[$,L]=J("model"),[D,O]=J(null),{cursor:F,error:U,setError:j}=useListNavigation({items:S,onSelect:__name(t=>{const n=getSupportedEfforts(t.model.id);if(n&&n.length>0)return O(t),void L("effort");e(t.model.id,t.providerId)},"onSelect"),onCancel:t,initialIndex:R,searchQuery:l,onSearchChange:u,isActive:"model"===$,validate:__name(e=>{if(g.has(e.providerId))return`Run /provider to authenticate with ${getProviderConfig(e.providerId)?.displayName??e.providerId} first`;if(d&&!f){const t=fn[d]?.supportedModelProviders;if(t&&!t.includes(e.model.provider))return`${fn[d]?.label??d} does not support ${e.model.provider} models. Switch provider via /provider.`}if(T)return DP;const t=checkModelAccess({model:{id:e.model.id,provider:e.model.provider,name:e.model.name},planId:A,purchasedCredits:P,freeCredits:I});return t.allowed?null:t.errorMessage??"Model not available for your plan"},"validate")}),q=X(!1),B=__name(t=>{if(!D||q.current)return;q.current=!0;const{model:r,providerId:o}=D,s=getReasoningEffort(r.id),i=t!==s,l=r.id===n;(async()=>{try{i&&(await setReasoningEffort({modelId:r.id,effort:t}),l&&a?.())}catch(e){dlog(`[Model] Failed to persist reasoning effort: ${e}`)}finally{e(r.id,o)}})()},"handleEffortSelect"),z=__name(()=>{q.current||(O(null),L("model"))},"handleEffortCancel");if(Z(()=>{if(T)return;if(U!==DP)return;const e=S[F];if(!e||x)return void j(null);const t=checkModelAccess({model:{id:e.model.id,provider:e.model.provider,name:e.model.name},planId:A,purchasedCredits:P,freeCredits:I});j(t.allowed?null:t.errorMessage??"Model not available for your plan")},[T,x,U,j,S,F,A,P,I]),Z(()=>{(async()=>{await isOAuthEnforced()&&m(await getConfiguredProvider())})()},[]),Z(()=>{(async()=>{const e=new Set(y.map(e=>e.providerId)),t=new Set;for(const n of e){const e=getProviderConfig(n);e?.requiresAuth&&e.checkAuth&&(await e.checkAuth()||t.add(n))}h(t)})()},[y]),"effort"===$&&D){const e=getSupportedEfforts(D.model.id)??[];return K.createElement(LP,{modelLabel:D.model.label,supportedEfforts:e,currentEffort:getReasoningEffort(D.model.id),onSelect:B,onCancel:z})}let W=0;return K.createElement(ne,{flexDirection:"column",paddingX:0,width:"100%"},K.createElement(ne,null,K.createElement(re,{color:pr,bold:!0},"Select model")),K.createElement(ne,{marginBottom:1},K.createElement(re,{dimColor:!0},f?"Select a model and provider. Sets the default for new sessions; other open sessions are unaffected. Provider is saved.":"Switch between Command Code models. Sets the default for new sessions; other open sessions are unaffected.")),K.createElement(ne,{marginBottom:2,flexDirection:"column",width:"100%"},K.createElement(lA,{query:l,resultCount:l?S.length:void 0,placeholder:"Type to search models..."})),0===S.length?K.createElement(ne,{marginY:1},K.createElement(re,{color:mr.GRAY},'No models match "',l,'"')):K.createElement(ne,{flexDirection:"column"},w.map((e,t)=>{const r=W;return W+=e.models.length,K.createElement(ne,{key:`${e.providerId}-${e.label}`,flexDirection:"column",marginTop:t>0?1:0},f?K.createElement(re,{bold:!0,color:pr},e.label):K.createElement(re,{bold:!0,dimColor:!0},e.label),e.models.map((t,o)=>K.createElement(VA,{key:`${e.providerId}-${e.label}-${t.id}`,model:t,providerId:e.providerId,isHighlighted:r+o===F,isCurrent:t.id===n&&e.providerId===N,showProviderLabel:!!f&&void 0})))})),U&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.GRAY},U)),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"type to search · ↑/↓ navigate · enter to select"),l?K.createElement(re,{color:mr.DIM}," · esc to clear"):K.createElement(re,{color:mr.DIM}," · esc to cancel")))},"ModelSelector");Ft(),no(),so(),er();var UP=__name(({currentModel:e,onClose:t,refreshBanner:n})=>{const r=getSupportedEfforts(e)??[],o=findModelById(e)?.label??getModelDisplayName(e),s=X(!1),i=__name(r=>{if(s.current)return;s.current=!0;const o=r!==getReasoningEffort(e);(async()=>{try{o&&(await setReasoningEffort({modelId:e,effort:r}),n())}catch(e){dlog(`[Effort] Failed to persist reasoning effort: ${e}`)}finally{t()}})()},"handleSelect"),a=__name(()=>{s.current||t()},"handleCancel");return K.createElement(LP,{modelLabel:o,supportedEfforts:r,currentEffort:getReasoningEffort(e),onSelect:i,onCancel:a})},"EffortSelector");Ft(),fo(),Or();var jP=__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:mr.DIM},"Current: "),K.createElement(re,{color:mr.GREEN},getProviderDisplayName(n)),i&&K.createElement(re,{color:mr.YELLOW}," ","[OAuth enforced]"))),K.createElement(ne,{marginBottom:0},K.createElement(re,{color:mr.DIM},"Available Providers:")),K.createElement(pt,{items:r,onSelect:o,initialIndex:s>=0?s:0,indicatorComponent:({isSelected:e})=>K.createElement(re,{color:e?mr.CYAN:mr.GRAY,bold:e},e?Ie.triangleRightSmall:" "),itemComponent:({isSelected:e,label:t})=>K.createElement(re,{color:e?mr.CYAN:mr.GRAY,bold:e},` ${t}`)}),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.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:Pr,dimColor:!0},"Connection Issue. Retrying (attempt ",e,")",r))}Ft(),Or(),__name(RetryMessage,"RetryMessage"),Ft(),fs(),Kn(),Or();var qP=[{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"}],BP=__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?qP:qP.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:pr,bold:!0},"Rewind"),K.createElement(re,{color:mr.DIM},"No checkpoints available. Start a conversation to create checkpoints."),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"Press "),K.createElement(re,{color:mr.DIM,bold:!0},"Esc"),K.createElement(re,{color:mr.DIM}," to close")));if("mode"===l&&d)return K.createElement(ne,{flexDirection:"column",paddingLeft:2,paddingTop:1},K.createElement(re,{color:pr,bold:!0},"Rewind"),K.createElement(ne,{marginBottom:1},K.createElement(re,{color:mr.DIM},"Restore to: "),K.createElement(re,{color:mr.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?pr:void 0},n?`${qn} `:" "),K.createElement(ne,{flexDirection:"column"},K.createElement(re,{color:n?pr:mr.WHITE},e.label),K.createElement(re,{color:mr.DIM},e.description))),!r&&K.createElement(re,null," "))})),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"Press "),K.createElement(re,{color:mr.DIM,bold:!0},"Enter"),K.createElement(re,{color:mr.DIM}," to confirm, "),K.createElement(re,{color:mr.DIM,bold:!0},"Esc"),K.createElement(re,{color:mr.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:pr,bold:!0},"Rewind"),K.createElement(re,{color:mr.DIM},"Select a checkpoint to restore your session"),r.length>8&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.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?pr:void 0},s?`${qn} `:" "),K.createElement(ne,{flexDirection:"column"},K.createElement(ne,null,K.createElement(re,{color:s?pr:mr.WHITE},truncateString({text:e.userPrompt||"(no prompt)",maxChars:60})),K.createElement(re,{color:mr.DIM}," • "),K.createElement(re,{color:mr.DIM},getRelativeTimeString({timestamp:e.timestamp}),u&&" (latest)")),K.createElement(re,{color:mr.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:mr.DIM},"Press "),K.createElement(re,{color:mr.DIM,bold:!0},"Enter"),K.createElement(re,{color:mr.DIM}," to select, "),K.createElement(re,{color:mr.DIM,bold:!0},"Esc"),K.createElement(re,{color:mr.DIM}," to cancel")))},"RewindSelector");Ft(),Or();var zP=[{label:"Complete brief",desc:"If the target, goal, audience, or artifact is clear, act without asking."},{label:"Composition",desc:"Choose layout from the work pattern: monitor, operate, compare, configure, learn, decide, or explore."},{label:"Scope",desc:"Broad prompts get the full mode pass. Narrow prompts stay narrow."},{label:"Truth",desc:"Only claim changes that exist in files and are visible or verifiable."},{label:"Templates",desc:"design-html and report-html are documentation templates, not UI inspiration."},{label:"Reports",desc:"Follow-up modes read markdown reports, apply relevant findings, then still run their own full mode pass."}],WP=['/design redesign "Make this dashboard feel like an operator console"','/design motion "Animate the whole page and add missing interactions"','/design checkup "Audit this UI and generate the design report"','/design "Build a landing page for a privacy-first contract review tool"'],HP=__name(({onCancel:e})=>(ie((t,n)=>{n.escape&&e()}),K.createElement(ne,{flexDirection:"column",paddingLeft:2,paddingRight:2},K.createElement(ne,{marginBottom:1,flexDirection:"column"},K.createElement(re,{bold:!0,color:pr},"Use"),K.createElement(ne,{paddingLeft:2,flexDirection:"column"},K.createElement(re,{color:mr.DIM},'/design <mode> "target or request"'),K.createElement(re,{color:mr.DIM},'/design "freeform request" also works. The closest mode is inferred.'))),K.createElement(ne,{marginBottom:1,flexDirection:"column"},K.createElement(re,{bold:!0,color:pr},"Modes"),K.createElement(ne,{paddingLeft:2,flexDirection:"column"},cx.map(e=>K.createElement(ne,{key:e.name,columnGap:2},K.createElement(ne,{width:18,flexShrink:0},K.createElement(re,{color:mr.CYAN},"/design ",e.name)),K.createElement(ne,null,K.createElement(re,{color:mr.DIM},e.description)))))),K.createElement(ne,{marginBottom:1,marginTop:1,flexDirection:"column"},K.createElement(re,{bold:!0,color:pr},"Working rules"),K.createElement(ne,{paddingLeft:2,flexDirection:"column"},zP.map(e=>K.createElement(ne,{key:e.label,columnGap:2},K.createElement(ne,{width:16,flexShrink:0},K.createElement(re,{color:mr.CYAN},e.label)),K.createElement(ne,null,K.createElement(re,{color:mr.DIM},e.desc)))))),K.createElement(ne,{marginBottom:1,marginTop:1,flexDirection:"column"},K.createElement(re,{bold:!0,color:pr},"Quick examples:"),K.createElement(ne,{paddingLeft:2,flexDirection:"column"},WP.map(e=>K.createElement(re,{key:e,color:mr.DIM},e)))),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"Press Esc to close. Type /design help anytime to return.")))),"DesignGuide");Ft(),er(),Ft(),Ft();var GP=__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 xT.on("reset",t),xT.on("new-event",r),()=>{xT.off("reset",t),xT.off("new-event",r)}},[e]),{steps:t,importError:r,setImportError:o}},"useProgressEvents");async function createRequestClient(){const e=getApiBaseUrl(),t=new Xw({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={[Bt.PROJECT_SLUG]:Rk.getCurrentProjectDirName(),[Bt.INTERNAL_TEAM_FLAG_HEADER]:r.toString()};return o&&(i[Bt.OAUTH_TOKEN]=`Bearer ${o}`,s&&(i[Bt.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}function buildObserverPrompt(e,t){return`Produce ${t} varied observations for these prompts:\n\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}`),xT.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()}`),xT.addEvent({type:"insight",message:e.trim()}))},"emitRemaining"),getChunkCount:__name(()=>t,"getChunkCount")}}async function callObserverAPI(e,t,n){const r=getTasteObserverModel();dlog(`[ObserverAPI] calling ${zt.ALPHA.GENERATE} with model: ${r}`);const o={config:getEnvironmentContext(),memory:"",taste:"",skills:"",params:{tools:[],messages:[{role:"user",content:n}],model:r,system:"You scan prompts and produce casual observations like a dev friend glancing at someone's 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 per observation\n- one observation per line\n- sound human, not robotic\n- output only the observations, no preamble",max_tokens:200,temperature:.7,stream:!0},threadId:Pe()},s=await e.post({endpoint:zt.ALPHA.GENERATE,body:o,headers:t,stream:!0});dlog("[ObserverAPI] got response stream");const i=createInsightEmitter();await consumeSSEStream(s,{onText:__name(e=>{i.addText(e)},"onText")}),dlog(`[ObserverAPI] stream complete, ${i.getChunkCount()} chunks received`),i.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(xT.observerHasRun)return;xT.markObserverRun();const{prompts:t}=e;try{const{request:e,headers:n}=await createRequestClient(),r={...n,[Bt.SESSION_ID]:`observer-${Pe()}`},o=splitPromptsIntoBatches(t);dlog(`[Observer] ${t.length} prompts → ${o.length} batches`);const s=Math.min(o.length,6);for(let t=0;t<s;t++){if(xT.learningComplete){dlog(`[Observer] stopped at batch ${t} (learning complete)`);break}const n=o[t];try{await processBatch(e,r,n,t+1,o.length)}catch{}}dlog("[Observer] done")}catch(e){dlog(`[Observer] failed (non-critical): ${e instanceof Error?e.message:String(e)}`),xT.addEvent({type:"progress",message:"Continuing without live observations..."})}}Ft(),Ft(),yS(),IS(),er(),Ft(),Cn(),er(),Ft(),Ft(),Cn(),yS(),IS(),er(),so(),yo(),__name(createRequestClient,"createRequestClient"),Ft(),__name(splitPromptsIntoBatches,"splitPromptsIntoBatches"),__name(function calculateObservationsPerBatch(e){return 4},"calculateObservationsPerBatch"),Ft(),Ft(),er(),Bo(),Ft(),Cn(),__name(buildObserverPrompt,"buildObserverPrompt"),__name(createInsightEmitter,"createInsightEmitter"),__name(callObserverAPI,"callObserverAPI"),__name(processBatch,"processBatch"),__name(observeSessionPrompts,"observeSessionPrompts");var VP=class{static{__name(this,"SessionImporter")}static async findClaudeCodeSessions(t=0){const n=[];try{const r=e.join(w.homedir(),".claude","projects");await C.access(r);const o=process.cwd().replace(/\//g,"-");dlog(`[Import] scanning project: ${o}`);const s=(await C.readdir(r)).filter(e=>e===o);for(const o of s){const s=e.join(r,o);try{if(!(await C.stat(s)).isDirectory())continue;const r=(await C.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 C.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{xT.addEvent({type:"progress",message:"Scanning Codex sessions..."});const n=await findCodexSessions(process.cwd(),e=>{t?.(e),"reading"===e.phase&&xT.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{xT.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 C.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{xT.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}`);xT.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})`),xT.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){xT.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)}`)});xT.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 Xw({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&&xT.addEvent({type:"progress",message:`Processing batch ${n}/${r}...`});const o=this.formatBatchLearning(t),s=new MT({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}`),xT.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=xT.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||xT.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 xT.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),xT.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 C.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")}},QP=__name(e=>new Promise((t,n)=>setTimeout(()=>n(new Error("Learning timed out. Try again with /learn-taste")),e)),"createTimeout"),KP=__name(e=>{const[t,n]=J({isImporting:!0,waitingForInput:!1,alreadyLearned:!1,learnedSessionCount:0,totalSessionCount:0,agentSessions:[],error:null});return Z(()=>{xT.reset(),xT.markImportStarted(),(async()=>{try{const t=await Promise.race([VP.importAndLearn(),QP(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");Ft();var YP=__name(({onEscape:e,onEnter:t,enabled:n=!0})=>{ie((r,o)=>{n&&(o.escape&&e(),(o.return||"\n"===r)&&t())})},"useKeyboardInput");Ft(),er();var JP=__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{xT.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{xT.reset(),e()}}Ft(),er(),Ft(),er(),__name(completeOnboarding,"completeOnboarding"),__name(skipOnboarding,"skipOnboarding");var XP=__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");Ft(),er();var ZP=__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");Ft(),Ft(),Or();var eI=__name(({error:e})=>K.createElement(ne,{padding:1},K.createElement(ne,{flexDirection:"column",borderColor:mr.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");Ft(),Ft(),Or();var tI=__name(()=>K.createElement(re,null,"Skip"),"SkipOptionText"),nI=__name(({sessionCount:e,agentSessions:t,onImport:n,onSkip:r})=>{const[o,s]=J(1);return ie((e,t)=>{t.escape?r():"n"!==e&&"N"!==e?t.upArrow||t.downArrow?s(e=>1===e?2:1):"1"!==e?"2"!==e?t.return&&(1===o?n():r()):r():n():dismissOnboardingForeverForProject().then(()=>r())}),K.createElement(ne,{flexDirection:"column",borderStyle:"single",borderColor:gr.TEXT,paddingX:1,paddingY:0},K.createElement(re,{color:gr.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,"Analyze"," ",1===e?"that session":"those sessions"," ","to build your coding taste package?"))),K.createElement(ne,{marginTop:1,flexDirection:"column"},K.createElement(ne,null,K.createElement(re,{color:1===o?gr.TEXT:mr.GRAY},1===o?Ie.pointer:" "," 1. Yes, learn (recommended)")),K.createElement(ne,null,K.createElement(re,{color:2===o?gr.TEXT:mr.GRAY},2===o?Ie.pointer:" "," 2."," ",K.createElement(tI,null)))),K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"↑↓ · "),K.createElement(re,{color:Ir.CODE},"enter"),K.createElement(re,{color:mr.DIM}," ok · "),K.createElement(re,{color:Ir.CODE},"esc"),K.createElement(re,{color:mr.DIM}," skip · "),K.createElement(re,{color:Ir.CODE},"n"),K.createElement(re,{color:mr.DIM}," never")))},"ImportChoice");Ft(),Ft(),Or();var rI=__name(({error:e})=>K.createElement(ne,{flexDirection:"column",borderStyle:"single",borderColor:mr.RED,paddingX:2,paddingY:1,marginBottom:2},K.createElement(re,{color:mr.RED,bold:!0},"Oops, something went wrong:"),K.createElement(ne,{marginTop:1},K.createElement(re,null,e))),"ErrorSection");Ft(),Ft(),Or(),Ft(),Ft(),Ft(),Or(),Ft(),Or();var oI=__name(()=>K.createElement(re,{backgroundColor:gr.BADGE_BG,color:gr.BADGE_FG},e_),"TasteBadge");Ft(),Or(),Ft();var sI=["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"],iI="⎿",aI=__name(()=>{const[e,t]=J(()=>Math.floor(Math.random()*sI.length));return Z(()=>{const e=setInterval(()=>{t(Math.floor(Math.random()*sI.length))},2e3);return()=>clearInterval(e)},[]),K.createElement(re,{color:mr.YELLOW},sI[e],"...")},"PulsingText");Ft(),Or();var lI=[Ie.bullet,Ie.squareSmallFilled,Ie.lozenge,Ie.star,Ie.triangleRight,Ie.triangleUp,Ie.circleFilled,Ie.pointer],cI=__name(e=>String(e).padStart(3," "),"padNum"),uI=__name(e=>lI[e%lI.length],"getSymbol"),dI=__name((e,t,n,r)=>r?`${e} observations (↑↓ scroll)`:`↑${cI(t)} ↓${cI(n)} (↑↓ scroll)`,"buildStatusLine"),mI=__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:mr.DIM},dI(s,u,d,r)),l.map((e,n)=>{const r=t+n;return K.createElement(ne,{key:r,marginBottom:0},K.createElement(re,{color:mr.DIM},uI(r)," ",e))}))},"ScrollableInsights");Ft(),Or();var pI=__name(()=>{const[e,t]=J(!0);return Z(()=>{const e=setInterval(()=>{t(e=>!e)},500);return()=>clearInterval(e)},[]),K.createElement(re,{color:mr.YELLOW},e?Ie.circleFilled:Ie.circle)},"PulsingDot"),gI=__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(oI,null),K.createElement(ne,{marginTop:0},K.createElement(re,{color:mr.DIM},iI),K.createElement(ne,{marginLeft:2},a?K.createElement(re,{color:gr.TEXT},"learned your coding taste"):K.createElement(aI,null))));const u=__name(()=>r?K.createElement(re,{color:wr.BG},Ie.square):n?K.createElement(pI,null):K.createElement(re,{color:mr.DIM},Ie.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?mr.WHITE:n?mr.YELLOW:mr.DIM},e)),r&&t&&(!l||0===l.learningCount)&&K.createElement(ne,{marginLeft:3,marginBottom:0},K.createElement(re,{color:mr.DIM},t)),o.length>0&&K.createElement(ne,{flexDirection:"column",marginLeft:1,marginBottom:0},o.map((e,t)=>K.createElement(re,{key:t,color:mr.DIM},`${Ie.bullet} ${e}`))),s.length>0&&K.createElement(mI,{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,iI),K.createElement(ne,{marginLeft:2},K.createElement(re,{color:gr.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:mr.DIM},Ie.pointerSmall," Stored in ",l.storage),K.createElement(re,{color:mr.DIM},"Command Code automatically uses & updates taste files.")))):null},"StepItem"),hI=__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(gI,{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"),fI=__name(({steps:e})=>K.createElement(hI,{steps:e}),"ProgressSection");Ft(),Or();var yI=__name(({isImporting:e=!1,waitingForInput:t=!1})=>K.createElement(K.Fragment,null,e&&K.createElement(ne,{marginTop:1},K.createElement(re,{color:mr.DIM},"ESC to cancel")),t&&K.createElement(ne,{marginTop:1},K.createElement(re,{bold:!0},"Press ENTER to continue"))),"HelpTextSection");Ft();var wI=[{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"}}],SI=__name(({onComplete:e,onError:t,onErrorDismiss:n})=>{const{steps:r,importError:o}=GP(wI),{isImporting:s,waitingForInput:i,error:a}=KP(t);return YP({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(rI,{error:o}),!o&&K.createElement(fI,{steps:r}),K.createElement(yI,{isImporting:s,waitingForInput:i}))},"ImportProgress"),bI=__name(({step:e,conditions:t,onImportStart:n,onImportComplete:r,onImportError:o,onErrorDismiss:s,onSkip:i})=>"asking"===e?t&&"has_sessions"===t.reason?K.createElement(nI,{sessionCount:t.sessionCount,agentSessions:t.agentSessions,onImport:n,onSkip:i}):null:"learning"===e?K.createElement(SI,{onComplete:r,onError:o,onErrorDismiss:s}):null,"OnboardingStepRenderer"),EI=__name(({onComplete:e,autoLearn:t=!1})=>{Z(()=>(dlog("[UI:Onboarding] mounted"),()=>{dlog("[UI:Onboarding] unmounted")}),[]);const{conditions:n,error:r,isLoading:o}=JP({autoLearn:t,onShouldSkip:e}),{step:s,setStep:i}=ZP({conditions:n,autoLearn:t}),{handleImportStart:a,handleImportComplete:l,handleImportError:u,handleErrorDismiss:d,handleSkip:m}=XP({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(eI,{error:r}):"done"===s?null:K.createElement(bI,{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 vI=Y(__name(function MainView2({feed:e,liveEntries:t,queuedMessages:n,isCmdCodeBusy:r,staticKey:o,setStaticKey:s,transcriptMode:i,tasteOnboardingEntryId:a,autoLearnTaste:l,showTasteSkipBanner:u,retryAttempt:d,input:m,setInput:g,fileSearchQuery:h,setFileSearchQuery:f,showFileList:y,setShowFileList:w,showProviderSelector:S,showModelSelector:E,showEffortSelector:v,showMemorySelector:C,showMcpManager:k,showAgentsConfig:T,showRewindSelector:_,showLoginOverlay:x,showUsageOverlay:A,showAddDirModal:P,showCompactModeSelector:I,showConfigureModels:M,setShowConfigureModels:N,authComponentInfo:R,status:$,currentProvider:L,currentModel:D,showProviderNotification:O,shareInfo:F,showShareNotification:U,unshareNotificationMessage:j,updateStatus:q,updateFailedInfo:B,creditWarning:z,permissionMode:W,hintMessage:H,pendingExitKey:G,tasteLearningEnabled:V,interactionTokens:Q,contextUsage:Y,historyManagerRef:J,executionState:X,contextEngineRef:Z,onSubmit:oe,onCommand:se,onToggleAutoAccept:ie,onResetPendingExitKey:ae,onDoubleEscapeEmpty:le,onTasteOnboardingComplete:ce,permissionPanel:ue,questionPanel:de,designSuggestionPanel:me,onRewindSelect:pe,onRewindCancel:ge,onLoginComplete:he,onLoginCancel:fe,setShowProviderSelector:ye,setShowModelSelector:we,setShowEffortSelector:Se,setShowMemorySelector:be,setShowMcpManager:Ee,setShowAgentsConfig:ve,setShowAddDirModal:Ce,setShowUsageOverlay:ke,handleProviderSelect:Te,handleProviderCancel:_e,handleModelSelect:xe,handleModelCancel:Ae,handleCompactModeSelect:Pe,handleCompactModeCancel:Ie,handleAuthSuccess:Me,handleAuthCancel:Ne,showDesignGuide:Re,setShowDesignGuide:$e}){const Le=ee(()=>e.filter(e=>"taste-onboarding"!==e.role),[e]),De=te(()=>$e(!1),[$e]),Oe=useTerminalWidth(),Fe=ee(()=>"off"===i?Le:getBudgetedFeed(Le,"limited"===i?15e3:5e4),[Le,i]),Ue=ee(()=>"off"===i?0:Math.max(0,Le.length-Fe.length),[Le.length,Fe.length,i]),je=ee(()=>0===Ue?Fe:Fe.filter(e=>"user"!==e.role),[Fe,Ue]),qe=te(()=>ve(!1),[ve]),Be=te(()=>be(!1),[be]),ze=te(()=>Ee(!1),[Ee]),We=te(()=>Ce(!1),[Ce]),He=te(()=>we(!0),[we]),Ge=te(()=>Se(!1),[Se]),Ve=te(()=>{hardResetForResize(),s(e=>e+1)},[s]),Qe=!("off"!==i||ue||de||me||S||E||v||R||C||k||T||_||x||A||P||I||M||Re||a);return K.createElement(ne,{flexDirection:"column",width:"100%"},K.createElement(IP,{staticKey:o,feed:je,showHeader:!0,expandedToolOutput:"off"!==i,currentModel:D,currentProvider:L,hiddenCount:Ue}),a&&K.createElement(EI,{onComplete:ce,autoLearn:l}),u&&K.createElement(TasteSkipMessage,null),t.map(e=>e.metadata?.isAgent?K.createElement(NP,{key:e.id,entry:e}):K.createElement(ne,{key:e.id,marginBottom:1,width:"90%"},renderFeedEntry(e,"off"!==i))),K.createElement(RetryMessage,{attempt:d}),me,de,ue,"off"!==i&&K.createElement(ne,{flexDirection:"column",marginTop:1},K.createElement(ne,null,K.createElement(re,{color:mr.DIM},"─".repeat(Oe))),K.createElement(ne,{paddingRight:1},K.createElement(re,{backgroundColor:wr.BG,color:wr.FG,bold:!0},`${ZT}DETAILED TRANSCRIPT${ZT}`),K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{bold:!0},"ctrl+o"),K.createElement(re,{color:mr.DIM}," to toggle"),K.createElement(re,{color:mr.DIM}," · "),K.createElement(re,{bold:!0},"ctrl+e"),K.createElement(re,{color:mr.DIM}," ","to"," ","limited"===i?"show all":"collapse"))),Qe&&K.createElement(CP,{queuedMessages:n,isProcessing:r,executionState:X,status:$,input:m,setInput:g,onSubmit:oe,showFileList:y,setShowFileList:w,fileSearchQuery:h,setFileSearchQuery:f,onCommand:se,outputTokens:Q,contextUsage:Y,tasteLearning:V,shareInfo:F,showShareNotification:U,unshareNotificationMessage:j,updateStatus:q,updateFailedInfo:B,creditWarning:z,currentProvider:L,currentModel:D,showProviderInfo:O,permissionMode:W,onToggleAutoAccept:ie,hintMessage:H,historyManager:J.current,pendingExitKey:G,onResetPendingExitKey:ae,onDoubleEscapeEmpty:le,retryAttempt:d,onAltP:He}),S&&K.createElement(ne,{marginY:1},K.createElement(jP,{onSelect:Te,onCancel:_e,currentProvider:L})),E&&K.createElement(ne,{marginY:1},K.createElement(FP,{onSelect:xe,onCancel:Ae,currentModel:D,currentProvider:L,refreshBanner:Ve})),v&&K.createElement(ne,{marginY:1},K.createElement(UP,{currentModel:D,onClose:Ge,refreshBanner:Ve})),Re&&K.createElement(ne,{marginY:1},K.createElement(HP,{onCancel:De})),I&&K.createElement(ne,{marginY:1},K.createElement(GA,{onSelect:Pe,onCancel:Ie})),M&&K.createElement(ne,{marginY:1},K.createElement(YA,{onClose:()=>N(!1)})),T&&K.createElement(ne,{marginY:1},K.createElement(WA,{onCancel:qe})),C&&K.createElement(ne,{marginY:1},K.createElement(_P,{onClose:Be})),k&&K.createElement(ne,{marginY:1},K.createElement(TP,{onClose:ze})),_&&Z.current&&K.createElement(ne,{marginY:1},K.createElement(BP,{checkpoints:Z.current.listCheckpoints(),onSelect:pe,onCancel:ge})),R&&K.createElement(ne,{marginY:1},K.createElement(R.Component,{onSuccess:Me,onCancel:Ne})),x&&K.createElement(ne,{marginY:1},K.createElement(kP,{onComplete:he,onCancel:fe})),P&&K.createElement(ne,{marginY:1},K.createElement(AA,{onClose:We})))},"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:v,creditWarning:C,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(Ax,{staticKey:o.staticKey,onTrust:k,onExit:T});if(o.showSessionSelector)return K.createElement(Mx,{onSelectSession:g.onSelectSession,onNewSession:g.onNewSession});if(!s.projectTrusted)return null;const I=o.pendingDesignSuggestion?K.createElement(Tx,{suggestion:o.pendingDesignSuggestion,onSelect:e=>{f(`/design ${e}`)},onClose:()=>o.setPendingDesignSuggestion(null)}):null,M=a.pendingQuestion?K.createElement(QuestionView,{pendingQuestion:a.pendingQuestion,permissionMode:l.permissionMode,setPermissionMode:l.setPermissionMode,dangerouslySkipPermissions:l.dangerouslySkipPermissions,setPendingQuestion:a.setPendingQuestion,setStatus:n.setStatus,setStaticKey:o.setStaticKey}):null,N=a.pendingPermission?K.createElement(zx,{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(vI,{feed:e.feed,liveEntries:e.liveEntries,queuedMessages:e.queuedMessages,isCmdCodeBusy:e.isCmdCodeBusy,staticKey:o.staticKey,setStaticKey:o.setStaticKey,transcriptMode:o.transcriptMode,tasteOnboardingEntryId:s.tasteOnboardingEntryId,autoLearnTaste:s.autoLearnTaste,showTasteSkipBanner:o.showTasteSkipBanner,retryAttempt:n.retryAttempt,input:y,setInput:w,fileSearchQuery:S,setFileSearchQuery:E,showFileList:o.showFileList,setShowFileList:o.setShowFileList,showProviderSelector:o.showProviderSelector,showModelSelector:o.showModelSelector,showEffortSelector:o.showEffortSelector,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,showConfigureModels:o.showConfigureModels,setShowConfigureModels:o.setShowConfigureModels,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:v,creditWarning:C,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:M,designSuggestionPanel:I,onRewindSelect:g.onRewindSelect,onRewindCancel:g.onRewindCancel,onLoginComplete:g.onLoginComplete,onLoginCancel:g.onLoginCancel,setShowProviderSelector:o.setShowProviderSelector,setShowModelSelector:o.setShowModelSelector,setShowEffortSelector:o.setShowEffortSelector,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,showDesignGuide:o.showDesignGuide,setShowDesignGuide:o.setShowDesignGuide})}__name(renderView,"renderView");var CI=__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();Z(()=>{prefetchBillingContext()},[]);const[h,f]=J(""),[y,w]=J(""),S=X(!1),E=X(!1),v=X(null),C=X(null),k=useUiOverlays(),T=useFeed(),_=useSession(),x=useStatus(s),A=useAuth(),P=usePendingOps(),I=useOnboarding(),M=useExit(),{executeBash:N,executionState:R}=gT(),$=usePermissionMode({initialPermissionMode:u,dangerouslySkipPermissions:o,setPendingPermission:P.setPendingPermission,setStatus:x.setStatus,contextEngineRef:C}),{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:C}),{onCommand:D}=useCommandCtx({feedState:T,sessionState:_,statusState:x,authState:A,uiOverlays:k,onboarding:I,exitState:M,permissionState:$,contextEngineRef:C,isSubmittingRef:S,executeBash:N,createContextEngineCallbacks:L,setInput:f}),{loadTasteStatus:O,loadCurrentProvider:F,onSubmit:U}=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:C,isSubmittingRef:S,initialPromptSubmittedRef:E,historyManagerRef:v,executeBash:N,createContextEngineCallbacks:L,setInput:f,onCommand:D});useLifecycle({exit:m,feedState:T,exitState:M,statusState:x,authState:A,onboarding:I,uiOverlays:k,skipOnboarding:l,contextEngineRef:C,sessionTitleHolder:d});const{handleToggleAutoAccept:j,handleDoubleEscapeEmpty:q,handleTasteOnboardingComplete:B,handleTrust:z,handleNoTrust:W}=useHandlers({resume:e,feedState:T,onboarding:I,uiOverlays:k,exitState:M,pendingOps:P,permissionState:$,statusState:x,authState:A,contextEngineRef:C,loadTasteStatus:O,loadCurrentProvider:F,setInput:__name(e=>f(e),"setInput")}),H=useMainActionCallbacks({feedState:T,sessionState:_,statusState:x,authState:A,uiOverlays:k,permissionState:$,contextEngineRef:C,createContextEngineCallbacks:L,setInput:f}),{creditWarning:G}=useCreditWarning({interactionTokens:x.interactionTokens});return renderView({feedState:T,sessionState:_,statusState:x,authState:A,uiOverlays:k,onboarding:I,exitState:M,pendingOps:P,permissionState:$,contextEngineRef:C,historyManagerRef:v,executionState:R,actionCallbacks:H,onSubmit:U,onCommand:D,input:h,setInput:f,fileSearchQuery:y,setFileSearchQuery:w,updateFailedInfo:i,creditWarning:G,handleTrust:z,handleNoTrust:W,handleToggleAutoAccept:j,handleDoubleEscapeEmpty:q,handleTasteOnboardingComplete:B,loadTasteStatus:O})},"InteractiveCLI");Kr(),ZS(),dr(),Or();var kI=__name(e=>e.replace(/\x1B\[[0-9;]*[A-Za-z]/g,"").replace(/[\x00-\x1F\x7F]/g," ").trim(),"sanitizeTitleForOutput"),TI=ue.hex(mr.DIM),_I=__name(e=>{const t=getInvokedCommandName(),n=nt([e]);return`${TI("To continue this session, run:")}\n${TI(`${t} --resume ${n}`)}\n`},"formatResumeHint"),xI=__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"),AI=__name(e=>Boolean(e.resume||e.continue),"shouldValidateSessions"),PI=__name(({isInitialized:e,sessionCount:t})=>e&&0===t?{canProceed:!1,exitCode:0,message:"No conversations found to resume."}:{canProceed:!0},"validateSessionAvailability"),II=__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"),MI=__name(()=>({stdin:process.stdin,stdout:process.stdout,stderr:process.stderr,exitOnCtrlC:!1}),"getInkRenderOptions"),NI=__name(()=>{enableBracketedPasteMode(),process.on("exit",()=>{disableBracketedPasteMode()})},"setupBracketedPasteMode"),RI=__name(()=>{NI()},"initializeTerminal"),$I=__name(async(e={})=>{const t=xI(process.stdin.isTTY);let n;if(t.isValid||(console.error(t.errorMessage),process.exit(1)),RI(),"string"==typeof e.resume){const t=e.resume;await Rk.isProjectInitialized()||(console.error("Project not initialized. Run cmd to start a conversation first."),process.exit(1));const r=await Rk.findSessionByName(t);r||(console.error(`No session named "${t}" found.`),process.exit(1)),n=r.id}if(AI(e)&&!n){const e=await Rk.isProjectInitialized(),t=e?await Rk.listSessions():[],n=PI({isInitialized:e,sessionCount:t.length});n.canProceed||(console.log(n.message),process.exit(n.exitCode))}startEarlyInputCapture();const r={},o=II({options:e,resumeSessionId:n,sessionTitleHolder:r}),s=MI(),i=ae(K.createElement(CI,{...o}),s);registerInkControl({clear:i.clear,stdout:process.stdout,instance:await resolveInkInstance(process.stdout)}),await i.waitUntilExit();const a=await(r.loadTitle?.());if(a){const e=kI(a);e&&process.stdout.write(_I(e))}},"interactiveMode");Do(),Ft(),Cn(),FE(),CE();var LI=__name(async()=>{try{return await runLogin(),!!await getAuthKey()||(console.error(`${Ie.cross} Authentication failed. Please try again with: cmd login`),!1)}catch(e){return isUserCancellation(e)||(console.error(`${Ie.cross} Login failed: ${getErrorMessage2(e)}`),console.error("Please try again with: cmd login")),!1}},"attemptLogin");async function ensureAuthenticated(){try{return!!await getAuthKey()||LI()}catch(e){return console.error("Error checking authentication:",e),!1}}__name(ensureAuthenticated,"ensureAuthenticated"),so(),Ft(),Cn(),no();var DI={bold:__name((e,t)=>t?`[1m${e}[0m`:e,"bold"),dim:__name((e,t)=>t?`[2m${e}[0m`:e,"dim"),green:__name((e,t)=>t?`[32m${e}[0m`:e,"green")};function modelNameOf(e){const t=e.lastIndexOf("/");return(-1===t?e:e.slice(t+1)).toLowerCase()}function displayModelId(e){return e.replace(Vr,"")}function resolveModelFlag({model:e}){const t=resolveKnownModelId(e);if(t)return t;const n=modelNameOf(e),r=getAllModelOptions().filter(e=>modelNameOf(e.id)===n);return 1===r.length?r[0].id:void 0}function editDistance(e,t){const n=e.length+1,r=t.length+1;let o=Array.from({length:r},(e,t)=>t);for(let s=1;s<n;s++){const n=[s];for(let i=1;i<r;i++){const r=e[s-1]===t[i-1]?0:1;n[i]=Math.min(o[i]+1,n[i-1]+1,o[i-1]+r)}o=n}return o[r-1]}function suggestModel(e){const t=e.trim().toLowerCase();if(!t)return;let n;for(const e of getAllModelOptions()){const r=displayModelId(e.id),o=Math.min(editDistance(t,r.toLowerCase()),editDistance(t,modelNameOf(r)));(!n||o<n.distance)&&(n={id:r,distance:o})}if(!n)return;const r=Math.min(4,Math.ceil(t.length/3));return n.distance<=r?n.id:void 0}function formatModelList(e={}){const t=e.color??!1,n=getModelGroupsInOrder(),r=n.flatMap(e=>e.models),o=Math.max(...r.map(e=>displayModelId(e.id).length)),s=n.map(e=>{const n=e.models.map(e=>{const n=displayModelId(e.id).padEnd(o),r=DI.dim(e.description,t);return`${n} ${"free"===e.badge?`${DI.green("FREE",t)} `:""}${r}${e.id===pn?` ${DI.green("(default)",t)}`:""}`});return[DI.bold(e.label,t),"",...n].join("\n")});return[`${DI.bold("Available models",t)} ${DI.dim(`· ${r.length} models`,t)}`,"",s.join("\n\n"),"",DI.dim('Pass the full id, or just the short name after the last "/":',t),"cmd --model moonshotai/Kimi-K2.5","cmd --model kimi-k2.5","","Docs: https://commandcode.ai/docs/reference/cli/models"].join("\n")}function printModelList(){const e=Boolean(process.stdout.isTTY)&&void 0===process.env.NO_COLOR;process.stdout.write(`${formatModelList({color:e})}\n`)}function resolveModelFlagOrExit({model:e}){const t=resolveModelFlag({model:e});if(t)return t;const n=suggestModel(e),r=n?` Did you mean "${n}"?`:"";process.stderr.write(`Error: unknown model "${e}".${r}\nRun "cmd --list-models" to see all available models\n`),process.exit(1)}__name(modelNameOf,"modelNameOf"),__name(displayModelId,"displayModelId"),__name(resolveModelFlag,"resolveModelFlag"),__name(editDistance,"editDistance"),__name(suggestModel,"suggestModel"),__name(formatModelList,"formatModelList"),__name(printModelList,"printModelList"),__name(resolveModelFlagOrExit,"resolveModelFlagOrExit");var OI=__name(e=>e&&!e.startsWith("-")?e:void 0,"parsePrompt"),FI=__name(async()=>{await ensureAuthenticated()||process.exit(1)},"requireAuth"),UI=__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"),jI=__name(({options:e,runtimeOptions:t,initialPrompt:n})=>e.resume?{resume:e.resume,...t}:e.continue?{continue:!0,...t}:{...t,initialPrompt:n},"getInteractiveConfig"),qI=__name((e,t)=>"string"==typeof e.print&&e.print.trim()?e.print:t&&!t.startsWith("-")?t:"","extractPrintQuery");async function interactiveModeAction(e,t){if(t.listModels)return void printModelList();if(t.addDir&&t.addDir.length>0)for(const e of t.addDir)addDirectory(e);const n=t.model?resolveModelFlagOrExit({model:t.model}):void 0;if(void 0!==t.print){const r=qI(t,e);return void await printMode({query:r,dangerouslySkipPermissions:t.dangerouslySkipPermissions,maxTurns:t.maxTurns,verbose:t.verbose,model:n,benchmarkOutput:t.benchmarkOutput})}n&&setModelOverride(n);const r=OI(e);await FI();const o=UI(t),s=jI({options:t,runtimeOptions:o,initialPrompt:r});await $I(s)}__name(interactiveModeAction,"interactiveModeAction"),Ft(),er(),Ts(),so(),EE(),FE();var BI=new Set(["update"]),zI=__name(()=>process.argv.slice(2).find(e=>!e.startsWith("-")),"getInvokedCommand");globalThis.COMMAND_CODE_CWD=process.cwd();var WI=__name(()=>process.cwd(),"getCwd"),HI=__name(()=>process.argv.slice(2),"getArgs"),GI=__name(e=>e.includes("--local")?"local":e.includes("--staging")?"staging":"production","getEnv"),VI=__name(()=>{const e=WI(),t=HI(),n=GI(t);dlog(`[Startup] cwd: ${e}`),dlog(`[Startup] args: ${t.join(" ")}`),dlog(`[Startup] env: ${n}`),dlog(`[Startup] traceId: ${getTraceId()??"unavailable"}`)},"logStartupInfo");async function preRun(){if(VI(),process.argv.includes("--ide-setup")){const e=await runIDESetup();formatSetupResult(e).forEach(e=>console.log(e)),process.exit("failed"===e.status?1:0)}const e=BI.has(zI()??"");e||(notifyCompletedUpdate(),maybeRunPendingUpdate()),await migrateDeprecatedModel(),await getAuthKey()&&detectAndTrackFirstInstall().catch(()=>{}),e||checkForUpdateAsync(),setTimeout(()=>ensureExtensionInstalled().catch(()=>{}),100).unref()}__name(preRun,"preRun"),Ft(),Cn(),er(),Io(),ZS(),fo();var QI=getPackageJson(),KI=__name((e,t=[])=>[...t,e],"collectAddDir");function displayCustomHelp(){const e=QI.version,t=getInvokedCommandName(),n=Ek.filter(e=>!("/provider"===e.key&&!isInternalTeamFlagEnforced()));console.log(),console.log(ue.bold("Command Code")+ue.gray(` v${e}`)),console.log(ue.gray(fk)),console.log(),console.log(ue.bold("Usage")),console.log(` ${t} <command> [options]`),console.log(),console.log(ue.bold("Options"));for(const e of bk){const n=e.key.replace(/^cmd/,t);console.log(" "+n.padEnd(yk)+ue.gray(e.description))}console.log(),console.log(ue.bold("Commands"));for(const e of vk){const n=e.key.replace(/^cmd/,t);console.log(" "+n.padEnd(yk)+ue.gray(e.description))}console.log(),console.log(ue.bold("Slash Commands"));for(const e of n)console.log(" "+e.key.padEnd(yk)+ue.gray(e.description));console.log(),console.log(ue.bold("Keyboard Shortcuts"));for(const e of Sk)console.log(" "+e.key.padEnd(yk)+ue.gray(e.description));console.log(),console.log(ue.bold("Examples"));for(const e of kk){const n=e.key.replace(/^cmd/,t);console.log(" "+n.padEnd(yk)+ue.gray(e.description))}console.log(),console.log(ue.cyan("❯")+" "+ue.gray(Tk.replace(/cmd/,t))),console.log(),console.log(ue.bold("Links"));for(const e of Ck)console.log(" "+e.key.padEnd(yk)+ue.cyan(e.description));console.log()}function createProgram(){const e=new Me;return e.name(getInvokedCommandName()).description("Command Code with your coding taste.").version(QI.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 Ne("--dangerously-skip-permissions","Bypass all permission prompts (use with caution)").hideHelp()).addOption(new Ne("--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 Ne("--auto-accept","Start in auto-accept mode").implies({permissionMode:"auto-accept"})).addOption(new Ne("--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",wk).option("--add-dir <directory>","Add directory to workspace context",KI,[]).option("-m, --model <model>","Run on a specific model this session (e.g. claude-sonnet-4-6, kimi-k2.5). Unknown ids are rejected; see --list-models.").option("--list-models","List the models available for use").addOption(new Ne("--benchmark-output <path>","Path to write benchmark metrics JSON").hideHelp()).addOption(new Ne("--experimental","Enable experimental features").hideHelp()).addOption(new Ne(jt).hideHelp()).addOption(new Ne(qt).hideHelp()).addOption(new Ne("-d, --debug","Enable debug mode").hideHelp()).addOption(new Ne("--local","Use local server").hideHelp()).addOption(new Ne("--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"),Ft(),Ts(),Ho(),eE(),BE(),pE(),Io(),FE(),Ft(),__name(isTTY,"isTTY");var YI=!1;function setupTelemetry(){initTelemetry()&&(startSession(),registerStartupTask(trackSystemInfo()),trackCliSessionExistsEvent(),registerCleanupHandlers())}async function trackSystemInfo(){try{const e=w.platform(),t=w.arch();let n,r,o,s;try{const e=await getAuthenticatedEntity();e.success&&(n=e.user?.userName,r=e.user?.id,o=e.org?.login,s=e.org?.id)}catch{}if(!r)try{const e=await loadCredentials();r=e?.userId}catch{}systemInfo({userName:n,userId:r,orgLogin:o,orgId:s,platform:e,arch:t})}catch{}}function registerCleanupHandlers(){process.on("beforeExit",async()=>{await shutdownTelemetry()}),process.on("exit",()=>{shutdownTelemetrySync()}),process.on("SIGINT",handleShutdownSignal),process.on("SIGTERM",handleShutdownSignal)}function handleShutdownSignal(){YI||(YI=!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=w.platform(),r=w.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=Re("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"),FE(),Ft(),mo(),__name(openGitHubIssue,"openGitHubIssue");var JI=new Me("feedback").description("Open GitHub issues to share feedback or report bugs").argument("[title]","Optional issue title").action(openGitHubIssue);Ft();var XI=new Me("help").description("Display help information").allowUnknownOption().allowExcessArguments().action(function(){this.parent?.help()});async function runInfo(e){const t=getSystemInfo(),{waitUntilExit:n}=ae(K.createElement(I_,{verbose:e.verbose,text:e.text,systemInfo:t}));await n()}Ft(),Ft(),__name(runInfo,"runInfo");var ZI=new Me("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(SI,{onComplete:__name(()=>{e(),process.exit(0)},"onComplete"),onErrorDismiss:__name(()=>{e(),process.exit(1)},"onErrorDismiss")}))}Ft(),Cn(),Ft(),__name(runLearnTaste,"runLearnTaste"),er(),Ts();var eM=new Me(rn.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:ws.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 Me("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 Ne("-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.")),isSecureOrLoopback(t)||(console.error(ue.red(`Error: Server '${e}' requires OAuth, but URL '${t}' is not secure.`)),console.error(ue.gray("OAuth requires https:// (http:// is only allowed for loopback hosts: localhost, 127.0.0.1, [::1]).")),console.error(ue.gray("Switch the URL to https:// or use a non-OAuth server.")),process.exit(1));let n,o="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:${JS}/callback`]});e&&(o=e.clientId,n=e.clientSecret)}s.oauth={authorizationUrl:r.metadata.authorizationEndpoint,tokenUrl:r.metadata.tokenEndpoint,clientId:o,clientSecret:n,scopes:r.metadata.scopes},console.log(ue.gray("A browser window will open for authentication.\n"));const a=await performOAuthFlow(e,t,{authorizationUrl:r.metadata.authorizationEndpoint,tokenUrl:r.metadata.tokenEndpoint,clientId:o,clientSecret:n,scopes:r.metadata.scopes},{onStatus:__name(e=>{console.log(ue.gray(` ${e}`))},"onStatus")});a.success?console.log(ue.green("✓ Successfully authenticated")):(i=!0,console.log(ue.yellow(`Warning: Authentication failed: ${a.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);looksLikeHttpUrl2(a)&&(console.error(ue.red(`Error: '${a}' looks like a URL, not a local command.`)),console.error(ue.gray(`Did you mean: cmd mcp add --transport http ${e} ${a}`)),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 looksLikeHttpUrl2(e){try{const t=new URL(e);return"http:"===t.protocol||"https:"===t.protocol}catch{return!1}}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 Me("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(Ie.tick):ue.red(Ie.cross):o.config.headers||o.config.env?ue.green(Ie.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 Me("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 Me("remove");return e.description("Remove an MCP server").argument("<name>","Server name").addOption(new Ne("-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 Me("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 Ne("-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?.oauth?.callbackPort&&(s=o.oauth.callbackPort,delete o.oauth.callbackPort),n.clientSecret&&o?.oauth&&(o.oauth.clientSecret=n.clientSecret);const i=US.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,a.url??"",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 Me("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)),console.log(ue.cyan(`Authenticating with '${e}'...`)),console.log(ue.gray("A browser window will open for authentication.\n"));const o=__name(e=>{console.log(ue.gray(` ${e}`))},"onStatus");let s;if(r.config.oauth){const t={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};s=await performOAuthFlow(e,r.config.url??"",t,{onStatus:o})}else"http"===r.config.transport&&r.config.url||(console.error(ue.red("Error: Discovery-based auth requires an http server with a url")),process.exit(1)),s=await discoverAndAuthenticate({serverName:e,serverUrl:r.config.url,onStatus:o});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 Me("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=ve(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 C.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 C.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 C.mkdtemp(e.join(w.tmpdir(),"taste-learn-"));try{await runCommand({cmd:"git",args:["clone","--depth",s,"--single-branch",...t.branch?["--branch",t.branch]:[],"--",i,a]})}catch{throw await C.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 C.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 Xw({baseUrl:r}),s=new MT({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:`${truncate3(t.removed,60)} → ${truncate3(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}Ft(),Ft(),ZS(),__name(addMcpCommand,"addMcpCommand"),__name(looksLikeHttpUrl2,"looksLikeHttpUrl"),__name(collectKeyValue,"collectKeyValue"),__name(collectHeaders,"collectHeaders"),Ft(),__name(listMcpCommand,"listMcpCommand"),Ft(),__name(getMcpCommand,"getMcpCommand"),Ft(),__name(removeMcpCommand,"removeMcpCommand"),Ft(),ZS(),__name(addJsonMcpCommand,"addJsonMcpCommand"),Ft(),ZS(),__name(authMcpCommand,"authMcpCommand"),__name(createMcpCommand,"createMcpCommand"),Ft(),Cn(),Ft(),qE(),Ft(),Cn(),Ft(),__name(runCommand,"runCommand"),Ft(),__name(detectDefaultBranch,"detectDefaultBranch"),__name(findGitRoot4,"findGitRoot"),__name(countLearnings,"countLearnings"),__name(resolveSource,"resolveSource"),__name(getTastePathForDir,"getTastePathForDir"),__name(resolveDisplayName,"resolveDisplayName"),__name(parseGitHubSource,"parseGitHubSource"),__name(inferGitHubRepo,"inferGitHubRepo"),Ft(),yS(),IS(),so(),yo(),__name(feedToLearningAgent,"feedToLearningAgent"),__name(logLearnSummary,"logLearnSummary"),Ft(),Ft(),__name(shouldContinueExtraction,"shouldContinueExtraction"),__name(extractAllSignals,"extractAllSignals"),__name(collectCommits,"collectCommits"),__name(getSubstitutions,"getSubstitutions"),__name(groupCrossFilePatterns,"groupCrossFilePatterns");var tM=5,nM=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>nM?(i=s.slice(0,nM-1),a=s.length-i.length):i=s;const l=i.length+(a>0?1:0),u=Math.max(0,tM-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 rM=[/package-lock\.json$/,/pnpm-lock\.yaml$/,/yarn\.lock$/,/CHANGELOG\.(md|yml|yaml)$/i,/\.versionbot\//,/\.min\.(js|css)$/,/dist\//,/\.map$/];function isNoiseFile(e){return rM.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 oM=new Set(["renovate[bot]","renovate","dependabot[bot]","dependabot","greenkeeper[bot]","snyk-bot"]),sM=[/^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!!oM.has(n)||!(!n.includes("[bot]")||!sM.some(e=>e.test(t)))}function truncate3(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){xT.addEvent({type:"auth_required",step:"auth",message:"Login to synthesize your taste profile",label:"Signing in"});try{await xT.waitForAuth()}catch{return xT.emitStepStart({step:"complete",label:"Login skipped",message:"Login skipped",learningCount:0,storage:""}),xT.markLearningComplete(),{summary:n()}}}t.isLocalSource||xT.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&&xT.emitStepStart({step:"collecting",label:"Collecting commits",message:`Cloned ${r.displayName} → ${a}`});const l=t.branch??await detectDefaultBranch({repoDir:i});await C.mkdir(a,{recursive:!0}),xT.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=>{xT.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.");xT.emitStepStart({step:"extracting",label:"Extracting taste signals",message:`${u.length} before/after code changes extracted`}),xT.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};xT.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 xT.emitStepStart({step:"complete",label:"Taste learned",message:"Taste learned",learningCount:f,storage:h}),xT.markLearningComplete(),{summary:{outputDir:a,tasteDir:g,sourceName:r.displayName,signalCount:u.length,contextLength:m.length},resolved:r}}__name(isDependencyBot,"isDependencyBot"),__name(truncate3,"truncate"),__name(runBounded,"runBounded"),Ft(),__name(compileTasteContext,"compileTasteContext"),__name(runLearnPipeline,"runLearnPipeline"),Ft(),Ft(),Ft();var iM=[/MallocStackLogging: can't turn off malloc stack logging because it was not enabled/i];function shouldIgnoreChunk(e){return iM.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"),Ft(),fs(),__name(toRepoLearnErrorMessage,"toRepoLearnErrorMessage"),__name(isRepoLearnMetricLikeText,"isRepoLearnMetricLikeText"),__name(truncateRepoLearnPanelText,"truncateRepoLearnPanelText"),Ft(),Ft();var aM=[{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"}],lM=[{id:"cloning",label:"Cloning repository"},...aM],cM=[Ie.bullet,Ie.squareSmallFilled,Ie.lozenge,Ie.star,Ie.triangleRight,Ie.triangleUp];function createInitialRepoLearnSteps(e){return(e??aM).map(e=>({...e,status:"pending"}))}__name(createInitialRepoLearnSteps,"createInitialRepoLearnSteps"),Ft();var uM={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 dM=__name(e=>e.map(e=>({...e,status:"complete"})),"markAllStepsComplete"),mM=__name(e=>e??uM,"withBase");function useRepoLearnState(e){const t=e??aM,[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),[v,C]=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,C(null),m(!1)},"handleReset"),n=__name(e=>{if("error"===e.type)return y(e.message),h(!0),r(dM),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=mM(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=mM(t);return{...n,topLearnings:[...n.topLearnings,e.message].slice(0,3)}}))):s(e.message):u(t=>{const n=mM(t),r=parseSummaryMetric(e.message);return r?{...n,...r}:n})}else m(!0)},"handleEvent"),o=__name(()=>{h(e=>e||(r(dM),!0)),s(""),E.current&&C(Math.round((Date.now()-E.current)/1e3))},"handleComplete");return xT.on("reset",e),xT.on("new-event",n),xT.on("learning-complete",o),()=>{xT.off("reset",e),xT.off("new-event",n),xT.off("learning-complete",o)}},[t]),{steps:n,currentMessage:o,insights:i,insightCount:w,summary:l,done:g,error:f,showLogin:d,setShowLogin:m,elapsedSeconds:v,markStarted:k}}__name(useRepoLearnState,"useRepoLearnState"),Ft(),Ft(),Or();var pM=__name(({isComplete:e,hasError:t})=>K.createElement(ne,{flexDirection:"column",marginTop:1,marginBottom:0},K.createElement(oI,null),K.createElement(ne,{marginTop:0},K.createElement(re,{color:mr.DIM},iI),K.createElement(ne,{marginLeft:2},t?K.createElement(re,{color:mr.DIM},"learning interrupted"):e?K.createElement(re,{color:gr.TEXT},"learned your coding taste"):K.createElement(aI,null)))),"RepoLearnTastePill");Ft(),Or();var gM=__name(({status:e})=>"active"===e?K.createElement(ne,null,K.createElement(re,{color:mr.YELLOW},K.createElement(Be,{type:"dots"})),K.createElement(re,null," ")):"complete"===e?K.createElement(re,{color:wr.BG},Ie.square," "):K.createElement(re,{color:mr.DIM},Ie.circle," "),"StepStatusIndicator"),hM=__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(gM,{status:e.status})),K.createElement(re,{bold:n,color:"complete"===e.status?mr.WHITE:n?mr.YELLOW:mr.DIM},e.label)),n&&t?K.createElement(ne,{marginLeft:3},K.createElement(re,{color:mr.DIM},truncateRepoLearnPanelText(t))):null)})),"RepoLearnStepList");Ft(),Or();var fM=__name(({insights:e,insightCount:t})=>0===e.length?null:K.createElement(ne,{flexDirection:"column",marginTop:1,marginLeft:4},K.createElement(re,{color:mr.CYAN},t>0?`Recent signals · ${t} ${1===t?"preference":"preferences"} learned`:"Recent signals"),e.map((e,t)=>K.createElement(re,{key:`${t}-${e}`,color:mr.DIM},cM[t%cM.length]," ",truncateRepoLearnPanelText(e,14)))),"RepoLearnRollingInsights");Ft(),Or();var yM=__name(({message:e})=>K.createElement(ne,{flexDirection:"column",borderStyle:"single",borderColor:mr.RED,paddingX:2,paddingY:1,marginTop:1},K.createElement(re,{color:mr.RED,bold:!0},"Oops, something went wrong:"),K.createElement(ne,{marginTop:1},K.createElement(re,null,e))),"RepoLearnErrorPanel");Ft(),Or(),io();var wM=__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:mr.DIM},iI),K.createElement(ne,{marginLeft:2},K.createElement(re,{color:gr.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:mr.DIM},Ie.pointerSmall," Taste stored in"," "),K.createElement(ro,{url:`file://${e.storage}`,text:r||".commandcode/taste/taste.md",color:mr.CYAN})),K.createElement(ne,null,K.createElement(re,{color:mr.DIM},Ie.pointerSmall," Share your coding taste:"," ",K.createElement(re,{color:mr.CYAN},"npx taste push --all")))),K.createElement(ne,{marginTop:1,marginLeft:1},K.createElement(re,{color:mr.DIM},o?"Command Code automatically uses & updates taste files as you code.":"Command Code will learn your preferences as you code.")))},"RepoLearnCompletionSummary");Ft(),Or();var SM=__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:mr.DIM},"ESC to cancel")),"RepoLearnFooter");Ft(),Or();var bM=__name(({text:e,repoName:t})=>{const n=useTerminalWidth(),r=ee(()=>Yx(n),[n]);return K.createElement(ne,{flexDirection:"column"},K.createElement(ne,{flexDirection:"column",marginBottom:1},K.createElement(nA,null,r.trimEnd())),e?K.createElement(re,{color:mr.WHITE},e):K.createElement(K.Fragment,null,K.createElement(re,{color:mr.WHITE},"Learning your coding taste from"," ",K.createElement(re,{bold:!0,color:mr.CYAN},t??"repository")),K.createElement(re,{color:mr.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(yM,{message:e}):t?K.createElement(wM,{summary:n,elapsedSeconds:r}):K.createElement(fM,{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(bM,{text:r,repoName:o}),K.createElement(kP,{onComplete:(e,t)=>{s.setShowLogin(!1),e?xT.resolveAuth():xT.rejectAuth(t)},onCancel:()=>{s.setShowLogin(!1),xT.rejectAuth("Login cancelled"),t({published:!1,cancelled:!0})}})):K.createElement(ne,{flexDirection:"column"},K.createElement(bM,{text:r,repoName:o}),K.createElement(pM,{isComplete:s.done&&!s.error,hasError:Boolean(s.error)}),K.createElement(hM,{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(SM,{done:s.done,error:s.error}))}async function runRepoLearnProgress(e){return withFilteredStderrNoise(()=>renderProgressUI(e))}function renderProgressUI(e){return new Promise((t,n)=>{xT.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,xT.addEvent({type:"error",message:toRepoLearnErrorMessage(e)}),xT.markLearningComplete())}},"handleRunTask"),u=__name(({published:e,cancelled:l})=>{a||(a=!0,i=e,r.abort(),d.unmount(),xT.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=>{xT.reset(),n(e)})})}__name(StatusPanel,"StatusPanel"),__name(RepoLearnProgressApp,"RepoLearnProgressApp"),__name(runRepoLearnProgress,"runRepoLearnProgress"),__name(renderProgressUI,"renderProgressUI"),FE();var EM=__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 Me("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",EM("--max-commits"),200).addOption(new Ne("--max-signals <number>","Maximum diff signals to extract").default(50).argParser(EM("--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 C.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:[...lM];({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),UE(),await $I({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(w.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"),Ft(),Ft(),Ft(),Cn(),__name(getTastePath,"getTastePath"),__name(getRootTasteFile,"getRootTasteFile"),__name(getCategoryPath,"getCategoryPath"),__name(getCategoryTasteFile,"getCategoryTasteFile"),Ft(),Ft();var vM=/confidence:/i;function findLookaheadEnd(e,t){const n=e.slice(t),r=n.findIndex(e=>{const t=e.trim();return t.startsWith("#")||t.startsWith("-")||vM.test(t)});if(-1===r)return{endIdx:e.length,inclusive:!1};const o=n[r].trim();return{endIdx:t+r,inclusive:vM.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(vM.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(!vM.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:`${Ie.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?Ie.cross:Ie.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"),Ft(),__name(formatSingleIssue,"formatSingleIssue"),__name(formatIssueGroup,"formatIssueGroup"),__name(formatValidationIssues,"formatValidationIssues");var CM=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;CM.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 kM=/^see \[[^\]]+\/taste\.md\]\([^\)]+\/taste\.md\)$/i,TM=/^\[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}):kM.test(s)||TM.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 _M=__name(e=>"local-global"===e?"global":"project","locationLabel"),xM=__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 O(n)?{result:{path:n,displayName:`${e}/taste.md`}}:{error:{file:e,error:`Taste package '${e}' not found in ${_M(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});O(o)&&r.push({path:o,displayName:"taste.md"});const s=(await C.readdir(t,{withFileTypes:!0})).filter(e=>e.isDirectory()).map(e=>({entry:e,categoryFile:getCategoryTasteFile({target:n,category:e.name})})).filter(({categoryFile:e})=>O(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 C.readFile(e.path,"utf-8");const n=migrateHeader({content:t});n!==t&&(await C.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 xM({file:"all",error:`No taste files found in ${_M(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 xM({file:"all",error:`No taste files found in ${_M(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 O(r)?t.length>0?lintSpecificPackages({packages:t,target:n}):lintAllFiles({tastePath:r,target:n}):xM({file:"all",error:`No taste directory found in ${_M(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"),Ft(),Ts(),__name(resolveConflictStrategy,"resolveConflictStrategy");var AM=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 PM=__name((e,t)=>t,"linkFallback");function getPackageLink({owner:e,packageName:t}){return bt(`commandcode.ai/${e}/${t}`,`https://commandcode.ai/${e}/${t}`,{fallback:PM})}function getProfileLink(e){return bt(`commandcode.ai/${e}`,`https://commandcode.ai/${e}`,{fallback:PM})}function wrapLine(e,t=0){const n=(process.stdout.columns||80)-t;return St(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 Me("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(Ie.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 C.readFile(t,"utf-8"),r=migrateHeader({content:n});return r===n?n:(await C.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 ov+"\n\n";const t=e.trim();return t.startsWith(nv)||t.startsWith(sv)||t.startsWith(iv)?e:ov+"\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"),Ft(),qs(),Ft(),Ft(),Ft(),__name(parseSection,"parseSection"),__name(parsePackages,"parsePackages"),__name(parseLearning,"parseLearning"),__name(normalizeCategory,"normalizeCategory"),__name(denormalizeCategory,"denormalizeCategory"),Ft(),__name(formatPackage,"formatPackage"),Ft(),__name(readAndMigrateFile,"readAndMigrateFile"),__name(trimTrailingBlanks,"trimTrailingBlanks"),__name(findCategoryRange,"findCategoryRange"),__name(ensureHeader,"ensureHeader"),__name(ensureTrailingNewlines,"ensureTrailingNewlines");var IM="local-global";async function loadCategoryPackages(e){if(!e.isDirectory())return[];const t=getCategoryTasteFile({target:IM,category:e.name});return O(t)?parsePackages({content:await readAndMigrateFile({filePath:t}),sourcePath:t}).map(t=>({...t,category:e.name})):[]}async function getPackageInfo(e){try{const t=await C.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:IM});if(!O(e))return[];const t=await C.readdir(e,{withFileTypes:!0});return(await Promise.all(t.map(loadCategoryPackages))).flat()}async function getPackage(e){const{category:t}=e,n=getCategoryTasteFile({target:IM,category:t});return O(n)&&parsePackages({content:await readAndMigrateFile({filePath:n}),sourcePath:n})[0]||null}async function writePackage(t){const{pkg:n}=t,r=getTastePath({target:IM});await C.mkdir(r,{recursive:!0});const o=getCategoryTasteFile({target:IM,category:n.category}),s=e.dirname(o);await C.mkdir(s,{recursive:!0});const i=formatPackage({pkg:n});await C.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"),Ft(),Ft();var MM="local-project";async function removeCategoryFromRoot(e){const{category:t,rootFile:n}=e;if(!O(n))return null;const r=migrateHeader({content:await C.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 C.rm(n,{force:!0}),""!==l&&await C.writeFile(n,l+"\n","utf-8"),a}async function removePackage(t){const{category:n}=t,r=getRootTasteFile({target:MM}),o=await removeCategoryFromRoot({category:n,rootFile:r}),s=getCategoryTasteFile({target:MM,category:n}),i=e.dirname(s);return O(i)&&await C.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 C.writeFile(n,e.trim()+"\n","utf-8")}let s="";O(n)&&(s=await C.readFile(n,"utf-8"),s=migrateHeader({content:s})),s=ensureHeader(s),s=ensureTrailingNewlines(s),s+=o,await C.writeFile(n,s.trim()+"\n","utf-8")}async function writeToSubdirectory(t){const{pkg:n,rootFile:r,categoryPosition:o}=t,s=getCategoryTasteFile({target:MM,category:n.category}),i=e.dirname(s);await C.mkdir(i,{recursive:!0});const a=formatPackage({pkg:n});await C.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 C.writeFile(r,e.trim()+"\n","utf-8")}let u="";O(r)&&(u=await C.readFile(r,"utf-8"),u=migrateHeader({content:u})),u=ensureHeader(u),u=ensureTrailingNewlines(u),u+=l,await C.writeFile(r,u.trim()+"\n","utf-8")}__name(removeCategoryFromRoot,"removeCategoryFromRoot"),__name(removePackage,"removePackage"),__name(writeToRoot,"writeToRoot"),__name(writeToSubdirectory,"writeToSubdirectory");var NM="local-project";async function loadCategoryPackages2(e){if(!e.isDirectory())return[];const t=getCategoryTasteFile({target:NM,category:e.name});return O(t)?parsePackages({content:await readAndMigrateFile({filePath:t}),sourcePath:t}).map(t=>({...t,category:e.name})):[]}async function getAllPackages2(){const e=getTastePath({target:NM});if(!O(e))return[];const t=[],n=getRootTasteFile({target:NM});if(O(n)){const e=parsePackages({content:await readAndMigrateFile({filePath:n}),sourcePath:n});t.push(...e)}const r=await C.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:NM});await C.mkdir(n,{recursive:!0});const r=getRootTasteFile({target:NM}),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:NM});return O(e)}async function appendCategoryFile(e,t){const n=getCategoryTasteFile({target:"local-project",category:t.category});if(!O(n))return;const r=await C.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(!O(h))return l;const f=getCategoryTasteFile({target:"local-project",category:r.category});if(!O(f))return l;const y=await C.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(O(a)){const e=await C.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:ws.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}${zt.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}${zt.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:ws.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()}${zt.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:ws.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()}${zt.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()}${zt.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()}${zt.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 C.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 Me("list").alias("ls").option("-g, --global","List global packages").addOption(new Ne("-l, --local","Use local server").hideHelp()).option("--remote","List remote packages").addOption(new Ne("--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"),Ft(),IS(),Ft(),__name(appendCategoryFile,"appendCategoryFile"),__name(prepareUploadFormData,"prepareUploadFormData"),__name(prepareMultiplePackagesUpload,"prepareMultiplePackagesUpload"),Cn(),Ft(),__name(parseLearningLine,"parseLearningLine"),__name(parseTasteContent,"parseTasteContent"),BE(),Ts(),Ft(),FE(),Ts(),__name(parseApiError,"parseApiError"),__name(throwTrackedError,"throwTrackedError"),__name(requireAuthKey,"requireAuthKey"),Ft(),IS(),FE(),Cn(),__name(downloadPackage,"downloadPackage"),__name(tryPublicDownload,"tryPublicDownload"),__name(tryAuthenticatedDownload,"tryAuthenticatedDownload"),er(),__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 RM={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?RM.remote:e.global?RM.global:RM.project}function getPackageDisplayLength(e){let t=e.category.length;return e.isPublic&&(t+=9),e.isPublic&&e.starCount&&(t+=` ${Ie.star}${e.starCount}`.length),e.downloadCount&&(t+=` ${Ie.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(` ${Ie.star}${e.starCount}`):""}${e.downloadCount?ue.gray(` ${Ie.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?Re(`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${AM} 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 C.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 wt([{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"),Ft(),Ft(),__name(fetchAllPackages,"fetchAllPackages"),__name(handleOpenError,"handleOpenError"),__name(readCategoryLineNumber,"readCategoryLineNumber"),__name(findCategoryLineNumber,"findCategoryLineNumber"),__name(openPackage,"openPackage");var $M=new Set(["local-project","local-global","remote-project","remote-user"]);async function open11(e){const{package:t,target:n}=e;if(!$M.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=Et.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 Me("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(Ie.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(Ie.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"),Ft(),Ft(),Ft(),Ft();var LM=null,DM=!1;function setActiveSpinner(e){LM=e}function stopActiveSpinner(e){LM&&(LM.stop(e),LM=null)}function setPrompted(e){DM=e}function wasPrompted(){return DM}function beginPrompt(e,t){stopActiveSpinner(),ze.intro(ue.dim(e)),t&&ze.log.message(ue.dim(t)),setPrompted(!0)}function handleCancel(e){ze.isCancel(e)&&(ze.cancel("Operation cancelled"),process.exit(0))}function startStrategySpinner(e){if("skip"===e){const e=ze.spinner();return e.start("Skipping"),void e.stop("Skipped")}const t="merge"===e?"Merging":"Overwriting",n="merge"===e?"Merged":"Overwritten",r=ze.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),ze.log.warn("Non-interactive terminal detected, using default merge strategy"),"merge";beginPrompt(`Pulling ${ue.green(`'${t}'`)} from ${n}`,s),ze.log.message(`Local: ${r.learnings.length} learnings\nRemote: ${o} learnings ${ue.dim(`(from ${n})`)}`);const i=await ze.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),ze.log.warn("Non-interactive terminal detected, using default merge strategy"),"merge";beginPrompt(`Pushing ${ue.green(`'${t}'`)} to global`,o),ze.log.message(`Local: ${n} learnings\nGlobal: ${r.learnings.length} learnings`);const s=await ze.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),ze.log.warn("Non-interactive terminal detected, using default merge strategy"),"merge";beginPrompt(`Pulling ${ue.green(`'${t}'`)} from global`,o),ze.log.message(`Local: ${n.learnings.length} learnings\nGlobal: ${r} learnings`);const s=await ze.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),ze.log.warn("Non-interactive terminal detected, skipping push"),"skip";const i=bt(`commandcode.ai/${n}/${t}`,`https://commandcode.ai/${n}/${t}`,{fallback:__name((e,t)=>t,"fallback")});beginPrompt(`Pushing ${ue.green(`'${t}'`)} to ${n}`,s),ze.log.message(`Local: ${t} (${r} learnings)\nRemote: ${t} (${o} learnings) in ${n}`),ze.log.info(`Current package: ${ue.cyan(i)} ${ue.dim("(review)")}`);const a=await ze.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),ze.log.warn("Non-interactive terminal detected, skipping push"),"skip";const i=bt(`commandcode.ai/${n}/${t}`,`https://commandcode.ai/${n}/${t}`,{fallback:__name((e,t)=>t,"fallback")});beginPrompt(`Pushing ${ue.green(`'${t}'`)} to ${n}`,s),ze.log.message(`Local: ${r} learnings\nRemote: ${o} learnings`),ze.log.info(`Current package: ${ue.cyan(i)} ${ue.dim("(review)")}`);const a=await ze.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"),Ft(),Ft(),__name(mergeSingleLearning,"mergeSingleLearning"),__name(mergePackages,"mergePackages"),__name(validateSinglePackage,"validateSinglePackage"),__name(validateSingleRemoteFile,"validateSingleRemoteFile"),__name(validatePackages,"validatePackages"),__name(validateRemoteFiles,"validateRemoteFiles"),__name(mergeOrKeep,"mergeOrKeep"),Ft(),__name(resolveRemotePullStrategy,"resolveRemotePullStrategy"),__name(executePackageStrategy,"executePackageStrategy"),__name(processPackage,"processPackage"),__name(pullProjectPackage,"pullProjectPackage"),__name(pullCategoryPackage,"pullCategoryPackage");var OM=__name(({pkg:e,error:t})=>({success:!1,packagesPulled:[],errors:[{pkg:e,error:t}],mergeDetails:{},overwritten:[],filePaths:{}}),"fail"),FM=__name(()=>({success:!0,packagesPulled:[],skipped:[],errors:[],mergeDetails:{},overwritten:[],filePaths:{}}),"emptyResult"),UM=__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 OM({pkg:"all",error:`Invalid source: ${n}`});const s=UM(n);let i;try{i="local-global"===n?await getAllPackages():await getAllPackages3()}catch(e){return OM({pkg:"all",error:e instanceof Error?e.message:String(e)})}if(0===i.length)return OM({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=FM();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 OM({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=FM();try{return await executePullRemote({owner:t,packageName:n,overwrite:r,flagStrategy:o,result:s})}catch(e){return OM({pkg:n,error:e instanceof Error?e.message:String(e)})}}function logResult(e){if(wasPrompted())return ze.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()?"":`${Ie.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&&ze.log.message(l.join("\n")),ze.outro(`${a} from ${n}`),setPrompted(!1),hasMergeConflictRiskInRecord(t.mergeDetails??{})):(console.log(`${ue.green(Ie.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 Me("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 Ne("--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 Ne("--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(Re("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(Re("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 Xw({baseUrl:e}),n=await t.get({endpoint:zt.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 ze.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()?"":`${Ie.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()?"":`${Ie.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()?"":`${Ie.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()?"":`${Ie.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&&ze.log.message(i.join("\n"));const a=`${s} ${1===s?"package":"packages"}`;ze.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"),Ft(),__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"),Ft(),er(),Ft(),IS(),yS(),Cn(),__name(fetchUserNamespaces,"fetchUserNamespaces"),Ft(),__name(logResult2,"logResult"),__name(logPushAllSuccess,"logPushAllSuccess"),__name(logPushSingleSuccess,"logPushSingleSuccess"),__name(logPushMultiSuccess,"logPushMultiSuccess"),__name(logPushUrls,"logPushUrls"),__name(logConflictSummary,"logConflictSummary"),__name(logPushBreakdown,"logPushBreakdown"),__name(logPushSuccess,"logPushSuccess"),Ft(),BE(),Ft();var jM=__name(({pkg:e,error:t})=>({success:!1,packagesPushed:[],skipped:[],errors:[{pkg:e,error:t}],mergeDetails:{},overwritten:[],filePaths:{}}),"fail"),qM=__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=qM(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 jM({pkg:"all",error:e instanceof Error?e.message:String(e)})}}__name(resolvePushAllStrategy,"resolvePushAllStrategy"),__name(executePushAllRemote,"executePushAllRemote"),__name(pushAllRemote,"pushAllRemote");var BM=__name(({pkg:e,error:t})=>({success:!1,packagesPushed:[],skipped:[],errors:[{pkg:e,error:t}],mergeDetails:{},overwritten:[],filePaths:{}}),"fail"),zM=__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 WM=__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=WM({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 BM({pkg:"all",error:"No taste directory found in project"});const a=await getAllPackages2();if(0===a.length)return BM({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}):BM({pkg:"all",error:"Failed to get owner for remote push"});if("local-global"!==r&&"remote-project"!==r&&"remote-user"!==r)return BM({pkg:"all",error:`Invalid target: ${r}`});const m=zM();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 BM({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 BM({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=zM();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 BM({pkg:t,error:"No taste directory found in project"});try{return await executeRemotePush(e)}catch(e){return BM({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 ze.select({message:"Owner",options:r,initialValue:t});return ze.isCancel(o)&&(ze.cancel("Operation cancelled"),process.exit(0)),o}function createPushCommand(){return new Me("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 Ne("--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 Ne("--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"),Ft(),__name(promptOwnerSelection,"promptOwnerSelection"),__name(createPushCommand,"createPushCommand"),__name(validatePushOptions,"validatePushOptions");var HM=__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};ze.intro(ue.dim(`pushing ${t}`)),setPrompted(!0);const o=ze.spinner();o.start("Resolving"),(await list({location:"local-project"})).some(e=>e.category===t)||(o.error("Failed"),ze.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(Re("Pushing taste packages").start());const l=await push({packages:[],target:"remote-project",overwrite:n.overwrite,isPublic:HM(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:HM(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=ze.spinner();return e.start(`Pushing to ${t}/${n}`),void setActiveSpinner(e)}setActiveSpinner(Re("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(Re("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 Me(rn.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=Re("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(Ie.tick)} Update available`),showVersionDetails(t)):e.succeed(`Up to date ${de.dim(`(${t.currentVersion})`)}`)}async function performUpdateAction(){const e=Re("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} ${Ie.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:ws.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"),so(),__name(createTasteCommand,"createTasteCommand"),Ft(),Cn(),Ts(),__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 GM=new Me("update").description("Update Command Code to the latest version").option("--check-only","Check for updates without installing").allowUnknownOption().allowExcessArguments().action(updateAction);Ft(),FE(),BE();var VM=__name((e,t)=>`${Ie.info} ${e}: ${de.cyan(t)}`,"formatInfoLine"),QM=__name(e=>de.bold(`${e}:`),"formatSectionHeader"),KM=__name(e=>de.red(e),"formatError"),YM=__name(e=>e instanceof Error?e.message:"Unknown error","formatErrorMessage"),JM=__name(e=>["",QM("User Information"),VM("Name",e.name),VM("Email",e.email),VM("Username",e.userName)],"buildUserOutput"),XM=__name(e=>["",QM("Organization"),VM("Name",e.name),VM("Login",e.login)],"buildOrgOutput"),ZM=__name(e=>{e.forEach(e=>console.log(e))},"printLines"),eN=__name((e,t)=>{ZM(JM(e)),t&&ZM(XM(t)),console.log("")},"displayUserInfo"),tN=__name(e=>null!==e&&e.length>0,"validateApiKey"),nN=__name(e=>e.success&&null!==e.user,"validateUserData");async function whoamiAction(){const e=Re("Fetching user information...").start();try{const t=await getAuthKey();tN(t)||(e.fail(KM('Not authenticated. Please login using "cmd auth login"')),process.exit(1));const n=await getAuthenticatedEntity();nN(n)||(e.fail(KM("Failed to fetch user info")),process.exit(1)),e.succeed("User information loaded"),eN(n.user,n.org)}catch(t){e.fail(KM(`Error: ${YM(t)}`)),process.exit(1)}}__name(whoamiAction,"whoamiAction");var rN=new Me("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"!==be("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=be("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=be("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(!be(`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:""===be("git status --porcelain",{encoding:"utf-8",stdio:["pipe","pipe","pipe"]}).trim()}}Ft(),Ft(),Cn(),yS(),Bs(),IS(),On(),fo(),Ft(),__name(normalizeGitUrl,"normalizeGitUrl"),__name(validateGitRepo,"validateGitRepo"),Ft(),IS(),FE(),Ft();var oN=["completed","failed","cancelled","timed_out"];function isTerminalStatus(e){return oN.includes(e)}__name(isTerminalStatus,"isTerminalStatus");var sN={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=sN[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=Re({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=Re({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){const n=e.data.message||"Unknown error";return t.workingSpinner&&(t.workingSpinner.fail(n),t.workingSpinner=null),t.currentSpinner&&(t.currentSpinner.fail(n),t.currentSpinner=null),void(t.phase="done")}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(`${Ie.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=Re({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=Re({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=L.readFileSync(getAuthFile(),"utf-8")}catch{}try{t=L.readFileSync(getConfigFile(),"utf-8")}catch{}return{auth:e,config:t}}async function askQuestion(e){const t=lt.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,isInternalTeam:r,configFiles:o}){return new Xw({baseUrl:getApiBaseUrl()}).post({endpoint:zt.ALPHA.SANDBOX.START,body:{repoUrl:e,branch:t,prompt:n,isInternalTeam:r,configFiles:o}})}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=isInternalTeamFlagPresent(),o=readLocalConfigFiles(),s=e||await askQuestion(`${de.bold("What do you want to do?")}\n${de.cyan(">")} `);if(!s.trim())return void console.error(de.yellow("No prompt provided. Aborting."));const i=s.trim().slice(0,on.MAX_PROMPT_CHARS),a=Re({stream:process.stderr,text:"Starting sandbox session..."}).start();try{const e=await startSandboxSession({repoUrl:n.repoUrl,branch:n.branch,prompt:i,isInternalTeam:r,configFiles:o});a.succeed("Sandbox started"),await streamSession({sessionId:e.sessionId,prompt:i}),process.exit(0)}catch(e){a.fail("Failed to start sandbox session");const t=e instanceof Ps,r=t?e.code:void 0;if(401===(t?e.status:void 0)||"UNAUTHORIZED"===r)console.error(de.red("\nAuthentication failed. Try logging in again: cmd login"));else if("GITHUB_APP_NOT_INSTALLED"===r){const e=de.cyan(de.underline(n.repoUrl)),t=de.cyan(de.underline("https://github.com/apps/command-code-ai/installations/new"));console.error(`\n${de.red("✖")} Command Code GitHub App isn't installed on ${e}`),console.error(` Install it here: ${t}`),console.error(de.dim(" Then run this command again."))}else{const n=t&&"string"==typeof e.message?e.message:"Something went wrong. Please try again.";console.error(de.red(`\n${n}`))}process.exit(1)}}function createSandboxCommand(){return new Me("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(S.tmpdir(),`commandcode-skill-${R()}`);await k.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 k.access(l),d=!0}catch{}if(!d)try{await k.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 k.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(()=>(YE(),KE)),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 k.access(n),n}catch{}const r=t.join(e,"skill.md");try{return await k.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 k.readFile(t,"utf-8"),{data:r}=Ue(n),o=_f.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 k.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 k.mkdir(a,{recursive:!0});const d=t.join(a,r),{randomUUID:m}=await import("crypto"),g=t.join(a,`.${r}.tmp.${m()}`);try{await k.cp(u,g,{recursive:!0,force:!0,dereference:!1}),l&&s&&await k.rm(d,{recursive:!0,force:!0}),await k.rename(g,d)}catch(e){if(await k.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 k.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 k.rm(i,{recursive:!0,force:!0})}async function listSkills(){const{global:e,project:t,warnings:n}=await loadAllSkillSummariesWithWarnings(),r=getBundledSkillsDir(),o=[],s=[];for(const t of e){const e={name:t.name,description:t.description,location:isBundledSkillPath({filePath:t.filePath,bundledDir:r})?"bundled":"global",path:t.filePath};("bundled"===e.location?o:s).push(e)}return{global:s,project:t.map(e=>({name:e.name,description:e.description,location:"project",path:e.filePath})),bundled:o,warnings:n}}__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"),so(),Ft(),Ft(),Ft(),Ft(),QE(),__name(validateSafeString,"validateSafeString"),__name(parseGitHubRepo,"parseGitHubRepo"),__name(buildGigetSource,"buildGigetSource"),__name(fetchSkillFromGitHub,"fetchSkillFromGitHub"),__name(discoverSkillsInRepo,"discoverSkillsInRepo"),LS(),zf(),__name(resolveSkillMdPath,"resolveSkillMdPath"),__name(validateSkillName,"validateSkillName"),__name(validateSkillContent,"validateSkillContent"),__name(skillExists,"skillExists"),__name(discoverSkills,"discoverSkills"),__name(installSkill,"installSkill"),__name(removeSkill,"removeSkill"),__name(listSkills,"listSkills"),Cn();var iN=[`${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/")}`],aN=__name((e,t)=>`${de.green(Ie.tick)} Installed ${de.cyan(e)} ${de.dim(`${Ie.arrowRight} ${t}/`)}`,"formatInstalled"),lN=__name(e=>`${de.red(Ie.cross)} ${e}`,"formatError");async function cleanupAndExit(e,t){e&&await x(e,{recursive:!0,force:!0}).catch(()=>{}),process.exit(t)}function validateRepoFormat(e){(e.startsWith(".")||e.startsWith("/")||e.startsWith("~"))&&(console.error(lN("Local paths are not supported. Skills must be installed from GitHub.")),console.log(""),iN.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(lN(`Invalid repository: "${e}"`)),console.log(""),console.log(`Expected format: ${de.cyan("owner/repo")} or ${de.cyan("owner/repo/path")}`),console.log(""),iN.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=Re({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(lN(`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(lN(`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 We({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=Re({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(aN(i.name,r))}catch(e){d++;const t=e instanceof Error?e.message:String(e);console.error(lN(`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(lN(t)),await cleanupAndExit(o,1)}}__name(cleanupAndExit,"cleanupAndExit"),__name(validateRepoFormat,"validateRepoFormat"),__name(addAction,"addAction");var cN=new Me("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${iN.join("\n")}`).configureOutput({outputError:__name((e,t)=>{e.includes("missing required argument")?(console.error(lN("No repository specified.")),console.log(""),iN.forEach(e=>console.log(e))):t(e)},"outputError")}).action(addAction);Ft(),Cn();var uN=__name((e,t)=>`${de.green(Ie.tick)} Removed ${de.cyan(e)} from ${t} skills`,"formatRemoved"),dN=__name(e=>`${de.red(Ie.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(dN(o)),console.log(de.dim(`Run ${de.cyan("cmd skills list")} to see installed skills.`)),process.exit(1)),!t.yes&&n){const t=await He({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(uN(e,r)),process.exit(0)}catch(n){const r=n instanceof Error?n.message:"Failed to remove skill";r.includes("not found")?(console.error(dN(`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(dN(r)),process.exit(1)}}__name(validateSkillNameEarly,"validateSkillNameEarly"),__name(removeAction,"removeAction");var mN=new Me("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);Ft(),LS(),lE(),Cn();var pN=__name((e,t)=>{const n=t.length>60?t.substring(0,57)+"...":t;return` ${de.cyan(e)} ${de.dim(`· ${n}`)}`},"formatSkillLine"),gN=__name((e,t)=>`${de.bold(de.white(e))} ${de.dim(`(${t})`)}`,"formatSectionHeader"),hN=__name(e=>{if(0===e.length)return;const t=groupWarnings(e);console.log(""),console.log(`${de.bold(de.yellow("Skipped"))} ${de.dim(`(${e.length})`)}`);for(const e of t){console.log(""),console.log(` ${de.bold(e.category)} ${de.dim(`(${e.items.length})`)}`);for(const t of e.items)console.log(` ${de.bold(skillIdentifier(t.path))}`),console.log(` ${de.dim(t.reason)}`)}},"printWarnings"),fN=__name(()=>{const e=process.cwd(),n=t.join(e,".commandcode","skills"),r=t.join(e,".agents","skills"),o=getProjectSkillsDir(),s=getProjectAgentsCompatSkillsDir(),i=["",de.dim("No skills installed."),"",de.dim("Looking in:"),de.dim(` ${getGlobalSkillsDir()} ${de.white("(global)")}`),de.dim(` ${getGlobalAgentsCompatSkillsDir()} ${de.white("(global, .agents)")}`)];return n!==o&&i.push(de.dim(` ${n} ${de.white("(cwd)")}`)),r!==s&&i.push(de.dim(` ${r} ${de.white("(cwd, .agents)")}`)),i.push(de.dim(` ${o} ${de.white("(project)")}`),de.dim(` ${s} ${de.white("(project, .agents)")}`),"",`Install a skill: ${de.cyan("cmd skills add")} ${de.dim("<owner/repo>")}`,""),i},"formatEmptyHint"),yN=__name(e=>{e.forEach(e=>console.log(e))},"printLines");async function listAction(){const e="true"===process.env.DEBUG;try{const{global:t,project:n,bundled:r,warnings:o}=await listSkills(),s=t.length+n.length,i=__name(()=>{e||0===o.length||(console.log(""),console.log(de.dim(`${o.length} skill${1===o.length?"":"s"} skipped · run with ${de.cyan("--debug")} to see issues`)))},"printDebugHint");0===s&&(yN(fN()),r.length>0&&(console.log(gN("Bundled",r.length)),r.forEach(e=>{console.log(pN(e.name,e.description))}),console.log("")),e&&(hN(o),o.length>0&&console.log("")),e||(i(),console.log("")),process.exit(0)),console.log(""),console.log(heading({text:"Skills",sub:de.dim(`${s} installed`)})),n.length>0&&(console.log(""),console.log(gN("Project",n.length)),n.forEach(e=>{console.log(pN(e.name,e.description))})),t.length>0&&(console.log(""),console.log(gN("Global",t.length)),t.forEach(e=>{console.log(pN(e.name,e.description))})),r.length>0&&(console.log(""),console.log(gN("Bundled",r.length)),r.forEach(e=>{console.log(pN(e.name,e.description))})),e&&hN(o),e||i(),console.log(""),process.exit(0)}catch(e){const t=e instanceof Error?e.message:"Unknown error";console.error(`${de.red(Ie.cross)} Failed to list skills: ${t}`),process.exit(1)}}__name(listAction,"listAction");var wN=new Me("list").description("List all installed skills. Run with -d/--debug to also see why any skills were skipped.").action(listAction),SN=new Me("skills").description("Manage skills from GitHub repositories").addCommand(cN).addCommand(mN).addCommand(wN);handleUnhandledErrors(),setupTelemetry(),await preRun();var bN=createProgram();bN.action(interactiveModeAction),bN.addCommand(XI),bN.addCommand(ZI),bN.addCommand(rN),bN.addCommand(GM),bN.addCommand(JI),bN.addCommand(createTasteCommand()),bN.addCommand(createMcpCommand()),bN.addCommand(eM),bN.addCommand(xs),bN.addCommand(bE),bN.addCommand(PE),bN.addCommand(SN),isExperimentalEnabled()&&bN.addCommand(createSandboxCommand()),setupCommanderHooks(bN),bN.parse();
|