@openhands/agent-canvas 1.0.0-beta.6 → 1.0.0-beta.8

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 (802) hide show
  1. package/README.md +24 -7
  2. package/README.windows.md +27 -0
  3. package/bin/agent-canvas.mjs +26 -3
  4. package/build/assets/{QueryClientProvider-CkGuhXg-.js → QueryClientProvider-Cnr-Yl3j.js} +1 -1
  5. package/build/assets/{Trans-Cvm_-SMi.js → Trans-4jmk54WC.js} +1 -1
  6. package/build/assets/acp-providers-BAX8OU5C.js +1 -0
  7. package/build/assets/{acp-route-guard-B2yoBZ_4.js → acp-route-guard-HPk6TV-L.js} +1 -1
  8. package/build/assets/active-backend-context-BSPE-W72.js +1 -0
  9. package/build/assets/add-backend-modal-mXKmfMI2.js +1 -0
  10. package/build/assets/agent-server-client-options-9agOSarV.js +1 -0
  11. package/build/assets/agent-server-compatibility-B7QStIcH.js +1 -0
  12. package/build/assets/agent-server-conversation-service.api-B9TUYJon.js +5 -0
  13. package/build/assets/{agent-settings-CnGSCmK8.js → agent-settings-g3F623RJ.js} +1 -1
  14. package/build/assets/{alert-banner-DtzAX654.js → alert-banner-DFnn_lC6.js} +1 -1
  15. package/build/assets/{analytics-consent-form-modal-CHZ3I37v.js → analytics-consent-form-modal-BQCNeNVt.js} +1 -1
  16. package/build/assets/api-key-entry-screen-myuWMqzW.js +1 -0
  17. package/build/assets/{app-settings-Db9ITeJH.js → app-settings-CCcX8ZEH.js} +1 -1
  18. package/build/assets/automation-detail-BDHLHSJd.js +1 -0
  19. package/build/assets/automations-list-CiNtQhq_.js +1 -0
  20. package/build/assets/back-nav-button-7dQJ2k3O.js +1 -0
  21. package/build/assets/backend-form-modal-D3bDMO3C.js +1 -0
  22. package/build/assets/{backend-synced-settings-badge-Dc6c7GT4.js → backend-synced-settings-badge-BkW5evM0.js} +1 -1
  23. package/build/assets/base-modal-C2oy2EBG.js +1 -0
  24. package/build/assets/brand-button-DJ_S16rO.js +1 -0
  25. package/build/assets/{browser-D810xUYt.js → browser-CGM-k-sH.js} +2 -2
  26. package/build/assets/browser-store-DAsixKdU.js +1 -0
  27. package/build/assets/{browser-tab-B-aIqXRl.js → browser-tab-dvSPdvkm.js} +1 -1
  28. package/build/assets/{checkmark-DL7acQA7.js → checkmark-Dus0b6jt.js} +1 -1
  29. package/build/assets/{chevron-left-small-CVWf8TI6.js → chevron-left-small-_uvG7RVM.js} +1 -1
  30. package/build/assets/{circle-plus-check-toggle-P7ZZToV4.js → circle-plus-check-toggle-DKS8MAVV.js} +1 -1
  31. package/build/assets/{close-B5LROHR3.js → close-BU5iTc66.js} +1 -1
  32. package/build/assets/code-tag-BzyqOtPD.js +1 -0
  33. package/build/assets/combobox-caret-BJC7XJsz.js +1 -0
  34. package/build/assets/{command-store-DFN_17p1.js → command-store-CE1weJy8.js} +1 -1
  35. package/build/assets/{condenser-settings-wnEKhBof.js → condenser-settings-DCTulgLO.js} +1 -1
  36. package/build/assets/{confirmation-modal-Dau3w_sa.js → confirmation-modal-B5Ca6qFE.js} +1 -1
  37. package/build/assets/context-menu-list-item-7tAcm2c3.js +1 -0
  38. package/build/assets/conversation-BKhikfYl.js +1 -0
  39. package/build/assets/conversation-DTn8jN8L.js +19 -0
  40. package/build/assets/conversation-panel-DfHR42mG.js +1 -0
  41. package/build/assets/conversation-service.api-B6CkzaKD.js +1 -0
  42. package/build/assets/conversation-state-store-D-w0uurj.js +1 -0
  43. package/build/assets/conversation-store-CC-isCnP.js +1 -0
  44. package/build/assets/{conversation-tab-empty-state-DyssnnWa.js → conversation-tab-empty-state-CStQLPVW.js} +1 -1
  45. package/build/assets/conversation-websocket-context-DShEuLjh.js +3 -0
  46. package/build/assets/{copy-DYgmUdIw.js → copy-Chg-sFu3.js} +1 -1
  47. package/build/assets/{custom-toast-handlers-C-SZFmto.js → custom-toast-handlers-ufGJ6_Rc.js} +1 -1
  48. package/build/assets/declaration-CR6HMp29.js +1 -0
  49. package/build/assets/{device-verify-DqDlphsG.js → device-verify-C6mj28zv.js} +1 -1
  50. package/build/assets/dist-DNeWJ2bh.js +1 -0
  51. package/build/assets/dropdown-classes-BsVmxlNG.js +1 -0
  52. package/build/assets/edit-automation-modal-DamwL0s0.js +1 -0
  53. package/build/assets/ellipsis-button-Vh5MvRZa.js +1 -0
  54. package/build/assets/entry.client-Cn71WM8q.js +2 -0
  55. package/build/assets/enum-filter-dropdown-5JeF2RLb.js +1 -0
  56. package/build/assets/{environment-switch-overlay-XL8yCGP6.js → environment-switch-overlay-Tf_BIfeR.js} +1 -1
  57. package/build/assets/extensions-hub-CUEmfvGy.js +1 -0
  58. package/build/assets/{extensions-navigation-BYR8Giqq.js → extensions-navigation-VQ-3umJ7.js} +1 -1
  59. package/build/assets/file-BTY6Gyy9.js +1 -0
  60. package/build/assets/files-tab-C47fQEeL.js +1 -0
  61. package/build/assets/files-tab-store-m0ARqX_E.js +1 -0
  62. package/build/assets/{folder-ZZJVGgd7.js → folder-D1T2W1cj.js} +1 -1
  63. package/build/assets/git-control-bar-branch-button-BT0aWH-o.js +27 -0
  64. package/build/assets/git-provider-icon-Pi-Cxpgv.js +1 -0
  65. package/build/assets/globe-Bzj_0oXT.js +1 -0
  66. package/build/assets/home-C3k6sFvB.js +1 -0
  67. package/build/assets/{i18n-CTohRuoO.js → i18n-DET2iOyh.js} +1 -1
  68. package/build/assets/install-server-modal-6fuq-TU6.js +1 -0
  69. package/build/assets/launch-DGghLfGx.js +1 -0
  70. package/build/assets/{lesson-plan-dH5Bj0pN.js → lesson-plan-duSsqWVs.js} +1 -1
  71. package/build/assets/link-external-DGxVm4Ps.js +1 -0
  72. package/build/assets/{llm-client-DaH1TuyR.js → llm-client-BqyLKgUN.js} +1 -1
  73. package/build/assets/llm-settings-BKraGtOu.js +1 -0
  74. package/build/assets/llm-settings-DRQTgOF1.js +1 -0
  75. package/build/assets/{loading-spinner-BPtYORNK.js → loading-spinner-5GT9q1xy.js} +1 -1
  76. package/build/assets/manage-backends-modal-CRMwyU0t.js +1 -0
  77. package/build/assets/manage-workspaces-modal-BYmGD1W7.js +1 -0
  78. package/build/assets/manifest-99b06a11.js +1 -0
  79. package/build/assets/{markdown-renderer-DMzf2i4x.js → markdown-renderer-B3IAVfv4.js} +1 -1
  80. package/build/assets/mcp-CfDRAmPn.js +9 -0
  81. package/build/assets/messages-Ba1vaw6t.js +36 -0
  82. package/build/assets/{modal-backdrop-BAbgYsqB.js → modal-backdrop-RfNCrSpK.js} +1 -1
  83. package/build/assets/{modal-body-BI6Ru2Qr.js → modal-body-aoa2fx5W.js} +1 -1
  84. package/build/assets/modal-classes-6YqcqA6y.js +1 -0
  85. package/build/assets/{modal-close-button-t1Gh3qmL.js → modal-close-button-CtWOUMmw.js} +1 -1
  86. package/build/assets/{model-selector-SM9IUz-q.js → model-selector-DcztJSxT.js} +1 -1
  87. package/build/assets/{navigation-context-D0YWpT8d.js → navigation-context-BdKYH32C.js} +1 -1
  88. package/build/assets/{navigation-link-Cn7KP3c5.js → navigation-link-U4vY9i_C.js} +1 -1
  89. package/build/assets/{openhands-logo-CnrF6LKb.js → openhands-logo-CCo0wJZX.js} +1 -1
  90. package/build/assets/{option-service.api-KvY_mZMY.js → option-service.api-CGNANEcT.js} +1 -1
  91. package/build/assets/{organization-service.api-DzYTHTYC.js → organization-service.api-BeuMC9QL.js} +1 -1
  92. package/build/assets/{path-utils-C3bQf6lJ.js → path-utils-z12iCrQO.js} +1 -1
  93. package/build/assets/{plan-components-atxXCF0R.js → plan-components-CRDMQzsS.js} +1 -1
  94. package/build/assets/{planner-tab-BlrCpv-7.js → planner-tab-Dte6Vzza.js} +1 -1
  95. package/build/assets/{profiles-client-D6IkTJof.js → profiles-client-BrqNmaDV.js} +1 -1
  96. package/build/assets/{providers-Bx6EfrzZ.js → providers-eUyo6pgr.js} +1 -1
  97. package/build/assets/proxy-BqDMnUY-.js +1 -0
  98. package/build/assets/{query-client-config-B7u9asM0.js → query-client-config-CRnGSujB.js} +1 -1
  99. package/build/assets/{recommended-automations-launcher-CgV8FyPK.js → recommended-automations-launcher-D5ADbXao.js} +3 -3
  100. package/build/assets/{root-dNntxffj.js → root-BmhaEJJ8.js} +2 -2
  101. package/build/assets/root-Z2VHU4R3.css +1 -0
  102. package/build/assets/root-layout-CNggm0d8.js +2 -0
  103. package/build/assets/{sdk-section-page-DOIKvwSL.js → sdk-section-page-CRCRY3PG.js} +1 -1
  104. package/build/assets/{sdk-settings-schema-DsUf9wu1.js → sdk-settings-schema-CLmJ9sho.js} +1 -1
  105. package/build/assets/{search-27Owlc3A.js → search-SuJctqNJ.js} +1 -1
  106. package/build/assets/secrets-service-B9AFn9OE.js +1 -0
  107. package/build/assets/secrets-settings-0UrKMS60.js +1 -0
  108. package/build/assets/{server-client-DyAQ3NZ_.js → server-client-DYv_GHPl.js} +1 -1
  109. package/build/assets/{settings-BYkVX7vW.js → settings-6t6LGW04.js} +1 -1
  110. package/build/assets/{settings-dropdown-input-BJYvGdg-.js → settings-dropdown-input-BtoovFre.js} +1 -1
  111. package/build/assets/{settings-gear-C77PgE_O.js → settings-gear-Dd8K2_8B.js} +1 -1
  112. package/build/assets/settings-index-CR6Ou73o.js +1 -0
  113. package/build/assets/{settings-input-Bn7F5C75.js → settings-input-CehsXnb3.js} +1 -1
  114. package/build/assets/settings-list-classes-E3v_f6QG.js +1 -0
  115. package/build/assets/settings-modal-T_Yk1Zfo.js +1 -0
  116. package/build/assets/{settings-section-header-context-BgZe5YkE.js → settings-section-header-context-DewwJ0-F.js} +1 -1
  117. package/build/assets/settings-service.api-DwtyDeGh.js +1 -0
  118. package/build/assets/{settings-switch-BeIKrWms.js → settings-switch-BiBuS3xa.js} +1 -1
  119. package/build/assets/{settings-utils-B6Nl07io.js → settings-utils-DY04tWG1.js} +1 -1
  120. package/build/assets/{shared-conversation-AMyqXvpk.js → shared-conversation-BzccsVej.js} +1 -1
  121. package/build/assets/sidebar-mobile-menu-toggle-DGlRg6jG.js +1 -0
  122. package/build/assets/{sidebar-nav-link-BGjiJq-4.js → sidebar-nav-link-dgVb8Fpy.js} +1 -1
  123. package/build/assets/{sidebar-store-Uy3v0AOV.js → sidebar-store-DnQAJAE5.js} +1 -1
  124. package/build/assets/{skill-card-pill-row-DF1axQCG.js → skill-card-pill-row-BW9qvhoK.js} +1 -1
  125. package/build/assets/{skills-ChIKZPK4.js → skills-0GRKX5Xj.js} +1 -1
  126. package/build/assets/{skills-plugins-CcI_19lM.js → skills-plugins-DctDrZ8Y.js} +1 -1
  127. package/build/assets/skills-settings-rvxImDj_.js +2 -0
  128. package/build/assets/{styled-tooltip-CBzrri6o.js → styled-tooltip-hdfMXPQC.js} +1 -1
  129. package/build/assets/{switch-skeleton-DnC9wLp7.js → switch-skeleton-DSKqSx2A.js} +1 -1
  130. package/build/assets/{task-list-tab-DUJn1sgz.js → task-list-tab-DT6_zfUs.js} +1 -1
  131. package/build/assets/{terminal-RmuaSdhJ.js → terminal-CPYWdo4j.js} +1 -1
  132. package/build/assets/{terminal-DgQk1Ay6.js → terminal-KldRPIRT.js} +2 -2
  133. package/build/assets/{toggle-switch-Pvyp2RAN.js → toggle-switch-T2v6sJ6l.js} +1 -1
  134. package/build/assets/{typography-gpuWmrQO.js → typography-BDgnT7Yp.js} +1 -1
  135. package/build/assets/{u-check-circle-IUIfACQQ.js → u-check-circle-DOauqQKb.js} +1 -1
  136. package/build/assets/{u-check-circle-half-C1YxB6py.js → u-check-circle-half-steSK_JB.js} +1 -1
  137. package/build/assets/{u-circuit-BmVikJHu.js → u-circuit-x3ExjBbU.js} +1 -1
  138. package/build/assets/{u-edit-CFvXHqZk.js → u-edit-BbrptMCa.js} +1 -1
  139. package/build/assets/{use-active-conversation-BEFNwnFk.js → use-active-conversation-sPgfSkql.js} +1 -1
  140. package/build/assets/use-agent-settings-schema-B66kGIi_.js +1 -0
  141. package/build/assets/{use-agent-state-Bkrd1FZq.js → use-agent-state-Dp3pD1h3.js} +1 -1
  142. package/build/assets/{use-cloud-current-user-id-CvkXFnTT.js → use-cloud-current-user-id-ClKFPjFz.js} +1 -1
  143. package/build/assets/{use-config-Co1O8-Ey.js → use-config-C9pvb0Sm.js} +1 -1
  144. package/build/assets/{use-create-conversation-CEgXpkfH.js → use-create-conversation-B-lwTnfE.js} +1 -1
  145. package/build/assets/{use-event-store-BT_gV3ut.js → use-event-store-BomO7ywK.js} +1 -1
  146. package/build/assets/{use-get-secrets-DuhdIA59.js → use-get-secrets-oyC7PFRz.js} +1 -1
  147. package/build/assets/{use-handle-plan-click-Ckkm5eIY.js → use-handle-plan-click-DP6Rs-YP.js} +1 -1
  148. package/build/assets/use-is-authed-dw2026rR.js +1 -0
  149. package/build/assets/{use-is-creating-conversation-BZ5hB_Bg.js → use-is-creating-conversation-DX2qSlfL.js} +1 -1
  150. package/build/assets/{use-launch-skill-in-chat-fNN_xGZG.js → use-launch-skill-in-chat-sQNEOLGD.js} +1 -1
  151. package/build/assets/use-llm-profiles-Bh5JqZUZ.js +1 -0
  152. package/build/assets/use-runtime-is-ready-BakOUVU-.js +1 -0
  153. package/build/assets/{use-save-settings-VUrj_QNG.js → use-save-settings-uXXkqvD7.js} +1 -1
  154. package/build/assets/use-settings-DeO7nvpM.js +1 -0
  155. package/build/assets/{use-settings-nav-items-1ZvovKSr.js → use-settings-nav-items-BGMFn25b.js} +1 -1
  156. package/build/assets/{use-skills-DAMLFjKU.js → use-skills-DWIK3l3a.js} +1 -1
  157. package/build/assets/{use-task-list-CLJbuJgM.js → use-task-list-CsT10CBb.js} +1 -1
  158. package/build/assets/{use-unified-vscode-url-DdSRw-6P.js → use-unified-vscode-url-DXPtB317.js} +1 -1
  159. package/build/assets/use-user-conversation-DJen4YIP.js +1 -0
  160. package/build/assets/{useMutation-DqrumCWD.js → useMutation-GSSKKebK.js} +1 -1
  161. package/build/assets/{useTranslation-DCOdSSMl.js → useTranslation-B6voJV4y.js} +1 -1
  162. package/build/assets/utils-DCVfKFRt.js +1 -0
  163. package/build/assets/{vendor~browser-BNjNhjFU.js → vendor~browser-BrOJLj3y.js} +1 -1
  164. package/build/assets/vendor~conversation-panel~conversation-C9o-K1hW.js +1 -0
  165. package/build/assets/vendor~conversation-panel~conversation~index-RXYdJYxU.js +1 -0
  166. package/build/assets/{vendor~entry.client~root~root-layout~home~conversation-panel~conversation~launch~skills-set~jfc6hidu-VnmIZrq3.js → vendor~entry.client~root~root-layout~home~conversation-panel~conversation~launch~skills-set~jfc6hidu-DJS-rJdI.js} +1 -1
  167. package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-DpAdkv8m.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-6ByzelMS.js} +1 -1
  168. package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-B92czPCF.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-BED5W_c4.js} +1 -1
  169. package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-By5W2oHN.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-CCbqAFiI.js} +1 -1
  170. package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-BbFOrAjI.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-CG96FCly.js} +1 -1
  171. package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-smY2r837.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-E4d6IEfI.js} +1 -1
  172. package/build/assets/{vendor~home~mcp~automations-list-Cs-TO3fK.js → vendor~home~mcp~automations-list-CZSK-lT2.js} +1 -1
  173. package/build/assets/{vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-Z3nsiNNq.js → vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-CjJdFLoM.js} +1 -1
  174. package/build/assets/{vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-DbfELDJu.js → vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-m8dOii0J.js} +2 -2
  175. package/build/assets/{vendor~root-layout~home~conversation-panel~conversation-DjAjXS5J.js → vendor~root-layout~home~conversation-panel~conversation-B5WNMnt4.js} +1 -1
  176. package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~i4kjfqhl-CbAhtEMv.js +1 -0
  177. package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-6Rm8U_Sr.js +9 -0
  178. package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-BkQGKpye.js → vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-tTR8C6m0.js} +1 -1
  179. package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~k776hupu-Bbs7UJ5U.js → vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~k776hupu-BJbu9kpL.js} +2 -2
  180. package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~dp08i1qy-DTwbEEcX.js → vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~dp08i1qy-D8soyAAx.js} +1 -1
  181. package/build/assets/{vendor~root~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-s~f2l2lr17-CDXvdvb2.js → vendor~root~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-s~f2l2lr17-DYXOLEck.js} +1 -1
  182. package/build/assets/{verification-settings-CsbvQcYS.js → verification-settings-C_zHuDx9.js} +1 -1
  183. package/build/assets/{vscode-tab-DjNArCgY.js → vscode-tab-DH9x7xXS.js} +1 -1
  184. package/build/assets/{waiting-for-runtime-message-CntjExbU.js → waiting-for-runtime-message-CdK3btDZ.js} +1 -1
  185. package/build/assets/{x-mark-CrpjscNc.js → x-mark-BrkSPIiT.js} +1 -1
  186. package/build/index.html +4 -4
  187. package/build/locales/ar/openhands.json +20 -2
  188. package/build/locales/ca/openhands.json +20 -2
  189. package/build/locales/de/openhands.json +20 -2
  190. package/build/locales/en/openhands.json +20 -2
  191. package/build/locales/es/openhands.json +20 -2
  192. package/build/locales/fr/openhands.json +20 -2
  193. package/build/locales/it/openhands.json +20 -2
  194. package/build/locales/ja/openhands.json +20 -2
  195. package/build/locales/ko-KR/openhands.json +20 -2
  196. package/build/locales/no/openhands.json +20 -2
  197. package/build/locales/pt/openhands.json +20 -2
  198. package/build/locales/tr/openhands.json +20 -2
  199. package/build/locales/uk/openhands.json +20 -2
  200. package/build/locales/zh-CN/openhands.json +20 -2
  201. package/build/locales/zh-TW/openhands.json +20 -2
  202. package/dist/api/acp-service/acp-service.api.d.ts +18 -0
  203. package/dist/api/agent-server-adapter.cjs +3 -3
  204. package/dist/api/agent-server-adapter.cjs.map +1 -1
  205. package/dist/api/agent-server-adapter.js +54 -55
  206. package/dist/api/agent-server-adapter.js.map +1 -1
  207. package/dist/api/agent-server-client-options.cjs +1 -1
  208. package/dist/api/agent-server-client-options.cjs.map +1 -1
  209. package/dist/api/agent-server-client-options.d.ts +4 -0
  210. package/dist/api/agent-server-client-options.js +18 -12
  211. package/dist/api/agent-server-client-options.js.map +1 -1
  212. package/dist/api/agent-server-compatibility.cjs +1 -1
  213. package/dist/api/agent-server-compatibility.cjs.map +1 -1
  214. package/dist/api/agent-server-compatibility.d.ts +1 -1
  215. package/dist/api/agent-server-compatibility.js +30 -25
  216. package/dist/api/agent-server-compatibility.js.map +1 -1
  217. package/dist/api/agent-server-config.cjs +1 -1
  218. package/dist/api/agent-server-config.cjs.map +1 -1
  219. package/dist/api/agent-server-config.d.ts +15 -48
  220. package/dist/api/agent-server-config.js +25 -69
  221. package/dist/api/agent-server-config.js.map +1 -1
  222. package/dist/api/backend-registry/active-store.cjs +1 -1
  223. package/dist/api/backend-registry/active-store.cjs.map +1 -1
  224. package/dist/api/backend-registry/active-store.d.ts +11 -5
  225. package/dist/api/backend-registry/active-store.js +36 -27
  226. package/dist/api/backend-registry/active-store.js.map +1 -1
  227. package/dist/api/backend-registry/auth.cjs +1 -1
  228. package/dist/api/backend-registry/auth.cjs.map +1 -1
  229. package/dist/api/backend-registry/auth.js +3 -9
  230. package/dist/api/backend-registry/auth.js.map +1 -1
  231. package/dist/api/backend-registry/default-backend.cjs +1 -1
  232. package/dist/api/backend-registry/default-backend.cjs.map +1 -1
  233. package/dist/api/backend-registry/default-backend.d.ts +9 -16
  234. package/dist/api/backend-registry/default-backend.js +5 -4
  235. package/dist/api/backend-registry/default-backend.js.map +1 -1
  236. package/dist/api/backend-registry/storage.cjs +1 -1
  237. package/dist/api/backend-registry/storage.cjs.map +1 -1
  238. package/dist/api/backend-registry/storage.js +67 -34
  239. package/dist/api/backend-registry/storage.js.map +1 -1
  240. package/dist/api/cloud/conversation-service.api.cjs.map +1 -1
  241. package/dist/api/cloud/conversation-service.api.d.ts +8 -13
  242. package/dist/api/cloud/conversation-service.api.js.map +1 -1
  243. package/dist/api/cloud/organization-service.api.cjs.map +1 -1
  244. package/dist/api/cloud/organization-service.api.d.ts +1 -2
  245. package/dist/api/cloud/organization-service.api.js.map +1 -1
  246. package/dist/api/cloud/proxy.cjs +1 -1
  247. package/dist/api/cloud/proxy.cjs.map +1 -1
  248. package/dist/api/cloud/proxy.d.ts +6 -6
  249. package/dist/api/cloud/proxy.js +33 -24
  250. package/dist/api/cloud/proxy.js.map +1 -1
  251. package/dist/api/cloud/sandbox-service.api.cjs.map +1 -1
  252. package/dist/api/cloud/sandbox-service.api.d.ts +3 -3
  253. package/dist/api/cloud/sandbox-service.api.js.map +1 -1
  254. package/dist/api/cloud/secrets-service.api.cjs.map +1 -1
  255. package/dist/api/cloud/secrets-service.api.d.ts +3 -4
  256. package/dist/api/cloud/secrets-service.api.js.map +1 -1
  257. package/dist/api/cloud/settings-service.api.cjs +1 -1
  258. package/dist/api/cloud/settings-service.api.cjs.map +1 -1
  259. package/dist/api/cloud/settings-service.api.js +5 -1
  260. package/dist/api/cloud/settings-service.api.js.map +1 -1
  261. package/dist/api/cloud/skills-service.api.cjs.map +1 -1
  262. package/dist/api/cloud/skills-service.api.d.ts +5 -5
  263. package/dist/api/cloud/skills-service.api.js.map +1 -1
  264. package/dist/api/conversation-service/agent-server-conversation-service.api.cjs +1 -1
  265. package/dist/api/conversation-service/agent-server-conversation-service.api.cjs.map +1 -1
  266. package/dist/api/conversation-service/agent-server-conversation-service.api.js +115 -108
  267. package/dist/api/conversation-service/agent-server-conversation-service.api.js.map +1 -1
  268. package/dist/api/device-flow-client.cjs +1 -1
  269. package/dist/api/device-flow-client.cjs.map +1 -1
  270. package/dist/api/device-flow-client.d.ts +3 -5
  271. package/dist/api/device-flow-client.js +55 -66
  272. package/dist/api/device-flow-client.js.map +1 -1
  273. package/dist/api/event-service/event-service.api.cjs +1 -1
  274. package/dist/api/event-service/event-service.api.cjs.map +1 -1
  275. package/dist/api/event-service/event-service.api.d.ts +3 -3
  276. package/dist/api/event-service/event-service.api.js +17 -17
  277. package/dist/api/event-service/event-service.api.js.map +1 -1
  278. package/dist/api/git-service/agent-server-git-service.api.cjs +1 -1
  279. package/dist/api/git-service/agent-server-git-service.api.js +11 -11
  280. package/dist/api/runtime-service/agent-server-runtime-service.cjs +1 -1
  281. package/dist/api/runtime-service/agent-server-runtime-service.js +6 -6
  282. package/dist/components/conversation-events/chat/event-content-helpers/get-action-content.cjs +2 -2
  283. package/dist/components/conversation-events/chat/event-content-helpers/get-action-content.js +10 -10
  284. package/dist/components/conversation-events/chat/event-content-helpers/get-observation-result.cjs.map +1 -1
  285. package/dist/components/conversation-events/chat/event-content-helpers/get-observation-result.d.ts +5 -5
  286. package/dist/components/conversation-events/chat/event-content-helpers/get-observation-result.js.map +1 -1
  287. package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.cjs +1 -1
  288. package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.cjs.map +1 -1
  289. package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.js +1 -1
  290. package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.js.map +1 -1
  291. package/dist/components/features/automations/automation-action-button-classes.d.ts +2 -2
  292. package/dist/components/features/backends/backend-form-modal.cjs +1 -1
  293. package/dist/components/features/backends/backend-form-modal.cjs.map +1 -1
  294. package/dist/components/features/backends/backend-form-modal.d.ts +1 -0
  295. package/dist/components/features/backends/backend-form-modal.js +203 -140
  296. package/dist/components/features/backends/backend-form-modal.js.map +1 -1
  297. package/dist/components/features/backends/backend-selector.cjs +1 -1
  298. package/dist/components/features/backends/backend-selector.cjs.map +1 -1
  299. package/dist/components/features/backends/backend-selector.js +117 -105
  300. package/dist/components/features/backends/backend-selector.js.map +1 -1
  301. package/dist/components/features/backends/backend-status-dot.cjs +1 -1
  302. package/dist/components/features/backends/backend-status-dot.cjs.map +1 -1
  303. package/dist/components/features/backends/backend-status-dot.d.ts +1 -1
  304. package/dist/components/features/backends/backend-status-dot.js +1 -1
  305. package/dist/components/features/backends/backend-status-dot.js.map +1 -1
  306. package/dist/components/features/backends/manage-backends-modal.cjs +1 -1
  307. package/dist/components/features/backends/manage-backends-modal.cjs.map +1 -1
  308. package/dist/components/features/backends/manage-backends-modal.js +81 -70
  309. package/dist/components/features/backends/manage-backends-modal.js.map +1 -1
  310. package/dist/components/features/chat/change-agent-button.cjs +1 -1
  311. package/dist/components/features/chat/change-agent-button.cjs.map +1 -1
  312. package/dist/components/features/chat/change-agent-button.js +59 -57
  313. package/dist/components/features/chat/change-agent-button.js.map +1 -1
  314. package/dist/components/features/chat/change-agent-context-menu.cjs +1 -1
  315. package/dist/components/features/chat/change-agent-context-menu.cjs.map +1 -1
  316. package/dist/components/features/chat/change-agent-context-menu.d.ts +3 -1
  317. package/dist/components/features/chat/change-agent-context-menu.js +30 -25
  318. package/dist/components/features/chat/change-agent-context-menu.js.map +1 -1
  319. package/dist/components/features/chat/chat-add-file-button.cjs +1 -1
  320. package/dist/components/features/chat/chat-add-file-button.cjs.map +1 -1
  321. package/dist/components/features/chat/chat-add-file-button.js +39 -38
  322. package/dist/components/features/chat/chat-add-file-button.js.map +1 -1
  323. package/dist/components/features/chat/chat-message.cjs +1 -1
  324. package/dist/components/features/chat/chat-message.cjs.map +1 -1
  325. package/dist/components/features/chat/chat-message.d.ts +2 -1
  326. package/dist/components/features/chat/chat-message.js +185 -57
  327. package/dist/components/features/chat/chat-message.js.map +1 -1
  328. package/dist/components/features/chat/components/chat-input-actions.cjs +1 -1
  329. package/dist/components/features/chat/components/chat-input-actions.cjs.map +1 -1
  330. package/dist/components/features/chat/components/chat-input-actions.js +113 -113
  331. package/dist/components/features/chat/components/chat-input-actions.js.map +1 -1
  332. package/dist/components/features/chat/components/chat-input-model.cjs +1 -1
  333. package/dist/components/features/chat/components/chat-input-model.cjs.map +1 -1
  334. package/dist/components/features/chat/components/chat-input-model.js +52 -51
  335. package/dist/components/features/chat/components/chat-input-model.js.map +1 -1
  336. package/dist/components/features/chat/components/slash-command-menu.cjs +2 -2
  337. package/dist/components/features/chat/components/slash-command-menu.cjs.map +1 -1
  338. package/dist/components/features/chat/components/slash-command-menu.js +38 -34
  339. package/dist/components/features/chat/components/slash-command-menu.js.map +1 -1
  340. package/dist/components/features/chat/git-control-bar-pr-button.cjs +1 -1
  341. package/dist/components/features/chat/git-control-bar-pr-button.cjs.map +1 -1
  342. package/dist/components/features/chat/git-control-bar-pr-button.js +16 -15
  343. package/dist/components/features/chat/git-control-bar-pr-button.js.map +1 -1
  344. package/dist/components/features/chat/git-control-bar-pull-button.cjs +1 -1
  345. package/dist/components/features/chat/git-control-bar-pull-button.cjs.map +1 -1
  346. package/dist/components/features/chat/git-control-bar-pull-button.js +16 -15
  347. package/dist/components/features/chat/git-control-bar-pull-button.js.map +1 -1
  348. package/dist/components/features/chat/git-control-bar-push-button.cjs +1 -1
  349. package/dist/components/features/chat/git-control-bar-push-button.cjs.map +1 -1
  350. package/dist/components/features/chat/git-control-bar-push-button.js +16 -15
  351. package/dist/components/features/chat/git-control-bar-push-button.js.map +1 -1
  352. package/dist/components/features/chat/git-control-bar.cjs +1 -1
  353. package/dist/components/features/chat/git-control-bar.cjs.map +1 -1
  354. package/dist/components/features/chat/git-control-bar.js +63 -62
  355. package/dist/components/features/chat/git-control-bar.js.map +1 -1
  356. package/dist/components/features/chat/pending-user-messages.cjs +1 -1
  357. package/dist/components/features/chat/pending-user-messages.cjs.map +1 -1
  358. package/dist/components/features/chat/pending-user-messages.js +27 -23
  359. package/dist/components/features/chat/pending-user-messages.js.map +1 -1
  360. package/dist/components/features/chat/switch-profile-button.cjs +1 -1
  361. package/dist/components/features/chat/switch-profile-button.cjs.map +1 -1
  362. package/dist/components/features/chat/switch-profile-button.js +26 -25
  363. package/dist/components/features/chat/switch-profile-button.js.map +1 -1
  364. package/dist/components/features/chat/switch-profile-context-menu.cjs +1 -1
  365. package/dist/components/features/chat/switch-profile-context-menu.cjs.map +1 -1
  366. package/dist/components/features/chat/switch-profile-context-menu.js +77 -67
  367. package/dist/components/features/chat/switch-profile-context-menu.js.map +1 -1
  368. package/dist/components/features/context-menu/context-menu-icon-text-with-description.cjs +1 -1
  369. package/dist/components/features/context-menu/context-menu-icon-text-with-description.cjs.map +1 -1
  370. package/dist/components/features/context-menu/context-menu-icon-text-with-description.d.ts +2 -1
  371. package/dist/components/features/context-menu/context-menu-icon-text-with-description.js +3 -2
  372. package/dist/components/features/context-menu/context-menu-icon-text-with-description.js.map +1 -1
  373. package/dist/components/features/context-menu/context-menu-icon-text.cjs +1 -1
  374. package/dist/components/features/context-menu/context-menu-icon-text.cjs.map +1 -1
  375. package/dist/components/features/context-menu/context-menu-icon-text.d.ts +2 -1
  376. package/dist/components/features/context-menu/context-menu-icon-text.js +20 -10
  377. package/dist/components/features/context-menu/context-menu-icon-text.js.map +1 -1
  378. package/dist/components/features/context-menu/context-menu-list-item.cjs +1 -1
  379. package/dist/components/features/context-menu/context-menu-list-item.cjs.map +1 -1
  380. package/dist/components/features/context-menu/context-menu-list-item.js +10 -9
  381. package/dist/components/features/context-menu/context-menu-list-item.js.map +1 -1
  382. package/dist/components/features/controls/agent-status.cjs +1 -1
  383. package/dist/components/features/controls/agent-status.js +12 -12
  384. package/dist/components/features/controls/git-tools-submenu.cjs +1 -1
  385. package/dist/components/features/controls/git-tools-submenu.cjs.map +1 -1
  386. package/dist/components/features/controls/git-tools-submenu.js +1 -1
  387. package/dist/components/features/controls/git-tools-submenu.js.map +1 -1
  388. package/dist/components/features/controls/macros-submenu.cjs +1 -1
  389. package/dist/components/features/controls/macros-submenu.cjs.map +1 -1
  390. package/dist/components/features/controls/macros-submenu.js +1 -1
  391. package/dist/components/features/controls/macros-submenu.js.map +1 -1
  392. package/dist/components/features/controls/server-status-context-menu-icon-text.cjs +1 -1
  393. package/dist/components/features/controls/server-status-context-menu-icon-text.cjs.map +1 -1
  394. package/dist/components/features/controls/server-status-context-menu-icon-text.js +14 -15
  395. package/dist/components/features/controls/server-status-context-menu-icon-text.js.map +1 -1
  396. package/dist/components/features/controls/server-status-context-menu.cjs +1 -1
  397. package/dist/components/features/controls/server-status-context-menu.js +4 -4
  398. package/dist/components/features/controls/server-status.cjs +1 -1
  399. package/dist/components/features/controls/server-status.js +7 -7
  400. package/dist/components/features/controls/tools-context-menu-icon-text.cjs +1 -1
  401. package/dist/components/features/controls/tools-context-menu-icon-text.cjs.map +1 -1
  402. package/dist/components/features/controls/tools-context-menu-icon-text.js +16 -16
  403. package/dist/components/features/controls/tools-context-menu-icon-text.js.map +1 -1
  404. package/dist/components/features/conversation/conversation-name-context-menu-icon-text.cjs +1 -1
  405. package/dist/components/features/conversation/conversation-name-context-menu-icon-text.cjs.map +1 -1
  406. package/dist/components/features/conversation/conversation-name-context-menu-icon-text.js +11 -11
  407. package/dist/components/features/conversation/conversation-name-context-menu-icon-text.js.map +1 -1
  408. package/dist/components/features/conversation/conversation-name-with-status.cjs +1 -1
  409. package/dist/components/features/conversation/conversation-name-with-status.js +11 -11
  410. package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.cjs +1 -1
  411. package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.cjs.map +1 -1
  412. package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.js +60 -47
  413. package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.js.map +1 -1
  414. package/dist/components/features/conversation-panel/cloud-new-conversation-menu.cjs +1 -1
  415. package/dist/components/features/conversation-panel/cloud-new-conversation-menu.cjs.map +1 -1
  416. package/dist/components/features/conversation-panel/cloud-new-conversation-menu.js +86 -82
  417. package/dist/components/features/conversation-panel/cloud-new-conversation-menu.js.map +1 -1
  418. package/dist/components/features/conversation-panel/conversation-card/conversation-card-actions.cjs +1 -1
  419. package/dist/components/features/conversation-panel/conversation-card/conversation-card-actions.js +4 -4
  420. package/dist/components/features/conversation-panel/conversation-card/conversation-card-footer.cjs +1 -1
  421. package/dist/components/features/conversation-panel/conversation-card/conversation-card-footer.js +9 -9
  422. package/dist/components/features/conversation-panel/conversation-panel-filter-menu.cjs +1 -1
  423. package/dist/components/features/conversation-panel/conversation-panel-filter-menu.cjs.map +1 -1
  424. package/dist/components/features/conversation-panel/conversation-panel-filter-menu.js +93 -93
  425. package/dist/components/features/conversation-panel/conversation-panel-filter-menu.js.map +1 -1
  426. package/dist/components/features/conversation-panel/conversation-panel.cjs +1 -1
  427. package/dist/components/features/conversation-panel/conversation-panel.cjs.map +1 -1
  428. package/dist/components/features/conversation-panel/conversation-panel.js +177 -177
  429. package/dist/components/features/conversation-panel/conversation-panel.js.map +1 -1
  430. package/dist/components/features/conversation-panel/ellipsis-button.cjs +1 -1
  431. package/dist/components/features/conversation-panel/ellipsis-button.cjs.map +1 -1
  432. package/dist/components/features/conversation-panel/ellipsis-button.js +13 -13
  433. package/dist/components/features/conversation-panel/ellipsis-button.js.map +1 -1
  434. package/dist/components/features/conversation-panel/local-new-conversation-menu.cjs +1 -1
  435. package/dist/components/features/conversation-panel/local-new-conversation-menu.cjs.map +1 -1
  436. package/dist/components/features/conversation-panel/local-new-conversation-menu.js +57 -53
  437. package/dist/components/features/conversation-panel/local-new-conversation-menu.js.map +1 -1
  438. package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.cjs +1 -1
  439. package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.cjs.map +1 -1
  440. package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.js +3 -2
  441. package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.js.map +1 -1
  442. package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.cjs +1 -1
  443. package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.cjs.map +1 -1
  444. package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.js +11 -8
  445. package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.js.map +1 -1
  446. package/dist/components/features/conversation-panel/system-message-modal/tab-content.cjs.map +1 -1
  447. package/dist/components/features/conversation-panel/system-message-modal/tab-content.d.ts +2 -5
  448. package/dist/components/features/conversation-panel/system-message-modal/tab-content.js.map +1 -1
  449. package/dist/components/features/files-tab/file-content-viewer.cjs +1 -1
  450. package/dist/components/features/files-tab/file-content-viewer.cjs.map +1 -1
  451. package/dist/components/features/files-tab/file-content-viewer.js +45 -42
  452. package/dist/components/features/files-tab/file-content-viewer.js.map +1 -1
  453. package/dist/components/features/home/llm-not-configured-banner.d.ts +11 -0
  454. package/dist/components/features/home/shared/dropdown-item.cjs +1 -1
  455. package/dist/components/features/home/shared/dropdown-item.cjs.map +1 -1
  456. package/dist/components/features/home/shared/dropdown-item.js +20 -16
  457. package/dist/components/features/home/shared/dropdown-item.js.map +1 -1
  458. package/dist/components/features/home/shared/generic-dropdown-menu.cjs +1 -1
  459. package/dist/components/features/home/shared/generic-dropdown-menu.cjs.map +1 -1
  460. package/dist/components/features/home/shared/generic-dropdown-menu.js +23 -22
  461. package/dist/components/features/home/shared/generic-dropdown-menu.js.map +1 -1
  462. package/dist/components/features/home/workspace-dropdown/folder-browser-modal.cjs +1 -1
  463. package/dist/components/features/home/workspace-dropdown/folder-browser-modal.cjs.map +1 -1
  464. package/dist/components/features/home/workspace-dropdown/folder-browser-modal.js +103 -102
  465. package/dist/components/features/home/workspace-dropdown/folder-browser-modal.js.map +1 -1
  466. package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.cjs +1 -1
  467. package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.cjs.map +1 -1
  468. package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.js +68 -67
  469. package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.js.map +1 -1
  470. package/dist/components/features/mcp-page/custom-server-editor.cjs +1 -1
  471. package/dist/components/features/mcp-page/custom-server-editor.cjs.map +1 -1
  472. package/dist/components/features/mcp-page/custom-server-editor.js +62 -60
  473. package/dist/components/features/mcp-page/custom-server-editor.js.map +1 -1
  474. package/dist/components/features/mcp-page/index.cjs +1 -1
  475. package/dist/components/features/mcp-page/index.d.ts +1 -0
  476. package/dist/components/features/mcp-page/index.js +1 -0
  477. package/dist/components/features/mcp-page/install-server-modal.cjs +1 -1
  478. package/dist/components/features/mcp-page/install-server-modal.cjs.map +1 -1
  479. package/dist/components/features/mcp-page/install-server-modal.js +141 -121
  480. package/dist/components/features/mcp-page/install-server-modal.js.map +1 -1
  481. package/dist/components/features/mcp-page/save-as-secret-toggle.cjs +2 -0
  482. package/dist/components/features/mcp-page/save-as-secret-toggle.cjs.map +1 -0
  483. package/dist/components/features/mcp-page/save-as-secret-toggle.d.ts +7 -0
  484. package/dist/components/features/mcp-page/save-as-secret-toggle.js +50 -0
  485. package/dist/components/features/mcp-page/save-as-secret-toggle.js.map +1 -0
  486. package/dist/components/features/onboarding/onboarding-modal.d.ts +2 -2
  487. package/dist/components/features/onboarding/steps/check-backend-step.d.ts +1 -1
  488. package/dist/components/features/onboarding/steps/choose-agent-step.d.ts +2 -1
  489. package/dist/components/features/onboarding/steps/setup-acp-secrets-step.d.ts +19 -10
  490. package/dist/components/features/settings/llm-profiles/llm-settings-local-view.cjs +1 -1
  491. package/dist/components/features/settings/llm-profiles/llm-settings-local-view.d.ts +5 -0
  492. package/dist/components/features/settings/llm-profiles/llm-settings-local-view.js +2 -0
  493. package/dist/components/features/settings/llm-profiles/profile-actions-menu.cjs +1 -1
  494. package/dist/components/features/settings/llm-profiles/profile-actions-menu.js +1 -0
  495. package/dist/components/features/skills/extensions-navigation.cjs +1 -1
  496. package/dist/components/features/skills/extensions-navigation.cjs.map +1 -1
  497. package/dist/components/features/skills/extensions-navigation.js +1 -1
  498. package/dist/components/features/skills/extensions-navigation.js.map +1 -1
  499. package/dist/components/shared/buttons/back-nav-button.cjs +2 -0
  500. package/dist/components/shared/buttons/back-nav-button.cjs.map +1 -0
  501. package/dist/components/shared/buttons/back-nav-button.d.ts +17 -0
  502. package/dist/components/shared/buttons/back-nav-button.js +33 -0
  503. package/dist/components/shared/buttons/back-nav-button.js.map +1 -0
  504. package/dist/components/shared/buttons/conversation-confirmation-buttons.cjs +1 -1
  505. package/dist/components/shared/buttons/conversation-confirmation-buttons.js +5 -5
  506. package/dist/components/shared/filters/enum-filter-dropdown.cjs +1 -1
  507. package/dist/components/shared/filters/enum-filter-dropdown.cjs.map +1 -1
  508. package/dist/components/shared/filters/enum-filter-dropdown.js +32 -31
  509. package/dist/components/shared/filters/enum-filter-dropdown.js.map +1 -1
  510. package/dist/components/shared/modals/confirmation-modals/base-modal.cjs +1 -1
  511. package/dist/components/shared/modals/confirmation-modals/base-modal.cjs.map +1 -1
  512. package/dist/components/shared/modals/confirmation-modals/base-modal.js +14 -13
  513. package/dist/components/shared/modals/confirmation-modals/base-modal.js.map +1 -1
  514. package/dist/components/shared/modals/settings/settings-modal.cjs +1 -1
  515. package/dist/components/shared/modals/settings/settings-modal.cjs.map +1 -1
  516. package/dist/components/shared/modals/settings/settings-modal.js +17 -16
  517. package/dist/components/shared/modals/settings/settings-modal.js.map +1 -1
  518. package/dist/components/shared/text-shimmer.cjs +2 -0
  519. package/dist/components/shared/text-shimmer.cjs.map +1 -0
  520. package/dist/components/shared/text-shimmer.d.ts +11 -0
  521. package/dist/components/shared/text-shimmer.js +43 -0
  522. package/dist/components/shared/text-shimmer.js.map +1 -0
  523. package/dist/constants/acp-providers.cjs +1 -1
  524. package/dist/constants/acp-providers.cjs.map +1 -1
  525. package/dist/constants/acp-providers.d.ts +16 -3
  526. package/dist/constants/acp-providers.js +0 -1
  527. package/dist/constants/acp-providers.js.map +1 -1
  528. package/dist/contexts/active-backend-context.cjs +1 -1
  529. package/dist/contexts/active-backend-context.cjs.map +1 -1
  530. package/dist/contexts/active-backend-context.js +32 -32
  531. package/dist/contexts/active-backend-context.js.map +1 -1
  532. package/dist/hooks/chat/use-chat-input-logic.cjs +1 -1
  533. package/dist/hooks/chat/use-chat-input-logic.cjs.map +1 -1
  534. package/dist/hooks/chat/use-chat-input-logic.js +13 -6
  535. package/dist/hooks/chat/use-chat-input-logic.js.map +1 -1
  536. package/dist/hooks/mutation/use-save-fields-as-secrets.cjs +2 -0
  537. package/dist/hooks/mutation/use-save-fields-as-secrets.cjs.map +1 -0
  538. package/dist/hooks/mutation/use-save-fields-as-secrets.d.ts +9 -0
  539. package/dist/hooks/mutation/use-save-fields-as-secrets.js +24 -0
  540. package/dist/hooks/mutation/use-save-fields-as-secrets.js.map +1 -0
  541. package/dist/hooks/mutation/use-unified-start-conversation.cjs +1 -1
  542. package/dist/hooks/mutation/use-unified-start-conversation.js +8 -8
  543. package/dist/hooks/mutation/use-unified-stop-conversation.cjs +1 -1
  544. package/dist/hooks/mutation/use-unified-stop-conversation.js +15 -15
  545. package/dist/hooks/query/use-acp-auth-status.d.ts +36 -0
  546. package/dist/hooks/query/use-agent-settings-schema.cjs +1 -1
  547. package/dist/hooks/query/use-agent-settings-schema.cjs.map +1 -1
  548. package/dist/hooks/query/use-agent-settings-schema.js +26 -16
  549. package/dist/hooks/query/use-agent-settings-schema.js.map +1 -1
  550. package/dist/hooks/query/use-backends-health.cjs +1 -1
  551. package/dist/hooks/query/use-backends-health.cjs.map +1 -1
  552. package/dist/hooks/query/use-backends-health.d.ts +2 -0
  553. package/dist/hooks/query/use-backends-health.js +31 -21
  554. package/dist/hooks/query/use-backends-health.js.map +1 -1
  555. package/dist/hooks/query/use-paginated-conversations.cjs +1 -1
  556. package/dist/hooks/query/use-paginated-conversations.cjs.map +1 -1
  557. package/dist/hooks/query/use-paginated-conversations.js +15 -14
  558. package/dist/hooks/query/use-paginated-conversations.js.map +1 -1
  559. package/dist/hooks/query/use-settings.cjs +1 -1
  560. package/dist/hooks/query/use-settings.cjs.map +1 -1
  561. package/dist/hooks/query/use-settings.js +65 -52
  562. package/dist/hooks/query/use-settings.js.map +1 -1
  563. package/dist/hooks/query/use-user-conversation.cjs +1 -1
  564. package/dist/hooks/query/use-user-conversation.cjs.map +1 -1
  565. package/dist/hooks/query/use-user-conversation.js +20 -11
  566. package/dist/hooks/query/use-user-conversation.js.map +1 -1
  567. package/dist/hooks/use-agent-state.cjs +1 -1
  568. package/dist/hooks/use-agent-state.js +13 -13
  569. package/dist/hooks/use-conversation-name-context-menu.cjs +1 -1
  570. package/dist/hooks/use-conversation-name-context-menu.js +10 -10
  571. package/dist/hooks/use-conversation-name-context-menu.js.map +1 -1
  572. package/dist/hooks/use-llm-configured.d.ts +25 -0
  573. package/dist/hooks/use-runtime-is-ready.cjs +1 -1
  574. package/dist/hooks/use-runtime-is-ready.js +5 -5
  575. package/dist/i18n/declaration.cjs +1 -1
  576. package/dist/i18n/declaration.cjs.map +1 -1
  577. package/dist/i18n/declaration.d.ts +19 -1
  578. package/dist/i18n/declaration.js +1 -1
  579. package/dist/i18n/declaration.js.map +1 -1
  580. package/dist/i18n/translation.cjs +3 -3
  581. package/dist/i18n/translation.cjs.map +1 -1
  582. package/dist/i18n/translation.js +321 -15
  583. package/dist/i18n/translation.js.map +1 -1
  584. package/dist/icons/stop-circle.cjs +1 -1
  585. package/dist/icons/stop-circle.cjs.map +1 -1
  586. package/dist/icons/stop-circle.js +7 -10
  587. package/dist/icons/stop-circle.js.map +1 -1
  588. package/dist/locales/ar/openhands.json +20 -2
  589. package/dist/locales/ca/openhands.json +20 -2
  590. package/dist/locales/de/openhands.json +20 -2
  591. package/dist/locales/en/openhands.json +20 -2
  592. package/dist/locales/es/openhands.json +20 -2
  593. package/dist/locales/fr/openhands.json +20 -2
  594. package/dist/locales/it/openhands.json +20 -2
  595. package/dist/locales/ja/openhands.json +20 -2
  596. package/dist/locales/ko-KR/openhands.json +20 -2
  597. package/dist/locales/no/openhands.json +20 -2
  598. package/dist/locales/pt/openhands.json +20 -2
  599. package/dist/locales/tr/openhands.json +20 -2
  600. package/dist/locales/uk/openhands.json +20 -2
  601. package/dist/locales/zh-CN/openhands.json +20 -2
  602. package/dist/locales/zh-TW/openhands.json +20 -2
  603. package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.cjs +2 -0
  604. package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.cjs.map +1 -0
  605. package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.js +15 -0
  606. package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.js.map +1 -0
  607. package/dist/package.cjs +1 -1
  608. package/dist/package.cjs.map +1 -1
  609. package/dist/package.js +1 -1
  610. package/dist/package.js.map +1 -1
  611. package/dist/routes/conversation.cjs +1 -1
  612. package/dist/routes/conversation.cjs.map +1 -1
  613. package/dist/routes/conversation.js +1 -1
  614. package/dist/routes/conversation.js.map +1 -1
  615. package/dist/routes/llm-settings.cjs +1 -1
  616. package/dist/routes/llm-settings.cjs.map +1 -1
  617. package/dist/routes/llm-settings.js +55 -54
  618. package/dist/routes/llm-settings.js.map +1 -1
  619. package/dist/routes/secrets-settings.cjs +1 -1
  620. package/dist/routes/secrets-settings.cjs.map +1 -1
  621. package/dist/routes/secrets-settings.js +19 -27
  622. package/dist/routes/secrets-settings.js.map +1 -1
  623. package/dist/stores/conversation-store.cjs +1 -1
  624. package/dist/stores/conversation-store.cjs.map +1 -1
  625. package/dist/stores/conversation-store.d.ts +4 -0
  626. package/dist/stores/conversation-store.js +6 -0
  627. package/dist/stores/conversation-store.js.map +1 -1
  628. package/dist/types/agent-server/core/events/acp-tool-call-event.d.ts +6 -4
  629. package/dist/types/agent-server/core/events/system-event.d.ts +5 -0
  630. package/dist/types/automation.d.ts +15 -0
  631. package/dist/types/settings.d.ts +3 -1
  632. package/dist/ui/combobox-caret.cjs +1 -1
  633. package/dist/ui/combobox-caret.cjs.map +1 -1
  634. package/dist/ui/combobox-caret.d.ts +1 -1
  635. package/dist/ui/combobox-caret.js +9 -8
  636. package/dist/ui/combobox-caret.js.map +1 -1
  637. package/dist/ui/context-menu.cjs +1 -1
  638. package/dist/ui/context-menu.cjs.map +1 -1
  639. package/dist/ui/context-menu.js +9 -8
  640. package/dist/ui/context-menu.js.map +1 -1
  641. package/dist/ui/dropdown/dropdown-menu.cjs +1 -1
  642. package/dist/ui/dropdown/dropdown-menu.cjs.map +1 -1
  643. package/dist/ui/dropdown/dropdown-menu.js +21 -17
  644. package/dist/ui/dropdown/dropdown-menu.js.map +1 -1
  645. package/dist/ui/dropdown/dropdown.cjs +1 -1
  646. package/dist/ui/dropdown/dropdown.cjs.map +1 -1
  647. package/dist/ui/dropdown/dropdown.js +2 -2
  648. package/dist/ui/dropdown/dropdown.js.map +1 -1
  649. package/dist/utils/automation-schedule.d.ts +1 -0
  650. package/dist/utils/dropdown-classes.cjs +2 -0
  651. package/dist/utils/dropdown-classes.cjs.map +1 -0
  652. package/dist/utils/dropdown-classes.d.ts +32 -0
  653. package/dist/utils/dropdown-classes.js +8 -0
  654. package/dist/utils/dropdown-classes.js.map +1 -0
  655. package/dist/utils/form-control-classes.cjs +1 -1
  656. package/dist/utils/form-control-classes.cjs.map +1 -1
  657. package/dist/utils/form-control-classes.d.ts +18 -2
  658. package/dist/utils/form-control-classes.js +4 -3
  659. package/dist/utils/form-control-classes.js.map +1 -1
  660. package/dist/utils/git-control-bar-classes.cjs +2 -0
  661. package/dist/utils/git-control-bar-classes.cjs.map +1 -0
  662. package/dist/utils/git-control-bar-classes.d.ts +4 -0
  663. package/dist/utils/git-control-bar-classes.js +14 -0
  664. package/dist/utils/git-control-bar-classes.js.map +1 -0
  665. package/dist/utils/handle-event-for-ui.cjs.map +1 -1
  666. package/dist/utils/handle-event-for-ui.d.ts +6 -3
  667. package/dist/utils/handle-event-for-ui.js.map +1 -1
  668. package/dist/utils/mobile-top-bar-icon-button-classes.cjs +1 -1
  669. package/dist/utils/mobile-top-bar-icon-button-classes.cjs.map +1 -1
  670. package/dist/utils/mobile-top-bar-icon-button-classes.js +3 -3
  671. package/dist/utils/mobile-top-bar-icon-button-classes.js.map +1 -1
  672. package/dist/utils/modal-classes.cjs +2 -0
  673. package/dist/utils/modal-classes.cjs.map +1 -0
  674. package/dist/utils/modal-classes.d.ts +8 -0
  675. package/dist/utils/modal-classes.js +7 -0
  676. package/dist/utils/modal-classes.js.map +1 -0
  677. package/dist/utils/openhands-llm.cjs +2 -0
  678. package/dist/utils/openhands-llm.cjs.map +1 -0
  679. package/dist/utils/openhands-llm.d.ts +2 -0
  680. package/dist/utils/openhands-llm.js +9 -0
  681. package/dist/utils/openhands-llm.js.map +1 -0
  682. package/dist/utils/redact-custom-secrets.cjs +2 -0
  683. package/dist/utils/redact-custom-secrets.cjs.map +1 -0
  684. package/dist/utils/redact-custom-secrets.d.ts +6 -0
  685. package/dist/utils/redact-custom-secrets.js +10 -0
  686. package/dist/utils/redact-custom-secrets.js.map +1 -0
  687. package/dist/utils/status.cjs +1 -1
  688. package/dist/utils/status.cjs.map +1 -1
  689. package/dist/utils/status.d.ts +2 -1
  690. package/dist/utils/status.js +9 -8
  691. package/dist/utils/status.js.map +1 -1
  692. package/dist/utils/system-message-adapter.cjs +1 -1
  693. package/dist/utils/system-message-adapter.cjs.map +1 -1
  694. package/dist/utils/system-message-adapter.js +10 -7
  695. package/dist/utils/system-message-adapter.js.map +1 -1
  696. package/dist/utils/utils.cjs +1 -1
  697. package/dist/utils/utils.cjs.map +1 -1
  698. package/dist/utils/utils.d.ts +2 -1
  699. package/dist/utils/utils.js +21 -20
  700. package/dist/utils/utils.js.map +1 -1
  701. package/package.json +1 -1
  702. package/scripts/dev-safe.mjs +3 -1
  703. package/scripts/dev-static.mjs +2 -2
  704. package/scripts/dev-with-automation.mjs +283 -108
  705. package/scripts/static-build.mjs +20 -19
  706. package/scripts/static-server.mjs +65 -6
  707. package/build/assets/acp-providers-CbiRekh9.js +0 -1
  708. package/build/assets/active-backend-context-cCM1vYYZ.js +0 -1
  709. package/build/assets/add-backend-modal-DIUQzMPa.js +0 -1
  710. package/build/assets/agent-server-client-options-Bc5ZorQZ.js +0 -1
  711. package/build/assets/agent-server-compatibility-BlkUsrX2.js +0 -1
  712. package/build/assets/agent-server-conversation-service.api-C2V5SlHu.js +0 -5
  713. package/build/assets/api-key-entry-screen-B2gynaCp.js +0 -1
  714. package/build/assets/automation-detail-DJvbVSYK.js +0 -1
  715. package/build/assets/automations-list-6FDbI5dc.js +0 -1
  716. package/build/assets/backend-form-modal-Dnk33xA_.js +0 -1
  717. package/build/assets/base-modal-_dYTw1ri.js +0 -1
  718. package/build/assets/brand-button-Br7f0kZJ.js +0 -1
  719. package/build/assets/browser-store-Couc4S5D.js +0 -1
  720. package/build/assets/clock-BRjCgHTc.js +0 -1
  721. package/build/assets/combobox-caret-to1O8irE.js +0 -1
  722. package/build/assets/context-menu-list-item-CWNFpuiC.js +0 -1
  723. package/build/assets/conversation-DVrKU0oz.js +0 -19
  724. package/build/assets/conversation-Dlys-D5A.js +0 -1
  725. package/build/assets/conversation-panel-iF09WjZ4.js +0 -1
  726. package/build/assets/conversation-service.api-CCfztilW.js +0 -1
  727. package/build/assets/conversation-state-store-u5jepov0.js +0 -1
  728. package/build/assets/conversation-store-Z5iMCRpc.js +0 -1
  729. package/build/assets/conversation-websocket-context-DhJhqUna.js +0 -3
  730. package/build/assets/declaration-BNMqORFE.js +0 -1
  731. package/build/assets/dist-BxBP7tFD.js +0 -1
  732. package/build/assets/edit-automation-modal-BGzR3nfZ.js +0 -1
  733. package/build/assets/ellipsis-button-ZyLMPURn.js +0 -1
  734. package/build/assets/entry.client-1VMHpktY.js +0 -2
  735. package/build/assets/enum-filter-dropdown-CEgCdu4A.js +0 -1
  736. package/build/assets/extensions-hub-C651jsVh.js +0 -1
  737. package/build/assets/files-tab-R5z0lLdY.js +0 -1
  738. package/build/assets/files-tab-store-CDyVTXNT.js +0 -1
  739. package/build/assets/git-control-bar-branch-button-COdRAYHb.js +0 -27
  740. package/build/assets/git-provider-icon-BzLbc0yC.js +0 -1
  741. package/build/assets/home-e-egNUXZ.js +0 -1
  742. package/build/assets/install-server-modal-DHlbgqVH.js +0 -1
  743. package/build/assets/launch-CshDse3e.js +0 -1
  744. package/build/assets/link-external-D2POYx4c.js +0 -1
  745. package/build/assets/llm-settings-Bql-vydt.js +0 -1
  746. package/build/assets/llm-settings-C_tal6Ds.js +0 -1
  747. package/build/assets/manage-backends-modal-l7RkKfwX.js +0 -1
  748. package/build/assets/manage-workspaces-modal-DhKF_8z3.js +0 -1
  749. package/build/assets/manifest-3bf30d69.js +0 -1
  750. package/build/assets/mcp-ByeBfdfU.js +0 -9
  751. package/build/assets/messages-D0rWot7s.js +0 -36
  752. package/build/assets/proxy-CxydCnis.js +0 -1
  753. package/build/assets/root-DHeCXo9N.css +0 -1
  754. package/build/assets/root-layout-Czo9Ma6Q.js +0 -2
  755. package/build/assets/secrets-service-BsnKFc2x.js +0 -1
  756. package/build/assets/secrets-settings-Bz_UohPJ.js +0 -1
  757. package/build/assets/settings-client-C73C7IgV.js +0 -1
  758. package/build/assets/settings-index-Dz0BmdJD.js +0 -1
  759. package/build/assets/settings-list-classes-Bf80tWtc.js +0 -1
  760. package/build/assets/settings-modal-Brzgh5Yw.js +0 -1
  761. package/build/assets/settings-service.api-CZ3uWx4v.js +0 -1
  762. package/build/assets/sidebar-mobile-menu-toggle-Do_aA9Zm.js +0 -1
  763. package/build/assets/skills-settings-DlA5hlXw.js +0 -2
  764. package/build/assets/status-hp6M6E7E.js +0 -1
  765. package/build/assets/use-agent-settings-schema-33Un7UF2.js +0 -1
  766. package/build/assets/use-is-authed-BggE5wPj.js +0 -1
  767. package/build/assets/use-llm-profiles-DDOol3gK.js +0 -1
  768. package/build/assets/use-runtime-is-ready-B7EF4BKU.js +0 -1
  769. package/build/assets/use-settings-DQIZmIov.js +0 -1
  770. package/build/assets/use-user-conversation-C6hrMMtn.js +0 -1
  771. package/build/assets/utils-i18rdUj2.js +0 -1
  772. package/build/assets/vendor~conversation-panel~conversation-a9SyrrhV.js +0 -1
  773. package/build/assets/vendor~conversation-panel~conversation~index-C23ZXO4R.js +0 -1
  774. package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~i4kjfqhl-BebWhFNT.js +0 -1
  775. package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-DzIXV3Ui.js +0 -9
  776. /package/build/assets/{automation-IdgZq6ZK.js → automation-XDPAjiZi.js} +0 -0
  777. /package/build/assets/{color-themes-DSaoIL6A.js → color-themes-B9pm9c-R.js} +0 -0
  778. /package/build/assets/{common-DR1t-EeP.js → common-DqjLSBOt.js} +0 -0
  779. /package/build/assets/{conversation-local-storage-UYl-SX-r.js → conversation-local-storage-YmOVXxxW.js} +0 -0
  780. /package/build/assets/{dist-C6t0EXL7.js → dist-C3NfioQC.js} +0 -0
  781. /package/build/assets/{environment-switch-store-C4ulFJKp.js → environment-switch-store-CiurvTtK.js} +0 -0
  782. /package/build/assets/{health-store-BDC2rM-X.js → health-store-B5f0S2FY.js} +0 -0
  783. /package/build/assets/{map-provider-COBVzZYo.js → map-provider-BJ_8KZKU.js} +0 -0
  784. /package/build/assets/{middleware-BC9EwbB9.js → middleware-CfatjPYZ.js} +0 -0
  785. /package/build/assets/{objectWithoutPropertiesLoose-Du6eBn-V.js → objectWithoutPropertiesLoose-DSQKyRhw.js} +0 -0
  786. /package/build/assets/{react-Do0CT17Y.js → react-Dy05vyj5.js} +0 -0
  787. /package/build/assets/{sdk-settings-field-metadata-CBPmeqYa.js → sdk-settings-field-metadata-DQiaIBie.js} +0 -0
  788. /package/build/assets/{settings-D_H-qsRm.js → settings-DGY6n4J2.js} +0 -0
  789. /package/build/assets/{settings-like-page-layout-classes-I0BDBEoq.js → settings-like-page-layout-classes-D7YjdTd0.js} +0 -0
  790. /package/build/assets/{use-breakpoint-DbJ6FkQ-.js → use-breakpoint-DF_RiQ6s.js} +0 -0
  791. /package/build/assets/{use-click-outside-element-DffgWWoZ.js → use-click-outside-element-DhxCUyWl.js} +0 -0
  792. /package/build/assets/{v4-CNn21NXa.js → v4-khGvL7i2.js} +0 -0
  793. /package/build/assets/{vendor~browser-DDiZgqD3.js → vendor~browser-DisFGEp9.js} +0 -0
  794. /package/build/assets/{vendor~browser-tab-BgwV1mxF.js → vendor~browser-tab-BxhTtM9_.js} +0 -0
  795. /package/build/assets/{vendor~conversation-panel~conversation~alert-banner-DbvX3OcM.js → vendor~conversation-panel~conversation~alert-banner-w-I2sY6c.js} +0 -0
  796. /package/build/assets/{vendor~entry.client~root~root-layout~home~conversation-panel~conversation~launch~skills-set~zm51vy4j-iOsylxCS.js → vendor~entry.client~root~root-layout~home~conversation-panel~conversation~launch~skills-set~zm51vy4j-BClAMeFe.js} +0 -0
  797. /package/build/assets/{vendor~files-tab-BGKayPiK.js → vendor~files-tab-BtkpAiMX.js} +0 -0
  798. /package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-BW6261Sb.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-CyZ-3lDQ.js} +0 -0
  799. /package/build/assets/{vendor~home~mcp~automations-list-DoPfwaXj.js → vendor~home~mcp~automations-list-BgV86Sti.js} +0 -0
  800. /package/build/assets/{vendor~launch-vdeRTWFu.js → vendor~launch-BXgl67Re.js} +0 -0
  801. /package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~ninslayh-D9P8e98a.js → vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~ninslayh-CLlsvdNP.js} +0 -0
  802. /package/build/assets/{vendor~terminal-DUrOWGFE.js → vendor~terminal-DZaJIY8A.js} +0 -0
