@exulu/frontend 1.3.0 → 1.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (122) hide show
  1. package/dist/.next/BUILD_ID +1 -1
  2. package/dist/.next/app-build-manifest.json +81 -81
  3. package/dist/.next/app-path-routes-manifest.json +1 -1
  4. package/dist/.next/build-manifest.json +2 -2
  5. package/dist/.next/prerender-manifest.json +1 -1
  6. package/dist/.next/server/app/(application)/agents/edit/[id]/page.js +1 -1
  7. package/dist/.next/server/app/(application)/agents/edit/[id]/page.js.nft.json +1 -1
  8. package/dist/.next/server/app/(application)/agents/edit/[id]/page_client-reference-manifest.js +1 -1
  9. package/dist/.next/server/app/(application)/agents/page.js +2 -2
  10. package/dist/.next/server/app/(application)/agents/page.js.nft.json +1 -1
  11. package/dist/.next/server/app/(application)/agents/page_client-reference-manifest.js +1 -1
  12. package/dist/.next/server/app/(application)/chat/[agent]/[session]/page.js +2 -2
  13. package/dist/.next/server/app/(application)/chat/[agent]/[session]/page.js.nft.json +1 -1
  14. package/dist/.next/server/app/(application)/chat/[agent]/[session]/page_client-reference-manifest.js +1 -1
  15. package/dist/.next/server/app/(application)/chat/[agent]/page.js +1 -1
  16. package/dist/.next/server/app/(application)/chat/[agent]/page.js.nft.json +1 -1
  17. package/dist/.next/server/app/(application)/chat/[agent]/page_client-reference-manifest.js +1 -1
  18. package/dist/.next/server/app/(application)/chat/page.js +1 -1
  19. package/dist/.next/server/app/(application)/chat/page.js.nft.json +1 -1
  20. package/dist/.next/server/app/(application)/chat/page_client-reference-manifest.js +1 -1
  21. package/dist/.next/server/app/(application)/configuration/page.js +1 -1
  22. package/dist/.next/server/app/(application)/configuration/page.js.nft.json +1 -1
  23. package/dist/.next/server/app/(application)/configuration/page_client-reference-manifest.js +1 -1
  24. package/dist/.next/server/app/(application)/dashboard/page.js +1 -1
  25. package/dist/.next/server/app/(application)/dashboard/page.js.nft.json +1 -1
  26. package/dist/.next/server/app/(application)/dashboard/page_client-reference-manifest.js +1 -1
  27. package/dist/.next/server/app/(application)/data/[[...query]]/page.js +1 -1
  28. package/dist/.next/server/app/(application)/data/[[...query]]/page.js.nft.json +1 -1
  29. package/dist/.next/server/app/(application)/data/[[...query]]/page_client-reference-manifest.js +1 -1
  30. package/dist/.next/server/app/(application)/evals/[id]/page.js +1 -1
  31. package/dist/.next/server/app/(application)/evals/[id]/page.js.nft.json +1 -1
  32. package/dist/.next/server/app/(application)/evals/[id]/page_client-reference-manifest.js +1 -1
  33. package/dist/.next/server/app/(application)/evals/[id]/runs/page.js +1 -1
  34. package/dist/.next/server/app/(application)/evals/[id]/runs/page.js.nft.json +1 -1
  35. package/dist/.next/server/app/(application)/evals/[id]/runs/page_client-reference-manifest.js +1 -1
  36. package/dist/.next/server/app/(application)/evals/cases/page.js +1 -1
  37. package/dist/.next/server/app/(application)/evals/cases/page.js.nft.json +1 -1
  38. package/dist/.next/server/app/(application)/evals/cases/page_client-reference-manifest.js +1 -1
  39. package/dist/.next/server/app/(application)/evals/page.js +1 -1
  40. package/dist/.next/server/app/(application)/evals/page.js.nft.json +1 -1
  41. package/dist/.next/server/app/(application)/evals/page_client-reference-manifest.js +1 -1
  42. package/dist/.next/server/app/(application)/explorer/page.js +1 -1
  43. package/dist/.next/server/app/(application)/explorer/page.js.nft.json +1 -1
  44. package/dist/.next/server/app/(application)/explorer/page_client-reference-manifest.js +1 -1
  45. package/dist/.next/server/app/(application)/jobs/page.js +1 -1
  46. package/dist/.next/server/app/(application)/jobs/page.js.nft.json +1 -1
  47. package/dist/.next/server/app/(application)/jobs/page_client-reference-manifest.js +1 -1
  48. package/dist/.next/server/app/(application)/keys/page.js +1 -1
  49. package/dist/.next/server/app/(application)/keys/page.js.nft.json +1 -1
  50. package/dist/.next/server/app/(application)/keys/page_client-reference-manifest.js +1 -1
  51. package/dist/.next/server/app/(application)/page.js +1 -1
  52. package/dist/.next/server/app/(application)/page.js.nft.json +1 -1
  53. package/dist/.next/server/app/(application)/page_client-reference-manifest.js +1 -1
  54. package/dist/.next/server/app/(application)/projects/[project]/page.js +1 -1
  55. package/dist/.next/server/app/(application)/projects/[project]/page.js.nft.json +1 -1
  56. package/dist/.next/server/app/(application)/projects/[project]/page_client-reference-manifest.js +1 -1
  57. package/dist/.next/server/app/(application)/projects/page.js +1 -1
  58. package/dist/.next/server/app/(application)/projects/page.js.nft.json +1 -1
  59. package/dist/.next/server/app/(application)/projects/page_client-reference-manifest.js +1 -1
  60. package/dist/.next/server/app/(application)/roles/page.js +1 -1
  61. package/dist/.next/server/app/(application)/roles/page.js.nft.json +1 -1
  62. package/dist/.next/server/app/(application)/roles/page_client-reference-manifest.js +1 -1
  63. package/dist/.next/server/app/(application)/token/page.js +1 -1
  64. package/dist/.next/server/app/(application)/token/page.js.nft.json +1 -1
  65. package/dist/.next/server/app/(application)/token/page_client-reference-manifest.js +1 -1
  66. package/dist/.next/server/app/(application)/users/page.js +1 -1
  67. package/dist/.next/server/app/(application)/users/page.js.nft.json +1 -1
  68. package/dist/.next/server/app/(application)/users/page_client-reference-manifest.js +1 -1
  69. package/dist/.next/server/app/(application)/variables/create/page.js +1 -1
  70. package/dist/.next/server/app/(application)/variables/create/page.js.nft.json +1 -1
  71. package/dist/.next/server/app/(application)/variables/create/page_client-reference-manifest.js +1 -1
  72. package/dist/.next/server/app/(application)/variables/edit/[variable_id]/page.js +1 -1
  73. package/dist/.next/server/app/(application)/variables/edit/[variable_id]/page.js.nft.json +1 -1
  74. package/dist/.next/server/app/(application)/variables/edit/[variable_id]/page_client-reference-manifest.js +1 -1
  75. package/dist/.next/server/app/(application)/variables/page.js +1 -1
  76. package/dist/.next/server/app/(application)/variables/page.js.nft.json +1 -1
  77. package/dist/.next/server/app/(application)/variables/page_client-reference-manifest.js +1 -1
  78. package/dist/.next/server/app/(application)/variables/usage/[variable_id]/page.js +1 -1
  79. package/dist/.next/server/app/(application)/variables/usage/[variable_id]/page.js.nft.json +1 -1
  80. package/dist/.next/server/app/(application)/variables/usage/[variable_id]/page_client-reference-manifest.js +1 -1
  81. package/dist/.next/server/app/(application)/workflows/page.js +1 -1
  82. package/dist/.next/server/app/(application)/workflows/page.js.nft.json +1 -1
  83. package/dist/.next/server/app/(application)/workflows/page_client-reference-manifest.js +1 -1
  84. package/dist/.next/server/app/(authentication)/login/page.js +3 -3
  85. package/dist/.next/server/app/(authentication)/login/page.js.nft.json +1 -1
  86. package/dist/.next/server/app/(authentication)/login/page_client-reference-manifest.js +1 -1
  87. package/dist/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  88. package/dist/.next/server/app/_not-found.html +1 -1
  89. package/dist/.next/server/app/_not-found.rsc +1 -1
  90. package/dist/.next/server/app-paths-manifest.json +3 -3
  91. package/dist/.next/server/chunks/1051.js +48 -0
  92. package/dist/.next/server/chunks/7944.js +1 -1
  93. package/dist/.next/server/middleware-manifest.json +5 -5
  94. package/dist/.next/server/pages/404.html +1 -1
  95. package/dist/.next/server/pages/500.html +1 -1
  96. package/dist/.next/server/server-reference-manifest.json +1 -1
  97. package/dist/.next/static/chunks/{3832-cfd7197465448e35.js → 3832-bfe8bd2edace90f9.js} +2 -2
  98. package/dist/.next/static/chunks/3832-bfe8bd2edace90f9.js.map +1 -0
  99. package/dist/.next/static/chunks/app/(application)/agents/page-499ac3bd1044306c.js +2 -0
  100. package/dist/.next/static/chunks/app/(application)/agents/page-499ac3bd1044306c.js.map +1 -0
  101. package/dist/.next/static/chunks/app/(application)/chat/[agent]/[session]/page-b600c0b270eedb7f.js +2 -0
  102. package/dist/.next/static/chunks/app/(application)/chat/[agent]/[session]/page-b600c0b270eedb7f.js.map +1 -0
  103. package/dist/.next/static/chunks/app/(application)/evals/[id]/page-2238f1fb73d93328.js +2 -0
  104. package/dist/.next/static/chunks/app/(application)/evals/[id]/page-2238f1fb73d93328.js.map +1 -0
  105. package/dist/.next/static/chunks/app/(authentication)/layout-0f416e1b9326e03a.js +2 -0
  106. package/dist/.next/static/chunks/app/(authentication)/layout-0f416e1b9326e03a.js.map +1 -0
  107. package/dist/.next/static/css/{175d6535ea9efb2c.css → 7b99daf4eb75ddb9.css} +2 -2
  108. package/dist/.next/static/css/{175d6535ea9efb2c.css.map → 7b99daf4eb75ddb9.css.map} +1 -1
  109. package/dist/.next/static/css/e3f2a16ab7676b05.css.map +1 -1
  110. package/package.json +1 -1
  111. package/dist/.next/server/chunks/7223.js +0 -48
  112. package/dist/.next/static/chunks/3832-cfd7197465448e35.js.map +0 -1
  113. package/dist/.next/static/chunks/app/(application)/agents/page-4137487b76f09235.js +0 -2
  114. package/dist/.next/static/chunks/app/(application)/agents/page-4137487b76f09235.js.map +0 -1
  115. package/dist/.next/static/chunks/app/(application)/chat/[agent]/[session]/page-0f729a6df64d730e.js +0 -2
  116. package/dist/.next/static/chunks/app/(application)/chat/[agent]/[session]/page-0f729a6df64d730e.js.map +0 -1
  117. package/dist/.next/static/chunks/app/(application)/evals/[id]/page-b2de62f11946627f.js +0 -2
  118. package/dist/.next/static/chunks/app/(application)/evals/[id]/page-b2de62f11946627f.js.map +0 -1
  119. package/dist/.next/static/chunks/app/(authentication)/layout-2dfa18ea6e6dc5cd.js +0 -2
  120. package/dist/.next/static/chunks/app/(authentication)/layout-2dfa18ea6e6dc5cd.js.map +0 -1
  121. /package/dist/.next/static/{_G7TS_eJB-KA5rdSZzdGX → ilyTh3roMkVIbl9q2AwIk}/_buildManifest.js +0 -0
  122. /package/dist/.next/static/{_G7TS_eJB-KA5rdSZzdGX → ilyTh3roMkVIbl9q2AwIk}/_ssgManifest.js +0 -0
