@hienlh/ppm 0.8.37 → 0.8.38

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 (50) hide show
  1. package/CHANGELOG.md +5 -0
  2. package/dist/web/assets/{api-client-Bs-0pRox.js → api-client-B0aMOJxF.js} +1 -1
  3. package/dist/web/assets/{api-settings-D42qxHtn.js → api-settings-0Hx_9lIU.js} +1 -1
  4. package/dist/web/assets/chat-tab-CGic5t8w.js +7 -0
  5. package/dist/web/assets/code-editor-DZlXHMtA.js +1 -0
  6. package/dist/web/assets/columns-2-BZ5wv2wA.js +1 -0
  7. package/dist/web/assets/database-viewer-BaxjPtYR.js +1 -0
  8. package/dist/web/assets/diff-viewer-CDdO3tqP.js +4 -0
  9. package/dist/web/assets/{dist-CU2je4l7.js → dist-QgqOdSYG.js} +2 -2
  10. package/dist/web/assets/git-graph-C-TRbbx7.js +1 -0
  11. package/dist/web/assets/index-CvbNQ1mi.js +28 -0
  12. package/dist/web/assets/input-4ElbicvY.js +41 -0
  13. package/dist/web/assets/jsx-runtime-wQxeESYQ.js +1 -0
  14. package/dist/web/assets/keybindings-store-Dqs-i9cV.js +1 -0
  15. package/dist/web/assets/{markdown-renderer-DmuIK1-X.js → markdown-renderer-DE503g9L.js} +2 -2
  16. package/dist/web/assets/postgres-viewer-hmqfZRr-.js +1 -0
  17. package/dist/web/assets/react-CYzKIDNi.js +1 -0
  18. package/dist/web/assets/{react-Dhei_cB0.js → react-Dk7fkoaB.js} +1 -1
  19. package/dist/web/assets/{settings-store-CIOAyrzs.js → settings-store-Clv3ZNje.js} +2 -2
  20. package/dist/web/assets/settings-tab-BdgsQeES.js +1 -0
  21. package/dist/web/assets/sqlite-viewer-9X_1ZHJE.js +1 -0
  22. package/dist/web/assets/tab-store-D7tRt0VT.js +1 -0
  23. package/dist/web/assets/table-B6neW6Hr.js +1 -0
  24. package/dist/web/assets/{terminal-tab-ZMG3urJd.js → terminal-tab-V7x81Qpr.js} +2 -2
  25. package/dist/web/assets/{use-monaco-theme-D6807XbV.js → use-monaco-theme-czriskTO.js} +1 -1
  26. package/dist/web/index.html +10 -11
  27. package/dist/web/sw.js +1 -1
  28. package/package.json +1 -1
  29. package/src/cli/commands/restart.ts +5 -1
  30. package/src/server/index.ts +9 -16
  31. package/src/server/routes/tunnel.ts +0 -14
  32. package/src/services/tunnel.service.ts +22 -0
  33. package/dist/web/assets/chat-tab-DesJNGlM.js +0 -7
  34. package/dist/web/assets/code-editor-BJSi0tN8.js +0 -1
  35. package/dist/web/assets/columns-2-BSNHGqVP.js +0 -1
  36. package/dist/web/assets/database-viewer-BRtti__1.js +0 -1
  37. package/dist/web/assets/diff-viewer-BtqxNPvT.js +0 -4
  38. package/dist/web/assets/git-graph-BwaH1gCr.js +0 -1
  39. package/dist/web/assets/index-cCRyobYW.js +0 -237
  40. package/dist/web/assets/input-D3FZB4A8.js +0 -45
  41. package/dist/web/assets/jsx-dev-runtime-B0R0R7SH.js +0 -6
  42. package/dist/web/assets/jsx-runtime-CdTrtNt5.js +0 -6
  43. package/dist/web/assets/keybindings-store-EctjzvyI.js +0 -1
  44. package/dist/web/assets/postgres-viewer-BToBpDFs.js +0 -1
  45. package/dist/web/assets/react-4j_0SqET.js +0 -13
  46. package/dist/web/assets/settings-tab-CIM3X82k.js +0 -1
  47. package/dist/web/assets/sqlite-viewer-CSsYLA1Q.js +0 -1
  48. package/dist/web/assets/tab-store-HCmwXLYA.js +0 -1
  49. package/dist/web/assets/table-CSrbr8mU.js +0 -1
  50. /package/dist/web/assets/{utils-DC-bdPS3.js → utils-DBpa1UZX.js} +0 -0
