@hienlh/ppm 0.8.37 → 0.8.39

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.
Files changed (55) hide show
  1. package/CHANGELOG.md +11 -0
  2. package/README.md +7 -1
  3. package/dist/web/assets/{api-client-Bs-0pRox.js → api-client-B0aMOJxF.js} +1 -1
  4. package/dist/web/assets/{api-settings-D42qxHtn.js → api-settings-0Hx_9lIU.js} +1 -1
  5. package/dist/web/assets/chat-tab-CGic5t8w.js +7 -0
  6. package/dist/web/assets/code-editor-DZlXHMtA.js +1 -0
  7. package/dist/web/assets/columns-2-BZ5wv2wA.js +1 -0
  8. package/dist/web/assets/database-viewer-BaxjPtYR.js +1 -0
  9. package/dist/web/assets/diff-viewer-CDdO3tqP.js +4 -0
  10. package/dist/web/assets/{dist-CU2je4l7.js → dist-QgqOdSYG.js} +2 -2
  11. package/dist/web/assets/git-graph-C-TRbbx7.js +1 -0
  12. package/dist/web/assets/index-CvbNQ1mi.js +28 -0
  13. package/dist/web/assets/input-4ElbicvY.js +41 -0
  14. package/dist/web/assets/jsx-runtime-wQxeESYQ.js +1 -0
  15. package/dist/web/assets/keybindings-store-Dqs-i9cV.js +1 -0
  16. package/dist/web/assets/{markdown-renderer-DmuIK1-X.js → markdown-renderer-DE503g9L.js} +2 -2
  17. package/dist/web/assets/postgres-viewer-hmqfZRr-.js +1 -0
  18. package/dist/web/assets/react-CYzKIDNi.js +1 -0
  19. package/dist/web/assets/{react-Dhei_cB0.js → react-Dk7fkoaB.js} +1 -1
  20. package/dist/web/assets/{settings-store-CIOAyrzs.js → settings-store-Clv3ZNje.js} +2 -2
  21. package/dist/web/assets/settings-tab-BdgsQeES.js +1 -0
  22. package/dist/web/assets/sqlite-viewer-9X_1ZHJE.js +1 -0
  23. package/dist/web/assets/tab-store-D7tRt0VT.js +1 -0
  24. package/dist/web/assets/table-B6neW6Hr.js +1 -0
  25. package/dist/web/assets/{terminal-tab-ZMG3urJd.js → terminal-tab-V7x81Qpr.js} +2 -2
  26. package/dist/web/assets/{use-monaco-theme-D6807XbV.js → use-monaco-theme-czriskTO.js} +1 -1
  27. package/dist/web/index.html +10 -11
  28. package/dist/web/sw.js +1 -1
  29. package/package.json +1 -1
  30. package/scripts/install.ps1 +116 -0
  31. package/scripts/install.sh +8 -15
  32. package/scripts/release.sh +34 -7
  33. package/src/cli/commands/restart.ts +5 -1
  34. package/src/server/index.ts +9 -16
  35. package/src/server/routes/static.ts +7 -2
  36. package/src/server/routes/tunnel.ts +0 -14
  37. package/src/services/tunnel.service.ts +22 -0
  38. package/dist/web/assets/chat-tab-DesJNGlM.js +0 -7
  39. package/dist/web/assets/code-editor-BJSi0tN8.js +0 -1
  40. package/dist/web/assets/columns-2-BSNHGqVP.js +0 -1
  41. package/dist/web/assets/database-viewer-BRtti__1.js +0 -1
  42. package/dist/web/assets/diff-viewer-BtqxNPvT.js +0 -4
  43. package/dist/web/assets/git-graph-BwaH1gCr.js +0 -1
  44. package/dist/web/assets/index-cCRyobYW.js +0 -237
  45. package/dist/web/assets/input-D3FZB4A8.js +0 -45
  46. package/dist/web/assets/jsx-dev-runtime-B0R0R7SH.js +0 -6
  47. package/dist/web/assets/jsx-runtime-CdTrtNt5.js +0 -6
  48. package/dist/web/assets/keybindings-store-EctjzvyI.js +0 -1
  49. package/dist/web/assets/postgres-viewer-BToBpDFs.js +0 -1
  50. package/dist/web/assets/react-4j_0SqET.js +0 -13
  51. package/dist/web/assets/settings-tab-CIM3X82k.js +0 -1
  52. package/dist/web/assets/sqlite-viewer-CSsYLA1Q.js +0 -1
  53. package/dist/web/assets/tab-store-HCmwXLYA.js +0 -1
  54. package/dist/web/assets/table-CSrbr8mU.js +0 -1
  55. /package/dist/web/assets/{utils-DC-bdPS3.js → utils-DBpa1UZX.js} +0 -0