@@ -1,2 +1,2 @@
1
- "use strict";(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[3832],{13832:function(e,a,t){t.d(a,{S:function(){return eu},default:function(){return ep}});var r=t(57437),s=t(24614),n=t(71946),i=t(81068),o=t(63761),d=t(51251),l=t(51451),c=t(80605),u=t(2265),f=t(27648),p=t(99376),m=t(37053),b=t(90535),h=t(30755),x=t(866),g=t(94508),v=t(62869),w=t(95186),j=t(6512),N=t(69304),y=t(93022),k=t(81103);let z=u.createContext(null);function C(){let e=u.useContext(z);if(!e)throw Error("useSidebar must be used within a SidebarProvider.");return e}let R=u.forwardRef((e,a)=>{let{defaultOpen:t=!0,open:s,onOpenChange:n,className:i,style:o,children:d,...l}=e,c=(0,x.d)(),[f,p]=u.useState(!1),[m,b]=u.useState(t),h=null!=s?s:m,v=u.useCallback(e=>{let a="function"==typeof e?e(h):e;n?n(a):b(a),document.cookie="".concat("sidebar_state","=").concat(a,"; path=/; max-age=").concat(604800)},[n,h]),w=u.useCallback(()=>c?p(e=>!e):v(e=>!e),[c,v,p]);u.useEffect(()=>{let e=e=>{"b"===e.key&&(e.metaKey||e.ctrlKey)&&(e.preventDefault(),w())};return window.addEventListener("keydown",e),()=>window.removeEventListener("keydown",e)},[w]);let j=h?"expanded":"collapsed",N=u.useMemo(()=>({state:j,open:h,setOpen:v,isMobile:c,openMobile:f,setOpenMobile:p,toggleSidebar:w}),[j,h,v,c,f,p,w]);return(0,r.jsx)(z.Provider,{value:N,children:(0,r.jsx)(k.pn,{delayDuration:0,children:(0,r.jsx)("div",{style:{"--sidebar-width":"16rem","--sidebar-width-icon":"3rem",...o},className:(0,g.cn)("group/sidebar-wrapper flex min-h-svh w-full has-[[data-variant=inset]]:bg-sidebar",i),ref:a,...l,children:d})})})});R.displayName="SidebarProvider";let S=u.forwardRef((e,a)=>{let{side:t="left",variant:s="sidebar",collapsible:n="offcanvas",className:i,children:o,...d}=e,{isMobile:l,state:c,openMobile:u,setOpenMobile:f}=C();return"none"===n?(0,r.jsx)("div",{className:(0,g.cn)("flex h-full w-[--sidebar-width] flex-col bg-sidebar text-sidebar-foreground",i),ref:a,...d,children:o}):l?(0,r.jsx)(N.yo,{open:u,onOpenChange:f,...d,children:(0,r.jsxs)(N.ue,{"data-sidebar":"sidebar","data-mobile":"true",className:"w-[--sidebar-width] bg-sidebar p-0 text-sidebar-foreground [&>button]:hidden",style:{"--sidebar-width":"18rem"},side:t,children:[(0,r.jsxs)(N.Tu,{className:"sr-only",children:[(0,r.jsx)(N.bC,{children:"Sidebar"}),(0,r.jsx)(N.Ei,{children:"Displays the mobile sidebar."})]}),(0,r.jsx)("div",{className:"flex h-full w-full flex-col",children:o})]})}):(0,r.jsxs)("div",{ref:a,className:"group peer hidden text-sidebar-foreground md:block","data-state":c,"data-collapsible":"collapsed"===c?n:"","data-variant":s,"data-side":t,children:[(0,r.jsx)("div",{className:(0,g.cn)("relative w-[--sidebar-width] bg-transparent transition-[width] duration-200 ease-linear","group-data-[collapsible=offcanvas]:w-0","group-data-[side=right]:rotate-180","floating"===s||"inset"===s?"group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)_+_theme(spacing.4))]":"group-data-[collapsible=icon]:w-[--sidebar-width-icon]")}),(0,r.jsx)("div",{className:(0,g.cn)("fixed inset-y-0 z-10 hidden h-svh w-[--sidebar-width] transition-[left,right,width] duration-200 ease-linear md:flex","left"===t?"left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]":"right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]","floating"===s||"inset"===s?"p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)_+_theme(spacing.4)_+2px)]":"group-data-[collapsible=icon]:w-[--sidebar-width-icon] group-data-[side=left]:border-r group-data-[side=right]:border-l",i),...d,children:(0,r.jsx)("div",{"data-sidebar":"sidebar",className:"flex h-full w-full flex-col bg-sidebar group-data-[variant=floating]:rounded-lg group-data-[variant=floating]:border group-data-[variant=floating]:border-sidebar-border group-data-[variant=floating]:shadow",children:o})})]})});S.displayName="Sidebar";let _=u.forwardRef((e,a)=>{let{className:t,onClick:s,...n}=e,{toggleSidebar:i}=C();return(0,r.jsxs)(v.z,{ref:a,"data-sidebar":"trigger",variant:"ghost",size:"icon",className:(0,g.cn)("h-7 w-7",t),onClick:e=>{null==s||s(e),i()},...n,children:[(0,r.jsx)(h.Z,{}),(0,r.jsx)("span",{className:"sr-only",children:"Toggle Sidebar"})]})});_.displayName="SidebarTrigger",u.forwardRef((e,a)=>{let{className:t,...s}=e,{toggleSidebar:n}=C();return(0,r.jsx)("button",{ref:a,"data-sidebar":"rail","aria-label":"Toggle Sidebar",tabIndex:-1,onClick:n,title:"Toggle Sidebar",className:(0,g.cn)("absolute inset-y-0 z-20 hidden w-4 -translate-x-1/2 transition-all ease-linear after:absolute after:inset-y-0 after:left-1/2 after:w-[2px] hover:after:bg-sidebar-border group-data-[side=left]:-right-4 group-data-[side=right]:left-0 sm:flex","[[data-side=left]_&]:cursor-w-resize [[data-side=right]_&]:cursor-e-resize","[[data-side=left][data-state=collapsed]_&]:cursor-e-resize [[data-side=right][data-state=collapsed]_&]:cursor-w-resize","group-data-[collapsible=offcanvas]:translate-x-0 group-data-[collapsible=offcanvas]:after:left-full group-data-[collapsible=offcanvas]:hover:bg-sidebar","[[data-side=left][data-collapsible=offcanvas]_&]:-right-2","[[data-side=right][data-collapsible=offcanvas]_&]:-left-2",t),...s})}).displayName="SidebarRail",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("main",{ref:a,className:(0,g.cn)("relative flex w-full flex-1 flex-col bg-background","md:peer-data-[variant=inset]:m-2 md:peer-data-[state=collapsed]:peer-data-[variant=inset]:ml-2 md:peer-data-[variant=inset]:ml-0 md:peer-data-[variant=inset]:rounded-xl md:peer-data-[variant=inset]:shadow",t),...s})}).displayName="SidebarInset",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)(w.I,{ref:a,"data-sidebar":"input",className:(0,g.cn)("h-8 w-full bg-background shadow-none focus-visible:ring-2 focus-visible:ring-sidebar-ring",t),...s})}).displayName="SidebarInput",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"header",className:(0,g.cn)("flex flex-col gap-2 p-2",t),...s})}).displayName="SidebarHeader";let E=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"footer",className:(0,g.cn)("flex flex-col gap-2 p-2",t),...s})});E.displayName="SidebarFooter",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)(j.Z,{ref:a,"data-sidebar":"separator",className:(0,g.cn)("mx-2 w-auto bg-sidebar-border",t),...s})}).displayName="SidebarSeparator";let Z=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"content",className:(0,g.cn)("flex min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden",t),...s})});Z.displayName="SidebarContent";let T=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"group",className:(0,g.cn)("relative flex w-full min-w-0 flex-col p-0",t),...s})});T.displayName="SidebarGroup",u.forwardRef((e,a)=>{let{className:t,asChild:s=!1,...n}=e,i=s?m.g7:"div";return(0,r.jsx)(i,{ref:a,"data-sidebar":"group-label",className:(0,g.cn)("flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium text-sidebar-foreground/70 outline-none ring-sidebar-ring transition-[margin,opacity] duration-200 ease-linear focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0","group-data-[collapsible=icon]:-mt-8 group-data-[collapsible=icon]:opacity-0",t),...n})}).displayName="SidebarGroupLabel",u.forwardRef((e,a)=>{let{className:t,asChild:s=!1,...n}=e,i=s?m.g7:"button";return(0,r.jsx)(i,{ref:a,"data-sidebar":"group-action",className:(0,g.cn)("absolute right-3 top-3.5 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground outline-none ring-sidebar-ring transition-transform hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0","after:absolute after:-inset-2 after:md:hidden","group-data-[collapsible=icon]:hidden",t),...n})}).displayName="SidebarGroupAction";let O=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"group-content",className:(0,g.cn)("w-full text-sm",t),...s})});O.displayName="SidebarGroupContent";let P=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("ul",{ref:a,"data-sidebar":"menu",className:(0,g.cn)("flex w-full min-w-0 flex-col gap-1",t),...s})});P.displayName="SidebarMenu";let A=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("li",{ref:a,"data-sidebar":"menu-item",className:(0,g.cn)("group/menu-item relative",t),...s})});A.displayName="SidebarMenuItem";let M=(0,b.j)("peer/menu-button flex w-full items-center gap-2 overflow-hidden rounded-md p-2 text-left text-sm outline-none ring-sidebar-ring transition-[width,height,padding] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 group-has-[[data-sidebar=menu-action]]/menu-item:pr-8 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-[active=true]:bg-sidebar-accent data-[active=true]:font-medium data-[active=true]:text-sidebar-accent-foreground data-[state=open]:hover:bg-sidebar-accent data-[state=open]:hover:text-sidebar-accent-foreground group-data-[collapsible=icon]:!size-8 group-data-[collapsible=icon]:!p-[0.40rem] [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0",{variants:{variant:{default:"hover:bg-sidebar-accent hover:text-sidebar-accent-foreground",outline:"bg-background shadow-[0_0_0_1px_hsl(var(--sidebar-border))] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground hover:shadow-[0_0_0_1px_hsl(var(--sidebar-accent))]"},size:{default:"h-8 text-sm",sm:"h-7 text-xs",lg:"h-12 text-sm group-data-[collapsible=icon]:!p-0"}},defaultVariants:{variant:"default",size:"default"}}),D=u.forwardRef((e,a)=>{let{asChild:t=!1,isActive:s=!1,variant:n="default",size:i="default",tooltip:o,className:d,...l}=e,c=t?m.g7:"button",{isMobile:u,state:f}=C(),p=(0,r.jsx)(c,{ref:a,"data-sidebar":"menu-button","data-size":i,"data-active":s,className:(0,g.cn)(M({variant:n,size:i}),d),...l});return o?("string"==typeof o&&(o={children:o}),(0,r.jsxs)(k.u,{children:[(0,r.jsx)(k.aJ,{asChild:!0,children:p}),(0,r.jsx)(k._v,{side:"right",align:"center",hidden:"collapsed"!==f||u,...o})]})):p});D.displayName="SidebarMenuButton",u.forwardRef((e,a)=>{let{className:t,asChild:s=!1,showOnHover:n=!1,...i}=e,o=s?m.g7:"button";return(0,r.jsx)(o,{ref:a,"data-sidebar":"menu-action",className:(0,g.cn)("absolute right-1 top-1.5 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground outline-none ring-sidebar-ring transition-transform hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 peer-hover/menu-button:text-sidebar-accent-foreground [&>svg]:size-4 [&>svg]:shrink-0","after:absolute after:-inset-2 after:md:hidden","peer-data-[size=sm]/menu-button:top-1","peer-data-[size=default]/menu-button:top-1.5","peer-data-[size=lg]/menu-button:top-2.5","group-data-[collapsible=icon]:hidden",n&&"group-focus-within/menu-item:opacity-100 group-hover/menu-item:opacity-100 data-[state=open]:opacity-100 peer-data-[active=true]/menu-button:text-sidebar-accent-foreground md:opacity-0",t),...i})}).displayName="SidebarMenuAction",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"menu-badge",className:(0,g.cn)("pointer-events-none absolute right-1 flex h-5 min-w-5 select-none items-center justify-center rounded-md px-1 text-xs font-medium tabular-nums text-sidebar-foreground","peer-hover/menu-button:text-sidebar-accent-foreground peer-data-[active=true]/menu-button:text-sidebar-accent-foreground","peer-data-[size=sm]/menu-button:top-1","peer-data-[size=default]/menu-button:top-1.5","peer-data-[size=lg]/menu-button:top-2.5","group-data-[collapsible=icon]:hidden",t),...s})}).displayName="SidebarMenuBadge",u.forwardRef((e,a)=>{let{className:t,showIcon:s=!1,...n}=e,i=u.useMemo(()=>"".concat(Math.floor(40*Math.random())+50,"%"),[]);return(0,r.jsxs)("div",{ref:a,"data-sidebar":"menu-skeleton",className:(0,g.cn)("flex h-8 items-center gap-2 rounded-md px-2",t),...n,children:[s&&(0,r.jsx)(y.O,{className:"size-4 rounded-md","data-sidebar":"menu-skeleton-icon"}),(0,r.jsx)(y.O,{className:"h-4 max-w-[--skeleton-width] flex-1","data-sidebar":"menu-skeleton-text",style:{"--skeleton-width":i}})]})}).displayName="SidebarMenuSkeleton",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("ul",{ref:a,"data-sidebar":"menu-sub",className:(0,g.cn)("mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l border-sidebar-border px-2.5 py-0.5","group-data-[collapsible=icon]:hidden",t),...s})}).displayName="SidebarMenuSub",u.forwardRef((e,a)=>{let{...t}=e;return(0,r.jsx)("li",{ref:a,...t})}).displayName="SidebarMenuSubItem",u.forwardRef((e,a)=>{let{asChild:t=!1,size:s="md",isActive:n,className:i,...o}=e,d=t?m.g7:"a";return(0,r.jsx)(d,{ref:a,"data-sidebar":"menu-sub-button","data-size":s,"data-active":n,className:(0,g.cn)("flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 text-sidebar-foreground outline-none ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0 [&>svg]:text-sidebar-accent-foreground","data-[active=true]:bg-sidebar-accent data-[active=true]:text-sidebar-accent-foreground","sm"===s&&"text-xs","md"===s&&"text-sm","group-data-[collapsible=icon]:hidden",i),...o})}).displayName="SidebarMenuSubButton";var V=t(84190),L=t(25466),B=t(50091),I=t(9343),q=t(82222),U=t(56475),Y=t(82718),F=t(64972),G=t(78406),J=t(95805),Q=t(54001),W=t(32790),X=t(64935),K=t(98728),H=t(22135),$=t(85929),ee=t(97226),ea=t(47692),et=t(48736),er=t(78298),es=t(16831),en=t(44045);let ei=(e,a)=>{let t=[];return e.super_admin&&t.push({label:"Dashboard",path:"dashboard",icon:(0,r.jsx)(L.Z,{})}),t.push({label:"Contexts",path:"data",icon:(0,r.jsx)(B.Z,{})}),t.push({label:"Jobs",path:"jobs",icon:(0,r.jsx)(I.Z,{})}),(e.super_admin||"write"===a.agents)&&t.push({label:"Agents",path:"agents",icon:(0,r.jsx)(q.Z,{})}),t.push({label:"Projects",path:"projects",icon:(0,r.jsx)(U.Z,{})}),t.push({label:"Chat",path:"chat",icon:(0,r.jsx)(Y.Z,{})}),(e.super_admin||"read"===a.evals||"write"===a.evals)&&t.push({label:"Evals",path:"evals",icon:(0,r.jsx)(F.Z,{})}),(e.super_admin||"write"===a.workflows)&&t.push({label:"Workflows",path:"workflows",icon:(0,r.jsx)(G.Z,{})}),(e.super_admin||"write"===a.users)&&t.push({label:"Users",path:"users",icon:(0,r.jsx)(J.Z,{})}),(e.super_admin||"write"===a.api)&&t.push({label:"Keys",path:"keys",icon:(0,r.jsx)(Q.Z,{})}),(e.super_admin||"write"===a.variables)&&t.push({label:"Variables",path:"variables",icon:(0,r.jsx)(W.Z,{})}),(e.super_admin||"write"===a.api)&&t.push({label:"API",path:"explorer",icon:(0,r.jsx)(X.Z,{})}),e.super_admin&&t.push({label:"Configurations",path:"configuration",icon:(0,r.jsx)(K.Z,{})}),t};function eo(e){let{items:a}=e,t=(0,p.usePathname)();return(0,r.jsx)(P,{className:"space-y-1",children:a.map((e,a)=>{let s=t.includes(e.path);return(0,r.jsx)(A,{children:(0,r.jsx)(D,{asChild:!0,isActive:s,tooltip:e.label,className:(0,g.cn)("h-10 transition-all duration-200"),children:(0,r.jsxs)(f.default,{href:"/".concat(e.path),className:"flex items-center gap-3",children:[(0,r.jsx)("div",{className:(0,g.cn)("flex h-5 w-5 items-center justify-center transition-colors"),children:e.icon}),(0,r.jsx)("span",{className:(0,g.cn)("font-medium transition-colors"),children:e.label})]})})},a)})})}function ed(e){let{sidebarDefaultOpen:a}=e,{user:t}=(0,u.useContext)(eu),s=ei(t,t.role),n=(0,p.useRouter)(),{setTheme:i,theme:o}=(0,er.F)(),d=(0,p.useParams)(),l=C(),c=(0,u.useContext)(en.E);return(0,u.useEffect)(()=>{d.agent&&void 0===a&&l.setOpen(!1)},[d.agent]),(0,r.jsxs)(S,{collapsible:"icon",className:"border-r",children:[(0,r.jsxs)("div",{className:"flex items-center gap-3 border-b bg-background/80 backdrop-blur-sm p-[12px] sticky top-0 z-10",children:[(0,r.jsx)(_,{}),(0,r.jsx)("div",{className:"flex items-center gap-2",children:(0,r.jsx)("img",{src:(null==c?void 0:c.backend)+"/logo.png",height:40,width:100,alt:"Logo"})})]}),(0,r.jsx)(Z,{className:"px-2",children:(0,r.jsx)(T,{className:"mt-4",children:(0,r.jsx)(O,{children:(0,r.jsx)(eo,{items:s})})})}),(0,r.jsx)(E,{className:"border-t bg-muted/20 p-[5px]",children:(0,r.jsx)(P,{children:(0,r.jsx)(A,{children:(0,r.jsxs)(V.h_,{children:[(0,r.jsx)(V.$F,{asChild:!0,children:(0,r.jsxs)(D,{className:"h-12 hover:bg-accent/50",children:[(0,r.jsx)(es.qE,{className:"h-5 w-5",children:(0,r.jsx)(es.Q5,{className:"bg-gradient-to-br from-primary/20 to-primary/60 text-white text-sm",children:t.email.charAt(0).toUpperCase()})}),(0,r.jsxs)("div",{className:"flex flex-col items-start group-data-[collapsible=icon]:hidden",children:[(0,r.jsx)("span",{className:"text-sm font-medium capitalize",children:t.email.split("@")[0]}),(0,r.jsx)("div",{className:"flex items-center gap-1",children:(0,r.jsx)("span",{className:"text-xs text-muted-foreground",children:t.email.split("@")[1]})})]}),(0,r.jsx)(H.Z,{className:"ml-auto h-4 w-4 group-data-[collapsible=icon]:hidden"})]})}),(0,r.jsxs)(V.AW,{side:"top",className:"w-[--radix-popper-anchor-width] mb-2",align:"start",children:[(0,r.jsx)(V.Xi,{onClick:()=>i("dark"===o?"light":"dark"),children:(0,r.jsxs)("div",{className:"flex items-center gap-2 w-full",children:["dark"===o?(0,r.jsx)($.Z,{className:"h-4 w-4"}):(0,r.jsx)(ee.Z,{className:"h-4 w-4"}),(0,r.jsx)("span",{children:"Theme"})]})}),(0,r.jsx)(V.Xi,{onClick:()=>n.push("/api/auth/signout"),children:(0,r.jsxs)("div",{className:"flex items-center gap-2 w-full",children:[(0,r.jsx)(ea.Z,{className:"h-4 w-4"}),(0,r.jsx)("span",{children:"Logout"})]})}),(0,r.jsx)(V.Xi,{onClick:()=>window.open("https://www.exulu.com/toc","_blank"),children:(0,r.jsxs)("div",{className:"flex items-center gap-2 w-full",children:[(0,r.jsx)(et.Z,{className:"h-4 w-4"}),(0,r.jsx)("span",{children:"Terms"})]})})]})]})})})})]})}function el(e){let{children:a,sidebarDefaultOpen:t}=e;return console.log("sidebarDefaultOpen",t),(0,r.jsx)(R,{defaultOpen:t,children:(0,r.jsxs)("div",{className:"flex h-screen w-full bg-background overflow-hidden",children:[(0,r.jsx)(ed,{sidebarDefaultOpen:t}),(0,r.jsx)("main",{className:"flex-1 overflow-auto",children:a})]})})}var ec=t(6374);let eu=u.createContext(null),ef=e=>{let{children:a,user:t,sidebarDefaultOpen:s}=e;return(0,r.jsx)(eu.Provider,{value:{user:t},children:(0,r.jsx)(el,{sidebarDefaultOpen:s,children:a})})};var ep=e=>{let{children:a,user:t,sidebarDefaultOpen:f}=e,p=u.useContext(en.E),m=(null==p?void 0:p.backend)?(null==p?void 0:p.backend)+"/graphql":"http://localhost:9001/graphql",b=(0,l.v)((e,a)=>({headers:{Accept:"charset=utf-8"}})),h=(0,l.v)(async(e,a)=>{let t=await (0,ec.LP)();return{headers:{Authorization:"Bearer ".concat(t)}}}),x=s.i.from([b,h,new n.u({uri:m})]),g=new i.f({uri:m,cache:new o.h({addTypename:!1}),link:x,defaultOptions:{watchQuery:{fetchPolicy:"no-cache",errorPolicy:"ignore"},query:{fetchPolicy:"no-cache",errorPolicy:"all"}}});return(0,r.jsx)(d.e,{client:g,children:(0,r.jsx)(c.SessionProvider,{children:(0,r.jsx)(ef,{sidebarDefaultOpen:f,user:t,children:a})})})}},44045:function(e,a,t){t.d(a,{ConfigContextProvider:function(){return n},E:function(){return s}});var r=t(57437);let s=(0,t(2265).createContext)(null);function n(e){let{children:a,config:t}=e;if(console.log("[EXULU] Config: ",t),!t)throw Error("Config not found");return(0,r.jsx)(s.Provider,{value:t,children:a})}},16831:function(e,a,t){t.d(a,{Q5:function(){return d},qE:function(){return o}});var r=t(57437),s=t(61146),n=t(2265),i=t(94508);let o=n.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.fC,{ref:a,className:(0,i.cn)("relative flex h-10 w-10 shrink-0 overflow-hidden rounded-full",t),...n})});o.displayName=s.fC.displayName,n.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.Ee,{ref:a,className:(0,i.cn)("aspect-square h-full w-full",t),...n})}).displayName=s.Ee.displayName;let d=n.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.NY,{ref:a,className:(0,i.cn)("flex h-full w-full items-center justify-center rounded-full bg-muted",t),...n})});d.displayName=s.NY.displayName},84190:function(e,a,t){t.d(a,{$F:function(){return u},AW:function(){return f},Ju:function(){return b},VD:function(){return h},Xi:function(){return p},bO:function(){return m},h_:function(){return c}});var r=t(57437),s=t(70085),n=t(10407),i=t(30401),o=t(40519),d=t(2265),l=t(94508);let c=s.fC,u=s.xz;s.ZA,s.Uv,s.Tr,s.Ee,d.forwardRef((e,a)=>{let{className:t,inset:i,children:o,...d}=e;return(0,r.jsxs)(s.fF,{ref:a,className:(0,l.cn)("flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent data-[state=open]:bg-accent",i&&"pl-8",t),...d,children:[o,(0,r.jsx)(n.Z,{className:"ml-auto size-4"})]})}).displayName=s.fF.displayName,d.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.tu,{ref:a,className:(0,l.cn)("z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",t),...n})}).displayName=s.tu.displayName;let f=d.forwardRef((e,a)=>{let{className:t,sideOffset:n=4,...i}=e;return(0,r.jsx)(s.Uv,{children:(0,r.jsx)(s.VY,{ref:a,sideOffset:n,className:(0,l.cn)("z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-md data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",t),...i})})});f.displayName=s.VY.displayName;let p=d.forwardRef((e,a)=>{let{className:t,inset:n,...i}=e;return(0,r.jsx)(s.ck,{ref:a,className:(0,l.cn)("relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",n&&"pl-8",t),...i})});p.displayName=s.ck.displayName;let m=d.forwardRef((e,a)=>{let{className:t,children:n,checked:o,...d}=e;return(0,r.jsxs)(s.oC,{ref:a,className:(0,l.cn)("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",t),checked:o,...d,children:[(0,r.jsx)("span",{className:"absolute left-2 flex size-3.5 items-center justify-center",children:(0,r.jsx)(s.wU,{children:(0,r.jsx)(i.Z,{className:"size-4"})})}),n]})});m.displayName=s.oC.displayName,d.forwardRef((e,a)=>{let{className:t,children:n,...i}=e;return(0,r.jsxs)(s.Rk,{ref:a,className:(0,l.cn)("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",t),...i,children:[(0,r.jsx)("span",{className:"absolute left-2 flex size-3.5 items-center justify-center",children:(0,r.jsx)(s.wU,{children:(0,r.jsx)(o.Z,{className:"size-2 fill-current"})})}),n]})}).displayName=s.Rk.displayName;let b=d.forwardRef((e,a)=>{let{className:t,inset:n,...i}=e;return(0,r.jsx)(s.__,{ref:a,className:(0,l.cn)("px-2 py-1.5 text-sm font-semibold",n&&"pl-8",t),...i})});b.displayName=s.__.displayName;let h=d.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.Z0,{ref:a,className:(0,l.cn)("-mx-1 my-1 h-px bg-muted",t),...n})});h.displayName=s.Z0.displayName},95186:function(e,a,t){t.d(a,{I:function(){return i}});var r=t(57437),s=t(2265),n=t(94508);let i=s.forwardRef((e,a)=>{let{className:t,type:s,...i}=e;return(0,r.jsx)("input",{type:s,className:(0,n.cn)("flex h-10 w-full rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50",t),ref:a,...i})});i.displayName="Input"},6512:function(e,a,t){t.d(a,{Z:function(){return o}});var r=t(57437),s=t(55156),n=t(2265),i=t(94508);let o=n.forwardRef((e,a)=>{let{className:t,orientation:n="horizontal",decorative:o=!0,...d}=e;return(0,r.jsx)(s.f,{ref:a,decorative:o,orientation:n,className:(0,i.cn)("shrink-0 bg-border","horizontal"===n?"h-[1px] w-full":"h-full w-[1px]",t),...d})});o.displayName=s.f.displayName},69304:function(e,a,t){t.d(a,{Ei:function(){return x},Tu:function(){return b},aM:function(){return c},bC:function(){return h},ue:function(){return m},yo:function(){return l}});var r=t(57437),s=t(34567),n=t(90535),i=t(32489),o=t(2265),d=t(94508);let l=s.fC,c=s.xz;s.x8;let u=s.h_,f=o.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.aV,{className:(0,d.cn)("fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",t),...n,ref:a})});f.displayName=s.aV.displayName;let p=(0,n.j)("fixed z-50 gap-4 bg-background p-6 shadow-lg transition ease-in-out data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:duration-300 data-[state=open]:duration-500",{variants:{side:{top:"inset-x-0 top-0 border-b data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top",bottom:"inset-x-0 bottom-0 border-t data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom",left:"inset-y-0 left-0 h-full w-3/4 border-r data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left sm:max-w-sm",right:"inset-y-0 right-0 h-full w-3/4 border-l data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right sm:max-w-sm"}},defaultVariants:{side:"right"}}),m=o.forwardRef((e,a)=>{let{side:t="right",className:n,children:o,...l}=e;return(0,r.jsxs)(u,{children:[(0,r.jsx)(f,{}),(0,r.jsxs)(s.VY,{ref:a,className:(0,d.cn)(p({side:t}),n),...l,children:[o,(0,r.jsxs)(s.x8,{className:"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-secondary",children:[(0,r.jsx)(i.Z,{className:"size-4"}),(0,r.jsx)("span",{className:"sr-only",children:"Close"})]})]})]})});m.displayName=s.VY.displayName;let b=e=>{let{className:a,...t}=e;return(0,r.jsx)("div",{className:(0,d.cn)("flex flex-col space-y-2 text-center sm:text-left",a),...t})};b.displayName="SheetHeader";let h=o.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.Dx,{ref:a,className:(0,d.cn)("text-lg font-semibold text-foreground",t),...n})});h.displayName=s.Dx.displayName;let x=o.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.dk,{ref:a,className:(0,d.cn)("text-sm text-muted-foreground",t),...n})});x.displayName=s.dk.displayName},93022:function(e,a,t){t.d(a,{O:function(){return n}});var r=t(57437),s=t(94508);function n(e){let{className:a,...t}=e;return(0,r.jsx)("div",{className:(0,s.cn)("animate-pulse rounded-md bg-muted",a),...t})}},81103:function(e,a,t){t.d(a,{_v:function(){return c},aJ:function(){return l},pn:function(){return o},u:function(){return d}});var r=t(57437),s=t(4957),n=t(2265),i=t(94508);let o=s.zt,d=s.fC,l=s.xz,c=n.forwardRef((e,a)=>{let{className:t,sideOffset:n=4,...o}=e;return(0,r.jsx)(s.VY,{ref:a,sideOffset:n,className:(0,i.cn)("z-50 overflow-hidden rounded-md border bg-popover px-3 py-1.5 text-sm text-popover-foreground shadow-md animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",t),...o})});c.displayName=s.VY.displayName},866:function(e,a,t){t.d(a,{d:function(){return s}});var r=t(2265);function s(){let[e,a]=r.useState(void 0);return r.useEffect(()=>{let e=window.matchMedia("(max-width: ".concat(767,"px)")),t=()=>{a(window.innerWidth<768)};return e.addEventListener("change",t),a(window.innerWidth<768),()=>e.removeEventListener("change",t)},[]),!!e}},6374:function(e,a,t){t.d(a,{DQ:function(){return i},LP:function(){return n},QZ:function(){return o}});var r=t(80605);let s=async()=>{let e=await fetch("/api/config").then(e=>e.json());if(!e.backend)throw Error("No backend set.");return{files:e.backend,base:e.backend}},n=async()=>{var e;let a=await (0,r.getSession)();return null==a?void 0:null===(e=a.user)||void 0===e?void 0:e.jwt},i={image:{generate:async e=>{let a=await s(),t="".concat(a.base,"/generate/agent/image"),r=await n();if(!r)throw Error("No valid session token available.");return fetch(t,{method:"POST",body:JSON.stringify(e),headers:{"Content-Type":"application/json",Authorization:"Bearer ".concat(r)}})}}},o={object:async e=>{let a=await s(),t="".concat(a.files,"/s3/object"),r=await n();return(await fetch(t,{method:"POST",body:JSON.stringify({key:e}),headers:{"Content-Type":"application/json",Authorization:"Bearer ".concat(r)}})).json()},list:async e=>{let{search:a,continuationToken:t}=e,r=await s(),i="".concat(r.files,"/s3/list"),o=await n();if(!o)throw Error("No valid session token available.");return a&&(i+="?search=".concat(a)),t&&(i+="?continuationToken=".concat(t)),(await fetch(i,{method:"GET",headers:{"Content-Type":"application/json",Authorization:"Bearer ".concat(o)}})).json()},download:async e=>{let a=await s(),t="".concat(a.files,"/s3/download?key=").concat(e),r=await n();if(!r)throw Error("No valid session token available.");return fetch(t,{method:"GET",headers:{"Content-Type":"application/json",Authorization:"Bearer ".concat(r)}})},delete:async e=>{let a=await s(),t="".concat(a.files,"/s3/delete?key=").concat(e),r=await n();if(!r)throw Error("No valid session token available.");return fetch(t,{method:"DELETE",headers:{"Content-Type":"application/json",Authorization:"Bearer ".concat(r)}})}}}}]);
2
- //# sourceMappingURL=3832-cfd7197465448e35.js.map
1
+ "use strict";(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[3832],{13832:function(e,a,t){t.d(a,{S:function(){return ef},default:function(){return em}});var r=t(57437),s=t(24614),n=t(71946),i=t(81068),o=t(63761),d=t(51251),l=t(51451),c=t(80605),u=t(2265),f=t(27648),p=t(99376),m=t(37053),b=t(90535),h=t(30755),x=t(866),g=t(94508),v=t(62869),w=t(95186),j=t(6512),N=t(69304),y=t(93022),k=t(81103);let z=u.createContext(null);function C(){let e=u.useContext(z);if(!e)throw Error("useSidebar must be used within a SidebarProvider.");return e}let R=u.forwardRef((e,a)=>{let{defaultOpen:t=!0,open:s,onOpenChange:n,className:i,style:o,children:d,...l}=e,c=(0,x.d)(),[f,p]=u.useState(!1),[m,b]=u.useState(t),h=null!=s?s:m,v=u.useCallback(e=>{let a="function"==typeof e?e(h):e;n?n(a):b(a),document.cookie="".concat("sidebar_state","=").concat(a,"; path=/; max-age=").concat(604800)},[n,h]),w=u.useCallback(()=>c?p(e=>!e):v(e=>!e),[c,v,p]);u.useEffect(()=>{let e=e=>{"b"===e.key&&(e.metaKey||e.ctrlKey)&&(e.preventDefault(),w())};return window.addEventListener("keydown",e),()=>window.removeEventListener("keydown",e)},[w]);let j=h?"expanded":"collapsed",N=u.useMemo(()=>({state:j,open:h,setOpen:v,isMobile:c,openMobile:f,setOpenMobile:p,toggleSidebar:w}),[j,h,v,c,f,p,w]);return(0,r.jsx)(z.Provider,{value:N,children:(0,r.jsx)(k.pn,{delayDuration:0,children:(0,r.jsx)("div",{style:{"--sidebar-width":"16rem","--sidebar-width-icon":"3rem",...o},className:(0,g.cn)("group/sidebar-wrapper flex min-h-svh w-full has-[[data-variant=inset]]:bg-sidebar",i),ref:a,...l,children:d})})})});R.displayName="SidebarProvider";let S=u.forwardRef((e,a)=>{let{side:t="left",variant:s="sidebar",collapsible:n="offcanvas",className:i,children:o,...d}=e,{isMobile:l,state:c,openMobile:u,setOpenMobile:f}=C();return"none"===n?(0,r.jsx)("div",{className:(0,g.cn)("flex h-full w-[--sidebar-width] flex-col bg-sidebar text-sidebar-foreground",i),ref:a,...d,children:o}):l?(0,r.jsx)(N.yo,{open:u,onOpenChange:f,...d,children:(0,r.jsxs)(N.ue,{"data-sidebar":"sidebar","data-mobile":"true",className:"w-[--sidebar-width] bg-sidebar p-0 text-sidebar-foreground [&>button]:hidden",style:{"--sidebar-width":"18rem"},side:t,children:[(0,r.jsxs)(N.Tu,{className:"sr-only",children:[(0,r.jsx)(N.bC,{children:"Sidebar"}),(0,r.jsx)(N.Ei,{children:"Displays the mobile sidebar."})]}),(0,r.jsx)("div",{className:"flex h-full w-full flex-col",children:o})]})}):(0,r.jsxs)("div",{ref:a,className:"group peer hidden text-sidebar-foreground md:block","data-state":c,"data-collapsible":"collapsed"===c?n:"","data-variant":s,"data-side":t,children:[(0,r.jsx)("div",{className:(0,g.cn)("relative w-[--sidebar-width] bg-transparent transition-[width] duration-200 ease-linear","group-data-[collapsible=offcanvas]:w-0","group-data-[side=right]:rotate-180","floating"===s||"inset"===s?"group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)_+_theme(spacing.4))]":"group-data-[collapsible=icon]:w-[--sidebar-width-icon]")}),(0,r.jsx)("div",{className:(0,g.cn)("fixed inset-y-0 z-10 hidden h-svh w-[--sidebar-width] transition-[left,right,width] duration-200 ease-linear md:flex","left"===t?"left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]":"right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]","floating"===s||"inset"===s?"p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)_+_theme(spacing.4)_+2px)]":"group-data-[collapsible=icon]:w-[--sidebar-width-icon] group-data-[side=left]:border-r group-data-[side=right]:border-l",i),...d,children:(0,r.jsx)("div",{"data-sidebar":"sidebar",className:"flex h-full w-full flex-col bg-sidebar group-data-[variant=floating]:rounded-lg group-data-[variant=floating]:border group-data-[variant=floating]:border-sidebar-border group-data-[variant=floating]:shadow",children:o})})]})});S.displayName="Sidebar";let _=u.forwardRef((e,a)=>{let{className:t,onClick:s,...n}=e,{toggleSidebar:i}=C();return(0,r.jsxs)(v.z,{ref:a,"data-sidebar":"trigger",variant:"ghost",size:"icon",className:(0,g.cn)("h-7 w-7",t),onClick:e=>{null==s||s(e),i()},...n,children:[(0,r.jsx)(h.Z,{}),(0,r.jsx)("span",{className:"sr-only",children:"Toggle Sidebar"})]})});_.displayName="SidebarTrigger",u.forwardRef((e,a)=>{let{className:t,...s}=e,{toggleSidebar:n}=C();return(0,r.jsx)("button",{ref:a,"data-sidebar":"rail","aria-label":"Toggle Sidebar",tabIndex:-1,onClick:n,title:"Toggle Sidebar",className:(0,g.cn)("absolute inset-y-0 z-20 hidden w-4 -translate-x-1/2 transition-all ease-linear after:absolute after:inset-y-0 after:left-1/2 after:w-[2px] hover:after:bg-sidebar-border group-data-[side=left]:-right-4 group-data-[side=right]:left-0 sm:flex","[[data-side=left]_&]:cursor-w-resize [[data-side=right]_&]:cursor-e-resize","[[data-side=left][data-state=collapsed]_&]:cursor-e-resize [[data-side=right][data-state=collapsed]_&]:cursor-w-resize","group-data-[collapsible=offcanvas]:translate-x-0 group-data-[collapsible=offcanvas]:after:left-full group-data-[collapsible=offcanvas]:hover:bg-sidebar","[[data-side=left][data-collapsible=offcanvas]_&]:-right-2","[[data-side=right][data-collapsible=offcanvas]_&]:-left-2",t),...s})}).displayName="SidebarRail",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("main",{ref:a,className:(0,g.cn)("relative flex w-full flex-1 flex-col bg-background","md:peer-data-[variant=inset]:m-2 md:peer-data-[state=collapsed]:peer-data-[variant=inset]:ml-2 md:peer-data-[variant=inset]:ml-0 md:peer-data-[variant=inset]:rounded-xl md:peer-data-[variant=inset]:shadow",t),...s})}).displayName="SidebarInset",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)(w.I,{ref:a,"data-sidebar":"input",className:(0,g.cn)("h-8 w-full bg-background shadow-none focus-visible:ring-2 focus-visible:ring-sidebar-ring",t),...s})}).displayName="SidebarInput",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"header",className:(0,g.cn)("flex flex-col gap-2 p-2",t),...s})}).displayName="SidebarHeader";let E=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"footer",className:(0,g.cn)("flex flex-col gap-2 p-2",t),...s})});E.displayName="SidebarFooter",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)(j.Z,{ref:a,"data-sidebar":"separator",className:(0,g.cn)("mx-2 w-auto bg-sidebar-border",t),...s})}).displayName="SidebarSeparator";let Z=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"content",className:(0,g.cn)("flex min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden",t),...s})});Z.displayName="SidebarContent";let T=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"group",className:(0,g.cn)("relative flex w-full min-w-0 flex-col p-0",t),...s})});T.displayName="SidebarGroup",u.forwardRef((e,a)=>{let{className:t,asChild:s=!1,...n}=e,i=s?m.g7:"div";return(0,r.jsx)(i,{ref:a,"data-sidebar":"group-label",className:(0,g.cn)("flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium text-sidebar-foreground/70 outline-none ring-sidebar-ring transition-[margin,opacity] duration-200 ease-linear focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0","group-data-[collapsible=icon]:-mt-8 group-data-[collapsible=icon]:opacity-0",t),...n})}).displayName="SidebarGroupLabel",u.forwardRef((e,a)=>{let{className:t,asChild:s=!1,...n}=e,i=s?m.g7:"button";return(0,r.jsx)(i,{ref:a,"data-sidebar":"group-action",className:(0,g.cn)("absolute right-3 top-3.5 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground outline-none ring-sidebar-ring transition-transform hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0","after:absolute after:-inset-2 after:md:hidden","group-data-[collapsible=icon]:hidden",t),...n})}).displayName="SidebarGroupAction";let O=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"group-content",className:(0,g.cn)("w-full text-sm",t),...s})});O.displayName="SidebarGroupContent";let P=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("ul",{ref:a,"data-sidebar":"menu",className:(0,g.cn)("flex w-full min-w-0 flex-col gap-1",t),...s})});P.displayName="SidebarMenu";let A=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("li",{ref:a,"data-sidebar":"menu-item",className:(0,g.cn)("group/menu-item relative",t),...s})});A.displayName="SidebarMenuItem";let M=(0,b.j)("peer/menu-button flex w-full items-center gap-2 overflow-hidden rounded-md p-2 text-left text-sm outline-none ring-sidebar-ring transition-[width,height,padding] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 group-has-[[data-sidebar=menu-action]]/menu-item:pr-8 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-[active=true]:bg-sidebar-accent data-[active=true]:font-medium data-[active=true]:text-sidebar-accent-foreground data-[state=open]:hover:bg-sidebar-accent data-[state=open]:hover:text-sidebar-accent-foreground group-data-[collapsible=icon]:!size-8 group-data-[collapsible=icon]:!p-[0.40rem] [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0",{variants:{variant:{default:"hover:bg-sidebar-accent hover:text-sidebar-accent-foreground",outline:"bg-background shadow-[0_0_0_1px_hsl(var(--sidebar-border))] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground hover:shadow-[0_0_0_1px_hsl(var(--sidebar-accent))]"},size:{default:"h-8 text-sm",sm:"h-7 text-xs",lg:"h-12 text-sm group-data-[collapsible=icon]:!p-0"}},defaultVariants:{variant:"default",size:"default"}}),D=u.forwardRef((e,a)=>{let{asChild:t=!1,isActive:s=!1,variant:n="default",size:i="default",tooltip:o,className:d,...l}=e,c=t?m.g7:"button",{isMobile:u,state:f}=C(),p=(0,r.jsx)(c,{ref:a,"data-sidebar":"menu-button","data-size":i,"data-active":s,className:(0,g.cn)(M({variant:n,size:i}),d),...l});return o?("string"==typeof o&&(o={children:o}),(0,r.jsxs)(k.u,{children:[(0,r.jsx)(k.aJ,{asChild:!0,children:p}),(0,r.jsx)(k._v,{side:"right",align:"center",hidden:"collapsed"!==f||u,...o})]})):p});D.displayName="SidebarMenuButton",u.forwardRef((e,a)=>{let{className:t,asChild:s=!1,showOnHover:n=!1,...i}=e,o=s?m.g7:"button";return(0,r.jsx)(o,{ref:a,"data-sidebar":"menu-action",className:(0,g.cn)("absolute right-1 top-1.5 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground outline-none ring-sidebar-ring transition-transform hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 peer-hover/menu-button:text-sidebar-accent-foreground [&>svg]:size-4 [&>svg]:shrink-0","after:absolute after:-inset-2 after:md:hidden","peer-data-[size=sm]/menu-button:top-1","peer-data-[size=default]/menu-button:top-1.5","peer-data-[size=lg]/menu-button:top-2.5","group-data-[collapsible=icon]:hidden",n&&"group-focus-within/menu-item:opacity-100 group-hover/menu-item:opacity-100 data-[state=open]:opacity-100 peer-data-[active=true]/menu-button:text-sidebar-accent-foreground md:opacity-0",t),...i})}).displayName="SidebarMenuAction",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"menu-badge",className:(0,g.cn)("pointer-events-none absolute right-1 flex h-5 min-w-5 select-none items-center justify-center rounded-md px-1 text-xs font-medium tabular-nums text-sidebar-foreground","peer-hover/menu-button:text-sidebar-accent-foreground peer-data-[active=true]/menu-button:text-sidebar-accent-foreground","peer-data-[size=sm]/menu-button:top-1","peer-data-[size=default]/menu-button:top-1.5","peer-data-[size=lg]/menu-button:top-2.5","group-data-[collapsible=icon]:hidden",t),...s})}).displayName="SidebarMenuBadge",u.forwardRef((e,a)=>{let{className:t,showIcon:s=!1,...n}=e,i=u.useMemo(()=>"".concat(Math.floor(40*Math.random())+50,"%"),[]);return(0,r.jsxs)("div",{ref:a,"data-sidebar":"menu-skeleton",className:(0,g.cn)("flex h-8 items-center gap-2 rounded-md px-2",t),...n,children:[s&&(0,r.jsx)(y.O,{className:"size-4 rounded-md","data-sidebar":"menu-skeleton-icon"}),(0,r.jsx)(y.O,{className:"h-4 max-w-[--skeleton-width] flex-1","data-sidebar":"menu-skeleton-text",style:{"--skeleton-width":i}})]})}).displayName="SidebarMenuSkeleton",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("ul",{ref:a,"data-sidebar":"menu-sub",className:(0,g.cn)("mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l border-sidebar-border px-2.5 py-0.5","group-data-[collapsible=icon]:hidden",t),...s})}).displayName="SidebarMenuSub",u.forwardRef((e,a)=>{let{...t}=e;return(0,r.jsx)("li",{ref:a,...t})}).displayName="SidebarMenuSubItem",u.forwardRef((e,a)=>{let{asChild:t=!1,size:s="md",isActive:n,className:i,...o}=e,d=t?m.g7:"a";return(0,r.jsx)(d,{ref:a,"data-sidebar":"menu-sub-button","data-size":s,"data-active":n,className:(0,g.cn)("flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 text-sidebar-foreground outline-none ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0 [&>svg]:text-sidebar-accent-foreground","data-[active=true]:bg-sidebar-accent data-[active=true]:text-sidebar-accent-foreground","sm"===s&&"text-xs","md"===s&&"text-sm","group-data-[collapsible=icon]:hidden",i),...o})}).displayName="SidebarMenuSubButton";var L=t(84190),V=t(25466),B=t(50091),I=t(9343),q=t(82222),U=t(56475),Y=t(82718),F=t(64972),G=t(78406),J=t(95805),Q=t(54001),W=t(32790),X=t(64935),K=t(98728),H=t(22135),$=t(85929),ee=t(97226),ea=t(47692),et=t(48736),er=t(78298),es=t(16831),en=t(21391);let ei=(e,a)=>{let t=[];return e.super_admin&&t.push({label:"Dashboard",path:"dashboard",icon:(0,r.jsx)(V.Z,{})}),t.push({label:"Contexts",path:"data",icon:(0,r.jsx)(B.Z,{})}),t.push({label:"Jobs",path:"jobs",icon:(0,r.jsx)(I.Z,{})}),(e.super_admin||"write"===a.agents)&&t.push({label:"Agents",path:"agents",icon:(0,r.jsx)(q.Z,{})}),t.push({label:"Projects",path:"projects",icon:(0,r.jsx)(U.Z,{})}),t.push({label:"Chat",path:"chat",icon:(0,r.jsx)(Y.Z,{})}),(e.super_admin||"read"===a.evals||"write"===a.evals)&&t.push({label:"Evals",path:"evals",icon:(0,r.jsx)(F.Z,{})}),(e.super_admin||"write"===a.workflows)&&t.push({label:"Workflows",path:"workflows",icon:(0,r.jsx)(G.Z,{})}),(e.super_admin||"write"===a.users)&&t.push({label:"Users",path:"users",icon:(0,r.jsx)(J.Z,{})}),(e.super_admin||"write"===a.api)&&t.push({label:"Keys",path:"keys",icon:(0,r.jsx)(Q.Z,{})}),(e.super_admin||"write"===a.variables)&&t.push({label:"Variables",path:"variables",icon:(0,r.jsx)(W.Z,{})}),(e.super_admin||"write"===a.api)&&t.push({label:"API",path:"explorer",icon:(0,r.jsx)(X.Z,{})}),e.super_admin&&t.push({label:"Configurations",path:"configuration",icon:(0,r.jsx)(K.Z,{})}),t};function eo(e){let{items:a}=e,t=(0,p.usePathname)();return(0,r.jsx)(P,{className:"space-y-1",children:a.map((e,a)=>{let s=t.includes(e.path);return(0,r.jsx)(A,{children:(0,r.jsx)(D,{asChild:!0,isActive:s,tooltip:e.label,className:(0,g.cn)("h-10 transition-all duration-200"),children:(0,r.jsxs)(f.default,{href:"/".concat(e.path),className:"flex items-center gap-3",children:[(0,r.jsx)("div",{className:(0,g.cn)("flex h-5 w-5 items-center justify-center transition-colors"),children:e.icon}),(0,r.jsx)("span",{className:(0,g.cn)("font-medium transition-colors"),children:e.label})]})})},a)})})}function ed(e){let{sidebarDefaultOpen:a}=e,{user:t}=(0,u.useContext)(ef),s=ei(t,t.role),n=(0,p.useRouter)(),{setTheme:i,theme:o}=(0,er.F)(),d=(0,p.useParams)(),l=C();return(0,u.useEffect)(()=>{d.agent&&void 0===a&&l.setOpen(!1)},[d.agent]),(0,r.jsxs)(S,{collapsible:"icon",className:"border-r",children:[(0,r.jsxs)("div",{className:"flex items-center gap-3 border-b bg-background/80 backdrop-blur-sm p-[12px] sticky top-0 z-10",children:[(0,r.jsx)(_,{}),(0,r.jsx)("div",{className:"flex items-center gap-2",children:(0,r.jsx)(en.default,{alt:"Logo",width:100,height:40})})]}),(0,r.jsx)(Z,{className:"px-2",children:(0,r.jsx)(T,{className:"mt-4",children:(0,r.jsx)(O,{children:(0,r.jsx)(eo,{items:s})})})}),(0,r.jsx)(E,{className:"border-t bg-muted/20 p-[5px]",children:(0,r.jsx)(P,{children:(0,r.jsx)(A,{children:(0,r.jsxs)(L.h_,{children:[(0,r.jsx)(L.$F,{asChild:!0,children:(0,r.jsxs)(D,{className:"h-12 hover:bg-accent/50",children:[(0,r.jsx)(es.qE,{className:"h-5 w-5",children:(0,r.jsx)(es.Q5,{className:"bg-gradient-to-br from-primary/20 to-primary/60 text-white text-sm",children:t.email.charAt(0).toUpperCase()})}),(0,r.jsxs)("div",{className:"flex flex-col items-start group-data-[collapsible=icon]:hidden",children:[(0,r.jsx)("span",{className:"text-sm font-medium capitalize",children:t.email.split("@")[0]}),(0,r.jsx)("div",{className:"flex items-center gap-1",children:(0,r.jsx)("span",{className:"text-xs text-muted-foreground",children:t.email.split("@")[1]})})]}),(0,r.jsx)(H.Z,{className:"ml-auto h-4 w-4 group-data-[collapsible=icon]:hidden"})]})}),(0,r.jsxs)(L.AW,{side:"top",className:"w-[--radix-popper-anchor-width] mb-2",align:"start",children:[(0,r.jsx)(L.Xi,{onClick:()=>i("dark"===o?"light":"dark"),children:(0,r.jsxs)("div",{className:"flex items-center gap-2 w-full",children:["dark"===o?(0,r.jsx)($.Z,{className:"h-4 w-4"}):(0,r.jsx)(ee.Z,{className:"h-4 w-4"}),(0,r.jsx)("span",{children:"Theme"})]})}),(0,r.jsx)(L.Xi,{onClick:()=>n.push("/api/auth/signout"),children:(0,r.jsxs)("div",{className:"flex items-center gap-2 w-full",children:[(0,r.jsx)(ea.Z,{className:"h-4 w-4"}),(0,r.jsx)("span",{children:"Logout"})]})}),(0,r.jsx)(L.Xi,{onClick:()=>window.open("https://www.exulu.com/toc","_blank"),children:(0,r.jsxs)("div",{className:"flex items-center gap-2 w-full",children:[(0,r.jsx)(et.Z,{className:"h-4 w-4"}),(0,r.jsx)("span",{children:"Terms"})]})})]})]})})})})]})}function el(e){let{children:a,sidebarDefaultOpen:t}=e;return console.log("sidebarDefaultOpen",t),(0,r.jsx)(R,{defaultOpen:t,children:(0,r.jsxs)("div",{className:"flex h-screen w-full bg-background overflow-hidden",children:[(0,r.jsx)(ed,{sidebarDefaultOpen:t}),(0,r.jsx)("main",{className:"flex-1 overflow-auto",children:a})]})})}var ec=t(6374),eu=t(44045);let ef=u.createContext(null),ep=e=>{let{children:a,user:t,sidebarDefaultOpen:s}=e;return(0,r.jsx)(ef.Provider,{value:{user:t},children:(0,r.jsx)(el,{sidebarDefaultOpen:s,children:a})})};var em=e=>{let{children:a,user:t,sidebarDefaultOpen:f}=e,p=u.useContext(eu.E),m=(null==p?void 0:p.backend)?(null==p?void 0:p.backend)+"/graphql":"http://localhost:9001/graphql",b=(0,l.v)((e,a)=>({headers:{Accept:"charset=utf-8"}})),h=(0,l.v)(async(e,a)=>{let t=await (0,ec.LP)();return{headers:{Authorization:"Bearer ".concat(t)}}}),x=s.i.from([b,h,new n.u({uri:m})]),g=new i.f({uri:m,cache:new o.h({addTypename:!1}),link:x,defaultOptions:{watchQuery:{fetchPolicy:"no-cache",errorPolicy:"ignore"},query:{fetchPolicy:"no-cache",errorPolicy:"all"}}});return(0,r.jsx)(d.e,{client:g,children:(0,r.jsx)(c.SessionProvider,{children:(0,r.jsx)(ep,{sidebarDefaultOpen:f,user:t,children:a})})})}},44045:function(e,a,t){t.d(a,{ConfigContextProvider:function(){return n},E:function(){return s}});var r=t(57437);let s=(0,t(2265).createContext)(null);function n(e){let{children:a,config:t}=e;if(console.log("[EXULU] Config: ",t),!t)throw Error("Config not found");return(0,r.jsx)(s.Provider,{value:t,children:a})}},21391:function(e,a,t){var r=t(57437),s=t(44045),n=t(2265);a.default=e=>{let{width:a=64,height:t=32,className:i="",alt:o="Logo"}=e,d=(0,n.useContext)(s.E);return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)("img",{src:(null==d?void 0:d.backend)+"/logo_dark.png",alt:o,width:a,height:t,className:i+"hidden dark:block invert"}),(0,r.jsx)("img",{src:(null==d?void 0:d.backend)+"/logo_light.png",alt:o,width:a,height:t,className:i+"block dark:hidden"})]})}},16831:function(e,a,t){t.d(a,{Q5:function(){return d},qE:function(){return o}});var r=t(57437),s=t(61146),n=t(2265),i=t(94508);let o=n.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.fC,{ref:a,className:(0,i.cn)("relative flex h-10 w-10 shrink-0 overflow-hidden rounded-full",t),...n})});o.displayName=s.fC.displayName,n.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.Ee,{ref:a,className:(0,i.cn)("aspect-square h-full w-full",t),...n})}).displayName=s.Ee.displayName;let d=n.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.NY,{ref:a,className:(0,i.cn)("flex h-full w-full items-center justify-center rounded-full bg-muted",t),...n})});d.displayName=s.NY.displayName},84190:function(e,a,t){t.d(a,{$F:function(){return u},AW:function(){return f},Ju:function(){return b},VD:function(){return h},Xi:function(){return p},bO:function(){return m},h_:function(){return c}});var r=t(57437),s=t(70085),n=t(10407),i=t(30401),o=t(40519),d=t(2265),l=t(94508);let c=s.fC,u=s.xz;s.ZA,s.Uv,s.Tr,s.Ee,d.forwardRef((e,a)=>{let{className:t,inset:i,children:o,...d}=e;return(0,r.jsxs)(s.fF,{ref:a,className:(0,l.cn)("flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent data-[state=open]:bg-accent",i&&"pl-8",t),...d,children:[o,(0,r.jsx)(n.Z,{className:"ml-auto size-4"})]})}).displayName=s.fF.displayName,d.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.tu,{ref:a,className:(0,l.cn)("z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",t),...n})}).displayName=s.tu.displayName;let f=d.forwardRef((e,a)=>{let{className:t,sideOffset:n=4,...i}=e;return(0,r.jsx)(s.Uv,{children:(0,r.jsx)(s.VY,{ref:a,sideOffset:n,className:(0,l.cn)("z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-md data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",t),...i})})});f.displayName=s.VY.displayName;let p=d.forwardRef((e,a)=>{let{className:t,inset:n,...i}=e;return(0,r.jsx)(s.ck,{ref:a,className:(0,l.cn)("relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",n&&"pl-8",t),...i})});p.displayName=s.ck.displayName;let m=d.forwardRef((e,a)=>{let{className:t,children:n,checked:o,...d}=e;return(0,r.jsxs)(s.oC,{ref:a,className:(0,l.cn)("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",t),checked:o,...d,children:[(0,r.jsx)("span",{className:"absolute left-2 flex size-3.5 items-center justify-center",children:(0,r.jsx)(s.wU,{children:(0,r.jsx)(i.Z,{className:"size-4"})})}),n]})});m.displayName=s.oC.displayName,d.forwardRef((e,a)=>{let{className:t,children:n,...i}=e;return(0,r.jsxs)(s.Rk,{ref:a,className:(0,l.cn)("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",t),...i,children:[(0,r.jsx)("span",{className:"absolute left-2 flex size-3.5 items-center justify-center",children:(0,r.jsx)(s.wU,{children:(0,r.jsx)(o.Z,{className:"size-2 fill-current"})})}),n]})}).displayName=s.Rk.displayName;let b=d.forwardRef((e,a)=>{let{className:t,inset:n,...i}=e;return(0,r.jsx)(s.__,{ref:a,className:(0,l.cn)("px-2 py-1.5 text-sm font-semibold",n&&"pl-8",t),...i})});b.displayName=s.__.displayName;let h=d.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.Z0,{ref:a,className:(0,l.cn)("-mx-1 my-1 h-px bg-muted",t),...n})});h.displayName=s.Z0.displayName},95186:function(e,a,t){t.d(a,{I:function(){return i}});var r=t(57437),s=t(2265),n=t(94508);let i=s.forwardRef((e,a)=>{let{className:t,type:s,...i}=e;return(0,r.jsx)("input",{type:s,className:(0,n.cn)("flex h-10 w-full rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50",t),ref:a,...i})});i.displayName="Input"},6512:function(e,a,t){t.d(a,{Z:function(){return o}});var r=t(57437),s=t(55156),n=t(2265),i=t(94508);let o=n.forwardRef((e,a)=>{let{className:t,orientation:n="horizontal",decorative:o=!0,...d}=e;return(0,r.jsx)(s.f,{ref:a,decorative:o,orientation:n,className:(0,i.cn)("shrink-0 bg-border","horizontal"===n?"h-[1px] w-full":"h-full w-[1px]",t),...d})});o.displayName=s.f.displayName},69304:function(e,a,t){t.d(a,{Ei:function(){return x},Tu:function(){return b},aM:function(){return c},bC:function(){return h},ue:function(){return m},yo:function(){return l}});var r=t(57437),s=t(34567),n=t(90535),i=t(32489),o=t(2265),d=t(94508);let l=s.fC,c=s.xz;s.x8;let u=s.h_,f=o.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.aV,{className:(0,d.cn)("fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",t),...n,ref:a})});f.displayName=s.aV.displayName;let p=(0,n.j)("fixed z-50 gap-4 bg-background p-6 shadow-lg transition ease-in-out data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:duration-300 data-[state=open]:duration-500",{variants:{side:{top:"inset-x-0 top-0 border-b data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top",bottom:"inset-x-0 bottom-0 border-t data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom",left:"inset-y-0 left-0 h-full w-3/4 border-r data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left sm:max-w-sm",right:"inset-y-0 right-0 h-full w-3/4 border-l data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right sm:max-w-sm"}},defaultVariants:{side:"right"}}),m=o.forwardRef((e,a)=>{let{side:t="right",className:n,children:o,...l}=e;return(0,r.jsxs)(u,{children:[(0,r.jsx)(f,{}),(0,r.jsxs)(s.VY,{ref:a,className:(0,d.cn)(p({side:t}),n),...l,children:[o,(0,r.jsxs)(s.x8,{className:"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-secondary",children:[(0,r.jsx)(i.Z,{className:"size-4"}),(0,r.jsx)("span",{className:"sr-only",children:"Close"})]})]})]})});m.displayName=s.VY.displayName;let b=e=>{let{className:a,...t}=e;return(0,r.jsx)("div",{className:(0,d.cn)("flex flex-col space-y-2 text-center sm:text-left",a),...t})};b.displayName="SheetHeader";let h=o.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.Dx,{ref:a,className:(0,d.cn)("text-lg font-semibold text-foreground",t),...n})});h.displayName=s.Dx.displayName;let x=o.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.dk,{ref:a,className:(0,d.cn)("text-sm text-muted-foreground",t),...n})});x.displayName=s.dk.displayName},93022:function(e,a,t){t.d(a,{O:function(){return n}});var r=t(57437),s=t(94508);function n(e){let{className:a,...t}=e;return(0,r.jsx)("div",{className:(0,s.cn)("animate-pulse rounded-md bg-muted",a),...t})}},81103:function(e,a,t){t.d(a,{_v:function(){return c},aJ:function(){return l},pn:function(){return o},u:function(){return d}});var r=t(57437),s=t(4957),n=t(2265),i=t(94508);let o=s.zt,d=s.fC,l=s.xz,c=n.forwardRef((e,a)=>{let{className:t,sideOffset:n=4,...o}=e;return(0,r.jsx)(s.VY,{ref:a,sideOffset:n,className:(0,i.cn)("z-50 overflow-hidden rounded-md border bg-popover px-3 py-1.5 text-sm text-popover-foreground shadow-md animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",t),...o})});c.displayName=s.VY.displayName},866:function(e,a,t){t.d(a,{d:function(){return s}});var r=t(2265);function s(){let[e,a]=r.useState(void 0);return r.useEffect(()=>{let e=window.matchMedia("(max-width: ".concat(767,"px)")),t=()=>{a(window.innerWidth<768)};return e.addEventListener("change",t),a(window.innerWidth<768),()=>e.removeEventListener("change",t)},[]),!!e}},6374:function(e,a,t){t.d(a,{DQ:function(){return i},LP:function(){return n},QZ:function(){return o}});var r=t(80605);let s=async()=>{let e=await fetch("/api/config").then(e=>e.json());if(!e.backend)throw Error("No backend set.");return{files:e.backend,base:e.backend}},n=async()=>{var e;let a=await (0,r.getSession)();return null==a?void 0:null===(e=a.user)||void 0===e?void 0:e.jwt},i={image:{generate:async e=>{let a=await s(),t="".concat(a.base,"/generate/agent/image"),r=await n();if(!r)throw Error("No valid session token available.");return fetch(t,{method:"POST",body:JSON.stringify(e),headers:{"Content-Type":"application/json",Authorization:"Bearer ".concat(r)}})}}},o={object:async e=>{let a=await s(),t="".concat(a.files,"/s3/object"),r=await n();return(await fetch(t,{method:"POST",body:JSON.stringify({key:e}),headers:{"Content-Type":"application/json",Authorization:"Bearer ".concat(r)}})).json()},list:async e=>{let{search:a,continuationToken:t}=e,r=await s(),i="".concat(r.files,"/s3/list"),o=await n();if(!o)throw Error("No valid session token available.");return a&&(i+="?search=".concat(a)),t&&(i+="?continuationToken=".concat(t)),(await fetch(i,{method:"GET",headers:{"Content-Type":"application/json",Authorization:"Bearer ".concat(o)}})).json()},download:async e=>{let a=await s(),t="".concat(a.files,"/s3/download?key=").concat(e),r=await n();if(!r)throw Error("No valid session token available.");return fetch(t,{method:"GET",headers:{"Content-Type":"application/json",Authorization:"Bearer ".concat(r)}})},delete:async e=>{let a=await s(),t="".concat(a.files,"/s3/delete?key=").concat(e),r=await n();if(!r)throw Error("No valid session token available.");return fetch(t,{method:"DELETE",headers:{"Content-Type":"application/json",Authorization:"Bearer ".concat(r)}})}}}}]);
2
+ //# sourceMappingURL=3832-bfe8bd2edace90f9.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"static/chunks/3832-bfe8bd2edace90f9.js","mappings":"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","sources":["webpack://_N_E/./components/ui/sidebar.tsx","webpack://_N_E/./components/custom/main-nav.tsx","webpack://_N_E/./app/(application)/authenticated.tsx","webpack://_N_E/./components/config-context.tsx","webpack://_N_E/./components/logo.tsx","webpack://_N_E/./components/ui/avatar.tsx","webpack://_N_E/./components/ui/dropdown-menu.tsx","webpack://_N_E/./components/ui/input.tsx","webpack://_N_E/./components/ui/separator.tsx","webpack://_N_E/./components/ui/sheet.tsx","webpack://_N_E/./components/ui/skeleton.tsx","webpack://_N_E/./components/ui/tooltip.tsx","webpack://_N_E/./hooks/use-mobile.tsx","webpack://_N_E/./util/api.ts"],"sourcesContent":["\"use client\"\n\nimport * as React from \"react\"\nimport { Slot } from \"@radix-ui/react-slot\"\nimport { VariantProps, cva } from \"class-variance-authority\"\nimport { PanelLeft } from \"lucide-react\"\nimport { useIsMobile } from \"@/hooks/use-mobile\"\nimport { cn } from \"@/lib/utils\"\nimport { Button } from \"@/components/ui/button\"\nimport { Input } from \"@/components/ui/input\"\nimport { Separator } from \"@/components/ui/separator\"\nimport {\n Sheet,\n SheetContent,\n SheetDescription,\n SheetHeader,\n SheetTitle,\n} from \"@/components/ui/sheet\"\nimport { Skeleton } from \"@/components/ui/skeleton\"\nimport {\n Tooltip,\n TooltipContent,\n TooltipProvider,\n TooltipTrigger,\n} from \"@/components/ui/tooltip\"\n\nconst SIDEBAR_COOKIE_NAME = \"sidebar_state\"\nconst SIDEBAR_COOKIE_MAX_AGE = 60 * 60 * 24 * 7\nconst SIDEBAR_WIDTH = \"16rem\"\nconst SIDEBAR_WIDTH_MOBILE = \"18rem\"\nconst SIDEBAR_WIDTH_ICON = \"3rem\"\nconst SIDEBAR_KEYBOARD_SHORTCUT = \"b\"\n\ntype SidebarContextProps = {\n state: \"expanded\" | \"collapsed\"\n open: boolean\n setOpen: (open: boolean) => void\n openMobile: boolean\n setOpenMobile: (open: boolean) => void\n isMobile: boolean\n toggleSidebar: () => void\n}\n\nconst SidebarContext = React.createContext<SidebarContextProps | null>(null)\n\nfunction useSidebar() {\n const context = React.useContext(SidebarContext)\n if (!context) {\n throw new Error(\"useSidebar must be used within a SidebarProvider.\")\n }\n\n return context\n}\n\nconst SidebarProvider = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\"> & {\n defaultOpen?: boolean\n open?: boolean\n onOpenChange?: (open: boolean) => void\n }\n>(\n (\n {\n defaultOpen = true,\n open: openProp,\n onOpenChange: setOpenProp,\n className,\n style,\n children,\n ...props\n },\n ref\n ) => {\n const isMobile = useIsMobile()\n const [openMobile, setOpenMobile] = React.useState(false)\n\n // This is the internal state of the sidebar.\n // We use openProp and setOpenProp for control from outside the component.\n const [_open, _setOpen] = React.useState(defaultOpen)\n const open = openProp ?? _open\n const setOpen = React.useCallback(\n (value: boolean | ((value: boolean) => boolean)) => {\n const openState = typeof value === \"function\" ? value(open) : value\n if (setOpenProp) {\n setOpenProp(openState)\n } else {\n _setOpen(openState)\n }\n\n // This sets the cookie to keep the sidebar state.\n document.cookie = `${SIDEBAR_COOKIE_NAME}=${openState}; path=/; max-age=${SIDEBAR_COOKIE_MAX_AGE}`\n },\n [setOpenProp, open]\n )\n\n // Helper to toggle the sidebar.\n const toggleSidebar = React.useCallback(() => {\n return isMobile\n ? setOpenMobile((open) => !open)\n : setOpen((open) => !open)\n }, [isMobile, setOpen, setOpenMobile])\n\n // Adds a keyboard shortcut to toggle the sidebar.\n React.useEffect(() => {\n const handleKeyDown = (event: KeyboardEvent) => {\n if (\n event.key === SIDEBAR_KEYBOARD_SHORTCUT &&\n (event.metaKey || event.ctrlKey)\n ) {\n event.preventDefault()\n toggleSidebar()\n }\n }\n\n window.addEventListener(\"keydown\", handleKeyDown)\n return () => window.removeEventListener(\"keydown\", handleKeyDown)\n }, [toggleSidebar])\n\n // We add a state so that we can do data-state=\"expanded\" or \"collapsed\".\n // This makes it easier to style the sidebar with Tailwind classes.\n const state = open ? \"expanded\" : \"collapsed\"\n\n const contextValue = React.useMemo<SidebarContextProps>(\n () => ({\n state,\n open,\n setOpen,\n isMobile,\n openMobile,\n setOpenMobile,\n toggleSidebar,\n }),\n [state, open, setOpen, isMobile, openMobile, setOpenMobile, toggleSidebar]\n )\n\n return (\n <SidebarContext.Provider value={contextValue}>\n <TooltipProvider delayDuration={0}>\n <div\n style={\n {\n \"--sidebar-width\": SIDEBAR_WIDTH,\n \"--sidebar-width-icon\": SIDEBAR_WIDTH_ICON,\n ...style,\n } as React.CSSProperties\n }\n className={cn(\n \"group/sidebar-wrapper flex min-h-svh w-full has-[[data-variant=inset]]:bg-sidebar\",\n className\n )}\n ref={ref}\n {...props}\n >\n {children}\n </div>\n </TooltipProvider>\n </SidebarContext.Provider>\n )\n }\n)\nSidebarProvider.displayName = \"SidebarProvider\"\n\nconst Sidebar = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\"> & {\n side?: \"left\" | \"right\"\n variant?: \"sidebar\" | \"floating\" | \"inset\"\n collapsible?: \"offcanvas\" | \"icon\" | \"none\"\n }\n>(\n (\n {\n side = \"left\",\n variant = \"sidebar\",\n collapsible = \"offcanvas\",\n className,\n children,\n ...props\n },\n ref\n ) => {\n const { isMobile, state, openMobile, setOpenMobile } = useSidebar()\n\n if (collapsible === \"none\") {\n return (\n <div\n className={cn(\n \"flex h-full w-[--sidebar-width] flex-col bg-sidebar text-sidebar-foreground\",\n className\n )}\n ref={ref}\n {...props}\n >\n {children}\n </div>\n )\n }\n\n if (isMobile) {\n return (\n <Sheet open={openMobile} onOpenChange={setOpenMobile} {...props}>\n <SheetContent\n data-sidebar=\"sidebar\"\n data-mobile=\"true\"\n className=\"w-[--sidebar-width] bg-sidebar p-0 text-sidebar-foreground [&>button]:hidden\"\n style={\n {\n \"--sidebar-width\": SIDEBAR_WIDTH_MOBILE,\n } as React.CSSProperties\n }\n side={side}\n >\n <SheetHeader className=\"sr-only\">\n <SheetTitle>Sidebar</SheetTitle>\n <SheetDescription>Displays the mobile sidebar.</SheetDescription>\n </SheetHeader>\n <div className=\"flex h-full w-full flex-col\">{children}</div>\n </SheetContent>\n </Sheet>\n )\n }\n\n return (\n <div\n ref={ref}\n className=\"group peer hidden text-sidebar-foreground md:block\"\n data-state={state}\n data-collapsible={state === \"collapsed\" ? collapsible : \"\"}\n data-variant={variant}\n data-side={side}\n >\n {/* This is what handles the sidebar gap on desktop */}\n <div\n className={cn(\n \"relative w-[--sidebar-width] bg-transparent transition-[width] duration-200 ease-linear\",\n \"group-data-[collapsible=offcanvas]:w-0\",\n \"group-data-[side=right]:rotate-180\",\n variant === \"floating\" || variant === \"inset\"\n ? \"group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)_+_theme(spacing.4))]\"\n : \"group-data-[collapsible=icon]:w-[--sidebar-width-icon]\"\n )}\n />\n <div\n className={cn(\n \"fixed inset-y-0 z-10 hidden h-svh w-[--sidebar-width] transition-[left,right,width] duration-200 ease-linear md:flex\",\n side === \"left\"\n ? \"left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]\"\n : \"right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]\",\n // Adjust the padding for floating and inset variants.\n variant === \"floating\" || variant === \"inset\"\n ? \"p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)_+_theme(spacing.4)_+2px)]\"\n : \"group-data-[collapsible=icon]:w-[--sidebar-width-icon] group-data-[side=left]:border-r group-data-[side=right]:border-l\",\n className\n )}\n {...props}\n >\n <div\n data-sidebar=\"sidebar\"\n className=\"flex h-full w-full flex-col bg-sidebar group-data-[variant=floating]:rounded-lg group-data-[variant=floating]:border group-data-[variant=floating]:border-sidebar-border group-data-[variant=floating]:shadow\"\n >\n {children}\n </div>\n </div>\n </div>\n )\n }\n)\nSidebar.displayName = \"Sidebar\"\n\nconst SidebarTrigger = React.forwardRef<\n React.ElementRef<typeof Button>,\n React.ComponentProps<typeof Button>\n>(({ className, onClick, ...props }, ref) => {\n const { toggleSidebar } = useSidebar()\n\n return (\n <Button\n ref={ref}\n data-sidebar=\"trigger\"\n variant=\"ghost\"\n size=\"icon\"\n className={cn(\"h-7 w-7\", className)}\n onClick={(event) => {\n onClick?.(event)\n toggleSidebar()\n }}\n {...props}\n >\n <PanelLeft />\n <span className=\"sr-only\">Toggle Sidebar</span>\n </Button>\n )\n})\nSidebarTrigger.displayName = \"SidebarTrigger\"\n\nconst SidebarRail = React.forwardRef<\n HTMLButtonElement,\n React.ComponentProps<\"button\">\n>(({ className, ...props }, ref) => {\n const { toggleSidebar } = useSidebar()\n\n return (\n <button\n ref={ref}\n data-sidebar=\"rail\"\n aria-label=\"Toggle Sidebar\"\n tabIndex={-1}\n onClick={toggleSidebar}\n title=\"Toggle Sidebar\"\n className={cn(\n \"absolute inset-y-0 z-20 hidden w-4 -translate-x-1/2 transition-all ease-linear after:absolute after:inset-y-0 after:left-1/2 after:w-[2px] hover:after:bg-sidebar-border group-data-[side=left]:-right-4 group-data-[side=right]:left-0 sm:flex\",\n \"[[data-side=left]_&]:cursor-w-resize [[data-side=right]_&]:cursor-e-resize\",\n \"[[data-side=left][data-state=collapsed]_&]:cursor-e-resize [[data-side=right][data-state=collapsed]_&]:cursor-w-resize\",\n \"group-data-[collapsible=offcanvas]:translate-x-0 group-data-[collapsible=offcanvas]:after:left-full group-data-[collapsible=offcanvas]:hover:bg-sidebar\",\n \"[[data-side=left][data-collapsible=offcanvas]_&]:-right-2\",\n \"[[data-side=right][data-collapsible=offcanvas]_&]:-left-2\",\n className\n )}\n {...props}\n />\n )\n})\nSidebarRail.displayName = \"SidebarRail\"\n\nconst SidebarInset = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"main\">\n>(({ className, ...props }, ref) => {\n return (\n <main\n ref={ref}\n className={cn(\n \"relative flex w-full flex-1 flex-col bg-background\",\n \"md:peer-data-[variant=inset]:m-2 md:peer-data-[state=collapsed]:peer-data-[variant=inset]:ml-2 md:peer-data-[variant=inset]:ml-0 md:peer-data-[variant=inset]:rounded-xl md:peer-data-[variant=inset]:shadow\",\n className\n )}\n {...props}\n />\n )\n})\nSidebarInset.displayName = \"SidebarInset\"\n\nconst SidebarInput = React.forwardRef<\n React.ElementRef<typeof Input>,\n React.ComponentProps<typeof Input>\n>(({ className, ...props }, ref) => {\n return (\n <Input\n ref={ref}\n data-sidebar=\"input\"\n className={cn(\n \"h-8 w-full bg-background shadow-none focus-visible:ring-2 focus-visible:ring-sidebar-ring\",\n className\n )}\n {...props}\n />\n )\n})\nSidebarInput.displayName = \"SidebarInput\"\n\nconst SidebarHeader = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\">\n>(({ className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n data-sidebar=\"header\"\n className={cn(\"flex flex-col gap-2 p-2\", className)}\n {...props}\n />\n )\n})\nSidebarHeader.displayName = \"SidebarHeader\"\n\nconst SidebarFooter = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\">\n>(({ className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n data-sidebar=\"footer\"\n className={cn(\"flex flex-col gap-2 p-2\", className)}\n {...props}\n />\n )\n})\nSidebarFooter.displayName = \"SidebarFooter\"\n\nconst SidebarSeparator = React.forwardRef<\n React.ElementRef<typeof Separator>,\n React.ComponentProps<typeof Separator>\n>(({ className, ...props }, ref) => {\n return (\n <Separator\n ref={ref}\n data-sidebar=\"separator\"\n className={cn(\"mx-2 w-auto bg-sidebar-border\", className)}\n {...props}\n />\n )\n})\nSidebarSeparator.displayName = \"SidebarSeparator\"\n\nconst SidebarContent = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\">\n>(({ className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n data-sidebar=\"content\"\n className={cn(\n \"flex min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden\",\n className\n )}\n {...props}\n />\n )\n})\nSidebarContent.displayName = \"SidebarContent\"\n\nconst SidebarGroup = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\">\n>(({ className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n data-sidebar=\"group\"\n className={cn(\"relative flex w-full min-w-0 flex-col p-0\", className)}\n {...props}\n />\n )\n})\nSidebarGroup.displayName = \"SidebarGroup\"\n\nconst SidebarGroupLabel = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\"> & { asChild?: boolean }\n>(({ className, asChild = false, ...props }, ref) => {\n const Comp = asChild ? Slot : \"div\"\n\n return (\n <Comp\n // @ts-ignore\n ref={ref}\n data-sidebar=\"group-label\"\n className={cn(\n \"flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium text-sidebar-foreground/70 outline-none ring-sidebar-ring transition-[margin,opacity] duration-200 ease-linear focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0\",\n \"group-data-[collapsible=icon]:-mt-8 group-data-[collapsible=icon]:opacity-0\",\n className\n )}\n {...props}\n />\n )\n})\nSidebarGroupLabel.displayName = \"SidebarGroupLabel\"\n\nconst SidebarGroupAction = React.forwardRef<\n HTMLButtonElement,\n React.ComponentProps<\"button\"> & { asChild?: boolean }\n>(({ className, asChild = false, ...props }, ref) => {\n const Comp = asChild ? Slot : \"button\"\n\n return (\n <Comp\n // @ts-ignore\n ref={ref}\n data-sidebar=\"group-action\"\n className={cn(\n \"absolute right-3 top-3.5 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground outline-none ring-sidebar-ring transition-transform hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0\",\n // Increases the hit area of the button on mobile.\n \"after:absolute after:-inset-2 after:md:hidden\",\n \"group-data-[collapsible=icon]:hidden\",\n className\n )}\n {...props}\n />\n )\n})\nSidebarGroupAction.displayName = \"SidebarGroupAction\"\n\nconst SidebarGroupContent = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\">\n>(({ className, ...props }, ref) => (\n <div\n ref={ref}\n data-sidebar=\"group-content\"\n className={cn(\"w-full text-sm\", className)}\n {...props}\n />\n))\nSidebarGroupContent.displayName = \"SidebarGroupContent\"\n\nconst SidebarMenu = React.forwardRef<\n HTMLUListElement,\n React.ComponentProps<\"ul\">\n>(({ className, ...props }, ref) => (\n <ul\n ref={ref}\n data-sidebar=\"menu\"\n className={cn(\"flex w-full min-w-0 flex-col gap-1\", className)}\n {...props}\n />\n))\nSidebarMenu.displayName = \"SidebarMenu\"\n\nconst SidebarMenuItem = React.forwardRef<\n HTMLLIElement,\n React.ComponentProps<\"li\">\n>(({ className, ...props }, ref) => (\n <li\n ref={ref}\n data-sidebar=\"menu-item\"\n className={cn(\"group/menu-item relative\", className)}\n {...props}\n />\n))\nSidebarMenuItem.displayName = \"SidebarMenuItem\"\n\nconst sidebarMenuButtonVariants = cva(\n \"peer/menu-button flex w-full items-center gap-2 overflow-hidden rounded-md p-2 text-left text-sm outline-none ring-sidebar-ring transition-[width,height,padding] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 group-has-[[data-sidebar=menu-action]]/menu-item:pr-8 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-[active=true]:bg-sidebar-accent data-[active=true]:font-medium data-[active=true]:text-sidebar-accent-foreground data-[state=open]:hover:bg-sidebar-accent data-[state=open]:hover:text-sidebar-accent-foreground group-data-[collapsible=icon]:!size-8 group-data-[collapsible=icon]:!p-[0.40rem] [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0\",\n {\n variants: {\n variant: {\n default: \"hover:bg-sidebar-accent hover:text-sidebar-accent-foreground\",\n outline:\n \"bg-background shadow-[0_0_0_1px_hsl(var(--sidebar-border))] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground hover:shadow-[0_0_0_1px_hsl(var(--sidebar-accent))]\",\n },\n size: {\n default: \"h-8 text-sm\",\n sm: \"h-7 text-xs\",\n lg: \"h-12 text-sm group-data-[collapsible=icon]:!p-0\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n size: \"default\",\n },\n }\n)\n\nconst SidebarMenuButton = React.forwardRef<\n HTMLButtonElement,\n React.ComponentProps<\"button\"> & {\n asChild?: boolean\n isActive?: boolean\n tooltip?: string | React.ComponentProps<typeof TooltipContent>\n } & VariantProps<typeof sidebarMenuButtonVariants>\n>(\n (\n {\n asChild = false,\n isActive = false,\n variant = \"default\",\n size = \"default\",\n tooltip,\n className,\n ...props\n },\n ref\n ) => {\n const Comp = asChild ? Slot : \"button\"\n const { isMobile, state } = useSidebar()\n\n const button = (\n <Comp\n // @ts-ignore\n ref={ref}\n data-sidebar=\"menu-button\"\n data-size={size}\n data-active={isActive}\n className={cn(sidebarMenuButtonVariants({ variant, size }), className)}\n {...props}\n />\n )\n\n if (!tooltip) {\n return button\n }\n\n if (typeof tooltip === \"string\") {\n tooltip = {\n children: tooltip,\n }\n }\n\n return (\n <Tooltip>\n <TooltipTrigger asChild>{button}</TooltipTrigger>\n <TooltipContent\n side=\"right\"\n align=\"center\"\n hidden={state !== \"collapsed\" || isMobile}\n {...tooltip}\n />\n </Tooltip>\n )\n }\n)\nSidebarMenuButton.displayName = \"SidebarMenuButton\"\n\nconst SidebarMenuAction = React.forwardRef<\n HTMLButtonElement,\n React.ComponentProps<\"button\"> & {\n asChild?: boolean\n showOnHover?: boolean\n }\n>(({ className, asChild = false, showOnHover = false, ...props }, ref) => {\n const Comp = asChild ? Slot : \"button\"\n\n return (\n <Comp\n // @ts-ignore\n ref={ref}\n data-sidebar=\"menu-action\"\n className={cn(\n \"absolute right-1 top-1.5 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground outline-none ring-sidebar-ring transition-transform hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 peer-hover/menu-button:text-sidebar-accent-foreground [&>svg]:size-4 [&>svg]:shrink-0\",\n // Increases the hit area of the button on mobile.\n \"after:absolute after:-inset-2 after:md:hidden\",\n \"peer-data-[size=sm]/menu-button:top-1\",\n \"peer-data-[size=default]/menu-button:top-1.5\",\n \"peer-data-[size=lg]/menu-button:top-2.5\",\n \"group-data-[collapsible=icon]:hidden\",\n showOnHover &&\n \"group-focus-within/menu-item:opacity-100 group-hover/menu-item:opacity-100 data-[state=open]:opacity-100 peer-data-[active=true]/menu-button:text-sidebar-accent-foreground md:opacity-0\",\n className\n )}\n {...props}\n />\n )\n})\nSidebarMenuAction.displayName = \"SidebarMenuAction\"\n\nconst SidebarMenuBadge = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\">\n>(({ className, ...props }, ref) => (\n <div\n ref={ref}\n data-sidebar=\"menu-badge\"\n className={cn(\n \"pointer-events-none absolute right-1 flex h-5 min-w-5 select-none items-center justify-center rounded-md px-1 text-xs font-medium tabular-nums text-sidebar-foreground\",\n \"peer-hover/menu-button:text-sidebar-accent-foreground peer-data-[active=true]/menu-button:text-sidebar-accent-foreground\",\n \"peer-data-[size=sm]/menu-button:top-1\",\n \"peer-data-[size=default]/menu-button:top-1.5\",\n \"peer-data-[size=lg]/menu-button:top-2.5\",\n \"group-data-[collapsible=icon]:hidden\",\n className\n )}\n {...props}\n />\n))\nSidebarMenuBadge.displayName = \"SidebarMenuBadge\"\n\nconst SidebarMenuSkeleton = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\"> & {\n showIcon?: boolean\n }\n>(({ className, showIcon = false, ...props }, ref) => {\n // Random width between 50 to 90%.\n const width = React.useMemo(() => {\n return `${Math.floor(Math.random() * 40) + 50}%`\n }, [])\n\n return (\n <div\n ref={ref}\n data-sidebar=\"menu-skeleton\"\n className={cn(\"flex h-8 items-center gap-2 rounded-md px-2\", className)}\n {...props}\n >\n {showIcon && (\n <Skeleton\n className=\"size-4 rounded-md\"\n data-sidebar=\"menu-skeleton-icon\"\n />\n )}\n <Skeleton\n className=\"h-4 max-w-[--skeleton-width] flex-1\"\n data-sidebar=\"menu-skeleton-text\"\n style={\n {\n \"--skeleton-width\": width,\n } as React.CSSProperties\n }\n />\n </div>\n )\n})\nSidebarMenuSkeleton.displayName = \"SidebarMenuSkeleton\"\n\nconst SidebarMenuSub = React.forwardRef<\n HTMLUListElement,\n React.ComponentProps<\"ul\">\n>(({ className, ...props }, ref) => (\n <ul\n ref={ref}\n data-sidebar=\"menu-sub\"\n className={cn(\n \"mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l border-sidebar-border px-2.5 py-0.5\",\n \"group-data-[collapsible=icon]:hidden\",\n className\n )}\n {...props}\n />\n))\nSidebarMenuSub.displayName = \"SidebarMenuSub\"\n\nconst SidebarMenuSubItem = React.forwardRef<\n HTMLLIElement,\n React.ComponentProps<\"li\">\n>(({ ...props }, ref) => <li ref={ref} {...props} />)\nSidebarMenuSubItem.displayName = \"SidebarMenuSubItem\"\n\nconst SidebarMenuSubButton = React.forwardRef<\n HTMLAnchorElement,\n React.ComponentProps<\"a\"> & {\n asChild?: boolean\n size?: \"sm\" | \"md\"\n isActive?: boolean\n }\n>(({ asChild = false, size = \"md\", isActive, className, ...props }, ref) => {\n const Comp = asChild ? Slot : \"a\"\n\n return (\n <Comp\n // @ts-ignore\n ref={ref}\n data-sidebar=\"menu-sub-button\"\n data-size={size}\n data-active={isActive}\n className={cn(\n \"flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 text-sidebar-foreground outline-none ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0 [&>svg]:text-sidebar-accent-foreground\",\n \"data-[active=true]:bg-sidebar-accent data-[active=true]:text-sidebar-accent-foreground\",\n size === \"sm\" && \"text-xs\",\n size === \"md\" && \"text-sm\",\n \"group-data-[collapsible=icon]:hidden\",\n className\n )}\n {...props}\n />\n )\n})\nSidebarMenuSubButton.displayName = \"SidebarMenuSubButton\"\n\nexport {\n Sidebar,\n SidebarContent,\n SidebarFooter,\n SidebarGroup,\n SidebarGroupAction,\n SidebarGroupContent,\n SidebarGroupLabel,\n SidebarHeader,\n SidebarInput,\n SidebarInset,\n SidebarMenu,\n SidebarMenuAction,\n SidebarMenuBadge,\n SidebarMenuButton,\n SidebarMenuItem,\n SidebarMenuSkeleton,\n SidebarMenuSub,\n SidebarMenuSubButton,\n SidebarMenuSubItem,\n SidebarProvider,\n SidebarRail,\n SidebarSeparator,\n SidebarTrigger,\n useSidebar,\n}\n","\"use client\";\n\nimport Link from \"next/link\";\nimport { useParams, usePathname } from \"next/navigation\";\nimport * as React from \"react\";\nimport { useContext, useEffect } from \"react\";\nimport { UserContext } from \"@/app/(application)/authenticated\";\nimport {\n Sidebar,\n SidebarContent,\n SidebarFooter,\n SidebarGroup,\n SidebarGroupContent,\n SidebarMenu,\n SidebarMenuButton,\n SidebarMenuItem,\n SidebarProvider,\n SidebarTrigger,\n useSidebar\n} from \"@/components/ui/sidebar\";\nimport { cn } from \"@/lib/utils\";\nimport { UserRole } from \"@/types/models/user-role\";\nimport { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuTrigger } from \"../ui/dropdown-menu\";\nimport { ChevronUp, Moon, Sun, Code, MessageCircle, Users, Key, LayoutDashboard, Database, ListTodo, Bot, Route, Variable, FileCheck, Sparkles, Settings, LogOut, FileText, FolderOpen, Brain } from \"lucide-react\";\nimport { useRouter } from \"next/navigation\";\nimport { useTheme } from \"next-themes\";\nimport { Avatar, AvatarFallback } from \"../ui/avatar\";\nimport Logo from \"../logo\";\n\ninterface User {\n email: string;\n super_admin: boolean;\n role: UserRole;\n}\n\nconst buildNavigation = (user: User, role: UserRole) => {\n const navigationItems: { label: string; path: string; icon: React.ReactNode }[] = [];\n\n if (user.super_admin) {\n navigationItems.push({\n label: \"Dashboard\",\n path: \"dashboard\",\n icon: <LayoutDashboard />,\n });\n }\n\n navigationItems.push({\n label: \"Contexts\",\n path: \"data\",\n icon: <Database />,\n });\n\n navigationItems.push({\n label: \"Jobs\",\n path: \"jobs\",\n icon: <ListTodo />,\n });\n\n if (user.super_admin || role.agents === \"write\") {\n navigationItems.push({\n label: \"Agents\",\n path: \"agents\",\n icon: <Bot />,\n });\n }\n\n navigationItems.push({\n label: \"Projects\",\n path: \"projects\",\n icon: <FolderOpen />,\n });\n\n navigationItems.push({\n label: \"Chat\",\n path: \"chat\",\n icon: <MessageCircle />,\n });\n\n if (user.super_admin || role.evals === \"read\" || role.evals === \"write\") {\n navigationItems.push({\n label: \"Evals\",\n path: \"evals\",\n icon: <Brain />,\n });\n }\n\n if (user.super_admin || role.workflows === \"write\") {\n navigationItems.push({\n label: \"Workflows\",\n path: \"workflows\",\n icon: <Route />,\n });\n }\n\n if (user.super_admin || role.users === \"write\") {\n navigationItems.push({\n label: \"Users\",\n path: \"users\",\n icon: <Users />,\n });\n }\n\n if (user.super_admin || role.api === \"write\") {\n navigationItems.push({\n label: \"Keys\",\n path: \"keys\",\n icon: <Key />,\n });\n }\n\n if (user.super_admin || role.variables === \"write\") {\n navigationItems.push({\n label: \"Variables\",\n path: \"variables\",\n icon: <Variable />,\n });\n }\n\n if (user.super_admin || role.api === \"write\") {\n navigationItems.push({\n label: \"API\",\n path: \"explorer\",\n icon: <Code />,\n });\n }\n\n if (user.super_admin) {\n navigationItems.push({\n label: \"Configurations\",\n path: \"configuration\",\n icon: <Settings />,\n });\n }\n\n return navigationItems;\n}\n\nfunction NavigationItems({ items }: { items: { label: string; path: string; icon: React.ReactNode }[] }) {\n const pathname = usePathname();\n\n return (\n <SidebarMenu className=\"space-y-1\">\n {items.map((navItem, index) => {\n const isActive = pathname.includes(navItem.path);\n return (\n <SidebarMenuItem key={index}>\n <SidebarMenuButton\n asChild\n isActive={isActive}\n tooltip={navItem.label}\n className={cn(\n \"h-10 transition-all duration-200\"\n )}\n >\n <Link href={`/${navItem.path}`} className=\"flex items-center gap-3\">\n <div className={cn(\n \"flex h-5 w-5 items-center justify-center transition-colors\",\n )}>\n {navItem.icon}\n </div>\n <span className={cn(\n \"font-medium transition-colors\",\n )}>\n {navItem.label}\n </span>\n </Link>\n </SidebarMenuButton>\n </SidebarMenuItem>\n );\n })}\n </SidebarMenu>\n );\n}\n\nexport function MainNavSidebar({ sidebarDefaultOpen }: { sidebarDefaultOpen: boolean }) {\n \n const { user } = useContext(UserContext);\n const navigationItems = buildNavigation(user, user.role);\n const router = useRouter();\n const { setTheme, theme } = useTheme();\n const params = useParams()\n const sidebar = useSidebar()\n\n useEffect(() => {\n if (params.agent && sidebarDefaultOpen === undefined) {\n sidebar.setOpen(false)\n }\n }, [params.agent])\n\n return (\n <Sidebar collapsible=\"icon\" className=\"border-r\">\n <div className=\"flex items-center gap-3 border-b bg-background/80 backdrop-blur-sm p-[12px] sticky top-0 z-10\">\n <SidebarTrigger />\n <div className=\"flex items-center gap-2\">\n <Logo alt=\"Logo\" width={100} height={40} />\n </div>\n </div>\n <SidebarContent className=\"px-2\">\n <SidebarGroup className=\"mt-4\">\n <SidebarGroupContent>\n <NavigationItems items={navigationItems} />\n </SidebarGroupContent>\n </SidebarGroup>\n </SidebarContent>\n <SidebarFooter className=\"border-t bg-muted/20 p-[5px]\">\n <SidebarMenu>\n <SidebarMenuItem>\n <DropdownMenu>\n <DropdownMenuTrigger asChild>\n <SidebarMenuButton className=\"h-12 hover:bg-accent/50\">\n <Avatar className=\"h-5 w-5\">\n <AvatarFallback className=\"bg-gradient-to-br from-primary/20 to-primary/60 text-white text-sm\">\n {user.email.charAt(0).toUpperCase()}\n </AvatarFallback>\n </Avatar>\n <div className=\"flex flex-col items-start group-data-[collapsible=icon]:hidden\">\n <span className=\"text-sm font-medium capitalize\">{user.email.split('@')[0]}</span>\n <div className=\"flex items-center gap-1\">\n <span className=\"text-xs text-muted-foreground\">{user.email.split('@')[1]}</span>\n </div>\n </div>\n <ChevronUp className=\"ml-auto h-4 w-4 group-data-[collapsible=icon]:hidden\" />\n </SidebarMenuButton>\n </DropdownMenuTrigger>\n <DropdownMenuContent\n side=\"top\"\n className=\"w-[--radix-popper-anchor-width] mb-2\"\n align=\"start\"\n >\n <DropdownMenuItem onClick={() => setTheme(theme === \"dark\" ? \"light\" : \"dark\")}>\n <div className=\"flex items-center gap-2 w-full\">\n {theme === \"dark\" ? <Sun className=\"h-4 w-4\" /> : <Moon className=\"h-4 w-4\" />}\n <span>Theme</span>\n </div>\n </DropdownMenuItem>\n <DropdownMenuItem onClick={() => router.push(\"/api/auth/signout\")}>\n <div className=\"flex items-center gap-2 w-full\">\n <LogOut className=\"h-4 w-4\" />\n <span>Logout</span>\n </div>\n </DropdownMenuItem>\n <DropdownMenuItem onClick={() => window.open(\"https://www.exulu.com/toc\", \"_blank\")}>\n <div className=\"flex items-center gap-2 w-full\">\n <FileText className=\"h-4 w-4\" />\n <span>Terms</span>\n </div>\n </DropdownMenuItem>\n </DropdownMenuContent>\n </DropdownMenu>\n </SidebarMenuItem>\n </SidebarMenu>\n </SidebarFooter>\n </Sidebar>\n );\n}\n\nexport function MainNavProvider({ children, sidebarDefaultOpen }: { children: React.ReactNode, sidebarDefaultOpen: boolean }) {\n console.log(\"sidebarDefaultOpen\", sidebarDefaultOpen)\n return (\n <SidebarProvider defaultOpen={sidebarDefaultOpen}>\n <div className=\"flex h-screen w-full bg-background overflow-hidden\">\n <MainNavSidebar sidebarDefaultOpen={sidebarDefaultOpen} />\n <main className=\"flex-1 overflow-auto\">\n {children}\n </main>\n </div>\n </SidebarProvider>\n );\n}\n","\"use client\";\n\nimport {\n ApolloClient,\n ApolloLink,\n ApolloProvider,\n HttpLink,\n InMemoryCache,\n} from \"@apollo/client\";\nimport { setContext } from \"@apollo/client/link/context\";\nimport { SessionProvider } from \"next-auth/react\";\nimport * as React from \"react\";\nimport { MainNavProvider } from \"@/components/custom/main-nav\";\nimport { getToken } from \"@/util/api\";\nimport { ConfigContext } from \"@/components/config-context\";\nimport { type User } from \"@/types/models/user\";\n\ninterface AuthenticatedProps {\n children: React.ReactNode;\n user: User & { role: { id: string } };\n sidebarDefaultOpen: boolean;\n}\n\nexport const UserContext = React.createContext<any>(null);\n\nconst User = ({ children, user, sidebarDefaultOpen }: AuthenticatedProps) => {\n\n return (\n <UserContext.Provider value={{ user }}>\n <MainNavProvider sidebarDefaultOpen={sidebarDefaultOpen}>\n {children}\n </MainNavProvider>\n\n </UserContext.Provider>\n );\n};\nconst Authenticated = ({ children, user, sidebarDefaultOpen }: AuthenticatedProps) => {\n\n const configContext = React.useContext(ConfigContext);\n\n const uri = configContext?.backend\n ? configContext?.backend + \"/graphql\"\n : \"http://localhost:9001/graphql\";\n\n const basic = setContext((operation, context) => ({\n headers: {\n Accept: \"charset=utf-8\",\n },\n }));\n\n const authLink = setContext(async (operation, context) => {\n const token = await getToken();\n return {\n headers: {\n Authorization: `Bearer ${token}`,\n },\n };\n });\n\n const link = ApolloLink.from([basic, authLink, new HttpLink({ uri: uri })]);\n\n const client = new ApolloClient({\n uri: uri,\n cache: new InMemoryCache({\n addTypename: false,\n }),\n link: link,\n defaultOptions: {\n watchQuery: {\n fetchPolicy: \"no-cache\",\n errorPolicy: \"ignore\",\n },\n query: {\n fetchPolicy: \"no-cache\",\n errorPolicy: \"all\",\n },\n },\n });\n\n return (\n <ApolloProvider client={client}>\n <SessionProvider>\n <User sidebarDefaultOpen={sidebarDefaultOpen} user={user}>\n {children}\n </User>\n </SessionProvider>\n </ApolloProvider>\n );\n};\n\nexport default Authenticated;\n","\"use client\"\nimport { BackendConfigType } from \"@/util/api\";\nimport { createContext } from \"react\";\n\nexport type ConfigContextType = {\n backend: string;\n google_client_id: string;\n auth_mode: string;\n} & BackendConfigType;\n\nexport const ConfigContext = createContext<ConfigContextType | null>(null);\n\nexport function ConfigContextProvider({ children, config }: {\n children: React.ReactNode;\n config: ConfigContextType;\n}) {\n\n console.log(\"[EXULU] Config: \", config);\n\n if (!config) {\n throw new Error(\"Config not found\");\n }\n\n return (\n <ConfigContext.Provider value={config}>\n {children}\n </ConfigContext.Provider>\n );\n}\n","\"use client\";\n\nimport { ConfigContext } from \"./config-context\";\nimport { useContext } from \"react\";\n\ninterface LogoProps {\n width?: number;\n height?: number;\n className?: string;\n alt?: string;\n}\n\nconst Logo = ({ width = 64, height = 32, className = \"\", alt = \"Logo\" }: LogoProps) => {\n const configContext = useContext(ConfigContext);\n return (\n <>\n <img\n src={configContext?.backend + \"/logo_dark.png\"}\n alt={alt}\n width={width}\n height={height}\n className={className + \"hidden dark:block invert\"}\n />\n <img\n src={configContext?.backend + \"/logo_light.png\"}\n alt={alt}\n width={width}\n height={height}\n className={className + \"block dark:hidden\"}\n />\n </>\n )\n}\n\nexport default Logo;","\"use client\";\n\nimport * as AvatarPrimitive from \"@radix-ui/react-avatar\";\nimport * as React from \"react\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst Avatar = React.forwardRef<\n React.ElementRef<typeof AvatarPrimitive.Root>,\n React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Root>\n>(({ className, ...props }, ref) => (\n <AvatarPrimitive.Root\n ref={ref}\n className={cn(\n \"relative flex h-10 w-10 shrink-0 overflow-hidden rounded-full\",\n className,\n )}\n {...props}\n />\n));\nAvatar.displayName = AvatarPrimitive.Root.displayName;\n\nconst AvatarImage = React.forwardRef<\n React.ElementRef<typeof AvatarPrimitive.Image>,\n React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Image>\n>(({ className, ...props }, ref) => (\n <AvatarPrimitive.Image\n ref={ref}\n className={cn(\"aspect-square h-full w-full\", className)}\n {...props}\n />\n));\nAvatarImage.displayName = AvatarPrimitive.Image.displayName;\n\nconst AvatarFallback = React.forwardRef<\n React.ElementRef<typeof AvatarPrimitive.Fallback>,\n React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Fallback>\n>(({ className, ...props }, ref) => (\n <AvatarPrimitive.Fallback\n ref={ref}\n className={cn(\n \"flex h-full w-full items-center justify-center rounded-full bg-muted\",\n className,\n )}\n {...props}\n />\n));\nAvatarFallback.displayName = AvatarPrimitive.Fallback.displayName;\n\nexport { Avatar, AvatarImage, AvatarFallback };\n","\"use client\";\n\nimport * as DropdownMenuPrimitive from \"@radix-ui/react-dropdown-menu\";\nimport { Check, ChevronRight, Circle } from \"lucide-react\";\nimport * as React from \"react\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst DropdownMenu = DropdownMenuPrimitive.Root;\n\nconst DropdownMenuTrigger = DropdownMenuPrimitive.Trigger;\n\nconst DropdownMenuGroup = DropdownMenuPrimitive.Group;\n\nconst DropdownMenuPortal = DropdownMenuPrimitive.Portal;\n\nconst DropdownMenuSub = DropdownMenuPrimitive.Sub;\n\nconst DropdownMenuRadioGroup = DropdownMenuPrimitive.RadioGroup;\n\nconst DropdownMenuSubTrigger = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.SubTrigger>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.SubTrigger> & {\n inset?: boolean;\n }\n>(({ className, inset, children, ...props }, ref) => (\n <DropdownMenuPrimitive.SubTrigger\n ref={ref}\n className={cn(\n \"flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent data-[state=open]:bg-accent\",\n inset && \"pl-8\",\n className,\n )}\n {...props}\n >\n {children}\n <ChevronRight className=\"ml-auto size-4\" />\n </DropdownMenuPrimitive.SubTrigger>\n));\nDropdownMenuSubTrigger.displayName =\n DropdownMenuPrimitive.SubTrigger.displayName;\n\nconst DropdownMenuSubContent = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.SubContent>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.SubContent>\n>(({ className, ...props }, ref) => (\n <DropdownMenuPrimitive.SubContent\n ref={ref}\n className={cn(\n \"z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2\",\n className,\n )}\n {...props}\n />\n));\nDropdownMenuSubContent.displayName =\n DropdownMenuPrimitive.SubContent.displayName;\n\nconst DropdownMenuContent = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Content>\n>(({ className, sideOffset = 4, ...props }, ref) => (\n <DropdownMenuPrimitive.Portal>\n <DropdownMenuPrimitive.Content\n ref={ref}\n sideOffset={sideOffset}\n className={cn(\n \"z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-md data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2\",\n className,\n )}\n {...props}\n />\n </DropdownMenuPrimitive.Portal>\n));\nDropdownMenuContent.displayName = DropdownMenuPrimitive.Content.displayName;\n\nconst DropdownMenuItem = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.Item>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Item> & {\n inset?: boolean;\n }\n>(({ className, inset, ...props }, ref) => (\n <DropdownMenuPrimitive.Item\n ref={ref}\n className={cn(\n \"relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n inset && \"pl-8\",\n className,\n )}\n {...props}\n />\n));\nDropdownMenuItem.displayName = DropdownMenuPrimitive.Item.displayName;\n\nconst DropdownMenuCheckboxItem = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.CheckboxItem>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.CheckboxItem>\n>(({ className, children, checked, ...props }, ref) => (\n <DropdownMenuPrimitive.CheckboxItem\n ref={ref}\n className={cn(\n \"relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n className,\n )}\n checked={checked}\n {...props}\n >\n <span className=\"absolute left-2 flex size-3.5 items-center justify-center\">\n <DropdownMenuPrimitive.ItemIndicator>\n <Check className=\"size-4\" />\n </DropdownMenuPrimitive.ItemIndicator>\n </span>\n {children}\n </DropdownMenuPrimitive.CheckboxItem>\n));\nDropdownMenuCheckboxItem.displayName =\n DropdownMenuPrimitive.CheckboxItem.displayName;\n\nconst DropdownMenuRadioItem = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.RadioItem>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.RadioItem>\n>(({ className, children, ...props }, ref) => (\n <DropdownMenuPrimitive.RadioItem\n ref={ref}\n className={cn(\n \"relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n className,\n )}\n {...props}\n >\n <span className=\"absolute left-2 flex size-3.5 items-center justify-center\">\n <DropdownMenuPrimitive.ItemIndicator>\n <Circle className=\"size-2 fill-current\" />\n </DropdownMenuPrimitive.ItemIndicator>\n </span>\n {children}\n </DropdownMenuPrimitive.RadioItem>\n));\nDropdownMenuRadioItem.displayName = DropdownMenuPrimitive.RadioItem.displayName;\n\nconst DropdownMenuLabel = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.Label>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Label> & {\n inset?: boolean;\n }\n>(({ className, inset, ...props }, ref) => (\n <DropdownMenuPrimitive.Label\n ref={ref}\n className={cn(\n \"px-2 py-1.5 text-sm font-semibold\",\n inset && \"pl-8\",\n className,\n )}\n {...props}\n />\n));\nDropdownMenuLabel.displayName = DropdownMenuPrimitive.Label.displayName;\n\nconst DropdownMenuSeparator = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.Separator>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Separator>\n>(({ className, ...props }, ref) => (\n <DropdownMenuPrimitive.Separator\n ref={ref}\n className={cn(\"-mx-1 my-1 h-px bg-muted\", className)}\n {...props}\n />\n));\nDropdownMenuSeparator.displayName = DropdownMenuPrimitive.Separator.displayName;\n\nconst DropdownMenuShortcut = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLSpanElement>) => {\n return (\n <span\n className={cn(\"ml-auto text-xs tracking-widest opacity-60\", className)}\n {...props}\n />\n );\n};\nDropdownMenuShortcut.displayName = \"DropdownMenuShortcut\";\n\nexport {\n DropdownMenu,\n DropdownMenuTrigger,\n DropdownMenuContent,\n DropdownMenuItem,\n DropdownMenuCheckboxItem,\n DropdownMenuRadioItem,\n DropdownMenuLabel,\n DropdownMenuSeparator,\n DropdownMenuShortcut,\n DropdownMenuGroup,\n DropdownMenuPortal,\n DropdownMenuSub,\n DropdownMenuSubContent,\n DropdownMenuSubTrigger,\n DropdownMenuRadioGroup,\n};\n","import * as React from \"react\";\n\nimport { cn } from \"@/lib/utils\";\n\nexport interface InputProps\n extends React.InputHTMLAttributes<HTMLInputElement> {}\n\nconst Input = React.forwardRef<HTMLInputElement, InputProps>(\n ({ className, type, ...props }, ref) => {\n return (\n <input\n type={type}\n className={cn(\n \"flex h-10 w-full rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50\",\n className,\n )}\n ref={ref}\n {...props}\n />\n );\n },\n);\nInput.displayName = \"Input\";\n\nexport { Input };\n","\"use client\";\n\nimport * as SeparatorPrimitive from \"@radix-ui/react-separator\";\nimport * as React from \"react\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst Separator = React.forwardRef<\n React.ElementRef<typeof SeparatorPrimitive.Root>,\n React.ComponentPropsWithoutRef<typeof SeparatorPrimitive.Root>\n>(\n (\n { className, orientation = \"horizontal\", decorative = true, ...props },\n ref,\n ) => (\n <SeparatorPrimitive.Root\n ref={ref}\n decorative={decorative}\n orientation={orientation}\n className={cn(\n \"shrink-0 bg-border\",\n orientation === \"horizontal\" ? \"h-[1px] w-full\" : \"h-full w-[1px]\",\n className,\n )}\n {...props}\n />\n ),\n);\nSeparator.displayName = SeparatorPrimitive.Root.displayName;\n\nexport { Separator };\n","\"use client\";\n\nimport * as SheetPrimitive from \"@radix-ui/react-dialog\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport { X } from \"lucide-react\";\nimport * as React from \"react\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst Sheet = SheetPrimitive.Root;\n\nconst SheetTrigger = SheetPrimitive.Trigger;\n\nconst SheetClose = SheetPrimitive.Close;\n\nconst SheetPortal = SheetPrimitive.Portal;\n\nconst SheetOverlay = React.forwardRef<\n React.ElementRef<typeof SheetPrimitive.Overlay>,\n React.ComponentPropsWithoutRef<typeof SheetPrimitive.Overlay>\n>(({ className, ...props }, ref) => (\n <SheetPrimitive.Overlay\n className={cn(\n \"fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0\",\n className,\n )}\n {...props}\n ref={ref}\n />\n));\nSheetOverlay.displayName = SheetPrimitive.Overlay.displayName;\n\nconst sheetVariants = cva(\n \"fixed z-50 gap-4 bg-background p-6 shadow-lg transition ease-in-out data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:duration-300 data-[state=open]:duration-500\",\n {\n variants: {\n side: {\n top: \"inset-x-0 top-0 border-b data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top\",\n bottom:\n \"inset-x-0 bottom-0 border-t data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom\",\n left: \"inset-y-0 left-0 h-full w-3/4 border-r data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left sm:max-w-sm\",\n right:\n \"inset-y-0 right-0 h-full w-3/4 border-l data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right sm:max-w-sm\",\n },\n },\n defaultVariants: {\n side: \"right\",\n },\n },\n);\n\ninterface SheetContentProps\n extends React.ComponentPropsWithoutRef<typeof SheetPrimitive.Content>,\n VariantProps<typeof sheetVariants> {}\n\nconst SheetContent = React.forwardRef<\n React.ElementRef<typeof SheetPrimitive.Content>,\n SheetContentProps\n>(({ side = \"right\", className, children, ...props }, ref) => (\n <SheetPortal>\n <SheetOverlay />\n <SheetPrimitive.Content\n ref={ref}\n className={cn(sheetVariants({ side }), className)}\n {...props}\n >\n {children}\n <SheetPrimitive.Close className=\"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-secondary\">\n <X className=\"size-4\" />\n <span className=\"sr-only\">Close</span>\n </SheetPrimitive.Close>\n </SheetPrimitive.Content>\n </SheetPortal>\n));\nSheetContent.displayName = SheetPrimitive.Content.displayName;\n\nconst SheetHeader = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n <div\n className={cn(\n \"flex flex-col space-y-2 text-center sm:text-left\",\n className,\n )}\n {...props}\n />\n);\nSheetHeader.displayName = \"SheetHeader\";\n\nconst SheetFooter = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n <div\n className={cn(\n \"flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2\",\n className,\n )}\n {...props}\n />\n);\nSheetFooter.displayName = \"SheetFooter\";\n\nconst SheetTitle = React.forwardRef<\n React.ElementRef<typeof SheetPrimitive.Title>,\n React.ComponentPropsWithoutRef<typeof SheetPrimitive.Title>\n>(({ className, ...props }, ref) => (\n <SheetPrimitive.Title\n ref={ref}\n className={cn(\"text-lg font-semibold text-foreground\", className)}\n {...props}\n />\n));\nSheetTitle.displayName = SheetPrimitive.Title.displayName;\n\nconst SheetDescription = React.forwardRef<\n React.ElementRef<typeof SheetPrimitive.Description>,\n React.ComponentPropsWithoutRef<typeof SheetPrimitive.Description>\n>(({ className, ...props }, ref) => (\n <SheetPrimitive.Description\n ref={ref}\n className={cn(\"text-sm text-muted-foreground\", className)}\n {...props}\n />\n));\nSheetDescription.displayName = SheetPrimitive.Description.displayName;\n\nexport {\n Sheet,\n SheetPortal,\n SheetOverlay,\n SheetTrigger,\n SheetClose,\n SheetContent,\n SheetHeader,\n SheetFooter,\n SheetTitle,\n SheetDescription,\n};\n","import { cn } from \"@/lib/utils\";\n\nfunction Skeleton({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) {\n return (\n <div\n className={cn(\"animate-pulse rounded-md bg-muted\", className)}\n {...props}\n />\n );\n}\n\nexport { Skeleton };\n","\"use client\";\n\nimport * as TooltipPrimitive from \"@radix-ui/react-tooltip\";\nimport * as React from \"react\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst TooltipProvider = TooltipPrimitive.Provider;\n\nconst Tooltip = TooltipPrimitive.Root;\n\nconst TooltipTrigger = TooltipPrimitive.Trigger;\n\nconst TooltipContent = React.forwardRef<\n React.ElementRef<typeof TooltipPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Content>\n>(({ className, sideOffset = 4, ...props }, ref) => (\n <TooltipPrimitive.Content\n ref={ref}\n sideOffset={sideOffset}\n className={cn(\n \"z-50 overflow-hidden rounded-md border bg-popover px-3 py-1.5 text-sm text-popover-foreground shadow-md animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2\",\n className,\n )}\n {...props}\n />\n));\nTooltipContent.displayName = TooltipPrimitive.Content.displayName;\n\nexport { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider };\n","import * as React from \"react\"\n\nconst MOBILE_BREAKPOINT = 768\n\nexport function useIsMobile() {\n const [isMobile, setIsMobile] = React.useState<boolean | undefined>(undefined)\n\n React.useEffect(() => {\n const mql = window.matchMedia(`(max-width: ${MOBILE_BREAKPOINT - 1}px)`)\n const onChange = () => {\n setIsMobile(window.innerWidth < MOBILE_BREAKPOINT)\n }\n mql.addEventListener(\"change\", onChange)\n setIsMobile(window.innerWidth < MOBILE_BREAKPOINT)\n return () => mql.removeEventListener(\"change\", onChange)\n }, [])\n\n return !!isMobile\n}\n","import { getSession } from \"next-auth/react\";\n\nexport type ImageStyle = \"origami\" | \"anime\" | \"japanese_anime\" | \"vaporwave\" | \"lego\" | \"paper_cut\" | \"felt_puppet\" | \"3d\" | \"app_icon\" | \"pixel_art\" | \"isometric\";\n\nconst getUris = async () => {\n // Server-side: use environment variable directly\n if (typeof window === 'undefined') {\n const backend = process.env.BACKEND;\n if (!backend) {\n throw new Error(\"No backend set.\")\n }\n return {\n files: backend,\n base: backend\n }\n }\n\n // Client-side: fetch from API\n const context = await fetch(\"/api/config\").then(res => res.json());\n if (!context.backend) {\n throw new Error(\"No backend set.\")\n }\n return {\n files: context.backend,\n base: context.backend\n }\n}\n\nexport const getToken = async () => {\n const session = await getSession()\n // @ts-ignore\n return session?.user?.jwt;\n}\n\nexport type BackendConfigType = {\n fileUploads?: {\n s3endpoint: string;\n }\n workers?: {\n redisHost: string;\n enabled: boolean;\n }\n}\n\nexport type ThemeConfig = {\n light?: Record<string, string>;\n dark?: Record<string, string>;\n}\n\nexport const config = {\n backend: async (): Promise<Response> => {\n const uris = await getUris();\n const url = `${uris.base}/config`\n return fetch(url, {\n method: \"GET\",\n headers: {\n \"Content-Type\": \"application/json\",\n },\n })\n },\n theme: async (): Promise<ThemeConfig> => {\n try {\n const token = await getToken();\n const uris = await getUris();\n const res = await fetch(`${uris.base}/theme`, {\n method: \"GET\",\n headers: {\n \"Content-Type\": \"application/json\",\n \"Authorization\": `Bearer ${token}`,\n },\n })\n const json = await res.json();\n return json.theme;\n } catch (error) {\n console.error(\"Error fetching theme config:\", error);\n return { light: {}, dark: {} };\n }\n }\n}\n\nexport const agents = {\n image: {\n generate: async (parameters: {\n name: string,\n description: string,\n style?: ImageStyle\n }): Promise<any> => {\n\n const uris = await getUris();\n const url = `${uris.base}/generate/agent/image`;\n const token = await getToken()\n\n if (!token) {\n throw new Error(\"No valid session token available.\")\n }\n\n return fetch(url, {\n method: \"POST\",\n body: JSON.stringify(parameters),\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${token}`,\n },\n });\n }\n }\n}\n\nexport type S3FileListOutput = {\n \"$metadata\": {\n \"httpStatusCode\": number,\n \"attempts\": number,\n \"totalRetryDelay\": number\n },\n \"Contents\": {\n \"Key\": string,\n \"LastModified\": string,\n \"ETag\": string,\n \"Size\": number\n }[]\n \"IsTruncated\": boolean,\n \"NextContinuationToken\": string,\n \"KeyCount\": number,\n \"MaxKeys\": number,\n \"Name\": string,\n \"Prefix\": string\n}\n\nexport type S3ObjectOutput = {\n \"$metadata\": {\n \"httpStatusCode\": number,\n \"attempts\": number,\n \"totalRetryDelay\": number\n },\n \"AcceptRanges\": \"bytes\",\n \"LastModified\": string,\n \"ContentLength\": number,\n \"ChecksumCRC32C\": string,\n \"ETag\": string,\n \"CacheControl\": string,\n \"ContentType\": string,\n \"Expires\": string,\n \"ExpiresString\": string\n}\n\nexport const files = {\n object: async (key: string): Promise<S3ObjectOutput> => {\n const uris = await getUris();\n let url = `${uris.files}/s3/object`;\n const token = await getToken()\n const response = await fetch(url, {\n method: \"POST\",\n body: JSON.stringify({ key }),\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${token}`,\n },\n });\n return response.json();\n },\n list: async ({ search, continuationToken }: { search?: string, continuationToken?: string }): Promise<S3FileListOutput> => {\n const uris = await getUris();\n let url = `${uris.files}/s3/list`;\n const token = await getToken()\n\n if (!token) {\n throw new Error(\"No valid session token available.\")\n }\n\n if (search) {\n url += `?search=${search}`;\n }\n\n if (continuationToken) {\n url += `?continuationToken=${continuationToken}`;\n }\n\n const response = await fetch(url, {\n method: \"GET\",\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${token}`,\n },\n });\n return response.json();\n },\n download: async (key: string) => {\n\n const uris = await getUris();\n let url = `${uris.files}/s3/download?key=${key}`;\n\n const token = await getToken()\n\n if (!token) {\n throw new Error(\"No valid session token available.\")\n }\n\n return fetch(url, {\n method: \"GET\",\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${token}`,\n },\n });\n },\n delete: async (key: string) => {\n\n const uris = await getUris();\n let url = `${uris.files}/s3/delete?key=${key}`;\n const token = await getToken()\n\n if (!token) {\n throw new Error(\"No valid session token available.\")\n }\n\n return fetch(url, {\n method: \"DELETE\",\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${token}`,\n },\n });\n }\n}\n"],"names":["SidebarContext","React","useSidebar","context","SidebarProvider","param","ref","defaultOpen","open","openProp","onOpenChange","setOpenProp","className","style","children","props","isMobile","useIsMobile","openMobile","setOpenMobile","_open","_setOpen","setOpen","openState","value","document","cookie","SIDEBAR_COOKIE_MAX_AGE","concat","toggleSidebar","handleKeyDown","event","key","metaKey","ctrlKey","preventDefault","window","addEventListener","removeEventListener","state","contextValue","jsx_runtime","jsx","Provider","TooltipProvider","delayDuration","div","cn","displayName","Sidebar","side","variant","collapsible","Sheet","jsxs","SheetContent","data-sidebar","data-mobile","SheetHeader","SheetTitle","SheetDescription","data-state","data-collapsible","data-variant","data-side","SidebarTrigger","onClick","Button","size","PanelLeft","span","SidebarRail","button","aria-label","tabIndex","title","SidebarInset","main","SidebarInput","Input","SidebarHeader","SidebarFooter","SidebarSeparator","Separator","SidebarContent","SidebarGroup","SidebarGroupLabel","asChild","Comp","Slot","SidebarGroupAction","SidebarGroupContent","SidebarMenu","ul","SidebarMenuItem","li","sidebarMenuButtonVariants","cva","variants","default","outline","sm","lg","defaultVariants","SidebarMenuButton","isActive","tooltip","data-size","data-active","Tooltip","TooltipTrigger","TooltipContent","align","hidden","SidebarMenuAction","showOnHover","SidebarMenuBadge","SidebarMenuSkeleton","showIcon","width","Math","floor","random","Skeleton","SidebarMenuSub","SidebarMenuSubItem","SidebarMenuSubButton","buildNavigation","user","role","navigationItems","super_admin","push","label","path","icon","LayoutDashboard","Database","ListTodo","agents","Bot","FolderOpen","MessageCircle","evals","Brain","workflows","Route","users","Users","api","Key","variables","Variable","Code","Settings","NavigationItems","items","pathname","usePathname","map","navItem","index","includes","Link","href","MainNavSidebar","sidebarDefaultOpen","useContext","UserContext","router","useRouter","setTheme","theme","useTheme","params","useParams","sidebar","useEffect","agent","undefined","Logo","alt","height","DropdownMenu","DropdownMenuTrigger","Avatar","AvatarFallback","email","charAt","toUpperCase","split","ChevronUp","DropdownMenuContent","DropdownMenuItem","Sun","Moon","LogOut","FileText","MainNavProvider","console","log","User","authenticated","configContext","ConfigContext","uri","backend","basic","setContext","operation","headers","Accept","authLink","token","getToken","Authorization","link","ApolloLink","from","HttpLink","client","ApolloClient","cache","InMemoryCache","addTypename","defaultOptions","watchQuery","fetchPolicy","errorPolicy","query","ApolloProvider","SessionProvider","createContext","ConfigContextProvider","config","react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__","__webpack_exports__","Fragment","img","src","AvatarPrimitive","AvatarImage","DropdownMenuPrimitive","DropdownMenuSubTrigger","inset","ChevronRight","DropdownMenuSubContent","sideOffset","DropdownMenuCheckboxItem","checked","Check","DropdownMenuRadioItem","Circle","DropdownMenuLabel","DropdownMenuSeparator","type","input","orientation","decorative","SeparatorPrimitive","SheetPrimitive","SheetTrigger","SheetPortal","SheetOverlay","sheetVariants","top","bottom","left","right","X","TooltipPrimitive","setIsMobile","mql","matchMedia","MOBILE_BREAKPOINT","onChange","innerWidth","getUris","fetch","then","res","json","files","base","session","getSession","jwt","image","generate","parameters","uris","url","method","body","JSON","stringify","object","response","list","search","continuationToken","download","delete"],"sourceRoot":""}
@@ -0,0 +1,2 @@
1
+ (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[9813],{79959:function(e,a,r){Promise.resolve().then(r.bind(r,72147))},72147:function(e,a,r){"use strict";r.r(a),r.d(a,{default:function(){return P},dynamic:function(){return S}});var t=r(57437),l=r(7211),s=r(12199),n=r(99376),i=r(2265),d=r(13832),o=r(35974),c=r(62869),m=r(66070),u=r(33245);function f(e){var a,r;let{agent:l,onSelect:s,showDetails:n}=e,i=l.description?l.description.length>200?l.description.substring(0,200)+"...":l.description:"No description available";return(0,t.jsx)(t.Fragment,{children:(0,t.jsx)(m.Zb,{className:"cursor-pointer hover:shadow-md transition-shadow duration-200 h-full flex flex-col pb-3",onClick:()=>{s&&s(l)},children:(0,t.jsx)(m.Ol,{className:"pb-3",children:(0,t.jsxs)("div",{className:"flex items-start gap-3",children:[(0,t.jsx)("div",{className:"w-20 h-20 bg-gradient-to-br from-primary/20 to-primary/5 rounded-full flex items-center justify-center flex-shrink-0 overflow-hidden",children:l.image?(0,t.jsx)("img",{src:l.image,alt:"".concat((null===(a=l.name)||void 0===a?void 0:a.charAt(0).toUpperCase())||"A"),className:"w-full h-full object-cover rounded-full"}):(0,t.jsx)("div",{className:"text-lg font-bold text-primary",children:(null===(r=l.name)||void 0===r?void 0:r.charAt(0).toUpperCase())||"A"})}),(0,t.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,t.jsxs)("div",{className:"flex items-center justify-between mb-2",children:[(0,t.jsx)(m.ll,{className:"text-lg line-clamp-1 flex-1 min-w-0",children:l.name}),(0,t.jsx)("div",{className:"flex items-center gap-1 flex-shrink-0",children:(0,t.jsx)(c.z,{variant:"ghost",size:"sm",onClick:e=>{e.stopPropagation(),n(l)},className:"p-1 h-auto",children:(0,t.jsx)(u.Z,{className:"h-4 w-4"})})})]}),(0,t.jsx)(m.SZ,{className:"text-sm line-clamp-2",children:i}),(0,t.jsx)(o.C,{variant:l.active?"default":"secondary",className:"text-xs mt-2",children:l.active?"Active":"Inactive"})]})]})})})})}var x=r(26110),g=r(95186),h=r(26815),p=r(10492),v=r(53647),j=r(27689);function N(e){var a;let{onSelect:r}=e,[s,n]=i.useState(),[d,o]=i.useState(""),c=i.useRef(null),{loading:m,error:u,data:f,refetch:x,previousData:h}=(0,l.aM)(j.E3,{fetchPolicy:"no-cache",nextFetchPolicy:"network-only"}),p=[],N=(p=(null==f?void 0:null===(a=f.providers)||void 0===a?void 0:a.items)||[]).filter(e=>"".concat(e.provider," - ").concat(e.name).toLowerCase().includes(d.toLowerCase()));return(0,t.jsxs)(v.Ph,{onOpenChange:e=>{e&&setTimeout(()=>{var e;return null===(e=c.current)||void 0===e?void 0:e.focus()},0)},onValueChange:e=>{n(null==p?void 0:p.find(a=>a.id===e)),r(e)},children:[(0,t.jsx)(v.i4,{children:(0,t.jsx)(v.ki,{placeholder:(null==s?void 0:s.name)||"Select an agent backend"})}),(0,t.jsxs)(v.Bw,{children:[(0,t.jsx)("div",{className:"p-2",children:(0,t.jsx)(g.I,{ref:c,placeholder:"Search providers...",value:d,onChange:e=>o(e.target.value),onKeyDown:e=>e.stopPropagation(),className:"h-8"})}),m?(0,t.jsx)(v.Ql,{value:"loading",children:"Loading..."},"loading"):null==N?void 0:N.map(e=>(0,t.jsx)(v.Ql,{value:e.id,children:e.provider+" - "+e.name},e.id))]})]})}var b=r(65613),y=r(19060),w=r(6374),C=r(14438);function A(e){let{createAgent:a,createAgentResult:r,company:l,children:s}=e,[n,d]=(0,i.useState)(""),[o,m]=(0,i.useState)(""),[u,f]=(0,i.useState)(""),[j,A]=(0,i.useState)(!0),[_,k]=(0,i.useState)([]),[R,S]=(0,i.useState)(null),[P,Z]=(0,i.useState)(!1),[z,I]=(0,i.useState)(0),[F,E]=(0,i.useState)("app_icon");return(0,t.jsxs)(x.Vq,{children:[(0,t.jsx)(x.hg,{asChild:!0,children:s||(0,t.jsx)(c.z,{variant:"secondary",children:"Create new agent"})}),(0,t.jsxs)(x.cZ,{className:"sm:max-w-[475px]",children:[(0,t.jsxs)(x.fK,{children:[(0,t.jsx)(x.$N,{children:"Create a new agent"}),(0,t.jsx)(x.Be,{children:"Give your new agent a name and a description (optional)."})]}),!j&&(0,t.jsx)("div",{className:"h-32 bg-gradient-to-br from-primary/20 to-primary/5 rounded-lg flex items-center justify-center",children:(0,t.jsx)("div",{className:"text-4xl font-bold text-primary",children:(null==n?void 0:n.charAt(0).toUpperCase())||"A"})}),P&&(0,t.jsx)("div",{className:"grid gap-4 py-4",children:(0,t.jsx)("div",{className:"w-full mb-4",children:(0,t.jsxs)("div",{className:"space-y-4",children:[(0,t.jsxs)("div",{className:"text-center",children:[(0,t.jsx)("h3",{className:"text-lg font-semibold mb-2",children:"Generating your agent images..."}),(0,t.jsxs)("p",{className:"text-sm text-muted-foreground mb-4",children:["Creating ",z,"/4 image options"]}),(0,t.jsx)("div",{className:"w-32 h-2 bg-muted rounded-full overflow-hidden mx-auto",children:(0,t.jsx)("div",{className:"h-full bg-primary transition-all duration-300 ease-out",style:{width:"".concat(z/4*100,"%")}})})]}),(0,t.jsx)("div",{className:"grid grid-cols-2 gap-3",children:Array.from({length:4},(e,a)=>(0,t.jsx)("div",{className:"relative h-32 rounded-lg overflow-hidden border-2 border-dashed border-muted-foreground/30",children:(0,t.jsxs)("div",{className:"w-full h-full bg-gradient-to-br from-muted/50 to-muted/20 flex flex-col items-center justify-center",children:[a<z?(0,t.jsx)("div",{className:"text-green-500",children:(0,t.jsx)("svg",{className:"w-8 h-8",fill:"currentColor",viewBox:"0 0 20 20",children:(0,t.jsx)("path",{fillRule:"evenodd",d:"M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z",clipRule:"evenodd"})})}):(0,t.jsx)(p.g,{className:"w-6 h-6 text-muted-foreground"}),(0,t.jsx)("span",{className:"text-xs text-muted-foreground mt-2",children:a<z?"Complete":"Generating..."})]})},a))})]})})}),_.length>0&&(0,t.jsx)("div",{className:"grid",children:(0,t.jsx)("div",{className:"space-y-4",children:(0,t.jsx)("div",{className:"grid grid-cols-2 gap-3",children:_.map((e,a)=>(0,t.jsxs)("button",{onClick:()=>S(e),className:"relative h-32 rounded-lg overflow-hidden border-2 transition-all hover:scale-105 ".concat(R===e?"border-primary ring-2 ring-primary/20":"border-border hover:border-primary/50"),children:[(0,t.jsx)("img",{src:e,alt:"Generated option ".concat(a+1),className:"w-full h-full object-cover"}),R===e&&(0,t.jsx)("div",{className:"absolute inset-0 bg-primary/10 flex items-center justify-center",children:(0,t.jsx)("div",{className:"w-6 h-6 rounded-full bg-primary flex items-center justify-center",children:(0,t.jsx)("svg",{className:"w-4 h-4 text-primary-foreground",fill:"currentColor",viewBox:"0 0 20 20",children:(0,t.jsx)("path",{fillRule:"evenodd",d:"M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z",clipRule:"evenodd"})})})})]},a))})})}),!P&&_.length<=0&&(0,t.jsx)("div",{className:"grid gap-4 py-4",children:(0,t.jsxs)("div",{className:"w-full mb-4",children:[(0,t.jsxs)("div",{className:"grid gap-2",children:[(0,t.jsx)(h._,{htmlFor:"name",children:"Name"}),(0,t.jsx)(g.I,{onChange:e=>{d(e.target.value)},id:"name",autoFocus:!0})]}),(0,t.jsxs)("div",{className:"grid gap-2 mt-3",children:[(0,t.jsx)(h._,{htmlFor:"description",children:"Description"}),(0,t.jsx)(g.I,{onChange:e=>{m(e.target.value)},id:"description"})]}),(0,t.jsxs)("div",{className:"grid gap-2 mt-3",children:[(0,t.jsx)(h._,{htmlFor:"backend",children:"Backend"}),(0,t.jsx)(N,{onSelect:e=>{f(e)}})]}),(0,t.jsxs)("div",{className:"flex items-center space-x-2 mt-2",children:[(0,t.jsx)(y.X,{id:"generateImage",checked:j,onCheckedChange:e=>A(!0===e)}),(0,t.jsx)(h._,{htmlFor:"generateImage",className:"text-sm font-normal",children:"Generate AI image for this agent"})]}),j&&(0,t.jsxs)("div",{className:"grid gap-2 mt-3",children:[(0,t.jsx)(h._,{htmlFor:"imageStyle",children:"Image Style"}),(0,t.jsxs)(v.Ph,{onValueChange:e=>E(e),defaultValue:F,children:[(0,t.jsx)(v.i4,{children:(0,t.jsx)(v.ki,{placeholder:"Select image style"})}),(0,t.jsx)(v.Bw,{children:[{value:"origami",label:"Origami"},{value:"anime",label:"Anime"},{value:"japanese_anime",label:"Japanese Anime"},{value:"vaporwave",label:"Vaporwave"},{value:"lego",label:"Lego"},{value:"paper_cut",label:"Paper Cut"},{value:"felt_puppet",label:"Felt Puppet"},{value:"3d",label:"3D"},{value:"app_icon",label:"App Icon"},{value:"pixel_art",label:"Pixel Art"},{value:"isometric",label:"Isometric"}].map(e=>(0,t.jsx)(v.Ql,{value:e.value,children:e.label},e.value))})]})]}),(0,t.jsx)(b.bZ,{variant:"info",className:"mt-3",children:(0,t.jsxs)(b.X,{children:["Exulu can generate a cool image for your agent if an ",(0,t.jsx)("strong",{children:"OPENAI_IMAGE_GENERATION_API_KEY"})," has been added to your"," ",(0,t.jsx)("a",{href:"/variables",className:"text-primary hover:underline",children:"variables page"}),"."]})})]})}),(0,t.jsx)(x.cN,{children:(0,t.jsxs)(c.z,{disabled:r.loading||P,onClick:async()=>{try{if(_.length>0&&R){a({variables:{name:n,description:o,rights_mode:"private",backend:u,image:R}});return}if(!n){C.Am.error("Please fill in all fields");return}if(!j){a({variables:{name:n,description:o,rights_mode:"private",backend:u}});return}if(j&&0===_.length){Z(!0),I(0);try{let e=Array.from({length:4},async()=>{let e=await w.DQ.image.generate({name:n,description:o,style:F}),a=await e.json();return I(e=>e+1),a.image}),a=(await Promise.all(e)).filter(Boolean);k(a),a.length>0&&S(a[0])}catch(e){console.error("Failed to generate images:",e),C.Am.error("Failed to generate images. Please try again.")}finally{Z(!1)}}}catch(e){console.error("Failed to create agent:",e),C.Am.error("Failed to create agent. Please try again.")}},type:"submit",children:[_.length>0||!j?"Create Agent":P?"Generating...":"Generate Images",(r.loading||P)&&(0,t.jsx)(p.g,{className:"ml-2"})]})})]})]})}function _(e){let{createAgent:a,createAgentResult:r,company:l}=e;return(0,t.jsx)(A,{createAgent:a,createAgentResult:r,company:l,children:(0,t.jsx)(m.Zb,{className:"cursor-pointer hover:shadow-md transition-shadow duration-200 h-full flex flex-col border-dashed border-2 hover:border-primary/50",children:(0,t.jsx)(m.Ol,{className:"pb-3 h-full",children:(0,t.jsx)("div",{className:"w-full h-full rounded-lg flex items-center justify-center mb-4 flex-col",children:(0,t.jsx)("div",{className:"text-center text-muted-foreground",children:(0,t.jsx)("p",{className:"text-lg",children:"Create New Agent"})})})})})})}var k=r(73247),R=r(25915);let S="force-dynamic";function P(){let e=(0,n.useRouter)(),{user:a}=(0,i.useContext)(d.S),r=a.company,[o,c]=(0,i.useState)(""),[m,u]=(0,i.useState)(null),{data:x,loading:h,error:p}=(0,l.aM)(j.ym,{variables:{page:1,limit:100,filters:[],sort:{field:"updatedAt",direction:"DESC"}}}),v=(0,i.useMemo)(()=>{var e;return(null==x?void 0:null===(e=x.agentsPagination)||void 0===e?void 0:e.items)?o.trim()?x.agentsPagination.items.filter(e=>e.name.toLowerCase().includes(o.toLowerCase())):x.agentsPagination.items:[]},[x,o]),[N,b]=(0,s.D)(j.rR,{onCompleted:a=>{var r,t;console.log(a),e.push("/agents/edit/".concat(null==a?void 0:null===(t=a.agentsCreateOne)||void 0===t?void 0:null===(r=t.item)||void 0===r?void 0:r.id),{scroll:!1})}}),y=a=>{e.push("/agents/edit/".concat(a.id),{scroll:!1})};return p?(0,t.jsxs)("div",{className:"container mx-auto py-12 text-center",children:[(0,t.jsx)("h1",{className:"text-2xl font-bold mb-4",children:"Error loading agents"}),(0,t.jsx)("p",{className:"text-muted-foreground",children:"There was an error loading your agents. Please try again."})]}):(0,t.jsxs)("div",{className:"container mx-auto py-12 px-6",children:[(0,t.jsxs)("div",{className:"mb-8",children:[(0,t.jsx)("h1",{className:"text-3xl font-bold mb-2",children:"Agents"}),(0,t.jsx)("p",{className:"text-muted-foreground mb-6",children:"Manage your AI agents and create new ones."}),(0,t.jsxs)("div",{className:"relative max-w-md",children:[(0,t.jsx)(k.Z,{className:"absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-muted-foreground"}),(0,t.jsx)(g.I,{type:"text",placeholder:"Search agents...",value:o,onChange:e=>c(e.target.value),className:"pl-10"})]})]}),h?(0,t.jsx)("div",{className:"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4 gap-6",children:Array.from({length:8}).map((e,a)=>(0,t.jsx)("div",{className:"h-80 bg-muted animate-pulse rounded-lg"},a))}):(0,t.jsxs)("div",{className:"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4 gap-6",children:[(0,t.jsx)(_,{createAgent:N,createAgentResult:b,company:r}),v.map(e=>(0,t.jsx)(f,{agent:e,onSelect:y,showDetails:u},e.id))]}),m&&(0,t.jsx)(R.z,{agentId:m.id,open:!!m,onOpenChange:()=>u(null)})]})}},65613:function(e,a,r){"use strict";r.d(a,{Cd:function(){return o},X:function(){return c},bZ:function(){return d}});var t=r(57437),l=r(90535),s=r(2265),n=r(94508);let i=(0,l.j)("relative w-full rounded-lg border p-4 [&>svg~*]:pl-7 [&>svg+div]:translate-y-[-3px] [&>svg]:absolute [&>svg]:left-4 [&>svg]:top-4 [&>svg]:text-foreground",{variants:{variant:{default:"bg-background text-foreground",destructive:"border-destructive/50 text-destructive dark:border-destructive [&>svg]:text-destructive",info:"border-info/50 text-info dark:border-info [&>svg]:text-info"}},defaultVariants:{variant:"default"}}),d=s.forwardRef((e,a)=>{let{className:r,variant:l,...s}=e;return(0,t.jsx)("div",{ref:a,role:"alert",className:(0,n.cn)(i({variant:l}),r),...s})});d.displayName="Alert";let o=s.forwardRef((e,a)=>{let{className:r,...l}=e;return(0,t.jsx)("h5",{ref:a,className:(0,n.cn)("mb-1 font-medium leading-none tracking-tight",r),...l})});o.displayName="AlertTitle";let c=s.forwardRef((e,a)=>{let{className:r,...l}=e;return(0,t.jsx)("div",{ref:a,className:(0,n.cn)("text-sm [&_p]:leading-relaxed",r),...l})});c.displayName="AlertDescription"},66070:function(e,a,r){"use strict";r.d(a,{Ol:function(){return i},SZ:function(){return o},Zb:function(){return n},aY:function(){return c},eW:function(){return m},ll:function(){return d}});var t=r(57437),l=r(2265),s=r(94508);let n=l.forwardRef((e,a)=>{let{className:r,...l}=e;return(0,t.jsx)("div",{ref:a,className:(0,s.cn)("rounded-lg border bg-card text-card-foreground shadow-sm",r),...l})});n.displayName="Card";let i=l.forwardRef((e,a)=>{let{className:r,...l}=e;return(0,t.jsx)("div",{ref:a,className:(0,s.cn)("flex flex-col space-y-1.5 p-6",r),...l})});i.displayName="CardHeader";let d=l.forwardRef((e,a)=>{let{className:r,...l}=e;return(0,t.jsx)("h3",{ref:a,className:(0,s.cn)("text-2xl font-semibold leading-none tracking-tight",r),...l})});d.displayName="CardTitle";let o=l.forwardRef((e,a)=>{let{className:r,...l}=e;return(0,t.jsx)("p",{ref:a,className:(0,s.cn)("text-sm text-muted-foreground",r),...l})});o.displayName="CardDescription";let c=l.forwardRef((e,a)=>{let{className:r,...l}=e;return(0,t.jsx)("div",{ref:a,className:(0,s.cn)("p-6 pt-0",r),...l})});c.displayName="CardContent";let m=l.forwardRef((e,a)=>{let{className:r,...l}=e;return(0,t.jsx)("div",{ref:a,className:(0,s.cn)("flex items-center p-6 pt-0",r),...l})});m.displayName="CardFooter"},19060:function(e,a,r){"use strict";r.d(a,{X:function(){return d}});var t=r(57437),l=r(9270),s=r(30401),n=r(2265),i=r(94508);let d=n.forwardRef((e,a)=>{let{className:r,...n}=e;return(0,t.jsx)(l.fC,{ref:a,className:(0,i.cn)("peer h-4 w-4 shrink-0 rounded-sm border border-primary ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground",r),...n,children:(0,t.jsx)(l.z$,{className:(0,i.cn)("flex items-center justify-center text-current"),children:(0,t.jsx)(s.Z,{className:"size-4"})})})});d.displayName=l.fC.displayName},26815:function(e,a,r){"use strict";r.d(a,{_:function(){return o}});var t=r(57437),l=r(6394),s=r(90535),n=r(2265),i=r(94508);let d=(0,s.j)("text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70"),o=n.forwardRef((e,a)=>{let{className:r,...s}=e;return(0,t.jsx)(l.f,{ref:a,className:(0,i.cn)(d(),r),...s})});o.displayName=l.f.displayName},10492:function(e,a,r){"use strict";r.d(a,{g:function(){return s}});var t=r(57437),l=r(94508);let s=e=>{let{className:a}=e;return(0,t.jsxs)("svg",{"aria-hidden":"true",role:"status",className:(0,l.cn)("inline w-4 h-4 text-white animate-spin fill-inherit",a),viewBox:"0 0 100 101",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[(0,t.jsx)("path",{d:"M100 50.5908C100 78.2051 77.6142 100.591 50 100.591C22.3858 100.591 0 78.2051 0 50.5908C0 22.9766 22.3858 0.59082 50 0.59082C77.6142 0.59082 100 22.9766 100 50.5908ZM9.08144 50.5908C9.08144 73.1895 27.4013 91.5094 50 91.5094C72.5987 91.5094 90.9186 73.1895 90.9186 50.5908C90.9186 27.9921 72.5987 9.67226 50 9.67226C27.4013 9.67226 9.08144 27.9921 9.08144 50.5908Z",className:"fill-inherit opacity-20"}),(0,t.jsx)("path",{d:"M93.9676 39.0409C96.393 38.4038 97.8624 35.9116 97.0079 33.5539C95.2932 28.8227 92.871 24.3692 89.8167 20.348C85.8452 15.1192 80.8826 10.7238 75.2124 7.41289C69.5422 4.10194 63.2754 1.94025 56.7698 1.05124C51.7666 0.367541 46.6976 0.446843 41.7345 1.27873C39.2613 1.69328 37.813 4.19778 38.4501 6.62326C39.0873 9.04874 41.5694 10.4717 44.0505 10.1071C47.8511 9.54855 51.7191 9.52689 55.5402 10.0491C60.8642 10.7766 65.9928 12.5457 70.6331 15.2552C75.2735 17.9648 79.3347 21.5619 82.5849 25.841C84.9175 28.9121 86.7997 32.2913 88.1811 35.8758C89.083 38.2158 91.5421 39.6781 93.9676 39.0409Z",className:"fill-inherit"})]})}},53647:function(e,a,r){"use strict";r.d(a,{Bw:function(){return g},Ph:function(){return c},Ql:function(){return h},i4:function(){return u},ki:function(){return m}});var t=r(57437),l=r(46943),s=r(40875),n=r(22135),i=r(30401),d=r(2265),o=r(94508);let c=l.fC;l.ZA;let m=l.B4,u=d.forwardRef((e,a)=>{let{className:r,children:n,...i}=e;return(0,t.jsxs)(l.xz,{ref:a,className:(0,o.cn)("flex h-10 w-full items-center justify-between rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background placeholder:text-muted-foreground focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 [&>span]:line-clamp-1",r),...i,children:[n,(0,t.jsx)(l.JO,{asChild:!0,children:(0,t.jsx)(s.Z,{className:"size-4 opacity-50"})})]})});u.displayName=l.xz.displayName;let f=d.forwardRef((e,a)=>{let{className:r,...s}=e;return(0,t.jsx)(l.u_,{ref:a,className:(0,o.cn)("flex cursor-default items-center justify-center py-1",r),...s,children:(0,t.jsx)(n.Z,{className:"size-4"})})});f.displayName=l.u_.displayName;let x=d.forwardRef((e,a)=>{let{className:r,...n}=e;return(0,t.jsx)(l.$G,{ref:a,className:(0,o.cn)("flex cursor-default items-center justify-center py-1",r),...n,children:(0,t.jsx)(s.Z,{className:"size-4"})})});x.displayName=l.$G.displayName;let g=d.forwardRef((e,a)=>{let{className:r,children:s,position:n="popper",...i}=e;return(0,t.jsx)(l.h_,{children:(0,t.jsxs)(l.VY,{ref:a,className:(0,o.cn)("relative z-50 max-h-96 min-w-[8rem] overflow-hidden rounded-md border bg-popover text-popover-foreground shadow-md data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2","popper"===n&&"data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1",r),position:n,...i,children:[(0,t.jsx)(f,{}),(0,t.jsx)(l.l_,{className:(0,o.cn)("p-1","popper"===n&&"h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)]"),children:s}),(0,t.jsx)(x,{})]})})});g.displayName=l.VY.displayName,d.forwardRef((e,a)=>{let{className:r,...s}=e;return(0,t.jsx)(l.__,{ref:a,className:(0,o.cn)("py-1.5 pl-8 pr-2 text-sm font-semibold",r),...s})}).displayName=l.__.displayName;let h=d.forwardRef((e,a)=>{let{className:r,children:s,...n}=e;return(0,t.jsxs)(l.ck,{ref:a,className:(0,o.cn)("relative flex w-full cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",r),...n,children:[(0,t.jsx)("span",{className:"absolute left-2 flex size-3.5 items-center justify-center",children:(0,t.jsx)(l.wU,{children:(0,t.jsx)(i.Z,{className:"size-4"})})}),(0,t.jsx)(l.eT,{children:s})]})});h.displayName=l.ck.displayName,d.forwardRef((e,a)=>{let{className:r,...s}=e;return(0,t.jsx)(l.Z0,{ref:a,className:(0,o.cn)("-mx-1 my-1 h-px bg-muted",r),...s})}).displayName=l.Z0.displayName}},function(e){e.O(0,[9851,7629,7093,6148,847,1942,7648,7823,8068,5799,4567,605,85,4957,7398,1785,5017,6373,3832,2293,2971,2117,1744],function(){return e(e.s=79959)}),_N_E=e.O()}]);
2
+ //# sourceMappingURL=page-499ac3bd1044306c.js.map