package/dist/web/sw.js CHANGED
@@ -1 +1 @@
1
- try{self[`workbox:core:7.3.0`]&&_()}catch{}var e={"invalid-value":({paramName:e,validValueDescription:t,value:n})=>{if(!e||!t)throw Error(`Unexpected input to 'invalid-value' error.`);return`The '${e}' parameter was given a value with an unexpected value. ${t} Received a value of ${JSON.stringify(n)}.`},"not-an-array":({moduleName:e,className:t,funcName:n,paramName:r})=>{if(!e||!t||!n||!r)throw Error(`Unexpected input to 'not-an-array' error.`);return`The parameter '${r}' passed into '${e}.${t}.${n}()' must be an array.`},"incorrect-type":({expectedType:e,paramName:t,moduleName:n,className:r,funcName:i})=>{if(!e||!t||!n||!i)throw Error(`Unexpected input to 'incorrect-type' error.`);return`The parameter '${t}' passed into '${n}.${r?`${r}.`:``}${i}()' must be of type ${e}.`},"incorrect-class":({expectedClassName:e,paramName:t,moduleName:n,className:r,funcName:i,isReturnValueProblem:a})=>{if(!e||!n||!i)throw Error(`Unexpected input to 'incorrect-class' error.`);let o=r?`${r}.`:``;return a?`The return value from '${n}.${o}${i}()' must be an instance of class ${e}.`:`The parameter '${t}' passed into '${n}.${o}${i}()' must be an instance of class ${e}.`},"missing-a-method":({expectedMethod:e,paramName:t,moduleName:n,className:r,funcName:i})=>{if(!e||!t||!n||!r||!i)throw Error(`Unexpected input to 'missing-a-method' error.`);return`${n}.${r}.${i}() expected the '${t}' parameter to expose a '${e}' method.`},"add-to-cache-list-unexpected-type":({entry:e})=>`An unexpected entry was passed to 'workbox-precaching.PrecacheController.addToCacheList()' The entry '${JSON.stringify(e)}' isn't supported. You must supply an array of strings with one or more characters, objects with a url property or Request objects.`,"add-to-cache-list-conflicting-entries":({firstEntry:e,secondEntry:t})=>{if(!e||!t)throw Error(`Unexpected input to 'add-to-cache-list-duplicate-entries' error.`);return`Two of the entries passed to 'workbox-precaching.PrecacheController.addToCacheList()' had the URL ${e} but different revision details. Workbox is unable to cache and version the asset correctly. Please remove one of the entries.`},"plugin-error-request-will-fetch":({thrownErrorMessage:e})=>{if(!e)throw Error(`Unexpected input to 'plugin-error-request-will-fetch', error.`);return`An error was thrown by a plugins 'requestWillFetch()' method. The thrown error message was: '${e}'.`},"invalid-cache-name":({cacheNameId:e,value:t})=>{if(!e)throw Error(`Expected a 'cacheNameId' for error 'invalid-cache-name'`);return`You must provide a name containing at least one character for setCacheDetails({${e}: '...'}). Received a value of '${JSON.stringify(t)}'`},"unregister-route-but-not-found-with-method":({method:e})=>{if(!e)throw Error(`Unexpected input to 'unregister-route-but-not-found-with-method' error.`);return`The route you're trying to unregister was not previously registered for the method type '${e}'.`},"unregister-route-route-not-registered":()=>`The route you're trying to unregister was not previously registered.`,"queue-replay-failed":({name:e})=>`Replaying the background sync queue '${e}' failed.`,"duplicate-queue-name":({name:e})=>`The Queue name '${e}' is already being used. All instances of backgroundSync.Queue must be given unique names.`,"expired-test-without-max-age":({methodName:e,paramName:t})=>`The '${e}()' method can only be used when the '${t}' is used in the constructor.`,"unsupported-route-type":({moduleName:e,className:t,funcName:n,paramName:r})=>`The supplied '${r}' parameter was an unsupported type. Please check the docs for ${e}.${t}.${n} for valid input types.`,"not-array-of-class":({value:e,expectedClass:t,moduleName:n,className:r,funcName:i,paramName:a})=>`The supplied '${a}' parameter must be an array of '${t}' objects. Received '${JSON.stringify(e)},'. Please check the call to ${n}.${r}.${i}() to fix the issue.`,"max-entries-or-age-required":({moduleName:e,className:t,funcName:n})=>`You must define either config.maxEntries or config.maxAgeSecondsin ${e}.${t}.${n}`,"statuses-or-headers-required":({moduleName:e,className:t,funcName:n})=>`You must define either config.statuses or config.headersin ${e}.${t}.${n}`,"invalid-string":({moduleName:e,funcName:t,paramName:n})=>{if(!n||!e||!t)throw Error(`Unexpected input to 'invalid-string' error.`);return`When using strings, the '${n}' parameter must start with 'http' (for cross-origin matches) or '/' (for same-origin matches). Please see the docs for ${e}.${t}() for more info.`},"channel-name-required":()=>`You must provide a channelName to construct a BroadcastCacheUpdate instance.`,"invalid-responses-are-same-args":()=>`The arguments passed into responsesAreSame() appear to be invalid. Please ensure valid Responses are used.`,"expire-custom-caches-only":()=>`You must provide a 'cacheName' property when using the expiration plugin with a runtime caching strategy.`,"unit-must-be-bytes":({normalizedRangeHeader:e})=>{if(!e)throw Error(`Unexpected input to 'unit-must-be-bytes' error.`);return`The 'unit' portion of the Range header must be set to 'bytes'. The Range header provided was "${e}"`},"single-range-only":({normalizedRangeHeader:e})=>{if(!e)throw Error(`Unexpected input to 'single-range-only' error.`);return`Multiple ranges are not supported. Please use a single start value, and optional end value. The Range header provided was "${e}"`},"invalid-range-values":({normalizedRangeHeader:e})=>{if(!e)throw Error(`Unexpected input to 'invalid-range-values' error.`);return`The Range header is missing both start and end values. At least one of those values is needed. The Range header provided was "${e}"`},"no-range-header":()=>`No Range header was found in the Request provided.`,"range-not-satisfiable":({size:e,start:t,end:n})=>`The start (${t}) and end (${n}) values in the Range are not satisfiable by the cached response, which is ${e} bytes.`,"attempt-to-cache-non-get-request":({url:e,method:t})=>`Unable to cache '${e}' because it is a '${t}' request and only 'GET' requests can be cached.`,"cache-put-with-no-response":({url:e})=>`There was an attempt to cache '${e}' but the response was not defined.`,"no-response":({url:e,error:t})=>{let n=`The strategy could not generate a response for '${e}'.`;return t&&(n+=` The underlying error is ${t}.`),n},"bad-precaching-response":({url:e,status:t})=>`The precaching request for '${e}' failed`+(t?` with an HTTP status of ${t}.`:`.`),"non-precached-url":({url:e})=>`createHandlerBoundToURL('${e}') was called, but that URL is not precached. Please pass in a URL that is precached instead.`,"add-to-cache-list-conflicting-integrities":({url:e})=>`Two of the entries passed to 'workbox-precaching.PrecacheController.addToCacheList()' had the URL ${e} with different integrity values. Please remove one of them.`,"missing-precache-entry":({cacheName:e,url:t})=>`Unable to find a precached response in ${e} for ${t}.`,"cross-origin-copy-response":({origin:e})=>`workbox-core.copyResponse() can only be used with same-origin responses. It was passed a response with origin ${e}.`,"opaque-streams-source":({type:e})=>{let t=`One of the workbox-streams sources resulted in an '${e}' response.`;return e===`opaqueredirect`?`${t} Please do not use a navigation request that results in a redirect as a source.`:`${t} Please ensure your sources are CORS-enabled.`}},t=(t,n={})=>{let r=e[t];if(!r)throw Error(`Unable to find message for code '${t}'.`);return r(n)},n=class extends Error{constructor(e,n){let r=t(e,n);super(r),this.name=e,this.details=n}},r={hasMethod:(e,t,r)=>{if(typeof e[t]!=`function`)throw r.expectedMethod=t,new n(`missing-a-method`,r)},isArray:(e,t)=>{if(!Array.isArray(e))throw new n(`not-an-array`,t)},isInstance:(e,t,r)=>{if(!(e instanceof t))throw r.expectedClassName=t.name,new n(`incorrect-class`,r)},isOneOf:(e,t,r)=>{if(!t.includes(e))throw r.validValueDescription=`Valid values are ${JSON.stringify(t)}.`,new n(`invalid-value`,r)},isType:(e,t,r)=>{if(typeof e!==t)throw r.expectedType=t,new n(`incorrect-type`,r)},isArrayOfClass:(e,t,r)=>{let i=new n(`not-array-of-class`,r);if(!Array.isArray(e))throw i;for(let n of e)if(!(n instanceof t))throw i}},i={googleAnalytics:`googleAnalytics`,precache:`precache-v2`,prefix:`workbox`,runtime:`runtime`,suffix:typeof registration<`u`?registration.scope:``},a=e=>[i.prefix,e,i.suffix].filter(e=>e&&e.length>0).join(`-`),o=e=>{for(let t of Object.keys(i))e(t)},s={updateDetails:e=>{o(t=>{typeof e[t]==`string`&&(i[t]=e[t])})},getGoogleAnalyticsName:e=>e||a(i.googleAnalytics),getPrecacheName:e=>e||a(i.precache),getPrefix:()=>i.prefix,getRuntimeName:e=>e||a(i.runtime),getSuffix:()=>i.suffix},c=(()=>{`__WB_DISABLE_DEV_LOGS`in globalThis||(self.__WB_DISABLE_DEV_LOGS=!1);let e=!1,t={debug:`#7f8c8d`,log:`#2ecc71`,warn:`#f39c12`,error:`#c0392b`,groupCollapsed:`#3498db`,groupEnd:null},n=function(n,r){if(self.__WB_DISABLE_DEV_LOGS)return;if(n===`groupCollapsed`&&/^((?!chrome|android).)*safari/i.test(navigator.userAgent)){console[n](...r);return}let i=[`background: ${t[n]}`,`border-radius: 0.5em`,`color: white`,`font-weight: bold`,`padding: 2px 0.5em`],a=e?[]:[`%cworkbox`,i.join(`;`)];console[n](...a,...r),n===`groupCollapsed`&&(e=!0),n===`groupEnd`&&(e=!1)},r={},i=Object.keys(t);for(let e of i){let t=e;r[t]=(...e)=>{n(t,e)}}return r})();function l(e,t){let n=t();return e.waitUntil(n),n}try{self[`workbox:precaching:7.3.0`]&&_()}catch{}var u=`__WB_REVISION__`;function d(e){if(!e)throw new n(`add-to-cache-list-unexpected-type`,{entry:e});if(typeof e==`string`){let t=new URL(e,location.href);return{cacheKey:t.href,url:t.href}}let{revision:t,url:r}=e;if(!r)throw new n(`add-to-cache-list-unexpected-type`,{entry:e});if(!t){let e=new URL(r,location.href);return{cacheKey:e.href,url:e.href}}let i=new URL(r,location.href),a=new URL(r,location.href);return i.searchParams.set(u,t),{cacheKey:i.href,url:a.href}}var f=class{constructor(){this.updatedURLs=[],this.notUpdatedURLs=[],this.handlerWillStart=async({request:e,state:t})=>{t&&(t.originalRequest=e)},this.cachedResponseWillBeUsed=async({event:e,state:t,cachedResponse:n})=>{if(e.type===`install`&&t&&t.originalRequest&&t.originalRequest instanceof Request){let e=t.originalRequest.url;n?this.notUpdatedURLs.push(e):this.updatedURLs.push(e)}return n}}},p=class{constructor({precacheController:e}){this.cacheKeyWillBeUsed=async({request:e,params:t})=>{let n=t?.cacheKey||this._precacheController.getCacheKeyForURL(e.url);return n?new Request(n,{headers:e.headers}):e},this._precacheController=e}},m=(e,t)=>{c.groupCollapsed(e);for(let e of t)c.log(e);c.groupEnd()};function h(e){let t=e.length;t>0&&(c.groupCollapsed(`During precaching cleanup, ${t} cached request${t===1?` was`:`s were`} deleted.`),m(`Deleted Cache Requests`,e),c.groupEnd())}function g(e,t){if(t.length!==0){c.groupCollapsed(e);for(let e of t)c.log(e);c.groupEnd()}}function v(e,t){let n=e.length,r=t.length;if(n||r){let i=`Precaching ${n} file${n===1?``:`s`}.`;r>0&&(i+=` ${r} file${r===1?` is`:`s are`} already cached.`),c.groupCollapsed(i),g(`View newly precached URLs.`,e),g(`View previously precached URLs.`,t),c.groupEnd()}}var y;function b(){if(y===void 0){let e=new Response(``);if(`body`in e)try{new Response(e.body),y=!0}catch{y=!1}y=!1}return y}async function x(e,t){let r=null;if(e.url&&(r=new URL(e.url).origin),r!==self.location.origin)throw new n(`cross-origin-copy-response`,{origin:r});let i=e.clone(),a={headers:new Headers(i.headers),status:i.status,statusText:i.statusText},o=t?t(a):a,s=b()?i.body:await i.blob();return new Response(s,o)}var S=e=>new URL(String(e),location.href).href.replace(RegExp(`^${location.origin}`),``);function C(e,t){let n=new URL(e);for(let e of t)n.searchParams.delete(e);return n.href}async function w(e,t,n,r){let i=C(t.url,n);if(t.url===i)return e.match(t,r);let a=Object.assign(Object.assign({},r),{ignoreSearch:!0}),o=await e.keys(t,a);for(let t of o)if(i===C(t.url,n))return e.match(t,r)}var T=class{constructor(){this.promise=new Promise((e,t)=>{this.resolve=e,this.reject=t})}},E=new Set;async function D(){c.log(`About to run ${E.size} callbacks to clean up caches.`);for(let e of E)await e(),c.log(e,`is complete.`);c.log(`Finished running callbacks.`)}function O(e){return new Promise(t=>setTimeout(t,e))}try{self[`workbox:strategies:7.3.0`]&&_()}catch{}function k(e){return typeof e==`string`?new Request(e):e}var A=class{constructor(e,t){this._cacheKeys={},r.isInstance(t.event,ExtendableEvent,{moduleName:`workbox-strategies`,className:`StrategyHandler`,funcName:`constructor`,paramName:`options.event`}),Object.assign(this,t),this.event=t.event,this._strategy=e,this._handlerDeferred=new T,this._extendLifetimePromises=[],this._plugins=[...e.plugins],this._pluginStateMap=new Map;for(let e of this._plugins)this._pluginStateMap.set(e,{});this.event.waitUntil(this._handlerDeferred.promise)}async fetch(e){let{event:t}=this,r=k(e);if(r.mode===`navigate`&&t instanceof FetchEvent&&t.preloadResponse){let e=await t.preloadResponse;if(e)return c.log(`Using a preloaded navigation response for '${S(r.url)}'`),e}let i=this.hasCallback(`fetchDidFail`)?r.clone():null;try{for(let e of this.iterateCallbacks(`requestWillFetch`))r=await e({request:r.clone(),event:t})}catch(e){if(e instanceof Error)throw new n(`plugin-error-request-will-fetch`,{thrownErrorMessage:e.message})}let a=r.clone();try{let e;e=await fetch(r,r.mode===`navigate`?void 0:this._strategy.fetchOptions),c.debug(`Network request for '${S(r.url)}' returned a response with status '${e.status}'.`);for(let n of this.iterateCallbacks(`fetchDidSucceed`))e=await n({event:t,request:a,response:e});return e}catch(e){throw c.log(`Network request for '${S(r.url)}' threw an error.`,e),i&&await this.runCallbacks(`fetchDidFail`,{error:e,event:t,originalRequest:i.clone(),request:a.clone()}),e}}async fetchAndCachePut(e){let t=await this.fetch(e),n=t.clone();return this.waitUntil(this.cachePut(e,n)),t}async cacheMatch(e){let t=k(e),n,{cacheName:r,matchOptions:i}=this._strategy,a=await this.getCacheKey(t,`read`),o=Object.assign(Object.assign({},i),{cacheName:r});n=await caches.match(a,o),n?c.debug(`Found a cached response in '${r}'.`):c.debug(`No cached response found in '${r}'.`);for(let e of this.iterateCallbacks(`cachedResponseWillBeUsed`))n=await e({cacheName:r,matchOptions:i,cachedResponse:n,request:a,event:this.event})||void 0;return n}async cachePut(e,t){let r=k(e);await O(0);let i=await this.getCacheKey(r,`write`);{if(i.method&&i.method!==`GET`)throw new n(`attempt-to-cache-non-get-request`,{url:S(i.url),method:i.method});let e=t.headers.get(`Vary`);e&&c.debug(`The response for ${S(i.url)} has a 'Vary: ${e}' header. Consider setting the {ignoreVary: true} option on your strategy to ensure cache matching and deletion works as expected.`)}if(!t)throw c.error(`Cannot cache non-existent response for '${S(i.url)}'.`),new n(`cache-put-with-no-response`,{url:S(i.url)});let a=await this._ensureResponseSafeToCache(t);if(!a)return c.debug(`Response '${S(i.url)}' will not be cached.`,a),!1;let{cacheName:o,matchOptions:s}=this._strategy,l=await self.caches.open(o),u=this.hasCallback(`cacheDidUpdate`),d=u?await w(l,i.clone(),[`__WB_REVISION__`],s):null;c.debug(`Updating the '${o}' cache with a new Response for ${S(i.url)}.`);try{await l.put(i,u?a.clone():a)}catch(e){if(e instanceof Error)throw e.name===`QuotaExceededError`&&await D(),e}for(let e of this.iterateCallbacks(`cacheDidUpdate`))await e({cacheName:o,oldResponse:d,newResponse:a.clone(),request:i,event:this.event});return!0}async getCacheKey(e,t){let n=`${e.url} | ${t}`;if(!this._cacheKeys[n]){let r=e;for(let e of this.iterateCallbacks(`cacheKeyWillBeUsed`))r=k(await e({mode:t,request:r,event:this.event,params:this.params}));this._cacheKeys[n]=r}return this._cacheKeys[n]}hasCallback(e){for(let t of this._strategy.plugins)if(e in t)return!0;return!1}async runCallbacks(e,t){for(let n of this.iterateCallbacks(e))await n(t)}*iterateCallbacks(e){for(let t of this._strategy.plugins)if(typeof t[e]==`function`){let n=this._pluginStateMap.get(t);yield r=>{let i=Object.assign(Object.assign({},r),{state:n});return t[e](i)}}}waitUntil(e){return this._extendLifetimePromises.push(e),e}async doneWaiting(){for(;this._extendLifetimePromises.length;){let e=this._extendLifetimePromises.splice(0),t=(await Promise.allSettled(e)).find(e=>e.status===`rejected`);if(t)throw t.reason}}destroy(){this._handlerDeferred.resolve(null)}async _ensureResponseSafeToCache(e){let t=e,n=!1;for(let e of this.iterateCallbacks(`cacheWillUpdate`))if(t=await e({request:this.request,response:t,event:this.event})||void 0,n=!0,!t)break;return n||(t&&t.status!==200&&(t=void 0),t&&t.status!==200&&(t.status===0?c.warn(`The response for '${this.request.url}' is an opaque response. The caching strategy that you're using will not cache opaque responses by default.`):c.debug(`The response for '${this.request.url}' returned a status code of '${e.status}' and won't be cached as a result.`))),t}},j=class{constructor(e={}){this.cacheName=s.getRuntimeName(e.cacheName),this.plugins=e.plugins||[],this.fetchOptions=e.fetchOptions,this.matchOptions=e.matchOptions}handle(e){let[t]=this.handleAll(e);return t}handleAll(e){e instanceof FetchEvent&&(e={event:e,request:e.request});let t=e.event,n=typeof e.request==`string`?new Request(e.request):e.request,r=`params`in e?e.params:void 0,i=new A(this,{event:t,request:n,params:r}),a=this._getResponse(i,n,t);return[a,this._awaitComplete(a,i,n,t)]}async _getResponse(e,t,r){await e.runCallbacks(`handlerWillStart`,{event:r,request:t});let i;try{if(i=await this._handle(t,e),!i||i.type===`error`)throw new n(`no-response`,{url:t.url})}catch(n){if(n instanceof Error){for(let a of e.iterateCallbacks(`handlerDidError`))if(i=await a({error:n,event:r,request:t}),i)break}if(i)c.log(`While responding to '${S(t.url)}', an ${n instanceof Error?n.toString():``} error occurred. Using a fallback response provided by a handlerDidError plugin.`);else throw n}for(let n of e.iterateCallbacks(`handlerWillRespond`))i=await n({event:r,request:t,response:i});return i}async _awaitComplete(e,t,n,r){let i,a;try{i=await e}catch{}try{await t.runCallbacks(`handlerDidRespond`,{event:r,request:n,response:i}),await t.doneWaiting()}catch(e){e instanceof Error&&(a=e)}if(await t.runCallbacks(`handlerDidComplete`,{event:r,request:n,response:i,error:a}),t.destroy(),a)throw a}},M=class e extends j{constructor(t={}){t.cacheName=s.getPrecacheName(t.cacheName),super(t),this._fallbackToNetwork=t.fallbackToNetwork!==!1,this.plugins.push(e.copyRedirectedCacheableResponsesPlugin)}async _handle(e,t){return await t.cacheMatch(e)||(t.event&&t.event.type===`install`?await this._handleInstall(e,t):await this._handleFetch(e,t))}async _handleFetch(e,t){let r,i=t.params||{};if(this._fallbackToNetwork){c.warn(`The precached response for ${S(e.url)} in ${this.cacheName} was not found. Falling back to the network.`);let n=i.integrity,a=e.integrity,o=!a||a===n;r=await t.fetch(new Request(e,{integrity:e.mode===`no-cors`?void 0:a||n})),n&&o&&e.mode!==`no-cors`&&(this._useDefaultCacheabilityPluginIfNeeded(),await t.cachePut(e,r.clone())&&c.log(`A response for ${S(e.url)} was used to "repair" the precache.`))}else throw new n(`missing-precache-entry`,{cacheName:this.cacheName,url:e.url});{let n=i.cacheKey||await t.getCacheKey(e,`read`);c.groupCollapsed(`Precaching is responding to: `+S(e.url)),c.log(`Serving the precached url: ${S(n instanceof Request?n.url:n)}`),c.groupCollapsed(`View request details here.`),c.log(e),c.groupEnd(),c.groupCollapsed(`View response details here.`),c.log(r),c.groupEnd(),c.groupEnd()}return r}async _handleInstall(e,t){this._useDefaultCacheabilityPluginIfNeeded();let r=await t.fetch(e);if(!await t.cachePut(e,r.clone()))throw new n(`bad-precaching-response`,{url:e.url,status:r.status});return r}_useDefaultCacheabilityPluginIfNeeded(){let t=null,n=0;for(let[r,i]of this.plugins.entries())i!==e.copyRedirectedCacheableResponsesPlugin&&(i===e.defaultPrecacheCacheabilityPlugin&&(t=r),i.cacheWillUpdate&&n++);n===0?this.plugins.push(e.defaultPrecacheCacheabilityPlugin):n>1&&t!==null&&this.plugins.splice(t,1)}};M.defaultPrecacheCacheabilityPlugin={async cacheWillUpdate({response:e}){return!e||e.status>=400?null:e}},M.copyRedirectedCacheableResponsesPlugin={async cacheWillUpdate({response:e}){return e.redirected?await x(e):e}};var N=class{constructor({cacheName:e,plugins:t=[],fallbackToNetwork:n=!0}={}){this._urlsToCacheKeys=new Map,this._urlsToCacheModes=new Map,this._cacheKeysToIntegrities=new Map,this._strategy=new M({cacheName:s.getPrecacheName(e),plugins:[...t,new p({precacheController:this})],fallbackToNetwork:n}),this.install=this.install.bind(this),this.activate=this.activate.bind(this)}get strategy(){return this._strategy}precache(e){this.addToCacheList(e),this._installAndActiveListenersAdded||=(self.addEventListener(`install`,this.install),self.addEventListener(`activate`,this.activate),!0)}addToCacheList(e){r.isArray(e,{moduleName:`workbox-precaching`,className:`PrecacheController`,funcName:`addToCacheList`,paramName:`entries`});let t=[];for(let r of e){typeof r==`string`?t.push(r):r&&r.revision===void 0&&t.push(r.url);let{cacheKey:e,url:i}=d(r),a=typeof r!=`string`&&r.revision?`reload`:`default`;if(this._urlsToCacheKeys.has(i)&&this._urlsToCacheKeys.get(i)!==e)throw new n(`add-to-cache-list-conflicting-entries`,{firstEntry:this._urlsToCacheKeys.get(i),secondEntry:e});if(typeof r!=`string`&&r.integrity){if(this._cacheKeysToIntegrities.has(e)&&this._cacheKeysToIntegrities.get(e)!==r.integrity)throw new n(`add-to-cache-list-conflicting-integrities`,{url:i});this._cacheKeysToIntegrities.set(e,r.integrity)}if(this._urlsToCacheKeys.set(i,e),this._urlsToCacheModes.set(i,a),t.length>0){let e=`Workbox is precaching URLs without revision info: ${t.join(`, `)}\nThis is generally NOT safe. Learn more at https://bit.ly/wb-precache`;c.warn(e)}}}install(e){return l(e,async()=>{let t=new f;this.strategy.plugins.push(t);for(let[t,n]of this._urlsToCacheKeys){let r=this._cacheKeysToIntegrities.get(n),i=this._urlsToCacheModes.get(t),a=new Request(t,{integrity:r,cache:i,credentials:`same-origin`});await Promise.all(this.strategy.handleAll({params:{cacheKey:n},request:a,event:e}))}let{updatedURLs:n,notUpdatedURLs:r}=t;return v(n,r),{updatedURLs:n,notUpdatedURLs:r}})}activate(e){return l(e,async()=>{let e=await self.caches.open(this.strategy.cacheName),t=await e.keys(),n=new Set(this._urlsToCacheKeys.values()),r=[];for(let i of t)n.has(i.url)||(await e.delete(i),r.push(i.url));return h(r),{deletedURLs:r}})}getURLsToCacheKeys(){return this._urlsToCacheKeys}getCachedURLs(){return[...this._urlsToCacheKeys.keys()]}getCacheKeyForURL(e){let t=new URL(e,location.href);return this._urlsToCacheKeys.get(t.href)}getIntegrityForCacheKey(e){return this._cacheKeysToIntegrities.get(e)}async matchPrecache(e){let t=e instanceof Request?e.url:e,n=this.getCacheKeyForURL(t);if(n)return(await self.caches.open(this.strategy.cacheName)).match(n)}createHandlerBoundToURL(e){let t=this.getCacheKeyForURL(e);if(!t)throw new n(`non-precached-url`,{url:e});return n=>(n.request=new Request(e),n.params=Object.assign({cacheKey:t},n.params),this.strategy.handle(n))}},P,F=()=>(P||=new N,P);try{self[`workbox:routing:7.3.0`]&&_()}catch{}var I=[`DELETE`,`GET`,`HEAD`,`PATCH`,`POST`,`PUT`],L=e=>e&&typeof e==`object`?(r.hasMethod(e,`handle`,{moduleName:`workbox-routing`,className:`Route`,funcName:`constructor`,paramName:`handler`}),e):(r.isType(e,`function`,{moduleName:`workbox-routing`,className:`Route`,funcName:`constructor`,paramName:`handler`}),{handle:e}),R=class{constructor(e,t,n=`GET`){r.isType(e,`function`,{moduleName:`workbox-routing`,className:`Route`,funcName:`constructor`,paramName:`match`}),n&&r.isOneOf(n,I,{paramName:`method`}),this.handler=L(t),this.match=e,this.method=n}setCatchHandler(e){this.catchHandler=L(e)}},z=class extends R{constructor(e,t,n){r.isInstance(e,RegExp,{moduleName:`workbox-routing`,className:`RegExpRoute`,funcName:`constructor`,paramName:`pattern`}),super(({url:t})=>{let n=e.exec(t.href);if(n){if(t.origin!==location.origin&&n.index!==0){c.debug(`The regular expression '${e.toString()}' only partially matched against the cross-origin URL '${t.toString()}'. RegExpRoute's will only handle cross-origin requests if they match the entire URL.`);return}return n.slice(1)}},t,n)}},B=class{constructor(){this._routes=new Map,this._defaultHandlerMap=new Map}get routes(){return this._routes}addFetchListener(){self.addEventListener(`fetch`,(e=>{let{request:t}=e,n=this.handleRequest({request:t,event:e});n&&e.respondWith(n)}))}addCacheListener(){self.addEventListener(`message`,(e=>{if(e.data&&e.data.type===`CACHE_URLS`){let{payload:t}=e.data;c.debug(`Caching URLs from the window`,t.urlsToCache);let n=Promise.all(t.urlsToCache.map(t=>{typeof t==`string`&&(t=[t]);let n=new Request(...t);return this.handleRequest({request:n,event:e})}));e.waitUntil(n),e.ports&&e.ports[0]&&n.then(()=>e.ports[0].postMessage(!0))}}))}handleRequest({request:e,event:t}){r.isInstance(e,Request,{moduleName:`workbox-routing`,className:`Router`,funcName:`handleRequest`,paramName:`options.request`});let n=new URL(e.url,location.href);if(!n.protocol.startsWith(`http`)){c.debug(`Workbox Router only supports URLs that start with 'http'.`);return}let i=n.origin===location.origin,{params:a,route:o}=this.findMatchingRoute({event:t,request:e,sameOrigin:i,url:n}),s=o&&o.handler,l=[];s&&(l.push([`Found a route to handle this request:`,o]),a&&l.push([`Passing the following params to the route's handler:`,a]));let u=e.method;if(!s&&this._defaultHandlerMap.has(u)&&(l.push(`Failed to find a matching route. Falling back to the default handler for ${u}.`),s=this._defaultHandlerMap.get(u)),!s){c.debug(`No route found for: ${S(n)}`);return}c.groupCollapsed(`Router is responding to: ${S(n)}`),l.forEach(e=>{Array.isArray(e)?c.log(...e):c.log(e)}),c.groupEnd();let d;try{d=s.handle({url:n,request:e,event:t,params:a})}catch(e){d=Promise.reject(e)}let f=o&&o.catchHandler;return d instanceof Promise&&(this._catchHandler||f)&&(d=d.catch(async r=>{if(f){c.groupCollapsed(`Error thrown when responding to: ${S(n)}. Falling back to route's Catch Handler.`),c.error(`Error thrown by:`,o),c.error(r),c.groupEnd();try{return await f.handle({url:n,request:e,event:t,params:a})}catch(e){e instanceof Error&&(r=e)}}if(this._catchHandler)return c.groupCollapsed(`Error thrown when responding to: ${S(n)}. Falling back to global Catch Handler.`),c.error(`Error thrown by:`,o),c.error(r),c.groupEnd(),this._catchHandler.handle({url:n,request:e,event:t});throw r})),d}findMatchingRoute({url:e,sameOrigin:t,request:n,event:r}){let i=this._routes.get(n.method)||[];for(let a of i){let i,o=a.match({url:e,sameOrigin:t,request:n,event:r});if(o)return o instanceof Promise&&c.warn(`While routing ${S(e)}, an async matchCallback function was used. Please convert the following route to use a synchronous matchCallback function:`,a),i=o,(Array.isArray(i)&&i.length===0||o.constructor===Object&&Object.keys(o).length===0||typeof o==`boolean`)&&(i=void 0),{route:a,params:i}}return{}}setDefaultHandler(e,t=`GET`){this._defaultHandlerMap.set(t,L(e))}setCatchHandler(e){this._catchHandler=L(e)}registerRoute(e){r.isType(e,`object`,{moduleName:`workbox-routing`,className:`Router`,funcName:`registerRoute`,paramName:`route`}),r.hasMethod(e,`match`,{moduleName:`workbox-routing`,className:`Router`,funcName:`registerRoute`,paramName:`route`}),r.isType(e.handler,`object`,{moduleName:`workbox-routing`,className:`Router`,funcName:`registerRoute`,paramName:`route`}),r.hasMethod(e.handler,`handle`,{moduleName:`workbox-routing`,className:`Router`,funcName:`registerRoute`,paramName:`route.handler`}),r.isType(e.method,`string`,{moduleName:`workbox-routing`,className:`Router`,funcName:`registerRoute`,paramName:`route.method`}),this._routes.has(e.method)||this._routes.set(e.method,[]),this._routes.get(e.method).push(e)}unregisterRoute(e){if(!this._routes.has(e.method))throw new n(`unregister-route-but-not-found-with-method`,{method:e.method});let t=this._routes.get(e.method).indexOf(e);if(t>-1)this._routes.get(e.method).splice(t,1);else throw new n(`unregister-route-route-not-registered`)}},V,H=()=>(V||(V=new B,V.addFetchListener(),V.addCacheListener()),V);function U(e,t,r){let i;if(typeof e==`string`){let a=new URL(e,location.href);{if(!(e.startsWith(`/`)||e.startsWith(`http`)))throw new n(`invalid-string`,{moduleName:`workbox-routing`,funcName:`registerRoute`,paramName:`capture`});let t=e.startsWith(`http`)?a.pathname:e,r=`[*:?+]`;RegExp(`${r}`).exec(t)&&c.debug(`The '$capture' parameter contains an Express-style wildcard character (${r}). Strings are now always interpreted as exact matches; use a RegExp for partial or wildcard matches.`)}i=new R(({url:t})=>(t.pathname===a.pathname&&t.origin!==a.origin&&c.debug(`${e} only partially matches the cross-origin URL ${t.toString()}. This route will only handle cross-origin requests if they match the entire URL.`),t.href===a.href),t,r)}else if(e instanceof RegExp)i=new z(e,t,r);else if(typeof e==`function`)i=new R(e,t,r);else if(e instanceof R)i=e;else throw new n(`unsupported-route-type`,{moduleName:`workbox-routing`,funcName:`registerRoute`,paramName:`capture`});return H().registerRoute(i),i}function W(e,t=[]){for(let n of[...e.searchParams.keys()])t.some(e=>e.test(n))&&e.searchParams.delete(n);return e}function*G(e,{ignoreURLParametersMatching:t=[/^utm_/,/^fbclid$/],directoryIndex:n=`index.html`,cleanURLs:r=!0,urlManipulation:i}={}){let a=new URL(e,location.href);a.hash=``,yield a.href;let o=W(a,t);if(yield o.href,n&&o.pathname.endsWith(`/`)){let e=new URL(o.href);e.pathname+=n,yield e.href}if(r){let e=new URL(o.href);e.pathname+=`.html`,yield e.href}if(i){let e=i({url:a});for(let t of e)yield t.href}}var K=class extends R{constructor(e,t){super(({request:n})=>{let r=e.getURLsToCacheKeys();for(let i of G(n.url,t)){let t=r.get(i);if(t)return{cacheKey:t,integrity:e.getIntegrityForCacheKey(t)}}c.debug(`Precaching did not find a match for `+S(n.url))},e.strategy)}};function q(e){U(new K(F(),e))}function J(e){F().precache(e)}function Y(e,t){J(e),q(t)}Y([{"revision":"1872c500de691dce40960bb85481de07","url":"registerSW.js"},{"revision":"f727c20fe5ff32da07c4d9ab1610f527","url":"index.html"},{"revision":"a0fb34fc84eb148d51812cd62669f20d","url":"icon-512.svg"},{"revision":"a0fb34fc84eb148d51812cd62669f20d","url":"icon-192.svg"},{"revision":"eb9818b9094675c0c5d303168f273345","url":"monacoeditorwork/ts.worker.bundle.js"},{"revision":"9af0be92dcefdc1f1290441cb5ff5d9b","url":"monacoeditorwork/json.worker.bundle.js"},{"revision":"a261b429c39dbb75ae97972d7d005e6d","url":"monacoeditorwork/html.worker.bundle.js"},{"revision":"79953d804e1bbacecfd79b85fd679016","url":"monacoeditorwork/editor.worker.bundle.js"},{"revision":"fdcba0d09aac31df7a0bc652f6e739bd","url":"monacoeditorwork/css.worker.bundle.js"},{"revision":null,"url":"assets/utils-DC-bdPS3.js"},{"revision":null,"url":"assets/use-monaco-theme-D6807XbV.js"},{"revision":null,"url":"assets/terminal-tab-ZMG3urJd.js"},{"revision":null,"url":"assets/terminal-tab-BrP-ENHg.css"},{"revision":null,"url":"assets/table-CSrbr8mU.js"},{"revision":null,"url":"assets/tab-store-HCmwXLYA.js"},{"revision":null,"url":"assets/sqlite-viewer-CSsYLA1Q.js"},{"revision":null,"url":"assets/settings-tab-CIM3X82k.js"},{"revision":null,"url":"assets/settings-store-CIOAyrzs.js"},{"revision":null,"url":"assets/react-Dhei_cB0.js"},{"revision":null,"url":"assets/react-4j_0SqET.js"},{"revision":null,"url":"assets/postgres-viewer-BToBpDFs.js"},{"revision":null,"url":"assets/markdown-renderer-DmuIK1-X.js"},{"revision":null,"url":"assets/keybindings-store-EctjzvyI.js"},{"revision":null,"url":"assets/jsx-runtime-CdTrtNt5.js"},{"revision":null,"url":"assets/jsx-dev-runtime-B0R0R7SH.js"},{"revision":null,"url":"assets/input-D3FZB4A8.js"},{"revision":null,"url":"assets/index-cCRyobYW.js"},{"revision":null,"url":"assets/index-DXTts38q.css"},{"revision":null,"url":"assets/git-graph-BwaH1gCr.js"},{"revision":null,"url":"assets/dist-CU2je4l7.js"},{"revision":null,"url":"assets/diff-viewer-BtqxNPvT.js"},{"revision":null,"url":"assets/database-viewer-BRtti__1.js"},{"revision":null,"url":"assets/columns-2-BSNHGqVP.js"},{"revision":null,"url":"assets/code-editor-BJSi0tN8.js"},{"revision":null,"url":"assets/chat-tab-DesJNGlM.js"},{"revision":null,"url":"assets/api-settings-D42qxHtn.js"},{"revision":null,"url":"assets/api-client-Bs-0pRox.js"},{"revision":"79c8870653c8f419f2e3323085e1f4be","url":"manifest.webmanifest"}]),self.addEventListener(`push`,e=>{e.waitUntil(self.clients.matchAll({type:`window`,includeUncontrolled:!0}).then(t=>{if(t.some(e=>e.visibilityState===`visible`))return;let n=e.data?.json()??{title:`PPM`,body:`Chat completed`};return self.registration.showNotification(n.title,{body:n.body,icon:`/icon-192.png`,badge:`/icon-192.png`,tag:`ppm-chat-done`,silent:!1,data:{url:self.location.origin}})}))}),self.addEventListener(`notificationclick`,e=>{e.notification.close(),e.waitUntil(self.clients.matchAll({type:`window`,includeUncontrolled:!0}).then(t=>{for(let e of t)if(e.url.includes(self.location.origin)&&`focus`in e)return e.focus();return self.clients.openWindow(e.notification.data?.url||`/`)}))});
1
+ try{self[`workbox:core:7.3.0`]&&_()}catch{}var e=(e,...t)=>{let n=e;return t.length>0&&(n+=` :: ${JSON.stringify(t)}`),n},t=class extends Error{constructor(t,n){let r=e(t,n);super(r),this.name=t,this.details=n}},n={googleAnalytics:`googleAnalytics`,precache:`precache-v2`,prefix:`workbox`,runtime:`runtime`,suffix:typeof registration<`u`?registration.scope:``},r=e=>[n.prefix,e,n.suffix].filter(e=>e&&e.length>0).join(`-`),i=e=>{for(let t of Object.keys(n))e(t)},a={updateDetails:e=>{i(t=>{typeof e[t]==`string`&&(n[t]=e[t])})},getGoogleAnalyticsName:e=>e||r(n.googleAnalytics),getPrecacheName:e=>e||r(n.precache),getPrefix:()=>n.prefix,getRuntimeName:e=>e||r(n.runtime),getSuffix:()=>n.suffix};function o(e,t){let n=t();return e.waitUntil(n),n}try{self[`workbox:precaching:7.3.0`]&&_()}catch{}var s=`__WB_REVISION__`;function c(e){if(!e)throw new t(`add-to-cache-list-unexpected-type`,{entry:e});if(typeof e==`string`){let t=new URL(e,location.href);return{cacheKey:t.href,url:t.href}}let{revision:n,url:r}=e;if(!r)throw new t(`add-to-cache-list-unexpected-type`,{entry:e});if(!n){let e=new URL(r,location.href);return{cacheKey:e.href,url:e.href}}let i=new URL(r,location.href),a=new URL(r,location.href);return i.searchParams.set(s,n),{cacheKey:i.href,url:a.href}}var l=class{constructor(){this.updatedURLs=[],this.notUpdatedURLs=[],this.handlerWillStart=async({request:e,state:t})=>{t&&(t.originalRequest=e)},this.cachedResponseWillBeUsed=async({event:e,state:t,cachedResponse:n})=>{if(e.type===`install`&&t&&t.originalRequest&&t.originalRequest instanceof Request){let e=t.originalRequest.url;n?this.notUpdatedURLs.push(e):this.updatedURLs.push(e)}return n}}},u=class{constructor({precacheController:e}){this.cacheKeyWillBeUsed=async({request:e,params:t})=>{let n=t?.cacheKey||this._precacheController.getCacheKeyForURL(e.url);return n?new Request(n,{headers:e.headers}):e},this._precacheController=e}},d;function f(){if(d===void 0){let e=new Response(``);if(`body`in e)try{new Response(e.body),d=!0}catch{d=!1}d=!1}return d}async function p(e,n){let r=null;if(e.url&&(r=new URL(e.url).origin),r!==self.location.origin)throw new t(`cross-origin-copy-response`,{origin:r});let i=e.clone(),a={headers:new Headers(i.headers),status:i.status,statusText:i.statusText},o=n?n(a):a,s=f()?i.body:await i.blob();return new Response(s,o)}var m=e=>new URL(String(e),location.href).href.replace(RegExp(`^${location.origin}`),``);function h(e,t){let n=new URL(e);for(let e of t)n.searchParams.delete(e);return n.href}async function g(e,t,n,r){let i=h(t.url,n);if(t.url===i)return e.match(t,r);let a=Object.assign(Object.assign({},r),{ignoreSearch:!0}),o=await e.keys(t,a);for(let t of o)if(i===h(t.url,n))return e.match(t,r)}var v=class{constructor(){this.promise=new Promise((e,t)=>{this.resolve=e,this.reject=t})}},y=new Set;async function b(){for(let e of y)await e()}function x(e){return new Promise(t=>setTimeout(t,e))}try{self[`workbox:strategies:7.3.0`]&&_()}catch{}function S(e){return typeof e==`string`?new Request(e):e}var C=class{constructor(e,t){this._cacheKeys={},Object.assign(this,t),this.event=t.event,this._strategy=e,this._handlerDeferred=new v,this._extendLifetimePromises=[],this._plugins=[...e.plugins],this._pluginStateMap=new Map;for(let e of this._plugins)this._pluginStateMap.set(e,{});this.event.waitUntil(this._handlerDeferred.promise)}async fetch(e){let{event:n}=this,r=S(e);if(r.mode===`navigate`&&n instanceof FetchEvent&&n.preloadResponse){let e=await n.preloadResponse;if(e)return e}let i=this.hasCallback(`fetchDidFail`)?r.clone():null;try{for(let e of this.iterateCallbacks(`requestWillFetch`))r=await e({request:r.clone(),event:n})}catch(e){if(e instanceof Error)throw new t(`plugin-error-request-will-fetch`,{thrownErrorMessage:e.message})}let a=r.clone();try{let e;e=await fetch(r,r.mode===`navigate`?void 0:this._strategy.fetchOptions);for(let t of this.iterateCallbacks(`fetchDidSucceed`))e=await t({event:n,request:a,response:e});return e}catch(e){throw i&&await this.runCallbacks(`fetchDidFail`,{error:e,event:n,originalRequest:i.clone(),request:a.clone()}),e}}async fetchAndCachePut(e){let t=await this.fetch(e),n=t.clone();return this.waitUntil(this.cachePut(e,n)),t}async cacheMatch(e){let t=S(e),n,{cacheName:r,matchOptions:i}=this._strategy,a=await this.getCacheKey(t,`read`),o=Object.assign(Object.assign({},i),{cacheName:r});n=await caches.match(a,o);for(let e of this.iterateCallbacks(`cachedResponseWillBeUsed`))n=await e({cacheName:r,matchOptions:i,cachedResponse:n,request:a,event:this.event})||void 0;return n}async cachePut(e,n){let r=S(e);await x(0);let i=await this.getCacheKey(r,`write`);if(!n)throw new t(`cache-put-with-no-response`,{url:m(i.url)});let a=await this._ensureResponseSafeToCache(n);if(!a)return!1;let{cacheName:o,matchOptions:s}=this._strategy,c=await self.caches.open(o),l=this.hasCallback(`cacheDidUpdate`),u=l?await g(c,i.clone(),[`__WB_REVISION__`],s):null;try{await c.put(i,l?a.clone():a)}catch(e){if(e instanceof Error)throw e.name===`QuotaExceededError`&&await b(),e}for(let e of this.iterateCallbacks(`cacheDidUpdate`))await e({cacheName:o,oldResponse:u,newResponse:a.clone(),request:i,event:this.event});return!0}async getCacheKey(e,t){let n=`${e.url} | ${t}`;if(!this._cacheKeys[n]){let r=e;for(let e of this.iterateCallbacks(`cacheKeyWillBeUsed`))r=S(await e({mode:t,request:r,event:this.event,params:this.params}));this._cacheKeys[n]=r}return this._cacheKeys[n]}hasCallback(e){for(let t of this._strategy.plugins)if(e in t)return!0;return!1}async runCallbacks(e,t){for(let n of this.iterateCallbacks(e))await n(t)}*iterateCallbacks(e){for(let t of this._strategy.plugins)if(typeof t[e]==`function`){let n=this._pluginStateMap.get(t);yield r=>{let i=Object.assign(Object.assign({},r),{state:n});return t[e](i)}}}waitUntil(e){return this._extendLifetimePromises.push(e),e}async doneWaiting(){for(;this._extendLifetimePromises.length;){let e=this._extendLifetimePromises.splice(0),t=(await Promise.allSettled(e)).find(e=>e.status===`rejected`);if(t)throw t.reason}}destroy(){this._handlerDeferred.resolve(null)}async _ensureResponseSafeToCache(e){let t=e,n=!1;for(let e of this.iterateCallbacks(`cacheWillUpdate`))if(t=await e({request:this.request,response:t,event:this.event})||void 0,n=!0,!t)break;return n||t&&t.status!==200&&(t=void 0),t}},w=class{constructor(e={}){this.cacheName=a.getRuntimeName(e.cacheName),this.plugins=e.plugins||[],this.fetchOptions=e.fetchOptions,this.matchOptions=e.matchOptions}handle(e){let[t]=this.handleAll(e);return t}handleAll(e){e instanceof FetchEvent&&(e={event:e,request:e.request});let t=e.event,n=typeof e.request==`string`?new Request(e.request):e.request,r=`params`in e?e.params:void 0,i=new C(this,{event:t,request:n,params:r}),a=this._getResponse(i,n,t);return[a,this._awaitComplete(a,i,n,t)]}async _getResponse(e,n,r){await e.runCallbacks(`handlerWillStart`,{event:r,request:n});let i;try{if(i=await this._handle(n,e),!i||i.type===`error`)throw new t(`no-response`,{url:n.url})}catch(t){if(t instanceof Error){for(let a of e.iterateCallbacks(`handlerDidError`))if(i=await a({error:t,event:r,request:n}),i)break}if(!i)throw t}for(let t of e.iterateCallbacks(`handlerWillRespond`))i=await t({event:r,request:n,response:i});return i}async _awaitComplete(e,t,n,r){let i,a;try{i=await e}catch{}try{await t.runCallbacks(`handlerDidRespond`,{event:r,request:n,response:i}),await t.doneWaiting()}catch(e){e instanceof Error&&(a=e)}if(await t.runCallbacks(`handlerDidComplete`,{event:r,request:n,response:i,error:a}),t.destroy(),a)throw a}},T=class e extends w{constructor(t={}){t.cacheName=a.getPrecacheName(t.cacheName),super(t),this._fallbackToNetwork=t.fallbackToNetwork!==!1,this.plugins.push(e.copyRedirectedCacheableResponsesPlugin)}async _handle(e,t){return await t.cacheMatch(e)||(t.event&&t.event.type===`install`?await this._handleInstall(e,t):await this._handleFetch(e,t))}async _handleFetch(e,n){let r,i=n.params||{};if(this._fallbackToNetwork){let t=i.integrity,a=e.integrity,o=!a||a===t;r=await n.fetch(new Request(e,{integrity:e.mode===`no-cors`?void 0:a||t})),t&&o&&e.mode!==`no-cors`&&(this._useDefaultCacheabilityPluginIfNeeded(),await n.cachePut(e,r.clone()))}else throw new t(`missing-precache-entry`,{cacheName:this.cacheName,url:e.url});return r}async _handleInstall(e,n){this._useDefaultCacheabilityPluginIfNeeded();let r=await n.fetch(e);if(!await n.cachePut(e,r.clone()))throw new t(`bad-precaching-response`,{url:e.url,status:r.status});return r}_useDefaultCacheabilityPluginIfNeeded(){let t=null,n=0;for(let[r,i]of this.plugins.entries())i!==e.copyRedirectedCacheableResponsesPlugin&&(i===e.defaultPrecacheCacheabilityPlugin&&(t=r),i.cacheWillUpdate&&n++);n===0?this.plugins.push(e.defaultPrecacheCacheabilityPlugin):n>1&&t!==null&&this.plugins.splice(t,1)}};T.defaultPrecacheCacheabilityPlugin={async cacheWillUpdate({response:e}){return!e||e.status>=400?null:e}},T.copyRedirectedCacheableResponsesPlugin={async cacheWillUpdate({response:e}){return e.redirected?await p(e):e}};var E=class{constructor({cacheName:e,plugins:t=[],fallbackToNetwork:n=!0}={}){this._urlsToCacheKeys=new Map,this._urlsToCacheModes=new Map,this._cacheKeysToIntegrities=new Map,this._strategy=new T({cacheName:a.getPrecacheName(e),plugins:[...t,new u({precacheController:this})],fallbackToNetwork:n}),this.install=this.install.bind(this),this.activate=this.activate.bind(this)}get strategy(){return this._strategy}precache(e){this.addToCacheList(e),this._installAndActiveListenersAdded||=(self.addEventListener(`install`,this.install),self.addEventListener(`activate`,this.activate),!0)}addToCacheList(e){let n=[];for(let r of e){typeof r==`string`?n.push(r):r&&r.revision===void 0&&n.push(r.url);let{cacheKey:e,url:i}=c(r),a=typeof r!=`string`&&r.revision?`reload`:`default`;if(this._urlsToCacheKeys.has(i)&&this._urlsToCacheKeys.get(i)!==e)throw new t(`add-to-cache-list-conflicting-entries`,{firstEntry:this._urlsToCacheKeys.get(i),secondEntry:e});if(typeof r!=`string`&&r.integrity){if(this._cacheKeysToIntegrities.has(e)&&this._cacheKeysToIntegrities.get(e)!==r.integrity)throw new t(`add-to-cache-list-conflicting-integrities`,{url:i});this._cacheKeysToIntegrities.set(e,r.integrity)}if(this._urlsToCacheKeys.set(i,e),this._urlsToCacheModes.set(i,a),n.length>0){let e=`Workbox is precaching URLs without revision info: ${n.join(`, `)}\nThis is generally NOT safe. Learn more at https://bit.ly/wb-precache`;console.warn(e)}}}install(e){return o(e,async()=>{let t=new l;this.strategy.plugins.push(t);for(let[t,n]of this._urlsToCacheKeys){let r=this._cacheKeysToIntegrities.get(n),i=this._urlsToCacheModes.get(t),a=new Request(t,{integrity:r,cache:i,credentials:`same-origin`});await Promise.all(this.strategy.handleAll({params:{cacheKey:n},request:a,event:e}))}let{updatedURLs:n,notUpdatedURLs:r}=t;return{updatedURLs:n,notUpdatedURLs:r}})}activate(e){return o(e,async()=>{let e=await self.caches.open(this.strategy.cacheName),t=await e.keys(),n=new Set(this._urlsToCacheKeys.values()),r=[];for(let i of t)n.has(i.url)||(await e.delete(i),r.push(i.url));return{deletedURLs:r}})}getURLsToCacheKeys(){return this._urlsToCacheKeys}getCachedURLs(){return[...this._urlsToCacheKeys.keys()]}getCacheKeyForURL(e){let t=new URL(e,location.href);return this._urlsToCacheKeys.get(t.href)}getIntegrityForCacheKey(e){return this._cacheKeysToIntegrities.get(e)}async matchPrecache(e){let t=e instanceof Request?e.url:e,n=this.getCacheKeyForURL(t);if(n)return(await self.caches.open(this.strategy.cacheName)).match(n)}createHandlerBoundToURL(e){let n=this.getCacheKeyForURL(e);if(!n)throw new t(`non-precached-url`,{url:e});return t=>(t.request=new Request(e),t.params=Object.assign({cacheKey:n},t.params),this.strategy.handle(t))}},D,O=()=>(D||=new E,D);try{self[`workbox:routing:7.3.0`]&&_()}catch{}var k=e=>e&&typeof e==`object`?e:{handle:e},A=class{constructor(e,t,n=`GET`){this.handler=k(t),this.match=e,this.method=n}setCatchHandler(e){this.catchHandler=k(e)}},j=class extends A{constructor(e,t,n){super(({url:t})=>{let n=e.exec(t.href);if(n&&!(t.origin!==location.origin&&n.index!==0))return n.slice(1)},t,n)}},M=class{constructor(){this._routes=new Map,this._defaultHandlerMap=new Map}get routes(){return this._routes}addFetchListener(){self.addEventListener(`fetch`,(e=>{let{request:t}=e,n=this.handleRequest({request:t,event:e});n&&e.respondWith(n)}))}addCacheListener(){self.addEventListener(`message`,(e=>{if(e.data&&e.data.type===`CACHE_URLS`){let{payload:t}=e.data,n=Promise.all(t.urlsToCache.map(t=>{typeof t==`string`&&(t=[t]);let n=new Request(...t);return this.handleRequest({request:n,event:e})}));e.waitUntil(n),e.ports&&e.ports[0]&&n.then(()=>e.ports[0].postMessage(!0))}}))}handleRequest({request:e,event:t}){let n=new URL(e.url,location.href);if(!n.protocol.startsWith(`http`))return;let r=n.origin===location.origin,{params:i,route:a}=this.findMatchingRoute({event:t,request:e,sameOrigin:r,url:n}),o=a&&a.handler,s=e.method;if(!o&&this._defaultHandlerMap.has(s)&&(o=this._defaultHandlerMap.get(s)),!o)return;let c;try{c=o.handle({url:n,request:e,event:t,params:i})}catch(e){c=Promise.reject(e)}let l=a&&a.catchHandler;return c instanceof Promise&&(this._catchHandler||l)&&(c=c.catch(async r=>{if(l)try{return await l.handle({url:n,request:e,event:t,params:i})}catch(e){e instanceof Error&&(r=e)}if(this._catchHandler)return this._catchHandler.handle({url:n,request:e,event:t});throw r})),c}findMatchingRoute({url:e,sameOrigin:t,request:n,event:r}){let i=this._routes.get(n.method)||[];for(let a of i){let i,o=a.match({url:e,sameOrigin:t,request:n,event:r});if(o)return i=o,(Array.isArray(i)&&i.length===0||o.constructor===Object&&Object.keys(o).length===0||typeof o==`boolean`)&&(i=void 0),{route:a,params:i}}return{}}setDefaultHandler(e,t=`GET`){this._defaultHandlerMap.set(t,k(e))}setCatchHandler(e){this._catchHandler=k(e)}registerRoute(e){this._routes.has(e.method)||this._routes.set(e.method,[]),this._routes.get(e.method).push(e)}unregisterRoute(e){if(!this._routes.has(e.method))throw new t(`unregister-route-but-not-found-with-method`,{method:e.method});let n=this._routes.get(e.method).indexOf(e);if(n>-1)this._routes.get(e.method).splice(n,1);else throw new t(`unregister-route-route-not-registered`)}},N,P=()=>(N||(N=new M,N.addFetchListener(),N.addCacheListener()),N);function F(e,n,r){let i;if(typeof e==`string`){let t=new URL(e,location.href);i=new A(({url:e})=>e.href===t.href,n,r)}else if(e instanceof RegExp)i=new j(e,n,r);else if(typeof e==`function`)i=new A(e,n,r);else if(e instanceof A)i=e;else throw new t(`unsupported-route-type`,{moduleName:`workbox-routing`,funcName:`registerRoute`,paramName:`capture`});return P().registerRoute(i),i}function I(e,t=[]){for(let n of[...e.searchParams.keys()])t.some(e=>e.test(n))&&e.searchParams.delete(n);return e}function*L(e,{ignoreURLParametersMatching:t=[/^utm_/,/^fbclid$/],directoryIndex:n=`index.html`,cleanURLs:r=!0,urlManipulation:i}={}){let a=new URL(e,location.href);a.hash=``,yield a.href;let o=I(a,t);if(yield o.href,n&&o.pathname.endsWith(`/`)){let e=new URL(o.href);e.pathname+=n,yield e.href}if(r){let e=new URL(o.href);e.pathname+=`.html`,yield e.href}if(i){let e=i({url:a});for(let t of e)yield t.href}}var R=class extends A{constructor(e,t){super(({request:n})=>{let r=e.getURLsToCacheKeys();for(let i of L(n.url,t)){let t=r.get(i);if(t)return{cacheKey:t,integrity:e.getIntegrityForCacheKey(t)}}},e.strategy)}};function z(e){F(new R(O(),e))}function B(e){O().precache(e)}function V(e,t){B(e),z(t)}V([{"revision":"1872c500de691dce40960bb85481de07","url":"registerSW.js"},{"revision":"81a25a239b5e5783d83ebff44e33d728","url":"index.html"},{"revision":"a0fb34fc84eb148d51812cd62669f20d","url":"icon-512.svg"},{"revision":"a0fb34fc84eb148d51812cd62669f20d","url":"icon-192.svg"},{"revision":"eb9818b9094675c0c5d303168f273345","url":"monacoeditorwork/ts.worker.bundle.js"},{"revision":"9af0be92dcefdc1f1290441cb5ff5d9b","url":"monacoeditorwork/json.worker.bundle.js"},{"revision":"a261b429c39dbb75ae97972d7d005e6d","url":"monacoeditorwork/html.worker.bundle.js"},{"revision":"79953d804e1bbacecfd79b85fd679016","url":"monacoeditorwork/editor.worker.bundle.js"},{"revision":"fdcba0d09aac31df7a0bc652f6e739bd","url":"monacoeditorwork/css.worker.bundle.js"},{"revision":null,"url":"assets/utils-DBpa1UZX.js"},{"revision":null,"url":"assets/use-monaco-theme-czriskTO.js"},{"revision":null,"url":"assets/terminal-tab-V7x81Qpr.js"},{"revision":null,"url":"assets/terminal-tab-BrP-ENHg.css"},{"revision":null,"url":"assets/table-B6neW6Hr.js"},{"revision":null,"url":"assets/tab-store-D7tRt0VT.js"},{"revision":null,"url":"assets/sqlite-viewer-9X_1ZHJE.js"},{"revision":null,"url":"assets/settings-tab-BdgsQeES.js"},{"revision":null,"url":"assets/settings-store-Clv3ZNje.js"},{"revision":null,"url":"assets/react-Dk7fkoaB.js"},{"revision":null,"url":"assets/react-CYzKIDNi.js"},{"revision":null,"url":"assets/postgres-viewer-hmqfZRr-.js"},{"revision":null,"url":"assets/markdown-renderer-DE503g9L.js"},{"revision":null,"url":"assets/keybindings-store-Dqs-i9cV.js"},{"revision":null,"url":"assets/jsx-runtime-wQxeESYQ.js"},{"revision":null,"url":"assets/input-4ElbicvY.js"},{"revision":null,"url":"assets/index-DXTts38q.css"},{"revision":null,"url":"assets/index-CvbNQ1mi.js"},{"revision":null,"url":"assets/git-graph-C-TRbbx7.js"},{"revision":null,"url":"assets/dist-QgqOdSYG.js"},{"revision":null,"url":"assets/diff-viewer-CDdO3tqP.js"},{"revision":null,"url":"assets/database-viewer-BaxjPtYR.js"},{"revision":null,"url":"assets/columns-2-BZ5wv2wA.js"},{"revision":null,"url":"assets/code-editor-DZlXHMtA.js"},{"revision":null,"url":"assets/chat-tab-CGic5t8w.js"},{"revision":null,"url":"assets/api-settings-0Hx_9lIU.js"},{"revision":null,"url":"assets/api-client-B0aMOJxF.js"},{"revision":"79c8870653c8f419f2e3323085e1f4be","url":"manifest.webmanifest"}]),self.addEventListener(`push`,e=>{e.waitUntil(self.clients.matchAll({type:`window`,includeUncontrolled:!0}).then(t=>{if(t.some(e=>e.visibilityState===`visible`))return;let n=e.data?.json()??{title:`PPM`,body:`Chat completed`};return self.registration.showNotification(n.title,{body:n.body,icon:`/icon-192.png`,badge:`/icon-192.png`,tag:`ppm-chat-done`,silent:!1,data:{url:self.location.origin}})}))}),self.addEventListener(`notificationclick`,e=>{e.notification.close(),e.waitUntil(self.clients.matchAll({type:`window`,includeUncontrolled:!0}).then(t=>{for(let e of t)if(e.url.includes(self.location.origin)&&`focus`in e)return e.focus();return self.clients.openWindow(e.notification.data?.url||`/`)}))});
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@hienlh/ppm",
3
- "version": "0.8.37",
3
+ "version": "0.8.38",
4
4
  "description": "Personal Project Manager — mobile-first web IDE with AI assistance",
