claudecode-dashboard 1.0.0 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli.js +31 -22
- package/package.json +1 -1
- package/dist/app-ALZQA2MU.js +0 -124
- package/dist/build-ATVYGQFJ.js +0 -2
- package/dist/chunk-AHIRPBQB.js +0 -7
- package/dist/chunk-CUZUQPDA.js +0 -47
- package/dist/chunk-H6DM526Z.js +0 -238
- package/dist/chunk-KBW7PPBV.js +0 -2
- package/dist/devtools-XXWLXKPC.js +0 -8
- package/dist/react-JYLNFGAJ.js +0 -2
package/dist/cli.js
CHANGED
|
@@ -1,23 +1,32 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import {
|
|
3
|
-
`)
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
`),
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
`)
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
2
|
+
import {homedir}from'os';import {join}from'path';import {readFile,readdir,mkdir,appendFile,writeFile,stat}from'fs/promises';import {existsSync}from'fs';import {useApp,useStdout,useInput,Box,Text}from'ink';import {jsxs,jsx}from'react/jsx-runtime';import xr from'openai';import wr from'@anthropic-ai/sdk';import {useState,useCallback,useEffect,useMemo}from'react';import dt from'ink-spinner';import {Command}from'commander';var Ft=Object.defineProperty;var p=(t,e)=>()=>(t&&(e=t(t=0)),e);var jt=(t,e)=>{for(var r in e)Ft(t,r,{get:e[r],enumerable:true});};function S(){return join(homedir(),".claude")}function Nt(){return join(homedir(),".claude.json")}var b,E=p(()=>{b={userSettings:()=>join(S(),"settings.json"),userSettingsLocal:()=>join(S(),"settings.local.json"),userMemory:()=>join(S(),"CLAUDE.md"),userSkills:()=>join(S(),"skills"),userAgents:()=>join(S(),"agents"),userCommands:()=>join(S(),"commands"),userHooks:()=>join(S(),"hooks"),userOutputStyles:()=>join(S(),"output-styles"),userPlugins:()=>join(S(),"plugins"),metadata:()=>join(S(),"metadata.json"),history:()=>join(S(),"history.jsonl"),todos:()=>join(S(),"todos"),projects:()=>join(S(),"projects"),claudeJson:()=>Nt()};});function Ae(){return Pe}var ne,oe,ie,Pe,Kt,l,k=p(()=>{ne=class{name="memory";entries=[];listeners=new Set;maxEntries;constructor(e=100){this.maxEntries=e;}write(e){this.entries.push(e),this.entries.length>this.maxEntries&&(this.entries=this.entries.slice(-this.maxEntries)),this.notifyListeners();}getEntries(){return [...this.entries]}getRecent(e){return this.entries.slice(-e)}subscribe(e){return this.listeners.add(e),()=>this.listeners.delete(e)}clear(){this.entries=[],this.notifyListeners();}notifyListeners(){let e=this.getEntries();this.listeners.forEach(r=>r(e));}},oe=class{name="file";logDir;logFile;buffer=[];flushInterval=null;initialized=false;constructor(e){this.logDir=e||join(homedir(),".claude","claudecode-dashboard","logs");let r=new Date().toISOString().split("T")[0];this.logFile=join(this.logDir,`${r}.jsonl`);}async ensureDir(){this.initialized||(existsSync(this.logDir)||await mkdir(this.logDir,{recursive:true}),this.initialized=true);}async write(e){let r=JSON.stringify({ts:e.timestamp.toISOString(),lvl:e.level,src:e.source,msg:e.message,...e.meta&&{meta:e.meta}});this.buffer.push(r),(e.level==="error"||this.buffer.length>=10)&&await this.flush();}async flush(){if(this.buffer.length===0)return;await this.ensureDir();let e=this.buffer.join(`
|
|
3
|
+
`)+`
|
|
4
|
+
`;this.buffer=[],await appendFile(this.logFile,e);}startAutoFlush(e=5e3){this.flushInterval||(this.flushInterval=setInterval(()=>this.flush(),e));}stopAutoFlush(){this.flushInterval&&(clearInterval(this.flushInterval),this.flushInterval=null);}},ie=class{sinks=[];minLevel="info";levelOrder={debug:0,info:1,warn:2,error:3};addSink(e){this.sinks.push(e);}removeSink(e){this.sinks=this.sinks.filter(r=>r.name!==e);}getSink(e){return this.sinks.find(r=>r.name===e)}setMinLevel(e){this.minLevel=e;}shouldLog(e){return this.levelOrder[e]>=this.levelOrder[this.minLevel]}log(e,r,n,a){if(!this.shouldLog(e))return;let s={level:e,source:r,message:n,timestamp:new Date,meta:a};for(let o of this.sinks)try{o.write(s);}catch{}}debug(e,r,n){this.log("debug",e,r,n);}info(e,r,n){this.log("info",e,r,n);}warn(e,r,n){this.log("warn",e,r,n);}error(e,r,n){this.log("error",e,r,n);}async flush(){for(let e of this.sinks)e.flush&&await e.flush();}},Pe=new ne(100),Kt=new oe,l=new ie;l.addSink(Pe);l.addSink(Kt);});async function j(){let t=b.userSettings();if(!existsSync(t))return null;try{let e=await readFile(t,"utf-8");return JSON.parse(e)}catch(e){let r=e instanceof Error?e.message:"Unknown error";return l.error("settings",`Failed to parse ${t}: ${r}`),null}}var Ie=p(()=>{E();k();});function qt(t){let e=t.match(/^---\n([\s\S]*?)\n---/);if(!e)return {};let r=e[1],n={};for(let a of r.split(`
|
|
5
|
+
`)){let[s,...o]=a.split(":"),i=o.join(":").trim();s==="name"&&(n.name=i),s==="description"&&(n.description=i),s==="allowed-tools"&&(n.allowedTools=i.split(",").map(c=>c.trim())),s==="model"&&(n.model=i);}return n}async function N(){let t=b.userSkills();if(!existsSync(t))return [];try{let e=await readdir(t,{withFileTypes:!0}),r=[];for(let n of e){if(!n.isDirectory())continue;let a=join(t,n.name,"SKILL.md");if(existsSync(a))try{let s=await readFile(a,"utf-8"),o=qt(s);r.push({name:o.name||n.name,description:o.description,allowedTools:o.allowedTools,model:o.model,source:"user",path:a});}catch(s){let o=s instanceof Error?s.message:"Unknown error";l.warn("skills",`Failed to read skill ${n.name}: ${o}`);}}return r}catch(e){let r=e instanceof Error?e.message:"Unknown error";return l.error("skills",`Failed to read skills directory: ${r}`),[]}}var Me=p(()=>{E();k();});function er(t){let e=t.match(/^---\n([\s\S]*?)\n---/);if(!e)return {};let r=e[1],n={};for(let a of r.split(`
|
|
6
|
+
`)){let[s,...o]=a.split(":"),i=o.join(":").trim();s==="name"&&(n.name=i),s==="description"&&(n.description=i),s==="tools"&&(n.tools=i.split(",").map(c=>c.trim())),s==="model"&&(n.model=i),s==="permissionMode"&&(n.permissionMode=i),s==="skills"&&(n.skills=i.split(",").map(c=>c.trim()));}return n}async function U(){let t=b.userAgents();if(!existsSync(t))return [];try{let e=await readdir(t),r=[];for(let n of e){if(!n.endsWith(".md"))continue;let a=join(t,n);try{let s=await readFile(a,"utf-8"),o=er(s),i=o.name||n.replace(".md","");r.push({name:i,description:o.description,tools:o.tools,model:o.model,permissionMode:o.permissionMode,skills:o.skills,source:"user",path:a});}catch(s){let o=s instanceof Error?s.message:"Unknown error";l.warn("agents",`Failed to read agent ${n}: ${o}`);}}return r}catch(e){let r=e instanceof Error?e.message:"Unknown error";return l.error("agents",`Failed to read agents directory: ${r}`),[]}}var $e=p(()=>{E();k();});function ir(t){let e=t.match(/^---\n([\s\S]*?)\n---/);if(!e)return {};let r=e[1],n={};for(let a of r.split(`
|
|
7
|
+
`)){let[s,...o]=a.split(":"),i=o.join(":").trim();s==="description"&&(n.description=i),s==="argument-hint"&&(n.argumentHint=i),s==="allowed-tools"&&(n.allowedTools=i.split(",").map(c=>c.trim())),s==="model"&&(n.model=i);}return n}async function B(){let t=b.userCommands();if(!existsSync(t))return [];try{let e=await readdir(t,{recursive:!0}),r=[];for(let n of e){let a=String(n);if(!a.endsWith(".md"))continue;let s=join(t,a);try{let o=await readFile(s,"utf-8"),i=ir(o),c=a.replace(/\.md$/,"").replace(/[\/\\]/g,":");r.push({name:c,description:i.description,argumentHint:i.argumentHint,allowedTools:i.allowedTools,model:i.model,source:"user",path:s});}catch(o){let i=o instanceof Error?o.message:"Unknown error";l.warn("commands",`Failed to read command ${a}: ${i}`);}}return r}catch(e){let r=e instanceof Error?e.message:"Unknown error";return l.error("commands",`Failed to read commands directory: ${r}`),[]}}var Oe=p(()=>{E();k();});async function H(){let t=b.userSettings();if(!existsSync(t))return [];try{let e=await readFile(t,"utf-8"),r=JSON.parse(e);if(!r.hooks)return [];let n=[];for(let[a,s]of Object.entries(r.hooks))for(let o of s)for(let i of o.hooks)n.push({event:a,matcher:o.matcher,type:i.type,command:i.command,prompt:i.prompt,timeout:i.timeout,source:"user"});return n}catch(e){let r=e instanceof Error?e.message:"Unknown error";return l.error("hooks",`Failed to parse hooks from settings: ${r}`),[]}}var Re=p(()=>{E();k();});async function _(){let t=[],e=join(homedir(),".mcp.json");if(existsSync(e))try{let n=await readFile(e,"utf-8"),a=JSON.parse(n);if(a.mcpServers)for(let[s,o]of Object.entries(a.mcpServers))t.push({name:s,type:o.type||(o.command?"stdio":"http"),url:o.url,command:o.command,args:o.args,env:o.env,scope:"user"});}catch(n){let a=n instanceof Error?n.message:"Unknown error";l.error("mcp",`Failed to parse ~/.mcp.json: ${a}`);}let r=join(process.cwd(),".mcp.json");if(existsSync(r))try{let n=await readFile(r,"utf-8"),a=JSON.parse(n);if(a.mcpServers)for(let[s,o]of Object.entries(a.mcpServers))t.push({name:s,type:o.type||(o.command?"stdio":"http"),url:o.url,command:o.command,args:o.args,env:o.env,scope:"project"});}catch(n){let a=n instanceof Error?n.message:"Unknown error";l.error("mcp",`Failed to parse ./.mcp.json: ${a}`);}return t}var Ue=p(()=>{k();});async function K(){let t=b.userPlugins();if(!existsSync(t))return [];try{let e=await readdir(t,{withFileTypes:!0}),r=[];for(let n of e){if(!n.isDirectory())continue;let a=join(t,n.name),s=join(a,"plugin.json");if(existsSync(s))try{let o=await readFile(s,"utf-8"),i=JSON.parse(o),c=u=>u?Array.isArray(u)?u:[u]:[];r.push({name:i.name||n.name,version:i.version,description:i.description,enabled:!0,path:a,commands:c(i.commands),agents:c(i.agents),skills:c(i.skills),hooks:i.hooks?[i.hooks]:[],mcpServers:i.mcpServers?[i.mcpServers]:[]});}catch(o){let i=o instanceof Error?o.message:"Unknown error";l.warn("plugins",`Failed to read plugin ${n.name}: ${i}`);}}return r}catch(e){let r=e instanceof Error?e.message:"Unknown error";return l.error("plugins",`Failed to read plugins directory: ${r}`),[]}}var _e=p(()=>{E();k();});var se=p(()=>{E();Ie();Me();$e();Oe();Re();Ue();_e();});function Ve({categories:t,selected:e,focused:r}){return jsxs(Box,{flexDirection:"column",children:[jsx(Text,{bold:true,underline:true,children:"CATEGORIES"}),jsx(Box,{marginTop:1,flexDirection:"column",children:t.map((n,a)=>{let s=a===e;return s&&r?jsxs(Text,{bold:true,underline:true,children:["\u25B8 ",n.label," ",jsx(Text,{bold:true,children:n.count})]},n.key):s?jsxs(Text,{bold:true,children:["\u203A ",n.label," ",jsx(Text,{dimColor:true,children:n.count})]},n.key):jsxs(Text,{dimColor:true,children:[" ",n.label," ",jsx(Text,{dimColor:true,children:n.count})]},n.key)})})]})}var ze=p(()=>{});function We({items:t,selected:e,focused:r,maxHeight:n=15}){if(t.length===0)return jsxs(Box,{flexDirection:"column",children:[jsx(Text,{bold:true,underline:true,children:"ITEMS"}),jsx(Box,{marginTop:1,children:jsx(Text,{dimColor:true,italic:true,children:"No items"})})]});let a=Math.max(5,n-3),s=Math.max(0,Math.min(e-Math.floor(a/2),t.length-a)),o=t.slice(s,s+a);return jsxs(Box,{flexDirection:"column",children:[jsxs(Text,{bold:true,underline:true,children:["ITEMS (",t.length,")"]}),jsxs(Box,{marginTop:1,flexDirection:"column",children:[s>0&&jsxs(Text,{dimColor:true,children:["\u2191 ",s," more"]}),o.map((i,c)=>{let u=s+c,g=u===e,m=i.name.length>24?i.name.slice(0,21)+"...":i.name;return g&&r?jsxs(Text,{bold:true,underline:true,children:["\u25B8 ",m]},`${i.name}-${u}`):g?jsxs(Text,{bold:true,children:["\u203A ",m]},`${i.name}-${u}`):jsxs(Text,{dimColor:true,children:[" ",m]},`${i.name}-${u}`)}),s+a<t.length&&jsxs(Text,{dimColor:true,children:["\u2193 ",t.length-s-a," more"]})]})]})}var Ye=p(()=>{});async function Ge(){existsSync(ce)||await mkdir(ce,{recursive:true});}async function me(){if(T)return T;if(await Ge(),!existsSync(le))return T={version:1,entries:{}},T;try{let t=await readFile(le,"utf-8");return T=JSON.parse(t),T}catch(t){let e=t instanceof Error?t.message:"Unknown error";return l.warn("cache",`Failed to load cache, starting fresh: ${e}`),T={version:1,entries:{}},T}}async function ue(){if(T)try{await Ge(),await writeFile(le,JSON.stringify(T,null,2));}catch(t){let e=t instanceof Error?t.message:"Unknown error";l.error("cache",`Failed to save cache: ${e}`);}}async function Qe(t){try{return (await stat(t)).mtimeMs}catch(e){let r=e instanceof Error?e.message:"Unknown error";return l.warn("cache",`Failed to get mtime for ${t}: ${r}`),0}}async function ge(t){let e=await me(),r=e.entries[t];return r?await Qe(t)!==r.mtime?(delete e.entries[t],await ue(),null):r.summary:null}async function de(t,e){let r=await me(),n=await Qe(t);r.entries[t]={summary:e,mtime:n,generatedAt:Date.now()},await ue();}async function pe(t){let e=await me();return e.entries[t]?(delete e.entries[t],await ue(),l.info("cache",`Cache cleared for: ${t}`),true):false}var ce,le,T,fe=p(()=>{k();ce=join(homedir(),".claude","claudecode-dashboard"),le=join(ce,"cache.json"),T=null;});function ee(){return process.env.ANTHROPIC_API_KEY?"anthropic":process.env.OPENAI_API_KEY?"openai":"none"}function V(){let t=ee();switch(t){case "anthropic":return {provider:t,description:`Claude AI (${ye})`};case "openai":return {provider:t,description:`OpenAI (${he})`};case "none":return {provider:t,description:"Set ANTHROPIC_API_KEY or OPENAI_API_KEY for AI summaries"}}}function kr(){if(Q)return Q;let t=process.env.OPENAI_API_KEY;return t?(Q=new xr({apiKey:t}),Q):null}function br(){if(Z)return Z;let t=process.env.ANTHROPIC_API_KEY;return t?(Z=new wr({apiKey:t}),Z):null}function Cr(t){return t.replace(/\|/g,"\u2502").replace(/─{3,}/g,"\u2500\u2500\u2500")}function Tr(t,e=Ze){let r=t.split(`
|
|
8
|
+
`),n=r.slice(0,e);if(n[0]==="---"){let o=n.findIndex((i,c)=>c>0&&i==="---");o>0&&n.splice(0,o+1);}let a=r.length<=e,s=n.join(`
|
|
9
|
+
`).trim();return s=Cr(s),a?s+=`
|
|
10
|
+
\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500
|
|
11
|
+
<EOF>`:s+=`
|
|
12
|
+
\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500
|
|
13
|
+
... (${r.length-e} more lines)`,{text:s,isEOF:a}}async function Lr(t,e){let r=ee(),n=`You are a senior engineer reviewing this Claude Code ${e}.
|
|
14
|
+
|
|
15
|
+
Provide a structured analysis (keep it concise, ~500 words max):
|
|
16
|
+
|
|
17
|
+
**What it does:** 2-3 sentences explaining the core functionality and behavior.
|
|
18
|
+
|
|
19
|
+
**Key details:**
|
|
20
|
+
- Implementation: How it works technically (tools, patterns, integrations)
|
|
21
|
+
- Trigger: When/how it activates (events, commands, conditions)
|
|
22
|
+
- Scope: What it affects (files, sessions, permissions)
|
|
23
|
+
|
|
24
|
+
**Engineering notes:** 1-2 practical tips or gotchas.
|
|
25
|
+
|
|
26
|
+
Be specific and technical. Include actual values from the config. Ensure your response is COMPLETE - do not cut off mid-sentence.`,a=t.slice(0,4e3);if(r==="anthropic"){let s=br();if(!s)throw l.error("ai","Anthropic client initialization failed"),new Error("Anthropic client init failed");try{let i=(await s.messages.create({model:ye,max_tokens:1e3,messages:[{role:"user",content:`${n}
|
|
27
|
+
|
|
28
|
+
${a}`}]})).content.find(c=>c.type==="text");if(i?.type==="text")return l.info("ai",`Generated summary using ${ye}`),i.text.trim();throw l.error("ai","No text in Anthropic response"),new Error("No text in Anthropic response")}catch(o){let i=o instanceof Error?o.message:"Unknown error";throw l.error("ai",`Anthropic API error: ${i}`),o}}if(r==="openai"){let s=kr();if(!s)throw l.error("ai","OpenAI client initialization failed"),new Error("OpenAI client init failed");try{let i=(await s.chat.completions.create({model:he,messages:[{role:"system",content:n},{role:"user",content:a}],max_tokens:1e3,temperature:.3})).choices[0]?.message?.content?.trim();if(i)return l.info("ai",`Generated summary using ${he}`),i;throw l.error("ai","No text in OpenAI response"),new Error("No text in OpenAI response")}catch(o){let i=o instanceof Error?o.message:"Unknown error";throw l.error("ai",`OpenAI API error: ${i}`),o}}throw l.warn("ai","No AI provider configured"),new Error("No AI provider configured")}async function xe(t,e){if(!existsSync(t))return l.warn("summary",`File not found: ${t}`),{aiSummary:null,preview:"[File not found]"};let r;try{r=await readFile(t,"utf-8");}catch(o){let i=o instanceof Error?o.message:"Unknown error";return l.error("summary",`Failed to read file ${t}: ${i}`),{aiSummary:null,preview:"[Failed to read file]"}}let n=Tr(r),a=await ge(t);if(a)return l.info("summary",`Using cached summary for ${t}`),{aiSummary:a,preview:n.text};if(ee()!=="none")try{let o=await Lr(r,e);return await de(t,o),{aiSummary:o,preview:n.text}}catch(o){let i=o instanceof Error?o.message:"Unknown error";return {aiSummary:null,preview:n.text,aiError:i}}return {aiSummary:null,preview:n.text}}var he,ye,Q,Z,Ze,et=p(()=>{fe();k();he="gpt-4o-mini",ye="claude-haiku-4-5-latest",Q=null,Z=null;Ze=30;});var we=p(()=>{et();fe();});function rt(t,e){let[r,n]=useState(null),[a,s]=useState(null),[o,i]=useState(null),[c,u]=useState(false),[g,m]=useState(null),x=V(),v=useCallback(async()=>{if(!t){n(null),s(null),i(null);return}u(true),m(null),s(null);try{let y=await xe(t,e);n(y.aiSummary),s(y.aiError||null),i(y.preview);}catch(y){let I=y instanceof Error?y.message:"Failed to load";l.error("summary-hook",`Failed to load summary: ${I}`),m(I);}finally{u(false);}},[t,e]),F=useCallback(async()=>{t&&(l.info("summary-hook",`Regenerating summary for: ${t}`),await pe(t),await v());},[t,v]);return useEffect(()=>{v();},[v]),{aiSummary:r,aiError:a,preview:o,loading:c,error:g,provider:x.provider,providerDescription:x.description,refresh:v,regenerate:F}}var nt=p(()=>{we();k();});function ct({tabs:t,activeTab:e,onTabChange:r,disabled:n}){return useInput((a,s)=>{if(n)return;let o=t.findIndex(i=>i.key===e);if(o!==-1){if(s.tab&&!s.shift){let i=(o+1)%t.length;r(t[i].key);}else if(s.tab&&s.shift){let i=(o-1+t.length)%t.length;r(t[i].key);}}}),jsxs(Box,{children:[t.map(a=>{let s=a.key===e;return jsx(Box,{marginRight:1,children:jsxs(Text,{bold:s,color:s?"cyan":void 0,dimColor:!s,children:["[",s?"\u25CF":" ","] ",a.label]})},a.key)}),jsx(Text,{dimColor:true,children:" (Tab \u2194)"})]})}var lt=p(()=>{});function ut({content:t,maxLines:e=8,width:r,disabled:n}){let[a,s]=useState(false),{truncated:o,needsTruncation:i,totalVisualLines:c}=useMemo(()=>{let g=Math.max(20,r-2),m=Mr(t,g);return m.length<=e?{truncated:t,needsTruncation:false,totalVisualLines:m.length}:{truncated:m.slice(0,e).join(`
|
|
29
|
+
`),needsTruncation:true,totalVisualLines:m.length}},[t,e,r]);useInput((g,m)=>{n||m.return&&i&&s(x=>!x);});let u=c-e;return i?jsxs(Box,{flexDirection:"column",children:[jsx(Text,{wrap:"wrap",children:a?t:o}),jsx(Box,{marginTop:1,children:jsx(Text,{color:"cyan",children:a?"[Enter: See less \u2191]":`[Enter: See more... +${u} lines]`})})]}):jsx(Text,{wrap:"wrap",children:t})}function Mr(t,e){let r=t.split(`
|
|
30
|
+
`),n=[];for(let a of r){if(a.length===0){n.push("");continue}if(a.length<=e){n.push(a);continue}let s=a.split(" "),o="";for(let i of s){let c=o?`${o} ${i}`:i;if(c.length<=e)o=c;else if(o&&n.push(o),i.length>e){let u=i;for(;u.length>e;)n.push(u.slice(0,e)),u=u.slice(e);o=u;}else o=i;}o&&n.push(o);}return n}var gt=p(()=>{});function pt({item:t,width:e,maxHeight:r=30,category:n}){let[a,s]=useState("preview"),o=t?.path,i=n||"configuration",{aiSummary:c,aiError:u,preview:g,loading:m,provider:x,regenerate:v}=rt(o,i);if(useInput(q=>{(q==="r"||q==="R")&&a==="summary"&&!m&&v();}),!t)return jsxs(Box,{flexDirection:"column",paddingX:1,children:[jsx(Text,{bold:true,underline:true,children:"DETAILS"}),jsx(Text,{dimColor:true,italic:true,children:"Select an item to view details"})]});let F="\u2500".repeat(Math.max(10,e-4)),y=ft(t),re=Math.max(5,r-y-6);return jsxs(Box,{flexDirection:"column",paddingX:1,children:[jsx(Text,{bold:true,underline:true,children:"DETAILS"}),jsxs(Box,{marginTop:1,flexDirection:"column",children:[jsx(Text,{color:"green",bold:true,children:"Properties:"}),ht(t,1,e-4)]}),o&&jsxs(Box,{marginTop:1,flexDirection:"column",children:[jsx(Text,{dimColor:true,children:F}),jsx(Box,{marginTop:1,children:jsx(ct,{tabs:Fr,activeTab:a,onTabChange:q=>s(q)})}),jsx(Box,{marginTop:1,flexDirection:"column",minHeight:re,children:a==="preview"?jsx(jr,{preview:g,loading:m,maxLines:re,width:e-6}):jsx(Nr,{summary:c,error:u,loading:m,provider:x,maxLines:re-2,width:e-6})})]})]})}function jr({preview:t,loading:e,maxLines:r,width:n}){if(e)return jsxs(Text,{color:"cyan",children:[jsx(dt,{type:"dots"})," Loading preview..."]});if(!t)return jsx(Text,{dimColor:true,italic:true,children:"No content available"});let a=Ur(t,r,n);return jsx(Text,{children:a})}function Nr({summary:t,error:e,loading:r,provider:n,maxLines:a,width:s}){return n==="none"?jsxs(Box,{flexDirection:"column",children:[jsx(Text,{dimColor:true,italic:true,children:"AI Summary not configured"}),jsx(Text,{dimColor:true,children:"Export ANTHROPIC_API_KEY or OPENAI_API_KEY to enable"})]}):r?jsxs(Text,{color:"cyan",children:[jsx(dt,{type:"dots"})," Generating summary..."]}):e?jsxs(Text,{color:"red",children:["Error: ",e]}):t?jsxs(Box,{flexDirection:"column",children:[jsx(ut,{content:t,maxLines:a-1,width:s}),jsx(Text,{dimColor:true,children:" (R: regenerate)"})]}):jsx(Text,{dimColor:true,italic:true,children:"No summary available"})}function ft(t){let e=0;for(let[,r]of Object.entries(t))r!=null&&(e++,typeof r=="object"&&!Array.isArray(r)?e+=ft(r):Array.isArray(r)&&r.length>0&&typeof r[0]=="object"&&(e+=Math.min(r.length,3),r.length>3&&e++));return e}function Ur(t,e,r){let n=t.split(`
|
|
31
|
+
`),a=n[n.length-1]||"",s=a.includes("<EOF>"),o=a.includes("... (")&&a.includes("more lines)"),i=n.length>=2&&n[n.length-2]?.startsWith("\u2500\u2500\u2500"),c=s||o?i?2:1:0,u=e-c,g=[],m=c>0?n.slice(0,-c):n;for(let v of m){if(g.length>=u)break;if(v.length<=r)g.push(v);else {let F=v.split(" "),y="";for(let I of F){if(g.length>=u)break;(y+" "+I).trim().length<=r?y=(y+" "+I).trim():(y&&g.push(y),y=I);}y&&g.length<u&&g.push(y);}}return g.length<m.length&&g.length>0&&(g[g.length-1]=g[g.length-1].slice(0,r-15)+"... [truncated]"),c>0&&(i&&c===2&&g.push(n[n.length-2]),g.push(a)),g.join(`
|
|
32
|
+
`)}function ht(t,e,r){let n=[],a=" ".repeat(e);for(let[s,o]of Object.entries(t))if(o!=null)if(typeof o=="object"&&!Array.isArray(o))n.push(jsxs(Text,{children:[a,jsxs(Text,{color:"yellow",children:[s,":"]})]},s)),n.push(...ht(o,e+1,r));else if(Array.isArray(o))if(o.length===0)n.push(jsxs(Text,{children:[a,jsxs(Text,{color:"yellow",children:[s,":"]})," ",jsx(Text,{dimColor:true,children:"[]"})]},s));else if(typeof o[0]=="object"&&o[0]!==null)n.push(jsxs(Text,{children:[a,jsxs(Text,{color:"yellow",children:[s,":"]})," ",jsxs(Text,{dimColor:true,children:["[",o.length," items]"]})]},s)),o.slice(0,3).forEach((i,c)=>{let u=i.name||i.event||i.command||`[${c}]`;n.push(jsxs(Text,{children:[a," ",jsxs(Text,{dimColor:true,children:["\u2022 ",String(u).slice(0,r-e*2-6)]})]},`${s}-${c}`));}),o.length>3&&n.push(jsxs(Text,{children:[a," ",jsxs(Text,{dimColor:true,children:["... +",o.length-3," more"]})]},`${s}-more`));else {let i=o.length>5?`[${o.slice(0,5).join(", ")}... +${o.length-5}]`:`[${o.join(", ")}]`;n.push(jsxs(Text,{children:[a,jsxs(Text,{color:"yellow",children:[s,":"]})," ",i]},s));}else {let i=String(o),c=r-a.length-s.length-3,u=i.length>c?i.slice(0,c-3)+"...":i;n.push(jsxs(Text,{children:[a,jsxs(Text,{color:"yellow",children:[s,":"]})," ",u]},s));}return n}var Fr,yt=p(()=>{nt();lt();gt();Fr=[{key:"preview",label:"Preview"},{key:"summary",label:"AI Summary"}];});function vt(){let{provider:t,description:e}=V(),r=t!=="none";return jsxs(Box,{borderStyle:"single",paddingX:1,justifyContent:"space-between",children:[jsx(Text,{dimColor:true,children:"\u2191\u2193 Navigate \u2190\u2192 Switch r Refresh q Quit"}),jsx(Text,{color:r?"green":"yellow",children:r?`\u25CF ${e}`:`\u25CB ${e}`})]})}var St=p(()=>{we();});function kt(t=10){let e=Ae(),[r,n]=useState(()=>e.getRecent(t));return useEffect(()=>e.subscribe(s=>{n(s.slice(-t));}),[t,e]),r}var bt=p(()=>{k();});function Vr(t){switch(t){case "error":return "red";case "warn":return "yellow";case "info":return "cyan";case "debug":return "gray"}}function zr(t){switch(t){case "error":return "\u2717";case "warn":return "\u26A0";case "info":return "\u2022";case "debug":return "\u25CB"}}function Wr(t){return t.toLocaleTimeString("en-US",{hour12:false,hour:"2-digit",minute:"2-digit",second:"2-digit"})}function Ct({height:t=5}){let e=kt(t-1);return jsxs(Box,{flexDirection:"column",height:t,borderStyle:"single",borderColor:"gray",paddingX:1,children:[jsx(Text,{bold:true,dimColor:true,children:"LOG"}),e.length===0?jsx(Text,{dimColor:true,italic:true,children:"No logs yet"}):e.map((r,n)=>jsxs(Text,{wrap:"truncate",children:[jsx(Text,{dimColor:true,children:Wr(r.timestamp)})," ",jsx(Text,{color:Vr(r.level),children:zr(r.level)})," ",jsxs(Text,{dimColor:true,children:["[",r.source,"]"]})," ",jsx(Text,{color:r.level==="error"?"red":void 0,children:r.message})]},n))]})}var Tt=p(()=>{bt();});function Et({config:t,nav:e,width:r,height:n}){let o=r-22-30-6,i=6,c=Math.max(10,n-6-i);return jsxs(Box,{flexDirection:"column",width:r,children:[jsxs(Box,{borderStyle:"single",paddingX:1,children:[jsx(Text,{bold:true,color:"cyan",children:"ClaudeCode Dashboard"}),jsx(Box,{flexGrow:1}),jsx(Text,{dimColor:true,children:"Claude Code Config Viewer"})]}),jsxs(Box,{height:c,children:[jsx(Box,{flexDirection:"column",width:22,borderStyle:"single",paddingX:1,children:jsx(Ve,{categories:e.categories,selected:e.categoryIndex,focused:e.panel==="category"})}),jsx(Box,{flexDirection:"column",width:30,borderStyle:"single",paddingX:1,children:jsx(We,{items:e.currentItems,selected:e.itemIndex,focused:e.panel==="item",maxHeight:c-4})}),jsx(Box,{flexDirection:"column",width:o,borderStyle:"single",children:jsx(pt,{item:e.selectedItem,width:o,maxHeight:c-2,category:e.categories[e.categoryIndex]?.key})})]}),jsx(Ct,{height:i}),jsx(vt,{})]})}var Pt=p(()=>{ze();Ye();yt();St();Tt();});function At(){let[t,e]=useState({settings:null,skills:[],agents:[],commands:[],plugins:[],hooks:[],mcpServers:[],outputStyles:[]}),[r,n]=useState(true),[a,s]=useState(null),o=useCallback(async()=>{n(true),l.info("config","Loading configurations...");try{let[i,c,u,g,m,x,v]=await Promise.all([j(),N(),U(),B(),H(),_(),K()]);e({settings:i,skills:c,agents:u,commands:g,plugins:v,hooks:m,mcpServers:x,outputStyles:[]}),s(null),l.info("config",`Loaded: ${c.length} skills, ${u.length} agents, ${g.length} commands`);}catch(i){let c=i instanceof Error?i.message:"Failed to load config";l.error("config",`Load failed: ${c}`),s(c);}finally{n(false);}},[]);return useEffect(()=>{o();},[o]),{data:t,loading:r,error:a,refresh:o}}var It=p(()=>{se();k();});function Mt(t,e){let[r,n]=useState("category"),[a,s]=useState(()=>{if(!e)return 0;let m=["skills","agents","commands","hooks","mcp","plugins","settings"].indexOf(e);return m>=0?m:0}),[o,i]=useState(0),c=useMemo(()=>[{key:"skills",label:"Skills",count:t.data.skills.length},{key:"agents",label:"Agents",count:t.data.agents.length},{key:"commands",label:"Commands",count:t.data.commands.length},{key:"hooks",label:"Hooks",count:t.data.hooks.length},{key:"mcp",label:"MCP Servers",count:t.data.mcpServers.length},{key:"plugins",label:"Plugins",count:t.data.plugins.length},{key:"settings",label:"Settings",count:t.data.settings?1:0}],[t.data]),u=useMemo(()=>{let m=c[a];if(!m)return [];switch(m.key){case "skills":return t.data.skills;case "agents":return t.data.agents;case "commands":return t.data.commands;case "hooks":return t.data.hooks.map(x=>({...x,name:`${x.event}${x.matcher?`:${x.matcher}`:""}`}));case "mcp":return t.data.mcpServers;case "plugins":return t.data.plugins;case "settings":return t.data.settings?[{name:"Settings",...t.data.settings}]:[]}},[t.data,a,c]),g=u[o]??null;return {panel:r,categoryIndex:a,itemIndex:o,categories:c,currentItems:u,selectedItem:g,up:()=>{r==="category"?(s(m=>Math.max(0,m-1)),i(0)):i(m=>Math.max(0,m-1));},down:()=>{r==="category"?(s(m=>Math.min(c.length-1,m+1)),i(0)):i(m=>Math.min(u.length-1,m+1));},left:()=>n("category"),right:()=>n("item"),select:()=>{r==="category"&&n("item");},pageUp:()=>{r==="item"&&i(m=>Math.max(0,m-10));},pageDown:()=>{r==="item"&&i(m=>Math.min(u.length-1,m+10));}}}var $t=p(()=>{});var Ot={};jt(Ot,{App:()=>en});function en({initialCategory:t}){let{exit:e}=useApp(),{stdout:r}=useStdout(),n=At(),a=Mt(n,t);useInput((i,c)=>{i==="q"&&e(),i==="r"&&n.refresh(),(c.upArrow||i==="k")&&a.up(),(c.downArrow||i==="j")&&a.down(),(c.leftArrow||i==="h")&&a.left(),(c.rightArrow||i==="l")&&a.right(),c.return&&a.select(),(c.pageUp||i==="u")&&a.pageUp(),(c.pageDown||i==="d")&&a.pageDown();});let s=r?.columns??120,o=r?.rows??30;return s<80?jsxs(Box,{flexDirection:"column",padding:1,children:[jsxs(Text,{color:"yellow",children:["Terminal too narrow (",s," cols)"]}),jsx(Text,{children:"Minimum 80 columns required."}),jsx(Text,{dimColor:true,children:"Press q to quit."})]}):n.loading?jsxs(Box,{padding:1,children:[jsx(Text,{color:"cyan",children:jsx(dt,{type:"dots"})}),jsx(Text,{children:" Loading configurations..."})]}):n.error?jsxs(Box,{flexDirection:"column",padding:1,children:[jsxs(Text,{color:"red",children:["Error: ",n.error]}),jsx(Text,{dimColor:true,children:"Press r to retry, q to quit."})]}):jsx(Et,{config:n.data,nav:a,width:Math.min(s,160),height:o})}var Rt=p(()=>{Pt();It();$t();});se();async function Ke(t){let e=t?.toLowerCase()??"all";try{let r=await ur(e);console.log(JSON.stringify(r,null,2)),process.exit(0);}catch(r){console.error(JSON.stringify({error:r instanceof Error?r.message:"Unknown error"})),process.exit(1);}}async function ur(t){switch(t){case "skills":return N();case "agents":return U();case "commands":return B();case "hooks":return H();case "mcp":return _();case "plugins":return K();case "settings":return j();default:return gr()}}async function gr(){let[t,e,r,n,a,s,o]=await Promise.all([j(),N(),U(),B(),H(),_(),K()]);return {settings:t,skills:e,agents:r,commands:n,plugins:o,hooks:a,mcpServers:s,outputStyles:[]}}var rn=new Command().name("claudecode-dashboard").description("View Claude Code configurations").version("1.0.0").argument("[category]","Category to show (skills, agents, commands, hooks, mcp, plugins, settings)").option("-j, --json","Output as JSON instead of TUI").action(async(t,e)=>{e.json?await Ke(t||"all"):await nn(t);});async function nn(t){let{render:e}=await import('ink'),r=await import('react'),{App:n}=await Promise.resolve().then(()=>(Rt(),Ot));e(r.createElement(n,{initialCategory:t}));}rn.parse();
|