n9router 0.3.88 → 0.3.89

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 (257) hide show
  1. package/.next/standalone/.next/BUILD_ID +1 -1
  2. package/.next/standalone/.next/build-manifest.json +3 -3
  3. package/.next/standalone/.next/server/app/(dashboard)/dashboard/basic-chat/page_client-reference-manifest.js +1 -1
  4. package/.next/standalone/.next/server/app/(dashboard)/dashboard/cli-tools/page_client-reference-manifest.js +1 -1
  5. package/.next/standalone/.next/server/app/(dashboard)/dashboard/combos/page_client-reference-manifest.js +1 -1
  6. package/.next/standalone/.next/server/app/(dashboard)/dashboard/console-log/page_client-reference-manifest.js +1 -1
  7. package/.next/standalone/.next/server/app/(dashboard)/dashboard/endpoint/page_client-reference-manifest.js +1 -1
  8. package/.next/standalone/.next/server/app/(dashboard)/dashboard/mitm/page_client-reference-manifest.js +1 -1
  9. package/.next/standalone/.next/server/app/(dashboard)/dashboard/page_client-reference-manifest.js +1 -1
  10. package/.next/standalone/.next/server/app/(dashboard)/dashboard/profile/page_client-reference-manifest.js +1 -1
  11. package/.next/standalone/.next/server/app/(dashboard)/dashboard/providers/[id]/page_client-reference-manifest.js +1 -1
  12. package/.next/standalone/.next/server/app/(dashboard)/dashboard/providers/new/page_client-reference-manifest.js +1 -1
  13. package/.next/standalone/.next/server/app/(dashboard)/dashboard/providers/page_client-reference-manifest.js +1 -1
  14. package/.next/standalone/.next/server/app/(dashboard)/dashboard/proxy-pools/page_client-reference-manifest.js +1 -1
  15. package/.next/standalone/.next/server/app/(dashboard)/dashboard/quota/page_client-reference-manifest.js +1 -1
  16. package/.next/standalone/.next/server/app/(dashboard)/dashboard/translator/page_client-reference-manifest.js +1 -1
  17. package/.next/standalone/.next/server/app/(dashboard)/dashboard/usage/page_client-reference-manifest.js +1 -1
  18. package/.next/standalone/.next/server/app/_global-error.html +1 -1
  19. package/.next/standalone/.next/server/app/_global-error.rsc +1 -1
  20. package/.next/standalone/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  21. package/.next/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  22. package/.next/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  23. package/.next/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  24. package/.next/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  25. package/.next/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  26. package/.next/standalone/.next/server/app/_not-found.html +1 -1
  27. package/.next/standalone/.next/server/app/_not-found.rsc +10 -10
  28. package/.next/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +10 -10
  29. package/.next/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +4 -4
  30. package/.next/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +5 -5
  31. package/.next/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +2 -2
  32. package/.next/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +3 -3
  33. package/.next/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  34. package/.next/standalone/.next/server/app/api/oauth/[provider]/[action]/route.js.nft.json +1 -1
  35. package/.next/standalone/.next/server/app/api/translator/send/route.js.nft.json +1 -1
  36. package/.next/standalone/.next/server/app/api/translator/translate/route.js.nft.json +1 -1
  37. package/.next/standalone/.next/server/app/api/usage/[connectionId]/route.js.nft.json +1 -1
  38. package/.next/standalone/.next/server/app/api/usage/chart/route.js.nft.json +1 -1
  39. package/.next/standalone/.next/server/app/api/usage/history/route.js.nft.json +1 -1
  40. package/.next/standalone/.next/server/app/api/usage/logs/route.js.nft.json +1 -1
  41. package/.next/standalone/.next/server/app/api/usage/request-details/route.js.nft.json +1 -1
  42. package/.next/standalone/.next/server/app/api/usage/request-logs/route.js.nft.json +1 -1
  43. package/.next/standalone/.next/server/app/api/usage/stats/route.js.nft.json +1 -1
  44. package/.next/standalone/.next/server/app/api/usage/stream/route.js.nft.json +1 -1
  45. package/.next/standalone/.next/server/app/api/v1/api/chat/route.js.nft.json +1 -1
  46. package/.next/standalone/.next/server/app/api/v1/chat/completions/route.js.nft.json +1 -1
  47. package/.next/standalone/.next/server/app/api/v1/embeddings/route.js.nft.json +1 -1
  48. package/.next/standalone/.next/server/app/api/v1/messages/route.js.nft.json +1 -1
  49. package/.next/standalone/.next/server/app/api/v1/responses/route.js.nft.json +1 -1
  50. package/.next/standalone/.next/server/app/api/v1beta/models/[...path]/route.js.nft.json +1 -1
  51. package/.next/standalone/.next/server/app/callback/page_client-reference-manifest.js +1 -1
  52. package/.next/standalone/.next/server/app/callback.html +1 -1
  53. package/.next/standalone/.next/server/app/callback.rsc +12 -12
  54. package/.next/standalone/.next/server/app/callback.segments/_full.segment.rsc +12 -12
  55. package/.next/standalone/.next/server/app/callback.segments/_head.segment.rsc +4 -4
  56. package/.next/standalone/.next/server/app/callback.segments/_index.segment.rsc +5 -5
  57. package/.next/standalone/.next/server/app/callback.segments/_tree.segment.rsc +1 -1
  58. package/.next/standalone/.next/server/app/callback.segments/callback/__PAGE__.segment.rsc +4 -4
  59. package/.next/standalone/.next/server/app/callback.segments/callback.segment.rsc +3 -3
  60. package/.next/standalone/.next/server/app/dashboard/basic-chat.html +1 -1
  61. package/.next/standalone/.next/server/app/dashboard/basic-chat.rsc +12 -12
  62. package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard/basic-chat/__PAGE__.segment.rsc +3 -3
  63. package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard/basic-chat.segment.rsc +3 -3
  64. package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  65. package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  66. package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/_full.segment.rsc +12 -12
  67. package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/_head.segment.rsc +4 -4
  68. package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/_index.segment.rsc +5 -5
  69. package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/_tree.segment.rsc +1 -1
  70. package/.next/standalone/.next/server/app/dashboard/cli-tools.html +1 -1
  71. package/.next/standalone/.next/server/app/dashboard/cli-tools.rsc +12 -12
  72. package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard/cli-tools/__PAGE__.segment.rsc +3 -3
  73. package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard/cli-tools.segment.rsc +3 -3
  74. package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  75. package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  76. package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/_full.segment.rsc +12 -12
  77. package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/_head.segment.rsc +4 -4
  78. package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/_index.segment.rsc +5 -5
  79. package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/_tree.segment.rsc +1 -1
  80. package/.next/standalone/.next/server/app/dashboard/combos.html +1 -1
  81. package/.next/standalone/.next/server/app/dashboard/combos.rsc +13 -13
  82. package/.next/standalone/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard/combos/__PAGE__.segment.rsc +4 -4
  83. package/.next/standalone/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard/combos.segment.rsc +3 -3
  84. package/.next/standalone/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  85. package/.next/standalone/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  86. package/.next/standalone/.next/server/app/dashboard/combos.segments/_full.segment.rsc +13 -13
  87. package/.next/standalone/.next/server/app/dashboard/combos.segments/_head.segment.rsc +4 -4
  88. package/.next/standalone/.next/server/app/dashboard/combos.segments/_index.segment.rsc +5 -5
  89. package/.next/standalone/.next/server/app/dashboard/combos.segments/_tree.segment.rsc +1 -1
  90. package/.next/standalone/.next/server/app/dashboard/endpoint.html +1 -1
  91. package/.next/standalone/.next/server/app/dashboard/endpoint.rsc +12 -12
  92. package/.next/standalone/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard/endpoint/__PAGE__.segment.rsc +3 -3
  93. package/.next/standalone/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard/endpoint.segment.rsc +3 -3
  94. package/.next/standalone/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  95. package/.next/standalone/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  96. package/.next/standalone/.next/server/app/dashboard/endpoint.segments/_full.segment.rsc +12 -12
  97. package/.next/standalone/.next/server/app/dashboard/endpoint.segments/_head.segment.rsc +4 -4
  98. package/.next/standalone/.next/server/app/dashboard/endpoint.segments/_index.segment.rsc +5 -5
  99. package/.next/standalone/.next/server/app/dashboard/endpoint.segments/_tree.segment.rsc +1 -1
  100. package/.next/standalone/.next/server/app/dashboard/mitm.html +1 -1
  101. package/.next/standalone/.next/server/app/dashboard/mitm.rsc +12 -12
  102. package/.next/standalone/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard/mitm/__PAGE__.segment.rsc +3 -3
  103. package/.next/standalone/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard/mitm.segment.rsc +3 -3
  104. package/.next/standalone/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  105. package/.next/standalone/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  106. package/.next/standalone/.next/server/app/dashboard/mitm.segments/_full.segment.rsc +12 -12
  107. package/.next/standalone/.next/server/app/dashboard/mitm.segments/_head.segment.rsc +4 -4
  108. package/.next/standalone/.next/server/app/dashboard/mitm.segments/_index.segment.rsc +5 -5
  109. package/.next/standalone/.next/server/app/dashboard/mitm.segments/_tree.segment.rsc +1 -1
  110. package/.next/standalone/.next/server/app/dashboard/profile.html +1 -1
  111. package/.next/standalone/.next/server/app/dashboard/profile.rsc +13 -13
  112. package/.next/standalone/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard/profile/__PAGE__.segment.rsc +4 -4
  113. package/.next/standalone/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard/profile.segment.rsc +3 -3
  114. package/.next/standalone/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  115. package/.next/standalone/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  116. package/.next/standalone/.next/server/app/dashboard/profile.segments/_full.segment.rsc +13 -13
  117. package/.next/standalone/.next/server/app/dashboard/profile.segments/_head.segment.rsc +4 -4
  118. package/.next/standalone/.next/server/app/dashboard/profile.segments/_index.segment.rsc +5 -5
  119. package/.next/standalone/.next/server/app/dashboard/profile.segments/_tree.segment.rsc +1 -1
  120. package/.next/standalone/.next/server/app/dashboard/providers/new.html +1 -1
  121. package/.next/standalone/.next/server/app/dashboard/providers/new.rsc +13 -13
  122. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers/new/__PAGE__.segment.rsc +4 -4
  123. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers/new.segment.rsc +3 -3
  124. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers.segment.rsc +3 -3
  125. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  126. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  127. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/_full.segment.rsc +13 -13
  128. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/_head.segment.rsc +4 -4
  129. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/_index.segment.rsc +5 -5
  130. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/_tree.segment.rsc +1 -1
  131. package/.next/standalone/.next/server/app/dashboard/providers.html +1 -1
  132. package/.next/standalone/.next/server/app/dashboard/providers.rsc +13 -13
  133. package/.next/standalone/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard/providers/__PAGE__.segment.rsc +4 -4
  134. package/.next/standalone/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard/providers.segment.rsc +3 -3
  135. package/.next/standalone/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  136. package/.next/standalone/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  137. package/.next/standalone/.next/server/app/dashboard/providers.segments/_full.segment.rsc +13 -13
  138. package/.next/standalone/.next/server/app/dashboard/providers.segments/_head.segment.rsc +4 -4
  139. package/.next/standalone/.next/server/app/dashboard/providers.segments/_index.segment.rsc +5 -5
  140. package/.next/standalone/.next/server/app/dashboard/providers.segments/_tree.segment.rsc +1 -1
  141. package/.next/standalone/.next/server/app/dashboard/proxy-pools.html +1 -1
  142. package/.next/standalone/.next/server/app/dashboard/proxy-pools.rsc +13 -13
  143. package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard/proxy-pools/__PAGE__.segment.rsc +4 -4
  144. package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard/proxy-pools.segment.rsc +3 -3
  145. package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  146. package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  147. package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/_full.segment.rsc +13 -13
  148. package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/_head.segment.rsc +4 -4
  149. package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/_index.segment.rsc +5 -5
  150. package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/_tree.segment.rsc +1 -1
  151. package/.next/standalone/.next/server/app/dashboard/quota.html +2 -2
  152. package/.next/standalone/.next/server/app/dashboard/quota.rsc +13 -13
  153. package/.next/standalone/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard/quota/__PAGE__.segment.rsc +4 -4
  154. package/.next/standalone/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard/quota.segment.rsc +3 -3
  155. package/.next/standalone/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  156. package/.next/standalone/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  157. package/.next/standalone/.next/server/app/dashboard/quota.segments/_full.segment.rsc +13 -13
  158. package/.next/standalone/.next/server/app/dashboard/quota.segments/_head.segment.rsc +4 -4
  159. package/.next/standalone/.next/server/app/dashboard/quota.segments/_index.segment.rsc +5 -5
  160. package/.next/standalone/.next/server/app/dashboard/quota.segments/_tree.segment.rsc +1 -1
  161. package/.next/standalone/.next/server/app/dashboard/settings/pricing/page_client-reference-manifest.js +1 -1
  162. package/.next/standalone/.next/server/app/dashboard/settings/pricing.html +1 -1
  163. package/.next/standalone/.next/server/app/dashboard/settings/pricing.rsc +12 -12
  164. package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/_full.segment.rsc +12 -12
  165. package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/_head.segment.rsc +4 -4
  166. package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/_index.segment.rsc +5 -5
  167. package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/_tree.segment.rsc +1 -1
  168. package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing/__PAGE__.segment.rsc +4 -4
  169. package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing.segment.rsc +3 -3
  170. package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings.segment.rsc +3 -3
  171. package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/dashboard.segment.rsc +3 -3
  172. package/.next/standalone/.next/server/app/dashboard/translator.html +1 -1
  173. package/.next/standalone/.next/server/app/dashboard/translator.rsc +13 -13
  174. package/.next/standalone/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard/translator/__PAGE__.segment.rsc +4 -4
  175. package/.next/standalone/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard/translator.segment.rsc +3 -3
  176. package/.next/standalone/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  177. package/.next/standalone/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  178. package/.next/standalone/.next/server/app/dashboard/translator.segments/_full.segment.rsc +13 -13
  179. package/.next/standalone/.next/server/app/dashboard/translator.segments/_head.segment.rsc +4 -4
  180. package/.next/standalone/.next/server/app/dashboard/translator.segments/_index.segment.rsc +5 -5
  181. package/.next/standalone/.next/server/app/dashboard/translator.segments/_tree.segment.rsc +1 -1
  182. package/.next/standalone/.next/server/app/dashboard/usage.html +1 -1
  183. package/.next/standalone/.next/server/app/dashboard/usage.rsc +13 -13
  184. package/.next/standalone/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard/usage/__PAGE__.segment.rsc +4 -4
  185. package/.next/standalone/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard/usage.segment.rsc +3 -3
  186. package/.next/standalone/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  187. package/.next/standalone/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  188. package/.next/standalone/.next/server/app/dashboard/usage.segments/_full.segment.rsc +13 -13
  189. package/.next/standalone/.next/server/app/dashboard/usage.segments/_head.segment.rsc +4 -4
  190. package/.next/standalone/.next/server/app/dashboard/usage.segments/_index.segment.rsc +5 -5
  191. package/.next/standalone/.next/server/app/dashboard/usage.segments/_tree.segment.rsc +1 -1
  192. package/.next/standalone/.next/server/app/dashboard.html +1 -1
  193. package/.next/standalone/.next/server/app/dashboard.rsc +12 -12
  194. package/.next/standalone/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk/dashboard/__PAGE__.segment.rsc +3 -3
  195. package/.next/standalone/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  196. package/.next/standalone/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  197. package/.next/standalone/.next/server/app/dashboard.segments/_full.segment.rsc +12 -12
  198. package/.next/standalone/.next/server/app/dashboard.segments/_head.segment.rsc +4 -4
  199. package/.next/standalone/.next/server/app/dashboard.segments/_index.segment.rsc +5 -5
  200. package/.next/standalone/.next/server/app/dashboard.segments/_tree.segment.rsc +1 -1
  201. package/.next/standalone/.next/server/app/index.html +1 -1
  202. package/.next/standalone/.next/server/app/index.rsc +10 -10
  203. package/.next/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  204. package/.next/standalone/.next/server/app/index.segments/_full.segment.rsc +10 -10
  205. package/.next/standalone/.next/server/app/index.segments/_head.segment.rsc +4 -4
  206. package/.next/standalone/.next/server/app/index.segments/_index.segment.rsc +5 -5
  207. package/.next/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  208. package/.next/standalone/.next/server/app/landing/page_client-reference-manifest.js +1 -1
  209. package/.next/standalone/.next/server/app/landing.html +1 -1
  210. package/.next/standalone/.next/server/app/landing.rsc +12 -12
  211. package/.next/standalone/.next/server/app/landing.segments/_full.segment.rsc +12 -12
  212. package/.next/standalone/.next/server/app/landing.segments/_head.segment.rsc +4 -4
  213. package/.next/standalone/.next/server/app/landing.segments/_index.segment.rsc +5 -5
  214. package/.next/standalone/.next/server/app/landing.segments/_tree.segment.rsc +1 -1
  215. package/.next/standalone/.next/server/app/landing.segments/landing/__PAGE__.segment.rsc +4 -4
  216. package/.next/standalone/.next/server/app/landing.segments/landing.segment.rsc +3 -3
  217. package/.next/standalone/.next/server/app/login/page_client-reference-manifest.js +1 -1
  218. package/.next/standalone/.next/server/app/login.html +1 -1
  219. package/.next/standalone/.next/server/app/login.rsc +12 -12
  220. package/.next/standalone/.next/server/app/login.segments/_full.segment.rsc +12 -12
  221. package/.next/standalone/.next/server/app/login.segments/_head.segment.rsc +4 -4
  222. package/.next/standalone/.next/server/app/login.segments/_index.segment.rsc +5 -5
  223. package/.next/standalone/.next/server/app/login.segments/_tree.segment.rsc +1 -1
  224. package/.next/standalone/.next/server/app/login.segments/login/__PAGE__.segment.rsc +4 -4
  225. package/.next/standalone/.next/server/app/login.segments/login.segment.rsc +3 -3
  226. package/.next/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
  227. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0.yvcis._.js +1 -1
  228. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0148t9m._.js +1 -1
  229. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0b802lh._.js +1 -1
  230. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0kpc-o6._.js +1 -1
  231. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0lc~.sk._.js +1 -1
  232. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0lp_pm5._.js +1 -1
  233. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0pwrfp1._.js +1 -1
  234. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0uw3x8s._.js +1 -1
  235. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0y.reft._.js +1 -1
  236. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0y5ae.7._.js +1 -1
  237. package/.next/standalone/.next/server/chunks/ssr/src_0_xhepz._.js +1 -1
  238. package/.next/standalone/.next/server/chunks/ssr/src_app_(dashboard)_dashboard_providers_[id]_page_0-3xvzc.js +1 -1
  239. package/.next/standalone/.next/server/middleware-build-manifest.js +3 -3
  240. package/.next/standalone/.next/server/pages/404.html +1 -1
  241. package/.next/standalone/.next/server/pages/500.html +1 -1
  242. package/.next/standalone/.next/static/chunks/0b285gqd-hcvu.js +1 -0
  243. package/.next/standalone/.next/static/chunks/{0epj7i9.s2-m2.js → 0hgyabetclndg.js} +1 -1
  244. package/.next/standalone/package-lock.json +2 -2
  245. package/.next/standalone/package.json +1 -1
  246. package/.next/standalone/src/app/(dashboard)/dashboard/providers/[id]/page.js +2 -1
  247. package/.next/static/chunks/0b285gqd-hcvu.js +1 -0
  248. package/.next/static/chunks/{0epj7i9.s2-m2.js → 0hgyabetclndg.js} +1 -1
  249. package/package.json +1 -1
  250. package/.next/standalone/.next/static/chunks/09g0cm09ynuao.js +0 -1
  251. package/.next/static/chunks/09g0cm09ynuao.js +0 -1
  252. /package/.next/standalone/.next/static/{Fr7ipSei0ydO_aZHViw9O → XSoZ0BJFg1b0W2IGyybf7}/_buildManifest.js +0 -0
  253. /package/.next/standalone/.next/static/{Fr7ipSei0ydO_aZHViw9O → XSoZ0BJFg1b0W2IGyybf7}/_clientMiddlewareManifest.js +0 -0
  254. /package/.next/standalone/.next/static/{Fr7ipSei0ydO_aZHViw9O → XSoZ0BJFg1b0W2IGyybf7}/_ssgManifest.js +0 -0
  255. /package/.next/static/{Fr7ipSei0ydO_aZHViw9O → XSoZ0BJFg1b0W2IGyybf7}/_buildManifest.js +0 -0
  256. /package/.next/static/{Fr7ipSei0ydO_aZHViw9O → XSoZ0BJFg1b0W2IGyybf7}/_clientMiddlewareManifest.js +0 -0
  257. /package/.next/static/{Fr7ipSei0ydO_aZHViw9O → XSoZ0BJFg1b0W2IGyybf7}/_ssgManifest.js +0 -0
