@exulu/frontend 1.10.0 → 1.11.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (174) hide show
  1. package/dist/.next/BUILD_ID +1 -1
  2. package/dist/.next/app-build-manifest.json +163 -160
  3. package/dist/.next/app-path-routes-manifest.json +1 -1
  4. package/dist/.next/build-manifest.json +2 -2
  5. package/dist/.next/prerender-manifest.json +1 -1
  6. package/dist/.next/server/app/(application)/agents/edit/[id]/page_client-reference-manifest.js +1 -1
  7. package/dist/.next/server/app/(application)/agents/page_client-reference-manifest.js +1 -1
  8. package/dist/.next/server/app/(application)/chat/[agent]/[session]/page.js +1 -1
  9. package/dist/.next/server/app/(application)/chat/[agent]/[session]/page_client-reference-manifest.js +1 -1
  10. package/dist/.next/server/app/(application)/chat/[agent]/page_client-reference-manifest.js +1 -1
  11. package/dist/.next/server/app/(application)/chat/page_client-reference-manifest.js +1 -1
  12. package/dist/.next/server/app/(application)/configuration/page_client-reference-manifest.js +1 -1
  13. package/dist/.next/server/app/(application)/dashboard/page_client-reference-manifest.js +1 -1
  14. package/dist/.next/server/app/(application)/data/[[...query]]/page.js +2 -2
  15. package/dist/.next/server/app/(application)/data/[[...query]]/page_client-reference-manifest.js +1 -1
  16. package/dist/.next/server/app/(application)/evals/[id]/page.js +1 -1
  17. package/dist/.next/server/app/(application)/evals/[id]/page.js.nft.json +1 -1
  18. package/dist/.next/server/app/(application)/evals/[id]/page_client-reference-manifest.js +1 -1
  19. package/dist/.next/server/app/(application)/evals/cases/page.js +1 -1
  20. package/dist/.next/server/app/(application)/evals/cases/page.js.nft.json +1 -1
  21. package/dist/.next/server/app/(application)/evals/cases/page_client-reference-manifest.js +1 -1
  22. package/dist/.next/server/app/(application)/evals/page_client-reference-manifest.js +1 -1
  23. package/dist/.next/server/app/(application)/explorer/page_client-reference-manifest.js +1 -1
  24. package/dist/.next/server/app/(application)/keys/page_client-reference-manifest.js +1 -1
  25. package/dist/.next/server/app/(application)/page_client-reference-manifest.js +1 -1
  26. package/dist/.next/server/app/(application)/projects/[project]/page.js +1 -1
  27. package/dist/.next/server/app/(application)/projects/[project]/page_client-reference-manifest.js +1 -1
  28. package/dist/.next/server/app/(application)/projects/page_client-reference-manifest.js +1 -1
  29. package/dist/.next/server/app/(application)/prompts/page_client-reference-manifest.js +1 -1
  30. package/dist/.next/server/app/(application)/roles/page_client-reference-manifest.js +1 -1
  31. package/dist/.next/server/app/(application)/token/page_client-reference-manifest.js +1 -1
  32. package/dist/.next/server/app/(application)/users/page_client-reference-manifest.js +1 -1
  33. package/dist/.next/server/app/(application)/variables/create/page_client-reference-manifest.js +1 -1
  34. package/dist/.next/server/app/(application)/variables/edit/[variable_id]/page_client-reference-manifest.js +1 -1
  35. package/dist/.next/server/app/(application)/variables/page_client-reference-manifest.js +1 -1
  36. package/dist/.next/server/app/(application)/variables/usage/[variable_id]/page_client-reference-manifest.js +1 -1
  37. package/dist/.next/server/app/(application)/workflows/page_client-reference-manifest.js +1 -1
  38. package/dist/.next/server/app/(authentication)/login/page_client-reference-manifest.js +1 -1
  39. package/dist/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  40. package/dist/.next/server/app/_not-found.html +1 -1
  41. package/dist/.next/server/app/_not-found.rsc +1 -1
  42. package/dist/.next/server/app-paths-manifest.json +5 -5
  43. package/dist/.next/server/chunks/2270.js +145 -132
  44. package/dist/.next/server/chunks/{5084.js → 2587.js} +1 -1
  45. package/dist/.next/server/chunks/3503.js +1 -1
  46. package/dist/.next/server/chunks/5485.js +1 -1
  47. package/dist/.next/server/chunks/5974.js +1 -1
  48. package/dist/.next/server/chunks/7944.js +1 -1
  49. package/dist/.next/server/chunks/8286.js +1 -1
  50. package/dist/.next/server/middleware-manifest.json +5 -5
  51. package/dist/.next/server/pages/404.html +1 -1
  52. package/dist/.next/server/pages/500.html +1 -1
  53. package/dist/.next/server/server-reference-manifest.json +1 -1
  54. package/dist/.next/static/chunks/1707-06e693c4a709c147.js +2 -0
  55. package/dist/.next/static/chunks/1707-06e693c4a709c147.js.map +1 -0
  56. package/dist/.next/static/chunks/{1957-cf44b1d31a9c7d5c.js → 1957-34f17de1e14e45de.js} +1 -1
  57. package/dist/.next/static/chunks/{1957-cf44b1d31a9c7d5c.js.map → 1957-34f17de1e14e45de.js.map} +1 -1
  58. package/dist/.next/static/chunks/{2293-48a95904b834eccc.js → 2293-592e22dde70d632b.js} +1 -1
  59. package/dist/.next/static/chunks/{2293-48a95904b834eccc.js.map → 2293-592e22dde70d632b.js.map} +1 -1
  60. package/dist/.next/static/chunks/2534-3dd7a9fabfbdb9d8.js +2 -0
  61. package/dist/.next/static/chunks/2534-3dd7a9fabfbdb9d8.js.map +1 -0
  62. package/dist/.next/static/chunks/2823-324b1cd8f15ff9c5.js +2 -0
  63. package/dist/.next/static/chunks/2823-324b1cd8f15ff9c5.js.map +1 -0
  64. package/dist/.next/static/chunks/3246-1812de142455a0ac.js +2 -0
  65. package/dist/.next/static/chunks/3246-1812de142455a0ac.js.map +1 -0
  66. package/dist/.next/static/chunks/{3750-e3d1b2cccd265190.js → 3750-d0ae5d73288be8de.js} +2 -2
  67. package/dist/.next/static/chunks/3750-d0ae5d73288be8de.js.map +1 -0
  68. package/dist/.next/static/chunks/{3832-d7782d6a2771ae6c.js → 3832-0b8edbcc671f4cc0.js} +2 -2
  69. package/dist/.next/static/chunks/3832-0b8edbcc671f4cc0.js.map +1 -0
  70. package/dist/.next/static/chunks/{4386-45b79e656a244d8a.js → 4386-21ac377a719ebdfa.js} +1 -1
  71. package/dist/.next/static/chunks/{4386-45b79e656a244d8a.js.map → 4386-21ac377a719ebdfa.js.map} +1 -1
  72. package/dist/.next/static/chunks/4612-da512770f949561a.js +2 -0
  73. package/dist/.next/static/chunks/4612-da512770f949561a.js.map +1 -0
  74. package/dist/.next/static/chunks/{5825-efd4db1da512bd7f.js → 4760-d5ceb992b68e35ca.js} +2 -2
  75. package/dist/.next/static/chunks/4760-d5ceb992b68e35ca.js.map +1 -0
  76. package/dist/.next/static/chunks/{6367-59655a85d75e19be.js → 6367-aa5020cbea5354e2.js} +1 -1
  77. package/dist/.next/static/chunks/{6367-59655a85d75e19be.js.map → 6367-aa5020cbea5354e2.js.map} +1 -1
  78. package/dist/.next/static/chunks/6373-3eee0b6c8b8fd459.js +2 -0
  79. package/dist/.next/static/chunks/6373-3eee0b6c8b8fd459.js.map +1 -0
  80. package/dist/.next/static/chunks/{8030-9c926ea4dfd3a54e.js → 8030-5d38a3f1a4ad44cb.js} +1 -1
  81. package/dist/.next/static/chunks/{8030-9c926ea4dfd3a54e.js.map → 8030-5d38a3f1a4ad44cb.js.map} +1 -1
  82. package/dist/.next/static/chunks/9105-143f12397a76a332.js +2 -0
  83. package/dist/.next/static/chunks/9105-143f12397a76a332.js.map +1 -0
  84. package/dist/.next/static/chunks/9877-378934ae38c6760c.js +2 -0
  85. package/dist/.next/static/chunks/9877-378934ae38c6760c.js.map +1 -0
  86. package/dist/.next/static/chunks/{9953-95900a236271a222.js → 9953-02d5b52553a5c573.js} +2 -2
  87. package/dist/.next/static/chunks/{9953-95900a236271a222.js.map → 9953-02d5b52553a5c573.js.map} +1 -1
  88. package/dist/.next/static/chunks/app/(application)/agents/edit/[id]/{page-e4a4693953329671.js → page-37918149a8e909b0.js} +2 -2
  89. package/dist/.next/static/chunks/app/(application)/agents/edit/[id]/{page-e4a4693953329671.js.map → page-37918149a8e909b0.js.map} +1 -1
  90. package/dist/.next/static/chunks/app/(application)/agents/{page-b77c21a993c55901.js → page-9cff3b35b042d46a.js} +1 -1
  91. package/dist/.next/static/chunks/app/(application)/agents/{page-b77c21a993c55901.js.map → page-9cff3b35b042d46a.js.map} +1 -1
  92. package/dist/.next/static/chunks/app/(application)/chat/[agent]/[session]/page-53a99d8df53380c7.js +2 -0
  93. package/dist/.next/static/chunks/app/(application)/chat/[agent]/[session]/page-53a99d8df53380c7.js.map +1 -0
  94. package/dist/.next/static/chunks/app/(application)/chat/{layout-093baa26f89338bc.js → layout-ba702af6bb56baa2.js} +1 -1
  95. package/dist/.next/static/chunks/app/(application)/chat/{layout-093baa26f89338bc.js.map → layout-ba702af6bb56baa2.js.map} +1 -1
  96. package/dist/.next/static/chunks/app/(application)/chat/{page-8a1fcfb68cf9c8c0.js → page-8b00a98d285829b1.js} +1 -1
  97. package/dist/.next/static/chunks/app/(application)/chat/{page-8a1fcfb68cf9c8c0.js.map → page-8b00a98d285829b1.js.map} +1 -1
  98. package/dist/.next/static/chunks/app/(application)/configuration/{page-f315ede6d66922e6.js → page-1e978e117d5086a1.js} +1 -1
  99. package/dist/.next/static/chunks/app/(application)/configuration/{page-f315ede6d66922e6.js.map → page-1e978e117d5086a1.js.map} +1 -1
  100. package/dist/.next/static/chunks/app/(application)/dashboard/{page-4a1956febf5235b6.js → page-c54b4bc8d0ac4ac8.js} +1 -1
  101. package/dist/.next/static/chunks/app/(application)/dashboard/{page-4a1956febf5235b6.js.map → page-c54b4bc8d0ac4ac8.js.map} +1 -1
  102. package/dist/.next/static/chunks/app/(application)/data/[[...query]]/{layout-0c7c1b0e1713bf60.js → layout-dfdb5c1cdc7ddefc.js} +2 -2
  103. package/dist/.next/static/chunks/app/(application)/data/[[...query]]/{layout-0c7c1b0e1713bf60.js.map → layout-dfdb5c1cdc7ddefc.js.map} +1 -1
  104. package/dist/.next/static/chunks/app/(application)/data/[[...query]]/page-faaee5fe82b45966.js +2 -0
  105. package/dist/.next/static/chunks/app/(application)/data/[[...query]]/page-faaee5fe82b45966.js.map +1 -0
  106. package/dist/.next/static/chunks/app/(application)/evals/[id]/{page-a7728cf9b0524489.js → page-c956d9892676aa4f.js} +2 -2
  107. package/dist/.next/static/chunks/app/(application)/evals/[id]/page-c956d9892676aa4f.js.map +1 -0
  108. package/dist/.next/static/chunks/app/(application)/evals/cases/page-6b4dde82376e9aac.js +2 -0
  109. package/dist/.next/static/chunks/app/(application)/evals/cases/page-6b4dde82376e9aac.js.map +1 -0
  110. package/dist/.next/static/chunks/app/(application)/evals/{page-8b38d8d29f275704.js → page-944bfc4f0a001e4c.js} +1 -1
  111. package/dist/.next/static/chunks/app/(application)/evals/page-944bfc4f0a001e4c.js.map +1 -0
  112. package/dist/.next/static/chunks/app/(application)/explorer/page-07d67145bb176711.js +2 -0
  113. package/dist/.next/static/chunks/app/(application)/explorer/page-07d67145bb176711.js.map +1 -0
  114. package/dist/.next/static/chunks/app/(application)/keys/{page-afe59c91cc347208.js → page-6c0cd9ef20cd1461.js} +2 -2
  115. package/dist/.next/static/chunks/app/(application)/keys/{page-afe59c91cc347208.js.map → page-6c0cd9ef20cd1461.js.map} +1 -1
  116. package/dist/.next/static/chunks/app/(application)/projects/[project]/{page-f04fd5291a1ef7b1.js → page-5e2be54e76b8509c.js} +2 -2
  117. package/dist/.next/static/chunks/app/(application)/projects/[project]/{page-f04fd5291a1ef7b1.js.map → page-5e2be54e76b8509c.js.map} +1 -1
  118. package/dist/.next/static/chunks/app/(application)/projects/{layout-a8e1830ef3faafb9.js → layout-f2e0f42a08c96bb8.js} +1 -1
  119. package/dist/.next/static/chunks/app/(application)/projects/{layout-a8e1830ef3faafb9.js.map → layout-f2e0f42a08c96bb8.js.map} +1 -1
  120. package/dist/.next/static/chunks/app/(application)/prompts/{page-2c500e9898447506.js → page-2c03bbe32800acc3.js} +2 -2
  121. package/dist/.next/static/chunks/app/(application)/prompts/{page-2c500e9898447506.js.map → page-2c03bbe32800acc3.js.map} +1 -1
  122. package/dist/.next/static/chunks/app/(application)/roles/{page-873911198c17d9a7.js → page-b977b5c658004717.js} +1 -1
  123. package/dist/.next/static/chunks/app/(application)/roles/{page-873911198c17d9a7.js.map → page-b977b5c658004717.js.map} +1 -1
  124. package/dist/.next/static/chunks/app/(application)/token/{page-3acc39cb8a718331.js → page-08596ece49a811b9.js} +2 -2
  125. package/dist/.next/static/chunks/app/(application)/token/page-08596ece49a811b9.js.map +1 -0
  126. package/dist/.next/static/chunks/app/(application)/users/{page-0d7f0d7e80cd1436.js → page-49212081be40aeca.js} +2 -2
  127. package/dist/.next/static/chunks/app/(application)/users/{page-0d7f0d7e80cd1436.js.map → page-49212081be40aeca.js.map} +1 -1
  128. package/dist/.next/static/chunks/app/(application)/variables/create/{page-8ebf4e3d4d17443b.js → page-9ce762918374f616.js} +1 -1
  129. package/dist/.next/static/chunks/app/(application)/variables/create/{page-8ebf4e3d4d17443b.js.map → page-9ce762918374f616.js.map} +1 -1
  130. package/dist/.next/static/chunks/app/(application)/variables/edit/[variable_id]/{page-006145e82e054e72.js → page-0e2b7038546d9f7a.js} +1 -1
  131. package/dist/.next/static/chunks/app/(application)/variables/edit/[variable_id]/{page-006145e82e054e72.js.map → page-0e2b7038546d9f7a.js.map} +1 -1
  132. package/dist/.next/static/chunks/app/(application)/variables/{page-51a8aeece444d388.js → page-141d5d3f735454fe.js} +1 -1
  133. package/dist/.next/static/chunks/app/(application)/variables/{page-51a8aeece444d388.js.map → page-141d5d3f735454fe.js.map} +1 -1
  134. package/dist/.next/static/chunks/app/(application)/variables/usage/[variable_id]/{page-8f5cfc9565fd919a.js → page-fb1bb3ea6f7cae47.js} +1 -1
  135. package/dist/.next/static/chunks/app/(application)/variables/usage/[variable_id]/{page-8f5cfc9565fd919a.js.map → page-fb1bb3ea6f7cae47.js.map} +1 -1
  136. package/dist/.next/static/chunks/app/(application)/workflows/{page-e38f9456120dab69.js → page-2b839fdbc55c297b.js} +2 -2
  137. package/dist/.next/static/chunks/app/(application)/workflows/page-2b839fdbc55c297b.js.map +1 -0
  138. package/dist/.next/static/css/0f539b50cca35462.css +4 -0
  139. package/dist/.next/static/css/0f539b50cca35462.css.map +1 -0
  140. package/dist/.next/static/css/e3f2a16ab7676b05.css.map +1 -1
  141. package/package.json +1 -1
  142. package/dist/.next/static/chunks/1685-939396dad2f8f1e0.js +0 -2
  143. package/dist/.next/static/chunks/1685-939396dad2f8f1e0.js.map +0 -1
  144. package/dist/.next/static/chunks/3171-6996819b8863d41f.js +0 -2
  145. package/dist/.next/static/chunks/3171-6996819b8863d41f.js.map +0 -1
  146. package/dist/.next/static/chunks/3750-e3d1b2cccd265190.js.map +0 -1
  147. package/dist/.next/static/chunks/3832-d7782d6a2771ae6c.js.map +0 -1
  148. package/dist/.next/static/chunks/4419-b9be79d8cd46a97d.js +0 -2
  149. package/dist/.next/static/chunks/4419-b9be79d8cd46a97d.js.map +0 -1
  150. package/dist/.next/static/chunks/5110-098aa924c3108fa4.js +0 -2
  151. package/dist/.next/static/chunks/5110-098aa924c3108fa4.js.map +0 -1
  152. package/dist/.next/static/chunks/5825-efd4db1da512bd7f.js.map +0 -1
  153. package/dist/.next/static/chunks/6280-50b751f993f2fe4f.js +0 -2
  154. package/dist/.next/static/chunks/6280-50b751f993f2fe4f.js.map +0 -1
  155. package/dist/.next/static/chunks/6373-aef582adc575d3ca.js +0 -2
  156. package/dist/.next/static/chunks/6373-aef582adc575d3ca.js.map +0 -1
  157. package/dist/.next/static/chunks/9105-d8ff41060f7ffc85.js +0 -2
  158. package/dist/.next/static/chunks/9105-d8ff41060f7ffc85.js.map +0 -1
  159. package/dist/.next/static/chunks/app/(application)/chat/[agent]/[session]/page-d59534ca19eee51f.js +0 -2
  160. package/dist/.next/static/chunks/app/(application)/chat/[agent]/[session]/page-d59534ca19eee51f.js.map +0 -1
  161. package/dist/.next/static/chunks/app/(application)/data/[[...query]]/page-7db6bfbf02606136.js +0 -2
  162. package/dist/.next/static/chunks/app/(application)/data/[[...query]]/page-7db6bfbf02606136.js.map +0 -1
  163. package/dist/.next/static/chunks/app/(application)/evals/[id]/page-a7728cf9b0524489.js.map +0 -1
  164. package/dist/.next/static/chunks/app/(application)/evals/cases/page-827f50c6d1f150d0.js +0 -2
  165. package/dist/.next/static/chunks/app/(application)/evals/cases/page-827f50c6d1f150d0.js.map +0 -1
  166. package/dist/.next/static/chunks/app/(application)/evals/page-8b38d8d29f275704.js.map +0 -1
  167. package/dist/.next/static/chunks/app/(application)/explorer/page-e6b1c034c07776e2.js +0 -2
  168. package/dist/.next/static/chunks/app/(application)/explorer/page-e6b1c034c07776e2.js.map +0 -1
  169. package/dist/.next/static/chunks/app/(application)/token/page-3acc39cb8a718331.js.map +0 -1
  170. package/dist/.next/static/chunks/app/(application)/workflows/page-e38f9456120dab69.js.map +0 -1
  171. package/dist/.next/static/css/9c08ae5d990a6b14.css +0 -4
  172. package/dist/.next/static/css/9c08ae5d990a6b14.css.map +0 -1
  173. /package/dist/.next/static/{3j63p6b3zZZB_v1Hn8Mxp → exslB-IPXi_veOKFA4L1Z}/_buildManifest.js +0 -0
  174. /package/dist/.next/static/{3j63p6b3zZZB_v1Hn8Mxp → exslB-IPXi_veOKFA4L1Z}/_ssgManifest.js +0 -0
