viba-cli 0.21.0 → 0.22.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (96) hide show
  1. package/.next/BUILD_ID +1 -1
  2. package/.next/build-manifest.json +2 -2
  3. package/.next/fallback-build-manifest.json +2 -2
  4. package/.next/prerender-manifest.json +3 -3
  5. package/.next/server/app/_global-error.html +2 -2
  6. package/.next/server/app/_global-error.rsc +1 -1
  7. package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  8. package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  9. package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  10. package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  11. package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  12. package/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  13. package/.next/server/app/_not-found.html +1 -1
  14. package/.next/server/app/_not-found.rsc +2 -2
  15. package/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
  16. package/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  17. package/.next/server/app/_not-found.segments/_index.segment.rsc +2 -2
  18. package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  19. package/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  20. package/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  21. package/.next/server/app/credentials/page/server-reference-manifest.json +4 -4
  22. package/.next/server/app/credentials/page.js.nft.json +1 -1
  23. package/.next/server/app/credentials/page_client-reference-manifest.js +1 -1
  24. package/.next/server/app/credentials.html +1 -1
  25. package/.next/server/app/credentials.rsc +3 -3
  26. package/.next/server/app/credentials.segments/_full.segment.rsc +3 -3
  27. package/.next/server/app/credentials.segments/_head.segment.rsc +1 -1
  28. package/.next/server/app/credentials.segments/_index.segment.rsc +2 -2
  29. package/.next/server/app/credentials.segments/_tree.segment.rsc +2 -2
  30. package/.next/server/app/credentials.segments/credentials/__PAGE__.segment.rsc +2 -2
  31. package/.next/server/app/credentials.segments/credentials.segment.rsc +1 -1
  32. package/.next/server/app/index.html +1 -1
  33. package/.next/server/app/index.rsc +3 -3
  34. package/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  35. package/.next/server/app/index.segments/_full.segment.rsc +3 -3
  36. package/.next/server/app/index.segments/_head.segment.rsc +1 -1
  37. package/.next/server/app/index.segments/_index.segment.rsc +2 -2
  38. package/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  39. package/.next/server/app/new/page/server-reference-manifest.json +39 -24
  40. package/.next/server/app/new/page.js +2 -1
  41. package/.next/server/app/new/page.js.nft.json +1 -1
  42. package/.next/server/app/new/page_client-reference-manifest.js +1 -1
  43. package/.next/server/app/page/server-reference-manifest.json +39 -24
  44. package/.next/server/app/page.js +2 -1
  45. package/.next/server/app/page.js.nft.json +1 -1
  46. package/.next/server/app/page_client-reference-manifest.js +1 -1
  47. package/.next/server/app/session/[sessionId]/page/server-reference-manifest.json +20 -20
  48. package/.next/server/app/session/[sessionId]/page.js.nft.json +1 -1
  49. package/.next/server/app/session/[sessionId]/page_client-reference-manifest.js +1 -1
  50. package/.next/server/chunks/ssr/[root-of-the-server]__04684e03._.js +3 -0
  51. package/.next/server/chunks/ssr/[root-of-the-server]__04684e03._.js.map +1 -0
  52. package/.next/server/chunks/ssr/{[root-of-the-server]__8169dd30._.js → [root-of-the-server]__18c94f9b._.js} +2 -2
  53. package/.next/server/chunks/ssr/{[root-of-the-server]__8169dd30._.js.map → [root-of-the-server]__18c94f9b._.js.map} +1 -1
  54. package/.next/server/chunks/ssr/{[root-of-the-server]__213d5b40._.js → [root-of-the-server]__1c2594e3._.js} +2 -2
  55. package/.next/server/chunks/ssr/[root-of-the-server]__1c2594e3._.js.map +1 -0
  56. package/.next/server/chunks/ssr/{[root-of-the-server]__284fa850._.js → [root-of-the-server]__1f9d0fc3._.js} +2 -2
  57. package/.next/server/chunks/ssr/{[root-of-the-server]__284fa850._.js.map → [root-of-the-server]__1f9d0fc3._.js.map} +1 -1
  58. package/.next/server/chunks/ssr/[root-of-the-server]__319c1c59._.js +1 -1
  59. package/.next/server/chunks/ssr/[root-of-the-server]__319c1c59._.js.map +1 -1
  60. package/.next/server/chunks/ssr/[root-of-the-server]__352d2b3c._.js +1 -1
  61. package/.next/server/chunks/ssr/[root-of-the-server]__352d2b3c._.js.map +1 -1
  62. package/.next/server/chunks/ssr/{[root-of-the-server]__d5706047._.js → [root-of-the-server]__4b5a2cc9._.js} +2 -2
  63. package/.next/server/chunks/ssr/{[root-of-the-server]__d5706047._.js.map → [root-of-the-server]__4b5a2cc9._.js.map} +1 -1
  64. package/.next/server/chunks/ssr/[root-of-the-server]__9201693f._.js +1 -1
  65. package/.next/server/chunks/ssr/[root-of-the-server]__9201693f._.js.map +1 -1
  66. package/.next/server/chunks/ssr/[root-of-the-server]__a091a4c1._.js +3 -0
  67. package/.next/server/chunks/ssr/[root-of-the-server]__a091a4c1._.js.map +1 -0
  68. package/.next/server/chunks/ssr/{[root-of-the-server]__7f8cd2b9._.js → [root-of-the-server]__e64b9aa2._.js} +2 -2
  69. package/.next/server/chunks/ssr/{[root-of-the-server]__7f8cd2b9._.js.map → [root-of-the-server]__e64b9aa2._.js.map} +1 -1
  70. package/.next/server/chunks/ssr/[root-of-the-server]__ee9c5185._.js +1 -1
  71. package/.next/server/chunks/ssr/[root-of-the-server]__ee9c5185._.js.map +1 -1
  72. package/.next/server/chunks/ssr/src_app_session_[sessionId]_SessionPageClient_tsx_dab490d7._.js +1 -1
  73. package/.next/server/chunks/ssr/src_app_session_[sessionId]_SessionPageClient_tsx_dab490d7._.js.map +1 -1
  74. package/.next/server/chunks/ssr/src_components_GitRepoSelector_tsx_05c81afa._.js +2 -2
  75. package/.next/server/chunks/ssr/src_components_GitRepoSelector_tsx_05c81afa._.js.map +1 -1
  76. package/.next/server/pages/404.html +1 -1
  77. package/.next/server/pages/500.html +2 -2
  78. package/.next/server/server-reference-manifest.js +1 -1
  79. package/.next/server/server-reference-manifest.json +65 -43
  80. package/.next/static/chunks/{5f3a2db85aacc485.js → 1fcc6a067a965845.js} +2 -2
  81. package/.next/static/chunks/{b453010d797f0f5c.js → 3c6dfb830cb337dd.js} +1 -1
  82. package/.next/static/chunks/{1891e07f938de79e.js → 496431a0f6bfe933.js} +3 -3
  83. package/.next/static/chunks/7dad2f2e170a6bec.css +3 -0
  84. package/.next/static/chunks/dec01b498b99a88a.js +3 -0
  85. package/.next/static/chunks/{32cdf7e667231c75.js → f632319d9eb6afac.js} +1 -1
  86. package/.next/static/chunks/fa31e69929e43d1a.js +1 -0
  87. package/package.json +1 -1
  88. package/.next/server/chunks/ssr/[root-of-the-server]__213d5b40._.js.map +0 -1
  89. package/.next/server/chunks/ssr/[root-of-the-server]__3e7d3e82._.js +0 -4
  90. package/.next/server/chunks/ssr/[root-of-the-server]__3e7d3e82._.js.map +0 -1
  91. package/.next/static/chunks/16f42a25676d2900.css +0 -3
  92. package/.next/static/chunks/c76f31165986fed7.js +0 -1
  93. package/.next/static/chunks/d8a68fb48b3718f5.js +0 -3
  94. /package/.next/static/{a3AUzSUWZmXcIvA31ymCS → NBlpuq6wedv5ixjNbqUAT}/_buildManifest.js +0 -0
  95. /package/.next/static/{a3AUzSUWZmXcIvA31ymCS → NBlpuq6wedv5ixjNbqUAT}/_clientMiddlewareManifest.json +0 -0
  96. /package/.next/static/{a3AUzSUWZmXcIvA31ymCS → NBlpuq6wedv5ixjNbqUAT}/_ssgManifest.js +0 -0