@@ -1,7 +0,0 @@
1
- const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/api-client-Bs-0pRox.js","assets/react-4j_0SqET.js"])))=>i.map(i=>d[i]);
2
- import{i as e,t}from"./react-4j_0SqET.js";import{A as n,M as r,N as i,j as a}from"./input-D3FZB4A8.js";import{n as o,t as s}from"./jsx-dev-runtime-B0R0R7SH.js";import{t as c}from"./columns-2-BSNHGqVP.js";import{a as l,n as u,t as d}from"./tab-store-HCmwXLYA.js";import{n as f,r as p}from"./settings-store-CIOAyrzs.js";import"./jsx-runtime-CdTrtNt5.js";import{r as m,t as h}from"./utils-DC-bdPS3.js";import{i as g,r as _,t as v}from"./api-client-Bs-0pRox.js";import{a as y,c as b,f as x,h as S,l as C,s as w}from"./api-settings-D42qxHtn.js";import{C as T,D as E,F as D,G as O,I as k,J as A,M as j,O as M,P as N,R as P,T as F,U as I,W as L,_ as ee,i as R,j as te,k as ne,q as z,r as re,t as ie}from"./index-cCRyobYW.js";import{t as ae}from"./markdown-renderer-DmuIK1-X.js";var oe=o(`activity`,[[`path`,{d:`M22 12h-2.48a2 2 0 0 0-1.93 1.46l-2.35 8.36a.25.25 0 0 1-.48 0L9.24 2.18a.25.25 0 0 0-.48 0l-2.35 8.36A2 2 0 0 1 4.49 12H2`,key:`169zse`}]]),se=o(`arrow-up`,[[`path`,{d:`m5 12 7-7 7 7`,key:`hav0vg`}],[`path`,{d:`M12 19V5`,key:`x0mq9r`}]]),ce=o(`circle-x`,[[`circle`,{cx:`12`,cy:`12`,r:`10`,key:`1mglay`}],[`path`,{d:`m15 9-6 6`,key:`1uzhvr`}],[`path`,{d:`m9 9 6 6`,key:`z0biqf`}]]),le=o(`clipboard-list`,[[`rect`,{width:`8`,height:`4`,x:`8`,y:`2`,rx:`1`,ry:`1`,key:`tgr4d6`}],[`path`,{d:`M16 4h2a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2h2`,key:`116196`}],[`path`,{d:`M12 11h4`,key:`1jrz19`}],[`path`,{d:`M12 16h4`,key:`n85exb`}],[`path`,{d:`M8 11h.01`,key:`1dfujw`}],[`path`,{d:`M8 16h.01`,key:`18s6g9`}]]),ue=o(`code`,[[`path`,{d:`m16 18 6-6-6-6`,key:`eg8j8`}],[`path`,{d:`m8 6-6 6 6 6`,key:`ppft3o`}]]),de=o(`globe`,[[`circle`,{cx:`12`,cy:`12`,r:`10`,key:`1mglay`}],[`path`,{d:`M12 2a14.5 14.5 0 0 0 0 20 14.5 14.5 0 0 0 0-20`,key:`13o1zl`}],[`path`,{d:`M2 12h20`,key:`9i4pu4`}]]),fe=o(`hand`,[[`path`,{d:`M18 11V6a2 2 0 0 0-2-2a2 2 0 0 0-2 2`,key:`1fvzgz`}],[`path`,{d:`M14 10V4a2 2 0 0 0-2-2a2 2 0 0 0-2 2v2`,key:`1kc0my`}],[`path`,{d:`M10 10.5V6a2 2 0 0 0-2-2a2 2 0 0 0-2 2v8`,key:`10h0bg`}],[`path`,{d:`M18 8a2 2 0 1 1 4 0v6a8 8 0 0 1-8 8h-2c-2.8 0-4.5-.86-5.99-2.34l-3.6-3.6a2 2 0 0 1 2.83-2.82L7 15`,key:`1s1gnw`}]]),pe=o(`history`,[[`path`,{d:`M3 12a9 9 0 1 0 9-9 9.75 9.75 0 0 0-6.74 2.74L3 8`,key:`1357e3`}],[`path`,{d:`M3 3v5h5`,key:`1xhq8a`}],[`path`,{d:`M12 7v5l4 2`,key:`1fdv2h`}]]),me=o(`image`,[[`rect`,{width:`18`,height:`18`,x:`3`,y:`3`,rx:`2`,ry:`2`,key:`1m3agn`}],[`circle`,{cx:`9`,cy:`9`,r:`2`,key:`af1f0g`}],[`path`,{d:`m21 15-3.086-3.086a2 2 0 0 0-2.828 0L6 21`,key:`1xmnt7`}]]),he=o(`list-todo`,[[`path`,{d:`M13 5h8`,key:`a7qcls`}],[`path`,{d:`M13 12h8`,key:`h98zly`}],[`path`,{d:`M13 19h8`,key:`c3s6r1`}],[`path`,{d:`m3 17 2 2 4-4`,key:`1jhpwq`}],[`rect`,{x:`3`,y:`4`,width:`6`,height:`6`,rx:`1`,key:`cif1o7`}]]),ge=o(`paperclip`,[[`path`,{d:`m16 6-8.414 8.586a2 2 0 0 0 2.829 2.829l8.414-8.586a4 4 0 1 0-5.657-5.657l-8.379 8.551a6 6 0 1 0 8.485 8.485l8.379-8.551`,key:`1miecu`}]]),_e=o(`settings-2`,[[`path`,{d:`M14 17H5`,key:`gfn3mx`}],[`path`,{d:`M19 7h-9`,key:`6i9tg`}],[`circle`,{cx:`17`,cy:`17`,r:`3`,key:`18b49y`}],[`circle`,{cx:`7`,cy:`7`,r:`3`,key:`dfmy0x`}]]),ve=o(`shield-alert`,[[`path`,{d:`M20 13c0 5-3.5 7.5-7.66 8.95a1 1 0 0 1-.67-.01C7.5 20.5 4 18 4 13V6a1 1 0 0 1 1-1c2 0 4.5-1.2 6.24-2.72a1.17 1.17 0 0 1 1.52 0C14.51 3.81 17 5 19 5a1 1 0 0 1 1 1z`,key:`oel41y`}],[`path`,{d:`M12 8v4`,key:`1got3b`}],[`path`,{d:`M12 16h.01`,key:`1drbdi`}]]),ye=o(`shield-check`,[[`path`,{d:`M20 13c0 5-3.5 7.5-7.66 8.95a1 1 0 0 1-.67-.01C7.5 20.5 4 18 4 13V6a1 1 0 0 1 1-1c2 0 4.5-1.2 6.24-2.72a1.17 1.17 0 0 1 1.52 0C14.51 3.81 17 5 19 5a1 1 0 0 1 1 1z`,key:`oel41y`}],[`path`,{d:`m9 12 2 2 4-4`,key:`dzmm74`}]]),be=o(`shield-off`,[[`path`,{d:`m2 2 20 20`,key:`1ooewy`}],[`path`,{d:`M5 5a1 1 0 0 0-1 1v7c0 5 3.5 7.5 7.67 8.94a1 1 0 0 0 .67.01c2.35-.82 4.48-1.97 5.9-3.71`,key:`1jlk70`}],[`path`,{d:`M9.309 3.652A12.252 12.252 0 0 0 11.24 2.28a1.17 1.17 0 0 1 1.52 0C14.51 3.81 17 5 19 5a1 1 0 0 1 1 1v7a9.784 9.784 0 0 1-.08 1.264`,key:`18rp1v`}]]),xe=o(`sparkles`,[[`path`,{d:`M11.017 2.814a1 1 0 0 1 1.966 0l1.051 5.558a2 2 0 0 0 1.594 1.594l5.558 1.051a1 1 0 0 1 0 1.966l-5.558 1.051a2 2 0 0 0-1.594 1.594l-1.051 5.558a1 1 0 0 1-1.966 0l-1.051-5.558a2 2 0 0 0-1.594-1.594l-5.558-1.051a1 1 0 0 1 0-1.966l5.558-1.051a2 2 0 0 0 1.594-1.594z`,key:`1s2grr`}],[`path`,{d:`M20 2v4`,key:`1rf3ol`}],[`path`,{d:`M22 4h-4`,key:`gwowj6`}],[`circle`,{cx:`4`,cy:`20`,r:`2`,key:`6kqj1y`}]]),Se=o(`square`,[[`rect`,{width:`18`,height:`18`,x:`3`,y:`3`,rx:`2`,key:`afitv7`}]]),B=e(t(),1),Ce=3e4,we=1e3,Te=class{ws=null;url;handlers=[];reconnectAttempts=0;reconnectTimer=null;intentionalClose=!1;pendingMessages=[];constructor(e){this.url=e}connect(){this.intentionalClose=!1,this.cleanup();let e=window.location.protocol===`https:`?`wss:`:`ws:`,t=this.url.startsWith(`ws`)?this.url:`${e}//${window.location.host}${this.url}`;this.ws=new WebSocket(t),this.ws.onopen=()=>{this.reconnectAttempts=0;try{this.ws?.send(JSON.stringify({type:`ready`}))}catch{}if(this.pendingMessages.length>0){console.log(`[ws] flushing ${this.pendingMessages.length} queued message(s)`);for(let e of this.pendingMessages)try{this.ws?.send(e)}catch{}this.pendingMessages=[]}},this.ws.onmessage=e=>{for(let t of this.handlers)t(e)},this.ws.onclose=()=>{this.intentionalClose||this.scheduleReconnect()},this.ws.onerror=()=>{this.ws?.close()}}disconnect(){this.intentionalClose=!0,this.pendingMessages=[],this.cleanup(),this.reconnectTimer&&=(clearTimeout(this.reconnectTimer),null)}send(e){this.ws?.readyState===WebSocket.OPEN?this.ws.send(e):this.ws?.readyState===WebSocket.CONNECTING?(console.warn(`[ws] WS still CONNECTING — queuing message`),this.pendingMessages.push(e)):console.warn(`[ws] message dropped — readyState=${this.ws?.readyState??`no-ws`}`)}onMessage(e){return this.handlers.push(e),()=>{this.handlers=this.handlers.filter(t=>t!==e)}}get isConnected(){return this.ws?.readyState===WebSocket.OPEN}cleanup(){this.ws&&=(this.ws.onopen=null,this.ws.onclose=null,this.ws.onmessage=null,this.ws.onerror=null,(this.ws.readyState===WebSocket.OPEN||this.ws.readyState===WebSocket.CONNECTING)&&this.ws.close(),null)}scheduleReconnect(){let e=Math.min(we*2**this.reconnectAttempts,Ce);this.reconnectAttempts++,this.reconnectTimer=setTimeout(()=>this.connect(),e)}};function Ee({url:e,onMessage:t,autoConnect:n=!0}){let r=(0,B.useRef)(null);return(0,B.useEffect)(()=>{let i=new Te(e);return r.current=i,t&&i.onMessage(t),n&&i.connect(),()=>{i.disconnect(),r.current=null}},[e,n]),{send:(0,B.useCallback)(e=>{r.current?.send(e)},[]),connect:(0,B.useCallback)(()=>{r.current?.connect()},[]),disconnect:(0,B.useCallback)(()=>{r.current?.disconnect()},[])}}var De=null;function Oe(){return De||=new AudioContext,De}function V(e,t,n,r,i=`sine`){let a=Oe(),o=a.createOscillator(),s=a.createGain();o.type=i,o.frequency.value=e,s.gain.setValueAtTime(r,n),s.gain.exponentialRampToValueAtTime(.001,n+t),o.connect(s),s.connect(a.destination),o.start(n),o.stop(n+t)}function ke(){let e=Oe().currentTime;V(523,.15,e,.15),V(659,.2,e+.12,.15)}function Ae(){let e=Oe().currentTime;V(880,.12,e,.18,`square`),V(698,.12,e+.15,.18,`square`),V(880,.15,e+.3,.15,`square`)}function je(){let e=Oe().currentTime;V(440,.12,e,.12),V(523,.12,e+.1,.12),V(659,.18,e+.2,.12)}var Me={done:ke,approval_request:Ae,question:je};function Ne(e){try{Me[e]?.()}catch{}}function Pe(e){if(document.hidden)return!1;let{panels:t,focusedPanelId:n}=u.getState(),r=t[n];if(!r)return!1;let i=r.tabs.find(e=>e.id===r.activeTabId);return i?.type===`chat`&&i.metadata?.sessionId===e}function Fe(e,t=`claude`,n=``){let[r,i]=(0,B.useState)([]),[a,o]=(0,B.useState)(!1),[s,c]=(0,B.useState)(!1),[l,u]=(0,B.useState)(`idle`),[d,f]=(0,B.useState)(0),[p,m]=(0,B.useState)(15),[h,v]=(0,B.useState)(null),[y,b]=(0,B.useState)(null),[x,S]=(0,B.useState)(null),[C,w]=(0,B.useState)(!1),T=(0,B.useRef)(``),E=(0,B.useRef)([]),D=(0,B.useRef)(null),O=(0,B.useRef)(!1),k=(0,B.useRef)(null),A=(0,B.useRef)(()=>{}),j=(0,B.useRef)(null),M=(0,B.useRef)(e);M.current=e;let N=(0,B.useRef)(n);N.current=n;let P=(0,B.useCallback)(e=>{let t;try{t=JSON.parse(e.data)}catch{return}if(t.type===`ping`)return;if(t.type===`title_updated`){S(t.title??null);return}if(t.type===`streaming_status`){let e=t.status??`idle`;if(u(e),f(e===`connecting`?t.elapsed??0:0),e===`connecting`){let e=t.effort,n=t.thinkingBudget,r=15;n&&n>0?r=Math.max(15,Math.round(n/500)):e===`high`?r=30:e===`low`&&(r=10),m(r)}return}if(t.type===`connected`){w(!0),t.sessionTitle&&S(t.sessionTitle);return}if(t.type===`status`){w(!0);let e=t;e.sessionTitle&&S(e.sessionTitle),e.isStreaming&&(O.current=!0,c(!0)),e.pendingApproval&&v({requestId:e.pendingApproval.requestId,tool:e.pendingApproval.tool,input:e.pendingApproval.input}),j.current?.();return}let n=(e,t)=>{let n=E.current.findIndex(e=>e.type===`tool_use`&&(e.tool===`Agent`||e.tool===`Task`)&&e.toolUseId===t);if(n===-1)return!1;let r=E.current[n];if(r.type!==`tool_use`)return!1;let i=[...r.children??[],e];return E.current[n]={...r,children:i},!0},r=()=>{let e=T.current,t=[...E.current],n=D.current;i(r=>{let i=r[r.length-1];return i?.role===`assistant`&&!i.id.startsWith(`final-`)?[...r.slice(0,-1),{...i,content:e,events:t,...n}]:[...r,{id:`streaming-${Date.now()}`,role:`assistant`,content:e,events:t,timestamp:new Date().toISOString(),...n}]})};switch(t.type){case`account_info`:D.current={accountId:t.accountId,accountLabel:t.accountLabel};break;case`text`:{let e=t.parentToolUseId;if(e&&n(t,e)){r();break}T.current+=t.content,E.current.push(t),r();break}case`thinking`:{let e=t.parentToolUseId;if(e&&n(t,e)){r();break}E.current.push(t),r();break}case`tool_use`:{let e=t.parentToolUseId;if(e&&n(t,e)){r();break}E.current.push(t),r();break}case`tool_result`:{let e=t.parentToolUseId;if(e&&n(t,e)){r();break}E.current.push(t),r();break}case`approval_request`:if(E.current.push(t),v({requestId:t.requestId,tool:t.tool,input:t.input}),M.current&&!Pe(M.current)){let e=t.tool===`AskUserQuestion`?`question`:`approval_request`;ee.getState().addNotification(M.current,e,N.current),Ne(e)}break;case`error`:{E.current.push(t);let e=[...E.current];i(n=>{let r=n[n.length-1];return r?.role===`assistant`?[...n.slice(0,-1),{...r,events:e}]:[...n,{id:`error-${Date.now()}`,role:`system`,content:t.message,events:[t],timestamp:new Date().toISOString()}]}),O.current=!1,c(!1),u(`idle`);break}case`done`:{if(!O.current)break;t.contextWindowPct!=null&&b(t.contextWindowPct),M.current&&!Pe(M.current)&&(ee.getState().addNotification(M.current,`done`,N.current),Ne(`done`));let e=T.current,n=[...E.current];i(t=>{let r=t[t.length-1];return r?.role===`assistant`?[...t.slice(0,-1),{...r,id:`final-${Date.now()}`,content:e||r.content,events:n.length>0?n:r.events}]:t}),T.current=``,E.current=[],D.current=null,O.current=!1,c(!1),u(`idle`);break}}},[]),{send:F,connect:I}=Ee({url:e&&n?`/ws/project/${encodeURIComponent(n)}/chat/${e}`:``,onMessage:P,autoConnect:!!e&&!!n});A.current=F,(0,B.useEffect)(()=>{let r=!1;return c(!1),v(null),T.current=``,E.current=[],w(!1),e&&n?(o(!0),fetch(`${g(n)}/chat/sessions/${e}/messages?providerId=${t}`,{headers:{Authorization:`Bearer ${_()}`}}).then(e=>e.json()).then(e=>{r||O.current||(e.ok&&Array.isArray(e.data)&&e.data.length>0?i(e.data):i([]))}).catch(()=>{!r&&!O.current&&i([])}).finally(()=>{r||o(!1)})):i([]),()=>{r=!0}},[e,t,n]);let L=(0,B.useCallback)((e,t)=>{if(e.trim()){if(O.current){let e=T.current,t=[...E.current];i(n=>{let r=n[n.length-1];return r?.role===`assistant`?[...n.slice(0,-1),{...r,id:`final-${Date.now()}`,content:e||r.content,events:t.length>0?t:r.events}]:n}),F(JSON.stringify({type:`cancel`}))}i(t=>[...t,{id:`user-${Date.now()}`,role:`user`,content:e,timestamp:new Date().toISOString()}]),T.current=``,E.current=[],k.current=null,O.current=!0,c(!0),u(`connecting`),v(null),F(JSON.stringify({type:`message`,content:e,permissionMode:t?.permissionMode}))}},[F]),R=(0,B.useCallback)((e,t,n)=>{if(F(JSON.stringify({type:`approval_response`,requestId:e,approved:t,data:n})),t&&n){let t=E.current.find(t=>t.type===`approval_request`&&t.requestId===e&&t.tool===`AskUserQuestion`);if(t){let e=t.input;e&&typeof e==`object`&&(e.answers=n)}i(e=>[...e])}v(null)},[F]),te=(0,B.useCallback)(()=>{if(!O.current)return;F(JSON.stringify({type:`cancel`}));let e=T.current,t=[...E.current];i(n=>{let r=n[n.length-1];return r?.role===`assistant`?[...n.slice(0,-1),{...r,id:`final-${Date.now()}`,content:e||r.content,events:t.length>0?t:r.events}]:n}),T.current=``,E.current=[],k.current=null,O.current=!1,c(!1),v(null)},[F]),ne=(0,B.useCallback)(()=>{w(!1),I(),j.current?.()},[I]),z=(0,B.useCallback)(()=>{!e||!n||(o(!0),fetch(`${g(n)}/chat/sessions/${e}/messages?providerId=${t}`,{headers:{Authorization:`Bearer ${_()}`}}).then(e=>e.json()).then(e=>{e.ok&&Array.isArray(e.data)&&e.data.length>0&&(i(e.data),T.current=``,E.current=[])}).catch(()=>{}).finally(()=>o(!1)))},[e,t,n]);return j.current=z,{messages:r,messagesLoading:a,isStreaming:s,streamingStatus:l,connectingElapsed:d,thinkingWarningThreshold:p,pendingApproval:h,contextWindowPct:y,sessionTitle:x,sendMessage:L,respondToApproval:R,cancelStreaming:te,reconnect:ne,refetchMessages:z,isConnected:C}}var Ie=12e4;function Le(e,t=`claude`){let[n,r]=(0,B.useState)({}),[i,a]=(0,B.useState)(!1),[o,s]=(0,B.useState)(null),c=(0,B.useRef)(null),l=(0,B.useCallback)((n=!1)=>{if(!e)return;a(!0);let i=n?`&refresh=1`:``;fetch(`${g(e)}/chat/usage?providerId=${t}${i}`,{headers:{Authorization:`Bearer ${_()}`}}).then(e=>e.json()).then(e=>{e.ok&&e.data&&(r(t=>({...t,...e.data})),e.data.lastFetchedAt&&s(e.data.lastFetchedAt))}).catch(()=>{}).finally(()=>a(!1))},[e,t]);return(0,B.useEffect)(()=>(l(),c.current=setInterval(()=>l(),Ie),()=>{c.current&&clearInterval(c.current)}),[l]),{usageInfo:n,usageLoading:i,lastFetchedAt:o,refreshUsage:(0,B.useCallback)(()=>l(!0),[l])}}var Re={damping:.7,stiffness:.05,mass:1.25},ze=70,Be=1e3/60,Ve=350,He=!1;globalThis.document?.addEventListener(`mousedown`,()=>{He=!0}),globalThis.document?.addEventListener(`mouseup`,()=>{He=!1}),globalThis.document?.addEventListener(`click`,()=>{He=!1});var Ue=(e={})=>{let[t,n]=(0,B.useState)(!1),[r,i]=(0,B.useState)(e.initial!==!1),[a,o]=(0,B.useState)(!1),s=(0,B.useRef)(null);s.current=e;let c=(0,B.useCallback)(()=>{if(!He)return!1;let e=window.getSelection();if(!e||!e.rangeCount)return!1;let t=e.getRangeAt(0);return t.commonAncestorContainer.contains(g.current)||g.current?.contains(t.commonAncestorContainer)},[]),l=(0,B.useCallback)(e=>{d.isAtBottom=e,i(e)},[]),u=(0,B.useCallback)(e=>{d.escapedFromLock=e,n(e)},[]),d=(0,B.useMemo)(()=>{let n;return{escapedFromLock:t,isAtBottom:r,resizeDifference:0,accumulated:0,velocity:0,listeners:new Set,get scrollTop(){return g.current?.scrollTop??0},set scrollTop(e){g.current&&(g.current.scrollTop=e,d.ignoreScrollToTop=g.current.scrollTop)},get targetScrollTop(){return!g.current||!_.current?0:g.current.scrollHeight-1-g.current.clientHeight},get calculatedTargetScrollTop(){if(!g.current||!_.current)return 0;let{targetScrollTop:t}=this;if(!e.targetScrollTop)return t;if(n?.targetScrollTop===t)return n.calculatedScrollTop;let r=Math.max(Math.min(e.targetScrollTop(t,{scrollElement:g.current,contentElement:_.current}),t),0);return n={targetScrollTop:t,calculatedScrollTop:r},requestAnimationFrame(()=>{n=void 0}),r},get scrollDifference(){return this.calculatedTargetScrollTop-this.scrollTop},get isNearBottom(){return this.scrollDifference<=ze}}},[]),f=(0,B.useCallback)((e={})=>{typeof e==`string`&&(e={animation:e}),e.preserveScrollPosition||l(!0);let t=Date.now()+(Number(e.wait)||0),n=Ke(s.current,e.animation),{ignoreEscapes:r=!1}=e,i,a=d.calculatedTargetScrollTop;e.duration instanceof Promise?e.duration.finally(()=>{i=Date.now()}):i=t+(e.duration??0);let o=async()=>{let e=new Promise(requestAnimationFrame).then(()=>{if(!d.isAtBottom)return d.animation=void 0,!1;let{scrollTop:l}=d,u=performance.now(),p=(u-(d.lastTick??u))/Be;if(d.animation||={behavior:n,promise:e,ignoreEscapes:r},d.animation.behavior===n&&(d.lastTick=u),c()||t>Date.now())return o();if(l<Math.min(a,d.calculatedTargetScrollTop)){if(d.animation?.behavior===n){if(n===`instant`)return d.scrollTop=d.calculatedTargetScrollTop,o();d.velocity=(n.damping*d.velocity+n.stiffness*d.scrollDifference)/n.mass,d.accumulated+=d.velocity*p,d.scrollTop+=d.accumulated,d.scrollTop!==l&&(d.accumulated=0)}return o()}return i>Date.now()?(a=d.calculatedTargetScrollTop,o()):(d.animation=void 0,d.scrollTop<d.calculatedTargetScrollTop?f({animation:Ke(s.current,s.current.resize),ignoreEscapes:r,duration:Math.max(0,i-Date.now())||void 0}):d.isAtBottom)});return e.then(e=>(requestAnimationFrame(()=>{d.animation||(d.lastTick=void 0,d.velocity=0)}),e))};return e.wait!==!0&&(d.animation=void 0),d.animation?.behavior===n?d.animation.promise:o()},[l,c,d]),p=(0,B.useCallback)(()=>{u(!0),l(!1)},[u,l]),m=(0,B.useCallback)(({target:e})=>{if(e!==g.current)return;let{scrollTop:t,ignoreScrollToTop:n}=d,{lastScrollTop:r=t}=d;d.lastScrollTop=t,d.ignoreScrollToTop=void 0,n&&n>t&&(r=n),o(d.isNearBottom),setTimeout(()=>{if(d.resizeDifference||t===n)return;if(c()){u(!0),l(!1);return}let e=t>r,i=t<r;if(d.animation?.ignoreEscapes){d.scrollTop=r;return}i&&(u(!0),l(!1)),e&&u(!1),!d.escapedFromLock&&d.isNearBottom&&l(!0)},1)},[u,l,c,d]),h=(0,B.useCallback)(({target:e,deltaY:t})=>{let n=e;for(;![`scroll`,`auto`].includes(getComputedStyle(n).overflow);){if(!n.parentElement)return;n=n.parentElement}n===g.current&&t<0&&g.current.scrollHeight>g.current.clientHeight&&!d.animation?.ignoreEscapes&&(u(!0),l(!1))},[u,l,d]),g=We(e=>{g.current?.removeEventListener(`scroll`,m),g.current?.removeEventListener(`wheel`,h),e?.addEventListener(`scroll`,m,{passive:!0}),e?.addEventListener(`wheel`,h,{passive:!0})},[]),_=We(e=>{if(d.resizeObserver?.disconnect(),!e)return;let t;d.resizeObserver=new ResizeObserver(([e])=>{let{height:n}=e.contentRect,r=n-(t??n);if(d.resizeDifference=r,d.scrollTop>d.targetScrollTop&&(d.scrollTop=d.targetScrollTop),o(d.isNearBottom),r>=0){let e=Ke(s.current,t?s.current.resize:s.current.initial);f({animation:e,wait:!0,preserveScrollPosition:!0,duration:e===`instant`?void 0:Ve})}else d.isNearBottom&&(u(!1),l(!0));t=n,requestAnimationFrame(()=>{setTimeout(()=>{d.resizeDifference===r&&(d.resizeDifference=0)},1)})}),d.resizeObserver?.observe(e)},[]);return{contentRef:_,scrollRef:g,scrollToBottom:f,stopScroll:p,isAtBottom:r||a,isNearBottom:a,escapedFromLock:t,state:d}};function We(e,t){let n=(0,B.useCallback)(t=>(n.current=t,e(t)),t);return n}var Ge=new Map;function Ke(...e){let t={...Re},n=!1;for(let r of e){if(r===`instant`){n=!0;continue}typeof r==`object`&&(n=!1,t.damping=r.damping??t.damping,t.stiffness=r.stiffness??t.stiffness,t.mass=r.mass??t.mass)}let r=JSON.stringify(t);return Ge.has(r)||Ge.set(r,Object.freeze(t)),n?`instant`:Ge.get(r)}var qe=(0,B.createContext)(null),Je=typeof window<`u`?B.useLayoutEffect:B.useEffect;function Ye({instance:e,children:t,resize:n,initial:r,mass:i,damping:a,stiffness:o,targetScrollTop:s,contextRef:c,...l}){let u=(0,B.useRef)(null),d=Ue({mass:i,damping:a,stiffness:o,resize:n,initial:r,targetScrollTop:B.useCallback((e,t)=>(y?.targetScrollTop??s)?.(e,t)??e,[s])}),{scrollRef:f,contentRef:p,scrollToBottom:m,stopScroll:h,isAtBottom:g,escapedFromLock:_,state:v}=e??d,y=(0,B.useMemo)(()=>({scrollToBottom:m,stopScroll:h,scrollRef:f,isAtBottom:g,escapedFromLock:_,contentRef:p,state:v,get targetScrollTop(){return u.current},set targetScrollTop(e){u.current=e}}),[m,g,p,f,h,_,v]);return(0,B.useImperativeHandle)(c,()=>y,[y]),Je(()=>{f.current&&getComputedStyle(f.current).overflow===`visible`&&(f.current.style.overflow=`auto`)},[]),B.createElement(qe.Provider,{value:y},B.createElement(`div`,{...l},typeof t==`function`?t(y):t))}(function(e){function t({children:e,scrollClassName:t,...n}){let r=Xe();return B.createElement(`div`,{ref:r.scrollRef,style:{height:`100%`,width:`100%`,scrollbarGutter:`stable both-edges`},className:t},B.createElement(`div`,{...n,ref:r.contentRef},typeof e==`function`?e(r):e))}e.Content=t})(Ye||={});function Xe(){let e=(0,B.useContext)(qe);if(!e)throw Error(`use-stick-to-bottom component context must be used within a StickToBottom component`);return e}var H=s(),U=`/Users/hienlh/Projects/ppm/src/web/components/chat/tool-cards.tsx`;function Ze(e){let t=e.type===`approval_request`;return{toolName:e.type===`tool_use`?e.tool:t?e.tool??`Tool`:`Tool`,input:e.type===`tool_use`?e.input:t?e.input??{}:{}}}function Qe({tool:e,result:t,completed:n,projectName:i}){let[a,o]=(0,B.useState)(!1);if(e.type===`error`)return(0,H.jsxDEV)(`div`,{className:`flex items-center gap-2 rounded bg-red-500/10 border border-red-500/20 px-2 py-1.5 text-xs text-red-400`,children:[(0,H.jsxDEV)(L,{className:`size-3`},void 0,!1,{fileName:U,lineNumber:59,columnNumber:9},this),(0,H.jsxDEV)(`span`,{children:e.message},void 0,!1,{fileName:U,lineNumber:60,columnNumber:9},this)]},void 0,!0,{fileName:U,lineNumber:58,columnNumber:7},this);let{toolName:s,input:c}=Ze(e),l=t?.type===`tool_result`,u=l&&!!t.isError,d=s===`AskUserQuestion`&&!!c?.answers,f=(s===`Agent`||s===`Task`)&&e.type===`tool_use`,p=f?e.children:void 0,m=p&&p.length>0;return(0,H.jsxDEV)(`div`,{className:`rounded border text-xs ${f?`border-accent/30 bg-accent/5`:`border-border bg-background`}`,children:[(0,H.jsxDEV)(`button`,{onClick:()=>o(!a),className:`flex items-center gap-2 px-2 py-1.5 w-full text-left hover:bg-surface transition-colors min-w-0`,children:[a?(0,H.jsxDEV)(r,{className:`size-3 shrink-0`},void 0,!1,{fileName:U,lineNumber:80,columnNumber:21},this):(0,H.jsxDEV)(O,{className:`size-3 shrink-0`},void 0,!1,{fileName:U,lineNumber:80,columnNumber:67},this),u?(0,H.jsxDEV)(ce,{className:`size-3 text-red-400 shrink-0`},void 0,!1,{fileName:U,lineNumber:82,columnNumber:13},this):l||d||n?(0,H.jsxDEV)(I,{className:`size-3 text-green-400 shrink-0`},void 0,!1,{fileName:U,lineNumber:84,columnNumber:15},this):(0,H.jsxDEV)(j,{className:`size-3 text-yellow-400 shrink-0 animate-spin`},void 0,!1,{fileName:U,lineNumber:85,columnNumber:15},this),(0,H.jsxDEV)(`span`,{className:`truncate text-text-primary`,children:(0,H.jsxDEV)($e,{name:s,input:c},void 0,!1,{fileName:U,lineNumber:87,columnNumber:11},this)},void 0,!1,{fileName:U,lineNumber:86,columnNumber:9},this),m&&(0,H.jsxDEV)(`span`,{className:`ml-auto text-[10px] text-text-subtle shrink-0`,children:[p.length,` steps`]},void 0,!0,{fileName:U,lineNumber:90,columnNumber:11},this)]},void 0,!0,{fileName:U,lineNumber:76,columnNumber:7},this),a&&(0,H.jsxDEV)(`div`,{className:`px-2 pb-2 space-y-1.5`,children:[(e.type===`tool_use`||e.type===`approval_request`)&&(0,H.jsxDEV)(et,{name:s,input:c,projectName:i},void 0,!1,{fileName:U,lineNumber:96,columnNumber:13},this),m&&(0,H.jsxDEV)(it,{events:p,projectName:i},void 0,!1,{fileName:U,lineNumber:100,columnNumber:13},this),l&&(0,H.jsxDEV)(nt,{toolName:s,output:t.output},void 0,!1,{fileName:U,lineNumber:103,columnNumber:13},this)]},void 0,!0,{fileName:U,lineNumber:94,columnNumber:9},this)]},void 0,!0,{fileName:U,lineNumber:75,columnNumber:5},this)}function $e({name:e,input:t}){let n=e=>String(e??``);switch(e){case`Read`:case`Write`:case`Edit`:case`MultiEdit`:case`NotebookEdit`:return(0,H.jsxDEV)(H.Fragment,{children:[e,` `,(0,H.jsxDEV)(`span`,{className:`text-text-subtle`,children:h(n(t.file_path))},void 0,!1,{fileName:U,lineNumber:120,columnNumber:23},this)]},void 0,!0);case`Bash`:return(0,H.jsxDEV)(H.Fragment,{children:[e,` `,(0,H.jsxDEV)(`span`,{className:`font-mono text-text-subtle`,children:W(n(t.command),60)},void 0,!1,{fileName:U,lineNumber:122,columnNumber:23},this)]},void 0,!0);case`Glob`:return(0,H.jsxDEV)(H.Fragment,{children:[e,` `,(0,H.jsxDEV)(`span`,{className:`font-mono text-text-subtle`,children:n(t.pattern)},void 0,!1,{fileName:U,lineNumber:124,columnNumber:23},this)]},void 0,!0);case`Grep`:return(0,H.jsxDEV)(H.Fragment,{children:[e,` `,(0,H.jsxDEV)(`span`,{className:`font-mono text-text-subtle`,children:W(n(t.pattern),40)},void 0,!1,{fileName:U,lineNumber:126,columnNumber:23},this)]},void 0,!0);case`WebSearch`:return(0,H.jsxDEV)(H.Fragment,{children:[(0,H.jsxDEV)(E,{className:`size-3 inline`},void 0,!1,{fileName:U,lineNumber:128,columnNumber:16},this),` `,e,` `,(0,H.jsxDEV)(`span`,{className:`text-text-subtle`,children:W(n(t.query),50)},void 0,!1,{fileName:U,lineNumber:128,columnNumber:60},this)]},void 0,!0);case`WebFetch`:return(0,H.jsxDEV)(H.Fragment,{children:[(0,H.jsxDEV)(de,{className:`size-3 inline`},void 0,!1,{fileName:U,lineNumber:130,columnNumber:16},this),` `,e,` `,(0,H.jsxDEV)(`span`,{className:`text-text-subtle`,children:W(n(t.url),50)},void 0,!1,{fileName:U,lineNumber:130,columnNumber:59},this)]},void 0,!0);case`ToolSearch`:return(0,H.jsxDEV)(H.Fragment,{children:[(0,H.jsxDEV)(E,{className:`size-3 inline`},void 0,!1,{fileName:U,lineNumber:132,columnNumber:16},this),` `,e,` `,(0,H.jsxDEV)(`span`,{className:`text-text-subtle`,children:W(n(t.query),50)},void 0,!1,{fileName:U,lineNumber:132,columnNumber:60},this)]},void 0,!0);case`Agent`:case`Task`:return(0,H.jsxDEV)(H.Fragment,{children:[(0,H.jsxDEV)(z,{className:`size-3 inline`},void 0,!1,{fileName:U,lineNumber:135,columnNumber:16},this),` `,e,` `,(0,H.jsxDEV)(`span`,{className:`text-text-subtle`,children:W(n(t.description||t.prompt),60)},void 0,!1,{fileName:U,lineNumber:135,columnNumber:57},this)]},void 0,!0);case`TodoWrite`:{let n=Array.isArray(t.todos)?t.todos:[],r=n.filter(e=>e.status===`completed`).length;return(0,H.jsxDEV)(H.Fragment,{children:[(0,H.jsxDEV)(he,{className:`size-3 inline`},void 0,!1,{fileName:U,lineNumber:139,columnNumber:16},this),` `,e,` `,(0,H.jsxDEV)(`span`,{className:`text-text-subtle`,children:[r,`/`,n.length,` done`]},void 0,!0,{fileName:U,lineNumber:139,columnNumber:62},this)]},void 0,!0)}case`AskUserQuestion`:{let n=Array.isArray(t.questions)?t.questions:[],r=!!t.answers;return(0,H.jsxDEV)(H.Fragment,{children:[e,` `,(0,H.jsxDEV)(`span`,{className:`text-text-subtle`,children:[n.length,` question`,n.length===1?``:`s`,r?` ✓`:``]},void 0,!0,{fileName:U,lineNumber:144,columnNumber:23},this)]},void 0,!0)}default:return(0,H.jsxDEV)(H.Fragment,{children:e},void 0,!1)}}function et({name:e,input:t,projectName:n}){let r=e=>String(e??``),{openTab:i}=d(),a=e=>{n&&i({type:`editor`,title:h(e),metadata:{filePath:e,projectName:n},projectId:n,closable:!0})},o=(e,t,r)=>{i({type:`git-diff`,title:`Diff ${h(e)}`,metadata:{filePath:e,projectName:n,original:t,modified:r},projectId:n??null,closable:!0})};switch(e){case`Bash`:return(0,H.jsxDEV)(`div`,{className:`space-y-1`,children:[!!t.description&&(0,H.jsxDEV)(`p`,{className:`text-text-subtle italic`,children:r(t.description)},void 0,!1,{fileName:U,lineNumber:191,columnNumber:35},this),(0,H.jsxDEV)(`pre`,{className:`font-mono text-text-secondary overflow-x-auto whitespace-pre-wrap break-all`,children:r(t.command)},void 0,!1,{fileName:U,lineNumber:192,columnNumber:11},this)]},void 0,!0,{fileName:U,lineNumber:190,columnNumber:9},this);case`Read`:case`Write`:case`Edit`:case`MultiEdit`:case`NotebookEdit`:{let n=r(t.file_path);return(0,H.jsxDEV)(`div`,{className:`space-y-1`,children:[(0,H.jsxDEV)(`button`,{type:`button`,className:`font-mono text-text-secondary break-all hover:text-primary hover:underline text-left flex items-center gap-1`,onClick:()=>a(n),title:`Open file in editor`,children:[(0,H.jsxDEV)(l,{className:`size-3 shrink-0`},void 0,!1,{fileName:U,lineNumber:209,columnNumber:13},this),n]},void 0,!0,{fileName:U,lineNumber:203,columnNumber:11},this),e===`Edit`&&(!!t.old_string||!!t.new_string)&&(0,H.jsxDEV)(`button`,{type:`button`,className:`text-text-subtle hover:text-primary hover:underline text-left flex items-center gap-1`,onClick:()=>o(n,r(t.old_string),r(t.new_string)),title:`View diff in new tab`,children:[(0,H.jsxDEV)(c,{className:`size-3 shrink-0`},void 0,!1,{fileName:U,lineNumber:219,columnNumber:15},this),`View Diff`]},void 0,!0,{fileName:U,lineNumber:213,columnNumber:13},this),e===`Write`&&!!t.content&&(0,H.jsxDEV)(`pre`,{className:`font-mono text-text-subtle overflow-x-auto max-h-32 whitespace-pre-wrap`,children:W(r(t.content),300)},void 0,!1,{fileName:U,lineNumber:224,columnNumber:13},this)]},void 0,!0,{fileName:U,lineNumber:202,columnNumber:9},this)}case`Glob`:return(0,H.jsxDEV)(`p`,{className:`font-mono text-text-secondary`,children:[r(t.pattern),t.path?` in ${r(t.path)}`:``]},void 0,!0,{fileName:U,lineNumber:230,columnNumber:14},this);case`Grep`:return(0,H.jsxDEV)(`div`,{className:`space-y-0.5`,children:[(0,H.jsxDEV)(`p`,{className:`font-mono text-text-secondary`,children:[`/`,r(t.pattern),`/`]},void 0,!0,{fileName:U,lineNumber:234,columnNumber:11},this),!!t.path&&(0,H.jsxDEV)(`p`,{className:`text-text-subtle`,children:[`in `,r(t.path)]},void 0,!0,{fileName:U,lineNumber:235,columnNumber:28},this)]},void 0,!0,{fileName:U,lineNumber:233,columnNumber:9},this);case`TodoWrite`:return(0,H.jsxDEV)(tt,{todos:t.todos??[]},void 0,!1,{fileName:U,lineNumber:239,columnNumber:14},this);case`Agent`:case`Task`:return(0,H.jsxDEV)(`div`,{className:`space-y-1`,children:[!!t.description&&(0,H.jsxDEV)(`p`,{className:`text-text-secondary font-medium`,children:r(t.description)},void 0,!1,{fileName:U,lineNumber:244,columnNumber:35},this),!!t.subagent_type&&(0,H.jsxDEV)(`p`,{className:`text-text-subtle`,children:[`Type: `,r(t.subagent_type)]},void 0,!0,{fileName:U,lineNumber:245,columnNumber:37},this),!!t.prompt&&(0,H.jsxDEV)(at,{content:r(t.prompt),maxHeight:`max-h-48`},void 0,!1,{fileName:U,lineNumber:246,columnNumber:30},this)]},void 0,!0,{fileName:U,lineNumber:243,columnNumber:9},this);case`ToolSearch`:return(0,H.jsxDEV)(`div`,{className:`space-y-0.5`,children:[(0,H.jsxDEV)(`p`,{className:`font-mono text-text-secondary`,children:r(t.query)},void 0,!1,{fileName:U,lineNumber:252,columnNumber:11},this),!!t.max_results&&(0,H.jsxDEV)(`p`,{className:`text-text-subtle`,children:[`Max results: `,r(t.max_results)]},void 0,!0,{fileName:U,lineNumber:253,columnNumber:35},this)]},void 0,!0,{fileName:U,lineNumber:251,columnNumber:9},this);case`WebFetch`:return(0,H.jsxDEV)(`div`,{className:`space-y-0.5`,children:[(0,H.jsxDEV)(`a`,{href:r(t.url),target:`_blank`,rel:`noopener noreferrer`,className:`font-mono text-primary hover:underline break-all flex items-center gap-1`,children:[(0,H.jsxDEV)(de,{className:`size-3 shrink-0`},void 0,!1,{fileName:U,lineNumber:260,columnNumber:13},this),r(t.url)]},void 0,!0,{fileName:U,lineNumber:259,columnNumber:11},this),!!t.prompt&&(0,H.jsxDEV)(`p`,{className:`text-text-subtle`,children:W(r(t.prompt),100)},void 0,!1,{fileName:U,lineNumber:263,columnNumber:30},this)]},void 0,!0,{fileName:U,lineNumber:258,columnNumber:9},this);case`AskUserQuestion`:{let e=t.questions??[],n=t.answers??{};return(0,H.jsxDEV)(`div`,{className:`space-y-2`,children:e.map((e,t)=>(0,H.jsxDEV)(`div`,{className:`space-y-0.5`,children:[(0,H.jsxDEV)(`p`,{className:`text-text-primary font-medium`,children:[e.header?`${e.header}: `:``,e.question]},void 0,!0,{fileName:U,lineNumber:273,columnNumber:15},this),(0,H.jsxDEV)(`div`,{className:`flex flex-wrap gap-1`,children:e.options.map((t,r)=>(0,H.jsxDEV)(`span`,{className:`inline-block rounded px-1.5 py-0.5 text-xs border ${(n[e.question]??``).split(`, `).includes(t.label)?`border-accent bg-accent/20 text-text-primary`:`border-border text-text-subtle`}`,children:t.label},r,!1,{fileName:U,lineNumber:279,columnNumber:21},this))},void 0,!1,{fileName:U,lineNumber:274,columnNumber:15},this),n[e.question]&&(0,H.jsxDEV)(`p`,{className:`text-foreground text-xs`,children:[`Answer: `,n[e.question]]},void 0,!0,{fileName:U,lineNumber:288,columnNumber:17},this)]},t,!0,{fileName:U,lineNumber:272,columnNumber:13},this))},void 0,!1,{fileName:U,lineNumber:270,columnNumber:9},this)}default:return(0,H.jsxDEV)(`pre`,{className:`overflow-x-auto text-text-secondary font-mono whitespace-pre-wrap break-all`,children:JSON.stringify(t,null,2)},void 0,!1,{fileName:U,lineNumber:297,columnNumber:9},this)}}function tt({todos:e}){return(0,H.jsxDEV)(`div`,{className:`space-y-0.5`,children:e.map((e,t)=>(0,H.jsxDEV)(`div`,{className:`flex items-start gap-1.5`,children:[(0,H.jsxDEV)(`span`,{className:`shrink-0 mt-0.5 ${e.status===`completed`?`text-green-400`:e.status===`in_progress`?`text-yellow-400`:`text-text-subtle`}`,children:e.status===`completed`?`✓`:e.status===`in_progress`?`▶`:`○`},void 0,!1,{fileName:U,lineNumber:310,columnNumber:11},this),(0,H.jsxDEV)(`span`,{className:e.status===`completed`?`line-through text-text-subtle`:`text-text-secondary`,children:e.content},void 0,!1,{fileName:U,lineNumber:319,columnNumber:11},this)]},t,!0,{fileName:U,lineNumber:309,columnNumber:9},this))},void 0,!1,{fileName:U,lineNumber:307,columnNumber:5},this)}function nt({toolName:e,output:t}){let[n,r]=(0,B.useState)(!1),i=(0,B.useMemo)(()=>{if(e!==`Agent`&&e!==`Task`)return null;try{let e=JSON.parse(t);if(Array.isArray(e)){let t=e.filter(e=>e.type===`text`&&e.text).map(e=>e.text).join(`
3
-
4
- `);if(t)return t}if(typeof e==`string`)return e}catch{if(t&&!t.startsWith(`[{`))return t}return null},[e,t]);return i?(0,H.jsxDEV)(`div`,{className:`border-t border-border pt-1.5 space-y-1`,children:[(0,H.jsxDEV)(at,{content:i,maxHeight:`max-h-60`},void 0,!1,{fileName:U,lineNumber:357,columnNumber:9},this),(0,H.jsxDEV)(`button`,{type:`button`,onClick:()=>r(!n),className:`flex items-center gap-1 text-[10px] text-text-subtle hover:text-text-secondary transition-colors`,children:[(0,H.jsxDEV)(ue,{className:`size-3`},void 0,!1,{fileName:U,lineNumber:364,columnNumber:11},this),n?`Hide`:`Show`,` raw`]},void 0,!0,{fileName:U,lineNumber:359,columnNumber:9},this),n&&(0,H.jsxDEV)(`pre`,{className:`overflow-x-auto text-text-subtle font-mono max-h-40 whitespace-pre-wrap break-all text-[10px]`,children:t},void 0,!1,{fileName:U,lineNumber:368,columnNumber:11},this)]},void 0,!0,{fileName:U,lineNumber:356,columnNumber:7},this):(0,H.jsxDEV)(rt,{output:t},void 0,!1,{fileName:U,lineNumber:378,columnNumber:5},this)}function rt({output:e}){let t=e.split(`
5
- `).length,n=t>3||e.length>200,[i,a]=(0,B.useState)(n);return(0,H.jsxDEV)(`div`,{className:`border-t border-border pt-1.5`,children:[n&&(0,H.jsxDEV)(`button`,{type:`button`,onClick:()=>a(!i),className:`flex items-center gap-1 text-[10px] text-text-subtle hover:text-text-secondary transition-colors mb-1`,children:[i?(0,H.jsxDEV)(O,{className:`size-3`},void 0,!1,{fileName:U,lineNumber:396,columnNumber:24},this):(0,H.jsxDEV)(r,{className:`size-3`},void 0,!1,{fileName:U,lineNumber:396,columnNumber:62},this),`Output (`,t,` lines)`]},void 0,!0,{fileName:U,lineNumber:391,columnNumber:9},this),(0,H.jsxDEV)(`pre`,{className:`overflow-x-auto text-text-subtle font-mono whitespace-pre-wrap break-all ${i?`max-h-16 overflow-hidden`:`max-h-60`}`,children:e},void 0,!1,{fileName:U,lineNumber:400,columnNumber:7},this)]},void 0,!0,{fileName:U,lineNumber:389,columnNumber:5},this)}function it({events:e,projectName:t}){let n=[],r=``;for(let t of e)if(t.type===`text`)r+=t.content;else if(t.type===`tool_use`)r&&=(n.push({kind:`text`,content:r}),``),n.push({kind:`tool`,tool:t});else if(t.type===`tool_result`){let e=t.toolUseId,r=e?n.find(t=>t.kind===`tool`&&t.tool.type===`tool_use`&&t.tool.toolUseId===e&&!t.result):n.findLast(e=>e.kind===`tool`&&!e.result);r&&(r.result=t)}return r&&n.push({kind:`text`,content:r}),(0,H.jsxDEV)(`div`,{className:`border-l-2 border-accent/20 pl-2 space-y-1 mt-1`,children:n.map((e,n)=>e.kind===`text`?(0,H.jsxDEV)(`div`,{className:`text-text-secondary text-[11px]`,children:(0,H.jsxDEV)(at,{content:e.content,maxHeight:`max-h-24`},void 0,!1,{fileName:U,lineNumber:442,columnNumber:15},this)},`st-${n}`,!1,{fileName:U,lineNumber:441,columnNumber:13},this):(0,H.jsxDEV)(Qe,{tool:e.tool,result:e.result,completed:!!e.result,projectName:t},`sc-${n}`,!1,{fileName:U,lineNumber:446,columnNumber:16},this))},void 0,!1,{fileName:U,lineNumber:437,columnNumber:5},this)}function at({content:e,maxHeight:t=`max-h-48`}){return(0,H.jsxDEV)(ae,{content:e,className:`text-text-secondary overflow-auto ${t}`},void 0,!1,{fileName:U,lineNumber:454,columnNumber:10},this)}function W(e,t=50){return e?e.length>t?e.slice(0,t)+`…`:e:``}var G=`/Users/hienlh/Projects/ppm/src/web/components/chat/question-card.tsx`;function ot(e){let[t,n]=(0,B.useState)({}),[r,i]=(0,B.useState)({}),[a,o]=(0,B.useState)(0),s=(0,B.useCallback)((e,t)=>{n(n=>({...n,[e]:[t]})),i(t=>({...t,[e]:``}))},[]),c=(0,B.useCallback)((e,t)=>{n(n=>{let r=n[e]||[];return{...n,[e]:r.includes(t)?r.filter(e=>e!==t):[...r,t]}})},[]),l=(0,B.useCallback)((e,t)=>{i(n=>({...n,[e]:t})),t&&n(t=>({...t,[e]:[]}))},[]),u=(0,B.useCallback)(e=>(t[e]?.length??0)>0||(r[e]?.trim().length??0)>0,[t,r]);return{answers:t,customInputs:r,activeTab:a,setActiveTab:o,handleSingleSelect:s,handleMultiSelect:c,handleCustomInput:l,hasAnswer:u,allAnswered:(0,B.useMemo)(()=>e.every((e,t)=>u(t)),[e,u]),getFinalAnswer:(0,B.useCallback)(e=>r[e]?.trim()||(t[e]??[]).join(`, `),[t,r]),goToNextTab:(0,B.useCallback)(()=>o(t=>Math.min(t+1,e.length-1)),[e.length]),goToPrevTab:(0,B.useCallback)(()=>o(e=>Math.max(e-1,0)),[])}}function st(e){let[t,n]=(0,B.useState)(0),r=(0,B.useRef)(null);return(0,B.useEffect)(()=>n(0),[e.activeTab]),(0,B.useEffect)(()=>{if(!e.enabled)return;let i=r=>{let i=document.activeElement===e.customInputRef.current;if(!i&&r.key>=`1`&&r.key<=`9`){r.preventDefault();let t=parseInt(r.key)-1;t<e.totalOptions-1&&(n(t),e.onSelectOption(t));return}if(!i&&(r.key===`o`||r.key===`O`||r.key===`0`)){r.preventDefault(),e.customInputRef.current?.focus(),n(e.totalOptions-1);return}if(r.key===`Tab`&&e.questions.length>1){r.preventDefault(),r.shiftKey?e.goToPrevTab():e.goToNextTab();return}if(!i){if(r.key===`ArrowLeft`){r.preventDefault(),e.goToPrevTab();return}if(r.key===`ArrowRight`){r.preventDefault(),e.goToNextTab();return}if(r.key===`ArrowUp`){r.preventDefault(),n(e=>Math.max(0,e-1));return}if(r.key===`ArrowDown`){r.preventDefault(),n(t=>Math.min(e.totalOptions-1,t+1));return}if(r.key===` `){r.preventDefault(),e.onSelectOption(t);return}}if(r.key===`Enter`){r.preventDefault(),e.allAnswered?e.onSubmit():e.hasAnswer(e.activeTab)&&e.goToNextTab();return}r.key===`Escape`&&i&&e.customInputRef.current?.blur()},a=r.current;return a&&(a.addEventListener(`keydown`,i),a.setAttribute(`tabindex`,`0`),a.contains(document.activeElement)||a.focus()),()=>{a?.removeEventListener(`keydown`,i)}},[e,t]),{focusedOption:t,setFocusedOption:n,containerRef:r}}function ct({questions:e,onSubmit:t,onSkip:n}){let r=(0,B.useRef)(null),i=ot(e),a=e[i.activeTab],o=a?a.options.length+1:0,s=e.length>1,c=(0,B.useCallback)(()=>{if(!i.allAnswered)return;let n={};e.forEach((e,t)=>{n[e.question]=i.getFinalAnswer(t)}),t(n)},[i.allAnswered,i.getFinalAnswer,e,t]),l=(0,B.useCallback)(e=>{if(!(!a||e<0))if(e<a.options.length){let t=a.options[e]?.label;if(!t)return;a.multiSelect?i.handleMultiSelect(i.activeTab,t):i.handleSingleSelect(i.activeTab,t)}else e===a.options.length&&r.current?.focus()},[a,i]),u=st({questions:e,activeTab:i.activeTab,totalOptions:o,allAnswered:i.allAnswered,hasAnswer:i.hasAnswer,onSelectOption:l,goToNextTab:i.goToNextTab,goToPrevTab:i.goToPrevTab,onSubmit:c,customInputRef:r,enabled:!0}),d=(0,B.useCallback)(e=>{l(e),u.setFocusedOption(e)},[l,u.setFocusedOption]);return(0,H.jsxDEV)(`div`,{ref:u.containerRef,className:`rounded-lg border-2 border-primary/30 bg-primary/5 p-3 space-y-3 outline-none animate-in slide-in-from-bottom-2`,children:[(0,H.jsxDEV)(`div`,{className:`flex items-center justify-between text-sm font-medium text-text-primary`,children:[(0,H.jsxDEV)(`span`,{children:[`AI has `,s?`${e.length} questions`:`a question`]},void 0,!0,{fileName:G,lineNumber:193,columnNumber:9},this),(0,H.jsxDEV)(`span`,{className:`text-[10px] text-text-secondary font-normal`,children:[s?`←→ tabs · `:``,`↑↓ options · 1-`,Math.min(o-1,9),` select · Enter submit`]},void 0,!0,{fileName:G,lineNumber:196,columnNumber:9},this)]},void 0,!0,{fileName:G,lineNumber:192,columnNumber:7},this),s&&(0,H.jsxDEV)(`div`,{className:`flex gap-1 p-1 bg-background rounded-md overflow-x-auto border border-border`,children:e.map((e,t)=>(0,H.jsxDEV)(`button`,{className:`flex items-center gap-1.5 px-3 py-1.5 rounded text-xs whitespace-nowrap transition-all ${i.activeTab===t?`bg-primary text-primary-foreground`:i.hasAnswer(t)?`text-primary bg-transparent`:`text-text-secondary hover:bg-surface-elevated`}`,onClick:()=>{i.setActiveTab(t),u.setFocusedOption(0)},tabIndex:-1,children:[(0,H.jsxDEV)(`span`,{className:`flex items-center justify-center w-4 h-4 rounded-full text-[10px] font-semibold ${i.activeTab===t?`bg-white/20`:i.hasAnswer(t)?`bg-primary/20 text-primary`:`bg-surface-elevated text-text-secondary`}`,children:i.hasAnswer(t)?`✓`:t+1},void 0,!1,{fileName:G,lineNumber:217,columnNumber:15},this),(0,H.jsxDEV)(`span`,{className:`max-w-[100px] overflow-hidden text-ellipsis`,children:e.header||`Q${t+1}`},void 0,!1,{fileName:G,lineNumber:228,columnNumber:15},this)]},t,!0,{fileName:G,lineNumber:205,columnNumber:13},this))},void 0,!1,{fileName:G,lineNumber:203,columnNumber:9},this),a&&(0,H.jsxDEV)(`div`,{className:`space-y-2`,children:[!s&&a.header&&(0,H.jsxDEV)(`div`,{className:`text-[11px] font-semibold uppercase tracking-wide text-text-secondary`,children:a.header},void 0,!1,{fileName:G,lineNumber:238,columnNumber:13},this),(0,H.jsxDEV)(`div`,{className:`text-sm text-text-primary`,children:a.question},void 0,!1,{fileName:G,lineNumber:240,columnNumber:11},this),a.multiSelect&&(0,H.jsxDEV)(`div`,{className:`text-[11px] text-text-secondary`,children:`Select multiple`},void 0,!1,{fileName:G,lineNumber:241,columnNumber:36},this),(0,H.jsxDEV)(`div`,{className:`flex flex-col gap-1.5`,children:[a.options.map((e,t)=>{let n=(i.answers[i.activeTab]||[]).includes(e.label),r=u.focusedOption===t;return(0,H.jsxDEV)(`button`,{onClick:()=>d(t),className:`text-left flex items-start gap-2.5 rounded px-2.5 py-2 text-xs border transition-all ${n?`border-primary bg-primary/10 text-text-primary`:`border-border bg-background text-text-secondary hover:border-primary/40 hover:bg-primary/5`} ${r?`ring-2 ring-primary/40 ring-offset-1 ring-offset-background`:``}`,children:[(0,H.jsxDEV)(`span`,{className:`flex items-center justify-center w-4.5 h-4.5 rounded text-[10px] font-semibold shrink-0 mt-px ${n?`bg-primary/20 text-primary`:`bg-surface-elevated text-text-secondary`}`,children:t+1},void 0,!1,{fileName:G,lineNumber:258,columnNumber:19},this),(0,H.jsxDEV)(`div`,{className:`flex flex-col gap-0.5 flex-1`,children:[(0,H.jsxDEV)(`span`,{className:`font-medium text-text-primary`,children:e.label},void 0,!1,{fileName:G,lineNumber:264,columnNumber:21},this),e.description&&(0,H.jsxDEV)(`span`,{className:`text-[11px] text-text-secondary`,children:e.description},void 0,!1,{fileName:G,lineNumber:265,columnNumber:41},this)]},void 0,!0,{fileName:G,lineNumber:263,columnNumber:19},this)]},t,!0,{fileName:G,lineNumber:249,columnNumber:17},this)}),(0,H.jsxDEV)(`div`,{className:`flex items-start gap-2.5 rounded px-2.5 py-2 text-xs border border-dashed transition-all border-border bg-transparent ${u.focusedOption===o-1?`ring-2 ring-primary/40 ring-offset-1 ring-offset-background`:``}`,children:[(0,H.jsxDEV)(`span`,{className:`flex items-center justify-center w-4.5 h-4.5 rounded bg-surface-elevated text-text-secondary text-[10px] font-semibold shrink-0 mt-px`,children:`O`},void 0,!1,{fileName:G,lineNumber:277,columnNumber:15},this),(0,H.jsxDEV)(`input`,{ref:r,type:`text`,className:`flex-1 px-2 py-1 text-xs bg-surface border border-border rounded text-text-primary outline-none placeholder:text-text-subtle focus:border-primary`,placeholder:`Other (press O to type)...`,value:i.customInputs[i.activeTab]||``,onChange:e=>i.handleCustomInput(i.activeTab,e.target.value),onFocus:()=>u.setFocusedOption(o-1)},void 0,!1,{fileName:G,lineNumber:280,columnNumber:15},this)]},void 0,!0,{fileName:G,lineNumber:272,columnNumber:13},this)]},void 0,!0,{fileName:G,lineNumber:244,columnNumber:11},this)]},void 0,!0,{fileName:G,lineNumber:236,columnNumber:9},this),(0,H.jsxDEV)(`div`,{className:`flex gap-2 justify-end pt-1`,children:[s&&(0,H.jsxDEV)(H.Fragment,{children:[(0,H.jsxDEV)(`button`,{className:`px-3 py-1.5 text-xs rounded border border-border bg-background text-text-primary hover:bg-surface-elevated disabled:opacity-40 disabled:cursor-not-allowed transition-colors`,onClick:i.goToPrevTab,disabled:i.activeTab===0,tabIndex:-1,children:`← Prev`},void 0,!1,{fileName:G,lineNumber:298,columnNumber:13},this),(0,H.jsxDEV)(`button`,{className:`px-3 py-1.5 text-xs rounded border border-border bg-background text-text-primary hover:bg-surface-elevated disabled:opacity-40 disabled:cursor-not-allowed transition-colors`,onClick:i.goToNextTab,disabled:i.activeTab===e.length-1,tabIndex:-1,children:`Next →`},void 0,!1,{fileName:G,lineNumber:306,columnNumber:13},this)]},void 0,!0),(0,H.jsxDEV)(`button`,{onClick:n,className:`px-4 py-1.5 rounded border border-border bg-background text-text-secondary text-xs hover:bg-surface-elevated transition-colors`,tabIndex:-1,children:`Skip`},void 0,!1,{fileName:G,lineNumber:316,columnNumber:9},this),(0,H.jsxDEV)(`button`,{onClick:c,disabled:!i.allAnswered,className:`px-4 py-1.5 rounded bg-primary text-primary-foreground text-xs font-medium hover:bg-primary/80 transition-colors disabled:opacity-40 disabled:cursor-not-allowed`,tabIndex:-1,children:[`Submit `,i.allAnswered?`✓`:`(${e.filter((e,t)=>i.hasAnswer(t)).length}/${e.length})`]},void 0,!0,{fileName:G,lineNumber:323,columnNumber:9},this)]},void 0,!0,{fileName:G,lineNumber:295,columnNumber:7},this)]},void 0,!0,{fileName:G,lineNumber:187,columnNumber:5},this)}var K=`/Users/hienlh/Projects/ppm/src/web/components/chat/message-list.tsx`;function lt({messages:e,messagesLoading:t,pendingApproval:n,onApprovalResponse:r,isStreaming:i,streamingStatus:a,connectingElapsed:o,thinkingWarningThreshold:s,projectName:c,onFork:l}){return t?(0,H.jsxDEV)(`div`,{className:`flex flex-col items-center justify-center h-full gap-3 text-text-secondary`,children:[(0,H.jsxDEV)(z,{className:`size-10 text-text-subtle animate-pulse`},void 0,!1,{fileName:K,lineNumber:58,columnNumber:9},this),(0,H.jsxDEV)(`p`,{className:`text-sm`,children:`Loading messages...`},void 0,!1,{fileName:K,lineNumber:59,columnNumber:9},this)]},void 0,!0,{fileName:K,lineNumber:57,columnNumber:7},this):e.length===0&&!i?(0,H.jsxDEV)(`div`,{className:`flex flex-col items-center justify-center h-full gap-3 text-text-secondary`,children:[(0,H.jsxDEV)(z,{className:`size-10 text-text-subtle`},void 0,!1,{fileName:K,lineNumber:67,columnNumber:9},this),(0,H.jsxDEV)(`p`,{className:`text-sm`,children:`Send a message to start the conversation`},void 0,!1,{fileName:K,lineNumber:68,columnNumber:9},this)]},void 0,!0,{fileName:K,lineNumber:66,columnNumber:7},this):(0,H.jsxDEV)(Ye,{className:`flex-1 overflow-y-auto`,resize:`smooth`,initial:`instant`,children:[(0,H.jsxDEV)(Ye.Content,{className:`p-4 space-y-4`,children:[e.filter(e=>{let t=e.content&&e.content.trim().length>0,n=e.events&&e.events.length>0;return t||n}).map(e=>(0,H.jsxDEV)(dt,{message:e,isStreaming:i&&e.id.startsWith(`streaming-`),projectName:c,onFork:e.role===`user`&&l?()=>l(e.content):void 0},e.id,!1,{fileName:K,lineNumber:83,columnNumber:13},this)),n&&(n.tool===`AskUserQuestion`?(0,H.jsxDEV)(Dt,{approval:n,onRespond:r},void 0,!1,{fileName:K,lineNumber:94,columnNumber:15},this):(0,H.jsxDEV)(Et,{approval:n,onRespond:r},void 0,!1,{fileName:K,lineNumber:95,columnNumber:15},this)),i&&(0,H.jsxDEV)(wt,{lastMessage:e[e.length-1],streamingStatus:a,elapsed:o,warningThreshold:s},void 0,!1,{fileName:K,lineNumber:98,columnNumber:25},this)]},void 0,!0,{fileName:K,lineNumber:75,columnNumber:7},this),(0,H.jsxDEV)(ut,{},void 0,!1,{fileName:K,lineNumber:100,columnNumber:7},this)]},void 0,!0,{fileName:K,lineNumber:74,columnNumber:5},this)}function ut(){let{isAtBottom:e,scrollToBottom:t}=Xe();return e?null:(0,H.jsxDEV)(`button`,{onClick:()=>t(),className:`absolute bottom-4 left-1/2 -translate-x-1/2 z-10 flex items-center gap-1 px-3 py-1 rounded-full bg-surface-elevated border border-border text-xs text-text-secondary hover:text-foreground shadow-lg transition-all`,children:[(0,H.jsxDEV)(r,{className:`size-3`},void 0,!1,{fileName:K,lineNumber:114,columnNumber:7},this),`Scroll to bottom`]},void 0,!0,{fileName:K,lineNumber:110,columnNumber:5},this)}function dt({message:e,isStreaming:t,projectName:n,onFork:r}){return e.role===`user`?(0,H.jsxDEV)(vt,{content:e.content,projectName:n,onFork:r},void 0,!1,{fileName:K,lineNumber:122,columnNumber:12},this):e.role===`system`?(0,H.jsxDEV)(`div`,{className:`flex items-center gap-2 rounded-lg bg-red-500/10 border border-red-500/20 px-3 py-2 text-sm text-red-400`,children:[(0,H.jsxDEV)(L,{className:`size-4 shrink-0`},void 0,!1,{fileName:K,lineNumber:128,columnNumber:9},this),(0,H.jsxDEV)(`p`,{children:e.content},void 0,!1,{fileName:K,lineNumber:129,columnNumber:9},this)]},void 0,!0,{fileName:K,lineNumber:127,columnNumber:7},this):(0,H.jsxDEV)(`div`,{className:`flex flex-col gap-2`,children:[e.events&&e.events.length>0?(0,H.jsxDEV)(xt,{events:e.events,isStreaming:t,projectName:n},void 0,!1,{fileName:K,lineNumber:138,columnNumber:11},this):e.content&&(0,H.jsxDEV)(`div`,{className:`text-sm text-text-primary`,children:(0,H.jsxDEV)(Tt,{content:e.content,projectName:n},void 0,!1,{fileName:K,lineNumber:141,columnNumber:15},this)},void 0,!1,{fileName:K,lineNumber:140,columnNumber:13},this),!t&&e.accountLabel&&(0,H.jsxDEV)(`p`,{className:`text-[10px] select-none`,style:{color:`var(--color-text-subtle)`},children:[`via `,e.accountLabel]},void 0,!0,{fileName:K,lineNumber:145,columnNumber:9},this)]},void 0,!0,{fileName:K,lineNumber:136,columnNumber:5},this)}var ft=new Set([`.png`,`.jpg`,`.jpeg`,`.gif`,`.webp`]);function pt(e){return e.replace(/<(system-reminder|available-deferred-tools|antml:[\w-]+|fast_mode_info|claudeMd|gitStatus|currentDate)[\s\S]*?<\/\1>/g,``).trim()}function mt(e){let t=e.match(/^\[Attached file: (.+?)\]\n\n?/);if(t)return{files:[t[1]],text:e.slice(t[0].length)};let n=e.match(/^\[Attached files:\n([\s\S]+?)\]\n\n?/);return n?{files:n[1].split(`
6
- `).map(e=>e.trim()).filter(Boolean),text:e.slice(n[0].length)}:{files:[],text:e}}function ht(e,t){let n=h(e);return`/api/project/${encodeURIComponent(t??`_`)}/chat/uploads/${encodeURIComponent(n)}`}function gt(e){let t=e.lastIndexOf(`.`);return t===-1?!1:ft.has(e.slice(t).toLowerCase())}function _t(e){return e.toLowerCase().endsWith(`.pdf`)}function vt({content:e,projectName:t,onFork:n}){let{files:r,text:i}=(0,B.useMemo)(()=>{let t=mt(e);return{files:t.files,text:pt(t.text)}},[e]);return(0,H.jsxDEV)(`div`,{className:`flex justify-end group/user`,children:(0,H.jsxDEV)(`div`,{className:`rounded-lg bg-primary/10 px-3 py-2 text-sm text-text-primary max-w-[85%] space-y-2 relative`,children:[r.length>0&&(0,H.jsxDEV)(`div`,{className:`flex flex-wrap gap-2`,children:r.map((e,n)=>gt(e)?(0,H.jsxDEV)(yt,{src:ht(e,t),alt:h(e)||`image`},n,!1,{fileName:K,lineNumber:211,columnNumber:17},this):_t(e)?(0,H.jsxDEV)(bt,{src:ht(e,t),filename:h(e)||`document.pdf`,mimeType:`application/pdf`},n,!1,{fileName:K,lineNumber:217,columnNumber:17},this):(0,H.jsxDEV)(`div`,{className:`flex items-center gap-1.5 rounded-md border border-border bg-background/50 px-2 py-1 text-xs text-text-secondary`,children:[(0,H.jsxDEV)(k,{className:`size-3.5 shrink-0`},void 0,!1,{fileName:K,lineNumber:228,columnNumber:19},this),(0,H.jsxDEV)(`span`,{className:`truncate max-w-40`,children:h(e)},void 0,!1,{fileName:K,lineNumber:229,columnNumber:19},this)]},n,!0,{fileName:K,lineNumber:224,columnNumber:17},this))},void 0,!1,{fileName:K,lineNumber:208,columnNumber:11},this),i&&(0,H.jsxDEV)(`p`,{className:`whitespace-pre-wrap break-words`,children:i},void 0,!1,{fileName:K,lineNumber:237,columnNumber:18},this),n&&(0,H.jsxDEV)(`button`,{onClick:n,title:`Retry from this message (fork session)`,className:`absolute -left-8 top-1/2 -translate-y-1/2 opacity-0 group-hover/user:opacity-100 transition-opacity size-6 flex items-center justify-center rounded bg-surface border border-border text-text-subtle hover:text-text-primary hover:bg-surface-elevated`,children:(0,H.jsxDEV)(a,{className:`size-3`},void 0,!1,{fileName:K,lineNumber:245,columnNumber:13},this)},void 0,!1,{fileName:K,lineNumber:240,columnNumber:11},this)]},void 0,!0,{fileName:K,lineNumber:205,columnNumber:7},this)},void 0,!1,{fileName:K,lineNumber:204,columnNumber:5},this)}function yt({src:e,alt:t}){let[n,r]=(0,B.useState)(null),[i,a]=(0,B.useState)(!1);return(0,B.useEffect)(()=>{let t,n=_();return fetch(e,{headers:n?{Authorization:`Bearer ${n}`}:{}}).then(e=>{if(!e.ok)throw Error(`Failed to load`);return e.blob()}).then(e=>{let n=URL.createObjectURL(e);t=n,r(n)}).catch(()=>a(!0)),()=>{t&&URL.revokeObjectURL(t)}},[e]),i?(0,H.jsxDEV)(`div`,{className:`flex items-center gap-1.5 rounded-md border border-border bg-background/50 px-2 py-1 text-xs text-text-secondary`,children:[(0,H.jsxDEV)(me,{className:`size-3.5 shrink-0`},void 0,!1,{fileName:K,lineNumber:279,columnNumber:9},this),(0,H.jsxDEV)(`span`,{className:`truncate max-w-40`,children:t},void 0,!1,{fileName:K,lineNumber:280,columnNumber:9},this)]},void 0,!0,{fileName:K,lineNumber:278,columnNumber:7},this):n?(0,H.jsxDEV)(`a`,{href:n,target:`_blank`,rel:`noopener noreferrer`,className:`block`,children:(0,H.jsxDEV)(`img`,{src:n,alt:t,className:`rounded-md max-h-48 max-w-full object-contain border border-border`},void 0,!1,{fileName:K,lineNumber:291,columnNumber:7},this)},void 0,!1,{fileName:K,lineNumber:290,columnNumber:5},this):(0,H.jsxDEV)(`div`,{className:`rounded-md bg-surface border border-border h-24 w-32 animate-pulse`},void 0,!1,{fileName:K,lineNumber:286,columnNumber:12},this)}function bt({src:e,filename:t,mimeType:n}){let[r,i]=(0,B.useState)(!1);return(0,H.jsxDEV)(`button`,{type:`button`,onClick:(0,B.useCallback)(async()=>{i(!0);try{let t=_(),r=await fetch(e,{headers:t?{Authorization:`Bearer ${t}`}:{}});if(!r.ok)throw Error(`Failed to load`);let i=await r.blob(),a=URL.createObjectURL(new Blob([i],{type:n}));window.open(a,`_blank`),setTimeout(()=>URL.revokeObjectURL(a),6e4)}catch{window.open(e,`_blank`)}finally{i(!1)}},[e,n]),disabled:r,className:`flex items-center gap-1.5 rounded-md border border-border bg-background/50 px-2 py-1 text-xs text-text-secondary hover:bg-surface hover:text-text-primary transition-colors cursor-pointer disabled:opacity-50`,children:[(0,H.jsxDEV)(k,{className:`size-3.5 shrink-0 text-red-400`},void 0,!1,{fileName:K,lineNumber:330,columnNumber:7},this),(0,H.jsxDEV)(`span`,{className:`truncate max-w-40`,children:t},void 0,!1,{fileName:K,lineNumber:331,columnNumber:7},this),r&&(0,H.jsxDEV)(`span`,{className:`animate-spin text-[10px]`,children:`...`},void 0,!1,{fileName:K,lineNumber:332,columnNumber:19},this)]},void 0,!0,{fileName:K,lineNumber:324,columnNumber:5},this)}function xt({events:e,isStreaming:t,projectName:n}){let r=[],i=``,a=``;for(let t=0;t<e.length;t++){let n=e[t];if(n.type===`thinking`){i&&=(r.push({kind:`text`,content:i}),``),a+=n.content;continue}a&&=(r.push({kind:`thinking`,content:a}),``),n.type===`text`?i+=n.content:n.type===`tool_use`?(i&&=(r.push({kind:`text`,content:i}),``),r.push({kind:`tool`,tool:n})):n.type===`tool_result`||(i&&=(r.push({kind:`text`,content:i}),``),r.push({kind:`tool`,tool:n}))}a&&r.push({kind:`thinking`,content:a}),i&&r.push({kind:`text`,content:i});let o=e.filter(e=>e.type===`tool_result`);for(let e of o){let t=e.toolUseId;if(t){let n=r.find(e=>e.kind===`tool`&&e.tool.type===`tool_use`&&e.tool.toolUseId===t);if(n){n.result=e;continue}}let n=r.find(e=>e.kind===`tool`&&!e.result);n&&(n.result=e)}for(let e=0;e<r.length;e++){let n=r[e];if(n.kind===`tool`&&!n.result){let i=!1;if(n.tool.type===`tool_use`&&n.tool.tool===`Read`){let t=n.tool.input?.file_path;t&&(i=r.slice(e+1).some(e=>e.kind===`tool`&&e.result&&e.tool.type===`tool_use`&&e.tool.tool===`Edit`&&e.tool.input?.file_path===t))}n.completed=i||!t}}return(0,H.jsxDEV)(H.Fragment,{children:r.map((e,i)=>{if(e.kind===`thinking`)return(0,H.jsxDEV)(St,{content:e.content,isStreaming:t&&i===r.length-1},`think-${i}`,!1,{fileName:K,lineNumber:440,columnNumber:18},this);if(e.kind===`text`){let a=t&&i===r.length-1;return(0,H.jsxDEV)(`div`,{className:`text-sm text-text-primary`,children:(0,H.jsxDEV)(Ct,{content:e.content,animate:a,projectName:n},void 0,!1,{fileName:K,lineNumber:446,columnNumber:15},this)},`text-${i}`,!1,{fileName:K,lineNumber:445,columnNumber:13},this)}return(0,H.jsxDEV)(Qe,{tool:e.tool,result:e.result,completed:e.completed,projectName:n},`tool-${i}`,!1,{fileName:K,lineNumber:450,columnNumber:16},this)})},void 0,!1)}function St({content:e,isStreaming:t}){let[n,r]=(0,B.useState)(t);return(0,B.useEffect)(()=>{!t&&e.length>0&&r(!1)},[t,e.length]),(0,H.jsxDEV)(`div`,{className:`rounded border border-border/50 bg-surface/30 text-xs`,children:[(0,H.jsxDEV)(`button`,{onClick:()=>r(!n),className:`flex items-center gap-2 px-2 py-1.5 w-full text-left hover:bg-surface transition-colors text-text-subtle`,children:[t?(0,H.jsxDEV)(j,{className:`size-3 animate-spin`},void 0,!1,{fileName:K,lineNumber:471,columnNumber:24},this):(0,H.jsxDEV)(O,{className:`size-3 transition-transform ${n?`rotate-90`:``}`},void 0,!1,{fileName:K,lineNumber:471,columnNumber:70},this),(0,H.jsxDEV)(`span`,{children:[`Thinking`,t?`...`:``]},void 0,!0,{fileName:K,lineNumber:472,columnNumber:9},this),!t&&(0,H.jsxDEV)(`span`,{className:`text-text-subtle/50 ml-auto`,children:e.length>100?`${Math.round(e.length/4)} tokens`:``},void 0,!1,{fileName:K,lineNumber:473,columnNumber:26},this)]},void 0,!0,{fileName:K,lineNumber:467,columnNumber:7},this),n&&(0,H.jsxDEV)(`div`,{className:`px-2 pb-2 text-text-subtle/80 whitespace-pre-wrap max-h-60 overflow-y-auto text-[11px] leading-relaxed`,children:e},void 0,!1,{fileName:K,lineNumber:476,columnNumber:9},this)]},void 0,!0,{fileName:K,lineNumber:466,columnNumber:5},this)}function Ct({content:e,animate:t,projectName:n}){return(0,H.jsxDEV)(H.Fragment,{children:[(0,H.jsxDEV)(Tt,{content:e,projectName:n},void 0,!1,{fileName:K,lineNumber:492,columnNumber:7},this),t&&(0,H.jsxDEV)(`span`,{className:`text-text-subtle text-sm animate-pulse`,children:`Thinking...`},void 0,!1,{fileName:K,lineNumber:494,columnNumber:9},this)]},void 0,!0)}function wt({lastMessage:e,streamingStatus:t,elapsed:n,warningThreshold:r=15}){let i=!e||e.role!==`assistant`,a=e?.events?.length?e.events[e.events.length-1].type===`tool_result`:!1;return!i&&!a?null:(0,H.jsxDEV)(`div`,{className:`flex flex-col gap-1 text-sm`,children:[(0,H.jsxDEV)(`div`,{className:`flex items-center gap-2 text-text-subtle`,children:[(0,H.jsxDEV)(j,{className:`size-3 animate-spin`},void 0,!1,{fileName:K,lineNumber:526,columnNumber:9},this),(0,H.jsxDEV)(`span`,{children:[`Thinking`,i&&(n??0)>0&&(0,H.jsxDEV)(`span`,{className:`text-text-subtle/60`,children:[`... (`,n,`s)`]},void 0,!0,{fileName:K,lineNumber:529,columnNumber:47},this)]},void 0,!0,{fileName:K,lineNumber:527,columnNumber:9},this)]},void 0,!0,{fileName:K,lineNumber:525,columnNumber:7},this),i&&(n??0)>=r&&(0,H.jsxDEV)(`p`,{className:`text-xs text-yellow-500/80 ml-5`,children:`Taking longer than usual — may be rate-limited or API slow. Try sending a new message to retry.`},void 0,!1,{fileName:K,lineNumber:533,columnNumber:9},this)]},void 0,!0,{fileName:K,lineNumber:524,columnNumber:5},this)}function Tt({content:e,projectName:t}){return(0,H.jsxDEV)(ae,{content:e,projectName:t,codeActions:!0},void 0,!1,{fileName:K,lineNumber:543,columnNumber:10},this)}function Et({approval:e,onRespond:t}){return(0,H.jsxDEV)(`div`,{className:`rounded-lg border-2 border-yellow-500/40 bg-yellow-500/10 p-3 space-y-2`,children:[(0,H.jsxDEV)(`div`,{className:`flex items-center gap-2 text-yellow-400 text-sm font-medium`,children:[(0,H.jsxDEV)(ve,{className:`size-4`},void 0,!1,{fileName:K,lineNumber:558,columnNumber:9},this),(0,H.jsxDEV)(`span`,{children:`Tool Approval Required`},void 0,!1,{fileName:K,lineNumber:559,columnNumber:9},this)]},void 0,!0,{fileName:K,lineNumber:557,columnNumber:7},this),(0,H.jsxDEV)(`div`,{className:`text-xs text-text-primary`,children:(0,H.jsxDEV)(`span`,{className:`font-medium`,children:e.tool},void 0,!1,{fileName:K,lineNumber:562,columnNumber:9},this)},void 0,!1,{fileName:K,lineNumber:561,columnNumber:7},this),(0,H.jsxDEV)(`pre`,{className:`text-xs font-mono text-text-secondary overflow-x-auto bg-background rounded p-2 border border-border`,children:JSON.stringify(e.input,null,2)},void 0,!1,{fileName:K,lineNumber:564,columnNumber:7},this),(0,H.jsxDEV)(`div`,{className:`flex gap-2`,children:[(0,H.jsxDEV)(`button`,{onClick:()=>t(e.requestId,!0),className:`px-4 py-1.5 rounded bg-green-600 text-white text-xs font-medium hover:bg-green-500 transition-colors`,children:`Allow`},void 0,!1,{fileName:K,lineNumber:568,columnNumber:9},this),(0,H.jsxDEV)(`button`,{onClick:()=>t(e.requestId,!1),className:`px-4 py-1.5 rounded bg-red-600 text-white text-xs font-medium hover:bg-red-500 transition-colors`,children:`Deny`},void 0,!1,{fileName:K,lineNumber:574,columnNumber:9},this)]},void 0,!0,{fileName:K,lineNumber:567,columnNumber:7},this)]},void 0,!0,{fileName:K,lineNumber:556,columnNumber:5},this)}function Dt({approval:e,onRespond:t}){return(0,H.jsxDEV)(ct,{questions:e.input.questions??[],onSubmit:n=>t(e.requestId,!0,n),onSkip:()=>t(e.requestId,!1)},void 0,!1,{fileName:K,lineNumber:597,columnNumber:5},this)}var Ot=new Set([`image/png`,`image/jpeg`,`image/gif`,`image/webp`]),kt=new Set([`application/pdf`]),At=[`text/`,`application/json`,`application/xml`,`application/javascript`,`application/typescript`,`application/x-yaml`,`application/toml`,`application/x-sh`],jt=new Set(`.ts,.tsx,.js,.jsx,.mjs,.cjs,.py,.rb,.go,.rs,.java,.kt,.swift,.c,.cpp,.h,.hpp,.cs,.json,.yaml,.yml,.toml,.xml,.md,.mdx,.txt,.csv,.tsv,.html,.css,.scss,.less,.sass,.sh,.bash,.zsh,.fish,.sql,.graphql,.gql,.env,.ini,.cfg,.conf,.dockerfile,.makefile,.vue,.svelte,.astro,.ipynb`.split(`,`));function Mt(e){return Ot.has(e.type)}function Nt(e){if(Ot.has(e.type)||kt.has(e.type)||At.some(t=>e.type.startsWith(t)))return!0;let t=Pt(e.name);return!!(t&&jt.has(t))}function Pt(e){let t=e.lastIndexOf(`.`);return t===-1?``:e.slice(t).toLowerCase()}var q=`/Users/hienlh/Projects/ppm/src/web/components/chat/attachment-chips.tsx`;function Ft({attachments:e,onRemove:t}){return e.length===0?null:(0,H.jsxDEV)(`div`,{className:`flex flex-wrap gap-1.5 px-2 md:px-4 pt-2`,children:e.map(e=>(0,H.jsxDEV)(`div`,{className:`flex items-center gap-1.5 rounded-md border border-border bg-surface px-2 py-1 text-xs text-text-secondary max-w-48`,children:[e.previewUrl?(0,H.jsxDEV)(`img`,{src:e.previewUrl,alt:e.name,className:`size-5 rounded object-cover shrink-0`},void 0,!1,{fileName:q,lineNumber:21,columnNumber:13},this):e.isImage?(0,H.jsxDEV)(me,{className:`size-3.5 shrink-0 text-text-subtle`},void 0,!1,{fileName:q,lineNumber:27,columnNumber:13},this):(0,H.jsxDEV)(k,{className:`size-3.5 shrink-0 text-text-subtle`},void 0,!1,{fileName:q,lineNumber:29,columnNumber:13},this),(0,H.jsxDEV)(`span`,{className:`truncate`,children:e.name},void 0,!1,{fileName:q,lineNumber:33,columnNumber:11},this),e.status===`uploading`?(0,H.jsxDEV)(j,{className:`size-3 shrink-0 animate-spin text-text-subtle`},void 0,!1,{fileName:q,lineNumber:37,columnNumber:13},this):e.status===`error`?(0,H.jsxDEV)(`span`,{className:`text-red-500 shrink-0`,title:`Upload failed`,children:`!`},void 0,!1,{fileName:q,lineNumber:39,columnNumber:13},this):null,(0,H.jsxDEV)(`button`,{type:`button`,onClick:()=>t(e.id),className:`shrink-0 rounded-sm p-0.5 hover:bg-border/50 transition-colors`,"aria-label":`Remove ${e.name}`,children:(0,H.jsxDEV)(n,{className:`size-3`},void 0,!1,{fileName:q,lineNumber:49,columnNumber:13},this)},void 0,!1,{fileName:q,lineNumber:43,columnNumber:11},this)]},e.id,!0,{fileName:q,lineNumber:15,columnNumber:9},this))},void 0,!1,{fileName:q,lineNumber:13,columnNumber:5},this)}var J=`/Users/hienlh/Projects/ppm/src/web/components/chat/mode-selector.tsx`,It=[{id:`default`,label:`Ask before edits`,icon:fe,description:`Claude will ask for approval before making each edit`},{id:`acceptEdits`,label:`Edit automatically`,icon:ue,description:`Claude will edit files without asking first`},{id:`plan`,label:`Plan mode`,icon:le,description:`Claude will present a plan before editing`},{id:`bypassPermissions`,label:`Bypass permissions`,icon:be,description:`Claude will not ask before running commands`}];function Lt(e){return It.find(t=>t.id===e)?.label??`Unknown`}function Rt(e){return It.find(t=>t.id===e)?.icon??fe}function zt({value:e,onChange:t,open:n,onOpenChange:r}){let a=(0,B.useRef)(null),o=(0,B.useRef)(0);(0,B.useEffect)(()=>{if(!n)return;let e=e=>{a.current&&!a.current.contains(e.target)&&r(!1)};return document.addEventListener(`mousedown`,e),()=>document.removeEventListener(`mousedown`,e)},[n,r]),(0,B.useEffect)(()=>{n&&(o.current=It.findIndex(t=>t.id===e),o.current<0&&(o.current=0))},[n,e]);let s=(0,B.useCallback)(e=>{if(e.key===`Escape`){r(!1);return}if(e.key===`ArrowDown`||e.key===`ArrowUp`){e.preventDefault();let t=e.key===`ArrowDown`?1:-1;o.current=(o.current+t+It.length)%It.length,(a.current?.querySelector(`[data-idx="${o.current}"]`))?.focus()}if(e.key===`Enter`){e.preventDefault();let n=It[o.current];n&&(t(n.id),r(!1))}},[t,r]);return n?(0,H.jsxDEV)(`div`,{ref:a,role:`listbox`,"aria-label":`Permission modes`,onKeyDown:s,onMouseDown:e=>e.stopPropagation(),onClick:e=>e.stopPropagation(),className:`absolute bottom-full left-0 mb-1 z-50 w-72 md:w-80 rounded-lg border border-border bg-surface shadow-lg`,children:[(0,H.jsxDEV)(`div`,{className:`flex items-center justify-between px-3 py-2 border-b border-border`,children:[(0,H.jsxDEV)(`span`,{className:`text-xs font-medium text-text-secondary`,children:`Modes`},void 0,!1,{fileName:J,lineNumber:86,columnNumber:9},this),(0,H.jsxDEV)(`kbd`,{className:`text-[10px] px-1.5 py-0.5 rounded bg-surface-elevated text-text-subtle border border-border`,children:`Shift + Tab`},void 0,!1,{fileName:J,lineNumber:87,columnNumber:9},this)]},void 0,!0,{fileName:J,lineNumber:85,columnNumber:7},this),(0,H.jsxDEV)(`div`,{className:`py-1`,children:It.map((n,a)=>{let o=n.icon,s=n.id===e;return(0,H.jsxDEV)(`button`,{"data-idx":a,role:`option`,"aria-selected":s,tabIndex:0,onClick:()=>{t(n.id),r(!1)},className:`w-full flex items-start gap-3 px-3 py-2.5 text-left transition-colors hover:bg-surface-elevated focus:bg-surface-elevated focus:outline-none ${s?`bg-surface-elevated`:``}`,children:[(0,H.jsxDEV)(o,{className:`size-4 mt-0.5 shrink-0 text-text-secondary`},void 0,!1,{fileName:J,lineNumber:105,columnNumber:15},this),(0,H.jsxDEV)(`div`,{className:`flex-1 min-w-0`,children:[(0,H.jsxDEV)(`div`,{className:`text-sm font-medium text-text-primary`,children:n.label},void 0,!1,{fileName:J,lineNumber:107,columnNumber:17},this),(0,H.jsxDEV)(`div`,{className:`text-xs text-text-subtle leading-snug`,children:n.description},void 0,!1,{fileName:J,lineNumber:108,columnNumber:17},this)]},void 0,!0,{fileName:J,lineNumber:106,columnNumber:15},this),s&&(0,H.jsxDEV)(i,{className:`size-4 mt-0.5 shrink-0 text-primary`},void 0,!1,{fileName:J,lineNumber:110,columnNumber:28},this)]},n.id,!0,{fileName:J,lineNumber:96,columnNumber:13},this)})},void 0,!1,{fileName:J,lineNumber:91,columnNumber:7},this)]},void 0,!0,{fileName:J,lineNumber:76,columnNumber:5},this):null}var Bt=`/Users/hienlh/Projects/ppm/src/web/components/chat/file-picker.tsx`;function Vt(e){let t=[];function n(e){for(let r of e)t.push(r),r.children&&n(r.children)}return n(e),t}function Ht({items:e,filter:t,onSelect:n,onClose:r,visible:i}){let[a,o]=(0,B.useState)(0),s=(0,B.useRef)(null),c=(()=>{if(!t)return e.slice(0,50);let n=t.toLowerCase();return e.filter(e=>e.path.toLowerCase().includes(n)||e.name.toLowerCase().includes(n)).slice(0,50)})();(0,B.useEffect)(()=>{o(0)},[t]),(0,B.useEffect)(()=>{let e=s.current;e&&e.children[a]?.scrollIntoView({block:`nearest`})},[a]);let l=(0,B.useCallback)(e=>{if(!i||c.length===0)return!1;switch(e.key){case`ArrowUp`:return e.preventDefault(),o(e=>e>0?e-1:c.length-1),!0;case`ArrowDown`:return e.preventDefault(),o(e=>e<c.length-1?e+1:0),!0;case`Enter`:case`Tab`:return e.preventDefault(),c[a]&&n(c[a]),!0;case`Escape`:return e.preventDefault(),r(),!0}return!1},[i,c,a,n,r]);return(0,B.useEffect)(()=>{if(!i)return;let e=e=>{l(e)&&e.stopPropagation()};return document.addEventListener(`keydown`,e,!0),()=>document.removeEventListener(`keydown`,e,!0)},[i,l]),!i||c.length===0?null:(0,H.jsxDEV)(`div`,{className:`max-h-52 overflow-y-auto border-b border-border bg-surface`,children:(0,H.jsxDEV)(`div`,{ref:s,className:`py-1`,children:c.map((e,t)=>(0,H.jsxDEV)(`button`,{className:`flex items-center gap-2 w-full px-3 py-1.5 text-left transition-colors ${t===a?`bg-primary/10 text-primary`:`hover:bg-surface-hover text-text-primary`}`,onMouseEnter:()=>o(t),onClick:()=>n(e),children:[(0,H.jsxDEV)(`span`,{className:`shrink-0`,children:e.type===`directory`?(0,H.jsxDEV)(N,{className:`size-4 text-amber-500`},void 0,!1,{fileName:Bt,lineNumber:115,columnNumber:17},this):(0,H.jsxDEV)(D,{className:`size-4 text-blue-400`},void 0,!1,{fileName:Bt,lineNumber:117,columnNumber:17},this)},void 0,!1,{fileName:Bt,lineNumber:113,columnNumber:13},this),(0,H.jsxDEV)(`span`,{className:`text-sm truncate`,children:e.path},void 0,!1,{fileName:Bt,lineNumber:120,columnNumber:13},this)]},e.path,!0,{fileName:Bt,lineNumber:103,columnNumber:11},this))},void 0,!1,{fileName:Bt,lineNumber:101,columnNumber:7},this)},void 0,!1,{fileName:Bt,lineNumber:100,columnNumber:5},this)}var Y=`/Users/hienlh/Projects/ppm/src/web/components/chat/message-input.tsx`,Ut=(0,B.memo)(function({onSend:e,isStreaming:t,onCancel:n,disabled:r,projectName:i,onSlashStateChange:a,onSlashItemsLoaded:o,slashSelected:s,onFileStateChange:c,onFileItemsLoaded:l,fileSelected:u,externalFiles:d,initialValue:f,autoFocus:p,permissionMode:h,onModeChange:y}){let[b,x]=(0,B.useState)(f??``),[S,C]=(0,B.useState)([]),[w,T]=(0,B.useState)(!1),E=(0,B.useRef)(null),D=(0,B.useRef)(null),O=(0,B.useRef)(null),k=(0,B.useRef)([]),A=(0,B.useRef)([]);(0,B.useEffect)(()=>{f&&(x(f),setTimeout(()=>{let e=E.current;e&&(e.focus(),e.selectionStart=e.selectionEnd=e.value.length)},50))},[f]),(0,B.useEffect)(()=>{p&&setTimeout(()=>{(window.matchMedia(`(min-width: 768px)`).matches?E.current:D.current)?.focus()},100)},[]),(0,B.useEffect)(()=>{if(!i){k.current=[],o?.([]);return}v.get(`${g(i)}/chat/slash-items`).then(e=>{k.current=e,o?.(e)}).catch(()=>{k.current=[],o?.([])})},[i]),(0,B.useEffect)(()=>{if(!i){A.current=[],l?.([]);return}v.get(`${g(i)}/files/tree?depth=5`).then(e=>{let t=Vt(e);A.current=t,l?.(t)}).catch(()=>{A.current=[],l?.([])})},[i]),(0,B.useEffect)(()=>{if(!s)return;let e=E.current,t=e?.selectionStart??b.length,n=b.slice(0,t),r=b.slice(t),i=n.replace(/(?:^|\s)\/\S*$/,e=>`${e.startsWith(`/`)?``:e[0]}/${s.name} `);x(i+r),a?.(!1,``),c?.(!1,``),e&&(e.focus(),setTimeout(()=>{e.selectionStart=e.selectionEnd=i.length},0))},[s]),(0,B.useEffect)(()=>{if(!u)return;let e=E.current;if(!e)return;let t=e.selectionStart,n=b.slice(0,t),r=b.slice(t),i=n.match(/@(\S*)$/);if(i){let t=n.length-i[0].length;x(n.slice(0,t)+`@${u.path} `+r);let a=t+u.path.length+2;setTimeout(()=>{e.selectionStart=e.selectionEnd=a,e.focus()},0)}else{let t=b+`@${u.path} `;x(t),setTimeout(()=>{e.selectionStart=e.selectionEnd=t.length,e.focus()},0)}c?.(!1,``)},[u]),(0,B.useEffect)(()=>{!d||d.length===0||M(d)},[d]);let j=(0,B.useCallback)(async e=>{if(!i)return null;try{let t=new FormData;t.append(`files`,e);let n={},r=_();r&&(n.Authorization=`Bearer ${r}`);let a=await(await fetch(`${g(i)}/chat/upload`,{method:`POST`,headers:n,body:t})).json();return a.ok&&Array.isArray(a.data)&&a.data.length>0?a.data[0].path:null}catch{return null}},[i]),M=(0,B.useCallback)(e=>{for(let t of e){if(!Nt(t)){x(e=>e+(e.length>0&&!e.endsWith(` `)?` `:``)+t.name);continue}let e=m(),n=Mt(t),r=n?URL.createObjectURL(t):void 0,i={id:e,name:t.name,file:t,isImage:n,previewUrl:r,status:`uploading`};C(e=>[...e,i]),j(t).then(t=>{C(n=>n.map(n=>n.id===e?{...n,serverPath:t??void 0,status:t?`ready`:`error`}:n))})}(D.current??E.current)?.focus()},[j]),N=(0,B.useCallback)(e=>{C(t=>{let n=t.find(t=>t.id===e);return n?.previewUrl&&URL.revokeObjectURL(n.previewUrl),t.filter(t=>t.id!==e)})},[]),P=(0,B.useCallback)(()=>{let t=b.trim(),n=S.filter(e=>e.status===`ready`);if(!(!t&&n.length===0)&&!r){a?.(!1,``),c?.(!1,``),e(t,n),x(``);for(let e of S)e.previewUrl&&URL.revokeObjectURL(e.previewUrl);C([]),E.current&&(E.current.style.height=`auto`),D.current&&(D.current.style.height=`auto`)}},[b,S,r,e,a,c]),F=(0,B.useCallback)(e=>{if(e.key===`Enter`&&!e.shiftKey){e.preventDefault(),P();return}if(e.shiftKey&&e.key===`Tab`){e.preventDefault();let t=[`default`,`acceptEdits`,`plan`,`bypassPermissions`],n=t[(t.indexOf(h??`bypassPermissions`)+1)%t.length];y?.(n)}},[P,h,y]),I=(0,B.useCallback)((e,t)=>{let n=e.slice(0,t),r=n.match(/(?:^|\s)\/(\S*)$/);if(r&&k.current.length>0){a?.(!0,r[1]??``),c?.(!1,``);return}let i=n.match(/@(\S*)$/);if(i&&A.current.length>0){c?.(!0,i[1]??``),a?.(!1,``);return}a?.(!1,``),c?.(!1,``)},[a,c]),L=(0,B.useCallback)((e,t)=>{x(e),I(e,t)},[I]),ee=(0,B.useCallback)(e=>{let t=e?.target??E.current;t&&(t.style.height=`auto`,t.style.height=Math.min(t.scrollHeight,160)+`px`)},[]),R=(0,B.useCallback)(e=>{let t=e.clipboardData?.items;if(!t)return;let n=[];for(let e of t)if(e.kind===`file`){let t=e.getAsFile();t&&n.push(t)}n.length>0&&(e.preventDefault(),M(n))},[M]),te=(0,B.useCallback)(e=>{e.preventDefault();let t=Array.from(e.dataTransfer.files);t.length>0&&M(t)},[M]),ne=(0,B.useCallback)(e=>{e.preventDefault()},[]),z=(0,B.useCallback)(()=>{O.current?.click()},[]),re=(0,B.useCallback)(e=>{let t=Array.from(e.target.files??[]);t.length>0&&M(t),e.target.value=``},[M]),ie=b.trim().length>0||S.some(e=>e.status===`ready`),ae=t&&!ie;return(0,H.jsxDEV)(`div`,{className:`p-2 md:p-3 bg-background`,children:[(0,H.jsxDEV)(`div`,{className:`border border-border rounded-xl md:rounded-2xl bg-surface shadow-sm cursor-text`,onClick:e=>{r||e.target instanceof HTMLTextAreaElement||(window.matchMedia(`(min-width: 768px)`).matches?E.current:D.current)?.focus()},children:[(0,H.jsxDEV)(Ft,{attachments:S,onRemove:N},void 0,!1,{fileName:Y,lineNumber:427,columnNumber:9},this),(0,H.jsxDEV)(`div`,{className:`flex items-center gap-1 px-2 pt-2 md:hidden relative`,children:[(0,H.jsxDEV)(Wt,{mode:h??`bypassPermissions`,onClick:()=>T(e=>!e)},void 0,!1,{fileName:Y,lineNumber:430,columnNumber:11},this),(0,H.jsxDEV)(zt,{value:h??`bypassPermissions`,onChange:e=>y?.(e),open:w,onOpenChange:T},void 0,!1,{fileName:Y,lineNumber:434,columnNumber:11},this)]},void 0,!0,{fileName:Y,lineNumber:429,columnNumber:9},this),(0,H.jsxDEV)(`div`,{className:`flex items-end gap-1 md:hidden px-2 py-2`,children:[(0,H.jsxDEV)(`button`,{type:`button`,onClick:e=>{e.stopPropagation(),z()},disabled:r,className:`flex items-center justify-center size-7 shrink-0 rounded-full text-text-subtle hover:text-text-primary transition-colors disabled:opacity-50`,"aria-label":`Attach file`,children:(0,H.jsxDEV)(ge,{className:`size-4`},void 0,!1,{fileName:Y,lineNumber:450,columnNumber:13},this)},void 0,!1,{fileName:Y,lineNumber:443,columnNumber:11},this),(0,H.jsxDEV)(`textarea`,{ref:D,value:b,onChange:e=>{L(e.target.value,e.target.selectionStart),ee(e)},onKeyDown:F,onPaste:R,onDrop:te,onDragOver:ne,placeholder:t?`Follow-up...`:`Ask anything...`,disabled:r,rows:1,className:`flex-1 resize-none bg-transparent py-1.5 text-sm text-foreground placeholder:text-text-subtle focus:outline-none disabled:opacity-50 max-h-20`},void 0,!1,{fileName:Y,lineNumber:452,columnNumber:11},this),ae?(0,H.jsxDEV)(`button`,{onClick:e=>{e.stopPropagation(),n?.()},className:`flex items-center justify-center size-7 shrink-0 rounded-full bg-red-600 text-white hover:bg-red-500 transition-colors`,"aria-label":`Stop`,children:(0,H.jsxDEV)(Se,{className:`size-3`},void 0,!1,{fileName:Y,lineNumber:471,columnNumber:15},this)},void 0,!1,{fileName:Y,lineNumber:466,columnNumber:13},this):(0,H.jsxDEV)(`button`,{onClick:e=>{e.stopPropagation(),P()},disabled:r||!ie,className:`flex items-center justify-center size-7 shrink-0 rounded-full bg-primary text-primary-foreground hover:bg-primary/90 disabled:opacity-30 transition-colors`,"aria-label":`Send`,children:(0,H.jsxDEV)(se,{className:`size-3.5`},void 0,!1,{fileName:Y,lineNumber:480,columnNumber:15},this)},void 0,!1,{fileName:Y,lineNumber:474,columnNumber:13},this)]},void 0,!0,{fileName:Y,lineNumber:442,columnNumber:9},this),(0,H.jsxDEV)(`div`,{className:`hidden md:block`,children:[(0,H.jsxDEV)(`textarea`,{ref:E,value:b,onChange:e=>{L(e.target.value,e.target.selectionStart),ee(e)},onKeyDown:F,onPaste:R,onDrop:te,onDragOver:ne,placeholder:t?`Follow-up or Stop...`:`Ask anything...`,disabled:r,rows:1,className:`w-full resize-none bg-transparent px-4 pt-3 pb-1 text-sm text-foreground placeholder:text-text-subtle focus:outline-none disabled:opacity-50 max-h-40`},void 0,!1,{fileName:Y,lineNumber:487,columnNumber:11},this),(0,H.jsxDEV)(`div`,{className:`flex items-center justify-between px-3 pb-2`,children:[(0,H.jsxDEV)(`div`,{className:`flex items-center gap-1`,children:[(0,H.jsxDEV)(`button`,{type:`button`,onClick:e=>{e.stopPropagation(),z()},disabled:r,className:`flex items-center justify-center size-8 rounded-full text-text-subtle hover:text-text-primary hover:bg-surface-elevated transition-colors disabled:opacity-50`,"aria-label":`Attach file`,children:(0,H.jsxDEV)(ge,{className:`size-4`},void 0,!1,{fileName:Y,lineNumber:509,columnNumber:17},this)},void 0,!1,{fileName:Y,lineNumber:502,columnNumber:15},this),(0,H.jsxDEV)(`div`,{className:`relative`,children:[(0,H.jsxDEV)(Wt,{mode:h??`bypassPermissions`,onClick:()=>T(e=>!e)},void 0,!1,{fileName:Y,lineNumber:513,columnNumber:17},this),(0,H.jsxDEV)(zt,{value:h??`bypassPermissions`,onChange:e=>y?.(e),open:w,onOpenChange:T},void 0,!1,{fileName:Y,lineNumber:517,columnNumber:17},this)]},void 0,!0,{fileName:Y,lineNumber:512,columnNumber:15},this)]},void 0,!0,{fileName:Y,lineNumber:501,columnNumber:13},this),(0,H.jsxDEV)(`div`,{className:`flex items-center gap-1`,children:ae?(0,H.jsxDEV)(`button`,{onClick:e=>{e.stopPropagation(),n?.()},className:`flex items-center justify-center size-8 rounded-full bg-red-600 text-white hover:bg-red-500 transition-colors`,"aria-label":`Stop response`,children:(0,H.jsxDEV)(Se,{className:`size-3.5`},void 0,!1,{fileName:Y,lineNumber:532,columnNumber:19},this)},void 0,!1,{fileName:Y,lineNumber:527,columnNumber:17},this):(0,H.jsxDEV)(`button`,{onClick:e=>{e.stopPropagation(),P()},disabled:r||!ie,className:`flex items-center justify-center size-8 rounded-full bg-primary text-primary-foreground hover:bg-primary/90 disabled:opacity-30 disabled:cursor-not-allowed transition-colors`,"aria-label":`Send message`,children:(0,H.jsxDEV)(se,{className:`size-4`},void 0,!1,{fileName:Y,lineNumber:541,columnNumber:19},this)},void 0,!1,{fileName:Y,lineNumber:535,columnNumber:17},this)},void 0,!1,{fileName:Y,lineNumber:525,columnNumber:13},this)]},void 0,!0,{fileName:Y,lineNumber:500,columnNumber:11},this)]},void 0,!0,{fileName:Y,lineNumber:486,columnNumber:9},this)]},void 0,!0,{fileName:Y,lineNumber:413,columnNumber:7},this),(0,H.jsxDEV)(`input`,{ref:O,type:`file`,multiple:!0,className:`hidden`,onChange:re},void 0,!1,{fileName:Y,lineNumber:549,columnNumber:7},this)]},void 0,!0,{fileName:Y,lineNumber:411,columnNumber:5},this)});function Wt({mode:e,onClick:t}){let n=Rt(e),r=Lt(e);return(0,H.jsxDEV)(`button`,{type:`button`,onClick:e=>{e.stopPropagation(),t()},className:`inline-flex items-center gap-1 px-2 py-1 rounded-md text-[11px] text-text-subtle hover:text-text-primary hover:bg-surface-elevated transition-colors border border-transparent hover:border-border`,"aria-label":`Permission mode: ${r}`,children:[(0,H.jsxDEV)(n,{className:`size-3`},void 0,!1,{fileName:Y,lineNumber:565,columnNumber:7},this),(0,H.jsxDEV)(`span`,{className:`max-w-[100px] truncate`,children:r},void 0,!1,{fileName:Y,lineNumber:566,columnNumber:7},this)]},void 0,!0,{fileName:Y,lineNumber:559,columnNumber:5},this)}var X=`/Users/hienlh/Projects/ppm/src/web/components/chat/slash-command-picker.tsx`;function Gt({items:e,filter:t,onSelect:n,onClose:r,visible:i}){let[a,o]=(0,B.useState)(0),s=(0,B.useRef)(null),c=e.filter(e=>{let n=t.toLowerCase();return e.name.toLowerCase().includes(n)||e.description.toLowerCase().includes(n)});(0,B.useEffect)(()=>{o(0)},[t]),(0,B.useEffect)(()=>{let e=s.current;e&&e.children[a]?.scrollIntoView({block:`nearest`})},[a]);let l=(0,B.useCallback)(e=>{if(!i||c.length===0)return!1;switch(e.key){case`ArrowUp`:return e.preventDefault(),o(e=>e>0?e-1:c.length-1),!0;case`ArrowDown`:return e.preventDefault(),o(e=>e<c.length-1?e+1:0),!0;case`Enter`:case`Tab`:return e.preventDefault(),c[a]&&n(c[a]),!0;case`Escape`:return e.preventDefault(),r(),!0}return!1},[i,c,a,n,r]);return(0,B.useEffect)(()=>{if(!i)return;let e=e=>{l(e)&&e.stopPropagation()};return document.addEventListener(`keydown`,e,!0),()=>document.removeEventListener(`keydown`,e,!0)},[i,l]),!i||c.length===0?null:(0,H.jsxDEV)(`div`,{className:`max-h-52 overflow-y-auto border-b border-border bg-surface`,children:(0,H.jsxDEV)(`div`,{ref:s,className:`py-1`,children:c.map((e,t)=>(0,H.jsxDEV)(`button`,{className:`flex items-start gap-3 w-full px-3 py-2 text-left transition-colors ${t===a?`bg-primary/10 text-primary`:`hover:bg-surface-hover text-text-primary`}`,onMouseEnter:()=>o(t),onClick:()=>n(e),children:[(0,H.jsxDEV)(`span`,{className:`shrink-0 mt-0.5`,children:e.type===`skill`?(0,H.jsxDEV)(xe,{className:`size-4 text-amber-500`},void 0,!1,{fileName:X,lineNumber:109,columnNumber:17},this):(0,H.jsxDEV)(F,{className:`size-4 text-blue-500`},void 0,!1,{fileName:X,lineNumber:111,columnNumber:17},this)},void 0,!1,{fileName:X,lineNumber:107,columnNumber:13},this),(0,H.jsxDEV)(`div`,{className:`min-w-0 flex-1`,children:[(0,H.jsxDEV)(`div`,{className:`flex items-baseline gap-2`,children:[(0,H.jsxDEV)(`span`,{className:`font-medium text-sm`,children:[`/`,e.name]},void 0,!0,{fileName:X,lineNumber:116,columnNumber:17},this),e.argumentHint&&(0,H.jsxDEV)(`span`,{className:`text-xs text-text-subtle`,children:e.argumentHint},void 0,!1,{fileName:X,lineNumber:118,columnNumber:19},this),(0,H.jsxDEV)(`span`,{className:`text-xs text-text-subtle capitalize ml-auto`,children:e.scope===`user`?`global`:e.type},void 0,!1,{fileName:X,lineNumber:120,columnNumber:17},this)]},void 0,!0,{fileName:X,lineNumber:115,columnNumber:15},this),e.description&&(0,H.jsxDEV)(`p`,{className:`text-xs text-text-subtle mt-0.5 line-clamp-2`,children:e.description},void 0,!1,{fileName:X,lineNumber:125,columnNumber:17},this)]},void 0,!0,{fileName:X,lineNumber:114,columnNumber:13},this)]},`${e.type}-${e.name}`,!0,{fileName:X,lineNumber:97,columnNumber:11},this))},void 0,!1,{fileName:X,lineNumber:95,columnNumber:7},this)},void 0,!1,{fileName:X,lineNumber:94,columnNumber:5},this)}var Z=`/Users/hienlh/Projects/ppm/src/web/components/chat/usage-badge.tsx`;function Kt(e){return e>=90?`text-red-500`:e>=70?`text-amber-500`:`text-green-500`}function qt(e){return e>=90?`bg-red-500`:e>=70?`bg-amber-500`:`bg-green-500`}function Jt(e){if(!e)return null;let t=null;if(e.resetsInMinutes!=null)t=e.resetsInMinutes;else if(e.resetsInHours!=null)t=Math.round(e.resetsInHours*60);else if(e.resetsAt){let n=new Date(e.resetsAt).getTime()-Date.now();t=n>0?Math.ceil(n/6e4):0}if(t==null)return null;if(t<=0)return`now`;let n=Math.floor(t/1440),r=Math.floor(t%1440/60),i=t%60;return n>0?i>0?`${n}d ${r}h ${i}m`:r>0?`${n}d ${r}h`:`${n}d`:r>0?i>0?`${r}h ${i}m`:`${r}h`:`${i}m`}function Yt({label:e,bucket:t}){if(!t)return null;let n=Math.round(t.utilization*100),r=Jt(t);return(0,H.jsxDEV)(`div`,{className:`space-y-1`,children:[(0,H.jsxDEV)(`div`,{className:`flex items-center justify-between`,children:[(0,H.jsxDEV)(`span`,{className:`text-xs font-medium text-text-primary`,children:e},void 0,!1,{fileName:Z,lineNumber:98,columnNumber:9},this),r&&(0,H.jsxDEV)(`span`,{className:`text-[10px] text-text-subtle`,children:[`↻ `,r]},void 0,!0,{fileName:Z,lineNumber:100,columnNumber:11},this)]},void 0,!0,{fileName:Z,lineNumber:97,columnNumber:7},this),(0,H.jsxDEV)(`div`,{className:`flex items-center gap-2`,children:[(0,H.jsxDEV)(`div`,{className:`flex-1 h-2 rounded-full bg-border overflow-hidden`,children:(0,H.jsxDEV)(`div`,{className:`h-full rounded-full transition-all ${qt(n)}`,style:{width:`${Math.min(n,100)}%`}},void 0,!1,{fileName:Z,lineNumber:105,columnNumber:11},this)},void 0,!1,{fileName:Z,lineNumber:104,columnNumber:9},this),(0,H.jsxDEV)(`span`,{className:`text-xs font-medium tabular-nums w-10 text-right ${Kt(n)}`,children:[n,`%`]},void 0,!0,{fileName:Z,lineNumber:110,columnNumber:9},this)]},void 0,!0,{fileName:Z,lineNumber:103,columnNumber:7},this)]},void 0,!0,{fileName:Z,lineNumber:96,columnNumber:5},this)}function Xt(e){if(!e)return null;let t=Math.round((Date.now()-e)/1e3);if(t<5)return`just now`;if(t<60)return`${t}s ago`;let n=Math.floor(t/60);if(n<60)return`${n}m ago`;let r=Math.floor(n/60),i=n%60;return r<24?i>0?`${r}h ${i}m ago`:`${r}h ago`:`${Math.floor(r/24)}d ago`}function Zt({entry:e,isActive:t,accountInfo:n,onToggle:r,onVerify:i,verifyingId:a,onViewProfile:o,flash:s}){let{usage:c}=e,l=c.session||c.weekly||c.weeklyOpus||c.weeklySonnet,u=n?.status??e.accountStatus;return(0,H.jsxDEV)(`div`,{className:`rounded-md border p-2 space-y-1.5 transition-colors duration-500 ${s?`bg-primary/10 border-primary/40`:``} ${t?`border-primary/30 bg-primary/5`:`border-border/50`}`,children:[(0,H.jsxDEV)(`div`,{className:`flex items-center gap-1.5`,children:[(0,H.jsxDEV)(`span`,{className:`text-xs font-medium truncate flex-1 min-w-0`,children:e.accountLabel??e.accountId.slice(0,8)},void 0,!1,{fileName:Z,lineNumber:149,columnNumber:9},this),!e.isOAuth&&(0,H.jsxDEV)(`span`,{className:`text-[9px] text-text-subtle shrink-0`,children:`API key`},void 0,!1,{fileName:Z,lineNumber:153,columnNumber:11},this),(0,H.jsxDEV)(`div`,{className:`flex items-center gap-0.5 shrink-0`,children:[o&&n?.profileData&&(0,H.jsxDEV)(`button`,{className:`p-1 rounded cursor-pointer text-text-subtle hover:text-foreground hover:bg-surface-elevated transition-colors`,onClick:()=>o(n.profileData),title:`View profile`,children:(0,H.jsxDEV)(P,{className:`size-3`},void 0,!1,{fileName:Z,lineNumber:163,columnNumber:15},this)},void 0,!1,{fileName:Z,lineNumber:158,columnNumber:13},this),i&&(0,H.jsxDEV)(`button`,{className:`p-1 rounded cursor-pointer text-text-subtle hover:text-green-600 hover:bg-surface-elevated transition-colors`,onClick:()=>i(e.accountId),disabled:a===e.accountId,title:`Verify token`,children:a===e.accountId?(0,H.jsxDEV)(j,{className:`size-3 animate-spin`},void 0,!1,{fileName:Z,lineNumber:173,columnNumber:50},this):(0,H.jsxDEV)(ye,{className:`size-3`},void 0,!1,{fileName:Z,lineNumber:173,columnNumber:96},this)},void 0,!1,{fileName:Z,lineNumber:167,columnNumber:13},this),r&&(0,H.jsxDEV)(re,{checked:u!==`disabled`,onCheckedChange:()=>r(e.accountId,u),disabled:u===`cooldown`,className:`scale-[0.6] cursor-pointer`},void 0,!1,{fileName:Z,lineNumber:177,columnNumber:13},this)]},void 0,!0,{fileName:Z,lineNumber:156,columnNumber:9},this)]},void 0,!0,{fileName:Z,lineNumber:148,columnNumber:7},this),l?(0,H.jsxDEV)(`div`,{className:`space-y-1.5`,children:[(0,H.jsxDEV)(Yt,{label:`5-Hour Session`,bucket:c.session},void 0,!1,{fileName:Z,lineNumber:188,columnNumber:11},this),(0,H.jsxDEV)(Yt,{label:`Weekly`,bucket:c.weekly},void 0,!1,{fileName:Z,lineNumber:189,columnNumber:11},this),(0,H.jsxDEV)(Yt,{label:`Weekly (Opus)`,bucket:c.weeklyOpus},void 0,!1,{fileName:Z,lineNumber:190,columnNumber:11},this),(0,H.jsxDEV)(Yt,{label:`Weekly (Sonnet)`,bucket:c.weeklySonnet},void 0,!1,{fileName:Z,lineNumber:191,columnNumber:11},this)]},void 0,!0,{fileName:Z,lineNumber:187,columnNumber:9},this):(0,H.jsxDEV)(`p`,{className:`text-[10px] text-text-subtle`,children:e.isOAuth?`No usage data yet`:`Usage tracking not available for API keys`},void 0,!1,{fileName:Z,lineNumber:194,columnNumber:9},this),c.lastFetchedAt&&(0,H.jsxDEV)(`p`,{className:`text-[9px] text-text-subtle`,children:[`Updated: `,Xt(new Date(c.lastFetchedAt).getTime())]},void 0,!0,{fileName:Z,lineNumber:199,columnNumber:9},this)]},void 0,!0,{fileName:Z,lineNumber:147,columnNumber:5},this)}function Qt({usage:e,visible:t,onClose:r,onReload:i,loading:a,lastFetchedAt:o}){let[s,c]=(0,B.useState)([]),[l,u]=(0,B.useState)([]),[d,f]=(0,B.useState)(null),[p,m]=(0,B.useState)(!0),[h,g]=(0,B.useState)(!1),[_,v]=(0,B.useState)(new Set),[y,T]=(0,B.useState)(null),[E,D]=(0,B.useState)(null),O=(0,B.useRef)([]);async function k(){let e=s.length>0;e?g(!0):m(!0);let[t,n,r]=await Promise.allSettled([C(),w(),b()]);if(t.status===`fulfilled`){let n=t.value;if(e&&O.current.length>0){let e=new Set,t=new Map(O.current.map(e=>[e.accountId,e]));for(let r of n){let n=t.get(r.accountId);if(!n){e.add(r.accountId);continue}let i=n.usage,a=r.usage;(i.session?.utilization!==a.session?.utilization||i.weekly?.utilization!==a.weekly?.utilization||i.weeklyOpus?.utilization!==a.weeklyOpus?.utilization||i.weeklySonnet?.utilization!==a.weeklySonnet?.utilization)&&e.add(r.accountId)}e.size>0&&(v(e),setTimeout(()=>v(new Set),1500))}O.current=n,c(n)}n.status===`fulfilled`&&u(n.value),r.status===`fulfilled`&&f(r.value?.id??null),m(!1),g(!1)}if((0,B.useEffect)(()=>{t&&k()},[t]),(0,B.useEffect)(()=>{!t||!o||k()},[o]),!t)return null;let A=new Map(l.map(e=>[e.id,e])),j=e.queryCostUsd!=null||e.totalCostUsd!=null,N=s.length>0;async function P(e,t){await x(e,{status:t===`disabled`?`active`:`disabled`}),k(),i?.()}async function F(e){T(e);try{await S(e),k()}catch{}T(null)}return(0,H.jsxDEV)(`div`,{className:`border-b border-border bg-surface px-3 py-2.5 space-y-2.5 max-h-[350px] overflow-y-auto`,children:[(0,H.jsxDEV)(`div`,{className:`flex items-center justify-between`,children:[(0,H.jsxDEV)(`div`,{className:`flex items-center gap-2`,children:[(0,H.jsxDEV)(`span`,{className:`text-xs font-semibold text-text-primary`,children:`Usage & Accounts`},void 0,!1,{fileName:Z,lineNumber:290,columnNumber:11},this),o&&(0,H.jsxDEV)(`span`,{className:`text-[10px] text-text-subtle`,children:Xt(new Date(o).getTime())},void 0,!1,{fileName:Z,lineNumber:292,columnNumber:13},this)]},void 0,!0,{fileName:Z,lineNumber:289,columnNumber:9},this),(0,H.jsxDEV)(`div`,{className:`flex items-center gap-1`,children:[i&&(0,H.jsxDEV)(`button`,{onClick:()=>{i(),k()},disabled:a||h,className:`text-xs text-text-subtle hover:text-text-primary px-1 disabled:opacity-50 cursor-pointer`,title:`Refresh`,children:(0,H.jsxDEV)(M,{className:`size-3 ${a||h?`animate-spin`:``}`},void 0,!1,{fileName:Z,lineNumber:303,columnNumber:15},this)},void 0,!1,{fileName:Z,lineNumber:297,columnNumber:13},this),(0,H.jsxDEV)(`button`,{onClick:r,className:`text-xs text-text-subtle hover:text-text-primary px-1 cursor-pointer`,children:(0,H.jsxDEV)(n,{className:`size-3`},void 0,!1,{fileName:Z,lineNumber:310,columnNumber:13},this)},void 0,!1,{fileName:Z,lineNumber:306,columnNumber:11},this)]},void 0,!0,{fileName:Z,lineNumber:295,columnNumber:9},this)]},void 0,!0,{fileName:Z,lineNumber:288,columnNumber:7},this),N||p?(0,H.jsxDEV)(`div`,{className:`grid grid-cols-[repeat(auto-fill,minmax(180px,1fr))] gap-1.5`,children:p?(0,H.jsxDEV)(`p`,{className:`text-[10px] text-text-subtle`,children:`Loading...`},void 0,!1,{fileName:Z,lineNumber:318,columnNumber:13},this):s.map(t=>(0,H.jsxDEV)(Zt,{entry:t,isActive:t.accountId===(d??e.activeAccountId),accountInfo:A.get(t.accountId),onToggle:P,onVerify:F,verifyingId:y,onViewProfile:D,flash:_.has(t.accountId)},t.accountId,!1,{fileName:Z,lineNumber:321,columnNumber:15},this))},void 0,!1,{fileName:Z,lineNumber:316,columnNumber:9},this):(0,H.jsxDEV)(H.Fragment,{children:e.session||e.weekly||e.weeklyOpus||e.weeklySonnet?(0,H.jsxDEV)(`div`,{className:`space-y-2.5`,children:[(0,H.jsxDEV)(Yt,{label:`5-Hour Session`,bucket:e.session},void 0,!1,{fileName:Z,lineNumber:339,columnNumber:15},this),(0,H.jsxDEV)(Yt,{label:`Weekly`,bucket:e.weekly},void 0,!1,{fileName:Z,lineNumber:340,columnNumber:15},this),(0,H.jsxDEV)(Yt,{label:`Weekly (Opus)`,bucket:e.weeklyOpus},void 0,!1,{fileName:Z,lineNumber:341,columnNumber:15},this),(0,H.jsxDEV)(Yt,{label:`Weekly (Sonnet)`,bucket:e.weeklySonnet},void 0,!1,{fileName:Z,lineNumber:342,columnNumber:15},this)]},void 0,!0,{fileName:Z,lineNumber:338,columnNumber:13},this):(0,H.jsxDEV)(`p`,{className:`text-xs text-text-subtle`,children:`No usage data available`},void 0,!1,{fileName:Z,lineNumber:345,columnNumber:13},this)},void 0,!1),j&&(0,H.jsxDEV)(`div`,{className:`border-t border-border pt-2 space-y-1`,children:[e.queryCostUsd!=null&&(0,H.jsxDEV)(`div`,{className:`flex items-center justify-between text-xs`,children:[(0,H.jsxDEV)(`span`,{className:`text-text-subtle`,children:`Last query`},void 0,!1,{fileName:Z,lineNumber:354,columnNumber:15},this),(0,H.jsxDEV)(`span`,{className:`text-text-primary font-medium tabular-nums`,children:[`$`,e.queryCostUsd.toFixed(4)]},void 0,!0,{fileName:Z,lineNumber:355,columnNumber:15},this)]},void 0,!0,{fileName:Z,lineNumber:353,columnNumber:13},this),e.totalCostUsd!=null&&(0,H.jsxDEV)(`div`,{className:`flex items-center justify-between text-xs`,children:[(0,H.jsxDEV)(`span`,{className:`text-text-subtle`,children:`Session total`},void 0,!1,{fileName:Z,lineNumber:362,columnNumber:15},this),(0,H.jsxDEV)(`span`,{className:`text-text-primary font-medium tabular-nums`,children:[`$`,e.totalCostUsd.toFixed(4)]},void 0,!0,{fileName:Z,lineNumber:363,columnNumber:15},this)]},void 0,!0,{fileName:Z,lineNumber:361,columnNumber:13},this)]},void 0,!0,{fileName:Z,lineNumber:351,columnNumber:9},this),E&&(0,H.jsxDEV)(`div`,{className:`border-t border-border pt-2`,children:[(0,H.jsxDEV)(`div`,{className:`flex items-center justify-between mb-1`,children:[(0,H.jsxDEV)(`span`,{className:`text-[10px] font-medium text-text-subtle`,children:`Profile`},void 0,!1,{fileName:Z,lineNumber:375,columnNumber:13},this),(0,H.jsxDEV)(`button`,{className:`text-text-subtle hover:text-foreground cursor-pointer`,onClick:()=>D(null),children:(0,H.jsxDEV)(n,{className:`size-3`},void 0,!1,{fileName:Z,lineNumber:377,columnNumber:15},this)},void 0,!1,{fileName:Z,lineNumber:376,columnNumber:13},this)]},void 0,!0,{fileName:Z,lineNumber:374,columnNumber:11},this),(0,H.jsxDEV)(`div`,{className:`grid grid-cols-[70px_1fr] gap-x-2 gap-y-0.5 text-[10px]`,children:[E.account?.display_name&&(0,H.jsxDEV)(H.Fragment,{children:[(0,H.jsxDEV)(`span`,{className:`text-text-subtle`,children:`Name`},void 0,!1,{fileName:Z,lineNumber:381,columnNumber:53},this),(0,H.jsxDEV)(`span`,{children:E.account.display_name},void 0,!1,{fileName:Z,lineNumber:381,columnNumber:99},this)]},void 0,!0),E.account?.email&&(0,H.jsxDEV)(H.Fragment,{children:[(0,H.jsxDEV)(`span`,{className:`text-text-subtle`,children:`Email`},void 0,!1,{fileName:Z,lineNumber:382,columnNumber:46},this),(0,H.jsxDEV)(`span`,{children:E.account.email},void 0,!1,{fileName:Z,lineNumber:382,columnNumber:93},this)]},void 0,!0),E.organization?.name&&(0,H.jsxDEV)(H.Fragment,{children:[(0,H.jsxDEV)(`span`,{className:`text-text-subtle`,children:`Org`},void 0,!1,{fileName:Z,lineNumber:383,columnNumber:50},this),(0,H.jsxDEV)(`span`,{children:E.organization.name},void 0,!1,{fileName:Z,lineNumber:383,columnNumber:95},this)]},void 0,!0),E.organization?.organization_type&&(0,H.jsxDEV)(H.Fragment,{children:[(0,H.jsxDEV)(`span`,{className:`text-text-subtle`,children:`Type`},void 0,!1,{fileName:Z,lineNumber:384,columnNumber:63},this),(0,H.jsxDEV)(`span`,{children:E.organization.organization_type},void 0,!1,{fileName:Z,lineNumber:384,columnNumber:109},this)]},void 0,!0),E.organization?.rate_limit_tier&&(0,H.jsxDEV)(H.Fragment,{children:[(0,H.jsxDEV)(`span`,{className:`text-text-subtle`,children:`Tier`},void 0,!1,{fileName:Z,lineNumber:385,columnNumber:61},this),(0,H.jsxDEV)(`span`,{children:E.organization.rate_limit_tier},void 0,!1,{fileName:Z,lineNumber:385,columnNumber:107},this)]},void 0,!0),E.organization?.subscription_status&&(0,H.jsxDEV)(H.Fragment,{children:[(0,H.jsxDEV)(`span`,{className:`text-text-subtle`,children:`Status`},void 0,!1,{fileName:Z,lineNumber:386,columnNumber:65},this),(0,H.jsxDEV)(`span`,{children:E.organization.subscription_status},void 0,!1,{fileName:Z,lineNumber:386,columnNumber:113},this)]},void 0,!0)]},void 0,!0,{fileName:Z,lineNumber:380,columnNumber:11},this)]},void 0,!0,{fileName:Z,lineNumber:373,columnNumber:9},this)]},void 0,!0,{fileName:Z,lineNumber:287,columnNumber:5},this)}var Q=`/Users/hienlh/Projects/ppm/src/web/components/chat/chat-history-bar.tsx`;function $t(e){try{return new Date(e).toLocaleDateString(void 0,{month:`short`,day:`numeric`})}catch{return``}}function en(e){return e>=90?`text-red-500`:e>=70?`text-amber-500`:`text-green-500`}function tn({projectName:e,usageInfo:t,contextWindowPct:r,usageLoading:a,refreshUsage:o,lastFetchedAt:s,sessionId:c,onSelectSession:l,onBugReport:u,isConnected:f,onReconnect:p}){let[m,h]=(0,B.useState)(null),[_,y]=(0,B.useState)([]),[b,x]=(0,B.useState)(!1),S=ee(e=>c?e.notifications.has(c):!1),C=ee(e=>e.clearForSession),[w,T]=(0,B.useState)(``),[D,O]=(0,B.useState)(null),[k,N]=(0,B.useState)(``),P=(0,B.useRef)(null),F=d(e=>e.openTab),I=e=>{h(t=>t===e?null:e)},L=(0,B.useCallback)(async()=>{if(e){x(!0);try{y(await v.get(`${g(e)}/chat/sessions`))}catch{}finally{x(!1)}}},[e]);(0,B.useEffect)(()=>{m===`history`&&_.length===0&&L()},[m]);function z(t){l?(l(t),h(null)):F({type:`chat`,title:t.title||`Chat`,projectId:e??null,metadata:{projectName:e,sessionId:t.id},closable:!0})}let re=(0,B.useCallback)((e,t)=>{t.stopPropagation(),O(e.id),N(e.title||``),setTimeout(()=>P.current?.select(),0)},[]),ie=(0,B.useCallback)(async()=>{if(!D||!k.trim()||!e){O(null);return}try{await v.patch(`${g(e)}/chat/sessions/${D}`,{title:k.trim()}),y(e=>e.map(e=>e.id===D?{...e,title:k.trim()}:e))}catch{}O(null)},[D,k,e]),ae=(0,B.useCallback)(()=>O(null),[]),se=w.trim()?_.filter(e=>(e.title||``).toLowerCase().includes(w.toLowerCase())):_,ce=t.fiveHour==null?null:Math.round(t.fiveHour*100),le=t.sevenDay==null?null:Math.round(t.sevenDay*100),ue=ce!=null||le!=null?en(Math.max(ce??0,le??0)):`text-text-subtle`;return(0,H.jsxDEV)(`div`,{className:`border-b border-border/50`,children:[(0,H.jsxDEV)(`div`,{className:`flex items-center gap-1 px-2 py-1`,children:[(0,H.jsxDEV)(`button`,{onClick:()=>I(`history`),className:`flex items-center gap-1 px-1.5 py-0.5 rounded text-[11px] transition-colors ${m===`history`?`text-primary bg-primary/10`:`text-text-secondary hover:text-foreground hover:bg-surface-elevated`}`,children:[(0,H.jsxDEV)(pe,{className:`size-3`},void 0,!1,{fileName:Q,lineNumber:146,columnNumber:11},this),(0,H.jsxDEV)(`span`,{children:`History`},void 0,!1,{fileName:Q,lineNumber:147,columnNumber:11},this)]},void 0,!0,{fileName:Q,lineNumber:140,columnNumber:9},this),(0,H.jsxDEV)(`button`,{onClick:()=>I(`config`),className:`p-1 rounded transition-colors ${m===`config`?`text-primary bg-primary/10`:`text-text-subtle hover:text-text-secondary hover:bg-surface-elevated`}`,title:`AI Settings`,children:(0,H.jsxDEV)(_e,{className:`size-3`},void 0,!1,{fileName:Q,lineNumber:158,columnNumber:11},this)},void 0,!1,{fileName:Q,lineNumber:151,columnNumber:9},this),(0,H.jsxDEV)(`button`,{onClick:()=>I(`usage`),className:`flex items-center gap-1 px-1.5 py-0.5 rounded text-[11px] font-medium tabular-nums transition-colors hover:bg-surface-elevated ${m===`usage`?`bg-primary/10`:``} ${ue}`,title:`Usage limits`,children:[(0,H.jsxDEV)(oe,{className:`size-3`},void 0,!1,{fileName:Q,lineNumber:169,columnNumber:11},this),t.activeAccountLabel&&(0,H.jsxDEV)(`span`,{className:`text-text-secondary font-normal truncate max-w-[60px]`,children:[`[`,t.activeAccountLabel,`]`]},void 0,!0,{fileName:Q,lineNumber:171,columnNumber:13},this),(0,H.jsxDEV)(`span`,{children:[`5h:`,ce==null?`--%`:`${ce}%`]},void 0,!0,{fileName:Q,lineNumber:173,columnNumber:11},this),(0,H.jsxDEV)(`span`,{className:`text-text-subtle`,children:`·`},void 0,!1,{fileName:Q,lineNumber:174,columnNumber:11},this),(0,H.jsxDEV)(`span`,{children:[`Wk:`,le==null?`--%`:`${le}%`]},void 0,!0,{fileName:Q,lineNumber:175,columnNumber:11},this),r!=null&&(0,H.jsxDEV)(H.Fragment,{children:[(0,H.jsxDEV)(`span`,{className:`text-text-subtle`,children:`·`},void 0,!1,{fileName:Q,lineNumber:178,columnNumber:15},this),(0,H.jsxDEV)(`span`,{className:en(r),children:[`Ctx:`,r,`%`]},void 0,!0,{fileName:Q,lineNumber:179,columnNumber:15},this)]},void 0,!0)]},void 0,!0,{fileName:Q,lineNumber:162,columnNumber:9},this),(0,H.jsxDEV)(`div`,{className:`flex-1`},void 0,!1,{fileName:Q,lineNumber:185,columnNumber:9},this),S&&c&&(0,H.jsxDEV)(`button`,{onClick:()=>C(c),className:`p-1 rounded text-amber-500 hover:text-amber-400 hover:bg-surface-elevated transition-colors`,title:`Mark as read`,children:(0,H.jsxDEV)(A,{className:`size-3`},void 0,!1,{fileName:Q,lineNumber:194,columnNumber:13},this)},void 0,!1,{fileName:Q,lineNumber:189,columnNumber:11},this),p&&(0,H.jsxDEV)(`button`,{onClick:p,className:`size-4 flex items-center justify-center`,title:f?`Connected`:`Disconnected — click to reconnect`,children:(0,H.jsxDEV)(`span`,{className:`size-2 rounded-full ${f?`bg-green-500`:`bg-red-500 animate-pulse`}`},void 0,!1,{fileName:Q,lineNumber:205,columnNumber:13},this)},void 0,!1,{fileName:Q,lineNumber:200,columnNumber:11},this)]},void 0,!0,{fileName:Q,lineNumber:138,columnNumber:7},this),m===`history`&&(0,H.jsxDEV)(`div`,{className:`border-t border-border/30 bg-surface`,children:[(0,H.jsxDEV)(`div`,{className:`flex items-center gap-1.5 px-2 py-1 border-b border-border/30`,children:[(0,H.jsxDEV)(E,{className:`size-3 text-text-subtle shrink-0`},void 0,!1,{fileName:Q,lineNumber:217,columnNumber:13},this),(0,H.jsxDEV)(`input`,{type:`text`,value:w,onChange:e=>T(e.target.value),placeholder:`Search sessions...`,className:`flex-1 bg-transparent text-[11px] text-text-primary outline-none placeholder:text-text-subtle`},void 0,!1,{fileName:Q,lineNumber:218,columnNumber:13},this),(0,H.jsxDEV)(`button`,{onClick:L,disabled:b,className:`p-0.5 rounded text-text-subtle hover:text-text-secondary transition-colors disabled:opacity-50`,title:`Refresh`,children:(0,H.jsxDEV)(M,{className:`size-3 ${b?`animate-spin`:``}`},void 0,!1,{fileName:Q,lineNumber:231,columnNumber:15},this)},void 0,!1,{fileName:Q,lineNumber:225,columnNumber:13},this)]},void 0,!0,{fileName:Q,lineNumber:216,columnNumber:11},this),(0,H.jsxDEV)(`div`,{className:`max-h-[200px] overflow-y-auto`,children:b&&_.length===0?(0,H.jsxDEV)(`div`,{className:`flex items-center justify-center py-3`,children:(0,H.jsxDEV)(j,{className:`size-3.5 animate-spin text-text-subtle`},void 0,!1,{fileName:Q,lineNumber:238,columnNumber:17},this)},void 0,!1,{fileName:Q,lineNumber:237,columnNumber:15},this):se.length===0?(0,H.jsxDEV)(`div`,{className:`flex items-center justify-center py-3 text-[11px] text-text-subtle`,children:w?`No matching sessions`:`No sessions yet`},void 0,!1,{fileName:Q,lineNumber:241,columnNumber:15},this):se.map(e=>(0,H.jsxDEV)(`div`,{className:`flex items-center gap-2 w-full px-3 py-1.5 text-left hover:bg-surface-elevated transition-colors group`,children:[(0,H.jsxDEV)(te,{className:`size-3 shrink-0 text-text-subtle`},void 0,!1,{fileName:Q,lineNumber:250,columnNumber:19},this),D===e.id?(0,H.jsxDEV)(`form`,{className:`flex items-center gap-1 flex-1 min-w-0`,onSubmit:e=>{e.preventDefault(),ie()},children:[(0,H.jsxDEV)(`input`,{ref:P,value:k,onChange:e=>N(e.target.value),onBlur:ie,onKeyDown:e=>{e.key===`Escape`&&ae()},className:`flex-1 min-w-0 bg-surface-elevated text-[11px] text-text-primary px-1 py-0.5 rounded border border-border outline-none focus:border-primary`,autoFocus:!0},void 0,!1,{fileName:Q,lineNumber:256,columnNumber:23},this),(0,H.jsxDEV)(`button`,{type:`submit`,className:`p-0.5 text-green-500 hover:text-green-400`,onClick:e=>e.stopPropagation(),children:(0,H.jsxDEV)(i,{className:`size-3`},void 0,!1,{fileName:Q,lineNumber:266,columnNumber:25},this)},void 0,!1,{fileName:Q,lineNumber:265,columnNumber:23},this),(0,H.jsxDEV)(`button`,{type:`button`,className:`p-0.5 text-text-subtle hover:text-text-secondary`,onClick:e=>{e.stopPropagation(),ae()},children:(0,H.jsxDEV)(n,{className:`size-3`},void 0,!1,{fileName:Q,lineNumber:269,columnNumber:25},this)},void 0,!1,{fileName:Q,lineNumber:268,columnNumber:23},this)]},void 0,!0,{fileName:Q,lineNumber:252,columnNumber:21},this):(0,H.jsxDEV)(H.Fragment,{children:[(0,H.jsxDEV)(`button`,{onClick:()=>z(e),className:`text-[11px] truncate flex-1 text-left`,children:e.title||`Untitled`},void 0,!1,{fileName:Q,lineNumber:274,columnNumber:23},this),(0,H.jsxDEV)(`button`,{onClick:t=>re(e,t),className:`p-0.5 rounded text-text-subtle hover:text-text-secondary opacity-0 group-hover:opacity-100 transition-opacity`,title:`Rename session`,children:(0,H.jsxDEV)(ne,{className:`size-3`},void 0,!1,{fileName:Q,lineNumber:285,columnNumber:25},this)},void 0,!1,{fileName:Q,lineNumber:280,columnNumber:23},this)]},void 0,!0),D!==e.id&&e.updatedAt&&(0,H.jsxDEV)(`span`,{className:`text-[10px] text-text-subtle shrink-0`,children:$t(e.updatedAt)},void 0,!1,{fileName:Q,lineNumber:290,columnNumber:21},this)]},e.id,!0,{fileName:Q,lineNumber:246,columnNumber:17},this))},void 0,!1,{fileName:Q,lineNumber:235,columnNumber:11},this)]},void 0,!0,{fileName:Q,lineNumber:214,columnNumber:9},this),m===`config`&&(0,H.jsxDEV)(`div`,{className:`border-t border-border/30 bg-surface px-3 py-2 max-h-[280px] overflow-y-auto`,children:(0,H.jsxDEV)(R,{compact:!0},void 0,!1,{fileName:Q,lineNumber:302,columnNumber:11},this)},void 0,!1,{fileName:Q,lineNumber:301,columnNumber:9},this),m===`usage`&&(0,H.jsxDEV)(Qt,{usage:t,visible:!0,onClose:()=>h(null),onReload:o,loading:a,lastFetchedAt:s},void 0,!1,{fileName:Q,lineNumber:308,columnNumber:9},this)]},void 0,!0,{fileName:Q,lineNumber:136,columnNumber:5},this)}var $=`/Users/hienlh/Projects/ppm/src/web/components/chat/chat-tab.tsx`;function nn({metadata:e,tabId:t}){let[n,r]=(0,B.useState)(e?.sessionId??null),[i,a]=(0,B.useState)(e?.providerId??`claude`),[o,s]=(0,B.useState)([]),[c,l]=(0,B.useState)(!1),[m,h]=(0,B.useState)(``),[_,b]=(0,B.useState)(null),[x,S]=(0,B.useState)([]),[C,w]=(0,B.useState)(!1),[E,D]=(0,B.useState)(``),[O,k]=(0,B.useState)(null),[A,j]=(0,B.useState)(e?.permissionMode??void 0),[M,N]=(0,B.useState)(!1),[P,F]=(0,B.useState)(null),I=(0,B.useRef)(0),L=e?.projectName??``,R=d(e=>e.updateTab),te=f(e=>e.version),{usageInfo:ne,usageLoading:z,lastFetchedAt:re,refreshUsage:ae}=Le(L,i);(0,B.useEffect)(()=>{A||y().then(e=>{let t=e.providers[e.default_provider??`claude`];j(t?.permission_mode??`bypassPermissions`)}).catch(()=>{})},[]),(0,B.useEffect)(()=>{!t||!n||R(t,{metadata:{...e,sessionId:n,providerId:i,permissionMode:A}})},[n,i,A]);let{messages:oe,messagesLoading:se,isStreaming:ce,streamingStatus:le,connectingElapsed:ue,thinkingWarningThreshold:de,pendingApproval:fe,contextWindowPct:pe,sessionTitle:me,sendMessage:he,respondToApproval:ge,cancelStreaming:_e,reconnect:ve,refetchMessages:ye,isConnected:be}=Fe(n,i,L);(0,B.useEffect)(()=>{if(!n||!t)return;let e=()=>{if(document.hidden)return;let{panels:e,focusedPanelId:r}=u.getState();e[r]?.activeTabId===t&&ee.getState().clearForSession(n)};e(),document.addEventListener(`visibilitychange`,e);let r=u.subscribe(e);return()=>{document.removeEventListener(`visibilitychange`,e),r()}},[n,t]),(0,B.useEffect)(()=>{t&&me&&R(t,{title:me})},[me]);let xe=(0,B.useRef)(e?.pendingMessage);(0,B.useEffect)(()=>{if(xe.current&&be&&n){let n=xe.current;xe.current=void 0,t&&R(t,{metadata:{...e,pendingMessage:void 0}}),setTimeout(()=>he(n,{permissionMode:A}),100)}},[be,n]),(0,B.useCallback)(()=>{d.getState().openTab({type:`chat`,title:`AI Chat`,metadata:{projectName:L},projectId:L||null,closable:!0})},[L]);let Se=(0,B.useCallback)(e=>{r(e.id),a(e.providerId),t&&R(t,{title:e.title||`Chat`})},[t,R]),Ce=(0,B.useCallback)(async e=>{if(!(!n||!L))try{let{api:t,projectUrl:r}=await p(async()=>{let{api:e,projectUrl:t}=await import(`./api-client-Bs-0pRox.js`).then(e=>e.n);return{api:e,projectUrl:t}},__vite__mapDeps([0,1])),a=await t.post(`${r(L)}/chat/sessions/${n}/fork?providerId=${i}`);d.getState().openTab({type:`chat`,title:`Fork: ${e.slice(0,30)}`,metadata:{projectName:L,sessionId:a.id,providerId:i,pendingMessage:e},projectId:L||null,closable:!0})}catch(e){console.error(`Fork failed:`,e)}},[n,L,i]),we=(0,B.useCallback)((e,t)=>{if(t.length===0)return e;let n=t.filter(e=>e.serverPath).map(e=>e.serverPath).join(`
7
- `);return n?(t.length===1?`[Attached file: ${n}]\n\n`:`[Attached files:\n${n}\n]\n\n`)+e:e},[]),Te=(0,B.useCallback)(async(e,t=[])=>{let o=we(e,t);if(o.trim()){if(!n)try{let t=L,n=await v.post(`${g(t)}/chat/sessions`,{providerId:i,title:e.slice(0,50)});r(n.id),a(n.providerId),setTimeout(()=>{he(o,{permissionMode:A})},500);return}catch(e){console.error(`Failed to create session:`,e);return}he(o,{permissionMode:A})}},[n,i,L,he,we,A]),Ee=(0,B.useCallback)((e,t)=>{l(e),h(t)},[]),De=(0,B.useCallback)(e=>{b(e),l(!1),h(``),setTimeout(()=>b(null),50)},[]),Oe=(0,B.useCallback)(()=>{l(!1),h(``)},[]),V=(0,B.useCallback)((e,t)=>{w(e),D(t)},[]),ke=(0,B.useCallback)(e=>{k(e),w(!1),D(``),setTimeout(()=>k(null),50)},[]),Ae=(0,B.useCallback)(()=>{w(!1),D(``)},[]);return(0,H.jsxDEV)(`div`,{className:`flex flex-col h-full relative`,onDragEnter:(0,B.useCallback)(e=>{e.preventDefault(),I.current++,e.dataTransfer.types.includes(`Files`)&&N(!0)},[]),onDragLeave:(0,B.useCallback)(e=>{e.preventDefault(),I.current--,I.current===0&&N(!1)},[]),onDragOver:(0,B.useCallback)(e=>{e.preventDefault()},[]),onDrop:(0,B.useCallback)(e=>{e.preventDefault(),I.current=0,N(!1);let t=Array.from(e.dataTransfer.files);t.length>0&&(F(t),setTimeout(()=>F(null),100))},[]),children:[M&&(0,H.jsxDEV)(`div`,{className:`absolute inset-0 z-50 flex items-center justify-center bg-background/80 backdrop-blur-sm border-2 border-dashed border-primary rounded-lg pointer-events-none`,children:(0,H.jsxDEV)(`div`,{className:`flex flex-col items-center gap-2 text-primary`,children:[(0,H.jsxDEV)(T,{className:`size-8`},void 0,!1,{fileName:$,lineNumber:308,columnNumber:13},this),(0,H.jsxDEV)(`span`,{className:`text-sm font-medium`,children:`Drop files to attach`},void 0,!1,{fileName:$,lineNumber:309,columnNumber:13},this)]},void 0,!0,{fileName:$,lineNumber:307,columnNumber:11},this)},void 0,!1,{fileName:$,lineNumber:306,columnNumber:9},this),(0,H.jsxDEV)(lt,{messages:oe,messagesLoading:se,pendingApproval:fe,onApprovalResponse:ge,isStreaming:ce,streamingStatus:le,connectingElapsed:ue,thinkingWarningThreshold:de,projectName:L,onFork:ce?void 0:Ce},void 0,!1,{fileName:$,lineNumber:315,columnNumber:7},this),(0,H.jsxDEV)(`div`,{className:`border-t border-border bg-background shrink-0`,children:[(0,H.jsxDEV)(tn,{projectName:L,usageInfo:ne,contextWindowPct:pe,usageLoading:z,refreshUsage:ae,lastFetchedAt:re,sessionId:n,onSelectSession:Se,onBugReport:n?()=>ie(te,{sessionId:n,projectName:L}):void 0,isConnected:be,onReconnect:()=>{be||ve(),ye()}},void 0,!1,{fileName:$,lineNumber:331,columnNumber:9},this),(0,H.jsxDEV)(Gt,{items:o,filter:m,onSelect:De,onClose:Oe,visible:c},void 0,!1,{fileName:$,lineNumber:349,columnNumber:9},this),(0,H.jsxDEV)(Ht,{items:x,filter:E,onSelect:ke,onClose:Ae,visible:C},void 0,!1,{fileName:$,lineNumber:356,columnNumber:9},this),(0,H.jsxDEV)(Ut,{onSend:Te,isStreaming:ce,onCancel:_e,autoFocus:!e?.sessionId,projectName:L,onSlashStateChange:Ee,onSlashItemsLoaded:s,slashSelected:_,onFileStateChange:V,onFileItemsLoaded:S,fileSelected:O,externalFiles:P,permissionMode:A,onModeChange:j},void 0,!1,{fileName:$,lineNumber:365,columnNumber:9},this)]},void 0,!0,{fileName:$,lineNumber:329,columnNumber:7},this)]},void 0,!0,{fileName:$,lineNumber:297,columnNumber:5},this)}export{nn as ChatTab};
@@ -1 +0,0 @@
1
- import{i as e,t}from"./react-4j_0SqET.js";import{n,t as r}from"./jsx-dev-runtime-B0R0R7SH.js";import{a as i,t as a}from"./tab-store-HCmwXLYA.js";import{n as o}from"./settings-store-CIOAyrzs.js";import{t as s}from"./utils-DC-bdPS3.js";import{i as c,r as l,t as u}from"./api-client-Bs-0pRox.js";import{M as d}from"./index-cCRyobYW.js";import{t as f}from"./markdown-renderer-DmuIK1-X.js";import{n as p,t as m}from"./use-monaco-theme-D6807XbV.js";var h=n(`file-exclamation-point`,[[`path`,{d:`M6 22a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h8a2.4 2.4 0 0 1 1.704.706l3.588 3.588A2.4 2.4 0 0 1 20 8v12a2 2 0 0 1-2 2z`,key:`1oefj6`}],[`path`,{d:`M12 9v4`,key:`juzpu7`}],[`path`,{d:`M12 17h.01`,key:`p32p05`}]]),g=e(t(),1),_=r(),v=`/Users/hienlh/Projects/ppm/src/web/components/editor/code-editor.tsx`,y=new Set([`png`,`jpg`,`jpeg`,`gif`,`webp`,`svg`,`ico`]),b=new Set([`db`,`sqlite`,`sqlite3`]);function x(e){return e.split(`.`).pop()?.toLowerCase()??``}function S(e){return{js:`javascript`,jsx:`javascript`,ts:`typescript`,tsx:`typescript`,py:`python`,html:`html`,css:`css`,scss:`scss`,json:`json`,md:`markdown`,mdx:`markdown`,yaml:`yaml`,yml:`yaml`,sh:`shell`,bash:`shell`}[x(e)]??`plaintext`}function C({metadata:e,tabId:t}){let n=e?.filePath,r=e?.projectName,[i,l]=(0,g.useState)(null),[f,C]=(0,g.useState)(`utf-8`),[D,O]=(0,g.useState)(!0),[k,A]=(0,g.useState)(null),[j,M]=(0,g.useState)(!1),N=(0,g.useRef)(null),P=(0,g.useRef)(``),F=(0,g.useRef)(null),{tabs:I,updateTab:L}=a(),{wordWrap:R,toggleWordWrap:z}=o(),B=m(),V=I.find(e=>e.id===t),H=n?x(n):``,U=y.has(H),W=H===`pdf`,G=b.has(H),K=H===`md`||H===`mdx`,[q,J]=(0,g.useState)(`preview`);(0,g.useEffect)(()=>{G&&t&&L(t,{type:`sqlite`})},[G,t,L]);let Y=n?/^(\/|[A-Za-z]:[/\\])/.test(n):!1;(0,g.useEffect)(()=>{if(!n||!Y&&!r)return;if(U||W){O(!1);return}O(!0),A(null);let e=Y?`/api/fs/read?path=${encodeURIComponent(n)}`:`${c(r)}/files/read?path=${encodeURIComponent(n)}`;return u.get(e).then(e=>{l(e.content),e.encoding&&C(e.encoding),P.current=e.content,O(!1)}).catch(e=>{A(e instanceof Error?e.message:`Failed to load file`),O(!1)}),()=>{N.current&&clearTimeout(N.current)}},[n,r,U,W,Y]),(0,g.useEffect)(()=>{if(!V)return;let e=n?s(n):`Untitled`,t=j?`${e} \u25CF`:e;V.title!==t&&L(V.id,{title:t})},[j]);let X=(0,g.useCallback)(async e=>{if(n&&!(!Y&&!r))try{Y?await u.put(`/api/fs/write`,{path:n,content:e}):await u.put(`${c(r)}/files/write`,{path:n,content:e}),M(!1)}catch{}},[n,r,Y]);function Z(e){let t=e??``;l(t),P.current=t,M(!0),N.current&&clearTimeout(N.current),N.current=setTimeout(()=>X(P.current),1e3)}let Q=e?.lineNumber,$=(0,g.useCallback)((e,t)=>{F.current=e,Q&&Q>0&&setTimeout(()=>{e.revealLineInCenter(Q),e.setPosition({lineNumber:Q,column:1}),e.focus()},100),e.addCommand(t.KeyMod.Alt|t.KeyCode.KeyZ,()=>o.getState().toggleWordWrap()),t.languages.typescript.typescriptDefaults.setDiagnosticsOptions({noSemanticValidation:!0,noSyntaxValidation:!0,noSuggestionDiagnostics:!0}),t.languages.typescript.javascriptDefaults.setDiagnosticsOptions({noSemanticValidation:!0,noSyntaxValidation:!0,noSuggestionDiagnostics:!0})},[]);return!n||!Y&&!r?(0,_.jsxDEV)(`div`,{className:`flex items-center justify-center h-full text-text-secondary text-sm`,children:`No file selected.`},void 0,!1,{fileName:v,lineNumber:165,columnNumber:7},this):D?(0,_.jsxDEV)(`div`,{className:`flex items-center justify-center h-full gap-2 text-text-secondary`,children:[(0,_.jsxDEV)(d,{className:`size-5 animate-spin`},void 0,!1,{fileName:v,lineNumber:174,columnNumber:9},this),(0,_.jsxDEV)(`span`,{className:`text-sm`,children:`Loading file...`},void 0,!1,{fileName:v,lineNumber:175,columnNumber:9},this)]},void 0,!0,{fileName:v,lineNumber:173,columnNumber:7},this):k?(0,_.jsxDEV)(`div`,{className:`flex items-center justify-center h-full text-error text-sm`,children:k},void 0,!1,{fileName:v,lineNumber:182,columnNumber:7},this):U?(0,_.jsxDEV)(T,{filePath:n,projectName:r},void 0,!1,{fileName:v,lineNumber:186,columnNumber:23},this):W?(0,_.jsxDEV)(E,{filePath:n,projectName:r},void 0,!1,{fileName:v,lineNumber:187,columnNumber:21},this):f===`base64`?(0,_.jsxDEV)(`div`,{className:`flex flex-col items-center justify-center h-full gap-3 text-text-secondary`,children:[(0,_.jsxDEV)(h,{className:`size-10 text-text-subtle`},void 0,!1,{fileName:v,lineNumber:192,columnNumber:9},this),(0,_.jsxDEV)(`p`,{className:`text-sm`,children:`This file is a binary format and cannot be displayed.`},void 0,!1,{fileName:v,lineNumber:193,columnNumber:9},this),(0,_.jsxDEV)(`p`,{className:`text-xs text-text-subtle`,children:n},void 0,!1,{fileName:v,lineNumber:194,columnNumber:9},this)]},void 0,!0,{fileName:v,lineNumber:191,columnNumber:7},this):(0,_.jsxDEV)(`div`,{className:`flex flex-col h-full w-full overflow-hidden`,children:K&&q===`preview`?(0,_.jsxDEV)(w,{content:i??``},void 0,!1,{fileName:v,lineNumber:226,columnNumber:9},this):(0,_.jsxDEV)(`div`,{className:`flex-1 overflow-hidden`,children:(0,_.jsxDEV)(p,{height:`100%`,language:S(n),value:i??``,onChange:Z,onMount:$,theme:B,options:{fontSize:13,fontFamily:`Menlo, Monaco, Consolas, monospace`,wordWrap:R?`on`:`off`,minimap:{enabled:!1},scrollBeyondLastLine:!1,automaticLayout:!0,lineNumbers:`on`,folding:!0,bracketPairColorization:{enabled:!0}},loading:(0,_.jsxDEV)(d,{className:`size-5 animate-spin text-text-subtle`},void 0,!1,{fileName:v,lineNumber:247,columnNumber:22},this)},void 0,!1,{fileName:v,lineNumber:229,columnNumber:11},this)},void 0,!1,{fileName:v,lineNumber:228,columnNumber:9},this)},void 0,!1,{fileName:v,lineNumber:224,columnNumber:5},this)}function w({content:e}){return(0,_.jsxDEV)(f,{content:e,className:`flex-1 overflow-auto p-4`},void 0,!1,{fileName:v,lineNumber:256,columnNumber:10},this)}function T({filePath:e,projectName:t}){let[n,r]=(0,g.useState)(null),[i,a]=(0,g.useState)(!1);return(0,g.useEffect)(()=>{let n,i=`${c(t)}/files/raw?path=${encodeURIComponent(e)}`,o=l();return fetch(i,{headers:o?{Authorization:`Bearer ${o}`}:{}}).then(e=>{if(!e.ok)throw Error(`Failed`);return e.blob()}).then(e=>{let t=URL.createObjectURL(e);n=t,r(t)}).catch(()=>a(!0)),()=>{n&&URL.revokeObjectURL(n)}},[e,t]),i?(0,_.jsxDEV)(`div`,{className:`flex flex-col items-center justify-center h-full gap-3 text-text-secondary`,children:[(0,_.jsxDEV)(h,{className:`size-10 text-text-subtle`},void 0,!1,{fileName:v,lineNumber:277,columnNumber:9},this),(0,_.jsxDEV)(`p`,{className:`text-sm`,children:`Failed to load image.`},void 0,!1,{fileName:v,lineNumber:278,columnNumber:9},this)]},void 0,!0,{fileName:v,lineNumber:276,columnNumber:7},this):n?(0,_.jsxDEV)(`div`,{className:`flex items-center justify-center h-full p-4 bg-surface overflow-auto`,children:(0,_.jsxDEV)(`img`,{src:n,alt:e,className:`max-w-full max-h-full object-contain`},void 0,!1,{fileName:v,lineNumber:287,columnNumber:7},this)},void 0,!1,{fileName:v,lineNumber:286,columnNumber:5},this):(0,_.jsxDEV)(`div`,{className:`flex items-center justify-center h-full`,children:(0,_.jsxDEV)(d,{className:`size-5 animate-spin text-text-subtle`},void 0,!1,{fileName:v,lineNumber:283,columnNumber:69},this)},void 0,!1,{fileName:v,lineNumber:283,columnNumber:12},this)}function E({filePath:e,projectName:t}){let[n,r]=(0,g.useState)(null),[a,o]=(0,g.useState)(!1);(0,g.useEffect)(()=>{let n,i=`${c(t)}/files/raw?path=${encodeURIComponent(e)}`,a=l();return fetch(i,{headers:a?{Authorization:`Bearer ${a}`}:{}}).then(e=>{if(!e.ok)throw Error(`Failed`);return e.blob()}).then(e=>{let t=URL.createObjectURL(new Blob([e],{type:`application/pdf`}));n=t,r(t)}).catch(()=>o(!0)),()=>{n&&URL.revokeObjectURL(n)}},[e,t]);let s=(0,g.useCallback)(()=>{n&&window.open(n,`_blank`)},[n]);return a?(0,_.jsxDEV)(`div`,{className:`flex flex-col items-center justify-center h-full gap-3 text-text-secondary`,children:[(0,_.jsxDEV)(h,{className:`size-10 text-text-subtle`},void 0,!1,{fileName:v,lineNumber:315,columnNumber:9},this),(0,_.jsxDEV)(`p`,{className:`text-sm`,children:`Failed to load PDF.`},void 0,!1,{fileName:v,lineNumber:316,columnNumber:9},this)]},void 0,!0,{fileName:v,lineNumber:314,columnNumber:7},this):n?(0,_.jsxDEV)(`div`,{className:`flex flex-col h-full`,children:[(0,_.jsxDEV)(`div`,{className:`flex items-center justify-between px-3 py-1.5 border-b border-border bg-background shrink-0`,children:[(0,_.jsxDEV)(`span`,{className:`text-xs text-text-secondary truncate`,children:e},void 0,!1,{fileName:v,lineNumber:326,columnNumber:9},this),(0,_.jsxDEV)(`button`,{onClick:s,className:`flex items-center gap-1 text-xs text-text-secondary hover:text-text-primary transition-colors`,children:[(0,_.jsxDEV)(i,{className:`size-3`},void 0,!1,{fileName:v,lineNumber:328,columnNumber:11},this),` Open in new tab`]},void 0,!0,{fileName:v,lineNumber:327,columnNumber:9},this)]},void 0,!0,{fileName:v,lineNumber:325,columnNumber:7},this),(0,_.jsxDEV)(`iframe`,{src:n,title:e,className:`flex-1 w-full border-none`},void 0,!1,{fileName:v,lineNumber:331,columnNumber:7},this)]},void 0,!0,{fileName:v,lineNumber:324,columnNumber:5},this):(0,_.jsxDEV)(`div`,{className:`flex items-center justify-center h-full`,children:(0,_.jsxDEV)(d,{className:`size-5 animate-spin text-text-subtle`},void 0,!1,{fileName:v,lineNumber:321,columnNumber:69},this)},void 0,!1,{fileName:v,lineNumber:321,columnNumber:12},this)}export{C as CodeEditor};
@@ -1 +0,0 @@
1
- import{n as e}from"./jsx-dev-runtime-B0R0R7SH.js";var t=e(`columns-2`,[[`rect`,{width:`18`,height:`18`,x:`3`,y:`3`,rx:`2`,key:`afitv7`}],[`path`,{d:`M12 3v18`,key:`108xh3`}]]);export{t};
@@ -1 +0,0 @@
1
- import{i as e,t}from"./react-4j_0SqET.js";import{t as n}from"./jsx-dev-runtime-B0R0R7SH.js";import{a as r,c as i,i as a,n as o,o as s,r as c,s as l,t as u}from"./dist-CU2je4l7.js";import"./jsx-runtime-CdTrtNt5.js";import{t as d}from"./api-client-Bs-0pRox.js";import{B as f,G as p,K as m,M as h,O as g}from"./index-cCRyobYW.js";var _=e(t(),1);function v(e,t,n,r){return`ppm-db-${e}-${n}.${t}-p${r}`}function y(e,t,n,r){try{let i=sessionStorage.getItem(v(e,t,n,r));return i?JSON.parse(i):null}catch{return null}}function b(e,t,n,r,i,a){try{sessionStorage.setItem(v(e,t,n,r),JSON.stringify({data:i,cols:a}))}catch{}}function x(e){let t=`/api/db/connections/${e}`,[n,r]=(0,_.useState)(null),[i,a]=(0,_.useState)(`public`),[o,s]=(0,_.useState)(null),[c,l]=(0,_.useState)([]),[u,f]=(0,_.useState)(!0),[p,m]=(0,_.useState)(null),[h,g]=(0,_.useState)(1),[v,x]=(0,_.useState)(null),[S,C]=(0,_.useState)(null),[w,T]=(0,_.useState)(!1),E=(0,_.useCallback)(async(r,a,o)=>{let c=r??n,u=a??i;if(c){f(!0);try{let[n,r]=await Promise.all([d.get(`${t}/data?table=${encodeURIComponent(c)}&schema=${u}&page=${o??h}&limit=100`),d.get(`${t}/schema?table=${encodeURIComponent(c)}&schema=${u}`)]);s(n),l(r),b(e,c,u,o??h,n,r)}catch(e){m(e.message)}finally{f(!1)}}},[t,e,n,i,h]);return{selectedTable:n,selectTable:(0,_.useCallback)((t,n=`public`)=>{r(t),a(n),g(1),x(null);let i=y(e,t,n,1);i?(s(i.data),l(i.cols),f(!1),E(t,n,1)):E(t,n,1)},[e,E]),tableData:o,schema:c,loading:u,error:p,page:h,setPage:(0,_.useCallback)(e=>{g(e),E(void 0,void 0,e)},[E]),queryResult:v,queryError:S,queryLoading:w,executeQuery:(0,_.useCallback)(async e=>{T(!0),C(null);try{let r=await d.post(`${t}/query`,{sql:e});x(r),r.changeType===`modify`&&E(n??void 0,i)}catch(e){C(e.message)}finally{T(!1)}},[t,n,i,E]),updateCell:(0,_.useCallback)(async(e,r,a,o)=>{if(!n)return;let s=n,c=i;try{await d.put(`${t}/cell`,{table:s,schema:c,pkColumn:e,pkValue:r,column:a,value:o}),E(s,c)}catch(e){m(e.message)}},[t,n,i,E]),refreshData:E}}var S=n(),C=`/Users/hienlh/Projects/ppm/src/web/components/database/database-viewer.tsx`,w={postgres:u,sqlite:o};function T({metadata:e}){let t=e?.connectionId,n=e?.connectionName,r=e?.dbType??`postgres`,i=e?.tableName,a=e?.schemaName??`public`,o=x(t),[s,c]=(0,_.useState)(!1),l=(0,_.useRef)(!1);return(0,_.useEffect)(()=>{!i||l.current||(l.current=!0,o.selectTable(i,a))},[i,a]),(0,S.jsxDEV)(`div`,{className:`flex h-full w-full overflow-hidden`,children:(0,S.jsxDEV)(`div`,{className:`flex-1 flex flex-col overflow-hidden`,children:[(0,S.jsxDEV)(`div`,{className:`flex items-center gap-2 px-3 py-1.5 border-b border-border bg-background shrink-0`,children:[(0,S.jsxDEV)(f,{className:`size-3.5 text-muted-foreground`},void 0,!1,{fileName:C,lineNumber:36,columnNumber:11},this),(0,S.jsxDEV)(`span`,{className:`text-xs text-muted-foreground truncate`,children:n??`Database`},void 0,!1,{fileName:C,lineNumber:37,columnNumber:11},this),o.selectedTable&&(0,S.jsxDEV)(`span`,{className:`text-xs text-muted-foreground`,children:[`/ `,o.selectedTable]},void 0,!0,{fileName:C,lineNumber:38,columnNumber:32},this),(0,S.jsxDEV)(`div`,{className:`ml-auto flex items-center gap-1`,children:[(0,S.jsxDEV)(`button`,{type:`button`,onClick:()=>o.refreshData(),title:`Reload data`,className:`p-1 rounded text-muted-foreground hover:text-foreground transition-colors`,children:(0,S.jsxDEV)(g,{className:`size-3 ${o.loading?`animate-spin`:``}`},void 0,!1,{fileName:C,lineNumber:42,columnNumber:15},this)},void 0,!1,{fileName:C,lineNumber:40,columnNumber:13},this),(0,S.jsxDEV)(`button`,{type:`button`,onClick:()=>c(e=>!e),className:`px-2 py-1 rounded text-xs transition-colors ${s?`bg-muted text-foreground`:`text-muted-foreground hover:text-foreground`}`,children:`SQL`},void 0,!1,{fileName:C,lineNumber:44,columnNumber:13},this)]},void 0,!0,{fileName:C,lineNumber:39,columnNumber:11},this)]},void 0,!0,{fileName:C,lineNumber:35,columnNumber:9},this),(0,S.jsxDEV)(`div`,{className:`flex-1 overflow-hidden ${s?`max-h-[60%]`:``}`,children:(0,S.jsxDEV)(E,{tableData:o.tableData,schema:o.schema,loading:o.loading,page:o.page,onPageChange:o.setPage,onCellUpdate:o.updateCell},void 0,!1,{fileName:C,lineNumber:53,columnNumber:11},this)},void 0,!1,{fileName:C,lineNumber:52,columnNumber:9},this),s&&(0,S.jsxDEV)(`div`,{className:`border-t border-border h-[40%] shrink-0`,children:(0,S.jsxDEV)(D,{dialect:w[r]??u,onExecute:o.executeQuery,result:o.queryResult,error:o.queryError,loading:o.queryLoading},void 0,!1,{fileName:C,lineNumber:60,columnNumber:13},this)},void 0,!1,{fileName:C,lineNumber:59,columnNumber:11},this)]},void 0,!0,{fileName:C,lineNumber:33,columnNumber:7},this)},void 0,!1,{fileName:C,lineNumber:32,columnNumber:5},this)}function E({tableData:e,schema:t,loading:n,page:i,onPageChange:a,onCellUpdate:o}){let[c,u]=(0,_.useState)(null),[d,f]=(0,_.useState)(``),g=(0,_.useMemo)(()=>t.find(e=>e.pk)?.name??null,[t]),v=(0,_.useCallback)((e,t,n)=>{u({rowIdx:e,col:t}),f(n==null?``:String(n))},[]),y=(0,_.useCallback)(()=>{if(!c||!e||!g)return;let t=e.rows[c.rowIdx];if(!t)return;let n=t[c.col];String(n??``)!==d&&o(g,t[g],c.col,d===``?null:d),u(null)},[c,d,e,g,o]),b=(0,_.useCallback)(()=>u(null),[]),x=(0,_.useMemo)(()=>(e?.columns??[]).map(e=>({id:e,accessorFn:t=>t[e],header:()=>(0,S.jsxDEV)(`span`,{className:t.find(t=>t.name===e)?.pk?`font-bold`:``,children:e},void 0,!1,{fileName:C,lineNumber:103,columnNumber:21},this),cell:({row:t,getValue:n})=>{let r=c?.rowIdx===t.index&&c?.col===e,i=n();return r?(0,S.jsxDEV)(`input`,{autoFocus:!0,className:`w-full bg-transparent border border-primary/50 rounded px-1 py-0 text-xs outline-none`,value:d,onChange:e=>f(e.target.value),onBlur:y,onKeyDown:e=>{e.key===`Enter`&&y(),e.key===`Escape`&&b()}},void 0,!1,{fileName:C,lineNumber:109,columnNumber:13},this):(0,S.jsxDEV)(`span`,{className:`cursor-pointer truncate block ${i==null?`text-muted-foreground/40 italic`:``}`,onDoubleClick:()=>g&&v(t.index,e,i),title:i==null?`NULL`:String(i),children:i==null?`NULL`:String(i)},void 0,!1,{fileName:C,lineNumber:115,columnNumber:11},this)}})),[e?.columns,t,c,d,y,b,v,g]),w=s({data:e?.rows??[],columns:x,getCoreRowModel:l()});if(!e)return(0,S.jsxDEV)(`div`,{className:`flex items-center justify-center h-full text-xs text-muted-foreground`,children:n?(0,S.jsxDEV)(h,{className:`size-4 animate-spin`},void 0,!1,{fileName:C,lineNumber:129,columnNumber:20},this):`Select a table`},void 0,!1,{fileName:C,lineNumber:128,columnNumber:7},this);let T=Math.ceil(e.total/e.limit)||1;return(0,S.jsxDEV)(`div`,{className:`flex flex-col h-full overflow-hidden`,children:[(0,S.jsxDEV)(`div`,{className:`flex-1 overflow-auto`,children:(0,S.jsxDEV)(`table`,{className:`w-full text-xs border-collapse`,children:[(0,S.jsxDEV)(`thead`,{className:`sticky top-0 z-10 bg-muted`,children:w.getHeaderGroups().map(e=>(0,S.jsxDEV)(`tr`,{children:e.headers.map(e=>(0,S.jsxDEV)(`th`,{className:`px-2 py-1.5 text-left font-medium text-muted-foreground border-b border-border whitespace-nowrap`,children:r(e.column.columnDef.header,e.getContext())},e.id,!1,{fileName:C,lineNumber:144,columnNumber:19},this))},e.id,!1,{fileName:C,lineNumber:142,columnNumber:15},this))},void 0,!1,{fileName:C,lineNumber:140,columnNumber:11},this),(0,S.jsxDEV)(`tbody`,{children:[w.getRowModel().rows.map(e=>(0,S.jsxDEV)(`tr`,{className:`hover:bg-muted/30 border-b border-border/50`,children:e.getVisibleCells().map(e=>(0,S.jsxDEV)(`td`,{className:`px-2 py-1 max-w-[300px]`,children:r(e.column.columnDef.cell,e.getContext())},e.id,!1,{fileName:C,lineNumber:155,columnNumber:19},this))},e.id,!1,{fileName:C,lineNumber:153,columnNumber:15},this)),e.rows.length===0&&(0,S.jsxDEV)(`tr`,{children:(0,S.jsxDEV)(`td`,{colSpan:e.columns.length,className:`px-2 py-8 text-center text-muted-foreground`,children:`No data`},void 0,!1,{fileName:C,lineNumber:162,columnNumber:19},this)},void 0,!1,{fileName:C,lineNumber:162,columnNumber:15},this)]},void 0,!0,{fileName:C,lineNumber:151,columnNumber:11},this)]},void 0,!0,{fileName:C,lineNumber:139,columnNumber:9},this)},void 0,!1,{fileName:C,lineNumber:138,columnNumber:7},this),(0,S.jsxDEV)(`div`,{className:`flex items-center justify-between px-3 py-1.5 border-t border-border bg-background shrink-0 text-xs text-muted-foreground`,children:[(0,S.jsxDEV)(`span`,{children:[e.total.toLocaleString(),` rows`]},void 0,!0,{fileName:C,lineNumber:168,columnNumber:9},this),(0,S.jsxDEV)(`div`,{className:`flex items-center gap-2`,children:[(0,S.jsxDEV)(`button`,{type:`button`,disabled:i<=1,onClick:()=>a(i-1),className:`p-0.5 rounded hover:bg-muted disabled:opacity-30`,children:(0,S.jsxDEV)(m,{className:`size-3.5`},void 0,!1,{fileName:C,lineNumber:171,columnNumber:13},this)},void 0,!1,{fileName:C,lineNumber:170,columnNumber:11},this),(0,S.jsxDEV)(`span`,{children:[i,` / `,T]},void 0,!0,{fileName:C,lineNumber:173,columnNumber:11},this),(0,S.jsxDEV)(`button`,{type:`button`,disabled:i>=T,onClick:()=>a(i+1),className:`p-0.5 rounded hover:bg-muted disabled:opacity-30`,children:(0,S.jsxDEV)(p,{className:`size-3.5`},void 0,!1,{fileName:C,lineNumber:175,columnNumber:13},this)},void 0,!1,{fileName:C,lineNumber:174,columnNumber:11},this)]},void 0,!0,{fileName:C,lineNumber:169,columnNumber:9},this)]},void 0,!0,{fileName:C,lineNumber:167,columnNumber:7},this)]},void 0,!0,{fileName:C,lineNumber:137,columnNumber:5},this)}function D({dialect:e,onExecute:t,result:n,error:r,loading:o}){let[s,l]=(0,_.useState)(`SELECT * FROM `),u=(0,_.useCallback)(()=>{let e=s.trim();e&&t(e)},[s,t]);return(0,S.jsxDEV)(`div`,{className:`flex flex-col h-full overflow-hidden`,children:[(0,S.jsxDEV)(`div`,{className:`flex items-start gap-1 border-b border-border bg-background`,onKeyDown:(0,_.useCallback)(e=>{(e.metaKey||e.ctrlKey)&&e.key===`Enter`&&(e.preventDefault(),u())},[u]),children:[(0,S.jsxDEV)(`div`,{className:`flex-1 max-h-[120px] overflow-auto`,children:(0,S.jsxDEV)(a,{value:s,onChange:l,extensions:[c({dialect:e})],basicSetup:{lineNumbers:!1,foldGutter:!1,highlightActiveLine:!1},className:`text-xs [&_.cm-editor]:!outline-none [&_.cm-scroller]:!overflow-auto`},void 0,!1,{fileName:C,lineNumber:198,columnNumber:11},this)},void 0,!1,{fileName:C,lineNumber:197,columnNumber:9},this),(0,S.jsxDEV)(`button`,{type:`button`,onClick:u,disabled:o,title:`Execute (Cmd+Enter)`,className:`shrink-0 m-1 p-1.5 rounded bg-primary text-primary-foreground hover:bg-primary/90 disabled:opacity-50 transition-colors`,children:o?(0,S.jsxDEV)(h,{className:`size-3.5 animate-spin`},void 0,!1,{fileName:C,lineNumber:204,columnNumber:22},this):(0,S.jsxDEV)(i,{className:`size-3.5`},void 0,!1,{fileName:C,lineNumber:204,columnNumber:70},this)},void 0,!1,{fileName:C,lineNumber:202,columnNumber:9},this)]},void 0,!0,{fileName:C,lineNumber:196,columnNumber:7},this),(0,S.jsxDEV)(`div`,{className:`flex-1 overflow-auto text-xs`,children:[r&&(0,S.jsxDEV)(`div`,{className:`px-3 py-2 text-destructive bg-destructive/5`,children:r},void 0,!1,{fileName:C,lineNumber:208,columnNumber:19},this),n?.changeType===`modify`&&(0,S.jsxDEV)(`div`,{className:`px-3 py-2 text-green-500`,children:[`Query executed. `,n.rowsAffected,` row(s) affected.`]},void 0,!0,{fileName:C,lineNumber:209,columnNumber:45},this),n?.changeType===`select`&&n.rows.length>0&&(0,S.jsxDEV)(`table`,{className:`w-full border-collapse`,children:[(0,S.jsxDEV)(`thead`,{className:`sticky top-0 bg-muted`,children:(0,S.jsxDEV)(`tr`,{children:n.columns.map(e=>(0,S.jsxDEV)(`th`,{className:`px-2 py-1 text-left font-medium text-muted-foreground border-b border-border whitespace-nowrap`,children:e},e,!1,{fileName:C,lineNumber:213,columnNumber:46},this))},void 0,!1,{fileName:C,lineNumber:213,columnNumber:15},this)},void 0,!1,{fileName:C,lineNumber:212,columnNumber:13},this),(0,S.jsxDEV)(`tbody`,{children:n.rows.map((e,t)=>(0,S.jsxDEV)(`tr`,{className:`hover:bg-muted/30 border-b border-border/50`,children:n.columns.map(t=>(0,S.jsxDEV)(`td`,{className:`px-2 py-1 max-w-[300px] truncate`,title:e[t]==null?`NULL`:String(e[t]),children:e[t]==null?(0,S.jsxDEV)(`span`,{className:`text-muted-foreground/40 italic`,children:`NULL`},void 0,!1,{fileName:C,lineNumber:220,columnNumber:41},this):String(e[t])},t,!1,{fileName:C,lineNumber:219,columnNumber:21},this))},t,!1,{fileName:C,lineNumber:217,columnNumber:17},this))},void 0,!1,{fileName:C,lineNumber:215,columnNumber:13},this)]},void 0,!0,{fileName:C,lineNumber:211,columnNumber:11},this),n?.changeType===`select`&&n.rows.length===0&&(0,S.jsxDEV)(`div`,{className:`px-3 py-2 text-muted-foreground`,children:`No results`},void 0,!1,{fileName:C,lineNumber:228,columnNumber:73},this)]},void 0,!0,{fileName:C,lineNumber:207,columnNumber:7},this)]},void 0,!0,{fileName:C,lineNumber:195,columnNumber:5},this)}export{T as DatabaseViewer};
@@ -1,4 +0,0 @@
1
- import{i as e,t}from"./react-4j_0SqET.js";import{n,t as r}from"./jsx-dev-runtime-B0R0R7SH.js";import{t as i}from"./columns-2-BSNHGqVP.js";import{n as a}from"./settings-store-CIOAyrzs.js";import{i as o,t as s}from"./api-client-Bs-0pRox.js";import{A as c,L as l,M as u}from"./index-cCRyobYW.js";import{r as d,t as f}from"./use-monaco-theme-D6807XbV.js";var p=n(`panel-right-open`,[[`rect`,{width:`18`,height:`18`,x:`3`,y:`3`,rx:`2`,key:`afitv7`}],[`path`,{d:`M15 3v18`,key:`14nvp0`}],[`path`,{d:`m10 15-3-3 3-3`,key:`1pgupc`}]]),m=n(`text-wrap`,[[`path`,{d:`m16 16-3 3 3 3`,key:`117b85`}],[`path`,{d:`M3 12h14.5a1 1 0 0 1 0 7H13`,key:`18xa6z`}],[`path`,{d:`M3 19h6`,key:`1ygdsz`}],[`path`,{d:`M3 5h18`,key:`1u36vt`}]]),h=e(t(),1),g=r(),_=`/Users/hienlh/Projects/ppm/src/web/components/editor/diff-viewer.tsx`;function v(e){return{js:`javascript`,jsx:`javascript`,ts:`typescript`,tsx:`typescript`,py:`python`,html:`html`,css:`css`,scss:`scss`,json:`json`,md:`markdown`,mdx:`markdown`,yaml:`yaml`,yml:`yaml`,sh:`shell`,bash:`shell`}[e.split(`.`).pop()?.toLowerCase()??``]??`plaintext`}function y({metadata:e}){let t=e?.filePath,n=e?.projectName,r=e?.ref1,y=e?.ref2,x=e?.file1,S=e?.file2,C=e?.original,w=e?.modified,T=C!=null||w!=null,E=!!(x&&S),[D,O]=(0,h.useState)(null),[k,A]=(0,h.useState)(null),[j,M]=(0,h.useState)(!T),[N,P]=(0,h.useState)(null),[F,I]=(0,h.useState)(`both`),{wordWrap:L,toggleWordWrap:R}=a(),z=f(),B=(0,h.useRef)(null),[V,H]=(0,h.useState)();(0,h.useEffect)(()=>{let e=B.current;if(!e)return;let t=new ResizeObserver(([e])=>{e&&H(Math.floor(e.contentRect.height))});return t.observe(e),()=>t.disconnect()},[j,N]),(0,h.useEffect)(()=>{if(T||!n)return;if(M(!0),P(null),x&&S){let e=new URLSearchParams({file1:x,file2:S});s.get(`${o(n)}/files/compare?${e}`).then(e=>{A(e),M(!1)}).catch(e=>{P(e instanceof Error?e.message:`Failed to compare files`),M(!1)});return}let e;if(t){let i=new URLSearchParams({file:t});r&&i.set(`ref`,r),e=`${o(n)}/git/file-diff?${i}`}else if(r||y){let t=new URLSearchParams;r&&t.set(`ref1`,r),y&&t.set(`ref2`,y),e=`${o(n)}/git/diff?${t}`}else e=`${o(n)}/git/diff`;s.get(e).then(e=>{O(e.diff),M(!1)}).catch(e=>{P(e instanceof Error?e.message:`Failed to load diff`),M(!1)})},[t,n,r,y,x,S,T]);let{original:U,modified:W}=(0,h.useMemo)(()=>T?{original:C??``,modified:w??``}:E&&k?k:D?b(D):{original:``,modified:``},[D,T,C,w,E,k]),G=(0,h.useMemo)(()=>{let e=t??S??x;return e?v(e):`plaintext`},[t,x,S]),K=typeof window<`u`&&window.innerWidth<768,q=!K&&F===`both`;return!n&&!T?(0,g.jsxDEV)(`div`,{className:`flex items-center justify-center h-full text-muted-foreground text-sm`,children:`No project selected.`},void 0,!1,{fileName:_,lineNumber:115,columnNumber:7},this):j?(0,g.jsxDEV)(`div`,{className:`flex items-center justify-center h-full gap-2 text-muted-foreground`,children:[(0,g.jsxDEV)(u,{className:`size-5 animate-spin`},void 0,!1,{fileName:_,lineNumber:124,columnNumber:9},this),(0,g.jsxDEV)(`span`,{className:`text-sm`,children:`Loading diff...`},void 0,!1,{fileName:_,lineNumber:125,columnNumber:9},this)]},void 0,!0,{fileName:_,lineNumber:123,columnNumber:7},this):N?(0,g.jsxDEV)(`div`,{className:`flex items-center justify-center h-full text-destructive text-sm`,children:N},void 0,!1,{fileName:_,lineNumber:132,columnNumber:7},this):!T&&!E&&!U&&!W?(0,g.jsxDEV)(`div`,{className:`flex flex-col items-center justify-center h-full gap-2 text-muted-foreground`,children:[(0,g.jsxDEV)(l,{className:`size-8`},void 0,!1,{fileName:_,lineNumber:140,columnNumber:9},this),(0,g.jsxDEV)(`p`,{className:`text-sm`,children:`No content changes`},void 0,!1,{fileName:_,lineNumber:141,columnNumber:9},this),t&&(0,g.jsxDEV)(`p`,{className:`text-xs font-mono`,children:t},void 0,!1,{fileName:_,lineNumber:142,columnNumber:22},this)]},void 0,!0,{fileName:_,lineNumber:139,columnNumber:7},this):(0,g.jsxDEV)(`div`,{className:`flex flex-col h-full`,children:[!K&&(0,g.jsxDEV)(`div`,{className:`flex items-center justify-end gap-0.5 px-2 py-0.5 border-b border-border shrink-0`,children:[(0,g.jsxDEV)(`button`,{type:`button`,onClick:()=>I(F===`left`?`both`:`left`),className:`p-1 rounded hover:bg-muted transition-colors ${F===`left`?`bg-muted text-foreground`:``}`,title:`Expand original`,children:(0,g.jsxDEV)(c,{className:`size-3.5`},void 0,!1,{fileName:_,lineNumber:157,columnNumber:13},this)},void 0,!1,{fileName:_,lineNumber:152,columnNumber:11},this),(0,g.jsxDEV)(`button`,{type:`button`,onClick:()=>I(`both`),className:`p-1 rounded hover:bg-muted transition-colors ${F===`both`?`bg-muted text-foreground`:``}`,title:`Side by side`,children:(0,g.jsxDEV)(i,{className:`size-3.5`},void 0,!1,{fileName:_,lineNumber:164,columnNumber:13},this)},void 0,!1,{fileName:_,lineNumber:159,columnNumber:11},this),(0,g.jsxDEV)(`button`,{type:`button`,onClick:()=>I(F===`right`?`both`:`right`),className:`p-1 rounded hover:bg-muted transition-colors ${F===`right`?`bg-muted text-foreground`:``}`,title:`Expand modified`,children:(0,g.jsxDEV)(p,{className:`size-3.5`},void 0,!1,{fileName:_,lineNumber:171,columnNumber:13},this)},void 0,!1,{fileName:_,lineNumber:166,columnNumber:11},this),(0,g.jsxDEV)(`div`,{className:`w-px h-3.5 bg-border mx-0.5 shrink-0`},void 0,!1,{fileName:_,lineNumber:173,columnNumber:11},this),(0,g.jsxDEV)(`button`,{type:`button`,onClick:R,title:`Toggle word wrap`,className:`p-1 rounded hover:bg-muted transition-colors ${L?`bg-muted text-foreground`:``}`,children:(0,g.jsxDEV)(m,{className:`size-3.5`},void 0,!1,{fileName:_,lineNumber:177,columnNumber:13},this)},void 0,!1,{fileName:_,lineNumber:174,columnNumber:11},this)]},void 0,!0,{fileName:_,lineNumber:151,columnNumber:9},this),(0,g.jsxDEV)(`div`,{ref:B,className:`flex-1 overflow-hidden`,children:V&&V>0?(0,g.jsxDEV)(d,{height:V,language:G,original:U,modified:W,theme:z,options:{fontSize:K?11:13,fontFamily:`Menlo, Monaco, Consolas, monospace`,wordWrap:K||L?`on`:`off`,renderSideBySide:q,readOnly:!0,automaticLayout:!0,scrollBeyondLastLine:!1},loading:(0,g.jsxDEV)(u,{className:`size-5 animate-spin text-muted-foreground`},void 0,!1,{fileName:_,lineNumber:199,columnNumber:22},this)},void 0,!1,{fileName:_,lineNumber:184,columnNumber:11},this):(0,g.jsxDEV)(`div`,{className:`flex items-center justify-center h-full`,children:(0,g.jsxDEV)(u,{className:`size-5 animate-spin text-muted-foreground`},void 0,!1,{fileName:_,lineNumber:203,columnNumber:13},this)},void 0,!1,{fileName:_,lineNumber:202,columnNumber:11},this)},void 0,!1,{fileName:_,lineNumber:182,columnNumber:7},this)]},void 0,!0,{fileName:_,lineNumber:148,columnNumber:5},this)}function b(e){let t=e.split(`
2
- `),n=[],r=[],i=!1;for(let e of t)if(!(e.startsWith(`diff --git`)||e.startsWith(`diff --no-index`)||e.startsWith(`index `)||e.startsWith(`new file`)||e.startsWith(`deleted file`)||e.startsWith(`old mode`)||e.startsWith(`new mode`)||e.startsWith(`---`)||e.startsWith(`+++`)||e.startsWith(`Binary files`)||e.startsWith(`\\ No newline`))){if(e.startsWith(`@@`)){i=!0;continue}if(i)if(e.startsWith(`-`))n.push(e.slice(1));else if(e.startsWith(`+`))r.push(e.slice(1));else{let t=e.startsWith(` `)?e.slice(1):e;n.push(t),r.push(t)}}return{original:n.join(`
3
- `),modified:r.join(`
4
- `)}}export{y as DiffViewer};
@@ -1 +0,0 @@
1
- import{i as e,t}from"./react-4j_0SqET.js";import{A as n,M as r,N as i,j as a,t as o}from"./input-D3FZB4A8.js";import{n as s,t as c}from"./jsx-dev-runtime-B0R0R7SH.js";import{a as l,t as u}from"./tab-store-HCmwXLYA.js";import"./jsx-runtime-CdTrtNt5.js";import{t as d}from"./utils-DC-bdPS3.js";import{i as f,t as p}from"./api-client-Bs-0pRox.js";import{D as m,E as h,M as g,N as _,O as v,V as y,Y as b,a as x,c as S,d as C,f as w,h as T,l as E,m as D,o as O,p as k,s as A,u as j,w as M,z as N}from"./index-cCRyobYW.js";var ee=s(`cherry`,[[`path`,{d:`M2 17a5 5 0 0 0 10 0c0-2.76-2.5-5-5-3-2.5-2-5 .24-5 3Z`,key:`cvxqlc`}],[`path`,{d:`M12 17a5 5 0 0 0 10 0c0-2.76-2.5-5-5-3-2.5-2-5 .24-5 3Z`,key:`1ostrc`}],[`path`,{d:`M7 14c3.22-2.91 4.29-8.75 5-12 1.66 2.38 4.94 9 5 12`,key:`hqx58h`}],[`path`,{d:`M22 9c-4.29 0-7.14-2.33-10-7 5.71 0 10 4.67 10 7Z`,key:`eykp1o`}]]),te=s(`git-merge`,[[`circle`,{cx:`18`,cy:`18`,r:`3`,key:`1xkwt0`}],[`circle`,{cx:`6`,cy:`6`,r:`3`,key:`1lh9wr`}],[`path`,{d:`M6 21V9a9 9 0 0 0 9 9`,key:`7kw0sc`}]]),P=s(`tag`,[[`path`,{d:`M12.586 2.586A2 2 0 0 0 11.172 2H4a2 2 0 0 0-2 2v7.172a2 2 0 0 0 .586 1.414l8.704 8.704a2.426 2.426 0 0 0 3.42 0l6.58-6.58a2.426 2.426 0 0 0 0-3.42z`,key:`vktsd0`}],[`circle`,{cx:`7.5`,cy:`7.5`,r:`.5`,fill:`currentColor`,key:`kqv944`}]]),F=e(t(),1),I=[`#0085d9`,`#d73a49`,`#6f42c1`,`#2cbe4e`,`#e36209`,`#005cc5`,`#b31d28`,`#5a32a3`,`#22863a`,`#cb2431`];function ne(e){let t=new Map;if(!e)return t;let n=new Set;for(let t of e.branches)if(!t.remote)for(let e of t.remotes)n.add(`remotes/${e}/${t.name}`);for(let r of e.branches)if(r.remote){if(n.has(r.name))continue;let e=t.get(r.commitHash)??[],i=r.name.replace(/^remotes\//,``);e.push({name:i,type:`branch`,remotes:[],current:!1}),t.set(r.commitHash,e)}else{let e=t.get(r.commitHash)??[];e.push({name:r.name,type:`branch`,remotes:r.remotes,current:r.current}),t.set(r.commitHash,e)}for(let n of e.commits)for(let e of n.refs)if(e.startsWith(`tag: `)){let r=e.replace(`tag: `,``),i=t.get(n.hash)??[];i.push({name:r,type:`tag`,remotes:[],current:!1}),t.set(n.hash,i)}return t}function re(e){let t=new Map;if(!e)return{laneMap:t,maxLane:0,unloadedParentLanes:new Map};let n=0,r=0,i=new Map,a=new Set(e.commits.map(e=>e.hash)),o=[],s=()=>o.length>0?(o.sort((e,t)=>e-t),o.shift()):n++;for(let n of e.commits){let e=i.get(n.hash);e===void 0&&(e=s()),t.set(n.hash,e),e>r&&(r=e),i.delete(n.hash);let a=!1;for(let t=0;t<n.parents.length;t++){let o=n.parents[t];if(!i.has(o))if(t===0)i.set(o,e),a=!0;else{let e=s();i.set(o,e),e>r&&(r=e)}}a||o.push(e)}let c=new Map;for(let[e,t]of i)a.has(e)||c.set(e,t);return{laneMap:t,maxLane:r,unloadedParentLanes:c}}function ie(e,t,n,r){if(!e)return[];let i=[],a=new Set(e.commits.map(e=>e.hash));for(let o=0;o<e.commits.length;o++){let s=e.commits[o],c=t.get(s.hash)??0,l=I[c%I.length];for(let u of s.parents){let d=e.commits.findIndex(e=>e.hash===u);if(d>=0){let e=t.get(u)??0,n=I[e%I.length],r=c*16+16/2,a=o*24+24/2,f=e*16+16/2,p=d*24+24/2,m,h=s.parents.indexOf(u)>0;if(r===f)m=`M ${r} ${a} L ${f} ${p}`;else if(h){let e=a+24;m=`M ${r} ${a} C ${r} ${e} ${f} ${a} ${f} ${e} L ${f} ${p}`}else{let e=p-24;m=`M ${r} ${a} L ${r} ${e} C ${r} ${p} ${f} ${e} ${f} ${p}`}let g=s.parents.indexOf(u)===0?l:n;i.push({d:m,color:g})}else if(!a.has(u)){let e=n.get(u)??c,t=I[e%I.length],a=c*16+16/2,s=o*24+24/2,d=e*16+16/2;if(a===d)i.push({d:`M ${a} ${s} L ${a} ${r}`,color:l});else{let e=s+24,n=`M ${a} ${s} C ${a} ${e} ${d} ${s} ${d} ${e} L ${d} ${r}`;i.push({d:n,color:t})}}}}return i}function ae(e){let t=new Date(e),n=new Date().getTime()-t.getTime(),r=Math.floor(n/6e4);if(r<1)return`just now`;if(r<60)return`${r}m ago`;let i=Math.floor(r/60);if(i<24)return`${i}h ago`;let a=Math.floor(i/24);if(a<30)return`${a}d ago`;let o=Math.floor(a/30);return o<12?`${o}mo ago`:`${Math.floor(o/12)}y ago`}var L=200;function R(e){let[t,n]=(0,F.useState)(null),[r,i]=(0,F.useState)(!0),[a,o]=(0,F.useState)(!1),[s,c]=(0,F.useState)(!0),[l,d]=(0,F.useState)(null),[m,h]=(0,F.useState)(!1),[g,_]=(0,F.useState)(null),[v,y]=(0,F.useState)([]),[b,x]=(0,F.useState)(!1),[S,C]=(0,F.useState)(`__all__`),[w,T]=(0,F.useState)(``),[E,D]=(0,F.useState)(!1),{openTab:O}=u(),k=(0,F.useRef)(0),A=(0,F.useCallback)(async()=>{if(e)try{i(!0);let t=Math.max(L,k.current),r=await p.get(`${f(e)}/git/graph?max=${t}`);n(r),k.current=r.commits.length,c(r.commits.length>=t),d(null)}catch(e){d(e instanceof Error?e.message:`Failed to fetch graph`)}finally{i(!1)}},[e]),j=(0,F.useCallback)(async()=>{if(!(!e||a||!s))try{o(!0);let t=k.current,r=await p.get(`${f(e)}/git/graph?max=${L}&skip=${t}`);if(r.commits.length===0){c(!1);return}n(e=>{if(!e)return r;let t=new Set(e.commits.map(e=>e.hash)),n=r.commits.filter(e=>!t.has(e.hash)),i=new Set(e.branches.map(e=>e.name)),a=r.branches.filter(e=>!i.has(e.name));return{commits:[...e.commits,...n],branches:[...e.branches,...a],head:e.head}}),k.current=t+r.commits.length,c(r.commits.length>=L)}catch(e){d(e instanceof Error?e.message:`Failed to load more`)}finally{o(!1)}},[e,a,s]);(0,F.useEffect)(()=>{A();let e=setInterval(A,1e4);return()=>clearInterval(e)},[A]);let M=async(t,n)=>{if(e){h(!0);try{await p.post(`${f(e)}${t}`,n),await A()}catch(e){d(e instanceof Error?e.message:`Action failed`)}finally{h(!1)}}},N=()=>M(`/git/fetch`,{}),ee=e=>M(`/git/checkout`,{ref:e}),te=e=>M(`/git/cherry-pick`,{hash:e}),P=e=>M(`/git/revert`,{hash:e}),I=e=>M(`/git/merge`,{source:e}),ae=e=>M(`/git/branch/delete`,{name:e}),R=e=>M(`/git/push`,{branch:e}),z=(e,t)=>M(`/git/tag`,{name:e,hash:t}),B=e=>navigator.clipboard.writeText(e),V=async(e,n)=>{if(t?.branches.some(t=>t.name===e||t.name.endsWith(`/${e}`))){if(!window.confirm(`Branch "${e}" already exists.\nDelete and recreate from this commit?`))return;await M(`/git/branch/delete`,{name:e})}await M(`/git/branch/create`,{name:e,from:n})},oe=async t=>{if(e)try{let n=await p.get(`${f(e)}/git/pr-url?branch=${encodeURIComponent(t)}`);n.url&&window.open(n.url,`_blank`)}catch{}},H=async t=>{if(g?.hash===t.hash){_(null);return}_(t),x(!0);try{let n=t.parents[0]??``,r=n?`ref1=${encodeURIComponent(n)}&`:``,i=await p.get(`${f(e)}/git/diff-stat?${r}ref2=${encodeURIComponent(t.hash)}`);y(Array.isArray(i)?i:[])}catch{y([])}finally{x(!1)}},U=t=>O({type:`git-diff`,title:`Diff ${t.abbreviatedHash}`,closable:!0,metadata:{projectName:e,ref1:t.parents[0]??void 0,ref2:t.hash},projectId:e??null}),se=(0,F.useMemo)(()=>ne(t),[t]),W=t?.branches.find(e=>e.current),G=t?.head??``,K=(0,F.useMemo)(()=>{if(!t)return[];let e=t.commits;if(S!==`__all__`){let n=t.branches.find(e=>e.name===S);if(n){let r=new Set,i=[n.commitHash];for(;i.length>0;){let e=i.pop();if(r.has(e))continue;r.add(e);let n=t.commits.find(t=>t.hash===e);n&&i.push(...n.parents)}e=e.filter(e=>r.has(e.hash))}}if(w.trim()){let t=w.toLowerCase();e=e.filter(e=>e.subject.toLowerCase().includes(t)||e.authorName.toLowerCase().includes(t)||e.abbreviatedHash.includes(t)||e.hash.includes(t))}return e},[t,S,w]),q=(0,F.useMemo)(()=>t?{...t,commits:K}:null,[t,K]),J=(0,F.useMemo)(()=>re(q),[q]),Y=K.length*24+48;return{data:t,loading:r,loadingMore:a,hasMore:s,error:l,acting:m,selectedCommit:g,setSelectedCommit:_,commitFiles:v,loadingDetail:b,branchFilter:S,setBranchFilter:C,searchQuery:w,setSearchQuery:T,showSearch:E,setShowSearch:D,fetchGraph:A,fetchFromRemotes:N,loadMore:j,handleCheckout:ee,handleCherryPick:te,handleRevert:P,handleMerge:I,handleDeleteBranch:ae,handlePushBranch:R,handleCreateBranch:V,handleCreateTag:z,handleCreatePr:oe,copyHash:B,selectCommit:H,openDiffForCommit:U,commitLabels:se,currentBranch:W,headHash:G,filteredCommits:K,filteredLanes:J,svgHeight:Y,svgPaths:(0,F.useMemo)(()=>ie(q,J.laneMap,J.unloadedParentLanes,Y),[q,J.laneMap,J.unloadedParentLanes,Y])}}function z(e){let[t,n]=(0,F.useState)(e),r=(0,F.useRef)(e);r.current=t;let i=(0,F.useRef)(!1);return{widths:t,startResize:(e,t)=>{i.current=!0;let a=r.current[e]??80,o=r=>{if(!i.current)return;let o=`touches`in r?r.touches[0].clientX:r.clientX,s=Math.max(40,a+o-t);n(t=>({...t,[e]:s}))},s=()=>{i.current=!1,window.removeEventListener(`mousemove`,o),window.removeEventListener(`mouseup`,s),window.removeEventListener(`touchmove`,o),window.removeEventListener(`touchend`,s)};window.addEventListener(`mousemove`,o),window.addEventListener(`mouseup`,s),window.addEventListener(`touchmove`,o,{passive:!1}),window.addEventListener(`touchend`,s)}}}var B=c(),V=`/Users/hienlh/Projects/ppm/src/web/components/git/git-graph-toolbar.tsx`;function oe({branches:e,branchFilter:t,onBranchFilterChange:i,searchQuery:a,onSearchQueryChange:s,showSearch:c,onToggleSearch:l,onFetch:u,onRefresh:d,onOpenSettings:f,loading:p,acting:g,projectName:_}){let y=e.filter(e=>!e.remote),[b,x]=(0,F.useState)(!1),[S,C]=(0,F.useState)(``),w=(0,F.useRef)(null);(0,F.useEffect)(()=>{if(!b)return;let e=e=>{w.current&&!w.current.contains(e.target)&&(x(!1),C(``))};return document.addEventListener(`mousedown`,e),()=>document.removeEventListener(`mousedown`,e)},[b]);let T=S?y.filter(e=>e.name.toLowerCase().includes(S.toLowerCase())):y,E=t===`__all__`?`Show All`:y.find(e=>e.name===t)?.name??`Show All`;return(0,B.jsxDEV)(`div`,{className:`border-b bg-background`,children:(0,B.jsxDEV)(`div`,{className:`flex items-center gap-1.5 px-2 py-1.5`,children:[(0,B.jsxDEV)(`div`,{className:`flex items-center gap-1 text-xs text-muted-foreground shrink-0`,children:[(0,B.jsxDEV)(`span`,{className:`font-semibold`,children:`Repo:`},void 0,!1,{fileName:V,lineNumber:80,columnNumber:11},this),(0,B.jsxDEV)(`span`,{className:`font-medium text-foreground truncate max-w-[120px]`,children:_??`—`},void 0,!1,{fileName:V,lineNumber:81,columnNumber:11},this)]},void 0,!0,{fileName:V,lineNumber:79,columnNumber:9},this),(0,B.jsxDEV)(`div`,{className:`w-px h-4 bg-border mx-1`},void 0,!1,{fileName:V,lineNumber:86,columnNumber:9},this),(0,B.jsxDEV)(`div`,{className:`relative shrink-0`,ref:w,children:[(0,B.jsxDEV)(`button`,{type:`button`,className:`flex items-center gap-1 h-6 px-2 text-xs border rounded-md bg-transparent hover:bg-muted/50`,onClick:()=>{x(e=>!e),C(``)},children:[(0,B.jsxDEV)(`span`,{className:`font-semibold text-muted-foreground`,children:`Branches:`},void 0,!1,{fileName:V,lineNumber:95,columnNumber:13},this),(0,B.jsxDEV)(`span`,{className:`max-w-[100px] truncate`,children:E},void 0,!1,{fileName:V,lineNumber:96,columnNumber:13},this),(0,B.jsxDEV)(r,{className:`size-3 opacity-50`},void 0,!1,{fileName:V,lineNumber:97,columnNumber:13},this)]},void 0,!0,{fileName:V,lineNumber:90,columnNumber:11},this),b&&(0,B.jsxDEV)(`div`,{className:`absolute top-full left-0 mt-1 z-50 w-[220px] rounded-md border bg-popover shadow-md`,children:[(0,B.jsxDEV)(`div`,{className:`p-1.5`,children:(0,B.jsxDEV)(o,{className:`h-6 text-xs px-2`,placeholder:`Filter branches...`,value:S,onChange:e=>C(e.target.value),autoFocus:!0},void 0,!1,{fileName:V,lineNumber:102,columnNumber:17},this)},void 0,!1,{fileName:V,lineNumber:101,columnNumber:15},this),(0,B.jsxDEV)(`div`,{className:`max-h-[200px] overflow-y-auto p-1`,children:[(0,B.jsxDEV)(H,{label:`Show All`,selected:t===`__all__`,onClick:()=>{i(`__all__`),x(!1)}},void 0,!1,{fileName:V,lineNumber:111,columnNumber:17},this),T.map(e=>(0,B.jsxDEV)(H,{label:e.name,current:e.current,selected:t===e.name,onClick:()=>{i(e.name),x(!1)}},e.name,!1,{fileName:V,lineNumber:117,columnNumber:19},this)),T.length===0&&S&&(0,B.jsxDEV)(`div`,{className:`px-2 py-1.5 text-xs text-muted-foreground`,children:`No branches found`},void 0,!1,{fileName:V,lineNumber:126,columnNumber:19},this)]},void 0,!0,{fileName:V,lineNumber:110,columnNumber:15},this)]},void 0,!0,{fileName:V,lineNumber:100,columnNumber:13},this)]},void 0,!0,{fileName:V,lineNumber:89,columnNumber:9},this),(0,B.jsxDEV)(`div`,{className:`flex-1`},void 0,!1,{fileName:V,lineNumber:133,columnNumber:9},this),c&&(0,B.jsxDEV)(`div`,{className:`flex items-center gap-1`,children:[(0,B.jsxDEV)(o,{className:`h-6 text-xs w-[160px] px-2`,placeholder:`Search commits...`,value:a,onChange:e=>s(e.target.value),autoFocus:!0},void 0,!1,{fileName:V,lineNumber:138,columnNumber:13},this),(0,B.jsxDEV)(j,{variant:`ghost`,size:`icon-xs`,onClick:l,children:(0,B.jsxDEV)(n,{className:`size-3`},void 0,!1,{fileName:V,lineNumber:146,columnNumber:15},this)},void 0,!1,{fileName:V,lineNumber:145,columnNumber:13},this)]},void 0,!0,{fileName:V,lineNumber:137,columnNumber:11},this),!c&&(0,B.jsxDEV)(j,{variant:`ghost`,size:`icon-xs`,onClick:l,title:`Find`,children:(0,B.jsxDEV)(m,{className:`size-3.5`},void 0,!1,{fileName:V,lineNumber:154,columnNumber:13},this)},void 0,!1,{fileName:V,lineNumber:153,columnNumber:11},this),(0,B.jsxDEV)(j,{variant:`ghost`,size:`icon-xs`,onClick:f,title:`Settings`,children:(0,B.jsxDEV)(h,{className:`size-3.5`},void 0,!1,{fileName:V,lineNumber:158,columnNumber:11},this)},void 0,!1,{fileName:V,lineNumber:157,columnNumber:9},this),(0,B.jsxDEV)(j,{variant:`ghost`,size:`icon-xs`,onClick:u,disabled:g,title:`Fetch`,children:(0,B.jsxDEV)(N,{className:`size-3.5`},void 0,!1,{fileName:V,lineNumber:161,columnNumber:11},this)},void 0,!1,{fileName:V,lineNumber:160,columnNumber:9},this),(0,B.jsxDEV)(j,{variant:`ghost`,size:`icon-xs`,onClick:d,disabled:g,title:`Refresh`,children:(0,B.jsxDEV)(v,{className:`size-3.5 ${p?`animate-spin`:``}`},void 0,!1,{fileName:V,lineNumber:164,columnNumber:11},this)},void 0,!1,{fileName:V,lineNumber:163,columnNumber:9},this)]},void 0,!0,{fileName:V,lineNumber:77,columnNumber:7},this)},void 0,!1,{fileName:V,lineNumber:76,columnNumber:5},this)}function H({label:e,selected:t,current:n,onClick:r}){return(0,B.jsxDEV)(`button`,{type:`button`,className:`flex items-center gap-2 w-full px-2 py-1 text-xs rounded-sm hover:bg-accent hover:text-accent-foreground text-left`,onClick:r,children:[(0,B.jsxDEV)(i,{className:`size-3 shrink-0 ${t?`opacity-100`:`opacity-0`}`},void 0,!1,{fileName:V,lineNumber:188,columnNumber:7},this),(0,B.jsxDEV)(`span`,{className:`truncate flex-1`,children:e},void 0,!1,{fileName:V,lineNumber:189,columnNumber:7},this),n&&(0,B.jsxDEV)(`span`,{className:`text-[10px] text-muted-foreground italic`,children:`current`},void 0,!1,{fileName:V,lineNumber:191,columnNumber:9},this)]},void 0,!0,{fileName:V,lineNumber:183,columnNumber:5},this)}var U=`/Users/hienlh/Projects/ppm/src/web/components/git/git-graph-svg.tsx`;function se({commits:e,laneMap:t,svgPaths:n,width:r,height:i,headHash:a}){return(0,B.jsxDEV)(`svg`,{width:r,height:i,children:[n.map((e,t)=>(0,B.jsxDEV)(`path`,{d:e.d,stroke:e.color,strokeWidth:2,fill:`none`},t,!1,{fileName:U,lineNumber:25,columnNumber:9},this)),e.map((e,n)=>{let r=t.get(e.hash)??0,i=r*16+16/2,o=n*24+24/2,s=I[r%I.length],c=e.hash===a;return(0,B.jsxDEV)(`circle`,{cx:i,cy:o,r:c?5:4,fill:s,stroke:c?`#000`:`none`,strokeWidth:c?2:0},e.hash,!1,{fileName:U,lineNumber:41,columnNumber:11},this)})]},void 0,!0,{fileName:U,lineNumber:22,columnNumber:5},this)}var W=`/Users/hienlh/Projects/ppm/src/web/components/git/git-graph-branch-label.tsx`;function G({name:e,type:t,remotes:n,isCurrent:r,color:i,currentBranch:a,onCheckout:o,onMerge:s,onPush:c,onCreatePr:u,onDelete:d}){return t===`tag`?(0,B.jsxDEV)(`span`,{className:`inline-flex items-center gap-0.5 px-1.5 py-0.5 rounded text-[10px] font-medium shrink-0 bg-amber-500/20 text-amber-500 border border-amber-500/30`,children:[(0,B.jsxDEV)(P,{className:`size-2.5`},void 0,!1,{fileName:W,lineNumber:48,columnNumber:9},this),e]},void 0,!0,{fileName:W,lineNumber:47,columnNumber:7},this):(0,B.jsxDEV)(C,{children:[(0,B.jsxDEV)(T,{asChild:!0,children:(0,B.jsxDEV)(`span`,{className:`inline-flex items-center rounded text-[10px] font-medium shrink-0 cursor-context-menu overflow-hidden`,style:{border:r?`1.5px solid ${i}`:`1px solid ${i}50`},children:[(0,B.jsxDEV)(`span`,{className:`inline-flex items-center gap-0.5 px-1.5 py-0.5`,style:{backgroundColor:r?i:`${i}30`,color:r?`#fff`:i},children:[(0,B.jsxDEV)(_,{className:`size-2.5`},void 0,!1,{fileName:W,lineNumber:73,columnNumber:13},this),e]},void 0,!0,{fileName:W,lineNumber:66,columnNumber:11},this),n.map(e=>(0,B.jsxDEV)(`span`,{className:`px-1.5 py-0.5 italic opacity-70`,style:{borderLeft:`1px solid ${i}40`,color:i,backgroundColor:`${i}15`},children:e},e,!1,{fileName:W,lineNumber:78,columnNumber:13},this))]},void 0,!0,{fileName:W,lineNumber:57,columnNumber:9},this)},void 0,!1,{fileName:W,lineNumber:56,columnNumber:7},this),(0,B.jsxDEV)(w,{children:[(0,B.jsxDEV)(k,{onClick:()=>o(e),children:`Checkout`},void 0,!1,{fileName:W,lineNumber:93,columnNumber:9},this),(0,B.jsxDEV)(k,{onClick:()=>s(e),disabled:e===a?.name,children:[(0,B.jsxDEV)(te,{className:`size-3`},void 0,!1,{fileName:W,lineNumber:100,columnNumber:11},this),`Merge into current`]},void 0,!0,{fileName:W,lineNumber:96,columnNumber:9},this),(0,B.jsxDEV)(D,{},void 0,!1,{fileName:W,lineNumber:103,columnNumber:9},this),(0,B.jsxDEV)(k,{onClick:()=>c(e),children:[(0,B.jsxDEV)(b,{className:`size-3`},void 0,!1,{fileName:W,lineNumber:105,columnNumber:11},this),`Push`]},void 0,!0,{fileName:W,lineNumber:104,columnNumber:9},this),(0,B.jsxDEV)(k,{onClick:()=>u(e),children:[(0,B.jsxDEV)(l,{className:`size-3`},void 0,!1,{fileName:W,lineNumber:109,columnNumber:11},this),`Create PR`]},void 0,!0,{fileName:W,lineNumber:108,columnNumber:9},this),(0,B.jsxDEV)(D,{},void 0,!1,{fileName:W,lineNumber:112,columnNumber:9},this),(0,B.jsxDEV)(k,{variant:`destructive`,onClick:()=>d(e),disabled:e===a?.name,children:[(0,B.jsxDEV)(M,{className:`size-3`},void 0,!1,{fileName:W,lineNumber:118,columnNumber:11},this),`Delete`]},void 0,!0,{fileName:W,lineNumber:113,columnNumber:9},this)]},void 0,!0,{fileName:W,lineNumber:92,columnNumber:7},this)]},void 0,!0,{fileName:W,lineNumber:55,columnNumber:5},this)}var K=`/Users/hienlh/Projects/ppm/src/web/components/git/git-graph-row.tsx`;function q({commit:e,lane:t,isSelected:n,isHead:r,labels:i,currentBranch:o,onSelect:s,onCheckout:c,onCherryPick:l,onRevert:u,onMerge:d,onDeleteBranch:f,onPushBranch:p,onCreatePr:m,onOpenCreateBranch:h,onOpenCreateTag:g,onOpenDiff:v,onCopyHash:b}){let x=I[t%I.length],S=i.filter(e=>e.type===`branch`),E=i.filter(e=>e.type===`tag`);return(0,B.jsxDEV)(C,{children:[(0,B.jsxDEV)(T,{asChild:!0,children:(0,B.jsxDEV)(`tr`,{className:`hover:bg-muted/50 cursor-pointer border-b border-border/20 ${n?`bg-primary/10`:``} ${r?`font-medium`:``}`,style:{height:`24px`},onClick:s,children:[(0,B.jsxDEV)(`td`,{className:`px-2 truncate max-w-0`,children:(0,B.jsxDEV)(`div`,{className:`flex items-center gap-1.5 min-w-0`,children:[S.map(e=>(0,B.jsxDEV)(G,{name:e.name,type:`branch`,remotes:e.remotes,isCurrent:e.current,color:x,currentBranch:o,onCheckout:c,onMerge:d,onPush:p,onCreatePr:m,onDelete:f},`branch-${e.name}`,!1,{fileName:K,lineNumber:85,columnNumber:17},this)),E.map(e=>(0,B.jsxDEV)(G,{name:e.name,type:`tag`,remotes:[],isCurrent:!1,color:x,currentBranch:o,onCheckout:c,onMerge:d,onPush:p,onCreatePr:m,onDelete:f},`tag-${e.name}`,!1,{fileName:K,lineNumber:101,columnNumber:17},this)),(0,B.jsxDEV)(`span`,{className:`truncate text-xs`,children:e.subject},void 0,!1,{fileName:K,lineNumber:116,columnNumber:15},this)]},void 0,!0,{fileName:K,lineNumber:83,columnNumber:13},this)},void 0,!1,{fileName:K,lineNumber:82,columnNumber:11},this),(0,B.jsxDEV)(`td`,{className:`px-2 text-xs text-muted-foreground whitespace-nowrap shrink-0`,children:ae(e.authorDate)},void 0,!1,{fileName:K,lineNumber:121,columnNumber:11},this),(0,B.jsxDEV)(`td`,{className:`px-2 text-xs text-muted-foreground truncate max-w-[120px]`,children:e.authorName},void 0,!1,{fileName:K,lineNumber:126,columnNumber:11},this),(0,B.jsxDEV)(`td`,{className:`px-2 text-xs text-muted-foreground font-mono whitespace-nowrap`,children:e.abbreviatedHash},void 0,!1,{fileName:K,lineNumber:131,columnNumber:11},this)]},void 0,!0,{fileName:K,lineNumber:74,columnNumber:9},this)},void 0,!1,{fileName:K,lineNumber:73,columnNumber:7},this),(0,B.jsxDEV)(w,{children:[(0,B.jsxDEV)(k,{onClick:()=>c(e.hash),children:`Checkout`},void 0,!1,{fileName:K,lineNumber:138,columnNumber:9},this),(0,B.jsxDEV)(k,{onClick:()=>h(e.hash),children:[(0,B.jsxDEV)(_,{className:`size-3`},void 0,!1,{fileName:K,lineNumber:142,columnNumber:11},this),`Create Branch...`]},void 0,!0,{fileName:K,lineNumber:141,columnNumber:9},this),(0,B.jsxDEV)(D,{},void 0,!1,{fileName:K,lineNumber:145,columnNumber:9},this),(0,B.jsxDEV)(k,{onClick:()=>l(e.hash),children:[(0,B.jsxDEV)(ee,{className:`size-3`},void 0,!1,{fileName:K,lineNumber:147,columnNumber:11},this),`Cherry Pick`]},void 0,!0,{fileName:K,lineNumber:146,columnNumber:9},this),(0,B.jsxDEV)(k,{onClick:()=>u(e.hash),children:[(0,B.jsxDEV)(a,{className:`size-3`},void 0,!1,{fileName:K,lineNumber:151,columnNumber:11},this),`Revert`]},void 0,!0,{fileName:K,lineNumber:150,columnNumber:9},this),(0,B.jsxDEV)(k,{onClick:()=>g(e.hash),children:[(0,B.jsxDEV)(P,{className:`size-3`},void 0,!1,{fileName:K,lineNumber:155,columnNumber:11},this),`Create Tag...`]},void 0,!0,{fileName:K,lineNumber:154,columnNumber:9},this),(0,B.jsxDEV)(D,{},void 0,!1,{fileName:K,lineNumber:158,columnNumber:9},this),(0,B.jsxDEV)(k,{onClick:v,children:`View Diff`},void 0,!1,{fileName:K,lineNumber:159,columnNumber:9},this),(0,B.jsxDEV)(k,{onClick:b,children:[(0,B.jsxDEV)(y,{className:`size-3`},void 0,!1,{fileName:K,lineNumber:161,columnNumber:11},this),`Copy Hash`]},void 0,!0,{fileName:K,lineNumber:160,columnNumber:9},this)]},void 0,!0,{fileName:K,lineNumber:137,columnNumber:7},this)]},void 0,!0,{fileName:K,lineNumber:72,columnNumber:5},this)}var J=`/Users/hienlh/Projects/ppm/src/web/components/git/git-graph-detail.tsx`;function Y({commit:e,files:t,loadingDetail:n,projectName:r,onClose:i,copyHash:a}){let{openTab:o}=u();return(0,B.jsxDEV)(`div`,{className:`border-t bg-muted/30 max-h-[40%] overflow-auto`,children:[(0,B.jsxDEV)(`div`,{className:`px-3 py-2 border-b flex items-center justify-between`,children:[(0,B.jsxDEV)(`span`,{className:`text-sm font-medium truncate`,children:[e.abbreviatedHash,` — `,e.subject]},void 0,!0,{fileName:J,lineNumber:28,columnNumber:9},this),(0,B.jsxDEV)(j,{variant:`ghost`,size:`icon-xs`,onClick:i,children:`✕`},void 0,!1,{fileName:J,lineNumber:31,columnNumber:9},this)]},void 0,!0,{fileName:J,lineNumber:27,columnNumber:7},this),(0,B.jsxDEV)(`div`,{className:`px-3 py-2 text-xs space-y-1`,children:[(0,B.jsxDEV)(`div`,{className:`flex gap-4`,children:[(0,B.jsxDEV)(`span`,{className:`text-muted-foreground w-12 shrink-0`,children:`Author`},void 0,!1,{fileName:J,lineNumber:37,columnNumber:11},this),(0,B.jsxDEV)(`span`,{children:[e.authorName,` <`,e.authorEmail,`>`]},void 0,!0,{fileName:J,lineNumber:38,columnNumber:11},this)]},void 0,!0,{fileName:J,lineNumber:36,columnNumber:9},this),(0,B.jsxDEV)(`div`,{className:`flex gap-4`,children:[(0,B.jsxDEV)(`span`,{className:`text-muted-foreground w-12 shrink-0`,children:`Date`},void 0,!1,{fileName:J,lineNumber:43,columnNumber:11},this),(0,B.jsxDEV)(`span`,{children:new Date(e.authorDate).toLocaleString()},void 0,!1,{fileName:J,lineNumber:44,columnNumber:11},this)]},void 0,!0,{fileName:J,lineNumber:42,columnNumber:9},this),(0,B.jsxDEV)(`div`,{className:`flex gap-4`,children:[(0,B.jsxDEV)(`span`,{className:`text-muted-foreground w-12 shrink-0`,children:`Hash`},void 0,!1,{fileName:J,lineNumber:47,columnNumber:11},this),(0,B.jsxDEV)(`span`,{className:`font-mono cursor-pointer hover:text-primary`,onClick:()=>a(e.hash),children:e.hash},void 0,!1,{fileName:J,lineNumber:48,columnNumber:11},this)]},void 0,!0,{fileName:J,lineNumber:46,columnNumber:9},this),e.parents.length>0&&(0,B.jsxDEV)(`div`,{className:`flex gap-4`,children:[(0,B.jsxDEV)(`span`,{className:`text-muted-foreground w-12 shrink-0`,children:`Parents`},void 0,!1,{fileName:J,lineNumber:57,columnNumber:13},this),(0,B.jsxDEV)(`span`,{className:`font-mono`,children:e.parents.map(e=>e.slice(0,7)).join(`, `)},void 0,!1,{fileName:J,lineNumber:58,columnNumber:13},this)]},void 0,!0,{fileName:J,lineNumber:56,columnNumber:11},this),e.body&&(0,B.jsxDEV)(`div`,{className:`mt-2 p-2 bg-background rounded text-xs whitespace-pre-wrap`,children:e.body},void 0,!1,{fileName:J,lineNumber:64,columnNumber:11},this)]},void 0,!0,{fileName:J,lineNumber:35,columnNumber:7},this),(0,B.jsxDEV)(`div`,{className:`px-3 py-1 border-t`,children:[(0,B.jsxDEV)(`div`,{className:`text-xs text-muted-foreground py-1`,children:n?`Loading files...`:`${t.length} file${t.length===1?``:`s`} changed`},void 0,!1,{fileName:J,lineNumber:71,columnNumber:9},this),t.map(t=>(0,B.jsxDEV)(`div`,{className:`flex items-center gap-2 py-0.5 text-xs hover:bg-muted/50 rounded px-1 cursor-pointer`,onClick:()=>o({type:`git-diff`,title:`Diff ${d(t.path)}`,closable:!0,metadata:{projectName:r,ref1:e.parents[0]??void 0,ref2:e.hash,filePath:t.path},projectId:r}),children:[(0,B.jsxDEV)(`span`,{className:`flex-1 truncate font-mono`,children:t.path},void 0,!1,{fileName:J,lineNumber:95,columnNumber:13},this),t.additions>0&&(0,B.jsxDEV)(`span`,{className:`text-green-500`,children:[`+`,t.additions]},void 0,!0,{fileName:J,lineNumber:97,columnNumber:15},this),t.deletions>0&&(0,B.jsxDEV)(`span`,{className:`text-red-500`,children:[`-`,t.deletions]},void 0,!0,{fileName:J,lineNumber:100,columnNumber:15},this)]},t.path,!0,{fileName:J,lineNumber:77,columnNumber:11},this))]},void 0,!0,{fileName:J,lineNumber:70,columnNumber:7},this)]},void 0,!0,{fileName:J,lineNumber:26,columnNumber:5},this)}var X=`/Users/hienlh/Projects/ppm/src/web/components/git/git-graph-dialog.tsx`;function ce({type:e,hash:t,onClose:n,onCreateBranch:r,onCreateTag:i}){let[a,s]=(0,F.useState)(``),c=()=>{a.trim()&&(e===`branch`?r(a.trim(),t):i(a.trim(),t),n())};return(0,B.jsxDEV)(x,{open:e!==null,onOpenChange:e=>{e||n()},children:(0,B.jsxDEV)(O,{children:[(0,B.jsxDEV)(S,{children:(0,B.jsxDEV)(E,{children:e===`branch`?`Create Branch`:`Create Tag`},void 0,!1,{fileName:X,lineNumber:48,columnNumber:11},this)},void 0,!1,{fileName:X,lineNumber:47,columnNumber:9},this),(0,B.jsxDEV)(o,{placeholder:e===`branch`?`Branch name`:`Tag name`,value:a,onChange:e=>s(e.target.value),onKeyDown:e=>{e.key===`Enter`&&c()},autoFocus:!0},void 0,!1,{fileName:X,lineNumber:52,columnNumber:9},this),(0,B.jsxDEV)(A,{children:[(0,B.jsxDEV)(j,{variant:`outline`,onClick:n,children:`Cancel`},void 0,!1,{fileName:X,lineNumber:62,columnNumber:11},this),(0,B.jsxDEV)(j,{disabled:!a.trim(),onClick:c,children:`Create`},void 0,!1,{fileName:X,lineNumber:65,columnNumber:11},this)]},void 0,!0,{fileName:X,lineNumber:61,columnNumber:9},this)]},void 0,!0,{fileName:X,lineNumber:46,columnNumber:7},this)},void 0,!1,{fileName:X,lineNumber:40,columnNumber:5},this)}var Z=`/Users/hienlh/Projects/ppm/src/web/components/git/git-graph-settings-dialog.tsx`;function le({open:e,onClose:t,projectName:n,branches:r}){let i=r.filter(e=>!e.remote),a=r.filter(e=>e.remote),o=new Map;for(let e of a){let t=e.name.replace(/^remotes\//,``),n=t.indexOf(`/`);if(n<0)continue;let r=t.slice(0,n),i=t.slice(n+1),a=o.get(r)??[];a.push(i),o.set(r,a)}return(0,B.jsxDEV)(x,{open:e,onOpenChange:e=>{e||t()},children:(0,B.jsxDEV)(O,{className:`max-w-md`,children:[(0,B.jsxDEV)(S,{children:(0,B.jsxDEV)(E,{children:`Repository Settings`},void 0,!1,{fileName:Z,lineNumber:42,columnNumber:11},this)},void 0,!1,{fileName:Z,lineNumber:41,columnNumber:9},this),(0,B.jsxDEV)(`div`,{className:`space-y-4 text-sm`,children:[(0,B.jsxDEV)(Q,{title:`General`,children:[(0,B.jsxDEV)(ue,{label:`Name`,value:n},void 0,!1,{fileName:Z,lineNumber:47,columnNumber:13},this),(0,B.jsxDEV)(ue,{label:`Branches`,value:`${i.length} local, ${a.length} remote`},void 0,!1,{fileName:Z,lineNumber:48,columnNumber:13},this)]},void 0,!0,{fileName:Z,lineNumber:46,columnNumber:11},this),(0,B.jsxDEV)(Q,{title:`Local Branches`,children:i.map(e=>(0,B.jsxDEV)(`div`,{className:`flex items-center gap-2 py-0.5`,children:[(0,B.jsxDEV)(`span`,{className:`text-xs ${e.current?`font-semibold text-primary`:`text-foreground`}`,children:e.name},void 0,!1,{fileName:Z,lineNumber:55,columnNumber:17},this),e.current&&(0,B.jsxDEV)(`span`,{className:`text-[10px] text-muted-foreground italic`,children:`HEAD`},void 0,!1,{fileName:Z,lineNumber:58,columnNumber:31},this),e.remotes.length>0&&(0,B.jsxDEV)(`span`,{className:`text-[10px] text-muted-foreground`,children:[`(`,e.remotes.join(`, `),`)`]},void 0,!0,{fileName:Z,lineNumber:60,columnNumber:19},this)]},e.name,!0,{fileName:Z,lineNumber:54,columnNumber:15},this))},void 0,!1,{fileName:Z,lineNumber:52,columnNumber:11},this),(0,B.jsxDEV)(Q,{title:`Remotes`,children:[[...o.entries()].map(([e,t])=>(0,B.jsxDEV)(`div`,{className:`py-0.5`,children:[(0,B.jsxDEV)(`span`,{className:`text-xs font-medium`,children:e},void 0,!1,{fileName:Z,lineNumber:72,columnNumber:17},this),(0,B.jsxDEV)(`span`,{className:`text-[10px] text-muted-foreground ml-2`,children:[t.length,` branch`,t.length===1?``:`es`]},void 0,!0,{fileName:Z,lineNumber:73,columnNumber:17},this)]},e,!0,{fileName:Z,lineNumber:71,columnNumber:15},this)),o.size===0&&(0,B.jsxDEV)(`span`,{className:`text-xs text-muted-foreground`,children:`No remotes configured`},void 0,!1,{fileName:Z,lineNumber:79,columnNumber:15},this)]},void 0,!0,{fileName:Z,lineNumber:69,columnNumber:11},this)]},void 0,!0,{fileName:Z,lineNumber:44,columnNumber:9},this)]},void 0,!0,{fileName:Z,lineNumber:40,columnNumber:7},this)},void 0,!1,{fileName:Z,lineNumber:39,columnNumber:5},this)}function Q({title:e,children:t}){return(0,B.jsxDEV)(`div`,{children:[(0,B.jsxDEV)(`h4`,{className:`text-xs font-semibold text-muted-foreground uppercase tracking-wider mb-1.5`,children:e},void 0,!1,{fileName:Z,lineNumber:91,columnNumber:7},this),(0,B.jsxDEV)(`div`,{className:`pl-1`,children:t},void 0,!1,{fileName:Z,lineNumber:92,columnNumber:7},this)]},void 0,!0,{fileName:Z,lineNumber:90,columnNumber:5},this)}function ue({label:e,value:t}){return(0,B.jsxDEV)(`div`,{className:`flex items-center gap-3 py-0.5`,children:[(0,B.jsxDEV)(`span`,{className:`text-xs text-muted-foreground w-16 shrink-0`,children:e},void 0,!1,{fileName:Z,lineNumber:100,columnNumber:7},this),(0,B.jsxDEV)(`span`,{className:`text-xs`,children:t},void 0,!1,{fileName:Z,lineNumber:101,columnNumber:7},this)]},void 0,!0,{fileName:Z,lineNumber:99,columnNumber:5},this)}var $=`/Users/hienlh/Projects/ppm/src/web/components/git/git-graph.tsx`;function de({metadata:e}){let t=e?.projectName,n=R(t),[r,i]=(0,F.useState)({type:null}),[a,o]=(0,F.useState)(!1),s=(typeof window<`u`&&window.innerWidth<768?6:10)*16+16,[c,l]=(0,F.useState)(s),u=(0,F.useRef)(s);u.current=c;let d=(0,F.useRef)(!1),f=e=>{d.current=!0;let t=u.current,n=n=>{if(!d.current)return;let r=`touches`in n?n.touches[0].clientX:n.clientX;l(Math.max(40,t+r-e))},r=()=>{d.current=!1,window.removeEventListener(`mousemove`,n),window.removeEventListener(`mouseup`,r),window.removeEventListener(`touchmove`,n),window.removeEventListener(`touchend`,r)};window.addEventListener(`mousemove`,n),window.addEventListener(`mouseup`,r),window.addEventListener(`touchmove`,n,{passive:!1}),window.addEventListener(`touchend`,r)},{widths:p,startResize:m}=z({date:80,author:120,commit:70}),h=(0,F.useRef)(n.loadMore);h.current=n.loadMore;let _=(0,F.useCallback)(e=>{let t=e.currentTarget;t.scrollHeight-t.scrollTop-t.clientHeight<200&&h.current()},[]);return t?n.loading&&!n.data?(0,B.jsxDEV)(me,{},void 0,!1,{fileName:$,lineNumber:70,columnNumber:36},this):n.error&&!n.data?(0,B.jsxDEV)(he,{error:n.error,onRetry:n.fetchGraph},void 0,!1,{fileName:$,lineNumber:71,columnNumber:34},this):(0,B.jsxDEV)(`div`,{className:`flex flex-col h-full`,children:[(0,B.jsxDEV)(oe,{branches:n.data?.branches??[],branchFilter:n.branchFilter,onBranchFilterChange:n.setBranchFilter,searchQuery:n.searchQuery,onSearchQueryChange:n.setSearchQuery,showSearch:n.showSearch,onToggleSearch:()=>n.setShowSearch(!n.showSearch),onFetch:n.fetchFromRemotes,onRefresh:n.fetchGraph,onOpenSettings:()=>o(!0),loading:n.loading,acting:n.acting,projectName:t},void 0,!1,{fileName:$,lineNumber:75,columnNumber:7},this),n.error&&(0,B.jsxDEV)(`div`,{className:`px-3 py-1.5 text-xs text-destructive bg-destructive/10`,children:n.error},void 0,!1,{fileName:$,lineNumber:84,columnNumber:19},this),(0,B.jsxDEV)(`div`,{className:`flex-1 overflow-auto`,onScroll:_,children:(0,B.jsxDEV)(`div`,{className:`flex min-w-max md:min-w-0`,children:[(0,B.jsxDEV)(`div`,{className:`sticky left-0 z-10 shrink-0 bg-background relative overflow-hidden`,style:{width:`${c}px`},children:[(0,B.jsxDEV)(`div`,{className:`text-[11px] font-semibold text-muted-foreground px-2 border-b bg-background sticky top-0 z-20`,style:{height:`24px`,lineHeight:`24px`},children:`Graph`},void 0,!1,{fileName:$,lineNumber:90,columnNumber:13},this),(0,B.jsxDEV)(se,{commits:n.filteredCommits,laneMap:n.filteredLanes.laneMap,svgPaths:n.svgPaths,width:(n.filteredLanes.maxLane+2)*16,height:n.svgHeight,headHash:n.headHash},void 0,!1,{fileName:$,lineNumber:92,columnNumber:13},this),(0,B.jsxDEV)(`div`,{className:`absolute top-0 right-0 w-1.5 h-full cursor-col-resize hover:bg-primary/30`,onMouseDown:e=>{e.preventDefault(),f(e.clientX)},onTouchStart:e=>f(e.touches[0].clientX)},void 0,!1,{fileName:$,lineNumber:94,columnNumber:13},this)]},void 0,!0,{fileName:$,lineNumber:89,columnNumber:11},this),(0,B.jsxDEV)(`div`,{className:`flex-1 min-w-[400px]`,children:[(0,B.jsxDEV)(`table`,{className:`w-full border-collapse text-xs`,style:{tableLayout:`fixed`},children:[(0,B.jsxDEV)(`colgroup`,{children:[(0,B.jsxDEV)(`col`,{},void 0,!1,{fileName:$,lineNumber:103,columnNumber:17},this),(0,B.jsxDEV)(`col`,{style:{width:`${p.date}px`}},void 0,!1,{fileName:$,lineNumber:104,columnNumber:17},this),(0,B.jsxDEV)(`col`,{style:{width:`${p.author}px`}},void 0,!1,{fileName:$,lineNumber:105,columnNumber:17},this),(0,B.jsxDEV)(`col`,{style:{width:`${p.commit}px`}},void 0,!1,{fileName:$,lineNumber:106,columnNumber:17},this)]},void 0,!0,{fileName:$,lineNumber:102,columnNumber:15},this),(0,B.jsxDEV)(`thead`,{className:`sticky top-0 z-10 bg-background`,children:(0,B.jsxDEV)(`tr`,{className:`border-b text-[11px] font-semibold text-muted-foreground`,style:{height:`24px`},children:[(0,B.jsxDEV)(`th`,{className:`text-left px-2 font-semibold`,children:`Description`},void 0,!1,{fileName:$,lineNumber:110,columnNumber:19},this),(0,B.jsxDEV)(fe,{label:`Date`,colKey:`date`,onStartResize:m},void 0,!1,{fileName:$,lineNumber:111,columnNumber:19},this),(0,B.jsxDEV)(fe,{label:`Author`,colKey:`author`,onStartResize:m},void 0,!1,{fileName:$,lineNumber:112,columnNumber:19},this),(0,B.jsxDEV)(`th`,{className:`text-left px-2 font-semibold`,children:`Commit`},void 0,!1,{fileName:$,lineNumber:113,columnNumber:19},this)]},void 0,!0,{fileName:$,lineNumber:109,columnNumber:17},this)},void 0,!1,{fileName:$,lineNumber:108,columnNumber:15},this),(0,B.jsxDEV)(`tbody`,{children:n.filteredCommits.map(e=>(0,B.jsxDEV)(q,{commit:e,lane:n.filteredLanes.laneMap.get(e.hash)??0,isSelected:n.selectedCommit?.hash===e.hash,isHead:e.hash===n.headHash,labels:n.commitLabels.get(e.hash)??[],currentBranch:n.currentBranch,onSelect:()=>n.selectCommit(e),onCheckout:n.handleCheckout,onCherryPick:n.handleCherryPick,onRevert:n.handleRevert,onMerge:n.handleMerge,onDeleteBranch:n.handleDeleteBranch,onPushBranch:n.handlePushBranch,onCreatePr:n.handleCreatePr,onOpenCreateBranch:e=>i({type:`branch`,hash:e}),onOpenCreateTag:e=>i({type:`tag`,hash:e}),onOpenDiff:()=>n.openDiffForCommit(e),onCopyHash:()=>n.copyHash(e.hash)},e.hash,!1,{fileName:$,lineNumber:118,columnNumber:19},this))},void 0,!1,{fileName:$,lineNumber:116,columnNumber:15},this)]},void 0,!0,{fileName:$,lineNumber:101,columnNumber:13},this),n.loadingMore&&(0,B.jsxDEV)(`div`,{className:`flex items-center justify-center gap-2 py-3 text-xs text-muted-foreground`,children:[(0,B.jsxDEV)(g,{className:`size-3.5 animate-spin`},void 0,!1,{fileName:$,lineNumber:138,columnNumber:17},this),` Loading more commits...`]},void 0,!0,{fileName:$,lineNumber:137,columnNumber:15},this),!n.hasMore&&n.data&&n.data.commits.length>0&&(0,B.jsxDEV)(`div`,{className:`text-center py-2 text-xs text-muted-foreground`,children:[n.data.commits.length,` commits loaded`]},void 0,!0,{fileName:$,lineNumber:142,columnNumber:15},this)]},void 0,!0,{fileName:$,lineNumber:100,columnNumber:11},this)]},void 0,!0,{fileName:$,lineNumber:87,columnNumber:9},this)},void 0,!1,{fileName:$,lineNumber:86,columnNumber:7},this),n.selectedCommit&&t&&(0,B.jsxDEV)(Y,{commit:n.selectedCommit,files:n.commitFiles,loadingDetail:n.loadingDetail,projectName:t,onClose:()=>n.setSelectedCommit(null),copyHash:n.copyHash},void 0,!1,{fileName:$,lineNumber:151,columnNumber:9},this),(0,B.jsxDEV)(ce,{type:r.type,hash:r.hash,onClose:()=>i({type:null}),onCreateBranch:n.handleCreateBranch,onCreateTag:n.handleCreateTag},void 0,!1,{fileName:$,lineNumber:155,columnNumber:7},this),(0,B.jsxDEV)(le,{open:a,onClose:()=>o(!1),projectName:t,branches:n.data?.branches??[]},void 0,!1,{fileName:$,lineNumber:158,columnNumber:7},this)]},void 0,!0,{fileName:$,lineNumber:74,columnNumber:5},this):(0,B.jsxDEV)(pe,{msg:`No project selected.`},void 0,!1,{fileName:$,lineNumber:69,columnNumber:28},this)}function fe({label:e,colKey:t,onStartResize:n}){return(0,B.jsxDEV)(`th`,{className:`text-left px-2 font-semibold relative`,children:[e,(0,B.jsxDEV)(`div`,{className:`absolute top-0 right-0 w-1.5 h-full cursor-col-resize hover:bg-primary/30`,onMouseDown:e=>{e.preventDefault(),n(t,e.clientX)},onTouchStart:e=>n(t,e.touches[0].clientX)},void 0,!1,{fileName:$,lineNumber:170,columnNumber:7},this)]},void 0,!0,{fileName:$,lineNumber:168,columnNumber:5},this)}function pe({msg:e}){return(0,B.jsxDEV)(`div`,{className:`flex items-center justify-center h-full text-muted-foreground text-sm`,children:e},void 0,!1,{fileName:$,lineNumber:178,columnNumber:10},this)}function me(){return(0,B.jsxDEV)(`div`,{className:`flex items-center justify-center h-full gap-2 text-muted-foreground`,children:[(0,B.jsxDEV)(g,{className:`size-5 animate-spin`},void 0,!1,{fileName:$,lineNumber:183,columnNumber:7},this),(0,B.jsxDEV)(`span`,{className:`text-sm`,children:`Loading git graph...`},void 0,!1,{fileName:$,lineNumber:183,columnNumber:50},this)]},void 0,!0,{fileName:$,lineNumber:182,columnNumber:5},this)}function he({error:e,onRetry:t}){return(0,B.jsxDEV)(`div`,{className:`flex flex-col items-center justify-center h-full gap-2 text-destructive text-sm`,children:[(0,B.jsxDEV)(`p`,{children:e},void 0,!1,{fileName:$,lineNumber:190,columnNumber:7},this),(0,B.jsxDEV)(j,{variant:`outline`,size:`sm`,onClick:t,children:`Retry`},void 0,!1,{fileName:$,lineNumber:190,columnNumber:21},this)]},void 0,!0,{fileName:$,lineNumber:189,columnNumber:5},this)}export{de as GitGraph};