@@ -1 +0,0 @@
1
- {"version":3,"file":"static/chunks/3750-e3d1b2cccd265190.js","mappings":"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","sources":["webpack://_N_E/./components/ai-elements/code-block.tsx","webpack://_N_E/./components/ai-elements/response.tsx","webpack://_N_E/./components/ui/alert.tsx","webpack://_N_E/./components/ui/collapsible.tsx","webpack://_N_E/./components/ui/tabs.tsx","webpack://_N_E/./components/ui/use-toast.ts","webpack://_N_E/./hooks/use-uppy.tsx","webpack://_N_E/./components/uppy-dashboard.tsx"],"sourcesContent":["'use client';\n\nimport { Button } from '@/components/ui/button';\nimport { cn } from '@/lib/utils';\nimport { CheckIcon, CopyIcon } from 'lucide-react';\nimport type { ComponentProps, HTMLAttributes, ReactNode } from 'react';\nimport { createContext, useContext, useState } from 'react';\nimport { Prism as SyntaxHighlighter } from 'react-syntax-highlighter';\nimport {\n oneDark,\n oneLight,\n} from 'react-syntax-highlighter/dist/esm/styles/prism';\n\ntype CodeBlockContextType = {\n code: string;\n};\n\nconst CodeBlockContext = createContext<CodeBlockContextType>({\n code: '',\n});\n\nexport type CodeBlockProps = HTMLAttributes<HTMLDivElement> & {\n code: string;\n language: string;\n showLineNumbers?: boolean;\n children?: ReactNode;\n};\n\nexport const CodeBlock = ({\n code,\n language,\n showLineNumbers = false,\n className,\n children,\n ...props\n}: CodeBlockProps) => (\n <CodeBlockContext.Provider value={{ code }}>\n <div\n className={cn(\n 'relative w-full overflow-hidden rounded-md border bg-background text-foreground',\n className\n )}\n {...props}\n >\n <div className=\"relative\">\n <SyntaxHighlighter\n className=\"overflow-hidden dark:hidden\"\n codeTagProps={{\n className: 'font-mono text-sm',\n }}\n customStyle={{\n margin: 0,\n padding: '1rem',\n fontSize: '0.875rem',\n background: 'hsl(var(--background))',\n color: 'hsl(var(--foreground))',\n }}\n language={language}\n lineNumberStyle={{\n color: 'hsl(var(--muted-foreground))',\n paddingRight: '1rem',\n minWidth: '2.5rem',\n }}\n showLineNumbers={showLineNumbers}\n style={oneLight}\n >\n {code}\n </SyntaxHighlighter>\n <SyntaxHighlighter\n className=\"hidden overflow-hidden dark:block\"\n codeTagProps={{\n className: 'font-mono text-sm',\n }}\n customStyle={{\n margin: 0,\n padding: '1rem',\n fontSize: '0.875rem',\n background: 'hsl(var(--background))',\n color: 'hsl(var(--foreground))',\n }}\n language={language}\n lineNumberStyle={{\n color: 'hsl(var(--muted-foreground))',\n paddingRight: '1rem',\n minWidth: '2.5rem',\n }}\n showLineNumbers={showLineNumbers}\n style={oneDark}\n >\n {code}\n </SyntaxHighlighter>\n {children && (\n <div className=\"absolute top-2 right-2 flex items-center gap-2\">\n {children}\n </div>\n )}\n </div>\n </div>\n </CodeBlockContext.Provider>\n);\n\nexport type CodeBlockCopyButtonProps = ComponentProps<typeof Button> & {\n onCopy?: () => void;\n onError?: (error: Error) => void;\n timeout?: number;\n};\n\nexport const CodeBlockCopyButton = ({\n onCopy,\n onError,\n timeout = 2000,\n children,\n className,\n ...props\n}: CodeBlockCopyButtonProps) => {\n const [isCopied, setIsCopied] = useState(false);\n const { code } = useContext(CodeBlockContext);\n\n const copyToClipboard = async () => {\n if (typeof window === 'undefined' || !navigator.clipboard.writeText) {\n onError?.(new Error('Clipboard API not available'));\n return;\n }\n\n try {\n await navigator.clipboard.writeText(code);\n setIsCopied(true);\n onCopy?.();\n setTimeout(() => setIsCopied(false), timeout);\n } catch (error) {\n onError?.(error as Error);\n }\n };\n\n const Icon = isCopied ? CheckIcon : CopyIcon;\n\n return (\n <Button\n className={cn('shrink-0', className)}\n onClick={copyToClipboard}\n size=\"icon\"\n variant=\"ghost\"\n {...props}\n >\n {children ?? <Icon size={14} />}\n </Button>\n );\n};\n","'use client';\n\nimport { cn } from '@/lib/utils';\nimport type { ComponentProps, HTMLAttributes } from 'react';\nimport { isValidElement, memo } from 'react';\nimport ReactMarkdown, { type Options } from 'react-markdown';\nimport rehypeKatex from 'rehype-katex';\nimport remarkGfm from 'remark-gfm';\nimport remarkMath from 'remark-math';\nimport { CodeBlock, CodeBlockCopyButton } from './code-block';\nimport 'katex/dist/katex.min.css';\nimport hardenReactMarkdown from 'harden-react-markdown';\n\n/**\n * Parses markdown text and removes incomplete tokens to prevent partial rendering\n * of links, images, bold, and italic formatting during streaming.\n */\nfunction parseIncompleteMarkdown(text: string): string {\n if (!text || typeof text !== 'string') {\n return text;\n }\n\n let result = text;\n\n // Handle incomplete links and images\n // Pattern: [...] or ![...] where the closing ] is missing\n const linkImagePattern = /(!?\\[)([^\\]]*?)$/;\n const linkMatch = result.match(linkImagePattern);\n if (linkMatch) {\n // If we have an unterminated [ or ![, remove it and everything after\n const startIndex = result.lastIndexOf(linkMatch[1]);\n result = result.substring(0, startIndex);\n }\n\n // Handle incomplete bold formatting (**)\n const boldPattern = /(\\*\\*)([^*]*?)$/;\n const boldMatch = result.match(boldPattern);\n if (boldMatch) {\n // Count the number of ** in the entire string\n const asteriskPairs = (result.match(/\\*\\*/g) || []).length;\n // If odd number of **, we have an incomplete bold - complete it\n if (asteriskPairs % 2 === 1) {\n result = `${result}**`;\n }\n }\n\n // Handle incomplete italic formatting (__)\n const italicPattern = /(__)([^_]*?)$/;\n const italicMatch = result.match(italicPattern);\n if (italicMatch) {\n // Count the number of __ in the entire string\n const underscorePairs = (result.match(/__/g) || []).length;\n // If odd number of __, we have an incomplete italic - complete it\n if (underscorePairs % 2 === 1) {\n result = `${result}__`;\n }\n }\n\n // Handle incomplete single asterisk italic (*)\n const singleAsteriskPattern = /(\\*)([^*]*?)$/;\n const singleAsteriskMatch = result.match(singleAsteriskPattern);\n if (singleAsteriskMatch) {\n // Count single asterisks that aren't part of **\n const singleAsterisks = result.split('').reduce((acc, char, index) => {\n if (char === '*') {\n // Check if it's part of a ** pair\n const prevChar = result[index - 1];\n const nextChar = result[index + 1];\n if (prevChar !== '*' && nextChar !== '*') {\n return acc + 1;\n }\n }\n return acc;\n }, 0);\n\n // If odd number of single *, we have an incomplete italic - complete it\n if (singleAsterisks % 2 === 1) {\n result = `${result}*`;\n }\n }\n\n // Handle incomplete single underscore italic (_)\n const singleUnderscorePattern = /(_)([^_]*?)$/;\n const singleUnderscoreMatch = result.match(singleUnderscorePattern);\n if (singleUnderscoreMatch) {\n // Count single underscores that aren't part of __\n const singleUnderscores = result.split('').reduce((acc, char, index) => {\n if (char === '_') {\n // Check if it's part of a __ pair\n const prevChar = result[index - 1];\n const nextChar = result[index + 1];\n if (prevChar !== '_' && nextChar !== '_') {\n return acc + 1;\n }\n }\n return acc;\n }, 0);\n\n // If odd number of single _, we have an incomplete italic - complete it\n if (singleUnderscores % 2 === 1) {\n result = `${result}_`;\n }\n }\n\n // Handle incomplete inline code blocks (`) - but avoid code blocks (```)\n const inlineCodePattern = /(`)([^`]*?)$/;\n const inlineCodeMatch = result.match(inlineCodePattern);\n if (inlineCodeMatch) {\n // Check if we're dealing with a code block (triple backticks)\n const hasCodeBlockStart = result.includes('```');\n const codeBlockPattern = /```[\\s\\S]*?```/g;\n const completeCodeBlocks = (result.match(codeBlockPattern) || []).length;\n const allTripleBackticks = (result.match(/```/g) || []).length;\n\n // If we have an odd number of ``` sequences, we're inside an incomplete code block\n // In this case, don't complete inline code\n const insideIncompleteCodeBlock = allTripleBackticks % 2 === 1;\n\n if (!insideIncompleteCodeBlock) {\n // Count the number of single backticks that are NOT part of triple backticks\n let singleBacktickCount = 0;\n for (let i = 0; i < result.length; i++) {\n if (result[i] === '`') {\n // Check if this backtick is part of a triple backtick sequence\n const isTripleStart = result.substring(i, i + 3) === '```';\n const isTripleMiddle =\n i > 0 && result.substring(i - 1, i + 2) === '```';\n const isTripleEnd = i > 1 && result.substring(i - 2, i + 1) === '```';\n\n if (!(isTripleStart || isTripleMiddle || isTripleEnd)) {\n singleBacktickCount++;\n }\n }\n }\n\n // If odd number of single backticks, we have an incomplete inline code - complete it\n if (singleBacktickCount % 2 === 1) {\n result = `${result}\\``;\n }\n }\n }\n\n // Handle incomplete strikethrough formatting (~~)\n const strikethroughPattern = /(~~)([^~]*?)$/;\n const strikethroughMatch = result.match(strikethroughPattern);\n if (strikethroughMatch) {\n // Count the number of ~~ in the entire string\n const tildePairs = (result.match(/~~/g) || []).length;\n // If odd number of ~~, we have an incomplete strikethrough - complete it\n if (tildePairs % 2 === 1) {\n result = `${result}~~`;\n }\n }\n\n return result;\n}\n\n// Create a hardened version of ReactMarkdown\nconst HardenedMarkdown = hardenReactMarkdown(ReactMarkdown);\n\nexport type ResponseProps = HTMLAttributes<HTMLDivElement> & {\n options?: Options;\n children: Options['children'];\n allowedImagePrefixes?: ComponentProps<\n ReturnType<typeof hardenReactMarkdown>\n >['allowedImagePrefixes'];\n allowedLinkPrefixes?: ComponentProps<\n ReturnType<typeof hardenReactMarkdown>\n >['allowedLinkPrefixes'];\n defaultOrigin?: ComponentProps<\n ReturnType<typeof hardenReactMarkdown>\n >['defaultOrigin'];\n parseIncompleteMarkdown?: boolean;\n};\n\nconst components: Options['components'] = {\n ol: ({ node, children, className, ...props }) => (\n <ol className={cn('ml-4 list-outside list-decimal', className)} {...props}>\n {children}\n </ol>\n ),\n li: ({ node, children, className, ...props }) => (\n <li className={cn('py-1', className)} {...props}>\n {children}\n </li>\n ),\n ul: ({ node, children, className, ...props }) => (\n <ul className={cn('ml-4 list-outside list-disc', className)} {...props}>\n {children}\n </ul>\n ),\n hr: ({ node, className, ...props }) => (\n <hr className={cn('my-6 border-border', className)} {...props} />\n ),\n strong: ({ node, children, className, ...props }) => (\n <span className={cn('font-semibold', className)} {...props}>\n {children}\n </span>\n ),\n a: ({ node, children, className, ...props }) => (\n <a\n className={cn('font-medium text-primary underline', className)}\n rel=\"noreferrer\"\n target=\"_blank\"\n {...props}\n >\n {children}\n </a>\n ),\n h1: ({ node, children, className, ...props }) => (\n <h1\n className={cn('mt-6 mb-2 font-semibold text-3xl', className)}\n {...props}\n >\n {children}\n </h1>\n ),\n h2: ({ node, children, className, ...props }) => (\n <h2\n className={cn('mt-6 mb-2 font-semibold text-2xl', className)}\n {...props}\n >\n {children}\n </h2>\n ),\n h3: ({ node, children, className, ...props }) => (\n <h3 className={cn('mt-6 mb-2 font-semibold text-xl', className)} {...props}>\n {children}\n </h3>\n ),\n h4: ({ node, children, className, ...props }) => (\n <h4 className={cn('mt-6 mb-2 font-semibold text-lg', className)} {...props}>\n {children}\n </h4>\n ),\n h5: ({ node, children, className, ...props }) => (\n <h5\n className={cn('mt-6 mb-2 font-semibold text-base', className)}\n {...props}\n >\n {children}\n </h5>\n ),\n h6: ({ node, children, className, ...props }) => (\n <h6 className={cn('mt-6 mb-2 font-semibold text-sm', className)} {...props}>\n {children}\n </h6>\n ),\n table: ({ node, children, className, ...props }) => (\n <div className=\"my-4 overflow-x-auto\">\n <table\n className={cn('w-full border-collapse border border-border', className)}\n {...props}\n >\n {children}\n </table>\n </div>\n ),\n thead: ({ node, children, className, ...props }) => (\n <thead className={cn('bg-muted/50', className)} {...props}>\n {children}\n </thead>\n ),\n tbody: ({ node, children, className, ...props }) => (\n <tbody className={cn('divide-y divide-border', className)} {...props}>\n {children}\n </tbody>\n ),\n tr: ({ node, children, className, ...props }) => (\n <tr className={cn('border-border border-b', className)} {...props}>\n {children}\n </tr>\n ),\n th: ({ node, children, className, ...props }) => (\n <th\n className={cn('px-4 py-2 text-left font-semibold text-sm', className)}\n {...props}\n >\n {children}\n </th>\n ),\n td: ({ node, children, className, ...props }) => (\n <td className={cn('px-4 py-2 text-sm', className)} {...props}>\n {children}\n </td>\n ),\n blockquote: ({ node, children, className, ...props }) => (\n <blockquote\n className={cn(\n 'my-4 border-muted-foreground/30 border-l-4 pl-4 text-muted-foreground italic',\n className\n )}\n {...props}\n >\n {children}\n </blockquote>\n ),\n code: ({ node, className, ...props }) => {\n const inline = node?.position?.start.line === node?.position?.end.line;\n\n if (!inline) {\n return <code className={className} {...props} />;\n }\n\n return (\n <code\n className={cn(\n 'rounded bg-muted px-1.5 py-0.5 font-mono text-sm',\n className\n )}\n {...props}\n />\n );\n },\n pre: ({ node, className, children }) => {\n let language = 'javascript';\n\n if (typeof node?.properties?.className === 'string') {\n language = node.properties.className.replace('language-', '');\n }\n\n // Extract code content from children safely\n let code = '';\n if (\n isValidElement(children) &&\n children.props &&\n typeof children.props.children === 'string'\n ) {\n code = children.props.children;\n } else if (typeof children === 'string') {\n code = children;\n }\n\n return (\n <CodeBlock\n className={cn('my-4 h-auto', className)}\n code={code}\n language={language}\n >\n <CodeBlockCopyButton\n onCopy={() => console.log('Copied code to clipboard')}\n onError={() => console.error('Failed to copy code to clipboard')}\n />\n </CodeBlock>\n );\n },\n};\n\nexport const Response = memo(\n ({\n className,\n options,\n children,\n allowedImagePrefixes,\n allowedLinkPrefixes,\n defaultOrigin,\n parseIncompleteMarkdown: shouldParseIncompleteMarkdown = true,\n ...props\n }: ResponseProps) => {\n // Parse the children to remove incomplete markdown tokens if enabled\n const parsedChildren =\n typeof children === 'string' && shouldParseIncompleteMarkdown\n ? parseIncompleteMarkdown(children)\n : children;\n\n return (\n <div\n className={cn(\n 'size-full [&>*:first-child]:mt-0 [&>*:last-child]:mb-0',\n className\n )}\n {...props}\n >\n <HardenedMarkdown\n allowedImagePrefixes={allowedImagePrefixes ?? ['*']}\n allowedLinkPrefixes={allowedLinkPrefixes ?? ['*']}\n components={components}\n defaultOrigin={defaultOrigin}\n rehypePlugins={[rehypeKatex]}\n remarkPlugins={[remarkGfm, remarkMath]}\n {...options}\n >\n {parsedChildren}\n </HardenedMarkdown>\n </div>\n );\n },\n (prevProps, nextProps) => prevProps.children === nextProps.children\n);\n\nResponse.displayName = 'Response';\n","import { cva, type VariantProps } from \"class-variance-authority\";\nimport * as React from \"react\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst alertVariants = cva(\n \"relative w-full rounded-lg border p-4 [&>svg~*]:pl-7 [&>svg+div]:translate-y-[-3px] [&>svg]:absolute [&>svg]:left-4 [&>svg]:top-4 [&>svg]:text-foreground\",\n {\n variants: {\n variant: {\n default: \"bg-background text-foreground\",\n destructive:\n \"border-destructive/50 text-destructive dark:border-destructive [&>svg]:text-destructive\",\n info: \"border-info/50 text-info dark:border-info [&>svg]:text-info\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n },\n },\n);\n\nconst Alert = React.forwardRef<\n HTMLDivElement,\n React.HTMLAttributes<HTMLDivElement> & VariantProps<typeof alertVariants>\n>(({ className, variant, ...props }, ref) => (\n <div\n ref={ref}\n role=\"alert\"\n className={cn(alertVariants({ variant }), className)}\n {...props}\n />\n));\nAlert.displayName = \"Alert\";\n\nconst AlertTitle = React.forwardRef<\n HTMLParagraphElement,\n React.HTMLAttributes<HTMLHeadingElement>\n>(({ className, ...props }, ref) => (\n <h5\n ref={ref}\n className={cn(\"mb-1 font-medium leading-none tracking-tight\", className)}\n {...props}\n />\n));\nAlertTitle.displayName = \"AlertTitle\";\n\nconst AlertDescription = React.forwardRef<\n HTMLParagraphElement,\n React.HTMLAttributes<HTMLParagraphElement>\n>(({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={cn(\"text-sm [&_p]:leading-relaxed\", className)}\n {...props}\n />\n));\nAlertDescription.displayName = \"AlertDescription\";\n\nexport { Alert, AlertTitle, AlertDescription };\n","\"use client\";\n\nimport * as CollapsiblePrimitive from \"@radix-ui/react-collapsible\";\n\nconst Collapsible = CollapsiblePrimitive.Root;\n\nconst CollapsibleTrigger = CollapsiblePrimitive.CollapsibleTrigger;\n\nconst CollapsibleContent = CollapsiblePrimitive.CollapsibleContent;\n\nexport { Collapsible, CollapsibleTrigger, CollapsibleContent };\n","\"use client\";\n\nimport * as TabsPrimitive from \"@radix-ui/react-tabs\";\nimport * as React from \"react\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst Tabs = TabsPrimitive.Root;\n\nconst TabsList = React.forwardRef<\n React.ElementRef<typeof TabsPrimitive.List>,\n React.ComponentPropsWithoutRef<typeof TabsPrimitive.List>\n>(({ className, ...props }, ref) => (\n <TabsPrimitive.List\n ref={ref}\n className={cn(\n \"inline-flex h-10 items-center justify-center rounded-md bg-muted p-1 text-muted-foreground\",\n className,\n )}\n {...props}\n />\n));\nTabsList.displayName = TabsPrimitive.List.displayName;\n\nconst TabsTrigger = React.forwardRef<\n React.ElementRef<typeof TabsPrimitive.Trigger>,\n React.ComponentPropsWithoutRef<typeof TabsPrimitive.Trigger>\n>(({ className, ...props }, ref) => (\n <TabsPrimitive.Trigger\n ref={ref}\n className={cn(\n \"inline-flex items-center justify-center whitespace-nowrap rounded-sm px-3 py-1.5 text-sm font-medium ring-offset-background transition-all focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 data-[state=active]:bg-background data-[state=active]:text-foreground data-[state=active]:shadow-sm\",\n className,\n )}\n {...props}\n />\n));\nTabsTrigger.displayName = TabsPrimitive.Trigger.displayName;\n\nconst TabsContent = React.forwardRef<\n React.ElementRef<typeof TabsPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof TabsPrimitive.Content>\n>(({ className, ...props }, ref) => (\n <TabsPrimitive.Content\n ref={ref}\n className={cn(\n \"mt-2 ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2\",\n className,\n )}\n {...props}\n />\n));\nTabsContent.displayName = TabsPrimitive.Content.displayName;\n\nexport { Tabs, TabsList, TabsTrigger, TabsContent };\n","\"use client\";\n\n// Inspired by react-hot-toast library\nimport * as React from \"react\";\n\nimport type { ToastActionElement, ToastProps } from \"@/components/ui/toast\";\n\nconst TOAST_LIMIT = 1;\nconst TOAST_REMOVE_DELAY = 1000000;\n\ntype ToasterToast = ToastProps & {\n id: string;\n title?: React.ReactNode;\n description?: React.ReactNode;\n action?: ToastActionElement;\n};\n\nconst actionTypes = {\n ADD_TOAST: \"ADD_TOAST\",\n UPDATE_TOAST: \"UPDATE_TOAST\",\n DISMISS_TOAST: \"DISMISS_TOAST\",\n REMOVE_TOAST: \"REMOVE_TOAST\",\n} as const;\n\nlet count = 0;\n\nfunction genId() {\n count = (count + 1) % Number.MAX_SAFE_INTEGER;\n return count.toString();\n}\n\ntype ActionType = typeof actionTypes;\n\ntype Action =\n | {\n type: ActionType[\"ADD_TOAST\"];\n toast: ToasterToast;\n }\n | {\n type: ActionType[\"UPDATE_TOAST\"];\n toast: Partial<ToasterToast>;\n }\n | {\n type: ActionType[\"DISMISS_TOAST\"];\n toastId?: ToasterToast[\"id\"];\n }\n | {\n type: ActionType[\"REMOVE_TOAST\"];\n toastId?: ToasterToast[\"id\"];\n };\n\ninterface State {\n toasts: ToasterToast[];\n}\n\nconst toastTimeouts = new Map<string, ReturnType<typeof setTimeout>>();\n\nconst addToRemoveQueue = (toastId: string) => {\n if (toastTimeouts.has(toastId)) {\n return;\n }\n\n const timeout = setTimeout(() => {\n toastTimeouts.delete(toastId);\n dispatch({\n type: \"REMOVE_TOAST\",\n toastId: toastId,\n });\n }, TOAST_REMOVE_DELAY);\n\n toastTimeouts.set(toastId, timeout);\n};\n\nexport const reducer = (state: State, action: Action): State => {\n switch (action.type) {\n case \"ADD_TOAST\":\n return {\n ...state,\n toasts: [action.toast, ...state.toasts].slice(0, TOAST_LIMIT),\n };\n\n case \"UPDATE_TOAST\":\n return {\n ...state,\n toasts: state.toasts.map((t) =>\n t.id === action.toast.id ? { ...t, ...action.toast } : t,\n ),\n };\n\n case \"DISMISS_TOAST\": {\n const { toastId } = action;\n\n // ! Side effects ! - This could be extracted into a dismissToast() action,\n // but I'll keep it here for simplicity\n if (toastId) {\n addToRemoveQueue(toastId);\n } else {\n state.toasts.forEach((toast) => {\n addToRemoveQueue(toast.id);\n });\n }\n\n return {\n ...state,\n toasts: state.toasts.map((t) =>\n t.id === toastId || toastId === undefined\n ? {\n ...t,\n open: false,\n }\n : t,\n ),\n };\n }\n case \"REMOVE_TOAST\":\n if (action.toastId === undefined) {\n return {\n ...state,\n toasts: [],\n };\n }\n return {\n ...state,\n toasts: state.toasts.filter((t) => t.id !== action.toastId),\n };\n }\n};\n\nconst listeners: Array<(state: State) => void> = [];\n\nlet memoryState: State = { toasts: [] };\n\nfunction dispatch(action: Action) {\n memoryState = reducer(memoryState, action);\n listeners.forEach((listener) => {\n listener(memoryState);\n });\n}\n\ntype Toast = Omit<ToasterToast, \"id\">;\n\nfunction toast({ ...props }: Toast) {\n const id = genId();\n\n const update = (props: ToasterToast) =>\n dispatch({\n type: \"UPDATE_TOAST\",\n toast: { ...props, id },\n });\n const dismiss = () => dispatch({ type: \"DISMISS_TOAST\", toastId: id });\n\n dispatch({\n type: \"ADD_TOAST\",\n toast: {\n ...props,\n id,\n open: true,\n onOpenChange: (open) => {\n if (!open) dismiss();\n },\n },\n });\n\n return {\n id: id,\n dismiss,\n update,\n };\n}\n\nfunction useToast() {\n const [state, setState] = React.useState<State>(memoryState);\n\n React.useEffect(() => {\n listeners.push(setState);\n return () => {\n const index = listeners.indexOf(setState);\n if (index > -1) {\n listeners.splice(index, 1);\n }\n };\n }, [state]);\n\n return {\n ...state,\n toast,\n dismiss: (toastId?: string) => dispatch({ type: \"DISMISS_TOAST\", toastId }),\n };\n}\n\nexport { useToast, toast };\n","import { useEffect, useState, useContext } from \"react\";\nimport Uppy from \"@uppy/core\";\nimport AwsS3 from \"@uppy/aws-s3\";\nimport \"@uppy/core/dist/style.min.css\";\nimport \"@uppy/dashboard/dist/style.min.css\";\nimport '@uppy/core/dist/style.min.css';\nimport '@uppy/dashboard/dist/style.min.css';\nimport { getToken } from \"@/util/api\";\nimport { ConfigContext } from \"@/components/config-context\";\n\ninterface InitializeOptions {\n backend: string;\n callbacks?: {\n uploadSuccess?: (response: {\n file: any | null;\n url: string\n key: string\n }) => void;\n };\n fileKey?: string;\n fileKeyPrefix?: string;\n maxNumberOfFiles?: number;\n uppyOptions?: {\n id?: string;\n allowedFileTypes: string[];\n };\n useName?: boolean;\n}\n\nexport const initializeUppy = async (options: InitializeOptions): Promise<Uppy> => {\n if (!options.backend) {\n throw new Error(\"No backend set.\")\n }\n const { callbacks, maxNumberOfFiles, uppyOptions } = options || {};\n const { uploadSuccess } = callbacks || {};\n const { allowedFileTypes, id } = uppyOptions || {};\n const token = await getToken()\n\n const uppy = new Uppy({\n autoProceed: true,\n debug: false,\n id: id || \"uppy\",\n restrictions: {\n maxNumberOfFiles: maxNumberOfFiles || 5,\n allowedFileTypes: allowedFileTypes || [\".heic\", \".jpg\", \".jpeg\", \".png\", \".webp\", \".svg\"],\n }\n })\n .use(AwsS3, {\n id: \"Exulu\",\n endpoint: options.backend,\n headers: { \n Authorization: `Bearer ${token}`,\n Session: localStorage.getItem(\"session\") ?? \"\",\n }\n })\n .on(\"file-added\", async (file) => {\n console.debug(\"added\", file);\n })\n .on(\"upload-error\", (file, error) => {\n if (!file?.id) {\n return;\n }\n uppy.removeFile(file?.id);\n console.error(\"error\", error);\n })\n .on(\"upload-success\", (file, response) => {\n if (!response.uploadURL) {\n return;\n }\n if (uploadSuccess) {\n console.log(\"response\", response)\n uploadSuccess({\n file: file,\n key: response.uploadURL.split(\"/\").pop() || \"\",\n url: response.uploadURL,\n });\n }\n });\n\n return uppy;\n};\n\nfunction useUppy(options: InitializeOptions, deps: any[] = []) {\n const configContext = useContext(ConfigContext);\n const [uppy, setUppy] = useState<Uppy | undefined>(undefined);\n useEffect(() => {\n const initUppy = async () => {\n const uppyInstance = await initializeUppy({\n ...options,\n backend: configContext?.backend || \"\",\n });\n setUppy(uppyInstance);\n };\n initUppy()\n return () => {\n if (uppy) {\n uppy.destroy();\n setUppy(undefined);\n }\n };\n }, [...deps]);\n\n return uppy;\n}\n\nexport default useUppy;\n","import useUppy from \"@/hooks/use-uppy\";\nimport { Dashboard } from '@uppy/react';\nimport { useContext, useEffect, useState } from \"react\"\nimport { X, File, ImageIcon, FileText, FilePlus, Download, LoaderIcon, FileWarning, Upload, PlusSquareIcon, EyeIcon, PlusIcon, ChevronRightIcon, ChevronLeftIcon } from \"lucide-react\"\nimport { Button } from \"@/components/ui/button\"\nimport {\n Dialog,\n DialogContent,\n DialogDescription,\n DialogHeader,\n DialogTitle,\n DialogTrigger,\n} from \"@/components/ui/dialog\"\nimport { ScrollArea } from \"@/components/ui/scroll-area\"\nimport '@uppy/core/dist/style.min.css';\nimport '@uppy/dashboard/dist/style.min.css';\nimport { files, S3FileListOutput } from \"@/util/api\"\nimport { useTheme } from \"next-themes\";\nimport { ConfigContext } from \"./config-context\";\nimport { useQuery as useTanstackQuery, useMutation as useTanstackMutation } from \"@tanstack/react-query\";\nimport { Loading } from \"./ui/loading\";\nimport { allFileTypes } from \"@/types/models/agent\";\nimport { Input } from \"./ui/input\";\nimport { DoubleArrowLeftIcon } from \"@radix-ui/react-icons\";\nimport { Card, CardContent, CardHeader, CardTitle } from \"./ui/card\";\nimport { Skeleton } from \"./ui/skeleton\";\n\nexport function FileDataCard({ s3key, children }: { s3key: string, children?: React.ReactNode }) {\n const { data, isLoading, error, refetch } = useTanstackQuery({\n queryKey: ['fileObject', s3key],\n queryFn: async () => {\n if (!s3key) {\n return null;\n }\n const result = await files.object(s3key);\n return result;\n },\n enabled: s3key !== undefined && s3key !== null,\n })\n\n useEffect(() => {\n if (s3key) {\n refetch();\n }\n }, [s3key]);\n\n if (!s3key) {\n return <Card>\n <CardContent className=\"p-3 flex\">\n <p className=\"text-sm text-muted-foreground m-auto\">No file selected</p>\n {children}\n </CardContent>\n </Card>;\n }\n\n let name = s3key;\n let bucket = s3key.split(\"/\")[0];\n name = s3key.split(\"/\").slice(1).join(\"/\");\n // Get the part after _EXULU_\n name = name.split(\"_EXULU_\").pop() || \"\";\n\n return <Card>\n <CardHeader className=\"pb-3\">\n <CardTitle className=\"text-sm max-w-[500px] truncate\">\n {name}\n </CardTitle>\n </CardHeader>\n <CardContent className=\"pt-0\">\n {\n isLoading && (\n <div className=\"space-y-2\">\n <Skeleton className=\"h-4 w-full\" />\n <Skeleton className=\"h-4 w-2/3\" />\n </div>\n )\n }\n {!isLoading && data && (\n <div className=\"space-y-2\">\n <div className=\"flex items-center justify-between text-xs text-muted-foreground\">\n <span className=\"capitalize\">\n {data?.ContentType.split(\"/\").pop()}\n {bucket && ` Bucket: ${bucket}`}\n </span>\n <span>{(data?.ContentLength / 1024 / 1024).toFixed(2)} MB</span>\n </div>\n <div className=\"flex items-center justify-between text-xs text-muted-foreground\">\n <span>Last modified: {new Date(data?.LastModified).toLocaleDateString(\"en-US\", { year: \"numeric\", month: \"long\", day: \"numeric\", hour: \"2-digit\", minute: \"2-digit\" })}</span>\n <Button\n variant=\"secondary\"\n size=\"sm\"\n type=\"button\"\n className=\"h-7 px-2\"\n onClick={() => {\n files.download(s3key).then(async res => {\n console.log(\"res\", res);\n const json = await res.json()\n console.log(\"res\", json);\n const downloadUrl = json.url;\n window.open(downloadUrl, '_blank');\n return;\n })\n }}>\n <span className=\"mr-1 text-xs\">View</span>\n <Download className=\"h-3 w-3\" />\n </Button>\n </div>\n </div>\n )}\n {\n !isLoading && error && (\n <p className=\"text-xs text-muted-foreground\">{error.message}</p>\n )\n }\n {children}\n </CardContent>\n </Card>\n}\n\nexport default function UppyDashboard({ id, allowedFileTypes, dependencies, onConfirm, selectionLimit, buttonText }: {\n id: string,\n buttonText?: string,\n allowedFileTypes?: allFileTypes[],\n selectionLimit: number,\n dependencies: any[],\n onConfirm: (keys: string[]) => void\n}) {\n const [open, setOpen] = useState(false)\n return <Dialog open={open} onOpenChange={setOpen}>\n <DialogTrigger asChild>\n <Button variant=\"outline\">\n {buttonText && (\n <span className=\"mr-2\">{buttonText}</span>\n )\n }\n <FilePlus className=\"h-4 w-4\" />\n </Button>\n </DialogTrigger>\n <DialogContent className=\"sm:max-w-[900px]\">\n <DialogHeader>\n <DialogTitle>File Gallery</DialogTitle>\n <DialogDescription>Browse your previously uploaded files or upload new ones.</DialogDescription>\n </DialogHeader>\n <FileGalleryAndUpload\n id={id}\n allowedFileTypes={allowedFileTypes}\n dependencies={dependencies}\n selectionLimit={selectionLimit}\n onConfirm={(data) => {\n onConfirm(data)\n setOpen(false)\n }}\n />\n </DialogContent>\n </Dialog>;\n}\n\nexport const FileGalleryAndUpload = ({ id, allowedFileTypes, dependencies, onConfirm, selectionLimit }: {\n id: string,\n allowedFileTypes?: allFileTypes[],\n dependencies: any[],\n selectionLimit: number,\n onConfirm: (keys: string[]) => void\n}) => {\n\n if (!allowedFileTypes) {\n allowedFileTypes = [\n '.png',\n '.jpg',\n '.jpeg',\n '.gif',\n '.webp',\n '.pdf',\n '.docx',\n '.xlsx',\n '.xls',\n '.csv',\n '.pptx',\n '.ppt',\n '.mp3',\n '.wav',\n '.m4a',\n '.mp4',\n '.mpeg',\n '.mp4',\n '.m4a',\n '.mp3',\n '.mpeg',\n '.wav'\n ]\n }\n\n const [search, setSearch] = useState<string | undefined>(undefined)\n const [previousContinuationToken, setPreviousContinuationToken] = useState<string | undefined>(undefined)\n const [currentContinuationToken, setCurrentContinuationToken] = useState<string | undefined>(undefined)\n const configContext = useContext(ConfigContext);\n const [selected, setSelected] = useState<string[]>([])\n\n const addSelected = (key: string) => {\n if (selected.includes(key)) {\n setSelected(selected.filter((s) => s !== key))\n return;\n }\n if (selectionLimit === 1) {\n setSelected([key])\n return;\n }\n if (selected.length >= selectionLimit) {\n return;\n }\n setSelected([...selected, key])\n }\n\n const deleteFile = useTanstackMutation({\n mutationFn: async ({ key }: { key: string }) => {\n await files.delete(key)\n refetch();\n return;\n }\n })\n\n const { data, isLoading: loading, error, refetch } = useTanstackQuery({\n queryKey: ['filesQuery', search, currentContinuationToken],\n staleTime: 30000,\n queryFn: async (): Promise<S3FileListOutput> => {\n return files.list({\n search,\n continuationToken: currentContinuationToken\n })\n },\n })\n\n console.log(\"!! data !!\", data)\n\n const { theme } = useTheme()\n const uppy = useUppy(\n {\n backend: configContext?.backend || \"\",\n uppyOptions: {\n id,\n allowedFileTypes\n },\n callbacks: {\n uploadSuccess: async (data) => {\n console.log(\"data\", data)\n /* \n We no longer create items automatically for files uploaded via uppy.\n const item = {\n name: data.file.name,\n type: data.file.type,\n rights_mode: \"private\",\n s3key: `${user?.id}/${data.key}`\n }\n await createItemMutation({ variables: { input: item } }) */\n },\n },\n maxNumberOfFiles: 10,\n },\n dependencies,\n );\n\n useEffect(() => {\n refetch();\n }, [search, currentContinuationToken]);\n\n // Loading state\n if (!uppy) {\n return null;\n }\n\n return <>\n <div className=\"grid grid-cols-1 md:grid-cols-2 gap-4 mt-4\">\n {/* Left side - Gallery of previously uploaded files */}\n <div className=\"border rounded-lg p-4\">\n <h3 className=\"text-sm font-medium mb-3\">Previously Uploaded Files</h3>\n\n {/* search */}\n <Input\n placeholder=\"Search files...\"\n value={search}\n onChange={(e) => setSearch(e.target.value)}\n className=\"mb-3\"\n />\n <div className=\"flex items-center justify-between text-xs text-muted-foreground pb-2\">\n <span>{selected.length} / {selectionLimit} files selected</span>\n <span>Allowed file types: {allowedFileTypes?.map((type) => type).join(\", \")}</span>\n </div>\n <ScrollArea>\n {loading && (\n <div className=\"flex items-center justify-center h-full w-full grid grid-cols-2 sm:grid-cols-3 gap-3\">\n <Skeleton className=\"h-[120px] w-full\" />\n <Skeleton className=\"h-[120px] w-full\" />\n <Skeleton className=\"h-[120px] w-full\" />\n <Skeleton className=\"h-[120px] w-full\" />\n <Skeleton className=\"h-[120px] w-full\" />\n <Skeleton className=\"h-[120px] w-full\" />\n <Skeleton className=\"h-[120px] w-full\" />\n <Skeleton className=\"h-[120px] w-full\" />\n <Skeleton className=\"h-[120px] w-full\" />\n </div>\n )}\n <div className=\"grid grid-cols-2 sm:grid-cols-3 gap-3\">\n {\n !loading && !data?.Contents?.length && (\n <div className=\"col-span-full flex flex-col items-center justify-center py-12 text-center\">\n <FileWarning className=\"h-12 w-12 text-muted-foreground/50 mb-3\" />\n <p className=\"text-sm font-medium text-muted-foreground\">Nothing to see here... yet!</p>\n <p className=\"text-xs text-muted-foreground/75 mt-1\">Upload some files to get started</p>\n </div>\n )\n }\n {data?.Contents?.map((item: S3FileListOutput[\"Contents\"][0]) => {\n return (\n <FileItem s3Key={item.Key} onSelect={addSelected} active={selected.some((s) => s === item.Key)} onRemove={() => {\n deleteFile.mutate({\n key: item.Key\n })\n }} disabled={!allowedFileTypes ? false : !allowedFileTypes?.some((type) => item.Key.endsWith(type))} />\n )\n })}\n </div>\n\n <div className=\"flex items-center space-x-6 lg:space-x-8 pt-3\">\n <div className=\"flex items-center space-x-2\">\n <Button\n variant=\"outline\"\n className=\"hidden size-8 p-0 lg:flex\"\n onClick={() => {\n setCurrentContinuationToken(undefined)\n }}\n disabled={\n !currentContinuationToken ||\n loading\n }\n >\n <span className=\"sr-only\">Go to first page</span>\n <DoubleArrowLeftIcon className=\"size-4\" />\n </Button>\n <Button\n variant=\"outline\"\n className=\"size-8 p-0\"\n onClick={() => {\n setCurrentContinuationToken(previousContinuationToken)\n }}\n disabled={\n !currentContinuationToken ||\n loading\n }\n >\n <span className=\"sr-only\">Go to previous page</span>\n <ChevronLeftIcon className=\"size-4\" />\n </Button>\n <Button\n variant=\"outline\"\n className=\"size-8 p-0\"\n onClick={() => {\n setPreviousContinuationToken(currentContinuationToken)\n setCurrentContinuationToken(data?.NextContinuationToken)\n }}\n disabled={\n !data?.NextContinuationToken ||\n loading\n }>\n <span className=\"sr-only\">Go to next page</span>\n <ChevronRightIcon className=\"size-4\" />\n </Button>\n </div>\n </div>\n </ScrollArea>\n </div>\n {/* Right side - Upload area */}\n <div className=\"border rounded-lg p-4\">\n <h3 className=\"text-sm font-medium mb-3\">Upload New Files</h3>\n <Dashboard uppy={uppy} theme={theme === \"dark\" ? \"dark\" : \"light\"} />\n </div>\n </div>\n <div className=\"flex justify-end\">\n <Button variant=\"outline\" onClick={() => {\n onConfirm(selected)\n setSelected([])\n }}>\n Confirm\n </Button>\n </div>\n </>\n}\n\nexport const FileItem = ({ s3Key, onSelect, onRemove, active, disabled, addToContext }: {\n s3Key: string,\n onSelect?: (key: string) => void,\n onRemove?: (key: string) => void,\n active: boolean,\n disabled: boolean,\n addToContext?: (key: string) => void\n}) => {\n const getFileIcon = (s3Key: string) => {\n if (!s3Key) {\n return <FileText className=\"h-6 w-6 text-gray-500\" />\n }\n if (\n s3Key.toLowerCase().endsWith(\"jpg\") ||\n s3Key.toLowerCase().endsWith(\"jpeg\") ||\n s3Key.toLowerCase().endsWith(\"png\") ||\n s3Key.toLowerCase().endsWith(\"svg\")\n ) {\n return <ImageIcon className=\"h-6 w-6 text-blue-500\" />\n } else if (s3Key.endsWith(\"pdf\")) {\n return <File className=\"h-6 w-6 text-red-500\" />\n } else if (s3Key.endsWith(\"xls\") || s3Key.endsWith(\"xlsx\") || s3Key.endsWith(\"csv\")) {\n return <FileText className=\"h-6 w-6 text-green-500\" />\n } else if (s3Key.endsWith(\"ppt\") || s3Key.endsWith(\"pptx\")) {\n return <FileText className=\"h-6 w-6 text-orange-500\" />\n } else {\n return <FileText className=\"h-6 w-6 text-gray-500\" />\n }\n }\n\n return (\n <div\n key={s3Key}\n className={`${disabled ? 'opacity-50' : ''} group relative rounded-lg p-2 hover:bg-muted transition-colors cursor-pointer ${active ? 'border border-purple-500' : 'border'}`}\n onClick={() => {\n if (!disabled && onSelect) {\n onSelect(s3Key)\n }\n }}>\n <div className=\"aspect-square relative mb-2 bg-muted/50 rounded-md overflow-hidden flex items-center justify-center\">\n {(\n s3Key && (\n s3Key.toLowerCase().endsWith(\"jpg\") ||\n s3Key.toLowerCase().endsWith(\"jpeg\") ||\n s3Key.toLowerCase().endsWith(\"png\") ||\n s3Key.toLowerCase().endsWith(\"svg\")\n )\n ) ? (\n <SecureImageRenderComponent fileKey={s3Key} />\n ) : (\n <div className=\"flex flex-col items-center justify-center h-full\">\n {getFileIcon(s3Key)}\n <span className=\"text-xs text-muted-foreground mt-1 text-center\">{s3Key ? s3Key.split(\"_EXULU_\").pop() : s3Key}</span>\n </div>\n )}\n </div>\n <p className=\"text-xs truncate\">{s3Key ? s3Key.split(\"_EXULU_\").pop() : s3Key}</p>\n <div className=\"opacity-0 group-hover:opacity-100 flex absolute top-1 right-1\">\n\n {addToContext && (\n <Button variant=\"ghost\" size=\"icon\" type=\"button\" className=\"h-6 w-6 bg-background/80 hover:bg-background\" onClick={() => {\n addToContext(s3Key)\n }}>\n <PlusIcon className=\"h-3 w-3\" />\n <span className=\"sr-only\">Add</span>\n </Button>\n )}\n\n <Button\n variant=\"ghost\"\n size=\"icon\"\n type=\"button\"\n className=\"h-6 w-6 bg-background/80 hover:bg-background\"\n onClick={() => {\n files.download(s3Key).then(async res => {\n console.log(\"res\", res);\n const json = await res.json()\n console.log(\"res\", json);\n const downloadUrl = json.url;\n window.open(downloadUrl, '_blank');\n return;\n })\n }}>\n <Download className=\"h-3 w-3\" />\n <span className=\"sr-only\">View</span>\n </Button>\n\n {onRemove && (\n <Button\n onClick={(e) => {\n e.stopPropagation()\n onRemove(s3Key)\n }}\n variant=\"ghost\"\n type=\"button\"\n size=\"icon\"\n className=\"h-6 w-6 opacity-0 group-hover:opacity-100 bg-background/80 hover:bg-background ml-1\">\n <X className=\"h-3 w-3\" />\n <span className=\"sr-only\">Remove</span>\n </Button>\n )}\n </div>\n </div>\n )\n}\n\nlet signedUrlCache: {\n [key: string]: {\n url: string;\n expiresAt: number;\n }\n} = {};\n\nexport const getPresignedUrl = async (fileKey: string) => {\n if (signedUrlCache[fileKey]) {\n if (signedUrlCache[fileKey].expiresAt < Date.now()) {\n delete signedUrlCache[fileKey];\n } else {\n return signedUrlCache[fileKey].url;\n }\n }\n const response = await files.download(fileKey)\n const json = await response.json();\n console.log(\"json\", json)\n signedUrlCache[fileKey] = {\n url: json.url,\n expiresAt: Date.now() + 60 * 1000, // 1 minute\n }\n return json.url;\n}\n\nconst SecureImageRenderComponent = ({ fileKey }: { fileKey: string }) => {\n // Gets a signed key to show the image\n console.log(\"key\", fileKey)\n const query = useTanstackQuery({\n queryKey: ['imageQuery', fileKey],\n staleTime: 30000,\n queryFn: async () => {\n return getPresignedUrl(fileKey)\n },\n })\n\n if (query.isLoading) {\n return <div><LoaderIcon /></div>\n }\n\n if (!query.isLoading && !query.data) {\n return <div><FileWarning /></div>\n }\n\n return (<img\n src={query.data}\n alt={fileKey}\n className=\"object-cover w-full h-full\"\n />)\n\n}"],"names":["CodeBlockContext","createContext","code","CodeBlock","language","showLineNumbers","className","children","props","param","react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__","jsx","Provider","value","div","cn","jsxs","SyntaxHighlighter","codeTagProps","customStyle","margin","padding","fontSize","background","color","lineNumberStyle","paddingRight","minWidth","style","oneLight","oneDark","CodeBlockCopyButton","onCopy","onError","timeout","isCopied","setIsCopied","useState","useContext","copyToClipboard","navigator","clipboard","writeText","setTimeout","error","Icon","CheckIcon","CopyIcon","Button","onClick","size","variant","HardenedMarkdown","hardenReactMarkdown","ReactMarkdown","components","ol","node","li","ul","hr","strong","span","a","rel","target","h1","h2","h3","h4","h5","h6","table","thead","tbody","tr","th","td","blockquote","position","start","line","end","pre","properties","replace","isValidElement","console","log","Response","memo","options","allowedImagePrefixes","allowedLinkPrefixes","defaultOrigin","parseIncompleteMarkdown","shouldParseIncompleteMarkdown","parsedChildren","text","result","linkMatch","match","startIndex","lastIndexOf","substring","asteriskPairs","length","concat","underscorePairs","singleAsterisks","split","reduce","acc","char","index","prevChar","nextChar","singleUnderscores","includes","singleBacktickCount","i","isTripleStart","isTripleMiddle","isTripleEnd","tildePairs","rehypePlugins","rehypeKatex","remarkPlugins","remarkGfm","remarkMath","prevProps","nextProps","displayName","alertVariants","cva","variants","default","destructive","info","defaultVariants","Alert","React","ref","role","AlertTitle","AlertDescription","Collapsible","CollapsiblePrimitive","CollapsibleTrigger","CollapsibleContent","Tabs","TabsPrimitive","TabsList","TabsTrigger","TabsContent","count","toastTimeouts","Map","addToRemoveQueue","has","toastId","delete","dispatch","type","set","reducer","state","action","toasts","toast","slice","map","t","id","forEach","undefined","open","filter","listeners","memoryState","listener","Number","MAX_SAFE_INTEGER","toString","dismiss","onOpenChange","update","useToast","setState","push","indexOf","splice","initializeUppy","localStorage","backend","callbacks","maxNumberOfFiles","uppyOptions","uploadSuccess","allowedFileTypes","token","getToken","uppy","Uppy","autoProceed","debug","restrictions","use","AwsS3","endpoint","headers","Authorization","Session","getItem","on","file","removeFile","response","uploadURL","key","pop","url","use_uppy","deps","configContext","ConfigContext","setUppy","useEffect","initUppy","destroy","FileDataCard","s3key","data","isLoading","refetch","useTanstackQuery","queryKey","queryFn","files","object","enabled","jsx_runtime","Card","CardContent","p","name","bucket","join","CardHeader","CardTitle","Skeleton","ContentType","ContentLength","toFixed","Date","LastModified","toLocaleDateString","year","month","day","hour","minute","download","then","res","json","downloadUrl","window","Download","message","UppyDashboard","dependencies","onConfirm","selectionLimit","buttonText","setOpen","Dialog","DialogTrigger","asChild","FilePlus","DialogContent","DialogHeader","DialogTitle","DialogDescription","FileGalleryAndUpload","search","setSearch","previousContinuationToken","setPreviousContinuationToken","currentContinuationToken","setCurrentContinuationToken","selected","setSelected","addSelected","s","deleteFile","useTanstackMutation","mutationFn","loading","staleTime","list","continuationToken","theme","useTheme","useUppy","Fragment","Input","placeholder","onChange","e","ScrollArea","Contents","FileWarning","FileItem","s3Key","item","Key","onSelect","active","some","onRemove","mutate","disabled","endsWith","DoubleArrowLeftIcon","ChevronLeftIcon","NextContinuationToken","ChevronRightIcon","Dashboard","addToContext","toLowerCase","SecureImageRenderComponent","fileKey","ImageIcon","File","FileText","PlusIcon","stopPropagation","X","signedUrlCache","getPresignedUrl","expiresAt","now","query","LoaderIcon","img","src","alt"],"sourceRoot":""}
@@ -1 +0,0 @@
1
- {"version":3,"file":"static/chunks/3832-d7782d6a2771ae6c.js","mappings":"oZA2CA,IAAMA,EAAiBC,EAAAA,aAAmB,CAA6B,MAEvE,SAASC,IACP,IAAMC,EAAUF,EAAAA,UAAgB,CAACD,GACjC,GAAI,CAACG,EACH,MAAM,MAAU,qDAGlB,OAAOA,CACT,CAEA,IAAMC,EAAkBH,EAAAA,UAAgB,CAQtC,CAAAI,EAUEC,QATA,CACEC,YAAAA,EAAc,EAAI,CAClBC,KAAMC,CAAQ,CACdC,aAAcC,CAAW,CACzBC,UAAAA,CAAS,CACTC,MAAAA,CAAK,CACLC,SAAAA,CAAQ,CACR,GAAGC,EACJ,CAAAV,EAGKW,EAAWC,CAAAA,EAAAA,EAAAA,CAAAA,IACX,CAACC,EAAYC,EAAc,CAAGlB,EAAAA,QAAc,CAAC,IAI7C,CAACmB,EAAOC,EAAS,CAAGpB,EAAAA,QAAc,CAACM,GACnCC,EAAOC,MAAAA,EAAAA,EAAYW,EACnBE,EAAUrB,EAAAA,WAAiB,CAC/B,IACE,IAAMsB,EAAY,mBAAOC,EAAuBA,EAAMhB,GAAQgB,EAC1Db,EACFA,EAAYY,GAEZF,EAASE,GAIXE,SAASC,MAAM,CAAG,GAA0BH,MAAAA,CAjExB,gBAiEqB,KAAiCI,MAAAA,CAA9BJ,EAAU,sBAA2CK,MAAA,CAhE1E,OAiEzB,EACA,CAACjB,EAAaH,EAAK,EAIfqB,EAAgB5B,EAAAA,WAAiB,CAAC,IAC/Be,EACHG,EAAc,GAAU,CAACX,GACzBc,EAAQ,GAAU,CAACd,GACtB,CAACQ,EAAUM,EAASH,EAAc,EAGrClB,EAAAA,SAAe,CAAC,KACd,IAAM6B,EAAgB,IA1EM,MA4ExBC,EAAMC,GAAG,EACRD,CAAAA,EAAME,OAAO,EAAIF,EAAMG,OAAO,IAE/BH,EAAMI,cAAc,GACpBN,IAEJ,EAGA,OADAO,OAAOC,gBAAgB,CAAC,UAAWP,GAC5B,IAAMM,OAAOE,mBAAmB,CAAC,UAAWR,EACrD,EAAG,CAACD,EAAc,EAIlB,IAAMU,EAAQ/B,EAAO,WAAa,YAE5BgC,EAAevC,EAAAA,OAAa,CAChC,IAAO,EACLsC,MAAAA,EACA/B,KAAAA,EACAc,QAAAA,EACAN,SAAAA,EACAE,WAAAA,EACAC,cAAAA,EACAU,cAAAA,CACF,GACA,CAACU,EAAO/B,EAAMc,EAASN,EAAUE,EAAYC,EAAeU,EAAc,EAG5E,MACE,GAAAY,EAAAC,GAAA,EAAC1C,EAAe2C,QAAQ,EAACnB,MAAOgB,WAC9B,GAAAC,EAAAC,GAAA,EAACE,EAAAA,EAAeA,CAAAA,CAACC,cAAe,WAC9B,GAAAJ,EAAAC,GAAA,EAACI,MAAAA,CACCjC,MACE,CACE,kBAlHM,QAmHN,uBAjHW,OAkHX,GAAGA,CAAK,EAGZD,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,oFACAnC,GAEFN,IAAKA,EACJ,GAAGS,CAAK,UAERD,OAKX,EAEFV,CAAAA,EAAgB4C,WAAW,CAAG,kBAE9B,IAAMC,EAAUhD,EAAAA,UAAgB,CAQ9B,CAAAI,EASEC,QARA,CACE4C,KAAAA,EAAO,MAAM,CACbC,QAAAA,EAAU,SAAS,CACnBC,YAAAA,EAAc,WAAW,CACzBxC,UAAAA,CAAS,CACTE,SAAAA,CAAQ,CACR,GAAGC,EACJ,CAAAV,EAGK,CAAEW,SAAAA,CAAQ,CAAEuB,MAAAA,CAAK,CAAErB,WAAAA,CAAU,CAAEC,cAAAA,CAAa,CAAE,CAAGjB,UAEvD,SAAIkD,EAEA,GAAAX,EAAAC,GAAA,EAACI,MAAAA,CACClC,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,8EACAnC,GAEFN,IAAKA,EACJ,GAAGS,CAAK,UAERD,IAKHE,EAEA,GAAAyB,EAAAC,GAAA,EAACW,EAAAA,EAAKA,CAAAA,CAAC7C,KAAMU,EAAYR,aAAcS,EAAgB,GAAGJ,CAAK,UAC7D,GAAA0B,EAAAa,IAAA,EAACC,EAAAA,EAAYA,CAAAA,CACXC,eAAa,UACbC,cAAY,OACZ7C,UAAU,+EACVC,MACE,CACE,kBAnLa,OAoLf,EAEFqC,KAAMA,YAEN,GAAAT,EAAAa,IAAA,EAACI,EAAAA,EAAWA,CAAAA,CAAC9C,UAAU,oBACrB,GAAA6B,EAAAC,GAAA,EAACiB,EAAAA,EAAUA,CAAAA,UAAC,YACZ,GAAAlB,EAAAC,GAAA,EAACkB,EAAAA,EAAgBA,CAAAA,UAAC,oCAEpB,GAAAnB,EAAAC,GAAA,EAACI,MAAAA,CAAIlC,UAAU,uCAA+BE,SAOpD,GAAA2B,EAAAa,IAAA,EAACR,MAAAA,CACCxC,IAAKA,EACLM,UAAU,qDACViD,aAAYtB,EACZuB,mBAAkBvB,cAAAA,EAAwBa,EAAc,GACxDW,eAAcZ,EACda,YAAWd,YAGX,GAAAT,EAAAC,GAAA,EAACI,MAAAA,CACClC,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,0FACA,yCACA,qCACAI,aAAAA,GAA0BA,UAAAA,EACtB,uFACA,4DAGR,GAAAV,EAAAC,GAAA,EAACI,MAAAA,CACClC,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,uHACAG,SAAAA,EACI,iFACA,mFAEJC,aAAAA,GAA0BA,UAAAA,EACtB,gGACA,0HACJvC,GAED,GAAGG,CAAK,UAET,GAAA0B,EAAAC,GAAA,EAACI,MAAAA,CACCU,eAAa,UACb5C,UAAU,yNAETE,QAKX,EAEFmC,CAAAA,EAAQD,WAAW,CAAG,UAEtB,IAAMiB,EAAiBhE,EAAAA,UAAgB,CAGrC,CAAAI,EAAmCC,QAAlC,CAAEM,UAAAA,CAAS,CAAEsD,QAAAA,CAAO,CAAE,GAAGnD,EAAO,CAAAV,EAC3B,CAAEwB,cAAAA,CAAa,CAAE,CAAG3B,IAE1B,MACE,GAAAuC,EAAAa,IAAA,EAACa,EAAAA,CAAMA,CAAAA,CACL7D,IAAKA,EACLkD,eAAa,UACbL,QAAQ,QACRiB,KAAK,OACLxD,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EAAG,UAAWnC,GACzBsD,QAAS,IACPA,MAAAA,GAAAA,EAAUnC,GACVF,GACF,EACC,GAAGd,CAAK,WAET,GAAA0B,EAAAC,GAAA,EAAC2B,EAAAA,CAASA,CAAAA,CAAAA,GACV,GAAA5B,EAAAC,GAAA,EAAC4B,OAAAA,CAAK1D,UAAU,mBAAU,qBAGhC,EACAqD,CAAAA,EAAejB,WAAW,CAAG,iBA6B7BuB,EA3BoBtE,UAAgB,CAGlC,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,EAClB,CAAEwB,cAAAA,CAAa,CAAE,CAAG3B,IAE1B,MACE,GAAAuC,EAAAC,GAAA,EAAC8B,SAAAA,CACClE,IAAKA,EACLkD,eAAa,OACbiB,aAAW,iBACXC,SAAU,GACVR,QAASrC,EACT8C,MAAM,iBACN/D,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,kPACA,6EACA,yHACA,0JACA,4DACA,4DACAnC,GAED,GAAGG,CAAK,EAGf,GACYiC,WAAW,CAAG,cAkB1B4B,EAhBqB3E,UAAgB,CAGnC,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,EACxB,MACE,GAAAoC,EAAAC,GAAA,EAACmC,OAAAA,CACCvE,IAAKA,EACLM,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,qDACA,+MACAnC,GAED,GAAGG,CAAK,EAGf,GACaiC,WAAW,CAAG,eAkB3B8B,EAhBqB7E,UAAgB,CAGnC,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,EACxB,MACE,GAAAoC,EAAAC,GAAA,EAACqC,EAAAA,CAAKA,CAAAA,CACJzE,IAAKA,EACLkD,eAAa,QACb5C,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,4FACAnC,GAED,GAAGG,CAAK,EAGf,GACaiC,WAAW,CAAG,eAe3BgC,EAbsB/E,UAAgB,CAGpC,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,EACxB,MACE,GAAAoC,EAAAC,GAAA,EAACI,MAAAA,CACCxC,IAAKA,EACLkD,eAAa,SACb5C,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EAAG,0BAA2BnC,GACxC,GAAGG,CAAK,EAGf,GACciC,WAAW,CAAG,gBAE5B,IAAMiC,EAAgBhF,EAAAA,UAAgB,CAGpC,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,EACxB,MACE,GAAAoC,EAAAC,GAAA,EAACI,MAAAA,CACCxC,IAAKA,EACLkD,eAAa,SACb5C,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EAAG,0BAA2BnC,GACxC,GAAGG,CAAK,EAGf,EACAkE,CAAAA,EAAcjC,WAAW,CAAG,gBAe5BkC,EAbyBjF,UAAgB,CAGvC,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,EACxB,MACE,GAAAoC,EAAAC,GAAA,EAACyC,EAAAA,CAASA,CAAAA,CACR7E,IAAKA,EACLkD,eAAa,YACb5C,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EAAG,gCAAiCnC,GAC9C,GAAGG,CAAK,EAGf,GACiBiC,WAAW,CAAG,mBAE/B,IAAMoC,EAAiBnF,EAAAA,UAAgB,CAGrC,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,EACxB,MACE,GAAAoC,EAAAC,GAAA,EAACI,MAAAA,CACCxC,IAAKA,EACLkD,eAAa,UACb5C,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,iGACAnC,GAED,GAAGG,CAAK,EAGf,EACAqE,CAAAA,EAAepC,WAAW,CAAG,iBAE7B,IAAMqC,EAAepF,EAAAA,UAAgB,CAGnC,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,EACxB,MACE,GAAAoC,EAAAC,GAAA,EAACI,MAAAA,CACCxC,IAAKA,EACLkD,eAAa,QACb5C,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EAAG,4CAA6CnC,GAC1D,GAAGG,CAAK,EAGf,EACAsE,CAAAA,EAAarC,WAAW,CAAG,eAsB3BsC,EApB0BrF,UAAgB,CAGxC,CAAAI,EAA2CC,QAA1C,CAAEM,UAAAA,CAAS,CAAE2E,QAAAA,EAAU,EAAK,CAAE,GAAGxE,EAAO,CAAAV,EACnCmF,EAAOD,EAAUE,EAAAA,EAAIA,CAAG,MAE9B,MACE,GAAAhD,EAAAC,GAAA,EAAC8C,EAAAA,CAEClF,IAAKA,EACLkD,eAAa,cACb5C,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,yOACA,8EACAnC,GAED,GAAGG,CAAK,EAGf,GACkBiC,WAAW,CAAG,oBAwBhC0C,EAtB2BzF,UAAgB,CAGzC,CAAAI,EAA2CC,QAA1C,CAAEM,UAAAA,CAAS,CAAE2E,QAAAA,EAAU,EAAK,CAAE,GAAGxE,EAAO,CAAAV,EACnCmF,EAAOD,EAAUE,EAAAA,EAAIA,CAAG,SAE9B,MACE,GAAAhD,EAAAC,GAAA,EAAC8C,EAAAA,CAEClF,IAAKA,EACLkD,eAAa,eACb5C,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,2RAEA,gDACA,uCACAnC,GAED,GAAGG,CAAK,EAGf,GACmBiC,WAAW,CAAG,qBAEjC,IAAM2C,EAAsB1F,EAAAA,UAAgB,CAG1C,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,QACxB,GAAAoC,EAAAC,GAAA,EAACI,MAAAA,CACCxC,IAAKA,EACLkD,eAAa,gBACb5C,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EAAG,iBAAkBnC,GAC/B,GAAGG,CAAK,IAGb4E,CAAAA,EAAoB3C,WAAW,CAAG,sBAElC,IAAM4C,EAAc3F,EAAAA,UAAgB,CAGlC,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,QACxB,GAAAoC,EAAAC,GAAA,EAACmD,KAAAA,CACCvF,IAAKA,EACLkD,eAAa,OACb5C,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EAAG,qCAAsCnC,GACnD,GAAGG,CAAK,IAGb6E,CAAAA,EAAY5C,WAAW,CAAG,cAE1B,IAAM8C,EAAkB7F,EAAAA,UAAgB,CAGtC,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,QACxB,GAAAoC,EAAAC,GAAA,EAACqD,KAAAA,CACCzF,IAAKA,EACLkD,eAAa,YACb5C,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EAAG,2BAA4BnC,GACzC,GAAGG,CAAK,IAGb+E,CAAAA,EAAgB9C,WAAW,CAAG,kBAE9B,IAAMgD,EAA4BC,CAAAA,EAAAA,EAAAA,CAAAA,EAChC,4zBACA,CACEC,SAAU,CACR/C,QAAS,CACPgD,QAAS,+DACTC,QACE,8KACJ,EACAhC,KAAM,CACJ+B,QAAS,cACTE,GAAI,cACJC,GAAI,iDACN,CACF,EACAC,gBAAiB,CACfpD,QAAS,UACTiB,KAAM,SACR,CACF,GAGIoC,EAAoBvG,EAAAA,UAAgB,CAQxC,CAAAI,EAUEC,QATA,CACEiF,QAAAA,EAAU,EAAK,CACfkB,SAAAA,EAAW,EAAK,CAChBtD,QAAAA,EAAU,SAAS,CACnBiB,KAAAA,EAAO,SAAS,CAChBsC,QAAAA,CAAO,CACP9F,UAAAA,CAAS,CACT,GAAGG,EACJ,CAAAV,EAGKmF,EAAOD,EAAUE,EAAAA,EAAIA,CAAG,SACxB,CAAEzE,SAAAA,CAAQ,CAAEuB,MAAAA,CAAK,CAAE,CAAGrC,IAEtBsE,EACJ,GAAA/B,EAAAC,GAAA,EAAC8C,EAAAA,CAEClF,IAAKA,EACLkD,eAAa,cACbmD,YAAWvC,EACXwC,cAAaH,EACb7F,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EAAGiD,EAA0B,CAAE7C,QAAAA,EAASiB,KAAAA,CAAK,GAAIxD,GAC3D,GAAGG,CAAK,UAIb,GAIuB,UAAnB,OAAO2F,GACTA,CAAAA,EAAU,CACR5F,SAAU4F,CACZ,GAIA,GAAAjE,EAAAa,IAAA,EAACuD,EAAAA,CAAOA,CAAAA,WACN,GAAApE,EAAAC,GAAA,EAACoE,EAAAA,EAAcA,CAAAA,CAACvB,QAAO,YAAEf,IACzB,GAAA/B,EAAAC,GAAA,EAACqE,EAAAA,EAAcA,CAAAA,CACb7D,KAAK,QACL8D,MAAM,SACNC,OAAQ1E,cAAAA,GAAyBvB,EAChC,GAAG0F,CAAO,OAhBRlC,CAoBX,EAEFgC,CAAAA,EAAkBxD,WAAW,CAAG,oBAgChCkE,EA9B0BjH,UAAgB,CAMxC,CAAAI,EAAgEC,QAA/D,CAAEM,UAAAA,CAAS,CAAE2E,QAAAA,EAAU,EAAK,CAAE4B,YAAAA,EAAc,EAAK,CAAE,GAAGpG,EAAO,CAAAV,EACxDmF,EAAOD,EAAUE,EAAAA,EAAIA,CAAG,SAE9B,MACE,GAAAhD,EAAAC,GAAA,EAAC8C,EAAAA,CAEClF,IAAKA,EACLkD,eAAa,cACb5C,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,iVAEA,gDACA,wCACA,+CACA,0CACA,uCACAoE,GACE,2LACFvG,GAED,GAAGG,CAAK,EAGf,GACkBiC,WAAW,CAAG,oBAqBhCoE,EAnByBnH,UAAgB,CAGvC,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,QACxB,GAAAoC,EAAAC,GAAA,EAACI,MAAAA,CACCxC,IAAKA,EACLkD,eAAa,aACb5C,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,yKACA,2HACA,wCACA,+CACA,0CACA,uCACAnC,GAED,GAAGG,CAAK,KAGIiC,WAAW,CAAG,mBAsC/BqE,EApC4BpH,UAAgB,CAK1C,CAAAI,EAA4CC,QAA3C,CAAEM,UAAAA,CAAS,CAAE0G,SAAAA,EAAW,EAAK,CAAE,GAAGvG,EAAO,CAAAV,EAEpCkH,EAAQtH,EAAAA,OAAa,CAAC,IACnB,GAAuC2B,MAAA,CAApC4F,KAAKC,KAAK,CAACD,GAAAA,KAAKE,MAAM,IAAW,GAAG,KAC7C,EAAE,EAEL,MACE,GAAAjF,EAAAa,IAAA,EAACR,MAAAA,CACCxC,IAAKA,EACLkD,eAAa,gBACb5C,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EAAG,8CAA+CnC,GAC5D,GAAGG,CAAK,WAERuG,GACC,GAAA7E,EAAAC,GAAA,EAACiF,EAAAA,CAAQA,CAAAA,CACP/G,UAAU,oBACV4C,eAAa,uBAGjB,GAAAf,EAAAC,GAAA,EAACiF,EAAAA,CAAQA,CAAAA,CACP/G,UAAU,sCACV4C,eAAa,qBACb3C,MACE,CACE,mBAAoB0G,CACtB,MAKV,GACoBvE,WAAW,CAAG,sBAiBlC4E,EAfuB3H,UAAgB,CAGrC,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,QACxB,GAAAoC,EAAAC,GAAA,EAACmD,KAAAA,CACCvF,IAAKA,EACLkD,eAAa,WACb5C,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,iGACA,uCACAnC,GAED,GAAGG,CAAK,KAGEiC,WAAW,CAAG,iBAM7B6E,EAJ2B5H,UAAgB,CAGzC,CAAAI,EAAeC,QAAd,CAAE,GAAGS,EAAO,CAAAV,QAAU,GAAAoC,EAAAC,GAAA,EAACqD,KAAAA,CAAGzF,IAAKA,EAAM,GAAGS,CAAK,KAC7BiC,WAAW,CAAG,qBA+BjC8E,EA7B6B7H,UAAgB,CAO3C,CAAAI,EAAkEC,QAAjE,CAAEiF,QAAAA,EAAU,EAAK,CAAEnB,KAAAA,EAAO,IAAI,CAAEqC,SAAAA,CAAQ,CAAE7F,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,EAC1DmF,EAAOD,EAAUE,EAAAA,EAAIA,CAAG,IAE9B,MACE,GAAAhD,EAAAC,GAAA,EAAC8C,EAAAA,CAEClF,IAAKA,EACLkD,eAAa,kBACbmD,YAAWvC,EACXwC,cAAaH,EACb7F,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,8eACA,yFACAqB,OAAAA,GAAiB,UACjBA,OAAAA,GAAiB,UACjB,uCACAxD,GAED,GAAGG,CAAK,EAGf,GACqBiC,WAAW,CAAG,uQC1sBnC,IAAM+E,GAAkB,CAACC,EAAYC,KACnC,IAAMC,EAA4E,EAAE,CAkGpF,OAhGIF,EAAKG,WAAW,EAClBD,EAAgBE,IAAI,CAAC,CACnBC,MAAO,YACPC,KAAM,YACNC,KAAM,GAAA9F,EAAAC,GAAA,EAAC8F,EAAAA,CAAeA,CAAAA,CAAAA,EACxB,GAGFN,EAAgBE,IAAI,CAAC,CACnBC,MAAO,YACPC,KAAM,OACNC,KAAM,GAAA9F,EAAAC,GAAA,EAAC+F,EAAAA,CAAQA,CAAAA,CAAAA,EACjB,GAEIT,CAAAA,EAAKG,WAAW,EAAIF,UAAAA,EAAKS,MAAM,GACjCR,EAAgBE,IAAI,CAAC,CACnBC,MAAO,SACPC,KAAM,SACNC,KAAM,GAAA9F,EAAAC,GAAA,EAACiG,EAAAA,CAAGA,CAAAA,CAAAA,EACZ,GAGFT,EAAgBE,IAAI,CAAC,CACnBC,MAAO,WACPC,KAAM,WACNC,KAAM,GAAA9F,EAAAC,GAAA,EAACkG,EAAAA,CAAUA,CAAAA,CAAAA,EACnB,GAEAV,EAAgBE,IAAI,CAAC,CACnBC,MAAO,OACPC,KAAM,OACNC,KAAM,GAAA9F,EAAAC,GAAA,EAACmG,EAAAA,CAAaA,CAAAA,CAAAA,EACtB,GAEAX,EAAgBE,IAAI,CAAC,CACnBC,MAAO,UACPC,KAAM,UACNC,KAAM,GAAA9F,EAAAC,GAAA,EAACoG,EAAAA,CAAKA,CAAAA,CAAAA,EACd,GAEId,CAAAA,EAAKG,WAAW,EAAIF,SAAAA,EAAKc,KAAK,EAAed,UAAAA,EAAKc,KAAK,GACzDb,EAAgBE,IAAI,CAAC,CACnBC,MAAO,QACPC,KAAM,QACNC,KAAM,GAAA9F,EAAAC,GAAA,EAACsG,EAAAA,CAAKA,CAAAA,CAAAA,EACd,GAWEhB,CAAAA,EAAKG,WAAW,EAAIF,UAAAA,EAAKgB,KAAK,GAChCf,EAAgBE,IAAI,CAAC,CACnBC,MAAO,QACPC,KAAM,QACNC,KAAM,GAAA9F,EAAAC,GAAA,EAACwG,EAAAA,CAAKA,CAAAA,CAAAA,EACd,GAGElB,CAAAA,EAAKG,WAAW,EAAIF,UAAAA,EAAKkB,GAAG,GAC9BjB,EAAgBE,IAAI,CAAC,CACnBC,MAAO,OACPC,KAAM,OACNC,KAAM,GAAA9F,EAAAC,GAAA,EAAC0G,EAAAA,CAAGA,CAAAA,CAAAA,EACZ,GAGEpB,CAAAA,EAAKG,WAAW,EAAIF,UAAAA,EAAKoB,SAAS,GACpCnB,EAAgBE,IAAI,CAAC,CACnBC,MAAO,YACPC,KAAM,YACNC,KAAM,GAAA9F,EAAAC,GAAA,EAAC4G,EAAAA,CAAQA,CAAAA,CAAAA,EACjB,GAGEtB,CAAAA,EAAKG,WAAW,EAAIF,UAAAA,EAAKkB,GAAG,GAC9BjB,EAAgBE,IAAI,CAAC,CACnBC,MAAO,MACPC,KAAM,WACNC,KAAM,GAAA9F,EAAAC,GAAA,EAAC6G,EAAAA,CAAIA,CAAAA,CAAAA,EACb,GAGEvB,EAAKG,WAAW,EAClBD,EAAgBE,IAAI,CAAC,CACnBC,MAAO,QACPC,KAAM,gBACNC,KAAM,GAAA9F,EAAAC,GAAA,EAAC8G,EAAAA,CAAQA,CAAAA,CAAAA,EACjB,GAGKtB,CACT,EAEA,SAASuB,GAAgBpJ,CAA8E,KAA9E,CAAEqJ,MAAAA,CAAK,CAAuE,CAA9ErJ,EACjBsJ,EAAWC,CAAAA,EAAAA,EAAAA,WAAAA,IAEjB,MACE,GAAAnH,EAAAC,GAAA,EAACkD,EAAWA,CAAChF,UAAU,qBACpB8I,EAAMG,GAAG,CAAC,CAACC,EAASC,KACnB,IAAMtD,EAAWkD,EAASK,QAAQ,CAACF,EAAQxB,IAAI,EAC/C,MACE,GAAA7F,EAAAC,GAAA,EAACoD,EAAeA,UACd,GAAArD,EAAAC,GAAA,EAAC8D,EAAiBA,CAChBjB,QAAO,GACPkB,SAAUA,EACVC,QAASoD,EAAQzB,KAAK,CACtBzH,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,6CAGF,GAAAN,EAAAa,IAAA,EAAC2G,EAAAA,OAAIA,CAAAA,CAACC,KAAM,IAAiBtI,MAAA,CAAbkI,EAAQxB,IAAI,EAAI1H,UAAU,oCACxC,GAAA6B,EAAAC,GAAA,EAACI,MAAAA,CAAIlC,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACd,uEAEC+G,EAAQvB,IAAI,GAEf,GAAA9F,EAAAC,GAAA,EAAC4B,OAAAA,CAAK1D,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACf,0CAEC+G,EAAQzB,KAAK,SAlBA0B,EAwB1B,IAGN,CAEO,SAASI,GAAe9J,CAAuD,KAAvD,CAAE+J,mBAAAA,CAAkB,CAAmC,CAAvD/J,EAEvB,CAAE2H,KAAAA,CAAI,CAAE,CAAGqC,CAAAA,EAAAA,EAAAA,UAAAA,EAAWC,IACtBpC,EAAkBH,GAAgBC,EAAMA,EAAKC,IAAI,EACjDsC,EAASC,CAAAA,EAAAA,EAAAA,SAAAA,IACT,CAAEC,SAAAA,CAAQ,CAAEC,MAAAA,CAAK,CAAE,CAAGC,CAAAA,EAAAA,GAAAA,CAAAA,IACtBC,EAASC,CAAAA,EAAAA,EAAAA,SAAAA,IACTC,EAAU5K,IAQhB,MANA6K,CAAAA,EAAAA,EAAAA,SAAAA,EAAU,KACJH,EAAOI,KAAK,EAAIZ,KAAuBa,IAAvBb,GAClBU,EAAQxJ,OAAO,CAAC,GAEpB,EAAG,CAACsJ,EAAOI,KAAK,CAAC,EAGf,GAAAvI,EAAAa,IAAA,EAACL,EAAOA,CAACG,YAAY,OAAOxC,UAAU,qBACpC,GAAA6B,EAAAa,IAAA,EAACR,MAAAA,CAAIlC,UAAU,0GACb,GAAA6B,EAAAC,GAAA,EAACuB,EAAcA,CAAAA,GACf,GAAAxB,EAAAC,GAAA,EAACI,MAAAA,CAAIlC,UAAU,mCACb,GAAA6B,EAAAC,GAAA,EAACwI,GAAAA,OAAIA,CAAAA,CAACC,IAAI,OAAO5D,MAAO,IAAK6D,OAAQ,UAGzC,GAAA3I,EAAAC,GAAA,EAAC0C,EAAcA,CAACxE,UAAU,gBACxB,GAAA6B,EAAAC,GAAA,EAAC2C,EAAYA,CAACzE,UAAU,gBACtB,GAAA6B,EAAAC,GAAA,EAACiD,EAAmBA,UAClB,GAAAlD,EAAAC,GAAA,EAAC+G,GAAAA,CAAgBC,MAAOxB,UAI9B,GAAAzF,EAAAa,IAAA,EAAC2B,EAAaA,CAACrE,UAAU,yCACvB,GAAA6B,EAAAC,GAAA,EAACI,MAAAA,CAAIlC,UAAU,0DACb,GAAA6B,EAAAa,IAAA,EAACR,MAAAA,CAAIlC,UAAU,8GACb,GAAA6B,EAAAC,GAAA,EAAC2I,EAAAA,CAAQA,CAAAA,CAACzK,UAAU,yBACpB,GAAA6B,EAAAC,GAAA,EAAC4B,OAAAA,CAAK1D,UAAU,4CAAmC,cAGvD,GAAA6B,EAAAC,GAAA,EAACkD,EAAWA,UACV,GAAAnD,EAAAC,GAAA,EAACoD,EAAeA,UACd,GAAArD,EAAAa,IAAA,EAACgI,EAAAA,EAAYA,CAAAA,CAACC,MAAO,aACnB,GAAA9I,EAAAC,GAAA,EAAC8I,EAAAA,EAAmBA,CAAAA,CAACjG,QAAO,YAC1B,GAAA9C,EAAAa,IAAA,EAACkD,EAAiBA,CAAC5F,UAAU,oCAC3B,GAAA6B,EAAAC,GAAA,EAAC+I,GAAAA,EAAMA,CAAAA,CAAC7K,UAAU,mBAChB,GAAA6B,EAAAC,GAAA,EAACgJ,GAAAA,EAAcA,CAAAA,CAAC9K,UAAU,8EACvBoH,EAAK2D,KAAK,CAACC,MAAM,CAAC,GAAGC,WAAW,OAGrC,GAAApJ,EAAAa,IAAA,EAACR,MAAAA,CAAIlC,UAAU,2EACb,GAAA6B,EAAAC,GAAA,EAAC4B,OAAAA,CAAK1D,UAAU,0CAAkCoH,EAAK2D,KAAK,CAACG,KAAK,CAAC,IAAI,CAAC,EAAE,GAC1E,GAAArJ,EAAAC,GAAA,EAACI,MAAAA,CAAIlC,UAAU,mCACb,GAAA6B,EAAAC,GAAA,EAAC4B,OAAAA,CAAK1D,UAAU,yCAAiCoH,EAAK2D,KAAK,CAACG,KAAK,CAAC,IAAI,CAAC,EAAE,QAG7E,GAAArJ,EAAAC,GAAA,EAACqJ,EAAAA,CAASA,CAAAA,CAACnL,UAAU,8DAGzB,GAAA6B,EAAAa,IAAA,EAAC0I,EAAAA,EAAmBA,CAAAA,CAClB9I,KAAK,MACLtC,UAAU,uCACVoG,MAAM,kBAEN,GAAAvE,EAAAC,GAAA,EAACuJ,EAAAA,EAAgBA,CAAAA,CAAC/H,QAAS,IAAMuG,EAASC,SAAAA,EAAmB,QAAU,iBACrE,GAAAjI,EAAAa,IAAA,EAACR,MAAAA,CAAIlC,UAAU,2CACZ8J,SAAAA,EAAmB,GAAAjI,EAAAC,GAAA,EAACwJ,EAAAA,CAAGA,CAAAA,CAACtL,UAAU,YAAe,GAAA6B,EAAAC,GAAA,EAACyJ,GAAAA,CAAIA,CAAAA,CAACvL,UAAU,YAClE,GAAA6B,EAAAC,GAAA,EAAC4B,OAAAA,UAAK,eAGV,GAAA7B,EAAAC,GAAA,EAACuJ,EAAAA,EAAgBA,CAAAA,CAAC/H,QAAS,IAAMqG,EAAOnC,IAAI,CAAC,8BAC3C,GAAA3F,EAAAa,IAAA,EAACR,MAAAA,CAAIlC,UAAU,2CACb,GAAA6B,EAAAC,GAAA,EAAC0J,GAAAA,CAAMA,CAAAA,CAACxL,UAAU,YAClB,GAAA6B,EAAAC,GAAA,EAAC4B,OAAAA,UAAK,+BAgB1B,CAEO,SAAS+H,GAAgBhM,CAA4F,KAA5F,CAAES,SAAAA,CAAQ,CAAEsJ,mBAAAA,CAAkB,CAA8D,CAA5F/J,EAE9B,OADAiM,QAAQC,GAAG,CAAC,qBAAsBnC,GAEhC,GAAA3H,EAAAC,GAAA,EAACtC,EAAeA,CAACG,YAAa6J,WAC5B,GAAA3H,EAAAa,IAAA,EAACR,MAAAA,CAAIlC,UAAU,sDACb,GAAA6B,EAAAC,GAAA,EAACyH,GAAAA,CAAeC,mBAAoBA,IACpC,GAAA3H,EAAAC,GAAA,EAACmC,OAAAA,CAAKjE,UAAU,gCACbE,QAKX,4BC3PO,IAAMwJ,GAAcrK,EAAAA,aAAmB,CAAM,MAE9CuM,GAAO,OAAC,CAAE1L,SAAAA,CAAQ,CAAEkH,KAAAA,CAAI,CAAEoC,mBAAAA,CAAkB,CAAsB,CAAA/J,EAEtE,MACE,GAAAoC,EAAAC,GAAA,EAAC4H,GAAY3H,QAAQ,EAACnB,MAAO,CAAEwG,KAAAA,CAAK,WAClC,GAAAvF,EAAAC,GAAA,EAAC2J,GAAeA,CAACjC,mBAAoBA,WAClCtJ,KAKT,EAuDA,IAAA2L,GAtDsB,OAAC,CAAE3L,SAAAA,CAAQ,CAAEkH,KAAAA,CAAI,CAAEoC,mBAAAA,CAAkB,CAAsB,CAAA/J,EAEzEqM,EAAgBzM,EAAAA,UAAgB,CAAC0M,GAAAA,CAAaA,EAE9CC,EAAMF,CAAAA,MAAAA,EAAAA,KAAAA,EAAAA,EAAeG,OAAO,EAC9BH,CAAAA,MAAAA,EAAAA,KAAAA,EAAAA,EAAeG,OAAO,EAAG,WACzB,gCAEEC,EAAQC,CAAAA,EAAAA,EAAAA,CAAAA,EAAW,CAACC,EAAW7M,IAAa,EAChD8M,QAAS,CACPC,OAAQ,eACV,CACF,IAEMC,EAAWJ,CAAAA,EAAAA,EAAAA,CAAAA,EAAW,MAAOC,EAAW7M,KAC5C,IAAMiN,EAAQ,MAAMC,CAAAA,EAAAA,GAAAA,EAAAA,IACpB,MAAO,CACLJ,QAAS,CACPK,cAAe,UAAgB1L,MAAA,CAANwL,EAC3B,CACF,CACF,GAEMG,EAAOC,EAAAA,CAAUA,CAACC,IAAI,CAAC,CAACX,EAAOK,EAAU,IAAIO,EAAAA,CAAQA,CAAC,CAAEd,IAAKA,CAAI,GAAG,EAEpEe,EAAS,IAAIC,EAAAA,CAAYA,CAAC,CAC9BhB,IAAKA,EACLiB,MAAO,IAAIC,EAAAA,CAAaA,CAAC,CACvBC,YAAa,EACf,GACAR,KAAMA,EACNS,eAAgB,CACdC,WAAY,CACVC,YAAa,WACbC,YAAa,QACf,EACAC,MAAO,CACLF,YAAa,WACbC,YAAa,KACf,CACF,CACF,GAEA,MACE,GAAA1L,EAAAC,GAAA,EAAC2L,EAAAA,CAAcA,CAAAA,CAACV,OAAQA,WACtB,GAAAlL,EAAAC,GAAA,EAAC4L,EAAAA,eAAeA,CAAAA,UACd,GAAA7L,EAAAC,GAAA,EAAC8J,GAAAA,CAAKpC,mBAAoBA,EAAoBpC,KAAMA,WACjDlH,OAKX,mHC9EO,IAAM6L,EAAgB4B,CAAAA,EAAAA,QAAAA,aAAAA,EAAwC,MAE9D,SAASC,EAAsBnO,CAGrC,KAHqC,CAAES,SAAAA,CAAQ,CAAE2N,OAAAA,CAAM,CAGvD,CAHqCpO,EAOpC,GAFAiM,QAAQC,GAAG,CAAC,mBAAoBkC,GAE5B,CAACA,EACH,MAAM,MAAU,oBAGlB,MACE,GAAAC,EAAAhM,GAAA,EAACiK,EAAchK,QAAQ,EAACnB,MAAOiN,WAC5B3N,GAGP,4DCMA6N,CAAAA,EAAA,QAtBa,OAAC,CAAEpH,MAAAA,EAAQ,EAAE,CAAE6D,OAAAA,EAAS,EAAE,CAAExK,UAAAA,EAAY,EAAE,CAAEuK,IAAAA,EAAM,MAAM,CAAa,CAAA9K,EACxEqM,EAAgBrC,CAAAA,EAAAA,EAAAA,UAAAA,EAAWsC,EAAAA,CAAaA,EAC9C,MACI,GAAA+B,EAAApL,IAAA,EAAAoL,EAAAE,QAAA,YACI,GAAAF,EAAAhM,GAAA,EAACmM,MAAAA,CACGC,IAAKpC,CAAAA,MAAAA,EAAAA,KAAAA,EAAAA,EAAeG,OAAO,EAAG,iBAC9B1B,IAAKA,EACL5D,MAAOA,EACP6D,OAAQA,EACRxK,UAAWA,EAAY,sBAE3B,GAAA8N,EAAAhM,GAAA,EAACmM,MAAAA,CACGC,IAAKpC,CAAAA,MAAAA,EAAAA,KAAAA,EAAAA,EAAeG,OAAO,EAAG,kBAC9B1B,IAAKA,EACL5D,MAAOA,EACP6D,OAAQA,EACRxK,UAAWA,EAAY,wBAIvC,iICzBA,IAAM6K,EAASxL,EAAAA,UAAgB,CAG7B,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,QACxB,GAAAqO,EAAAhM,GAAA,EAACqM,EAAAA,EAAoB,EACnBzO,IAAKA,EACLM,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,gEACAnC,GAED,GAAGG,CAAK,IAGb0K,CAAAA,EAAOzI,WAAW,CAAG+L,EAAAA,EAAoB,CAAC/L,WAAW,CAYrDgM,EAVoB/O,UAAgB,CAGlC,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,QACxB,GAAAqO,EAAAhM,GAAA,EAACqM,EAAAA,EAAqB,EACpBzO,IAAKA,EACLM,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EAAG,8BAA+BnC,GAC5C,GAAGG,CAAK,KAGDiC,WAAW,CAAG+L,EAAAA,EAAqB,CAAC/L,WAAW,CAE3D,IAAM0I,EAAiBzL,EAAAA,UAAgB,CAGrC,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,QACxB,GAAAqO,EAAAhM,GAAA,EAACqM,EAAAA,EAAwB,EACvBzO,IAAKA,EACLM,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,uEACAnC,GAED,GAAGG,CAAK,IAGb2K,CAAAA,EAAe1I,WAAW,CAAG+L,EAAAA,EAAwB,CAAC/L,WAAW,yUCvCjE,IAAMsI,EAAe2D,EAAAA,EAA0B,CAEzCzD,EAAsByD,EAAAA,EAA6B,CAE/BA,EAAAA,EAA2B,CAE1BA,EAAAA,EAA4B,CAE/BA,EAAAA,EAAyB,CAEjD,IAAMC,EAAyBD,EAAAA,EAAgC,CAEhChP,EAAAA,UAAgB,CAK7C,CAAAI,EAA2CC,QAA1C,CAAEM,UAAAA,CAAS,CAAEuO,MAAAA,CAAK,CAAErO,SAAAA,CAAQ,CAAE,GAAGC,EAAO,CAAAV,QACzC,GAAAqO,EAAApL,IAAA,EAAC2L,EAAAA,EAAgC,EAC/B3O,IAAKA,EACLM,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,uIACAoM,GAAS,OACTvO,GAED,GAAGG,CAAK,WAERD,EACD,GAAA4N,EAAAhM,GAAA,EAAC0M,EAAAA,CAAYA,CAAAA,CAACxO,UAAU,wBAGLoC,WAAW,CAChCiM,EAAAA,EAAgC,CAACjM,WAAW,CAe9CqM,EAb+BpP,UAAgB,CAG7C,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,QACxB,GAAAqO,EAAAhM,GAAA,EAACuM,EAAAA,EAAgC,EAC/B3O,IAAKA,EACLM,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,wbACAnC,GAED,GAAGG,CAAK,KAGUiC,WAAW,CAChCiM,EAAAA,EAAgC,CAACjM,WAAW,CAE9C,IAAMgJ,EAAsB/L,EAAAA,UAAgB,CAG1C,CAAAI,EAA0CC,QAAzC,CAAEM,UAAAA,CAAS,CAAE0O,WAAAA,EAAa,CAAC,CAAE,GAAGvO,EAAO,CAAAV,QACxC,GAAAqO,EAAAhM,GAAA,EAACuM,EAAAA,EAA4B,WAC3B,GAAAP,EAAAhM,GAAA,EAACuM,EAAAA,EAA6B,EAC5B3O,IAAKA,EACLgP,WAAYA,EACZ1O,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,wbACAnC,GAED,GAAGG,CAAK,MAIfiL,CAAAA,EAAoBhJ,WAAW,CAAGiM,EAAAA,EAA6B,CAACjM,WAAW,CAE3E,IAAMiJ,EAAmBhM,EAAAA,UAAgB,CAKvC,CAAAI,EAAiCC,QAAhC,CAAEM,UAAAA,CAAS,CAAEuO,MAAAA,CAAK,CAAE,GAAGpO,EAAO,CAAAV,QAC/B,GAAAqO,EAAAhM,GAAA,EAACuM,EAAAA,EAA0B,EACzB3O,IAAKA,EACLM,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,kOACAoM,GAAS,OACTvO,GAED,GAAGG,CAAK,IAGbkL,CAAAA,EAAiBjJ,WAAW,CAAGiM,EAAAA,EAA0B,CAACjM,WAAW,CAErE,IAAMuM,EAA2BtP,EAAAA,UAAgB,CAG/C,CAAAI,EAA6CC,QAA5C,CAAEM,UAAAA,CAAS,CAAEE,SAAAA,CAAQ,CAAE0O,QAAAA,CAAO,CAAE,GAAGzO,EAAO,CAAAV,QAC3C,GAAAqO,EAAApL,IAAA,EAAC2L,EAAAA,EAAkC,EACjC3O,IAAKA,EACLM,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,uOACAnC,GAEF4O,QAASA,EACR,GAAGzO,CAAK,WAET,GAAA2N,EAAAhM,GAAA,EAAC4B,OAAAA,CAAK1D,UAAU,qEACd,GAAA8N,EAAAhM,GAAA,EAACuM,EAAAA,EAAmC,WAClC,GAAAP,EAAAhM,GAAA,EAAC+M,EAAAA,CAAKA,CAAAA,CAAC7O,UAAU,eAGpBE,MAGLyO,CAAAA,EAAyBvM,WAAW,CAClCiM,EAAAA,EAAkC,CAACjM,WAAW,CAEhD,IAAM0M,EAAwBzP,EAAAA,UAAgB,CAG5C,CAAAI,EAAoCC,QAAnC,CAAEM,UAAAA,CAAS,CAAEE,SAAAA,CAAQ,CAAE,GAAGC,EAAO,CAAAV,QAClC,GAAAqO,EAAApL,IAAA,EAAC2L,EAAAA,EAA+B,EAC9B3O,IAAKA,EACLM,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,uOACAnC,GAED,GAAGG,CAAK,WAET,GAAA2N,EAAAhM,GAAA,EAAC4B,OAAAA,CAAK1D,UAAU,qEACd,GAAA8N,EAAAhM,GAAA,EAACuM,EAAAA,EAAmC,WAClC,GAAAP,EAAAhM,GAAA,EAACiN,EAAAA,CAAMA,CAAAA,CAAC/O,UAAU,4BAGrBE,MAGL4O,CAAAA,EAAsB1M,WAAW,CAAGiM,EAAAA,EAA+B,CAACjM,WAAW,CAE/E,IAAM4M,EAAoB3P,EAAAA,UAAgB,CAKxC,CAAAI,EAAiCC,QAAhC,CAAEM,UAAAA,CAAS,CAAEuO,MAAAA,CAAK,CAAE,GAAGpO,EAAO,CAAAV,QAC/B,GAAAqO,EAAAhM,GAAA,EAACuM,EAAAA,EAA2B,EAC1B3O,IAAKA,EACLM,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,oCACAoM,GAAS,OACTvO,GAED,GAAGG,CAAK,IAGb6O,CAAAA,EAAkB5M,WAAW,CAAGiM,EAAAA,EAA2B,CAACjM,WAAW,CAEvE,IAAM6M,EAAwB5P,EAAAA,UAAgB,CAG5C,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,QACxB,GAAAqO,EAAAhM,GAAA,EAACuM,EAAAA,EAA+B,EAC9B3O,IAAKA,EACLM,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EAAG,2BAA4BnC,GACzC,GAAGG,CAAK,IAGb8O,CAAAA,EAAsB7M,WAAW,CAAGiM,EAAAA,EAA+B,CAACjM,WAAW,4FCjK/E,IAAM+B,EAAQ9E,EAAAA,UAAgB,CAC5B,CAAAI,EAAgCC,QAA/B,CAAEM,UAAAA,CAAS,CAAEkP,KAAAA,CAAI,CAAE,GAAG/O,EAAO,CAAAV,EAC5B,MACE,GAAAqO,EAAAhM,GAAA,EAACqN,QAAAA,CACCD,KAAMA,EACNlP,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,+VACAnC,GAEFN,IAAKA,EACJ,GAAGS,CAAK,EAGf,EAEFgE,CAAAA,EAAM/B,WAAW,CAAG,6GCfpB,IAAMmC,EAAYlF,EAAAA,UAAgB,CAIhC,CAAAI,EAEEC,QADA,CAAEM,UAAAA,CAAS,CAAEoP,YAAAA,EAAc,YAAY,CAAEC,WAAAA,EAAa,EAAI,CAAE,GAAGlP,EAAO,CAAAV,QAGtE,GAAAqO,EAAAhM,GAAA,EAACwN,EAAAA,CAAuB,EACtB5P,IAAKA,EACL2P,WAAYA,EACZD,YAAaA,EACbpP,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,qBACAiN,eAAAA,EAA+B,iBAAmB,iBAClDpP,GAED,GAAGG,CAAK,IAIfoE,CAAAA,EAAUnC,WAAW,CAAGkN,EAAAA,CAAuB,CAAClN,WAAW,sPCnB3D,IAAMK,EAAQ8M,EAAAA,EAAmB,CAE3BC,EAAeD,EAAAA,EAAsB,CAExBA,EAAAA,EAAoB,CAEvC,IAAME,EAAcF,EAAAA,EAAqB,CAEnCG,EAAerQ,EAAAA,UAAgB,CAGnC,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,QACxB,GAAAqO,EAAAhM,GAAA,EAACyN,EAAAA,EAAsB,EACrBvP,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,0JACAnC,GAED,GAAGG,CAAK,CACTT,IAAKA,KAGTgQ,CAAAA,EAAatN,WAAW,CAAGmN,EAAAA,EAAsB,CAACnN,WAAW,CAE7D,IAAMuN,EAAgBtK,CAAAA,EAAAA,EAAAA,CAAAA,EACpB,mMACA,CACEC,SAAU,CACRhD,KAAM,CACJsN,IAAK,oGACLC,OACE,6GACFC,KAAM,gIACNC,MACE,mIACJ,CACF,EACApK,gBAAiB,CACfrD,KAAM,OACR,CACF,GAOIK,EAAetD,EAAAA,UAAgB,CAGnC,CAAAI,EAAoDC,QAAnD,CAAE4C,KAAAA,EAAO,OAAO,CAAEtC,UAAAA,CAAS,CAAEE,SAAAA,CAAQ,CAAE,GAAGC,EAAO,CAAAV,QAClD,GAAAqO,EAAApL,IAAA,EAAC+M,EAAAA,WACC,GAAA3B,EAAAhM,GAAA,EAAC4N,EAAAA,CAAAA,GACD,GAAA5B,EAAApL,IAAA,EAAC6M,EAAAA,EAAsB,EACrB7P,IAAKA,EACLM,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EAAGwN,EAAc,CAAErN,KAAAA,CAAK,GAAItC,GACtC,GAAGG,CAAK,WAERD,EACD,GAAA4N,EAAApL,IAAA,EAAC6M,EAAAA,EAAoB,EAACvP,UAAU,qPAC9B,GAAA8N,EAAAhM,GAAA,EAACkO,EAAAA,CAACA,CAAAA,CAAChQ,UAAU,WACb,GAAA8N,EAAAhM,GAAA,EAAC4B,OAAAA,CAAK1D,UAAU,mBAAU,oBAKlC2C,CAAAA,EAAaP,WAAW,CAAGmN,EAAAA,EAAsB,CAACnN,WAAW,CAE7D,IAAMU,EAAc,OAAC,CACnB9C,UAAAA,CAAS,CACT,GAAGG,EACkC,CAAAV,QACrC,GAAAqO,EAAAhM,GAAA,EAACI,MAAAA,CACClC,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,mDACAnC,GAED,GAAGG,CAAK,GAGb2C,CAAAA,EAAYV,WAAW,CAAG,cAgB1B,IAAMW,EAAa1D,EAAAA,UAAgB,CAGjC,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,QACxB,GAAAqO,EAAAhM,GAAA,EAACyN,EAAAA,EAAoB,EACnB7P,IAAKA,EACLM,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EAAG,wCAAyCnC,GACtD,GAAGG,CAAK,IAGb4C,CAAAA,EAAWX,WAAW,CAAGmN,EAAAA,EAAoB,CAACnN,WAAW,CAEzD,IAAMY,EAAmB3D,EAAAA,UAAgB,CAGvC,CAAAI,EAA0BC,QAAzB,CAAEM,UAAAA,CAAS,CAAE,GAAGG,EAAO,CAAAV,QACxB,GAAAqO,EAAAhM,GAAA,EAACyN,EAAAA,EAA0B,EACzB7P,IAAKA,EACLM,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EAAG,gCAAiCnC,GAC9C,GAAGG,CAAK,IAGb6C,CAAAA,EAAiBZ,WAAW,CAAGmN,EAAAA,EAA0B,CAACnN,WAAW,kFC5HrE,SAAS2E,EAAStH,CAGqB,KAHrB,CAChBO,UAAAA,CAAS,CACT,GAAGG,EACkC,CAHrBV,EAIhB,MACE,GAAAqO,EAAAhM,GAAA,EAACI,MAAAA,CACClC,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EAAG,oCAAqCnC,GAClD,GAAGG,CAAK,EAGf,+KCLA,IAAM6B,EAAkBiO,EAAAA,EAAyB,CAE3ChK,EAAUgK,EAAAA,EAAqB,CAE/B/J,EAAiB+J,EAAAA,EAAwB,CAEzC9J,EAAiB9G,EAAAA,UAAgB,CAGrC,CAAAI,EAA0CC,QAAzC,CAAEM,UAAAA,CAAS,CAAE0O,WAAAA,EAAa,CAAC,CAAE,GAAGvO,EAAO,CAAAV,QACxC,GAAAqO,EAAAhM,GAAA,EAACmO,EAAAA,EAAwB,EACvBvQ,IAAKA,EACLgP,WAAYA,EACZ1O,UAAWmC,CAAAA,EAAAA,EAAAA,EAAAA,EACT,qYACAnC,GAED,GAAGG,CAAK,IAGbgG,CAAAA,EAAe/D,WAAW,CAAG6N,EAAAA,EAAwB,CAAC7N,WAAW,oECvB1D,SAAS/B,IACd,GAAM,CAACD,EAAU8P,EAAY,CAAG7Q,EAAAA,QAAc,CAAsBgL,KAAAA,GAYpE,OAVAhL,EAAAA,SAAe,CAAC,KACd,IAAM8Q,EAAM3O,OAAO4O,UAAU,CAAC,eAAqCpP,MAAA,CAAtBqP,IAAsB,QAC7DC,EAAW,KACfJ,EAAY1O,OAAO+O,UAAU,CART,IAStB,EAGA,OAFAJ,EAAI1O,gBAAgB,CAAC,SAAU6O,GAC/BJ,EAAY1O,OAAO+O,UAAU,CAXP,KAYf,IAAMJ,EAAIzO,mBAAmB,CAAC,SAAU4O,EACjD,EAAG,EAAE,EAEE,CAAC,CAAClQ,CACX,wHCdA,IAAMoQ,EAAU,UAcZ,IAAMjR,EAAU,MAAMkR,MAAM,eAAeC,IAAI,CAACC,GAAOA,EAAIC,IAAI,IAC/D,GAAI,CAACrR,EAAQ0M,OAAO,CAChB,MAAM,MAAU,mBAEpB,MAAO,CACH4E,MAAOtR,EAAQ0M,OAAO,CACtB6E,KAAMvR,EAAQ0M,OAAO,CAE7B,EAEaQ,EAAW,cAGbsE,EAFP,IAAMA,EAAU,MAAMC,CAAAA,EAAAA,EAAAA,UAAAA,IAEtB,OAAOD,MAAAA,EAAAA,KAAAA,EAAAA,OAAAA,CAAAA,EAAAA,EAAS3J,IAAI,GAAb2J,KAAAA,IAAAA,EAAAA,KAAAA,EAAAA,EAAeE,GAAG,EAiDhBnJ,EAAS,CAClBoJ,MAAO,CACHC,SAAU,MAAOC,IAMb,IAAMC,EAAO,MAAMb,IACbc,EAAM,GAAatQ,MAAA,CAAVqQ,EAAKP,IAAI,CAAC,yBACnBtE,EAAQ,MAAMC,IAEpB,GAAI,CAACD,EACD,MAAM,MAAU,qCAGpB,OAAOiE,MAAMa,EAAK,CACdC,OAAQ,OACRC,KAAMC,KAAKC,SAAS,CAACN,GACrB/E,QAAS,CACL,eAAgB,mBAChBK,cAAe,UAAgB1L,MAAA,CAANwL,EAC7B,CACJ,EACJ,CACJ,CACJ,EAuCaqE,EAAQ,CACjBc,OAAQ,MAAOvQ,IACX,IAAMiQ,EAAO,MAAMb,IACfc,EAAM,GAActQ,MAAA,CAAXqQ,EAAKR,KAAK,CAAC,cAClBrE,EAAQ,MAAMC,IASpB,MAAOmF,CARU,MAAMnB,MAAMa,EAAK,CAC9BC,OAAQ,OACRC,KAAMC,KAAKC,SAAS,CAAC,CAAEtQ,IAAAA,CAAI,GAC3BiL,QAAS,CACL,eAAgB,mBAChBK,cAAe,UAAgB1L,MAAA,CAANwL,EAC7B,CACJ,IACgBoE,IAAI,EACxB,EACAiB,KAAM,MAAApS,OAAO,CAAEqS,OAAAA,CAAM,CAAEC,kBAAAA,CAAiB,CAAmD,CAAAtS,EACjF4R,EAAO,MAAMb,IACfc,EAAM,GAActQ,MAAA,CAAXqQ,EAAKR,KAAK,CAAC,YAClBrE,EAAQ,MAAMC,IAEpB,GAAI,CAACD,EACD,MAAM,MAAU,qCAkBpB,OAfIsF,GACAR,CAAAA,GAAO,WAAkBtQ,MAAA,CAAP8Q,EAAAA,EAGlBC,GACAT,CAAAA,GAAO,sBAAwCtQ,MAAA,CAAlB+Q,EAAAA,EAU1BH,CAPU,MAAMnB,MAAMa,EAAK,CAC9BC,OAAQ,MACRlF,QAAS,CACL,eAAgB,mBAChBK,cAAe,UAAgB1L,MAAA,CAANwL,EAC7B,CACJ,IACgBoE,IAAI,EACxB,EAWAoB,SAAU,MAAO5Q,IAEb,IAAMiQ,EAAO,MAAMb,IACfc,EAAM,GAAiClQ,MAAAA,CAA9BiQ,EAAKR,KAAK,CAAC,qBAAuB7P,MAAA,CAAJI,GAErCoL,EAAQ,MAAMC,IAEpB,GAAI,CAACD,EACD,MAAM,MAAU,qCAGpB,OAAOiE,MAAMa,EAAK,CACdC,OAAQ,MACRlF,QAAS,CACL,eAAgB,mBAChBK,cAAe,UAAgB1L,MAAA,CAANwL,EAC7B,CACJ,EACJ,EACAyF,OAAQ,MAAO7Q,IAEX,IAAMiQ,EAAO,MAAMb,IACfc,EAAM,GAA+BlQ,MAAAA,CAA5BiQ,EAAKR,KAAK,CAAC,mBAAqB7P,MAAA,CAAJI,GACnCoL,EAAQ,MAAMC,IAEpB,GAAI,CAACD,EACD,MAAM,MAAU,qCAGpB,OAAOiE,MAAMa,EAAK,CACdC,OAAQ,SACRlF,QAAS,CACL,eAAgB,mBAChBK,cAAe,UAAgB1L,MAAA,CAANwL,EAC7B,CACJ,EACJ,CACJ","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":""}
@@ -1,2 +0,0 @@
1
- "use strict";(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[4419],{63639:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("AlertTriangle",[["path",{d:"m21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3Z",key:"c3ski4"}],["path",{d:"M12 9v4",key:"juzpu7"}],["path",{d:"M12 17h.01",key:"p32p05"}]])},40875:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("ChevronDown",[["path",{d:"m6 9 6 6 6-6",key:"qrunsl"}]])},78867:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("Copy",[["rect",{width:"14",height:"14",x:"8",y:"8",rx:"2",ry:"2",key:"17jyea"}],["path",{d:"M4 16c-1.1 0-2-.9-2-2V4c0-1.1.9-2 2-2h10c1.1 0 2 .9 2 2",key:"zix9uf"}]])},87769:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("EyeOff",[["path",{d:"M9.88 9.88a3 3 0 1 0 4.24 4.24",key:"1jxqfv"}],["path",{d:"M10.73 5.08A10.43 10.43 0 0 1 12 5c7 0 10 7 10 7a13.16 13.16 0 0 1-1.67 2.68",key:"9wicm4"}],["path",{d:"M6.61 6.61A13.526 13.526 0 0 0 2 12s3 7 10 7a9.74 9.74 0 0 0 5.39-1.61",key:"1jreej"}],["line",{x1:"2",x2:"22",y1:"2",y2:"22",key:"a6p6uj"}]])},42208:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("Eye",[["path",{d:"M2 12s3-7 10-7 10 7 10 7-3 7-10 7-10-7-10-7Z",key:"rwhkz3"}],["circle",{cx:"12",cy:"12",r:"3",key:"1v7zrd"}]])},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"}]])},18930:function(e,t,n){n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("Trash2",[["path",{d:"M3 6h18",key:"d0wm0j"}],["path",{d:"M19 6v14c0 1-1 2-2 2H7c-1 0-2-1-2-2V6",key:"4alrt4"}],["path",{d:"M8 6V4c0-1 1-2 2-2h4c1 0 2 1 2 2v2",key:"v07s0e"}],["line",{x1:"10",x2:"10",y1:"11",y2:"17",key:"1uufr5"}],["line",{x1:"14",x2:"14",y1:"11",y2:"17",key:"xtxkd"}]])},12199:function(e,t,n){n.d(t,{D:function(){return s}});var r=n(5853),u=n(79285),o=n(49466),a=n(36628),i=n(59058),c=n(77828),l=n(63251),d=n(59394).Nq?u.useLayoutEffect:u.useEffect;function s(e,t){var n=(0,l.x)(null==t?void 0:t.client);(0,i.Vp)(e,i.n_.Mutation);var s=u.useState({called:!1,loading:!1,client:n}),f=s[0],p=s[1],v=u.useRef({result:f,mutationId:0,isMounted:!0,client:n,mutation:e,options:t});d(function(){Object.assign(v.current,{client:n,options:t,mutation:e})});var h=u.useCallback(function(e){void 0===e&&(e={});var t=v.current,n=t.options,u=t.mutation,i=(0,r.pi)((0,r.pi)({},n),{mutation:u}),l=e.client||v.current.client;v.current.result.loading||i.ignoreResults||!v.current.isMounted||p(v.current.result={loading:!0,error:void 0,data:void 0,called:!0,client:l});var d=++v.current.mutationId,s=(0,o.J)(i,e);return l.mutate(s).then(function(t){var n,r,u=t.data,o=t.errors,i=o&&o.length>0?new c.cA({graphQLErrors:o}):void 0,f=e.onError||(null===(n=v.current.options)||void 0===n?void 0:n.onError);if(i&&f&&f(i,s),d===v.current.mutationId&&!s.ignoreResults){var h={called:!0,loading:!1,data:u,error:i,client:l};v.current.isMounted&&!(0,a.D)(v.current.result,h)&&p(v.current.result=h)}var y=e.onCompleted||(null===(r=v.current.options)||void 0===r?void 0:r.onCompleted);return i||null==y||y(t.data,s),t},function(t){if(d===v.current.mutationId&&v.current.isMounted){var n,r={loading:!1,error:t,data:void 0,called:!0,client:l};(0,a.D)(v.current.result,r)||p(v.current.result=r)}var u=e.onError||(null===(n=v.current.options)||void 0===n?void 0:n.onError);if(u)return u(t,s),{data:void 0,errors:t};throw t})},[]),y=u.useCallback(function(){if(v.current.isMounted){var e={called:!1,loading:!1,client:v.current.client};Object.assign(v.current,{mutationId:0,result:e}),p(e)}},[]);return u.useEffect(function(){var e=v.current;return e.isMounted=!0,function(){e.isMounted=!1}},[]),[h,(0,r.pi)({reset:y},f)]}},9270:function(e,t,n){n.d(t,{fC:function(){return M},z$:function(){return E}});var r=n(2265),u=n(98575),o=n(73966),a=n(6741),i=n(80886),c=n(6718),l=n(90420),d=n(71599),s=n(66840),f=n(57437),p="Checkbox",[v,h]=(0,o.b)(p),[y,k]=v(p);function m(e){let{__scopeCheckbox:t,checked:n,children:u,defaultChecked:o,disabled:a,form:c,name:l,onCheckedChange:d,required:s,value:v="on",internal_do_not_use_render:h}=e,[k,m]=(0,i.T)({prop:n,defaultProp:null!=o&&o,onChange:d,caller:p}),[x,b]=r.useState(null),[M,g]=r.useState(null),E=r.useRef(!1),w=!x||!!c||!!x.closest("form"),j={checked:k,disabled:a,setChecked:m,control:x,setControl:b,name:l,form:c,value:v,hasConsumerStoppedPropagationRef:E,required:s,defaultChecked:!C(o)&&o,isFormControl:w,bubbleInput:M,setBubbleInput:g};return(0,f.jsx)(y,{scope:t,...j,children:"function"==typeof h?h(j):u})}var x="CheckboxTrigger",b=r.forwardRef((e,t)=>{let{__scopeCheckbox:n,onKeyDown:o,onClick:i,...c}=e,{control:l,value:d,disabled:p,checked:v,required:h,setControl:y,setChecked:m,hasConsumerStoppedPropagationRef:b,isFormControl:M,bubbleInput:g}=k(x,n),E=(0,u.e)(t,y),w=r.useRef(v);return r.useEffect(()=>{let e=null==l?void 0:l.form;if(e){let t=()=>m(w.current);return e.addEventListener("reset",t),()=>e.removeEventListener("reset",t)}},[l,m]),(0,f.jsx)(s.WV.button,{type:"button",role:"checkbox","aria-checked":C(v)?"mixed":v,"aria-required":h,"data-state":Z(v),"data-disabled":p?"":void 0,disabled:p,value:d,...c,ref:E,onKeyDown:(0,a.M)(o,e=>{"Enter"===e.key&&e.preventDefault()}),onClick:(0,a.M)(i,e=>{m(e=>!!C(e)||!e),g&&M&&(b.current=e.isPropagationStopped(),b.current||e.stopPropagation())})})});b.displayName=x;var M=r.forwardRef((e,t)=>{let{__scopeCheckbox:n,name:r,checked:u,defaultChecked:o,required:a,disabled:i,value:c,onCheckedChange:l,form:d,...s}=e;return(0,f.jsx)(m,{__scopeCheckbox:n,checked:u,defaultChecked:o,disabled:i,required:a,onCheckedChange:l,name:r,form:d,value:c,internal_do_not_use_render:e=>{let{isFormControl:r}=e;return(0,f.jsxs)(f.Fragment,{children:[(0,f.jsx)(b,{...s,ref:t,__scopeCheckbox:n}),r&&(0,f.jsx)(j,{__scopeCheckbox:n})]})}})});M.displayName=p;var g="CheckboxIndicator",E=r.forwardRef((e,t)=>{let{__scopeCheckbox:n,forceMount:r,...u}=e,o=k(g,n);return(0,f.jsx)(d.z,{present:r||C(o.checked)||!0===o.checked,children:(0,f.jsx)(s.WV.span,{"data-state":Z(o.checked),"data-disabled":o.disabled?"":void 0,...u,ref:t,style:{pointerEvents:"none",...e.style}})})});E.displayName=g;var w="CheckboxBubbleInput",j=r.forwardRef((e,t)=>{let{__scopeCheckbox:n,...o}=e,{control:a,hasConsumerStoppedPropagationRef:i,checked:d,defaultChecked:p,required:v,disabled:h,name:y,value:m,form:x,bubbleInput:b,setBubbleInput:M}=k(w,n),g=(0,u.e)(t,M),E=(0,c.D)(d),j=(0,l.t)(a);r.useEffect(()=>{if(!b)return;let e=Object.getOwnPropertyDescriptor(window.HTMLInputElement.prototype,"checked").set,t=!i.current;if(E!==d&&e){let n=new Event("click",{bubbles:t});b.indeterminate=C(d),e.call(b,!C(d)&&d),b.dispatchEvent(n)}},[b,E,d,i]);let Z=r.useRef(!C(d)&&d);return(0,f.jsx)(s.WV.input,{type:"checkbox","aria-hidden":!0,defaultChecked:null!=p?p:Z.current,required:v,disabled:h,name:y,value:m,form:x,...o,tabIndex:-1,ref:g,style:{...o.style,...j,position:"absolute",pointerEvents:"none",opacity:0,margin:0,transform:"translateX(-100%)"}})});function C(e){return"indeterminate"===e}function Z(e){return C(e)?"indeterminate":e?"checked":"unchecked"}j.displayName=w},6394:function(e,t,n){n.d(t,{f:function(){return i}});var r=n(2265),u=n(66840),o=n(57437),a=r.forwardRef((e,t)=>(0,o.jsx)(u.WV.label,{...e,ref:t,onMouseDown:t=>{var n;t.target.closest("button, input, select, textarea")||(null===(n=e.onMouseDown)||void 0===n||n.call(e,t),!t.defaultPrevented&&t.detail>1&&t.preventDefault())}}));a.displayName="Label";var i=a},6718:function(e,t,n){n.d(t,{D:function(){return u}});var r=n(2265);function u(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=4419-b9be79d8cd46a97d.js.map