@exulu/frontend 1.3.2 → 1.4.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 (254) hide show
  1. package/dist/.next/BUILD_ID +1 -1
  2. package/dist/.next/app-build-manifest.json +185 -174
  3. package/dist/.next/app-path-routes-manifest.json +1 -1
  4. package/dist/.next/build-manifest.json +2 -2
  5. package/dist/.next/prerender-manifest.json +1 -1
  6. package/dist/.next/server/app/(application)/agents/edit/[id]/page.js +1 -1
  7. package/dist/.next/server/app/(application)/agents/edit/[id]/page.js.nft.json +1 -1
  8. package/dist/.next/server/app/(application)/agents/edit/[id]/page_client-reference-manifest.js +1 -1
  9. package/dist/.next/server/app/(application)/agents/page.js +1 -2
  10. package/dist/.next/server/app/(application)/agents/page.js.nft.json +1 -1
  11. package/dist/.next/server/app/(application)/agents/page_client-reference-manifest.js +1 -1
  12. package/dist/.next/server/app/(application)/chat/[agent]/[session]/page.js +1 -1
  13. package/dist/.next/server/app/(application)/chat/[agent]/[session]/page.js.nft.json +1 -1
  14. package/dist/.next/server/app/(application)/chat/[agent]/[session]/page_client-reference-manifest.js +1 -1
  15. package/dist/.next/server/app/(application)/chat/[agent]/page.js +1 -1
  16. package/dist/.next/server/app/(application)/chat/[agent]/page.js.nft.json +1 -1
  17. package/dist/.next/server/app/(application)/chat/[agent]/page_client-reference-manifest.js +1 -1
  18. package/dist/.next/server/app/(application)/chat/page.js +1 -1
  19. package/dist/.next/server/app/(application)/chat/page.js.nft.json +1 -1
  20. package/dist/.next/server/app/(application)/chat/page_client-reference-manifest.js +1 -1
  21. package/dist/.next/server/app/(application)/configuration/page.js +1 -1
  22. package/dist/.next/server/app/(application)/configuration/page.js.nft.json +1 -1
  23. package/dist/.next/server/app/(application)/configuration/page_client-reference-manifest.js +1 -1
  24. package/dist/.next/server/app/(application)/dashboard/page.js +5 -1
  25. package/dist/.next/server/app/(application)/dashboard/page.js.nft.json +1 -1
  26. package/dist/.next/server/app/(application)/dashboard/page_client-reference-manifest.js +1 -1
  27. package/dist/.next/server/app/(application)/data/[[...query]]/page.js +5 -1
  28. package/dist/.next/server/app/(application)/data/[[...query]]/page.js.nft.json +1 -1
  29. package/dist/.next/server/app/(application)/data/[[...query]]/page_client-reference-manifest.js +1 -1
  30. package/dist/.next/server/app/(application)/evals/[id]/page.js +1 -1
  31. package/dist/.next/server/app/(application)/evals/[id]/page.js.nft.json +1 -1
  32. package/dist/.next/server/app/(application)/evals/[id]/page_client-reference-manifest.js +1 -1
  33. package/dist/.next/server/app/(application)/evals/[id]/runs/page.js +1 -1
  34. package/dist/.next/server/app/(application)/evals/[id]/runs/page.js.nft.json +1 -1
  35. package/dist/.next/server/app/(application)/evals/[id]/runs/page_client-reference-manifest.js +1 -1
  36. package/dist/.next/server/app/(application)/evals/cases/page.js +1 -1
  37. package/dist/.next/server/app/(application)/evals/cases/page.js.nft.json +1 -1
  38. package/dist/.next/server/app/(application)/evals/cases/page_client-reference-manifest.js +1 -1
  39. package/dist/.next/server/app/(application)/evals/page.js +1 -1
  40. package/dist/.next/server/app/(application)/evals/page.js.nft.json +1 -1
  41. package/dist/.next/server/app/(application)/evals/page_client-reference-manifest.js +1 -1
  42. package/dist/.next/server/app/(application)/explorer/page.js +1 -1
  43. package/dist/.next/server/app/(application)/explorer/page.js.nft.json +1 -1
  44. package/dist/.next/server/app/(application)/explorer/page_client-reference-manifest.js +1 -1
  45. package/dist/.next/server/app/(application)/jobs/page.js +1 -1
  46. package/dist/.next/server/app/(application)/jobs/page.js.nft.json +1 -1
  47. package/dist/.next/server/app/(application)/jobs/page_client-reference-manifest.js +1 -1
  48. package/dist/.next/server/app/(application)/keys/page.js +1 -1
  49. package/dist/.next/server/app/(application)/keys/page.js.nft.json +1 -1
  50. package/dist/.next/server/app/(application)/keys/page_client-reference-manifest.js +1 -1
  51. package/dist/.next/server/app/(application)/page.js +1 -1
  52. package/dist/.next/server/app/(application)/page.js.nft.json +1 -1
  53. package/dist/.next/server/app/(application)/page_client-reference-manifest.js +1 -1
  54. package/dist/.next/server/app/(application)/projects/[project]/page.js +1 -1
  55. package/dist/.next/server/app/(application)/projects/[project]/page.js.nft.json +1 -1
  56. package/dist/.next/server/app/(application)/projects/[project]/page_client-reference-manifest.js +1 -1
  57. package/dist/.next/server/app/(application)/projects/page.js +1 -1
  58. package/dist/.next/server/app/(application)/projects/page.js.nft.json +1 -1
  59. package/dist/.next/server/app/(application)/projects/page_client-reference-manifest.js +1 -1
  60. package/dist/.next/server/app/(application)/roles/page.js +1 -1
  61. package/dist/.next/server/app/(application)/roles/page.js.nft.json +1 -1
  62. package/dist/.next/server/app/(application)/roles/page_client-reference-manifest.js +1 -1
  63. package/dist/.next/server/app/(application)/token/page.js +1 -1
  64. package/dist/.next/server/app/(application)/token/page.js.nft.json +1 -1
  65. package/dist/.next/server/app/(application)/token/page_client-reference-manifest.js +1 -1
  66. package/dist/.next/server/app/(application)/users/page.js +1 -1
  67. package/dist/.next/server/app/(application)/users/page.js.nft.json +1 -1
  68. package/dist/.next/server/app/(application)/users/page_client-reference-manifest.js +1 -1
  69. package/dist/.next/server/app/(application)/variables/create/page.js +1 -1
  70. package/dist/.next/server/app/(application)/variables/create/page.js.nft.json +1 -1
  71. package/dist/.next/server/app/(application)/variables/create/page_client-reference-manifest.js +1 -1
  72. package/dist/.next/server/app/(application)/variables/edit/[variable_id]/page.js +1 -1
  73. package/dist/.next/server/app/(application)/variables/edit/[variable_id]/page.js.nft.json +1 -1
  74. package/dist/.next/server/app/(application)/variables/edit/[variable_id]/page_client-reference-manifest.js +1 -1
  75. package/dist/.next/server/app/(application)/variables/page.js +1 -1
  76. package/dist/.next/server/app/(application)/variables/page.js.nft.json +1 -1
  77. package/dist/.next/server/app/(application)/variables/page_client-reference-manifest.js +1 -1
  78. package/dist/.next/server/app/(application)/variables/usage/[variable_id]/page.js +1 -1
  79. package/dist/.next/server/app/(application)/variables/usage/[variable_id]/page.js.nft.json +1 -1
  80. package/dist/.next/server/app/(application)/variables/usage/[variable_id]/page_client-reference-manifest.js +1 -1
  81. package/dist/.next/server/app/(application)/workflows/page.js +1 -1
  82. package/dist/.next/server/app/(application)/workflows/page.js.nft.json +1 -1
  83. package/dist/.next/server/app/(application)/workflows/page_client-reference-manifest.js +1 -1
  84. package/dist/.next/server/app/(authentication)/login/page_client-reference-manifest.js +1 -1
  85. package/dist/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  86. package/dist/.next/server/app/_not-found.html +1 -1
  87. package/dist/.next/server/app/_not-found.rsc +1 -1
  88. package/dist/.next/server/app/api/auth/[...nextauth]/route.js +9 -9
  89. package/dist/.next/server/app-paths-manifest.json +5 -5
  90. package/dist/.next/server/chunks/1051.js +16 -16
  91. package/dist/.next/server/chunks/2270.js +188 -100
  92. package/dist/.next/server/chunks/{8838.js → 2875.js} +1 -1
  93. package/dist/.next/server/chunks/2916.js +1 -1
  94. package/dist/.next/server/chunks/3503.js +1 -0
  95. package/dist/.next/server/chunks/{7544.js → 4552.js} +1 -1
  96. package/dist/.next/server/chunks/{3393.js → 4739.js} +1 -1
  97. package/dist/.next/server/chunks/5192.js +1 -1
  98. package/dist/.next/server/chunks/5999.js +2 -0
  99. package/dist/.next/server/chunks/6282.js +1 -0
  100. package/dist/.next/server/chunks/6623.js +1 -0
  101. package/dist/.next/server/chunks/7721.js +1 -0
  102. package/dist/.next/server/chunks/7944.js +2 -2
  103. package/dist/.next/server/chunks/8050.js +1 -0
  104. package/dist/.next/server/chunks/8206.js +1 -0
  105. package/dist/.next/server/chunks/8679.js +5 -0
  106. package/dist/.next/server/middleware-manifest.json +5 -5
  107. package/dist/.next/server/pages/404.html +1 -1
  108. package/dist/.next/server/pages/500.html +1 -1
  109. package/dist/.next/server/server-reference-manifest.json +1 -1
  110. package/dist/.next/static/chunks/1294-368dc8ec59054da4.js +2 -0
  111. package/dist/.next/static/chunks/1294-368dc8ec59054da4.js.map +1 -0
  112. package/dist/.next/static/chunks/{1645-e5fd10236c0183ce.js → 1645-570e014100772437.js} +1 -1
  113. package/dist/.next/static/chunks/{1645-e5fd10236c0183ce.js.map → 1645-570e014100772437.js.map} +1 -1
  114. package/dist/.next/static/chunks/1957-5867716304ecd208.js +2 -0
  115. package/dist/.next/static/chunks/1957-5867716304ecd208.js.map +1 -0
  116. package/dist/.next/static/chunks/{2293-59b4bbce0c5bd2f2.js → 2293-1681cdef5b8c0c0b.js} +1 -1
  117. package/dist/.next/static/chunks/{2293-59b4bbce0c5bd2f2.js.map → 2293-1681cdef5b8c0c0b.js.map} +1 -1
  118. package/dist/.next/static/chunks/3475-28ce4fce960656bd.js +2 -0
  119. package/dist/.next/static/chunks/3475-28ce4fce960656bd.js.map +1 -0
  120. package/dist/.next/static/chunks/3832-a5e8fc6647e2be65.js +2 -0
  121. package/dist/.next/static/chunks/3832-a5e8fc6647e2be65.js.map +1 -0
  122. package/dist/.next/static/chunks/{4386-a36fe9c65884f025.js → 4386-c7690667749bff6a.js} +1 -1
  123. package/dist/.next/static/chunks/{4386-a36fe9c65884f025.js.map → 4386-c7690667749bff6a.js.map} +1 -1
  124. package/dist/.next/static/chunks/4750-4d5c13bbc96bc19b.js +2 -0
  125. package/dist/.next/static/chunks/4750-4d5c13bbc96bc19b.js.map +1 -0
  126. package/dist/.next/static/chunks/5243-1aaa41b2cd0ea87c.js +2 -0
  127. package/dist/.next/static/chunks/5243-1aaa41b2cd0ea87c.js.map +1 -0
  128. package/dist/.next/static/chunks/5978-814d6900645d2fcc.js +2 -0
  129. package/dist/.next/static/chunks/5978-814d6900645d2fcc.js.map +1 -0
  130. package/dist/.next/static/chunks/6373-651cb258c9e2b57b.js +2 -0
  131. package/dist/.next/static/chunks/6373-651cb258c9e2b57b.js.map +1 -0
  132. package/dist/.next/static/chunks/{7564-44a20b31206685e1.js → 6545-5a1d7cf4d5ca770e.js} +21 -21
  133. package/dist/.next/static/chunks/6545-5a1d7cf4d5ca770e.js.map +1 -0
  134. package/dist/.next/static/chunks/6839-0f4cfb48058a5ab6.js +2 -0
  135. package/dist/.next/static/chunks/6839-0f4cfb48058a5ab6.js.map +1 -0
  136. package/dist/.next/static/chunks/723-94e596796cbf911d.js +2 -0
  137. package/dist/.next/static/chunks/723-94e596796cbf911d.js.map +1 -0
  138. package/dist/.next/static/chunks/8202-db2cc384c66bc1be.js +2 -0
  139. package/dist/.next/static/chunks/8202-db2cc384c66bc1be.js.map +1 -0
  140. package/dist/.next/static/chunks/8269-37dd07515eb44201.js +2 -0
  141. package/dist/.next/static/chunks/8269-37dd07515eb44201.js.map +1 -0
  142. package/dist/.next/static/chunks/8469-ba31cbd7acab5f94.js +2 -0
  143. package/dist/.next/static/chunks/8469-ba31cbd7acab5f94.js.map +1 -0
  144. package/dist/.next/static/chunks/8824-20030459012376a3.js +2 -0
  145. package/dist/.next/static/chunks/8824-20030459012376a3.js.map +1 -0
  146. package/dist/.next/static/chunks/9105-3800f721d38e2b9a.js +2 -0
  147. package/dist/.next/static/chunks/9105-3800f721d38e2b9a.js.map +1 -0
  148. package/dist/.next/static/chunks/9183-a51605ff26b92fed.js +41 -0
  149. package/dist/.next/static/chunks/9183-a51605ff26b92fed.js.map +1 -0
  150. package/dist/.next/static/chunks/app/(application)/agents/edit/[id]/page-511f168123f85285.js +2 -0
  151. package/dist/.next/static/chunks/app/(application)/agents/edit/[id]/page-511f168123f85285.js.map +1 -0
  152. package/dist/.next/static/chunks/app/(application)/agents/{page-499ac3bd1044306c.js → page-63643deabdaa6b2c.js} +2 -2
  153. package/dist/.next/static/chunks/app/(application)/agents/{page-499ac3bd1044306c.js.map → page-63643deabdaa6b2c.js.map} +1 -1
  154. package/dist/.next/static/chunks/app/(application)/chat/[agent]/[session]/{page-3807a8bc2ae87548.js → page-62c7321ba26632af.js} +2 -2
  155. package/dist/.next/static/chunks/app/(application)/chat/[agent]/[session]/page-62c7321ba26632af.js.map +1 -0
  156. package/dist/.next/static/chunks/app/(application)/chat/{layout-53796525bd3e2443.js → layout-5eb1d22ddcbc0b55.js} +2 -2
  157. package/dist/.next/static/chunks/app/(application)/chat/{layout-53796525bd3e2443.js.map → layout-5eb1d22ddcbc0b55.js.map} +1 -1
  158. package/dist/.next/static/chunks/app/(application)/configuration/{page-2d8a0e2664ab9a94.js → page-8f92af5318feb84f.js} +1 -1
  159. package/dist/.next/static/chunks/app/(application)/configuration/{page-2d8a0e2664ab9a94.js.map → page-8f92af5318feb84f.js.map} +1 -1
  160. package/dist/.next/static/chunks/app/(application)/dashboard/page-00e425d942e0d769.js +2 -0
  161. package/dist/.next/static/chunks/app/(application)/dashboard/page-00e425d942e0d769.js.map +1 -0
  162. package/dist/.next/static/chunks/app/(application)/data/[[...query]]/layout-a460a56d3efac658.js +2 -0
  163. package/dist/.next/static/chunks/app/(application)/data/[[...query]]/layout-a460a56d3efac658.js.map +1 -0
  164. package/dist/.next/static/chunks/app/(application)/data/[[...query]]/page-bb06a9553c9ed178.js +2 -0
  165. package/dist/.next/static/chunks/app/(application)/data/[[...query]]/page-bb06a9553c9ed178.js.map +1 -0
  166. package/dist/.next/static/chunks/app/(application)/evals/[id]/{page-2238f1fb73d93328.js → page-ef82e92ca7d0da6c.js} +2 -2
  167. package/dist/.next/static/chunks/app/(application)/evals/[id]/{page-2238f1fb73d93328.js.map → page-ef82e92ca7d0da6c.js.map} +1 -1
  168. package/dist/.next/static/chunks/app/(application)/evals/[id]/runs/page-6622dd1b22a7885d.js +2 -0
  169. package/dist/.next/static/chunks/app/(application)/evals/[id]/runs/page-6622dd1b22a7885d.js.map +1 -0
  170. package/dist/.next/static/chunks/app/(application)/evals/cases/{page-ea5faf58b368feae.js → page-6246be9d6592d1d3.js} +2 -2
  171. package/dist/.next/static/chunks/app/(application)/evals/cases/{page-ea5faf58b368feae.js.map → page-6246be9d6592d1d3.js.map} +1 -1
  172. package/dist/.next/static/chunks/app/(application)/evals/{page-f79e1a90384ba618.js → page-b1e1fd7dba1e675f.js} +2 -2
  173. package/dist/.next/static/chunks/app/(application)/evals/{page-f79e1a90384ba618.js.map → page-b1e1fd7dba1e675f.js.map} +1 -1
  174. package/dist/.next/static/chunks/app/(application)/jobs/{page-e6f02a338bec4806.js → page-a96441a0bc654d68.js} +1 -1
  175. package/dist/.next/static/chunks/app/(application)/jobs/{page-e6f02a338bec4806.js.map → page-a96441a0bc654d68.js.map} +1 -1
  176. package/dist/.next/static/chunks/app/(application)/keys/{page-59ee4e0281131cbc.js → page-163aadfe9ad0d794.js} +1 -1
  177. package/dist/.next/static/chunks/app/(application)/keys/{page-59ee4e0281131cbc.js.map → page-163aadfe9ad0d794.js.map} +1 -1
  178. package/dist/.next/static/chunks/app/(application)/{layout-73d93420d0c6661c.js → layout-694c53aca85ef437.js} +2 -2
  179. package/dist/.next/static/chunks/app/(application)/{layout-73d93420d0c6661c.js.map → layout-694c53aca85ef437.js.map} +1 -1
  180. package/dist/.next/static/chunks/app/(application)/projects/[project]/page-e69828fde85c50af.js +2 -0
  181. package/dist/.next/static/chunks/app/(application)/projects/[project]/page-e69828fde85c50af.js.map +1 -0
  182. package/dist/.next/static/chunks/app/(application)/projects/{layout-f73ad7daf4825f1b.js → layout-d7642b25bf6d33b3.js} +2 -2
  183. package/dist/.next/static/chunks/app/(application)/projects/{layout-f73ad7daf4825f1b.js.map → layout-d7642b25bf6d33b3.js.map} +1 -1
  184. package/dist/.next/static/chunks/app/(application)/roles/page-5d5e5142f0997122.js +2 -0
  185. package/dist/.next/static/chunks/app/(application)/roles/page-5d5e5142f0997122.js.map +1 -0
  186. package/dist/.next/static/chunks/app/(application)/users/{page-e0a04fda52138aa0.js → page-b862cb199fd72525.js} +2 -2
  187. package/dist/.next/static/chunks/app/(application)/users/{page-e0a04fda52138aa0.js.map → page-b862cb199fd72525.js.map} +1 -1
  188. package/dist/.next/static/chunks/app/(application)/variables/create/{page-6c6076f3f253190d.js → page-d79d5c1c1ecabdb5.js} +1 -1
  189. package/dist/.next/static/chunks/app/(application)/variables/create/{page-6c6076f3f253190d.js.map → page-d79d5c1c1ecabdb5.js.map} +1 -1
  190. package/dist/.next/static/chunks/app/(application)/variables/edit/[variable_id]/{page-a3fa477fead5609a.js → page-72cf3aa95776ab96.js} +1 -1
  191. package/dist/.next/static/chunks/app/(application)/variables/edit/[variable_id]/{page-a3fa477fead5609a.js.map → page-72cf3aa95776ab96.js.map} +1 -1
  192. package/dist/.next/static/chunks/app/(application)/variables/{page-ddeff54a8b19bdbe.js → page-67864b471b48c950.js} +2 -2
  193. package/dist/.next/static/chunks/app/(application)/variables/{page-ddeff54a8b19bdbe.js.map → page-67864b471b48c950.js.map} +1 -1
  194. package/dist/.next/static/chunks/app/(application)/variables/usage/[variable_id]/{page-ed6d136e7ee3a591.js → page-208b4c9cc64abf2e.js} +1 -1
  195. package/dist/.next/static/chunks/app/(application)/variables/usage/[variable_id]/{page-ed6d136e7ee3a591.js.map → page-208b4c9cc64abf2e.js.map} +1 -1
  196. package/dist/.next/static/chunks/app/(application)/workflows/page-5b1ffc7c5012fdf6.js +2 -0
  197. package/dist/.next/static/chunks/app/(application)/workflows/page-5b1ffc7c5012fdf6.js.map +1 -0
  198. package/dist/.next/static/css/006966ab2edd0ebc.css +4 -0
  199. package/dist/.next/static/css/006966ab2edd0ebc.css.map +1 -0
  200. package/dist/.next/static/css/e3f2a16ab7676b05.css.map +1 -1
  201. package/dist/package.json +4 -1
  202. package/package.json +1 -1
  203. package/dist/.next/server/chunks/3743.js +0 -1
  204. package/dist/.next/server/chunks/4375.js +0 -1
  205. package/dist/.next/server/chunks/4680.js +0 -1
  206. package/dist/.next/server/chunks/7203.js +0 -5
  207. package/dist/.next/server/chunks/7598.js +0 -5
  208. package/dist/.next/server/chunks/8806.js +0 -1
  209. package/dist/.next/static/chunks/1957-670ddf66742d95f2.js +0 -2
  210. package/dist/.next/static/chunks/1957-670ddf66742d95f2.js.map +0 -1
  211. package/dist/.next/static/chunks/3397-5a704b2e12e9e883.js +0 -2
  212. package/dist/.next/static/chunks/3397-5a704b2e12e9e883.js.map +0 -1
  213. package/dist/.next/static/chunks/3832-10b779e2f89f162f.js +0 -2
  214. package/dist/.next/static/chunks/3832-10b779e2f89f162f.js.map +0 -1
  215. package/dist/.next/static/chunks/3998-c1c5bec61ce07357.js +0 -2
  216. package/dist/.next/static/chunks/3998-c1c5bec61ce07357.js.map +0 -1
  217. package/dist/.next/static/chunks/428-61741966c36f4f72.js +0 -2
  218. package/dist/.next/static/chunks/428-61741966c36f4f72.js.map +0 -1
  219. package/dist/.next/static/chunks/5585-4f0c084850210a82.js +0 -2
  220. package/dist/.next/static/chunks/5585-4f0c084850210a82.js.map +0 -1
  221. package/dist/.next/static/chunks/5615-042f927b657e6db1.js +0 -41
  222. package/dist/.next/static/chunks/5615-042f927b657e6db1.js.map +0 -1
  223. package/dist/.next/static/chunks/5978-f3b8475a2d9f9299.js +0 -2
  224. package/dist/.next/static/chunks/5978-f3b8475a2d9f9299.js.map +0 -1
  225. package/dist/.next/static/chunks/6242-c1c2f1479529e9d4.js +0 -2
  226. package/dist/.next/static/chunks/6242-c1c2f1479529e9d4.js.map +0 -1
  227. package/dist/.next/static/chunks/6373-fc4799cc7a13474a.js +0 -2
  228. package/dist/.next/static/chunks/6373-fc4799cc7a13474a.js.map +0 -1
  229. package/dist/.next/static/chunks/7398-c6de1642586049cd.js +0 -2
  230. package/dist/.next/static/chunks/7398-c6de1642586049cd.js.map +0 -1
  231. package/dist/.next/static/chunks/7564-44a20b31206685e1.js.map +0 -1
  232. package/dist/.next/static/chunks/79-1d568f3c4cd45bd4.js +0 -2
  233. package/dist/.next/static/chunks/79-1d568f3c4cd45bd4.js.map +0 -1
  234. package/dist/.next/static/chunks/app/(application)/agents/edit/[id]/page-b66390eb4a95ac1a.js +0 -2
  235. package/dist/.next/static/chunks/app/(application)/agents/edit/[id]/page-b66390eb4a95ac1a.js.map +0 -1
  236. package/dist/.next/static/chunks/app/(application)/chat/[agent]/[session]/page-3807a8bc2ae87548.js.map +0 -1
  237. package/dist/.next/static/chunks/app/(application)/dashboard/page-85d3f8d2bd28ae4b.js +0 -2
  238. package/dist/.next/static/chunks/app/(application)/dashboard/page-85d3f8d2bd28ae4b.js.map +0 -1
  239. package/dist/.next/static/chunks/app/(application)/data/[[...query]]/layout-822dad4cb57f62e2.js +0 -2
  240. package/dist/.next/static/chunks/app/(application)/data/[[...query]]/layout-822dad4cb57f62e2.js.map +0 -1
  241. package/dist/.next/static/chunks/app/(application)/data/[[...query]]/page-3efd7701534078ea.js +0 -2
  242. package/dist/.next/static/chunks/app/(application)/data/[[...query]]/page-3efd7701534078ea.js.map +0 -1
  243. package/dist/.next/static/chunks/app/(application)/evals/[id]/runs/page-b6a3cb8435be3ade.js +0 -2
  244. package/dist/.next/static/chunks/app/(application)/evals/[id]/runs/page-b6a3cb8435be3ade.js.map +0 -1
  245. package/dist/.next/static/chunks/app/(application)/projects/[project]/page-19382bb263f85fda.js +0 -2
  246. package/dist/.next/static/chunks/app/(application)/projects/[project]/page-19382bb263f85fda.js.map +0 -1
  247. package/dist/.next/static/chunks/app/(application)/roles/page-acd9ef282bc53557.js +0 -2
  248. package/dist/.next/static/chunks/app/(application)/roles/page-acd9ef282bc53557.js.map +0 -1
  249. package/dist/.next/static/chunks/app/(application)/workflows/page-38488c44d89b32f4.js +0 -2
  250. package/dist/.next/static/chunks/app/(application)/workflows/page-38488c44d89b32f4.js.map +0 -1
  251. package/dist/.next/static/css/a7092ddec8ffd4fb.css +0 -4
  252. package/dist/.next/static/css/a7092ddec8ffd4fb.css.map +0 -1
  253. /package/dist/.next/static/{HHwzgh0RLIMeodnSs4vIv → soJPoIxCmlpJ75t9n-Q9V}/_buildManifest.js +0 -0
  254. /package/dist/.next/static/{HHwzgh0RLIMeodnSs4vIv → soJPoIxCmlpJ75t9n-Q9V}/_ssgManifest.js +0 -0