@@ -1,3 +1,3 @@
1
1
  (globalThis.TURBOPACK||(globalThis.TURBOPACK=[])).push(["object"==typeof document?document.currentScript:void 0,33525,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"warnOnce",{enumerable:!0,get:function(){return a}});let a=e=>{}},95187,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0});var a={callServer:function(){return s.callServer},createServerReference:function(){return l.createServerReference},findSourceMapURL:function(){return n.findSourceMapURL}};for(var i in a)Object.defineProperty(r,i,{enumerable:!0,get:a[i]});let s=e.r(32120),n=e.r(92245),l=e.r(35326)},75254,e=>{"use strict";var t=e.i(71645);let r=(...e)=>e.filter((e,t,r)=>!!e&&""!==e.trim()&&r.indexOf(e)===t).join(" ").trim(),a=e=>{let t=e.replace(/^([A-Z])|[\s-_]+(\w)/g,(e,t,r)=>r?r.toUpperCase():t.toLowerCase());return t.charAt(0).toUpperCase()+t.slice(1)};var i={xmlns:"http://www.w3.org/2000/svg",width:24,height:24,viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round",strokeLinejoin:"round"};let s=(0,t.forwardRef)(({color:e="currentColor",size:a=24,strokeWidth:s=2,absoluteStrokeWidth:n,className:l="",children:o,iconNode:d,...c},u)=>(0,t.createElement)("svg",{ref:u,...i,width:a,height:a,stroke:e,strokeWidth:n?24*Number(s)/Number(a):s,className:r("lucide",l),...!o&&!(e=>{for(let t in e)if(t.startsWith("aria-")||"role"===t||"title"===t)return!0;return!1})(c)&&{"aria-hidden":"true"},...c},[...d.map(([e,r])=>(0,t.createElement)(e,r)),...Array.isArray(o)?o:[o]])),n=(e,i)=>{let n=(0,t.forwardRef)(({className:n,...l},o)=>(0,t.createElement)(s,{ref:o,iconNode:i,className:r(`lucide-${a(e).replace(/([a-z0-9])([A-Z])/g,"$1-$2").toLowerCase()}`,`lucide-${e}`,n),...l}));return n.displayName=a(e),n};e.s(["default",()=>n],75254)},71689,e=>{"use strict";let t=(0,e.i(75254).default)("arrow-left",[["path",{d:"m12 19-7-7 7-7",key:"1l729n"}],["path",{d:"M19 12H5",key:"x3x0zl"}]]);e.s(["ArrowLeft",()=>t],71689)},27612,e=>{"use strict";let t=(0,e.i(75254).default)("trash-2",[["path",{d:"M10 11v6",key:"nco0om"}],["path",{d:"M14 11v6",key:"outv1u"}],["path",{d:"M19 6v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6",key:"miytrc"}],["path",{d:"M3 6h18",key:"d0wm0j"}],["path",{d:"M8 6V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2",key:"e791ji"}]]);e.s(["Trash2",()=>t],27612)},88143,(e,t,r)=>{"use strict";function a({widthInt:e,heightInt:t,blurWidth:r,blurHeight:a,blurDataURL:i,objectFit:s}){let n=r?40*r:e,l=a?40*a:t,o=n&&l?`viewBox='0 0 ${n} ${l}'`:"";return`%3Csvg xmlns='http://www.w3.org/2000/svg' ${o}%3E%3Cfilter id='b' color-interpolation-filters='sRGB'%3E%3CfeGaussianBlur stdDeviation='20'/%3E%3CfeColorMatrix values='1 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 100 -1' result='s'/%3E%3CfeFlood x='0' y='0' width='100%25' height='100%25'/%3E%3CfeComposite operator='out' in='s'/%3E%3CfeComposite in2='SourceGraphic'/%3E%3CfeGaussianBlur stdDeviation='20'/%3E%3C/filter%3E%3Cimage width='100%25' height='100%25' x='0' y='0' preserveAspectRatio='${o?"none":"contain"===s?"xMidYMid":"cover"===s?"xMidYMid slice":"none"}' style='filter: url(%23b);' href='${i}'/%3E%3C/svg%3E`}Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"getImageBlurSvg",{enumerable:!0,get:function(){return a}})},87690,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0});var a={VALID_LOADERS:function(){return s},imageConfigDefault:function(){return n}};for(var i in a)Object.defineProperty(r,i,{enumerable:!0,get:a[i]});let s=["default","imgix","cloudinary","akamai","custom"],n={deviceSizes:[640,750,828,1080,1200,1920,2048,3840],imageSizes:[32,48,64,96,128,256,384],path:"/_next/image",loader:"default",loaderFile:"",domains:[],disableStaticImages:!1,minimumCacheTTL:14400,formats:["image/webp"],maximumRedirects:3,maximumResponseBody:5e7,dangerouslyAllowLocalIP:!1,dangerouslyAllowSVG:!1,contentSecurityPolicy:"script-src 'none'; frame-src 'none'; sandbox;",contentDispositionType:"attachment",localPatterns:void 0,remotePatterns:[],qualities:[75],unoptimized:!1}},8927,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"getImgProps",{enumerable:!0,get:function(){return d}}),e.r(33525);let a=e.r(43369),i=e.r(88143),s=e.r(87690),n=["-moz-initial","fill","none","scale-down",void 0];function l(e){return void 0!==e.default}function o(e){return void 0===e?e:"number"==typeof e?Number.isFinite(e)?e:NaN:"string"==typeof e&&/^[0-9]+$/.test(e)?parseInt(e,10):NaN}function d({src:e,sizes:t,unoptimized:r=!1,priority:d=!1,preload:c=!1,loading:u,className:f,quality:p,width:m,height:g,fill:h=!1,style:b,overrideSrc:x,onLoad:v,onLoadingComplete:y,placeholder:j="empty",blurDataURL:w,fetchPriority:_,decoding:N="async",layout:S,objectFit:C,objectPosition:P,lazyBoundary:O,lazyRoot:R,...E},M){var k;let z,$,A,{imgConf:L,showAltText:I,blurComplete:D,defaultLoader:U}=M,T=L||s.imageConfigDefault;if("allSizes"in T)z=T;else{let e=[...T.deviceSizes,...T.imageSizes].sort((e,t)=>e-t),t=T.deviceSizes.sort((e,t)=>e-t),r=T.qualities?.sort((e,t)=>e-t);z={...T,allSizes:e,deviceSizes:t,qualities:r}}if(void 0===U)throw Object.defineProperty(Error("images.loaderFile detected but the file is missing default export.\nRead more: https://nextjs.org/docs/messages/invalid-images-config"),"__NEXT_ERROR_CODE",{value:"E163",enumerable:!1,configurable:!0});let G=E.loader||U;delete E.loader,delete E.srcSet;let B="__next_img_default"in G;if(B){if("custom"===z.loader)throw Object.defineProperty(Error(`Image with src "${e}" is missing "loader" prop.
2
2
  Read more: https://nextjs.org/docs/messages/next-image-missing-loader`),"__NEXT_ERROR_CODE",{value:"E252",enumerable:!1,configurable:!0})}else{let e=G;G=t=>{let{config:r,...a}=t;return e(a)}}if(S){"fill"===S&&(h=!0);let e={intrinsic:{maxWidth:"100%",height:"auto"},responsive:{width:"100%",height:"auto"}}[S];e&&(b={...b,...e});let r={responsive:"100vw",fill:"100vw"}[S];r&&!t&&(t=r)}let H="",W=o(m),q=o(g);if((k=e)&&"object"==typeof k&&(l(k)||void 0!==k.src)){let t=l(e)?e.default:e;if(!t.src)throw Object.defineProperty(Error(`An object should only be passed to the image component src parameter if it comes from a static image import. It must include src. Received ${JSON.stringify(t)}`),"__NEXT_ERROR_CODE",{value:"E460",enumerable:!1,configurable:!0});if(!t.height||!t.width)throw Object.defineProperty(Error(`An object should only be passed to the image component src parameter if it comes from a static image import. It must include height and width. Received ${JSON.stringify(t)}`),"__NEXT_ERROR_CODE",{value:"E48",enumerable:!1,configurable:!0});if($=t.blurWidth,A=t.blurHeight,w=w||t.blurDataURL,H=t.src,!h)if(W||q){if(W&&!q){let e=W/t.width;q=Math.round(t.height*e)}else if(!W&&q){let e=q/t.height;W=Math.round(t.width*e)}}else W=t.width,q=t.height}let F=!d&&!c&&("lazy"===u||void 0===u);(!(e="string"==typeof e?e:H)||e.startsWith("data:")||e.startsWith("blob:"))&&(r=!0,F=!1),z.unoptimized&&(r=!0),B&&!z.dangerouslyAllowSVG&&e.split("?",1)[0].endsWith(".svg")&&(r=!0);let V=o(p),X=Object.assign(h?{position:"absolute",height:"100%",width:"100%",left:0,top:0,right:0,bottom:0,objectFit:C,objectPosition:P}:{},I?{}:{color:"transparent"},b),K=D||"empty"===j?null:"blur"===j?`url("data:image/svg+xml;charset=utf-8,${(0,i.getImageBlurSvg)({widthInt:W,heightInt:q,blurWidth:$,blurHeight:A,blurDataURL:w||"",objectFit:X.objectFit})}")`:`url("${j}")`,J=n.includes(X.objectFit)?"fill"===X.objectFit?"100% 100%":"cover":X.objectFit,Q=K?{backgroundSize:J,backgroundPosition:X.objectPosition||"50% 50%",backgroundRepeat:"no-repeat",backgroundImage:K}:{},Y=function({config:e,src:t,unoptimized:r,width:i,quality:s,sizes:n,loader:l}){if(r){let e=(0,a.getDeploymentId)();if(t.startsWith("/")&&!t.startsWith("//")&&e){let r=t.includes("?")?"&":"?";t=`${t}${r}dpl=${e}`}return{src:t,srcSet:void 0,sizes:void 0}}let{widths:o,kind:d}=function({deviceSizes:e,allSizes:t},r,a){if(a){let r=/(^|\s)(1?\d?\d)vw/g,i=[];for(let e;e=r.exec(a);)i.push(parseInt(e[2]));if(i.length){let r=.01*Math.min(...i);return{widths:t.filter(t=>t>=e[0]*r),kind:"w"}}return{widths:t,kind:"w"}}return"number"!=typeof r?{widths:e,kind:"w"}:{widths:[...new Set([r,2*r].map(e=>t.find(t=>t>=e)||t[t.length-1]))],kind:"x"}}(e,i,n),c=o.length-1;return{sizes:n||"w"!==d?n:"100vw",srcSet:o.map((r,a)=>`${l({config:e,src:t,quality:s,width:r})} ${"w"===d?r:a+1}${d}`).join(", "),src:l({config:e,src:t,quality:s,width:o[c]})}}({config:z,src:e,unoptimized:r,width:W,quality:V,sizes:t,loader:G}),Z=F?"lazy":u;return{props:{...E,loading:Z,fetchPriority:_,width:W,height:q,decoding:N,className:f,style:{...X,...Q},sizes:Y.sizes,srcSet:Y.srcSet,src:x||Y.src},meta:{unoptimized:r,preload:c||d,placeholder:j,fill:h}}}},98879,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"default",{enumerable:!0,get:function(){return l}});let a=e.r(71645),i="u"<typeof window,s=i?()=>{}:a.useLayoutEffect,n=i?()=>{}:a.useEffect;function l(e){let{headManager:t,reduceComponentsToState:r}=e;function l(){if(t&&t.mountedInstances){let e=a.Children.toArray(Array.from(t.mountedInstances).filter(Boolean));t.updateHead(r(e))}}return i&&(t?.mountedInstances?.add(e.children),l()),s(()=>(t?.mountedInstances?.add(e.children),()=>{t?.mountedInstances?.delete(e.children)})),s(()=>(t&&(t._pendingUpdate=l),()=>{t&&(t._pendingUpdate=l)})),n(()=>(t&&t._pendingUpdate&&(t._pendingUpdate(),t._pendingUpdate=null),()=>{t&&t._pendingUpdate&&(t._pendingUpdate(),t._pendingUpdate=null)})),null}},25633,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0});var a={default:function(){return g},defaultHead:function(){return u}};for(var i in a)Object.defineProperty(r,i,{enumerable:!0,get:a[i]});let s=e.r(55682),n=e.r(90809),l=e.r(43476),o=n._(e.r(71645)),d=s._(e.r(98879)),c=e.r(42732);function u(){return[(0,l.jsx)("meta",{charSet:"utf-8"},"charset"),(0,l.jsx)("meta",{name:"viewport",content:"width=device-width"},"viewport")]}function f(e,t){return"string"==typeof t||"number"==typeof t?e:t.type===o.default.Fragment?e.concat(o.default.Children.toArray(t.props.children).reduce((e,t)=>"string"==typeof t||"number"==typeof t?e:e.concat(t),[])):e.concat(t)}e.r(33525);let p=["name","httpEquiv","charSet","itemProp"];function m(e){let t,r,a,i;return e.reduce(f,[]).reverse().concat(u().reverse()).filter((t=new Set,r=new Set,a=new Set,i={},e=>{let s=!0,n=!1;if(e.key&&"number"!=typeof e.key&&e.key.indexOf("$")>0){n=!0;let r=e.key.slice(e.key.indexOf("$")+1);t.has(r)?s=!1:t.add(r)}switch(e.type){case"title":case"base":r.has(e.type)?s=!1:r.add(e.type);break;case"meta":for(let t=0,r=p.length;t<r;t++){let r=p[t];if(e.props.hasOwnProperty(r))if("charSet"===r)a.has(r)?s=!1:a.add(r);else{let t=e.props[r],a=i[r]||new Set;("name"!==r||!n)&&a.has(t)?s=!1:(a.add(t),i[r]=a)}}}return s})).reverse().map((e,t)=>{let r=e.key||t;return o.default.cloneElement(e,{key:r})})}let g=function({children:e}){let t=(0,o.useContext)(c.HeadManagerContext);return(0,l.jsx)(d.default,{reduceComponentsToState:m,headManager:t,children:e})};("function"==typeof r.default||"object"==typeof r.default&&null!==r.default)&&void 0===r.default.__esModule&&(Object.defineProperty(r.default,"__esModule",{value:!0}),Object.assign(r.default,r),t.exports=r.default)},18556,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"ImageConfigContext",{enumerable:!0,get:function(){return s}});let a=e.r(55682)._(e.r(71645)),i=e.r(87690),s=a.default.createContext(i.imageConfigDefault)},65856,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"RouterContext",{enumerable:!0,get:function(){return a}});let a=e.r(55682)._(e.r(71645)).default.createContext(null)},70965,(e,t,r)=>{"use strict";function a(e,t){let r=e||75;return t?.qualities?.length?t.qualities.reduce((e,t)=>Math.abs(t-r)<Math.abs(e-r)?t:e,0):r}Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"findClosestQuality",{enumerable:!0,get:function(){return a}})},1948,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"default",{enumerable:!0,get:function(){return n}});let a=e.r(70965),i=e.r(43369);function s({config:e,src:t,width:r,quality:s}){if(t.startsWith("/")&&t.includes("?")&&e.localPatterns?.length===1&&"**"===e.localPatterns[0].pathname&&""===e.localPatterns[0].search)throw Object.defineProperty(Error(`Image with src "${t}" is using a query string which is not configured in images.localPatterns.
3
- Read more: https://nextjs.org/docs/messages/next-image-unconfigured-localpatterns`),"__NEXT_ERROR_CODE",{value:"E871",enumerable:!1,configurable:!0});let n=(0,a.findClosestQuality)(s,e),l=(0,i.getDeploymentId)();return`${e.path}?url=${encodeURIComponent(t)}&w=${r}&q=${n}${t.startsWith("/")&&l?`&dpl=${l}`:""}`}s.__next_img_default=!0;let n=s},18581,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"useMergedRef",{enumerable:!0,get:function(){return i}});let a=e.r(71645);function i(e,t){let r=(0,a.useRef)(null),i=(0,a.useRef)(null);return(0,a.useCallback)(a=>{if(null===a){let e=r.current;e&&(r.current=null,e());let t=i.current;t&&(i.current=null,t())}else e&&(r.current=s(e,a)),t&&(i.current=s(t,a))},[e,t])}function s(e,t){if("function"!=typeof e)return e.current=t,()=>{e.current=null};{let r=e(t);return"function"==typeof r?r:()=>e(null)}}("function"==typeof r.default||"object"==typeof r.default&&null!==r.default)&&void 0===r.default.__esModule&&(Object.defineProperty(r.default,"__esModule",{value:!0}),Object.assign(r.default,r),t.exports=r.default)},5500,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"Image",{enumerable:!0,get:function(){return y}});let a=e.r(55682),i=e.r(90809),s=e.r(43476),n=i._(e.r(71645)),l=a._(e.r(74080)),o=a._(e.r(25633)),d=e.r(8927),c=e.r(87690),u=e.r(18556);e.r(33525);let f=e.r(65856),p=a._(e.r(1948)),m=e.r(18581),g={deviceSizes:[640,750,828,1080,1200,1920,2048,3840],imageSizes:[32,48,64,96,128,256,384],qualities:[75],path:"/_next/image",loader:"default",dangerouslyAllowSVG:!1,unoptimized:!1};function h(e,t,r,a,i,s,n){let l=e?.src;e&&e["data-loaded-src"]!==l&&(e["data-loaded-src"]=l,("decode"in e?e.decode():Promise.resolve()).catch(()=>{}).then(()=>{if(e.parentElement&&e.isConnected){if("empty"!==t&&i(!0),r?.current){let t=new Event("load");Object.defineProperty(t,"target",{writable:!1,value:e});let a=!1,i=!1;r.current({...t,nativeEvent:t,currentTarget:e,target:e,isDefaultPrevented:()=>a,isPropagationStopped:()=>i,persist:()=>{},preventDefault:()=>{a=!0,t.preventDefault()},stopPropagation:()=>{i=!0,t.stopPropagation()}})}a?.current&&a.current(e)}}))}function b(e){return n.use?{fetchPriority:e}:{fetchpriority:e}}"u"<typeof window&&(globalThis.__NEXT_IMAGE_IMPORTED=!0);let x=(0,n.forwardRef)(({src:e,srcSet:t,sizes:r,height:a,width:i,decoding:l,className:o,style:d,fetchPriority:c,placeholder:u,loading:f,unoptimized:p,fill:g,onLoadRef:x,onLoadingCompleteRef:v,setBlurComplete:y,setShowAltText:j,sizesInput:w,onLoad:_,onError:N,...S},C)=>{let P=(0,n.useCallback)(e=>{e&&(N&&(e.src=e.src),e.complete&&h(e,u,x,v,y,p,w))},[e,u,x,v,y,N,p,w]),O=(0,m.useMergedRef)(C,P);return(0,s.jsx)("img",{...S,...b(c),loading:f,width:i,height:a,decoding:l,"data-nimg":g?"fill":"1",className:o,style:d,sizes:r,srcSet:t,src:e,ref:O,onLoad:e=>{h(e.currentTarget,u,x,v,y,p,w)},onError:e=>{j(!0),"empty"!==u&&y(!0),N&&N(e)}})});function v({isAppRouter:e,imgAttributes:t}){let r={as:"image",imageSrcSet:t.srcSet,imageSizes:t.sizes,crossOrigin:t.crossOrigin,referrerPolicy:t.referrerPolicy,...b(t.fetchPriority)};return e&&l.default.preload?(l.default.preload(t.src,r),null):(0,s.jsx)(o.default,{children:(0,s.jsx)("link",{rel:"preload",href:t.srcSet?void 0:t.src,...r},"__nimg-"+t.src+t.srcSet+t.sizes)})}let y=(0,n.forwardRef)((e,t)=>{let r=(0,n.useContext)(f.RouterContext),a=(0,n.useContext)(u.ImageConfigContext),i=(0,n.useMemo)(()=>{let e=g||a||c.imageConfigDefault,t=[...e.deviceSizes,...e.imageSizes].sort((e,t)=>e-t),r=e.deviceSizes.sort((e,t)=>e-t),i=e.qualities?.sort((e,t)=>e-t);return{...e,allSizes:t,deviceSizes:r,qualities:i,localPatterns:"u"<typeof window?a?.localPatterns:e.localPatterns}},[a]),{onLoad:l,onLoadingComplete:o}=e,m=(0,n.useRef)(l);(0,n.useEffect)(()=>{m.current=l},[l]);let h=(0,n.useRef)(o);(0,n.useEffect)(()=>{h.current=o},[o]);let[b,y]=(0,n.useState)(!1),[j,w]=(0,n.useState)(!1),{props:_,meta:N}=(0,d.getImgProps)(e,{defaultLoader:p.default,imgConf:i,blurComplete:b,showAltText:j});return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(x,{..._,unoptimized:N.unoptimized,placeholder:N.placeholder,fill:N.fill,onLoadRef:m,onLoadingCompleteRef:h,setBlurComplete:y,setShowAltText:w,sizesInput:e.sizes,ref:t}),N.preload?(0,s.jsx)(v,{isAppRouter:!r,imgAttributes:_}):null]})});("function"==typeof r.default||"object"==typeof r.default&&null!==r.default)&&void 0===r.default.__esModule&&(Object.defineProperty(r.default,"__esModule",{value:!0}),Object.assign(r.default,r),t.exports=r.default)},94909,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0});var a={default:function(){return c},getImageProps:function(){return d}};for(var i in a)Object.defineProperty(r,i,{enumerable:!0,get:a[i]});let s=e.r(55682),n=e.r(8927),l=e.r(5500),o=s._(e.r(1948));function d(e){let{props:t}=(0,n.getImgProps)(e,{defaultLoader:o.default,imgConf:{deviceSizes:[640,750,828,1080,1200,1920,2048,3840],imageSizes:[32,48,64,96,128,256,384],qualities:[75],path:"/_next/image",loader:"default",dangerouslyAllowSVG:!1,unoptimized:!1}});for(let[e,r]of Object.entries(t))void 0===r&&delete t[e];return{props:t}}let c=l.Image},57688,(e,t,r)=>{t.exports=e.r(94909)},18566,(e,t,r)=>{t.exports=e.r(76562)},54808,e=>{"use strict";var t=e.i(95187);let r=(0,t.createServerReference)("009a52b5211f7188280192b7f54d2b7d360227dbb3",t.callServer,void 0,t.findSourceMapURL,"listCredentials");e.s(["listCredentials",()=>r])},65261,e=>{"use strict";let t=(0,e.i(75254).default)("key-round",[["path",{d:"M2.586 17.414A2 2 0 0 0 2 18.828V21a1 1 0 0 0 1 1h3a1 1 0 0 0 1-1v-1a1 1 0 0 1 1-1h1a1 1 0 0 0 1-1v-1a1 1 0 0 1 1-1h.172a2 2 0 0 0 1.414-.586l.814-.814a6.5 6.5 0 1 0-4-4z",key:"1s6t7t"}],["circle",{cx:"16.5",cy:"7.5",r:".5",fill:"currentColor",key:"w0ekpg"}]]);e.s(["KeyRound",()=>t],65261)},63768,e=>{"use strict";var t=e.i(43476),r=e.i(54808),a=e.i(95187);let i=(0,a.createServerReference)("40badba051858a0eefeb404f511e0df8053a815b20",a.callServer,void 0,a.findSourceMapURL,"removeCredential"),s=(0,a.createServerReference)("40be8b850b232f864e7ab716e5d1d982c37793c20b",a.callServer,void 0,a.findSourceMapURL,"saveGitHubCredential"),n=(0,a.createServerReference)("60c0fb15bb860aa80aab9cecb3b35b3b7faec3a36b",a.callServer,void 0,a.findSourceMapURL,"saveGitLabCredential");var l=e.i(71689),o=e.i(65261),d=e.i(27612),c=e.i(57688),u=e.i(18566),f=e.i(71645);let p="https://gitlab.com",m={github:"https://www.google.com/s2/favicons?domain=github.com&sz=64",gitlab:"https://www.google.com/s2/favicons?domain=gitlab.com&sz=64"};function g(e){return"github"===e?"GitHub":"GitLab"}function h({type:e}){return(0,t.jsx)(c.default,{src:m[e],alt:`${g(e)} icon`,width:20,height:20,className:"h-5 w-5 rounded-sm",unoptimized:!0})}function b(){let e=(0,u.useRouter)(),[a,c]=(0,f.useState)([]),[m,b]=(0,f.useState)(!0),[x,v]=(0,f.useState)(""),[y,j]=(0,f.useState)(""),[w,_]=(0,f.useState)(p),[N,S]=(0,f.useState)(null),[C,P]=(0,f.useState)(null),[O,R]=(0,f.useState)(null),E=(0,f.useMemo)(()=>a.filter(e=>"github"===e.type),[a]),M=(0,f.useMemo)(()=>a.filter(e=>"gitlab"===e.type),[a]),k=async()=>{let e=await (0,r.listCredentials)();if(!e.success){R({tone:"error",text:e.error}),b(!1);return}c(e.credentials),b(!1)};(0,f.useEffect)(()=>{let e=!0;return(async()=>{let t=await (0,r.listCredentials)();if(e){if(!t.success){R({tone:"error",text:t.error}),b(!1);return}c(t.credentials),b(!1)}})(),()=>{e=!1}},[]);let z=async()=>{R(null),S("github");let e=await s(x);if(!e.success){R({tone:"error",text:e.error}),S(null);return}v(""),R({tone:"success",text:"GitHub credential added."}),await k(),S(null)},$=async()=>{R(null),S("gitlab");let e=await n(w,y);if(!e.success){R({tone:"error",text:e.error}),S(null);return}j(""),R({tone:"success",text:"GitLab credential added."}),await k(),S(null)},A=async e=>{let t=g(e.type);if(!confirm(`Delete this ${t} credential for ${"gitlab"===e.type?`${e.username} @ ${e.serverUrl}`:e.username}?`))return;R(null),P(e.id);let r=await i(e.id);if(!r.success){R({tone:"error",text:r.error}),P(null);return}R({tone:"success",text:`${t} credential deleted.`}),await k(),P(null)};return(0,t.jsx)("main",{className:"min-h-screen bg-base-100 p-4 md:p-10",children:(0,t.jsxs)("div",{className:"mx-auto w-full max-w-5xl space-y-5",children:[(0,t.jsx)("div",{className:"flex items-center justify-between",children:(0,t.jsxs)("div",{className:"flex items-center gap-3",children:[(0,t.jsxs)("button",{className:"btn btn-ghost btn-sm",onClick:()=>e.push("/"),children:[(0,t.jsx)(l.ArrowLeft,{className:"h-4 w-4"}),"Back"]}),(0,t.jsxs)("div",{children:[(0,t.jsx)("h1",{className:"text-2xl font-semibold",children:"Credentials"}),(0,t.jsx)("p",{className:"text-sm opacity-70",children:"GitHub and GitLab API tokens are stored securely in your system keychain."})]})]})}),O&&(0,t.jsx)("div",{className:`alert ${"error"===O.tone?"alert-error":"alert-success"} text-sm`,children:O.text}),m?(0,t.jsx)("div",{className:"card bg-base-200 shadow-xl",children:(0,t.jsxs)("div",{className:"card-body items-center py-10",children:[(0,t.jsx)("span",{className:"loading loading-spinner loading-md"}),(0,t.jsx)("p",{className:"text-sm opacity-70",children:"Loading credentials..."})]})}):(0,t.jsxs)("div",{className:"grid grid-cols-1 gap-5 lg:grid-cols-2 items-start",children:[(0,t.jsx)("div",{className:"card bg-base-200 shadow-xl",children:(0,t.jsxs)("div",{className:"card-body space-y-4",children:[(0,t.jsxs)("h2",{className:"card-title flex items-center gap-2",children:[(0,t.jsx)(h,{type:"github"}),"GitHub"]}),(0,t.jsxs)("label",{className:"form-control w-full gap-2",children:[(0,t.jsx)("span",{className:"label-text text-xs uppercase tracking-wide opacity-70",children:"Personal Access Token"}),(0,t.jsx)("input",{type:"password",className:"input input-bordered w-full",placeholder:"ghp_xxx",value:x,onChange:e=>v(e.target.value),disabled:"github"===N})]}),(0,t.jsx)("div",{className:"card-actions justify-end pt-1",children:(0,t.jsxs)("button",{className:"btn btn-primary btn-sm",onClick:()=>void z(),disabled:"github"===N,children:["github"===N?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(o.KeyRound,{className:"h-4 w-4"}),"Add Credential"]})}),(0,t.jsx)("div",{className:"divider my-0"}),0===E.length?(0,t.jsx)("div",{className:"text-sm opacity-60",children:"No GitHub credentials saved."}):(0,t.jsx)("div",{className:"space-y-2",children:E.map(e=>(0,t.jsx)("div",{className:"rounded-md border border-base-300 bg-base-100 p-3",children:(0,t.jsxs)("div",{className:"flex items-center justify-between gap-3",children:[(0,t.jsxs)("div",{className:"min-w-0 flex items-start gap-2",children:[(0,t.jsx)(h,{type:"github"}),(0,t.jsxs)("div",{className:"min-w-0",children:[(0,t.jsx)("div",{className:"text-sm font-medium truncate",children:e.username}),(0,t.jsxs)("div",{className:"text-xs opacity-60",children:["Updated ",new Date(e.updatedAt).toLocaleString()]})]})]}),(0,t.jsxs)("button",{className:"btn btn-error btn-outline btn-xs",onClick:()=>void A(e),disabled:C===e.id,children:[C===e.id?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(d.Trash2,{className:"h-3.5 w-3.5"}),"Delete"]})]})},e.id))})]})}),(0,t.jsx)("div",{className:"card bg-base-200 shadow-xl",children:(0,t.jsxs)("div",{className:"card-body space-y-4",children:[(0,t.jsxs)("h2",{className:"card-title flex items-center gap-2",children:[(0,t.jsx)(h,{type:"gitlab"}),"GitLab"]}),(0,t.jsxs)("label",{className:"form-control w-full gap-2",children:[(0,t.jsx)("span",{className:"label-text text-xs uppercase tracking-wide opacity-70",children:"Server URL"}),(0,t.jsx)("input",{type:"url",className:"input input-bordered w-full",placeholder:p,value:w,onChange:e=>_(e.target.value),disabled:"gitlab"===N})]}),(0,t.jsxs)("label",{className:"form-control w-full gap-2",children:[(0,t.jsx)("span",{className:"label-text text-xs uppercase tracking-wide opacity-70",children:"Personal Access Token"}),(0,t.jsx)("input",{type:"password",className:"input input-bordered w-full",placeholder:"glpat-xxx",value:y,onChange:e=>j(e.target.value),disabled:"gitlab"===N})]}),(0,t.jsx)("div",{className:"card-actions justify-end pt-1",children:(0,t.jsxs)("button",{className:"btn btn-primary btn-sm",onClick:()=>void $(),disabled:"gitlab"===N,children:["gitlab"===N?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(o.KeyRound,{className:"h-4 w-4"}),"Add Credential"]})}),(0,t.jsx)("div",{className:"divider my-0"}),0===M.length?(0,t.jsx)("div",{className:"text-sm opacity-60",children:"No GitLab credentials saved."}):(0,t.jsx)("div",{className:"space-y-2",children:M.map(e=>(0,t.jsx)("div",{className:"rounded-md border border-base-300 bg-base-100 p-3",children:(0,t.jsxs)("div",{className:"flex items-center justify-between gap-3",children:[(0,t.jsxs)("div",{className:"min-w-0 flex items-start gap-2",children:[(0,t.jsx)(h,{type:"gitlab"}),(0,t.jsxs)("div",{className:"min-w-0",children:[(0,t.jsx)("div",{className:"text-sm font-medium truncate",children:e.username}),(0,t.jsx)("div",{className:"text-xs opacity-70 truncate",children:e.serverUrl}),(0,t.jsxs)("div",{className:"text-xs opacity-60",children:["Updated ",new Date(e.updatedAt).toLocaleString()]})]})]}),(0,t.jsxs)("button",{className:"btn btn-error btn-outline btn-xs",onClick:()=>void A(e),disabled:C===e.id,children:[C===e.id?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(d.Trash2,{className:"h-3.5 w-3.5"}),"Delete"]})]})},e.id))})]})})]})]})})}e.s(["default",()=>b],63768)}]);
3
+ Read more: https://nextjs.org/docs/messages/next-image-unconfigured-localpatterns`),"__NEXT_ERROR_CODE",{value:"E871",enumerable:!1,configurable:!0});let n=(0,a.findClosestQuality)(s,e),l=(0,i.getDeploymentId)();return`${e.path}?url=${encodeURIComponent(t)}&w=${r}&q=${n}${t.startsWith("/")&&l?`&dpl=${l}`:""}`}s.__next_img_default=!0;let n=s},18581,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"useMergedRef",{enumerable:!0,get:function(){return i}});let a=e.r(71645);function i(e,t){let r=(0,a.useRef)(null),i=(0,a.useRef)(null);return(0,a.useCallback)(a=>{if(null===a){let e=r.current;e&&(r.current=null,e());let t=i.current;t&&(i.current=null,t())}else e&&(r.current=s(e,a)),t&&(i.current=s(t,a))},[e,t])}function s(e,t){if("function"!=typeof e)return e.current=t,()=>{e.current=null};{let r=e(t);return"function"==typeof r?r:()=>e(null)}}("function"==typeof r.default||"object"==typeof r.default&&null!==r.default)&&void 0===r.default.__esModule&&(Object.defineProperty(r.default,"__esModule",{value:!0}),Object.assign(r.default,r),t.exports=r.default)},5500,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"Image",{enumerable:!0,get:function(){return y}});let a=e.r(55682),i=e.r(90809),s=e.r(43476),n=i._(e.r(71645)),l=a._(e.r(74080)),o=a._(e.r(25633)),d=e.r(8927),c=e.r(87690),u=e.r(18556);e.r(33525);let f=e.r(65856),p=a._(e.r(1948)),m=e.r(18581),g={deviceSizes:[640,750,828,1080,1200,1920,2048,3840],imageSizes:[32,48,64,96,128,256,384],qualities:[75],path:"/_next/image",loader:"default",dangerouslyAllowSVG:!1,unoptimized:!1};function h(e,t,r,a,i,s,n){let l=e?.src;e&&e["data-loaded-src"]!==l&&(e["data-loaded-src"]=l,("decode"in e?e.decode():Promise.resolve()).catch(()=>{}).then(()=>{if(e.parentElement&&e.isConnected){if("empty"!==t&&i(!0),r?.current){let t=new Event("load");Object.defineProperty(t,"target",{writable:!1,value:e});let a=!1,i=!1;r.current({...t,nativeEvent:t,currentTarget:e,target:e,isDefaultPrevented:()=>a,isPropagationStopped:()=>i,persist:()=>{},preventDefault:()=>{a=!0,t.preventDefault()},stopPropagation:()=>{i=!0,t.stopPropagation()}})}a?.current&&a.current(e)}}))}function b(e){return n.use?{fetchPriority:e}:{fetchpriority:e}}"u"<typeof window&&(globalThis.__NEXT_IMAGE_IMPORTED=!0);let x=(0,n.forwardRef)(({src:e,srcSet:t,sizes:r,height:a,width:i,decoding:l,className:o,style:d,fetchPriority:c,placeholder:u,loading:f,unoptimized:p,fill:g,onLoadRef:x,onLoadingCompleteRef:v,setBlurComplete:y,setShowAltText:j,sizesInput:w,onLoad:_,onError:N,...S},C)=>{let P=(0,n.useCallback)(e=>{e&&(N&&(e.src=e.src),e.complete&&h(e,u,x,v,y,p,w))},[e,u,x,v,y,N,p,w]),O=(0,m.useMergedRef)(C,P);return(0,s.jsx)("img",{...S,...b(c),loading:f,width:i,height:a,decoding:l,"data-nimg":g?"fill":"1",className:o,style:d,sizes:r,srcSet:t,src:e,ref:O,onLoad:e=>{h(e.currentTarget,u,x,v,y,p,w)},onError:e=>{j(!0),"empty"!==u&&y(!0),N&&N(e)}})});function v({isAppRouter:e,imgAttributes:t}){let r={as:"image",imageSrcSet:t.srcSet,imageSizes:t.sizes,crossOrigin:t.crossOrigin,referrerPolicy:t.referrerPolicy,...b(t.fetchPriority)};return e&&l.default.preload?(l.default.preload(t.src,r),null):(0,s.jsx)(o.default,{children:(0,s.jsx)("link",{rel:"preload",href:t.srcSet?void 0:t.src,...r},"__nimg-"+t.src+t.srcSet+t.sizes)})}let y=(0,n.forwardRef)((e,t)=>{let r=(0,n.useContext)(f.RouterContext),a=(0,n.useContext)(u.ImageConfigContext),i=(0,n.useMemo)(()=>{let e=g||a||c.imageConfigDefault,t=[...e.deviceSizes,...e.imageSizes].sort((e,t)=>e-t),r=e.deviceSizes.sort((e,t)=>e-t),i=e.qualities?.sort((e,t)=>e-t);return{...e,allSizes:t,deviceSizes:r,qualities:i,localPatterns:"u"<typeof window?a?.localPatterns:e.localPatterns}},[a]),{onLoad:l,onLoadingComplete:o}=e,m=(0,n.useRef)(l);(0,n.useEffect)(()=>{m.current=l},[l]);let h=(0,n.useRef)(o);(0,n.useEffect)(()=>{h.current=o},[o]);let[b,y]=(0,n.useState)(!1),[j,w]=(0,n.useState)(!1),{props:_,meta:N}=(0,d.getImgProps)(e,{defaultLoader:p.default,imgConf:i,blurComplete:b,showAltText:j});return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(x,{..._,unoptimized:N.unoptimized,placeholder:N.placeholder,fill:N.fill,onLoadRef:m,onLoadingCompleteRef:h,setBlurComplete:y,setShowAltText:w,sizesInput:e.sizes,ref:t}),N.preload?(0,s.jsx)(v,{isAppRouter:!r,imgAttributes:_}):null]})});("function"==typeof r.default||"object"==typeof r.default&&null!==r.default)&&void 0===r.default.__esModule&&(Object.defineProperty(r.default,"__esModule",{value:!0}),Object.assign(r.default,r),t.exports=r.default)},94909,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0});var a={default:function(){return c},getImageProps:function(){return d}};for(var i in a)Object.defineProperty(r,i,{enumerable:!0,get:a[i]});let s=e.r(55682),n=e.r(8927),l=e.r(5500),o=s._(e.r(1948));function d(e){let{props:t}=(0,n.getImgProps)(e,{defaultLoader:o.default,imgConf:{deviceSizes:[640,750,828,1080,1200,1920,2048,3840],imageSizes:[32,48,64,96,128,256,384],qualities:[75],path:"/_next/image",loader:"default",dangerouslyAllowSVG:!1,unoptimized:!1}});for(let[e,r]of Object.entries(t))void 0===r&&delete t[e];return{props:t}}let c=l.Image},57688,(e,t,r)=>{t.exports=e.r(94909)},18566,(e,t,r)=>{t.exports=e.r(76562)},27796,e=>{"use strict";var t=e.i(95187);let r=(0,t.createServerReference)("003637a3e46a6432a8c742495ebbd0b128e5fe6652",t.callServer,void 0,t.findSourceMapURL,"listCredentials");e.s(["listCredentials",()=>r])},65261,e=>{"use strict";let t=(0,e.i(75254).default)("key-round",[["path",{d:"M2.586 17.414A2 2 0 0 0 2 18.828V21a1 1 0 0 0 1 1h3a1 1 0 0 0 1-1v-1a1 1 0 0 1 1-1h1a1 1 0 0 0 1-1v-1a1 1 0 0 1 1-1h.172a2 2 0 0 0 1.414-.586l.814-.814a6.5 6.5 0 1 0-4-4z",key:"1s6t7t"}],["circle",{cx:"16.5",cy:"7.5",r:".5",fill:"currentColor",key:"w0ekpg"}]]);e.s(["KeyRound",()=>t],65261)},63768,e=>{"use strict";var t=e.i(43476),r=e.i(27796),a=e.i(95187);let i=(0,a.createServerReference)("4055e131aba0d68ece15f5f518d1c8a236c0571114",a.callServer,void 0,a.findSourceMapURL,"removeCredential"),s=(0,a.createServerReference)("40c5fe5cd6c63784b2007076e2c227d7d1bbab0a4a",a.callServer,void 0,a.findSourceMapURL,"saveGitHubCredential"),n=(0,a.createServerReference)("60cd94298549065ab25bdfea13ed37f08e76f88599",a.callServer,void 0,a.findSourceMapURL,"saveGitLabCredential");var l=e.i(71689),o=e.i(65261),d=e.i(27612),c=e.i(57688),u=e.i(18566),f=e.i(71645);let p="https://gitlab.com",m={github:"https://www.google.com/s2/favicons?domain=github.com&sz=64",gitlab:"https://www.google.com/s2/favicons?domain=gitlab.com&sz=64"};function g(e){return"github"===e?"GitHub":"GitLab"}function h({type:e}){return(0,t.jsx)(c.default,{src:m[e],alt:`${g(e)} icon`,width:20,height:20,className:"h-5 w-5 rounded-sm",unoptimized:!0})}function b(){let e=(0,u.useRouter)(),[a,c]=(0,f.useState)([]),[m,b]=(0,f.useState)(!0),[x,v]=(0,f.useState)(""),[y,j]=(0,f.useState)(""),[w,_]=(0,f.useState)(p),[N,S]=(0,f.useState)(null),[C,P]=(0,f.useState)(null),[O,R]=(0,f.useState)(null),E=(0,f.useMemo)(()=>a.filter(e=>"github"===e.type),[a]),M=(0,f.useMemo)(()=>a.filter(e=>"gitlab"===e.type),[a]),k=async()=>{let e=await (0,r.listCredentials)();if(!e.success){R({tone:"error",text:e.error}),b(!1);return}c(e.credentials),b(!1)};(0,f.useEffect)(()=>{let e=!0;return(async()=>{let t=await (0,r.listCredentials)();if(e){if(!t.success){R({tone:"error",text:t.error}),b(!1);return}c(t.credentials),b(!1)}})(),()=>{e=!1}},[]);let z=async()=>{R(null),S("github");let e=await s(x);if(!e.success){R({tone:"error",text:e.error}),S(null);return}v(""),R({tone:"success",text:"GitHub credential added."}),await k(),S(null)},$=async()=>{R(null),S("gitlab");let e=await n(w,y);if(!e.success){R({tone:"error",text:e.error}),S(null);return}j(""),R({tone:"success",text:"GitLab credential added."}),await k(),S(null)},A=async e=>{let t=g(e.type);if(!confirm(`Delete this ${t} credential for ${"gitlab"===e.type?`${e.username} @ ${e.serverUrl}`:e.username}?`))return;R(null),P(e.id);let r=await i(e.id);if(!r.success){R({tone:"error",text:r.error}),P(null);return}R({tone:"success",text:`${t} credential deleted.`}),await k(),P(null)};return(0,t.jsx)("main",{className:"min-h-screen bg-base-100 p-4 md:p-10",children:(0,t.jsxs)("div",{className:"mx-auto w-full max-w-5xl space-y-5",children:[(0,t.jsx)("div",{className:"flex items-center justify-between",children:(0,t.jsxs)("div",{className:"flex items-center gap-3",children:[(0,t.jsxs)("button",{className:"btn btn-ghost btn-sm",onClick:()=>e.push("/"),children:[(0,t.jsx)(l.ArrowLeft,{className:"h-4 w-4"}),"Back"]}),(0,t.jsxs)("div",{children:[(0,t.jsx)("h1",{className:"text-2xl font-semibold",children:"Credentials"}),(0,t.jsx)("p",{className:"text-sm opacity-70",children:"GitHub and GitLab API tokens are stored securely in your system keychain."})]})]})}),O&&(0,t.jsx)("div",{className:`alert ${"error"===O.tone?"alert-error":"alert-success"} text-sm`,children:O.text}),m?(0,t.jsx)("div",{className:"card bg-base-200 shadow-xl",children:(0,t.jsxs)("div",{className:"card-body items-center py-10",children:[(0,t.jsx)("span",{className:"loading loading-spinner loading-md"}),(0,t.jsx)("p",{className:"text-sm opacity-70",children:"Loading credentials..."})]})}):(0,t.jsxs)("div",{className:"grid grid-cols-1 gap-5 lg:grid-cols-2 items-start",children:[(0,t.jsx)("div",{className:"card bg-base-200 shadow-xl",children:(0,t.jsxs)("div",{className:"card-body space-y-4",children:[(0,t.jsxs)("h2",{className:"card-title flex items-center gap-2",children:[(0,t.jsx)(h,{type:"github"}),"GitHub"]}),(0,t.jsxs)("label",{className:"form-control w-full gap-2",children:[(0,t.jsx)("span",{className:"label-text text-xs uppercase tracking-wide opacity-70",children:"Personal Access Token"}),(0,t.jsx)("input",{type:"password",className:"input input-bordered w-full",placeholder:"ghp_xxx",value:x,onChange:e=>v(e.target.value),disabled:"github"===N})]}),(0,t.jsx)("div",{className:"card-actions justify-end pt-1",children:(0,t.jsxs)("button",{className:"btn btn-primary btn-sm",onClick:()=>void z(),disabled:"github"===N,children:["github"===N?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(o.KeyRound,{className:"h-4 w-4"}),"Add Credential"]})}),(0,t.jsx)("div",{className:"divider my-0"}),0===E.length?(0,t.jsx)("div",{className:"text-sm opacity-60",children:"No GitHub credentials saved."}):(0,t.jsx)("div",{className:"space-y-2",children:E.map(e=>(0,t.jsx)("div",{className:"rounded-md border border-base-300 bg-base-100 p-3",children:(0,t.jsxs)("div",{className:"flex items-center justify-between gap-3",children:[(0,t.jsxs)("div",{className:"min-w-0 flex items-start gap-2",children:[(0,t.jsx)(h,{type:"github"}),(0,t.jsxs)("div",{className:"min-w-0",children:[(0,t.jsx)("div",{className:"text-sm font-medium truncate",children:e.username}),(0,t.jsxs)("div",{className:"text-xs opacity-60",children:["Updated ",new Date(e.updatedAt).toLocaleString()]})]})]}),(0,t.jsxs)("button",{className:"btn btn-error btn-outline btn-xs",onClick:()=>void A(e),disabled:C===e.id,children:[C===e.id?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(d.Trash2,{className:"h-3.5 w-3.5"}),"Delete"]})]})},e.id))})]})}),(0,t.jsx)("div",{className:"card bg-base-200 shadow-xl",children:(0,t.jsxs)("div",{className:"card-body space-y-4",children:[(0,t.jsxs)("h2",{className:"card-title flex items-center gap-2",children:[(0,t.jsx)(h,{type:"gitlab"}),"GitLab"]}),(0,t.jsxs)("label",{className:"form-control w-full gap-2",children:[(0,t.jsx)("span",{className:"label-text text-xs uppercase tracking-wide opacity-70",children:"Server URL"}),(0,t.jsx)("input",{type:"url",className:"input input-bordered w-full",placeholder:p,value:w,onChange:e=>_(e.target.value),disabled:"gitlab"===N})]}),(0,t.jsxs)("label",{className:"form-control w-full gap-2",children:[(0,t.jsx)("span",{className:"label-text text-xs uppercase tracking-wide opacity-70",children:"Personal Access Token"}),(0,t.jsx)("input",{type:"password",className:"input input-bordered w-full",placeholder:"glpat-xxx",value:y,onChange:e=>j(e.target.value),disabled:"gitlab"===N})]}),(0,t.jsx)("div",{className:"card-actions justify-end pt-1",children:(0,t.jsxs)("button",{className:"btn btn-primary btn-sm",onClick:()=>void $(),disabled:"gitlab"===N,children:["gitlab"===N?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(o.KeyRound,{className:"h-4 w-4"}),"Add Credential"]})}),(0,t.jsx)("div",{className:"divider my-0"}),0===M.length?(0,t.jsx)("div",{className:"text-sm opacity-60",children:"No GitLab credentials saved."}):(0,t.jsx)("div",{className:"space-y-2",children:M.map(e=>(0,t.jsx)("div",{className:"rounded-md border border-base-300 bg-base-100 p-3",children:(0,t.jsxs)("div",{className:"flex items-center justify-between gap-3",children:[(0,t.jsxs)("div",{className:"min-w-0 flex items-start gap-2",children:[(0,t.jsx)(h,{type:"gitlab"}),(0,t.jsxs)("div",{className:"min-w-0",children:[(0,t.jsx)("div",{className:"text-sm font-medium truncate",children:e.username}),(0,t.jsx)("div",{className:"text-xs opacity-70 truncate",children:e.serverUrl}),(0,t.jsxs)("div",{className:"text-xs opacity-60",children:["Updated ",new Date(e.updatedAt).toLocaleString()]})]})]}),(0,t.jsxs)("button",{className:"btn btn-error btn-outline btn-xs",onClick:()=>void A(e),disabled:C===e.id,children:[C===e.id?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(d.Trash2,{className:"h-3.5 w-3.5"}),"Delete"]})]})},e.id))})]})})]})]})})}e.s(["default",()=>b],63768)}]);
@@ -0,0 +1 @@
1
+ (globalThis.TURBOPACK||(globalThis.TURBOPACK=[])).push(["object"==typeof document?document.currentScript:void 0,36438,e=>{"use strict";var t=e.i(43476),r=e.i(71645),n=e.i(18566),a=e.i(95187);let s=(0,a.createServerReference)("403aed320e0eb7acc8eaa900651f17911245cc3069",a.callServer,void 0,a.findSourceMapURL,"deleteSessionInBackground"),i=(0,a.createServerReference)("4002630a7d98cbc0f434aaaa3e822ad5e2eefa6ec6",a.callServer,void 0,a.findSourceMapURL,"getSessionDivergence"),l=(0,a.createServerReference)("40604aaf9b60d2572c243e1663750ddb389a4b4706",a.callServer,void 0,a.findSourceMapURL,"getSessionUncommittedFileCount"),o=(0,a.createServerReference)("40ba9705625f99bdd2eac827a6b1a915fcec29bb4f",a.callServer,void 0,a.findSourceMapURL,"listSessionBaseBranches"),c=(0,a.createServerReference)("40c378f4e255af2ea0b4037126d04d07bc7441f3f4",a.callServer,void 0,a.findSourceMapURL,"mergeSessionToBase"),d=(0,a.createServerReference)("4014bdda073dacc18189abb0014f7a38a9ad7c9a6b",a.callServer,void 0,a.findSourceMapURL,"rebaseSessionOntoBase"),u=(0,a.createServerReference)("607435f755f72620c974a3ece9fc6b626c2763c734",a.callServer,void 0,a.findSourceMapURL,"updateSessionBaseBranch"),m=(0,a.createServerReference)("60ca699e13c4ab3777a0d8834c917f1948c6de9319",a.callServer,void 0,a.findSourceMapURL,"writeSessionPromptFile"),h=(0,a.createServerReference)("7f877168be02bb6a00a7d90daa19dbc4e02db717d0",a.callServer,void 0,a.findSourceMapURL,"setTmuxSessionMouseMode"),p=(0,a.createServerReference)("7ff1605c177285fc5f5cc1eaf21a40e996698b5b18",a.callServer,void 0,a.findSourceMapURL,"setTmuxSessionStatusVisibility");var f=e.i(6478),b=e.i(1237),x=e.i(27612),v=e.i(78917),w=e.i(31343),g=e.i(75254);let y=(0,g.default)("git-commit-horizontal",[["circle",{cx:"12",cy:"12",r:"3",key:"1v7zrd"}],["line",{x1:"3",x2:"9",y1:"12",y2:"12",key:"1dyftd"}],["line",{x1:"15",x2:"21",y1:"12",y2:"12",key:"oup4p8"}]]),j=(0,g.default)("git-merge",[["circle",{cx:"18",cy:"18",r:"3",key:"1xkwt0"}],["circle",{cx:"6",cy:"6",r:"3",key:"1lh9wr"}],["path",{d:"M6 21V9a9 9 0 0 0 9 9",key:"7kw0sc"}]]),k=(0,g.default)("git-pull-request-arrow",[["circle",{cx:"5",cy:"6",r:"3",key:"1qnov2"}],["path",{d:"M5 9v12",key:"ih889a"}],["circle",{cx:"19",cy:"18",r:"3",key:"1qljk2"}],["path",{d:"m15 9-3-3 3-3",key:"1lwv8l"}],["path",{d:"M12 6h5a2 2 0 0 1 2 2v7",key:"1yj91y"}]]);var N=e.i(55716);let S=(0,g.default)("arrow-up",[["path",{d:"m5 12 7-7 7 7",key:"hav0vg"}],["path",{d:"M12 19V5",key:"x0mq9r"}]]),C=(0,g.default)("arrow-down",[["path",{d:"M12 5v14",key:"s699le"}],["path",{d:"m19 12-7 7-7-7",key:"1idqje"}]]),$=(0,g.default)("folder-open",[["path",{d:"m6 14 1.5-2.9A2 2 0 0 1 9.24 10H20a2 2 0 0 1 1.94 2.5l-1.54 6a2 2 0 0 1-1.95 1.5H4a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h3.9a2 2 0 0 1 1.69.9l.81 1.2a2 2 0 0 0 1.67.9H18a2 2 0 0 1 2 2v2",key:"usdka0"}]]),R=(0,g.default)("chevron-left",[["path",{d:"m15 18-6-6 6-6",key:"1wnfg3"}]]),E=(0,g.default)("grip",[["circle",{cx:"12",cy:"5",r:"1",key:"gxeob9"}],["circle",{cx:"19",cy:"5",r:"1",key:"w8mnmm"}],["circle",{cx:"5",cy:"5",r:"1",key:"lttvr7"}],["circle",{cx:"12",cy:"12",r:"1",key:"41hilf"}],["circle",{cx:"19",cy:"12",r:"1",key:"1wjl8i"}],["circle",{cx:"5",cy:"12",r:"1",key:"1pcz8c"}],["circle",{cx:"12",cy:"19",r:"1",key:"lyex9k"}],["circle",{cx:"19",cy:"19",r:"1",key:"shf9b7"}],["circle",{cx:"5",cy:"19",r:"1",key:"bfqh0e"}]]),M=(0,g.default)("chevron-down",[["path",{d:"m6 9 6 6 6-6",key:"qrunsl"}]]);var L=e.i(7233);let P=(0,g.default)("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"}]]),T=(0,g.default)("mouse-pointer-2",[["path",{d:"M4.037 4.688a.495.495 0 0 1 .651-.651l16 6.5a.5.5 0 0 1-.063.947l-6.124 1.58a2 2 0 0 0-1.438 1.435l-1.579 6.126a.5.5 0 0 1-.947.063z",key:"edeuup"}]]);var F=e.i(71689);let D=(0,g.default)("arrow-right",[["path",{d:"M5 12h14",key:"1ays0h"}],["path",{d:"m12 5 7 7-7 7",key:"xquz4c"}]]),B=(0,g.default)("rotate-cw",[["path",{d:"M21 12a9 9 0 1 1-9-9c2.52 0 4.93 1 6.74 2.74L21 8",key:"1p45f6"}],["path",{d:"M21 3v5h-5",key:"1q7to0"}]]);var A=e.i(57688),z=e.i(93664);let I=(0,a.createServerReference)("40fa9052f4f49beffccce971da2637bf060b95ff83",a.callServer,void 0,a.findSourceMapURL,"listPathEntries");var U=e.i(65837);let q=(0,g.default)("clipboard",[["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"}]]),W=(0,g.default)("file-text",[["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:"M14 2v5a1 1 0 0 0 1 1h5",key:"wfsgrz"}],["path",{d:"M10 9H8",key:"b1mrlr"}],["path",{d:"M16 13H8",key:"t4e002"}],["path",{d:"M16 17H8",key:"z1uh3a"}]]);var H=e.i(27025);let _=(0,g.default)("grid-2x2",[["path",{d:"M12 3v18",key:"108xh3"}],["path",{d:"M3 12h18",key:"1i2n21"}],["rect",{x:"3",y:"3",width:"18",height:"18",rx:"2",key:"h1oib"}]]),O=(0,g.default)("house",[["path",{d:"M15 21v-8a1 1 0 0 0-1-1h-4a1 1 0 0 0-1 1v8",key:"5wwlr5"}],["path",{d:"M3 10a2 2 0 0 1 .709-1.528l7-6a2 2 0 0 1 2.582 0l7 6A2 2 0 0 1 21 10v9a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z",key:"r6nss1"}]]),K=(0,g.default)("list",[["path",{d:"M3 5h.01",key:"18ugdj"}],["path",{d:"M3 12h.01",key:"nlz23k"}],["path",{d:"M3 19h.01",key:"noohij"}],["path",{d:"M8 5h13",key:"1pao27"}],["path",{d:"M8 12h13",key:"1za7za"}],["path",{d:"M8 19h13",key:"m83p4d"}]]),G=(0,g.default)("pin",[["path",{d:"M12 17v5",key:"bb1du9"}],["path",{d:"M9 10.76a2 2 0 0 1-1.11 1.79l-1.78.9A2 2 0 0 0 5 15.24V16a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-.76a2 2 0 0 0-1.11-1.79l-1.78-.9A2 2 0 0 1 15 10.76V7a1 1 0 0 1 1-1 2 2 0 0 0 0-4H8a2 2 0 0 0 0 4 1 1 0 0 1 1 1z",key:"1nkz8b"}]]),V=(0,g.default)("pin-off",[["path",{d:"M12 17v5",key:"bb1du9"}],["path",{d:"M15 9.34V7a1 1 0 0 1 1-1 2 2 0 0 0 0-4H7.89",key:"znwnzq"}],["path",{d:"m2 2 20 20",key:"1ooewy"}],["path",{d:"M9 9v1.76a2 2 0 0 1-1.11 1.79l-1.78.9A2 2 0 0 0 5 15.24V16a1 1 0 0 0 1 1h11",key:"c9qhm2"}]]);var Y=e.i(81016),X=e.i(43733);let J="viba:session-file-browser:view-mode";function Z({initialPath:e,worktreePath:n,onConfirm:a,onCancel:s,onPathChange:i}){let l=(0,r.useMemo)(()=>new Set([".png",".jpg",".jpeg",".gif",".webp",".bmp",".svg",".ico",".avif"]),[]),[o,c]=(0,r.useState)(""),[d,u]=(0,r.useState)([]),[m,h]=(0,r.useState)(!1),[p,x]=(0,r.useState)(null),[v,w]=(0,r.useState)(""),[g,y]=(0,r.useState)([]),[j,k]=(0,r.useState)(null),[N,S]=(0,r.useState)("list"),[C,$]=(0,r.useState)(!1),[R,E]=(0,r.useState)({}),[M,L]=(0,r.useState)([]);(0,r.useEffect)(()=>{let t=!0;return(async()=>{try{let r=await (0,z.getHomeDirectory)();if(!t)return;w(r),e||c(r)}catch(e){console.error("Failed to resolve home directory:",e)}e&&t&&c(e)})(),()=>{t=!1}},[e]),(0,r.useEffect)(()=>{let e=!0;return(async()=>{try{let t=await (0,f.getConfig)();if(!e)return;let r=Array.isArray(t.pinnedFolderShortcuts)?t.pinnedFolderShortcuts.filter(e=>"string"==typeof e&&e.trim().length>0):[];L(Array.from(new Set(r)))}catch(e){console.error("Failed to load pinned folder shortcuts:",e)}})(),()=>{e=!1}},[]),(0,r.useEffect)(()=>{try{let e=localStorage.getItem(J);("list"===e||"grid"===e)&&S(e)}catch{}finally{$(!0)}},[]),(0,r.useEffect)(()=>{if(C)try{localStorage.setItem(J,N)}catch{}},[C,N]),(0,r.useEffect)(()=>{o&&(async()=>{h(!0),x(null);try{let e=await I(o);u(e)}catch(e){console.error("Failed to list files:",e),x("Failed to load directory contents")}finally{h(!1)}})()},[o]),(0,r.useEffect)(()=>{o&&i?.(o)},[o,i]),(0,r.useEffect)(()=>{y([]),k(null),E({})},[o]);let P=(0,r.useMemo)(()=>new Set(g),[g]),T=(e,t,r)=>{if(e.isDirectory)return void c(e.path);let n=r.metaKey||r.ctrlKey;if(r.shiftKey&&null!==j){let e=Math.min(j,t),r=Math.max(j,t);y(d.slice(e,r+1).filter(e=>!e.isDirectory).map(e=>e.path));return}if(n){y(t=>t.includes(e.path)?t.filter(t=>t!==e.path):[...t,e.path]),k(t);return}y([e.path]),k(t)},D=async()=>{if(x(null),!n)return void x("Cannot paste: Session worktree path is missing.");try{if(h(!0),!navigator.clipboard||!navigator.clipboard.read)throw Error("Clipboard API not supported in this browser");let e=await navigator.clipboard.read(),t=new FormData,r=!1;for(let n of e)for(let e of n.types)if(e.startsWith("image/")){let a=await n.getType(e),s=e.split("/")[1]||"png",i=`pasted-image-${Date.now()}.${s}`,l=new File([a],i,{type:e});t.append(i,l),r=!0;break}if(r){let e=await (0,U.saveAttachments)(n,t);if(e&&e.length>0)return void await a(e);x("Failed to save pasted files.")}else try{let e=await navigator.clipboard.readText();e&&e.trim().startsWith("/")?x("No file content found in clipboard. Copy an image or file first."):x("No file content found in clipboard.")}catch{x("No file content found in clipboard.")}}catch(t){let e=t instanceof Error?t.message:String(t);console.error("Paste error:",t),x(`Failed to read from clipboard: ${e}`)}finally{h(!1)}},B=async e=>{L(e);try{await (0,b.updateConfig)({pinnedFolderShortcuts:e})}catch(e){console.error("Failed to save pinned folder shortcuts:",e),x("Failed to save pinned shortcuts")}},Z=async e=>{(x(null),M.includes(e))?await B(M.filter(t=>t!==e)):await B([...M,e])},Q=(0,r.useCallback)(async()=>{0!==g.length&&await a(g)},[a,g]);return(0,X.useDialogKeyboardShortcuts)({onConfirm:Q,onDismiss:s,canConfirm:g.length>0}),(0,t.jsx)("div",{className:"fixed inset-0 z-50 flex items-center justify-center bg-black/50 backdrop-blur-sm p-4",children:(0,t.jsxs)("div",{className:"bg-base-200 rounded-lg shadow-xl w-full max-w-5xl h-[82vh] flex flex-col",children:[(0,t.jsxs)("div",{className:"flex items-center justify-between p-4 border-b border-base-300",children:[(0,t.jsxs)("h2",{className:"text-xl font-bold flex items-center gap-2",children:[(0,t.jsx)(H.Folder,{className:"w-5 h-5"}),"Browse Files"]}),(0,t.jsx)("button",{onClick:s,className:"btn btn-sm btn-ghost btn-circle",title:"Close file browser",children:"✕"})]}),(0,t.jsxs)("div",{className:"flex items-center gap-2 p-3 bg-base-300",children:[(0,t.jsx)("button",{onClick:()=>{let e=(0,Y.getDirName)(o);e&&e!==o&&c(e)},className:"btn btn-sm btn-square btn-ghost",title:"Go Up",disabled:"/"===o||!o,children:(0,t.jsx)(F.ArrowLeft,{className:"w-4 h-4"})}),(0,t.jsxs)("button",{onClick:()=>{v&&o!==v&&c(v)},className:"btn btn-sm btn-ghost gap-1",title:v?`Go to Home Folder (${v})`:"Go to Home Folder",disabled:!v||o===v,children:[(0,t.jsx)(O,{className:"w-4 h-4"}),"Home"]}),(0,t.jsx)("div",{className:"flex-1 overflow-x-auto whitespace-nowrap px-2 font-mono text-sm",children:o}),(0,t.jsxs)("div",{className:"join",children:[(0,t.jsx)("button",{type:"button",onClick:()=>S("list"),className:`btn btn-sm join-item ${"list"===N?"btn-active":"btn-ghost"}`,title:"List view",children:(0,t.jsx)(K,{className:"w-4 h-4"})}),(0,t.jsx)("button",{type:"button",onClick:()=>S("grid"),className:`btn btn-sm join-item ${"grid"===N?"btn-active":"btn-ghost"}`,title:"Grid view",children:(0,t.jsx)(_,{className:"w-4 h-4"})})]}),(0,t.jsxs)("button",{onClick:Q,className:"btn btn-sm btn-primary gap-2",disabled:0===g.length,title:"Insert selected absolute paths",children:["Insert (",g.length,")"]}),(0,t.jsx)("div",{className:"w-[1px] h-6 bg-base-content/10 mx-1"}),(0,t.jsxs)("button",{onClick:D,className:"btn btn-sm btn-ghost gap-2",title:"Paste file/image from clipboard",disabled:!n,children:[(0,t.jsx)(q,{className:"w-4 h-4"}),"Paste"]})]}),M.length>0&&(0,t.jsx)("div",{className:"px-3 py-2 border-b border-base-300 bg-base-200/50",children:(0,t.jsx)("div",{className:"flex items-center gap-2 overflow-x-auto",children:M.map(e=>{let r=e===o,n=e.split(/[\\/]/).filter(Boolean).pop()||e;return(0,t.jsxs)("div",{className:"join shrink-0",children:[(0,t.jsxs)("button",{type:"button",className:`btn btn-xs join-item ${r?"btn-primary":"btn-ghost"}`,onClick:()=>c(e),title:e,children:[(0,t.jsx)(H.Folder,{className:"w-3 h-3"}),n]}),(0,t.jsx)("button",{type:"button",className:"btn btn-xs btn-ghost join-item",onClick:()=>void Z(e),title:`Unpin ${e}`,children:(0,t.jsx)(V,{className:"w-3 h-3"})})]},e)})})}),(0,t.jsx)("div",{className:"flex-1 overflow-y-auto p-2",children:m?(0,t.jsx)("div",{className:"flex justify-center items-center h-full",children:(0,t.jsx)("span",{className:"loading loading-spinner loading-lg"})}):p?(0,t.jsx)("div",{className:"alert alert-error",children:p}):0===d.length?(0,t.jsx)("div",{className:"text-center text-base-content/50 mt-10",children:"Empty directory"}):"list"===N?(0,t.jsx)("div",{className:"grid grid-cols-1 gap-1",children:d.map((e,r)=>{let n=P.has(e.path);return(0,t.jsxs)("div",{className:`flex items-center justify-between p-2 rounded-md cursor-pointer transition-colors border ${n?"bg-primary text-primary-content border-primary":"hover:bg-base-100 border-transparent"}`,onClick:t=>T(e,r,t),title:e.path,children:[(0,t.jsxs)("div",{className:"flex items-center gap-3 overflow-hidden",children:[e.isDirectory?(0,t.jsx)(H.Folder,{className:"w-5 h-5 shrink-0"}):(0,t.jsx)(W,{className:"w-5 h-5 shrink-0"}),(0,t.jsx)("span",{className:"truncate",children:e.name})]}),(0,t.jsx)("span",{className:"text-[10px] opacity-70 shrink-0",children:e.isDirectory?(0,t.jsx)("button",{type:"button",className:"btn btn-ghost btn-xs h-6 min-h-6",onClick:t=>{t.stopPropagation(),Z(e.path)},title:M.includes(e.path)?"Unpin folder":"Pin folder",children:(0,t.jsx)(G,{className:`w-3 h-3 ${M.includes(e.path)?"fill-current":""}`})}):"file"})]},e.path)})}):(0,t.jsx)("div",{className:"grid grid-cols-2 md:grid-cols-4 lg:grid-cols-5 gap-3",children:d.map((e,r)=>{var n;let a,s=P.has(e.path),i=!e.isDirectory&&-1!==(a=(n=e.name).lastIndexOf("."))&&l.has(n.slice(a).toLowerCase()),o=`/api/file-thumbnail?path=${encodeURIComponent(e.path)}`;return(0,t.jsxs)("button",{type:"button",className:`rounded-lg border text-left overflow-hidden transition-colors ${s?"border-primary bg-primary/15":"border-base-300 hover:bg-base-100"}`,onClick:t=>T(e,r,t),title:e.path,children:[(0,t.jsxs)("div",{className:"aspect-square bg-base-300 flex items-center justify-center overflow-hidden relative",children:[i&&!R[e.path]?(0,t.jsx)(A.default,{src:o,alt:e.name,fill:!0,sizes:"(max-width: 768px) 50vw, (max-width: 1024px) 25vw, 20vw",className:"object-cover",unoptimized:!0,onError:()=>E(t=>({...t,[e.path]:!0}))}):e.isDirectory?(0,t.jsx)(H.Folder,{className:"w-10 h-10 opacity-80"}):(0,t.jsx)(W,{className:"w-10 h-10 opacity-80"}),e.isDirectory&&(0,t.jsx)("button",{type:"button",className:`absolute top-1 right-1 btn btn-xs btn-circle ${M.includes(e.path)?"btn-primary":"btn-ghost bg-base-100/70"}`,onClick:t=>{t.stopPropagation(),Z(e.path)},title:M.includes(e.path)?"Unpin folder":"Pin folder",children:(0,t.jsx)(G,{className:`w-3 h-3 ${M.includes(e.path)?"fill-current":""}`})})]}),(0,t.jsxs)("div",{className:"px-2 py-2",children:[(0,t.jsx)("div",{className:"truncate text-sm font-medium",title:e.name,children:e.name}),(0,t.jsx)("div",{className:"text-[10px] opacity-70",children:e.isDirectory?"folder":i?"image":"file"})]})]},e.path)})})}),(0,t.jsx)("div",{className:"p-3 border-t border-base-300 text-xs text-base-content/60 text-center",children:"Click: single select. Cmd/Ctrl+Click: multi-select. Shift+Click: range select. Click a folder to open it."})]})})}var Q=e.i(63671);function ee(e,t,r){var n,a;let s=(n=e,a=t,`viba-${(n.trim().replace(/[^a-zA-Z0-9_-]/g,"-")||"session").slice(0,40)}-${a}`),i=new URLSearchParams;return i.append("arg","new-session"),r?.value&&(i.append("arg","-e"),i.append("arg",`${r.name}=${r.value}`)),i.append("arg","-A"),i.append("arg","-s"),i.append("arg",s),`/terminal?${i.toString()}`}let et=e=>{let t=e.trim();return t?/^https?:\/\//i.test(t)?t:/^[a-z][a-z0-9+.-]*:/i.test(t)?null:`http://${t}`:null},er=e=>`'${e.replace(/'/g,"'\\''")}'`,en=[{id:"vscode",name:"VS Code",protocol:"vscode"},{id:"cursor",name:"Cursor",protocol:"cursor"},{id:"windsurf",name:"Windsurf",protocol:"windsurf"},{id:"antigravity",name:"Antigravity",protocol:"antigravity"}],ea="viba-terminal-size",es="viba-agent-preview-split-ratio",ei="__vibaTerminalBootstrapRegistry",el=/(?:\$|%|#|>) $/,eo=e=>Math.max(.2,Math.min(.8,e)),ec=(e,t)=>{let r=e.replace(/\\/g,"/").replace(/\/+$/,""),n=t.replace(/\\/g,"/").replace(/^\/+/,"");return`${r}/${n}`},ed=(e,t)=>{let r=t.trim().replace(/\\/g,"/").replace(/\/+$/,"");if(!r)return null;let n=(e=>{let t=e.trim();if(!t)return"";if(t=t.replace(/[#?].*$/,""),/^file:\/\//i.test(t))try{let e=new URL(t);t=decodeURIComponent(e.pathname)}catch{}else if(/^https?:\/\//i.test(t))try{let e=new URL(t);t=decodeURIComponent(e.pathname)}catch{}return(t=t.replace(/^webpack(?:-internal)?:\/\/\/?/,"").replace(/^rsc:\/\//,"").replace(/^\(.*?\)\//,"").replace(/^\/\.\//,"/").replace(/^\.\//,"").replace(/\\/g,"/")).trim()})(e);if(!n)return null;if(n.startsWith("/")||(0,Y.isWindowsAbsolutePath)(n))return n;let a=new Set;a.add(n.replace(/^\.\/+/,""));let s=n.indexOf("/src/");for(let e of(s>=0&&a.add(n.slice(s+1)),n.startsWith("src/")&&a.add(n),a))if(e)return ec(r,e);return null},eu=e=>{let t=e.trim();if(!t)return"";let r=t.match(/[A-Za-z_$][\w$]*/);return r?r[0]:""};function em({repo:e,worktree:n,branch:a,baseBranch:g,sessionName:A,agent:z,model:I,startupScript:U,devServerScript:q,initialMessage:W,attachmentNames:H,title:_,sessionMode:O="fast",onExit:K,isResume:G,terminalPersistenceMode:V="shell",onSessionStart:X,agentTerminalSrc:J,floatingTerminalSrc:ec}){let em="hidden min-[1900px]:inline",eh=(0,r.useRef)(null),ep=(0,r.useRef)(null),ef=(0,r.useRef)(null),eb=(0,r.useRef)(null),ex=(0,r.useRef)(null),ev=(0,r.useRef)({startX:0,startRatio:.5}),ew=(0,r.useRef)(null),eg=(0,r.useRef)(null),ey=(0,r.useRef)(null),ej=(0,r.useRef)({injected:!1,timer:null}),ek=(0,r.useMemo)(()=>J||ee(A,"agent"),[J,A]),eN=(0,r.useMemo)(()=>ec||ee(A,"terminal"),[ec,A]),eS=(0,r.useRef)({agent:"idle",terminal:"idle"}),eC=(0,r.useRef)({agent:!1,terminal:!1});(0,r.useEffect)(()=>{eS.current={agent:"idle",terminal:"idle"},eC.current={agent:!1,terminal:!1},null!==ej.current.timer&&window.clearTimeout(ej.current.timer),ej.current={injected:!1,timer:null}},[A]),(0,r.useEffect)(()=>()=>{null!==ej.current.timer&&(window.clearTimeout(ej.current.timer),ej.current.timer=null)},[]);let e$=(0,r.useCallback)(e=>`viba:terminal-bootstrap:${A}:${e}`,[A]),eR=(0,r.useCallback)(e=>`${A}:${e}`,[A]),eE=(0,r.useCallback)(()=>{let e=window;return e[ei]||(e[ei]={}),e[ei]||null},[]),eM=(0,r.useCallback)(e=>{let t=eE();return t&&t[eR(e)]||"idle"},[eE,eR]),eL=(0,r.useCallback)((e,t)=>{let r=eE();r&&(r[eR(e)]=t)},[eE,eR]),eP=(0,r.useCallback)(e=>{if("done"===eS.current[e]||"done"===eM(e))return!0;try{return"1"===window.sessionStorage.getItem(e$(e))}catch{return!1}},[eM,e$]),eT=(0,r.useCallback)(e=>{let t=eS.current[e],r=eM(e);return"done"!==t&&"in_progress"!==t&&"done"!==r&&"in_progress"!==r&&(eS.current[e]="in_progress",eL(e,"in_progress"),!0)},[eM,eL]),eF=(0,r.useCallback)(e=>{"done"!==eS.current[e]&&(eS.current[e]="idle"),"done"!==eM(e)&&eL(e,"idle")},[eM,eL]),eD=(0,r.useCallback)(e=>{eS.current[e]="done",eL(e,"done");try{window.sessionStorage.setItem(e$(e),"1")}catch{}},[e$,eL]),eB=(0,r.useCallback)(e=>{let t=e?.buffer?.active;if(!t||"function"!=typeof t.getLine)return!0;let r=t.baseY+t.cursorY;for(let e=0;e<6;e+=1){let n=t.getLine(r-e),a=n?.translateToString(!0)??"";if(a.trim())return el.test(a)}return!1},[]),eA=(0,r.useCallback)(()=>{ey.current&&(ey.current(),ey.current=null)},[]),ez=(0,r.useCallback)((e,t)=>{eA();let r=!1,n=null,a=null,s=null,i=()=>{if(r)return;let e=!eB(t);eY(t=>t===e?t:e)};i(),s=window.setInterval(i,1e3);try{if("function"==typeof t.onWriteParsed)n=t.onWriteParsed(i)||null;else{let t=e.contentDocument?.querySelector(".xterm-screen")||e.contentDocument?.body;t&&(a=new MutationObserver(i)).observe(t,{childList:!0,subtree:!0,characterData:!0})}}catch(e){console.error("Failed to setup terminal process monitor:",e)}ey.current=()=>{r=!0,null!==s&&(window.clearInterval(s),s=null),n&&"function"==typeof n.dispose&&n.dispose(),a?.disconnect()}},[eB,eA]);(0,r.useEffect)(()=>()=>{eA()},[eA]),(0,r.useEffect)(()=>{eY(!1),eA()},[A,eA]);let eI=(0,r.useCallback)((e,t,r)=>{if(G)return!1;let n=U?.trim();return!!n&&!ej.current.injected&&(ej.current.injected=!0,null!==ej.current.timer&&window.clearTimeout(ej.current.timer),ej.current.timer=window.setTimeout(()=>{ej.current.timer=null;try{let a;r.paste(n),(a=e.contentDocument?.querySelector("textarea.xterm-helper-textarea"))?a.dispatchEvent(new KeyboardEvent("keypress",{bubbles:!0,cancelable:!0,charCode:13,keyCode:13,key:"Enter",view:t})):r.paste("\r")}catch(e){ej.current.injected=!1,console.error("Failed to inject startup script into terminal iframe:",e)}},500),!0)},[G,U]);(0,r.useEffect)(()=>{if(G||!U?.trim()||ej.current.injected)return;let e=!1,t=(r=0)=>{if(e||ej.current.injected||r>30)return;if(!eP("terminal"))return void window.setTimeout(()=>t(r+1),200);let n=ep.current;if(n){try{let e=n.contentWindow;if(e?.term)return void eI(n,e,e.term)}catch{}window.setTimeout(()=>t(r+1),200)}};return t(),()=>{e=!0}},[eP,eI,G,U]);let[eU,eq]=(0,r.useState)("Initializing..."),[eW,eH]=(0,r.useState)("idle"),[e_,eO]=(0,r.useState)(null),[eK,eG]=(0,r.useState)(!1),[eV,eY]=(0,r.useState)(!1),[eX,eJ]=(0,r.useState)(!1),[eZ,eQ]=(0,r.useState)(!1),[e0,e1]=(0,r.useState)(!1),[e2,e3]=(0,r.useState)(!1),[e4,e6]=(0,r.useState)(n||e),[e5,e7]=(0,r.useState)(!1),[e9,e8]=(0,r.useState)(g?.trim()||""),[te,tt]=(0,r.useState)([]),[tr,tn]=(0,r.useState)(!1),ta=(0,r.useRef)(!1),[ts,ti]=(0,r.useState)(!1),[tl,to]=(0,r.useState)({ahead:0,behind:0}),[tc,td]=(0,r.useState)(0),[tu,tm]=(0,r.useState)(!1),[th,tp]=(0,r.useState)(""),[tf,tb]=(0,r.useState)(""),[tx,tv]=(0,r.useState)(!1),[tw,tg]=(0,r.useState)(!1),[ty,tj]=(0,r.useState)(.5),[tk,tN]=(0,r.useState)(!1),[tS,tC]=(0,r.useState)(!0),[t$,tR]=(0,r.useState)({width:460,height:320}),[tE,tM]=(0,r.useState)(!1),[tL,tP]=(0,r.useState)(!1),tT=(0,r.useRef)({startX:0,startY:0,startWidth:0,startHeight:0}),[tF,tD]=(0,r.useState)("scroll"),[tB,tA]=(0,r.useState)(!1),tz=(0,r.useRef)(0);(0,r.useEffect)(()=>{e6(n||e)},[e,n]),(0,r.useEffect)(()=>{let e=localStorage.getItem(ea);if(e)try{tR(JSON.parse(e))}catch(e){console.error("Failed to parse saved terminal size",e)}let t=localStorage.getItem(es);if(t){let e=Number.parseFloat(t);Number.isNaN(e)||tj(eo(e))}tP(!0)},[]),(0,r.useEffect)(()=>{if(!tE)return;let e=e=>{let t=tT.current.startX-e.clientX,r=tT.current.startY-e.clientY;tR({width:Math.max(300,Math.min(window.innerWidth-32,tT.current.startWidth+t)),height:Math.max(100,Math.min(window.innerHeight-32,tT.current.startHeight+r))})},t=()=>{tM(!1)};return window.addEventListener("mousemove",e),window.addEventListener("mouseup",t),()=>{window.removeEventListener("mousemove",e),window.removeEventListener("mouseup",t)}},[tE]),(0,r.useEffect)(()=>{tL&&!tE&&localStorage.setItem(ea,JSON.stringify(t$))},[tL,tE,t$]),(0,r.useEffect)(()=>{tL&&!tk&&localStorage.setItem(es,String(ty))},[ty,tL,tk]),(0,r.useEffect)(()=>{if(!tk)return;let e=e=>{let t=ex.current;if(!t)return;let r=t.getBoundingClientRect();if(r.width<=0)return;let n=e.clientX-ev.current.startX;tj(eo((ev.current.startRatio*r.width+n)/r.width))},t=()=>{tN(!1)};return window.addEventListener("mousemove",e),window.addEventListener("mouseup",t),()=>{window.removeEventListener("mousemove",e),window.removeEventListener("mouseup",t)}},[tk]),(0,r.useEffect)(()=>{if(!tS&&ep.current){let e=ep.current;setTimeout(()=>{try{let t=e.contentWindow;if(t&&t.term){t.term.scrollToBottom?.(),t.focus();let r=e.contentDocument?.querySelector("textarea.xterm-helper-textarea");r&&r.focus()}}catch(e){console.error("Failed to focus/scroll terminal on restore:",e)}},100)}},[tS]);let[tI,tU]=(0,r.useState)("vscode");(0,r.useEffect)(()=>{let e=_?.trim();if(e)return document.title=`${e} | Viba`,()=>{document.title="Viba"};document.title="Viba"},[_]),(0,r.useEffect)(()=>{(async()=>{let e=await (0,f.getConfig)();e.selectedIde&&en.some(t=>t.id===e.selectedIde)&&tU(e.selectedIde)})()},[]),(0,r.useEffect)(()=>{e8(g?.trim()||""),tt([])},[g,A]),(0,r.useEffect)(()=>{tD("scroll"),tA(!1),tz.current+=1},[A]);let tq=async e=>{let t=e.target.value;tU(t),await (0,b.updateConfig)({selectedIde:t})},tW=(0,r.useCallback)(async(e,t)=>{if("tmux"!==V)return!0;let r=++tz.current;t?.silent||tA(!0);let n="scroll"===e,[a,s]=await Promise.all([h(A,"agent",n),h(A,"terminal",n)]);return r===tz.current&&((t?.silent||tA(!1),[a,s].find(e=>!e.success))?(t?.silent||eq(`Failed to switch to ${"scroll"===e?"scroll mode":"text select mode"}`),!1):(t?.silent||eq("scroll"===e?"Terminal mode: Scroll":"Terminal mode: Text Select"),!0))},[A,V]),tH=(0,r.useCallback)(e=>{"tmux"!==V||eC.current[e]||(async()=>{let t=await p(A,e,!1);t.success&&t.applied?eC.current[e]=!0:t.success||console.error(`Failed to hide tmux status bar for ${e}:`,t.error)})()},[A,V]);(0,r.useEffect)(()=>{"tmux"===V&&tW("scroll",{silent:!0})},[tW,V]);let t_=(0,r.useCallback)(()=>{if("tmux"!==V||tB)return;let e="scroll"===tF?"select":"scroll";tD(e),(async()=>{await tW(e)||tD(tF)})()},[tW,tB,tF,V]),tO=async(t=!0)=>{if(!e||!n||!a||t&&!confirm("Are you sure you want to delete this session? This will remove the branch and worktree."))return!1;eO(null),eH("idle"),eq("Purging session...");try{let e=await s(A);if(!e.success)return console.error("Cleanup failed:",e.error||"Unknown error"),eH("error"),eO(e.error||"Failed to delete session"),!1;(0,Q.notifySessionsUpdated)()}catch(e){return console.error("Cleanup request failed:",e),eH("error"),eO(e instanceof Error?e.message:"Unknown error"),!1}return K(!0),!0},tK=async()=>{await tO(!0)},tG=(0,r.useCallback)((e,t)=>new Promise(r=>{let n=eh.current;if(!n)return void r(!1);let s=(i=0)=>{if(i>30)return void r(!1);try{let l=n.contentWindow;if(!l||(l.postMessage({type:"viba:agent-request",action:t,prompt:e,sessionName:A,branch:a,baseBranch:e9||void 0,timestamp:Date.now()},"*"),!l.term))return void setTimeout(()=>s(i+1),300);l.term.paste(e);let o=n.contentDocument?.querySelector("textarea.xterm-helper-textarea");o?(o.dispatchEvent(new KeyboardEvent("keypress",{bubbles:!0,cancelable:!0,charCode:13,keyCode:13,key:"Enter",view:l})),o.focus()):l.term.paste("\r"),l.focus(),r(!0)}catch(e){console.error("Failed to send prompt to agent iframe:",e),setTimeout(()=>s(i+1),300)}};s()}),[a,e9,A]),tV=async()=>{eJ(!0),eq("Requesting commit from agent..."),eq(await tG("Please create a git commit with the current changes in this worktree.","commit")?"Commit request sent to agent":"Failed to send commit request to agent"),eJ(!1)},tY=(0,r.useCallback)(e=>new Promise(t=>{let r=eh.current;if(!r)return void t(!1);let n=(a=0)=>{if(a>30)return void t(!1);try{let s=r.contentWindow;if(!s||!s.term)return void setTimeout(()=>n(a+1),300);s.term.paste(e);let i=r.contentDocument?.querySelector("textarea.xterm-helper-textarea");i&&i.focus(),s.focus(),t(!0)}catch(e){console.error("Failed to paste into agent iframe:",e),setTimeout(()=>n(a+1),300)}};n()}),[]),tX=(0,r.useCallback)(async e=>{if(0===e.length)return;e7(!0);let t=`${e.join(" ")} `;eq(await tY(t)?`Inserted ${e.length} file path${1===e.length?"":"s"} into agent input`:"Failed to insert file paths into agent input"),e7(!1)},[tY]),tJ=(0,r.useCallback)(async t=>{let r=t.map(eu).filter(Boolean);if(0===r.length)return null;let a=Array.from(new Set([e,n].map(e=>(e||"").trim()).filter(Boolean)));if(0===a.length)return null;for(let e of a)try{let t=await fetch("/api/component-source/resolve",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({componentNames:r,workspaceRoot:e})}),n=await t.json().catch(()=>null);if(!t.ok){console.warn("Component source resolve miss",{componentNames:r,workspaceRoot:e,error:n?.error||t.statusText});continue}let a="string"==typeof n?.sourcePath?n.sourcePath.trim():"",s="string"==typeof n?.resolvedName?n.resolvedName.trim():"";if(a&&s)return{sourcePath:a,resolvedName:s}}catch(e){console.error("Failed to resolve component source path:",e)}return null},[e,n]),tZ=(0,r.useCallback)(async()=>{if(A&&!ta.current){ta.current=!0,tn(!0);try{let e=await o(A);e.success?(tt(e.branches??[]),e8(e.baseBranch?.trim()||"")):e.error&&eq(`Failed to load branches: ${e.error}`)}catch(e){console.error("Failed to load base branches:",e)}finally{ta.current=!1,tn(!1)}}},[A]);(0,r.useEffect)(()=>{A&&tZ()},[tZ,A]);let tQ=(0,r.useCallback)(async()=>{if(A)try{let e=await i(A);e.success&&"number"==typeof e.ahead&&"number"==typeof e.behind&&to({ahead:e.ahead,behind:e.behind})}catch(e){console.error("Failed to load branch divergence:",e)}},[A]);(0,r.useEffect)(()=>{if(!A||!e9)return void to({ahead:0,behind:0});tQ();let e=window.setInterval(()=>{tQ()},6e4);return()=>window.clearInterval(e)},[e9,tQ,A]);let t0=(0,r.useCallback)(async()=>{if(A)try{let e=await l(A);e.success&&"number"==typeof e.count&&td(e.count)}catch(e){console.error("Failed to load uncommitted file count:",e)}},[A]);(0,r.useEffect)(()=>{if(!A)return;t0();let e=window.setInterval(()=>{t0()},1e4);return()=>window.clearInterval(e)},[t0,A]);let t1=async()=>{if(!A||!e9)return!1;eQ(!0),eq("Merging session branch...");try{let e=await c(A);if(e.success)return eq(`Merged ${e.branchName} into ${e.baseBranch}`),tQ(),!0;return eq(`Merge failed: ${e.error}`),!1}catch(e){return console.error("Merge request failed:",e),eq("Merge failed"),!1}finally{eQ(!1)}},t2=async()=>{await t1()},[t3,t4]=(0,r.useState)(!1),t6=(0,r.useRef)(null);(0,r.useEffect)(()=>{let e=e=>{t6.current&&!t6.current.contains(e.target)&&t4(!1)};return document.addEventListener("mousedown",e),()=>document.removeEventListener("mousedown",e)},[]);let t5=async e=>{if(t4(!1),!A)return;let t=e!==e9;e1(!0),eq(t?`Updating base to ${e} and rebasing...`:"Rebasing session branch...");try{if(t){let t=await u(A,e);if(!t.success){eq(`Failed to update base branch: ${t.error}`),e1(!1);return}e8(t.baseBranch),await tZ()}let r=await d(A);r.success?(eq(`Rebased ${r.branchName} onto ${r.baseBranch}`),tQ()):eq(`Rebase failed: ${r.error}`)}catch(e){console.error("Rebase request failed:",e),eq("Rebase failed")}finally{e1(!1)}},t7=(0,r.useCallback)(async(e,t)=>{let r=et(e);if(!r)return eq("Please enter a preview URL"),!1;tp(r),tv(!1),eq(`Loading preview: ${r}`);try{let e=await fetch("/api/preview-proxy/start",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({target:r})}),n=await e.json().catch(()=>null);if(!e.ok||!n?.proxyUrl)throw Error(n?.error||"Failed to start preview proxy");return tb(n.proxyUrl),t&&tm(!0),eq(`Loaded preview: ${r}`),!0}catch(t){let e=t instanceof Error?t.message:"Failed to load preview";return console.error("Failed to load preview via proxy:",t),eq(`Failed to load preview: ${e}`),!1}},[]),t9=(0,r.useCallback)(()=>{if(!tf)return void eq("Load a preview before picking elements");let e=ef.current?.contentWindow;if(!e)return void eq("Preview is not ready yet");let t=!tx;e.postMessage({type:"viba:preview-picker-toggle",active:t},"*"),tv(t),eq(t?"Picker enabled: click an element in the preview":"Picker disabled")},[tx,tf]),t8=(0,r.useCallback)(e=>{let t=ef.current?.contentWindow;return t?(t.postMessage(e,"*"),!0):(eq("Preview is not ready yet"),!1)},[]),re=(0,r.useCallback)(e=>{tf?t8({type:"viba:preview-navigation",action:e})&&"reload"===e&&eq("Reloading preview..."):eq("Load a preview before using navigation controls")},[t8,tf]),rt=(0,r.useCallback)(()=>{t8({type:"viba:preview-location-request"})},[t8]),{attachTerminalLinkHandler:rr}=function({onLoadPreview:e}){let t=(0,r.useCallback)((t,r)=>{let n=et(t);return!!n&&("new_tab"===r?window.open(n,"_blank","noopener,noreferrer"):e(n,!0),!0)},[e]),n=(0,r.useCallback)((e,r,n)=>{r.current?.();let a=e.contentWindow,s=a?.term;if(!a||!s)return;let i=n?.onLinkActivated,l=n?.directOpenBehavior??"preview",o=n?.modifierOpenBehavior??"new_tab",c=e=>e?o:l,d=[],u=e.contentDocument,m={metaKey:!1,ctrlKey:!1,at:0};if(u){let e=e=>{m={metaKey:e.metaKey,ctrlKey:e.ctrlKey,at:Date.now()}};u.addEventListener("mousedown",e,!0),u.addEventListener("click",e,!0),d.push(()=>{u.removeEventListener("mousedown",e,!0),u.removeEventListener("click",e,!0)})}let h=a.open.bind(a);a.open=(...e)=>{let r=c(Date.now()-m.at<1e3&&(m.metaKey||m.ctrlKey));if("string"==typeof e[0]&&e[0].trim())return(i?.(),t(e[0],r))?null:h(...e);if(0===e.length){let e=null;return{opener:null,location:{set href(url){if(i?.(),!t(url,r)&&(e=h())){try{e.opener=null}catch{}e.location.href=url}},get href(){return""}}}}return h(...e)},d.push(()=>{a.open=h});let p=s._core?._linkProviderService?.linkProviders;if(p instanceof Map){for(let e of p.values())if(e&&"object"==typeof e){if("function"==typeof e._handler){let r=e._handler;e._handler=(e,n)=>{i?.(),t(n,c(!!(e?.metaKey||e?.ctrlKey)))||r(e,n)},d.push(()=>{e._handler=r})}if("function"==typeof e.provideLinks){let r=e.provideLinks.bind(e);e.provideLinks=(e,n)=>{r(e,e=>{if(Array.isArray(e))for(let r of e){if(!r||"object"!=typeof r||"function"!=typeof r.activate)continue;let e=r.activate.bind(r);r.activate=(r,n)=>{i?.(),t(n,c(!!(r?.metaKey||r?.ctrlKey)))||e(r,n)}}n(e)})},d.push(()=>{e.provideLinks=r})}}}let f=s.options.linkHandler,b={allowNonHttpProtocols:f?.allowNonHttpProtocols??!1,activate:(e,r,n)=>{i?.(),t(r,c(!!(e?.metaKey||e?.ctrlKey)))||f?.activate?.(e,r,n)},hover:(e,t,r)=>{f?.hover?.(e,t,r)},leave:(e,t,r)=>{f?.leave?.(e,t,r)}};s.options.linkHandler=b,d.push(()=>{s.options.linkHandler=f??null}),r.current=()=>{for(let e of d)e();r.current=null}},[t]);return{handleTerminalLinkOpen:t,attachTerminalLinkHandler:n}}({onLoadPreview:t7});if((0,r.useEffect)(()=>{if(!tu||th.trim())return;let e=window.setTimeout(()=>{eb.current?.focus()},0);return()=>{window.clearTimeout(e)}},[tu,th]),(0,r.useEffect)(()=>{let t=t=>{if(!ef.current||t.source!==ef.current.contentWindow)return;let r=t.data;if(r&&"object"==typeof r){if("viba:preview-picker-state"===r.type)return void tv(!!r.active);if("viba:preview-picker-ready"===r.type){let e=ef.current?.contentWindow;e&&e.postMessage({type:"viba:preview-location-request"},"*");return}if("viba:preview-link-open"===r.type){"string"==typeof r.url&&r.url.trim().length>0&&window.open(r.url,"_blank","noopener,noreferrer");return}if("viba:preview-location-change"===r.type){"string"==typeof r.url&&r.url.trim().length>0&&tp(r.url);return}if("viba:preview-element-selected"===r.type){let t=r.element&&"object"==typeof r.element?r.element:null,a=Array.isArray(t?.reactComponentStack)?t.reactComponentStack:[],s=((e,t)=>{for(let r of e){if(!r||"object"!=typeof r)continue;let e="string"==typeof r.name?r.name.trim():"";if(!e)continue;let n="string"==typeof r.source?.fileName?r.source.fileName.trim():"",a=n?ed(n,t):null;if(a)return`${e} (${a})`}return null})(a,n||e),i=a[0]&&"object"==typeof a[0]?a[0].name:void 0,l="string"==typeof i&&i.trim().length>0?i.trim():"",o=new Set(["Suspense","ErrorBoundary","Router","AppRouter","LayoutRouter","RenderFromTemplateContext","ScrollAndFocusHandler","InnerLayoutRouter","RedirectErrorBoundary","NotFoundBoundary","LoadingBoundary","ReactDevOverlay","HotReload","AppContainer","Route","Link","Image","OuterLayoutRouter","Head","StringRefs","Fragment","Profiler","StrictMode","SuspenseList","Script","Page","__next_root_layout_boundary__"]),c=Array.from(new Set(a.map(e=>{if(!e||"object"!=typeof e)return"";let t=e.name;return"string"==typeof t?t.trim():""}).filter(e=>!(!e||o.has(e)||e.startsWith("styled.")||e.startsWith("Styled(")))));console.log("Filtered stack component names:",c);let d=s||l||("string"==typeof t?.selector?t.selector:"");if(console.log("Preview selected element:",t),console.log("Preview selected reactComponentStack:",a),console.log("Preview selected identifier:",d),tv(!1),!d)return void eq("Element selected. No identifier was resolved.");(async()=>{let e=s||"";if(!e&&c.length>0){tg(!0);try{let t=await tJ(c);t?.resolvedName&&t?.sourcePath&&(e=`${t.resolvedName} (${t.sourcePath})`)}finally{tg(!1)}}if(!e){if(c.length>0)return eq("Element selected, but source file path could not be resolved for the component");e=d}console.log("Final resolved component identifier:",e),eq(await tY(`${e} `)?`Element identifier sent to agent: ${e}`:"Element selected, but failed to send identifier to agent input")})()}}};return window.addEventListener("message",t),()=>{window.removeEventListener("message",t)}},[tY,e,tJ,n]),(0,r.useEffect)(()=>{tv(!1)},[tf]),!e)return(0,t.jsx)("div",{className:"p-4 text-error",children:"No repository specified"});if("error"===eW)return(0,t.jsx)("div",{className:"flex h-screen w-full items-center justify-center bg-base-100",children:(0,t.jsx)("div",{className:"card w-96 bg-base-200 shadow-xl",children:(0,t.jsxs)("div",{className:"card-body items-center text-center",children:[(0,t.jsx)("h2",{className:"card-title text-error",children:"Cleanup failed"}),(0,t.jsx)("p",{children:e_||"An unknown error occurred while cleaning up this session."}),(0,t.jsx)("div",{className:"card-actions justify-end",children:(0,t.jsx)("button",{className:"btn btn-primary",onClick:()=>K(),children:"Back to Home"})})]})})});let rn=Array.from(new Set([...e9?[e9]:[],...te])).filter(e=>e!==a||e===e9),ra=tS?`calc(40px - min(${t$.width}px, calc(100vw - 2rem)))`:16,rs=!!q?.trim();return(0,t.jsxs)("div",{className:`flex flex-col h-screen w-full overflow-hidden bg-base-100 ${tE||tk?"select-none":""}`,children:[(tE||tk)&&(0,t.jsx)("div",{className:`fixed inset-0 z-[9999] ${tE?"cursor-nwse-resize":"cursor-col-resize"}`}),(0,t.jsxs)("div",{className:"z-20 bg-base-300/95 p-2 text-xs flex justify-between px-4 font-mono select-none items-center shadow-md backdrop-blur-sm border-b border-base-content/10",children:[(0,t.jsxs)("div",{className:"flex items-center gap-4",children:[(0,t.jsx)("button",{className:"btn btn-ghost btn-xs h-6 min-h-6 px-1 hover:bg-base-content/10",onClick:()=>K(),title:"Back to Home",children:(0,t.jsx)(R,{className:"w-4 h-4"})}),(0,t.jsxs)("div",{className:"flex flex-col",children:[(0,t.jsxs)("div",{className:"flex items-center gap-2",children:[(0,t.jsx)("span",{className:"opacity-50",children:"Repo:"}),(0,t.jsx)("span",{className:"font-bold",children:(0,Y.getBaseName)(e)})]}),A&&(0,t.jsxs)("div",{className:"hidden min-[1200px]:flex min-w-0 items-center gap-2 text-[10px] opacity-70",children:[(0,t.jsx)("span",{children:"Session:"}),(0,t.jsx)("span",{className:"truncate max-w-[220px]",title:A,children:A})]})]})]}),(0,t.jsxs)("div",{className:"flex items-center gap-4",children:[(0,t.jsxs)("div",{className:"flex items-center border border-base-content/20 rounded overflow-hidden",children:[(0,t.jsx)("select",{className:"select select-xs h-6 min-h-6 bg-base-200 border-none focus:outline-none rounded-none pr-7",value:tI,onChange:tq,children:en.map(e=>(0,t.jsx)("option",{value:e.id,children:e.name},e.id))}),(0,t.jsx)("div",{className:"w-[1px] h-4 bg-base-content/20"}),(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs rounded-none h-6 min-h-6 border-none hover:bg-base-content/10",onClick:()=>{if(!n)return;let e=en.find(e=>e.id===tI);if(!e)return;let t=`${e.protocol}://file/${encodeURI(n)}`;window.open(t,"_blank")},title:`Open in ${en.find(e=>e.id===tI)?.name}`,children:[(0,t.jsx)(v.ExternalLink,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:em,children:"Open"})]})]}),(0,t.jsxs)("div",{className:"flex items-center border border-base-content/20 rounded overflow-hidden bg-base-100",children:[(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs rounded-none h-6 min-h-6 border-none px-2 hover:bg-base-content/10",onClick:()=>{if(!n||!a)return;let e=new URLSearchParams({path:n,branch:a});window.open(`http://localhost:3100/workspace?${e.toString()}`,"_blank","noopener,noreferrer")},disabled:!n||!a,title:"Open this worktree and branch in Trident",children:[(0,t.jsx)(N.GitBranch,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:em,children:"Diff"})]}),(0,t.jsx)("div",{className:"w-[1px] h-4 bg-base-content/10"}),(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs rounded-none h-6 min-h-6 border-none px-2 hover:bg-base-content/10",onClick:tV,disabled:eX,title:"Ask agent to create a commit with current changes",children:[eX?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(y,{className:"w-3 h-3"}),(0,t.jsxs)("span",{className:em,children:["Commit (",tc,")"]})]})]}),(0,t.jsxs)("div",{className:"flex items-center border border-base-content/20 rounded overflow-hidden bg-base-100",children:[(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs rounded-none h-6 min-h-6 border-none px-2 hover:bg-base-content/10",onClick:()=>e3(!0),disabled:e5,title:"Browse files and insert absolute paths into the agent input",children:[e5?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)($,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:em,children:"Add Files"})]}),(0,t.jsx)("div",{className:"w-[1px] h-4 bg-base-content/10"}),(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs rounded-none h-6 min-h-6 border-none px-2 hover:bg-base-content/10",onClick:()=>{if(!e||!A)return;let t=`/new?repo=${encodeURIComponent(e)}&prefillFromSession=${encodeURIComponent(A)}`;window.open(t,"_blank","noopener,noreferrer")},title:"Start a new attempt in a new tab with this session context",children:[(0,t.jsx)(L.Plus,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:em,children:"New Attempt"})]})]}),(0,t.jsxs)("div",{className:"flex items-center border border-base-content/20 rounded overflow-hidden bg-base-100",children:[(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs rounded-none h-6 min-h-6 border-none px-2 hover:bg-base-content/10",onClick:()=>{let e=q?.trim();if(!e||!ep.current||eV)return;tC(!1);let t=ep.current;eG(!0),eq("Starting dev server...");let r=(n=0)=>{if(n>30){eq("Failed to start dev server: terminal is not ready"),eG(!1);return}try{let a=t.contentWindow;if(a&&a.term){a.term.paste(e);let r=t.contentDocument?.querySelector("textarea.xterm-helper-textarea");r?r.dispatchEvent(new KeyboardEvent("keypress",{bubbles:!0,cancelable:!0,charCode:13,keyCode:13,key:"Enter",view:a})):a.term.paste("\r"),a.focus(),r&&r.focus(),eq("Dev server start command sent"),eG(!1)}else setTimeout(()=>r(n+1),300)}catch(e){console.error("Dev server injection error",e),eq("Failed to start dev server"),eG(!1)}};r()},disabled:!rs||eK||eV,title:rs?eV?"A process is already running in the terminal":"Run dev server script in terminal":"Set a dev server script to enable this button",children:[eK?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(w.Play,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:em,children:"Dev"})]}),(0,t.jsx)("div",{className:"w-[1px] h-4 bg-base-content/10"}),(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs rounded-none h-6 min-h-6 border-none px-2 hover:bg-base-content/10",onClick:()=>tm(e=>!e),title:tu?"Hide preview panel":"Show preview panel",children:[(0,t.jsx)(P,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:em,children:tu?"Close":"Preview"})]})]}),(0,t.jsx)("div",{className:"flex items-center border border-base-content/20 rounded overflow-hidden bg-base-100",children:(0,t.jsxs)("button",{className:`btn btn-ghost btn-xs rounded-none h-6 min-h-6 border-none px-2 hover:bg-base-content/10 ${"select"===tF?"text-warning":""}`,onClick:t_,disabled:"tmux"!==V||tB,title:"tmux"===V?"scroll"===tF?"Switch to text select mode for easier copy":"Switch to scroll mode for wheel scrollback":"Mode toggle is available only in tmux persistence mode",children:[tB?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(T,{className:"w-3 h-3"}),(0,t.jsx)("span",{children:"scroll"===tF?"Scroll Mode":"Text Select"})]})}),(0,t.jsxs)("div",{className:"flex items-center border border-base-content/20 rounded relative bg-base-100",ref:t6,children:[(0,t.jsxs)("div",{className:"relative",children:[(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs rounded-none rounded-l h-6 min-h-6 border-none px-2 hover:bg-base-content/10",onClick:()=>{t4(!t3)},disabled:e0||eZ||ts,title:"Select base branch and rebase",children:[e0?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(k,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:em,children:"Rebase"}),(0,t.jsx)(M,{className:"w-3 h-3 opacity-50 ml-0.5"})]}),t3&&(0,t.jsxs)("div",{className:"absolute top-full left-0 z-50 mt-1 w-64 p-0 shadow-xl dropdown-content bg-base-200 rounded-box border border-base-content/20 flex flex-col max-h-80 overflow-hidden",children:[(0,t.jsxs)("div",{className:"px-4 py-2 text-[10px] uppercase font-bold tracking-wider opacity-50 border-b border-base-content/10 bg-base-200 flex justify-between items-center shrink-0",children:[(0,t.jsx)("span",{children:"Select Base Branch"}),(tr||ts)&&(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"})]}),(0,t.jsxs)("ul",{className:"menu p-0 overflow-y-auto flex-nowrap custom-scrollbar overflow-x-hidden w-full",children:[rn.length>0?rn.map(e=>(0,t.jsx)("li",{children:(0,t.jsxs)("button",{onClick:()=>t5(e),className:`flex justify-between items-center text-xs py-2 truncate max-w-full rounded-none ${e===e9?"active font-bold":""}`,title:e,children:[(0,t.jsx)("span",{className:"truncate",children:e}),e===e9&&(0,t.jsx)("span",{className:"opacity-70 text-[10px] ml-2 shrink-0",children:"(Current)"})]})},e)):(0,t.jsx)("li",{className:"text-xs px-4 py-2 opacity-50 italic text-center",children:"No other branches found"}),(0,t.jsx)("div",{className:"divider my-1 opacity-50"}),(0,t.jsx)("li",{children:(0,t.jsx)("button",{onClick:()=>void tZ(),className:"text-[10px] justify-center opacity-70 hover:opacity-100",children:"Refresh Branches"})})]})]})]}),(0,t.jsx)("div",{className:"w-[1px] h-4 bg-base-content/10"}),(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs btn-success rounded-none h-6 min-h-6 border-none px-2 hover:bg-success/20 hover:border-transparent",onClick:t2,disabled:eZ||e0||ts||!e9,title:e9?`Merge current branch (${a}) into target branch (${e9})`:"Target branch unavailable for this session",children:[eZ?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(j,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:em,children:"Merge"})]}),(0,t.jsx)("div",{className:"w-[1px] h-4 bg-base-content/10"}),(0,t.jsxs)("button",{className:"btn btn-ghost btn-error btn-xs rounded-none rounded-r h-6 min-h-6 border-none px-2 hover:bg-error/20 hover:border-transparent",onClick:tK,disabled:eZ||e0||!n,title:"Clean up and exit",children:[(0,t.jsx)(x.Trash2,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:em,children:"Purge"})]})]}),e9&&(0,t.jsxs)("div",{className:"flex items-center gap-2 text-xs opacity-80",title:`Divergence against ${e9}`,children:[(0,t.jsxs)("span",{className:"inline-flex items-center gap-1",children:[(0,t.jsx)(S,{className:"w-3 h-3"}),tl.ahead]}),(0,t.jsxs)("span",{className:"inline-flex items-center gap-1",children:[(0,t.jsx)(C,{className:"w-3 h-3"}),tl.behind]})]}),(0,t.jsx)("div",{className:"hidden min-[1200px]:block w-[1px] h-4 bg-base-content/20 mx-2"}),(0,t.jsxs)("div",{className:"hidden min-[1200px]:flex min-w-0 max-w-[280px] items-center gap-2",children:[(0,t.jsx)("span",{className:`w-2 h-2 rounded-full ${eU.includes("Error")||eU.includes("failed")?"bg-error":eU.includes("started")||eU.includes("Merged")||eU.includes("Rebased")||eU.includes("sent")?"bg-success":"bg-warning"}`}),(0,t.jsx)("span",{className:"truncate",title:eU,children:eU})]})]})]}),(0,t.jsxs)("div",{ref:ex,className:"flex min-h-0 flex-1 w-full",children:[(0,t.jsx)("div",{className:"h-full min-w-0",style:{width:tu?`${100*ty}%`:"100%"},children:(0,t.jsx)("iframe",{ref:eh,src:ek,className:`h-full w-full border-none dark:invert dark:brightness-90 ${tE||tk?"pointer-events-none":""}`,allow:"clipboard-read; clipboard-write",onLoad:()=>{if(!eh.current)return;let t=eh.current;try{t.contentWindow}catch(e){eq("Error: Cross-Origin access blocked. Ensure proxy is working.");return}t.contentWindow&&(t.contentWindow.onbeforeunload=null,t.contentWindow.addEventListener("beforeunload",e=>{e.stopImmediatePropagation()},!0)),eq("Connecting to terminal...");let r=(a=0)=>{if(a>30)return void eq("Timeout waiting for terminal to be ready");try{let s=t.contentWindow;if(s&&s.term){tH("agent");let i=s.term;rr(t,ew,{directOpenBehavior:"new_tab",modifierOpenBehavior:"new_tab"});try{i.options.theme={...i.options.theme||{},selectionBackground:"rgba(59, 130, 246, 0.4)"}}catch{}let l=eP("agent"),o=!!G&&"tmux"===V;if(l||o){o&&!l?(eD("agent"),eq("Attached to persisted terminal")):eq("Reconnected to terminal"),s.focus();let e=t.contentDocument?.querySelector("textarea.xterm-helper-textarea");e&&e.focus();return}if(!eB(i)&&a<10)return void setTimeout(()=>r(a+1),200);if(!eT("agent")){eq("Reconnected to terminal"),s.focus();let e=t.contentDocument?.querySelector("textarea.xterm-helper-textarea");e&&e.focus();return}let c=n||e,d=`cd ${er(c)}`;i.paste(d);let u=()=>{let e=t.contentDocument?.querySelector("textarea.xterm-helper-textarea");e?e.dispatchEvent(new KeyboardEvent("keypress",{bubbles:!0,cancelable:!0,charCode:13,keyCode:13,key:"Enter",view:s})):i.paste("\r")};if(u(),eD("agent"),z){let t=async()=>{let t="";if(G)t=z.toLowerCase().includes("gemini")?"gemini --resume latest --yolo":z.toLowerCase().includes("codex")?"codex resume --last --sandbox danger-full-access --ask-for-approval on-request --search":"agent"===z.toLowerCase()||z.toLowerCase().includes("cursor")?"agent resume":`${er(z)} resume`;else{let r=_?.trim()||"",a=W?.trim()||"",s=[];r&&s.push(r),a&&s.push(a);let i=s.join("\n\n"),l=(H||[]).map(e=>e.trim()).filter(Boolean).map(t=>`${n||e}-attachments/${t}`),o=[];i&&o.push(i),l.length>0&&o.push(["Attachments:",...l.map(e=>`- ${e}`)].join("\n"));let c=o.join("\n\n"),d="";if(c){let e=[];"plan"===O&&e.push("Plan mode: inspect the relevant code first, present a concrete implementation plan, and wait for explicit user approval before any file edits or write commands."),e.push("After each round, if work is complete and files changed, commit all changes without confirmation. Use a commit message with a clear title and a detailed body explaining what changed and why. If GITHUB_TOKEN or GITLAB_TOKEN is set, push the current branch after committed rounds and create (or update) a GitHub Pull Request or GitLab Merge Request with an appropriate title and description; include the PR/MR link in the first push reply.");let t=["# Instructions\n",e.join("\n"),"\n# Task\n",c].join("\n");try{let e=await m(A,t);e.success&&e.filePath?d=` "$(cat ${er(e.filePath)})"`:(console.error("Failed to write prompt file, falling back to inline prompt",e.error),d=` ${er(t)}`)}catch(e){console.error("Exception writing prompt file",e),d=` ${er(t)}`}}let u=I&&"auto"!==I.toLowerCase()?` --model ${er(I)}`:"";t=z.toLowerCase().includes("codex")?`codex${u} --sandbox danger-full-access --ask-for-approval on-request --search${d}`:z.toLowerCase().includes("gemini")?`gemini${u} --yolo${d}`:"agent"===z.toLowerCase()||z.toLowerCase().includes("cursor")?`agent${u}${d}`:`${er(z)}${u}${d}`}t&&(i.paste(t),u(),eq(G?`Resumed session with ${z}`:`Session started with ${z}`),!G&&X&&X())};setTimeout(()=>t(),500)}else eq(`Session started ${n?"(Worktree)":""}`),!G&&X&&X();s.focus();let h=t.contentDocument?.querySelector("textarea.xterm-helper-textarea");h&&h.focus()}else setTimeout(()=>r(a+1),500)}catch(e){eF("agent"),console.error("Access error during injection:",e),eq("Error accessing terminal: "+String(e))}};setTimeout(()=>r(),1e3)}})}),tu&&(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)("div",{className:"relative h-full w-2 shrink-0 cursor-col-resize bg-base-300/40 hover:bg-base-content/20",onMouseDown:e=>{e.preventDefault(),tN(!0),ev.current={startX:e.clientX,startRatio:ty}},role:"separator","aria-orientation":"vertical","aria-label":"Resize preview panel",title:"Drag to resize preview panel",children:(0,t.jsx)("div",{className:"absolute left-1/2 top-1/2 h-12 w-[2px] -translate-x-1/2 -translate-y-1/2 rounded-full bg-base-content/30"})}),(0,t.jsxs)("div",{className:"flex h-full min-w-0 flex-1 flex-col border-l border-base-content/10 bg-base-200/50",children:[(0,t.jsxs)("form",{className:"flex items-center gap-2 border-b border-base-content/10 bg-base-200 px-3 py-2",onSubmit:e=>{e.preventDefault(),t7(th,!0)},children:[(0,t.jsx)("button",{className:"btn btn-ghost btn-xs h-7 min-h-7 w-7 p-0",type:"button",onClick:()=>re("back"),disabled:!tf,title:"Go back","aria-label":"Go back",children:(0,t.jsx)(F.ArrowLeft,{className:"h-3.5 w-3.5"})}),(0,t.jsx)("button",{className:"btn btn-ghost btn-xs h-7 min-h-7 w-7 p-0",type:"button",onClick:()=>re("forward"),disabled:!tf,title:"Go forward","aria-label":"Go forward",children:(0,t.jsx)(D,{className:"h-3.5 w-3.5"})}),(0,t.jsx)("button",{className:"btn btn-ghost btn-xs h-7 min-h-7 w-7 p-0",type:"button",onClick:()=>re("reload"),disabled:!tf,title:"Reload preview","aria-label":"Reload preview",children:(0,t.jsx)(B,{className:"h-3.5 w-3.5"})}),(0,t.jsx)("input",{ref:eb,type:"text",className:"input input-xs input-bordered w-full font-mono",value:th,onChange:e=>tp(e.target.value),placeholder:"http://127.0.0.1:3000",spellCheck:!1}),(0,t.jsx)("button",{className:`btn btn-ghost btn-xs ${tx?"btn-active text-success":""}`,type:"button",onClick:t9,disabled:!tf||tw,title:tx?"Disable picker":"Pick element from preview",children:tw?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs w-3 h-3"}):(0,t.jsx)(T,{className:"h-3 w-3"})}),(0,t.jsx)("button",{className:"btn btn-xs",type:"submit",children:"Go"})]}),(0,t.jsx)("div",{className:"min-h-0 flex-1",children:tf?(0,t.jsx)("iframe",{ref:ef,src:tf,className:`h-full w-full border-none ${tE||tk?"pointer-events-none":""}`,title:"Dev server preview",onLoad:rt,sandbox:"allow-forms allow-modals allow-pointer-lock allow-popups allow-same-origin allow-scripts allow-downloads"}):(0,t.jsx)("div",{className:"flex h-full items-center justify-center px-6 text-center text-xs opacity-70",children:"Run the dev server, or enter a URL above to load a preview."})})]})]})]}),(0,t.jsxs)("div",{className:`absolute z-30 overflow-hidden rounded-lg border border-base-content/20 bg-base-200/95 shadow-2xl backdrop-blur-sm ${tE||tk?"":"transition-all"}`,style:{bottom:80,right:ra,width:t$.width,height:tS?40:t$.height,maxWidth:"calc(100vw - 2rem)",maxHeight:"calc(100vh - 2rem)"},children:[(0,t.jsx)("button",{className:`absolute left-0 top-0 z-50 flex h-10 w-10 items-center justify-center text-base-content/30 hover:text-base-content/60 ${tS?"cursor-pointer":"cursor-nwse-resize"}`,onMouseDown:tS?void 0:e=>{e.preventDefault(),e.stopPropagation(),tM(!0),tT.current={startX:e.clientX,startY:e.clientY,startWidth:t$.width,startHeight:t$.height}},onClick:tS?()=>tC(!1):void 0,title:tS?"Expand terminal":"Drag to resize",type:"button",children:(0,t.jsx)(E,{size:14})}),!tS&&(0,t.jsxs)("button",{className:"flex h-10 w-full items-center justify-between px-3 pl-10 text-xs font-mono hover:bg-base-content/10",onClick:()=>tC(e=>!e),title:"Minimize terminal",type:"button",children:[(0,t.jsx)("span",{children:"Terminal"}),(0,t.jsx)("span",{className:"opacity-70",children:"Hide"})]}),(0,t.jsx)("div",{className:tS?"h-0 overflow-hidden":"h-[calc(100%-2.5rem)]",children:(0,t.jsx)("iframe",{ref:ep,src:eN,className:`h-full w-full border-none dark:invert dark:brightness-90 ${tE||tk?"pointer-events-none":""}`,allow:"clipboard-read; clipboard-write",onLoad:()=>{if(!ep.current)return;let t=ep.current;eA(),eY(!1);try{t.contentWindow}catch(e){console.error("Secondary terminal: Cross-Origin access blocked.");return}t.contentWindow&&(t.contentWindow.onbeforeunload=null,t.contentWindow.addEventListener("beforeunload",e=>{e.stopImmediatePropagation()},!0));let r=(a=0)=>{if(!(a>30))try{let s=t.contentWindow;if(s&&s.term){let i;tH("terminal");let l=s.term;rr(t,eg,{onLinkActivated:()=>tC(!0),directOpenBehavior:"preview",modifierOpenBehavior:"new_tab"});try{l.options.theme={...l.options.theme||{},selectionBackground:"rgba(59, 130, 246, 0.4)"}}catch{}ez(t,l);try{let e=()=>{let e=l.buffer?.active,t="number"==typeof e?.baseY?e.baseY:0;"number"==typeof e?.viewportY&&e.viewportY,l.scrollToBottom?.()};if("function"==typeof l.onWriteParsed)l.onWriteParsed(e);else{let r=t.contentDocument?.querySelector(".xterm-screen")||t.contentDocument?.body;r&&new MutationObserver(e).observe(r,{childList:!0,subtree:!0,characterData:!0})}}catch(e){console.error("Failed to setup auto-scroll:",e)}let o=eP("terminal"),c=!!G&&"tmux"===V;if(o||c){c&&!o&&eD("terminal"),o&&eI(t,s,l),s.focus();let e=t.contentDocument?.querySelector("textarea.xterm-helper-textarea");e&&e.focus();return}if(!eB(l)&&a<10)return void setTimeout(()=>r(a+1),200);if(!eT("terminal")){s.focus();let e=t.contentDocument?.querySelector("textarea.xterm-helper-textarea");e&&e.focus();return}let d=n||e,u=`cd ${er(d)}`;l.paste(u),(i=t.contentDocument?.querySelector("textarea.xterm-helper-textarea"))?i.dispatchEvent(new KeyboardEvent("keypress",{bubbles:!0,cancelable:!0,charCode:13,keyCode:13,key:"Enter",view:s})):l.paste("\r"),eD("terminal"),eI(t,s,l),s.focus();let m=t.contentDocument?.querySelector("textarea.xterm-helper-textarea");m&&m.focus()}else setTimeout(()=>r(a+1),500)}catch(e){eY(!1),eF("terminal"),console.error("Secondary terminal injection error",e)}};setTimeout(()=>r(),1e3)}})})]}),e2&&(0,t.jsx)(Z,{initialPath:e4,worktreePath:n,onPathChange:e6,onConfirm:e=>{e3(!1),tX(e)},onCancel:()=>e3(!1)})]})}let eh=(0,a.createServerReference)("40345ce4c9695579537743dba5874914ecad10c94a",a.callServer,void 0,a.findSourceMapURL,"consumeSessionLaunchContext"),ep=(0,a.createServerReference)("407bc00c62086b0b40bbc00b7c42ea80a09a18f666",a.callServer,void 0,a.findSourceMapURL,"getSessionMetadata"),ef=(0,a.createServerReference)("40092059abd78e7b70e8304ded8424ccc8c183a376",a.callServer,void 0,a.findSourceMapURL,"markSessionInitialized"),eb=(0,a.createServerReference)("7f97df4a11ef26d3be2146351af6d44fc8b938f2c5",a.callServer,void 0,a.findSourceMapURL,"getSessionTerminalSources");var ex=e.i(17297);function ev(){let e=(0,n.useParams)().sessionId,a=Array.isArray(e)?e[0]:e,s=(0,n.useRouter)(),[i,l]=(0,r.useState)(null),[o,c]=(0,r.useState)(!0),[d,u]=(0,r.useState)(null),[m,h]=(0,r.useState)(null),[p,f]=(0,r.useState)(void 0),[b,x]=(0,r.useState)(void 0),[v,w]=(0,r.useState)(void 0),[g,y]=(0,r.useState)(void 0),[j,k]=(0,r.useState)(void 0),[N,S]=(0,r.useState)(void 0),[C,$]=(0,r.useState)([]),[R,E]=(0,r.useState)(!0),[M,L]=(0,r.useState)("shell");(0,r.useEffect)(()=>(document.documentElement.classList.add("session-page"),()=>{document.documentElement.classList.remove("session-page")}),[]),(0,r.useEffect)(()=>{a&&(async()=>{try{h(null);let e=await (0,ex.startTtydProcess)();if(!e.success){u("Failed to start terminal service"),c(!1);return}L("tmux"===e.persistenceMode?"tmux":"shell");let t=await ep(a);if(!t){u("Session not found"),c(!1);return}l(t);let r=await eb(t.sessionName,t.repoPath);if(h(r),!1===t.initialized){let e=await eh(a);if(e.success&&e.context){let t=e.context;f(t.initialMessage),x(t.startupScript),w(t.title),y(t.agentProvider),k(t.model),S(t.sessionMode),$(t.attachmentNames||[])}E(!1)}else E(!0);c(!1)}catch(e){console.error("Failed to load session:",e),u("Failed to load session"),c(!1)}})()},[a]);let P=e=>{e?window.location.href="/":s.push("/")},T=async()=>{a&&await ef(a)};return o?(0,t.jsx)("div",{className:"flex h-screen w-full items-center justify-center bg-base-100",children:(0,t.jsxs)("div",{className:"flex flex-col items-center gap-4",children:[(0,t.jsx)("span",{className:"loading loading-spinner loading-lg text-primary"}),(0,t.jsx)("p",{className:"opacity-60",children:"Loading session..."})]})}):d||!i?(0,t.jsx)("div",{className:"flex h-screen w-full items-center justify-center bg-base-100",children:(0,t.jsx)("div",{className:"card w-96 bg-base-200 shadow-xl",children:(0,t.jsxs)("div",{className:"card-body items-center text-center",children:[(0,t.jsx)("h2",{className:"card-title text-error",children:"Error"}),(0,t.jsx)("p",{children:d||"Session not found"}),(0,t.jsx)("div",{className:"card-actions justify-end",children:(0,t.jsx)("button",{className:"btn btn-primary",onClick:()=>P(),children:"Back to Home"})})]})})}):m?(0,t.jsx)(em,{repo:i.repoPath,worktree:i.worktreePath,branch:i.branchName,baseBranch:i.baseBranch,sessionName:i.sessionName,agent:g||i.agent,model:j||i.model,startupScript:b,devServerScript:i.devServerScript,initialMessage:p,attachmentNames:C,title:v||i.title,sessionMode:N,onExit:P,isResume:R,terminalPersistenceMode:M,onSessionStart:T,agentTerminalSrc:m.agentTerminalSrc,floatingTerminalSrc:m.floatingTerminalSrc}):(0,t.jsx)("div",{className:"flex h-screen w-full items-center justify-center bg-base-100",children:(0,t.jsxs)("div",{className:"flex flex-col items-center gap-4",children:[(0,t.jsx)("span",{className:"loading loading-spinner loading-lg text-primary"}),(0,t.jsx)("p",{className:"opacity-60",children:"Initializing terminals..."})]})})}e.s(["default",()=>ev],36438)}]);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "viba-cli",
3
- "version": "0.21.0",
3
+ "version": "0.22.0",
4
4
  "private": false,
5
5
  "description": "Local session manager for AI coding agents.",
6
6
  "repository": {
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../node_modules/next/src/build/webpack/loaders/next-flight-loader/server-reference.ts","../../../../node_modules/next/src/build/webpack/loaders/next-flight-loader/action-validate.ts","../../../../src/lib/credentials.ts","../../../../src/app/actions/credentials.ts","../../../../src/lib/repo-resolver.ts","../../../../src/app/actions/repository.ts","../../../../.next-internal/server/app/page/actions.js%20%28server%20actions%20loader%29"],"sourcesContent":["/* eslint-disable import/no-extraneous-dependencies */\nexport { registerServerReference } from 'react-server-dom-webpack/server'\n","// This function ensures that all the exported values are valid server actions,\n// during the runtime. By definition all actions are required to be async\n// functions, but here we can only check that they are functions.\nexport function ensureServerEntryExports(actions: any[]) {\n for (let i = 0; i < actions.length; i++) {\n const action = actions[i]\n if (typeof action !== 'function') {\n throw new Error(\n `A \"use server\" file can only export async functions, found ${typeof action}.\\nRead more: https://nextjs.org/docs/messages/invalid-use-server-value`\n )\n }\n }\n}\n","import fs from 'fs/promises';\nimport os from 'os';\nimport path from 'path';\n\nconst SERVICE_NAME = 'viba-git-credentials';\nconst CREDENTIALS_FILE_NAME = 'credentials.json';\n\nexport type CredentialType = 'github' | 'gitlab';\n\nexport interface BaseCredential {\n id: string;\n type: CredentialType;\n username: string;\n createdAt: string;\n updatedAt: string;\n}\n\nexport interface GitHubCredential extends BaseCredential {\n type: 'github';\n}\n\nexport interface GitLabCredential extends BaseCredential {\n type: 'gitlab';\n serverUrl: string;\n}\n\nexport type Credential = GitHubCredential | GitLabCredential;\n\ntype CredentialMetadata = {\n id: string;\n type: CredentialType;\n username: string;\n serverUrl?: string;\n createdAt: string;\n updatedAt: string;\n keytarAccount?: string;\n};\n\ntype LegacyCredentialMetadata = {\n type: CredentialType;\n username: string;\n serverUrl?: string;\n createdAt: string;\n updatedAt: string;\n};\n\ntype KeytarModule = {\n getPassword(service: string, account: string): Promise<string | null>;\n setPassword(service: string, account: string, password: string): Promise<void>;\n deletePassword(service: string, account: string): Promise<boolean>;\n};\n\nlet keytarPromise: Promise<KeytarModule | null> | null = null;\nlet keytarUnavailableReason: string | null = null;\nlet didLogKeytarWarning = false;\n\nfunction keytarUnavailableMessage(): string {\n if (keytarUnavailableReason) {\n return `Secure credential storage is unavailable: ${keytarUnavailableReason}`;\n }\n return 'Secure credential storage is unavailable in this runtime.';\n}\n\nasync function loadKeytar(): Promise<KeytarModule | null> {\n if (!keytarPromise) {\n keytarPromise = import('keytar')\n .then((module) => (module.default ?? module) as KeytarModule)\n .catch((error: unknown) => {\n keytarUnavailableReason = error instanceof Error ? error.message : String(error);\n if (!didLogKeytarWarning) {\n didLogKeytarWarning = true;\n console.warn(`[credentials] ${keytarUnavailableMessage()}`);\n }\n return null;\n });\n }\n\n return keytarPromise;\n}\n\nasync function requireKeytar(): Promise<KeytarModule> {\n const keytar = await loadKeytar();\n if (!keytar) {\n throw new Error(keytarUnavailableMessage());\n }\n return keytar;\n}\n\nfunction generateId(): string {\n return `${Date.now()}-${Math.random().toString(36).slice(2, 9)}`;\n}\n\nfunction normalizeGitLabServerUrl(serverUrl: string): string {\n return serverUrl.trim().replace(/\\/$/, '');\n}\n\nfunction getDefaultKeytarAccount(id: string): string {\n return `credential-${id}`;\n}\n\nfunction getLegacyKeytarAccount(type: CredentialType): string {\n return `credential-${type}`;\n}\n\nfunction getKeytarAccountForMetadata(metadata: CredentialMetadata): string {\n return metadata.keytarAccount || getDefaultKeytarAccount(metadata.id);\n}\n\nfunction toCredential(metadata: CredentialMetadata): Credential {\n if (metadata.type === 'gitlab') {\n return {\n id: metadata.id,\n type: 'gitlab',\n username: metadata.username,\n serverUrl: metadata.serverUrl || 'https://gitlab.com',\n createdAt: metadata.createdAt,\n updatedAt: metadata.updatedAt,\n };\n }\n\n return {\n id: metadata.id,\n type: 'github',\n username: metadata.username,\n createdAt: metadata.createdAt,\n updatedAt: metadata.updatedAt,\n };\n}\n\nasync function getCredentialsFilePath(): Promise<string> {\n const vibaDir = path.join(os.homedir(), '.viba');\n await fs.mkdir(vibaDir, { recursive: true });\n return path.join(vibaDir, CREDENTIALS_FILE_NAME);\n}\n\nfunction isLegacyCredentialMetadata(value: unknown, expectedType: CredentialType): value is LegacyCredentialMetadata {\n if (!value || typeof value !== 'object') return false;\n\n const candidate = value as Record<string, unknown>;\n if (candidate.type !== expectedType) return false;\n if (typeof candidate.username !== 'string') return false;\n if (typeof candidate.createdAt !== 'string') return false;\n if (typeof candidate.updatedAt !== 'string') return false;\n\n if (expectedType === 'gitlab') {\n return typeof candidate.serverUrl === 'string';\n }\n\n return true;\n}\n\nfunction isCredentialMetadata(value: unknown): value is CredentialMetadata {\n if (!value || typeof value !== 'object') return false;\n\n const candidate = value as Record<string, unknown>;\n if (typeof candidate.id !== 'string' || !candidate.id.trim()) return false;\n if (candidate.type !== 'github' && candidate.type !== 'gitlab') return false;\n if (typeof candidate.username !== 'string') return false;\n if (typeof candidate.createdAt !== 'string') return false;\n if (typeof candidate.updatedAt !== 'string') return false;\n if (candidate.keytarAccount !== undefined && typeof candidate.keytarAccount !== 'string') return false;\n\n if (candidate.type === 'gitlab') {\n return typeof candidate.serverUrl === 'string';\n }\n\n return true;\n}\n\nasync function writeCredentialsMetadata(metadata: CredentialMetadata[]): Promise<void> {\n const credentialsFilePath = await getCredentialsFilePath();\n await fs.writeFile(credentialsFilePath, JSON.stringify(metadata, null, 2), 'utf-8');\n}\n\nasync function readCredentialsMetadata(): Promise<CredentialMetadata[]> {\n const credentialsFilePath = await getCredentialsFilePath();\n\n try {\n const content = await fs.readFile(credentialsFilePath, 'utf-8');\n const parsed = JSON.parse(content) as unknown;\n\n if (Array.isArray(parsed)) {\n return parsed.filter(isCredentialMetadata);\n }\n\n if (!parsed || typeof parsed !== 'object') {\n return [];\n }\n\n const legacyMapped = parsed as Record<string, unknown>;\n const migrated: CredentialMetadata[] = [];\n\n if (isLegacyCredentialMetadata(legacyMapped.github, 'github')) {\n const metadata = legacyMapped.github;\n migrated.push({\n id: generateId(),\n type: 'github',\n username: metadata.username,\n createdAt: metadata.createdAt,\n updatedAt: metadata.updatedAt,\n keytarAccount: getLegacyKeytarAccount('github'),\n });\n }\n\n if (isLegacyCredentialMetadata(legacyMapped.gitlab, 'gitlab')) {\n const metadata = legacyMapped.gitlab;\n migrated.push({\n id: generateId(),\n type: 'gitlab',\n username: metadata.username,\n serverUrl: metadata.serverUrl,\n createdAt: metadata.createdAt,\n updatedAt: metadata.updatedAt,\n keytarAccount: getLegacyKeytarAccount('gitlab'),\n });\n }\n\n if (migrated.length > 0) {\n await writeCredentialsMetadata(migrated);\n }\n\n return migrated;\n } catch (error) {\n if ((error as NodeJS.ErrnoException)?.code === 'ENOENT') {\n return [];\n }\n\n console.error('Failed to parse credentials metadata:', error);\n return [];\n }\n}\n\nexport async function getAllCredentials(): Promise<Credential[]> {\n const metadata = await readCredentialsMetadata();\n\n return metadata\n .map(toCredential)\n .sort((a, b) => b.updatedAt.localeCompare(a.updatedAt));\n}\n\nexport async function getCredentialById(id: string): Promise<Credential | null> {\n const metadata = await readCredentialsMetadata();\n const found = metadata.find((credential) => credential.id === id);\n return found ? toCredential(found) : null;\n}\n\nexport async function getCredentialToken(id: string): Promise<string | null> {\n const metadata = await readCredentialsMetadata();\n const found = metadata.find((credential) => credential.id === id);\n if (!found) {\n return null;\n }\n\n const keytar = await loadKeytar();\n if (!keytar) {\n return null;\n }\n\n return keytar.getPassword(SERVICE_NAME, getKeytarAccountForMetadata(found));\n}\n\nasync function verifyGitHubToken(token: string): Promise<{ valid: boolean; username?: string; error?: string }> {\n try {\n const response = await fetch('https://api.github.com/user', {\n headers: {\n Authorization: `Bearer ${token}`,\n Accept: 'application/vnd.github+json',\n 'X-GitHub-Api-Version': '2022-11-28',\n },\n });\n\n if (!response.ok) {\n if (response.status === 401) {\n return { valid: false, error: 'Invalid or expired GitHub token.' };\n }\n return { valid: false, error: `GitHub API returned ${response.status}.` };\n }\n\n const data = await response.json();\n const username = typeof data?.login === 'string' ? data.login : null;\n if (!username) {\n return { valid: false, error: 'GitHub API response did not include a username.' };\n }\n\n return { valid: true, username };\n } catch (error) {\n return { valid: false, error: `Failed to verify GitHub token: ${(error as Error).message}` };\n }\n}\n\nasync function verifyGitLabToken(serverUrl: string, token: string): Promise<{ valid: boolean; username?: string; error?: string }> {\n try {\n const normalizedUrl = normalizeGitLabServerUrl(serverUrl);\n const response = await fetch(`${normalizedUrl}/api/v4/user`, {\n headers: {\n 'PRIVATE-TOKEN': token,\n },\n });\n\n if (!response.ok) {\n if (response.status === 401) {\n return { valid: false, error: 'Invalid or expired GitLab token.' };\n }\n return { valid: false, error: `GitLab API returned ${response.status}.` };\n }\n\n const data = await response.json();\n const username = typeof data?.username === 'string' ? data.username : null;\n if (!username) {\n return { valid: false, error: 'GitLab API response did not include a username.' };\n }\n\n return { valid: true, username };\n } catch (error) {\n return { valid: false, error: `Failed to verify GitLab token: ${(error as Error).message}` };\n }\n}\n\nexport async function createGitHubCredential(token: string): Promise<{ success: boolean; credential?: GitHubCredential; error?: string }> {\n const trimmedToken = token.trim();\n if (!trimmedToken) {\n return { success: false, error: 'GitHub token is required.' };\n }\n\n let keytar: KeytarModule;\n try {\n keytar = await requireKeytar();\n } catch (error) {\n return { success: false, error: (error as Error).message };\n }\n\n const verification = await verifyGitHubToken(trimmedToken);\n if (!verification.valid || !verification.username) {\n return { success: false, error: verification.error || 'Failed to verify GitHub token.' };\n }\n\n const metadata = await readCredentialsMetadata();\n const duplicate = metadata.find((credential) => (\n credential.type === 'github'\n && credential.username === verification.username\n ));\n\n if (duplicate) {\n return { success: false, error: `A GitHub credential for ${verification.username} already exists.` };\n }\n\n const id = generateId();\n const now = new Date().toISOString();\n const keytarAccount = getDefaultKeytarAccount(id);\n\n await keytar.setPassword(SERVICE_NAME, keytarAccount, trimmedToken);\n\n const created: CredentialMetadata = {\n id,\n type: 'github',\n username: verification.username,\n createdAt: now,\n updatedAt: now,\n keytarAccount,\n };\n\n metadata.push(created);\n await writeCredentialsMetadata(metadata);\n\n return {\n success: true,\n credential: {\n id: created.id,\n type: 'github',\n username: created.username,\n createdAt: created.createdAt,\n updatedAt: created.updatedAt,\n },\n };\n}\n\nexport async function createGitLabCredential(\n serverUrl: string,\n token: string,\n): Promise<{ success: boolean; credential?: GitLabCredential; error?: string }> {\n const normalizedServerUrl = normalizeGitLabServerUrl(serverUrl);\n const trimmedToken = token.trim();\n\n if (!normalizedServerUrl) {\n return { success: false, error: 'GitLab server URL is required.' };\n }\n\n try {\n new URL(normalizedServerUrl);\n } catch {\n return { success: false, error: 'GitLab server URL must be a valid URL.' };\n }\n\n if (!trimmedToken) {\n return { success: false, error: 'GitLab token is required.' };\n }\n\n let keytar: KeytarModule;\n try {\n keytar = await requireKeytar();\n } catch (error) {\n return { success: false, error: (error as Error).message };\n }\n\n const verification = await verifyGitLabToken(normalizedServerUrl, trimmedToken);\n if (!verification.valid || !verification.username) {\n return { success: false, error: verification.error || 'Failed to verify GitLab token.' };\n }\n\n const metadata = await readCredentialsMetadata();\n const duplicate = metadata.find((credential) => (\n credential.type === 'gitlab'\n && credential.username === verification.username\n && credential.serverUrl === normalizedServerUrl\n ));\n\n if (duplicate) {\n return {\n success: false,\n error: `A GitLab credential for ${verification.username} on ${normalizedServerUrl} already exists.`,\n };\n }\n\n const id = generateId();\n const now = new Date().toISOString();\n const keytarAccount = getDefaultKeytarAccount(id);\n\n await keytar.setPassword(SERVICE_NAME, keytarAccount, trimmedToken);\n\n const created: CredentialMetadata = {\n id,\n type: 'gitlab',\n username: verification.username,\n serverUrl: normalizedServerUrl,\n createdAt: now,\n updatedAt: now,\n keytarAccount,\n };\n\n metadata.push(created);\n await writeCredentialsMetadata(metadata);\n\n return {\n success: true,\n credential: {\n id: created.id,\n type: 'gitlab',\n username: created.username,\n serverUrl: created.serverUrl || normalizedServerUrl,\n createdAt: created.createdAt,\n updatedAt: created.updatedAt,\n },\n };\n}\n\nexport async function deleteCredential(id: string): Promise<{ success: boolean; error?: string }> {\n const metadata = await readCredentialsMetadata();\n const index = metadata.findIndex((credential) => credential.id === id);\n\n if (index === -1) {\n return { success: false, error: 'Credential not found.' };\n }\n\n const credential = metadata[index];\n metadata.splice(index, 1);\n await writeCredentialsMetadata(metadata);\n\n const keytar = await loadKeytar();\n if (keytar) {\n await keytar.deletePassword(SERVICE_NAME, getKeytarAccountForMetadata(credential));\n }\n\n return { success: true };\n}\n","'use server';\n\nimport {\n createGitHubCredential,\n createGitLabCredential,\n deleteCredential,\n getAllCredentials,\n} from '@/lib/credentials';\nimport type { Credential } from '@/lib/credentials';\n\ntype ListCredentialsResult =\n | { success: true; credentials: Credential[] }\n | { success: false; error: string };\n\nexport async function listCredentials(): Promise<ListCredentialsResult> {\n try {\n const credentials = await getAllCredentials();\n return { success: true, credentials };\n } catch (error) {\n console.error('Failed to list credentials:', error);\n return { success: false, error: 'Failed to load credentials.' };\n }\n}\n\ntype SaveCredentialResult =\n | { success: true; credential: Credential }\n | { success: false; error: string };\n\nexport async function saveGitHubCredential(token: string): Promise<SaveCredentialResult> {\n const result = await createGitHubCredential(token);\n if (!result.success || !result.credential) {\n return { success: false, error: result.error || 'Failed to save GitHub credential.' };\n }\n\n return { success: true, credential: result.credential };\n}\n\nexport async function saveGitLabCredential(serverUrl: string, token: string): Promise<SaveCredentialResult> {\n const result = await createGitLabCredential(serverUrl, token);\n if (!result.success || !result.credential) {\n return { success: false, error: result.error || 'Failed to save GitLab credential.' };\n }\n\n return { success: true, credential: result.credential };\n}\n\ntype RemoveCredentialResult =\n | { success: true }\n | { success: false; error: string };\n\nexport async function removeCredential(id: string): Promise<RemoveCredentialResult> {\n try {\n const result = await deleteCredential(id);\n if (!result.success) {\n return { success: false, error: result.error || 'Failed to remove credential.' };\n }\n\n return { success: true };\n } catch (error) {\n console.error('Failed to remove credential:', error);\n return { success: false, error: 'Failed to remove credential.' };\n }\n}\n","import fs from 'fs/promises';\nimport type { Dirent } from 'fs';\nimport path from 'path';\nimport { getConfig } from '@/app/actions/config';\n\nconst MAX_SCAN_DEPTH = 5;\nconst MAX_SCANNED_DIRECTORIES = 5000;\nconst RESOLUTION_CACHE_TTL_MS = 5 * 60 * 1000;\nconst SKIPPED_DIR_NAMES = new Set([\n '.git',\n 'node_modules',\n '.next',\n '.viba',\n 'dist',\n 'build',\n 'coverage',\n]);\n\ntype RepoResolutionCacheEntry = {\n repoPath: string;\n resolvedAt: number;\n};\n\ndeclare global {\n var repoResolutionCache: Map<string, RepoResolutionCacheEntry> | undefined;\n}\n\nfunction getResolutionCache(): Map<string, RepoResolutionCacheEntry> {\n if (!global.repoResolutionCache) {\n global.repoResolutionCache = new Map<string, RepoResolutionCacheEntry>();\n }\n return global.repoResolutionCache;\n}\n\nfunction cacheResolution(repoName: string, repoPath: string): void {\n getResolutionCache().set(repoName.toLowerCase(), {\n repoPath,\n resolvedAt: Date.now(),\n });\n}\n\nasync function getValidCachedResolution(repoName: string): Promise<string | null> {\n const entry = getResolutionCache().get(repoName.toLowerCase());\n if (!entry) return null;\n if (Date.now() - entry.resolvedAt > RESOLUTION_CACHE_TTL_MS) {\n getResolutionCache().delete(repoName.toLowerCase());\n return null;\n }\n\n if (await isGitRepository(entry.repoPath)) {\n return entry.repoPath;\n }\n\n getResolutionCache().delete(repoName.toLowerCase());\n return null;\n}\n\nasync function isGitRepository(dirPath: string): Promise<boolean> {\n try {\n await fs.access(path.join(dirPath, '.git'));\n return true;\n } catch {\n return false;\n }\n}\n\nfunction hasMatchingName(repoPath: string, repoName: string): boolean {\n return path.basename(repoPath).toLowerCase() === repoName.toLowerCase();\n}\n\nfunction shouldSkipDirectory(entryName: string, targetName: string): boolean {\n const lowerName = entryName.toLowerCase();\n if (lowerName === targetName) return false;\n if (SKIPPED_DIR_NAMES.has(lowerName)) return true;\n if (entryName.startsWith('.')) return true;\n return false;\n}\n\nasync function findByNameWithinRoot(rootPath: string, repoName: string): Promise<string | null> {\n const directCandidate = path.join(rootPath, repoName);\n if (await isGitRepository(directCandidate)) {\n return directCandidate;\n }\n\n const queue: Array<{ dirPath: string; depth: number }> = [{ dirPath: rootPath, depth: 0 }];\n let scannedCount = 0;\n const targetName = repoName.toLowerCase();\n\n for (let index = 0; index < queue.length; index += 1) {\n const current = queue[index];\n scannedCount += 1;\n if (scannedCount > MAX_SCANNED_DIRECTORIES) {\n break;\n }\n\n let entries: Dirent[];\n try {\n entries = await fs.readdir(current.dirPath, { withFileTypes: true });\n } catch {\n continue;\n }\n\n for (const entry of entries) {\n if (!entry.isDirectory()) continue;\n if (shouldSkipDirectory(entry.name, targetName)) continue;\n\n const nextDirPath = path.join(current.dirPath, entry.name);\n\n if (entry.name.toLowerCase() === targetName && await isGitRepository(nextDirPath)) {\n return nextDirPath;\n }\n\n if (current.depth + 1 <= MAX_SCAN_DEPTH) {\n queue.push({ dirPath: nextDirPath, depth: current.depth + 1 });\n }\n }\n }\n\n return null;\n}\n\nexport async function resolveRepositoryPathByName(repoName: string): Promise<string | null> {\n const trimmedName = repoName.trim();\n if (!trimmedName) return null;\n\n const cachedResolution = await getValidCachedResolution(trimmedName);\n if (cachedResolution) {\n return cachedResolution;\n }\n\n const config = await getConfig();\n\n const recentMatches = config.recentRepos.filter((repoPath) => hasMatchingName(repoPath, trimmedName));\n for (const repoPath of recentMatches) {\n if (await isGitRepository(repoPath)) {\n cacheResolution(trimmedName, repoPath);\n return repoPath;\n }\n }\n\n const searchRoots: string[] = [];\n const visitedRoots = new Set<string>();\n for (const repoPath of config.recentRepos) {\n const parentPath = path.dirname(repoPath);\n if (!visitedRoots.has(parentPath)) {\n visitedRoots.add(parentPath);\n searchRoots.push(parentPath);\n }\n }\n if (config.defaultRoot && !visitedRoots.has(config.defaultRoot)) {\n visitedRoots.add(config.defaultRoot);\n searchRoots.push(config.defaultRoot);\n }\n\n for (const rootPath of searchRoots) {\n const resolvedPath = await findByNameWithinRoot(rootPath, trimmedName);\n if (resolvedPath) {\n cacheResolution(trimmedName, resolvedPath);\n return resolvedPath;\n }\n }\n\n return null;\n}\n","'use server';\n\nimport { resolveRepositoryPathByName } from '@/lib/repo-resolver';\n\ntype ResolveRepositoryResult = {\n success: boolean;\n repoPath: string | null;\n error?: string;\n};\n\nexport async function resolveRepositoryByName(repoName: string): Promise<ResolveRepositoryResult> {\n try {\n const resolvedPath = await resolveRepositoryPathByName(repoName);\n return {\n success: true,\n repoPath: resolvedPath,\n };\n } catch (error) {\n console.error('Failed to resolve repository by name:', error);\n return {\n success: false,\n repoPath: null,\n error: 'Failed to search repositories. Please try again.',\n };\n }\n}\n","export {checkDirectoryAccessible as '403ef707dab230c18860718e1bdf896059f3d5fd91'} from 'ACTIONS_MODULE0'\nexport {listDirectories as '40926025dfa54333beb998cd7af50d262b08857b7d'} from 'ACTIONS_MODULE0'\nexport {getHomeDirectory as '005d259cc8fa8d952f814b4fb979df53e92986d9a5'} from 'ACTIONS_MODULE0'\nexport {checkIsGitRepo as '40a7796191f83d4a386060c5b8728adf970b9cbf2c'} from 'ACTIONS_MODULE0'\nexport {getBranches as '40ef3d541634346a280afe8eb270b20a44e65c12f0'} from 'ACTIONS_MODULE0'\nexport {checkoutBranch as '6039f5f40f5cf0d2cc408be7a9ae5bfb689d8ac196'} from 'ACTIONS_MODULE0'\nexport {startTtydProcess as '7f9f1c8bfbea857703a62a8b12c5404cc5fe241ff2'} from 'ACTIONS_MODULE0'\nexport {getStartupScript as '7ffe03accac8ebe36db5f881f52a53547a4e0e9903'} from 'ACTIONS_MODULE0'\nexport {getDefaultDevServerScript as '7fa7e9c4cf5a3fd0284293b74e27199a5b60b6fdf5'} from 'ACTIONS_MODULE0'\nexport {listRepoFiles as '7f2fc548d4b7196815ce7140fbc75c85a186233828'} from 'ACTIONS_MODULE0'\nexport {saveAttachments as '7f5447571c45e842042484075d6317cc6616d95234'} from 'ACTIONS_MODULE0'\nexport {checkAgentCliInstalled as '40ce90bc4dfaf88079b648b8bebf9271e1ff650388'} from 'ACTIONS_MODULE0'\nexport {installAgentCli as '407994deb1605079bc7f7d7d119e1aedb3d719c7a8'} from 'ACTIONS_MODULE0'\nexport {resolveRepositoryByName as '404b9a81ad08961f5663afc48da41f5dea5266acce'} from 'ACTIONS_MODULE1'\nexport {copySessionAttachments as '704c9027e7bf3d827fd63f3e4f5fa807b18886e1ae'} from 'ACTIONS_MODULE2'\nexport {createSession as '70778b8dc6016e978ec4727eac642d772029330eda'} from 'ACTIONS_MODULE2'\nexport {deleteSession as '409403aa85eead3387f294f47402c012ceb5c91bbd'} from 'ACTIONS_MODULE2'\nexport {getSessionPrefillContext as '4070abb4a7b4faa1523dad0dc921f2c7e09885a380'} from 'ACTIONS_MODULE2'\nexport {listSessions as '40a8d0ecc48f9bb727d3395a6033866ee92b41a006'} from 'ACTIONS_MODULE2'\nexport {saveSessionLaunchContext as '60ec6db86191de8841beb65e6cd1e09bb6145fae5f'} from 'ACTIONS_MODULE2'\nexport {getConfig as '00cd80dc5a4a84c6544b997eb412d9fec0f08638d5'} from 'ACTIONS_MODULE3'\nexport {updateConfig as '4014476978d1b7b7928122371ecaf1a366c694b482'} from 'ACTIONS_MODULE3'\nexport {updateRepoSettings as '603cd11d6744363d69162d87cd83724a5ba6d81c66'} from 'ACTIONS_MODULE3'\nexport {listCredentials as '009a52b5211f7188280192b7f54d2b7d360227dbb3'} from 'ACTIONS_MODULE4'\n"],"names":["registerServerReference","ensureServerEntryExports","actions","i","length","action","Error"],"mappings":"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","ignoreList":[0,1]}
@@ -1,4 +0,0 @@
1
- module.exports=[33405,(a,b,c)=>{b.exports=a.x("child_process",()=>require("child_process"))},70722,(a,b,c)=>{b.exports=a.x("tty",()=>require("tty"))},24868,(a,b,c)=>{b.exports=a.x("fs/promises",()=>require("fs/promises"))},46786,(a,b,c)=>{b.exports=a.x("os",()=>require("os"))},37936,(a,b,c)=>{"use strict";Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"registerServerReference",{enumerable:!0,get:function(){return d.registerServerReference}});let d=a.r(11857)},13095,(a,b,c)=>{"use strict";function d(a){for(let b=0;b<a.length;b++){let c=a[b];if("function"!=typeof c)throw Object.defineProperty(Error(`A "use server" file can only export async functions, found ${typeof c}.
2
- Read more: https://nextjs.org/docs/messages/invalid-use-server-value`),"__NEXT_ERROR_CODE",{value:"E352",enumerable:!1,configurable:!0})}}Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"ensureServerEntryExports",{enumerable:!0,get:function(){return d}})},70798,a=>{"use strict";var b=a.i(24868),c=a.i(46786),d=a.i(14747);let e="viba-git-credentials",f=null,g=null,h=!1;function i(){return g?`Secure credential storage is unavailable: ${g}`:"Secure credential storage is unavailable in this runtime."}async function j(){return f||(f=a.A(45581).then(a=>a.default??a).catch(a=>(g=a instanceof Error?a.message:String(a),h||(h=!0,console.warn(`[credentials] ${i()}`)),null))),f}async function k(){let a=await j();if(!a)throw Error(i());return a}function l(){return`${Date.now()}-${Math.random().toString(36).slice(2,9)}`}function m(a){return a.trim().replace(/\/$/,"")}function n(a){return`credential-${a}`}function o(a){return`credential-${a}`}function p(a){return a.keytarAccount||n(a.id)}function q(a){return"gitlab"===a.type?{id:a.id,type:"gitlab",username:a.username,serverUrl:a.serverUrl||"https://gitlab.com",createdAt:a.createdAt,updatedAt:a.updatedAt}:{id:a.id,type:"github",username:a.username,createdAt:a.createdAt,updatedAt:a.updatedAt}}async function r(){let a=d.default.join(c.default.homedir(),".viba");return await b.default.mkdir(a,{recursive:!0}),d.default.join(a,"credentials.json")}function s(a,b){return!!a&&"object"==typeof a&&a.type===b&&"string"==typeof a.username&&"string"==typeof a.createdAt&&"string"==typeof a.updatedAt&&("gitlab"!==b||"string"==typeof a.serverUrl)}function t(a){return!!a&&"object"==typeof a&&"string"==typeof a.id&&!!a.id.trim()&&("github"===a.type||"gitlab"===a.type)&&"string"==typeof a.username&&"string"==typeof a.createdAt&&"string"==typeof a.updatedAt&&(void 0===a.keytarAccount||"string"==typeof a.keytarAccount)&&("gitlab"!==a.type||"string"==typeof a.serverUrl)}async function u(a){let c=await r();await b.default.writeFile(c,JSON.stringify(a,null,2),"utf-8")}async function v(){let a=await r();try{let c=await b.default.readFile(a,"utf-8"),d=JSON.parse(c);if(Array.isArray(d))return d.filter(t);if(!d||"object"!=typeof d)return[];let e=[];if(s(d.github,"github")){let a=d.github;e.push({id:l(),type:"github",username:a.username,createdAt:a.createdAt,updatedAt:a.updatedAt,keytarAccount:o("github")})}if(s(d.gitlab,"gitlab")){let a=d.gitlab;e.push({id:l(),type:"gitlab",username:a.username,serverUrl:a.serverUrl,createdAt:a.createdAt,updatedAt:a.updatedAt,keytarAccount:o("gitlab")})}return e.length>0&&await u(e),e}catch(a){if(a?.code==="ENOENT")return[];return console.error("Failed to parse credentials metadata:",a),[]}}async function w(){return(await v()).map(q).sort((a,b)=>b.updatedAt.localeCompare(a.updatedAt))}async function x(a){let b=(await v()).find(b=>b.id===a);return b?q(b):null}async function y(a){let b=(await v()).find(b=>b.id===a);if(!b)return null;let c=await j();return c?c.getPassword(e,p(b)):null}async function z(a){try{let b=await fetch("https://api.github.com/user",{headers:{Authorization:`Bearer ${a}`,Accept:"application/vnd.github+json","X-GitHub-Api-Version":"2022-11-28"}});if(!b.ok){if(401===b.status)return{valid:!1,error:"Invalid or expired GitHub token."};return{valid:!1,error:`GitHub API returned ${b.status}.`}}let c=await b.json(),d="string"==typeof c?.login?c.login:null;if(!d)return{valid:!1,error:"GitHub API response did not include a username."};return{valid:!0,username:d}}catch(a){return{valid:!1,error:`Failed to verify GitHub token: ${a.message}`}}}async function A(a,b){try{let c=m(a),d=await fetch(`${c}/api/v4/user`,{headers:{"PRIVATE-TOKEN":b}});if(!d.ok){if(401===d.status)return{valid:!1,error:"Invalid or expired GitLab token."};return{valid:!1,error:`GitLab API returned ${d.status}.`}}let e=await d.json(),f="string"==typeof e?.username?e.username:null;if(!f)return{valid:!1,error:"GitLab API response did not include a username."};return{valid:!0,username:f}}catch(a){return{valid:!1,error:`Failed to verify GitLab token: ${a.message}`}}}async function B(a){let b,c=a.trim();if(!c)return{success:!1,error:"GitHub token is required."};try{b=await k()}catch(a){return{success:!1,error:a.message}}let d=await z(c);if(!d.valid||!d.username)return{success:!1,error:d.error||"Failed to verify GitHub token."};let f=await v();if(f.find(a=>"github"===a.type&&a.username===d.username))return{success:!1,error:`A GitHub credential for ${d.username} already exists.`};let g=l(),h=new Date().toISOString(),i=n(g);await b.setPassword(e,i,c);let j={id:g,type:"github",username:d.username,createdAt:h,updatedAt:h,keytarAccount:i};return f.push(j),await u(f),{success:!0,credential:{id:j.id,type:"github",username:j.username,createdAt:j.createdAt,updatedAt:j.updatedAt}}}async function C(a,b){let c,d=m(a),f=b.trim();if(!d)return{success:!1,error:"GitLab server URL is required."};try{new URL(d)}catch{return{success:!1,error:"GitLab server URL must be a valid URL."}}if(!f)return{success:!1,error:"GitLab token is required."};try{c=await k()}catch(a){return{success:!1,error:a.message}}let g=await A(d,f);if(!g.valid||!g.username)return{success:!1,error:g.error||"Failed to verify GitLab token."};let h=await v();if(h.find(a=>"gitlab"===a.type&&a.username===g.username&&a.serverUrl===d))return{success:!1,error:`A GitLab credential for ${g.username} on ${d} already exists.`};let i=l(),j=new Date().toISOString(),o=n(i);await c.setPassword(e,o,f);let p={id:i,type:"gitlab",username:g.username,serverUrl:d,createdAt:j,updatedAt:j,keytarAccount:o};return h.push(p),await u(h),{success:!0,credential:{id:p.id,type:"gitlab",username:p.username,serverUrl:p.serverUrl||d,createdAt:p.createdAt,updatedAt:p.updatedAt}}}async function D(a){let b=await v(),c=b.findIndex(b=>b.id===a);if(-1===c)return{success:!1,error:"Credential not found."};let d=b[c];b.splice(c,1),await u(b);let f=await j();return f&&await f.deletePassword(e,p(d)),{success:!0}}a.s(["createGitHubCredential",()=>B,"createGitLabCredential",()=>C,"deleteCredential",()=>D,"getAllCredentials",()=>w,"getCredentialById",()=>x,"getCredentialToken",()=>y])},37359,a=>{"use strict";var b=a.i(37936),c=a.i(70798);async function d(){try{let a=await (0,c.getAllCredentials)();return{success:!0,credentials:a}}catch(a){return console.error("Failed to list credentials:",a),{success:!1,error:"Failed to load credentials."}}}async function e(a){let b=await (0,c.createGitHubCredential)(a);return b.success&&b.credential?{success:!0,credential:b.credential}:{success:!1,error:b.error||"Failed to save GitHub credential."}}async function f(a,b){let d=await (0,c.createGitLabCredential)(a,b);return d.success&&d.credential?{success:!0,credential:d.credential}:{success:!1,error:d.error||"Failed to save GitLab credential."}}async function g(a){try{let b=await (0,c.deleteCredential)(a);if(!b.success)return{success:!1,error:b.error||"Failed to remove credential."};return{success:!0}}catch(a){return console.error("Failed to remove credential:",a),{success:!1,error:"Failed to remove credential."}}}(0,a.i(13095).ensureServerEntryExports)([d,e,f,g]),(0,b.registerServerReference)(d,"009a52b5211f7188280192b7f54d2b7d360227dbb3",null),(0,b.registerServerReference)(e,"40be8b850b232f864e7ab716e5d1d982c37793c20b",null),(0,b.registerServerReference)(f,"60c0fb15bb860aa80aab9cecb3b35b3b7faec3a36b",null),(0,b.registerServerReference)(g,"40badba051858a0eefeb404f511e0df8053a815b20",null),a.s(["listCredentials",()=>d,"removeCredential",()=>g,"saveGitHubCredential",()=>e,"saveGitLabCredential",()=>f])},98624,a=>{"use strict";var b=a.i(37936),c=a.i(24868),d=a.i(14747),e=a.i(38642);let f=new Set([".git","node_modules",".next",".viba","dist","build","coverage"]);function g(){return global.repoResolutionCache||(global.repoResolutionCache=new Map),global.repoResolutionCache}function h(a,b){g().set(a.toLowerCase(),{repoPath:b,resolvedAt:Date.now()})}async function i(a){let b=g().get(a.toLowerCase());return b?Date.now()-b.resolvedAt>3e5?(g().delete(a.toLowerCase()),null):await j(b.repoPath)?b.repoPath:(g().delete(a.toLowerCase()),null):null}async function j(a){try{return await c.default.access(d.default.join(a,".git")),!0}catch{return!1}}async function k(a,b){let e=d.default.join(a,b);if(await j(e))return e;let g=[{dirPath:a,depth:0}],h=0,i=b.toLowerCase();for(let a=0;a<g.length;a+=1){let b,e=g[a];if((h+=1)>5e3)break;try{b=await c.default.readdir(e.dirPath,{withFileTypes:!0})}catch{continue}for(let a of b){if(!a.isDirectory()||function(a,b){let c=a.toLowerCase();return c!==b&&!!(f.has(c)||a.startsWith("."))}(a.name,i))continue;let b=d.default.join(e.dirPath,a.name);if(a.name.toLowerCase()===i&&await j(b))return b;e.depth+1<=5&&g.push({dirPath:b,depth:e.depth+1})}}return null}async function l(a){let b=a.trim();if(!b)return null;let c=await i(b);if(c)return c;let f=await (0,e.getConfig)();for(let a of f.recentRepos.filter(a=>d.default.basename(a).toLowerCase()===b.toLowerCase()))if(await j(a))return h(b,a),a;let g=[],l=new Set;for(let a of f.recentRepos){let b=d.default.dirname(a);l.has(b)||(l.add(b),g.push(b))}for(let a of(f.defaultRoot&&!l.has(f.defaultRoot)&&(l.add(f.defaultRoot),g.push(f.defaultRoot)),g)){let c=await k(a,b);if(c)return h(b,c),c}return null}async function m(a){try{let b=await l(a);return{success:!0,repoPath:b}}catch(a){return console.error("Failed to resolve repository by name:",a),{success:!1,repoPath:null,error:"Failed to search repositories. Please try again."}}}(0,a.i(13095).ensureServerEntryExports)([m]),(0,b.registerServerReference)(m,"404b9a81ad08961f5663afc48da41f5dea5266acce",null),a.s(["resolveRepositoryByName",()=>m],98624)},72496,a=>{"use strict";var b=a.i(15271),c=a.i(98624),d=a.i(51817),e=a.i(38642),f=a.i(37359);a.s([],17406),a.i(17406),a.s(["005d259cc8fa8d952f814b4fb979df53e92986d9a5",()=>b.getHomeDirectory,"009a52b5211f7188280192b7f54d2b7d360227dbb3",()=>f.listCredentials,"00cd80dc5a4a84c6544b997eb412d9fec0f08638d5",()=>e.getConfig,"4014476978d1b7b7928122371ecaf1a366c694b482",()=>e.updateConfig,"403ef707dab230c18860718e1bdf896059f3d5fd91",()=>b.checkDirectoryAccessible,"404b9a81ad08961f5663afc48da41f5dea5266acce",()=>c.resolveRepositoryByName,"4070abb4a7b4faa1523dad0dc921f2c7e09885a380",()=>d.getSessionPrefillContext,"407994deb1605079bc7f7d7d119e1aedb3d719c7a8",()=>b.installAgentCli,"40926025dfa54333beb998cd7af50d262b08857b7d",()=>b.listDirectories,"409403aa85eead3387f294f47402c012ceb5c91bbd",()=>d.deleteSession,"40a7796191f83d4a386060c5b8728adf970b9cbf2c",()=>b.checkIsGitRepo,"40a8d0ecc48f9bb727d3395a6033866ee92b41a006",()=>d.listSessions,"40ce90bc4dfaf88079b648b8bebf9271e1ff650388",()=>b.checkAgentCliInstalled,"40ef3d541634346a280afe8eb270b20a44e65c12f0",()=>b.getBranches,"6039f5f40f5cf0d2cc408be7a9ae5bfb689d8ac196",()=>b.checkoutBranch,"603cd11d6744363d69162d87cd83724a5ba6d81c66",()=>e.updateRepoSettings,"60ec6db86191de8841beb65e6cd1e09bb6145fae5f",()=>d.saveSessionLaunchContext,"704c9027e7bf3d827fd63f3e4f5fa807b18886e1ae",()=>d.copySessionAttachments,"70778b8dc6016e978ec4727eac642d772029330eda",()=>d.createSession,"7f2fc548d4b7196815ce7140fbc75c85a186233828",()=>b.listRepoFiles,"7f5447571c45e842042484075d6317cc6616d95234",()=>b.saveAttachments,"7f9f1c8bfbea857703a62a8b12c5404cc5fe241ff2",()=>b.startTtydProcess,"7fa7e9c4cf5a3fd0284293b74e27199a5b60b6fdf5",()=>b.getDefaultDevServerScript,"7ffe03accac8ebe36db5f881f52a53547a4e0e9903",()=>b.getStartupScript],72496)},45581,a=>{a.v(b=>Promise.all(["server/chunks/ssr/[externals]_keytar_23140f5c._.js"].map(b=>a.l(b))).then(()=>b(83034)))},44264,a=>{a.v(a=>Promise.resolve().then(()=>a(33405)))},37706,a=>{a.v(b=>Promise.all(["server/chunks/ssr/[root-of-the-server]__edf0aa7a._.js"].map(b=>a.l(b))).then(()=>b(78775)))}];
3
-
4
- //# sourceMappingURL=%5Broot-of-the-server%5D__3e7d3e82._.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../node_modules/next/src/build/webpack/loaders/next-flight-loader/server-reference.ts","../../../../node_modules/next/src/build/webpack/loaders/next-flight-loader/action-validate.ts","../../../../src/lib/credentials.ts","../../../../src/app/actions/credentials.ts","../../../../src/lib/repo-resolver.ts","../../../../src/app/actions/repository.ts","../../../../.next-internal/server/app/new/page/actions.js%20%28server%20actions%20loader%29"],"sourcesContent":["/* eslint-disable import/no-extraneous-dependencies */\nexport { registerServerReference } from 'react-server-dom-webpack/server'\n","// This function ensures that all the exported values are valid server actions,\n// during the runtime. By definition all actions are required to be async\n// functions, but here we can only check that they are functions.\nexport function ensureServerEntryExports(actions: any[]) {\n for (let i = 0; i < actions.length; i++) {\n const action = actions[i]\n if (typeof action !== 'function') {\n throw new Error(\n `A \"use server\" file can only export async functions, found ${typeof action}.\\nRead more: https://nextjs.org/docs/messages/invalid-use-server-value`\n )\n }\n }\n}\n","import fs from 'fs/promises';\nimport os from 'os';\nimport path from 'path';\n\nconst SERVICE_NAME = 'viba-git-credentials';\nconst CREDENTIALS_FILE_NAME = 'credentials.json';\n\nexport type CredentialType = 'github' | 'gitlab';\n\nexport interface BaseCredential {\n id: string;\n type: CredentialType;\n username: string;\n createdAt: string;\n updatedAt: string;\n}\n\nexport interface GitHubCredential extends BaseCredential {\n type: 'github';\n}\n\nexport interface GitLabCredential extends BaseCredential {\n type: 'gitlab';\n serverUrl: string;\n}\n\nexport type Credential = GitHubCredential | GitLabCredential;\n\ntype CredentialMetadata = {\n id: string;\n type: CredentialType;\n username: string;\n serverUrl?: string;\n createdAt: string;\n updatedAt: string;\n keytarAccount?: string;\n};\n\ntype LegacyCredentialMetadata = {\n type: CredentialType;\n username: string;\n serverUrl?: string;\n createdAt: string;\n updatedAt: string;\n};\n\ntype KeytarModule = {\n getPassword(service: string, account: string): Promise<string | null>;\n setPassword(service: string, account: string, password: string): Promise<void>;\n deletePassword(service: string, account: string): Promise<boolean>;\n};\n\nlet keytarPromise: Promise<KeytarModule | null> | null = null;\nlet keytarUnavailableReason: string | null = null;\nlet didLogKeytarWarning = false;\n\nfunction keytarUnavailableMessage(): string {\n if (keytarUnavailableReason) {\n return `Secure credential storage is unavailable: ${keytarUnavailableReason}`;\n }\n return 'Secure credential storage is unavailable in this runtime.';\n}\n\nasync function loadKeytar(): Promise<KeytarModule | null> {\n if (!keytarPromise) {\n keytarPromise = import('keytar')\n .then((module) => (module.default ?? module) as KeytarModule)\n .catch((error: unknown) => {\n keytarUnavailableReason = error instanceof Error ? error.message : String(error);\n if (!didLogKeytarWarning) {\n didLogKeytarWarning = true;\n console.warn(`[credentials] ${keytarUnavailableMessage()}`);\n }\n return null;\n });\n }\n\n return keytarPromise;\n}\n\nasync function requireKeytar(): Promise<KeytarModule> {\n const keytar = await loadKeytar();\n if (!keytar) {\n throw new Error(keytarUnavailableMessage());\n }\n return keytar;\n}\n\nfunction generateId(): string {\n return `${Date.now()}-${Math.random().toString(36).slice(2, 9)}`;\n}\n\nfunction normalizeGitLabServerUrl(serverUrl: string): string {\n return serverUrl.trim().replace(/\\/$/, '');\n}\n\nfunction getDefaultKeytarAccount(id: string): string {\n return `credential-${id}`;\n}\n\nfunction getLegacyKeytarAccount(type: CredentialType): string {\n return `credential-${type}`;\n}\n\nfunction getKeytarAccountForMetadata(metadata: CredentialMetadata): string {\n return metadata.keytarAccount || getDefaultKeytarAccount(metadata.id);\n}\n\nfunction toCredential(metadata: CredentialMetadata): Credential {\n if (metadata.type === 'gitlab') {\n return {\n id: metadata.id,\n type: 'gitlab',\n username: metadata.username,\n serverUrl: metadata.serverUrl || 'https://gitlab.com',\n createdAt: metadata.createdAt,\n updatedAt: metadata.updatedAt,\n };\n }\n\n return {\n id: metadata.id,\n type: 'github',\n username: metadata.username,\n createdAt: metadata.createdAt,\n updatedAt: metadata.updatedAt,\n };\n}\n\nasync function getCredentialsFilePath(): Promise<string> {\n const vibaDir = path.join(os.homedir(), '.viba');\n await fs.mkdir(vibaDir, { recursive: true });\n return path.join(vibaDir, CREDENTIALS_FILE_NAME);\n}\n\nfunction isLegacyCredentialMetadata(value: unknown, expectedType: CredentialType): value is LegacyCredentialMetadata {\n if (!value || typeof value !== 'object') return false;\n\n const candidate = value as Record<string, unknown>;\n if (candidate.type !== expectedType) return false;\n if (typeof candidate.username !== 'string') return false;\n if (typeof candidate.createdAt !== 'string') return false;\n if (typeof candidate.updatedAt !== 'string') return false;\n\n if (expectedType === 'gitlab') {\n return typeof candidate.serverUrl === 'string';\n }\n\n return true;\n}\n\nfunction isCredentialMetadata(value: unknown): value is CredentialMetadata {\n if (!value || typeof value !== 'object') return false;\n\n const candidate = value as Record<string, unknown>;\n if (typeof candidate.id !== 'string' || !candidate.id.trim()) return false;\n if (candidate.type !== 'github' && candidate.type !== 'gitlab') return false;\n if (typeof candidate.username !== 'string') return false;\n if (typeof candidate.createdAt !== 'string') return false;\n if (typeof candidate.updatedAt !== 'string') return false;\n if (candidate.keytarAccount !== undefined && typeof candidate.keytarAccount !== 'string') return false;\n\n if (candidate.type === 'gitlab') {\n return typeof candidate.serverUrl === 'string';\n }\n\n return true;\n}\n\nasync function writeCredentialsMetadata(metadata: CredentialMetadata[]): Promise<void> {\n const credentialsFilePath = await getCredentialsFilePath();\n await fs.writeFile(credentialsFilePath, JSON.stringify(metadata, null, 2), 'utf-8');\n}\n\nasync function readCredentialsMetadata(): Promise<CredentialMetadata[]> {\n const credentialsFilePath = await getCredentialsFilePath();\n\n try {\n const content = await fs.readFile(credentialsFilePath, 'utf-8');\n const parsed = JSON.parse(content) as unknown;\n\n if (Array.isArray(parsed)) {\n return parsed.filter(isCredentialMetadata);\n }\n\n if (!parsed || typeof parsed !== 'object') {\n return [];\n }\n\n const legacyMapped = parsed as Record<string, unknown>;\n const migrated: CredentialMetadata[] = [];\n\n if (isLegacyCredentialMetadata(legacyMapped.github, 'github')) {\n const metadata = legacyMapped.github;\n migrated.push({\n id: generateId(),\n type: 'github',\n username: metadata.username,\n createdAt: metadata.createdAt,\n updatedAt: metadata.updatedAt,\n keytarAccount: getLegacyKeytarAccount('github'),\n });\n }\n\n if (isLegacyCredentialMetadata(legacyMapped.gitlab, 'gitlab')) {\n const metadata = legacyMapped.gitlab;\n migrated.push({\n id: generateId(),\n type: 'gitlab',\n username: metadata.username,\n serverUrl: metadata.serverUrl,\n createdAt: metadata.createdAt,\n updatedAt: metadata.updatedAt,\n keytarAccount: getLegacyKeytarAccount('gitlab'),\n });\n }\n\n if (migrated.length > 0) {\n await writeCredentialsMetadata(migrated);\n }\n\n return migrated;\n } catch (error) {\n if ((error as NodeJS.ErrnoException)?.code === 'ENOENT') {\n return [];\n }\n\n console.error('Failed to parse credentials metadata:', error);\n return [];\n }\n}\n\nexport async function getAllCredentials(): Promise<Credential[]> {\n const metadata = await readCredentialsMetadata();\n\n return metadata\n .map(toCredential)\n .sort((a, b) => b.updatedAt.localeCompare(a.updatedAt));\n}\n\nexport async function getCredentialById(id: string): Promise<Credential | null> {\n const metadata = await readCredentialsMetadata();\n const found = metadata.find((credential) => credential.id === id);\n return found ? toCredential(found) : null;\n}\n\nexport async function getCredentialToken(id: string): Promise<string | null> {\n const metadata = await readCredentialsMetadata();\n const found = metadata.find((credential) => credential.id === id);\n if (!found) {\n return null;\n }\n\n const keytar = await loadKeytar();\n if (!keytar) {\n return null;\n }\n\n return keytar.getPassword(SERVICE_NAME, getKeytarAccountForMetadata(found));\n}\n\nasync function verifyGitHubToken(token: string): Promise<{ valid: boolean; username?: string; error?: string }> {\n try {\n const response = await fetch('https://api.github.com/user', {\n headers: {\n Authorization: `Bearer ${token}`,\n Accept: 'application/vnd.github+json',\n 'X-GitHub-Api-Version': '2022-11-28',\n },\n });\n\n if (!response.ok) {\n if (response.status === 401) {\n return { valid: false, error: 'Invalid or expired GitHub token.' };\n }\n return { valid: false, error: `GitHub API returned ${response.status}.` };\n }\n\n const data = await response.json();\n const username = typeof data?.login === 'string' ? data.login : null;\n if (!username) {\n return { valid: false, error: 'GitHub API response did not include a username.' };\n }\n\n return { valid: true, username };\n } catch (error) {\n return { valid: false, error: `Failed to verify GitHub token: ${(error as Error).message}` };\n }\n}\n\nasync function verifyGitLabToken(serverUrl: string, token: string): Promise<{ valid: boolean; username?: string; error?: string }> {\n try {\n const normalizedUrl = normalizeGitLabServerUrl(serverUrl);\n const response = await fetch(`${normalizedUrl}/api/v4/user`, {\n headers: {\n 'PRIVATE-TOKEN': token,\n },\n });\n\n if (!response.ok) {\n if (response.status === 401) {\n return { valid: false, error: 'Invalid or expired GitLab token.' };\n }\n return { valid: false, error: `GitLab API returned ${response.status}.` };\n }\n\n const data = await response.json();\n const username = typeof data?.username === 'string' ? data.username : null;\n if (!username) {\n return { valid: false, error: 'GitLab API response did not include a username.' };\n }\n\n return { valid: true, username };\n } catch (error) {\n return { valid: false, error: `Failed to verify GitLab token: ${(error as Error).message}` };\n }\n}\n\nexport async function createGitHubCredential(token: string): Promise<{ success: boolean; credential?: GitHubCredential; error?: string }> {\n const trimmedToken = token.trim();\n if (!trimmedToken) {\n return { success: false, error: 'GitHub token is required.' };\n }\n\n let keytar: KeytarModule;\n try {\n keytar = await requireKeytar();\n } catch (error) {\n return { success: false, error: (error as Error).message };\n }\n\n const verification = await verifyGitHubToken(trimmedToken);\n if (!verification.valid || !verification.username) {\n return { success: false, error: verification.error || 'Failed to verify GitHub token.' };\n }\n\n const metadata = await readCredentialsMetadata();\n const duplicate = metadata.find((credential) => (\n credential.type === 'github'\n && credential.username === verification.username\n ));\n\n if (duplicate) {\n return { success: false, error: `A GitHub credential for ${verification.username} already exists.` };\n }\n\n const id = generateId();\n const now = new Date().toISOString();\n const keytarAccount = getDefaultKeytarAccount(id);\n\n await keytar.setPassword(SERVICE_NAME, keytarAccount, trimmedToken);\n\n const created: CredentialMetadata = {\n id,\n type: 'github',\n username: verification.username,\n createdAt: now,\n updatedAt: now,\n keytarAccount,\n };\n\n metadata.push(created);\n await writeCredentialsMetadata(metadata);\n\n return {\n success: true,\n credential: {\n id: created.id,\n type: 'github',\n username: created.username,\n createdAt: created.createdAt,\n updatedAt: created.updatedAt,\n },\n };\n}\n\nexport async function createGitLabCredential(\n serverUrl: string,\n token: string,\n): Promise<{ success: boolean; credential?: GitLabCredential; error?: string }> {\n const normalizedServerUrl = normalizeGitLabServerUrl(serverUrl);\n const trimmedToken = token.trim();\n\n if (!normalizedServerUrl) {\n return { success: false, error: 'GitLab server URL is required.' };\n }\n\n try {\n new URL(normalizedServerUrl);\n } catch {\n return { success: false, error: 'GitLab server URL must be a valid URL.' };\n }\n\n if (!trimmedToken) {\n return { success: false, error: 'GitLab token is required.' };\n }\n\n let keytar: KeytarModule;\n try {\n keytar = await requireKeytar();\n } catch (error) {\n return { success: false, error: (error as Error).message };\n }\n\n const verification = await verifyGitLabToken(normalizedServerUrl, trimmedToken);\n if (!verification.valid || !verification.username) {\n return { success: false, error: verification.error || 'Failed to verify GitLab token.' };\n }\n\n const metadata = await readCredentialsMetadata();\n const duplicate = metadata.find((credential) => (\n credential.type === 'gitlab'\n && credential.username === verification.username\n && credential.serverUrl === normalizedServerUrl\n ));\n\n if (duplicate) {\n return {\n success: false,\n error: `A GitLab credential for ${verification.username} on ${normalizedServerUrl} already exists.`,\n };\n }\n\n const id = generateId();\n const now = new Date().toISOString();\n const keytarAccount = getDefaultKeytarAccount(id);\n\n await keytar.setPassword(SERVICE_NAME, keytarAccount, trimmedToken);\n\n const created: CredentialMetadata = {\n id,\n type: 'gitlab',\n username: verification.username,\n serverUrl: normalizedServerUrl,\n createdAt: now,\n updatedAt: now,\n keytarAccount,\n };\n\n metadata.push(created);\n await writeCredentialsMetadata(metadata);\n\n return {\n success: true,\n credential: {\n id: created.id,\n type: 'gitlab',\n username: created.username,\n serverUrl: created.serverUrl || normalizedServerUrl,\n createdAt: created.createdAt,\n updatedAt: created.updatedAt,\n },\n };\n}\n\nexport async function deleteCredential(id: string): Promise<{ success: boolean; error?: string }> {\n const metadata = await readCredentialsMetadata();\n const index = metadata.findIndex((credential) => credential.id === id);\n\n if (index === -1) {\n return { success: false, error: 'Credential not found.' };\n }\n\n const credential = metadata[index];\n metadata.splice(index, 1);\n await writeCredentialsMetadata(metadata);\n\n const keytar = await loadKeytar();\n if (keytar) {\n await keytar.deletePassword(SERVICE_NAME, getKeytarAccountForMetadata(credential));\n }\n\n return { success: true };\n}\n","'use server';\n\nimport {\n createGitHubCredential,\n createGitLabCredential,\n deleteCredential,\n getAllCredentials,\n} from '@/lib/credentials';\nimport type { Credential } from '@/lib/credentials';\n\ntype ListCredentialsResult =\n | { success: true; credentials: Credential[] }\n | { success: false; error: string };\n\nexport async function listCredentials(): Promise<ListCredentialsResult> {\n try {\n const credentials = await getAllCredentials();\n return { success: true, credentials };\n } catch (error) {\n console.error('Failed to list credentials:', error);\n return { success: false, error: 'Failed to load credentials.' };\n }\n}\n\ntype SaveCredentialResult =\n | { success: true; credential: Credential }\n | { success: false; error: string };\n\nexport async function saveGitHubCredential(token: string): Promise<SaveCredentialResult> {\n const result = await createGitHubCredential(token);\n if (!result.success || !result.credential) {\n return { success: false, error: result.error || 'Failed to save GitHub credential.' };\n }\n\n return { success: true, credential: result.credential };\n}\n\nexport async function saveGitLabCredential(serverUrl: string, token: string): Promise<SaveCredentialResult> {\n const result = await createGitLabCredential(serverUrl, token);\n if (!result.success || !result.credential) {\n return { success: false, error: result.error || 'Failed to save GitLab credential.' };\n }\n\n return { success: true, credential: result.credential };\n}\n\ntype RemoveCredentialResult =\n | { success: true }\n | { success: false; error: string };\n\nexport async function removeCredential(id: string): Promise<RemoveCredentialResult> {\n try {\n const result = await deleteCredential(id);\n if (!result.success) {\n return { success: false, error: result.error || 'Failed to remove credential.' };\n }\n\n return { success: true };\n } catch (error) {\n console.error('Failed to remove credential:', error);\n return { success: false, error: 'Failed to remove credential.' };\n }\n}\n","import fs from 'fs/promises';\nimport type { Dirent } from 'fs';\nimport path from 'path';\nimport { getConfig } from '@/app/actions/config';\n\nconst MAX_SCAN_DEPTH = 5;\nconst MAX_SCANNED_DIRECTORIES = 5000;\nconst RESOLUTION_CACHE_TTL_MS = 5 * 60 * 1000;\nconst SKIPPED_DIR_NAMES = new Set([\n '.git',\n 'node_modules',\n '.next',\n '.viba',\n 'dist',\n 'build',\n 'coverage',\n]);\n\ntype RepoResolutionCacheEntry = {\n repoPath: string;\n resolvedAt: number;\n};\n\ndeclare global {\n var repoResolutionCache: Map<string, RepoResolutionCacheEntry> | undefined;\n}\n\nfunction getResolutionCache(): Map<string, RepoResolutionCacheEntry> {\n if (!global.repoResolutionCache) {\n global.repoResolutionCache = new Map<string, RepoResolutionCacheEntry>();\n }\n return global.repoResolutionCache;\n}\n\nfunction cacheResolution(repoName: string, repoPath: string): void {\n getResolutionCache().set(repoName.toLowerCase(), {\n repoPath,\n resolvedAt: Date.now(),\n });\n}\n\nasync function getValidCachedResolution(repoName: string): Promise<string | null> {\n const entry = getResolutionCache().get(repoName.toLowerCase());\n if (!entry) return null;\n if (Date.now() - entry.resolvedAt > RESOLUTION_CACHE_TTL_MS) {\n getResolutionCache().delete(repoName.toLowerCase());\n return null;\n }\n\n if (await isGitRepository(entry.repoPath)) {\n return entry.repoPath;\n }\n\n getResolutionCache().delete(repoName.toLowerCase());\n return null;\n}\n\nasync function isGitRepository(dirPath: string): Promise<boolean> {\n try {\n await fs.access(path.join(dirPath, '.git'));\n return true;\n } catch {\n return false;\n }\n}\n\nfunction hasMatchingName(repoPath: string, repoName: string): boolean {\n return path.basename(repoPath).toLowerCase() === repoName.toLowerCase();\n}\n\nfunction shouldSkipDirectory(entryName: string, targetName: string): boolean {\n const lowerName = entryName.toLowerCase();\n if (lowerName === targetName) return false;\n if (SKIPPED_DIR_NAMES.has(lowerName)) return true;\n if (entryName.startsWith('.')) return true;\n return false;\n}\n\nasync function findByNameWithinRoot(rootPath: string, repoName: string): Promise<string | null> {\n const directCandidate = path.join(rootPath, repoName);\n if (await isGitRepository(directCandidate)) {\n return directCandidate;\n }\n\n const queue: Array<{ dirPath: string; depth: number }> = [{ dirPath: rootPath, depth: 0 }];\n let scannedCount = 0;\n const targetName = repoName.toLowerCase();\n\n for (let index = 0; index < queue.length; index += 1) {\n const current = queue[index];\n scannedCount += 1;\n if (scannedCount > MAX_SCANNED_DIRECTORIES) {\n break;\n }\n\n let entries: Dirent[];\n try {\n entries = await fs.readdir(current.dirPath, { withFileTypes: true });\n } catch {\n continue;\n }\n\n for (const entry of entries) {\n if (!entry.isDirectory()) continue;\n if (shouldSkipDirectory(entry.name, targetName)) continue;\n\n const nextDirPath = path.join(current.dirPath, entry.name);\n\n if (entry.name.toLowerCase() === targetName && await isGitRepository(nextDirPath)) {\n return nextDirPath;\n }\n\n if (current.depth + 1 <= MAX_SCAN_DEPTH) {\n queue.push({ dirPath: nextDirPath, depth: current.depth + 1 });\n }\n }\n }\n\n return null;\n}\n\nexport async function resolveRepositoryPathByName(repoName: string): Promise<string | null> {\n const trimmedName = repoName.trim();\n if (!trimmedName) return null;\n\n const cachedResolution = await getValidCachedResolution(trimmedName);\n if (cachedResolution) {\n return cachedResolution;\n }\n\n const config = await getConfig();\n\n const recentMatches = config.recentRepos.filter((repoPath) => hasMatchingName(repoPath, trimmedName));\n for (const repoPath of recentMatches) {\n if (await isGitRepository(repoPath)) {\n cacheResolution(trimmedName, repoPath);\n return repoPath;\n }\n }\n\n const searchRoots: string[] = [];\n const visitedRoots = new Set<string>();\n for (const repoPath of config.recentRepos) {\n const parentPath = path.dirname(repoPath);\n if (!visitedRoots.has(parentPath)) {\n visitedRoots.add(parentPath);\n searchRoots.push(parentPath);\n }\n }\n if (config.defaultRoot && !visitedRoots.has(config.defaultRoot)) {\n visitedRoots.add(config.defaultRoot);\n searchRoots.push(config.defaultRoot);\n }\n\n for (const rootPath of searchRoots) {\n const resolvedPath = await findByNameWithinRoot(rootPath, trimmedName);\n if (resolvedPath) {\n cacheResolution(trimmedName, resolvedPath);\n return resolvedPath;\n }\n }\n\n return null;\n}\n","'use server';\n\nimport { resolveRepositoryPathByName } from '@/lib/repo-resolver';\n\ntype ResolveRepositoryResult = {\n success: boolean;\n repoPath: string | null;\n error?: string;\n};\n\nexport async function resolveRepositoryByName(repoName: string): Promise<ResolveRepositoryResult> {\n try {\n const resolvedPath = await resolveRepositoryPathByName(repoName);\n return {\n success: true,\n repoPath: resolvedPath,\n };\n } catch (error) {\n console.error('Failed to resolve repository by name:', error);\n return {\n success: false,\n repoPath: null,\n error: 'Failed to search repositories. Please try again.',\n };\n }\n}\n","export {checkDirectoryAccessible as '403ef707dab230c18860718e1bdf896059f3d5fd91'} from 'ACTIONS_MODULE0'\nexport {listDirectories as '40926025dfa54333beb998cd7af50d262b08857b7d'} from 'ACTIONS_MODULE0'\nexport {getHomeDirectory as '005d259cc8fa8d952f814b4fb979df53e92986d9a5'} from 'ACTIONS_MODULE0'\nexport {checkIsGitRepo as '40a7796191f83d4a386060c5b8728adf970b9cbf2c'} from 'ACTIONS_MODULE0'\nexport {getBranches as '40ef3d541634346a280afe8eb270b20a44e65c12f0'} from 'ACTIONS_MODULE0'\nexport {checkoutBranch as '6039f5f40f5cf0d2cc408be7a9ae5bfb689d8ac196'} from 'ACTIONS_MODULE0'\nexport {startTtydProcess as '7f9f1c8bfbea857703a62a8b12c5404cc5fe241ff2'} from 'ACTIONS_MODULE0'\nexport {getStartupScript as '7ffe03accac8ebe36db5f881f52a53547a4e0e9903'} from 'ACTIONS_MODULE0'\nexport {getDefaultDevServerScript as '7fa7e9c4cf5a3fd0284293b74e27199a5b60b6fdf5'} from 'ACTIONS_MODULE0'\nexport {listRepoFiles as '7f2fc548d4b7196815ce7140fbc75c85a186233828'} from 'ACTIONS_MODULE0'\nexport {saveAttachments as '7f5447571c45e842042484075d6317cc6616d95234'} from 'ACTIONS_MODULE0'\nexport {checkAgentCliInstalled as '40ce90bc4dfaf88079b648b8bebf9271e1ff650388'} from 'ACTIONS_MODULE0'\nexport {installAgentCli as '407994deb1605079bc7f7d7d119e1aedb3d719c7a8'} from 'ACTIONS_MODULE0'\nexport {resolveRepositoryByName as '404b9a81ad08961f5663afc48da41f5dea5266acce'} from 'ACTIONS_MODULE1'\nexport {copySessionAttachments as '704c9027e7bf3d827fd63f3e4f5fa807b18886e1ae'} from 'ACTIONS_MODULE2'\nexport {createSession as '70778b8dc6016e978ec4727eac642d772029330eda'} from 'ACTIONS_MODULE2'\nexport {deleteSession as '409403aa85eead3387f294f47402c012ceb5c91bbd'} from 'ACTIONS_MODULE2'\nexport {getSessionPrefillContext as '4070abb4a7b4faa1523dad0dc921f2c7e09885a380'} from 'ACTIONS_MODULE2'\nexport {listSessions as '40a8d0ecc48f9bb727d3395a6033866ee92b41a006'} from 'ACTIONS_MODULE2'\nexport {saveSessionLaunchContext as '60ec6db86191de8841beb65e6cd1e09bb6145fae5f'} from 'ACTIONS_MODULE2'\nexport {getConfig as '00cd80dc5a4a84c6544b997eb412d9fec0f08638d5'} from 'ACTIONS_MODULE3'\nexport {updateConfig as '4014476978d1b7b7928122371ecaf1a366c694b482'} from 'ACTIONS_MODULE3'\nexport {updateRepoSettings as '603cd11d6744363d69162d87cd83724a5ba6d81c66'} from 'ACTIONS_MODULE3'\nexport {listCredentials as '009a52b5211f7188280192b7f54d2b7d360227dbb3'} from 'ACTIONS_MODULE4'\n"],"names":["registerServerReference","ensureServerEntryExports","actions","i","length","action","Error"],"mappings":"mTAAoD,OAAA,cAAA,CAAA,EAAA,aAAA,oCAC3CA,0BAAAA,qCAAAA,EAAAA,uBAAuB,YAAQ,CAAA,CAAA,IAAA,iCCEjC,SAASC,EAAyBC,CAAc,EACrD,IAAK,IAAIC,EAAI,EAAGA,EAAID,EAAQE,MAAM,CAAED,IAAK,CACvC,IAAME,EAASH,CAAO,CAACC,EAAE,CACzB,GAAsB,YAAY,AAA9B,OAAOE,EACT,MAAM,OAAA,cAEL,CAFK,AAAIC,MACR,CAAC,2DAA2D,EAAE,OAAOD,EAAO;AAAA,oEAAuE,CAAC,EADhJ,oBAAA,OAAA,mBAAA,gBAAA,CAEN,EAEJ,CACF,0EATgBJ,2BAAAA,qCAAAA,6BCHhB,IAAA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OAEA,IAAM,EAAe,uBAgDjB,EAAqD,KACrD,EAAyC,KACzC,GAAsB,EAE1B,SAAS,WACP,AAAI,EACK,CAAC,sBADmB,oBACuB,EAAE,EAAA,CAAyB,CAExE,2DACT,CAEA,eAAe,IAcb,OAbI,AAAC,IACH,EAAgB,EAAA,CAAA,CAAA,KADE,EAEf,IAAI,CAAC,AAAC,GAAY,EAAO,OAAO,EAAI,GACpC,KAAK,CAAC,AAAC,IACN,EAA0B,aAAiB,MAAQ,EAAM,OAAO,CAAG,OAAO,GACrE,IACH,GAAsB,EACtB,QAAQ,IAFgB,AAEZ,CAAC,CAAC,cAAc,EAAE,IAAA,CAA4B,GAErD,MACT,EAGG,CACT,CAEA,eAAe,IACb,IAAM,EAAS,MAAM,IACrB,GAAI,CAAC,EACH,MADW,AACL,AAAI,MAAM,KAElB,OAAO,CACT,CAEA,SAAS,IACP,MAAO,CAAA,EAAG,KAAK,GAAG,GAAG,CAAC,EAAE,KAAK,MAAM,GAAG,QAAQ,CAAC,IAAI,KAAK,CAAC,EAAG,GAAA,CAAI,AAClE,CAEA,SAAS,EAAyB,CAAiB,EACjD,OAAO,EAAU,IAAI,GAAG,OAAO,CAAC,MAAO,GACzC,CAEA,SAAS,EAAwB,CAAU,EACzC,MAAO,CAAC,WAAW,EAAE,EAAA,CAAI,AAC3B,CAEA,SAAS,EAAuB,CAAoB,EAClD,MAAO,CAAC,WAAW,EAAE,EAAA,CACvB,AAD6B,CAG7B,SAAS,EAA4B,CAA4B,EAC/D,OAAO,EAAS,aAAa,EAAI,EAAwB,EAAS,EAAE,CACtE,CAEA,SAAS,EAAa,CAA4B,QAChD,AAAsB,UAAU,CAA5B,EAAS,IAAI,CACR,CACL,GAAI,EAAS,EAAE,CACf,KAAM,SACN,SAAU,EAAS,QAAQ,CAC3B,UAAW,EAAS,SAAS,EAAI,qBACjC,UAAW,EAAS,SAAS,CAC7B,UAAW,EAAS,SAAS,AAC/B,EAGK,CACL,GAAI,EAAS,EAAE,CACf,KAAM,SACN,SAAU,EAAS,QAAQ,CAC3B,UAAW,EAAS,SAAS,CAC7B,UAAW,EAAS,SAAS,AAC/B,CACF,CAEA,eAAe,IACb,IAAM,EAAU,EAAA,OAAI,CAAC,IAAI,CAAC,EAAA,OAAE,CAAC,OAAO,GAAI,SAExC,OADA,MAAM,EAAA,OAAE,CAAC,KAAK,CAAC,EAAS,CAAE,WAAW,CAAK,GACnC,EAAA,OAAI,CAAC,IAAI,CAAC,EA/HW,OA+HF,YAC5B,CAEA,SAAS,EAA2B,CAAc,CAAE,CAA4B,QAC9E,CAAI,CAAC,GAA0B,UAAjB,AAA2B,OAApB,AAA2B,GAG5C,EAAU,IAAI,GAAK,GACW,UAA9B,AAAwC,CADP,MAC1B,AAAwC,CADP,CACvB,QAAQ,EACzB,AAA+B,UAAU,OAAO,AAAzC,EAAU,SAAS,EACK,UAA/B,AAAyC,OAAlC,AAAyC,EAA/B,SAAS,GAET,UAAU,CAA3B,GACoC,UAA/B,OAAO,AAPE,EAOQ,SAAS,CAIrC,CAEA,SAAS,EAAqB,CAAc,QAC1C,CAAI,CAAC,GAA0B,UAAjB,AAA2B,OAApB,AAA2B,GAGpB,UAAxB,OADc,AACP,EAAU,EAAE,GAAiB,CAAC,EAAU,EAAE,CAAC,IAAI,IAAI,CACvC,MAD8C,KACjE,EAAU,IAAI,EAAoC,WAAnB,EAAU,IAAI,AAAK,GAAU,AAC9B,OADqC,GACnE,AAAwC,OAAO,AAAxC,EAAU,QAAQ,EACM,UAAU,AAAzC,OAAgD,AAAzC,EAAU,SAAS,EACK,UAA/B,AAAyC,OAAlC,AAAyC,EAA/B,SAAS,QACE,IAA5B,EAAU,aAAa,EAAqD,UAAnC,OAAO,EAAU,aAAa,AAAK,GAAU,CAEnE,MAF0E,IAEhE,CAA7B,EAAU,IAAI,EACsB,UAA/B,OAAO,EAAU,SAAS,CAIrC,CAEA,eAAe,EAAyB,CAA8B,EACpE,IAAM,EAAsB,MAAM,GAClC,OAAM,EAAA,OAAE,CAAC,SAAS,CAAC,EAAqB,KAAK,SAAS,CAAC,EAAU,KAAM,GAAI,QAC7E,CAEA,eAAe,IACb,IAAM,EAAsB,MAAM,IAElC,GAAI,CACF,IAAM,EAAU,MAAM,EAAA,OAAE,CAAC,QAAQ,CAAC,EAAqB,SACjD,EAAS,KAAK,KAAK,CAAC,GAE1B,GAAI,MAAM,OAAO,CAAC,GAChB,MADyB,CAClB,EAAO,MAAM,CAAC,GAGvB,GAAI,CAAC,GAAU,AAAkB,UAAU,OAArB,EACpB,MAAO,EAAE,CAIX,IAAM,EAAiC,EAAE,CAEzC,GAAI,EAA2B,EAAa,MAAM,CAAE,UAAW,CAC7D,IAAM,EAAW,EAAa,MAAM,CACpC,EAAS,IAAI,CAAC,CACZ,GAAI,IACJ,KAAM,SACN,SAAU,EAAS,QAAQ,CAC3B,UAAW,EAAS,SAAS,CAC7B,UAAW,EAAS,SAAS,CAC7B,cAAe,EAAuB,SACxC,EACF,CAEA,GAAI,EAA2B,EAAa,MAAM,CAAE,UAAW,CAC7D,IAAM,EAAW,AAhBE,EAgBW,MAAM,CACpC,EAAS,IAAI,CAAC,CACZ,GAAI,IACJ,KAAM,SACN,SAAU,EAAS,QAAQ,CAC3B,UAAW,EAAS,SAAS,CAC7B,UAAW,EAAS,SAAS,CAC7B,UAAW,EAAS,SAAS,CAC7B,cAAe,EAAuB,SACxC,EACF,CAMA,OAJI,EAAS,MAAM,CAAG,GAAG,AACvB,MAAM,EAAyB,GAG1B,CACT,CAAE,MAAO,EAAO,CACd,GAAK,GAAiC,OAAS,SAC7C,CADuD,KAChD,EAAE,CAIX,OADA,QAAQ,KAAK,CAAC,wCAAyC,GAChD,EAAE,AACX,CACF,CAEO,eAAe,IAGpB,MAAO,CAFU,MAAM,GAAA,EAGpB,GAAG,CAAC,GACJ,IAAI,CAAC,CAAC,EAAG,IAAM,EAAE,SAAS,CAAC,aAAa,CAAC,EAAE,SAAS,EACzD,CAEO,eAAe,EAAkB,CAAU,EAEhD,IAAM,EAAQ,CADG,MAAM,GAAA,EACA,IAAI,CAAC,AAAC,GAAe,EAAW,EAAE,GAAK,GAC9D,OAAO,EAAQ,EAAa,GAAS,IACvC,CAEO,eAAe,EAAmB,CAAU,EAEjD,IAAM,EAAQ,CADG,MAAM,GAAA,EACA,IAAI,CAAE,AAAD,GAAgB,EAAW,EAAE,GAAK,GAC9D,GAAI,CAAC,EACH,KADU,EACH,KAGT,IAAM,EAAS,MAAM,WACrB,AAAK,EAIE,EAJH,AAIU,IAJD,OAIY,CAAC,EAAc,EAA4B,IAH3D,IAIX,CAEA,eAAe,EAAkB,CAAa,EAC5C,GAAI,CACF,IAAM,EAAW,MAAM,MAAM,8BAA+B,CAC1D,QAAS,CACP,cAAe,CAAC,OAAO,EAAE,EAAA,CAAO,CAChC,OAAQ,8BACR,uBAAwB,YAC1B,CACF,GAEA,GAAI,CAAC,EAAS,EAAE,CAAE,CAChB,GAAI,AAAoB,KAAK,GAAhB,MAAM,CACjB,MAAO,CAAE,OAAO,EAAO,MAAO,kCAAmC,EAEnE,MAAO,CAAE,OAAO,EAAO,MAAO,CAAC,oBAAoB,EAAE,EAAS,MAAM,CAAC,CAAC,CAAC,AAAC,CAC1E,CAEA,IAAM,EAAO,MAAM,EAAS,IAAI,GAC1B,EAAkC,UAAvB,OAAO,GAAM,MAAqB,EAAK,KAAK,CAAG,KAChE,GAAI,CAAC,EACH,MAAO,CAAE,CADI,MACG,EAAO,MAAO,iDAAkD,EAGlF,MAAO,CAAE,OAAO,WAAM,CAAS,CACjC,CAAE,MAAO,EAAO,CACd,MAAO,CAAE,OAAO,EAAO,MAAO,CAAC,+BAA+B,EAAG,EAAgB,OAAO,CAAA,CAAE,AAAC,CAC7F,CACF,CAEA,eAAe,EAAkB,CAAiB,CAAE,CAAa,EAC/D,GAAI,CACF,IAAM,EAAgB,EAAyB,GACzC,EAAW,MAAM,MAAM,CAAA,EAAG,EAAc,YAAY,CAAC,CAAE,CAC3D,QAAS,CACP,gBAAiB,CACnB,CACF,GAEA,GAAI,CAAC,EAAS,EAAE,CAAE,CAChB,GAAwB,KAAK,CAAzB,EAAS,MAAM,CACjB,MAAO,CAAE,OAAO,EAAO,MAAO,kCAAmC,EAEnE,MAAO,CAAE,OAAO,EAAO,MAAO,CAAC,oBAAoB,EAAE,EAAS,MAAM,CAAC,CAAC,CAAC,AAAC,CAC1E,CAEA,IAAM,EAAO,MAAM,EAAS,IAAI,GAC1B,EAAqC,UAA1B,OAAO,GAAM,SAAwB,EAAK,QAAQ,CAAG,KACtE,GAAI,CAAC,EACH,MAAO,CAAE,CADI,MACG,EAAO,MAAO,iDAAkD,EAGlF,MAAO,CAAE,OAAO,WAAM,CAAS,CACjC,CAAE,MAAO,EAAO,CACd,MAAO,CAAE,OAAO,EAAO,MAAO,CAAC,+BAA+B,EAAG,EAAgB,OAAO,CAAA,CAAG,AAAD,CAC5F,CACF,CAEO,eAAe,EAAuB,CAAa,EACxD,IAKI,EALE,EAAe,EAAM,IAAI,GAC/B,GAAI,CAAC,EACH,MAAO,CAAE,KADQ,IACC,EAAO,MAAO,2BAA4B,EAI9D,GAAI,CACF,EAAS,MAAM,GACjB,CAAE,MAAO,EAAO,CACd,MAAO,CAAE,SAAS,EAAO,MAAQ,EAAgB,OAAO,AAAC,CAC3D,CAEA,IAAM,EAAe,MAAM,EAAkB,GAC7C,GAAI,CAAC,EAAa,KAAK,EAAI,CAAC,EAAa,QAAQ,CAC/C,CADiD,KAC1C,CAAE,SAAS,EAAO,MAAO,EAAa,KAAK,EAAI,gCAAiC,EAGzF,IAAM,EAAW,MAAM,IAMvB,GALkB,CAKd,CALuB,IAAI,CAAC,AAAC,GACX,EAIP,SAJb,EAAW,IAAI,EACZ,EAAW,QAAQ,GAAK,EAAa,QAAQ,EAIhD,MAAO,CAAE,SAAS,EAAO,MAAO,CAAC,wBAAwB,EAAE,EAAa,QAAQ,CAAC,gBAAgB,CAAE,AAAD,EAGpG,IAAM,EAAK,IACL,EAAM,IAAI,OAAO,WAAW,GAC5B,EAAgB,EAAwB,EAE9C,OAAM,EAAO,WAAW,CAAC,EAAc,EAAe,GAEtD,IAAM,EAA8B,CAClC,KACA,KAAM,SACN,SAAU,EAAa,QAAQ,CAC/B,UAAW,EACX,UAAW,gBACX,CACF,EAKA,OAHA,EAAS,IAAI,CAAC,GACd,MAAM,EAAyB,GAExB,CACL,SAAS,EACT,WAAY,CACV,GAAI,EAAQ,EAAE,CACd,KAAM,SACN,SAAU,EAAQ,QAAQ,CAC1B,UAAW,EAAQ,SAAS,CAC5B,UAAW,EAAQ,SAAS,AAC9B,CACF,CACF,CAEO,eAAe,EACpB,CAAiB,CACjB,CAAa,EAEb,IAiBI,EAjBE,EAAsB,EAAyB,GAC/C,EAAe,EAAM,IAAI,GAE/B,GAAI,CAAC,EACH,MAAO,CAAE,QAAS,GAAO,CADD,KACQ,gCAAiC,EAGnE,GAAI,CACF,IAAI,IAAI,EACV,CAAE,KAAM,CACN,MAAO,CAAE,QAAS,GAAO,MAAO,wCAAyC,CAC3E,CAEA,GAAI,CAAC,EACH,MAAO,CAAE,KADQ,IACC,EAAO,MAAO,2BAA4B,EAI9D,GAAI,CACF,EAAS,MAAM,GACjB,CAAE,MAAO,EAAO,CACd,MAAO,CAAE,SAAS,EAAO,MAAQ,EAAgB,OAAO,AAAC,CAC3D,CAEA,IAAM,EAAe,MAAM,EAAkB,EAAqB,GAClE,GAAI,CAAC,EAAa,KAAK,EAAI,CAAC,EAAa,QAAQ,CAC/C,CADiD,KAC1C,CAAE,SAAS,EAAO,MAAO,EAAa,KAAK,EAAI,gCAAiC,EAGzF,IAAM,EAAW,MAAM,IAOvB,GANkB,CAMd,CANuB,IAAI,CAAC,AAAC,GAC/B,AAAoB,EAKP,WALF,IAAI,EACZ,EAAW,QAAQ,GAAK,EAAa,QAAQ,EAC7C,EAAW,SAAS,GAAK,GAI5B,MAAO,CACL,SAAS,EACT,MAAO,CAAC,wBAAwB,EAAE,EAAa,QAAQ,CAAC,IAAI,EAAE,EAAoB,gBAAgB,CAAC,AACrG,EAGF,IAAM,EAAK,IACL,EAAM,IAAI,OAAO,WAAW,GAC5B,EAAgB,EAAwB,EAE9C,OAAM,EAAO,WAAW,CAAC,EAAc,EAAe,GAEtD,IAAM,EAA8B,IAClC,EACA,KAAM,SACN,SAAU,EAAa,QAAQ,CAC/B,UAAW,EACX,UAAW,EACX,UAAW,gBACX,CACF,EAKA,OAHA,EAAS,IAAI,CAAC,GACd,MAAM,EAAyB,GAExB,CACL,SAAS,EACT,WAAY,CACV,GAAI,EAAQ,EAAE,CACd,KAAM,SACN,SAAU,EAAQ,QAAQ,CAC1B,UAAW,EAAQ,SAAS,EAAI,EAChC,UAAW,EAAQ,SAAS,CAC5B,UAAW,EAAQ,SAAS,AAC9B,CACF,CACF,CAEO,eAAe,EAAiB,CAAU,EAC/C,IAAM,EAAW,MAAM,IACjB,EAAQ,EAAS,SAAS,CAAC,AAAC,GAAe,EAAW,EAAE,GAAK,GAEnE,GAAc,CAAC,GAAG,CAAd,EACF,MAAO,CAAE,SAAS,EAAO,MAAO,uBAAwB,EAG1D,IAAM,EAAa,CAAQ,CAAC,EAAM,CAClC,EAAS,MAAM,CAAC,EAAO,GACvB,MAAM,EAAyB,GAE/B,IAAM,EAAS,MAAM,IAKrB,OAJI,GACF,KADU,CACJ,EAAO,cAAc,CAAC,EAAc,EAA4B,IAGjE,CAAE,SAAS,CAAK,CACzB,uNCvdA,EAAA,EAAA,CAAA,CAAA,OAYO,eAAe,IACpB,GAAI,CACF,IAAM,EAAc,MAAM,CAAA,EAAA,EAAA,iBAAA,AAAiB,IAC3C,MAAO,CAAE,SAAS,cAAM,CAAY,CACtC,CAAE,MAAO,EAAO,CAEd,OADA,QAAQ,KAAK,CAAC,8BAA+B,GACtC,CAAE,SAAS,EAAO,MAAO,6BAA8B,CAChE,CACF,CAMO,eAAe,EAAqB,CAAa,EACtD,IAAM,EAAS,MAAM,CAAA,EAAA,EAAA,sBAAsB,AAAtB,EAAuB,UAC5C,AAAI,AAAC,EAAO,OAAO,EAAK,EAAD,AAAQ,UAAU,CAIlC,CAJoC,AAIlC,SAAS,EAAM,WAAY,EAAO,UAAU,AAAC,EAH7C,CAAE,SAAS,EAAO,MAAO,EAAO,KAAK,EAAI,mCAAoC,CAIxF,CAEO,eAAe,EAAqB,CAAiB,CAAE,CAAa,EACzE,IAAM,EAAS,MAAM,CAAA,EAAA,EAAA,sBAAA,AAAsB,EAAC,EAAW,UACvD,AAAI,AAAC,EAAO,OAAO,EAAK,EAAD,AAAQ,UAAU,CAIlC,CAJoC,AAIlC,SAAS,EAAM,WAAY,EAAO,UAAU,AAAC,EAH7C,CAAE,SAAS,EAAO,MAAO,EAAO,KAAK,EAAI,mCAAoC,CAIxF,CAMO,eAAe,EAAiB,CAAU,EAC/C,GAAI,CACF,IAAM,EAAS,MAAM,CAAA,EAAA,EAAA,gBAAgB,AAAhB,EAAiB,GACtC,GAAI,CAAC,EAAO,OAAO,CACjB,CADmB,KACZ,CAAE,SAAS,EAAO,MAAO,EAAO,KAAK,EAAI,8BAA+B,EAGjF,MAAO,CAAE,SAAS,CAAK,CACzB,CAAE,MAAO,EAAO,CAEd,OADA,QAAQ,KAAK,CAAC,+BAAgC,GACvC,CAAE,SAAS,EAAO,MAAO,8BAA+B,CACjE,CACF,0CAhDsB,EAcA,EASA,EAaA,IApCA,CAAA,EAAA,EAAA,uBAAA,EAAA,EAAA,6CAAA,MAcA,CAAA,EAAA,EAAA,uBAAA,EAAA,EAAA,6CAAA,MASA,CAAA,EAAA,EAAA,uBAAA,EAAA,EAAA,6CAAA,MAaA,CAAA,EAAA,EAAA,uBAAA,EAAA,EAAA,6CAAA,iKClDtB,EAAA,EAAA,CAAA,CAAA,OAEA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OAKA,IAAM,EAAoB,IAAI,IAAI,CAChC,OACA,eACA,QACA,QACA,OACA,QACA,WACD,EAWD,SAAS,IAIP,OAHK,AAAD,OAAQ,mBAAmB,EAAE,CAC/B,OAAO,mBAAmB,CAAG,IAAI,GAAA,EAE5B,OAAO,mBAAmB,AACnC,CAEA,SAAS,EAAgB,CAAgB,CAAE,CAAgB,EACzD,IAAqB,GAAG,CAAC,EAAS,WAAW,GAAI,UAC/C,EACA,WAAY,KAAK,GAAG,EACtB,EACF,CAEA,eAAe,EAAyB,CAAgB,EACtD,IAAM,EAAQ,IAAqB,GAAG,CAAC,EAAS,WAAW,WAC3D,AAAK,EACD,EADA,GAAQ,AACH,GAAG,GAAK,EAAM,UAAU,CArCH,EAqCM,EArCF,CAsChC,IAtCqC,AAsChB,MAAM,CAAC,EAAS,SADsB,EACX,IACzC,MAGL,MAAM,EAAgB,EAAM,QAAQ,EAC/B,CADkC,CAC5B,QAAQ,EAGvB,IAAqB,MAAM,CAAC,EAAS,WAAW,IACzC,MAXY,IAYrB,CAEA,eAAe,EAAgB,CAAe,EAC5C,GAAI,CAEF,OADA,MAAM,EAAA,OAAE,CAAC,MAAM,CAAC,EAAA,OAAI,CAAC,IAAI,CAAC,EAAS,UAC5B,CACT,CAAE,KAAM,CACN,OAAO,CACT,CACF,CAcA,eAAe,EAAqB,CAAgB,CAAE,CAAgB,EACpE,IAAM,EAAkB,EAAA,OAAI,CAAC,IAAI,CAAC,EAAU,GAC5C,GAAI,MAAM,EAAgB,GACxB,OAAO,EAGT,IAAM,EAJsC,AAIa,CAAC,CAAE,QAAS,EAAU,MAAO,CAAE,EAAE,CACtF,EAAe,EACb,EAAa,EAAS,WAAW,GAEvC,IAAK,IAAI,EAAQ,EAAG,EAAQ,EAAM,MAAM,CAAE,GAAS,EAAG,CACpD,IAMI,EANE,EAAU,CAAK,CAAC,EAAM,CAE5B,GADA,AACI,KADY,EApFY,IAsF1B,IADiB,EAKnB,GAAI,CACF,EAAU,MAAM,EAAA,OAAE,CAAC,CANuB,MAMhB,CAAC,EAAQ,OAAO,CAAE,CAAE,eAAe,CAAK,EACpE,CAAE,KAAM,CACN,QACF,CAEA,IAAK,IAAM,KAAS,EAAS,CAC3B,GAAI,CAAC,EAAM,WAAW,IAjC5B,AAkCU,SAlCD,AAAoB,CAAiB,CAAE,CAAkB,EAChE,IAAM,EAAY,EAAU,WAAW,UACnC,AAAJ,IAAkB,MACd,EAAkB,GAAG,CADK,AACJ,IACtB,EAAU,CAFuB,KACC,IACd,CAAC,EADoB,GAG/C,CAFiC,CA8BH,EAAM,IA9BI,AA8BA,CAAE,GADV,SAG1B,CAFiD,GAE3C,EAAc,EAAA,OAAI,CAAC,IAAI,CAAC,EAAQ,OAAO,CAAE,EAAM,IAAI,EAEzD,GAAI,EAAM,IAAI,CAAC,WAAW,KAAO,GAAc,MAAM,EAAgB,GACnE,OAAO,EAGL,EAAQ,AAJuE,KAIlE,CAAG,GA3GH,EA2GQ,CACvB,EAAM,IAAI,CAAC,CAAE,OAD0B,CACjB,EAAa,MAAO,EAAQ,KAAK,CAAG,CAAE,EAEhE,CACF,CAEA,OAAO,IACT,CAEO,eAAe,EAA4B,CAAgB,EAChE,IAAM,EAAc,EAAS,IAAI,GACjC,GAAI,CAAC,EAAa,OAAO,KAEzB,IAAM,EAAmB,MAAM,EAAyB,GACxD,GAAI,EACF,OAAO,EAGT,IAAM,EAAS,CAJO,KAID,CAAA,EAAA,EAAA,SAAA,AAAS,IAG9B,IAAK,IAAM,KADW,EAAO,KACN,MADiB,CAAC,MAAM,CAAC,AAAC,AACX,GAlE/B,EAAA,MAiEuD,CAjEnD,CAAC,QAAQ,CAAC,AAiEyD,GAjE/C,WAAW,KAAO,AAiEuC,EAjE9B,WAAW,IAmEnE,GAAI,MAAM,EAAgB,GAExB,OADA,CADmC,CACnB,EAAa,GACtB,EAIX,IAAM,EAAwB,EAAE,CAC1B,EAAe,IAAI,IACzB,IAAK,IAAM,KAAY,EAAO,WAAW,CAAE,CACzC,IAAM,EAAa,EAAA,OAAI,CAAC,OAAO,CAAC,GAC3B,EAAa,GAAG,CAAC,KACpB,EAAa,GAAG,CAAC,EADgB,CAEjC,EAAY,IAAI,CAAC,GAErB,CAMA,IAAK,IAAM,KALP,EAAO,WAAW,EAAI,CAAC,EAAa,GAAG,CAAC,EAAO,WAAW,GAAG,CAC/D,EAAa,GAAG,CAAC,EAAO,WAAW,EACnC,EAAY,IAAI,CAAC,EAAO,WAAW,GAGd,GAAa,CAClC,IAAM,EAAe,MAAM,EAAqB,EAAU,GAC1D,GAAI,EAEF,OADA,EAAgB,EAAa,CADb,EAET,CAEX,CAEA,OAAO,IACT,CCzJO,eAAe,EAAwB,CAAgB,EAC5D,GAAI,CACF,IAAM,EAAe,MAAM,EAA4B,GACvD,MAAO,CACL,SAAS,EACT,SAAU,CACZ,CACF,CAAE,MAAO,EAAO,CAEd,OADA,QAAQ,KAAK,CAAC,wCAAyC,GAChD,CACL,SAAS,EACT,SAAU,KACV,MAAO,kDACT,CACF,CACF,0CAfsB,IAAA,CAAA,EAAA,EAAA,uBAAA,EAAA,EAAA,6CAAA,2ECVtB,IAAA,EAAA,EAAA,CAAA,CAAA,OAaA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OAMA,EAAA,EAAA,CAAA,CAAA,OAGA,EAAA,EAAA,CAAA,CAAA","ignoreList":[0,1]}