@@ -11,36 +11,37 @@ import { useAgentSettingsSchema as c } from "../hooks/query/use-agent-settings-s
11
11
  import { KeyStatusIcon as l } from "../components/features/settings/key-status-icon.js";
12
12
  import { inferInitialView as u } from "../utils/sdk-settings-schema.js";
13
13
  import { SdkSectionPage as d } from "../components/features/settings/sdk-settings/sdk-section-page.js";
14
+ import { OPENHANDS_LLM_PROXY_BASE_URL as f, isOpenHandsProviderModel as p } from "../utils/openhands-llm.js";
14
15
  import "../components/features/settings/llm-profiles/index.js";
15
- import f from "react";
16
- import { Fragment as p, jsx as m, jsxs as h } from "react/jsx-runtime";
16
+ import m from "react";
17
+ import { Fragment as h, jsx as g, jsxs as _ } from "react/jsx-runtime";
17
18
  //#region src/routes/llm-settings.tsx
18
- var g = new Set([
19
+ var v = new Set([
19
20
  "llm.model",
20
21
  "llm.api_key",
21
22
  "llm.base_url"
22
- ]), _ = (e, t) => !e || !t ? null : `${e}/${t}`, v = (e, t) => e?.sections.flatMap((e) => e.fields).find((e) => e.key === t)?.default ?? null, y = {
23
+ ]), y = (e, t) => !e || !t ? null : `${e}/${t}`, b = (e, t) => e?.sections.flatMap((e) => e.fields).find((e) => e.key === t)?.default ?? null, x = {
23
24
  openai: new Set(["https://api.openai.com", "https://api.openai.com/v1"]),
24
- openhands: new Set(["https://llm-proxy.app.all-hands.dev", "https://llm-proxy.app.all-hands.dev/v1"]),
25
- litellm_proxy: new Set(["https://llm-proxy.app.all-hands.dev", "https://llm-proxy.app.all-hands.dev/v1"])
26
- }, b = (e) => {
25
+ openhands: new Set([f, "https://llm-proxy.app.all-hands.dev/v1"]),
26
+ litellm_proxy: new Set([f, "https://llm-proxy.app.all-hands.dev/v1"])
27
+ }, S = (e) => {
27
28
  try {
28
29
  let t = new URL(e), n = t.pathname.replace(/\/+$/, "") || "";
29
30
  return `${t.origin}${n}`;
30
31
  } catch {
31
32
  return e.trim().replace(/\/+$/, "");
32
33
  }
33
- }, x = (e, t) => {
34
- let n = b(t), { provider: r } = a(e);
34
+ }, C = (e, t) => {
35
+ let n = S(t), { provider: r } = a(e);
35
36
  if (r) {
36
- let e = y[r];
37
+ let e = x[r];
37
38
  if (e) return e.has(n);
38
39
  }
39
- return Object.values(y).some((e) => e?.has(n));
40
+ return Object.values(x).some((e) => e?.has(n));
40
41
  };
41
- function S({ testId: n }) {
42
+ function w({ testId: n }) {
42
43
  let { t: r } = e("openhands");
43
- return /* @__PURE__ */ m(o, {
44
+ return /* @__PURE__ */ g(o, {
44
45
  testId: n,
45
46
  text: r(t.SETTINGS$OPENHANDS_API_KEY_HELP_TEXT),
46
47
  linkText: r(t.SETTINGS$NAV_API_KEYS),
@@ -48,71 +49,71 @@ function S({ testId: n }) {
48
49
  suffix: ` ${r(t.SETTINGS$OPENHANDS_API_KEY_HELP_SUFFIX)}`
49
50
  });
50
51
  }
51
- function C({ scope: a = "personal", onSaveSuccess: y, initialValueOverrides: b, embedded: C, hideSaveButton: w, onSaveControlChange: T }) {
52
- let { t: E } = e("openhands"), { data: D } = r(a), { data: O } = c(D?.agent_settings_schema), k = String(n.agent_settings?.llm?.model ?? ""), A = f.useCallback((e, t) => {
52
+ function T({ scope: a = "personal", onSaveSuccess: x, initialValueOverrides: S, embedded: T, hideSaveButton: E, onSaveControlChange: D }) {
53
+ let { t: O } = e("openhands"), { data: k } = r(a), { data: A } = c(k?.agent_settings_schema), j = String(n.agent_settings?.llm?.model ?? ""), M = m.useCallback((e, t) => {
53
54
  let n = u(e, t);
54
55
  if (n !== "basic") return n;
55
56
  let r = e.llm_model ?? "", i = e.llm_base_url?.trim() ?? "";
56
- return i.length > 0 && !x(r, i) ? "all" : "basic";
57
+ return i.length > 0 && !C(r, i) ? "all" : "basic";
57
58
  }, []);
58
- return /* @__PURE__ */ m(d, {
59
+ return /* @__PURE__ */ g(d, {
59
60
  scope: a,
60
61
  sectionKeys: ["llm"],
61
- excludeKeys: g,
62
- header: f.useCallback(({ values: e, isDisabled: n, view: r, onChange: a }) => {
63
- let c = typeof e["llm.model"] == "string" ? e["llm.model"] : "", u = typeof e["llm.base_url"] == "string" ? e["llm.base_url"] : "", d = c.startsWith("openhands/"), f = typeof e["llm.api_key"] == "string" ? e["llm.api_key"] : "", g = C ? f.length > 0 : !!D?.llm_api_key_set, v = (e, r) => /* @__PURE__ */ h(p, { children: [/* @__PURE__ */ m(i, {
62
+ excludeKeys: v,
63
+ header: m.useCallback(({ values: e, isDisabled: n, view: r, onChange: a }) => {
64
+ let c = typeof e["llm.model"] == "string" ? e["llm.model"] : "", u = typeof e["llm.base_url"] == "string" ? e["llm.base_url"] : "", d = c.startsWith("openhands/"), f = typeof e["llm.api_key"] == "string" ? e["llm.api_key"] : "", p = T ? f.length > 0 : !!k?.llm_api_key_set, m = (e, r) => /* @__PURE__ */ _(h, { children: [/* @__PURE__ */ g(i, {
64
65
  testId: e,
65
- label: E(t.SETTINGS_FORM$API_KEY),
66
+ label: O(t.SETTINGS_FORM$API_KEY),
66
67
  type: "password",
67
68
  className: "w-full",
68
69
  value: f,
69
- placeholder: g ? "<hidden>" : "",
70
+ placeholder: p ? "<hidden>" : "",
70
71
  onChange: (e) => a("llm.api_key", e),
71
72
  isDisabled: n,
72
- startContent: g ? /* @__PURE__ */ m(l, { isSet: g }) : void 0
73
- }), /* @__PURE__ */ m(o, {
73
+ startContent: p ? /* @__PURE__ */ g(l, { isSet: p }) : void 0
74
+ }), /* @__PURE__ */ g(o, {
74
75
  testId: r,
75
- text: E(t.SETTINGS$DONT_KNOW_API_KEY),
76
- linkText: E(t.SETTINGS$CLICK_FOR_INSTRUCTIONS),
76
+ text: O(t.SETTINGS$DONT_KNOW_API_KEY),
77
+ linkText: O(t.SETTINGS$CLICK_FOR_INSTRUCTIONS),
77
78
  href: "https://docs.openhands.dev/usage/local-setup#getting-an-api-key"
78
79
  })] });
79
- return /* @__PURE__ */ m("div", {
80
+ return /* @__PURE__ */ g("div", {
80
81
  className: "flex flex-col gap-6",
81
- children: r === "basic" ? /* @__PURE__ */ h("div", {
82
+ children: r === "basic" ? /* @__PURE__ */ _("div", {
82
83
  className: "flex flex-col gap-6",
83
84
  "data-testid": "llm-settings-form-basic",
84
85
  children: [
85
- /* @__PURE__ */ m(s, {
86
+ /* @__PURE__ */ g(s, {
86
87
  currentModel: c || void 0,
87
88
  currentBaseUrl: u || void 0,
88
89
  onChange: (e, t) => {
89
- let n = _(e, t);
90
+ let n = y(e, t);
90
91
  n && a("llm.model", n);
91
92
  },
92
93
  wrapperClassName: "!flex-col !gap-6",
93
94
  isDisabled: n
94
95
  }),
95
- d ? /* @__PURE__ */ m(S, { testId: "openhands-api-key-help" }) : null,
96
- v("llm-api-key-input", "llm-api-key-help-anchor")
96
+ d ? /* @__PURE__ */ g(w, { testId: "openhands-api-key-help" }) : null,
97
+ m("llm-api-key-input", "llm-api-key-help-anchor")
97
98
  ]
98
- }) : /* @__PURE__ */ h("div", {
99
+ }) : /* @__PURE__ */ _("div", {
99
100
  className: "flex flex-col gap-6",
100
101
  "data-testid": "llm-settings-form-advanced",
101
102
  children: [
102
- /* @__PURE__ */ m(i, {
103
+ /* @__PURE__ */ g(i, {
103
104
  testId: "llm-custom-model-input",
104
- label: E(t.SETTINGS$CUSTOM_MODEL),
105
+ label: O(t.SETTINGS$CUSTOM_MODEL),
105
106
  type: "text",
106
107
  className: "w-full",
107
108
  value: c,
108
- placeholder: k,
109
+ placeholder: j,
109
110
  onChange: (e) => a("llm.model", e),
110
111
  isDisabled: n
111
112
  }),
112
- d ? /* @__PURE__ */ m(S, { testId: "openhands-api-key-help-2" }) : null,
113
- /* @__PURE__ */ m(i, {
113
+ d ? /* @__PURE__ */ g(w, { testId: "openhands-api-key-help-2" }) : null,
114
+ /* @__PURE__ */ g(i, {
114
115
  testId: "base-url-input",
115
- label: E(t.SETTINGS$BASE_URL),
116
+ label: O(t.SETTINGS$BASE_URL),
116
117
  type: "text",
117
118
  className: "w-full",
118
119
  value: u,
@@ -120,32 +121,32 @@ function C({ scope: a = "personal", onSaveSuccess: y, initialValueOverrides: b,
120
121
  onChange: (e) => a("llm.base_url", e),
121
122
  isDisabled: n
122
123
  }),
123
- v("llm-api-key-input", "llm-api-key-help-anchor-advanced")
124
+ m("llm-api-key-input", "llm-api-key-help-anchor-advanced")
124
125
  ]
125
126
  })
126
127
  });
127
128
  }, [
128
- k,
129
- C,
130
- D?.llm_api_key_set,
131
- E
129
+ j,
130
+ T,
131
+ k?.llm_api_key_set,
132
+ O
132
133
  ]),
133
- buildPayload: f.useCallback((e, t) => {
134
+ buildPayload: m.useCallback((e, t) => {
134
135
  let n = structuredClone(e), r = n.llm ?? {};
135
- return t.view === "basic" && (r.base_url = v(O, "llm.base_url"), n.llm = r), { agent_settings_diff: n };
136
- }, [O]),
137
- getInitialView: A,
136
+ return t.view === "basic" && (r.base_url = p(r.model ?? t.values["llm.model"]) ? f : b(A, "llm.base_url"), n.llm = r), { agent_settings_diff: n };
137
+ }, [A]),
138
+ getInitialView: M,
138
139
  forceShowAdvancedView: !0,
139
140
  allowAllView: !0,
140
- onSaveSuccess: y,
141
- initialValueOverrides: b,
142
- embedded: C,
143
- hideSaveButton: w,
144
- onSaveControlChange: T,
141
+ onSaveSuccess: x,
142
+ initialValueOverrides: S,
143
+ embedded: T,
144
+ hideSaveButton: E,
145
+ onSaveControlChange: D,
145
146
  testId: "llm-settings-screen"
146
147
  });
147
148
  }
148
149
  //#endregion
149
- export { C as LlmSettingsScreen };
150
+ export { T as LlmSettingsScreen };
150
151
 
151
152
  //# sourceMappingURL=llm-settings.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"llm-settings.js","names":[],"sources":["../../src/routes/llm-settings.tsx"],"sourcesContent":["import React from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { ModelSelector } from \"#/components/shared/modals/settings/model-selector\";\nimport { useAgentSettingsSchema } from \"#/hooks/query/use-agent-settings-schema\";\nimport { useSettings } from \"#/hooks/query/use-settings\";\nimport { SettingsInput } from \"#/components/features/settings/settings-input\";\nimport { HelpLink } from \"#/ui/help-link\";\nimport { KeyStatusIcon } from \"#/components/features/settings/key-status-icon\";\nimport {\n SdkSectionHeaderProps,\n SdkSectionPage,\n SdkSectionSaveControl,\n} from \"#/components/features/settings/sdk-settings/sdk-section-page\";\nimport { LlmSettingsLocalView } from \"#/components/features/settings/llm-profiles\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { Settings, SettingsSchema, SettingsScope } from \"#/types/settings\";\nimport { extractModelAndProvider } from \"#/utils/extract-model-and-provider\";\nimport { useActiveBackend } from \"#/contexts/active-backend-context\";\nimport {\n inferInitialView,\n type SettingsFormValues,\n type SettingsView,\n} from \"#/utils/sdk-settings-schema\";\nimport { DEFAULT_SETTINGS } from \"#/services/settings\";\n\nconst LLM_EXCLUDED_KEYS = new Set([\"llm.model\", \"llm.api_key\", \"llm.base_url\"]);\n\nconst buildModelId = (provider: string | null, model: string | null) => {\n if (!provider || !model) return null;\n return `${provider}/${model}`;\n};\n\nconst getSchemaFieldDefaultValue = (\n schema: SettingsSchema | null | undefined,\n fieldKey: string,\n) =>\n schema?.sections\n .flatMap((section) => section.fields)\n .find((field) => field.key === fieldKey)?.default ?? null;\n\nconst KNOWN_PROVIDER_DEFAULT_BASE_URLS: Partial<Record<string, Set<string>>> = {\n openai: new Set([\"https://api.openai.com\", \"https://api.openai.com/v1\"]),\n openhands: new Set([\n \"https://llm-proxy.app.all-hands.dev\",\n \"https://llm-proxy.app.all-hands.dev/v1\",\n ]),\n litellm_proxy: new Set([\n \"https://llm-proxy.app.all-hands.dev\",\n \"https://llm-proxy.app.all-hands.dev/v1\",\n ]),\n};\n\nconst normalizeBaseUrl = (baseUrl: string) => {\n try {\n const parsedUrl = new URL(baseUrl);\n const normalizedPath = parsedUrl.pathname.replace(/\\/+$/, \"\") || \"\";\n return `${parsedUrl.origin}${normalizedPath}`;\n } catch {\n return baseUrl.trim().replace(/\\/+$/, \"\");\n }\n};\n\nconst isProviderDefaultBaseUrl = (model: string, baseUrl: string) => {\n const normalizedBaseUrl = normalizeBaseUrl(baseUrl);\n const { provider } = extractModelAndProvider(model);\n\n if (provider) {\n const knownDefaults = KNOWN_PROVIDER_DEFAULT_BASE_URLS[provider];\n if (knownDefaults) {\n return knownDefaults.has(normalizedBaseUrl);\n }\n }\n\n return Object.values(KNOWN_PROVIDER_DEFAULT_BASE_URLS).some((knownDefaults) =>\n knownDefaults?.has(normalizedBaseUrl),\n );\n};\n\ninterface OpenHandsApiKeyHelpProps {\n testId: string;\n}\n\nfunction OpenHandsApiKeyHelp({ testId }: OpenHandsApiKeyHelpProps) {\n const { t } = useTranslation(\"openhands\");\n\n return (\n <HelpLink\n testId={testId}\n text={t(I18nKey.SETTINGS$OPENHANDS_API_KEY_HELP_TEXT)}\n linkText={t(I18nKey.SETTINGS$NAV_API_KEYS)}\n href=\"https://app.all-hands.dev/settings/api-keys\"\n suffix={` ${t(I18nKey.SETTINGS$OPENHANDS_API_KEY_HELP_SUFFIX)}`}\n />\n );\n}\n\nexport function LlmSettingsScreen({\n scope = \"personal\",\n onSaveSuccess,\n initialValueOverrides,\n embedded,\n hideSaveButton,\n onSaveControlChange,\n}: {\n scope?: SettingsScope;\n /** Optional hook fired after a successful save (e.g. advance an onboarding step). */\n onSaveSuccess?: () => void;\n /** Forwarded to {@link SdkSectionPage}. */\n initialValueOverrides?: SettingsFormValues;\n /** Forwarded to {@link SdkSectionPage}. */\n embedded?: boolean;\n /** Forwarded to {@link SdkSectionPage}. */\n hideSaveButton?: boolean;\n /** Forwarded to {@link SdkSectionPage}. */\n onSaveControlChange?: (control: SdkSectionSaveControl) => void;\n}) {\n const { t } = useTranslation(\"openhands\");\n\n const { data: settings } = useSettings(scope);\n const { data: schema } = useAgentSettingsSchema(\n settings?.agent_settings_schema,\n );\n\n const defaultModel = String(\n (DEFAULT_SETTINGS.agent_settings?.llm as Record<string, unknown>)?.model ??\n \"\",\n );\n\n const getInitialView = React.useCallback(\n (\n currentSettings: Settings,\n filteredSchema: SettingsSchema,\n ): SettingsView => {\n const schemaView = inferInitialView(currentSettings, filteredSchema);\n if (schemaView !== \"basic\") {\n return schemaView;\n }\n\n const currentModel = currentSettings.llm_model ?? \"\";\n const trimmedBaseUrl = currentSettings.llm_base_url?.trim() ?? \"\";\n const hasCustomBaseUrl =\n trimmedBaseUrl.length > 0 &&\n !isProviderDefaultBaseUrl(currentModel, trimmedBaseUrl);\n\n return hasCustomBaseUrl ? \"all\" : \"basic\";\n },\n [],\n );\n\n const buildHeader = React.useCallback(\n ({ values, isDisabled, view, onChange }: SdkSectionHeaderProps) => {\n const modelValue =\n typeof values[\"llm.model\"] === \"string\" ? values[\"llm.model\"] : \"\";\n const baseUrlValue =\n typeof values[\"llm.base_url\"] === \"string\"\n ? values[\"llm.base_url\"]\n : \"\";\n const showOpenHandsApiKeyHelp = modelValue.startsWith(\"openhands/\");\n\n const apiKeyValue =\n typeof values[\"llm.api_key\"] === \"string\" ? values[\"llm.api_key\"] : \"\";\n // For embedded profile forms (create/edit) the global\n // `llm_api_key_set` flag is misleading: a brand-new profile would show a\n // \"key set\" indicator just because some other profile has a key. Reflect\n // the form's own key state instead so create mode starts visibly unset.\n const apiKeyIsSet = embedded\n ? apiKeyValue.length > 0\n : Boolean(settings?.llm_api_key_set);\n\n const renderApiKeyInput = (testId: string, helpTestId: string) => (\n <>\n <SettingsInput\n testId={testId}\n label={t(I18nKey.SETTINGS_FORM$API_KEY)}\n type=\"password\"\n className=\"w-full\"\n value={apiKeyValue}\n placeholder={apiKeyIsSet ? \"<hidden>\" : \"\"}\n onChange={(value) => onChange(\"llm.api_key\", value)}\n isDisabled={isDisabled}\n startContent={\n apiKeyIsSet ? <KeyStatusIcon isSet={apiKeyIsSet} /> : undefined\n }\n />\n\n <HelpLink\n testId={helpTestId}\n text={t(I18nKey.SETTINGS$DONT_KNOW_API_KEY)}\n linkText={t(I18nKey.SETTINGS$CLICK_FOR_INSTRUCTIONS)}\n href=\"https://docs.openhands.dev/usage/local-setup#getting-an-api-key\"\n />\n </>\n );\n\n return (\n <div className=\"flex flex-col gap-6\">\n {view === \"basic\" ? (\n <div\n className=\"flex flex-col gap-6\"\n data-testid=\"llm-settings-form-basic\"\n >\n <ModelSelector\n currentModel={modelValue || undefined}\n currentBaseUrl={baseUrlValue || undefined}\n onChange={(provider, model) => {\n const nextModel = buildModelId(provider, model);\n if (nextModel) {\n onChange(\"llm.model\", nextModel);\n }\n }}\n wrapperClassName=\"!flex-col !gap-6\"\n isDisabled={isDisabled}\n />\n\n {showOpenHandsApiKeyHelp ? (\n <OpenHandsApiKeyHelp testId=\"openhands-api-key-help\" />\n ) : null}\n\n {renderApiKeyInput(\n \"llm-api-key-input\",\n \"llm-api-key-help-anchor\",\n )}\n </div>\n ) : (\n <div\n className=\"flex flex-col gap-6\"\n data-testid=\"llm-settings-form-advanced\"\n >\n <SettingsInput\n testId=\"llm-custom-model-input\"\n label={t(I18nKey.SETTINGS$CUSTOM_MODEL)}\n type=\"text\"\n className=\"w-full\"\n value={modelValue}\n placeholder={defaultModel}\n onChange={(value) => onChange(\"llm.model\", value)}\n isDisabled={isDisabled}\n />\n\n {showOpenHandsApiKeyHelp ? (\n <OpenHandsApiKeyHelp testId=\"openhands-api-key-help-2\" />\n ) : null}\n\n <SettingsInput\n testId=\"base-url-input\"\n label={t(I18nKey.SETTINGS$BASE_URL)}\n type=\"text\"\n className=\"w-full\"\n value={baseUrlValue}\n placeholder=\"https://api.openai.com\"\n onChange={(value) => onChange(\"llm.base_url\", value)}\n isDisabled={isDisabled}\n />\n\n {renderApiKeyInput(\n \"llm-api-key-input\",\n \"llm-api-key-help-anchor-advanced\",\n )}\n </div>\n )}\n </div>\n );\n },\n [defaultModel, embedded, settings?.llm_api_key_set, t],\n );\n\n const buildPayload = React.useCallback(\n (\n basePayload: Record<string, unknown>,\n context: {\n values: Record<string, string | boolean>;\n view: SettingsView;\n },\n ) => {\n // basePayload is a nested dict (e.g. {llm: {model: \"gpt-4\"}})\n const agentSettings = structuredClone(basePayload);\n\n const llm = (agentSettings.llm ?? {}) as Record<string, unknown>;\n\n if (context.view === \"basic\") {\n llm.base_url = getSchemaFieldDefaultValue(schema, \"llm.base_url\");\n agentSettings.llm = llm;\n }\n\n return { agent_settings_diff: agentSettings };\n },\n [schema],\n );\n\n return (\n <SdkSectionPage\n scope={scope}\n sectionKeys={[\"llm\"]}\n excludeKeys={LLM_EXCLUDED_KEYS}\n header={buildHeader}\n buildPayload={buildPayload}\n getInitialView={getInitialView}\n forceShowAdvancedView\n allowAllView\n onSaveSuccess={onSaveSuccess}\n initialValueOverrides={initialValueOverrides}\n embedded={embedded}\n hideSaveButton={hideSaveButton}\n onSaveControlChange={onSaveControlChange}\n testId=\"llm-settings-screen\"\n />\n );\n}\n\n/**\n * Default export for the route renders different views based on backend type:\n * - Local backends: LlmSettingsLocalView with profile management\n * - Cloud backends: Standard LlmSettingsScreen (profiles are not supported)\n *\n * The LlmSettingsScreen component is also exported for embedded use cases\n * (e.g., onboarding, profile editing forms).\n *\n * Note: This is a route file, only the router should import the default export.\n * Other consumers should use the named export `LlmSettingsScreen` for embedded\n * use cases.\n */\nexport default function LlmSettingsRoute() {\n const { backend } = useActiveBackend();\n const isCloud = backend.kind === \"cloud\";\n\n // Cloud backends use the standard LLM settings form (no profiles support)\n if (isCloud) {\n return <LlmSettingsScreen />;\n }\n\n // Local backends use the profile management view\n return <LlmSettingsLocalView />;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AAyBA,IAAM,IAAoB,IAAI,IAAI;CAAC;CAAa;CAAe;CAAe,CAAC,EAEzE,KAAgB,GAAyB,MACzC,CAAC,KAAY,CAAC,IAAc,OACzB,GAAG,EAAS,GAAG,KAGlB,KACJ,GACA,MAEA,GAAQ,SACL,SAAS,MAAY,EAAQ,OAAO,CACpC,MAAM,MAAU,EAAM,QAAQ,EAAS,EAAE,WAAW,MAEnD,IAAyE;CAC7E,QAAQ,IAAI,IAAI,CAAC,0BAA0B,4BAA4B,CAAC;CACxE,WAAW,IAAI,IAAI,CACjB,uCACA,yCACD,CAAC;CACF,eAAe,IAAI,IAAI,CACrB,uCACA,yCACD,CAAC;CACH,EAEK,KAAoB,MAAoB;AAC5C,KAAI;EACF,IAAM,IAAY,IAAI,IAAI,EAAQ,EAC5B,IAAiB,EAAU,SAAS,QAAQ,QAAQ,GAAG,IAAI;AACjE,SAAO,GAAG,EAAU,SAAS;SACvB;AACN,SAAO,EAAQ,MAAM,CAAC,QAAQ,QAAQ,GAAG;;GAIvC,KAA4B,GAAe,MAAoB;CACnE,IAAM,IAAoB,EAAiB,EAAQ,EAC7C,EAAE,gBAAa,EAAwB,EAAM;AAEnD,KAAI,GAAU;EACZ,IAAM,IAAgB,EAAiC;AACvD,MAAI,EACF,QAAO,EAAc,IAAI,EAAkB;;AAI/C,QAAO,OAAO,OAAO,EAAiC,CAAC,MAAM,MAC3D,GAAe,IAAI,EAAkB,CACtC;;AAOH,SAAS,EAAoB,EAAE,aAAoC;CACjE,IAAM,EAAE,SAAM,EAAe,YAAY;AAEzC,QACE,kBAAC,GAAD;EACU;EACR,MAAM,EAAE,EAAQ,qCAAqC;EACrD,UAAU,EAAE,EAAQ,sBAAsB;EAC1C,MAAK;EACL,QAAQ,IAAI,EAAE,EAAQ,uCAAuC;EAC7D,CAAA;;AAIN,SAAgB,EAAkB,EAChC,WAAQ,YACR,kBACA,0BACA,aACA,mBACA,0BAaC;CACD,IAAM,EAAE,SAAM,EAAe,YAAY,EAEnC,EAAE,MAAM,MAAa,EAAY,EAAM,EACvC,EAAE,MAAM,MAAW,EACvB,GAAU,sBACX,EAEK,IAAe,OAClB,EAAiB,gBAAgB,KAAiC,SACjE,GACH,EAEK,IAAiB,EAAM,aAEzB,GACA,MACiB;EACjB,IAAM,IAAa,EAAiB,GAAiB,EAAe;AACpE,MAAI,MAAe,QACjB,QAAO;EAGT,IAAM,IAAe,EAAgB,aAAa,IAC5C,IAAiB,EAAgB,cAAc,MAAM,IAAI;AAK/D,SAHE,EAAe,SAAS,KACxB,CAAC,EAAyB,GAAc,EAAe,GAE/B,QAAQ;IAEpC,EAAE,CACH;AA8ID,QACE,kBAAC,GAAD;EACS;EACP,aAAa,CAAC,MAAM;EACpB,aAAa;EACb,QAjJgB,EAAM,aACvB,EAAE,WAAQ,eAAY,SAAM,kBAAsC;GACjE,IAAM,IACJ,OAAO,EAAO,gBAAiB,WAAW,EAAO,eAAe,IAC5D,IACJ,OAAO,EAAO,mBAAoB,WAC9B,EAAO,kBACP,IACA,IAA0B,EAAW,WAAW,aAAa,EAE7D,IACJ,OAAO,EAAO,kBAAmB,WAAW,EAAO,iBAAiB,IAKhE,IAAc,IAChB,EAAY,SAAS,IACrB,EAAQ,GAAU,iBAEhB,KAAqB,GAAgB,MACzC,kBAAA,GAAA,EAAA,UAAA,CACE,kBAAC,GAAD;IACU;IACR,OAAO,EAAE,EAAQ,sBAAsB;IACvC,MAAK;IACL,WAAU;IACV,OAAO;IACP,aAAa,IAAc,aAAa;IACxC,WAAW,MAAU,EAAS,eAAe,EAAM;IACvC;IACZ,cACE,IAAc,kBAAC,GAAD,EAAe,OAAO,GAAe,CAAA,GAAG,KAAA;IAExD,CAAA,EAEF,kBAAC,GAAD;IACE,QAAQ;IACR,MAAM,EAAE,EAAQ,2BAA2B;IAC3C,UAAU,EAAE,EAAQ,gCAAgC;IACpD,MAAK;IACL,CAAA,CACD,EAAA,CAAA;AAGL,UACE,kBAAC,OAAD;IAAK,WAAU;cACZ,MAAS,UACR,kBAAC,OAAD;KACE,WAAU;KACV,eAAY;eAFd;MAIE,kBAAC,GAAD;OACE,cAAc,KAAc,KAAA;OAC5B,gBAAgB,KAAgB,KAAA;OAChC,WAAW,GAAU,MAAU;QAC7B,IAAM,IAAY,EAAa,GAAU,EAAM;AAC/C,QAAI,KACF,EAAS,aAAa,EAAU;;OAGpC,kBAAiB;OACL;OACZ,CAAA;MAED,IACC,kBAAC,GAAD,EAAqB,QAAO,0BAA2B,CAAA,GACrD;MAEH,EACC,qBACA,0BACD;MACG;SAEN,kBAAC,OAAD;KACE,WAAU;KACV,eAAY;eAFd;MAIE,kBAAC,GAAD;OACE,QAAO;OACP,OAAO,EAAE,EAAQ,sBAAsB;OACvC,MAAK;OACL,WAAU;OACV,OAAO;OACP,aAAa;OACb,WAAW,MAAU,EAAS,aAAa,EAAM;OACrC;OACZ,CAAA;MAED,IACC,kBAAC,GAAD,EAAqB,QAAO,4BAA6B,CAAA,GACvD;MAEJ,kBAAC,GAAD;OACE,QAAO;OACP,OAAO,EAAE,EAAQ,kBAAkB;OACnC,MAAK;OACL,WAAU;OACV,OAAO;OACP,aAAY;OACZ,WAAW,MAAU,EAAS,gBAAgB,EAAM;OACxC;OACZ,CAAA;MAED,EACC,qBACA,mCACD;MACG;;IAEJ,CAAA;KAGV;GAAC;GAAc;GAAU,GAAU;GAAiB;GAAE,CA+B5C;EACM,cA7BG,EAAM,aAEvB,GACA,MAIG;GAEH,IAAM,IAAgB,gBAAgB,EAAY,EAE5C,IAAO,EAAc,OAAO,EAAE;AAOpC,UALI,EAAQ,SAAS,YACnB,EAAI,WAAW,EAA2B,GAAQ,eAAe,EACjE,EAAc,MAAM,IAGf,EAAE,qBAAqB,GAAe;KAE/C,CAAC,EAAO,CASQ;EACE;EAChB,uBAAA;EACA,cAAA;EACe;EACQ;EACb;EACM;EACK;EACrB,QAAO;EACP,CAAA"}
1
+ {"version":3,"file":"llm-settings.js","names":[],"sources":["../../src/routes/llm-settings.tsx"],"sourcesContent":["import React from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { ModelSelector } from \"#/components/shared/modals/settings/model-selector\";\nimport { useAgentSettingsSchema } from \"#/hooks/query/use-agent-settings-schema\";\nimport { useSettings } from \"#/hooks/query/use-settings\";\nimport { SettingsInput } from \"#/components/features/settings/settings-input\";\nimport { HelpLink } from \"#/ui/help-link\";\nimport { KeyStatusIcon } from \"#/components/features/settings/key-status-icon\";\nimport {\n SdkSectionHeaderProps,\n SdkSectionPage,\n SdkSectionSaveControl,\n} from \"#/components/features/settings/sdk-settings/sdk-section-page\";\nimport { LlmSettingsLocalView } from \"#/components/features/settings/llm-profiles\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { Settings, SettingsSchema, SettingsScope } from \"#/types/settings\";\nimport { extractModelAndProvider } from \"#/utils/extract-model-and-provider\";\nimport { useActiveBackend } from \"#/contexts/active-backend-context\";\nimport {\n inferInitialView,\n type SettingsFormValues,\n type SettingsView,\n} from \"#/utils/sdk-settings-schema\";\nimport { DEFAULT_SETTINGS } from \"#/services/settings\";\nimport {\n OPENHANDS_LLM_PROXY_BASE_URL,\n isOpenHandsProviderModel,\n} from \"#/utils/openhands-llm\";\n\nconst LLM_EXCLUDED_KEYS = new Set([\"llm.model\", \"llm.api_key\", \"llm.base_url\"]);\n\nconst buildModelId = (provider: string | null, model: string | null) => {\n if (!provider || !model) return null;\n return `${provider}/${model}`;\n};\n\nconst getSchemaFieldDefaultValue = (\n schema: SettingsSchema | null | undefined,\n fieldKey: string,\n) =>\n schema?.sections\n .flatMap((section) => section.fields)\n .find((field) => field.key === fieldKey)?.default ?? null;\n\nconst KNOWN_PROVIDER_DEFAULT_BASE_URLS: Partial<Record<string, Set<string>>> = {\n openai: new Set([\"https://api.openai.com\", \"https://api.openai.com/v1\"]),\n openhands: new Set([\n OPENHANDS_LLM_PROXY_BASE_URL,\n \"https://llm-proxy.app.all-hands.dev/v1\",\n ]),\n litellm_proxy: new Set([\n OPENHANDS_LLM_PROXY_BASE_URL,\n \"https://llm-proxy.app.all-hands.dev/v1\",\n ]),\n};\n\nconst normalizeBaseUrl = (baseUrl: string) => {\n try {\n const parsedUrl = new URL(baseUrl);\n const normalizedPath = parsedUrl.pathname.replace(/\\/+$/, \"\") || \"\";\n return `${parsedUrl.origin}${normalizedPath}`;\n } catch {\n return baseUrl.trim().replace(/\\/+$/, \"\");\n }\n};\n\nconst isProviderDefaultBaseUrl = (model: string, baseUrl: string) => {\n const normalizedBaseUrl = normalizeBaseUrl(baseUrl);\n const { provider } = extractModelAndProvider(model);\n\n if (provider) {\n const knownDefaults = KNOWN_PROVIDER_DEFAULT_BASE_URLS[provider];\n if (knownDefaults) {\n return knownDefaults.has(normalizedBaseUrl);\n }\n }\n\n return Object.values(KNOWN_PROVIDER_DEFAULT_BASE_URLS).some((knownDefaults) =>\n knownDefaults?.has(normalizedBaseUrl),\n );\n};\n\ninterface OpenHandsApiKeyHelpProps {\n testId: string;\n}\n\nfunction OpenHandsApiKeyHelp({ testId }: OpenHandsApiKeyHelpProps) {\n const { t } = useTranslation(\"openhands\");\n\n return (\n <HelpLink\n testId={testId}\n text={t(I18nKey.SETTINGS$OPENHANDS_API_KEY_HELP_TEXT)}\n linkText={t(I18nKey.SETTINGS$NAV_API_KEYS)}\n href=\"https://app.all-hands.dev/settings/api-keys\"\n suffix={` ${t(I18nKey.SETTINGS$OPENHANDS_API_KEY_HELP_SUFFIX)}`}\n />\n );\n}\n\nexport function LlmSettingsScreen({\n scope = \"personal\",\n onSaveSuccess,\n initialValueOverrides,\n embedded,\n hideSaveButton,\n onSaveControlChange,\n}: {\n scope?: SettingsScope;\n /** Optional hook fired after a successful save (e.g. advance an onboarding step). */\n onSaveSuccess?: () => void;\n /** Forwarded to {@link SdkSectionPage}. */\n initialValueOverrides?: SettingsFormValues;\n /** Forwarded to {@link SdkSectionPage}. */\n embedded?: boolean;\n /** Forwarded to {@link SdkSectionPage}. */\n hideSaveButton?: boolean;\n /** Forwarded to {@link SdkSectionPage}. */\n onSaveControlChange?: (control: SdkSectionSaveControl) => void;\n}) {\n const { t } = useTranslation(\"openhands\");\n\n const { data: settings } = useSettings(scope);\n const { data: schema } = useAgentSettingsSchema(\n settings?.agent_settings_schema,\n );\n\n const defaultModel = String(\n (DEFAULT_SETTINGS.agent_settings?.llm as Record<string, unknown>)?.model ??\n \"\",\n );\n\n const getInitialView = React.useCallback(\n (\n currentSettings: Settings,\n filteredSchema: SettingsSchema,\n ): SettingsView => {\n const schemaView = inferInitialView(currentSettings, filteredSchema);\n if (schemaView !== \"basic\") {\n return schemaView;\n }\n\n const currentModel = currentSettings.llm_model ?? \"\";\n const trimmedBaseUrl = currentSettings.llm_base_url?.trim() ?? \"\";\n const hasCustomBaseUrl =\n trimmedBaseUrl.length > 0 &&\n !isProviderDefaultBaseUrl(currentModel, trimmedBaseUrl);\n\n return hasCustomBaseUrl ? \"all\" : \"basic\";\n },\n [],\n );\n\n const buildHeader = React.useCallback(\n ({ values, isDisabled, view, onChange }: SdkSectionHeaderProps) => {\n const modelValue =\n typeof values[\"llm.model\"] === \"string\" ? values[\"llm.model\"] : \"\";\n const baseUrlValue =\n typeof values[\"llm.base_url\"] === \"string\"\n ? values[\"llm.base_url\"]\n : \"\";\n const showOpenHandsApiKeyHelp = modelValue.startsWith(\"openhands/\");\n\n const apiKeyValue =\n typeof values[\"llm.api_key\"] === \"string\" ? values[\"llm.api_key\"] : \"\";\n // For embedded profile forms (create/edit) the global\n // `llm_api_key_set` flag is misleading: a brand-new profile would show a\n // \"key set\" indicator just because some other profile has a key. Reflect\n // the form's own key state instead so create mode starts visibly unset.\n const apiKeyIsSet = embedded\n ? apiKeyValue.length > 0\n : Boolean(settings?.llm_api_key_set);\n\n const renderApiKeyInput = (testId: string, helpTestId: string) => (\n <>\n <SettingsInput\n testId={testId}\n label={t(I18nKey.SETTINGS_FORM$API_KEY)}\n type=\"password\"\n className=\"w-full\"\n value={apiKeyValue}\n placeholder={apiKeyIsSet ? \"<hidden>\" : \"\"}\n onChange={(value) => onChange(\"llm.api_key\", value)}\n isDisabled={isDisabled}\n startContent={\n apiKeyIsSet ? <KeyStatusIcon isSet={apiKeyIsSet} /> : undefined\n }\n />\n\n <HelpLink\n testId={helpTestId}\n text={t(I18nKey.SETTINGS$DONT_KNOW_API_KEY)}\n linkText={t(I18nKey.SETTINGS$CLICK_FOR_INSTRUCTIONS)}\n href=\"https://docs.openhands.dev/usage/local-setup#getting-an-api-key\"\n />\n </>\n );\n\n return (\n <div className=\"flex flex-col gap-6\">\n {view === \"basic\" ? (\n <div\n className=\"flex flex-col gap-6\"\n data-testid=\"llm-settings-form-basic\"\n >\n <ModelSelector\n currentModel={modelValue || undefined}\n currentBaseUrl={baseUrlValue || undefined}\n onChange={(provider, model) => {\n const nextModel = buildModelId(provider, model);\n if (nextModel) {\n onChange(\"llm.model\", nextModel);\n }\n }}\n wrapperClassName=\"!flex-col !gap-6\"\n isDisabled={isDisabled}\n />\n\n {showOpenHandsApiKeyHelp ? (\n <OpenHandsApiKeyHelp testId=\"openhands-api-key-help\" />\n ) : null}\n\n {renderApiKeyInput(\n \"llm-api-key-input\",\n \"llm-api-key-help-anchor\",\n )}\n </div>\n ) : (\n <div\n className=\"flex flex-col gap-6\"\n data-testid=\"llm-settings-form-advanced\"\n >\n <SettingsInput\n testId=\"llm-custom-model-input\"\n label={t(I18nKey.SETTINGS$CUSTOM_MODEL)}\n type=\"text\"\n className=\"w-full\"\n value={modelValue}\n placeholder={defaultModel}\n onChange={(value) => onChange(\"llm.model\", value)}\n isDisabled={isDisabled}\n />\n\n {showOpenHandsApiKeyHelp ? (\n <OpenHandsApiKeyHelp testId=\"openhands-api-key-help-2\" />\n ) : null}\n\n <SettingsInput\n testId=\"base-url-input\"\n label={t(I18nKey.SETTINGS$BASE_URL)}\n type=\"text\"\n className=\"w-full\"\n value={baseUrlValue}\n placeholder=\"https://api.openai.com\"\n onChange={(value) => onChange(\"llm.base_url\", value)}\n isDisabled={isDisabled}\n />\n\n {renderApiKeyInput(\n \"llm-api-key-input\",\n \"llm-api-key-help-anchor-advanced\",\n )}\n </div>\n )}\n </div>\n );\n },\n [defaultModel, embedded, settings?.llm_api_key_set, t],\n );\n\n const buildPayload = React.useCallback(\n (\n basePayload: Record<string, unknown>,\n context: {\n values: Record<string, string | boolean>;\n view: SettingsView;\n },\n ) => {\n // basePayload is a nested dict (e.g. {llm: {model: \"gpt-4\"}})\n const agentSettings = structuredClone(basePayload);\n\n const llm = (agentSettings.llm ?? {}) as Record<string, unknown>;\n\n if (context.view === \"basic\") {\n const model = llm.model ?? context.values[\"llm.model\"];\n llm.base_url = isOpenHandsProviderModel(model)\n ? OPENHANDS_LLM_PROXY_BASE_URL\n : getSchemaFieldDefaultValue(schema, \"llm.base_url\");\n agentSettings.llm = llm;\n }\n\n return { agent_settings_diff: agentSettings };\n },\n [schema],\n );\n\n return (\n <SdkSectionPage\n scope={scope}\n sectionKeys={[\"llm\"]}\n excludeKeys={LLM_EXCLUDED_KEYS}\n header={buildHeader}\n buildPayload={buildPayload}\n getInitialView={getInitialView}\n forceShowAdvancedView\n allowAllView\n onSaveSuccess={onSaveSuccess}\n initialValueOverrides={initialValueOverrides}\n embedded={embedded}\n hideSaveButton={hideSaveButton}\n onSaveControlChange={onSaveControlChange}\n testId=\"llm-settings-screen\"\n />\n );\n}\n\n/**\n * Default export for the route renders different views based on backend type:\n * - Local backends: LlmSettingsLocalView with profile management\n * - Cloud backends: Standard LlmSettingsScreen (profiles are not supported)\n *\n * The LlmSettingsScreen component is also exported for embedded use cases\n * (e.g., onboarding, profile editing forms).\n *\n * Note: This is a route file, only the router should import the default export.\n * Other consumers should use the named export `LlmSettingsScreen` for embedded\n * use cases.\n */\nexport default function LlmSettingsRoute() {\n const { backend } = useActiveBackend();\n const isCloud = backend.kind === \"cloud\";\n\n // Cloud backends use the standard LLM settings form (no profiles support)\n if (isCloud) {\n return <LlmSettingsScreen />;\n }\n\n // Local backends use the profile management view\n return <LlmSettingsLocalView />;\n}\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- const e=require(`../_virtual/_rolldown/runtime.cjs`),t=require(`../node_modules/react-i18next/dist/es/useTranslation.cjs`),n=require(`../i18n/declaration.cjs`),r=require(`../utils/utils.cjs`),i=require(`../node_modules/lucide-react/dist/esm/icons/arrow-left.cjs`),a=require(`../node_modules/@tanstack/react-query/build/modern/QueryClientProvider.cjs`),o=require(`../ui/typography.cjs`),s=require(`../components/shared/loading-spinner.cjs`),c=require(`../components/features/settings/brand-button.cjs`),l=require(`../utils/settings-list-classes.cjs`),u=require(`../components/shared/modals/confirmation-modal.cjs`),d=require(`../hooks/query/use-get-secrets.cjs`),f=require(`../hooks/mutation/use-delete-secret.cjs`),p=require(`../components/features/settings/secrets-settings/secret-form.cjs`),m=require(`../components/features/settings/secrets-settings/secret-list-item.cjs`);let h=require(`react`);h=e.__toESM(h,1);let g=require(`react/jsx-runtime`);function _(){let e=a.useQueryClient(),{t:_}=t.useTranslation(`openhands`),v=(0,h.useRef)(null),{data:y,isLoading:b,hasNextPage:x,isFetchingNextPage:S,onLoadMore:C}=d.useSearchSecrets(),{mutate:w}=f.useDeleteSecret(),[T,E]=h.default.useState(`list`),[D,O]=h.default.useState(null),[k,A]=h.default.useState(!1),j=(0,h.useCallback)(e=>{let t=e.currentTarget;t.scrollHeight-t.scrollTop<=t.clientHeight+100&&x&&!S&&C()},[x,S,C]),M=()=>{e.invalidateQueries({queryKey:[`secrets-search`]}),e.invalidateQueries({queryKey:[`secrets`]})},N=e=>{w(e,{onSettled:()=>{A(!1)},onSuccess:M,onError:M})},P=()=>{D&&N(D)},F=()=>{A(!1)},I=()=>{E(`list`),O(null)},L=T===`add-secret-form`||T===`edit-secret-form`,R=_(T===`add-secret-form`?n.I18nKey.SECRETS$ADD_A_SECRET:n.I18nKey.SECRETS$EDIT_A_SECRET);return(0,g.jsxs)(`div`,{"data-testid":`secrets-settings-screen`,className:`flex flex-col gap-6`,children:[T===`list`?(0,g.jsxs)(`div`,{className:`flex items-start justify-between gap-4`,children:[(0,g.jsxs)(`div`,{className:`min-w-0 space-y-1`,children:[(0,g.jsx)(o.Typography.H2,{children:_(n.I18nKey.SETTINGS$NAV_SECRETS)}),(0,g.jsx)(`p`,{"data-testid":`settings-page-subtitle`,className:`text-sm leading-5 text-tertiary-light`,children:_(n.I18nKey.SETTINGS$PAGE_SECRETS_SUBLINE)})]}),(0,g.jsx)(c.BrandButton,{testId:`add-secret-button`,type:`button`,variant:`primary`,className:`shrink-0 whitespace-nowrap`,onClick:()=>E(`add-secret-form`),isDisabled:b,children:_(`SECRETS$ADD_NEW_SECRET`)})]}):null,L?(0,g.jsxs)(`div`,{className:`flex flex-col gap-2`,children:[(0,g.jsxs)(`button`,{type:`button`,onClick:I,className:`flex items-center gap-2 self-start rounded-lg p-2 text-[var(--oh-muted)] transition-colors hover:bg-tertiary hover:text-white`,"data-testid":`back-to-secrets`,children:[(0,g.jsx)(i.ArrowLeft,{size:20,"aria-hidden":!0}),(0,g.jsx)(`span`,{className:`text-sm leading-5`,children:_(n.I18nKey.BUTTON$BACK)})]}),(0,g.jsx)(o.Typography.H2,{testId:`secret-editor-title`,children:R})]}):null,b&&T===`list`&&(0,g.jsxs)(`ul`,{children:[(0,g.jsx)(m.SecretListItemSkeleton,{}),(0,g.jsx)(m.SecretListItemSkeleton,{}),(0,g.jsx)(m.SecretListItemSkeleton,{})]}),T===`list`&&!b&&(0,g.jsxs)(`div`,{ref:v,className:l.settingsListScrollContainerClassName,onScroll:j,children:[(0,g.jsxs)(`table`,{className:`w-full min-w-full table-fixed`,children:[(0,g.jsx)(`thead`,{className:l.settingsListTableHeadClassName,children:(0,g.jsxs)(`tr`,{children:[(0,g.jsx)(`th`,{className:r.cn(l.settingsListTableHeaderCellClassName,`w-1/4`),children:_(n.I18nKey.SETTINGS$NAME)}),(0,g.jsx)(`th`,{className:r.cn(l.settingsListTableHeaderCellClassName,`w-1/2`),children:_(n.I18nKey.SECRETS$DESCRIPTION)}),(0,g.jsx)(`th`,{className:r.cn(l.settingsListTableHeaderCellClassName,`w-1/4 text-right`),children:_(n.I18nKey.SETTINGS$ACTIONS)})]})}),(0,g.jsx)(`tbody`,{children:y?.map(e=>(0,g.jsx)(m.SecretListItem,{title:e.name,description:e.description,onEdit:()=>{E(`edit-secret-form`),O(e.name)},onDelete:()=>{A(!0),O(e.name)}},e.name))})]}),S&&(0,g.jsx)(`div`,{className:`flex justify-center p-4`,children:(0,g.jsx)(s.LoadingSpinner,{size:`small`})})]}),(T===`add-secret-form`||T===`edit-secret-form`)&&(0,g.jsx)(p.SecretForm,{mode:T===`add-secret-form`?`add`:`edit`,selectedSecret:D,onCancel:I}),k&&(0,g.jsx)(u.ConfirmationModal,{text:_(`SECRETS$CONFIRM_DELETE_KEY`),onConfirm:P,onCancel:F})]})}exports.default=_;
1
+ const e=require(`../_virtual/_rolldown/runtime.cjs`),t=require(`../node_modules/react-i18next/dist/es/useTranslation.cjs`),n=require(`../i18n/declaration.cjs`),r=require(`../utils/utils.cjs`),i=require(`../node_modules/@tanstack/react-query/build/modern/QueryClientProvider.cjs`),a=require(`../ui/typography.cjs`),o=require(`../components/shared/loading-spinner.cjs`),s=require(`../components/features/settings/brand-button.cjs`),c=require(`../utils/settings-list-classes.cjs`),l=require(`../components/shared/buttons/back-nav-button.cjs`),u=require(`../components/shared/modals/confirmation-modal.cjs`),d=require(`../hooks/query/use-get-secrets.cjs`),f=require(`../hooks/mutation/use-delete-secret.cjs`),p=require(`../components/features/settings/secrets-settings/secret-form.cjs`),m=require(`../components/features/settings/secrets-settings/secret-list-item.cjs`);let h=require(`react`);h=e.__toESM(h,1);let g=require(`react/jsx-runtime`);function _(){let e=i.useQueryClient(),{t:_}=t.useTranslation(`openhands`),v=(0,h.useRef)(null),{data:y,isLoading:b,hasNextPage:x,isFetchingNextPage:S,onLoadMore:C}=d.useSearchSecrets(),{mutate:w}=f.useDeleteSecret(),[T,E]=h.default.useState(`list`),[D,O]=h.default.useState(null),[k,A]=h.default.useState(!1),j=(0,h.useCallback)(e=>{let t=e.currentTarget;t.scrollHeight-t.scrollTop<=t.clientHeight+100&&x&&!S&&C()},[x,S,C]),M=()=>{e.invalidateQueries({queryKey:[`secrets-search`]}),e.invalidateQueries({queryKey:[`secrets`]})},N=e=>{w(e,{onSettled:()=>{A(!1)},onSuccess:M,onError:M})},P=()=>{D&&N(D)},F=()=>{A(!1)},I=()=>{E(`list`),O(null)},L=T===`add-secret-form`||T===`edit-secret-form`,R=_(T===`add-secret-form`?n.I18nKey.SECRETS$ADD_A_SECRET:n.I18nKey.SECRETS$EDIT_A_SECRET);return(0,g.jsxs)(`div`,{"data-testid":`secrets-settings-screen`,className:`flex flex-col gap-6`,children:[T===`list`?(0,g.jsxs)(`div`,{className:`flex items-start justify-between gap-4`,children:[(0,g.jsxs)(`div`,{className:`min-w-0 space-y-1`,children:[(0,g.jsx)(a.Typography.H2,{children:_(n.I18nKey.SETTINGS$NAV_SECRETS)}),(0,g.jsx)(`p`,{"data-testid":`settings-page-subtitle`,className:`text-sm leading-5 text-tertiary-light`,children:_(n.I18nKey.SETTINGS$PAGE_SECRETS_SUBLINE)})]}),(0,g.jsx)(s.BrandButton,{testId:`add-secret-button`,type:`button`,variant:`primary`,className:`shrink-0 whitespace-nowrap`,onClick:()=>E(`add-secret-form`),isDisabled:b,children:_(`SECRETS$ADD_NEW_SECRET`)})]}):null,L?(0,g.jsxs)(`div`,{className:`flex flex-col gap-2`,children:[(0,g.jsx)(l.BackNavButton,{testId:`back-to-secrets`,onClick:I,children:_(n.I18nKey.BUTTON$BACK)}),(0,g.jsx)(a.Typography.H2,{testId:`secret-editor-title`,children:R})]}):null,b&&T===`list`&&(0,g.jsxs)(`ul`,{children:[(0,g.jsx)(m.SecretListItemSkeleton,{}),(0,g.jsx)(m.SecretListItemSkeleton,{}),(0,g.jsx)(m.SecretListItemSkeleton,{})]}),T===`list`&&!b&&(0,g.jsxs)(`div`,{ref:v,className:c.settingsListScrollContainerClassName,onScroll:j,children:[(0,g.jsxs)(`table`,{className:`w-full min-w-full table-fixed`,children:[(0,g.jsx)(`thead`,{className:c.settingsListTableHeadClassName,children:(0,g.jsxs)(`tr`,{children:[(0,g.jsx)(`th`,{className:r.cn(c.settingsListTableHeaderCellClassName,`w-1/4`),children:_(n.I18nKey.SETTINGS$NAME)}),(0,g.jsx)(`th`,{className:r.cn(c.settingsListTableHeaderCellClassName,`w-1/2`),children:_(n.I18nKey.SECRETS$DESCRIPTION)}),(0,g.jsx)(`th`,{className:r.cn(c.settingsListTableHeaderCellClassName,`w-1/4 text-right`),children:_(n.I18nKey.SETTINGS$ACTIONS)})]})}),(0,g.jsx)(`tbody`,{children:y?.map(e=>(0,g.jsx)(m.SecretListItem,{title:e.name,description:e.description,onEdit:()=>{E(`edit-secret-form`),O(e.name)},onDelete:()=>{A(!0),O(e.name)}},e.name))})]}),S&&(0,g.jsx)(`div`,{className:`flex justify-center p-4`,children:(0,g.jsx)(o.LoadingSpinner,{size:`small`})})]}),(T===`add-secret-form`||T===`edit-secret-form`)&&(0,g.jsx)(p.SecretForm,{mode:T===`add-secret-form`?`add`:`edit`,selectedSecret:D,onCancel:I}),k&&(0,g.jsx)(u.ConfirmationModal,{text:_(`SECRETS$CONFIRM_DELETE_KEY`),onConfirm:P,onCancel:F})]})}exports.default=_;
2
2
  //# sourceMappingURL=secrets-settings.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"secrets-settings.cjs","names":[],"sources":["../../src/routes/secrets-settings.tsx"],"sourcesContent":["import { useQueryClient } from \"@tanstack/react-query\";\nimport React, { useCallback, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { ArrowLeft } from \"lucide-react\";\nimport { useSearchSecrets } from \"#/hooks/query/use-get-secrets\";\nimport { useDeleteSecret } from \"#/hooks/mutation/use-delete-secret\";\nimport { SecretForm } from \"#/components/features/settings/secrets-settings/secret-form\";\nimport {\n SecretListItem,\n SecretListItemSkeleton,\n} from \"#/components/features/settings/secrets-settings/secret-list-item\";\nimport { BrandButton } from \"#/components/features/settings/brand-button\";\nimport { ConfirmationModal } from \"#/components/shared/modals/confirmation-modal\";\nimport { Typography } from \"#/ui/typography\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { cn } from \"#/utils/utils\";\nimport { LoadingSpinner } from \"#/components/shared/loading-spinner\";\nimport {\n settingsListScrollContainerClassName,\n settingsListTableHeadClassName,\n settingsListTableHeaderCellClassName,\n} from \"#/utils/settings-list-classes\";\n\nexport const handle = { hideTitle: true };\n\nexport function SecretsSettingsScreen() {\n const queryClient = useQueryClient();\n const { t } = useTranslation(\"openhands\");\n const tableContainerRef = useRef<HTMLDivElement>(null);\n\n const {\n data: secrets,\n isLoading: isLoadingSecrets,\n hasNextPage,\n isFetchingNextPage,\n onLoadMore,\n } = useSearchSecrets();\n\n const { mutate: deleteSecret } = useDeleteSecret();\n\n const [view, setView] = React.useState<\n \"list\" | \"add-secret-form\" | \"edit-secret-form\"\n >(\"list\");\n const [selectedSecret, setSelectedSecret] = React.useState<string | null>(\n null,\n );\n const [confirmationModalIsVisible, setConfirmationModalIsVisible] =\n React.useState(false);\n\n const handleScroll = useCallback(\n (e: React.UIEvent<HTMLDivElement>) => {\n const target = e.currentTarget;\n const isNearBottom =\n target.scrollHeight - target.scrollTop <= target.clientHeight + 100;\n\n if (isNearBottom && hasNextPage && !isFetchingNextPage) {\n onLoadMore();\n }\n },\n [hasNextPage, isFetchingNextPage, onLoadMore],\n );\n\n const invalidateSecrets = () => {\n queryClient.invalidateQueries({\n queryKey: [\"secrets-search\"],\n });\n queryClient.invalidateQueries({\n queryKey: [\"secrets\"],\n });\n };\n\n const handleDeleteSecret = (secret: string) => {\n deleteSecret(secret, {\n onSettled: () => {\n setConfirmationModalIsVisible(false);\n },\n onSuccess: invalidateSecrets,\n onError: invalidateSecrets,\n });\n };\n\n const onConfirmDeleteSecret = () => {\n if (selectedSecret) handleDeleteSecret(selectedSecret);\n };\n\n const onCancelDeleteSecret = () => {\n setConfirmationModalIsVisible(false);\n };\n\n const handleBackToList = () => {\n setView(\"list\");\n setSelectedSecret(null);\n };\n\n const isFormView = view === \"add-secret-form\" || view === \"edit-secret-form\";\n const formTitle =\n view === \"add-secret-form\"\n ? t(I18nKey.SECRETS$ADD_A_SECRET)\n : t(I18nKey.SECRETS$EDIT_A_SECRET);\n\n return (\n <div data-testid=\"secrets-settings-screen\" className=\"flex flex-col gap-6\">\n {view === \"list\" ? (\n <div className=\"flex items-start justify-between gap-4\">\n <div className=\"min-w-0 space-y-1\">\n <Typography.H2>{t(I18nKey.SETTINGS$NAV_SECRETS)}</Typography.H2>\n <p\n data-testid=\"settings-page-subtitle\"\n className=\"text-sm leading-5 text-tertiary-light\"\n >\n {t(I18nKey.SETTINGS$PAGE_SECRETS_SUBLINE)}\n </p>\n </div>\n <BrandButton\n testId=\"add-secret-button\"\n type=\"button\"\n variant=\"primary\"\n className=\"shrink-0 whitespace-nowrap\"\n onClick={() => setView(\"add-secret-form\")}\n isDisabled={isLoadingSecrets}\n >\n {t(\"SECRETS$ADD_NEW_SECRET\")}\n </BrandButton>\n </div>\n ) : null}\n\n {isFormView ? (\n <div className=\"flex flex-col gap-2\">\n <button\n type=\"button\"\n onClick={handleBackToList}\n className=\"flex items-center gap-2 self-start rounded-lg p-2 text-[var(--oh-muted)] transition-colors hover:bg-tertiary hover:text-white\"\n data-testid=\"back-to-secrets\"\n >\n <ArrowLeft size={20} aria-hidden />\n <span className=\"text-sm leading-5\">{t(I18nKey.BUTTON$BACK)}</span>\n </button>\n <Typography.H2 testId=\"secret-editor-title\">\n {formTitle}\n </Typography.H2>\n </div>\n ) : null}\n\n {isLoadingSecrets && view === \"list\" && (\n <ul>\n <SecretListItemSkeleton />\n <SecretListItemSkeleton />\n <SecretListItemSkeleton />\n </ul>\n )}\n\n {view === \"list\" && !isLoadingSecrets && (\n <div\n ref={tableContainerRef}\n className={settingsListScrollContainerClassName}\n onScroll={handleScroll}\n >\n <table className=\"w-full min-w-full table-fixed\">\n <thead className={settingsListTableHeadClassName}>\n <tr>\n <th\n className={cn(settingsListTableHeaderCellClassName, \"w-1/4\")}\n >\n {t(I18nKey.SETTINGS$NAME)}\n </th>\n <th\n className={cn(settingsListTableHeaderCellClassName, \"w-1/2\")}\n >\n {t(I18nKey.SECRETS$DESCRIPTION)}\n </th>\n <th\n className={cn(\n settingsListTableHeaderCellClassName,\n \"w-1/4 text-right\",\n )}\n >\n {t(I18nKey.SETTINGS$ACTIONS)}\n </th>\n </tr>\n </thead>\n <tbody>\n {secrets?.map((secret) => (\n <SecretListItem\n key={secret.name}\n title={secret.name}\n description={secret.description}\n onEdit={() => {\n setView(\"edit-secret-form\");\n setSelectedSecret(secret.name);\n }}\n onDelete={() => {\n setConfirmationModalIsVisible(true);\n setSelectedSecret(secret.name);\n }}\n />\n ))}\n </tbody>\n </table>\n\n {isFetchingNextPage && (\n <div className=\"flex justify-center p-4\">\n <LoadingSpinner size=\"small\" />\n </div>\n )}\n </div>\n )}\n\n {(view === \"add-secret-form\" || view === \"edit-secret-form\") && (\n <SecretForm\n mode={view === \"add-secret-form\" ? \"add\" : \"edit\"}\n selectedSecret={selectedSecret}\n onCancel={handleBackToList}\n />\n )}\n\n {confirmationModalIsVisible && (\n <ConfirmationModal\n text={t(\"SECRETS$CONFIRM_DELETE_KEY\")}\n onConfirm={onConfirmDeleteSecret}\n onCancel={onCancelDeleteSecret}\n />\n )}\n </div>\n );\n}\n\nexport default SecretsSettingsScreen;\n"],"mappings":"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"}
1
+ {"version":3,"file":"secrets-settings.cjs","names":[],"sources":["../../src/routes/secrets-settings.tsx"],"sourcesContent":["import { useQueryClient } from \"@tanstack/react-query\";\nimport React, { useCallback, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { BackNavButton } from \"#/components/shared/buttons/back-nav-button\";\nimport { useSearchSecrets } from \"#/hooks/query/use-get-secrets\";\nimport { useDeleteSecret } from \"#/hooks/mutation/use-delete-secret\";\nimport { SecretForm } from \"#/components/features/settings/secrets-settings/secret-form\";\nimport {\n SecretListItem,\n SecretListItemSkeleton,\n} from \"#/components/features/settings/secrets-settings/secret-list-item\";\nimport { BrandButton } from \"#/components/features/settings/brand-button\";\nimport { ConfirmationModal } from \"#/components/shared/modals/confirmation-modal\";\nimport { Typography } from \"#/ui/typography\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { cn } from \"#/utils/utils\";\nimport { LoadingSpinner } from \"#/components/shared/loading-spinner\";\nimport {\n settingsListScrollContainerClassName,\n settingsListTableHeadClassName,\n settingsListTableHeaderCellClassName,\n} from \"#/utils/settings-list-classes\";\n\nexport const handle = { hideTitle: true };\n\nexport function SecretsSettingsScreen() {\n const queryClient = useQueryClient();\n const { t } = useTranslation(\"openhands\");\n const tableContainerRef = useRef<HTMLDivElement>(null);\n\n const {\n data: secrets,\n isLoading: isLoadingSecrets,\n hasNextPage,\n isFetchingNextPage,\n onLoadMore,\n } = useSearchSecrets();\n\n const { mutate: deleteSecret } = useDeleteSecret();\n\n const [view, setView] = React.useState<\n \"list\" | \"add-secret-form\" | \"edit-secret-form\"\n >(\"list\");\n const [selectedSecret, setSelectedSecret] = React.useState<string | null>(\n null,\n );\n const [confirmationModalIsVisible, setConfirmationModalIsVisible] =\n React.useState(false);\n\n const handleScroll = useCallback(\n (e: React.UIEvent<HTMLDivElement>) => {\n const target = e.currentTarget;\n const isNearBottom =\n target.scrollHeight - target.scrollTop <= target.clientHeight + 100;\n\n if (isNearBottom && hasNextPage && !isFetchingNextPage) {\n onLoadMore();\n }\n },\n [hasNextPage, isFetchingNextPage, onLoadMore],\n );\n\n const invalidateSecrets = () => {\n queryClient.invalidateQueries({\n queryKey: [\"secrets-search\"],\n });\n queryClient.invalidateQueries({\n queryKey: [\"secrets\"],\n });\n };\n\n const handleDeleteSecret = (secret: string) => {\n deleteSecret(secret, {\n onSettled: () => {\n setConfirmationModalIsVisible(false);\n },\n onSuccess: invalidateSecrets,\n onError: invalidateSecrets,\n });\n };\n\n const onConfirmDeleteSecret = () => {\n if (selectedSecret) handleDeleteSecret(selectedSecret);\n };\n\n const onCancelDeleteSecret = () => {\n setConfirmationModalIsVisible(false);\n };\n\n const handleBackToList = () => {\n setView(\"list\");\n setSelectedSecret(null);\n };\n\n const isFormView = view === \"add-secret-form\" || view === \"edit-secret-form\";\n const formTitle =\n view === \"add-secret-form\"\n ? t(I18nKey.SECRETS$ADD_A_SECRET)\n : t(I18nKey.SECRETS$EDIT_A_SECRET);\n\n return (\n <div data-testid=\"secrets-settings-screen\" className=\"flex flex-col gap-6\">\n {view === \"list\" ? (\n <div className=\"flex items-start justify-between gap-4\">\n <div className=\"min-w-0 space-y-1\">\n <Typography.H2>{t(I18nKey.SETTINGS$NAV_SECRETS)}</Typography.H2>\n <p\n data-testid=\"settings-page-subtitle\"\n className=\"text-sm leading-5 text-tertiary-light\"\n >\n {t(I18nKey.SETTINGS$PAGE_SECRETS_SUBLINE)}\n </p>\n </div>\n <BrandButton\n testId=\"add-secret-button\"\n type=\"button\"\n variant=\"primary\"\n className=\"shrink-0 whitespace-nowrap\"\n onClick={() => setView(\"add-secret-form\")}\n isDisabled={isLoadingSecrets}\n >\n {t(\"SECRETS$ADD_NEW_SECRET\")}\n </BrandButton>\n </div>\n ) : null}\n\n {isFormView ? (\n <div className=\"flex flex-col gap-2\">\n <BackNavButton testId=\"back-to-secrets\" onClick={handleBackToList}>\n {t(I18nKey.BUTTON$BACK)}\n </BackNavButton>\n <Typography.H2 testId=\"secret-editor-title\">\n {formTitle}\n </Typography.H2>\n </div>\n ) : null}\n\n {isLoadingSecrets && view === \"list\" && (\n <ul>\n <SecretListItemSkeleton />\n <SecretListItemSkeleton />\n <SecretListItemSkeleton />\n </ul>\n )}\n\n {view === \"list\" && !isLoadingSecrets && (\n <div\n ref={tableContainerRef}\n className={settingsListScrollContainerClassName}\n onScroll={handleScroll}\n >\n <table className=\"w-full min-w-full table-fixed\">\n <thead className={settingsListTableHeadClassName}>\n <tr>\n <th\n className={cn(settingsListTableHeaderCellClassName, \"w-1/4\")}\n >\n {t(I18nKey.SETTINGS$NAME)}\n </th>\n <th\n className={cn(settingsListTableHeaderCellClassName, \"w-1/2\")}\n >\n {t(I18nKey.SECRETS$DESCRIPTION)}\n </th>\n <th\n className={cn(\n settingsListTableHeaderCellClassName,\n \"w-1/4 text-right\",\n )}\n >\n {t(I18nKey.SETTINGS$ACTIONS)}\n </th>\n </tr>\n </thead>\n <tbody>\n {secrets?.map((secret) => (\n <SecretListItem\n key={secret.name}\n title={secret.name}\n description={secret.description}\n onEdit={() => {\n setView(\"edit-secret-form\");\n setSelectedSecret(secret.name);\n }}\n onDelete={() => {\n setConfirmationModalIsVisible(true);\n setSelectedSecret(secret.name);\n }}\n />\n ))}\n </tbody>\n </table>\n\n {isFetchingNextPage && (\n <div className=\"flex justify-center p-4\">\n <LoadingSpinner size=\"small\" />\n </div>\n )}\n </div>\n )}\n\n {(view === \"add-secret-form\" || view === \"edit-secret-form\") && (\n <SecretForm\n mode={view === \"add-secret-form\" ? \"add\" : \"edit\"}\n selectedSecret={selectedSecret}\n onCancel={handleBackToList}\n />\n )}\n\n {confirmationModalIsVisible && (\n <ConfirmationModal\n text={t(\"SECRETS$CONFIRM_DELETE_KEY\")}\n onConfirm={onConfirmDeleteSecret}\n onCancel={onCancelDeleteSecret}\n />\n )}\n </div>\n );\n}\n\nexport default SecretsSettingsScreen;\n"],"mappings":"66BAyBA,SAAgB,GAAwB,CACtC,IAAM,EAAc,EAAA,gBAAgB,CAC9B,CAAE,KAAM,EAAA,eAAe,YAAY,CACnC,GAAA,EAAA,EAAA,QAA2C,KAAK,CAEhD,CACJ,KAAM,EACN,UAAW,EACX,cACA,qBACA,cACE,EAAA,kBAAkB,CAEhB,CAAE,OAAQ,GAAiB,EAAA,iBAAiB,CAE5C,CAAC,EAAM,GAAW,EAAA,QAAM,SAE5B,OAAO,CACH,CAAC,EAAgB,GAAqB,EAAA,QAAM,SAChD,KACD,CACK,CAAC,EAA4B,GACjC,EAAA,QAAM,SAAS,GAAM,CAEjB,GAAA,EAAA,EAAA,aACH,GAAqC,CACpC,IAAM,EAAS,EAAE,cAEf,EAAO,aAAe,EAAO,WAAa,EAAO,aAAe,KAE9C,GAAe,CAAC,GAClC,GAAY,EAGhB,CAAC,EAAa,EAAoB,EAAW,CAC9C,CAEK,MAA0B,CAC9B,EAAY,kBAAkB,CAC5B,SAAU,CAAC,iBAAiB,CAC7B,CAAC,CACF,EAAY,kBAAkB,CAC5B,SAAU,CAAC,UAAU,CACtB,CAAC,EAGE,EAAsB,GAAmB,CAC7C,EAAa,EAAQ,CACnB,cAAiB,CACf,EAA8B,GAAM,EAEtC,UAAW,EACX,QAAS,EACV,CAAC,EAGE,MAA8B,CAC9B,GAAgB,EAAmB,EAAe,EAGlD,MAA6B,CACjC,EAA8B,GAAM,EAGhC,MAAyB,CAC7B,EAAQ,OAAO,CACf,EAAkB,KAAK,EAGnB,EAAa,IAAS,mBAAqB,IAAS,mBACpD,EAEA,EADJ,IAAS,kBACH,EAAA,QAAQ,qBACR,EAAA,QAAQ,sBAAsB,CAEtC,OACE,EAAA,EAAA,MAAC,MAAD,CAAK,cAAY,0BAA0B,UAAU,+BAArD,CACG,IAAS,QACR,EAAA,EAAA,MAAC,MAAD,CAAK,UAAU,kDAAf,EACE,EAAA,EAAA,MAAC,MAAD,CAAK,UAAU,6BAAf,EACE,EAAA,EAAA,KAAC,EAAA,WAAW,GAAZ,CAAA,SAAgB,EAAE,EAAA,QAAQ,qBAAqB,CAAiB,CAAA,EAChE,EAAA,EAAA,KAAC,IAAD,CACE,cAAY,yBACZ,UAAU,iDAET,EAAE,EAAA,QAAQ,8BAA8B,CACvC,CAAA,CACA,IACN,EAAA,EAAA,KAAC,EAAA,YAAD,CACE,OAAO,oBACP,KAAK,SACL,QAAQ,UACR,UAAU,6BACV,YAAe,EAAQ,kBAAkB,CACzC,WAAY,WAEX,EAAE,yBAAyB,CAChB,CAAA,CACV,GACJ,KAEH,GACC,EAAA,EAAA,MAAC,MAAD,CAAK,UAAU,+BAAf,EACE,EAAA,EAAA,KAAC,EAAA,cAAD,CAAe,OAAO,kBAAkB,QAAS,WAC9C,EAAE,EAAA,QAAQ,YAAY,CACT,CAAA,EAChB,EAAA,EAAA,KAAC,EAAA,WAAW,GAAZ,CAAe,OAAO,+BACnB,EACa,CAAA,CACZ,GACJ,KAEH,GAAoB,IAAS,SAC5B,EAAA,EAAA,MAAC,KAAD,CAAA,SAAA,EACE,EAAA,EAAA,KAAC,EAAA,uBAAD,EAA0B,CAAA,EAC1B,EAAA,EAAA,KAAC,EAAA,uBAAD,EAA0B,CAAA,EAC1B,EAAA,EAAA,KAAC,EAAA,uBAAD,EAA0B,CAAA,CACvB,CAAA,CAAA,CAGN,IAAS,QAAU,CAAC,IACnB,EAAA,EAAA,MAAC,MAAD,CACE,IAAK,EACL,UAAW,EAAA,qCACX,SAAU,WAHZ,EAKE,EAAA,EAAA,MAAC,QAAD,CAAO,UAAU,yCAAjB,EACE,EAAA,EAAA,KAAC,QAAD,CAAO,UAAW,EAAA,yCAChB,EAAA,EAAA,MAAC,KAAD,CAAA,SAAA,EACE,EAAA,EAAA,KAAC,KAAD,CACE,UAAW,EAAA,GAAG,EAAA,qCAAsC,QAAQ,UAE3D,EAAE,EAAA,QAAQ,cAAc,CACtB,CAAA,EACL,EAAA,EAAA,KAAC,KAAD,CACE,UAAW,EAAA,GAAG,EAAA,qCAAsC,QAAQ,UAE3D,EAAE,EAAA,QAAQ,oBAAoB,CAC5B,CAAA,EACL,EAAA,EAAA,KAAC,KAAD,CACE,UAAW,EAAA,GACT,EAAA,qCACA,mBACD,UAEA,EAAE,EAAA,QAAQ,iBAAiB,CACzB,CAAA,CACF,CAAA,CAAA,CACC,CAAA,EACR,EAAA,EAAA,KAAC,QAAD,CAAA,SACG,GAAS,IAAK,IACb,EAAA,EAAA,KAAC,EAAA,eAAD,CAEE,MAAO,EAAO,KACd,YAAa,EAAO,YACpB,WAAc,CACZ,EAAQ,mBAAmB,CAC3B,EAAkB,EAAO,KAAK,EAEhC,aAAgB,CACd,EAA8B,GAAK,CACnC,EAAkB,EAAO,KAAK,EAEhC,CAXK,EAAO,KAWZ,CACF,CACI,CAAA,CACF,GAEP,IACC,EAAA,EAAA,KAAC,MAAD,CAAK,UAAU,oCACb,EAAA,EAAA,KAAC,EAAA,eAAD,CAAgB,KAAK,QAAU,CAAA,CAC3B,CAAA,CAEJ,IAGN,IAAS,mBAAqB,IAAS,sBACvC,EAAA,EAAA,KAAC,EAAA,WAAD,CACE,KAAM,IAAS,kBAAoB,MAAQ,OAC3B,iBAChB,SAAU,EACV,CAAA,CAGH,IACC,EAAA,EAAA,KAAC,EAAA,kBAAD,CACE,KAAM,EAAE,6BAA6B,CACrC,UAAW,EACX,SAAU,EACV,CAAA,CAEA"}
@@ -1,12 +1,12 @@
1
1
  import { useTranslation as e } from "../node_modules/react-i18next/dist/es/useTranslation.js";
2
2
  import { I18nKey as t } from "../i18n/declaration.js";
3
3
  import { cn as n } from "../utils/utils.js";
4
- import { ArrowLeft as r } from "../node_modules/lucide-react/dist/esm/icons/arrow-left.js";
5
- import { useQueryClient as i } from "../node_modules/@tanstack/react-query/build/modern/QueryClientProvider.js";
6
- import { Typography as a } from "../ui/typography.js";
7
- import { LoadingSpinner as o } from "../components/shared/loading-spinner.js";
8
- import { BrandButton as s } from "../components/features/settings/brand-button.js";
9
- import { settingsListScrollContainerClassName as c, settingsListTableHeadClassName as l, settingsListTableHeaderCellClassName as u } from "../utils/settings-list-classes.js";
4
+ import { useQueryClient as r } from "../node_modules/@tanstack/react-query/build/modern/QueryClientProvider.js";
5
+ import { Typography as i } from "../ui/typography.js";
6
+ import { LoadingSpinner as a } from "../components/shared/loading-spinner.js";
7
+ import { BrandButton as o } from "../components/features/settings/brand-button.js";
8
+ import { settingsListScrollContainerClassName as s, settingsListTableHeadClassName as c, settingsListTableHeaderCellClassName as l } from "../utils/settings-list-classes.js";
9
+ import { BackNavButton as u } from "../components/shared/buttons/back-nav-button.js";
10
10
  import { ConfirmationModal as d } from "../components/shared/modals/confirmation-modal.js";
11
11
  import { useSearchSecrets as f } from "../hooks/query/use-get-secrets.js";
12
12
  import { useDeleteSecret as p } from "../hooks/mutation/use-delete-secret.js";
@@ -16,7 +16,7 @@ import _, { useCallback as v, useRef as y } from "react";
16
16
  import { jsx as b, jsxs as x } from "react/jsx-runtime";
17
17
  //#region src/routes/secrets-settings.tsx
18
18
  function S() {
19
- let S = i(), { t: C } = e("openhands"), w = y(null), { data: T, isLoading: E, hasNextPage: D, isFetchingNextPage: O, onLoadMore: k } = f(), { mutate: A } = p(), [j, M] = _.useState("list"), [N, P] = _.useState(null), [F, I] = _.useState(!1), L = v((e) => {
19
+ let S = r(), { t: C } = e("openhands"), w = y(null), { data: T, isLoading: E, hasNextPage: D, isFetchingNextPage: O, onLoadMore: k } = f(), { mutate: A } = p(), [j, M] = _.useState("list"), [N, P] = _.useState(null), [F, I] = _.useState(!1), L = v((e) => {
20
20
  let t = e.currentTarget;
21
21
  t.scrollHeight - t.scrollTop <= t.clientHeight + 100 && D && !O && k();
22
22
  }, [
@@ -48,12 +48,12 @@ function S() {
48
48
  className: "flex items-start justify-between gap-4",
49
49
  children: [/* @__PURE__ */ x("div", {
50
50
  className: "min-w-0 space-y-1",
51
- children: [/* @__PURE__ */ b(a.H2, { children: C(t.SETTINGS$NAV_SECRETS) }), /* @__PURE__ */ b("p", {
51
+ children: [/* @__PURE__ */ b(i.H2, { children: C(t.SETTINGS$NAV_SECRETS) }), /* @__PURE__ */ b("p", {
52
52
  "data-testid": "settings-page-subtitle",
53
53
  className: "text-sm leading-5 text-tertiary-light",
54
54
  children: C(t.SETTINGS$PAGE_SECRETS_SUBLINE)
55
55
  })]
56
- }), /* @__PURE__ */ b(s, {
56
+ }), /* @__PURE__ */ b(o, {
57
57
  testId: "add-secret-button",
58
58
  type: "button",
59
59
  variant: "primary",
@@ -65,19 +65,11 @@ function S() {
65
65
  }) : null,
66
66
  U ? /* @__PURE__ */ x("div", {
67
67
  className: "flex flex-col gap-2",
68
- children: [/* @__PURE__ */ x("button", {
69
- type: "button",
68
+ children: [/* @__PURE__ */ b(u, {
69
+ testId: "back-to-secrets",
70
70
  onClick: H,
71
- className: "flex items-center gap-2 self-start rounded-lg p-2 text-[var(--oh-muted)] transition-colors hover:bg-tertiary hover:text-white",
72
- "data-testid": "back-to-secrets",
73
- children: [/* @__PURE__ */ b(r, {
74
- size: 20,
75
- "aria-hidden": !0
76
- }), /* @__PURE__ */ b("span", {
77
- className: "text-sm leading-5",
78
- children: C(t.BUTTON$BACK)
79
- })]
80
- }), /* @__PURE__ */ b(a.H2, {
71
+ children: C(t.BUTTON$BACK)
72
+ }), /* @__PURE__ */ b(i.H2, {
81
73
  testId: "secret-editor-title",
82
74
  children: W
83
75
  })]
@@ -89,23 +81,23 @@ function S() {
89
81
  ] }),
90
82
  j === "list" && !E && /* @__PURE__ */ x("div", {
91
83
  ref: w,
92
- className: c,
84
+ className: s,
93
85
  onScroll: L,
94
86
  children: [/* @__PURE__ */ x("table", {
95
87
  className: "w-full min-w-full table-fixed",
96
88
  children: [/* @__PURE__ */ b("thead", {
97
- className: l,
89
+ className: c,
98
90
  children: /* @__PURE__ */ x("tr", { children: [
99
91
  /* @__PURE__ */ b("th", {
100
- className: n(u, "w-1/4"),
92
+ className: n(l, "w-1/4"),
101
93
  children: C(t.SETTINGS$NAME)
102
94
  }),
103
95
  /* @__PURE__ */ b("th", {
104
- className: n(u, "w-1/2"),
96
+ className: n(l, "w-1/2"),
105
97
  children: C(t.SECRETS$DESCRIPTION)
106
98
  }),
107
99
  /* @__PURE__ */ b("th", {
108
- className: n(u, "w-1/4 text-right"),
100
+ className: n(l, "w-1/4 text-right"),
109
101
  children: C(t.SETTINGS$ACTIONS)
110
102
  })
111
103
  ] })
@@ -121,7 +113,7 @@ function S() {
121
113
  }, e.name)) })]
122
114
  }), O && /* @__PURE__ */ b("div", {
123
115
  className: "flex justify-center p-4",
124
- children: /* @__PURE__ */ b(o, { size: "small" })
116
+ children: /* @__PURE__ */ b(a, { size: "small" })
125
117
  })]
126
118
  }),
127
119
  (j === "add-secret-form" || j === "edit-secret-form") && /* @__PURE__ */ b(m, {
@@ -1 +1 @@
1
- {"version":3,"file":"secrets-settings.js","names":[],"sources":["../../src/routes/secrets-settings.tsx"],"sourcesContent":["import { useQueryClient } from \"@tanstack/react-query\";\nimport React, { useCallback, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { ArrowLeft } from \"lucide-react\";\nimport { useSearchSecrets } from \"#/hooks/query/use-get-secrets\";\nimport { useDeleteSecret } from \"#/hooks/mutation/use-delete-secret\";\nimport { SecretForm } from \"#/components/features/settings/secrets-settings/secret-form\";\nimport {\n SecretListItem,\n SecretListItemSkeleton,\n} from \"#/components/features/settings/secrets-settings/secret-list-item\";\nimport { BrandButton } from \"#/components/features/settings/brand-button\";\nimport { ConfirmationModal } from \"#/components/shared/modals/confirmation-modal\";\nimport { Typography } from \"#/ui/typography\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { cn } from \"#/utils/utils\";\nimport { LoadingSpinner } from \"#/components/shared/loading-spinner\";\nimport {\n settingsListScrollContainerClassName,\n settingsListTableHeadClassName,\n settingsListTableHeaderCellClassName,\n} from \"#/utils/settings-list-classes\";\n\nexport const handle = { hideTitle: true };\n\nexport function SecretsSettingsScreen() {\n const queryClient = useQueryClient();\n const { t } = useTranslation(\"openhands\");\n const tableContainerRef = useRef<HTMLDivElement>(null);\n\n const {\n data: secrets,\n isLoading: isLoadingSecrets,\n hasNextPage,\n isFetchingNextPage,\n onLoadMore,\n } = useSearchSecrets();\n\n const { mutate: deleteSecret } = useDeleteSecret();\n\n const [view, setView] = React.useState<\n \"list\" | \"add-secret-form\" | \"edit-secret-form\"\n >(\"list\");\n const [selectedSecret, setSelectedSecret] = React.useState<string | null>(\n null,\n );\n const [confirmationModalIsVisible, setConfirmationModalIsVisible] =\n React.useState(false);\n\n const handleScroll = useCallback(\n (e: React.UIEvent<HTMLDivElement>) => {\n const target = e.currentTarget;\n const isNearBottom =\n target.scrollHeight - target.scrollTop <= target.clientHeight + 100;\n\n if (isNearBottom && hasNextPage && !isFetchingNextPage) {\n onLoadMore();\n }\n },\n [hasNextPage, isFetchingNextPage, onLoadMore],\n );\n\n const invalidateSecrets = () => {\n queryClient.invalidateQueries({\n queryKey: [\"secrets-search\"],\n });\n queryClient.invalidateQueries({\n queryKey: [\"secrets\"],\n });\n };\n\n const handleDeleteSecret = (secret: string) => {\n deleteSecret(secret, {\n onSettled: () => {\n setConfirmationModalIsVisible(false);\n },\n onSuccess: invalidateSecrets,\n onError: invalidateSecrets,\n });\n };\n\n const onConfirmDeleteSecret = () => {\n if (selectedSecret) handleDeleteSecret(selectedSecret);\n };\n\n const onCancelDeleteSecret = () => {\n setConfirmationModalIsVisible(false);\n };\n\n const handleBackToList = () => {\n setView(\"list\");\n setSelectedSecret(null);\n };\n\n const isFormView = view === \"add-secret-form\" || view === \"edit-secret-form\";\n const formTitle =\n view === \"add-secret-form\"\n ? t(I18nKey.SECRETS$ADD_A_SECRET)\n : t(I18nKey.SECRETS$EDIT_A_SECRET);\n\n return (\n <div data-testid=\"secrets-settings-screen\" className=\"flex flex-col gap-6\">\n {view === \"list\" ? (\n <div className=\"flex items-start justify-between gap-4\">\n <div className=\"min-w-0 space-y-1\">\n <Typography.H2>{t(I18nKey.SETTINGS$NAV_SECRETS)}</Typography.H2>\n <p\n data-testid=\"settings-page-subtitle\"\n className=\"text-sm leading-5 text-tertiary-light\"\n >\n {t(I18nKey.SETTINGS$PAGE_SECRETS_SUBLINE)}\n </p>\n </div>\n <BrandButton\n testId=\"add-secret-button\"\n type=\"button\"\n variant=\"primary\"\n className=\"shrink-0 whitespace-nowrap\"\n onClick={() => setView(\"add-secret-form\")}\n isDisabled={isLoadingSecrets}\n >\n {t(\"SECRETS$ADD_NEW_SECRET\")}\n </BrandButton>\n </div>\n ) : null}\n\n {isFormView ? (\n <div className=\"flex flex-col gap-2\">\n <button\n type=\"button\"\n onClick={handleBackToList}\n className=\"flex items-center gap-2 self-start rounded-lg p-2 text-[var(--oh-muted)] transition-colors hover:bg-tertiary hover:text-white\"\n data-testid=\"back-to-secrets\"\n >\n <ArrowLeft size={20} aria-hidden />\n <span className=\"text-sm leading-5\">{t(I18nKey.BUTTON$BACK)}</span>\n </button>\n <Typography.H2 testId=\"secret-editor-title\">\n {formTitle}\n </Typography.H2>\n </div>\n ) : null}\n\n {isLoadingSecrets && view === \"list\" && (\n <ul>\n <SecretListItemSkeleton />\n <SecretListItemSkeleton />\n <SecretListItemSkeleton />\n </ul>\n )}\n\n {view === \"list\" && !isLoadingSecrets && (\n <div\n ref={tableContainerRef}\n className={settingsListScrollContainerClassName}\n onScroll={handleScroll}\n >\n <table className=\"w-full min-w-full table-fixed\">\n <thead className={settingsListTableHeadClassName}>\n <tr>\n <th\n className={cn(settingsListTableHeaderCellClassName, \"w-1/4\")}\n >\n {t(I18nKey.SETTINGS$NAME)}\n </th>\n <th\n className={cn(settingsListTableHeaderCellClassName, \"w-1/2\")}\n >\n {t(I18nKey.SECRETS$DESCRIPTION)}\n </th>\n <th\n className={cn(\n settingsListTableHeaderCellClassName,\n \"w-1/4 text-right\",\n )}\n >\n {t(I18nKey.SETTINGS$ACTIONS)}\n </th>\n </tr>\n </thead>\n <tbody>\n {secrets?.map((secret) => (\n <SecretListItem\n key={secret.name}\n title={secret.name}\n description={secret.description}\n onEdit={() => {\n setView(\"edit-secret-form\");\n setSelectedSecret(secret.name);\n }}\n onDelete={() => {\n setConfirmationModalIsVisible(true);\n setSelectedSecret(secret.name);\n }}\n />\n ))}\n </tbody>\n </table>\n\n {isFetchingNextPage && (\n <div className=\"flex justify-center p-4\">\n <LoadingSpinner size=\"small\" />\n </div>\n )}\n </div>\n )}\n\n {(view === \"add-secret-form\" || view === \"edit-secret-form\") && (\n <SecretForm\n mode={view === \"add-secret-form\" ? \"add\" : \"edit\"}\n selectedSecret={selectedSecret}\n onCancel={handleBackToList}\n />\n )}\n\n {confirmationModalIsVisible && (\n <ConfirmationModal\n text={t(\"SECRETS$CONFIRM_DELETE_KEY\")}\n onConfirm={onConfirmDeleteSecret}\n onCancel={onCancelDeleteSecret}\n />\n )}\n </div>\n );\n}\n\nexport default SecretsSettingsScreen;\n"],"mappings":";;;;;;;;;;;;;;;;;AAyBA,SAAgB,IAAwB;CACtC,IAAM,IAAc,GAAgB,EAC9B,EAAE,SAAM,EAAe,YAAY,EACnC,IAAoB,EAAuB,KAAK,EAEhD,EACJ,MAAM,GACN,WAAW,GACX,gBACA,uBACA,kBACE,GAAkB,EAEhB,EAAE,QAAQ,MAAiB,GAAiB,EAE5C,CAAC,GAAM,KAAW,EAAM,SAE5B,OAAO,EACH,CAAC,GAAgB,KAAqB,EAAM,SAChD,KACD,EACK,CAAC,GAA4B,KACjC,EAAM,SAAS,GAAM,EAEjB,IAAe,GAClB,MAAqC;EACpC,IAAM,IAAS,EAAE;AAIjB,EAFE,EAAO,eAAe,EAAO,aAAa,EAAO,eAAe,OAE9C,KAAe,CAAC,KAClC,GAAY;IAGhB;EAAC;EAAa;EAAoB;EAAW,CAC9C,EAEK,UAA0B;AAI9B,EAHA,EAAY,kBAAkB,EAC5B,UAAU,CAAC,iBAAiB,EAC7B,CAAC,EACF,EAAY,kBAAkB,EAC5B,UAAU,CAAC,UAAU,EACtB,CAAC;IAGE,KAAsB,MAAmB;AAC7C,IAAa,GAAQ;GACnB,iBAAiB;AACf,MAA8B,GAAM;;GAEtC,WAAW;GACX,SAAS;GACV,CAAC;IAGE,UAA8B;AAClC,EAAI,KAAgB,EAAmB,EAAe;IAGlD,UAA6B;AACjC,IAA8B,GAAM;IAGhC,UAAyB;AAE7B,EADA,EAAQ,OAAO,EACf,EAAkB,KAAK;IAGnB,IAAa,MAAS,qBAAqB,MAAS,oBACpD,IAEA,EADJ,MAAS,oBACH,EAAQ,uBACR,EAAQ,sBAAsB;AAEtC,QACE,kBAAC,OAAD;EAAK,eAAY;EAA0B,WAAU;YAArD;GACG,MAAS,SACR,kBAAC,OAAD;IAAK,WAAU;cAAf,CACE,kBAAC,OAAD;KAAK,WAAU;eAAf,CACE,kBAAC,EAAW,IAAZ,EAAA,UAAgB,EAAE,EAAQ,qBAAqB,EAAiB,CAAA,EAChE,kBAAC,KAAD;MACE,eAAY;MACZ,WAAU;gBAET,EAAE,EAAQ,8BAA8B;MACvC,CAAA,CACA;QACN,kBAAC,GAAD;KACE,QAAO;KACP,MAAK;KACL,SAAQ;KACR,WAAU;KACV,eAAe,EAAQ,kBAAkB;KACzC,YAAY;eAEX,EAAE,yBAAyB;KAChB,CAAA,CACV;QACJ;GAEH,IACC,kBAAC,OAAD;IAAK,WAAU;cAAf,CACE,kBAAC,UAAD;KACE,MAAK;KACL,SAAS;KACT,WAAU;KACV,eAAY;eAJd,CAME,kBAAC,GAAD;MAAW,MAAM;MAAI,eAAA;MAAc,CAAA,EACnC,kBAAC,QAAD;MAAM,WAAU;gBAAqB,EAAE,EAAQ,YAAY;MAAQ,CAAA,CAC5D;QACT,kBAAC,EAAW,IAAZ;KAAe,QAAO;eACnB;KACa,CAAA,CACZ;QACJ;GAEH,KAAoB,MAAS,UAC5B,kBAAC,MAAD,EAAA,UAAA;IACE,kBAAC,GAAD,EAA0B,CAAA;IAC1B,kBAAC,GAAD,EAA0B,CAAA;IAC1B,kBAAC,GAAD,EAA0B,CAAA;IACvB,EAAA,CAAA;GAGN,MAAS,UAAU,CAAC,KACnB,kBAAC,OAAD;IACE,KAAK;IACL,WAAW;IACX,UAAU;cAHZ,CAKE,kBAAC,SAAD;KAAO,WAAU;eAAjB,CACE,kBAAC,SAAD;MAAO,WAAW;gBAChB,kBAAC,MAAD,EAAA,UAAA;OACE,kBAAC,MAAD;QACE,WAAW,EAAG,GAAsC,QAAQ;kBAE3D,EAAE,EAAQ,cAAc;QACtB,CAAA;OACL,kBAAC,MAAD;QACE,WAAW,EAAG,GAAsC,QAAQ;kBAE3D,EAAE,EAAQ,oBAAoB;QAC5B,CAAA;OACL,kBAAC,MAAD;QACE,WAAW,EACT,GACA,mBACD;kBAEA,EAAE,EAAQ,iBAAiB;QACzB,CAAA;OACF,EAAA,CAAA;MACC,CAAA,EACR,kBAAC,SAAD,EAAA,UACG,GAAS,KAAK,MACb,kBAAC,GAAD;MAEE,OAAO,EAAO;MACd,aAAa,EAAO;MACpB,cAAc;AAEZ,OADA,EAAQ,mBAAmB,EAC3B,EAAkB,EAAO,KAAK;;MAEhC,gBAAgB;AAEd,OADA,EAA8B,GAAK,EACnC,EAAkB,EAAO,KAAK;;MAEhC,EAXK,EAAO,KAWZ,CACF,EACI,CAAA,CACF;QAEP,KACC,kBAAC,OAAD;KAAK,WAAU;eACb,kBAAC,GAAD,EAAgB,MAAK,SAAU,CAAA;KAC3B,CAAA,CAEJ;;IAGN,MAAS,qBAAqB,MAAS,uBACvC,kBAAC,GAAD;IACE,MAAM,MAAS,oBAAoB,QAAQ;IAC3B;IAChB,UAAU;IACV,CAAA;GAGH,KACC,kBAAC,GAAD;IACE,MAAM,EAAE,6BAA6B;IACrC,WAAW;IACX,UAAU;IACV,CAAA;GAEA"}
1
+ {"version":3,"file":"secrets-settings.js","names":[],"sources":["../../src/routes/secrets-settings.tsx"],"sourcesContent":["import { useQueryClient } from \"@tanstack/react-query\";\nimport React, { useCallback, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { BackNavButton } from \"#/components/shared/buttons/back-nav-button\";\nimport { useSearchSecrets } from \"#/hooks/query/use-get-secrets\";\nimport { useDeleteSecret } from \"#/hooks/mutation/use-delete-secret\";\nimport { SecretForm } from \"#/components/features/settings/secrets-settings/secret-form\";\nimport {\n SecretListItem,\n SecretListItemSkeleton,\n} from \"#/components/features/settings/secrets-settings/secret-list-item\";\nimport { BrandButton } from \"#/components/features/settings/brand-button\";\nimport { ConfirmationModal } from \"#/components/shared/modals/confirmation-modal\";\nimport { Typography } from \"#/ui/typography\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { cn } from \"#/utils/utils\";\nimport { LoadingSpinner } from \"#/components/shared/loading-spinner\";\nimport {\n settingsListScrollContainerClassName,\n settingsListTableHeadClassName,\n settingsListTableHeaderCellClassName,\n} from \"#/utils/settings-list-classes\";\n\nexport const handle = { hideTitle: true };\n\nexport function SecretsSettingsScreen() {\n const queryClient = useQueryClient();\n const { t } = useTranslation(\"openhands\");\n const tableContainerRef = useRef<HTMLDivElement>(null);\n\n const {\n data: secrets,\n isLoading: isLoadingSecrets,\n hasNextPage,\n isFetchingNextPage,\n onLoadMore,\n } = useSearchSecrets();\n\n const { mutate: deleteSecret } = useDeleteSecret();\n\n const [view, setView] = React.useState<\n \"list\" | \"add-secret-form\" | \"edit-secret-form\"\n >(\"list\");\n const [selectedSecret, setSelectedSecret] = React.useState<string | null>(\n null,\n );\n const [confirmationModalIsVisible, setConfirmationModalIsVisible] =\n React.useState(false);\n\n const handleScroll = useCallback(\n (e: React.UIEvent<HTMLDivElement>) => {\n const target = e.currentTarget;\n const isNearBottom =\n target.scrollHeight - target.scrollTop <= target.clientHeight + 100;\n\n if (isNearBottom && hasNextPage && !isFetchingNextPage) {\n onLoadMore();\n }\n },\n [hasNextPage, isFetchingNextPage, onLoadMore],\n );\n\n const invalidateSecrets = () => {\n queryClient.invalidateQueries({\n queryKey: [\"secrets-search\"],\n });\n queryClient.invalidateQueries({\n queryKey: [\"secrets\"],\n });\n };\n\n const handleDeleteSecret = (secret: string) => {\n deleteSecret(secret, {\n onSettled: () => {\n setConfirmationModalIsVisible(false);\n },\n onSuccess: invalidateSecrets,\n onError: invalidateSecrets,\n });\n };\n\n const onConfirmDeleteSecret = () => {\n if (selectedSecret) handleDeleteSecret(selectedSecret);\n };\n\n const onCancelDeleteSecret = () => {\n setConfirmationModalIsVisible(false);\n };\n\n const handleBackToList = () => {\n setView(\"list\");\n setSelectedSecret(null);\n };\n\n const isFormView = view === \"add-secret-form\" || view === \"edit-secret-form\";\n const formTitle =\n view === \"add-secret-form\"\n ? t(I18nKey.SECRETS$ADD_A_SECRET)\n : t(I18nKey.SECRETS$EDIT_A_SECRET);\n\n return (\n <div data-testid=\"secrets-settings-screen\" className=\"flex flex-col gap-6\">\n {view === \"list\" ? (\n <div className=\"flex items-start justify-between gap-4\">\n <div className=\"min-w-0 space-y-1\">\n <Typography.H2>{t(I18nKey.SETTINGS$NAV_SECRETS)}</Typography.H2>\n <p\n data-testid=\"settings-page-subtitle\"\n className=\"text-sm leading-5 text-tertiary-light\"\n >\n {t(I18nKey.SETTINGS$PAGE_SECRETS_SUBLINE)}\n </p>\n </div>\n <BrandButton\n testId=\"add-secret-button\"\n type=\"button\"\n variant=\"primary\"\n className=\"shrink-0 whitespace-nowrap\"\n onClick={() => setView(\"add-secret-form\")}\n isDisabled={isLoadingSecrets}\n >\n {t(\"SECRETS$ADD_NEW_SECRET\")}\n </BrandButton>\n </div>\n ) : null}\n\n {isFormView ? (\n <div className=\"flex flex-col gap-2\">\n <BackNavButton testId=\"back-to-secrets\" onClick={handleBackToList}>\n {t(I18nKey.BUTTON$BACK)}\n </BackNavButton>\n <Typography.H2 testId=\"secret-editor-title\">\n {formTitle}\n </Typography.H2>\n </div>\n ) : null}\n\n {isLoadingSecrets && view === \"list\" && (\n <ul>\n <SecretListItemSkeleton />\n <SecretListItemSkeleton />\n <SecretListItemSkeleton />\n </ul>\n )}\n\n {view === \"list\" && !isLoadingSecrets && (\n <div\n ref={tableContainerRef}\n className={settingsListScrollContainerClassName}\n onScroll={handleScroll}\n >\n <table className=\"w-full min-w-full table-fixed\">\n <thead className={settingsListTableHeadClassName}>\n <tr>\n <th\n className={cn(settingsListTableHeaderCellClassName, \"w-1/4\")}\n >\n {t(I18nKey.SETTINGS$NAME)}\n </th>\n <th\n className={cn(settingsListTableHeaderCellClassName, \"w-1/2\")}\n >\n {t(I18nKey.SECRETS$DESCRIPTION)}\n </th>\n <th\n className={cn(\n settingsListTableHeaderCellClassName,\n \"w-1/4 text-right\",\n )}\n >\n {t(I18nKey.SETTINGS$ACTIONS)}\n </th>\n </tr>\n </thead>\n <tbody>\n {secrets?.map((secret) => (\n <SecretListItem\n key={secret.name}\n title={secret.name}\n description={secret.description}\n onEdit={() => {\n setView(\"edit-secret-form\");\n setSelectedSecret(secret.name);\n }}\n onDelete={() => {\n setConfirmationModalIsVisible(true);\n setSelectedSecret(secret.name);\n }}\n />\n ))}\n </tbody>\n </table>\n\n {isFetchingNextPage && (\n <div className=\"flex justify-center p-4\">\n <LoadingSpinner size=\"small\" />\n </div>\n )}\n </div>\n )}\n\n {(view === \"add-secret-form\" || view === \"edit-secret-form\") && (\n <SecretForm\n mode={view === \"add-secret-form\" ? \"add\" : \"edit\"}\n selectedSecret={selectedSecret}\n onCancel={handleBackToList}\n />\n )}\n\n {confirmationModalIsVisible && (\n <ConfirmationModal\n text={t(\"SECRETS$CONFIRM_DELETE_KEY\")}\n onConfirm={onConfirmDeleteSecret}\n onCancel={onCancelDeleteSecret}\n />\n )}\n </div>\n );\n}\n\nexport default SecretsSettingsScreen;\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- require(`../_virtual/_rolldown/runtime.cjs`);const e=require(`../node_modules/zustand/esm/react.cjs`),t=require(`../node_modules/zustand/esm/middleware.cjs`),n=require(`../utils/conversation-local-storage.cjs`);var r=()=>{if(typeof window>`u`)return null;let e=window.location.pathname.match(/\/conversations\/([^/]+)/);return e?e[1]:null},i=()=>{if(typeof window>`u`)return`code`;let e=r();return e?n.getConversationState(e).conversationMode:`code`},a=e.create()(t.devtools(e=>({isRightPanelShown:!1,selectedTab:`files`,images:[],files:[],imagesMarkedUploadAsFile:[],pastedImageNames:[],loadingFiles:[],loadingImages:[],messageToSend:null,shouldShownAgentLoading:!1,submittedMessage:null,shouldHideSuggestions:!1,hasRightPanelToggled:!1,planContent:null,conversationMode:i(),subConversationTaskId:null,setIsRightPanelShown:t=>e({isRightPanelShown:t},!1,`setIsRightPanelShown`),setSelectedTab:t=>e({selectedTab:t},!1,`setSelectedTab`),setShouldShownAgentLoading:t=>e({shouldShownAgentLoading:t},!1,`setShouldShownAgentLoading`),setShouldHideSuggestions:t=>e({shouldHideSuggestions:t},!1,`setShouldHideSuggestions`),addImages:t=>e(e=>({images:[...e.images,...t]}),!1,`addImages`),addFiles:t=>e(e=>({files:[...e.files,...t]}),!1,`addFiles`),toggleImageUploadAsFile:t=>e(e=>{let n=new Set(e.imagesMarkedUploadAsFile);return n.has(t)?n.delete(t):n.add(t),{imagesMarkedUploadAsFile:[...n]}},!1,`toggleImageUploadAsFile`),markImagesAsPasted:t=>e(e=>({pastedImageNames:[...new Set([...e.pastedImageNames,...t])]}),!1,`markImagesAsPasted`),removeImage:t=>e(e=>{let n=e.images[t],r=[...e.images];return r.splice(t,1),{images:r,imagesMarkedUploadAsFile:n?e.imagesMarkedUploadAsFile.filter(e=>e!==n.name):e.imagesMarkedUploadAsFile,pastedImageNames:n?e.pastedImageNames.filter(e=>e!==n.name):e.pastedImageNames}},!1,`removeImage`),removeFile:t=>e(e=>{let n=[...e.files];return n.splice(t,1),{files:n}},!1,`removeFile`),clearImages:()=>e({images:[]},!1,`clearImages`),clearFiles:()=>e({files:[]},!1,`clearFiles`),clearAllFiles:()=>e({images:[],files:[],imagesMarkedUploadAsFile:[],pastedImageNames:[],loadingFiles:[],loadingImages:[]},!1,`clearAllFiles`),addFileLoading:t=>e(e=>e.loadingFiles.includes(t)?e:{loadingFiles:[...e.loadingFiles,t]},!1,`addFileLoading`),removeFileLoading:t=>e(e=>({loadingFiles:e.loadingFiles.filter(e=>e!==t)}),!1,`removeFileLoading`),addImageLoading:t=>e(e=>e.loadingImages.includes(t)?e:{loadingImages:[...e.loadingImages,t]},!1,`addImageLoading`),removeImageLoading:t=>e(e=>({loadingImages:e.loadingImages.filter(e=>e!==t)}),!1,`removeImageLoading`),clearAllLoading:()=>e({loadingFiles:[],loadingImages:[]},!1,`clearAllLoading`),setMessageToSend:t=>e({messageToSend:{text:t,timestamp:Date.now()}},!1,`setMessageToSend`),setSubmittedMessage:t=>e({submittedMessage:t},!1,`setSubmittedMessage`),resetConversationState:()=>e({shouldHideSuggestions:!1,conversationMode:i(),subConversationTaskId:null,planContent:null},!1,`resetConversationState`),setHasRightPanelToggled:t=>e({hasRightPanelToggled:t},!1,`setHasRightPanelToggled`),setConversationMode:t=>{let i=r();i&&n.setConversationState(i,{conversationMode:t}),e({conversationMode:t},!1,`setConversationMode`)},setSubConversationTaskId:t=>e({subConversationTaskId:t},!1,`setSubConversationTaskId`),setPlanContent:t=>e({planContent:t},!1,`setPlanContent`)}),{name:`conversation-store`}));exports.useConversationStore=a;
1
+ require(`../_virtual/_rolldown/runtime.cjs`);const e=require(`../node_modules/zustand/esm/react.cjs`),t=require(`../node_modules/zustand/esm/middleware.cjs`),n=require(`../utils/conversation-local-storage.cjs`);var r=()=>{if(typeof window>`u`)return null;let e=window.location.pathname.match(/\/conversations\/([^/]+)/);return e?e[1]:null},i=()=>{if(typeof window>`u`)return`code`;let e=r();return e?n.getConversationState(e).conversationMode:`code`},a=e.create()(t.devtools(e=>({isRightPanelShown:!1,selectedTab:`files`,images:[],files:[],imagesMarkedUploadAsFile:[],pastedImageNames:[],loadingFiles:[],loadingImages:[],messageToSend:null,messageRestoreIfEmpty:null,shouldShownAgentLoading:!1,submittedMessage:null,shouldHideSuggestions:!1,hasRightPanelToggled:!1,planContent:null,conversationMode:i(),subConversationTaskId:null,setIsRightPanelShown:t=>e({isRightPanelShown:t},!1,`setIsRightPanelShown`),setSelectedTab:t=>e({selectedTab:t},!1,`setSelectedTab`),setShouldShownAgentLoading:t=>e({shouldShownAgentLoading:t},!1,`setShouldShownAgentLoading`),setShouldHideSuggestions:t=>e({shouldHideSuggestions:t},!1,`setShouldHideSuggestions`),addImages:t=>e(e=>({images:[...e.images,...t]}),!1,`addImages`),addFiles:t=>e(e=>({files:[...e.files,...t]}),!1,`addFiles`),toggleImageUploadAsFile:t=>e(e=>{let n=new Set(e.imagesMarkedUploadAsFile);return n.has(t)?n.delete(t):n.add(t),{imagesMarkedUploadAsFile:[...n]}},!1,`toggleImageUploadAsFile`),markImagesAsPasted:t=>e(e=>({pastedImageNames:[...new Set([...e.pastedImageNames,...t])]}),!1,`markImagesAsPasted`),removeImage:t=>e(e=>{let n=e.images[t],r=[...e.images];return r.splice(t,1),{images:r,imagesMarkedUploadAsFile:n?e.imagesMarkedUploadAsFile.filter(e=>e!==n.name):e.imagesMarkedUploadAsFile,pastedImageNames:n?e.pastedImageNames.filter(e=>e!==n.name):e.pastedImageNames}},!1,`removeImage`),removeFile:t=>e(e=>{let n=[...e.files];return n.splice(t,1),{files:n}},!1,`removeFile`),clearImages:()=>e({images:[]},!1,`clearImages`),clearFiles:()=>e({files:[]},!1,`clearFiles`),clearAllFiles:()=>e({images:[],files:[],imagesMarkedUploadAsFile:[],pastedImageNames:[],loadingFiles:[],loadingImages:[]},!1,`clearAllFiles`),addFileLoading:t=>e(e=>e.loadingFiles.includes(t)?e:{loadingFiles:[...e.loadingFiles,t]},!1,`addFileLoading`),removeFileLoading:t=>e(e=>({loadingFiles:e.loadingFiles.filter(e=>e!==t)}),!1,`removeFileLoading`),addImageLoading:t=>e(e=>e.loadingImages.includes(t)?e:{loadingImages:[...e.loadingImages,t]},!1,`addImageLoading`),removeImageLoading:t=>e(e=>({loadingImages:e.loadingImages.filter(e=>e!==t)}),!1,`removeImageLoading`),clearAllLoading:()=>e({loadingFiles:[],loadingImages:[]},!1,`clearAllLoading`),setMessageToSend:t=>e({messageToSend:{text:t,timestamp:Date.now()}},!1,`setMessageToSend`),restoreMessageToInputIfEmpty:t=>e({messageRestoreIfEmpty:{text:t,timestamp:Date.now()}},!1,`restoreMessageToInputIfEmpty`),clearMessageRestoreIfEmpty:()=>e({messageRestoreIfEmpty:null},!1,`clearMessageRestoreIfEmpty`),setSubmittedMessage:t=>e({submittedMessage:t},!1,`setSubmittedMessage`),resetConversationState:()=>e({shouldHideSuggestions:!1,conversationMode:i(),subConversationTaskId:null,planContent:null},!1,`resetConversationState`),setHasRightPanelToggled:t=>e({hasRightPanelToggled:t},!1,`setHasRightPanelToggled`),setConversationMode:t=>{let i=r();i&&n.setConversationState(i,{conversationMode:t}),e({conversationMode:t},!1,`setConversationMode`)},setSubConversationTaskId:t=>e({subConversationTaskId:t},!1,`setSubConversationTaskId`),setPlanContent:t=>e({planContent:t},!1,`setPlanContent`)}),{name:`conversation-store`}));exports.useConversationStore=a;
2
2
  //# sourceMappingURL=conversation-store.cjs.map