@exulu/frontend 1.9.0 → 1.10.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/.next/BUILD_ID +1 -1
- package/dist/.next/app-build-manifest.json +140 -140
- package/dist/.next/app-path-routes-manifest.json +1 -1
- package/dist/.next/build-manifest.json +2 -2
- package/dist/.next/prerender-manifest.json +1 -1
- package/dist/.next/server/app/(application)/agents/edit/[id]/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/agents/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/chat/[agent]/[session]/page.js +7 -7
- package/dist/.next/server/app/(application)/chat/[agent]/[session]/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/chat/[agent]/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/chat/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/configuration/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/dashboard/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/data/[[...query]]/page.js +3 -3
- package/dist/.next/server/app/(application)/data/[[...query]]/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/evals/[id]/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/evals/cases/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/evals/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/explorer/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/keys/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/projects/[project]/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/projects/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/prompts/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/roles/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/token/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/users/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/variables/create/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/variables/edit/[variable_id]/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/variables/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/variables/usage/[variable_id]/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(application)/workflows/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/(authentication)/login/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/dist/.next/server/app/_not-found.html +1 -1
- package/dist/.next/server/app/_not-found.rsc +1 -1
- package/dist/.next/server/app-paths-manifest.json +6 -6
- package/dist/.next/server/chunks/2270.js +17 -6
- package/dist/.next/server/chunks/5485.js +1 -1
- package/dist/.next/server/chunks/5974.js +1 -1
- package/dist/.next/server/middleware-manifest.json +5 -5
- package/dist/.next/server/pages/404.html +1 -1
- package/dist/.next/server/pages/500.html +1 -1
- package/dist/.next/server/server-reference-manifest.json +1 -1
- package/dist/.next/static/chunks/3750-e3d1b2cccd265190.js +2 -0
- package/dist/.next/static/chunks/3750-e3d1b2cccd265190.js.map +1 -0
- package/dist/.next/static/chunks/{3832-417a5eeee712a793.js → 3832-d7782d6a2771ae6c.js} +1 -1
- package/dist/.next/static/chunks/{3832-417a5eeee712a793.js.map → 3832-d7782d6a2771ae6c.js.map} +1 -1
- package/dist/.next/static/chunks/6280-50b751f993f2fe4f.js +2 -0
- package/dist/.next/static/chunks/6280-50b751f993f2fe4f.js.map +1 -0
- package/dist/.next/static/chunks/{6373-601400fab8a3bb55.js → 6373-aef582adc575d3ca.js} +2 -2
- package/dist/.next/static/chunks/6373-aef582adc575d3ca.js.map +1 -0
- package/dist/.next/static/chunks/{8293-0e69d89d2dac7111.js → 8293-ba5cd36594e6fde1.js} +3 -3
- package/dist/.next/static/chunks/8293-ba5cd36594e6fde1.js.map +1 -0
- package/dist/.next/static/chunks/9105-d8ff41060f7ffc85.js +2 -0
- package/dist/.next/static/chunks/9105-d8ff41060f7ffc85.js.map +1 -0
- package/dist/.next/static/chunks/app/(application)/chat/[agent]/[session]/{page-7edb1c7c850f982c.js → page-d59534ca19eee51f.js} +1 -1
- package/dist/.next/static/chunks/app/(application)/chat/[agent]/[session]/{page-7edb1c7c850f982c.js.map → page-d59534ca19eee51f.js.map} +1 -1
- package/dist/.next/static/chunks/app/(application)/data/[[...query]]/layout-0c7c1b0e1713bf60.js +2 -0
- package/dist/.next/static/chunks/app/(application)/data/[[...query]]/layout-0c7c1b0e1713bf60.js.map +1 -0
- package/dist/.next/static/chunks/app/(application)/data/[[...query]]/page-7db6bfbf02606136.js +2 -0
- package/dist/.next/static/chunks/app/(application)/data/[[...query]]/page-7db6bfbf02606136.js.map +1 -0
- package/dist/.next/static/chunks/app/(application)/explorer/{page-1d676c9dfe3ed58b.js → page-e6b1c034c07776e2.js} +1 -1
- package/dist/.next/static/chunks/app/(application)/explorer/{page-1d676c9dfe3ed58b.js.map → page-e6b1c034c07776e2.js.map} +1 -1
- package/dist/.next/static/chunks/app/(application)/token/{page-3f74f711f3d04fce.js → page-3acc39cb8a718331.js} +1 -1
- package/dist/.next/static/chunks/app/(application)/token/{page-3f74f711f3d04fce.js.map → page-3acc39cb8a718331.js.map} +1 -1
- package/dist/.next/static/chunks/ba12c10f-85ed008ce7746dbe.js +2 -0
- package/dist/.next/static/chunks/ba12c10f-85ed008ce7746dbe.js.map +1 -0
- package/dist/.next/static/css/9c08ae5d990a6b14.css +4 -0
- package/dist/.next/static/css/9c08ae5d990a6b14.css.map +1 -0
- package/dist/.next/static/css/e3f2a16ab7676b05.css.map +1 -1
- package/dist/package.json +1 -1
- package/package.json +1 -1
- package/dist/.next/static/chunks/3750-f45c59ef1cc79417.js +0 -2
- package/dist/.next/static/chunks/3750-f45c59ef1cc79417.js.map +0 -1
- package/dist/.next/static/chunks/572-2940a399da1e3a3b.js +0 -2
- package/dist/.next/static/chunks/572-2940a399da1e3a3b.js.map +0 -1
- package/dist/.next/static/chunks/6373-601400fab8a3bb55.js.map +0 -1
- package/dist/.next/static/chunks/8293-0e69d89d2dac7111.js.map +0 -1
- package/dist/.next/static/chunks/9105-dfbce1bad8e3e8dd.js +0 -2
- package/dist/.next/static/chunks/9105-dfbce1bad8e3e8dd.js.map +0 -1
- package/dist/.next/static/chunks/app/(application)/data/[[...query]]/layout-2d47be0ee80dd89d.js +0 -2
- package/dist/.next/static/chunks/app/(application)/data/[[...query]]/layout-2d47be0ee80dd89d.js.map +0 -1
- package/dist/.next/static/chunks/app/(application)/data/[[...query]]/page-8d2b3995cacfd832.js +0 -2
- package/dist/.next/static/chunks/app/(application)/data/[[...query]]/page-8d2b3995cacfd832.js.map +0 -1
- package/dist/.next/static/chunks/ba12c10f-aaafcb074f608624.js +0 -2
- package/dist/.next/static/chunks/ba12c10f-aaafcb074f608624.js.map +0 -1
- package/dist/.next/static/css/6f8c5212af8ef284.css +0 -4
- package/dist/.next/static/css/6f8c5212af8ef284.css.map +0 -1
- /package/dist/.next/static/{ls-syPkq9-MWp-VWWDEZJ → 3j63p6b3zZZB_v1Hn8Mxp}/_buildManifest.js +0 -0
- /package/dist/.next/static/{ls-syPkq9-MWp-VWWDEZJ → 3j63p6b3zZZB_v1Hn8Mxp}/_ssgManifest.js +0 -0
package/dist/.next/static/chunks/{3832-417a5eeee712a793.js.map → 3832-d7782d6a2771ae6c.js.map}
RENAMED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"static/chunks/3832-417a5eeee712a793.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, Album } 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: \"Knowledge\",\n path: \"data\",\n icon: <Database />,\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 navigationItems.push({\n label: \"Prompts\",\n path: \"prompts\",\n icon: <Album />,\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: \"Theme\",\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 <div className=\"px-2 pb-1 group-data-[collapsible=icon]:hidden\">\n <div className=\"inline-flex items-center gap-1.5 rounded-full border border-primary/20 bg-primary/5 px-2.5 py-0.5\">\n <Sparkles className=\"h-3 w-3 text-primary\" />\n <span className=\"text-xs font-medium text-primary\">Beta</span>\n </div>\n </div>\n <SidebarMenu>\n <SidebarMenuItem>\n <DropdownMenu modal={false}>\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 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\"}\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","agents","Bot","FolderOpen","MessageCircle","Album","evals","Brain","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","Sparkles","DropdownMenu","modal","DropdownMenuTrigger","Avatar","AvatarFallback","email","charAt","toUpperCase","split","ChevronUp","DropdownMenuContent","DropdownMenuItem","Sun","Moon","LogOut","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","DropdownMenuRadioGroup","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":""}
|
|
1
|
+
{"version":3,"file":"static/chunks/3832-d7782d6a2771ae6c.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, Album } 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: \"Knowledge\",\n path: \"data\",\n icon: <Database />,\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 navigationItems.push({\n label: \"Prompts\",\n path: \"prompts\",\n icon: <Album />,\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: \"Theme\",\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 <div className=\"px-2 pb-1 group-data-[collapsible=icon]:hidden\">\n <div className=\"inline-flex items-center gap-1.5 rounded-full border border-primary/20 bg-primary/5 px-2.5 py-0.5\">\n <Sparkles className=\"h-3 w-3 text-primary\" />\n <span className=\"text-xs font-medium text-primary\">Beta</span>\n </div>\n </div>\n <SidebarMenu>\n <SidebarMenuItem>\n <DropdownMenu modal={false}>\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 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\"}\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 // Key is the base s3 key of the file\n // if only the key is provided only the\n // user that uploaded the file, a super\n // admin or api user can access and \n // download the file. If an item ID is\n // provided, the RBAC rights associated\n // with the item are checked and used.\n // The item must be provided as a GID\n // with the context id as the prefix before\n // the first slash.\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","agents","Bot","FolderOpen","MessageCircle","Album","evals","Brain","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","Sparkles","DropdownMenu","modal","DropdownMenuTrigger","Avatar","AvatarFallback","email","charAt","toUpperCase","split","ChevronUp","DropdownMenuContent","DropdownMenuItem","Sun","Moon","LogOut","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","DropdownMenuRadioGroup","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
|
+
"use strict";(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[6280],{42833:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("ArchiveX",[["rect",{width:"20",height:"5",x:"2",y:"3",rx:"1",key:"1wp1u1"}],["path",{d:"M4 8v11a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8",key:"1s80jp"}],["path",{d:"m9.5 17 5-5",key:"nakeu6"}],["path",{d:"m9.5 12 5 5",key:"1hccrj"}]])},9334:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("Archive",[["rect",{width:"20",height:"5",x:"2",y:"3",rx:"1",key:"1wp1u1"}],["path",{d:"M4 8v11a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8",key:"1s80jp"}],["path",{d:"M10 12h4",key:"a56b0p"}]])},32660:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("ArrowLeft",[["path",{d:"m12 19-7-7 7-7",key:"1l729n"}],["path",{d:"M19 12H5",key:"x3x0zl"}]])},49277:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("FileStack",[["path",{d:"M16 2v5h5",key:"kt2in0"}],["path",{d:"M21 6v6.5c0 .8-.7 1.5-1.5 1.5h-7c-.8 0-1.5-.7-1.5-1.5v-9c0-.8.7-1.5 1.5-1.5H17l4 4z",key:"1km23n"}],["path",{d:"M7 8v8.8c0 .3.2.6.4.8.2.2.5.4.8.4H15",key:"16874u"}],["path",{d:"M3 12v8.8c0 .3.2.6.4.8.2.2.5.4.8.4H11",key:"k2ox98"}]])},14924:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("Folder",[["path",{d:"M20 20a2 2 0 0 0 2-2V8a2 2 0 0 0-2-2h-7.9a2 2 0 0 1-1.69-.9L9.6 3.9A2 2 0 0 0 7.93 3H4a2 2 0 0 0-2 2v13a2 2 0 0 0 2 2Z",key:"1kt360"}]])},41905:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("GripVertical",[["circle",{cx:"9",cy:"12",r:"1",key:"1vctgf"}],["circle",{cx:"9",cy:"5",r:"1",key:"hp0tcf"}],["circle",{cx:"9",cy:"19",r:"1",key:"fkjjf6"}],["circle",{cx:"15",cy:"12",r:"1",key:"1tmaij"}],["circle",{cx:"15",cy:"5",r:"1",key:"19l28e"}],["circle",{cx:"15",cy:"19",r:"1",key:"f4zoj3"}]])},45554:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("ListChecks",[["path",{d:"m3 17 2 2 4-4",key:"1jhpwq"}],["path",{d:"m3 7 2 2 4-4",key:"1obspn"}],["path",{d:"M13 6h8",key:"15sg57"}],["path",{d:"M13 12h8",key:"h98zly"}],["path",{d:"M13 18h8",key:"oe0vm4"}]])},15001:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("Loader",[["line",{x1:"12",x2:"12",y1:"2",y2:"6",key:"gza1u7"}],["line",{x1:"12",x2:"12",y1:"18",y2:"22",key:"1qhbu9"}],["line",{x1:"4.93",x2:"7.76",y1:"4.93",y2:"7.76",key:"xae44r"}],["line",{x1:"16.24",x2:"19.07",y1:"16.24",y2:"19.07",key:"bxnmvf"}],["line",{x1:"2",x2:"6",y1:"12",y2:"12",key:"89khin"}],["line",{x1:"18",x2:"22",y1:"12",y2:"12",key:"pb8tfm"}],["line",{x1:"4.93",x2:"7.76",y1:"19.07",y2:"16.24",key:"1uxjnu"}],["line",{x1:"16.24",x2:"19.07",y1:"7.76",y2:"4.93",key:"6duxfx"}]])},21563:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("PackageOpen",[["path",{d:"M20.91 8.84 8.56 2.23a1.93 1.93 0 0 0-1.81 0L3.1 4.13a2.12 2.12 0 0 0-.05 3.69l12.22 6.93a2 2 0 0 0 1.94 0L21 12.51a2.12 2.12 0 0 0-.09-3.67Z",key:"1vy178"}],["path",{d:"m3.09 8.84 12.35-6.61a1.93 1.93 0 0 1 1.81 0l3.65 1.9a2.12 2.12 0 0 1 .1 3.69L8.73 14.75a2 2 0 0 1-1.94 0L3 12.51a2.12 2.12 0 0 1 .09-3.67Z",key:"s3bv25"}],["line",{x1:"12",x2:"12",y1:"22",y2:"13",key:"1o4xyi"}],["path",{d:"M20 13.5v3.37a2.06 2.06 0 0 1-1.11 1.83l-6 3.08a1.93 1.93 0 0 1-1.78 0l-6-3.08A2.06 2.06 0 0 1 4 16.87V13.5",key:"1na2nq"}]])},45675:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("Pencil",[["path",{d:"M17 3a2.85 2.83 0 1 1 4 4L7.5 20.5 2 22l1.5-5.5Z",key:"5qss01"}],["path",{d:"m15 5 4 4",key:"1mk7zo"}]])},99397:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("Plus",[["path",{d:"M5 12h14",key:"1ays0h"}],["path",{d:"M12 5v14",key:"s699le"}]])},73247:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("Search",[["circle",{cx:"11",cy:"11",r:"8",key:"4ej97u"}],["path",{d:"m21 21-4.3-4.3",key:"1qie3q"}]])},69493:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("StepForward",[["line",{x1:"6",x2:"6",y1:"4",y2:"20",key:"fy8qot"}],["polygon",{points:"10,4 20,12 10,20",key:"1mc1pf"}]])},23374:function(e,t,n){n.d(t,{OT:function(){return er},eh:function(){return ee},s_:function(){return z}});var r,l=n(2265);let{createElement:a,createContext:i,createRef:u,forwardRef:o,useCallback:c,useContext:d,useEffect:s,useImperativeHandle:f,useLayoutEffect:p,useMemo:h,useRef:y,useState:m}=r||(r=n.t(l,2)),v=(r||(r=n.t(l,2)))["useId".toString()],g=i(null);g.displayName="PanelGroupContext";let b="function"==typeof v?v:()=>null,x=0;function k(e=null){let t=b(),n=y(e||t||null);return null===n.current&&(n.current=""+x++),null!=e?e:n.current}function w({children:e,className:t="",collapsedSize:n,collapsible:r,defaultSize:l,forwardedRef:i,id:u,maxSize:o,minSize:c,onCollapse:s,onExpand:h,onResize:m,order:v,style:b,tagName:x="div",...w}){let z=d(g);if(null===z)throw Error("Panel components must be rendered within a PanelGroup container");let{collapsePanel:M,expandPanel:E,getPanelSize:C,getPanelStyle:I,groupId:A,isPanelCollapsed:S,reevaluatePanelConstraints:L,registerPanel:j,resizePanel:D,unregisterPanel:N}=z,P=k(u),Z=y({callbacks:{onCollapse:s,onExpand:h,onResize:m},constraints:{collapsedSize:n,collapsible:r,defaultSize:l,maxSize:o,minSize:c},id:P,idIsFromProps:void 0!==u,order:v});y({didLogMissingDefaultSizeWarning:!1}),p(()=>{let{callbacks:e,constraints:t}=Z.current,a={...t};Z.current.id=P,Z.current.idIsFromProps=void 0!==u,Z.current.order=v,e.onCollapse=s,e.onExpand=h,e.onResize=m,t.collapsedSize=n,t.collapsible=r,t.defaultSize=l,t.maxSize=o,t.minSize=c,(a.collapsedSize!==t.collapsedSize||a.collapsible!==t.collapsible||a.maxSize!==t.maxSize||a.minSize!==t.minSize)&&L(Z.current,a)}),p(()=>{let e=Z.current;return j(e),()=>{N(e)}},[v,P,j,N]),f(i,()=>({collapse:()=>{M(Z.current)},expand:()=>{E(Z.current)},getId:()=>P,getSize:()=>C(Z.current),isCollapsed:()=>S(Z.current),isExpanded:()=>!S(Z.current),resize:e=>{D(Z.current,e)}}),[M,E,C,S,P,D]);let R=I(Z.current,l);return a(x,{...w,children:e,className:t,style:{...R,...b},"data-panel":"","data-panel-id":P,"data-panel-group-id":A,"data-panel-collapsible":void 0,"data-panel-size":void 0})}let z=o((e,t)=>a(w,{...e,forwardedRef:t}));function M(e,t="Assertion failed!"){if(!e)throw console.error(t),Error(t)}function E(e,t,n=10){let r=(e=parseFloat(e.toFixed(n)))-(t=parseFloat(t.toFixed(n)));return 0===r?0:r>0?1:-1}function C(e,t,n){return 0===E(e,t,n)}function I({panelConstraints:e,panelIndex:t,size:n}){let r=e[t];M(null!=r);let{collapsedSize:l=0,collapsible:a,maxSize:i=100,minSize:u=0}=r;return 0>E(n,u)&&(n=a&&0>E(n,(l+u)/2)?l:u),n=parseFloat((n=Math.min(i,n)).toFixed(10))}function A({delta:e,layout:t,panelConstraints:n,pivotIndices:r,trigger:l}){if(C(e,0))return t;let a=[...t],[i,u]=r;M(null!=i),M(null!=u);let o=0;if("keyboard"===l){{let r=e<0?u:i,l=n[r];if(M(l),l.collapsible){let l=t[r];M(null!=l);let a=n[r];M(a);let{collapsedSize:i=0,minSize:u=0}=a;if(C(l,i)){let t=u-l;E(t,Math.abs(e))>0&&(e=e<0?0-t:t)}}}{let r=e<0?i:u,l=n[r];M(l);let{collapsible:a}=l;if(a){let l=t[r];M(null!=l);let a=n[r];M(a);let{collapsedSize:i=0,minSize:u=0}=a;if(C(l,u)){let t=l-i;E(t,Math.abs(e))>0&&(e=e<0?0-t:t)}}}}{let r=e<0?1:-1,l=e<0?u:i,a=0;for(;;){let e=t[l];if(M(null!=e),a+=I({panelConstraints:n,panelIndex:l,size:100})-e,(l+=r)<0||l>=n.length)break}let o=Math.min(Math.abs(e),Math.abs(a));e=e<0?0-o:o}{let r=e<0?i:u;for(;r>=0&&r<n.length;){let l=Math.abs(e)-Math.abs(o),i=t[r];M(null!=i);let u=I({panelConstraints:n,panelIndex:r,size:i-l});if(!C(i,u)&&(o+=i-u,a[r]=u,o.toPrecision(3).localeCompare(Math.abs(e).toPrecision(3),void 0,{numeric:!0})>=0))break;e<0?r--:r++}}if(C(o,0))return t;{let r=e<0?u:i,l=t[r];M(null!=l);let c=l+o,d=I({panelConstraints:n,panelIndex:r,size:c});if(a[r]=d,!C(d,c)){let t=c-d,r=e<0?u:i;for(;r>=0&&r<n.length;){let l=a[r];M(null!=l);let i=I({panelConstraints:n,panelIndex:r,size:l+t});if(C(l,i)||(t-=i-l,a[r]=i),C(t,0))break;e>0?r--:r++}}}return C(a.reduce((e,t)=>t+e,0),100)?a:t}function S(e,t=document){return Array.from(t.querySelectorAll(`[data-panel-resize-handle-id][data-panel-group-id="${e}"]`))}function L(e,t,n=document){let r=S(e,n).findIndex(e=>e.getAttribute("data-panel-resize-handle-id")===t);return null!=r?r:null}function j(e,t,n){let r=L(e,t,n);return null!=r?[r,r+1]:[-1,-1]}function D(e,t=document){var n;return t instanceof HTMLElement&&(null==t?void 0:null===(n=t.dataset)||void 0===n?void 0:n.panelGroupId)==e?t:t.querySelector(`[data-panel-group][data-panel-group-id="${e}"]`)||null}function N(e,t=document){return t.querySelector(`[data-panel-resize-handle-id="${e}"]`)||null}function P(e,t){if(e.length!==t.length)return!1;for(let n=0;n<e.length;n++)if(e[n]!==t[n])return!1;return!0}function Z(e){return"keydown"===e.type}function R(e){return e.type.startsWith("mouse")}function T(e){return e.type.startsWith("touch")}function F(e,t){let n="horizontal"===e;if(R(t))return n?t.clientX:t.clientY;if(T(t)){let e=t.touches[0];return M(e),n?e.screenX:e.screenY}throw Error(`Unsupported event type "${t.type}"`)}function V(e,t,n){t.forEach((t,r)=>{let l=e[r];M(l);let{callbacks:a,constraints:i,id:u}=l,{collapsedSize:o=0,collapsible:c}=i,d=n[u];if(null==d||t!==d){n[u]=t;let{onCollapse:e,onExpand:r,onResize:l}=a;l&&l(t,d),c&&(e||r)&&(r&&(null==d||d===o)&&t!==o&&r(),e&&(null==d||d!==o)&&t===o&&e())}})}function H(e,t){if(e.length!==t.length)return!1;for(let n=0;n<e.length;n++)if(e[n]!=t[n])return!1;return!0}w.displayName="Panel",z.displayName="forwardRef(Panel)";let W=null,$=null;function q(e){switch(e){case"horizontal":return"ew-resize";case"horizontal-max":return"w-resize";case"horizontal-min":return"e-resize";case"vertical":return"ns-resize";case"vertical-max":return"n-resize";case"vertical-min":return"s-resize"}}function O(e){if(W===e)return;W=e;let t=q(e);null===$&&($=document.createElement("style"),document.head.appendChild($)),$.innerHTML=`*{cursor: ${t}!important;}`}function G(e){try{if("undefined"!=typeof localStorage)e.getItem=e=>localStorage.getItem(e),e.setItem=(e,t)=>{localStorage.setItem(e,t)};else throw Error("localStorage not supported in this environment")}catch(t){console.error(t),e.getItem=()=>null,e.setItem=()=>{}}}function _(e){return`react-resizable-panels:${e}`}function K(e){return e.map(e=>{let{constraints:t,id:n,idIsFromProps:r,order:l}=e;return r?n:l?`${l}:${JSON.stringify(t)}`:JSON.stringify(t)}).sort((e,t)=>e.localeCompare(t)).join(",")}function B(e,t){try{let n=_(e),r=t.getItem(n);if(r){let e=JSON.parse(r);if("object"==typeof e&&null!=e)return e}}catch(e){}return null}function J(e,t,n,r,l){var a;let i=_(e),u=K(t),o=null!==(a=B(e,l))&&void 0!==a?a:{};o[u]={expandToSizes:Object.fromEntries(n.entries()),layout:r};try{l.setItem(i,JSON.stringify(o))}catch(e){console.error(e)}}function U({layout:e,panelConstraints:t}){let n=[...e],r=n.reduce((e,t)=>e+t,0);if(n.length!==t.length)throw Error(`Invalid ${t.length} panel layout: ${n.map(e=>`${e}%`).join(", ")}`);if(!C(r,100))for(let e=0;e<t.length;e++){let t=n[e];M(null!=t);let l=100/r*t;n[e]=l}let l=0;for(let e=0;e<t.length;e++){let r=n[e];M(null!=r);let a=I({panelConstraints:t,panelIndex:e,size:r});r!=a&&(l+=r-a,n[e]=a)}if(!C(l,0))for(let e=0;e<t.length;e++){let r=n[e];M(null!=r);let a=I({panelConstraints:t,panelIndex:e,size:r+l});if(r!==a&&(l-=a-r,n[e]=a,C(l,0)))break}return n}let X={getItem:e=>(G(X),X.getItem(e)),setItem:(e,t)=>{G(X),X.setItem(e,t)}},Y={};function Q({autoSaveId:e=null,children:t,className:n="",direction:r,forwardedRef:l,id:i=null,onLayout:u=null,keyboardResizeBy:o=null,storage:d=X,style:v,tagName:b="div",...x}){let w=k(i),z=y(null),[E,I]=m(null),[L,q]=m([]),G=y({}),_=y(new Map),Q=y(0),ee=y({autoSaveId:e,direction:r,dragState:E,id:w,keyboardResizeBy:o,onLayout:u,storage:d}),er=y({layout:L,panelDataArray:[],panelDataArrayChanged:!1});y({didLogIdAndOrderWarning:!1,didLogPanelConstraintsWarning:!1,prevPanelIds:[]}),f(l,()=>({getId:()=>ee.current.id,getLayout:()=>{let{layout:e}=er.current;return e},setLayout:e=>{let{onLayout:t}=ee.current,{layout:n,panelDataArray:r}=er.current,l=U({layout:e,panelConstraints:r.map(e=>e.constraints)});P(n,l)||(q(l),er.current.layout=l,t&&t(l),V(r,l,G.current))}}),[]),p(()=>{ee.current.autoSaveId=e,ee.current.direction=r,ee.current.dragState=E,ee.current.id=w,ee.current.onLayout=u,ee.current.storage=d}),function({committedValuesRef:e,eagerValuesRef:t,groupId:n,layout:r,panelDataArray:l,panelGroupElement:a,setLayout:i}){y({didWarnAboutMissingResizeHandle:!1}),p(()=>{if(!a)return;let e=S(n,a);for(let t=0;t<l.length-1;t++){let{valueMax:n,valueMin:a,valueNow:i}=function({layout:e,panelsArray:t,pivotIndices:n}){let r=0,l=100,a=0,i=0,u=n[0];return M(null!=u),t.forEach((e,t)=>{let{constraints:n}=e,{maxSize:o=100,minSize:c=0}=n;t===u?(r=c,l=o):(a+=c,i+=o)}),{valueMax:Math.min(l,100-a),valueMin:Math.max(r,100-i),valueNow:e[u]}}({layout:r,panelsArray:l,pivotIndices:[t,t+1]}),u=e[t];if(null==u);else{let e=l[t];M(e),u.setAttribute("aria-controls",e.id),u.setAttribute("aria-valuemax",""+Math.round(n)),u.setAttribute("aria-valuemin",""+Math.round(a)),u.setAttribute("aria-valuenow",null!=i?""+Math.round(i):"")}}return()=>{e.forEach((e,t)=>{e.removeAttribute("aria-controls"),e.removeAttribute("aria-valuemax"),e.removeAttribute("aria-valuemin"),e.removeAttribute("aria-valuenow")})}},[n,r,l,a]),s(()=>{if(!a)return;let e=t.current;M(e);let{panelDataArray:l}=e;M(null!=D(n,a),`No group found for id "${n}"`);let u=S(n,a);M(u);let o=u.map(e=>{let t=e.getAttribute("data-panel-resize-handle-id");M(t);let[u,o]=function(e,t,n,r=document){var l,a,i,u;let o=N(t,r),c=S(e,r),d=o?c.indexOf(o):-1;return[null!==(l=null===(a=n[d])||void 0===a?void 0:a.id)&&void 0!==l?l:null,null!==(i=null===(u=n[d+1])||void 0===u?void 0:u.id)&&void 0!==i?i:null]}(n,t,l,a);if(null==u||null==o)return()=>{};let c=e=>{if(!e.defaultPrevented&&"Enter"===e.key){e.preventDefault();let o=l.findIndex(e=>e.id===u);if(o>=0){let e=l[o];M(e);let u=r[o],{collapsedSize:c=0,collapsible:d,minSize:s=0}=e.constraints;if(null!=u&&d){let e=A({delta:C(u,c)?s-c:c-u,layout:r,panelConstraints:l.map(e=>e.constraints),pivotIndices:j(n,t,a),trigger:"keyboard"});r!==e&&i(e)}}}};return e.addEventListener("keydown",c),()=>{e.removeEventListener("keydown",c)}});return()=>{o.forEach(e=>e())}},[a,e,t,n,r,l,i])}({committedValuesRef:ee,eagerValuesRef:er,groupId:w,layout:L,panelDataArray:er.current.panelDataArray,setLayout:q,panelGroupElement:z.current}),s(()=>{let{panelDataArray:t}=er.current;if(e){if(0===L.length||L.length!==t.length)return;let n=Y[e];null==n&&(n=function(e,t=10){let n=null;return(...r)=>{null!==n&&clearTimeout(n),n=setTimeout(()=>{e(...r)},t)}}(J,100),Y[e]=n),n(e,[...t],new Map(_.current),L,d)}},[e,L,d]),s(()=>{});let el=c(e=>{let{onLayout:t}=ee.current,{layout:n,panelDataArray:r}=er.current;if(e.constraints.collapsible){let l=r.map(e=>e.constraints),{collapsedSize:a=0,panelSize:i,pivotIndices:u}=en(r,e,n);if(M(null!=i),i!==a){_.current.set(e.id,i);let o=A({delta:et(r,e)===r.length-1?i-a:a-i,layout:n,panelConstraints:l,pivotIndices:u,trigger:"imperative-api"});H(n,o)||(q(o),er.current.layout=o,t&&t(o),V(r,o,G.current))}}},[]),ea=c(e=>{let{onLayout:t}=ee.current,{layout:n,panelDataArray:r}=er.current;if(e.constraints.collapsible){let l=r.map(e=>e.constraints),{collapsedSize:a=0,panelSize:i,minSize:u=0,pivotIndices:o}=en(r,e,n);if(i===a){let a=_.current.get(e.id),c=null!=a&&a>=u?a:u,d=A({delta:et(r,e)===r.length-1?i-c:c-i,layout:n,panelConstraints:l,pivotIndices:o,trigger:"imperative-api"});H(n,d)||(q(d),er.current.layout=d,t&&t(d),V(r,d,G.current))}}},[]),ei=c(e=>{let{layout:t,panelDataArray:n}=er.current,{panelSize:r}=en(n,e,t);return M(null!=r),r},[]),eu=c((e,t)=>{let{panelDataArray:n}=er.current,r=et(n,e);return function({defaultSize:e,dragState:t,layout:n,panelData:r,panelIndex:l,precision:a=3}){let i=n[l];return{flexBasis:0,flexGrow:null==i?null!=e?e:"1":1===r.length?"1":i.toPrecision(a),flexShrink:1,overflow:"hidden",pointerEvents:null!==t?"none":void 0}}({defaultSize:t,dragState:E,layout:L,panelData:n,panelIndex:r})},[E,L]),eo=c(e=>{let{layout:t,panelDataArray:n}=er.current,{collapsedSize:r=0,collapsible:l,panelSize:a}=en(n,e,t);return!0===l&&a===r},[]),ec=c(e=>{let{layout:t,panelDataArray:n}=er.current,{collapsedSize:r=0,collapsible:l,panelSize:a}=en(n,e,t);return M(null!=a),!l||a>r},[]),ed=c(e=>{let{panelDataArray:t}=er.current;t.push(e),t.sort((e,t)=>{let n=e.order,r=t.order;return null==n&&null==r?0:null==n?-1:null==r?1:n-r}),er.current.panelDataArrayChanged=!0},[]);p(()=>{if(er.current.panelDataArrayChanged){er.current.panelDataArrayChanged=!1;let{autoSaveId:n,onLayout:r,storage:l}=ee.current,{layout:a,panelDataArray:i}=er.current,u=null;if(n){var e,t;let r=null!==(t=(null!==(e=B(n,l))&&void 0!==e?e:{})[K(i)])&&void 0!==t?t:null;r&&(_.current=new Map(Object.entries(r.expandToSizes)),u=r.layout)}null==u&&(u=function({panelDataArray:e}){let t=Array(e.length),n=e.map(e=>e.constraints),r=0,l=100;for(let a=0;a<e.length;a++){let e=n[a];M(e);let{defaultSize:i}=e;null!=i&&(r++,t[a]=i,l-=i)}for(let a=0;a<e.length;a++){let i=n[a];M(i);let{defaultSize:u}=i;if(null!=u)continue;let o=l/(e.length-r);r++,t[a]=o,l-=o}return t}({panelDataArray:i}));let o=U({layout:u,panelConstraints:i.map(e=>e.constraints)});P(a,o)||(q(o),er.current.layout=o,r&&r(o),V(i,o,G.current))}});let es=c(e=>function(t){t.preventDefault();let n=z.current;if(!n)return()=>null;let{direction:r,dragState:l,id:a,keyboardResizeBy:i,onLayout:u}=ee.current,{layout:o,panelDataArray:c}=er.current,{initialLayout:d}=null!=l?l:{},s=j(a,e,n),f=function(e,t,n,r,l,a){if(Z(e)){let t="horizontal"===n,r=0;r=e.shiftKey?100:null!=l?l:10;let a=0;switch(e.key){case"ArrowDown":a=t?0:r;break;case"ArrowLeft":a=t?-r:0;break;case"ArrowRight":a=t?r:0;break;case"ArrowUp":a=t?0:-r;break;case"End":a=100;break;case"Home":a=-100}return a}return null==r?0:function(e,t,n,r,l){let a="horizontal"===n,i=N(t,l);M(i);let u=i.getAttribute("data-panel-group-id");M(u);let{initialCursorPosition:o}=r,c=F(n,e),d=D(u,l);M(d);let s=d.getBoundingClientRect();return(c-o)/(a?s.width:s.height)*100}(e,t,n,r,a)}(t,e,r,l,i,n);if(0===f)return;let p="horizontal"===r;"rtl"===document.dir&&p&&(f=-f);let h=A({delta:f,layout:null!=d?d:o,panelConstraints:c.map(e=>e.constraints),pivotIndices:s,trigger:Z(t)?"keyboard":"mouse-or-touch"}),y=!H(o,h);(R(t)||T(t))&&Q.current!=f&&(Q.current=f,y?O(p?"horizontal":"vertical"):p?O(f<0?"horizontal-min":"horizontal-max"):O(f<0?"vertical-min":"vertical-max")),y&&(q(h),er.current.layout=h,u&&u(h),V(c,h,G.current))},[]),ef=c((e,t)=>{let{onLayout:n}=ee.current,{layout:r,panelDataArray:l}=er.current,a=l.map(e=>e.constraints),{panelSize:i,pivotIndices:u}=en(l,e,r);M(null!=i);let o=A({delta:et(l,e)===l.length-1?i-t:t-i,layout:r,panelConstraints:a,pivotIndices:u,trigger:"imperative-api"});H(r,o)||(q(o),er.current.layout=o,n&&n(o),V(l,o,G.current))},[]),ep=c((e,t)=>{let{layout:n,panelDataArray:r}=er.current,{collapsedSize:l=0,collapsible:a}=t,{collapsedSize:i=0,collapsible:u,maxSize:o=100,minSize:c=0}=e.constraints,{panelSize:d}=en(r,e,n);M(null!=d),a&&u&&d===l?l!==i&&ef(e,i):d<c?ef(e,c):d>o&&ef(e,o)},[ef]),eh=c((e,t)=>{let{direction:n}=ee.current,{layout:r}=er.current;if(!z.current)return;let l=N(e,z.current);M(l);let a=F(n,t);I({dragHandleId:e,dragHandleRect:l.getBoundingClientRect(),initialCursorPosition:a,initialLayout:r})},[]),ey=c(()=>{null!==$&&(document.head.removeChild($),W=null,$=null),I(null)},[]),em=c(e=>{let{panelDataArray:t}=er.current,n=et(t,e);n>=0&&(t.splice(n,1),delete G.current[e.id],er.current.panelDataArrayChanged=!0)},[]),ev=h(()=>({collapsePanel:el,direction:r,dragState:E,expandPanel:ea,getPanelSize:ei,getPanelStyle:eu,groupId:w,isPanelCollapsed:eo,isPanelExpanded:ec,reevaluatePanelConstraints:ep,registerPanel:ed,registerResizeHandle:es,resizePanel:ef,startDragging:eh,stopDragging:ey,unregisterPanel:em,panelGroupElement:z.current}),[el,E,r,ea,ei,eu,w,eo,ec,ep,ed,es,ef,eh,ey,em]);return a(g.Provider,{value:ev},a(b,{...x,children:t,className:n,style:{display:"flex",flexDirection:"horizontal"===r?"row":"column",height:"100%",overflow:"hidden",width:"100%",...v},ref:z,"data-panel-group":"","data-panel-group-direction":r,"data-panel-group-id":w}))}let ee=o((e,t)=>a(Q,{...e,forwardedRef:t}));function et(e,t){return e.findIndex(e=>e===t||e.id===t.id)}function en(e,t,n){let r=et(e,t),l=r===e.length-1,a=n[r];return{...t.constraints,panelSize:a,pivotIndices:l?[r-1,r]:[r,r+1]}}function er({children:e=null,className:t="",disabled:n=!1,id:r,onDragging:l,style:i={},tabIndex:u=0,tagName:o="div",...f}){let p=y(null),h=y({onDragging:l});s(()=>{h.current.onDragging=l});let v=d(g);if(null===v)throw Error("PanelResizeHandle components must be rendered within a PanelGroup container");let{direction:b,dragState:x,groupId:w,registerResizeHandle:z,startDragging:E,stopDragging:C,panelGroupElement:I}=v,A=k(r),j=(null==x?void 0:x.dragHandleId)===A,[D,P]=m(!1),[Z,R]=m(null),T=c(()=>{let e=p.current;M(e),e.blur(),C();let{onDragging:t}=h.current;t&&t(!1)},[C]);s(()=>{if(n)R(null);else{let e=z(A);R(()=>e)}},[n,A,z]),s(()=>{if(n||null==Z||!j)return;let e=e=>{Z(e)},t=e=>{Z(e)},r=p.current;M(r);let l=r.ownerDocument;return l.body.addEventListener("contextmenu",T),l.body.addEventListener("mousemove",e),l.body.addEventListener("touchmove",e),l.body.addEventListener("mouseleave",t),window.addEventListener("mouseup",T),window.addEventListener("touchend",T),()=>{l.body.removeEventListener("contextmenu",T),l.body.removeEventListener("mousemove",e),l.body.removeEventListener("touchmove",e),l.body.removeEventListener("mouseleave",t),window.removeEventListener("mouseup",T),window.removeEventListener("touchend",T)}},[b,n,j,Z,T]),function({disabled:e,handleId:t,resizeHandler:n,panelGroupElement:r}){s(()=>{if(e||null==n||null==r)return;let l=N(t,r);if(null==l)return;let a=e=>{if(!e.defaultPrevented)switch(e.key){case"ArrowDown":case"ArrowLeft":case"ArrowRight":case"ArrowUp":case"End":case"Home":e.preventDefault(),n(e);break;case"F6":{e.preventDefault();let n=l.getAttribute("data-panel-group-id");M(n);let a=S(n,r),i=L(n,t,r);M(null!==i);let u=e.shiftKey?i>0?i-1:a.length-1:i+1<a.length?i+1:0;a[u].focus()}}};return l.addEventListener("keydown",a),()=>{l.removeEventListener("keydown",a)}},[r,e,t,n])}({disabled:n,handleId:A,resizeHandler:Z,panelGroupElement:I});let F={cursor:q(b),touchAction:"none",userSelect:"none"};return a(o,{...f,children:e,className:t,onBlur:()=>P(!1),onFocus:()=>P(!0),onMouseDown:e=>{E(A,e.nativeEvent);let t=h.current;M(t);let{onDragging:n}=t;n&&n(!0)},onMouseUp:T,onTouchCancel:T,onTouchEnd:T,onTouchStart:e=>{E(A,e.nativeEvent);let t=h.current;M(t);let{onDragging:n}=t;n&&n(!0)},ref:p,role:"separator",style:{...F,...i},tabIndex:u,"data-panel-group-direction":b,"data-panel-group-id":w,"data-resize-handle":"","data-resize-handle-active":j?"pointer":D?"keyboard":void 0,"data-panel-resize-handle-enabled":!n,"data-panel-resize-handle-id":A})}Q.displayName="PanelGroup",ee.displayName="forwardRef(PanelGroup)",er.displayName="PanelResizeHandle"},62484:function(e,t,n){n.d(t,{u:function(){return r}});function r(e,[t,n]){return Math.min(n,Math.max(t,e))}},9270:function(e,t,n){n.d(t,{fC:function(){return k},z$:function(){return z}});var r=n(2265),l=n(98575),a=n(73966),i=n(6741),u=n(80886),o=n(6718),c=n(90420),d=n(71599),s=n(66840),f=n(57437),p="Checkbox",[h,y]=(0,a.b)(p),[m,v]=h(p);function g(e){let{__scopeCheckbox:t,checked:n,children:l,defaultChecked:a,disabled:i,form:o,name:c,onCheckedChange:d,required:s,value:h="on",internal_do_not_use_render:y}=e,[v,g]=(0,u.T)({prop:n,defaultProp:null!=a&&a,onChange:d,caller:p}),[b,x]=r.useState(null),[k,w]=r.useState(null),z=r.useRef(!1),M=!b||!!o||!!b.closest("form"),E={checked:v,disabled:i,setChecked:g,control:b,setControl:x,name:c,form:o,value:h,hasConsumerStoppedPropagationRef:z,required:s,defaultChecked:!C(a)&&a,isFormControl:M,bubbleInput:k,setBubbleInput:w};return(0,f.jsx)(m,{scope:t,...E,children:"function"==typeof y?y(E):l})}var b="CheckboxTrigger",x=r.forwardRef((e,t)=>{let{__scopeCheckbox:n,onKeyDown:a,onClick:u,...o}=e,{control:c,value:d,disabled:p,checked:h,required:y,setControl:m,setChecked:g,hasConsumerStoppedPropagationRef:x,isFormControl:k,bubbleInput:w}=v(b,n),z=(0,l.e)(t,m),M=r.useRef(h);return r.useEffect(()=>{let e=null==c?void 0:c.form;if(e){let t=()=>g(M.current);return e.addEventListener("reset",t),()=>e.removeEventListener("reset",t)}},[c,g]),(0,f.jsx)(s.WV.button,{type:"button",role:"checkbox","aria-checked":C(h)?"mixed":h,"aria-required":y,"data-state":I(h),"data-disabled":p?"":void 0,disabled:p,value:d,...o,ref:z,onKeyDown:(0,i.M)(a,e=>{"Enter"===e.key&&e.preventDefault()}),onClick:(0,i.M)(u,e=>{g(e=>!!C(e)||!e),w&&k&&(x.current=e.isPropagationStopped(),x.current||e.stopPropagation())})})});x.displayName=b;var k=r.forwardRef((e,t)=>{let{__scopeCheckbox:n,name:r,checked:l,defaultChecked:a,required:i,disabled:u,value:o,onCheckedChange:c,form:d,...s}=e;return(0,f.jsx)(g,{__scopeCheckbox:n,checked:l,defaultChecked:a,disabled:u,required:i,onCheckedChange:c,name:r,form:d,value:o,internal_do_not_use_render:e=>{let{isFormControl:r}=e;return(0,f.jsxs)(f.Fragment,{children:[(0,f.jsx)(x,{...s,ref:t,__scopeCheckbox:n}),r&&(0,f.jsx)(E,{__scopeCheckbox:n})]})}})});k.displayName=p;var w="CheckboxIndicator",z=r.forwardRef((e,t)=>{let{__scopeCheckbox:n,forceMount:r,...l}=e,a=v(w,n);return(0,f.jsx)(d.z,{present:r||C(a.checked)||!0===a.checked,children:(0,f.jsx)(s.WV.span,{"data-state":I(a.checked),"data-disabled":a.disabled?"":void 0,...l,ref:t,style:{pointerEvents:"none",...e.style}})})});z.displayName=w;var M="CheckboxBubbleInput",E=r.forwardRef((e,t)=>{let{__scopeCheckbox:n,...a}=e,{control:i,hasConsumerStoppedPropagationRef:u,checked:d,defaultChecked:p,required:h,disabled:y,name:m,value:g,form:b,bubbleInput:x,setBubbleInput:k}=v(M,n),w=(0,l.e)(t,k),z=(0,o.D)(d),E=(0,c.t)(i);r.useEffect(()=>{if(!x)return;let e=Object.getOwnPropertyDescriptor(window.HTMLInputElement.prototype,"checked").set,t=!u.current;if(z!==d&&e){let n=new Event("click",{bubbles:t});x.indeterminate=C(d),e.call(x,!C(d)&&d),x.dispatchEvent(n)}},[x,z,d,u]);let I=r.useRef(!C(d)&&d);return(0,f.jsx)(s.WV.input,{type:"checkbox","aria-hidden":!0,defaultChecked:null!=p?p:I.current,required:h,disabled:y,name:m,value:g,form:b,...a,tabIndex:-1,ref:w,style:{...a.style,...E,position:"absolute",pointerEvents:"none",opacity:0,margin:0,transform:"translateX(-100%)"}})});function C(e){return"indeterminate"===e}function I(e){return C(e)?"indeterminate":e?"checked":"unchecked"}E.displayName=M},20271:function(e,t,n){n.d(t,{VY:function(){return j},aV:function(){return S},fC:function(){return A},xz:function(){return L}});var r=n(2265),l=n(6741),a=n(73966),i=n(1353),u=n(71599),o=n(66840),c=n(29114),d=n(80886),s=n(99255),f=n(57437),p="Tabs",[h,y]=(0,a.b)(p,[i.Pc]),m=(0,i.Pc)(),[v,g]=h(p),b=r.forwardRef((e,t)=>{let{__scopeTabs:n,value:r,onValueChange:l,defaultValue:a,orientation:i="horizontal",dir:u,activationMode:h="automatic",...y}=e,m=(0,c.gm)(u),[g,b]=(0,d.T)({prop:r,onChange:l,defaultProp:null!=a?a:"",caller:p});return(0,f.jsx)(v,{scope:n,baseId:(0,s.M)(),value:g,onValueChange:b,orientation:i,dir:m,activationMode:h,children:(0,f.jsx)(o.WV.div,{dir:m,"data-orientation":i,...y,ref:t})})});b.displayName=p;var x="TabsList",k=r.forwardRef((e,t)=>{let{__scopeTabs:n,loop:r=!0,...l}=e,a=g(x,n),u=m(n);return(0,f.jsx)(i.fC,{asChild:!0,...u,orientation:a.orientation,dir:a.dir,loop:r,children:(0,f.jsx)(o.WV.div,{role:"tablist","aria-orientation":a.orientation,...l,ref:t})})});k.displayName=x;var w="TabsTrigger",z=r.forwardRef((e,t)=>{let{__scopeTabs:n,value:r,disabled:a=!1,...u}=e,c=g(w,n),d=m(n),s=C(c.baseId,r),p=I(c.baseId,r),h=r===c.value;return(0,f.jsx)(i.ck,{asChild:!0,...d,focusable:!a,active:h,children:(0,f.jsx)(o.WV.button,{type:"button",role:"tab","aria-selected":h,"aria-controls":p,"data-state":h?"active":"inactive","data-disabled":a?"":void 0,disabled:a,id:s,...u,ref:t,onMouseDown:(0,l.M)(e.onMouseDown,e=>{a||0!==e.button||!1!==e.ctrlKey?e.preventDefault():c.onValueChange(r)}),onKeyDown:(0,l.M)(e.onKeyDown,e=>{[" ","Enter"].includes(e.key)&&c.onValueChange(r)}),onFocus:(0,l.M)(e.onFocus,()=>{let e="manual"!==c.activationMode;h||a||!e||c.onValueChange(r)})})})});z.displayName=w;var M="TabsContent",E=r.forwardRef((e,t)=>{let{__scopeTabs:n,value:l,forceMount:a,children:i,...c}=e,d=g(M,n),s=C(d.baseId,l),p=I(d.baseId,l),h=l===d.value,y=r.useRef(h);return r.useEffect(()=>{let e=requestAnimationFrame(()=>y.current=!1);return()=>cancelAnimationFrame(e)},[]),(0,f.jsx)(u.z,{present:a||h,children:n=>{let{present:r}=n;return(0,f.jsx)(o.WV.div,{"data-state":h?"active":"inactive","data-orientation":d.orientation,role:"tabpanel","aria-labelledby":s,hidden:!r,id:p,tabIndex:0,...c,ref:t,style:{...e.style,animationDuration:y.current?"0s":void 0},children:r&&i})}})});function C(e,t){return"".concat(e,"-trigger-").concat(t)}function I(e,t){return"".concat(e,"-content-").concat(t)}E.displayName=M;var A=b,S=k,L=z,j=E},6718:function(e,t,n){n.d(t,{D:function(){return l}});var r=n(2265);function l(e){let t=r.useRef({value:e,previous:e});return r.useMemo(()=>(t.current.value!==e&&(t.current.previous=t.current.value,t.current.value=e),t.current.previous),[e])}}}]);
|
|
2
|
+
//# sourceMappingURL=6280-50b751f993f2fe4f.js.map
|