@@ -1 +0,0 @@
1
- {"version":3,"file":"static/chunks/3397-5a704b2e12e9e883.js","mappings":"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","sources":["webpack://_N_E/./node_modules/@apollo/client/react/hooks/internal/useIsomorphicLayoutEffect.js","webpack://_N_E/./node_modules/@apollo/client/react/hooks/useMutation.js","webpack://_N_E/../src/presence.tsx","webpack://_N_E/../src/use-state-machine.tsx","webpack://_N_E/./node_modules/@radix-ui/react-scroll-area/node_modules/@radix-ui/primitive/dist/index.mjs","webpack://_N_E/../src/scroll-area.tsx","webpack://_N_E/../src/use-state-machine.ts"],"sourcesContent":["import * as React from \"rehackt\";\nimport { canUseDOM } from \"../../../utilities/index.js\";\n// use canUseDOM here instead of canUseLayoutEffect because we want to be able\n// to use useLayoutEffect in our jest tests. useLayoutEffect seems to work fine\n// in useSuspenseQuery tests, but to honor the original comment about the\n// warnings for useSyncExternalStore implementation, canUseLayoutEffect is left\n// alone.\nexport var useIsomorphicLayoutEffect = canUseDOM ? React.useLayoutEffect : React.useEffect;\n//# sourceMappingURL=useIsomorphicLayoutEffect.js.map","import { __assign } from \"tslib\";\nimport * as React from \"rehackt\";\nimport { mergeOptions } from \"../../utilities/index.js\";\nimport { equal } from \"@wry/equality\";\nimport { DocumentType, verifyDocumentType } from \"../parser/index.js\";\nimport { ApolloError } from \"../../errors/index.js\";\nimport { useApolloClient } from \"./useApolloClient.js\";\nimport { useIsomorphicLayoutEffect } from \"./internal/useIsomorphicLayoutEffect.js\";\n/**\n *\n *\n * > Refer to the [Mutations](https://www.apollographql.com/docs/react/data/mutations/) section for a more in-depth overview of `useMutation`.\n *\n * @example\n * ```jsx\n * import { gql, useMutation } from '@apollo/client';\n *\n * const ADD_TODO = gql`\n * mutation AddTodo($type: String!) {\n * addTodo(type: $type) {\n * id\n * type\n * }\n * }\n * `;\n *\n * function AddTodo() {\n * let input;\n * const [addTodo, { data }] = useMutation(ADD_TODO);\n *\n * return (\n * <div>\n * <form\n * onSubmit={e => {\n * e.preventDefault();\n * addTodo({ variables: { type: input.value } });\n * input.value = '';\n * }}\n * >\n * <input\n * ref={node => {\n * input = node;\n * }}\n * />\n * <button type=\"submit\">Add Todo</button>\n * </form>\n * </div>\n * );\n * }\n * ```\n * @since 3.0.0\n * @param mutation - A GraphQL mutation document parsed into an AST by `gql`.\n * @param options - Options to control how the mutation is executed.\n * @returns A tuple in the form of `[mutate, result]`\n */\nexport function useMutation(mutation, options) {\n var client = useApolloClient(options === null || options === void 0 ? void 0 : options.client);\n verifyDocumentType(mutation, DocumentType.Mutation);\n var _a = React.useState({\n called: false,\n loading: false,\n client: client,\n }), result = _a[0], setResult = _a[1];\n var ref = React.useRef({\n result: result,\n mutationId: 0,\n isMounted: true,\n client: client,\n mutation: mutation,\n options: options,\n });\n useIsomorphicLayoutEffect(function () {\n Object.assign(ref.current, { client: client, options: options, mutation: mutation });\n });\n var execute = React.useCallback(function (executeOptions) {\n if (executeOptions === void 0) { executeOptions = {}; }\n var _a = ref.current, options = _a.options, mutation = _a.mutation;\n var baseOptions = __assign(__assign({}, options), { mutation: mutation });\n var client = executeOptions.client || ref.current.client;\n if (!ref.current.result.loading &&\n !baseOptions.ignoreResults &&\n ref.current.isMounted) {\n setResult((ref.current.result = {\n loading: true,\n error: void 0,\n data: void 0,\n called: true,\n client: client,\n }));\n }\n var mutationId = ++ref.current.mutationId;\n var clientOptions = mergeOptions(baseOptions, executeOptions);\n return client\n .mutate(clientOptions)\n .then(function (response) {\n var _a, _b;\n var data = response.data, errors = response.errors;\n var error = errors && errors.length > 0 ?\n new ApolloError({ graphQLErrors: errors })\n : void 0;\n var onError = executeOptions.onError || ((_a = ref.current.options) === null || _a === void 0 ? void 0 : _a.onError);\n if (error && onError) {\n onError(error, clientOptions);\n }\n if (mutationId === ref.current.mutationId &&\n !clientOptions.ignoreResults) {\n var result_1 = {\n called: true,\n loading: false,\n data: data,\n error: error,\n client: client,\n };\n if (ref.current.isMounted && !equal(ref.current.result, result_1)) {\n setResult((ref.current.result = result_1));\n }\n }\n var onCompleted = executeOptions.onCompleted || ((_b = ref.current.options) === null || _b === void 0 ? void 0 : _b.onCompleted);\n if (!error) {\n onCompleted === null || onCompleted === void 0 ? void 0 : onCompleted(response.data, clientOptions);\n }\n return response;\n }, function (error) {\n var _a;\n if (mutationId === ref.current.mutationId &&\n ref.current.isMounted) {\n var result_2 = {\n loading: false,\n error: error,\n data: void 0,\n called: true,\n client: client,\n };\n if (!equal(ref.current.result, result_2)) {\n setResult((ref.current.result = result_2));\n }\n }\n var onError = executeOptions.onError || ((_a = ref.current.options) === null || _a === void 0 ? void 0 : _a.onError);\n if (onError) {\n onError(error, clientOptions);\n // TODO(brian): why are we returning this here???\n return { data: void 0, errors: error };\n }\n throw error;\n });\n }, []);\n var reset = React.useCallback(function () {\n if (ref.current.isMounted) {\n var result_3 = {\n called: false,\n loading: false,\n client: ref.current.client,\n };\n Object.assign(ref.current, { mutationId: 0, result: result_3 });\n setResult(result_3);\n }\n }, []);\n React.useEffect(function () {\n var current = ref.current;\n // eslint-disable-next-line react-compiler/react-compiler\n current.isMounted = true;\n return function () {\n current.isMounted = false;\n };\n }, []);\n return [execute, __assign({ reset: reset }, result)];\n}\n//# sourceMappingURL=useMutation.js.map","import * as React from 'react';\nimport { useComposedRefs } from '@radix-ui/react-compose-refs';\nimport { useLayoutEffect } from '@radix-ui/react-use-layout-effect';\nimport { useStateMachine } from './use-state-machine';\n\ninterface PresenceProps {\n children: React.ReactElement | ((props: { present: boolean }) => React.ReactElement);\n present: boolean;\n}\n\nconst Presence: React.FC<PresenceProps> = (props) => {\n const { present, children } = props;\n const presence = usePresence(present);\n\n const child = (\n typeof children === 'function'\n ? children({ present: presence.isPresent })\n : React.Children.only(children)\n ) as React.ReactElement<{ ref?: React.Ref<HTMLElement> }>;\n\n const ref = useComposedRefs(presence.ref, getElementRef(child));\n const forceMount = typeof children === 'function';\n return forceMount || presence.isPresent ? React.cloneElement(child, { ref }) : null;\n};\n\nPresence.displayName = 'Presence';\n\n/* -------------------------------------------------------------------------------------------------\n * usePresence\n * -----------------------------------------------------------------------------------------------*/\n\nfunction usePresence(present: boolean) {\n const [node, setNode] = React.useState<HTMLElement>();\n const stylesRef = React.useRef<CSSStyleDeclaration | null>(null);\n const prevPresentRef = React.useRef(present);\n const prevAnimationNameRef = React.useRef<string>('none');\n const initialState = present ? 'mounted' : 'unmounted';\n const [state, send] = useStateMachine(initialState, {\n mounted: {\n UNMOUNT: 'unmounted',\n ANIMATION_OUT: 'unmountSuspended',\n },\n unmountSuspended: {\n MOUNT: 'mounted',\n ANIMATION_END: 'unmounted',\n },\n unmounted: {\n MOUNT: 'mounted',\n },\n });\n\n React.useEffect(() => {\n const currentAnimationName = getAnimationName(stylesRef.current);\n prevAnimationNameRef.current = state === 'mounted' ? currentAnimationName : 'none';\n }, [state]);\n\n useLayoutEffect(() => {\n const styles = stylesRef.current;\n const wasPresent = prevPresentRef.current;\n const hasPresentChanged = wasPresent !== present;\n\n if (hasPresentChanged) {\n const prevAnimationName = prevAnimationNameRef.current;\n const currentAnimationName = getAnimationName(styles);\n\n if (present) {\n send('MOUNT');\n } else if (currentAnimationName === 'none' || styles?.display === 'none') {\n // If there is no exit animation or the element is hidden, animations won't run\n // so we unmount instantly\n send('UNMOUNT');\n } else {\n /**\n * When `present` changes to `false`, we check changes to animation-name to\n * determine whether an animation has started. We chose this approach (reading\n * computed styles) because there is no `animationrun` event and `animationstart`\n * fires after `animation-delay` has expired which would be too late.\n */\n const isAnimating = prevAnimationName !== currentAnimationName;\n\n if (wasPresent && isAnimating) {\n send('ANIMATION_OUT');\n } else {\n send('UNMOUNT');\n }\n }\n\n prevPresentRef.current = present;\n }\n }, [present, send]);\n\n useLayoutEffect(() => {\n if (node) {\n let timeoutId: number;\n const ownerWindow = node.ownerDocument.defaultView ?? window;\n /**\n * Triggering an ANIMATION_OUT during an ANIMATION_IN will fire an `animationcancel`\n * event for ANIMATION_IN after we have entered `unmountSuspended` state. So, we\n * make sure we only trigger ANIMATION_END for the currently active animation.\n */\n const handleAnimationEnd = (event: AnimationEvent) => {\n const currentAnimationName = getAnimationName(stylesRef.current);\n // The event.animationName is unescaped for CSS syntax,\n // so we need to escape it to compare with the animationName computed from the style.\n const isCurrentAnimation = currentAnimationName.includes(CSS.escape(event.animationName));\n if (event.target === node && isCurrentAnimation) {\n // With React 18 concurrency this update is applied a frame after the\n // animation ends, creating a flash of visible content. By setting the\n // animation fill mode to \"forwards\", we force the node to keep the\n // styles of the last keyframe, removing the flash.\n //\n // Previously we flushed the update via ReactDom.flushSync, but with\n // exit animations this resulted in the node being removed from the\n // DOM before the synthetic animationEnd event was dispatched, meaning\n // user-provided event handlers would not be called.\n // https://github.com/radix-ui/primitives/pull/1849\n send('ANIMATION_END');\n if (!prevPresentRef.current) {\n const currentFillMode = node.style.animationFillMode;\n node.style.animationFillMode = 'forwards';\n // Reset the style after the node had time to unmount (for cases\n // where the component chooses not to unmount). Doing this any\n // sooner than `setTimeout` (e.g. with `requestAnimationFrame`)\n // still causes a flash.\n timeoutId = ownerWindow.setTimeout(() => {\n if (node.style.animationFillMode === 'forwards') {\n node.style.animationFillMode = currentFillMode;\n }\n });\n }\n }\n };\n const handleAnimationStart = (event: AnimationEvent) => {\n if (event.target === node) {\n // if animation occurred, store its name as the previous animation.\n prevAnimationNameRef.current = getAnimationName(stylesRef.current);\n }\n };\n node.addEventListener('animationstart', handleAnimationStart);\n node.addEventListener('animationcancel', handleAnimationEnd);\n node.addEventListener('animationend', handleAnimationEnd);\n return () => {\n ownerWindow.clearTimeout(timeoutId);\n node.removeEventListener('animationstart', handleAnimationStart);\n node.removeEventListener('animationcancel', handleAnimationEnd);\n node.removeEventListener('animationend', handleAnimationEnd);\n };\n } else {\n // Transition to the unmounted state if the node is removed prematurely.\n // We avoid doing so during cleanup as the node may change but still exist.\n send('ANIMATION_END');\n }\n }, [node, send]);\n\n return {\n isPresent: ['mounted', 'unmountSuspended'].includes(state),\n ref: React.useCallback((node: HTMLElement) => {\n stylesRef.current = node ? getComputedStyle(node) : null;\n setNode(node);\n }, []),\n };\n}\n\n/* -----------------------------------------------------------------------------------------------*/\n\nfunction getAnimationName(styles: CSSStyleDeclaration | null) {\n return styles?.animationName || 'none';\n}\n\n// Before React 19 accessing `element.props.ref` will throw a warning and suggest using `element.ref`\n// After React 19 accessing `element.ref` does the opposite.\n// https://github.com/facebook/react/pull/28348\n//\n// Access the ref using the method that doesn't yield a warning.\nfunction getElementRef(element: React.ReactElement<{ ref?: React.Ref<unknown> }>) {\n // React <=18 in DEV\n let getter = Object.getOwnPropertyDescriptor(element.props, 'ref')?.get;\n let mayWarn = getter && 'isReactWarning' in getter && getter.isReactWarning;\n if (mayWarn) {\n return (element as any).ref;\n }\n\n // React 19 in DEV\n getter = Object.getOwnPropertyDescriptor(element, 'ref')?.get;\n mayWarn = getter && 'isReactWarning' in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n\n // Not DEV\n return element.props.ref || (element as any).ref;\n}\n\nconst Root = Presence;\n\nexport {\n Presence,\n //\n Root,\n};\nexport type { PresenceProps };\n","import * as React from 'react';\n\ntype Machine<S> = { [k: string]: { [k: string]: S } };\ntype MachineState<T> = keyof T;\ntype MachineEvent<T> = keyof UnionToIntersection<T[keyof T]>;\n\n// 🤯 https://fettblog.eu/typescript-union-to-intersection/\ntype UnionToIntersection<T> = (T extends any ? (x: T) => any : never) extends (x: infer R) => any\n ? R\n : never;\n\nexport function useStateMachine<M>(\n initialState: MachineState<M>,\n machine: M & Machine<MachineState<M>>\n) {\n return React.useReducer((state: MachineState<M>, event: MachineEvent<M>): MachineState<M> => {\n const nextState = (machine[state] as any)[event];\n return nextState ?? state;\n }, initialState);\n}\n","// src/primitive.tsx\nvar canUseDOM = !!(typeof window !== \"undefined\" && window.document && window.document.createElement);\nfunction composeEventHandlers(originalEventHandler, ourEventHandler, { checkForDefaultPrevented = true } = {}) {\n return function handleEvent(event) {\n originalEventHandler?.(event);\n if (checkForDefaultPrevented === false || !event.defaultPrevented) {\n return ourEventHandler?.(event);\n }\n };\n}\nfunction getOwnerWindow(element) {\n if (!canUseDOM) {\n throw new Error(\"Cannot access window outside of the DOM\");\n }\n return element?.ownerDocument?.defaultView ?? window;\n}\nfunction getOwnerDocument(element) {\n if (!canUseDOM) {\n throw new Error(\"Cannot access document outside of the DOM\");\n }\n return element?.ownerDocument ?? document;\n}\nfunction getActiveElement(node, activeDescendant = false) {\n const { activeElement } = getOwnerDocument(node);\n if (!activeElement?.nodeName) {\n return null;\n }\n if (isFrame(activeElement) && activeElement.contentDocument) {\n return getActiveElement(activeElement.contentDocument.body, activeDescendant);\n }\n if (activeDescendant) {\n const id = activeElement.getAttribute(\"aria-activedescendant\");\n if (id) {\n const element = getOwnerDocument(activeElement).getElementById(id);\n if (element) {\n return element;\n }\n }\n }\n return activeElement;\n}\nfunction isFrame(element) {\n return element.tagName === \"IFRAME\";\n}\nexport {\n canUseDOM,\n composeEventHandlers,\n getActiveElement,\n getOwnerDocument,\n getOwnerWindow,\n isFrame\n};\n//# sourceMappingURL=index.mjs.map\n","import * as React from 'react';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Presence } from '@radix-ui/react-presence';\nimport { createContextScope } from '@radix-ui/react-context';\nimport { useComposedRefs } from '@radix-ui/react-compose-refs';\nimport { useCallbackRef } from '@radix-ui/react-use-callback-ref';\nimport { useDirection } from '@radix-ui/react-direction';\nimport { useLayoutEffect } from '@radix-ui/react-use-layout-effect';\nimport { clamp } from '@radix-ui/number';\nimport { composeEventHandlers } from '@radix-ui/primitive';\nimport { useStateMachine } from './use-state-machine';\n\nimport type { Scope } from '@radix-ui/react-context';\n\ntype Direction = 'ltr' | 'rtl';\ntype Sizes = {\n content: number;\n viewport: number;\n scrollbar: {\n size: number;\n paddingStart: number;\n paddingEnd: number;\n };\n};\n\n/* -------------------------------------------------------------------------------------------------\n * ScrollArea\n * -----------------------------------------------------------------------------------------------*/\n\nconst SCROLL_AREA_NAME = 'ScrollArea';\n\ntype ScopedProps<P> = P & { __scopeScrollArea?: Scope };\nconst [createScrollAreaContext, createScrollAreaScope] = createContextScope(SCROLL_AREA_NAME);\n\ntype ScrollAreaContextValue = {\n type: 'auto' | 'always' | 'scroll' | 'hover';\n dir: Direction;\n scrollHideDelay: number;\n scrollArea: ScrollAreaElement | null;\n viewport: ScrollAreaViewportElement | null;\n onViewportChange(viewport: ScrollAreaViewportElement | null): void;\n content: HTMLDivElement | null;\n onContentChange(content: HTMLDivElement): void;\n scrollbarX: ScrollAreaScrollbarElement | null;\n onScrollbarXChange(scrollbar: ScrollAreaScrollbarElement | null): void;\n scrollbarXEnabled: boolean;\n onScrollbarXEnabledChange(rendered: boolean): void;\n scrollbarY: ScrollAreaScrollbarElement | null;\n onScrollbarYChange(scrollbar: ScrollAreaScrollbarElement | null): void;\n scrollbarYEnabled: boolean;\n onScrollbarYEnabledChange(rendered: boolean): void;\n onCornerWidthChange(width: number): void;\n onCornerHeightChange(height: number): void;\n};\n\nconst [ScrollAreaProvider, useScrollAreaContext] =\n createScrollAreaContext<ScrollAreaContextValue>(SCROLL_AREA_NAME);\n\ntype ScrollAreaElement = React.ComponentRef<typeof Primitive.div>;\ntype PrimitiveDivProps = React.ComponentPropsWithoutRef<typeof Primitive.div>;\ninterface ScrollAreaProps extends PrimitiveDivProps {\n type?: ScrollAreaContextValue['type'];\n dir?: ScrollAreaContextValue['dir'];\n scrollHideDelay?: number;\n}\n\nconst ScrollArea = React.forwardRef<ScrollAreaElement, ScrollAreaProps>(\n (props: ScopedProps<ScrollAreaProps>, forwardedRef) => {\n const {\n __scopeScrollArea,\n type = 'hover',\n dir,\n scrollHideDelay = 600,\n ...scrollAreaProps\n } = props;\n const [scrollArea, setScrollArea] = React.useState<ScrollAreaElement | null>(null);\n const [viewport, setViewport] = React.useState<ScrollAreaViewportElement | null>(null);\n const [content, setContent] = React.useState<HTMLDivElement | null>(null);\n const [scrollbarX, setScrollbarX] = React.useState<ScrollAreaScrollbarElement | null>(null);\n const [scrollbarY, setScrollbarY] = React.useState<ScrollAreaScrollbarElement | null>(null);\n const [cornerWidth, setCornerWidth] = React.useState(0);\n const [cornerHeight, setCornerHeight] = React.useState(0);\n const [scrollbarXEnabled, setScrollbarXEnabled] = React.useState(false);\n const [scrollbarYEnabled, setScrollbarYEnabled] = React.useState(false);\n const composedRefs = useComposedRefs(forwardedRef, (node) => setScrollArea(node));\n const direction = useDirection(dir);\n\n return (\n <ScrollAreaProvider\n scope={__scopeScrollArea}\n type={type}\n dir={direction}\n scrollHideDelay={scrollHideDelay}\n scrollArea={scrollArea}\n viewport={viewport}\n onViewportChange={setViewport}\n content={content}\n onContentChange={setContent}\n scrollbarX={scrollbarX}\n onScrollbarXChange={setScrollbarX}\n scrollbarXEnabled={scrollbarXEnabled}\n onScrollbarXEnabledChange={setScrollbarXEnabled}\n scrollbarY={scrollbarY}\n onScrollbarYChange={setScrollbarY}\n scrollbarYEnabled={scrollbarYEnabled}\n onScrollbarYEnabledChange={setScrollbarYEnabled}\n onCornerWidthChange={setCornerWidth}\n onCornerHeightChange={setCornerHeight}\n >\n <Primitive.div\n dir={direction}\n {...scrollAreaProps}\n ref={composedRefs}\n style={{\n position: 'relative',\n // Pass corner sizes as CSS vars to reduce re-renders of context consumers\n ['--radix-scroll-area-corner-width' as any]: cornerWidth + 'px',\n ['--radix-scroll-area-corner-height' as any]: cornerHeight + 'px',\n ...props.style,\n }}\n />\n </ScrollAreaProvider>\n );\n }\n);\n\nScrollArea.displayName = SCROLL_AREA_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * ScrollAreaViewport\n * -----------------------------------------------------------------------------------------------*/\n\nconst VIEWPORT_NAME = 'ScrollAreaViewport';\n\ntype ScrollAreaViewportElement = React.ComponentRef<typeof Primitive.div>;\ninterface ScrollAreaViewportProps extends PrimitiveDivProps {\n nonce?: string;\n}\n\nconst ScrollAreaViewport = React.forwardRef<ScrollAreaViewportElement, ScrollAreaViewportProps>(\n (props: ScopedProps<ScrollAreaViewportProps>, forwardedRef) => {\n const { __scopeScrollArea, children, nonce, ...viewportProps } = props;\n const context = useScrollAreaContext(VIEWPORT_NAME, __scopeScrollArea);\n const ref = React.useRef<ScrollAreaViewportElement>(null);\n const composedRefs = useComposedRefs(forwardedRef, ref, context.onViewportChange);\n return (\n <>\n {/* Hide scrollbars cross-browser and enable momentum scroll for touch devices */}\n <style\n dangerouslySetInnerHTML={{\n __html: `[data-radix-scroll-area-viewport]{scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;}[data-radix-scroll-area-viewport]::-webkit-scrollbar{display:none}`,\n }}\n nonce={nonce}\n />\n <Primitive.div\n data-radix-scroll-area-viewport=\"\"\n {...viewportProps}\n ref={composedRefs}\n style={{\n /**\n * We don't support `visible` because the intention is to have at least one scrollbar\n * if this component is used and `visible` will behave like `auto` in that case\n * https://developer.mozilla.org/en-US/docs/Web/CSS/overflow#description\n *\n * We don't handle `auto` because the intention is for the native implementation\n * to be hidden if using this component. We just want to ensure the node is scrollable\n * so could have used either `scroll` or `auto` here. We picked `scroll` to prevent\n * the browser from having to work out whether to render native scrollbars or not,\n * we tell it to with the intention of hiding them in CSS.\n */\n overflowX: context.scrollbarXEnabled ? 'scroll' : 'hidden',\n overflowY: context.scrollbarYEnabled ? 'scroll' : 'hidden',\n ...props.style,\n }}\n >\n {/**\n * `display: table` ensures our content div will match the size of its children in both\n * horizontal and vertical axis so we can determine if scroll width/height changed and\n * recalculate thumb sizes. This doesn't account for children with *percentage*\n * widths that change. We'll wait to see what use-cases consumers come up with there\n * before trying to resolve it.\n */}\n <div ref={context.onContentChange} style={{ minWidth: '100%', display: 'table' }}>\n {children}\n </div>\n </Primitive.div>\n </>\n );\n }\n);\n\nScrollAreaViewport.displayName = VIEWPORT_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * ScrollAreaScrollbar\n * -----------------------------------------------------------------------------------------------*/\n\nconst SCROLLBAR_NAME = 'ScrollAreaScrollbar';\n\ntype ScrollAreaScrollbarElement = ScrollAreaScrollbarVisibleElement;\ninterface ScrollAreaScrollbarProps extends ScrollAreaScrollbarVisibleProps {\n forceMount?: true;\n}\n\nconst ScrollAreaScrollbar = React.forwardRef<ScrollAreaScrollbarElement, ScrollAreaScrollbarProps>(\n (props: ScopedProps<ScrollAreaScrollbarProps>, forwardedRef) => {\n const { forceMount, ...scrollbarProps } = props;\n const context = useScrollAreaContext(SCROLLBAR_NAME, props.__scopeScrollArea);\n const { onScrollbarXEnabledChange, onScrollbarYEnabledChange } = context;\n const isHorizontal = props.orientation === 'horizontal';\n\n React.useEffect(() => {\n isHorizontal ? onScrollbarXEnabledChange(true) : onScrollbarYEnabledChange(true);\n return () => {\n isHorizontal ? onScrollbarXEnabledChange(false) : onScrollbarYEnabledChange(false);\n };\n }, [isHorizontal, onScrollbarXEnabledChange, onScrollbarYEnabledChange]);\n\n return context.type === 'hover' ? (\n <ScrollAreaScrollbarHover {...scrollbarProps} ref={forwardedRef} forceMount={forceMount} />\n ) : context.type === 'scroll' ? (\n <ScrollAreaScrollbarScroll {...scrollbarProps} ref={forwardedRef} forceMount={forceMount} />\n ) : context.type === 'auto' ? (\n <ScrollAreaScrollbarAuto {...scrollbarProps} ref={forwardedRef} forceMount={forceMount} />\n ) : context.type === 'always' ? (\n <ScrollAreaScrollbarVisible {...scrollbarProps} ref={forwardedRef} />\n ) : null;\n }\n);\n\nScrollAreaScrollbar.displayName = SCROLLBAR_NAME;\n\n/* -----------------------------------------------------------------------------------------------*/\n\ntype ScrollAreaScrollbarHoverElement = ScrollAreaScrollbarAutoElement;\ninterface ScrollAreaScrollbarHoverProps extends ScrollAreaScrollbarAutoProps {\n forceMount?: true;\n}\n\nconst ScrollAreaScrollbarHover = React.forwardRef<\n ScrollAreaScrollbarHoverElement,\n ScrollAreaScrollbarHoverProps\n>((props: ScopedProps<ScrollAreaScrollbarHoverProps>, forwardedRef) => {\n const { forceMount, ...scrollbarProps } = props;\n const context = useScrollAreaContext(SCROLLBAR_NAME, props.__scopeScrollArea);\n const [visible, setVisible] = React.useState(false);\n\n React.useEffect(() => {\n const scrollArea = context.scrollArea;\n let hideTimer = 0;\n if (scrollArea) {\n const handlePointerEnter = () => {\n window.clearTimeout(hideTimer);\n setVisible(true);\n };\n const handlePointerLeave = () => {\n hideTimer = window.setTimeout(() => setVisible(false), context.scrollHideDelay);\n };\n scrollArea.addEventListener('pointerenter', handlePointerEnter);\n scrollArea.addEventListener('pointerleave', handlePointerLeave);\n return () => {\n window.clearTimeout(hideTimer);\n scrollArea.removeEventListener('pointerenter', handlePointerEnter);\n scrollArea.removeEventListener('pointerleave', handlePointerLeave);\n };\n }\n }, [context.scrollArea, context.scrollHideDelay]);\n\n return (\n <Presence present={forceMount || visible}>\n <ScrollAreaScrollbarAuto\n data-state={visible ? 'visible' : 'hidden'}\n {...scrollbarProps}\n ref={forwardedRef}\n />\n </Presence>\n );\n});\n\ntype ScrollAreaScrollbarScrollElement = ScrollAreaScrollbarVisibleElement;\ninterface ScrollAreaScrollbarScrollProps extends ScrollAreaScrollbarVisibleProps {\n forceMount?: true;\n}\n\nconst ScrollAreaScrollbarScroll = React.forwardRef<\n ScrollAreaScrollbarScrollElement,\n ScrollAreaScrollbarScrollProps\n>((props: ScopedProps<ScrollAreaScrollbarScrollProps>, forwardedRef) => {\n const { forceMount, ...scrollbarProps } = props;\n const context = useScrollAreaContext(SCROLLBAR_NAME, props.__scopeScrollArea);\n const isHorizontal = props.orientation === 'horizontal';\n const debounceScrollEnd = useDebounceCallback(() => send('SCROLL_END'), 100);\n const [state, send] = useStateMachine('hidden', {\n hidden: {\n SCROLL: 'scrolling',\n },\n scrolling: {\n SCROLL_END: 'idle',\n POINTER_ENTER: 'interacting',\n },\n interacting: {\n SCROLL: 'interacting',\n POINTER_LEAVE: 'idle',\n },\n idle: {\n HIDE: 'hidden',\n SCROLL: 'scrolling',\n POINTER_ENTER: 'interacting',\n },\n });\n\n React.useEffect(() => {\n if (state === 'idle') {\n const hideTimer = window.setTimeout(() => send('HIDE'), context.scrollHideDelay);\n return () => window.clearTimeout(hideTimer);\n }\n }, [state, context.scrollHideDelay, send]);\n\n React.useEffect(() => {\n const viewport = context.viewport;\n const scrollDirection = isHorizontal ? 'scrollLeft' : 'scrollTop';\n\n if (viewport) {\n let prevScrollPos = viewport[scrollDirection];\n const handleScroll = () => {\n const scrollPos = viewport[scrollDirection];\n const hasScrollInDirectionChanged = prevScrollPos !== scrollPos;\n if (hasScrollInDirectionChanged) {\n send('SCROLL');\n debounceScrollEnd();\n }\n prevScrollPos = scrollPos;\n };\n viewport.addEventListener('scroll', handleScroll);\n return () => viewport.removeEventListener('scroll', handleScroll);\n }\n }, [context.viewport, isHorizontal, send, debounceScrollEnd]);\n\n return (\n <Presence present={forceMount || state !== 'hidden'}>\n <ScrollAreaScrollbarVisible\n data-state={state === 'hidden' ? 'hidden' : 'visible'}\n {...scrollbarProps}\n ref={forwardedRef}\n onPointerEnter={composeEventHandlers(props.onPointerEnter, () => send('POINTER_ENTER'))}\n onPointerLeave={composeEventHandlers(props.onPointerLeave, () => send('POINTER_LEAVE'))}\n />\n </Presence>\n );\n});\n\ntype ScrollAreaScrollbarAutoElement = ScrollAreaScrollbarVisibleElement;\ninterface ScrollAreaScrollbarAutoProps extends ScrollAreaScrollbarVisibleProps {\n forceMount?: true;\n}\n\nconst ScrollAreaScrollbarAuto = React.forwardRef<\n ScrollAreaScrollbarAutoElement,\n ScrollAreaScrollbarAutoProps\n>((props: ScopedProps<ScrollAreaScrollbarAutoProps>, forwardedRef) => {\n const context = useScrollAreaContext(SCROLLBAR_NAME, props.__scopeScrollArea);\n const { forceMount, ...scrollbarProps } = props;\n const [visible, setVisible] = React.useState(false);\n const isHorizontal = props.orientation === 'horizontal';\n const handleResize = useDebounceCallback(() => {\n if (context.viewport) {\n const isOverflowX = context.viewport.offsetWidth < context.viewport.scrollWidth;\n const isOverflowY = context.viewport.offsetHeight < context.viewport.scrollHeight;\n setVisible(isHorizontal ? isOverflowX : isOverflowY);\n }\n }, 10);\n\n useResizeObserver(context.viewport, handleResize);\n useResizeObserver(context.content, handleResize);\n\n return (\n <Presence present={forceMount || visible}>\n <ScrollAreaScrollbarVisible\n data-state={visible ? 'visible' : 'hidden'}\n {...scrollbarProps}\n ref={forwardedRef}\n />\n </Presence>\n );\n});\n\n/* -----------------------------------------------------------------------------------------------*/\n\ntype ScrollAreaScrollbarVisibleElement = ScrollAreaScrollbarAxisElement;\ninterface ScrollAreaScrollbarVisibleProps\n extends Omit<ScrollAreaScrollbarAxisProps, keyof ScrollAreaScrollbarAxisPrivateProps> {\n orientation?: 'horizontal' | 'vertical';\n}\n\nconst ScrollAreaScrollbarVisible = React.forwardRef<\n ScrollAreaScrollbarVisibleElement,\n ScrollAreaScrollbarVisibleProps\n>((props: ScopedProps<ScrollAreaScrollbarVisibleProps>, forwardedRef) => {\n const { orientation = 'vertical', ...scrollbarProps } = props;\n const context = useScrollAreaContext(SCROLLBAR_NAME, props.__scopeScrollArea);\n const thumbRef = React.useRef<ScrollAreaThumbElement | null>(null);\n const pointerOffsetRef = React.useRef(0);\n const [sizes, setSizes] = React.useState<Sizes>({\n content: 0,\n viewport: 0,\n scrollbar: { size: 0, paddingStart: 0, paddingEnd: 0 },\n });\n const thumbRatio = getThumbRatio(sizes.viewport, sizes.content);\n\n type UncommonProps = 'onThumbPositionChange' | 'onDragScroll' | 'onWheelScroll';\n const commonProps: Omit<ScrollAreaScrollbarAxisPrivateProps, UncommonProps> = {\n ...scrollbarProps,\n sizes,\n onSizesChange: setSizes,\n hasThumb: Boolean(thumbRatio > 0 && thumbRatio < 1),\n onThumbChange: (thumb) => (thumbRef.current = thumb),\n onThumbPointerUp: () => (pointerOffsetRef.current = 0),\n onThumbPointerDown: (pointerPos) => (pointerOffsetRef.current = pointerPos),\n };\n\n function getScrollPosition(pointerPos: number, dir?: Direction) {\n return getScrollPositionFromPointer(pointerPos, pointerOffsetRef.current, sizes, dir);\n }\n\n if (orientation === 'horizontal') {\n return (\n <ScrollAreaScrollbarX\n {...commonProps}\n ref={forwardedRef}\n onThumbPositionChange={() => {\n if (context.viewport && thumbRef.current) {\n const scrollPos = context.viewport.scrollLeft;\n const offset = getThumbOffsetFromScroll(scrollPos, sizes, context.dir);\n thumbRef.current.style.transform = `translate3d(${offset}px, 0, 0)`;\n }\n }}\n onWheelScroll={(scrollPos) => {\n if (context.viewport) context.viewport.scrollLeft = scrollPos;\n }}\n onDragScroll={(pointerPos) => {\n if (context.viewport) {\n context.viewport.scrollLeft = getScrollPosition(pointerPos, context.dir);\n }\n }}\n />\n );\n }\n\n if (orientation === 'vertical') {\n return (\n <ScrollAreaScrollbarY\n {...commonProps}\n ref={forwardedRef}\n onThumbPositionChange={() => {\n if (context.viewport && thumbRef.current) {\n const scrollPos = context.viewport.scrollTop;\n const offset = getThumbOffsetFromScroll(scrollPos, sizes);\n thumbRef.current.style.transform = `translate3d(0, ${offset}px, 0)`;\n }\n }}\n onWheelScroll={(scrollPos) => {\n if (context.viewport) context.viewport.scrollTop = scrollPos;\n }}\n onDragScroll={(pointerPos) => {\n if (context.viewport) context.viewport.scrollTop = getScrollPosition(pointerPos);\n }}\n />\n );\n }\n\n return null;\n});\n\n/* -----------------------------------------------------------------------------------------------*/\n\ntype ScrollAreaScrollbarAxisPrivateProps = {\n hasThumb: boolean;\n sizes: Sizes;\n onSizesChange(sizes: Sizes): void;\n onThumbChange(thumb: ScrollAreaThumbElement | null): void;\n onThumbPointerDown(pointerPos: number): void;\n onThumbPointerUp(): void;\n onThumbPositionChange(): void;\n onWheelScroll(scrollPos: number): void;\n onDragScroll(pointerPos: number): void;\n};\n\ntype ScrollAreaScrollbarAxisElement = ScrollAreaScrollbarImplElement;\ninterface ScrollAreaScrollbarAxisProps\n extends Omit<ScrollAreaScrollbarImplProps, keyof ScrollAreaScrollbarImplPrivateProps>,\n ScrollAreaScrollbarAxisPrivateProps {}\n\nconst ScrollAreaScrollbarX = React.forwardRef<\n ScrollAreaScrollbarAxisElement,\n ScrollAreaScrollbarAxisProps\n>((props: ScopedProps<ScrollAreaScrollbarAxisProps>, forwardedRef) => {\n const { sizes, onSizesChange, ...scrollbarProps } = props;\n const context = useScrollAreaContext(SCROLLBAR_NAME, props.__scopeScrollArea);\n const [computedStyle, setComputedStyle] = React.useState<CSSStyleDeclaration>();\n const ref = React.useRef<ScrollAreaScrollbarAxisElement>(null);\n const composeRefs = useComposedRefs(forwardedRef, ref, context.onScrollbarXChange);\n\n React.useEffect(() => {\n if (ref.current) setComputedStyle(getComputedStyle(ref.current));\n }, [ref]);\n\n return (\n <ScrollAreaScrollbarImpl\n data-orientation=\"horizontal\"\n {...scrollbarProps}\n ref={composeRefs}\n sizes={sizes}\n style={{\n bottom: 0,\n left: context.dir === 'rtl' ? 'var(--radix-scroll-area-corner-width)' : 0,\n right: context.dir === 'ltr' ? 'var(--radix-scroll-area-corner-width)' : 0,\n ['--radix-scroll-area-thumb-width' as any]: getThumbSize(sizes) + 'px',\n ...props.style,\n }}\n onThumbPointerDown={(pointerPos) => props.onThumbPointerDown(pointerPos.x)}\n onDragScroll={(pointerPos) => props.onDragScroll(pointerPos.x)}\n onWheelScroll={(event, maxScrollPos) => {\n if (context.viewport) {\n const scrollPos = context.viewport.scrollLeft + event.deltaX;\n props.onWheelScroll(scrollPos);\n // prevent window scroll when wheeling on scrollbar\n if (isScrollingWithinScrollbarBounds(scrollPos, maxScrollPos)) {\n event.preventDefault();\n }\n }\n }}\n onResize={() => {\n if (ref.current && context.viewport && computedStyle) {\n onSizesChange({\n content: context.viewport.scrollWidth,\n viewport: context.viewport.offsetWidth,\n scrollbar: {\n size: ref.current.clientWidth,\n paddingStart: toInt(computedStyle.paddingLeft),\n paddingEnd: toInt(computedStyle.paddingRight),\n },\n });\n }\n }}\n />\n );\n});\n\nconst ScrollAreaScrollbarY = React.forwardRef<\n ScrollAreaScrollbarAxisElement,\n ScrollAreaScrollbarAxisProps\n>((props: ScopedProps<ScrollAreaScrollbarAxisProps>, forwardedRef) => {\n const { sizes, onSizesChange, ...scrollbarProps } = props;\n const context = useScrollAreaContext(SCROLLBAR_NAME, props.__scopeScrollArea);\n const [computedStyle, setComputedStyle] = React.useState<CSSStyleDeclaration>();\n const ref = React.useRef<ScrollAreaScrollbarAxisElement>(null);\n const composeRefs = useComposedRefs(forwardedRef, ref, context.onScrollbarYChange);\n\n React.useEffect(() => {\n if (ref.current) setComputedStyle(getComputedStyle(ref.current));\n }, [ref]);\n\n return (\n <ScrollAreaScrollbarImpl\n data-orientation=\"vertical\"\n {...scrollbarProps}\n ref={composeRefs}\n sizes={sizes}\n style={{\n top: 0,\n right: context.dir === 'ltr' ? 0 : undefined,\n left: context.dir === 'rtl' ? 0 : undefined,\n bottom: 'var(--radix-scroll-area-corner-height)',\n ['--radix-scroll-area-thumb-height' as any]: getThumbSize(sizes) + 'px',\n ...props.style,\n }}\n onThumbPointerDown={(pointerPos) => props.onThumbPointerDown(pointerPos.y)}\n onDragScroll={(pointerPos) => props.onDragScroll(pointerPos.y)}\n onWheelScroll={(event, maxScrollPos) => {\n if (context.viewport) {\n const scrollPos = context.viewport.scrollTop + event.deltaY;\n props.onWheelScroll(scrollPos);\n // prevent window scroll when wheeling on scrollbar\n if (isScrollingWithinScrollbarBounds(scrollPos, maxScrollPos)) {\n event.preventDefault();\n }\n }\n }}\n onResize={() => {\n if (ref.current && context.viewport && computedStyle) {\n onSizesChange({\n content: context.viewport.scrollHeight,\n viewport: context.viewport.offsetHeight,\n scrollbar: {\n size: ref.current.clientHeight,\n paddingStart: toInt(computedStyle.paddingTop),\n paddingEnd: toInt(computedStyle.paddingBottom),\n },\n });\n }\n }}\n />\n );\n});\n\n/* -----------------------------------------------------------------------------------------------*/\n\ntype ScrollbarContext = {\n hasThumb: boolean;\n scrollbar: ScrollAreaScrollbarElement | null;\n onThumbChange(thumb: ScrollAreaThumbElement | null): void;\n onThumbPointerUp(): void;\n onThumbPointerDown(pointerPos: { x: number; y: number }): void;\n onThumbPositionChange(): void;\n};\n\nconst [ScrollbarProvider, useScrollbarContext] =\n createScrollAreaContext<ScrollbarContext>(SCROLLBAR_NAME);\n\ntype ScrollAreaScrollbarImplElement = React.ComponentRef<typeof Primitive.div>;\ntype ScrollAreaScrollbarImplPrivateProps = {\n sizes: Sizes;\n hasThumb: boolean;\n onThumbChange: ScrollbarContext['onThumbChange'];\n onThumbPointerUp: ScrollbarContext['onThumbPointerUp'];\n onThumbPointerDown: ScrollbarContext['onThumbPointerDown'];\n onThumbPositionChange: ScrollbarContext['onThumbPositionChange'];\n onWheelScroll(event: WheelEvent, maxScrollPos: number): void;\n onDragScroll(pointerPos: { x: number; y: number }): void;\n onResize(): void;\n};\ninterface ScrollAreaScrollbarImplProps\n extends Omit<PrimitiveDivProps, keyof ScrollAreaScrollbarImplPrivateProps>,\n ScrollAreaScrollbarImplPrivateProps {}\n\nconst ScrollAreaScrollbarImpl = React.forwardRef<\n ScrollAreaScrollbarImplElement,\n ScrollAreaScrollbarImplProps\n>((props: ScopedProps<ScrollAreaScrollbarImplProps>, forwardedRef) => {\n const {\n __scopeScrollArea,\n sizes,\n hasThumb,\n onThumbChange,\n onThumbPointerUp,\n onThumbPointerDown,\n onThumbPositionChange,\n onDragScroll,\n onWheelScroll,\n onResize,\n ...scrollbarProps\n } = props;\n const context = useScrollAreaContext(SCROLLBAR_NAME, __scopeScrollArea);\n const [scrollbar, setScrollbar] = React.useState<ScrollAreaScrollbarElement | null>(null);\n const composeRefs = useComposedRefs(forwardedRef, (node) => setScrollbar(node));\n const rectRef = React.useRef<DOMRect | null>(null);\n const prevWebkitUserSelectRef = React.useRef<string>('');\n const viewport = context.viewport;\n const maxScrollPos = sizes.content - sizes.viewport;\n const handleWheelScroll = useCallbackRef(onWheelScroll);\n const handleThumbPositionChange = useCallbackRef(onThumbPositionChange);\n const handleResize = useDebounceCallback(onResize, 10);\n\n function handleDragScroll(event: React.PointerEvent<HTMLElement>) {\n if (rectRef.current) {\n const x = event.clientX - rectRef.current.left;\n const y = event.clientY - rectRef.current.top;\n onDragScroll({ x, y });\n }\n }\n\n /**\n * We bind wheel event imperatively so we can switch off passive\n * mode for document wheel event to allow it to be prevented\n */\n React.useEffect(() => {\n const handleWheel = (event: WheelEvent) => {\n const element = event.target as HTMLElement;\n const isScrollbarWheel = scrollbar?.contains(element);\n if (isScrollbarWheel) handleWheelScroll(event, maxScrollPos);\n };\n document.addEventListener('wheel', handleWheel, { passive: false });\n return () => document.removeEventListener('wheel', handleWheel, { passive: false } as any);\n }, [viewport, scrollbar, maxScrollPos, handleWheelScroll]);\n\n /**\n * Update thumb position on sizes change\n */\n React.useEffect(handleThumbPositionChange, [sizes, handleThumbPositionChange]);\n\n useResizeObserver(scrollbar, handleResize);\n useResizeObserver(context.content, handleResize);\n\n return (\n <ScrollbarProvider\n scope={__scopeScrollArea}\n scrollbar={scrollbar}\n hasThumb={hasThumb}\n onThumbChange={useCallbackRef(onThumbChange)}\n onThumbPointerUp={useCallbackRef(onThumbPointerUp)}\n onThumbPositionChange={handleThumbPositionChange}\n onThumbPointerDown={useCallbackRef(onThumbPointerDown)}\n >\n <Primitive.div\n {...scrollbarProps}\n ref={composeRefs}\n style={{ position: 'absolute', ...scrollbarProps.style }}\n onPointerDown={composeEventHandlers(props.onPointerDown, (event) => {\n const mainPointer = 0;\n if (event.button === mainPointer) {\n const element = event.target as HTMLElement;\n element.setPointerCapture(event.pointerId);\n rectRef.current = scrollbar!.getBoundingClientRect();\n // pointer capture doesn't prevent text selection in Safari\n // so we remove text selection manually when scrolling\n prevWebkitUserSelectRef.current = document.body.style.webkitUserSelect;\n document.body.style.webkitUserSelect = 'none';\n if (context.viewport) context.viewport.style.scrollBehavior = 'auto';\n handleDragScroll(event);\n }\n })}\n onPointerMove={composeEventHandlers(props.onPointerMove, handleDragScroll)}\n onPointerUp={composeEventHandlers(props.onPointerUp, (event) => {\n const element = event.target as HTMLElement;\n if (element.hasPointerCapture(event.pointerId)) {\n element.releasePointerCapture(event.pointerId);\n }\n document.body.style.webkitUserSelect = prevWebkitUserSelectRef.current;\n if (context.viewport) context.viewport.style.scrollBehavior = '';\n rectRef.current = null;\n })}\n />\n </ScrollbarProvider>\n );\n});\n\n/* -------------------------------------------------------------------------------------------------\n * ScrollAreaThumb\n * -----------------------------------------------------------------------------------------------*/\n\nconst THUMB_NAME = 'ScrollAreaThumb';\n\ntype ScrollAreaThumbElement = ScrollAreaThumbImplElement;\ninterface ScrollAreaThumbProps extends ScrollAreaThumbImplProps {\n /**\n * Used to force mounting when more control is needed. Useful when\n * controlling animation with React animation libraries.\n */\n forceMount?: true;\n}\n\nconst ScrollAreaThumb = React.forwardRef<ScrollAreaThumbElement, ScrollAreaThumbProps>(\n (props: ScopedProps<ScrollAreaThumbProps>, forwardedRef) => {\n const { forceMount, ...thumbProps } = props;\n const scrollbarContext = useScrollbarContext(THUMB_NAME, props.__scopeScrollArea);\n return (\n <Presence present={forceMount || scrollbarContext.hasThumb}>\n <ScrollAreaThumbImpl ref={forwardedRef} {...thumbProps} />\n </Presence>\n );\n }\n);\n\ntype ScrollAreaThumbImplElement = React.ComponentRef<typeof Primitive.div>;\ninterface ScrollAreaThumbImplProps extends PrimitiveDivProps {}\n\nconst ScrollAreaThumbImpl = React.forwardRef<ScrollAreaThumbImplElement, ScrollAreaThumbImplProps>(\n (props: ScopedProps<ScrollAreaThumbImplProps>, forwardedRef) => {\n const { __scopeScrollArea, style, ...thumbProps } = props;\n const scrollAreaContext = useScrollAreaContext(THUMB_NAME, __scopeScrollArea);\n const scrollbarContext = useScrollbarContext(THUMB_NAME, __scopeScrollArea);\n const { onThumbPositionChange } = scrollbarContext;\n const composedRef = useComposedRefs(forwardedRef, (node) =>\n scrollbarContext.onThumbChange(node)\n );\n const removeUnlinkedScrollListenerRef = React.useRef<() => void>(undefined);\n const debounceScrollEnd = useDebounceCallback(() => {\n if (removeUnlinkedScrollListenerRef.current) {\n removeUnlinkedScrollListenerRef.current();\n removeUnlinkedScrollListenerRef.current = undefined;\n }\n }, 100);\n\n React.useEffect(() => {\n const viewport = scrollAreaContext.viewport;\n if (viewport) {\n /**\n * We only bind to native scroll event so we know when scroll starts and ends.\n * When scroll starts we start a requestAnimationFrame loop that checks for\n * changes to scroll position. That rAF loop triggers our thumb position change\n * when relevant to avoid scroll-linked effects. We cancel the loop when scroll ends.\n * https://developer.mozilla.org/en-US/docs/Mozilla/Performance/Scroll-linked_effects\n */\n const handleScroll = () => {\n debounceScrollEnd();\n if (!removeUnlinkedScrollListenerRef.current) {\n const listener = addUnlinkedScrollListener(viewport, onThumbPositionChange);\n removeUnlinkedScrollListenerRef.current = listener;\n onThumbPositionChange();\n }\n };\n onThumbPositionChange();\n viewport.addEventListener('scroll', handleScroll);\n return () => viewport.removeEventListener('scroll', handleScroll);\n }\n }, [scrollAreaContext.viewport, debounceScrollEnd, onThumbPositionChange]);\n\n return (\n <Primitive.div\n data-state={scrollbarContext.hasThumb ? 'visible' : 'hidden'}\n {...thumbProps}\n ref={composedRef}\n style={{\n width: 'var(--radix-scroll-area-thumb-width)',\n height: 'var(--radix-scroll-area-thumb-height)',\n ...style,\n }}\n onPointerDownCapture={composeEventHandlers(props.onPointerDownCapture, (event) => {\n const thumb = event.target as HTMLElement;\n const thumbRect = thumb.getBoundingClientRect();\n const x = event.clientX - thumbRect.left;\n const y = event.clientY - thumbRect.top;\n scrollbarContext.onThumbPointerDown({ x, y });\n })}\n onPointerUp={composeEventHandlers(props.onPointerUp, scrollbarContext.onThumbPointerUp)}\n />\n );\n }\n);\n\nScrollAreaThumb.displayName = THUMB_NAME;\n\n/* -------------------------------------------------------------------------------------------------\n * ScrollAreaCorner\n * -----------------------------------------------------------------------------------------------*/\n\nconst CORNER_NAME = 'ScrollAreaCorner';\n\ntype ScrollAreaCornerElement = ScrollAreaCornerImplElement;\ninterface ScrollAreaCornerProps extends ScrollAreaCornerImplProps {}\n\nconst ScrollAreaCorner = React.forwardRef<ScrollAreaCornerElement, ScrollAreaCornerProps>(\n (props: ScopedProps<ScrollAreaCornerProps>, forwardedRef) => {\n const context = useScrollAreaContext(CORNER_NAME, props.__scopeScrollArea);\n const hasBothScrollbarsVisible = Boolean(context.scrollbarX && context.scrollbarY);\n const hasCorner = context.type !== 'scroll' && hasBothScrollbarsVisible;\n return hasCorner ? <ScrollAreaCornerImpl {...props} ref={forwardedRef} /> : null;\n }\n);\n\nScrollAreaCorner.displayName = CORNER_NAME;\n\n/* -----------------------------------------------------------------------------------------------*/\n\ntype ScrollAreaCornerImplElement = React.ComponentRef<typeof Primitive.div>;\ninterface ScrollAreaCornerImplProps extends PrimitiveDivProps {}\n\nconst ScrollAreaCornerImpl = React.forwardRef<\n ScrollAreaCornerImplElement,\n ScrollAreaCornerImplProps\n>((props: ScopedProps<ScrollAreaCornerImplProps>, forwardedRef) => {\n const { __scopeScrollArea, ...cornerProps } = props;\n const context = useScrollAreaContext(CORNER_NAME, __scopeScrollArea);\n const [width, setWidth] = React.useState(0);\n const [height, setHeight] = React.useState(0);\n const hasSize = Boolean(width && height);\n\n useResizeObserver(context.scrollbarX, () => {\n const height = context.scrollbarX?.offsetHeight || 0;\n context.onCornerHeightChange(height);\n setHeight(height);\n });\n\n useResizeObserver(context.scrollbarY, () => {\n const width = context.scrollbarY?.offsetWidth || 0;\n context.onCornerWidthChange(width);\n setWidth(width);\n });\n\n return hasSize ? (\n <Primitive.div\n {...cornerProps}\n ref={forwardedRef}\n style={{\n width,\n height,\n position: 'absolute',\n right: context.dir === 'ltr' ? 0 : undefined,\n left: context.dir === 'rtl' ? 0 : undefined,\n bottom: 0,\n ...props.style,\n }}\n />\n ) : null;\n});\n\n/* -----------------------------------------------------------------------------------------------*/\n\nfunction toInt(value?: string) {\n return value ? parseInt(value, 10) : 0;\n}\n\nfunction getThumbRatio(viewportSize: number, contentSize: number) {\n const ratio = viewportSize / contentSize;\n return isNaN(ratio) ? 0 : ratio;\n}\n\nfunction getThumbSize(sizes: Sizes) {\n const ratio = getThumbRatio(sizes.viewport, sizes.content);\n const scrollbarPadding = sizes.scrollbar.paddingStart + sizes.scrollbar.paddingEnd;\n const thumbSize = (sizes.scrollbar.size - scrollbarPadding) * ratio;\n // minimum of 18 matches macOS minimum\n return Math.max(thumbSize, 18);\n}\n\nfunction getScrollPositionFromPointer(\n pointerPos: number,\n pointerOffset: number,\n sizes: Sizes,\n dir: Direction = 'ltr'\n) {\n const thumbSizePx = getThumbSize(sizes);\n const thumbCenter = thumbSizePx / 2;\n const offset = pointerOffset || thumbCenter;\n const thumbOffsetFromEnd = thumbSizePx - offset;\n const minPointerPos = sizes.scrollbar.paddingStart + offset;\n const maxPointerPos = sizes.scrollbar.size - sizes.scrollbar.paddingEnd - thumbOffsetFromEnd;\n const maxScrollPos = sizes.content - sizes.viewport;\n const scrollRange = dir === 'ltr' ? [0, maxScrollPos] : [maxScrollPos * -1, 0];\n const interpolate = linearScale([minPointerPos, maxPointerPos], scrollRange as [number, number]);\n return interpolate(pointerPos);\n}\n\nfunction getThumbOffsetFromScroll(scrollPos: number, sizes: Sizes, dir: Direction = 'ltr') {\n const thumbSizePx = getThumbSize(sizes);\n const scrollbarPadding = sizes.scrollbar.paddingStart + sizes.scrollbar.paddingEnd;\n const scrollbar = sizes.scrollbar.size - scrollbarPadding;\n const maxScrollPos = sizes.content - sizes.viewport;\n const maxThumbPos = scrollbar - thumbSizePx;\n const scrollClampRange = dir === 'ltr' ? [0, maxScrollPos] : [maxScrollPos * -1, 0];\n const scrollWithoutMomentum = clamp(scrollPos, scrollClampRange as [number, number]);\n const interpolate = linearScale([0, maxScrollPos], [0, maxThumbPos]);\n return interpolate(scrollWithoutMomentum);\n}\n\n// https://github.com/tmcw-up-for-adoption/simple-linear-scale/blob/master/index.js\nfunction linearScale(input: readonly [number, number], output: readonly [number, number]) {\n return (value: number) => {\n if (input[0] === input[1] || output[0] === output[1]) return output[0];\n const ratio = (output[1] - output[0]) / (input[1] - input[0]);\n return output[0] + ratio * (value - input[0]);\n };\n}\n\nfunction isScrollingWithinScrollbarBounds(scrollPos: number, maxScrollPos: number) {\n return scrollPos > 0 && scrollPos < maxScrollPos;\n}\n\n// Custom scroll handler to avoid scroll-linked effects\n// https://developer.mozilla.org/en-US/docs/Mozilla/Performance/Scroll-linked_effects\nconst addUnlinkedScrollListener = (node: HTMLElement, handler = () => {}) => {\n let prevPosition = { left: node.scrollLeft, top: node.scrollTop };\n let rAF = 0;\n (function loop() {\n const position = { left: node.scrollLeft, top: node.scrollTop };\n const isHorizontalScroll = prevPosition.left !== position.left;\n const isVerticalScroll = prevPosition.top !== position.top;\n if (isHorizontalScroll || isVerticalScroll) handler();\n prevPosition = position;\n rAF = window.requestAnimationFrame(loop);\n })();\n return () => window.cancelAnimationFrame(rAF);\n};\n\nfunction useDebounceCallback(callback: () => void, delay: number) {\n const handleCallback = useCallbackRef(callback);\n const debounceTimerRef = React.useRef(0);\n React.useEffect(() => () => window.clearTimeout(debounceTimerRef.current), []);\n return React.useCallback(() => {\n window.clearTimeout(debounceTimerRef.current);\n debounceTimerRef.current = window.setTimeout(handleCallback, delay);\n }, [handleCallback, delay]);\n}\n\nfunction useResizeObserver(element: HTMLElement | null, onResize: () => void) {\n const handleResize = useCallbackRef(onResize);\n useLayoutEffect(() => {\n let rAF = 0;\n if (element) {\n /**\n * Resize Observer will throw an often benign error that says `ResizeObserver loop\n * completed with undelivered notifications`. This means that ResizeObserver was not\n * able to deliver all observations within a single animation frame, so we use\n * `requestAnimationFrame` to ensure we don't deliver unnecessary observations.\n * Further reading: https://github.com/WICG/resize-observer/issues/38\n */\n const resizeObserver = new ResizeObserver(() => {\n cancelAnimationFrame(rAF);\n rAF = window.requestAnimationFrame(handleResize);\n });\n resizeObserver.observe(element);\n return () => {\n window.cancelAnimationFrame(rAF);\n resizeObserver.unobserve(element);\n };\n }\n }, [element, handleResize]);\n}\n\n/* -----------------------------------------------------------------------------------------------*/\n\nconst Root = ScrollArea;\nconst Viewport = ScrollAreaViewport;\nconst Scrollbar = ScrollAreaScrollbar;\nconst Thumb = ScrollAreaThumb;\nconst Corner = ScrollAreaCorner;\n\nexport {\n createScrollAreaScope,\n //\n ScrollArea,\n ScrollAreaViewport,\n ScrollAreaScrollbar,\n ScrollAreaThumb,\n ScrollAreaCorner,\n //\n Root,\n Viewport,\n Scrollbar,\n Thumb,\n Corner,\n};\nexport type {\n ScrollAreaProps,\n ScrollAreaViewportProps,\n ScrollAreaScrollbarProps,\n ScrollAreaThumbProps,\n ScrollAreaCornerProps,\n};\n","import * as React from 'react';\n\ntype Machine<S> = { [k: string]: { [k: string]: S } };\ntype MachineState<T> = keyof T;\ntype MachineEvent<T> = keyof UnionToIntersection<T[keyof T]>;\n\n// 🤯 https://fettblog.eu/typescript-union-to-intersection/\ntype UnionToIntersection<T> = (T extends any ? (x: T) => any : never) extends (x: infer R) => any\n ? R\n : never;\n\nexport function useStateMachine<M>(\n initialState: MachineState<M>,\n machine: M & Machine<MachineState<M>>\n) {\n return React.useReducer((state: MachineState<M>, event: MachineEvent<M>): MachineState<M> => {\n const nextState = (machine[state] as any)[event];\n return nextState ?? state;\n }, initialState);\n}\n"],"names":["useIsomorphicLayoutEffect","canUse","Nq","rehackt","useLayoutEffect","useEffect","useMutation","mutation","options","client","useApolloClient","x","parser","Vp","n_","Mutation","_a","useState","called","loading","result","setResult","ref","useRef","mutationId","isMounted","Object","assign","current","execute","useCallback","executeOptions","baseOptions","tslib_es6","pi","ignoreResults","error","data","clientOptions","mergeOptions","J","mutate","then","response","_b","errors","length","client_errors","cA","graphQLErrors","onError","result_1","lib","D","onCompleted","result_2","reset","result_3","Presence","getter","mayWarn","present","children","props","presence","usePresence","initialState","machine","node","setNode","React2","stylesRef","prevPresentRef","prevAnimationNameRef","state","send","mounted","UNMOUNT","ANIMATION_OUT","unmountSuspended","MOUNT","ANIMATION_END","unmounted","React","event","nextState","currentAnimationName","getAnimationName","styles","wasPresent","prevAnimationName","display","timeoutId","ownerWindow","ownerDocument","defaultView","window","handleAnimationEnd","isCurrentAnimation","includes","CSS","escape","animationName","target","currentFillMode","style","animationFillMode","setTimeout","handleAnimationStart","addEventListener","clearTimeout","removeEventListener","isPresent","getComputedStyle","child","only","useComposedRefs","getOwnPropertyDescriptor","element","get","isReactWarning","forceMount","displayName","composeEventHandlers","originalEventHandler","ourEventHandler","checkForDefaultPrevented","defaultPrevented","document","createElement","SCROLL_AREA_NAME","createScrollAreaContext","createScrollAreaScope","createContextScope","ScrollAreaProvider","useScrollAreaContext","ScrollArea","forwardedRef","__scopeScrollArea","type","dir","scrollHideDelay","scrollAreaProps","scrollArea","setScrollArea","viewport","setViewport","content","setContent","scrollbarX","setScrollbarX","scrollbarY","setScrollbarY","cornerWidth","setCornerWidth","cornerHeight","setCornerHeight","scrollbarXEnabled","setScrollbarXEnabled","scrollbarYEnabled","setScrollbarYEnabled","composedRefs","direction","useDirection","jsx","scope","onViewportChange","onContentChange","onScrollbarXChange","onScrollbarXEnabledChange","onScrollbarYChange","onScrollbarYEnabledChange","onCornerWidthChange","onCornerHeightChange","Primitive","div","position","VIEWPORT_NAME","ScrollAreaViewport","nonce","viewportProps","context","jsxs","Fragment","dangerouslySetInnerHTML","__html","overflowX","overflowY","minWidth","SCROLLBAR_NAME","ScrollAreaScrollbar","scrollbarProps","isHorizontal","orientation","ScrollAreaScrollbarHover","ScrollAreaScrollbarScroll","ScrollAreaScrollbarAuto","ScrollAreaScrollbarVisible","visible","setVisible","hideTimer","handlePointerEnter","handlePointerLeave","debounceScrollEnd","useDebounceCallback","hidden","SCROLL","scrolling","SCROLL_END","POINTER_ENTER","interacting","POINTER_LEAVE","idle","HIDE","scrollDirection","prevScrollPos","handleScroll","scrollPos","onPointerEnter","onPointerLeave","handleResize","isOverflowX","offsetWidth","scrollWidth","isOverflowY","offsetHeight","scrollHeight","useResizeObserver","thumbRef","pointerOffsetRef","sizes","setSizes","scrollbar","size","paddingStart","paddingEnd","thumbRatio","getThumbRatio","commonProps","onSizesChange","hasThumb","Boolean","onThumbChange","thumb","onThumbPointerUp","onThumbPointerDown","pointerPos","getScrollPosition","getScrollPositionFromPointer","pointerOffset","thumbSizePx","getThumbSize","offset","minPointerPos","maxPointerPos","maxScrollPos","interpolate","ScrollAreaScrollbarX","onThumbPositionChange","getThumbOffsetFromScroll","scrollLeft","transform","concat","onWheelScroll","onDragScroll","ScrollAreaScrollbarY","scrollTop","computedStyle","setComputedStyle","composeRefs","ScrollAreaScrollbarImpl","bottom","left","right","deltaX","preventDefault","onResize","clientWidth","toInt","paddingLeft","paddingRight","top","y","deltaY","clientHeight","paddingTop","paddingBottom","ScrollbarProvider","useScrollbarContext","setScrollbar","rectRef","prevWebkitUserSelectRef","handleWheelScroll","useCallbackRef","handleThumbPositionChange","handleDragScroll","clientX","clientY","handleWheel","contains","passive","onPointerDown","button","setPointerCapture","pointerId","getBoundingClientRect","body","webkitUserSelect","scrollBehavior","onPointerMove","onPointerUp","hasPointerCapture","releasePointerCapture","THUMB_NAME","ScrollAreaThumb","thumbProps","scrollbarContext","ScrollAreaThumbImpl","scrollAreaContext","composedRef","removeUnlinkedScrollListenerRef","listener","addUnlinkedScrollListener","width","height","onPointerDownCapture","thumbRect","CORNER_NAME","ScrollAreaCorner","hasBothScrollbarsVisible","hasCorner","ScrollAreaCornerImpl","cornerProps","setWidth","setHeight","hasSize","value","parseInt","viewportSize","contentSize","ratio","isNaN","scrollbarPadding","Math","max","scrollWithoutMomentum","clamp","linearScale","input","output","handler","prevPosition","rAF","loop","isHorizontalScroll","isVerticalScroll","requestAnimationFrame","cancelAnimationFrame","callback","delay","handleCallback","debounceTimerRef","resizeObserver","ResizeObserver","observe","unobserve","Root","Viewport","Corner"],"sourceRoot":""}
@@ -1,2 +0,0 @@
1
- "use strict";(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[3832],{13832:function(e,a,t){t.d(a,{S:function(){return ef},default:function(){return em}});var r=t(57437),s=t(24614),n=t(71946),i=t(81068),o=t(63761),d=t(51251),l=t(51451),c=t(80605),u=t(2265),f=t(27648),p=t(99376),m=t(37053),b=t(90535),h=t(30755),x=t(866),g=t(94508),v=t(62869),w=t(95186),j=t(6512),N=t(69304),y=t(93022),k=t(81103);let z=u.createContext(null);function C(){let e=u.useContext(z);if(!e)throw Error("useSidebar must be used within a SidebarProvider.");return e}let R=u.forwardRef((e,a)=>{let{defaultOpen:t=!0,open:s,onOpenChange:n,className:i,style:o,children:d,...l}=e,c=(0,x.d)(),[f,p]=u.useState(!1),[m,b]=u.useState(t),h=null!=s?s:m,v=u.useCallback(e=>{let a="function"==typeof e?e(h):e;n?n(a):b(a),document.cookie="".concat("sidebar_state","=").concat(a,"; path=/; max-age=").concat(604800)},[n,h]),w=u.useCallback(()=>c?p(e=>!e):v(e=>!e),[c,v,p]);u.useEffect(()=>{let e=e=>{"b"===e.key&&(e.metaKey||e.ctrlKey)&&(e.preventDefault(),w())};return window.addEventListener("keydown",e),()=>window.removeEventListener("keydown",e)},[w]);let j=h?"expanded":"collapsed",N=u.useMemo(()=>({state:j,open:h,setOpen:v,isMobile:c,openMobile:f,setOpenMobile:p,toggleSidebar:w}),[j,h,v,c,f,p,w]);return(0,r.jsx)(z.Provider,{value:N,children:(0,r.jsx)(k.pn,{delayDuration:0,children:(0,r.jsx)("div",{style:{"--sidebar-width":"16rem","--sidebar-width-icon":"3rem",...o},className:(0,g.cn)("group/sidebar-wrapper flex min-h-svh w-full has-[[data-variant=inset]]:bg-sidebar",i),ref:a,...l,children:d})})})});R.displayName="SidebarProvider";let S=u.forwardRef((e,a)=>{let{side:t="left",variant:s="sidebar",collapsible:n="offcanvas",className:i,children:o,...d}=e,{isMobile:l,state:c,openMobile:u,setOpenMobile:f}=C();return"none"===n?(0,r.jsx)("div",{className:(0,g.cn)("flex h-full w-[--sidebar-width] flex-col bg-sidebar text-sidebar-foreground",i),ref:a,...d,children:o}):l?(0,r.jsx)(N.yo,{open:u,onOpenChange:f,...d,children:(0,r.jsxs)(N.ue,{"data-sidebar":"sidebar","data-mobile":"true",className:"w-[--sidebar-width] bg-sidebar p-0 text-sidebar-foreground [&>button]:hidden",style:{"--sidebar-width":"18rem"},side:t,children:[(0,r.jsxs)(N.Tu,{className:"sr-only",children:[(0,r.jsx)(N.bC,{children:"Sidebar"}),(0,r.jsx)(N.Ei,{children:"Displays the mobile sidebar."})]}),(0,r.jsx)("div",{className:"flex h-full w-full flex-col",children:o})]})}):(0,r.jsxs)("div",{ref:a,className:"group peer hidden text-sidebar-foreground md:block","data-state":c,"data-collapsible":"collapsed"===c?n:"","data-variant":s,"data-side":t,children:[(0,r.jsx)("div",{className:(0,g.cn)("relative w-[--sidebar-width] bg-transparent transition-[width] duration-200 ease-linear","group-data-[collapsible=offcanvas]:w-0","group-data-[side=right]:rotate-180","floating"===s||"inset"===s?"group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)_+_theme(spacing.4))]":"group-data-[collapsible=icon]:w-[--sidebar-width-icon]")}),(0,r.jsx)("div",{className:(0,g.cn)("fixed inset-y-0 z-10 hidden h-svh w-[--sidebar-width] transition-[left,right,width] duration-200 ease-linear md:flex","left"===t?"left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]":"right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]","floating"===s||"inset"===s?"p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)_+_theme(spacing.4)_+2px)]":"group-data-[collapsible=icon]:w-[--sidebar-width-icon] group-data-[side=left]:border-r group-data-[side=right]:border-l",i),...d,children:(0,r.jsx)("div",{"data-sidebar":"sidebar",className:"flex h-full w-full flex-col bg-sidebar group-data-[variant=floating]:rounded-lg group-data-[variant=floating]:border group-data-[variant=floating]:border-sidebar-border group-data-[variant=floating]:shadow",children:o})})]})});S.displayName="Sidebar";let _=u.forwardRef((e,a)=>{let{className:t,onClick:s,...n}=e,{toggleSidebar:i}=C();return(0,r.jsxs)(v.z,{ref:a,"data-sidebar":"trigger",variant:"ghost",size:"icon",className:(0,g.cn)("h-7 w-7",t),onClick:e=>{null==s||s(e),i()},...n,children:[(0,r.jsx)(h.Z,{}),(0,r.jsx)("span",{className:"sr-only",children:"Toggle Sidebar"})]})});_.displayName="SidebarTrigger",u.forwardRef((e,a)=>{let{className:t,...s}=e,{toggleSidebar:n}=C();return(0,r.jsx)("button",{ref:a,"data-sidebar":"rail","aria-label":"Toggle Sidebar",tabIndex:-1,onClick:n,title:"Toggle Sidebar",className:(0,g.cn)("absolute inset-y-0 z-20 hidden w-4 -translate-x-1/2 transition-all ease-linear after:absolute after:inset-y-0 after:left-1/2 after:w-[2px] hover:after:bg-sidebar-border group-data-[side=left]:-right-4 group-data-[side=right]:left-0 sm:flex","[[data-side=left]_&]:cursor-w-resize [[data-side=right]_&]:cursor-e-resize","[[data-side=left][data-state=collapsed]_&]:cursor-e-resize [[data-side=right][data-state=collapsed]_&]:cursor-w-resize","group-data-[collapsible=offcanvas]:translate-x-0 group-data-[collapsible=offcanvas]:after:left-full group-data-[collapsible=offcanvas]:hover:bg-sidebar","[[data-side=left][data-collapsible=offcanvas]_&]:-right-2","[[data-side=right][data-collapsible=offcanvas]_&]:-left-2",t),...s})}).displayName="SidebarRail",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("main",{ref:a,className:(0,g.cn)("relative flex w-full flex-1 flex-col bg-background","md:peer-data-[variant=inset]:m-2 md:peer-data-[state=collapsed]:peer-data-[variant=inset]:ml-2 md:peer-data-[variant=inset]:ml-0 md:peer-data-[variant=inset]:rounded-xl md:peer-data-[variant=inset]:shadow",t),...s})}).displayName="SidebarInset",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)(w.I,{ref:a,"data-sidebar":"input",className:(0,g.cn)("h-8 w-full bg-background shadow-none focus-visible:ring-2 focus-visible:ring-sidebar-ring",t),...s})}).displayName="SidebarInput",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"header",className:(0,g.cn)("flex flex-col gap-2 p-2",t),...s})}).displayName="SidebarHeader";let E=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"footer",className:(0,g.cn)("flex flex-col gap-2 p-2",t),...s})});E.displayName="SidebarFooter",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)(j.Z,{ref:a,"data-sidebar":"separator",className:(0,g.cn)("mx-2 w-auto bg-sidebar-border",t),...s})}).displayName="SidebarSeparator";let Z=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"content",className:(0,g.cn)("flex min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden",t),...s})});Z.displayName="SidebarContent";let T=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"group",className:(0,g.cn)("relative flex w-full min-w-0 flex-col p-0",t),...s})});T.displayName="SidebarGroup",u.forwardRef((e,a)=>{let{className:t,asChild:s=!1,...n}=e,i=s?m.g7:"div";return(0,r.jsx)(i,{ref:a,"data-sidebar":"group-label",className:(0,g.cn)("flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium text-sidebar-foreground/70 outline-none ring-sidebar-ring transition-[margin,opacity] duration-200 ease-linear focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0","group-data-[collapsible=icon]:-mt-8 group-data-[collapsible=icon]:opacity-0",t),...n})}).displayName="SidebarGroupLabel",u.forwardRef((e,a)=>{let{className:t,asChild:s=!1,...n}=e,i=s?m.g7:"button";return(0,r.jsx)(i,{ref:a,"data-sidebar":"group-action",className:(0,g.cn)("absolute right-3 top-3.5 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground outline-none ring-sidebar-ring transition-transform hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0","after:absolute after:-inset-2 after:md:hidden","group-data-[collapsible=icon]:hidden",t),...n})}).displayName="SidebarGroupAction";let O=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"group-content",className:(0,g.cn)("w-full text-sm",t),...s})});O.displayName="SidebarGroupContent";let P=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("ul",{ref:a,"data-sidebar":"menu",className:(0,g.cn)("flex w-full min-w-0 flex-col gap-1",t),...s})});P.displayName="SidebarMenu";let A=u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("li",{ref:a,"data-sidebar":"menu-item",className:(0,g.cn)("group/menu-item relative",t),...s})});A.displayName="SidebarMenuItem";let M=(0,b.j)("peer/menu-button flex w-full items-center gap-2 overflow-hidden rounded-md p-2 text-left text-sm outline-none ring-sidebar-ring transition-[width,height,padding] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 group-has-[[data-sidebar=menu-action]]/menu-item:pr-8 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-[active=true]:bg-sidebar-accent data-[active=true]:font-medium data-[active=true]:text-sidebar-accent-foreground data-[state=open]:hover:bg-sidebar-accent data-[state=open]:hover:text-sidebar-accent-foreground group-data-[collapsible=icon]:!size-8 group-data-[collapsible=icon]:!p-[0.40rem] [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0",{variants:{variant:{default:"hover:bg-sidebar-accent hover:text-sidebar-accent-foreground",outline:"bg-background shadow-[0_0_0_1px_hsl(var(--sidebar-border))] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground hover:shadow-[0_0_0_1px_hsl(var(--sidebar-accent))]"},size:{default:"h-8 text-sm",sm:"h-7 text-xs",lg:"h-12 text-sm group-data-[collapsible=icon]:!p-0"}},defaultVariants:{variant:"default",size:"default"}}),D=u.forwardRef((e,a)=>{let{asChild:t=!1,isActive:s=!1,variant:n="default",size:i="default",tooltip:o,className:d,...l}=e,c=t?m.g7:"button",{isMobile:u,state:f}=C(),p=(0,r.jsx)(c,{ref:a,"data-sidebar":"menu-button","data-size":i,"data-active":s,className:(0,g.cn)(M({variant:n,size:i}),d),...l});return o?("string"==typeof o&&(o={children:o}),(0,r.jsxs)(k.u,{children:[(0,r.jsx)(k.aJ,{asChild:!0,children:p}),(0,r.jsx)(k._v,{side:"right",align:"center",hidden:"collapsed"!==f||u,...o})]})):p});D.displayName="SidebarMenuButton",u.forwardRef((e,a)=>{let{className:t,asChild:s=!1,showOnHover:n=!1,...i}=e,o=s?m.g7:"button";return(0,r.jsx)(o,{ref:a,"data-sidebar":"menu-action",className:(0,g.cn)("absolute right-1 top-1.5 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground outline-none ring-sidebar-ring transition-transform hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 peer-hover/menu-button:text-sidebar-accent-foreground [&>svg]:size-4 [&>svg]:shrink-0","after:absolute after:-inset-2 after:md:hidden","peer-data-[size=sm]/menu-button:top-1","peer-data-[size=default]/menu-button:top-1.5","peer-data-[size=lg]/menu-button:top-2.5","group-data-[collapsible=icon]:hidden",n&&"group-focus-within/menu-item:opacity-100 group-hover/menu-item:opacity-100 data-[state=open]:opacity-100 peer-data-[active=true]/menu-button:text-sidebar-accent-foreground md:opacity-0",t),...i})}).displayName="SidebarMenuAction",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("div",{ref:a,"data-sidebar":"menu-badge",className:(0,g.cn)("pointer-events-none absolute right-1 flex h-5 min-w-5 select-none items-center justify-center rounded-md px-1 text-xs font-medium tabular-nums text-sidebar-foreground","peer-hover/menu-button:text-sidebar-accent-foreground peer-data-[active=true]/menu-button:text-sidebar-accent-foreground","peer-data-[size=sm]/menu-button:top-1","peer-data-[size=default]/menu-button:top-1.5","peer-data-[size=lg]/menu-button:top-2.5","group-data-[collapsible=icon]:hidden",t),...s})}).displayName="SidebarMenuBadge",u.forwardRef((e,a)=>{let{className:t,showIcon:s=!1,...n}=e,i=u.useMemo(()=>"".concat(Math.floor(40*Math.random())+50,"%"),[]);return(0,r.jsxs)("div",{ref:a,"data-sidebar":"menu-skeleton",className:(0,g.cn)("flex h-8 items-center gap-2 rounded-md px-2",t),...n,children:[s&&(0,r.jsx)(y.O,{className:"size-4 rounded-md","data-sidebar":"menu-skeleton-icon"}),(0,r.jsx)(y.O,{className:"h-4 max-w-[--skeleton-width] flex-1","data-sidebar":"menu-skeleton-text",style:{"--skeleton-width":i}})]})}).displayName="SidebarMenuSkeleton",u.forwardRef((e,a)=>{let{className:t,...s}=e;return(0,r.jsx)("ul",{ref:a,"data-sidebar":"menu-sub",className:(0,g.cn)("mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l border-sidebar-border px-2.5 py-0.5","group-data-[collapsible=icon]:hidden",t),...s})}).displayName="SidebarMenuSub",u.forwardRef((e,a)=>{let{...t}=e;return(0,r.jsx)("li",{ref:a,...t})}).displayName="SidebarMenuSubItem",u.forwardRef((e,a)=>{let{asChild:t=!1,size:s="md",isActive:n,className:i,...o}=e,d=t?m.g7:"a";return(0,r.jsx)(d,{ref:a,"data-sidebar":"menu-sub-button","data-size":s,"data-active":n,className:(0,g.cn)("flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 text-sidebar-foreground outline-none ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0 [&>svg]:text-sidebar-accent-foreground","data-[active=true]:bg-sidebar-accent data-[active=true]:text-sidebar-accent-foreground","sm"===s&&"text-xs","md"===s&&"text-sm","group-data-[collapsible=icon]:hidden",i),...o})}).displayName="SidebarMenuSubButton";var L=t(84190),V=t(25466),B=t(50091),I=t(9343),q=t(82222),U=t(56475),Y=t(82718),F=t(64972),G=t(78406),J=t(95805),Q=t(54001),W=t(32790),X=t(64935),K=t(98728),H=t(22135),$=t(85929),ee=t(97226),ea=t(47692),et=t(48736),er=t(78298),es=t(16831),en=t(21391);let ei=(e,a)=>{let t=[];return e.super_admin&&t.push({label:"Dashboard",path:"dashboard",icon:(0,r.jsx)(V.Z,{})}),t.push({label:"Contexts",path:"data",icon:(0,r.jsx)(B.Z,{})}),t.push({label:"Jobs",path:"jobs",icon:(0,r.jsx)(I.Z,{})}),(e.super_admin||"write"===a.agents)&&t.push({label:"Agents",path:"agents",icon:(0,r.jsx)(q.Z,{})}),t.push({label:"Projects",path:"projects",icon:(0,r.jsx)(U.Z,{})}),t.push({label:"Chat",path:"chat",icon:(0,r.jsx)(Y.Z,{})}),(e.super_admin||"read"===a.evals||"write"===a.evals)&&t.push({label:"Evals",path:"evals",icon:(0,r.jsx)(F.Z,{})}),(e.super_admin||"write"===a.workflows)&&t.push({label:"Workflows",path:"workflows",icon:(0,r.jsx)(G.Z,{})}),(e.super_admin||"write"===a.users)&&t.push({label:"Users",path:"users",icon:(0,r.jsx)(J.Z,{})}),(e.super_admin||"write"===a.api)&&t.push({label:"Keys",path:"keys",icon:(0,r.jsx)(Q.Z,{})}),(e.super_admin||"write"===a.variables)&&t.push({label:"Variables",path:"variables",icon:(0,r.jsx)(W.Z,{})}),(e.super_admin||"write"===a.api)&&t.push({label:"API",path:"explorer",icon:(0,r.jsx)(X.Z,{})}),e.super_admin&&t.push({label:"Configurations",path:"configuration",icon:(0,r.jsx)(K.Z,{})}),t};function eo(e){let{items:a}=e,t=(0,p.usePathname)();return(0,r.jsx)(P,{className:"space-y-1",children:a.map((e,a)=>{let s=t.includes(e.path);return(0,r.jsx)(A,{children:(0,r.jsx)(D,{asChild:!0,isActive:s,tooltip:e.label,className:(0,g.cn)("h-10 transition-all duration-200"),children:(0,r.jsxs)(f.default,{href:"/".concat(e.path),className:"flex items-center gap-3",children:[(0,r.jsx)("div",{className:(0,g.cn)("flex h-5 w-5 items-center justify-center transition-colors"),children:e.icon}),(0,r.jsx)("span",{className:(0,g.cn)("font-medium transition-colors"),children:e.label})]})})},a)})})}function ed(e){let{sidebarDefaultOpen:a}=e,{user:t}=(0,u.useContext)(ef),s=ei(t,t.role),n=(0,p.useRouter)(),{setTheme:i,theme:o}=(0,er.F)(),d=(0,p.useParams)(),l=C();return(0,u.useEffect)(()=>{d.agent&&void 0===a&&l.setOpen(!1)},[d.agent]),(0,r.jsxs)(S,{collapsible:"icon",className:"border-r",children:[(0,r.jsxs)("div",{className:"flex items-center gap-3 border-b bg-background/80 backdrop-blur-sm p-[12px] sticky top-0 z-10",children:[(0,r.jsx)(_,{}),(0,r.jsx)("div",{className:"flex items-center gap-2",children:(0,r.jsx)(en.default,{alt:"Logo",width:100,height:40})})]}),(0,r.jsx)(Z,{className:"px-2",children:(0,r.jsx)(T,{className:"mt-4",children:(0,r.jsx)(O,{children:(0,r.jsx)(eo,{items:s})})})}),(0,r.jsx)(E,{className:"border-t bg-muted/20 p-[5px]",children:(0,r.jsx)(P,{children:(0,r.jsx)(A,{children:(0,r.jsxs)(L.h_,{children:[(0,r.jsx)(L.$F,{asChild:!0,children:(0,r.jsxs)(D,{className:"h-12 hover:bg-accent/50",children:[(0,r.jsx)(es.qE,{className:"h-5 w-5",children:(0,r.jsx)(es.Q5,{className:"bg-gradient-to-br from-primary/20 to-primary/60 text-white text-sm",children:t.email.charAt(0).toUpperCase()})}),(0,r.jsxs)("div",{className:"flex flex-col items-start group-data-[collapsible=icon]:hidden",children:[(0,r.jsx)("span",{className:"text-sm font-medium capitalize",children:t.email.split("@")[0]}),(0,r.jsx)("div",{className:"flex items-center gap-1",children:(0,r.jsx)("span",{className:"text-xs text-muted-foreground",children:t.email.split("@")[1]})})]}),(0,r.jsx)(H.Z,{className:"ml-auto h-4 w-4 group-data-[collapsible=icon]:hidden"})]})}),(0,r.jsxs)(L.AW,{side:"top",className:"w-[--radix-popper-anchor-width] mb-2",align:"start",children:[(0,r.jsx)(L.Xi,{onClick:()=>i("dark"===o?"light":"dark"),children:(0,r.jsxs)("div",{className:"flex items-center gap-2 w-full",children:["dark"===o?(0,r.jsx)($.Z,{className:"h-4 w-4"}):(0,r.jsx)(ee.Z,{className:"h-4 w-4"}),(0,r.jsx)("span",{children:"Theme"})]})}),(0,r.jsx)(L.Xi,{onClick:()=>n.push("/api/auth/signout"),children:(0,r.jsxs)("div",{className:"flex items-center gap-2 w-full",children:[(0,r.jsx)(ea.Z,{className:"h-4 w-4"}),(0,r.jsx)("span",{children:"Logout"})]})}),(0,r.jsx)(L.Xi,{onClick:()=>window.open("https://www.exulu.com/toc","_blank"),children:(0,r.jsxs)("div",{className:"flex items-center gap-2 w-full",children:[(0,r.jsx)(et.Z,{className:"h-4 w-4"}),(0,r.jsx)("span",{children:"Terms"})]})})]})]})})})})]})}function el(e){let{children:a,sidebarDefaultOpen:t}=e;return console.log("sidebarDefaultOpen",t),(0,r.jsx)(R,{defaultOpen:t,children:(0,r.jsxs)("div",{className:"flex h-screen w-full bg-background overflow-hidden",children:[(0,r.jsx)(ed,{sidebarDefaultOpen:t}),(0,r.jsx)("main",{className:"flex-1 overflow-auto",children:a})]})})}var ec=t(6374),eu=t(44045);let ef=u.createContext(null),ep=e=>{let{children:a,user:t,sidebarDefaultOpen:s}=e;return(0,r.jsx)(ef.Provider,{value:{user:t},children:(0,r.jsx)(el,{sidebarDefaultOpen:s,children:a})})};var em=e=>{let{children:a,user:t,sidebarDefaultOpen:f}=e,p=u.useContext(eu.E),m=(null==p?void 0:p.backend)?(null==p?void 0:p.backend)+"/graphql":"http://localhost:9001/graphql",b=(0,l.v)((e,a)=>({headers:{Accept:"charset=utf-8"}})),h=(0,l.v)(async(e,a)=>{let t=await (0,ec.LP)();return{headers:{Authorization:"Bearer ".concat(t)}}}),x=s.i.from([b,h,new n.u({uri:m})]),g=new i.f({uri:m,cache:new o.h({addTypename:!1}),link:x,defaultOptions:{watchQuery:{fetchPolicy:"no-cache",errorPolicy:"ignore"},query:{fetchPolicy:"no-cache",errorPolicy:"all"}}});return(0,r.jsx)(d.e,{client:g,children:(0,r.jsx)(c.SessionProvider,{children:(0,r.jsx)(ep,{sidebarDefaultOpen:f,user:t,children:a})})})}},44045:function(e,a,t){t.d(a,{ConfigContextProvider:function(){return n},E:function(){return s}});var r=t(57437);let s=(0,t(2265).createContext)(null);function n(e){let{children:a,config:t}=e;if(console.log("[EXULU] Config: ",t),!t)throw Error("Config not found");return(0,r.jsx)(s.Provider,{value:t,children:a})}},21391:function(e,a,t){var r=t(57437),s=t(44045),n=t(2265);a.default=e=>{let{width:a=64,height:t=32,className:i="",alt:o="Logo"}=e,d=(0,n.useContext)(s.E);return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)("img",{src:(null==d?void 0:d.backend)+"/logo_dark.png",alt:o,width:a,height:t,className:i+"hidden dark:block"}),(0,r.jsx)("img",{src:(null==d?void 0:d.backend)+"/logo_light.png",alt:o,width:a,height:t,className:i+"block dark:hidden"})]})}},16831:function(e,a,t){t.d(a,{Q5:function(){return d},qE:function(){return o}});var r=t(57437),s=t(61146),n=t(2265),i=t(94508);let o=n.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.fC,{ref:a,className:(0,i.cn)("relative flex h-10 w-10 shrink-0 overflow-hidden rounded-full",t),...n})});o.displayName=s.fC.displayName,n.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.Ee,{ref:a,className:(0,i.cn)("aspect-square h-full w-full",t),...n})}).displayName=s.Ee.displayName;let d=n.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.NY,{ref:a,className:(0,i.cn)("flex h-full w-full items-center justify-center rounded-full bg-muted",t),...n})});d.displayName=s.NY.displayName},84190:function(e,a,t){t.d(a,{$F:function(){return u},AW:function(){return f},Ju:function(){return b},VD:function(){return h},Xi:function(){return p},bO:function(){return m},h_:function(){return c}});var r=t(57437),s=t(70085),n=t(10407),i=t(30401),o=t(40519),d=t(2265),l=t(94508);let c=s.fC,u=s.xz;s.ZA,s.Uv,s.Tr,s.Ee,d.forwardRef((e,a)=>{let{className:t,inset:i,children:o,...d}=e;return(0,r.jsxs)(s.fF,{ref:a,className:(0,l.cn)("flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent data-[state=open]:bg-accent",i&&"pl-8",t),...d,children:[o,(0,r.jsx)(n.Z,{className:"ml-auto size-4"})]})}).displayName=s.fF.displayName,d.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.tu,{ref:a,className:(0,l.cn)("z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",t),...n})}).displayName=s.tu.displayName;let f=d.forwardRef((e,a)=>{let{className:t,sideOffset:n=4,...i}=e;return(0,r.jsx)(s.Uv,{children:(0,r.jsx)(s.VY,{ref:a,sideOffset:n,className:(0,l.cn)("z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-md data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",t),...i})})});f.displayName=s.VY.displayName;let p=d.forwardRef((e,a)=>{let{className:t,inset:n,...i}=e;return(0,r.jsx)(s.ck,{ref:a,className:(0,l.cn)("relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",n&&"pl-8",t),...i})});p.displayName=s.ck.displayName;let m=d.forwardRef((e,a)=>{let{className:t,children:n,checked:o,...d}=e;return(0,r.jsxs)(s.oC,{ref:a,className:(0,l.cn)("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",t),checked:o,...d,children:[(0,r.jsx)("span",{className:"absolute left-2 flex size-3.5 items-center justify-center",children:(0,r.jsx)(s.wU,{children:(0,r.jsx)(i.Z,{className:"size-4"})})}),n]})});m.displayName=s.oC.displayName,d.forwardRef((e,a)=>{let{className:t,children:n,...i}=e;return(0,r.jsxs)(s.Rk,{ref:a,className:(0,l.cn)("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",t),...i,children:[(0,r.jsx)("span",{className:"absolute left-2 flex size-3.5 items-center justify-center",children:(0,r.jsx)(s.wU,{children:(0,r.jsx)(o.Z,{className:"size-2 fill-current"})})}),n]})}).displayName=s.Rk.displayName;let b=d.forwardRef((e,a)=>{let{className:t,inset:n,...i}=e;return(0,r.jsx)(s.__,{ref:a,className:(0,l.cn)("px-2 py-1.5 text-sm font-semibold",n&&"pl-8",t),...i})});b.displayName=s.__.displayName;let h=d.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.Z0,{ref:a,className:(0,l.cn)("-mx-1 my-1 h-px bg-muted",t),...n})});h.displayName=s.Z0.displayName},95186:function(e,a,t){t.d(a,{I:function(){return i}});var r=t(57437),s=t(2265),n=t(94508);let i=s.forwardRef((e,a)=>{let{className:t,type:s,...i}=e;return(0,r.jsx)("input",{type:s,className:(0,n.cn)("flex h-10 w-full rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50",t),ref:a,...i})});i.displayName="Input"},6512:function(e,a,t){t.d(a,{Z:function(){return o}});var r=t(57437),s=t(55156),n=t(2265),i=t(94508);let o=n.forwardRef((e,a)=>{let{className:t,orientation:n="horizontal",decorative:o=!0,...d}=e;return(0,r.jsx)(s.f,{ref:a,decorative:o,orientation:n,className:(0,i.cn)("shrink-0 bg-border","horizontal"===n?"h-[1px] w-full":"h-full w-[1px]",t),...d})});o.displayName=s.f.displayName},69304:function(e,a,t){t.d(a,{Ei:function(){return x},Tu:function(){return b},aM:function(){return c},bC:function(){return h},ue:function(){return m},yo:function(){return l}});var r=t(57437),s=t(34567),n=t(90535),i=t(32489),o=t(2265),d=t(94508);let l=s.fC,c=s.xz;s.x8;let u=s.h_,f=o.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.aV,{className:(0,d.cn)("fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",t),...n,ref:a})});f.displayName=s.aV.displayName;let p=(0,n.j)("fixed z-50 gap-4 bg-background p-6 shadow-lg transition ease-in-out data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:duration-300 data-[state=open]:duration-500",{variants:{side:{top:"inset-x-0 top-0 border-b data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top",bottom:"inset-x-0 bottom-0 border-t data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom",left:"inset-y-0 left-0 h-full w-3/4 border-r data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left sm:max-w-sm",right:"inset-y-0 right-0 h-full w-3/4 border-l data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right sm:max-w-sm"}},defaultVariants:{side:"right"}}),m=o.forwardRef((e,a)=>{let{side:t="right",className:n,children:o,...l}=e;return(0,r.jsxs)(u,{children:[(0,r.jsx)(f,{}),(0,r.jsxs)(s.VY,{ref:a,className:(0,d.cn)(p({side:t}),n),...l,children:[o,(0,r.jsxs)(s.x8,{className:"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-secondary",children:[(0,r.jsx)(i.Z,{className:"size-4"}),(0,r.jsx)("span",{className:"sr-only",children:"Close"})]})]})]})});m.displayName=s.VY.displayName;let b=e=>{let{className:a,...t}=e;return(0,r.jsx)("div",{className:(0,d.cn)("flex flex-col space-y-2 text-center sm:text-left",a),...t})};b.displayName="SheetHeader";let h=o.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.Dx,{ref:a,className:(0,d.cn)("text-lg font-semibold text-foreground",t),...n})});h.displayName=s.Dx.displayName;let x=o.forwardRef((e,a)=>{let{className:t,...n}=e;return(0,r.jsx)(s.dk,{ref:a,className:(0,d.cn)("text-sm text-muted-foreground",t),...n})});x.displayName=s.dk.displayName},93022:function(e,a,t){t.d(a,{O:function(){return n}});var r=t(57437),s=t(94508);function n(e){let{className:a,...t}=e;return(0,r.jsx)("div",{className:(0,s.cn)("animate-pulse rounded-md bg-muted",a),...t})}},81103:function(e,a,t){t.d(a,{_v:function(){return c},aJ:function(){return l},pn:function(){return o},u:function(){return d}});var r=t(57437),s=t(4957),n=t(2265),i=t(94508);let o=s.zt,d=s.fC,l=s.xz,c=n.forwardRef((e,a)=>{let{className:t,sideOffset:n=4,...o}=e;return(0,r.jsx)(s.VY,{ref:a,sideOffset:n,className:(0,i.cn)("z-50 overflow-hidden rounded-md border bg-popover px-3 py-1.5 text-sm text-popover-foreground shadow-md animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",t),...o})});c.displayName=s.VY.displayName},866:function(e,a,t){t.d(a,{d:function(){return s}});var r=t(2265);function s(){let[e,a]=r.useState(void 0);return r.useEffect(()=>{let e=window.matchMedia("(max-width: ".concat(767,"px)")),t=()=>{a(window.innerWidth<768)};return e.addEventListener("change",t),a(window.innerWidth<768),()=>e.removeEventListener("change",t)},[]),!!e}},6374:function(e,a,t){t.d(a,{DQ:function(){return i},LP:function(){return n},QZ:function(){return o}});var r=t(80605);let s=async()=>{let e=await fetch("/api/config").then(e=>e.json());if(!e.backend)throw Error("No backend set.");return{files:e.backend,base:e.backend}},n=async()=>{var e;let a=await (0,r.getSession)();return null==a?void 0:null===(e=a.user)||void 0===e?void 0:e.jwt},i={image:{generate:async e=>{let a=await s(),t="".concat(a.base,"/generate/agent/image"),r=await n();if(!r)throw Error("No valid session token available.");return fetch(t,{method:"POST",body:JSON.stringify(e),headers:{"Content-Type":"application/json",Authorization:"Bearer ".concat(r)}})}}},o={object:async e=>{let a=await s(),t="".concat(a.files,"/s3/object"),r=await n();return(await fetch(t,{method:"POST",body:JSON.stringify({key:e}),headers:{"Content-Type":"application/json",Authorization:"Bearer ".concat(r)}})).json()},list:async e=>{let{search:a,continuationToken:t}=e,r=await s(),i="".concat(r.files,"/s3/list"),o=await n();if(!o)throw Error("No valid session token available.");return a&&(i+="?search=".concat(a)),t&&(i+="?continuationToken=".concat(t)),(await fetch(i,{method:"GET",headers:{"Content-Type":"application/json",Authorization:"Bearer ".concat(o)}})).json()},download:async e=>{let a=await s(),t="".concat(a.files,"/s3/download?key=").concat(e),r=await n();if(!r)throw Error("No valid session token available.");return fetch(t,{method:"GET",headers:{"Content-Type":"application/json",Authorization:"Bearer ".concat(r)}})},delete:async e=>{let a=await s(),t="".concat(a.files,"/s3/delete?key=").concat(e),r=await n();if(!r)throw Error("No valid session token available.");return fetch(t,{method:"DELETE",headers:{"Content-Type":"application/json",Authorization:"Bearer ".concat(r)}})}}}}]);
2
- //# sourceMappingURL=3832-10b779e2f89f162f.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"static/chunks/3832-10b779e2f89f162f.js","mappings":"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","sources":["webpack://_N_E/./components/ui/sidebar.tsx","webpack://_N_E/./components/custom/main-nav.tsx","webpack://_N_E/./app/(application)/authenticated.tsx","webpack://_N_E/./components/config-context.tsx","webpack://_N_E/./components/logo.tsx","webpack://_N_E/./components/ui/avatar.tsx","webpack://_N_E/./components/ui/dropdown-menu.tsx","webpack://_N_E/./components/ui/input.tsx","webpack://_N_E/./components/ui/separator.tsx","webpack://_N_E/./components/ui/sheet.tsx","webpack://_N_E/./components/ui/skeleton.tsx","webpack://_N_E/./components/ui/tooltip.tsx","webpack://_N_E/./hooks/use-mobile.tsx","webpack://_N_E/./util/api.ts"],"sourcesContent":["\"use client\"\n\nimport * as React from \"react\"\nimport { Slot } from \"@radix-ui/react-slot\"\nimport { VariantProps, cva } from \"class-variance-authority\"\nimport { PanelLeft } from \"lucide-react\"\nimport { useIsMobile } from \"@/hooks/use-mobile\"\nimport { cn } from \"@/lib/utils\"\nimport { Button } from \"@/components/ui/button\"\nimport { Input } from \"@/components/ui/input\"\nimport { Separator } from \"@/components/ui/separator\"\nimport {\n Sheet,\n SheetContent,\n SheetDescription,\n SheetHeader,\n SheetTitle,\n} from \"@/components/ui/sheet\"\nimport { Skeleton } from \"@/components/ui/skeleton\"\nimport {\n Tooltip,\n TooltipContent,\n TooltipProvider,\n TooltipTrigger,\n} from \"@/components/ui/tooltip\"\n\nconst SIDEBAR_COOKIE_NAME = \"sidebar_state\"\nconst SIDEBAR_COOKIE_MAX_AGE = 60 * 60 * 24 * 7\nconst SIDEBAR_WIDTH = \"16rem\"\nconst SIDEBAR_WIDTH_MOBILE = \"18rem\"\nconst SIDEBAR_WIDTH_ICON = \"3rem\"\nconst SIDEBAR_KEYBOARD_SHORTCUT = \"b\"\n\ntype SidebarContextProps = {\n state: \"expanded\" | \"collapsed\"\n open: boolean\n setOpen: (open: boolean) => void\n openMobile: boolean\n setOpenMobile: (open: boolean) => void\n isMobile: boolean\n toggleSidebar: () => void\n}\n\nconst SidebarContext = React.createContext<SidebarContextProps | null>(null)\n\nfunction useSidebar() {\n const context = React.useContext(SidebarContext)\n if (!context) {\n throw new Error(\"useSidebar must be used within a SidebarProvider.\")\n }\n\n return context\n}\n\nconst SidebarProvider = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\"> & {\n defaultOpen?: boolean\n open?: boolean\n onOpenChange?: (open: boolean) => void\n }\n>(\n (\n {\n defaultOpen = true,\n open: openProp,\n onOpenChange: setOpenProp,\n className,\n style,\n children,\n ...props\n },\n ref\n ) => {\n const isMobile = useIsMobile()\n const [openMobile, setOpenMobile] = React.useState(false)\n\n // This is the internal state of the sidebar.\n // We use openProp and setOpenProp for control from outside the component.\n const [_open, _setOpen] = React.useState(defaultOpen)\n const open = openProp ?? _open\n const setOpen = React.useCallback(\n (value: boolean | ((value: boolean) => boolean)) => {\n const openState = typeof value === \"function\" ? value(open) : value\n if (setOpenProp) {\n setOpenProp(openState)\n } else {\n _setOpen(openState)\n }\n\n // This sets the cookie to keep the sidebar state.\n document.cookie = `${SIDEBAR_COOKIE_NAME}=${openState}; path=/; max-age=${SIDEBAR_COOKIE_MAX_AGE}`\n },\n [setOpenProp, open]\n )\n\n // Helper to toggle the sidebar.\n const toggleSidebar = React.useCallback(() => {\n return isMobile\n ? setOpenMobile((open) => !open)\n : setOpen((open) => !open)\n }, [isMobile, setOpen, setOpenMobile])\n\n // Adds a keyboard shortcut to toggle the sidebar.\n React.useEffect(() => {\n const handleKeyDown = (event: KeyboardEvent) => {\n if (\n event.key === SIDEBAR_KEYBOARD_SHORTCUT &&\n (event.metaKey || event.ctrlKey)\n ) {\n event.preventDefault()\n toggleSidebar()\n }\n }\n\n window.addEventListener(\"keydown\", handleKeyDown)\n return () => window.removeEventListener(\"keydown\", handleKeyDown)\n }, [toggleSidebar])\n\n // We add a state so that we can do data-state=\"expanded\" or \"collapsed\".\n // This makes it easier to style the sidebar with Tailwind classes.\n const state = open ? \"expanded\" : \"collapsed\"\n\n const contextValue = React.useMemo<SidebarContextProps>(\n () => ({\n state,\n open,\n setOpen,\n isMobile,\n openMobile,\n setOpenMobile,\n toggleSidebar,\n }),\n [state, open, setOpen, isMobile, openMobile, setOpenMobile, toggleSidebar]\n )\n\n return (\n <SidebarContext.Provider value={contextValue}>\n <TooltipProvider delayDuration={0}>\n <div\n style={\n {\n \"--sidebar-width\": SIDEBAR_WIDTH,\n \"--sidebar-width-icon\": SIDEBAR_WIDTH_ICON,\n ...style,\n } as React.CSSProperties\n }\n className={cn(\n \"group/sidebar-wrapper flex min-h-svh w-full has-[[data-variant=inset]]:bg-sidebar\",\n className\n )}\n ref={ref}\n {...props}\n >\n {children}\n </div>\n </TooltipProvider>\n </SidebarContext.Provider>\n )\n }\n)\nSidebarProvider.displayName = \"SidebarProvider\"\n\nconst Sidebar = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\"> & {\n side?: \"left\" | \"right\"\n variant?: \"sidebar\" | \"floating\" | \"inset\"\n collapsible?: \"offcanvas\" | \"icon\" | \"none\"\n }\n>(\n (\n {\n side = \"left\",\n variant = \"sidebar\",\n collapsible = \"offcanvas\",\n className,\n children,\n ...props\n },\n ref\n ) => {\n const { isMobile, state, openMobile, setOpenMobile } = useSidebar()\n\n if (collapsible === \"none\") {\n return (\n <div\n className={cn(\n \"flex h-full w-[--sidebar-width] flex-col bg-sidebar text-sidebar-foreground\",\n className\n )}\n ref={ref}\n {...props}\n >\n {children}\n </div>\n )\n }\n\n if (isMobile) {\n return (\n <Sheet open={openMobile} onOpenChange={setOpenMobile} {...props}>\n <SheetContent\n data-sidebar=\"sidebar\"\n data-mobile=\"true\"\n className=\"w-[--sidebar-width] bg-sidebar p-0 text-sidebar-foreground [&>button]:hidden\"\n style={\n {\n \"--sidebar-width\": SIDEBAR_WIDTH_MOBILE,\n } as React.CSSProperties\n }\n side={side}\n >\n <SheetHeader className=\"sr-only\">\n <SheetTitle>Sidebar</SheetTitle>\n <SheetDescription>Displays the mobile sidebar.</SheetDescription>\n </SheetHeader>\n <div className=\"flex h-full w-full flex-col\">{children}</div>\n </SheetContent>\n </Sheet>\n )\n }\n\n return (\n <div\n ref={ref}\n className=\"group peer hidden text-sidebar-foreground md:block\"\n data-state={state}\n data-collapsible={state === \"collapsed\" ? collapsible : \"\"}\n data-variant={variant}\n data-side={side}\n >\n {/* This is what handles the sidebar gap on desktop */}\n <div\n className={cn(\n \"relative w-[--sidebar-width] bg-transparent transition-[width] duration-200 ease-linear\",\n \"group-data-[collapsible=offcanvas]:w-0\",\n \"group-data-[side=right]:rotate-180\",\n variant === \"floating\" || variant === \"inset\"\n ? \"group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)_+_theme(spacing.4))]\"\n : \"group-data-[collapsible=icon]:w-[--sidebar-width-icon]\"\n )}\n />\n <div\n className={cn(\n \"fixed inset-y-0 z-10 hidden h-svh w-[--sidebar-width] transition-[left,right,width] duration-200 ease-linear md:flex\",\n side === \"left\"\n ? \"left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]\"\n : \"right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]\",\n // Adjust the padding for floating and inset variants.\n variant === \"floating\" || variant === \"inset\"\n ? \"p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)_+_theme(spacing.4)_+2px)]\"\n : \"group-data-[collapsible=icon]:w-[--sidebar-width-icon] group-data-[side=left]:border-r group-data-[side=right]:border-l\",\n className\n )}\n {...props}\n >\n <div\n data-sidebar=\"sidebar\"\n className=\"flex h-full w-full flex-col bg-sidebar group-data-[variant=floating]:rounded-lg group-data-[variant=floating]:border group-data-[variant=floating]:border-sidebar-border group-data-[variant=floating]:shadow\"\n >\n {children}\n </div>\n </div>\n </div>\n )\n }\n)\nSidebar.displayName = \"Sidebar\"\n\nconst SidebarTrigger = React.forwardRef<\n React.ElementRef<typeof Button>,\n React.ComponentProps<typeof Button>\n>(({ className, onClick, ...props }, ref) => {\n const { toggleSidebar } = useSidebar()\n\n return (\n <Button\n ref={ref}\n data-sidebar=\"trigger\"\n variant=\"ghost\"\n size=\"icon\"\n className={cn(\"h-7 w-7\", className)}\n onClick={(event) => {\n onClick?.(event)\n toggleSidebar()\n }}\n {...props}\n >\n <PanelLeft />\n <span className=\"sr-only\">Toggle Sidebar</span>\n </Button>\n )\n})\nSidebarTrigger.displayName = \"SidebarTrigger\"\n\nconst SidebarRail = React.forwardRef<\n HTMLButtonElement,\n React.ComponentProps<\"button\">\n>(({ className, ...props }, ref) => {\n const { toggleSidebar } = useSidebar()\n\n return (\n <button\n ref={ref}\n data-sidebar=\"rail\"\n aria-label=\"Toggle Sidebar\"\n tabIndex={-1}\n onClick={toggleSidebar}\n title=\"Toggle Sidebar\"\n className={cn(\n \"absolute inset-y-0 z-20 hidden w-4 -translate-x-1/2 transition-all ease-linear after:absolute after:inset-y-0 after:left-1/2 after:w-[2px] hover:after:bg-sidebar-border group-data-[side=left]:-right-4 group-data-[side=right]:left-0 sm:flex\",\n \"[[data-side=left]_&]:cursor-w-resize [[data-side=right]_&]:cursor-e-resize\",\n \"[[data-side=left][data-state=collapsed]_&]:cursor-e-resize [[data-side=right][data-state=collapsed]_&]:cursor-w-resize\",\n \"group-data-[collapsible=offcanvas]:translate-x-0 group-data-[collapsible=offcanvas]:after:left-full group-data-[collapsible=offcanvas]:hover:bg-sidebar\",\n \"[[data-side=left][data-collapsible=offcanvas]_&]:-right-2\",\n \"[[data-side=right][data-collapsible=offcanvas]_&]:-left-2\",\n className\n )}\n {...props}\n />\n )\n})\nSidebarRail.displayName = \"SidebarRail\"\n\nconst SidebarInset = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"main\">\n>(({ className, ...props }, ref) => {\n return (\n <main\n ref={ref}\n className={cn(\n \"relative flex w-full flex-1 flex-col bg-background\",\n \"md:peer-data-[variant=inset]:m-2 md:peer-data-[state=collapsed]:peer-data-[variant=inset]:ml-2 md:peer-data-[variant=inset]:ml-0 md:peer-data-[variant=inset]:rounded-xl md:peer-data-[variant=inset]:shadow\",\n className\n )}\n {...props}\n />\n )\n})\nSidebarInset.displayName = \"SidebarInset\"\n\nconst SidebarInput = React.forwardRef<\n React.ElementRef<typeof Input>,\n React.ComponentProps<typeof Input>\n>(({ className, ...props }, ref) => {\n return (\n <Input\n ref={ref}\n data-sidebar=\"input\"\n className={cn(\n \"h-8 w-full bg-background shadow-none focus-visible:ring-2 focus-visible:ring-sidebar-ring\",\n className\n )}\n {...props}\n />\n )\n})\nSidebarInput.displayName = \"SidebarInput\"\n\nconst SidebarHeader = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\">\n>(({ className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n data-sidebar=\"header\"\n className={cn(\"flex flex-col gap-2 p-2\", className)}\n {...props}\n />\n )\n})\nSidebarHeader.displayName = \"SidebarHeader\"\n\nconst SidebarFooter = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\">\n>(({ className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n data-sidebar=\"footer\"\n className={cn(\"flex flex-col gap-2 p-2\", className)}\n {...props}\n />\n )\n})\nSidebarFooter.displayName = \"SidebarFooter\"\n\nconst SidebarSeparator = React.forwardRef<\n React.ElementRef<typeof Separator>,\n React.ComponentProps<typeof Separator>\n>(({ className, ...props }, ref) => {\n return (\n <Separator\n ref={ref}\n data-sidebar=\"separator\"\n className={cn(\"mx-2 w-auto bg-sidebar-border\", className)}\n {...props}\n />\n )\n})\nSidebarSeparator.displayName = \"SidebarSeparator\"\n\nconst SidebarContent = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\">\n>(({ className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n data-sidebar=\"content\"\n className={cn(\n \"flex min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden\",\n className\n )}\n {...props}\n />\n )\n})\nSidebarContent.displayName = \"SidebarContent\"\n\nconst SidebarGroup = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\">\n>(({ className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n data-sidebar=\"group\"\n className={cn(\"relative flex w-full min-w-0 flex-col p-0\", className)}\n {...props}\n />\n )\n})\nSidebarGroup.displayName = \"SidebarGroup\"\n\nconst SidebarGroupLabel = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\"> & { asChild?: boolean }\n>(({ className, asChild = false, ...props }, ref) => {\n const Comp = asChild ? Slot : \"div\"\n\n return (\n <Comp\n // @ts-ignore\n ref={ref}\n data-sidebar=\"group-label\"\n className={cn(\n \"flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium text-sidebar-foreground/70 outline-none ring-sidebar-ring transition-[margin,opacity] duration-200 ease-linear focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0\",\n \"group-data-[collapsible=icon]:-mt-8 group-data-[collapsible=icon]:opacity-0\",\n className\n )}\n {...props}\n />\n )\n})\nSidebarGroupLabel.displayName = \"SidebarGroupLabel\"\n\nconst SidebarGroupAction = React.forwardRef<\n HTMLButtonElement,\n React.ComponentProps<\"button\"> & { asChild?: boolean }\n>(({ className, asChild = false, ...props }, ref) => {\n const Comp = asChild ? Slot : \"button\"\n\n return (\n <Comp\n // @ts-ignore\n ref={ref}\n data-sidebar=\"group-action\"\n className={cn(\n \"absolute right-3 top-3.5 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground outline-none ring-sidebar-ring transition-transform hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0\",\n // Increases the hit area of the button on mobile.\n \"after:absolute after:-inset-2 after:md:hidden\",\n \"group-data-[collapsible=icon]:hidden\",\n className\n )}\n {...props}\n />\n )\n})\nSidebarGroupAction.displayName = \"SidebarGroupAction\"\n\nconst SidebarGroupContent = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\">\n>(({ className, ...props }, ref) => (\n <div\n ref={ref}\n data-sidebar=\"group-content\"\n className={cn(\"w-full text-sm\", className)}\n {...props}\n />\n))\nSidebarGroupContent.displayName = \"SidebarGroupContent\"\n\nconst SidebarMenu = React.forwardRef<\n HTMLUListElement,\n React.ComponentProps<\"ul\">\n>(({ className, ...props }, ref) => (\n <ul\n ref={ref}\n data-sidebar=\"menu\"\n className={cn(\"flex w-full min-w-0 flex-col gap-1\", className)}\n {...props}\n />\n))\nSidebarMenu.displayName = \"SidebarMenu\"\n\nconst SidebarMenuItem = React.forwardRef<\n HTMLLIElement,\n React.ComponentProps<\"li\">\n>(({ className, ...props }, ref) => (\n <li\n ref={ref}\n data-sidebar=\"menu-item\"\n className={cn(\"group/menu-item relative\", className)}\n {...props}\n />\n))\nSidebarMenuItem.displayName = \"SidebarMenuItem\"\n\nconst sidebarMenuButtonVariants = cva(\n \"peer/menu-button flex w-full items-center gap-2 overflow-hidden rounded-md p-2 text-left text-sm outline-none ring-sidebar-ring transition-[width,height,padding] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 group-has-[[data-sidebar=menu-action]]/menu-item:pr-8 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-[active=true]:bg-sidebar-accent data-[active=true]:font-medium data-[active=true]:text-sidebar-accent-foreground data-[state=open]:hover:bg-sidebar-accent data-[state=open]:hover:text-sidebar-accent-foreground group-data-[collapsible=icon]:!size-8 group-data-[collapsible=icon]:!p-[0.40rem] [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0\",\n {\n variants: {\n variant: {\n default: \"hover:bg-sidebar-accent hover:text-sidebar-accent-foreground\",\n outline:\n \"bg-background shadow-[0_0_0_1px_hsl(var(--sidebar-border))] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground hover:shadow-[0_0_0_1px_hsl(var(--sidebar-accent))]\",\n },\n size: {\n default: \"h-8 text-sm\",\n sm: \"h-7 text-xs\",\n lg: \"h-12 text-sm group-data-[collapsible=icon]:!p-0\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n size: \"default\",\n },\n }\n)\n\nconst SidebarMenuButton = React.forwardRef<\n HTMLButtonElement,\n React.ComponentProps<\"button\"> & {\n asChild?: boolean\n isActive?: boolean\n tooltip?: string | React.ComponentProps<typeof TooltipContent>\n } & VariantProps<typeof sidebarMenuButtonVariants>\n>(\n (\n {\n asChild = false,\n isActive = false,\n variant = \"default\",\n size = \"default\",\n tooltip,\n className,\n ...props\n },\n ref\n ) => {\n const Comp = asChild ? Slot : \"button\"\n const { isMobile, state } = useSidebar()\n\n const button = (\n <Comp\n // @ts-ignore\n ref={ref}\n data-sidebar=\"menu-button\"\n data-size={size}\n data-active={isActive}\n className={cn(sidebarMenuButtonVariants({ variant, size }), className)}\n {...props}\n />\n )\n\n if (!tooltip) {\n return button\n }\n\n if (typeof tooltip === \"string\") {\n tooltip = {\n children: tooltip,\n }\n }\n\n return (\n <Tooltip>\n <TooltipTrigger asChild>{button}</TooltipTrigger>\n <TooltipContent\n side=\"right\"\n align=\"center\"\n hidden={state !== \"collapsed\" || isMobile}\n {...tooltip}\n />\n </Tooltip>\n )\n }\n)\nSidebarMenuButton.displayName = \"SidebarMenuButton\"\n\nconst SidebarMenuAction = React.forwardRef<\n HTMLButtonElement,\n React.ComponentProps<\"button\"> & {\n asChild?: boolean\n showOnHover?: boolean\n }\n>(({ className, asChild = false, showOnHover = false, ...props }, ref) => {\n const Comp = asChild ? Slot : \"button\"\n\n return (\n <Comp\n // @ts-ignore\n ref={ref}\n data-sidebar=\"menu-action\"\n className={cn(\n \"absolute right-1 top-1.5 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground outline-none ring-sidebar-ring transition-transform hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 peer-hover/menu-button:text-sidebar-accent-foreground [&>svg]:size-4 [&>svg]:shrink-0\",\n // Increases the hit area of the button on mobile.\n \"after:absolute after:-inset-2 after:md:hidden\",\n \"peer-data-[size=sm]/menu-button:top-1\",\n \"peer-data-[size=default]/menu-button:top-1.5\",\n \"peer-data-[size=lg]/menu-button:top-2.5\",\n \"group-data-[collapsible=icon]:hidden\",\n showOnHover &&\n \"group-focus-within/menu-item:opacity-100 group-hover/menu-item:opacity-100 data-[state=open]:opacity-100 peer-data-[active=true]/menu-button:text-sidebar-accent-foreground md:opacity-0\",\n className\n )}\n {...props}\n />\n )\n})\nSidebarMenuAction.displayName = \"SidebarMenuAction\"\n\nconst SidebarMenuBadge = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\">\n>(({ className, ...props }, ref) => (\n <div\n ref={ref}\n data-sidebar=\"menu-badge\"\n className={cn(\n \"pointer-events-none absolute right-1 flex h-5 min-w-5 select-none items-center justify-center rounded-md px-1 text-xs font-medium tabular-nums text-sidebar-foreground\",\n \"peer-hover/menu-button:text-sidebar-accent-foreground peer-data-[active=true]/menu-button:text-sidebar-accent-foreground\",\n \"peer-data-[size=sm]/menu-button:top-1\",\n \"peer-data-[size=default]/menu-button:top-1.5\",\n \"peer-data-[size=lg]/menu-button:top-2.5\",\n \"group-data-[collapsible=icon]:hidden\",\n className\n )}\n {...props}\n />\n))\nSidebarMenuBadge.displayName = \"SidebarMenuBadge\"\n\nconst SidebarMenuSkeleton = React.forwardRef<\n HTMLDivElement,\n React.ComponentProps<\"div\"> & {\n showIcon?: boolean\n }\n>(({ className, showIcon = false, ...props }, ref) => {\n // Random width between 50 to 90%.\n const width = React.useMemo(() => {\n return `${Math.floor(Math.random() * 40) + 50}%`\n }, [])\n\n return (\n <div\n ref={ref}\n data-sidebar=\"menu-skeleton\"\n className={cn(\"flex h-8 items-center gap-2 rounded-md px-2\", className)}\n {...props}\n >\n {showIcon && (\n <Skeleton\n className=\"size-4 rounded-md\"\n data-sidebar=\"menu-skeleton-icon\"\n />\n )}\n <Skeleton\n className=\"h-4 max-w-[--skeleton-width] flex-1\"\n data-sidebar=\"menu-skeleton-text\"\n style={\n {\n \"--skeleton-width\": width,\n } as React.CSSProperties\n }\n />\n </div>\n )\n})\nSidebarMenuSkeleton.displayName = \"SidebarMenuSkeleton\"\n\nconst SidebarMenuSub = React.forwardRef<\n HTMLUListElement,\n React.ComponentProps<\"ul\">\n>(({ className, ...props }, ref) => (\n <ul\n ref={ref}\n data-sidebar=\"menu-sub\"\n className={cn(\n \"mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l border-sidebar-border px-2.5 py-0.5\",\n \"group-data-[collapsible=icon]:hidden\",\n className\n )}\n {...props}\n />\n))\nSidebarMenuSub.displayName = \"SidebarMenuSub\"\n\nconst SidebarMenuSubItem = React.forwardRef<\n HTMLLIElement,\n React.ComponentProps<\"li\">\n>(({ ...props }, ref) => <li ref={ref} {...props} />)\nSidebarMenuSubItem.displayName = \"SidebarMenuSubItem\"\n\nconst SidebarMenuSubButton = React.forwardRef<\n HTMLAnchorElement,\n React.ComponentProps<\"a\"> & {\n asChild?: boolean\n size?: \"sm\" | \"md\"\n isActive?: boolean\n }\n>(({ asChild = false, size = \"md\", isActive, className, ...props }, ref) => {\n const Comp = asChild ? Slot : \"a\"\n\n return (\n <Comp\n // @ts-ignore\n ref={ref}\n data-sidebar=\"menu-sub-button\"\n data-size={size}\n data-active={isActive}\n className={cn(\n \"flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 text-sidebar-foreground outline-none ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0 [&>svg]:text-sidebar-accent-foreground\",\n \"data-[active=true]:bg-sidebar-accent data-[active=true]:text-sidebar-accent-foreground\",\n size === \"sm\" && \"text-xs\",\n size === \"md\" && \"text-sm\",\n \"group-data-[collapsible=icon]:hidden\",\n className\n )}\n {...props}\n />\n )\n})\nSidebarMenuSubButton.displayName = \"SidebarMenuSubButton\"\n\nexport {\n Sidebar,\n SidebarContent,\n SidebarFooter,\n SidebarGroup,\n SidebarGroupAction,\n SidebarGroupContent,\n SidebarGroupLabel,\n SidebarHeader,\n SidebarInput,\n SidebarInset,\n SidebarMenu,\n SidebarMenuAction,\n SidebarMenuBadge,\n SidebarMenuButton,\n SidebarMenuItem,\n SidebarMenuSkeleton,\n SidebarMenuSub,\n SidebarMenuSubButton,\n SidebarMenuSubItem,\n SidebarProvider,\n SidebarRail,\n SidebarSeparator,\n SidebarTrigger,\n useSidebar,\n}\n","\"use client\";\n\nimport Link from \"next/link\";\nimport { useParams, usePathname } from \"next/navigation\";\nimport * as React from \"react\";\nimport { useContext, useEffect } from \"react\";\nimport { UserContext } from \"@/app/(application)/authenticated\";\nimport {\n Sidebar,\n SidebarContent,\n SidebarFooter,\n SidebarGroup,\n SidebarGroupContent,\n SidebarMenu,\n SidebarMenuButton,\n SidebarMenuItem,\n SidebarProvider,\n SidebarTrigger,\n useSidebar\n} from \"@/components/ui/sidebar\";\nimport { cn } from \"@/lib/utils\";\nimport { UserRole } from \"@/types/models/user-role\";\nimport { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuTrigger } from \"../ui/dropdown-menu\";\nimport { ChevronUp, Moon, Sun, Code, MessageCircle, Users, Key, LayoutDashboard, Database, ListTodo, Bot, Route, Variable, FileCheck, Sparkles, Settings, LogOut, FileText, FolderOpen, Brain } from \"lucide-react\";\nimport { useRouter } from \"next/navigation\";\nimport { useTheme } from \"next-themes\";\nimport { Avatar, AvatarFallback } from \"../ui/avatar\";\nimport Logo from \"../logo\";\n\ninterface User {\n email: string;\n super_admin: boolean;\n role: UserRole;\n}\n\nconst buildNavigation = (user: User, role: UserRole) => {\n const navigationItems: { label: string; path: string; icon: React.ReactNode }[] = [];\n\n if (user.super_admin) {\n navigationItems.push({\n label: \"Dashboard\",\n path: \"dashboard\",\n icon: <LayoutDashboard />,\n });\n }\n\n navigationItems.push({\n label: \"Contexts\",\n path: \"data\",\n icon: <Database />,\n });\n\n navigationItems.push({\n label: \"Jobs\",\n path: \"jobs\",\n icon: <ListTodo />,\n });\n\n if (user.super_admin || role.agents === \"write\") {\n navigationItems.push({\n label: \"Agents\",\n path: \"agents\",\n icon: <Bot />,\n });\n }\n\n navigationItems.push({\n label: \"Projects\",\n path: \"projects\",\n icon: <FolderOpen />,\n });\n\n navigationItems.push({\n label: \"Chat\",\n path: \"chat\",\n icon: <MessageCircle />,\n });\n\n if (user.super_admin || role.evals === \"read\" || role.evals === \"write\") {\n navigationItems.push({\n label: \"Evals\",\n path: \"evals\",\n icon: <Brain />,\n });\n }\n\n if (user.super_admin || role.workflows === \"write\") {\n navigationItems.push({\n label: \"Workflows\",\n path: \"workflows\",\n icon: <Route />,\n });\n }\n\n if (user.super_admin || role.users === \"write\") {\n navigationItems.push({\n label: \"Users\",\n path: \"users\",\n icon: <Users />,\n });\n }\n\n if (user.super_admin || role.api === \"write\") {\n navigationItems.push({\n label: \"Keys\",\n path: \"keys\",\n icon: <Key />,\n });\n }\n\n if (user.super_admin || role.variables === \"write\") {\n navigationItems.push({\n label: \"Variables\",\n path: \"variables\",\n icon: <Variable />,\n });\n }\n\n if (user.super_admin || role.api === \"write\") {\n navigationItems.push({\n label: \"API\",\n path: \"explorer\",\n icon: <Code />,\n });\n }\n\n if (user.super_admin) {\n navigationItems.push({\n label: \"Configurations\",\n path: \"configuration\",\n icon: <Settings />,\n });\n }\n\n return navigationItems;\n}\n\nfunction NavigationItems({ items }: { items: { label: string; path: string; icon: React.ReactNode }[] }) {\n const pathname = usePathname();\n\n return (\n <SidebarMenu className=\"space-y-1\">\n {items.map((navItem, index) => {\n const isActive = pathname.includes(navItem.path);\n return (\n <SidebarMenuItem key={index}>\n <SidebarMenuButton\n asChild\n isActive={isActive}\n tooltip={navItem.label}\n className={cn(\n \"h-10 transition-all duration-200\"\n )}\n >\n <Link href={`/${navItem.path}`} className=\"flex items-center gap-3\">\n <div className={cn(\n \"flex h-5 w-5 items-center justify-center transition-colors\",\n )}>\n {navItem.icon}\n </div>\n <span className={cn(\n \"font-medium transition-colors\",\n )}>\n {navItem.label}\n </span>\n </Link>\n </SidebarMenuButton>\n </SidebarMenuItem>\n );\n })}\n </SidebarMenu>\n );\n}\n\nexport function MainNavSidebar({ sidebarDefaultOpen }: { sidebarDefaultOpen: boolean }) {\n \n const { user } = useContext(UserContext);\n const navigationItems = buildNavigation(user, user.role);\n const router = useRouter();\n const { setTheme, theme } = useTheme();\n const params = useParams()\n const sidebar = useSidebar()\n\n useEffect(() => {\n if (params.agent && sidebarDefaultOpen === undefined) {\n sidebar.setOpen(false)\n }\n }, [params.agent])\n\n return (\n <Sidebar collapsible=\"icon\" className=\"border-r\">\n <div className=\"flex items-center gap-3 border-b bg-background/80 backdrop-blur-sm p-[12px] sticky top-0 z-10\">\n <SidebarTrigger />\n <div className=\"flex items-center gap-2\">\n <Logo alt=\"Logo\" width={100} height={40} />\n </div>\n </div>\n <SidebarContent className=\"px-2\">\n <SidebarGroup className=\"mt-4\">\n <SidebarGroupContent>\n <NavigationItems items={navigationItems} />\n </SidebarGroupContent>\n </SidebarGroup>\n </SidebarContent>\n <SidebarFooter className=\"border-t bg-muted/20 p-[5px]\">\n <SidebarMenu>\n <SidebarMenuItem>\n <DropdownMenu>\n <DropdownMenuTrigger asChild>\n <SidebarMenuButton className=\"h-12 hover:bg-accent/50\">\n <Avatar className=\"h-5 w-5\">\n <AvatarFallback className=\"bg-gradient-to-br from-primary/20 to-primary/60 text-white text-sm\">\n {user.email.charAt(0).toUpperCase()}\n </AvatarFallback>\n </Avatar>\n <div className=\"flex flex-col items-start group-data-[collapsible=icon]:hidden\">\n <span className=\"text-sm font-medium capitalize\">{user.email.split('@')[0]}</span>\n <div className=\"flex items-center gap-1\">\n <span className=\"text-xs text-muted-foreground\">{user.email.split('@')[1]}</span>\n </div>\n </div>\n <ChevronUp className=\"ml-auto h-4 w-4 group-data-[collapsible=icon]:hidden\" />\n </SidebarMenuButton>\n </DropdownMenuTrigger>\n <DropdownMenuContent\n side=\"top\"\n className=\"w-[--radix-popper-anchor-width] mb-2\"\n align=\"start\"\n >\n <DropdownMenuItem onClick={() => setTheme(theme === \"dark\" ? \"light\" : \"dark\")}>\n <div className=\"flex items-center gap-2 w-full\">\n {theme === \"dark\" ? <Sun className=\"h-4 w-4\" /> : <Moon className=\"h-4 w-4\" />}\n <span>Theme</span>\n </div>\n </DropdownMenuItem>\n <DropdownMenuItem onClick={() => router.push(\"/api/auth/signout\")}>\n <div className=\"flex items-center gap-2 w-full\">\n <LogOut className=\"h-4 w-4\" />\n <span>Logout</span>\n </div>\n </DropdownMenuItem>\n <DropdownMenuItem onClick={() => window.open(\"https://www.exulu.com/toc\", \"_blank\")}>\n <div className=\"flex items-center gap-2 w-full\">\n <FileText className=\"h-4 w-4\" />\n <span>Terms</span>\n </div>\n </DropdownMenuItem>\n </DropdownMenuContent>\n </DropdownMenu>\n </SidebarMenuItem>\n </SidebarMenu>\n </SidebarFooter>\n </Sidebar>\n );\n}\n\nexport function MainNavProvider({ children, sidebarDefaultOpen }: { children: React.ReactNode, sidebarDefaultOpen: boolean }) {\n console.log(\"sidebarDefaultOpen\", sidebarDefaultOpen)\n return (\n <SidebarProvider defaultOpen={sidebarDefaultOpen}>\n <div className=\"flex h-screen w-full bg-background overflow-hidden\">\n <MainNavSidebar sidebarDefaultOpen={sidebarDefaultOpen} />\n <main className=\"flex-1 overflow-auto\">\n {children}\n </main>\n </div>\n </SidebarProvider>\n );\n}\n","\"use client\";\n\nimport {\n ApolloClient,\n ApolloLink,\n ApolloProvider,\n HttpLink,\n InMemoryCache,\n} from \"@apollo/client\";\nimport { setContext } from \"@apollo/client/link/context\";\nimport { SessionProvider } from \"next-auth/react\";\nimport * as React from \"react\";\nimport { MainNavProvider } from \"@/components/custom/main-nav\";\nimport { getToken } from \"@/util/api\";\nimport { ConfigContext } from \"@/components/config-context\";\nimport { type User } from \"@/types/models/user\";\n\ninterface AuthenticatedProps {\n children: React.ReactNode;\n user: User & { role: { id: string } };\n sidebarDefaultOpen: boolean;\n}\n\nexport const UserContext = React.createContext<any>(null);\n\nconst User = ({ children, user, sidebarDefaultOpen }: AuthenticatedProps) => {\n\n return (\n <UserContext.Provider value={{ user }}>\n <MainNavProvider sidebarDefaultOpen={sidebarDefaultOpen}>\n {children}\n </MainNavProvider>\n\n </UserContext.Provider>\n );\n};\nconst Authenticated = ({ children, user, sidebarDefaultOpen }: AuthenticatedProps) => {\n\n const configContext = React.useContext(ConfigContext);\n\n const uri = configContext?.backend\n ? configContext?.backend + \"/graphql\"\n : \"http://localhost:9001/graphql\";\n\n const basic = setContext((operation, context) => ({\n headers: {\n Accept: \"charset=utf-8\",\n },\n }));\n\n const authLink = setContext(async (operation, context) => {\n const token = await getToken();\n return {\n headers: {\n Authorization: `Bearer ${token}`,\n },\n };\n });\n\n const link = ApolloLink.from([basic, authLink, new HttpLink({ uri: uri })]);\n\n const client = new ApolloClient({\n uri: uri,\n cache: new InMemoryCache({\n addTypename: false,\n }),\n link: link,\n defaultOptions: {\n watchQuery: {\n fetchPolicy: \"no-cache\",\n errorPolicy: \"ignore\",\n },\n query: {\n fetchPolicy: \"no-cache\",\n errorPolicy: \"all\",\n },\n },\n });\n\n return (\n <ApolloProvider client={client}>\n <SessionProvider>\n <User sidebarDefaultOpen={sidebarDefaultOpen} user={user}>\n {children}\n </User>\n </SessionProvider>\n </ApolloProvider>\n );\n};\n\nexport default Authenticated;\n","\"use client\"\nimport { BackendConfigType } from \"@/util/api\";\nimport { createContext } from \"react\";\n\nexport type ConfigContextType = {\n backend: string;\n google_client_id: string;\n auth_mode: string;\n} & BackendConfigType;\n\nexport const ConfigContext = createContext<ConfigContextType | null>(null);\n\nexport function ConfigContextProvider({ children, config }: {\n children: React.ReactNode;\n config: ConfigContextType;\n}) {\n\n console.log(\"[EXULU] Config: \", config);\n\n if (!config) {\n throw new Error(\"Config not found\");\n }\n\n return (\n <ConfigContext.Provider value={config}>\n {children}\n </ConfigContext.Provider>\n );\n}\n","\"use client\";\n\nimport { ConfigContext } from \"./config-context\";\nimport { useContext } from \"react\";\n\ninterface LogoProps {\n width?: number;\n height?: number;\n className?: string;\n alt?: string;\n}\n\nconst Logo = ({ width = 64, height = 32, className = \"\", alt = \"Logo\" }: LogoProps) => {\n const configContext = useContext(ConfigContext);\n return (\n <>\n <img\n src={configContext?.backend + \"/logo_dark.png\"}\n alt={alt}\n width={width}\n height={height}\n className={className + \"hidden dark:block\"}\n />\n <img\n src={configContext?.backend + \"/logo_light.png\"}\n alt={alt}\n width={width}\n height={height}\n className={className + \"block dark:hidden\"}\n />\n </>\n )\n}\n\nexport default Logo;","\"use client\";\n\nimport * as AvatarPrimitive from \"@radix-ui/react-avatar\";\nimport * as React from \"react\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst Avatar = React.forwardRef<\n React.ElementRef<typeof AvatarPrimitive.Root>,\n React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Root>\n>(({ className, ...props }, ref) => (\n <AvatarPrimitive.Root\n ref={ref}\n className={cn(\n \"relative flex h-10 w-10 shrink-0 overflow-hidden rounded-full\",\n className,\n )}\n {...props}\n />\n));\nAvatar.displayName = AvatarPrimitive.Root.displayName;\n\nconst AvatarImage = React.forwardRef<\n React.ElementRef<typeof AvatarPrimitive.Image>,\n React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Image>\n>(({ className, ...props }, ref) => (\n <AvatarPrimitive.Image\n ref={ref}\n className={cn(\"aspect-square h-full w-full\", className)}\n {...props}\n />\n));\nAvatarImage.displayName = AvatarPrimitive.Image.displayName;\n\nconst AvatarFallback = React.forwardRef<\n React.ElementRef<typeof AvatarPrimitive.Fallback>,\n React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Fallback>\n>(({ className, ...props }, ref) => (\n <AvatarPrimitive.Fallback\n ref={ref}\n className={cn(\n \"flex h-full w-full items-center justify-center rounded-full bg-muted\",\n className,\n )}\n {...props}\n />\n));\nAvatarFallback.displayName = AvatarPrimitive.Fallback.displayName;\n\nexport { Avatar, AvatarImage, AvatarFallback };\n","\"use client\";\n\nimport * as DropdownMenuPrimitive from \"@radix-ui/react-dropdown-menu\";\nimport { Check, ChevronRight, Circle } from \"lucide-react\";\nimport * as React from \"react\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst DropdownMenu = DropdownMenuPrimitive.Root;\n\nconst DropdownMenuTrigger = DropdownMenuPrimitive.Trigger;\n\nconst DropdownMenuGroup = DropdownMenuPrimitive.Group;\n\nconst DropdownMenuPortal = DropdownMenuPrimitive.Portal;\n\nconst DropdownMenuSub = DropdownMenuPrimitive.Sub;\n\nconst DropdownMenuRadioGroup = DropdownMenuPrimitive.RadioGroup;\n\nconst DropdownMenuSubTrigger = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.SubTrigger>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.SubTrigger> & {\n inset?: boolean;\n }\n>(({ className, inset, children, ...props }, ref) => (\n <DropdownMenuPrimitive.SubTrigger\n ref={ref}\n className={cn(\n \"flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent data-[state=open]:bg-accent\",\n inset && \"pl-8\",\n className,\n )}\n {...props}\n >\n {children}\n <ChevronRight className=\"ml-auto size-4\" />\n </DropdownMenuPrimitive.SubTrigger>\n));\nDropdownMenuSubTrigger.displayName =\n DropdownMenuPrimitive.SubTrigger.displayName;\n\nconst DropdownMenuSubContent = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.SubContent>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.SubContent>\n>(({ className, ...props }, ref) => (\n <DropdownMenuPrimitive.SubContent\n ref={ref}\n className={cn(\n \"z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2\",\n className,\n )}\n {...props}\n />\n));\nDropdownMenuSubContent.displayName =\n DropdownMenuPrimitive.SubContent.displayName;\n\nconst DropdownMenuContent = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Content>\n>(({ className, sideOffset = 4, ...props }, ref) => (\n <DropdownMenuPrimitive.Portal>\n <DropdownMenuPrimitive.Content\n ref={ref}\n sideOffset={sideOffset}\n className={cn(\n \"z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-md data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2\",\n className,\n )}\n {...props}\n />\n </DropdownMenuPrimitive.Portal>\n));\nDropdownMenuContent.displayName = DropdownMenuPrimitive.Content.displayName;\n\nconst DropdownMenuItem = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.Item>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Item> & {\n inset?: boolean;\n }\n>(({ className, inset, ...props }, ref) => (\n <DropdownMenuPrimitive.Item\n ref={ref}\n className={cn(\n \"relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n inset && \"pl-8\",\n className,\n )}\n {...props}\n />\n));\nDropdownMenuItem.displayName = DropdownMenuPrimitive.Item.displayName;\n\nconst DropdownMenuCheckboxItem = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.CheckboxItem>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.CheckboxItem>\n>(({ className, children, checked, ...props }, ref) => (\n <DropdownMenuPrimitive.CheckboxItem\n ref={ref}\n className={cn(\n \"relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n className,\n )}\n checked={checked}\n {...props}\n >\n <span className=\"absolute left-2 flex size-3.5 items-center justify-center\">\n <DropdownMenuPrimitive.ItemIndicator>\n <Check className=\"size-4\" />\n </DropdownMenuPrimitive.ItemIndicator>\n </span>\n {children}\n </DropdownMenuPrimitive.CheckboxItem>\n));\nDropdownMenuCheckboxItem.displayName =\n DropdownMenuPrimitive.CheckboxItem.displayName;\n\nconst DropdownMenuRadioItem = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.RadioItem>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.RadioItem>\n>(({ className, children, ...props }, ref) => (\n <DropdownMenuPrimitive.RadioItem\n ref={ref}\n className={cn(\n \"relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n className,\n )}\n {...props}\n >\n <span className=\"absolute left-2 flex size-3.5 items-center justify-center\">\n <DropdownMenuPrimitive.ItemIndicator>\n <Circle className=\"size-2 fill-current\" />\n </DropdownMenuPrimitive.ItemIndicator>\n </span>\n {children}\n </DropdownMenuPrimitive.RadioItem>\n));\nDropdownMenuRadioItem.displayName = DropdownMenuPrimitive.RadioItem.displayName;\n\nconst DropdownMenuLabel = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.Label>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Label> & {\n inset?: boolean;\n }\n>(({ className, inset, ...props }, ref) => (\n <DropdownMenuPrimitive.Label\n ref={ref}\n className={cn(\n \"px-2 py-1.5 text-sm font-semibold\",\n inset && \"pl-8\",\n className,\n )}\n {...props}\n />\n));\nDropdownMenuLabel.displayName = DropdownMenuPrimitive.Label.displayName;\n\nconst DropdownMenuSeparator = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.Separator>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Separator>\n>(({ className, ...props }, ref) => (\n <DropdownMenuPrimitive.Separator\n ref={ref}\n className={cn(\"-mx-1 my-1 h-px bg-muted\", className)}\n {...props}\n />\n));\nDropdownMenuSeparator.displayName = DropdownMenuPrimitive.Separator.displayName;\n\nconst DropdownMenuShortcut = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLSpanElement>) => {\n return (\n <span\n className={cn(\"ml-auto text-xs tracking-widest opacity-60\", className)}\n {...props}\n />\n );\n};\nDropdownMenuShortcut.displayName = \"DropdownMenuShortcut\";\n\nexport {\n DropdownMenu,\n DropdownMenuTrigger,\n DropdownMenuContent,\n DropdownMenuItem,\n DropdownMenuCheckboxItem,\n DropdownMenuRadioItem,\n DropdownMenuLabel,\n DropdownMenuSeparator,\n DropdownMenuShortcut,\n DropdownMenuGroup,\n DropdownMenuPortal,\n DropdownMenuSub,\n DropdownMenuSubContent,\n DropdownMenuSubTrigger,\n DropdownMenuRadioGroup,\n};\n","import * as React from \"react\";\n\nimport { cn } from \"@/lib/utils\";\n\nexport interface InputProps\n extends React.InputHTMLAttributes<HTMLInputElement> {}\n\nconst Input = React.forwardRef<HTMLInputElement, InputProps>(\n ({ className, type, ...props }, ref) => {\n return (\n <input\n type={type}\n className={cn(\n \"flex h-10 w-full rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50\",\n className,\n )}\n ref={ref}\n {...props}\n />\n );\n },\n);\nInput.displayName = \"Input\";\n\nexport { Input };\n","\"use client\";\n\nimport * as SeparatorPrimitive from \"@radix-ui/react-separator\";\nimport * as React from \"react\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst Separator = React.forwardRef<\n React.ElementRef<typeof SeparatorPrimitive.Root>,\n React.ComponentPropsWithoutRef<typeof SeparatorPrimitive.Root>\n>(\n (\n { className, orientation = \"horizontal\", decorative = true, ...props },\n ref,\n ) => (\n <SeparatorPrimitive.Root\n ref={ref}\n decorative={decorative}\n orientation={orientation}\n className={cn(\n \"shrink-0 bg-border\",\n orientation === \"horizontal\" ? \"h-[1px] w-full\" : \"h-full w-[1px]\",\n className,\n )}\n {...props}\n />\n ),\n);\nSeparator.displayName = SeparatorPrimitive.Root.displayName;\n\nexport { Separator };\n","\"use client\";\n\nimport * as SheetPrimitive from \"@radix-ui/react-dialog\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport { X } from \"lucide-react\";\nimport * as React from \"react\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst Sheet = SheetPrimitive.Root;\n\nconst SheetTrigger = SheetPrimitive.Trigger;\n\nconst SheetClose = SheetPrimitive.Close;\n\nconst SheetPortal = SheetPrimitive.Portal;\n\nconst SheetOverlay = React.forwardRef<\n React.ElementRef<typeof SheetPrimitive.Overlay>,\n React.ComponentPropsWithoutRef<typeof SheetPrimitive.Overlay>\n>(({ className, ...props }, ref) => (\n <SheetPrimitive.Overlay\n className={cn(\n \"fixed inset-0 z-50 bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0\",\n className,\n )}\n {...props}\n ref={ref}\n />\n));\nSheetOverlay.displayName = SheetPrimitive.Overlay.displayName;\n\nconst sheetVariants = cva(\n \"fixed z-50 gap-4 bg-background p-6 shadow-lg transition ease-in-out data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:duration-300 data-[state=open]:duration-500\",\n {\n variants: {\n side: {\n top: \"inset-x-0 top-0 border-b data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top\",\n bottom:\n \"inset-x-0 bottom-0 border-t data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom\",\n left: \"inset-y-0 left-0 h-full w-3/4 border-r data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left sm:max-w-sm\",\n right:\n \"inset-y-0 right-0 h-full w-3/4 border-l data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right sm:max-w-sm\",\n },\n },\n defaultVariants: {\n side: \"right\",\n },\n },\n);\n\ninterface SheetContentProps\n extends React.ComponentPropsWithoutRef<typeof SheetPrimitive.Content>,\n VariantProps<typeof sheetVariants> {}\n\nconst SheetContent = React.forwardRef<\n React.ElementRef<typeof SheetPrimitive.Content>,\n SheetContentProps\n>(({ side = \"right\", className, children, ...props }, ref) => (\n <SheetPortal>\n <SheetOverlay />\n <SheetPrimitive.Content\n ref={ref}\n className={cn(sheetVariants({ side }), className)}\n {...props}\n >\n {children}\n <SheetPrimitive.Close className=\"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-secondary\">\n <X className=\"size-4\" />\n <span className=\"sr-only\">Close</span>\n </SheetPrimitive.Close>\n </SheetPrimitive.Content>\n </SheetPortal>\n));\nSheetContent.displayName = SheetPrimitive.Content.displayName;\n\nconst SheetHeader = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n <div\n className={cn(\n \"flex flex-col space-y-2 text-center sm:text-left\",\n className,\n )}\n {...props}\n />\n);\nSheetHeader.displayName = \"SheetHeader\";\n\nconst SheetFooter = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n <div\n className={cn(\n \"flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2\",\n className,\n )}\n {...props}\n />\n);\nSheetFooter.displayName = \"SheetFooter\";\n\nconst SheetTitle = React.forwardRef<\n React.ElementRef<typeof SheetPrimitive.Title>,\n React.ComponentPropsWithoutRef<typeof SheetPrimitive.Title>\n>(({ className, ...props }, ref) => (\n <SheetPrimitive.Title\n ref={ref}\n className={cn(\"text-lg font-semibold text-foreground\", className)}\n {...props}\n />\n));\nSheetTitle.displayName = SheetPrimitive.Title.displayName;\n\nconst SheetDescription = React.forwardRef<\n React.ElementRef<typeof SheetPrimitive.Description>,\n React.ComponentPropsWithoutRef<typeof SheetPrimitive.Description>\n>(({ className, ...props }, ref) => (\n <SheetPrimitive.Description\n ref={ref}\n className={cn(\"text-sm text-muted-foreground\", className)}\n {...props}\n />\n));\nSheetDescription.displayName = SheetPrimitive.Description.displayName;\n\nexport {\n Sheet,\n SheetPortal,\n SheetOverlay,\n SheetTrigger,\n SheetClose,\n SheetContent,\n SheetHeader,\n SheetFooter,\n SheetTitle,\n SheetDescription,\n};\n","import { cn } from \"@/lib/utils\";\n\nfunction Skeleton({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) {\n return (\n <div\n className={cn(\"animate-pulse rounded-md bg-muted\", className)}\n {...props}\n />\n );\n}\n\nexport { Skeleton };\n","\"use client\";\n\nimport * as TooltipPrimitive from \"@radix-ui/react-tooltip\";\nimport * as React from \"react\";\n\nimport { cn } from \"@/lib/utils\";\n\nconst TooltipProvider = TooltipPrimitive.Provider;\n\nconst Tooltip = TooltipPrimitive.Root;\n\nconst TooltipTrigger = TooltipPrimitive.Trigger;\n\nconst TooltipContent = React.forwardRef<\n React.ElementRef<typeof TooltipPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Content>\n>(({ className, sideOffset = 4, ...props }, ref) => (\n <TooltipPrimitive.Content\n ref={ref}\n sideOffset={sideOffset}\n className={cn(\n \"z-50 overflow-hidden rounded-md border bg-popover px-3 py-1.5 text-sm text-popover-foreground shadow-md animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2\",\n className,\n )}\n {...props}\n />\n));\nTooltipContent.displayName = TooltipPrimitive.Content.displayName;\n\nexport { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider };\n","import * as React from \"react\"\n\nconst MOBILE_BREAKPOINT = 768\n\nexport function useIsMobile() {\n const [isMobile, setIsMobile] = React.useState<boolean | undefined>(undefined)\n\n React.useEffect(() => {\n const mql = window.matchMedia(`(max-width: ${MOBILE_BREAKPOINT - 1}px)`)\n const onChange = () => {\n setIsMobile(window.innerWidth < MOBILE_BREAKPOINT)\n }\n mql.addEventListener(\"change\", onChange)\n setIsMobile(window.innerWidth < MOBILE_BREAKPOINT)\n return () => mql.removeEventListener(\"change\", onChange)\n }, [])\n\n return !!isMobile\n}\n","import { getSession } from \"next-auth/react\";\n\nexport type ImageStyle = \"origami\" | \"anime\" | \"japanese_anime\" | \"vaporwave\" | \"lego\" | \"paper_cut\" | \"felt_puppet\" | \"3d\" | \"app_icon\" | \"pixel_art\" | \"isometric\";\n\nconst getUris = async () => {\n // Server-side: use environment variable directly\n if (typeof window === 'undefined') {\n const backend = process.env.BACKEND;\n if (!backend) {\n throw new Error(\"No backend set.\")\n }\n return {\n files: backend,\n base: backend\n }\n }\n\n // Client-side: fetch from API\n const context = await fetch(\"/api/config\").then(res => res.json());\n if (!context.backend) {\n throw new Error(\"No backend set.\")\n }\n return {\n files: context.backend,\n base: context.backend\n }\n}\n\nexport const getToken = async () => {\n const session = await getSession()\n // @ts-ignore\n return session?.user?.jwt;\n}\n\nexport type BackendConfigType = {\n fileUploads?: {\n s3endpoint: string;\n }\n workers?: {\n redisHost: string;\n enabled: boolean;\n }\n}\n\nexport type ThemeConfig = {\n light?: Record<string, string>;\n dark?: Record<string, string>;\n}\n\nexport const config = {\n backend: async (): Promise<Response> => {\n const uris = await getUris();\n const url = `${uris.base}/config`\n return fetch(url, {\n method: \"GET\",\n headers: {\n \"Content-Type\": \"application/json\",\n },\n })\n },\n theme: async (): Promise<ThemeConfig> => {\n try {\n const token = await getToken();\n const uris = await getUris();\n const res = await fetch(`${uris.base}/theme`, {\n method: \"GET\",\n headers: {\n \"Content-Type\": \"application/json\",\n \"Authorization\": `Bearer ${token}`,\n },\n })\n const json = await res.json();\n return json.theme;\n } catch (error) {\n console.error(\"Error fetching theme config:\", error);\n return { light: {}, dark: {} };\n }\n }\n}\n\nexport const agents = {\n image: {\n generate: async (parameters: {\n name: string,\n description: string,\n style?: ImageStyle\n }): Promise<any> => {\n\n const uris = await getUris();\n const url = `${uris.base}/generate/agent/image`;\n const token = await getToken()\n\n if (!token) {\n throw new Error(\"No valid session token available.\")\n }\n\n return fetch(url, {\n method: \"POST\",\n body: JSON.stringify(parameters),\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${token}`,\n },\n });\n }\n }\n}\n\nexport type S3FileListOutput = {\n \"$metadata\": {\n \"httpStatusCode\": number,\n \"attempts\": number,\n \"totalRetryDelay\": number\n },\n \"Contents\": {\n \"Key\": string,\n \"LastModified\": string,\n \"ETag\": string,\n \"Size\": number\n }[]\n \"IsTruncated\": boolean,\n \"NextContinuationToken\": string,\n \"KeyCount\": number,\n \"MaxKeys\": number,\n \"Name\": string,\n \"Prefix\": string\n}\n\nexport type S3ObjectOutput = {\n \"$metadata\": {\n \"httpStatusCode\": number,\n \"attempts\": number,\n \"totalRetryDelay\": number\n },\n \"AcceptRanges\": \"bytes\",\n \"LastModified\": string,\n \"ContentLength\": number,\n \"ChecksumCRC32C\": string,\n \"ETag\": string,\n \"CacheControl\": string,\n \"ContentType\": string,\n \"Expires\": string,\n \"ExpiresString\": string\n}\n\nexport const files = {\n object: async (key: string): Promise<S3ObjectOutput> => {\n const uris = await getUris();\n let url = `${uris.files}/s3/object`;\n const token = await getToken()\n const response = await fetch(url, {\n method: \"POST\",\n body: JSON.stringify({ key }),\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${token}`,\n },\n });\n return response.json();\n },\n list: async ({ search, continuationToken }: { search?: string, continuationToken?: string }): Promise<S3FileListOutput> => {\n const uris = await getUris();\n let url = `${uris.files}/s3/list`;\n const token = await getToken()\n\n if (!token) {\n throw new Error(\"No valid session token available.\")\n }\n\n if (search) {\n url += `?search=${search}`;\n }\n\n if (continuationToken) {\n url += `?continuationToken=${continuationToken}`;\n }\n\n const response = await fetch(url, {\n method: \"GET\",\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${token}`,\n },\n });\n return response.json();\n },\n download: async (key: string) => {\n\n const uris = await getUris();\n let url = `${uris.files}/s3/download?key=${key}`;\n\n const token = await getToken()\n\n if (!token) {\n throw new Error(\"No valid session token available.\")\n }\n\n return fetch(url, {\n method: \"GET\",\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${token}`,\n },\n });\n },\n delete: async (key: string) => {\n\n const uris = await getUris();\n let url = `${uris.files}/s3/delete?key=${key}`;\n const token = await getToken()\n\n if (!token) {\n throw new Error(\"No valid session token available.\")\n }\n\n return fetch(url, {\n method: \"DELETE\",\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${token}`,\n },\n });\n }\n}\n"],"names":["SidebarContext","React","useSidebar","context","SidebarProvider","param","ref","defaultOpen","open","openProp","onOpenChange","setOpenProp","className","style","children","props","isMobile","useIsMobile","openMobile","setOpenMobile","_open","_setOpen","setOpen","openState","value","document","cookie","SIDEBAR_COOKIE_MAX_AGE","concat","toggleSidebar","handleKeyDown","event","key","metaKey","ctrlKey","preventDefault","window","addEventListener","removeEventListener","state","contextValue","jsx_runtime","jsx","Provider","TooltipProvider","delayDuration","div","cn","displayName","Sidebar","side","variant","collapsible","Sheet","jsxs","SheetContent","data-sidebar","data-mobile","SheetHeader","SheetTitle","SheetDescription","data-state","data-collapsible","data-variant","data-side","SidebarTrigger","onClick","Button","size","PanelLeft","span","SidebarRail","button","aria-label","tabIndex","title","SidebarInset","main","SidebarInput","Input","SidebarHeader","SidebarFooter","SidebarSeparator","Separator","SidebarContent","SidebarGroup","SidebarGroupLabel","asChild","Comp","Slot","SidebarGroupAction","SidebarGroupContent","SidebarMenu","ul","SidebarMenuItem","li","sidebarMenuButtonVariants","cva","variants","default","outline","sm","lg","defaultVariants","SidebarMenuButton","isActive","tooltip","data-size","data-active","Tooltip","TooltipTrigger","TooltipContent","align","hidden","SidebarMenuAction","showOnHover","SidebarMenuBadge","SidebarMenuSkeleton","showIcon","width","Math","floor","random","Skeleton","SidebarMenuSub","SidebarMenuSubItem","SidebarMenuSubButton","buildNavigation","user","role","navigationItems","super_admin","push","label","path","icon","LayoutDashboard","Database","ListTodo","agents","Bot","FolderOpen","MessageCircle","evals","Brain","workflows","Route","users","Users","api","Key","variables","Variable","Code","Settings","NavigationItems","items","pathname","usePathname","map","navItem","index","includes","Link","href","MainNavSidebar","sidebarDefaultOpen","useContext","UserContext","router","useRouter","setTheme","theme","useTheme","params","useParams","sidebar","useEffect","agent","undefined","Logo","alt","height","DropdownMenu","DropdownMenuTrigger","Avatar","AvatarFallback","email","charAt","toUpperCase","split","ChevronUp","DropdownMenuContent","DropdownMenuItem","Sun","Moon","LogOut","FileText","MainNavProvider","console","log","User","authenticated","configContext","ConfigContext","uri","backend","basic","setContext","operation","headers","Accept","authLink","token","getToken","Authorization","link","ApolloLink","from","HttpLink","client","ApolloClient","cache","InMemoryCache","addTypename","defaultOptions","watchQuery","fetchPolicy","errorPolicy","query","ApolloProvider","SessionProvider","createContext","ConfigContextProvider","config","react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__","__webpack_exports__","Fragment","img","src","AvatarPrimitive","AvatarImage","DropdownMenuPrimitive","DropdownMenuSubTrigger","inset","ChevronRight","DropdownMenuSubContent","sideOffset","DropdownMenuCheckboxItem","checked","Check","DropdownMenuRadioItem","Circle","DropdownMenuLabel","DropdownMenuSeparator","type","input","orientation","decorative","SeparatorPrimitive","SheetPrimitive","SheetTrigger","SheetPortal","SheetOverlay","sheetVariants","top","bottom","left","right","X","TooltipPrimitive","setIsMobile","mql","matchMedia","MOBILE_BREAKPOINT","onChange","innerWidth","getUris","fetch","then","res","json","files","base","session","getSession","jwt","image","generate","parameters","uris","url","method","body","JSON","stringify","object","response","list","search","continuationToken","download","delete"],"sourceRoot":""}
@@ -1,2 +0,0 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[3998],{23910:function(e,t,n){var r=n(74288).Symbol;e.exports=r},54506:function(e,t,n){var r=n(23910),o=n(4479),i=n(80910),u=r?r.toStringTag:void 0;e.exports=function(e){return null==e?void 0===e?"[object Undefined]":"[object Null]":u&&u in Object(e)?o(e):i(e)}},55041:function(e,t,n){var r=n(5035),o=/^\s+/;e.exports=function(e){return e?e.slice(0,r(e)+1).replace(o,""):e}},17071:function(e,t,n){var r="object"==typeof n.g&&n.g&&n.g.Object===Object&&n.g;e.exports=r},4479:function(e,t,n){var r=n(23910),o=Object.prototype,i=o.hasOwnProperty,u=o.toString,a=r?r.toStringTag:void 0;e.exports=function(e){var t=i.call(e,a),n=e[a];try{e[a]=void 0;var r=!0}catch(e){}var o=u.call(e);return r&&(t?e[a]=n:delete e[a]),o}},80910:function(e){var t=Object.prototype.toString;e.exports=function(e){return t.call(e)}},74288:function(e,t,n){var r=n(17071),o="object"==typeof self&&self&&self.Object===Object&&self,i=r||o||Function("return this")();e.exports=i},5035:function(e){var t=/\s/;e.exports=function(e){for(var n=e.length;n--&&t.test(e.charAt(n)););return n}},7310:function(e,t,n){var r=n(28302),o=n(11121),i=n(6660),u=Math.max,a=Math.min;e.exports=function(e,t,n){var c,l,s,f,p,d,v=0,h=!1,g=!1,x=!0;if("function"!=typeof e)throw TypeError("Expected a function");function y(t){var n=c,r=l;return c=l=void 0,v=t,f=e.apply(r,n)}function b(e){var n=e-d,r=e-v;return void 0===d||n>=t||n<0||g&&r>=s}function m(){var e,n,r,i=o();if(b(i))return j(i);p=setTimeout(m,(e=i-d,n=i-v,r=t-e,g?a(r,s-n):r))}function j(e){return(p=void 0,x&&c)?y(e):(c=l=void 0,f)}function C(){var e,n=o(),r=b(n);if(c=arguments,l=this,d=n,r){if(void 0===p)return v=e=d,p=setTimeout(m,t),h?y(e):f;if(g)return clearTimeout(p),p=setTimeout(m,t),y(d)}return void 0===p&&(p=setTimeout(m,t)),f}return t=i(t)||0,r(n)&&(h=!!n.leading,s=(g="maxWait"in n)?u(i(n.maxWait)||0,t):s,x="trailing"in n?!!n.trailing:x),C.cancel=function(){void 0!==p&&clearTimeout(p),v=0,c=d=l=p=void 0},C.flush=function(){return void 0===p?f:j(o())},C}},28302:function(e){e.exports=function(e){var t=typeof e;return null!=e&&("object"==t||"function"==t)}},10303:function(e){e.exports=function(e){return null!=e&&"object"==typeof e}},78371:function(e,t,n){var r=n(54506),o=n(10303);e.exports=function(e){return"symbol"==typeof e||o(e)&&"[object Symbol]"==r(e)}},11121:function(e,t,n){var r=n(74288);e.exports=function(){return r.Date.now()}},37065:function(e,t,n){var r=n(7310),o=n(28302);e.exports=function(e,t,n){var i=!0,u=!0;if("function"!=typeof e)throw TypeError("Expected a function");return o(n)&&(i="leading"in n?!!n.leading:i,u="trailing"in n?!!n.trailing:u),r(e,t,{leading:i,maxWait:t,trailing:u})}},6660:function(e,t,n){var r=n(55041),o=n(28302),i=n(78371),u=0/0,a=/^[-+]0x[0-9a-f]+$/i,c=/^0b[01]+$/i,l=/^0o[0-7]+$/i,s=parseInt;e.exports=function(e){if("number"==typeof e)return e;if(i(e))return u;if(o(e)){var t="function"==typeof e.valueOf?e.valueOf():e;e=o(t)?t+"":t}if("string"!=typeof e)return 0===e?e:+e;e=r(e);var n=c.test(e);return n||l.test(e)?s(e.slice(2),n?2:8):a.test(e)?u:+e}},92451:function(e,t,n){"use strict";n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("ChevronLeft",[["path",{d:"m15 18-6-6 6-6",key:"1wnfg3"}]])},21047:function(e,t,n){"use strict";n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("Minus",[["path",{d:"M5 12h14",key:"1ays0h"}]])},3085:function(e,t,n){"use strict";n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("TrendingDown",[["polyline",{points:"22 17 13.5 8.5 8.5 13.5 2 7",key:"1r2t7k"}],["polyline",{points:"16 17 22 17 22 11",key:"11uiuu"}]])},70525:function(e,t,n){"use strict";n.d(t,{Z:function(){return r}});let r=(0,n(39763).Z)("TrendingUp",[["polyline",{points:"22 7 13.5 15.5 8.5 10.5 2 17",key:"126l90"}],["polyline",{points:"16 7 22 7 22 13",key:"kwv8wd"}]])},29114:function(e,t,n){"use strict";n.d(t,{gm:function(){return i}});var r=n(2265);n(57437);var o=r.createContext(void 0);function i(e){let t=r.useContext(o);return e||t||"ltr"}},27312:function(e,t,n){"use strict";n.d(t,{VY:function(){return X},fC:function(){return U},h_:function(){return L},xz:function(){return $}});var r=n(2265),o=n(6741),i=n(98575),u=n(73966),a=n(22308),c=n(86097),l=n(99103),s=n(99255),f=n(49289),p=n(83832),d=n(71599),v=n(66840),h=n(37053),g=n(80886),x=n(5478),y=n(60703),b=n(57437),m="Popover",[j,C]=(0,u.b)(m,[f.D7]),w=(0,f.D7)(),[O,P]=j(m),k=e=>{let{__scopePopover:t,children:n,open:o,defaultOpen:i,onOpenChange:u,modal:a=!1}=e,c=w(t),l=r.useRef(null),[p,d]=r.useState(!1),[v,h]=(0,g.T)({prop:o,defaultProp:null!=i&&i,onChange:u,caller:m});return(0,b.jsx)(f.fC,{...c,children:(0,b.jsx)(O,{scope:t,contentId:(0,s.M)(),triggerRef:l,open:v,onOpenChange:h,onOpenToggle:r.useCallback(()=>h(e=>!e),[h]),hasCustomAnchor:p,onCustomAnchorAdd:r.useCallback(()=>d(!0),[]),onCustomAnchorRemove:r.useCallback(()=>d(!1),[]),modal:a,children:n})})};k.displayName=m;var R="PopoverAnchor";r.forwardRef((e,t)=>{let{__scopePopover:n,...o}=e,i=P(R,n),u=w(n),{onCustomAnchorAdd:a,onCustomAnchorRemove:c}=i;return r.useEffect(()=>(a(),()=>c()),[a,c]),(0,b.jsx)(f.ee,{...u,...o,ref:t})}).displayName=R;var T="PopoverTrigger",E=r.forwardRef((e,t)=>{let{__scopePopover:n,...r}=e,u=P(T,n),a=w(n),c=(0,i.e)(t,u.triggerRef),l=(0,b.jsx)(v.WV.button,{type:"button","aria-haspopup":"dialog","aria-expanded":u.open,"aria-controls":u.contentId,"data-state":z(u.open),...r,ref:c,onClick:(0,o.M)(e.onClick,u.onOpenToggle)});return u.hasCustomAnchor?l:(0,b.jsx)(f.ee,{asChild:!0,...a,children:l})});E.displayName=T;var D="PopoverPortal",[M,A]=j(D,{forceMount:void 0}),F=e=>{let{__scopePopover:t,forceMount:n,children:r,container:o}=e,i=P(D,t);return(0,b.jsx)(M,{scope:t,forceMount:n,children:(0,b.jsx)(d.z,{present:n||i.open,children:(0,b.jsx)(p.h,{asChild:!0,container:o,children:r})})})};F.displayName=D;var _="PopoverContent",N=r.forwardRef((e,t)=>{let n=A(_,e.__scopePopover),{forceMount:r=n.forceMount,...o}=e,i=P(_,e.__scopePopover);return(0,b.jsx)(d.z,{present:r||i.open,children:i.modal?(0,b.jsx)(S,{...o,ref:t}):(0,b.jsx)(W,{...o,ref:t})})});N.displayName=_;var Z=(0,h.Z8)("PopoverContent.RemoveScroll"),S=r.forwardRef((e,t)=>{let n=P(_,e.__scopePopover),u=r.useRef(null),a=(0,i.e)(t,u),c=r.useRef(!1);return r.useEffect(()=>{let e=u.current;if(e)return(0,x.Ry)(e)},[]),(0,b.jsx)(y.Z,{as:Z,allowPinchZoom:!0,children:(0,b.jsx)(I,{...e,ref:a,trapFocus:n.open,disableOutsidePointerEvents:!0,onCloseAutoFocus:(0,o.M)(e.onCloseAutoFocus,e=>{var t;e.preventDefault(),c.current||null===(t=n.triggerRef.current)||void 0===t||t.focus()}),onPointerDownOutside:(0,o.M)(e.onPointerDownOutside,e=>{let t=e.detail.originalEvent,n=0===t.button&&!0===t.ctrlKey,r=2===t.button||n;c.current=r},{checkForDefaultPrevented:!1}),onFocusOutside:(0,o.M)(e.onFocusOutside,e=>e.preventDefault(),{checkForDefaultPrevented:!1})})})}),W=r.forwardRef((e,t)=>{let n=P(_,e.__scopePopover),o=r.useRef(!1),i=r.useRef(!1);return(0,b.jsx)(I,{...e,ref:t,trapFocus:!1,disableOutsidePointerEvents:!1,onCloseAutoFocus:t=>{var r,u;null===(r=e.onCloseAutoFocus)||void 0===r||r.call(e,t),t.defaultPrevented||(o.current||null===(u=n.triggerRef.current)||void 0===u||u.focus(),t.preventDefault()),o.current=!1,i.current=!1},onInteractOutside:t=>{var r,u;null===(r=e.onInteractOutside)||void 0===r||r.call(e,t),t.defaultPrevented||(o.current=!0,"pointerdown"!==t.detail.originalEvent.type||(i.current=!0));let a=t.target;(null===(u=n.triggerRef.current)||void 0===u?void 0:u.contains(a))&&t.preventDefault(),"focusin"===t.detail.originalEvent.type&&i.current&&t.preventDefault()}})}),I=r.forwardRef((e,t)=>{let{__scopePopover:n,trapFocus:r,onOpenAutoFocus:o,onCloseAutoFocus:i,disableOutsidePointerEvents:u,onEscapeKeyDown:s,onPointerDownOutside:p,onFocusOutside:d,onInteractOutside:v,...h}=e,g=P(_,n),x=w(n);return(0,c.EW)(),(0,b.jsx)(l.M,{asChild:!0,loop:!0,trapped:r,onMountAutoFocus:o,onUnmountAutoFocus:i,children:(0,b.jsx)(a.XB,{asChild:!0,disableOutsidePointerEvents:u,onInteractOutside:v,onEscapeKeyDown:s,onPointerDownOutside:p,onFocusOutside:d,onDismiss:()=>g.onOpenChange(!1),children:(0,b.jsx)(f.VY,{"data-state":z(g.open),role:"dialog",id:g.contentId,...x,...h,ref:t,style:{...h.style,"--radix-popover-content-transform-origin":"var(--radix-popper-transform-origin)","--radix-popover-content-available-width":"var(--radix-popper-available-width)","--radix-popover-content-available-height":"var(--radix-popper-available-height)","--radix-popover-trigger-width":"var(--radix-popper-anchor-width)","--radix-popover-trigger-height":"var(--radix-popper-anchor-height)"}})})})}),V="PopoverClose";function z(e){return e?"open":"closed"}r.forwardRef((e,t)=>{let{__scopePopover:n,...r}=e,i=P(V,n);return(0,b.jsx)(v.WV.button,{type:"button",...r,ref:t,onClick:(0,o.M)(e.onClick,()=>i.onOpenChange(!1))})}).displayName=V,r.forwardRef((e,t)=>{let{__scopePopover:n,...r}=e,o=w(n);return(0,b.jsx)(f.Eh,{...o,...r,ref:t})}).displayName="PopoverArrow";var U=k,$=E,L=F,X=N},95098:function(e,t,n){"use strict";n.d(t,{C2:function(){return u},TX:function(){return a},fC:function(){return c}});var r=n(2265),o=n(66840),i=n(57437),u=Object.freeze({position:"absolute",border:0,width:1,height:1,padding:0,margin:-1,overflow:"hidden",clip:"rect(0, 0, 0, 0)",whiteSpace:"nowrap",wordWrap:"normal"}),a=r.forwardRef((e,t)=>(0,i.jsx)(o.WV.span,{...e,ref:t,style:{...u,...e.style}}));a.displayName="VisuallyHidden";var c=a},44372:function(e,t,n){"use strict";n.d(t,{b:function(){return u}});var r=n(99649),o=n(63497),i=n(78198);function u(e,t){return function(e,t){let n=+(0,r.Q)(e);return(0,o.L)(e,n+t)}(e,-t*i.vh)}}}]);
2
- //# sourceMappingURL=3998-c1c5bec61ce07357.js.map