@@ -1,4 +1,4 @@
1
- module.exports=[46786,(e,t,o)=>{t.exports=e.x("os",()=>require("os"))},18622,(e,t,o)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,o)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,o)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},70406,(e,t,o)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,o)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},27699,(e,t,o)=>{t.exports=e.x("events",()=>require("events"))},88077,e=>{"use strict";let t={kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gc",name:"Gemini CLI",icon:"terminal",color:"#4285F4",deprecated:!0,deprecationNotice:"Google has tightened Gemini CLI abuse detection and restricted Pro models to paid accounts (Mar 25, 2026). Using this provider may violate ToS and risk account bans."},iflow:{id:"iflow",alias:"if",name:"iFlow AI",icon:"water_drop",color:"#6366F1"}},o={openrouter:{id:"openrouter",alias:"openrouter",name:"OpenRouter",icon:"router",color:"#F97316",textIcon:"OR",passthroughModels:!0,website:"https://openrouter.ai",notice:{text:"Free tier: 27+ free models, no credit card needed, 200 req/day. After $10 credit: 1,000 req/day.",apiKeyUrl:"https://openrouter.ai/settings/keys"},modelsFetcher:{url:"https://openrouter.ai/api/v1/models",type:"openrouter-free"}},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://developer.nvidia.com/nim",notice:{text:"Free access for NVIDIA Developer Program members (prototyping & testing).",apiKeyUrl:"https://build.nvidia.com/settings/api-keys"}},ollama:{id:"ollama",alias:"ollama",name:"Ollama Cloud",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com",notice:{text:"Free tier: light usage, 1 cloud model at a time (limits reset every 5h & 7d). Pro $20/mo · Max $100/mo.",apiKeyUrl:"https://ollama.com/settings/keys"}},vertex:{id:"vertex",alias:"vx",name:"Vertex AI",icon:"cloud",color:"#4285F4",textIcon:"VX",website:"https://cloud.google.com/vertex-ai",notice:{text:"New Google Cloud accounts get $300 free credits. Requires GCP project + Service Account with Vertex AI API enabled.",apiKeyUrl:"https://console.cloud.google.com/iam-admin/serviceaccounts"}}},i={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:"ag",name:"Antigravity",icon:"rocket_launch",color:"#F59E0B",deprecated:!0,deprecationNotice:"Antigravity has tightened abuse detection and restricted model access. Using this provider may violate ToS and risk account bans."},codex:{id:"codex",alias:"cx",name:"OpenAI Codex",icon:"code",color:"#3B82F6"},github:{id:"github",alias:"gh",name:"GitHub Copilot",icon:"code",color:"#333333"},cursor:{id:"cursor",alias:"cu",name:"Cursor IDE",icon:"edit_note",color:"#00D4AA"},kilocode:{id:"kilocode",alias:"kc",name:"Kilo Code",icon:"code",color:"#FF6B35",textIcon:"KC"},cline:{id:"cline",alias:"cl",name:"Cline",icon:"smart_toy",color:"#5B9BD5",textIcon:"CL"}},a={glm:{id:"glm",alias:"glm",name:"GLM Coding",icon:"code",color:"#2563EB",textIcon:"GL",website:"https://open.bigmodel.cn"},"glm-cn":{id:"glm-cn",alias:"glm-cn",name:"GLM (China)",icon:"code",color:"#DC2626",textIcon:"GC",website:"https://open.bigmodel.cn"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},minimax:{id:"minimax",alias:"minimax",name:"Minimax Coding",icon:"memory",color:"#7C3AED",textIcon:"MM",website:"https://www.minimaxi.com"},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",name:"Minimax (China)",icon:"memory",color:"#DC2626",textIcon:"MC",website:"https://www.minimaxi.com"},alicode:{id:"alicode",alias:"alicode",name:"Alibaba",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},"alicode-intl":{id:"alicode-intl",alias:"alicode-intl",name:"Alibaba Intl",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},openai:{id:"openai",alias:"openai",name:"OpenAI",icon:"auto_awesome",color:"#10A37F",textIcon:"OA",website:"https://platform.openai.com"},anthropic:{id:"anthropic",alias:"anthropic",name:"Anthropic",icon:"smart_toy",color:"#D97757",textIcon:"AN",website:"https://console.anthropic.com"},gemini:{id:"gemini",alias:"gemini",name:"Gemini",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev"},deepseek:{id:"deepseek",alias:"ds",name:"DeepSeek",icon:"bolt",color:"#4D6BFE",textIcon:"DS",website:"https://deepseek.com"},groq:{id:"groq",alias:"groq",name:"Groq",icon:"speed",color:"#F55036",textIcon:"GQ",website:"https://groq.com"},xai:{id:"xai",alias:"xai",name:"xAI (Grok)",icon:"auto_awesome",color:"#1DA1F2",textIcon:"XA",website:"https://x.ai"},mistral:{id:"mistral",alias:"mistral",name:"Mistral",icon:"air",color:"#FF7000",textIcon:"MI",website:"https://mistral.ai"},perplexity:{id:"perplexity",alias:"pplx",name:"Perplexity",icon:"search",color:"#20808D",textIcon:"PP",website:"https://www.perplexity.ai"},together:{id:"together",alias:"together",name:"Together AI",icon:"group_work",color:"#0F6FFF",textIcon:"TG",website:"https://www.together.ai"},fireworks:{id:"fireworks",alias:"fireworks",name:"Fireworks AI",icon:"local_fire_department",color:"#7B2EF2",textIcon:"FW",website:"https://fireworks.ai"},cerebras:{id:"cerebras",alias:"cerebras",name:"Cerebras",icon:"memory",color:"#FF4F00",textIcon:"CB",website:"https://www.cerebras.ai"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nebius:{id:"nebius",alias:"nebius",name:"Nebius AI",icon:"cloud",color:"#6C5CE7",textIcon:"NB",website:"https://nebius.com"},siliconflow:{id:"siliconflow",alias:"siliconflow",name:"SiliconFlow",icon:"cloud_queue",color:"#5B6EF5",textIcon:"SF",website:"https://cloud.siliconflow.com"},hyperbolic:{id:"hyperbolic",alias:"hyp",name:"Hyperbolic",icon:"bolt",color:"#00D4FF",textIcon:"HY",website:"https://hyperbolic.xyz"},deepgram:{id:"deepgram",alias:"dg",name:"Deepgram",icon:"mic",color:"#13EF93",textIcon:"DG",website:"https://deepgram.com"},assemblyai:{id:"assemblyai",alias:"aai",name:"AssemblyAI",icon:"record_voice_over",color:"#0062FF",textIcon:"AA",website:"https://assemblyai.com"},nanobanana:{id:"nanobanana",alias:"nb",name:"NanoBanana",icon:"image",color:"#FFD700",textIcon:"NB",website:"https://nanobananaapi.ai"},chutes:{id:"chutes",alias:"ch",name:"Chutes AI",icon:"water_drop",color:"#ffffffff",textIcon:"CH",website:"https://chutes.ai"},"ollama-local":{id:"ollama-local",alias:"ollama-local",name:"Ollama Local",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com"},"vertex-partner":{id:"vertex-partner",alias:"vxp",name:"Vertex Partner",icon:"cloud",color:"#34A853",textIcon:"VP",website:"https://cloud.google.com/vertex-ai/generative-ai/docs/partner-models/use-partner-models"}},n="openai-compatible-",r="anthropic-compatible-",s={...t,...o,...i,...a};function l(e){for(let t of Object.values(s))if(t.alias===e||t.id===e)return t;return null}Object.values(s).reduce((e,t)=>(e[t.alias]=t.id,e),{}),Object.values(s).reduce((e,t)=>(e[t.id]=t.alias,e),{}),e.s(["AI_PROVIDERS",0,s,"ANTHROPIC_COMPATIBLE_PREFIX",0,r,"APIKEY_PROVIDERS",0,a,"FREE_PROVIDERS",0,t,"FREE_TIER_PROVIDERS",0,o,"OAUTH_PROVIDERS",0,i,"OPENAI_COMPATIBLE_PREFIX",0,n,"getProviderAlias",0,function(e){let t=s[e];return t?.alias||e},"getProviderByAlias",0,l,"isAnthropicCompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(r)},"isOpenAICompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(n)},"resolveProviderId",0,function(e){let t=l(e);return t?.id||e}])},12943,e=>{"use strict";e.s(["default",0,{name:"n9router",version:"0.3.88",description:"Self-hosted AI routing gateway — local proxy for Claude, Gemini, OpenAI and 40+ providers",keywords:["ai","llm","proxy","router","claude","openai","gemini","cursor"],homepage:"https://github.com/nightwalker89/n9router",repository:{type:"git",url:"https://github.com/nightwalker89/n9router.git"},config:{appName:"n9router"},license:"MIT",bin:{n9router:"./bin/n9router.js"},files:["bin/",".next/standalone/",".next/static/","public/"],scripts:{dev:"next dev --webpack --port 20128",build:"cross-env NODE_ENV=production next build",start:"cross-env NODE_ENV=production next start","dev:bun":"bun --bun next dev --webpack --port 20128","build:bun":"NODE_ENV=production bun --bun next build --webpack","start:bun":"NODE_ENV=production bun ./.next/standalone/server.js","publish:npm":"./scripts/publish-npm.sh","publish:npm:dry":"./scripts/publish-npm.sh --dry-run"},dependencies:{"@monaco-editor/react":"^4.7.0","@xyflow/react":"^12.10.1",bcryptjs:"^3.0.3",confbox:"^0.2.4",express:"^5.2.1",fs:"^0.0.1-security","http-proxy-middleware":"^3.0.5",jose:"^6.1.3",lowdb:"^7.0.1","monaco-editor":"^0.55.1",next:"^16.1.6","node-forge":"^1.3.3","node-machine-id":"^1.1.12",open:"^11.0.0",ora:"^9.1.0","proper-lockfile":"^4.1.2",react:"19.2.4","react-dom":"19.2.4","react-is":"^16.13.1",recharts:"^3.7.0",selfsigned:"^5.5.0","socks-proxy-agent":"^8.0.5","sql.js":"^1.14.1",undici:"^7.19.2",uuid:"^13.0.0",zustand:"^5.0.10"},optionalDependencies:{"better-sqlite3":"^12.6.2"},devDependencies:{"@tailwindcss/postcss":"^4.1.18","cross-env":"^10.1.0",eslint:"^9","eslint-config-next":"16.1.6",postcss:"^8.5.6",tailwindcss:"^4"}}])},53526,e=>{"use strict";var t=e.i(20491);Object.entries(e.i(88077).AI_PROVIDERS).filter(([,e])=>e.passthroughModels).map(([e])=>e);let o=Object.entries(t.PROVIDER_MODELS).flatMap(([e,t])=>t.map(t=>({provider:e,model:t.id,name:t.name})));e.s(["AI_MODELS",0,o])},55870,e=>{"use strict";var t=e.i(12943);e.i(88077),e.i(53526),t.default.version,e.s(["CONSOLE_LOG_CONFIG",0,{maxLines:200,pollIntervalMs:1e3}])},39838,e=>{"use strict";var t=e.i(27699),o=e.i(55870);let i=["log","info","warn","error","debug"];e.g._consoleLogBufferState||(e.g._consoleLogBufferState={logs:[],patched:!1,originals:{},emitter:new t.EventEmitter},e.g._consoleLogBufferState.emitter.setMaxListeners(50));let a=e.g._consoleLogBufferState;a.emitter||(a.emitter=new t.EventEmitter,a.emitter.setMaxListeners(50));let n=/\x1b\[[0-9;]*m/g;function r(e){return e.replace(n,"")}function s(e){if("string"==typeof e)return r(e);if(e instanceof Error)return r(e.stack||e.message||String(e));try{return r(JSON.stringify(e))}catch{return r(String(e))}}e.s(["clearConsoleLogs",0,function(){a.logs=[],a.emitter.emit("clear")},"getConsoleEmitter",0,function(){return a.emitter},"getConsoleLogs",0,function(){return a.logs},"initConsoleLogCapture",0,function(){if(!a.patched){for(let e of i)a.originals[e]=console[e],console[e]=(...t)=>{!function(e){a.logs.push(e);let t=o.CONSOLE_LOG_CONFIG.maxLines;a.logs.length>t&&(a.logs=a.logs.slice(-t)),a.emitter.emit("line",e)}(t.map(s).join(" ")),a.originals[e](...t)};a.patched=!0}}])},99280,e=>{"use strict";var t=e.i(47909),o=e.i(74017),i=e.i(96250),a=e.i(59756),n=e.i(61916),r=e.i(74677),s=e.i(69741),l=e.i(16795),c=e.i(87718),d=e.i(95169),p=e.i(47587),u=e.i(66012),m=e.i(70101),h=e.i(26937),g=e.i(10372),x=e.i(93695);e.i(20232);var f=e.i(220),b=e.i(39838);async function v(){let e=new TextEncoder,t=(0,b.getConsoleEmitter)(),o={closed:!1,send:null,keepalive:null};return new Response(new ReadableStream({start(i){let a=(0,b.getConsoleLogs)();a.length>0&&i.enqueue(e.encode(`data: ${JSON.stringify({type:"init",logs:a})}
1
+ module.exports=[46786,(e,t,o)=>{t.exports=e.x("os",()=>require("os"))},18622,(e,t,o)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,o)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,o)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},70406,(e,t,o)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,o)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},27699,(e,t,o)=>{t.exports=e.x("events",()=>require("events"))},88077,e=>{"use strict";let t={kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gc",name:"Gemini CLI",icon:"terminal",color:"#4285F4",deprecated:!0,deprecationNotice:"Google has tightened Gemini CLI abuse detection and restricted Pro models to paid accounts (Mar 25, 2026). Using this provider may violate ToS and risk account bans."},iflow:{id:"iflow",alias:"if",name:"iFlow AI",icon:"water_drop",color:"#6366F1"}},o={openrouter:{id:"openrouter",alias:"openrouter",name:"OpenRouter",icon:"router",color:"#F97316",textIcon:"OR",passthroughModels:!0,website:"https://openrouter.ai",notice:{text:"Free tier: 27+ free models, no credit card needed, 200 req/day. After $10 credit: 1,000 req/day.",apiKeyUrl:"https://openrouter.ai/settings/keys"},modelsFetcher:{url:"https://openrouter.ai/api/v1/models",type:"openrouter-free"}},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://developer.nvidia.com/nim",notice:{text:"Free access for NVIDIA Developer Program members (prototyping & testing).",apiKeyUrl:"https://build.nvidia.com/settings/api-keys"}},ollama:{id:"ollama",alias:"ollama",name:"Ollama Cloud",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com",notice:{text:"Free tier: light usage, 1 cloud model at a time (limits reset every 5h & 7d). Pro $20/mo · Max $100/mo.",apiKeyUrl:"https://ollama.com/settings/keys"}},vertex:{id:"vertex",alias:"vx",name:"Vertex AI",icon:"cloud",color:"#4285F4",textIcon:"VX",website:"https://cloud.google.com/vertex-ai",notice:{text:"New Google Cloud accounts get $300 free credits. Requires GCP project + Service Account with Vertex AI API enabled.",apiKeyUrl:"https://console.cloud.google.com/iam-admin/serviceaccounts"}}},i={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:"ag",name:"Antigravity",icon:"rocket_launch",color:"#F59E0B",deprecated:!0,deprecationNotice:"Antigravity has tightened abuse detection and restricted model access. Using this provider may violate ToS and risk account bans."},codex:{id:"codex",alias:"cx",name:"OpenAI Codex",icon:"code",color:"#3B82F6"},github:{id:"github",alias:"gh",name:"GitHub Copilot",icon:"code",color:"#333333"},cursor:{id:"cursor",alias:"cu",name:"Cursor IDE",icon:"edit_note",color:"#00D4AA"},kilocode:{id:"kilocode",alias:"kc",name:"Kilo Code",icon:"code",color:"#FF6B35",textIcon:"KC"},cline:{id:"cline",alias:"cl",name:"Cline",icon:"smart_toy",color:"#5B9BD5",textIcon:"CL"}},a={glm:{id:"glm",alias:"glm",name:"GLM Coding",icon:"code",color:"#2563EB",textIcon:"GL",website:"https://open.bigmodel.cn"},"glm-cn":{id:"glm-cn",alias:"glm-cn",name:"GLM (China)",icon:"code",color:"#DC2626",textIcon:"GC",website:"https://open.bigmodel.cn"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},minimax:{id:"minimax",alias:"minimax",name:"Minimax Coding",icon:"memory",color:"#7C3AED",textIcon:"MM",website:"https://www.minimaxi.com"},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",name:"Minimax (China)",icon:"memory",color:"#DC2626",textIcon:"MC",website:"https://www.minimaxi.com"},alicode:{id:"alicode",alias:"alicode",name:"Alibaba",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},"alicode-intl":{id:"alicode-intl",alias:"alicode-intl",name:"Alibaba Intl",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},openai:{id:"openai",alias:"openai",name:"OpenAI",icon:"auto_awesome",color:"#10A37F",textIcon:"OA",website:"https://platform.openai.com"},anthropic:{id:"anthropic",alias:"anthropic",name:"Anthropic",icon:"smart_toy",color:"#D97757",textIcon:"AN",website:"https://console.anthropic.com"},gemini:{id:"gemini",alias:"gemini",name:"Gemini",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev"},deepseek:{id:"deepseek",alias:"ds",name:"DeepSeek",icon:"bolt",color:"#4D6BFE",textIcon:"DS",website:"https://deepseek.com"},groq:{id:"groq",alias:"groq",name:"Groq",icon:"speed",color:"#F55036",textIcon:"GQ",website:"https://groq.com"},xai:{id:"xai",alias:"xai",name:"xAI (Grok)",icon:"auto_awesome",color:"#1DA1F2",textIcon:"XA",website:"https://x.ai"},mistral:{id:"mistral",alias:"mistral",name:"Mistral",icon:"air",color:"#FF7000",textIcon:"MI",website:"https://mistral.ai"},perplexity:{id:"perplexity",alias:"pplx",name:"Perplexity",icon:"search",color:"#20808D",textIcon:"PP",website:"https://www.perplexity.ai"},together:{id:"together",alias:"together",name:"Together AI",icon:"group_work",color:"#0F6FFF",textIcon:"TG",website:"https://www.together.ai"},fireworks:{id:"fireworks",alias:"fireworks",name:"Fireworks AI",icon:"local_fire_department",color:"#7B2EF2",textIcon:"FW",website:"https://fireworks.ai"},cerebras:{id:"cerebras",alias:"cerebras",name:"Cerebras",icon:"memory",color:"#FF4F00",textIcon:"CB",website:"https://www.cerebras.ai"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nebius:{id:"nebius",alias:"nebius",name:"Nebius AI",icon:"cloud",color:"#6C5CE7",textIcon:"NB",website:"https://nebius.com"},siliconflow:{id:"siliconflow",alias:"siliconflow",name:"SiliconFlow",icon:"cloud_queue",color:"#5B6EF5",textIcon:"SF",website:"https://cloud.siliconflow.com"},hyperbolic:{id:"hyperbolic",alias:"hyp",name:"Hyperbolic",icon:"bolt",color:"#00D4FF",textIcon:"HY",website:"https://hyperbolic.xyz"},deepgram:{id:"deepgram",alias:"dg",name:"Deepgram",icon:"mic",color:"#13EF93",textIcon:"DG",website:"https://deepgram.com"},assemblyai:{id:"assemblyai",alias:"aai",name:"AssemblyAI",icon:"record_voice_over",color:"#0062FF",textIcon:"AA",website:"https://assemblyai.com"},nanobanana:{id:"nanobanana",alias:"nb",name:"NanoBanana",icon:"image",color:"#FFD700",textIcon:"NB",website:"https://nanobananaapi.ai"},chutes:{id:"chutes",alias:"ch",name:"Chutes AI",icon:"water_drop",color:"#ffffffff",textIcon:"CH",website:"https://chutes.ai"},"ollama-local":{id:"ollama-local",alias:"ollama-local",name:"Ollama Local",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com"},"vertex-partner":{id:"vertex-partner",alias:"vxp",name:"Vertex Partner",icon:"cloud",color:"#34A853",textIcon:"VP",website:"https://cloud.google.com/vertex-ai/generative-ai/docs/partner-models/use-partner-models"}},n="openai-compatible-",r="anthropic-compatible-",s={...t,...o,...i,...a};function l(e){for(let t of Object.values(s))if(t.alias===e||t.id===e)return t;return null}Object.values(s).reduce((e,t)=>(e[t.alias]=t.id,e),{}),Object.values(s).reduce((e,t)=>(e[t.id]=t.alias,e),{}),e.s(["AI_PROVIDERS",0,s,"ANTHROPIC_COMPATIBLE_PREFIX",0,r,"APIKEY_PROVIDERS",0,a,"FREE_PROVIDERS",0,t,"FREE_TIER_PROVIDERS",0,o,"OAUTH_PROVIDERS",0,i,"OPENAI_COMPATIBLE_PREFIX",0,n,"getProviderAlias",0,function(e){let t=s[e];return t?.alias||e},"getProviderByAlias",0,l,"isAnthropicCompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(r)},"isOpenAICompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(n)},"resolveProviderId",0,function(e){let t=l(e);return t?.id||e}])},12943,e=>{"use strict";e.s(["default",0,{name:"n9router",version:"0.3.89",description:"Self-hosted AI routing gateway — local proxy for Claude, Gemini, OpenAI and 40+ providers",keywords:["ai","llm","proxy","router","claude","openai","gemini","cursor"],homepage:"https://github.com/nightwalker89/n9router",repository:{type:"git",url:"https://github.com/nightwalker89/n9router.git"},config:{appName:"n9router"},license:"MIT",bin:{n9router:"./bin/n9router.js"},files:["bin/",".next/standalone/",".next/static/","public/"],scripts:{dev:"next dev --webpack --port 20128",build:"cross-env NODE_ENV=production next build",start:"cross-env NODE_ENV=production next start","dev:bun":"bun --bun next dev --webpack --port 20128","build:bun":"NODE_ENV=production bun --bun next build --webpack","start:bun":"NODE_ENV=production bun ./.next/standalone/server.js","publish:npm":"./scripts/publish-npm.sh","publish:npm:dry":"./scripts/publish-npm.sh --dry-run"},dependencies:{"@monaco-editor/react":"^4.7.0","@xyflow/react":"^12.10.1",bcryptjs:"^3.0.3",confbox:"^0.2.4",express:"^5.2.1",fs:"^0.0.1-security","http-proxy-middleware":"^3.0.5",jose:"^6.1.3",lowdb:"^7.0.1","monaco-editor":"^0.55.1",next:"^16.1.6","node-forge":"^1.3.3","node-machine-id":"^1.1.12",open:"^11.0.0",ora:"^9.1.0","proper-lockfile":"^4.1.2",react:"19.2.4","react-dom":"19.2.4","react-is":"^16.13.1",recharts:"^3.7.0",selfsigned:"^5.5.0","socks-proxy-agent":"^8.0.5","sql.js":"^1.14.1",undici:"^7.19.2",uuid:"^13.0.0",zustand:"^5.0.10"},optionalDependencies:{"better-sqlite3":"^12.6.2"},devDependencies:{"@tailwindcss/postcss":"^4.1.18","cross-env":"^10.1.0",eslint:"^9","eslint-config-next":"16.1.6",postcss:"^8.5.6",tailwindcss:"^4"}}])},53526,e=>{"use strict";var t=e.i(20491);Object.entries(e.i(88077).AI_PROVIDERS).filter(([,e])=>e.passthroughModels).map(([e])=>e);let o=Object.entries(t.PROVIDER_MODELS).flatMap(([e,t])=>t.map(t=>({provider:e,model:t.id,name:t.name})));e.s(["AI_MODELS",0,o])},55870,e=>{"use strict";var t=e.i(12943);e.i(88077),e.i(53526),t.default.version,e.s(["CONSOLE_LOG_CONFIG",0,{maxLines:200,pollIntervalMs:1e3}])},39838,e=>{"use strict";var t=e.i(27699),o=e.i(55870);let i=["log","info","warn","error","debug"];e.g._consoleLogBufferState||(e.g._consoleLogBufferState={logs:[],patched:!1,originals:{},emitter:new t.EventEmitter},e.g._consoleLogBufferState.emitter.setMaxListeners(50));let a=e.g._consoleLogBufferState;a.emitter||(a.emitter=new t.EventEmitter,a.emitter.setMaxListeners(50));let n=/\x1b\[[0-9;]*m/g;function r(e){return e.replace(n,"")}function s(e){if("string"==typeof e)return r(e);if(e instanceof Error)return r(e.stack||e.message||String(e));try{return r(JSON.stringify(e))}catch{return r(String(e))}}e.s(["clearConsoleLogs",0,function(){a.logs=[],a.emitter.emit("clear")},"getConsoleEmitter",0,function(){return a.emitter},"getConsoleLogs",0,function(){return a.logs},"initConsoleLogCapture",0,function(){if(!a.patched){for(let e of i)a.originals[e]=console[e],console[e]=(...t)=>{!function(e){a.logs.push(e);let t=o.CONSOLE_LOG_CONFIG.maxLines;a.logs.length>t&&(a.logs=a.logs.slice(-t)),a.emitter.emit("line",e)}(t.map(s).join(" ")),a.originals[e](...t)};a.patched=!0}}])},99280,e=>{"use strict";var t=e.i(47909),o=e.i(74017),i=e.i(96250),a=e.i(59756),n=e.i(61916),r=e.i(74677),s=e.i(69741),l=e.i(16795),c=e.i(87718),d=e.i(95169),p=e.i(47587),u=e.i(66012),m=e.i(70101),h=e.i(26937),g=e.i(10372),x=e.i(93695);e.i(20232);var f=e.i(220),b=e.i(39838);async function v(){let e=new TextEncoder,t=(0,b.getConsoleEmitter)(),o={closed:!1,send:null,keepalive:null};return new Response(new ReadableStream({start(i){let a=(0,b.getConsoleLogs)();a.length>0&&i.enqueue(e.encode(`data: ${JSON.stringify({type:"init",logs:a})}
2
2
 
3
3
  `)),o.send=t=>{if(!o.closed)try{i.enqueue(e.encode(`data: ${JSON.stringify({type:"line",line:t})}
4
4
 
@@ -1,3 +1,3 @@
1
- module.exports=[46786,(e,t,i)=>{t.exports=e.x("os",()=>require("os"))},24361,(e,t,i)=>{t.exports=e.x("util",()=>require("util"))},18622,(e,t,i)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,i)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,i)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,i)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},14747,(e,t,i)=>{t.exports=e.x("path",()=>require("path"))},70406,(e,t,i)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,i)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},22734,(e,t,i)=>{t.exports=e.x("fs",()=>require("fs"))},12714,(e,t,i)=>{t.exports=e.x("node:fs/promises",()=>require("node:fs/promises"))},50227,(e,t,i)=>{t.exports=e.x("node:path",()=>require("node:path"))},57764,(e,t,i)=>{t.exports=e.x("node:url",()=>require("node:url"))},27699,(e,t,i)=>{t.exports=e.x("events",()=>require("events"))},2157,(e,t,i)=>{t.exports=e.x("node:fs",()=>require("node:fs"))},60526,(e,t,i)=>{t.exports=e.x("node:os",()=>require("node:os"))},22593,67059,21023,e=>{"use strict";e.s(["Low",0,class{adapter;data;constructor(e,t){!function(e,t){if(void 0===e)throw Error("lowdb: missing adapter");if(void 0===t)throw Error("lowdb: missing default data")}(e,t),this.adapter=e,this.data=t}async read(){let e=await this.adapter.read();e&&(this.data=e)}async write(){this.data&&await this.adapter.write(this.data)}async update(e){e(this.data),await this.write()}}],22593),e.i(2157);var t=e.i(12714),i=e.i(50227),r=e.i(57764);async function a(e,t,i){for(let r=0;r<t;r++)try{return await e()}catch(e){if(r<t-1)await new Promise(e=>setTimeout(e,i));else throw e}}class o{#e;#t;#i=!1;#r=null;#a=null;#o=null;#n=null;#s(e){return this.#n=e,this.#o||=new Promise((e,t)=>{this.#a=[e,t]}),new Promise((e,t)=>{this.#o?.then(e).catch(t)})}async #l(e){this.#i=!0;try{await (0,t.writeFile)(this.#t,e,"utf-8"),await a(async()=>{await (0,t.rename)(this.#t,this.#e)},10,100),this.#r?.[0]()}catch(e){throw e instanceof Error&&this.#r?.[1](e),e}finally{if(this.#i=!1,this.#r=this.#a,this.#a=this.#o=null,null!==this.#n){let e=this.#n;this.#n=null,await this.write(e)}}}constructor(e){this.#e=e,this.#t=function(e){let t=e instanceof URL?(0,r.fileURLToPath)(e):e.toString();return(0,i.join)((0,i.dirname)(t),`.${(0,i.basename)(t)}.tmp`)}(e)}async write(e){return this.#i?this.#s(e):this.#l(e)}}class n{#e;#c;constructor(e){this.#e=e,this.#c=new o(e)}async read(){let e;try{e=await (0,t.readFile)(this.#e,"utf-8")}catch(e){if("ENOENT"===e.code)return null;throw e}return e}write(e){return this.#c.write(e)}}class s{#d;#p;#u;constructor(e,{parse:t,stringify:i}){this.#d=new n(e),this.#p=t,this.#u=i}async read(){let e=await this.#d.read();return null===e?null:this.#p(e)}write(e){return this.#d.write(this.#u(e))}}e.s(["JSONFile",0,class extends s{constructor(e){super(e,{parse:JSON.parse,stringify:e=>JSON.stringify(e,null,2)})}}],67059),e.s([],21023)},66680,(e,t,i)=>{t.exports=e.x("node:crypto",()=>require("node:crypto"))},88947,(e,t,i)=>{t.exports=e.x("stream",()=>require("stream"))},12249,(e,t,i)=>{t.exports=e.x("constants",()=>require("constants"))},49719,(e,t,i)=>{t.exports=e.x("assert",()=>require("assert"))},69789,e=>{"use strict";e.i(26753),e.s([])},88077,e=>{"use strict";let t={kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gc",name:"Gemini CLI",icon:"terminal",color:"#4285F4",deprecated:!0,deprecationNotice:"Google has tightened Gemini CLI abuse detection and restricted Pro models to paid accounts (Mar 25, 2026). Using this provider may violate ToS and risk account bans."},iflow:{id:"iflow",alias:"if",name:"iFlow AI",icon:"water_drop",color:"#6366F1"}},i={openrouter:{id:"openrouter",alias:"openrouter",name:"OpenRouter",icon:"router",color:"#F97316",textIcon:"OR",passthroughModels:!0,website:"https://openrouter.ai",notice:{text:"Free tier: 27+ free models, no credit card needed, 200 req/day. After $10 credit: 1,000 req/day.",apiKeyUrl:"https://openrouter.ai/settings/keys"},modelsFetcher:{url:"https://openrouter.ai/api/v1/models",type:"openrouter-free"}},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://developer.nvidia.com/nim",notice:{text:"Free access for NVIDIA Developer Program members (prototyping & testing).",apiKeyUrl:"https://build.nvidia.com/settings/api-keys"}},ollama:{id:"ollama",alias:"ollama",name:"Ollama Cloud",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com",notice:{text:"Free tier: light usage, 1 cloud model at a time (limits reset every 5h & 7d). Pro $20/mo · Max $100/mo.",apiKeyUrl:"https://ollama.com/settings/keys"}},vertex:{id:"vertex",alias:"vx",name:"Vertex AI",icon:"cloud",color:"#4285F4",textIcon:"VX",website:"https://cloud.google.com/vertex-ai",notice:{text:"New Google Cloud accounts get $300 free credits. Requires GCP project + Service Account with Vertex AI API enabled.",apiKeyUrl:"https://console.cloud.google.com/iam-admin/serviceaccounts"}}},r={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:"ag",name:"Antigravity",icon:"rocket_launch",color:"#F59E0B",deprecated:!0,deprecationNotice:"Antigravity has tightened abuse detection and restricted model access. Using this provider may violate ToS and risk account bans."},codex:{id:"codex",alias:"cx",name:"OpenAI Codex",icon:"code",color:"#3B82F6"},github:{id:"github",alias:"gh",name:"GitHub Copilot",icon:"code",color:"#333333"},cursor:{id:"cursor",alias:"cu",name:"Cursor IDE",icon:"edit_note",color:"#00D4AA"},kilocode:{id:"kilocode",alias:"kc",name:"Kilo Code",icon:"code",color:"#FF6B35",textIcon:"KC"},cline:{id:"cline",alias:"cl",name:"Cline",icon:"smart_toy",color:"#5B9BD5",textIcon:"CL"}},a={glm:{id:"glm",alias:"glm",name:"GLM Coding",icon:"code",color:"#2563EB",textIcon:"GL",website:"https://open.bigmodel.cn"},"glm-cn":{id:"glm-cn",alias:"glm-cn",name:"GLM (China)",icon:"code",color:"#DC2626",textIcon:"GC",website:"https://open.bigmodel.cn"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},minimax:{id:"minimax",alias:"minimax",name:"Minimax Coding",icon:"memory",color:"#7C3AED",textIcon:"MM",website:"https://www.minimaxi.com"},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",name:"Minimax (China)",icon:"memory",color:"#DC2626",textIcon:"MC",website:"https://www.minimaxi.com"},alicode:{id:"alicode",alias:"alicode",name:"Alibaba",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},"alicode-intl":{id:"alicode-intl",alias:"alicode-intl",name:"Alibaba Intl",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},openai:{id:"openai",alias:"openai",name:"OpenAI",icon:"auto_awesome",color:"#10A37F",textIcon:"OA",website:"https://platform.openai.com"},anthropic:{id:"anthropic",alias:"anthropic",name:"Anthropic",icon:"smart_toy",color:"#D97757",textIcon:"AN",website:"https://console.anthropic.com"},gemini:{id:"gemini",alias:"gemini",name:"Gemini",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev"},deepseek:{id:"deepseek",alias:"ds",name:"DeepSeek",icon:"bolt",color:"#4D6BFE",textIcon:"DS",website:"https://deepseek.com"},groq:{id:"groq",alias:"groq",name:"Groq",icon:"speed",color:"#F55036",textIcon:"GQ",website:"https://groq.com"},xai:{id:"xai",alias:"xai",name:"xAI (Grok)",icon:"auto_awesome",color:"#1DA1F2",textIcon:"XA",website:"https://x.ai"},mistral:{id:"mistral",alias:"mistral",name:"Mistral",icon:"air",color:"#FF7000",textIcon:"MI",website:"https://mistral.ai"},perplexity:{id:"perplexity",alias:"pplx",name:"Perplexity",icon:"search",color:"#20808D",textIcon:"PP",website:"https://www.perplexity.ai"},together:{id:"together",alias:"together",name:"Together AI",icon:"group_work",color:"#0F6FFF",textIcon:"TG",website:"https://www.together.ai"},fireworks:{id:"fireworks",alias:"fireworks",name:"Fireworks AI",icon:"local_fire_department",color:"#7B2EF2",textIcon:"FW",website:"https://fireworks.ai"},cerebras:{id:"cerebras",alias:"cerebras",name:"Cerebras",icon:"memory",color:"#FF4F00",textIcon:"CB",website:"https://www.cerebras.ai"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nebius:{id:"nebius",alias:"nebius",name:"Nebius AI",icon:"cloud",color:"#6C5CE7",textIcon:"NB",website:"https://nebius.com"},siliconflow:{id:"siliconflow",alias:"siliconflow",name:"SiliconFlow",icon:"cloud_queue",color:"#5B6EF5",textIcon:"SF",website:"https://cloud.siliconflow.com"},hyperbolic:{id:"hyperbolic",alias:"hyp",name:"Hyperbolic",icon:"bolt",color:"#00D4FF",textIcon:"HY",website:"https://hyperbolic.xyz"},deepgram:{id:"deepgram",alias:"dg",name:"Deepgram",icon:"mic",color:"#13EF93",textIcon:"DG",website:"https://deepgram.com"},assemblyai:{id:"assemblyai",alias:"aai",name:"AssemblyAI",icon:"record_voice_over",color:"#0062FF",textIcon:"AA",website:"https://assemblyai.com"},nanobanana:{id:"nanobanana",alias:"nb",name:"NanoBanana",icon:"image",color:"#FFD700",textIcon:"NB",website:"https://nanobananaapi.ai"},chutes:{id:"chutes",alias:"ch",name:"Chutes AI",icon:"water_drop",color:"#ffffffff",textIcon:"CH",website:"https://chutes.ai"},"ollama-local":{id:"ollama-local",alias:"ollama-local",name:"Ollama Local",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com"},"vertex-partner":{id:"vertex-partner",alias:"vxp",name:"Vertex Partner",icon:"cloud",color:"#34A853",textIcon:"VP",website:"https://cloud.google.com/vertex-ai/generative-ai/docs/partner-models/use-partner-models"}},o="openai-compatible-",n="anthropic-compatible-",s={...t,...i,...r,...a};function l(e){for(let t of Object.values(s))if(t.alias===e||t.id===e)return t;return null}Object.values(s).reduce((e,t)=>(e[t.alias]=t.id,e),{}),Object.values(s).reduce((e,t)=>(e[t.id]=t.alias,e),{}),e.s(["AI_PROVIDERS",0,s,"ANTHROPIC_COMPATIBLE_PREFIX",0,n,"APIKEY_PROVIDERS",0,a,"FREE_PROVIDERS",0,t,"FREE_TIER_PROVIDERS",0,i,"OAUTH_PROVIDERS",0,r,"OPENAI_COMPATIBLE_PREFIX",0,o,"getProviderAlias",0,function(e){let t=s[e];return t?.alias||e},"getProviderByAlias",0,l,"isAnthropicCompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(n)},"isOpenAICompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(o)},"resolveProviderId",0,function(e){let t=l(e);return t?.id||e}])},12943,e=>{"use strict";e.s(["default",0,{name:"n9router",version:"0.3.88",description:"Self-hosted AI routing gateway — local proxy for Claude, Gemini, OpenAI and 40+ providers",keywords:["ai","llm","proxy","router","claude","openai","gemini","cursor"],homepage:"https://github.com/nightwalker89/n9router",repository:{type:"git",url:"https://github.com/nightwalker89/n9router.git"},config:{appName:"n9router"},license:"MIT",bin:{n9router:"./bin/n9router.js"},files:["bin/",".next/standalone/",".next/static/","public/"],scripts:{dev:"next dev --webpack --port 20128",build:"cross-env NODE_ENV=production next build",start:"cross-env NODE_ENV=production next start","dev:bun":"bun --bun next dev --webpack --port 20128","build:bun":"NODE_ENV=production bun --bun next build --webpack","start:bun":"NODE_ENV=production bun ./.next/standalone/server.js","publish:npm":"./scripts/publish-npm.sh","publish:npm:dry":"./scripts/publish-npm.sh --dry-run"},dependencies:{"@monaco-editor/react":"^4.7.0","@xyflow/react":"^12.10.1",bcryptjs:"^3.0.3",confbox:"^0.2.4",express:"^5.2.1",fs:"^0.0.1-security","http-proxy-middleware":"^3.0.5",jose:"^6.1.3",lowdb:"^7.0.1","monaco-editor":"^0.55.1",next:"^16.1.6","node-forge":"^1.3.3","node-machine-id":"^1.1.12",open:"^11.0.0",ora:"^9.1.0","proper-lockfile":"^4.1.2",react:"19.2.4","react-dom":"19.2.4","react-is":"^16.13.1",recharts:"^3.7.0",selfsigned:"^5.5.0","socks-proxy-agent":"^8.0.5","sql.js":"^1.14.1",undici:"^7.19.2",uuid:"^13.0.0",zustand:"^5.0.10"},optionalDependencies:{"better-sqlite3":"^12.6.2"},devDependencies:{"@tailwindcss/postcss":"^4.1.18","cross-env":"^10.1.0",eslint:"^9","eslint-config-next":"16.1.6",postcss:"^8.5.6",tailwindcss:"^4"}}])},53526,e=>{"use strict";var t=e.i(20491);Object.entries(e.i(88077).AI_PROVIDERS).filter(([,e])=>e.passthroughModels).map(([e])=>e);let i=Object.entries(t.PROVIDER_MODELS).flatMap(([e,t])=>t.map(t=>({provider:e,model:t.id,name:t.name})));e.s(["AI_MODELS",0,i])},55870,e=>{"use strict";var t=e.i(12943);e.i(88077),e.i(53526),t.default.version,e.s(["CONSOLE_LOG_CONFIG",0,{maxLines:200,pollIntervalMs:1e3}])},37828,e=>{"use strict";var t=e.i(47909),i=e.i(74017),r=e.i(96250),a=e.i(59756),o=e.i(61916),n=e.i(74677),s=e.i(69741),l=e.i(16795),c=e.i(87718),d=e.i(95169),p=e.i(47587),u=e.i(66012),m=e.i(70101),h=e.i(26937),x=e.i(10372),w=e.i(93695);e.i(20232);var f=e.i(220),g=e.i(89171);e.i(69789);var b=e.i(26753);e.i(55870);var v=e.i(53526);async function y(){try{let e=await (0,b.getModelAliases)(),t=v.AI_MODELS.map(t=>{let i=`${t.provider}/${t.model}`;return{...t,fullModel:i,alias:e[i]||t.model}});return g.NextResponse.json({models:t})}catch(e){return console.log("Error fetching models:",e),g.NextResponse.json({error:"Failed to fetch models"},{status:500})}}async function I(e){try{let{model:t,alias:i}=await e.json();if(!t||!i)return g.NextResponse.json({error:"Model and alias required"},{status:400});let r=await (0,b.getModelAliases)();if(Object.entries(r).find(([e,r])=>r===i&&e!==t))return g.NextResponse.json({error:"Alias already in use"},{status:400});return await (0,b.setModelAlias)(t,i),g.NextResponse.json({success:!0,model:t,alias:i})}catch(e){return console.log("Error updating alias:",e),g.NextResponse.json({error:"Failed to update alias"},{status:500})}}e.s(["GET",0,y,"PUT",0,I],86625);var A=e.i(86625);let E=new t.AppRouteRouteModule({definition:{kind:i.RouteKind.APP_ROUTE,page:"/api/models/route",pathname:"/api/models",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/models/route.js",nextConfigOutput:"standalone",userland:A,...{}}),{workAsyncStorage:R,workUnitAsyncStorage:C,serverHooks:F}=E;async function _(e,t,r){r.requestMeta&&(0,a.setRequestMeta)(e,r.requestMeta),E.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let g="/api/models/route";g=g.replace(/\/index$/,"")||"/";let b=await E.prepare(e,t,{srcPage:g,multiZoneDraftMode:!1});if(!b)return t.statusCode=400,t.end("Bad Request"),null==r.waitUntil||r.waitUntil.call(r,Promise.resolve()),null;let{buildId:v,params:y,nextConfig:I,parsedUrl:A,isDraftMode:R,prerenderManifest:C,routerServerContext:F,isOnDemandRevalidate:_,revalidateOnlyGenerated:O,resolvedPathname:P,clientReferenceManifest:k,serverActionsManifest:N}=b,D=(0,s.normalizeAppPath)(g),q=!!(C.dynamicRoutes[D]||C.routes[P]),S=async()=>((null==F?void 0:F.render404)?await F.render404(e,t,A,!1):t.end("This page could not be found"),null);if(q&&!R){let e=!!C.routes[P],t=C.dynamicRoutes[D];if(t&&!1===t.fallback&&!e){if(I.adapterPath)return await S();throw new w.NoFallbackError}}let M=null;!q||E.isDev||R||(M="/index"===(M=P)?"/":M);let j=!0===E.isDev||!q,T=q&&!j;N&&k&&(0,n.setManifestsSingleton)({page:g,clientReferenceManifest:k,serverActionsManifest:N});let L=e.method||"GET",U=(0,o.getTracer)(),B=U.getActiveScopeSpan(),G=!!(null==F?void 0:F.isWrappedByNextServer),H=!!(0,a.getRequestMeta)(e,"minimalMode"),V=(0,a.getRequestMeta)(e,"incrementalCache")||await E.getIncrementalCache(e,I,C,H);null==V||V.resetRequestCache(),globalThis.__incrementalCache=V;let K={params:y,previewProps:C.preview,renderOpts:{experimental:{authInterrupts:!!I.experimental.authInterrupts},cacheComponents:!!I.cacheComponents,supportsDynamicResponse:j,incrementalCache:V,cacheLifeProfiles:I.cacheLife,waitUntil:r.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,i,r,a)=>E.onRequestError(e,t,r,a,F)},sharedContext:{buildId:v}},$=new l.NodeNextRequest(e),X=new l.NodeNextResponse(t),W=c.NextRequestAdapter.fromNodeNextRequest($,(0,c.signalFromNodeResponse)(t));try{let a,n=async e=>E.handle(W,K).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let i=U.getRootSpanAttributes();if(!i)return;if(i.get("next.span_type")!==d.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${i.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let r=i.get("next.route");if(r){let t=`${L} ${r}`;e.setAttributes({"next.route":r,"http.route":r,"next.span_name":t}),e.updateName(t),a&&a!==e&&(a.setAttribute("http.route",r),a.updateName(t))}else e.updateName(`${L} ${g}`)}),s=async a=>{var o,s;let l=async({previousCacheEntry:i})=>{try{if(!H&&_&&O&&!i)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let o=await n(a);e.fetchMetrics=K.renderOpts.fetchMetrics;let s=K.renderOpts.pendingWaitUntil;s&&r.waitUntil&&(r.waitUntil(s),s=void 0);let l=K.renderOpts.collectedTags;if(!q)return await (0,u.sendResponse)($,X,o,K.renderOpts.pendingWaitUntil),null;{let e=await o.blob(),t=(0,m.toNodeOutgoingHttpHeaders)(o.headers);l&&(t[x.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let i=void 0!==K.renderOpts.collectedRevalidate&&!(K.renderOpts.collectedRevalidate>=x.INFINITE_CACHE)&&K.renderOpts.collectedRevalidate,r=void 0===K.renderOpts.collectedExpire||K.renderOpts.collectedExpire>=x.INFINITE_CACHE?void 0:K.renderOpts.collectedExpire;return{value:{kind:f.CachedRouteKind.APP_ROUTE,status:o.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:i,expire:r}}}}catch(t){throw(null==i?void 0:i.isStale)&&await E.onRequestError(e,t,{routerKind:"App Router",routePath:g,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:T,isOnDemandRevalidate:_})},!1,F),t}},c=await E.handleResponse({req:e,nextConfig:I,cacheKey:M,routeKind:i.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:C,isRoutePPREnabled:!1,isOnDemandRevalidate:_,revalidateOnlyGenerated:O,responseGenerator:l,waitUntil:r.waitUntil,isMinimalMode:H});if(!q)return null;if((null==c||null==(o=c.value)?void 0:o.kind)!==f.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==c||null==(s=c.value)?void 0:s.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});H||t.setHeader("x-nextjs-cache",_?"REVALIDATED":c.isMiss?"MISS":c.isStale?"STALE":"HIT"),R&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let d=(0,m.fromNodeOutgoingHttpHeaders)(c.value.headers);return H&&q||d.delete(x.NEXT_CACHE_TAGS_HEADER),!c.cacheControl||t.getHeader("Cache-Control")||d.get("Cache-Control")||d.set("Cache-Control",(0,h.getCacheControlHeader)(c.cacheControl)),await (0,u.sendResponse)($,X,new Response(c.value.body,{headers:d,status:c.value.status||200})),null};G&&B?await s(B):(a=U.getActiveScopeSpan(),await U.withPropagatedContext(e.headers,()=>U.trace(d.BaseServerSpan.handleRequest,{spanName:`${L} ${g}`,kind:o.SpanKind.SERVER,attributes:{"http.method":L,"http.target":e.url}},s),void 0,!G))}catch(t){if(t instanceof w.NoFallbackError||await E.onRequestError(e,t,{routerKind:"App Router",routePath:D,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:T,isOnDemandRevalidate:_})},!1,F),q)throw t;return await (0,u.sendResponse)($,X,new Response(null,{status:500})),null}}e.s(["handler",0,_,"patchFetch",0,function(){return(0,r.patchFetch)({workAsyncStorage:R,workUnitAsyncStorage:C})},"routeModule",0,E,"serverHooks",0,F,"workAsyncStorage",0,R,"workUnitAsyncStorage",0,C],37828)},36498,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0kaoh2i._.js"].map(t=>e.l(t))).then(()=>t(21297)))},66510,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_constants_pricing_0oa_fz9.js"].map(t=>e.l(t))).then(()=>t(28628)))}];
1
+ module.exports=[46786,(e,t,i)=>{t.exports=e.x("os",()=>require("os"))},24361,(e,t,i)=>{t.exports=e.x("util",()=>require("util"))},18622,(e,t,i)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,i)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,i)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,i)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},14747,(e,t,i)=>{t.exports=e.x("path",()=>require("path"))},70406,(e,t,i)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,i)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},22734,(e,t,i)=>{t.exports=e.x("fs",()=>require("fs"))},12714,(e,t,i)=>{t.exports=e.x("node:fs/promises",()=>require("node:fs/promises"))},50227,(e,t,i)=>{t.exports=e.x("node:path",()=>require("node:path"))},57764,(e,t,i)=>{t.exports=e.x("node:url",()=>require("node:url"))},27699,(e,t,i)=>{t.exports=e.x("events",()=>require("events"))},2157,(e,t,i)=>{t.exports=e.x("node:fs",()=>require("node:fs"))},60526,(e,t,i)=>{t.exports=e.x("node:os",()=>require("node:os"))},22593,67059,21023,e=>{"use strict";e.s(["Low",0,class{adapter;data;constructor(e,t){!function(e,t){if(void 0===e)throw Error("lowdb: missing adapter");if(void 0===t)throw Error("lowdb: missing default data")}(e,t),this.adapter=e,this.data=t}async read(){let e=await this.adapter.read();e&&(this.data=e)}async write(){this.data&&await this.adapter.write(this.data)}async update(e){e(this.data),await this.write()}}],22593),e.i(2157);var t=e.i(12714),i=e.i(50227),r=e.i(57764);async function a(e,t,i){for(let r=0;r<t;r++)try{return await e()}catch(e){if(r<t-1)await new Promise(e=>setTimeout(e,i));else throw e}}class o{#e;#t;#i=!1;#r=null;#a=null;#o=null;#n=null;#s(e){return this.#n=e,this.#o||=new Promise((e,t)=>{this.#a=[e,t]}),new Promise((e,t)=>{this.#o?.then(e).catch(t)})}async #l(e){this.#i=!0;try{await (0,t.writeFile)(this.#t,e,"utf-8"),await a(async()=>{await (0,t.rename)(this.#t,this.#e)},10,100),this.#r?.[0]()}catch(e){throw e instanceof Error&&this.#r?.[1](e),e}finally{if(this.#i=!1,this.#r=this.#a,this.#a=this.#o=null,null!==this.#n){let e=this.#n;this.#n=null,await this.write(e)}}}constructor(e){this.#e=e,this.#t=function(e){let t=e instanceof URL?(0,r.fileURLToPath)(e):e.toString();return(0,i.join)((0,i.dirname)(t),`.${(0,i.basename)(t)}.tmp`)}(e)}async write(e){return this.#i?this.#s(e):this.#l(e)}}class n{#e;#c;constructor(e){this.#e=e,this.#c=new o(e)}async read(){let e;try{e=await (0,t.readFile)(this.#e,"utf-8")}catch(e){if("ENOENT"===e.code)return null;throw e}return e}write(e){return this.#c.write(e)}}class s{#d;#p;#u;constructor(e,{parse:t,stringify:i}){this.#d=new n(e),this.#p=t,this.#u=i}async read(){let e=await this.#d.read();return null===e?null:this.#p(e)}write(e){return this.#d.write(this.#u(e))}}e.s(["JSONFile",0,class extends s{constructor(e){super(e,{parse:JSON.parse,stringify:e=>JSON.stringify(e,null,2)})}}],67059),e.s([],21023)},66680,(e,t,i)=>{t.exports=e.x("node:crypto",()=>require("node:crypto"))},88947,(e,t,i)=>{t.exports=e.x("stream",()=>require("stream"))},12249,(e,t,i)=>{t.exports=e.x("constants",()=>require("constants"))},49719,(e,t,i)=>{t.exports=e.x("assert",()=>require("assert"))},69789,e=>{"use strict";e.i(26753),e.s([])},88077,e=>{"use strict";let t={kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gc",name:"Gemini CLI",icon:"terminal",color:"#4285F4",deprecated:!0,deprecationNotice:"Google has tightened Gemini CLI abuse detection and restricted Pro models to paid accounts (Mar 25, 2026). Using this provider may violate ToS and risk account bans."},iflow:{id:"iflow",alias:"if",name:"iFlow AI",icon:"water_drop",color:"#6366F1"}},i={openrouter:{id:"openrouter",alias:"openrouter",name:"OpenRouter",icon:"router",color:"#F97316",textIcon:"OR",passthroughModels:!0,website:"https://openrouter.ai",notice:{text:"Free tier: 27+ free models, no credit card needed, 200 req/day. After $10 credit: 1,000 req/day.",apiKeyUrl:"https://openrouter.ai/settings/keys"},modelsFetcher:{url:"https://openrouter.ai/api/v1/models",type:"openrouter-free"}},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://developer.nvidia.com/nim",notice:{text:"Free access for NVIDIA Developer Program members (prototyping & testing).",apiKeyUrl:"https://build.nvidia.com/settings/api-keys"}},ollama:{id:"ollama",alias:"ollama",name:"Ollama Cloud",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com",notice:{text:"Free tier: light usage, 1 cloud model at a time (limits reset every 5h & 7d). Pro $20/mo · Max $100/mo.",apiKeyUrl:"https://ollama.com/settings/keys"}},vertex:{id:"vertex",alias:"vx",name:"Vertex AI",icon:"cloud",color:"#4285F4",textIcon:"VX",website:"https://cloud.google.com/vertex-ai",notice:{text:"New Google Cloud accounts get $300 free credits. Requires GCP project + Service Account with Vertex AI API enabled.",apiKeyUrl:"https://console.cloud.google.com/iam-admin/serviceaccounts"}}},r={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:"ag",name:"Antigravity",icon:"rocket_launch",color:"#F59E0B",deprecated:!0,deprecationNotice:"Antigravity has tightened abuse detection and restricted model access. Using this provider may violate ToS and risk account bans."},codex:{id:"codex",alias:"cx",name:"OpenAI Codex",icon:"code",color:"#3B82F6"},github:{id:"github",alias:"gh",name:"GitHub Copilot",icon:"code",color:"#333333"},cursor:{id:"cursor",alias:"cu",name:"Cursor IDE",icon:"edit_note",color:"#00D4AA"},kilocode:{id:"kilocode",alias:"kc",name:"Kilo Code",icon:"code",color:"#FF6B35",textIcon:"KC"},cline:{id:"cline",alias:"cl",name:"Cline",icon:"smart_toy",color:"#5B9BD5",textIcon:"CL"}},a={glm:{id:"glm",alias:"glm",name:"GLM Coding",icon:"code",color:"#2563EB",textIcon:"GL",website:"https://open.bigmodel.cn"},"glm-cn":{id:"glm-cn",alias:"glm-cn",name:"GLM (China)",icon:"code",color:"#DC2626",textIcon:"GC",website:"https://open.bigmodel.cn"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},minimax:{id:"minimax",alias:"minimax",name:"Minimax Coding",icon:"memory",color:"#7C3AED",textIcon:"MM",website:"https://www.minimaxi.com"},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",name:"Minimax (China)",icon:"memory",color:"#DC2626",textIcon:"MC",website:"https://www.minimaxi.com"},alicode:{id:"alicode",alias:"alicode",name:"Alibaba",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},"alicode-intl":{id:"alicode-intl",alias:"alicode-intl",name:"Alibaba Intl",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},openai:{id:"openai",alias:"openai",name:"OpenAI",icon:"auto_awesome",color:"#10A37F",textIcon:"OA",website:"https://platform.openai.com"},anthropic:{id:"anthropic",alias:"anthropic",name:"Anthropic",icon:"smart_toy",color:"#D97757",textIcon:"AN",website:"https://console.anthropic.com"},gemini:{id:"gemini",alias:"gemini",name:"Gemini",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev"},deepseek:{id:"deepseek",alias:"ds",name:"DeepSeek",icon:"bolt",color:"#4D6BFE",textIcon:"DS",website:"https://deepseek.com"},groq:{id:"groq",alias:"groq",name:"Groq",icon:"speed",color:"#F55036",textIcon:"GQ",website:"https://groq.com"},xai:{id:"xai",alias:"xai",name:"xAI (Grok)",icon:"auto_awesome",color:"#1DA1F2",textIcon:"XA",website:"https://x.ai"},mistral:{id:"mistral",alias:"mistral",name:"Mistral",icon:"air",color:"#FF7000",textIcon:"MI",website:"https://mistral.ai"},perplexity:{id:"perplexity",alias:"pplx",name:"Perplexity",icon:"search",color:"#20808D",textIcon:"PP",website:"https://www.perplexity.ai"},together:{id:"together",alias:"together",name:"Together AI",icon:"group_work",color:"#0F6FFF",textIcon:"TG",website:"https://www.together.ai"},fireworks:{id:"fireworks",alias:"fireworks",name:"Fireworks AI",icon:"local_fire_department",color:"#7B2EF2",textIcon:"FW",website:"https://fireworks.ai"},cerebras:{id:"cerebras",alias:"cerebras",name:"Cerebras",icon:"memory",color:"#FF4F00",textIcon:"CB",website:"https://www.cerebras.ai"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nebius:{id:"nebius",alias:"nebius",name:"Nebius AI",icon:"cloud",color:"#6C5CE7",textIcon:"NB",website:"https://nebius.com"},siliconflow:{id:"siliconflow",alias:"siliconflow",name:"SiliconFlow",icon:"cloud_queue",color:"#5B6EF5",textIcon:"SF",website:"https://cloud.siliconflow.com"},hyperbolic:{id:"hyperbolic",alias:"hyp",name:"Hyperbolic",icon:"bolt",color:"#00D4FF",textIcon:"HY",website:"https://hyperbolic.xyz"},deepgram:{id:"deepgram",alias:"dg",name:"Deepgram",icon:"mic",color:"#13EF93",textIcon:"DG",website:"https://deepgram.com"},assemblyai:{id:"assemblyai",alias:"aai",name:"AssemblyAI",icon:"record_voice_over",color:"#0062FF",textIcon:"AA",website:"https://assemblyai.com"},nanobanana:{id:"nanobanana",alias:"nb",name:"NanoBanana",icon:"image",color:"#FFD700",textIcon:"NB",website:"https://nanobananaapi.ai"},chutes:{id:"chutes",alias:"ch",name:"Chutes AI",icon:"water_drop",color:"#ffffffff",textIcon:"CH",website:"https://chutes.ai"},"ollama-local":{id:"ollama-local",alias:"ollama-local",name:"Ollama Local",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com"},"vertex-partner":{id:"vertex-partner",alias:"vxp",name:"Vertex Partner",icon:"cloud",color:"#34A853",textIcon:"VP",website:"https://cloud.google.com/vertex-ai/generative-ai/docs/partner-models/use-partner-models"}},o="openai-compatible-",n="anthropic-compatible-",s={...t,...i,...r,...a};function l(e){for(let t of Object.values(s))if(t.alias===e||t.id===e)return t;return null}Object.values(s).reduce((e,t)=>(e[t.alias]=t.id,e),{}),Object.values(s).reduce((e,t)=>(e[t.id]=t.alias,e),{}),e.s(["AI_PROVIDERS",0,s,"ANTHROPIC_COMPATIBLE_PREFIX",0,n,"APIKEY_PROVIDERS",0,a,"FREE_PROVIDERS",0,t,"FREE_TIER_PROVIDERS",0,i,"OAUTH_PROVIDERS",0,r,"OPENAI_COMPATIBLE_PREFIX",0,o,"getProviderAlias",0,function(e){let t=s[e];return t?.alias||e},"getProviderByAlias",0,l,"isAnthropicCompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(n)},"isOpenAICompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(o)},"resolveProviderId",0,function(e){let t=l(e);return t?.id||e}])},12943,e=>{"use strict";e.s(["default",0,{name:"n9router",version:"0.3.89",description:"Self-hosted AI routing gateway — local proxy for Claude, Gemini, OpenAI and 40+ providers",keywords:["ai","llm","proxy","router","claude","openai","gemini","cursor"],homepage:"https://github.com/nightwalker89/n9router",repository:{type:"git",url:"https://github.com/nightwalker89/n9router.git"},config:{appName:"n9router"},license:"MIT",bin:{n9router:"./bin/n9router.js"},files:["bin/",".next/standalone/",".next/static/","public/"],scripts:{dev:"next dev --webpack --port 20128",build:"cross-env NODE_ENV=production next build",start:"cross-env NODE_ENV=production next start","dev:bun":"bun --bun next dev --webpack --port 20128","build:bun":"NODE_ENV=production bun --bun next build --webpack","start:bun":"NODE_ENV=production bun ./.next/standalone/server.js","publish:npm":"./scripts/publish-npm.sh","publish:npm:dry":"./scripts/publish-npm.sh --dry-run"},dependencies:{"@monaco-editor/react":"^4.7.0","@xyflow/react":"^12.10.1",bcryptjs:"^3.0.3",confbox:"^0.2.4",express:"^5.2.1",fs:"^0.0.1-security","http-proxy-middleware":"^3.0.5",jose:"^6.1.3",lowdb:"^7.0.1","monaco-editor":"^0.55.1",next:"^16.1.6","node-forge":"^1.3.3","node-machine-id":"^1.1.12",open:"^11.0.0",ora:"^9.1.0","proper-lockfile":"^4.1.2",react:"19.2.4","react-dom":"19.2.4","react-is":"^16.13.1",recharts:"^3.7.0",selfsigned:"^5.5.0","socks-proxy-agent":"^8.0.5","sql.js":"^1.14.1",undici:"^7.19.2",uuid:"^13.0.0",zustand:"^5.0.10"},optionalDependencies:{"better-sqlite3":"^12.6.2"},devDependencies:{"@tailwindcss/postcss":"^4.1.18","cross-env":"^10.1.0",eslint:"^9","eslint-config-next":"16.1.6",postcss:"^8.5.6",tailwindcss:"^4"}}])},53526,e=>{"use strict";var t=e.i(20491);Object.entries(e.i(88077).AI_PROVIDERS).filter(([,e])=>e.passthroughModels).map(([e])=>e);let i=Object.entries(t.PROVIDER_MODELS).flatMap(([e,t])=>t.map(t=>({provider:e,model:t.id,name:t.name})));e.s(["AI_MODELS",0,i])},55870,e=>{"use strict";var t=e.i(12943);e.i(88077),e.i(53526),t.default.version,e.s(["CONSOLE_LOG_CONFIG",0,{maxLines:200,pollIntervalMs:1e3}])},37828,e=>{"use strict";var t=e.i(47909),i=e.i(74017),r=e.i(96250),a=e.i(59756),o=e.i(61916),n=e.i(74677),s=e.i(69741),l=e.i(16795),c=e.i(87718),d=e.i(95169),p=e.i(47587),u=e.i(66012),m=e.i(70101),h=e.i(26937),x=e.i(10372),w=e.i(93695);e.i(20232);var f=e.i(220),g=e.i(89171);e.i(69789);var b=e.i(26753);e.i(55870);var v=e.i(53526);async function y(){try{let e=await (0,b.getModelAliases)(),t=v.AI_MODELS.map(t=>{let i=`${t.provider}/${t.model}`;return{...t,fullModel:i,alias:e[i]||t.model}});return g.NextResponse.json({models:t})}catch(e){return console.log("Error fetching models:",e),g.NextResponse.json({error:"Failed to fetch models"},{status:500})}}async function I(e){try{let{model:t,alias:i}=await e.json();if(!t||!i)return g.NextResponse.json({error:"Model and alias required"},{status:400});let r=await (0,b.getModelAliases)();if(Object.entries(r).find(([e,r])=>r===i&&e!==t))return g.NextResponse.json({error:"Alias already in use"},{status:400});return await (0,b.setModelAlias)(t,i),g.NextResponse.json({success:!0,model:t,alias:i})}catch(e){return console.log("Error updating alias:",e),g.NextResponse.json({error:"Failed to update alias"},{status:500})}}e.s(["GET",0,y,"PUT",0,I],86625);var A=e.i(86625);let E=new t.AppRouteRouteModule({definition:{kind:i.RouteKind.APP_ROUTE,page:"/api/models/route",pathname:"/api/models",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/models/route.js",nextConfigOutput:"standalone",userland:A,...{}}),{workAsyncStorage:R,workUnitAsyncStorage:C,serverHooks:F}=E;async function _(e,t,r){r.requestMeta&&(0,a.setRequestMeta)(e,r.requestMeta),E.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let g="/api/models/route";g=g.replace(/\/index$/,"")||"/";let b=await E.prepare(e,t,{srcPage:g,multiZoneDraftMode:!1});if(!b)return t.statusCode=400,t.end("Bad Request"),null==r.waitUntil||r.waitUntil.call(r,Promise.resolve()),null;let{buildId:v,params:y,nextConfig:I,parsedUrl:A,isDraftMode:R,prerenderManifest:C,routerServerContext:F,isOnDemandRevalidate:_,revalidateOnlyGenerated:O,resolvedPathname:P,clientReferenceManifest:k,serverActionsManifest:N}=b,D=(0,s.normalizeAppPath)(g),q=!!(C.dynamicRoutes[D]||C.routes[P]),S=async()=>((null==F?void 0:F.render404)?await F.render404(e,t,A,!1):t.end("This page could not be found"),null);if(q&&!R){let e=!!C.routes[P],t=C.dynamicRoutes[D];if(t&&!1===t.fallback&&!e){if(I.adapterPath)return await S();throw new w.NoFallbackError}}let M=null;!q||E.isDev||R||(M="/index"===(M=P)?"/":M);let j=!0===E.isDev||!q,T=q&&!j;N&&k&&(0,n.setManifestsSingleton)({page:g,clientReferenceManifest:k,serverActionsManifest:N});let L=e.method||"GET",U=(0,o.getTracer)(),B=U.getActiveScopeSpan(),G=!!(null==F?void 0:F.isWrappedByNextServer),H=!!(0,a.getRequestMeta)(e,"minimalMode"),V=(0,a.getRequestMeta)(e,"incrementalCache")||await E.getIncrementalCache(e,I,C,H);null==V||V.resetRequestCache(),globalThis.__incrementalCache=V;let K={params:y,previewProps:C.preview,renderOpts:{experimental:{authInterrupts:!!I.experimental.authInterrupts},cacheComponents:!!I.cacheComponents,supportsDynamicResponse:j,incrementalCache:V,cacheLifeProfiles:I.cacheLife,waitUntil:r.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,i,r,a)=>E.onRequestError(e,t,r,a,F)},sharedContext:{buildId:v}},$=new l.NodeNextRequest(e),X=new l.NodeNextResponse(t),W=c.NextRequestAdapter.fromNodeNextRequest($,(0,c.signalFromNodeResponse)(t));try{let a,n=async e=>E.handle(W,K).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let i=U.getRootSpanAttributes();if(!i)return;if(i.get("next.span_type")!==d.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${i.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let r=i.get("next.route");if(r){let t=`${L} ${r}`;e.setAttributes({"next.route":r,"http.route":r,"next.span_name":t}),e.updateName(t),a&&a!==e&&(a.setAttribute("http.route",r),a.updateName(t))}else e.updateName(`${L} ${g}`)}),s=async a=>{var o,s;let l=async({previousCacheEntry:i})=>{try{if(!H&&_&&O&&!i)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let o=await n(a);e.fetchMetrics=K.renderOpts.fetchMetrics;let s=K.renderOpts.pendingWaitUntil;s&&r.waitUntil&&(r.waitUntil(s),s=void 0);let l=K.renderOpts.collectedTags;if(!q)return await (0,u.sendResponse)($,X,o,K.renderOpts.pendingWaitUntil),null;{let e=await o.blob(),t=(0,m.toNodeOutgoingHttpHeaders)(o.headers);l&&(t[x.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let i=void 0!==K.renderOpts.collectedRevalidate&&!(K.renderOpts.collectedRevalidate>=x.INFINITE_CACHE)&&K.renderOpts.collectedRevalidate,r=void 0===K.renderOpts.collectedExpire||K.renderOpts.collectedExpire>=x.INFINITE_CACHE?void 0:K.renderOpts.collectedExpire;return{value:{kind:f.CachedRouteKind.APP_ROUTE,status:o.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:i,expire:r}}}}catch(t){throw(null==i?void 0:i.isStale)&&await E.onRequestError(e,t,{routerKind:"App Router",routePath:g,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:T,isOnDemandRevalidate:_})},!1,F),t}},c=await E.handleResponse({req:e,nextConfig:I,cacheKey:M,routeKind:i.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:C,isRoutePPREnabled:!1,isOnDemandRevalidate:_,revalidateOnlyGenerated:O,responseGenerator:l,waitUntil:r.waitUntil,isMinimalMode:H});if(!q)return null;if((null==c||null==(o=c.value)?void 0:o.kind)!==f.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==c||null==(s=c.value)?void 0:s.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});H||t.setHeader("x-nextjs-cache",_?"REVALIDATED":c.isMiss?"MISS":c.isStale?"STALE":"HIT"),R&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let d=(0,m.fromNodeOutgoingHttpHeaders)(c.value.headers);return H&&q||d.delete(x.NEXT_CACHE_TAGS_HEADER),!c.cacheControl||t.getHeader("Cache-Control")||d.get("Cache-Control")||d.set("Cache-Control",(0,h.getCacheControlHeader)(c.cacheControl)),await (0,u.sendResponse)($,X,new Response(c.value.body,{headers:d,status:c.value.status||200})),null};G&&B?await s(B):(a=U.getActiveScopeSpan(),await U.withPropagatedContext(e.headers,()=>U.trace(d.BaseServerSpan.handleRequest,{spanName:`${L} ${g}`,kind:o.SpanKind.SERVER,attributes:{"http.method":L,"http.target":e.url}},s),void 0,!G))}catch(t){if(t instanceof w.NoFallbackError||await E.onRequestError(e,t,{routerKind:"App Router",routePath:D,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:T,isOnDemandRevalidate:_})},!1,F),q)throw t;return await (0,u.sendResponse)($,X,new Response(null,{status:500})),null}}e.s(["handler",0,_,"patchFetch",0,function(){return(0,r.patchFetch)({workAsyncStorage:R,workUnitAsyncStorage:C})},"routeModule",0,E,"serverHooks",0,F,"workAsyncStorage",0,R,"workUnitAsyncStorage",0,C],37828)},36498,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0kaoh2i._.js"].map(t=>e.l(t))).then(()=>t(21297)))},66510,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_constants_pricing_0oa_fz9.js"].map(t=>e.l(t))).then(()=>t(28628)))}];
2
2
 
3
3
  //# sourceMappingURL=%5Broot-of-the-server%5D__0y5ae.7._.js.map
@@ -1,3 +1,3 @@
1
- module.exports=[67434,a=>{"use strict";var b=a.i(87945);Object.entries(a.i(13364).AI_PROVIDERS).filter(([,a])=>a.passthroughModels).map(([a])=>a),Object.entries(b.PROVIDER_MODELS).flatMap(([a,b])=>b.map(b=>({provider:a,model:b.id,name:b.name}))),a.s([])},83945,a=>{"use strict";a.i(13364),a.i(67434),a.s(["APP_CONFIG",0,{name:"Endpoint Proxy",description:"AI Infrastructure Management",version:"0.3.88"},"CONSOLE_LOG_CONFIG",0,{maxLines:200,pollIntervalMs:1e3},"THEME_CONFIG",0,{storageKey:"theme",defaultTheme:"system"}],83945)},22259,20226,a=>{"use strict";let b,c;var d=a.i(72131);let e=a=>{let b,c=new Set,d=(a,d)=>{let e="function"==typeof a?a(b):a;if(!Object.is(e,b)){let a=b;b=(null!=d?d:"object"!=typeof e||null===e)?e:Object.assign({},b,e),c.forEach(c=>c(b,a))}},e=()=>b,f={setState:d,getState:e,getInitialState:()=>g,subscribe:a=>(c.add(a),()=>c.delete(a))},g=b=a(d,e,f);return f},f=a=>{let b=a?e(a):e,c=a=>(function(a,b=a=>a){let c=d.default.useSyncExternalStore(a.subscribe,d.default.useCallback(()=>b(a.getState()),[a,b]),d.default.useCallback(()=>b(a.getInitialState()),[a,b]));return d.default.useDebugValue(c),c})(b,a);return Object.assign(c,b),c},g=a=>a?f(a):f;a.s(["create",0,g],20226);let h=a=>b=>{try{let c=a(b);if(c instanceof Promise)return c;return{then:a=>h(a)(c),catch(a){return this}}}catch(a){return{then(a){return this},catch:b=>h(b)(a)}}};var i=a.i(83945);let j=g((b=(a,b)=>({theme:i.THEME_CONFIG.defaultTheme,setTheme:b=>{a({theme:b}),k(b)},toggleTheme:()=>{let c="dark"===b().theme?"light":"dark";a({theme:c}),k(c)},initTheme:()=>{k(b().theme)}}),c={name:i.THEME_CONFIG.storageKey},(a,d,e)=>{let f,g={storage:function(a){let b;try{b=a()}catch(a){return}return{getItem:a=>{var c;let d=a=>null===a?null:JSON.parse(a,void 0),e=null!=(c=b.getItem(a))?c:null;return e instanceof Promise?e.then(d):d(e)},setItem:(a,c)=>b.setItem(a,JSON.stringify(c,void 0)),removeItem:a=>b.removeItem(a)}}(()=>window.localStorage),partialize:a=>a,version:0,merge:(a,b)=>({...b,...a}),...c},i=!1,j=0,k=new Set,l=new Set,m=g.storage;if(!m)return b((...b)=>{console.warn(`[zustand persist middleware] Unable to update item '${g.name}', the given storage is currently unavailable.`),a(...b)},d,e);let n=()=>{let a=g.partialize({...d()});return m.setItem(g.name,{state:a,version:g.version})},o=e.setState;e.setState=(a,b)=>(o(a,b),n());let p=b((...b)=>(a(...b),n()),d,e);e.getInitialState=()=>p;let q=()=>{var b,c;if(!m)return;let e=++j;i=!1,k.forEach(a=>{var b;return a(null!=(b=d())?b:p)});let o=(null==(c=g.onRehydrateStorage)?void 0:c.call(g,null!=(b=d())?b:p))||void 0;return h(m.getItem.bind(m))(g.name).then(a=>{if(a)if("number"!=typeof a.version||a.version===g.version)return[!1,a.state];else{if(g.migrate){let b=g.migrate(a.state,a.version);return b instanceof Promise?b.then(a=>[!0,a]):[!0,b]}console.error("State loaded from storage couldn't be migrated since no migrate function was provided")}return[!1,void 0]}).then(b=>{var c;if(e!==j)return;let[h,i]=b;if(a(f=g.merge(i,null!=(c=d())?c:p),!0),h)return n()}).then(()=>{e===j&&(null==o||o(d(),void 0),f=d(),i=!0,l.forEach(a=>a(f)))}).catch(a=>{e===j&&(null==o||o(void 0,a))})};return e.persist={setOptions:a=>{g={...g,...a},a.storage&&(m=a.storage)},clearStorage:()=>{null==m||m.removeItem(g.name)},getOptions:()=>g,rehydrate:()=>q(),hasHydrated:()=>i,onHydrate:a=>(k.add(a),()=>{k.delete(a)}),onFinishHydration:a=>(l.add(a),()=>{l.delete(a)})},g.skipHydration||q(),f||p}));function k(a){}a.s(["default",0,j],22259)},14931,a=>{"use strict";var b=a.i(87924),c=a.i(72131),d=a.i(22259);a.s(["ThemeProvider",0,function({children:a}){let{initTheme:e}=(0,d.default)();return(0,c.useEffect)(()=>{e()},[e]),(0,b.jsx)(b.Fragment,{children:a})}])},50979,87724,a=>{"use strict";let b="locale";function c(a){return"zh"===a||"zh-CN"===a?"zh-CN":"en"===a?"en":"vi"===a?"vi":"zh-TW"===a?"zh-TW":"ja"===a?"ja":"pt-BR"===a?"pt-BR":"pt-PT"===a?"pt-PT":"ko"===a?"ko":"es"===a?"es":"de"===a?"de":"fr"===a?"fr":"he"===a?"he":"ar"===a?"ar":"ru"===a?"ru":"pl"===a?"pl":"cs"===a?"cs":"nl"===a?"nl":"tr"===a?"tr":"uk"===a?"uk":"tl"===a?"tl":"id"===a?"id":"th"===a?"th":"hi"===a?"hi":"bn"===a?"bn":"ur"===a?"ur":"ro"===a?"ro":"sv"===a?"sv":"it"===a?"it":"el"===a?"el":"hu"===a?"hu":"fi"===a?"fi":"da"===a?"da":"no"===a?"no":"en"}a.s(["DEFAULT_LOCALE",0,"en","LOCALES",0,["en","vi","zh-CN","zh-TW","ja","pt-BR","pt-PT","ko","es","de","fr","he","ar","ru","pl","cs","nl","tr","uk","tl","id","th","hi","bn","ur","ro","sv","it","el","hu","fi","da","no"],"LOCALE_COOKIE",0,b,"normalizeLocale",0,c],87724);let d={},e="en",f=[];async function g(a){if("en"===a){d={};return}try{let b=await fetch(`/i18n/literals/${a}.json`);d=await b.json()}catch(a){console.error("Failed to load translations:",a),d={}}}function h(a){if(!a||"string"!=typeof a)return a;let b=a.trim();return b&&"en"!==e&&d[b]||a}function i(a){if(!a.nodeValue||!a.nodeValue.trim())return;let b=a.parentElement;if(!b)return;let c=b;for(;c;){if(c.hasAttribute&&c.hasAttribute("data-i18n-skip"))return;c=c.parentElement}if(["script","style","code","pre","colgroup","table","thead","tbody","tfoot","tr","select","datalist","optgroup"].includes(b.tagName?.toLowerCase()))return;a._originalText||(a._originalText=a.nodeValue);let d=h(a._originalText);d!==a.nodeValue&&(a.nodeValue=d)}async function j(){}async function k(){e=function(){if("u"<typeof document)return"en";let a=document.cookie.split(";").find(a=>a.trim().startsWith(`${b}=`));return c(a?decodeURIComponent(a.split("=")[1]):"en")}(),await g(e),f.forEach(a=>a()),function(a){let b;if(!a)return;let c=document.createTreeWalker(a,NodeFilter.SHOW_TEXT,null,!1),d=[];for(;b=c.nextNode();)d.push(b);d.forEach(i)}(document.body)}a.s(["initRuntimeI18n",0,j,"reloadTranslations",0,k,"translate",0,h],50979)}];
1
+ module.exports=[67434,a=>{"use strict";var b=a.i(87945);Object.entries(a.i(13364).AI_PROVIDERS).filter(([,a])=>a.passthroughModels).map(([a])=>a),Object.entries(b.PROVIDER_MODELS).flatMap(([a,b])=>b.map(b=>({provider:a,model:b.id,name:b.name}))),a.s([])},83945,a=>{"use strict";a.i(13364),a.i(67434),a.s(["APP_CONFIG",0,{name:"Endpoint Proxy",description:"AI Infrastructure Management",version:"0.3.89"},"CONSOLE_LOG_CONFIG",0,{maxLines:200,pollIntervalMs:1e3},"THEME_CONFIG",0,{storageKey:"theme",defaultTheme:"system"}],83945)},22259,20226,a=>{"use strict";let b,c;var d=a.i(72131);let e=a=>{let b,c=new Set,d=(a,d)=>{let e="function"==typeof a?a(b):a;if(!Object.is(e,b)){let a=b;b=(null!=d?d:"object"!=typeof e||null===e)?e:Object.assign({},b,e),c.forEach(c=>c(b,a))}},e=()=>b,f={setState:d,getState:e,getInitialState:()=>g,subscribe:a=>(c.add(a),()=>c.delete(a))},g=b=a(d,e,f);return f},f=a=>{let b=a?e(a):e,c=a=>(function(a,b=a=>a){let c=d.default.useSyncExternalStore(a.subscribe,d.default.useCallback(()=>b(a.getState()),[a,b]),d.default.useCallback(()=>b(a.getInitialState()),[a,b]));return d.default.useDebugValue(c),c})(b,a);return Object.assign(c,b),c},g=a=>a?f(a):f;a.s(["create",0,g],20226);let h=a=>b=>{try{let c=a(b);if(c instanceof Promise)return c;return{then:a=>h(a)(c),catch(a){return this}}}catch(a){return{then(a){return this},catch:b=>h(b)(a)}}};var i=a.i(83945);let j=g((b=(a,b)=>({theme:i.THEME_CONFIG.defaultTheme,setTheme:b=>{a({theme:b}),k(b)},toggleTheme:()=>{let c="dark"===b().theme?"light":"dark";a({theme:c}),k(c)},initTheme:()=>{k(b().theme)}}),c={name:i.THEME_CONFIG.storageKey},(a,d,e)=>{let f,g={storage:function(a){let b;try{b=a()}catch(a){return}return{getItem:a=>{var c;let d=a=>null===a?null:JSON.parse(a,void 0),e=null!=(c=b.getItem(a))?c:null;return e instanceof Promise?e.then(d):d(e)},setItem:(a,c)=>b.setItem(a,JSON.stringify(c,void 0)),removeItem:a=>b.removeItem(a)}}(()=>window.localStorage),partialize:a=>a,version:0,merge:(a,b)=>({...b,...a}),...c},i=!1,j=0,k=new Set,l=new Set,m=g.storage;if(!m)return b((...b)=>{console.warn(`[zustand persist middleware] Unable to update item '${g.name}', the given storage is currently unavailable.`),a(...b)},d,e);let n=()=>{let a=g.partialize({...d()});return m.setItem(g.name,{state:a,version:g.version})},o=e.setState;e.setState=(a,b)=>(o(a,b),n());let p=b((...b)=>(a(...b),n()),d,e);e.getInitialState=()=>p;let q=()=>{var b,c;if(!m)return;let e=++j;i=!1,k.forEach(a=>{var b;return a(null!=(b=d())?b:p)});let o=(null==(c=g.onRehydrateStorage)?void 0:c.call(g,null!=(b=d())?b:p))||void 0;return h(m.getItem.bind(m))(g.name).then(a=>{if(a)if("number"!=typeof a.version||a.version===g.version)return[!1,a.state];else{if(g.migrate){let b=g.migrate(a.state,a.version);return b instanceof Promise?b.then(a=>[!0,a]):[!0,b]}console.error("State loaded from storage couldn't be migrated since no migrate function was provided")}return[!1,void 0]}).then(b=>{var c;if(e!==j)return;let[h,i]=b;if(a(f=g.merge(i,null!=(c=d())?c:p),!0),h)return n()}).then(()=>{e===j&&(null==o||o(d(),void 0),f=d(),i=!0,l.forEach(a=>a(f)))}).catch(a=>{e===j&&(null==o||o(void 0,a))})};return e.persist={setOptions:a=>{g={...g,...a},a.storage&&(m=a.storage)},clearStorage:()=>{null==m||m.removeItem(g.name)},getOptions:()=>g,rehydrate:()=>q(),hasHydrated:()=>i,onHydrate:a=>(k.add(a),()=>{k.delete(a)}),onFinishHydration:a=>(l.add(a),()=>{l.delete(a)})},g.skipHydration||q(),f||p}));function k(a){}a.s(["default",0,j],22259)},14931,a=>{"use strict";var b=a.i(87924),c=a.i(72131),d=a.i(22259);a.s(["ThemeProvider",0,function({children:a}){let{initTheme:e}=(0,d.default)();return(0,c.useEffect)(()=>{e()},[e]),(0,b.jsx)(b.Fragment,{children:a})}])},50979,87724,a=>{"use strict";let b="locale";function c(a){return"zh"===a||"zh-CN"===a?"zh-CN":"en"===a?"en":"vi"===a?"vi":"zh-TW"===a?"zh-TW":"ja"===a?"ja":"pt-BR"===a?"pt-BR":"pt-PT"===a?"pt-PT":"ko"===a?"ko":"es"===a?"es":"de"===a?"de":"fr"===a?"fr":"he"===a?"he":"ar"===a?"ar":"ru"===a?"ru":"pl"===a?"pl":"cs"===a?"cs":"nl"===a?"nl":"tr"===a?"tr":"uk"===a?"uk":"tl"===a?"tl":"id"===a?"id":"th"===a?"th":"hi"===a?"hi":"bn"===a?"bn":"ur"===a?"ur":"ro"===a?"ro":"sv"===a?"sv":"it"===a?"it":"el"===a?"el":"hu"===a?"hu":"fi"===a?"fi":"da"===a?"da":"no"===a?"no":"en"}a.s(["DEFAULT_LOCALE",0,"en","LOCALES",0,["en","vi","zh-CN","zh-TW","ja","pt-BR","pt-PT","ko","es","de","fr","he","ar","ru","pl","cs","nl","tr","uk","tl","id","th","hi","bn","ur","ro","sv","it","el","hu","fi","da","no"],"LOCALE_COOKIE",0,b,"normalizeLocale",0,c],87724);let d={},e="en",f=[];async function g(a){if("en"===a){d={};return}try{let b=await fetch(`/i18n/literals/${a}.json`);d=await b.json()}catch(a){console.error("Failed to load translations:",a),d={}}}function h(a){if(!a||"string"!=typeof a)return a;let b=a.trim();return b&&"en"!==e&&d[b]||a}function i(a){if(!a.nodeValue||!a.nodeValue.trim())return;let b=a.parentElement;if(!b)return;let c=b;for(;c;){if(c.hasAttribute&&c.hasAttribute("data-i18n-skip"))return;c=c.parentElement}if(["script","style","code","pre","colgroup","table","thead","tbody","tfoot","tr","select","datalist","optgroup"].includes(b.tagName?.toLowerCase()))return;a._originalText||(a._originalText=a.nodeValue);let d=h(a._originalText);d!==a.nodeValue&&(a.nodeValue=d)}async function j(){}async function k(){e=function(){if("u"<typeof document)return"en";let a=document.cookie.split(";").find(a=>a.trim().startsWith(`${b}=`));return c(a?decodeURIComponent(a.split("=")[1]):"en")}(),await g(e),f.forEach(a=>a()),function(a){let b;if(!a)return;let c=document.createTreeWalker(a,NodeFilter.SHOW_TEXT,null,!1),d=[];for(;b=c.nextNode();)d.push(b);d.forEach(i)}(document.body)}a.s(["initRuntimeI18n",0,j,"reloadTranslations",0,k,"translate",0,h],50979)}];
2
2
 
3
3
  //# sourceMappingURL=src_0_xhepz._.js.map
@@ -1,3 +1,3 @@
1
- module.exports=[69617,a=>{"use strict";var b=a.i(87924),c=a.i(72131),d=a.i(41212),e=a.i(50944),f=a.i(38246),g=a.i(71987);a.i(7284);var h=a.i(12532),i=a.i(1374),j=a.i(56882),k=a.i(40695),l=a.i(78236),m=a.i(39204),n=a.i(13100),o=a.i(73428),o=o,p=a.i(74862),p=p,q=a.i(76454),q=q,r=a.i(88526),r=r,s=a.i(2231),t=a.i(65928),u=a.i(13364);a.i(67434);var v=a.i(87945),w=a.i(74208);let x=new Map,y={"openrouter-free":a=>a.filter(a=>a.pricing?.prompt==="0"&&a.pricing?.completion==="0"&&a.context_length>=2e5).map(a=>({id:a.id,name:a.name,contextLength:a.context_length})).sort((a,b)=>b.contextLength-a.contextLength)};async function z(a){if(!a?.url||!a?.type)return[];let b=x.get(a.url);if(b&&Date.now()<b.expiresAt)return b.data;try{let b=await fetch(a.url);if(!b.ok)return[];let c=await b.json(),d=c.data??c.models??c,e=y[a.type],f=e?e(Array.isArray(d)?d:[]):[];return x.set(a.url,{data:f,expiresAt:Date.now()+6e5}),f}catch{return[]}}function A({model:a,fullModel:c,alias:d,copied:e,onCopy:f,testStatus:g,isCustom:h,isFree:i,onDeleteAlias:j,onTest:k,isTesting:l}){let m="ok"===g?"#22c55e":"error"===g?"#ef4444":void 0;return(0,b.jsx)("div",{className:`group px-3 py-2 rounded-lg border ${"ok"===g?"border-green-500/40":"error"===g?"border-red-500/40":"border-border"} hover:bg-sidebar/50`,children:(0,b.jsxs)("div",{className:"flex items-center gap-2",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-base",style:m?{color:m}:void 0,children:"ok"===g?"check_circle":"error"===g?"cancel":"smart_toy"}),(0,b.jsx)("code",{className:"text-xs text-text-muted font-mono bg-sidebar px-1.5 py-0.5 rounded",children:c}),k&&(0,b.jsxs)("div",{className:"relative group/btn",children:[(0,b.jsx)("button",{onClick:k,disabled:l,className:`p-0.5 hover:bg-sidebar rounded text-text-muted hover:text-primary transition-opacity ${l?"opacity-100":"opacity-0 group-hover:opacity-100"}`,children:(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",style:l?{animation:"spin 1s linear infinite"}:void 0,children:l?"progress_activity":"science"})}),(0,b.jsx)("span",{className:"pointer-events-none absolute mt-1 top-5 left-1/2 -translate-x-1/2 text-[10px] text-text-muted whitespace-nowrap opacity-0 group-hover/btn:opacity-100 transition-opacity",children:l?"Testing...":"Test"})]}),(0,b.jsxs)("div",{className:"relative group/btn",children:[(0,b.jsx)("button",{onClick:()=>f(c,`model-${a.id}`),className:"p-0.5 hover:bg-sidebar rounded text-text-muted hover:text-primary",children:(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",children:e===`model-${a.id}`?"check":"content_copy"})}),(0,b.jsx)("span",{className:"pointer-events-none absolute mt-1 top-5 left-1/2 -translate-x-1/2 text-[10px] text-text-muted whitespace-nowrap opacity-0 group-hover/btn:opacity-100 transition-opacity",children:e===`model-${a.id}`?"Copied!":"Copy"})]}),h&&(0,b.jsx)("button",{onClick:j,className:"p-0.5 hover:bg-red-500/10 rounded text-text-muted hover:text-red-500 opacity-0 group-hover:opacity-100 transition-opacity ml-auto",title:"Remove custom model",children:(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",children:"close"})})]})})}function B({modelId:a,fullModel:c,copied:d,onCopy:e,onDeleteAlias:f,onTest:g,testStatus:h,isTesting:i}){let j="ok"===h?"#22c55e":"error"===h?"#ef4444":void 0;return(0,b.jsxs)("div",{className:`flex items-center gap-3 p-3 rounded-lg border ${"ok"===h?"border-green-500/40":"error"===h?"border-red-500/40":"border-border"} hover:bg-sidebar/50`,children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-base text-text-muted",style:j?{color:j}:void 0,children:"ok"===h?"check_circle":"error"===h?"cancel":"smart_toy"}),(0,b.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,b.jsx)("p",{className:"text-sm font-medium truncate",children:a}),(0,b.jsxs)("div",{className:"flex items-center gap-1 mt-1",children:[(0,b.jsx)("code",{className:"text-xs text-text-muted font-mono bg-sidebar px-1.5 py-0.5 rounded",children:c}),isFree&&(0,b.jsx)("span",{className:"text-[10px] font-medium px-1.5 py-0.5 rounded bg-green-500/10 text-green-600 dark:text-green-400",children:"Free"}),(0,b.jsxs)("div",{className:"relative group/btn",children:[(0,b.jsx)("button",{onClick:()=>e(c,`model-${a}`),className:"p-0.5 hover:bg-sidebar rounded text-text-muted hover:text-primary",children:(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",children:d===`model-${a}`?"check":"content_copy"})}),(0,b.jsx)("span",{className:"pointer-events-none absolute top-5 left-1/2 -translate-x-1/2 text-[10px] text-text-muted whitespace-nowrap opacity-0 group-hover/btn:opacity-100 transition-opacity",children:d===`model-${a}`?"Copied!":"Copy"})]}),g&&(0,b.jsxs)("div",{className:"relative group/btn",children:[(0,b.jsx)("button",{onClick:g,disabled:i,className:"p-0.5 hover:bg-sidebar rounded text-text-muted hover:text-primary transition-colors",children:(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",style:i?{animation:"spin 1s linear infinite"}:void 0,children:i?"progress_activity":"science"})}),(0,b.jsx)("span",{className:"pointer-events-none absolute top-5 left-1/2 -translate-x-1/2 text-[10px] text-text-muted whitespace-nowrap opacity-0 group-hover/btn:opacity-100 transition-opacity",children:i?"Testing...":"Test"})]})]})]}),(0,b.jsx)("button",{onClick:f,className:"p-1 hover:bg-red-50 rounded text-red-500",title:"Remove model",children:(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",children:"delete"})})]})}function C({providerStorageAlias:a,providerDisplayAlias:d,modelAliases:e,copied:f,onCopy:g,onSetAlias:h,onDeleteAlias:j,connections:k,isAnthropic:l}){let[m,n]=(0,c.useState)(""),[o,p]=(0,c.useState)(!1),[q,r]=(0,c.useState)(!1),[s,t]=(0,c.useState)(null),[u,v]=(0,c.useState)({}),w=async b=>{if(!s){t(b);try{let c=await fetch("/api/models/test",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:`${a}/${b}`})}),d=await c.json();v(a=>({...a,[b]:d.ok?"ok":"error"}))}catch{v(a=>({...a,[b]:"error"}))}finally{t(null)}}},x=Object.entries(e).filter(([,b])=>b.startsWith(`${a}/`)).map(([b,c])=>({modelId:c.replace(`${a}/`,""),fullModel:c,alias:b})),y=b=>{let c,f=`${a}/${b}`;if(Object.values(e).includes(f))return null;let g=(c=b.split("/"))[c.length-1];if(!e[g])return g;let h=`${d}-${g}`;return e[h]?null:h},z=async()=>{if(!m.trim()||o)return;let b=m.trim(),c=y(b);if(!c)return void alert("All suggested aliases already exist. Please choose a different model or remove conflicting aliases.");p(!0);try{await h(b,c,a),n("")}catch(a){console.log("Error adding model:",a)}finally{p(!1)}},A=async()=>{if(q)return;let b=k.find(a=>!1!==a.isActive);if(b){r(!0);try{let c=await fetch(`/api/providers/${b.id}/models`),d=await c.json();if(!c.ok)return void alert(d.error||"Failed to import models");let e=d.models||[];if(0===e.length)return void alert("No models returned from /models.");let f=0;for(let b of e){let c=b.id||b.name||b.model;if(!c)continue;let d=y(c);d&&(await h(c,d,a),f+=1)}0===f&&alert("No new models were added.")}catch(a){console.log("Error importing models:",a)}finally{r(!1)}}},D=k.some(a=>!1!==a.isActive);return(0,b.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,b.jsxs)("p",{className:"text-sm text-text-muted",children:["Add ",l?"Anthropic":"OpenAI","-compatible models manually or import them from the /models endpoint."]}),(0,b.jsxs)("div",{className:"flex items-end gap-2 flex-wrap",children:[(0,b.jsxs)("div",{className:"flex-1 min-w-[240px]",children:[(0,b.jsx)("label",{htmlFor:"new-compatible-model-input",className:"text-xs text-text-muted mb-1 block",children:"Model ID"}),(0,b.jsx)("input",{id:"new-compatible-model-input",type:"text",value:m,onChange:a=>n(a.target.value),onKeyDown:a=>"Enter"===a.key&&z(),placeholder:l?"claude-3-opus-20240229":"gpt-4o",className:"w-full px-3 py-2 text-sm border border-border rounded-lg bg-background focus:outline-none focus:border-primary"})]}),(0,b.jsx)(i.Button,{size:"sm",icon:"add",onClick:z,disabled:!m.trim()||o,children:o?"Adding...":"Add"}),(0,b.jsx)(i.Button,{size:"sm",variant:"secondary",icon:"download",onClick:A,disabled:!D||q,children:q?"Importing...":"Import from /models"})]}),!D&&(0,b.jsx)("p",{className:"text-xs text-text-muted",children:"Add a connection to enable importing models."}),x.length>0&&(0,b.jsx)("div",{className:"flex flex-col gap-3",children:x.map(({modelId:a,fullModel:c,alias:e})=>(0,b.jsx)(B,{modelId:a,fullModel:`${d}/${a}`,copied:f,onCopy:g,onDeleteAlias:()=>j(e),onTest:k.length>0?()=>w(a):void 0,testStatus:u[a],isTesting:s===a},c))})]})}function D({until:a}){let[d,e]=(0,c.useState)("");return((0,c.useEffect)(()=>{let b=()=>{let b=new Date(a).getTime()-Date.now();if(b<=0)return void e("");let c=Math.floor(b/1e3);if(c<60)e(`${c}s`);else if(c<3600)e(`${Math.floor(c/60)}m ${c%60}s`);else{let a=Math.floor(c/3600),b=Math.floor(c%3600/60);e(`${a}h ${b}m`)}};b();let c=setInterval(b,1e3);return()=>clearInterval(c)},[a]),d)?(0,b.jsxs)("span",{className:"text-xs text-orange-500 font-mono",children:["⏱ ",d]}):null}function E({connection:a,proxyPools:d,isOAuth:e,isFirst:f,isLast:g,onMoveUp:h,onMoveDown:i,onToggleActive:k,onUpdateProxy:l,onEdit:m,onDelete:n}){let[o,p]=(0,c.useState)(!1),[q,r]=(0,c.useState)(!1),t=(0,c.useRef)(null),u=new Map((d||[]).map(a=>[a.id,a])),v=a.providerSpecificData?.proxyPoolId||null,w=v?u.get(v):null,x=a.providerSpecificData?.connectionProxyEnabled===!0&&!!a.providerSpecificData?.connectionProxyUrl,y=!!v||x,z=w?`Pool: ${w.name}`:v?`Pool: ${v} (inactive/missing)`:x?`Legacy: ${a.providerSpecificData?.connectionProxyUrl}`:"",A="";if(w?.proxyUrl||a.providerSpecificData?.connectionProxyUrl){let b=w?.proxyUrl||a.providerSpecificData?.connectionProxyUrl;try{let a=new URL(b);A=`${a.protocol}//${a.hostname}${a.port?`:${a.port}`:""}`}catch{A=b}}let B=w?.noProxy||a.providerSpecificData?.connectionNoProxy||"",C="default";w?.isActive===!0?C="success":(v||x)&&(C="error"),(0,c.useEffect)(()=>{if(!o)return;let a=a=>{t.current&&!t.current.contains(a.target)&&p(!1)};return document.addEventListener("mousedown",a),()=>document.removeEventListener("mousedown",a)},[o]);let F=async a=>{r(!0);try{await l("__none__"===a?null:a)}finally{r(!1),p(!1)}},G=e?a.name||a.email||a.displayName||"OAuth Account":a.name,[H,I]=(0,c.useState)(!1),J=Object.entries(a).filter(([a])=>a.startsWith("modelLock_")).map(([,a])=>a).filter(a=>!!a).sort()[0]||null;(0,c.useEffect)(()=>{let b=()=>{I(!!Object.entries(a).filter(([a])=>a.startsWith("modelLock_")).map(([,a])=>a).filter(a=>a&&new Date(a).getTime()>Date.now()).sort()[0])};b();let c=J?setInterval(b,1e3):null;return()=>{c&&clearInterval(c)}},[J]);let K="unavailable"!==a.testStatus||H?a.testStatus:"active";return(0,b.jsxs)("div",{className:`group flex items-center justify-between p-3 rounded-lg hover:bg-black/[0.02] dark:hover:bg-white/[0.02] transition-colors ${!1===a.isActive?"opacity-60":""}`,children:[(0,b.jsxs)("div",{className:"flex items-center gap-3 flex-1 min-w-0",children:[(0,b.jsxs)("div",{className:"flex flex-col",children:[(0,b.jsx)("button",{onClick:h,disabled:f,className:`p-0.5 rounded ${f?"text-text-muted/30 cursor-not-allowed":"hover:bg-sidebar text-text-muted hover:text-primary"}`,children:(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",children:"keyboard_arrow_up"})}),(0,b.jsx)("button",{onClick:i,disabled:g,className:`p-0.5 rounded ${g?"text-text-muted/30 cursor-not-allowed":"hover:bg-sidebar text-text-muted hover:text-primary"}`,children:(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",children:"keyboard_arrow_down"})})]}),(0,b.jsx)("span",{className:"material-symbols-outlined text-base text-text-muted",children:e?"lock":"key"}),(0,b.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,b.jsx)("p",{className:"text-sm font-medium truncate",children:G}),(0,b.jsxs)("div",{className:"flex items-center gap-2 mt-1",children:[(0,b.jsx)(j.Badge,{variant:!1===a.isActive?"default":"active"===K||"success"===K?"success":"error"===K||"expired"===K||"unavailable"===K?"error":"default",size:"sm",dot:!0,children:!1===a.isActive?"disabled":K||"Unknown"}),y&&(0,b.jsx)(j.Badge,{variant:C,size:"sm",children:"Proxy"}),H&&!1!==a.isActive&&(0,b.jsx)(D,{until:J}),a.lastError&&!1!==a.isActive&&(0,b.jsx)("span",{className:"text-xs text-red-500 truncate max-w-[300px]",title:a.lastError,children:a.lastError}),(0,b.jsxs)("span",{className:"text-xs text-text-muted",children:["#",a.priority]}),a.globalPriority&&(0,b.jsxs)("span",{className:"text-xs text-text-muted",children:["Auto: ",a.globalPriority]})]}),y&&(0,b.jsxs)("div",{className:"mt-1 flex items-center gap-2 flex-wrap",children:[(0,b.jsx)("span",{className:"text-[11px] text-text-muted truncate max-w-[420px]",title:z,children:z}),A&&(0,b.jsx)("code",{className:"text-[10px] font-mono bg-black/5 dark:bg-white/5 px-1 py-0.5 rounded text-text-muted",children:A}),B&&(0,b.jsxs)("span",{className:"text-[11px] text-text-muted truncate max-w-[320px]",title:B,children:["no_proxy: ",B]})]})]})]}),(0,b.jsxs)("div",{className:"flex items-center gap-2",children:[(0,b.jsxs)("div",{className:"flex gap-1",children:[(d||[]).length>0&&(0,b.jsxs)("div",{className:"relative",ref:t,children:[(0,b.jsxs)("button",{onClick:()=>p(a=>!a),className:`flex flex-col items-center px-2 py-1 rounded hover:bg-black/5 dark:hover:bg-white/5 transition-colors ${y?"text-primary":"text-text-muted hover:text-primary"}`,disabled:q,children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:q?"progress_activity":"lan"}),(0,b.jsx)("span",{className:"text-[10px] leading-tight",children:"Proxy"})]}),o&&(0,b.jsxs)("div",{className:"absolute right-0 top-full mt-1 z-50 bg-bg border border-border rounded-lg shadow-lg py-1 min-w-[160px]",children:[(0,b.jsx)("button",{onClick:()=>F("__none__"),className:`w-full text-left px-3 py-1.5 text-sm hover:bg-black/5 dark:hover:bg-white/5 ${!v?"text-primary font-medium":"text-text-main"}`,children:"None"}),(d||[]).map(a=>(0,b.jsx)("button",{onClick:()=>F(a.id),className:`w-full text-left px-3 py-1.5 text-sm hover:bg-black/5 dark:hover:bg-white/5 ${v===a.id?"text-primary font-medium":"text-text-main"}`,children:a.name},a.id))]})]}),(0,b.jsxs)("button",{onClick:m,className:"flex flex-col items-center px-2 py-1 rounded hover:bg-black/5 dark:hover:bg-white/5 text-text-muted hover:text-primary",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:"edit"}),(0,b.jsx)("span",{className:"text-[10px] leading-tight",children:"Edit"})]}),(0,b.jsxs)("button",{onClick:n,className:"flex flex-col items-center px-2 py-1 rounded hover:bg-red-500/10 text-red-500",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:"delete"}),(0,b.jsx)("span",{className:"text-[10px] leading-tight",children:"Delete"})]})]}),(0,b.jsx)(s.Toggle,{size:"sm",checked:a.isActive??!0,onChange:k,title:a.isActive??!0?"Disable connection":"Enable connection"})]})]})}function F({isOpen:a,provider:d,providerName:e,isCompatible:f,isAnthropic:g,proxyPools:h,onSave:m,onClose:n}){let o="__none__",[p,q]=(0,c.useState)({name:"",apiKey:"",priority:1,proxyPoolId:o}),[r,s]=(0,c.useState)(!1),[u,v]=(0,c.useState)(null),[w,x]=(0,c.useState)(!1),y=async()=>{s(!0);try{let a=await fetch("/api/providers/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:d,apiKey:p.apiKey})}),b=await a.json();v(b.valid?"success":"failed")}catch{v("failed")}finally{s(!1)}},z=async()=>{if(d&&p.apiKey){x(!0);try{let a=!1;try{s(!0),v(null);let b=await fetch("/api/providers/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:d,apiKey:p.apiKey})});a=!!(await b.json()).valid,v(a?"success":"failed")}catch{v("failed")}finally{s(!1)}await m({name:p.name,apiKey:p.apiKey,priority:p.priority,proxyPoolId:p.proxyPoolId===o?null:p.proxyPoolId,testStatus:a?"active":"unknown",providerSpecificData:void 0})}finally{x(!1)}}};return d?(0,b.jsx)(l.Modal,{isOpen:a,title:`Add ${e||d} API Key`,onClose:n,children:(0,b.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,b.jsx)(k.Input,{label:"Name",value:p.name,onChange:a=>q({...p,name:a.target.value}),placeholder:"Production Key"}),(0,b.jsxs)("div",{className:"flex gap-2",children:[(0,b.jsx)(k.Input,{label:"API Key",type:"password",value:p.apiKey,onChange:a=>q({...p,apiKey:a.target.value}),className:"flex-1"}),(0,b.jsx)("div",{className:"pt-6",children:(0,b.jsx)(i.Button,{onClick:y,disabled:!p.apiKey||r||w,variant:"secondary",children:r?"Checking...":"Check"})})]}),u&&(0,b.jsx)(j.Badge,{variant:"success"===u?"success":"error",children:"success"===u?"Valid":"Invalid"}),f&&(0,b.jsx)("p",{className:"text-xs text-text-muted",children:g?`Validation checks ${e||"Anthropic Compatible"} by verifying the API key.`:`Validation checks ${e||"OpenAI Compatible"} via /models on your base URL.`}),(0,b.jsx)(k.Input,{label:"Priority",type:"number",value:p.priority,onChange:a=>q({...p,priority:Number.parseInt(a.target.value)||1})}),(0,b.jsx)(t.Select,{label:"Proxy Pool",value:p.proxyPoolId,onChange:a=>q({...p,proxyPoolId:a.target.value}),options:[{value:o,label:"None"},...(h||[]).map(a=>({value:a.id,label:a.name}))],placeholder:"None"}),0===(h||[]).length&&(0,b.jsx)("p",{className:"text-xs text-text-muted",children:"No active proxy pools available. Create one in Proxy Pools page first."}),(0,b.jsx)("p",{className:"text-xs text-text-muted",children:"Legacy manual proxy fields are still accepted by API for backward compatibility."}),(0,b.jsxs)("div",{className:"flex gap-2",children:[(0,b.jsx)(i.Button,{onClick:z,fullWidth:!0,disabled:!p.name||!p.apiKey||w,children:w?"Saving...":"Save"}),(0,b.jsx)(i.Button,{onClick:n,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})}):null}function G({isOpen:a,connection:d,proxyPools:e,onSave:f,onClose:g}){let[h,m]=(0,c.useState)({name:"",priority:1,apiKey:""}),[n,o]=(0,c.useState)(!1),[p,q]=(0,c.useState)(null),[r,s]=(0,c.useState)(!1),[t,v]=(0,c.useState)(null),[w,x]=(0,c.useState)(!1);(0,c.useEffect)(()=>{d&&(m({name:d.name||"",priority:d.priority||1,apiKey:""}),q(null),v(null))},[d]);let y=async()=>{if(d?.provider){o(!0),q(null);try{let a=await fetch(`/api/providers/${d.id}/test`,{method:"POST"}),b=await a.json();q(b.valid?"success":"failed")}catch{q("failed")}finally{o(!1)}}},z=async()=>{if(d?.provider&&h.apiKey){s(!0),v(null);try{let a=await fetch("/api/providers/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:d.provider,apiKey:h.apiKey})}),b=await a.json();v(b.valid?"success":"failed")}catch{v("failed")}finally{s(!1)}}},A=async()=>{x(!0);try{let a={name:h.name,priority:h.priority};if(!B&&h.apiKey){a.apiKey=h.apiKey;let b="success"===t;if(!b)try{s(!0),v(null);let a=await fetch("/api/providers/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:d.provider,apiKey:h.apiKey})});b=!!(await a.json()).valid,v(b?"success":"failed")}catch{v("failed")}finally{s(!1)}b&&(a.testStatus="active",a.lastError=null,a.lastErrorAt=null)}await f(a)}finally{x(!1)}};if(!d)return null;let B="oauth"===d.authType,C=(0,u.isOpenAICompatibleProvider)(d.provider)||(0,u.isAnthropicCompatibleProvider)(d.provider);return(0,b.jsx)(l.Modal,{isOpen:a,title:"Edit Connection",onClose:g,children:(0,b.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,b.jsx)(k.Input,{label:"Name",value:h.name,onChange:a=>m({...h,name:a.target.value}),placeholder:B?"Account name":"Production Key"}),B&&d.email&&(0,b.jsxs)("div",{className:"bg-sidebar/50 p-3 rounded-lg",children:[(0,b.jsx)("p",{className:"text-sm text-text-muted mb-1",children:"Email"}),(0,b.jsx)("p",{className:"font-medium",children:d.email})]}),(0,b.jsx)(k.Input,{label:"Priority",type:"number",value:h.priority,onChange:a=>m({...h,priority:Number.parseInt(a.target.value)||1})}),!B&&(0,b.jsxs)(b.Fragment,{children:[(0,b.jsxs)("div",{className:"flex gap-2",children:[(0,b.jsx)(k.Input,{label:"API Key",type:"password",value:h.apiKey,onChange:a=>m({...h,apiKey:a.target.value}),placeholder:"Enter new API key",hint:"Leave blank to keep the current API key.",className:"flex-1"}),(0,b.jsx)("div",{className:"pt-6",children:(0,b.jsx)(i.Button,{onClick:z,disabled:!h.apiKey||r||w,variant:"secondary",children:r?"Checking...":"Check"})})]}),t&&(0,b.jsx)(j.Badge,{variant:"success"===t?"success":"error",children:"success"===t?"Valid":"Invalid"})]}),!C&&(0,b.jsxs)("div",{className:"flex items-center gap-3",children:[(0,b.jsx)(i.Button,{onClick:y,variant:"secondary",disabled:n,children:n?"Testing...":"Test Connection"}),p&&(0,b.jsx)(j.Badge,{variant:"success"===p?"success":"error",children:"success"===p?"Valid":"Failed"})]}),(0,b.jsxs)("div",{className:"flex gap-2",children:[(0,b.jsx)(i.Button,{onClick:A,fullWidth:!0,disabled:w,children:w?"Saving...":"Save"}),(0,b.jsx)(i.Button,{onClick:g,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})})}function H({isOpen:a,node:d,onSave:e,onClose:f,isAnthropic:g}){let[h,m]=(0,c.useState)({name:"",prefix:"",apiType:"chat",baseUrl:"https://api.openai.com/v1"}),[n,o]=(0,c.useState)(!1),[p,q]=(0,c.useState)(""),[r,s]=(0,c.useState)(""),[u,v]=(0,c.useState)(!1),[w,x]=(0,c.useState)(null);(0,c.useEffect)(()=>{d&&m({name:d.name||"",prefix:d.prefix||"",apiType:d.apiType||"chat",baseUrl:d.baseUrl||(g?"https://api.anthropic.com/v1":"https://api.openai.com/v1")})},[d,g]);let y=async()=>{if(h.name.trim()&&h.prefix.trim()&&h.baseUrl.trim()){o(!0);try{let a={name:h.name,prefix:h.prefix,baseUrl:h.baseUrl};g||(a.apiType=h.apiType),await e(a)}finally{o(!1)}}},z=async()=>{v(!0);try{let a=await fetch("/api/provider-nodes/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({baseUrl:h.baseUrl,apiKey:p,type:g?"anthropic-compatible":"openai-compatible",modelId:r.trim()||void 0})}),b=await a.json();x(b.valid?"success":"failed")}catch{x("failed")}finally{v(!1)}};return d?(0,b.jsx)(l.Modal,{isOpen:a,title:`Edit ${g?"Anthropic":"OpenAI"} Compatible`,onClose:f,children:(0,b.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,b.jsx)(k.Input,{label:"Name",value:h.name,onChange:a=>m({...h,name:a.target.value}),placeholder:`${g?"Anthropic":"OpenAI"} Compatible (Prod)`,hint:"Required. A friendly label for this node."}),(0,b.jsx)(k.Input,{label:"Prefix",value:h.prefix,onChange:a=>m({...h,prefix:a.target.value}),placeholder:g?"ac-prod":"oc-prod",hint:"Required. Used as the provider prefix for model IDs."}),!g&&(0,b.jsx)(t.Select,{label:"API Type",options:[{value:"chat",label:"Chat Completions"},{value:"responses",label:"Responses API"}],value:h.apiType,onChange:a=>m({...h,apiType:a.target.value})}),(0,b.jsx)(k.Input,{label:"Base URL",value:h.baseUrl,onChange:a=>m({...h,baseUrl:a.target.value}),placeholder:g?"https://api.anthropic.com/v1":"https://api.openai.com/v1",hint:`Use the base URL (ending in /v1) for your ${g?"Anthropic":"OpenAI"}-compatible API.`}),(0,b.jsxs)("div",{className:"flex gap-2",children:[(0,b.jsx)(k.Input,{label:"API Key (for Check)",type:"password",value:p,onChange:a=>q(a.target.value),className:"flex-1"}),(0,b.jsx)("div",{className:"pt-6",children:(0,b.jsx)(i.Button,{onClick:z,disabled:!p||u||!h.baseUrl.trim(),variant:"secondary",children:u?"Checking...":"Check"})})]}),(0,b.jsx)(k.Input,{label:"Model ID (optional)",value:r,onChange:a=>s(a.target.value),placeholder:"e.g. my-model-id",hint:"If provider lacks /models endpoint, enter a model ID to validate via chat/completions instead."}),w&&(0,b.jsx)(j.Badge,{variant:"success"===w?"success":"error",children:"success"===w?"Valid":"Invalid"}),(0,b.jsxs)("div",{className:"flex gap-2",children:[(0,b.jsx)(i.Button,{onClick:y,fullWidth:!0,disabled:!h.name.trim()||!h.prefix.trim()||!h.baseUrl.trim()||n,children:n?"Saving...":"Save"}),(0,b.jsx)(i.Button,{onClick:f,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})}):null}function I({isOpen:a,providerAlias:d,providerDisplayAlias:e,onSave:f,onClose:g}){let[h,j]=(0,c.useState)(""),[k,m]=(0,c.useState)(null),[n,o]=(0,c.useState)(""),[p,q]=(0,c.useState)(!1);(0,c.useEffect)(()=>{a&&(j(""),m(null),o(""))},[a]);let r=async()=>{if(h.trim()){m("testing"),o("");try{let a=await fetch("/api/models/test",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:`${d}/${h.trim()}`})}),b=await a.json();m(b.ok?"ok":"error"),o(b.error||"")}catch(a){m("error"),o(a.message)}}},s=async()=>{if(h.trim()&&!p){q(!0);try{await f(h.trim())}finally{q(!1)}}};return(0,b.jsx)(l.Modal,{isOpen:a,onClose:g,title:"Add Custom Model",children:(0,b.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,b.jsxs)("div",{children:[(0,b.jsx)("label",{className:"text-sm font-medium mb-1.5 block",children:"Model ID"}),(0,b.jsxs)("div",{className:"flex gap-2",children:[(0,b.jsx)("input",{type:"text",value:h,onChange:a=>{j(a.target.value),m(null),o("")},onKeyDown:a=>{"Enter"===a.key&&r()},placeholder:"e.g. claude-opus-4-5",className:"flex-1 px-3 py-2 text-sm border border-border rounded-lg bg-background focus:outline-none focus:border-primary",autoFocus:!0}),(0,b.jsx)(i.Button,{variant:"secondary",icon:"science",loading:"testing"===k,onClick:r,disabled:!h.trim()||"testing"===k,children:"testing"===k?"Testing...":"Test"})]}),(0,b.jsxs)("p",{className:"text-xs text-text-muted mt-1",children:["Sent to provider as: ",(0,b.jsx)("code",{className:"font-mono bg-sidebar px-1 rounded",children:h.trim()||"model-id"})]})]}),"ok"===k&&(0,b.jsxs)("div",{className:"flex items-center gap-2 text-sm text-green-600",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-base",children:"check_circle"}),"Model is reachable"]}),"error"===k&&(0,b.jsxs)("div",{className:"flex items-start gap-2 text-sm text-red-500",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-base shrink-0",children:"cancel"}),(0,b.jsx)("span",{children:n||"Model not reachable"})]}),(0,b.jsxs)("div",{className:"flex gap-2 pt-1",children:[(0,b.jsx)(i.Button,{onClick:g,variant:"ghost",fullWidth:!0,size:"sm",children:"Cancel"}),(0,b.jsx)(i.Button,{onClick:s,fullWidth:!0,size:"sm",disabled:!h.trim()||p,children:p?"Adding...":"Add Model"})]})]})})}A.propTypes={model:d.default.shape({id:d.default.string.isRequired}).isRequired,fullModel:d.default.string.isRequired,alias:d.default.string,copied:d.default.string,onCopy:d.default.func.isRequired,testStatus:d.default.oneOf(["ok","error"]),isCustom:d.default.bool,isFree:d.default.bool,onDeleteAlias:d.default.func,onTest:d.default.func,isTesting:d.default.bool},d.default.string.isRequired,d.default.object.isRequired,d.default.string,d.default.func.isRequired,d.default.func.isRequired,d.default.func.isRequired,B.propTypes={modelId:d.default.string.isRequired,fullModel:d.default.string.isRequired,copied:d.default.string,onCopy:d.default.func.isRequired,onDeleteAlias:d.default.func.isRequired,onTest:d.default.func,testStatus:d.default.oneOf(["ok","error"]),isTesting:d.default.bool},C.propTypes={providerStorageAlias:d.default.string.isRequired,providerDisplayAlias:d.default.string.isRequired,modelAliases:d.default.object.isRequired,copied:d.default.string,onCopy:d.default.func.isRequired,onSetAlias:d.default.func.isRequired,onDeleteAlias:d.default.func.isRequired,connections:d.default.arrayOf(d.default.shape({id:d.default.string,isActive:d.default.bool})).isRequired,isAnthropic:d.default.bool},D.propTypes={until:d.default.string.isRequired},E.propTypes={connection:d.default.shape({id:d.default.string,name:d.default.string,email:d.default.string,displayName:d.default.string,modelLockUntil:d.default.string,testStatus:d.default.string,isActive:d.default.bool,lastError:d.default.string,priority:d.default.number,globalPriority:d.default.number}).isRequired,proxyPools:d.default.arrayOf(d.default.shape({id:d.default.string,name:d.default.string,proxyUrl:d.default.string,noProxy:d.default.string,isActive:d.default.bool})),isOAuth:d.default.bool.isRequired,isFirst:d.default.bool.isRequired,isLast:d.default.bool.isRequired,onMoveUp:d.default.func.isRequired,onMoveDown:d.default.func.isRequired,onToggleActive:d.default.func.isRequired,onUpdateProxy:d.default.func,onEdit:d.default.func.isRequired,onDelete:d.default.func.isRequired},F.propTypes={isOpen:d.default.bool.isRequired,provider:d.default.string,providerName:d.default.string,isCompatible:d.default.bool,isAnthropic:d.default.bool,proxyPools:d.default.arrayOf(d.default.shape({id:d.default.string,name:d.default.string})),onSave:d.default.func.isRequired,onClose:d.default.func.isRequired},G.propTypes={isOpen:d.default.bool.isRequired,connection:d.default.shape({id:d.default.string,name:d.default.string,email:d.default.string,priority:d.default.number,authType:d.default.string,provider:d.default.string,providerSpecificData:d.default.object}),proxyPools:d.default.arrayOf(d.default.shape({id:d.default.string,name:d.default.string})),onSave:d.default.func.isRequired,onClose:d.default.func.isRequired},H.propTypes={isOpen:d.default.bool.isRequired,node:d.default.shape({id:d.default.string,name:d.default.string,prefix:d.default.string,apiType:d.default.string,baseUrl:d.default.string}),onSave:d.default.func.isRequired,onClose:d.default.func.isRequired,isAnthropic:d.default.bool},I.propTypes={isOpen:d.default.bool.isRequired,providerAlias:d.default.string.isRequired,providerDisplayAlias:d.default.string.isRequired,onSave:d.default.func.isRequired,onClose:d.default.func.isRequired},a.s(["default",0,function(){let a=(0,e.useParams)(),d=(0,e.useRouter)(),j=a.id,[k,x]=(0,c.useState)([]),[y,B]=(0,c.useState)(!0),[D,J]=(0,c.useState)(null),[K,L]=(0,c.useState)([]),[M,N]=(0,c.useState)(!1),[O,P]=(0,c.useState)(!1),[Q,R]=(0,c.useState)(!1),[S,T]=(0,c.useState)(!1),[U,V]=(0,c.useState)(!1),[W,X]=(0,c.useState)(!1),[Y,Z]=(0,c.useState)(!1),[$,_]=(0,c.useState)(null),[aa,ab]=(0,c.useState)(null),[ac,ad]=(0,c.useState)({}),[ae,af]=(0,c.useState)(!1),[ag,ah]=(0,c.useState)({}),[ai,aj]=(0,c.useState)(""),[ak,al]=(0,c.useState)(null),[am,an]=(0,c.useState)(!1),[ao,ap]=(0,c.useState)([]),[aq,ar]=(0,c.useState)("__none__"),[as,at]=(0,c.useState)(!1),[au,av]=(0,c.useState)(null),[aw,ax]=(0,c.useState)(""),[ay,az]=(0,c.useState)([]),[aA,aB]=(0,c.useState)([]),{copied:aC,copy:aD}=(0,w.useCopyToClipboard)(),aE=D?{id:D.id,name:D.name||("anthropic-compatible"===D.type?"Anthropic Compatible":"OpenAI Compatible"),color:"anthropic-compatible"===D.type?"#D97757":"#10A37F",textIcon:"anthropic-compatible"===D.type?"AC":"OC",apiType:D.apiType,baseUrl:D.baseUrl,type:D.type}:u.OAUTH_PROVIDERS[j]||u.APIKEY_PROVIDERS[j]||u.FREE_PROVIDERS[j]||u.FREE_TIER_PROVIDERS[j],aF=!!u.OAUTH_PROVIDERS[j]||!!u.FREE_PROVIDERS[j],aG=(0,v.getModelsByProviderId)(j),aH=(0,u.getProviderAlias)(j),aI=(0,u.isOpenAICompatibleProvider)(j),aJ=(0,u.isAnthropicCompatibleProvider)(j),aK=aI||aJ,aL=aK?j:aH,aM=aK?D?.prefix||j:aH,aN=(0,c.useCallback)(async()=>{try{let a=await fetch("/api/models/alias"),b=await a.json();a.ok&&ad(b.aliases||{})}catch(a){console.log("Error fetching aliases:",a)}},[]);(0,c.useEffect)(()=>{"kilocode"===j&&fetch("/api/providers/kilo/free-models").then(a=>a.json()).then(a=>{a.models?.length&&aB(a.models)}).catch(()=>{})},[j]);let aO=(0,c.useCallback)(async()=>{try{let[a,b,c,d]=await Promise.all([fetch("/api/providers",{cache:"no-store"}),fetch("/api/provider-nodes",{cache:"no-store"}),fetch("/api/proxy-pools?isActive=true",{cache:"no-store"}),fetch("/api/settings",{cache:"no-store"})]),e=await a.json(),f=await b.json(),g=await c.json(),h=d.ok?await d.json():{};if(a.ok){let a=(e.connections||[]).filter(a=>a.provider===j);x(a)}c.ok&&L(g.proxyPools||[]);let i=(h.providerStrategies||{})[j]||{};if(av(i.fallbackStrategy||null),ax(null!=i.stickyRoundRobinLimit?String(i.stickyRoundRobinLimit):"1"),b.ok){let a=(f.nodes||[]).find(a=>a.id===j)||null;if(!a&&aK)for(let b=0;b<3;b+=1){await new Promise(a=>setTimeout(a,150));let b=await fetch("/api/provider-nodes",{cache:"no-store"});if(b.ok&&(a=((await b.json()).nodes||[]).find(a=>a.id===j)||null))break}J(a)}}catch(a){console.log("Error fetching connections:",a)}finally{B(!1)}},[j,aK]),aP=async a=>{try{let b=await fetch(`/api/provider-nodes/${j}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(a)}),c=await b.json();b.ok&&(J(c.node),await aO(),V(!1))}catch(a){console.log("Error updating provider node:",a)}},aQ=async(a,b)=>{try{let c=await fetch("/api/settings",{cache:"no-store"}),d=(c.ok?await c.json():{}).providerStrategies||{},e={};a&&(e.fallbackStrategy=a),"round-robin"===a&&""!==b&&(e.stickyRoundRobinLimit=Number(b)||3);let f={...d};0===Object.keys(e).length?delete f[j]:f[j]=e,await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({providerStrategies:f})})}catch(a){console.log("Error saving provider strategy:",a)}};(0,c.useEffect)(()=>{aO(),aN()},[aO,aN]),(0,c.useEffect)(()=>{let a=(u.OAUTH_PROVIDERS[j]||u.APIKEY_PROVIDERS[j]||u.FREE_PROVIDERS[j]||u.FREE_TIER_PROVIDERS[j])?.modelsFetcher;a&&z(a).then(az)},[j]);let aR=async(a,b,c=aH)=>{let d=`${c}/${a}`;try{let a=await fetch("/api/models/alias",{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:d,alias:b})});if(a.ok)await aN();else{let b=await a.json();alert(b.error||"Failed to set alias")}}catch(a){console.log("Error setting alias:",a)}},aS=async a=>{try{(await fetch(`/api/models/alias?alias=${encodeURIComponent(a)}`,{method:"DELETE"})).ok&&await aN()}catch(a){console.log("Error deleting alias:",a)}},aT=async a=>{if(confirm("Delete this connection?"))try{(await fetch(`/api/providers/${a}`,{method:"DELETE"})).ok&&x(k.filter(b=>b.id!==a))}catch(a){console.log("Error deleting connection:",a)}},aU=()=>{aO(),N(!1)},aV=async a=>{try{(await fetch("/api/providers",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:j,...a})})).ok&&(await aO(),R(!1))}catch(a){console.log("Error saving connection:",a)}},aW=async a=>{try{(await fetch(`/api/providers/${aa.id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(a)})).ok&&(await aO(),T(!1))}catch(a){console.log("Error updating connection:",a)}},aX=async(a,b)=>{try{(await fetch(`/api/providers/${a}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({isActive:b})})).ok&&x(c=>c.map(c=>c.id===a?{...c,isActive:b}:c))}catch(a){console.log("Error updating connection status:",a)}},aY=async(a,b)=>{let c=[...k];[c[a],c[b]]=[c[b],c[a]],x(c);try{await Promise.all([fetch(`/api/providers/${c[a].id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({priority:a})}),fetch(`/api/providers/${c[b].id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({priority:b})})])}catch(a){console.log("Error swapping priority:",a),await aO()}},aZ=k.filter(a=>ao.includes(a.id));k.length>0&&(ao.length,k.length),(0,c.useEffect)(()=>{ap(a=>a.filter(a=>k.some(b=>b.id===a)))},[k]);let a$=(()=>{if(0===aZ.length)return"";let a=new Set(aZ.map(a=>a.providerSpecificData?.proxyPoolId||"__none__"));if(1===a.size){let b=[...a][0];if("__none__"===b)return"All selected currently unbound";let c=K.find(a=>a.id===b);return`All selected currently bound to ${c?.name||b}`}return"Selected connections have mixed proxy bindings"})(),a_=()=>{as||X(!1)},a0=async()=>{if(0===ao.length)return;let a="__none__"===aq?null:aq;at(!0);try{let b=[];for(let c of ao)try{let d=await fetch(`/api/providers/${c}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({proxyPoolId:a})});b.push(d.ok)}catch(a){console.log("Error applying bulk proxy pool for",c,a),b.push(!1)}let c=b.filter(a=>!a).length;c>0&&alert(`Updated with ${c} failed request(s).`),await aO(),ap([]),ar("__none__"),X(!1)}catch(a){console.log("Error applying bulk proxy pool:",a)}finally{at(!1)}},a1=async()=>{Z(!0),_(null);try{let a=await fetch("/api/antigravity-tools/import",{method:"POST"}),b=await a.json();a.ok?(_(b),await aO()):_({error:b.error||"Import failed"})}catch(a){_({error:a.message})}Z(!1)},a2=(0,b.jsx)("div",{className:"flex flex-col divide-y divide-black/[0.03] dark:divide-white/[0.03]",children:k.map((a,c)=>(0,b.jsx)("div",{className:"flex items-stretch",children:(0,b.jsx)("div",{className:"flex-1 min-w-0",children:(0,b.jsx)(E,{connection:a,proxyPools:K,isOAuth:aF,isFirst:0===c,isLast:c===k.length-1,onMoveUp:()=>aY(c,c-1),onMoveDown:()=>aY(c,c+1),onToggleActive:b=>aX(a.id,b),onUpdateProxy:async b=>{try{(await fetch(`/api/providers/${a.id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({proxyPoolId:b||null})})).ok&&x(c=>c.map(c=>c.id===a.id?{...c,providerSpecificData:{...c.providerSpecificData,proxyPoolId:b||null}}:c))}catch(a){console.log("Error updating proxy:",a)}},onEdit:()=>{ab(a),T(!0)},onDelete:()=>aT(a.id)})})},a.id))}),a3=[{value:"__none__",label:"None"},...K.map(a=>({value:a.id,label:a.name}))],a4=0===ao.length?"Select one or more connections, then click Proxy Action.":a$,a5=ao.length>0&&!as,a6=(0,b.jsx)(l.Modal,{isOpen:W,onClose:a_,title:`Proxy Action (${ao.length} selected)`,children:(0,b.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,b.jsx)(t.Select,{label:"Proxy Pool",value:aq,onChange:a=>ar(a.target.value),options:a3,placeholder:"None"}),(0,b.jsx)("p",{className:"text-xs text-text-muted",children:a4}),(0,b.jsx)("p",{className:"text-xs text-text-muted",children:"Selecting None will unbind selected connections from proxy pool."}),(0,b.jsxs)("div",{className:"flex gap-2",children:[(0,b.jsx)(i.Button,{onClick:a0,fullWidth:!0,disabled:!a5,children:as?"Applying...":"Apply"}),(0,b.jsx)(i.Button,{onClick:a_,variant:"ghost",fullWidth:!0,disabled:as,children:"Cancel"})]})]})}),a7=async a=>{if(!ak){al(a);try{let b=await fetch("/api/models/test",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:`${aL}/${a}`})}),c=await b.json();ah(b=>({...b,[a]:c.ok?"ok":"error"})),aj(c.ok?"":c.error||"Model not reachable")}catch{ah(b=>({...b,[a]:"error"})),aj("Network error")}finally{al(null)}}};return y?(0,b.jsxs)("div",{className:"flex flex-col gap-8",children:[(0,b.jsx)(m.CardSkeleton,{}),(0,b.jsx)(m.CardSkeleton,{})]}):aE?(0,b.jsxs)("div",{className:"flex flex-col gap-8",children:[(0,b.jsxs)("div",{children:[(0,b.jsxs)(f.default,{href:"/dashboard/providers",className:"inline-flex items-center gap-1 text-sm text-text-muted hover:text-primary transition-colors mb-4",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-lg",children:"arrow_back"}),"Back to Providers"]}),(0,b.jsxs)("div",{className:"flex items-center gap-4",children:[(0,b.jsx)("div",{className:"rounded-lg flex items-center justify-center",style:{backgroundColor:`${aE.color}15`},children:ae?(0,b.jsx)("span",{className:"text-sm font-bold",style:{color:aE.color},children:aE.textIcon||aE.id.slice(0,2).toUpperCase()}):(0,b.jsx)(g.default,{src:aI&&aE.apiType?"responses"===aE.apiType?"/providers/oai-r.png":"/providers/oai-cc.png":aJ?"/providers/anthropic-m.png":`/providers/${aE.id}.png`,alt:aE.name,width:48,height:48,className:"object-contain rounded-lg max-w-[48px] max-h-[48px]",sizes:"48px",onError:()=>af(!0)})}),(0,b.jsxs)("div",{children:[(0,b.jsx)("h1",{className:"text-3xl font-semibold tracking-tight",children:aE.name}),(0,b.jsxs)("p",{className:"text-text-muted",children:[k.length," connection",1===k.length?"":"s"]})]})]})]}),aE.deprecated&&(0,b.jsxs)("div",{className:"flex items-start gap-2 px-3 py-2 rounded-lg bg-black/[0.02] dark:bg-white/[0.02] border border-black/[0.05] dark:border-white/[0.05]",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-[16px] text-text-muted mt-0.5 shrink-0",children:"info"}),(0,b.jsx)("p",{className:"text-xs text-text-muted leading-relaxed",children:aE.deprecationNotice})]}),aE.notice&&!aE.deprecated&&(0,b.jsxs)("div",{className:"flex items-center gap-2 px-3 py-2 rounded-lg bg-black/[0.02] dark:bg-white/[0.02] border border-black/[0.05] dark:border-white/[0.05]",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-[16px] text-text-muted shrink-0",children:"info"}),(0,b.jsx)("p",{className:"text-xs text-text-muted leading-relaxed",children:aE.notice.text}),aE.notice.apiKeyUrl&&(0,b.jsx)("a",{href:aE.notice.apiKeyUrl,target:"_blank",rel:"noopener noreferrer",className:"text-xs text-primary hover:underline shrink-0",children:"Get API Key →"})]}),aK&&D&&(0,b.jsxs)(h.Card,{children:[(0,b.jsxs)("div",{className:"flex items-center justify-between mb-4",children:[(0,b.jsxs)("div",{children:[(0,b.jsx)("h2",{className:"text-lg font-semibold",children:aJ?"Anthropic Compatible Details":"OpenAI Compatible Details"}),(0,b.jsxs)("p",{className:"text-sm text-text-muted",children:[aJ?"Messages API":"responses"===D.apiType?"Responses API":"Chat Completions"," · ",(D.baseUrl||"").replace(/\/$/,""),"/",aJ?"messages":"responses"===D.apiType?"responses":"chat/completions"]})]}),(0,b.jsxs)("div",{className:"flex items-center gap-2",children:[(0,b.jsx)(i.Button,{size:"sm",icon:"add",onClick:()=>R(!0),disabled:k.length>0,children:"Add"}),(0,b.jsx)(i.Button,{size:"sm",variant:"secondary",icon:"edit",onClick:()=>V(!0),children:"Edit"}),(0,b.jsx)(i.Button,{size:"sm",variant:"secondary",icon:"delete",onClick:async()=>{if(confirm(`Delete this ${aJ?"Anthropic":"OpenAI"} Compatible node?`))try{(await fetch(`/api/provider-nodes/${j}`,{method:"DELETE"})).ok&&d.push("/dashboard/providers")}catch(a){console.log("Error deleting provider node:",a)}},children:"Delete"})]})]}),k.length>0&&(0,b.jsx)("p",{className:"text-sm text-text-muted",children:"Only one connection is allowed per compatible node. Add another node if you need more connections."})]}),(0,b.jsxs)(h.Card,{children:[(0,b.jsxs)("div",{className:"flex items-center justify-between mb-4",children:[(0,b.jsx)("h2",{className:"text-lg font-semibold",children:"Connections"}),(0,b.jsxs)("div",{className:"flex items-center gap-2",children:[(0,b.jsx)("span",{className:"text-xs text-text-muted font-medium",children:"Round Robin"}),(0,b.jsx)(s.Toggle,{checked:"round-robin"===au,onChange:a=>{let b=a?"round-robin":null,c=a?aw||"1":aw;a&&!aw&&ax("1"),av(b),aQ(b,c)}}),"round-robin"===au&&(0,b.jsxs)("div",{className:"flex items-center gap-1.5",children:[(0,b.jsx)("span",{className:"text-xs text-text-muted",children:"Sticky:"}),(0,b.jsx)("input",{type:"number",min:1,value:aw,onChange:a=>{var b;ax(b=a.target.value),aQ("round-robin",b)},placeholder:"1",className:"w-14 px-2 py-1 text-xs border border-border rounded-md bg-background focus:outline-none focus:border-primary"})]})]})]}),$&&(0,b.jsxs)("div",{className:`flex items-center justify-between gap-2 mb-3 px-3 py-2 rounded-lg text-xs ${$.error?"bg-red-500/5 border border-red-500/15 text-red-500":"bg-green-500/5 border border-green-500/15 text-green-600"}`,children:[(0,b.jsx)("span",{children:$.error?`✗ ${$.error}`:`✓ Imported ${$.imported}, updated ${$.updated}, skipped ${$.skipped}`}),(0,b.jsx)("button",{onClick:()=>_(null),className:"text-current opacity-60 hover:opacity-100",children:"✕"})]}),0===k.length?(0,b.jsxs)("div",{className:"text-center py-12",children:[(0,b.jsx)("div",{className:"inline-flex items-center justify-center w-16 h-16 rounded-full bg-primary/10 text-primary mb-4",children:(0,b.jsx)("span",{className:"material-symbols-outlined text-[32px]",children:aF?"lock":"key"})}),(0,b.jsx)("p",{className:"text-text-main font-medium mb-1",children:"No connections yet"}),(0,b.jsx)("p",{className:"text-sm text-text-muted mb-4",children:"Add your first connection to get started"}),!aK&&(0,b.jsxs)("div",{className:"flex gap-2 justify-center",children:["iflow"===j&&(0,b.jsx)(i.Button,{icon:"cookie",variant:"secondary",onClick:()=>P(!0),children:"Cookie Auth"}),(0,b.jsx)(i.Button,{icon:"add",onClick:()=>aF?N(!0):R(!0),children:"iflow"===j?"OAuth":"Add Connection"}),"antigravity"===j&&(0,b.jsx)(i.Button,{icon:"download",variant:"secondary",onClick:a1,disabled:Y,children:Y?"Importing…":"Import from AGT"})]})]}):(0,b.jsxs)(b.Fragment,{children:[a2,!aK&&(0,b.jsxs)("div",{className:"flex gap-2 mt-4",children:["iflow"===j&&(0,b.jsx)(i.Button,{size:"sm",icon:"cookie",variant:"secondary",onClick:()=>P(!0),title:"Add connection using browser cookie",children:"Cookie"}),(0,b.jsx)(i.Button,{size:"sm",icon:"add",onClick:()=>aF?N(!0):R(!0),children:"Add"}),"antigravity"===j&&(0,b.jsx)(i.Button,{size:"sm",icon:"download",variant:"secondary",onClick:a1,disabled:Y,children:Y?"Importing…":"Import from AGT"})]})]})]}),(0,b.jsxs)(h.Card,{children:[(0,b.jsx)("div",{className:"flex items-center justify-between mb-4",children:(0,b.jsx)("h2",{className:"text-lg font-semibold",children:"Available Models"})}),!!ai&&(0,b.jsx)("p",{className:"text-xs text-red-500 mb-3 break-words",children:ai}),(()=>{let a,c;if(aK)return(0,b.jsx)(C,{providerStorageAlias:aL,providerDisplayAlias:aM,modelAliases:ac,copied:aC,onCopy:aD,onSetAlias:aR,onDeleteAlias:aS,connections:k,isAnthropic:aJ});let d=[...aG,...aA.filter(a=>!aG.some(b=>b.id===a.id))],e=Object.entries(ac).filter(([a,b])=>{let c=`${aL}/`;if(!b.startsWith(c))return!1;let d=b.slice(c.length);return aE.passthroughModels?!aG.some(a=>a.id===d):!aG.some(a=>a.id===d)&&a===d}).map(([a,b])=>({id:b.slice(`${aL}/`.length),alias:a,fullModel:b}));return(0,b.jsxs)("div",{className:"flex flex-wrap gap-3",children:[d.map(a=>{let c=`${aL}/${a.id}`,d=`${j}/${a.id}`,e=Object.entries(ac).find(([,a])=>a===c||a===d)?.[0];return(0,b.jsx)(A,{model:a,fullModel:`${aM}/${a.id}`,alias:e,copied:aC,onCopy:aD,onSetAlias:b=>aR(a.id,b,aL),onDeleteAlias:()=>aS(e),testStatus:ag[a.id],onTest:k.length>0?()=>a7(a.id):void 0,isTesting:ak===a.id,isFree:a.isFree},a.id)}),e.map(a=>(0,b.jsx)(A,{model:{id:a.id},fullModel:`${aM}/${a.id}`,alias:a.alias,copied:aC,onCopy:aD,onSetAlias:()=>{},onDeleteAlias:()=>aS(a.alias),testStatus:ag[a.id],onTest:k.length>0?()=>a7(a.id):void 0,isTesting:ak===a.id,isCustom:!0},a.id)),(0,b.jsxs)("button",{onClick:()=>an(!0),className:"flex items-center gap-1.5 px-3 py-2 rounded-lg border border-dashed border-black/15 dark:border-white/15 text-xs text-text-muted hover:text-primary hover:border-primary/40 transition-colors",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",children:"add"}),"Add Model"]}),ay.length>0&&(a=new Set(Object.values(ac)),0===(c=ay.filter(b=>!a.has(`${aL}/${b.id}`))).length?null:(0,b.jsxs)("div",{className:"w-full mt-2",children:[(0,b.jsx)("p",{className:"text-xs text-text-muted mb-2",children:"Suggested free models (≥200k context):"}),(0,b.jsx)("div",{className:"flex flex-wrap gap-2",children:c.map(a=>(0,b.jsxs)("button",{onClick:async()=>{let b=a.id.split("/").pop();await aR(a.id,b,aL)},className:"flex items-center gap-1 px-2.5 py-1.5 rounded-lg border border-black/10 dark:border-white/10 text-xs text-text-muted hover:text-primary hover:border-primary/40 hover:bg-primary/5 transition-colors",title:`${a.name} \xb7 ${(a.contextLength/1e3).toFixed(0)}k ctx`,children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-[13px]",children:"add"}),a.id.split("/").pop()]},a.id))})]}))]})})()]}),a6,"kiro"===j?(0,b.jsx)(o.default,{isOpen:M,providerInfo:aE,onSuccess:aU,onClose:()=>N(!1)}):"cursor"===j?(0,b.jsx)(p.default,{isOpen:M,onSuccess:aU,onClose:()=>N(!1)}):"gitlab"===j?(0,b.jsx)(r.default,{isOpen:M,providerInfo:aE,onSuccess:aU,onClose:()=>N(!1)}):(0,b.jsx)(n.OAuthModal,{isOpen:M,provider:j,providerInfo:aE,onSuccess:aU,onClose:()=>N(!1)}),"iflow"===j&&(0,b.jsx)(q.default,{isOpen:O,onSuccess:()=>{aO(),P(!1)},onClose:()=>P(!1)}),(0,b.jsx)(F,{isOpen:Q,provider:j,providerName:aE.name,isCompatible:aK,isAnthropic:aJ,proxyPools:K,onSave:aV,onClose:()=>R(!1)}),(0,b.jsx)(G,{isOpen:S,connection:aa,proxyPools:K,onSave:aW,onClose:()=>T(!1)}),aK&&(0,b.jsx)(H,{isOpen:U,node:D,onSave:aP,onClose:()=>V(!1),isAnthropic:aJ}),!aK&&(0,b.jsx)(I,{isOpen:am,providerAlias:aL,providerDisplayAlias:aM,onSave:async a=>{let b=aE?.passthroughModels?a.split("/").pop():a;await aR(a,b,aL),an(!1)},onClose:()=>an(!1)})]}):(0,b.jsxs)("div",{className:"text-center py-20",children:[(0,b.jsx)("p",{className:"text-text-muted",children:"Provider not found"}),(0,b.jsx)(f.default,{href:"/dashboard/providers",className:"text-primary mt-4 inline-block",children:"Back to Providers"})]})}],69617)}];
1
+ module.exports=[69617,a=>{"use strict";var b=a.i(87924),c=a.i(72131),d=a.i(41212),e=a.i(50944),f=a.i(38246),g=a.i(71987);a.i(7284);var h=a.i(12532),i=a.i(1374),j=a.i(56882),k=a.i(40695),l=a.i(78236),m=a.i(39204),n=a.i(13100),o=a.i(73428),o=o,p=a.i(74862),p=p,q=a.i(76454),q=q,r=a.i(88526),r=r,s=a.i(2231),t=a.i(65928),u=a.i(13364);a.i(67434);var v=a.i(87945),w=a.i(74208);let x=new Map,y={"openrouter-free":a=>a.filter(a=>a.pricing?.prompt==="0"&&a.pricing?.completion==="0"&&a.context_length>=2e5).map(a=>({id:a.id,name:a.name,contextLength:a.context_length})).sort((a,b)=>b.contextLength-a.contextLength)};async function z(a){if(!a?.url||!a?.type)return[];let b=x.get(a.url);if(b&&Date.now()<b.expiresAt)return b.data;try{let b=await fetch(a.url);if(!b.ok)return[];let c=await b.json(),d=c.data??c.models??c,e=y[a.type],f=e?e(Array.isArray(d)?d:[]):[];return x.set(a.url,{data:f,expiresAt:Date.now()+6e5}),f}catch{return[]}}function A({model:a,fullModel:c,alias:d,copied:e,onCopy:f,testStatus:g,isCustom:h,isFree:i,onDeleteAlias:j,onTest:k,isTesting:l}){let m="ok"===g?"#22c55e":"error"===g?"#ef4444":void 0;return(0,b.jsx)("div",{className:`group px-3 py-2 rounded-lg border ${"ok"===g?"border-green-500/40":"error"===g?"border-red-500/40":"border-border"} hover:bg-sidebar/50`,children:(0,b.jsxs)("div",{className:"flex items-center gap-2",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-base",style:m?{color:m}:void 0,children:"ok"===g?"check_circle":"error"===g?"cancel":"smart_toy"}),(0,b.jsx)("code",{className:"text-xs text-text-muted font-mono bg-sidebar px-1.5 py-0.5 rounded",children:c}),k&&(0,b.jsxs)("div",{className:"relative group/btn",children:[(0,b.jsx)("button",{onClick:k,disabled:l,className:`p-0.5 hover:bg-sidebar rounded text-text-muted hover:text-primary transition-opacity ${l?"opacity-100":"opacity-0 group-hover:opacity-100"}`,children:(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",style:l?{animation:"spin 1s linear infinite"}:void 0,children:l?"progress_activity":"science"})}),(0,b.jsx)("span",{className:"pointer-events-none absolute mt-1 top-5 left-1/2 -translate-x-1/2 text-[10px] text-text-muted whitespace-nowrap opacity-0 group-hover/btn:opacity-100 transition-opacity",children:l?"Testing...":"Test"})]}),(0,b.jsxs)("div",{className:"relative group/btn",children:[(0,b.jsx)("button",{onClick:()=>f(c,`model-${a.id}`),className:"p-0.5 hover:bg-sidebar rounded text-text-muted hover:text-primary",children:(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",children:e===`model-${a.id}`?"check":"content_copy"})}),(0,b.jsx)("span",{className:"pointer-events-none absolute mt-1 top-5 left-1/2 -translate-x-1/2 text-[10px] text-text-muted whitespace-nowrap opacity-0 group-hover/btn:opacity-100 transition-opacity",children:e===`model-${a.id}`?"Copied!":"Copy"})]}),h&&(0,b.jsx)("button",{onClick:j,className:"p-0.5 hover:bg-red-500/10 rounded text-text-muted hover:text-red-500 opacity-0 group-hover:opacity-100 transition-opacity ml-auto",title:"Remove custom model",children:(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",children:"close"})})]})})}function B({modelId:a,fullModel:c,copied:d,onCopy:e,onDeleteAlias:f,onTest:g,testStatus:h,isTesting:i,isFree:j}){let k="ok"===h?"#22c55e":"error"===h?"#ef4444":void 0;return(0,b.jsxs)("div",{className:`flex items-center gap-3 p-3 rounded-lg border ${"ok"===h?"border-green-500/40":"error"===h?"border-red-500/40":"border-border"} hover:bg-sidebar/50`,children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-base text-text-muted",style:k?{color:k}:void 0,children:"ok"===h?"check_circle":"error"===h?"cancel":"smart_toy"}),(0,b.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,b.jsx)("p",{className:"text-sm font-medium truncate",children:a}),(0,b.jsxs)("div",{className:"flex items-center gap-1 mt-1",children:[(0,b.jsx)("code",{className:"text-xs text-text-muted font-mono bg-sidebar px-1.5 py-0.5 rounded",children:c}),j&&(0,b.jsx)("span",{className:"text-[10px] font-medium px-1.5 py-0.5 rounded bg-green-500/10 text-green-600 dark:text-green-400",children:"Free"}),(0,b.jsxs)("div",{className:"relative group/btn",children:[(0,b.jsx)("button",{onClick:()=>e(c,`model-${a}`),className:"p-0.5 hover:bg-sidebar rounded text-text-muted hover:text-primary",children:(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",children:d===`model-${a}`?"check":"content_copy"})}),(0,b.jsx)("span",{className:"pointer-events-none absolute top-5 left-1/2 -translate-x-1/2 text-[10px] text-text-muted whitespace-nowrap opacity-0 group-hover/btn:opacity-100 transition-opacity",children:d===`model-${a}`?"Copied!":"Copy"})]}),g&&(0,b.jsxs)("div",{className:"relative group/btn",children:[(0,b.jsx)("button",{onClick:g,disabled:i,className:"p-0.5 hover:bg-sidebar rounded text-text-muted hover:text-primary transition-colors",children:(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",style:i?{animation:"spin 1s linear infinite"}:void 0,children:i?"progress_activity":"science"})}),(0,b.jsx)("span",{className:"pointer-events-none absolute top-5 left-1/2 -translate-x-1/2 text-[10px] text-text-muted whitespace-nowrap opacity-0 group-hover/btn:opacity-100 transition-opacity",children:i?"Testing...":"Test"})]})]})]}),(0,b.jsx)("button",{onClick:f,className:"p-1 hover:bg-red-50 rounded text-red-500",title:"Remove model",children:(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",children:"delete"})})]})}function C({providerStorageAlias:a,providerDisplayAlias:d,modelAliases:e,copied:f,onCopy:g,onSetAlias:h,onDeleteAlias:j,connections:k,isAnthropic:l}){let[m,n]=(0,c.useState)(""),[o,p]=(0,c.useState)(!1),[q,r]=(0,c.useState)(!1),[s,t]=(0,c.useState)(null),[u,v]=(0,c.useState)({}),w=async b=>{if(!s){t(b);try{let c=await fetch("/api/models/test",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:`${a}/${b}`})}),d=await c.json();v(a=>({...a,[b]:d.ok?"ok":"error"}))}catch{v(a=>({...a,[b]:"error"}))}finally{t(null)}}},x=Object.entries(e).filter(([,b])=>b.startsWith(`${a}/`)).map(([b,c])=>({modelId:c.replace(`${a}/`,""),fullModel:c,alias:b})),y=b=>{let c,f=`${a}/${b}`;if(Object.values(e).includes(f))return null;let g=(c=b.split("/"))[c.length-1];if(!e[g])return g;let h=`${d}-${g}`;return e[h]?null:h},z=async()=>{if(!m.trim()||o)return;let b=m.trim(),c=y(b);if(!c)return void alert("All suggested aliases already exist. Please choose a different model or remove conflicting aliases.");p(!0);try{await h(b,c,a),n("")}catch(a){console.log("Error adding model:",a)}finally{p(!1)}},A=async()=>{if(q)return;let b=k.find(a=>!1!==a.isActive);if(b){r(!0);try{let c=await fetch(`/api/providers/${b.id}/models`),d=await c.json();if(!c.ok)return void alert(d.error||"Failed to import models");let e=d.models||[];if(0===e.length)return void alert("No models returned from /models.");let f=0;for(let b of e){let c=b.id||b.name||b.model;if(!c)continue;let d=y(c);d&&(await h(c,d,a),f+=1)}0===f&&alert("No new models were added.")}catch(a){console.log("Error importing models:",a)}finally{r(!1)}}},D=k.some(a=>!1!==a.isActive);return(0,b.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,b.jsxs)("p",{className:"text-sm text-text-muted",children:["Add ",l?"Anthropic":"OpenAI","-compatible models manually or import them from the /models endpoint."]}),(0,b.jsxs)("div",{className:"flex items-end gap-2 flex-wrap",children:[(0,b.jsxs)("div",{className:"flex-1 min-w-[240px]",children:[(0,b.jsx)("label",{htmlFor:"new-compatible-model-input",className:"text-xs text-text-muted mb-1 block",children:"Model ID"}),(0,b.jsx)("input",{id:"new-compatible-model-input",type:"text",value:m,onChange:a=>n(a.target.value),onKeyDown:a=>"Enter"===a.key&&z(),placeholder:l?"claude-3-opus-20240229":"gpt-4o",className:"w-full px-3 py-2 text-sm border border-border rounded-lg bg-background focus:outline-none focus:border-primary"})]}),(0,b.jsx)(i.Button,{size:"sm",icon:"add",onClick:z,disabled:!m.trim()||o,children:o?"Adding...":"Add"}),(0,b.jsx)(i.Button,{size:"sm",variant:"secondary",icon:"download",onClick:A,disabled:!D||q,children:q?"Importing...":"Import from /models"})]}),!D&&(0,b.jsx)("p",{className:"text-xs text-text-muted",children:"Add a connection to enable importing models."}),x.length>0&&(0,b.jsx)("div",{className:"flex flex-col gap-3",children:x.map(({modelId:a,fullModel:c,alias:e})=>(0,b.jsx)(B,{modelId:a,fullModel:`${d}/${a}`,copied:f,onCopy:g,onDeleteAlias:()=>j(e),onTest:k.length>0?()=>w(a):void 0,testStatus:u[a],isTesting:s===a},c))})]})}function D({until:a}){let[d,e]=(0,c.useState)("");return((0,c.useEffect)(()=>{let b=()=>{let b=new Date(a).getTime()-Date.now();if(b<=0)return void e("");let c=Math.floor(b/1e3);if(c<60)e(`${c}s`);else if(c<3600)e(`${Math.floor(c/60)}m ${c%60}s`);else{let a=Math.floor(c/3600),b=Math.floor(c%3600/60);e(`${a}h ${b}m`)}};b();let c=setInterval(b,1e3);return()=>clearInterval(c)},[a]),d)?(0,b.jsxs)("span",{className:"text-xs text-orange-500 font-mono",children:["⏱ ",d]}):null}function E({connection:a,proxyPools:d,isOAuth:e,isFirst:f,isLast:g,onMoveUp:h,onMoveDown:i,onToggleActive:k,onUpdateProxy:l,onEdit:m,onDelete:n}){let[o,p]=(0,c.useState)(!1),[q,r]=(0,c.useState)(!1),t=(0,c.useRef)(null),u=new Map((d||[]).map(a=>[a.id,a])),v=a.providerSpecificData?.proxyPoolId||null,w=v?u.get(v):null,x=a.providerSpecificData?.connectionProxyEnabled===!0&&!!a.providerSpecificData?.connectionProxyUrl,y=!!v||x,z=w?`Pool: ${w.name}`:v?`Pool: ${v} (inactive/missing)`:x?`Legacy: ${a.providerSpecificData?.connectionProxyUrl}`:"",A="";if(w?.proxyUrl||a.providerSpecificData?.connectionProxyUrl){let b=w?.proxyUrl||a.providerSpecificData?.connectionProxyUrl;try{let a=new URL(b);A=`${a.protocol}//${a.hostname}${a.port?`:${a.port}`:""}`}catch{A=b}}let B=w?.noProxy||a.providerSpecificData?.connectionNoProxy||"",C="default";w?.isActive===!0?C="success":(v||x)&&(C="error"),(0,c.useEffect)(()=>{if(!o)return;let a=a=>{t.current&&!t.current.contains(a.target)&&p(!1)};return document.addEventListener("mousedown",a),()=>document.removeEventListener("mousedown",a)},[o]);let F=async a=>{r(!0);try{await l("__none__"===a?null:a)}finally{r(!1),p(!1)}},G=e?a.name||a.email||a.displayName||"OAuth Account":a.name,[H,I]=(0,c.useState)(!1),J=Object.entries(a).filter(([a])=>a.startsWith("modelLock_")).map(([,a])=>a).filter(a=>!!a).sort()[0]||null;(0,c.useEffect)(()=>{let b=()=>{I(!!Object.entries(a).filter(([a])=>a.startsWith("modelLock_")).map(([,a])=>a).filter(a=>a&&new Date(a).getTime()>Date.now()).sort()[0])};b();let c=J?setInterval(b,1e3):null;return()=>{c&&clearInterval(c)}},[J]);let K="unavailable"!==a.testStatus||H?a.testStatus:"active";return(0,b.jsxs)("div",{className:`group flex items-center justify-between p-3 rounded-lg hover:bg-black/[0.02] dark:hover:bg-white/[0.02] transition-colors ${!1===a.isActive?"opacity-60":""}`,children:[(0,b.jsxs)("div",{className:"flex items-center gap-3 flex-1 min-w-0",children:[(0,b.jsxs)("div",{className:"flex flex-col",children:[(0,b.jsx)("button",{onClick:h,disabled:f,className:`p-0.5 rounded ${f?"text-text-muted/30 cursor-not-allowed":"hover:bg-sidebar text-text-muted hover:text-primary"}`,children:(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",children:"keyboard_arrow_up"})}),(0,b.jsx)("button",{onClick:i,disabled:g,className:`p-0.5 rounded ${g?"text-text-muted/30 cursor-not-allowed":"hover:bg-sidebar text-text-muted hover:text-primary"}`,children:(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",children:"keyboard_arrow_down"})})]}),(0,b.jsx)("span",{className:"material-symbols-outlined text-base text-text-muted",children:e?"lock":"key"}),(0,b.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,b.jsx)("p",{className:"text-sm font-medium truncate",children:G}),(0,b.jsxs)("div",{className:"flex items-center gap-2 mt-1",children:[(0,b.jsx)(j.Badge,{variant:!1===a.isActive?"default":"active"===K||"success"===K?"success":"error"===K||"expired"===K||"unavailable"===K?"error":"default",size:"sm",dot:!0,children:!1===a.isActive?"disabled":K||"Unknown"}),y&&(0,b.jsx)(j.Badge,{variant:C,size:"sm",children:"Proxy"}),H&&!1!==a.isActive&&(0,b.jsx)(D,{until:J}),a.lastError&&!1!==a.isActive&&(0,b.jsx)("span",{className:"text-xs text-red-500 truncate max-w-[300px]",title:a.lastError,children:a.lastError}),(0,b.jsxs)("span",{className:"text-xs text-text-muted",children:["#",a.priority]}),a.globalPriority&&(0,b.jsxs)("span",{className:"text-xs text-text-muted",children:["Auto: ",a.globalPriority]})]}),y&&(0,b.jsxs)("div",{className:"mt-1 flex items-center gap-2 flex-wrap",children:[(0,b.jsx)("span",{className:"text-[11px] text-text-muted truncate max-w-[420px]",title:z,children:z}),A&&(0,b.jsx)("code",{className:"text-[10px] font-mono bg-black/5 dark:bg-white/5 px-1 py-0.5 rounded text-text-muted",children:A}),B&&(0,b.jsxs)("span",{className:"text-[11px] text-text-muted truncate max-w-[320px]",title:B,children:["no_proxy: ",B]})]})]})]}),(0,b.jsxs)("div",{className:"flex items-center gap-2",children:[(0,b.jsxs)("div",{className:"flex gap-1",children:[(d||[]).length>0&&(0,b.jsxs)("div",{className:"relative",ref:t,children:[(0,b.jsxs)("button",{onClick:()=>p(a=>!a),className:`flex flex-col items-center px-2 py-1 rounded hover:bg-black/5 dark:hover:bg-white/5 transition-colors ${y?"text-primary":"text-text-muted hover:text-primary"}`,disabled:q,children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:q?"progress_activity":"lan"}),(0,b.jsx)("span",{className:"text-[10px] leading-tight",children:"Proxy"})]}),o&&(0,b.jsxs)("div",{className:"absolute right-0 top-full mt-1 z-50 bg-bg border border-border rounded-lg shadow-lg py-1 min-w-[160px]",children:[(0,b.jsx)("button",{onClick:()=>F("__none__"),className:`w-full text-left px-3 py-1.5 text-sm hover:bg-black/5 dark:hover:bg-white/5 ${!v?"text-primary font-medium":"text-text-main"}`,children:"None"}),(d||[]).map(a=>(0,b.jsx)("button",{onClick:()=>F(a.id),className:`w-full text-left px-3 py-1.5 text-sm hover:bg-black/5 dark:hover:bg-white/5 ${v===a.id?"text-primary font-medium":"text-text-main"}`,children:a.name},a.id))]})]}),(0,b.jsxs)("button",{onClick:m,className:"flex flex-col items-center px-2 py-1 rounded hover:bg-black/5 dark:hover:bg-white/5 text-text-muted hover:text-primary",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:"edit"}),(0,b.jsx)("span",{className:"text-[10px] leading-tight",children:"Edit"})]}),(0,b.jsxs)("button",{onClick:n,className:"flex flex-col items-center px-2 py-1 rounded hover:bg-red-500/10 text-red-500",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:"delete"}),(0,b.jsx)("span",{className:"text-[10px] leading-tight",children:"Delete"})]})]}),(0,b.jsx)(s.Toggle,{size:"sm",checked:a.isActive??!0,onChange:k,title:a.isActive??!0?"Disable connection":"Enable connection"})]})]})}function F({isOpen:a,provider:d,providerName:e,isCompatible:f,isAnthropic:g,proxyPools:h,onSave:m,onClose:n}){let o="__none__",[p,q]=(0,c.useState)({name:"",apiKey:"",priority:1,proxyPoolId:o}),[r,s]=(0,c.useState)(!1),[u,v]=(0,c.useState)(null),[w,x]=(0,c.useState)(!1),y=async()=>{s(!0);try{let a=await fetch("/api/providers/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:d,apiKey:p.apiKey})}),b=await a.json();v(b.valid?"success":"failed")}catch{v("failed")}finally{s(!1)}},z=async()=>{if(d&&p.apiKey){x(!0);try{let a=!1;try{s(!0),v(null);let b=await fetch("/api/providers/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:d,apiKey:p.apiKey})});a=!!(await b.json()).valid,v(a?"success":"failed")}catch{v("failed")}finally{s(!1)}await m({name:p.name,apiKey:p.apiKey,priority:p.priority,proxyPoolId:p.proxyPoolId===o?null:p.proxyPoolId,testStatus:a?"active":"unknown",providerSpecificData:void 0})}finally{x(!1)}}};return d?(0,b.jsx)(l.Modal,{isOpen:a,title:`Add ${e||d} API Key`,onClose:n,children:(0,b.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,b.jsx)(k.Input,{label:"Name",value:p.name,onChange:a=>q({...p,name:a.target.value}),placeholder:"Production Key"}),(0,b.jsxs)("div",{className:"flex gap-2",children:[(0,b.jsx)(k.Input,{label:"API Key",type:"password",value:p.apiKey,onChange:a=>q({...p,apiKey:a.target.value}),className:"flex-1"}),(0,b.jsx)("div",{className:"pt-6",children:(0,b.jsx)(i.Button,{onClick:y,disabled:!p.apiKey||r||w,variant:"secondary",children:r?"Checking...":"Check"})})]}),u&&(0,b.jsx)(j.Badge,{variant:"success"===u?"success":"error",children:"success"===u?"Valid":"Invalid"}),f&&(0,b.jsx)("p",{className:"text-xs text-text-muted",children:g?`Validation checks ${e||"Anthropic Compatible"} by verifying the API key.`:`Validation checks ${e||"OpenAI Compatible"} via /models on your base URL.`}),(0,b.jsx)(k.Input,{label:"Priority",type:"number",value:p.priority,onChange:a=>q({...p,priority:Number.parseInt(a.target.value)||1})}),(0,b.jsx)(t.Select,{label:"Proxy Pool",value:p.proxyPoolId,onChange:a=>q({...p,proxyPoolId:a.target.value}),options:[{value:o,label:"None"},...(h||[]).map(a=>({value:a.id,label:a.name}))],placeholder:"None"}),0===(h||[]).length&&(0,b.jsx)("p",{className:"text-xs text-text-muted",children:"No active proxy pools available. Create one in Proxy Pools page first."}),(0,b.jsx)("p",{className:"text-xs text-text-muted",children:"Legacy manual proxy fields are still accepted by API for backward compatibility."}),(0,b.jsxs)("div",{className:"flex gap-2",children:[(0,b.jsx)(i.Button,{onClick:z,fullWidth:!0,disabled:!p.name||!p.apiKey||w,children:w?"Saving...":"Save"}),(0,b.jsx)(i.Button,{onClick:n,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})}):null}function G({isOpen:a,connection:d,proxyPools:e,onSave:f,onClose:g}){let[h,m]=(0,c.useState)({name:"",priority:1,apiKey:""}),[n,o]=(0,c.useState)(!1),[p,q]=(0,c.useState)(null),[r,s]=(0,c.useState)(!1),[t,v]=(0,c.useState)(null),[w,x]=(0,c.useState)(!1);(0,c.useEffect)(()=>{d&&(m({name:d.name||"",priority:d.priority||1,apiKey:""}),q(null),v(null))},[d]);let y=async()=>{if(d?.provider){o(!0),q(null);try{let a=await fetch(`/api/providers/${d.id}/test`,{method:"POST"}),b=await a.json();q(b.valid?"success":"failed")}catch{q("failed")}finally{o(!1)}}},z=async()=>{if(d?.provider&&h.apiKey){s(!0),v(null);try{let a=await fetch("/api/providers/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:d.provider,apiKey:h.apiKey})}),b=await a.json();v(b.valid?"success":"failed")}catch{v("failed")}finally{s(!1)}}},A=async()=>{x(!0);try{let a={name:h.name,priority:h.priority};if(!B&&h.apiKey){a.apiKey=h.apiKey;let b="success"===t;if(!b)try{s(!0),v(null);let a=await fetch("/api/providers/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:d.provider,apiKey:h.apiKey})});b=!!(await a.json()).valid,v(b?"success":"failed")}catch{v("failed")}finally{s(!1)}b&&(a.testStatus="active",a.lastError=null,a.lastErrorAt=null)}await f(a)}finally{x(!1)}};if(!d)return null;let B="oauth"===d.authType,C=(0,u.isOpenAICompatibleProvider)(d.provider)||(0,u.isAnthropicCompatibleProvider)(d.provider);return(0,b.jsx)(l.Modal,{isOpen:a,title:"Edit Connection",onClose:g,children:(0,b.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,b.jsx)(k.Input,{label:"Name",value:h.name,onChange:a=>m({...h,name:a.target.value}),placeholder:B?"Account name":"Production Key"}),B&&d.email&&(0,b.jsxs)("div",{className:"bg-sidebar/50 p-3 rounded-lg",children:[(0,b.jsx)("p",{className:"text-sm text-text-muted mb-1",children:"Email"}),(0,b.jsx)("p",{className:"font-medium",children:d.email})]}),(0,b.jsx)(k.Input,{label:"Priority",type:"number",value:h.priority,onChange:a=>m({...h,priority:Number.parseInt(a.target.value)||1})}),!B&&(0,b.jsxs)(b.Fragment,{children:[(0,b.jsxs)("div",{className:"flex gap-2",children:[(0,b.jsx)(k.Input,{label:"API Key",type:"password",value:h.apiKey,onChange:a=>m({...h,apiKey:a.target.value}),placeholder:"Enter new API key",hint:"Leave blank to keep the current API key.",className:"flex-1"}),(0,b.jsx)("div",{className:"pt-6",children:(0,b.jsx)(i.Button,{onClick:z,disabled:!h.apiKey||r||w,variant:"secondary",children:r?"Checking...":"Check"})})]}),t&&(0,b.jsx)(j.Badge,{variant:"success"===t?"success":"error",children:"success"===t?"Valid":"Invalid"})]}),!C&&(0,b.jsxs)("div",{className:"flex items-center gap-3",children:[(0,b.jsx)(i.Button,{onClick:y,variant:"secondary",disabled:n,children:n?"Testing...":"Test Connection"}),p&&(0,b.jsx)(j.Badge,{variant:"success"===p?"success":"error",children:"success"===p?"Valid":"Failed"})]}),(0,b.jsxs)("div",{className:"flex gap-2",children:[(0,b.jsx)(i.Button,{onClick:A,fullWidth:!0,disabled:w,children:w?"Saving...":"Save"}),(0,b.jsx)(i.Button,{onClick:g,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})})}function H({isOpen:a,node:d,onSave:e,onClose:f,isAnthropic:g}){let[h,m]=(0,c.useState)({name:"",prefix:"",apiType:"chat",baseUrl:"https://api.openai.com/v1"}),[n,o]=(0,c.useState)(!1),[p,q]=(0,c.useState)(""),[r,s]=(0,c.useState)(""),[u,v]=(0,c.useState)(!1),[w,x]=(0,c.useState)(null);(0,c.useEffect)(()=>{d&&m({name:d.name||"",prefix:d.prefix||"",apiType:d.apiType||"chat",baseUrl:d.baseUrl||(g?"https://api.anthropic.com/v1":"https://api.openai.com/v1")})},[d,g]);let y=async()=>{if(h.name.trim()&&h.prefix.trim()&&h.baseUrl.trim()){o(!0);try{let a={name:h.name,prefix:h.prefix,baseUrl:h.baseUrl};g||(a.apiType=h.apiType),await e(a)}finally{o(!1)}}},z=async()=>{v(!0);try{let a=await fetch("/api/provider-nodes/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({baseUrl:h.baseUrl,apiKey:p,type:g?"anthropic-compatible":"openai-compatible",modelId:r.trim()||void 0})}),b=await a.json();x(b.valid?"success":"failed")}catch{x("failed")}finally{v(!1)}};return d?(0,b.jsx)(l.Modal,{isOpen:a,title:`Edit ${g?"Anthropic":"OpenAI"} Compatible`,onClose:f,children:(0,b.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,b.jsx)(k.Input,{label:"Name",value:h.name,onChange:a=>m({...h,name:a.target.value}),placeholder:`${g?"Anthropic":"OpenAI"} Compatible (Prod)`,hint:"Required. A friendly label for this node."}),(0,b.jsx)(k.Input,{label:"Prefix",value:h.prefix,onChange:a=>m({...h,prefix:a.target.value}),placeholder:g?"ac-prod":"oc-prod",hint:"Required. Used as the provider prefix for model IDs."}),!g&&(0,b.jsx)(t.Select,{label:"API Type",options:[{value:"chat",label:"Chat Completions"},{value:"responses",label:"Responses API"}],value:h.apiType,onChange:a=>m({...h,apiType:a.target.value})}),(0,b.jsx)(k.Input,{label:"Base URL",value:h.baseUrl,onChange:a=>m({...h,baseUrl:a.target.value}),placeholder:g?"https://api.anthropic.com/v1":"https://api.openai.com/v1",hint:`Use the base URL (ending in /v1) for your ${g?"Anthropic":"OpenAI"}-compatible API.`}),(0,b.jsxs)("div",{className:"flex gap-2",children:[(0,b.jsx)(k.Input,{label:"API Key (for Check)",type:"password",value:p,onChange:a=>q(a.target.value),className:"flex-1"}),(0,b.jsx)("div",{className:"pt-6",children:(0,b.jsx)(i.Button,{onClick:z,disabled:!p||u||!h.baseUrl.trim(),variant:"secondary",children:u?"Checking...":"Check"})})]}),(0,b.jsx)(k.Input,{label:"Model ID (optional)",value:r,onChange:a=>s(a.target.value),placeholder:"e.g. my-model-id",hint:"If provider lacks /models endpoint, enter a model ID to validate via chat/completions instead."}),w&&(0,b.jsx)(j.Badge,{variant:"success"===w?"success":"error",children:"success"===w?"Valid":"Invalid"}),(0,b.jsxs)("div",{className:"flex gap-2",children:[(0,b.jsx)(i.Button,{onClick:y,fullWidth:!0,disabled:!h.name.trim()||!h.prefix.trim()||!h.baseUrl.trim()||n,children:n?"Saving...":"Save"}),(0,b.jsx)(i.Button,{onClick:f,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})}):null}function I({isOpen:a,providerAlias:d,providerDisplayAlias:e,onSave:f,onClose:g}){let[h,j]=(0,c.useState)(""),[k,m]=(0,c.useState)(null),[n,o]=(0,c.useState)(""),[p,q]=(0,c.useState)(!1);(0,c.useEffect)(()=>{a&&(j(""),m(null),o(""))},[a]);let r=async()=>{if(h.trim()){m("testing"),o("");try{let a=await fetch("/api/models/test",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:`${d}/${h.trim()}`})}),b=await a.json();m(b.ok?"ok":"error"),o(b.error||"")}catch(a){m("error"),o(a.message)}}},s=async()=>{if(h.trim()&&!p){q(!0);try{await f(h.trim())}finally{q(!1)}}};return(0,b.jsx)(l.Modal,{isOpen:a,onClose:g,title:"Add Custom Model",children:(0,b.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,b.jsxs)("div",{children:[(0,b.jsx)("label",{className:"text-sm font-medium mb-1.5 block",children:"Model ID"}),(0,b.jsxs)("div",{className:"flex gap-2",children:[(0,b.jsx)("input",{type:"text",value:h,onChange:a=>{j(a.target.value),m(null),o("")},onKeyDown:a=>{"Enter"===a.key&&r()},placeholder:"e.g. claude-opus-4-5",className:"flex-1 px-3 py-2 text-sm border border-border rounded-lg bg-background focus:outline-none focus:border-primary",autoFocus:!0}),(0,b.jsx)(i.Button,{variant:"secondary",icon:"science",loading:"testing"===k,onClick:r,disabled:!h.trim()||"testing"===k,children:"testing"===k?"Testing...":"Test"})]}),(0,b.jsxs)("p",{className:"text-xs text-text-muted mt-1",children:["Sent to provider as: ",(0,b.jsx)("code",{className:"font-mono bg-sidebar px-1 rounded",children:h.trim()||"model-id"})]})]}),"ok"===k&&(0,b.jsxs)("div",{className:"flex items-center gap-2 text-sm text-green-600",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-base",children:"check_circle"}),"Model is reachable"]}),"error"===k&&(0,b.jsxs)("div",{className:"flex items-start gap-2 text-sm text-red-500",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-base shrink-0",children:"cancel"}),(0,b.jsx)("span",{children:n||"Model not reachable"})]}),(0,b.jsxs)("div",{className:"flex gap-2 pt-1",children:[(0,b.jsx)(i.Button,{onClick:g,variant:"ghost",fullWidth:!0,size:"sm",children:"Cancel"}),(0,b.jsx)(i.Button,{onClick:s,fullWidth:!0,size:"sm",disabled:!h.trim()||p,children:p?"Adding...":"Add Model"})]})]})})}A.propTypes={model:d.default.shape({id:d.default.string.isRequired}).isRequired,fullModel:d.default.string.isRequired,alias:d.default.string,copied:d.default.string,onCopy:d.default.func.isRequired,testStatus:d.default.oneOf(["ok","error"]),isCustom:d.default.bool,isFree:d.default.bool,onDeleteAlias:d.default.func,onTest:d.default.func,isTesting:d.default.bool},d.default.string.isRequired,d.default.object.isRequired,d.default.string,d.default.func.isRequired,d.default.func.isRequired,d.default.func.isRequired,B.propTypes={modelId:d.default.string.isRequired,fullModel:d.default.string.isRequired,copied:d.default.string,onCopy:d.default.func.isRequired,onDeleteAlias:d.default.func.isRequired,onTest:d.default.func,testStatus:d.default.oneOf(["ok","error"]),isTesting:d.default.bool,isFree:d.default.bool},C.propTypes={providerStorageAlias:d.default.string.isRequired,providerDisplayAlias:d.default.string.isRequired,modelAliases:d.default.object.isRequired,copied:d.default.string,onCopy:d.default.func.isRequired,onSetAlias:d.default.func.isRequired,onDeleteAlias:d.default.func.isRequired,connections:d.default.arrayOf(d.default.shape({id:d.default.string,isActive:d.default.bool})).isRequired,isAnthropic:d.default.bool},D.propTypes={until:d.default.string.isRequired},E.propTypes={connection:d.default.shape({id:d.default.string,name:d.default.string,email:d.default.string,displayName:d.default.string,modelLockUntil:d.default.string,testStatus:d.default.string,isActive:d.default.bool,lastError:d.default.string,priority:d.default.number,globalPriority:d.default.number}).isRequired,proxyPools:d.default.arrayOf(d.default.shape({id:d.default.string,name:d.default.string,proxyUrl:d.default.string,noProxy:d.default.string,isActive:d.default.bool})),isOAuth:d.default.bool.isRequired,isFirst:d.default.bool.isRequired,isLast:d.default.bool.isRequired,onMoveUp:d.default.func.isRequired,onMoveDown:d.default.func.isRequired,onToggleActive:d.default.func.isRequired,onUpdateProxy:d.default.func,onEdit:d.default.func.isRequired,onDelete:d.default.func.isRequired},F.propTypes={isOpen:d.default.bool.isRequired,provider:d.default.string,providerName:d.default.string,isCompatible:d.default.bool,isAnthropic:d.default.bool,proxyPools:d.default.arrayOf(d.default.shape({id:d.default.string,name:d.default.string})),onSave:d.default.func.isRequired,onClose:d.default.func.isRequired},G.propTypes={isOpen:d.default.bool.isRequired,connection:d.default.shape({id:d.default.string,name:d.default.string,email:d.default.string,priority:d.default.number,authType:d.default.string,provider:d.default.string,providerSpecificData:d.default.object}),proxyPools:d.default.arrayOf(d.default.shape({id:d.default.string,name:d.default.string})),onSave:d.default.func.isRequired,onClose:d.default.func.isRequired},H.propTypes={isOpen:d.default.bool.isRequired,node:d.default.shape({id:d.default.string,name:d.default.string,prefix:d.default.string,apiType:d.default.string,baseUrl:d.default.string}),onSave:d.default.func.isRequired,onClose:d.default.func.isRequired,isAnthropic:d.default.bool},I.propTypes={isOpen:d.default.bool.isRequired,providerAlias:d.default.string.isRequired,providerDisplayAlias:d.default.string.isRequired,onSave:d.default.func.isRequired,onClose:d.default.func.isRequired},a.s(["default",0,function(){let a=(0,e.useParams)(),d=(0,e.useRouter)(),j=a.id,[k,x]=(0,c.useState)([]),[y,B]=(0,c.useState)(!0),[D,J]=(0,c.useState)(null),[K,L]=(0,c.useState)([]),[M,N]=(0,c.useState)(!1),[O,P]=(0,c.useState)(!1),[Q,R]=(0,c.useState)(!1),[S,T]=(0,c.useState)(!1),[U,V]=(0,c.useState)(!1),[W,X]=(0,c.useState)(!1),[Y,Z]=(0,c.useState)(!1),[$,_]=(0,c.useState)(null),[aa,ab]=(0,c.useState)(null),[ac,ad]=(0,c.useState)({}),[ae,af]=(0,c.useState)(!1),[ag,ah]=(0,c.useState)({}),[ai,aj]=(0,c.useState)(""),[ak,al]=(0,c.useState)(null),[am,an]=(0,c.useState)(!1),[ao,ap]=(0,c.useState)([]),[aq,ar]=(0,c.useState)("__none__"),[as,at]=(0,c.useState)(!1),[au,av]=(0,c.useState)(null),[aw,ax]=(0,c.useState)(""),[ay,az]=(0,c.useState)([]),[aA,aB]=(0,c.useState)([]),{copied:aC,copy:aD}=(0,w.useCopyToClipboard)(),aE=D?{id:D.id,name:D.name||("anthropic-compatible"===D.type?"Anthropic Compatible":"OpenAI Compatible"),color:"anthropic-compatible"===D.type?"#D97757":"#10A37F",textIcon:"anthropic-compatible"===D.type?"AC":"OC",apiType:D.apiType,baseUrl:D.baseUrl,type:D.type}:u.OAUTH_PROVIDERS[j]||u.APIKEY_PROVIDERS[j]||u.FREE_PROVIDERS[j]||u.FREE_TIER_PROVIDERS[j],aF=!!u.OAUTH_PROVIDERS[j]||!!u.FREE_PROVIDERS[j],aG=(0,v.getModelsByProviderId)(j),aH=(0,u.getProviderAlias)(j),aI=(0,u.isOpenAICompatibleProvider)(j),aJ=(0,u.isAnthropicCompatibleProvider)(j),aK=aI||aJ,aL=aK?j:aH,aM=aK?D?.prefix||j:aH,aN=(0,c.useCallback)(async()=>{try{let a=await fetch("/api/models/alias"),b=await a.json();a.ok&&ad(b.aliases||{})}catch(a){console.log("Error fetching aliases:",a)}},[]);(0,c.useEffect)(()=>{"kilocode"===j&&fetch("/api/providers/kilo/free-models").then(a=>a.json()).then(a=>{a.models?.length&&aB(a.models)}).catch(()=>{})},[j]);let aO=(0,c.useCallback)(async()=>{try{let[a,b,c,d]=await Promise.all([fetch("/api/providers",{cache:"no-store"}),fetch("/api/provider-nodes",{cache:"no-store"}),fetch("/api/proxy-pools?isActive=true",{cache:"no-store"}),fetch("/api/settings",{cache:"no-store"})]),e=await a.json(),f=await b.json(),g=await c.json(),h=d.ok?await d.json():{};if(a.ok){let a=(e.connections||[]).filter(a=>a.provider===j);x(a)}c.ok&&L(g.proxyPools||[]);let i=(h.providerStrategies||{})[j]||{};if(av(i.fallbackStrategy||null),ax(null!=i.stickyRoundRobinLimit?String(i.stickyRoundRobinLimit):"1"),b.ok){let a=(f.nodes||[]).find(a=>a.id===j)||null;if(!a&&aK)for(let b=0;b<3;b+=1){await new Promise(a=>setTimeout(a,150));let b=await fetch("/api/provider-nodes",{cache:"no-store"});if(b.ok&&(a=((await b.json()).nodes||[]).find(a=>a.id===j)||null))break}J(a)}}catch(a){console.log("Error fetching connections:",a)}finally{B(!1)}},[j,aK]),aP=async a=>{try{let b=await fetch(`/api/provider-nodes/${j}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(a)}),c=await b.json();b.ok&&(J(c.node),await aO(),V(!1))}catch(a){console.log("Error updating provider node:",a)}},aQ=async(a,b)=>{try{let c=await fetch("/api/settings",{cache:"no-store"}),d=(c.ok?await c.json():{}).providerStrategies||{},e={};a&&(e.fallbackStrategy=a),"round-robin"===a&&""!==b&&(e.stickyRoundRobinLimit=Number(b)||3);let f={...d};0===Object.keys(e).length?delete f[j]:f[j]=e,await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({providerStrategies:f})})}catch(a){console.log("Error saving provider strategy:",a)}};(0,c.useEffect)(()=>{aO(),aN()},[aO,aN]),(0,c.useEffect)(()=>{let a=(u.OAUTH_PROVIDERS[j]||u.APIKEY_PROVIDERS[j]||u.FREE_PROVIDERS[j]||u.FREE_TIER_PROVIDERS[j])?.modelsFetcher;a&&z(a).then(az)},[j]);let aR=async(a,b,c=aH)=>{let d=`${c}/${a}`;try{let a=await fetch("/api/models/alias",{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:d,alias:b})});if(a.ok)await aN();else{let b=await a.json();alert(b.error||"Failed to set alias")}}catch(a){console.log("Error setting alias:",a)}},aS=async a=>{try{(await fetch(`/api/models/alias?alias=${encodeURIComponent(a)}`,{method:"DELETE"})).ok&&await aN()}catch(a){console.log("Error deleting alias:",a)}},aT=async a=>{if(confirm("Delete this connection?"))try{(await fetch(`/api/providers/${a}`,{method:"DELETE"})).ok&&x(k.filter(b=>b.id!==a))}catch(a){console.log("Error deleting connection:",a)}},aU=()=>{aO(),N(!1)},aV=async a=>{try{(await fetch("/api/providers",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:j,...a})})).ok&&(await aO(),R(!1))}catch(a){console.log("Error saving connection:",a)}},aW=async a=>{try{(await fetch(`/api/providers/${aa.id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(a)})).ok&&(await aO(),T(!1))}catch(a){console.log("Error updating connection:",a)}},aX=async(a,b)=>{try{(await fetch(`/api/providers/${a}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({isActive:b})})).ok&&x(c=>c.map(c=>c.id===a?{...c,isActive:b}:c))}catch(a){console.log("Error updating connection status:",a)}},aY=async(a,b)=>{let c=[...k];[c[a],c[b]]=[c[b],c[a]],x(c);try{await Promise.all([fetch(`/api/providers/${c[a].id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({priority:a})}),fetch(`/api/providers/${c[b].id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({priority:b})})])}catch(a){console.log("Error swapping priority:",a),await aO()}},aZ=k.filter(a=>ao.includes(a.id));k.length>0&&(ao.length,k.length),(0,c.useEffect)(()=>{ap(a=>a.filter(a=>k.some(b=>b.id===a)))},[k]);let a$=(()=>{if(0===aZ.length)return"";let a=new Set(aZ.map(a=>a.providerSpecificData?.proxyPoolId||"__none__"));if(1===a.size){let b=[...a][0];if("__none__"===b)return"All selected currently unbound";let c=K.find(a=>a.id===b);return`All selected currently bound to ${c?.name||b}`}return"Selected connections have mixed proxy bindings"})(),a_=()=>{as||X(!1)},a0=async()=>{if(0===ao.length)return;let a="__none__"===aq?null:aq;at(!0);try{let b=[];for(let c of ao)try{let d=await fetch(`/api/providers/${c}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({proxyPoolId:a})});b.push(d.ok)}catch(a){console.log("Error applying bulk proxy pool for",c,a),b.push(!1)}let c=b.filter(a=>!a).length;c>0&&alert(`Updated with ${c} failed request(s).`),await aO(),ap([]),ar("__none__"),X(!1)}catch(a){console.log("Error applying bulk proxy pool:",a)}finally{at(!1)}},a1=async()=>{Z(!0),_(null);try{let a=await fetch("/api/antigravity-tools/import",{method:"POST"}),b=await a.json();a.ok?(_(b),await aO()):_({error:b.error||"Import failed"})}catch(a){_({error:a.message})}Z(!1)},a2=(0,b.jsx)("div",{className:"flex flex-col divide-y divide-black/[0.03] dark:divide-white/[0.03]",children:k.map((a,c)=>(0,b.jsx)("div",{className:"flex items-stretch",children:(0,b.jsx)("div",{className:"flex-1 min-w-0",children:(0,b.jsx)(E,{connection:a,proxyPools:K,isOAuth:aF,isFirst:0===c,isLast:c===k.length-1,onMoveUp:()=>aY(c,c-1),onMoveDown:()=>aY(c,c+1),onToggleActive:b=>aX(a.id,b),onUpdateProxy:async b=>{try{(await fetch(`/api/providers/${a.id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({proxyPoolId:b||null})})).ok&&x(c=>c.map(c=>c.id===a.id?{...c,providerSpecificData:{...c.providerSpecificData,proxyPoolId:b||null}}:c))}catch(a){console.log("Error updating proxy:",a)}},onEdit:()=>{ab(a),T(!0)},onDelete:()=>aT(a.id)})})},a.id))}),a3=[{value:"__none__",label:"None"},...K.map(a=>({value:a.id,label:a.name}))],a4=0===ao.length?"Select one or more connections, then click Proxy Action.":a$,a5=ao.length>0&&!as,a6=(0,b.jsx)(l.Modal,{isOpen:W,onClose:a_,title:`Proxy Action (${ao.length} selected)`,children:(0,b.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,b.jsx)(t.Select,{label:"Proxy Pool",value:aq,onChange:a=>ar(a.target.value),options:a3,placeholder:"None"}),(0,b.jsx)("p",{className:"text-xs text-text-muted",children:a4}),(0,b.jsx)("p",{className:"text-xs text-text-muted",children:"Selecting None will unbind selected connections from proxy pool."}),(0,b.jsxs)("div",{className:"flex gap-2",children:[(0,b.jsx)(i.Button,{onClick:a0,fullWidth:!0,disabled:!a5,children:as?"Applying...":"Apply"}),(0,b.jsx)(i.Button,{onClick:a_,variant:"ghost",fullWidth:!0,disabled:as,children:"Cancel"})]})]})}),a7=async a=>{if(!ak){al(a);try{let b=await fetch("/api/models/test",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:`${aL}/${a}`})}),c=await b.json();ah(b=>({...b,[a]:c.ok?"ok":"error"})),aj(c.ok?"":c.error||"Model not reachable")}catch{ah(b=>({...b,[a]:"error"})),aj("Network error")}finally{al(null)}}};return y?(0,b.jsxs)("div",{className:"flex flex-col gap-8",children:[(0,b.jsx)(m.CardSkeleton,{}),(0,b.jsx)(m.CardSkeleton,{})]}):aE?(0,b.jsxs)("div",{className:"flex flex-col gap-8",children:[(0,b.jsxs)("div",{children:[(0,b.jsxs)(f.default,{href:"/dashboard/providers",className:"inline-flex items-center gap-1 text-sm text-text-muted hover:text-primary transition-colors mb-4",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-lg",children:"arrow_back"}),"Back to Providers"]}),(0,b.jsxs)("div",{className:"flex items-center gap-4",children:[(0,b.jsx)("div",{className:"rounded-lg flex items-center justify-center",style:{backgroundColor:`${aE.color}15`},children:ae?(0,b.jsx)("span",{className:"text-sm font-bold",style:{color:aE.color},children:aE.textIcon||aE.id.slice(0,2).toUpperCase()}):(0,b.jsx)(g.default,{src:aI&&aE.apiType?"responses"===aE.apiType?"/providers/oai-r.png":"/providers/oai-cc.png":aJ?"/providers/anthropic-m.png":`/providers/${aE.id}.png`,alt:aE.name,width:48,height:48,className:"object-contain rounded-lg max-w-[48px] max-h-[48px]",sizes:"48px",onError:()=>af(!0)})}),(0,b.jsxs)("div",{children:[(0,b.jsx)("h1",{className:"text-3xl font-semibold tracking-tight",children:aE.name}),(0,b.jsxs)("p",{className:"text-text-muted",children:[k.length," connection",1===k.length?"":"s"]})]})]})]}),aE.deprecated&&(0,b.jsxs)("div",{className:"flex items-start gap-2 px-3 py-2 rounded-lg bg-black/[0.02] dark:bg-white/[0.02] border border-black/[0.05] dark:border-white/[0.05]",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-[16px] text-text-muted mt-0.5 shrink-0",children:"info"}),(0,b.jsx)("p",{className:"text-xs text-text-muted leading-relaxed",children:aE.deprecationNotice})]}),aE.notice&&!aE.deprecated&&(0,b.jsxs)("div",{className:"flex items-center gap-2 px-3 py-2 rounded-lg bg-black/[0.02] dark:bg-white/[0.02] border border-black/[0.05] dark:border-white/[0.05]",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-[16px] text-text-muted shrink-0",children:"info"}),(0,b.jsx)("p",{className:"text-xs text-text-muted leading-relaxed",children:aE.notice.text}),aE.notice.apiKeyUrl&&(0,b.jsx)("a",{href:aE.notice.apiKeyUrl,target:"_blank",rel:"noopener noreferrer",className:"text-xs text-primary hover:underline shrink-0",children:"Get API Key →"})]}),aK&&D&&(0,b.jsxs)(h.Card,{children:[(0,b.jsxs)("div",{className:"flex items-center justify-between mb-4",children:[(0,b.jsxs)("div",{children:[(0,b.jsx)("h2",{className:"text-lg font-semibold",children:aJ?"Anthropic Compatible Details":"OpenAI Compatible Details"}),(0,b.jsxs)("p",{className:"text-sm text-text-muted",children:[aJ?"Messages API":"responses"===D.apiType?"Responses API":"Chat Completions"," · ",(D.baseUrl||"").replace(/\/$/,""),"/",aJ?"messages":"responses"===D.apiType?"responses":"chat/completions"]})]}),(0,b.jsxs)("div",{className:"flex items-center gap-2",children:[(0,b.jsx)(i.Button,{size:"sm",icon:"add",onClick:()=>R(!0),disabled:k.length>0,children:"Add"}),(0,b.jsx)(i.Button,{size:"sm",variant:"secondary",icon:"edit",onClick:()=>V(!0),children:"Edit"}),(0,b.jsx)(i.Button,{size:"sm",variant:"secondary",icon:"delete",onClick:async()=>{if(confirm(`Delete this ${aJ?"Anthropic":"OpenAI"} Compatible node?`))try{(await fetch(`/api/provider-nodes/${j}`,{method:"DELETE"})).ok&&d.push("/dashboard/providers")}catch(a){console.log("Error deleting provider node:",a)}},children:"Delete"})]})]}),k.length>0&&(0,b.jsx)("p",{className:"text-sm text-text-muted",children:"Only one connection is allowed per compatible node. Add another node if you need more connections."})]}),(0,b.jsxs)(h.Card,{children:[(0,b.jsxs)("div",{className:"flex items-center justify-between mb-4",children:[(0,b.jsx)("h2",{className:"text-lg font-semibold",children:"Connections"}),(0,b.jsxs)("div",{className:"flex items-center gap-2",children:[(0,b.jsx)("span",{className:"text-xs text-text-muted font-medium",children:"Round Robin"}),(0,b.jsx)(s.Toggle,{checked:"round-robin"===au,onChange:a=>{let b=a?"round-robin":null,c=a?aw||"1":aw;a&&!aw&&ax("1"),av(b),aQ(b,c)}}),"round-robin"===au&&(0,b.jsxs)("div",{className:"flex items-center gap-1.5",children:[(0,b.jsx)("span",{className:"text-xs text-text-muted",children:"Sticky:"}),(0,b.jsx)("input",{type:"number",min:1,value:aw,onChange:a=>{var b;ax(b=a.target.value),aQ("round-robin",b)},placeholder:"1",className:"w-14 px-2 py-1 text-xs border border-border rounded-md bg-background focus:outline-none focus:border-primary"})]})]})]}),$&&(0,b.jsxs)("div",{className:`flex items-center justify-between gap-2 mb-3 px-3 py-2 rounded-lg text-xs ${$.error?"bg-red-500/5 border border-red-500/15 text-red-500":"bg-green-500/5 border border-green-500/15 text-green-600"}`,children:[(0,b.jsx)("span",{children:$.error?`✗ ${$.error}`:`✓ Imported ${$.imported}, updated ${$.updated}, skipped ${$.skipped}`}),(0,b.jsx)("button",{onClick:()=>_(null),className:"text-current opacity-60 hover:opacity-100",children:"✕"})]}),0===k.length?(0,b.jsxs)("div",{className:"text-center py-12",children:[(0,b.jsx)("div",{className:"inline-flex items-center justify-center w-16 h-16 rounded-full bg-primary/10 text-primary mb-4",children:(0,b.jsx)("span",{className:"material-symbols-outlined text-[32px]",children:aF?"lock":"key"})}),(0,b.jsx)("p",{className:"text-text-main font-medium mb-1",children:"No connections yet"}),(0,b.jsx)("p",{className:"text-sm text-text-muted mb-4",children:"Add your first connection to get started"}),!aK&&(0,b.jsxs)("div",{className:"flex gap-2 justify-center",children:["iflow"===j&&(0,b.jsx)(i.Button,{icon:"cookie",variant:"secondary",onClick:()=>P(!0),children:"Cookie Auth"}),(0,b.jsx)(i.Button,{icon:"add",onClick:()=>aF?N(!0):R(!0),children:"iflow"===j?"OAuth":"Add Connection"}),"antigravity"===j&&(0,b.jsx)(i.Button,{icon:"download",variant:"secondary",onClick:a1,disabled:Y,children:Y?"Importing…":"Import from AGT"})]})]}):(0,b.jsxs)(b.Fragment,{children:[a2,!aK&&(0,b.jsxs)("div",{className:"flex gap-2 mt-4",children:["iflow"===j&&(0,b.jsx)(i.Button,{size:"sm",icon:"cookie",variant:"secondary",onClick:()=>P(!0),title:"Add connection using browser cookie",children:"Cookie"}),(0,b.jsx)(i.Button,{size:"sm",icon:"add",onClick:()=>aF?N(!0):R(!0),children:"Add"}),"antigravity"===j&&(0,b.jsx)(i.Button,{size:"sm",icon:"download",variant:"secondary",onClick:a1,disabled:Y,children:Y?"Importing…":"Import from AGT"})]})]})]}),(0,b.jsxs)(h.Card,{children:[(0,b.jsx)("div",{className:"flex items-center justify-between mb-4",children:(0,b.jsx)("h2",{className:"text-lg font-semibold",children:"Available Models"})}),!!ai&&(0,b.jsx)("p",{className:"text-xs text-red-500 mb-3 break-words",children:ai}),(()=>{let a,c;if(aK)return(0,b.jsx)(C,{providerStorageAlias:aL,providerDisplayAlias:aM,modelAliases:ac,copied:aC,onCopy:aD,onSetAlias:aR,onDeleteAlias:aS,connections:k,isAnthropic:aJ});let d=[...aG,...aA.filter(a=>!aG.some(b=>b.id===a.id))],e=Object.entries(ac).filter(([a,b])=>{let c=`${aL}/`;if(!b.startsWith(c))return!1;let d=b.slice(c.length);return aE.passthroughModels?!aG.some(a=>a.id===d):!aG.some(a=>a.id===d)&&a===d}).map(([a,b])=>({id:b.slice(`${aL}/`.length),alias:a,fullModel:b}));return(0,b.jsxs)("div",{className:"flex flex-wrap gap-3",children:[d.map(a=>{let c=`${aL}/${a.id}`,d=`${j}/${a.id}`,e=Object.entries(ac).find(([,a])=>a===c||a===d)?.[0];return(0,b.jsx)(A,{model:a,fullModel:`${aM}/${a.id}`,alias:e,copied:aC,onCopy:aD,onSetAlias:b=>aR(a.id,b,aL),onDeleteAlias:()=>aS(e),testStatus:ag[a.id],onTest:k.length>0?()=>a7(a.id):void 0,isTesting:ak===a.id,isFree:a.isFree},a.id)}),e.map(a=>(0,b.jsx)(A,{model:{id:a.id},fullModel:`${aM}/${a.id}`,alias:a.alias,copied:aC,onCopy:aD,onSetAlias:()=>{},onDeleteAlias:()=>aS(a.alias),testStatus:ag[a.id],onTest:k.length>0?()=>a7(a.id):void 0,isTesting:ak===a.id,isCustom:!0},a.id)),(0,b.jsxs)("button",{onClick:()=>an(!0),className:"flex items-center gap-1.5 px-3 py-2 rounded-lg border border-dashed border-black/15 dark:border-white/15 text-xs text-text-muted hover:text-primary hover:border-primary/40 transition-colors",children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-sm",children:"add"}),"Add Model"]}),ay.length>0&&(a=new Set(Object.values(ac)),0===(c=ay.filter(b=>!a.has(`${aL}/${b.id}`))).length?null:(0,b.jsxs)("div",{className:"w-full mt-2",children:[(0,b.jsx)("p",{className:"text-xs text-text-muted mb-2",children:"Suggested free models (≥200k context):"}),(0,b.jsx)("div",{className:"flex flex-wrap gap-2",children:c.map(a=>(0,b.jsxs)("button",{onClick:async()=>{let b=a.id.split("/").pop();await aR(a.id,b,aL)},className:"flex items-center gap-1 px-2.5 py-1.5 rounded-lg border border-black/10 dark:border-white/10 text-xs text-text-muted hover:text-primary hover:border-primary/40 hover:bg-primary/5 transition-colors",title:`${a.name} \xb7 ${(a.contextLength/1e3).toFixed(0)}k ctx`,children:[(0,b.jsx)("span",{className:"material-symbols-outlined text-[13px]",children:"add"}),a.id.split("/").pop()]},a.id))})]}))]})})()]}),a6,"kiro"===j?(0,b.jsx)(o.default,{isOpen:M,providerInfo:aE,onSuccess:aU,onClose:()=>N(!1)}):"cursor"===j?(0,b.jsx)(p.default,{isOpen:M,onSuccess:aU,onClose:()=>N(!1)}):"gitlab"===j?(0,b.jsx)(r.default,{isOpen:M,providerInfo:aE,onSuccess:aU,onClose:()=>N(!1)}):(0,b.jsx)(n.OAuthModal,{isOpen:M,provider:j,providerInfo:aE,onSuccess:aU,onClose:()=>N(!1)}),"iflow"===j&&(0,b.jsx)(q.default,{isOpen:O,onSuccess:()=>{aO(),P(!1)},onClose:()=>P(!1)}),(0,b.jsx)(F,{isOpen:Q,provider:j,providerName:aE.name,isCompatible:aK,isAnthropic:aJ,proxyPools:K,onSave:aV,onClose:()=>R(!1)}),(0,b.jsx)(G,{isOpen:S,connection:aa,proxyPools:K,onSave:aW,onClose:()=>T(!1)}),aK&&(0,b.jsx)(H,{isOpen:U,node:D,onSave:aP,onClose:()=>V(!1),isAnthropic:aJ}),!aK&&(0,b.jsx)(I,{isOpen:am,providerAlias:aL,providerDisplayAlias:aM,onSave:async a=>{let b=aE?.passthroughModels?a.split("/").pop():a;await aR(a,b,aL),an(!1)},onClose:()=>an(!1)})]}):(0,b.jsxs)("div",{className:"text-center py-20",children:[(0,b.jsx)("p",{className:"text-text-muted",children:"Provider not found"}),(0,b.jsx)(f.default,{href:"/dashboard/providers",className:"text-primary mt-4 inline-block",children:"Back to Providers"})]})}],69617)}];
2
2
 
3
3
  //# sourceMappingURL=src_app_%28dashboard%29_dashboard_providers_%5Bid%5D_page_0-3xvzc.js.map
@@ -7,9 +7,9 @@ globalThis.__BUILD_MANIFEST = {
7
7
  "static/chunks/03~yq9q893hmn.js"
8
8
  ],
9
9
  "lowPriorityFiles": [
10
- "static/Fr7ipSei0ydO_aZHViw9O/_buildManifest.js",
11
- "static/Fr7ipSei0ydO_aZHViw9O/_ssgManifest.js",
12
- "static/Fr7ipSei0ydO_aZHViw9O/_clientMiddlewareManifest.js"
10
+ "static/XSoZ0BJFg1b0W2IGyybf7/_buildManifest.js",
11
+ "static/XSoZ0BJFg1b0W2IGyybf7/_ssgManifest.js",
12
+ "static/XSoZ0BJFg1b0W2IGyybf7/_clientMiddlewareManifest.js"
13
13
  ],
14
14
  "rootMainFiles": [
15
15
  "static/chunks/0vn3aevizo-in.js",