5
5
  "author": "hienlh",
6
6
  "license": "MIT",
@@ -126,7 +126,11 @@ async function main() {
126
126
  // Spawn new server — on Windows use PowerShell Start-Process for true detach
127
127
  // (Bun.spawn + unref on Windows keeps child in same job object → dies when worker exits)
128
128
  let childPid: number;
129
- const serverArgs = ["run", P.serverScript, "__serve__", String(P.port), P.host, P.config].filter(Boolean);
129
+ // Compiled binary: execPath IS the server, no "run script" needed
130
+ const { isCompiledBinary } = await import("../../services/autostart-generator.ts");
131
+ const serverArgs = isCompiledBinary()
132
+ ? ["__serve__", String(P.port), P.host, P.config].filter(Boolean)
133
+ : ["run", P.serverScript, "__serve__", String(P.port), P.host, P.config].filter(Boolean);
130
134
 
131
135
  if (process.platform === "win32") {
132
136
  const bunExe = process.execPath.replace(/\\\\/g, "\\\\\\\\");
@@ -247,6 +247,8 @@ export async function startServer(options: {
247
247
 
248
248
  // Spawn server child process with log file
249
249
  const { openSync } = await import("node:fs");
250
+ const { isCompiledBinary } = await import("../services/autostart-generator.ts");
251
+ const isCompiledBin = isCompiledBinary();
250
252
  const logFile = resolve(ppmDir, "ppm.log");
251
253
  const logFd = openSync(logFile, "a");
252
254
  const { resolve: resolvePath } = await import("node:path");
@@ -265,7 +267,8 @@ export async function startServer(options: {
265
267
  const logEscaped = logFile.replace(/\\/g, "\\\\");
266
268
  const errLog = logFile.replace(/\.log$/, ".err.log").replace(/\\/g, "\\\\");
267
269
  // Use "_" placeholder for empty args — PowerShell rejects empty strings in ArgumentList
268
- const argStr = ["run", script, ...args].map((a) => `'${a || "_"}'`).join(",");
270
+ const winArgs = isCompiledBin ? args : ["run", script, ...args];
271
+ const argStr = winArgs.map((a) => `'${a || "_"}'`).join(",");
269
272
  const psCmd = [
270
273
  `$p = Start-Process -PassThru -WindowStyle Hidden`,
271
274
  `-FilePath '${bunExe}'`,
@@ -288,8 +291,12 @@ export async function startServer(options: {
288
291
  }
289
292
  } else {
290
293
  // macOS/Linux: Bun.spawn + unref works fine
294
+ // Compiled binary: execPath IS the server, no "run script" needed
295
+ const cmd = isCompiledBin
296
+ ? [process.execPath, ...args]
297
+ : [process.execPath, "run", script, ...args];
291
298
  const child = Bun.spawn({
292
- cmd: [process.execPath, "run", script, ...args],
299
+ cmd,
293
300
  stdio: ["ignore", logFd, logFd],
294
301
  env: process.env,
295
302
  });
@@ -427,13 +434,6 @@ export async function startServer(options: {
427
434
  const qr = await import("qrcode-terminal");
428
435
  console.log();
429
436
  qr.generate(shareUrl, { small: true });
430
-
431
- // Auto-sync tunnel URL to PPM Cloud (if linked)
432
- import("../services/cloud.service.ts")
433
- .then(({ startHeartbeat, getCloudDevice }) => {
434
- if (getCloudDevice()) startHeartbeat(shareUrl);
435
- })
436
- .catch(() => {});
437
437
  } catch (err: unknown) {
438
438
  const msg = err instanceof Error ? err.message : String(err);
439
439
  console.error(` ✗ Share failed: ${msg}`);
@@ -492,13 +492,6 @@ if (process.argv.includes("__serve__")) {
492
492
  const { tunnelService } = await import("../services/tunnel.service.ts");
493
493
  tunnelService.setExternalUrl(status.shareUrl);
494
494
  if (status.tunnelPid) tunnelService.setExternalPid(status.tunnelPid);
495
-
496
- // Auto-sync tunnel URL to PPM Cloud (daemon mode)
497
- import("../services/cloud.service.ts")
498
- .then(({ startHeartbeat, getCloudDevice }) => {
499
- if (getCloudDevice()) startHeartbeat(status.shareUrl);
500
- })
501
- .catch(() => {});
502
495
  }
503
496
  } catch { /* status.json missing or no shareUrl — normal */ }
504
497
 
@@ -25,14 +25,6 @@ tunnelRoutes.post("/start", async (c) => {
25
25
  try {
26
26
  const port = configService.get("port") ?? 8080;
27
27
  const url = await tunnelService.startTunnel(port);
28
-
29
- // Sync tunnel URL to PPM Cloud (if linked)
30
- import("../../services/cloud.service.ts")
31
- .then(({ startHeartbeat, getCloudDevice }) => {
32
- if (getCloudDevice()) startHeartbeat(url);
33
- })
34
- .catch(() => {});
35
-
36
28
  return c.json(ok({ url }));
37
29
  } catch (e) {
38
30
  return c.json(err((e as Error).message), 500);
@@ -42,11 +34,5 @@ tunnelRoutes.post("/start", async (c) => {
42
34
  /** POST /api/tunnel/stop — stop tunnel */
43
35
  tunnelRoutes.post("/stop", (c) => {
44
36
  tunnelService.stopTunnel();
45
-
46
- // Stop cloud heartbeat
47
- import("../../services/cloud.service.ts")
48
- .then(({ stopHeartbeat }) => stopHeartbeat())
49
- .catch(() => {});
50
-
51
37
  return c.json(ok({ stopped: true }));
52
38
  });
@@ -82,6 +82,7 @@ class TunnelService {
82
82
 
83
83
  this.url = url;
84
84
  this.persistToStatusFile();
85
+ this.syncToCloud();
85
86
  return url;
86
87
  }
87
88
 
@@ -110,6 +111,7 @@ class TunnelService {
110
111
  }
111
112
  this.url = null;
112
113
  this.persistToStatusFile();
114
+ this.stopCloudSync();
113
115
  }
114
116
 
115
117
  /** Get current tunnel URL (null if not running) */
@@ -125,6 +127,8 @@ class TunnelService {
125
127
  /** Inject an externally-started tunnel URL (e.g. from daemon --share) */
126
128
  setExternalUrl(url: string): void {
127
129
  this.url = url;
130
+ this.persistToStatusFile();
131
+ this.syncToCloud();
128
132
  }
129
133
 
130
134
  /** Adopt an externally-started tunnel by PID (for stop management after restart) */
@@ -143,6 +147,24 @@ class TunnelService {
143
147
  writeFileSync(statusFile, JSON.stringify(data));
144
148
  } catch {}
145
149
  }
150
+
151
+ /** Start cloud heartbeat if device is linked (non-blocking) */
152
+ private syncToCloud(): void {
153
+ if (!this.url) return;
154
+ const url = this.url;
155
+ import("./cloud.service.ts")
156
+ .then(({ startHeartbeat, getCloudDevice }) => {
157
+ if (getCloudDevice()) startHeartbeat(url);
158
+ })
159
+ .catch(() => {});
160
+ }
161
+
162
+ /** Stop cloud heartbeat (non-blocking) */
163
+ private stopCloudSync(): void {
164
+ import("./cloud.service.ts")
165
+ .then(({ stopHeartbeat }) => stopHeartbeat())
166
+ .catch(() => {});
167
+ }
146
168
  }
147
169
 
148
170
  /** Singleton tunnel service */
@@ -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};