@openhands/agent-canvas 1.0.0-alpha.7 → 1.0.0-alpha.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 (691) hide show
  1. package/README.md +9 -18
  2. package/bin/agent-canvas.mjs +27 -1
  3. package/build/assets/{QueryClientProvider-DITRCGAK.js → QueryClientProvider-B7kl84Kj.js} +1 -1
  4. package/build/assets/{Trans-D43bd3yR.js → Trans-1j65oy9O.js} +1 -1
  5. package/build/assets/{acp-providers-SCPK1BIU.js → acp-providers-DauuOsW9.js} +1 -1
  6. package/build/assets/{acp-route-guard-IWlFmS6x.js → acp-route-guard-CQTmeJwM.js} +1 -1
  7. package/build/assets/{active-backend-context-CkP3ZEJs.js → active-backend-context-TVbjnvmP.js} +1 -1
  8. package/build/assets/add-backend-modal-KMmPQNZU.js +1 -0
  9. package/build/assets/{agent-server-client-options-8OJSXbm8.js → agent-server-client-options-DT2GP6VJ.js} +1 -1
  10. package/build/assets/{agent-server-compatibility-DvKtnXHw.js → agent-server-compatibility-2aOx5iWd.js} +1 -1
  11. package/build/assets/{agent-server-conversation-service.api-BdEre_71.js → agent-server-conversation-service.api-DSl9G5UR.js} +3 -3
  12. package/build/assets/{agent-settings-DdisD2Xx.js → agent-settings-B247S9G3.js} +2 -2
  13. package/build/assets/{alert-banner-CvTYN73l.js → alert-banner-BWoqueRw.js} +1 -1
  14. package/build/assets/{analytics-consent-form-modal-BKgT9i2w.js → analytics-consent-form-modal-C7sXfxRh.js} +1 -1
  15. package/build/assets/{app-settings-DcYXtxGP.js → app-settings-BVeSaty9.js} +1 -1
  16. package/build/assets/{automation-detail-D7GEU0vR.js → automation-detail-g5-RZ0da.js} +1 -1
  17. package/build/assets/{automations-list-CkVNsgzm.js → automations-list-DHoq_0MM.js} +1 -1
  18. package/build/assets/{backend-form-modal-KudhWUX8.js → backend-form-modal-K6IMCr3p.js} +1 -1
  19. package/build/assets/{backend-synced-settings-badge-BFy2HylT.js → backend-synced-settings-badge-nAfiUWvM.js} +1 -1
  20. package/build/assets/{base-modal-B4HvlFHE.js → base-modal-CQRvRHu1.js} +1 -1
  21. package/build/assets/{brand-button-8fVVei4i.js → brand-button-C2nEKopC.js} +1 -1
  22. package/build/assets/{browser-vYpdU3CR.js → browser-DKG63inJ.js} +1 -1
  23. package/build/assets/{browser-tab-DTM6RyoV.js → browser-tab-B_BuTvrO.js} +1 -1
  24. package/build/assets/{checkmark-BcvXE9bf.js → checkmark-BJJrZUF8.js} +1 -1
  25. package/build/assets/{chevron-left-small-BqSkXTeq.js → chevron-left-small-CSh-sE9L.js} +1 -1
  26. package/build/assets/{circle-plus-check-toggle-DRvuu-RD.js → circle-plus-check-toggle-qs8Va1cC.js} +1 -1
  27. package/build/assets/{clock-DfoVUZVq.js → clock-ZR4Kn-_Y.js} +1 -1
  28. package/build/assets/{close-SnIy2eLD.js → close-BdmyeRqS.js} +1 -1
  29. package/build/assets/{combobox-caret-BMsz5mQX.js → combobox-caret-B53O9Hsq.js} +1 -1
  30. package/build/assets/{condenser-settings-DduLQcpV.js → condenser-settings-A35V3yng.js} +1 -1
  31. package/build/assets/{confirmation-modal-B-DOYMUH.js → confirmation-modal-C9-La0h3.js} +1 -1
  32. package/build/assets/{context-menu-list-item-DzjPB8aC.js → context-menu-list-item-Buu9nc0q.js} +1 -1
  33. package/build/assets/conversation-BD5WemJI.js +19 -0
  34. package/build/assets/conversation-C47K62n8.js +1 -0
  35. package/build/assets/conversation-panel-Dn-S56Gk.js +1 -0
  36. package/build/assets/{conversation-service.api-YTGTw0pz.js → conversation-service.api-C8pYCyV6.js} +1 -1
  37. package/build/assets/{conversation-tab-empty-state-BtFDbyTe.js → conversation-tab-empty-state-D8dNvo-V.js} +1 -1
  38. package/build/assets/{conversation-websocket-context-DulnrIHh.js → conversation-websocket-context-Ywrxd_9p.js} +1 -1
  39. package/build/assets/{copy-BxgbrjDT.js → copy-C7Ti2d8C.js} +1 -1
  40. package/build/assets/{custom-toast-handlers-BYxhSr3t.js → custom-toast-handlers-BOc3qeQ7.js} +1 -1
  41. package/build/assets/declaration-D378OjpZ.js +1 -0
  42. package/build/assets/{device-verify-CTbXX9CQ.js → device-verify-CMusn8nX.js} +1 -1
  43. package/build/assets/edit-automation-modal-Dnjxbjn7.js +1 -0
  44. package/build/assets/{ellipsis-button-BoU2-xlG.js → ellipsis-button-ugUATsNo.js} +1 -1
  45. package/build/assets/{entry.client-DU7-q4ZU.js → entry.client-D9uR9Blz.js} +2 -2
  46. package/build/assets/{enum-filter-dropdown-BJt-NplD.js → enum-filter-dropdown-1vpOGySB.js} +1 -1
  47. package/build/assets/{environment-switch-overlay-DQ1n6Iu6.js → environment-switch-overlay-CTCTQikP.js} +1 -1
  48. package/build/assets/{extensions-hub-BW1FAKFJ.js → extensions-hub-BSUseHVF.js} +1 -1
  49. package/build/assets/{extensions-navigation-CbPMhSML.js → extensions-navigation-CT1kc1u_.js} +1 -1
  50. package/build/assets/{files-tab-CbJ4s7Ik.js → files-tab-B3A1NDlZ.js} +1 -1
  51. package/build/assets/{folder-CerIk8uG.js → folder-0WSMImNX.js} +1 -1
  52. package/build/assets/git-control-bar-branch-button-CcIpmyfM.js +27 -0
  53. package/build/assets/{git-provider-icon-D8RE4unY.js → git-provider-icon-DYE9n7fs.js} +1 -1
  54. package/build/assets/{home-DR11ejqB.js → home-dIzxi5Dd.js} +1 -1
  55. package/build/assets/{i18n-DkYgs32x.js → i18n-DjAGhTis.js} +1 -1
  56. package/build/assets/install-server-modal-z5VaHeXd.js +1 -0
  57. package/build/assets/{launch-DKCU9uJH.js → launch-hZ0ifhcV.js} +1 -1
  58. package/build/assets/{lesson-plan-CmkRbe6Z.js → lesson-plan-DRYG5SLI.js} +1 -1
  59. package/build/assets/{link-external-CvxB0BmI.js → link-external-Df8J52xI.js} +1 -1
  60. package/build/assets/{llm-client-BpIfxETv.js → llm-client-ChQzg4wX.js} +1 -1
  61. package/build/assets/llm-settings-2036m7Wt.js +1 -0
  62. package/build/assets/{llm-settings-BOJC4vD-.js → llm-settings-CcHqGOYL.js} +1 -1
  63. package/build/assets/{loading-spinner-91b5FiMQ.js → loading-spinner-C04FGh14.js} +1 -1
  64. package/build/assets/{manage-backends-modal-DqpzcxdI.js → manage-backends-modal-rYeyGx7j.js} +1 -1
  65. package/build/assets/{manage-workspaces-modal-eG6XgAvw.js → manage-workspaces-modal-C5EuW8m1.js} +1 -1
  66. package/build/assets/manifest-97e839da.js +1 -0
  67. package/build/assets/{markdown-renderer-wZnLDbA1.js → markdown-renderer-CEX4Becj.js} +1 -1
  68. package/build/assets/mcp-C06YssEI.js +9 -0
  69. package/build/assets/messages-T2ewVkbp.js +36 -0
  70. package/build/assets/{modal-backdrop-B04pVYAD.js → modal-backdrop-DTYGVmOR.js} +1 -1
  71. package/build/assets/{modal-body-CgUoFQA1.js → modal-body-YElmM1dV.js} +1 -1
  72. package/build/assets/{modal-close-button-SM_WXzDY.js → modal-close-button-C_GpQt9F.js} +1 -1
  73. package/build/assets/{model-selector-7id-Uirf.js → model-selector-DeMmw-Xa.js} +1 -1
  74. package/build/assets/{navigation-context-BFjstyH6.js → navigation-context-DeIPtGPp.js} +1 -1
  75. package/build/assets/{navigation-link-DFQ7YcWq.js → navigation-link-C9JD4PYD.js} +1 -1
  76. package/build/assets/{openhands-logo-DkDp75rC.js → openhands-logo-CI5Fhn1W.js} +1 -1
  77. package/build/assets/{option-service.api-DN0ZcGjw.js → option-service.api-DsI1UW7N.js} +1 -1
  78. package/build/assets/{organization-service.api-Ct2dZF8M.js → organization-service.api-COwMPFg5.js} +1 -1
  79. package/build/assets/{path-utils-D1ZtqFC7.js → path-utils-CqJboYxo.js} +1 -1
  80. package/build/assets/{plan-components-gOm-daR3.js → plan-components-DEjMuDDG.js} +1 -1
  81. package/build/assets/{planner-tab-yubfN-6U.js → planner-tab-BrntFmb1.js} +1 -1
  82. package/build/assets/{profiles-client-D4twHRVf.js → profiles-client-BGkKEV9j.js} +1 -1
  83. package/build/assets/{providers-C2T07PM3.js → providers-DXvCAN_u.js} +1 -1
  84. package/build/assets/{proxy-BMZyC45G.js → proxy-CurRmrqf.js} +1 -1
  85. package/build/assets/{query-client-config-CiK0GJJO.js → query-client-config-Ba7qAAoO.js} +1 -1
  86. package/build/assets/recommended-automations-launcher-BI9NhG8Y.js +52 -0
  87. package/build/assets/root-BS1Td78t.js +2 -0
  88. package/build/assets/root-DHeCXo9N.css +1 -0
  89. package/build/assets/{root-layout-B4QioBS6.js → root-layout-BLjAEgle.js} +2 -2
  90. package/build/assets/{sdk-section-page-03k88tIR.js → sdk-section-page-CJW0G04-.js} +1 -1
  91. package/build/assets/{sdk-settings-schema-BY8dOy3a.js → sdk-settings-schema-QBYH-ONX.js} +1 -1
  92. package/build/assets/{search-BCAF9EDS.js → search-Cq_cFrDt.js} +1 -1
  93. package/build/assets/{secrets-service-Z3qtRb_G.js → secrets-service-Bwd5DeUs.js} +1 -1
  94. package/build/assets/{secrets-settings-BnlByuMZ.js → secrets-settings-MLXqOtX2.js} +1 -1
  95. package/build/assets/{server-client-CG1zHqph.js → server-client-C3mC8Hl3.js} +1 -1
  96. package/build/assets/{settings-DyzGLF_d.js → settings-D7E2U5tK.js} +1 -1
  97. package/build/assets/{settings-client-CkXDJwIY.js → settings-client-CwjfwoiB.js} +1 -1
  98. package/build/assets/{settings-dropdown-input-CAQWQgx-.js → settings-dropdown-input-VwAXNrOb.js} +1 -1
  99. package/build/assets/{settings-gear-D4ZkEDGb.js → settings-gear-BJwWR1ej.js} +1 -1
  100. package/build/assets/{settings-index-KtTw49xL.js → settings-index-J-3BNR0W.js} +1 -1
  101. package/build/assets/{settings-input-BWCZt9g2.js → settings-input-DBywAnA7.js} +1 -1
  102. package/build/assets/{settings-list-classes-xMleGkTC.js → settings-list-classes-BOS092DR.js} +1 -1
  103. package/build/assets/{settings-modal-Cv2YWSUY.js → settings-modal-B8vgWDTe.js} +1 -1
  104. package/build/assets/{settings-section-header-context-1wfkgjZZ.js → settings-section-header-context-32x6WTyL.js} +1 -1
  105. package/build/assets/settings-service.api-FvJGK45W.js +1 -0
  106. package/build/assets/{settings-switch-CGap2LtG.js → settings-switch-DTKmHC8F.js} +1 -1
  107. package/build/assets/{settings-utils-BBozxqqi.js → settings-utils-BsvSU3OM.js} +1 -1
  108. package/build/assets/{shared-conversation-DQlzwdpo.js → shared-conversation-a0QV8o99.js} +1 -1
  109. package/build/assets/{sidebar-mobile-menu-toggle-DXplko7u.js → sidebar-mobile-menu-toggle-DTUNI1WQ.js} +1 -1
  110. package/build/assets/{sidebar-nav-link-B4h8naZ7.js → sidebar-nav-link-CnWoZcwc.js} +1 -1
  111. package/build/assets/{skill-card-pill-row-D0oTWx-a.js → skill-card-pill-row-tZ599jli.js} +1 -1
  112. package/build/assets/{skills-BN8atjgW.js → skills-ZyAO5dyK.js} +1 -1
  113. package/build/assets/{skills-plugins-BTnp7QcQ.js → skills-plugins-BSRz041I.js} +1 -1
  114. package/build/assets/{skills-settings-CbOQvzkR.js → skills-settings-DOnMn9q1.js} +2 -2
  115. package/build/assets/{status-DDL-ipIP.js → status-CsatcFbK.js} +1 -1
  116. package/build/assets/{styled-tooltip-Awq4HMw3.js → styled-tooltip-CS3mB_1X.js} +1 -1
  117. package/build/assets/{switch-skeleton-Bv21RGWd.js → switch-skeleton-C-CfhYYV.js} +1 -1
  118. package/build/assets/{task-list-tab-B45ktzHM.js → task-list-tab-Day9nhRT.js} +1 -1
  119. package/build/assets/{terminal-DGuR4559.js → terminal-LNa-iU5c.js} +1 -1
  120. package/build/assets/{terminal-D5pzR9Ru.js → terminal-ro4SNjUU.js} +1 -1
  121. package/build/assets/{toggle-switch-gj6T-wsU.js → toggle-switch-k-IZCDbt.js} +1 -1
  122. package/build/assets/{typography-BbaUAC4V.js → typography-vVUMoNUg.js} +1 -1
  123. package/build/assets/{u-check-circle-DHGiAi-w.js → u-check-circle-DplbarS5.js} +1 -1
  124. package/build/assets/{u-check-circle-half-BPcWtWwv.js → u-check-circle-half-yDuiSZHC.js} +1 -1
  125. package/build/assets/{u-circuit-B_nK9hOu.js → u-circuit-C9tYkpeK.js} +1 -1
  126. package/build/assets/{u-edit-BPFJBd34.js → u-edit-KAUlufD8.js} +1 -1
  127. package/build/assets/{use-active-conversation-Bu5J9iLy.js → use-active-conversation-D15D9GgR.js} +1 -1
  128. package/build/assets/{use-agent-settings-schema-BbtOsR7P.js → use-agent-settings-schema-Bvp5UzV8.js} +1 -1
  129. package/build/assets/{use-agent-state-DN9Nc5pP.js → use-agent-state-DE5dlEXJ.js} +1 -1
  130. package/build/assets/{use-cloud-current-user-id-B_rMUiu8.js → use-cloud-current-user-id-DWVar4st.js} +1 -1
  131. package/build/assets/{use-config-Bcz2JL2t.js → use-config-BSu_53GL.js} +1 -1
  132. package/build/assets/{use-conversation-id-BOaaZahn.js → use-conversation-id-DajhCn2A.js} +1 -1
  133. package/build/assets/{use-create-conversation-BWFA_FId.js → use-create-conversation-DW7AGgLA.js} +1 -1
  134. package/build/assets/{use-handle-plan-click-CgrCGmT1.js → use-handle-plan-click-DpgEQDAV.js} +1 -1
  135. package/build/assets/use-is-authed-hXC8vxgT.js +1 -0
  136. package/build/assets/{use-is-creating-conversation-DhoM7UAB.js → use-is-creating-conversation-DhDeeWfA.js} +1 -1
  137. package/build/assets/{use-launch-skill-in-chat-DOyQsXFO.js → use-launch-skill-in-chat-DVGPFrbI.js} +1 -1
  138. package/build/assets/{use-llm-profiles-CAIzHJDX.js → use-llm-profiles-D3-KXwQ0.js} +1 -1
  139. package/build/assets/use-runtime-is-ready-XFbT16BD.js +1 -0
  140. package/build/assets/{use-save-settings-5m3w89Ph.js → use-save-settings-CEEKSTWG.js} +1 -1
  141. package/build/assets/{use-settings-DzG0C3vO.js → use-settings-DQ7Oo1Hj.js} +1 -1
  142. package/build/assets/{use-settings-nav-items-BIsKeX52.js → use-settings-nav-items-YmrXrjn9.js} +2 -2
  143. package/build/assets/{use-skills-Cn-78xP1.js → use-skills-Xe0vjPMt.js} +1 -1
  144. package/build/assets/{use-unified-vscode-url-C5iI-Z5A.js → use-unified-vscode-url-BOsIOd-b.js} +1 -1
  145. package/build/assets/use-user-conversation-Mc0mQgkl.js +1 -0
  146. package/build/assets/{useMutation-CRJwk4cR.js → useMutation-B4OUESdw.js} +1 -1
  147. package/build/assets/{useTranslation-01pF7z10.js → useTranslation-CpIcQBq6.js} +1 -1
  148. package/build/assets/{utils-Czcl6buL.js → utils-D-HX7JCe.js} +1 -1
  149. package/build/assets/{vendor~conversation-panel~conversation-CbjvWBSu.js → vendor~conversation-panel~conversation-BlCIz9XQ.js} +1 -1
  150. package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-CofhIDpd.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-Ds9quNZ9.js} +1 -1
  151. package/build/assets/vendor~home~mcp~automations-list-C5PoHCy6.js +1 -0
  152. package/build/assets/{vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-BQPOygpY.js → vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-CGlZoBKa.js} +1 -1
  153. package/build/assets/{vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-CyYIBiBk.js → vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-DE11mPxp.js} +1 -1
  154. package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-CuGq_cxH.js → vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-8b8V5bfO.js} +1 -1
  155. package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-CFpDeb9o.js → vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-Dy7L6fMG.js} +1 -1
  156. package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~k776hupu-C1p8-pMr.js → vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~k776hupu-D40EXhZx.js} +1 -1
  157. package/build/assets/vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~dp08i1qy-CHrEOFl6.js +48 -0
  158. package/build/assets/{vendor~root~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-s~kyz9p27j-DlKA6SoO.js → vendor~root~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-s~kyz9p27j-CyUbhpbm.js} +1 -1
  159. package/build/assets/{verification-settings-DbziMp4K.js → verification-settings-BtlTiHP8.js} +1 -1
  160. package/build/assets/{vscode-tab-BVhQR2rt.js → vscode-tab-C0ShhiSU.js} +1 -1
  161. package/build/assets/{waiting-for-runtime-message-JotSOBdC.js → waiting-for-runtime-message-DWPl_Yby.js} +1 -1
  162. package/build/assets/{x-mark-CZ57VvRX.js → x-mark-CWI0f9yI.js} +1 -1
  163. package/build/favicon.svg +1 -0
  164. package/build/index.html +4 -4
  165. package/build/locales/ar/openhands.json +8 -0
  166. package/build/locales/ca/openhands.json +8 -0
  167. package/build/locales/de/openhands.json +8 -0
  168. package/build/locales/en/openhands.json +8 -0
  169. package/build/locales/es/openhands.json +8 -0
  170. package/build/locales/fr/openhands.json +8 -0
  171. package/build/locales/it/openhands.json +8 -0
  172. package/build/locales/ja/openhands.json +8 -0
  173. package/build/locales/ko-KR/openhands.json +8 -0
  174. package/build/locales/no/openhands.json +8 -0
  175. package/build/locales/pt/openhands.json +8 -0
  176. package/build/locales/tr/openhands.json +8 -0
  177. package/build/locales/uk/openhands.json +8 -0
  178. package/build/locales/zh-CN/openhands.json +8 -0
  179. package/build/locales/zh-TW/openhands.json +8 -0
  180. package/config/defaults.json +1 -1
  181. package/dist/api/agent-server-config.cjs +1 -1
  182. package/dist/api/agent-server-config.cjs.map +1 -1
  183. package/dist/api/agent-server-config.d.ts +1 -1
  184. package/dist/api/agent-server-config.js +1 -1
  185. package/dist/api/agent-server-config.js.map +1 -1
  186. package/dist/api/conversation-service/agent-server-conversation-service.api.cjs +1 -1
  187. package/dist/api/conversation-service/agent-server-conversation-service.api.cjs.map +1 -1
  188. package/dist/api/conversation-service/agent-server-conversation-service.api.d.ts +12 -0
  189. package/dist/api/conversation-service/agent-server-conversation-service.api.js +4 -0
  190. package/dist/api/conversation-service/agent-server-conversation-service.api.js.map +1 -1
  191. package/dist/api/mcp-service/mcp-service.api.cjs +2 -0
  192. package/dist/api/mcp-service/mcp-service.api.cjs.map +1 -0
  193. package/dist/api/mcp-service/mcp-service.api.d.ts +6 -0
  194. package/dist/api/mcp-service/mcp-service.api.js +36 -0
  195. package/dist/api/mcp-service/mcp-service.api.js.map +1 -0
  196. package/dist/api/settings-service/settings-service.api.cjs +1 -1
  197. package/dist/api/settings-service/settings-service.api.cjs.map +1 -1
  198. package/dist/api/settings-service/settings-service.api.d.ts +1 -0
  199. package/dist/api/settings-service/settings-service.api.js +59 -41
  200. package/dist/api/settings-service/settings-service.api.js.map +1 -1
  201. package/dist/components/features/automations/detail/activity-log-item.d.ts +1 -1
  202. package/dist/components/features/automations/recommended-automations-launcher.d.ts +1 -1
  203. package/dist/components/features/chat/change-agent-button.cjs +1 -1
  204. package/dist/components/features/chat/change-agent-button.cjs.map +1 -1
  205. package/dist/components/features/chat/change-agent-button.js +65 -59
  206. package/dist/components/features/chat/change-agent-button.js.map +1 -1
  207. package/dist/components/features/chat/chat-interface.cjs +2 -2
  208. package/dist/components/features/chat/chat-interface.cjs.map +1 -1
  209. package/dist/components/features/chat/chat-interface.js +15 -14
  210. package/dist/components/features/chat/chat-interface.js.map +1 -1
  211. package/dist/components/features/chat/components/chat-input-actions.cjs +1 -1
  212. package/dist/components/features/chat/components/chat-input-actions.cjs.map +1 -1
  213. package/dist/components/features/chat/components/chat-input-actions.js +127 -149
  214. package/dist/components/features/chat/components/chat-input-actions.js.map +1 -1
  215. package/dist/components/features/chat/components/chat-input-model.cjs +1 -1
  216. package/dist/components/features/chat/components/chat-input-model.cjs.map +1 -1
  217. package/dist/components/features/chat/components/chat-input-model.d.ts +10 -0
  218. package/dist/components/features/chat/components/chat-input-model.js +95 -60
  219. package/dist/components/features/chat/components/chat-input-model.js.map +1 -1
  220. package/dist/components/features/chat/git-control-bar.cjs +1 -1
  221. package/dist/components/features/chat/git-control-bar.cjs.map +1 -1
  222. package/dist/components/features/chat/git-control-bar.js +60 -59
  223. package/dist/components/features/chat/git-control-bar.js.map +1 -1
  224. package/dist/components/features/conversation/conversation-name-with-status.cjs +1 -1
  225. package/dist/components/features/conversation/conversation-name-with-status.cjs.map +1 -1
  226. package/dist/components/features/conversation/conversation-name-with-status.js +2 -2
  227. package/dist/components/features/conversation/conversation-name-with-status.js.map +1 -1
  228. package/dist/components/features/conversation/conversation-name.cjs +1 -1
  229. package/dist/components/features/conversation/conversation-name.cjs.map +1 -1
  230. package/dist/components/features/conversation/conversation-name.js +3 -3
  231. package/dist/components/features/conversation/conversation-name.js.map +1 -1
  232. package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.cjs +1 -1
  233. package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.cjs.map +1 -1
  234. package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.js +1 -1
  235. package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.js.map +1 -1
  236. package/dist/components/features/conversation/conversation-tabs/conversation-tabs.cjs +1 -1
  237. package/dist/components/features/conversation/conversation-tabs/conversation-tabs.cjs.map +1 -1
  238. package/dist/components/features/conversation/conversation-tabs/conversation-tabs.js +16 -16
  239. package/dist/components/features/conversation/conversation-tabs/conversation-tabs.js.map +1 -1
  240. package/dist/components/features/mcp-logo-badge.cjs +1 -1
  241. package/dist/components/features/mcp-logo-badge.cjs.map +1 -1
  242. package/dist/components/features/mcp-logo-badge.d.ts +2 -2
  243. package/dist/components/features/mcp-logo-badge.js +1 -1
  244. package/dist/components/features/mcp-logo-badge.js.map +1 -1
  245. package/dist/components/features/mcp-page/custom-server-editor.cjs +1 -1
  246. package/dist/components/features/mcp-page/custom-server-editor.cjs.map +1 -1
  247. package/dist/components/features/mcp-page/custom-server-editor.js +64 -41
  248. package/dist/components/features/mcp-page/custom-server-editor.js.map +1 -1
  249. package/dist/components/features/mcp-page/install-server-modal.cjs +1 -1
  250. package/dist/components/features/mcp-page/install-server-modal.cjs.map +1 -1
  251. package/dist/components/features/mcp-page/install-server-modal.d.ts +1 -1
  252. package/dist/components/features/mcp-page/install-server-modal.js +126 -102
  253. package/dist/components/features/mcp-page/install-server-modal.js.map +1 -1
  254. package/dist/components/features/mcp-page/installed-server-card.cjs +1 -1
  255. package/dist/components/features/mcp-page/installed-server-card.cjs.map +1 -1
  256. package/dist/components/features/mcp-page/installed-server-card.js +1 -1
  257. package/dist/components/features/mcp-page/installed-server-card.js.map +1 -1
  258. package/dist/components/features/mcp-page/marketplace-card.cjs +1 -1
  259. package/dist/components/features/mcp-page/marketplace-card.cjs.map +1 -1
  260. package/dist/components/features/mcp-page/marketplace-card.d.ts +1 -1
  261. package/dist/components/features/mcp-page/marketplace-card.js +27 -25
  262. package/dist/components/features/mcp-page/marketplace-card.js.map +1 -1
  263. package/dist/components/features/mcp-page/marketplace-section.cjs +1 -1
  264. package/dist/components/features/mcp-page/marketplace-section.cjs.map +1 -1
  265. package/dist/components/features/mcp-page/marketplace-section.d.ts +1 -1
  266. package/dist/components/features/mcp-page/marketplace-section.js +1 -1
  267. package/dist/components/features/mcp-page/marketplace-section.js.map +1 -1
  268. package/dist/components/features/mcp-page/mcp-logo-stack-badge.d.ts +2 -2
  269. package/dist/components/features/settings/mcp-settings/mcp-server-form.cjs +7 -7
  270. package/dist/components/features/settings/mcp-settings/mcp-server-form.cjs.map +1 -1
  271. package/dist/components/features/settings/mcp-settings/mcp-server-form.d.ts +8 -12
  272. package/dist/components/features/settings/mcp-settings/mcp-server-form.js +114 -87
  273. package/dist/components/features/settings/mcp-settings/mcp-server-form.js.map +1 -1
  274. package/dist/context/scroll-context.cjs +1 -1
  275. package/dist/context/scroll-context.cjs.map +1 -1
  276. package/dist/context/scroll-context.d.ts +1 -0
  277. package/dist/context/scroll-context.js +4 -1
  278. package/dist/context/scroll-context.js.map +1 -1
  279. package/dist/favicon.svg +1 -0
  280. package/dist/hooks/mutation/use-switch-acp-model.cjs +2 -0
  281. package/dist/hooks/mutation/use-switch-acp-model.cjs.map +1 -0
  282. package/dist/hooks/mutation/use-switch-acp-model.d.ts +23 -0
  283. package/dist/hooks/mutation/use-switch-acp-model.js +26 -0
  284. package/dist/hooks/mutation/use-switch-acp-model.js.map +1 -0
  285. package/dist/hooks/mutation/use-test-mcp-server.cjs +2 -0
  286. package/dist/hooks/mutation/use-test-mcp-server.cjs.map +1 -0
  287. package/dist/hooks/mutation/use-test-mcp-server.d.ts +2 -0
  288. package/dist/hooks/mutation/use-test-mcp-server.js +10 -0
  289. package/dist/hooks/mutation/use-test-mcp-server.js.map +1 -0
  290. package/dist/hooks/query/use-automation-detail.d.ts +3 -2
  291. package/dist/hooks/use-acp-model-context.cjs.map +1 -1
  292. package/dist/hooks/use-acp-model-context.d.ts +3 -4
  293. package/dist/hooks/use-acp-model-context.js.map +1 -1
  294. package/dist/hooks/use-chat-input-model-state.cjs +2 -0
  295. package/dist/hooks/use-chat-input-model-state.cjs.map +1 -0
  296. package/dist/hooks/use-chat-input-model-state.d.ts +12 -0
  297. package/dist/hooks/use-chat-input-model-state.js +29 -0
  298. package/dist/hooks/use-chat-input-model-state.js.map +1 -0
  299. package/dist/i18n/declaration.cjs +1 -1
  300. package/dist/i18n/declaration.cjs.map +1 -1
  301. package/dist/i18n/declaration.d.ts +8 -0
  302. package/dist/i18n/declaration.js +1 -1
  303. package/dist/i18n/declaration.js.map +1 -1
  304. package/dist/i18n/translation.cjs +2 -2
  305. package/dist/i18n/translation.cjs.map +1 -1
  306. package/dist/i18n/translation.js +136 -0
  307. package/dist/i18n/translation.js.map +1 -1
  308. package/dist/locales/ar/openhands.json +8 -0
  309. package/dist/locales/ca/openhands.json +8 -0
  310. package/dist/locales/de/openhands.json +8 -0
  311. package/dist/locales/en/openhands.json +8 -0
  312. package/dist/locales/es/openhands.json +8 -0
  313. package/dist/locales/fr/openhands.json +8 -0
  314. package/dist/locales/it/openhands.json +8 -0
  315. package/dist/locales/ja/openhands.json +8 -0
  316. package/dist/locales/ko-KR/openhands.json +8 -0
  317. package/dist/locales/no/openhands.json +8 -0
  318. package/dist/locales/pt/openhands.json +8 -0
  319. package/dist/locales/tr/openhands.json +8 -0
  320. package/dist/locales/uk/openhands.json +8 -0
  321. package/dist/locales/zh-CN/openhands.json +8 -0
  322. package/dist/locales/zh-TW/openhands.json +8 -0
  323. package/dist/node_modules/@openhands/extensions/integrations/catalog/airtable.cjs +2 -0
  324. package/dist/node_modules/@openhands/extensions/integrations/catalog/airtable.cjs.map +1 -0
  325. package/dist/node_modules/@openhands/extensions/integrations/catalog/airtable.js +37 -0
  326. package/dist/node_modules/@openhands/extensions/integrations/catalog/airtable.js.map +1 -0
  327. package/dist/node_modules/@openhands/extensions/integrations/catalog/apify.cjs +2 -0
  328. package/dist/node_modules/@openhands/extensions/integrations/catalog/apify.cjs.map +1 -0
  329. package/dist/node_modules/@openhands/extensions/integrations/catalog/apify.js +36 -0
  330. package/dist/node_modules/@openhands/extensions/integrations/catalog/apify.js.map +1 -0
  331. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/atlassian.cjs +1 -1
  332. package/dist/node_modules/@openhands/extensions/integrations/catalog/atlassian.cjs.map +1 -0
  333. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/atlassian.js +15 -5
  334. package/dist/node_modules/@openhands/extensions/integrations/catalog/atlassian.js.map +1 -0
  335. package/dist/node_modules/@openhands/extensions/integrations/catalog/brave-search.cjs +2 -0
  336. package/dist/node_modules/@openhands/extensions/integrations/catalog/brave-search.cjs.map +1 -0
  337. package/dist/node_modules/@openhands/extensions/integrations/catalog/brave-search.js +36 -0
  338. package/dist/node_modules/@openhands/extensions/integrations/catalog/brave-search.js.map +1 -0
  339. package/dist/node_modules/@openhands/extensions/integrations/catalog/browser-mcp.cjs +2 -0
  340. package/dist/node_modules/@openhands/extensions/integrations/catalog/browser-mcp.cjs.map +1 -0
  341. package/dist/node_modules/@openhands/extensions/integrations/catalog/browser-mcp.js +31 -0
  342. package/dist/node_modules/@openhands/extensions/integrations/catalog/browser-mcp.js.map +1 -0
  343. package/dist/node_modules/@openhands/extensions/integrations/catalog/clickhouse.cjs +2 -0
  344. package/dist/node_modules/@openhands/extensions/integrations/catalog/clickhouse.cjs.map +1 -0
  345. package/dist/node_modules/@openhands/extensions/integrations/catalog/clickhouse.js +52 -0
  346. package/dist/node_modules/@openhands/extensions/integrations/catalog/clickhouse.js.map +1 -0
  347. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/cloudflare-bindings.cjs +1 -1
  348. package/dist/node_modules/@openhands/extensions/integrations/catalog/cloudflare-bindings.cjs.map +1 -0
  349. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/cloudflare-bindings.js +15 -5
  350. package/dist/node_modules/@openhands/extensions/integrations/catalog/cloudflare-bindings.js.map +1 -0
  351. package/dist/node_modules/@openhands/extensions/integrations/catalog/cloudflare-browser-rendering.cjs +2 -0
  352. package/dist/node_modules/@openhands/extensions/integrations/catalog/cloudflare-browser-rendering.cjs.map +1 -0
  353. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/cloudflare-browser-rendering.js +15 -5
  354. package/dist/node_modules/@openhands/extensions/integrations/catalog/cloudflare-browser-rendering.js.map +1 -0
  355. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/cloudflare-builds.cjs +1 -1
  356. package/dist/node_modules/@openhands/extensions/integrations/catalog/cloudflare-builds.cjs.map +1 -0
  357. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/cloudflare-builds.js +15 -5
  358. package/dist/node_modules/@openhands/extensions/integrations/catalog/cloudflare-builds.js.map +1 -0
  359. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/cloudflare-docs.cjs +1 -1
  360. package/dist/node_modules/@openhands/extensions/integrations/catalog/cloudflare-docs.cjs.map +1 -0
  361. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/cloudflare-docs.js +15 -5
  362. package/dist/node_modules/@openhands/extensions/integrations/catalog/cloudflare-docs.js.map +1 -0
  363. package/dist/node_modules/@openhands/extensions/integrations/catalog/cloudflare-observability.cjs +2 -0
  364. package/dist/node_modules/@openhands/extensions/integrations/catalog/cloudflare-observability.cjs.map +1 -0
  365. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/cloudflare-observability.js +15 -5
  366. package/dist/node_modules/@openhands/extensions/integrations/catalog/cloudflare-observability.js.map +1 -0
  367. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/deepwiki.cjs +1 -1
  368. package/dist/node_modules/@openhands/extensions/integrations/catalog/deepwiki.cjs.map +1 -0
  369. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/deepwiki.js +15 -5
  370. package/dist/node_modules/@openhands/extensions/integrations/catalog/deepwiki.js.map +1 -0
  371. package/dist/node_modules/@openhands/extensions/integrations/catalog/elevenlabs.cjs +2 -0
  372. package/dist/node_modules/@openhands/extensions/integrations/catalog/elevenlabs.cjs.map +1 -0
  373. package/dist/node_modules/@openhands/extensions/integrations/catalog/elevenlabs.js +36 -0
  374. package/dist/node_modules/@openhands/extensions/integrations/catalog/elevenlabs.js.map +1 -0
  375. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/everything.cjs +1 -1
  376. package/dist/node_modules/@openhands/extensions/integrations/catalog/everything.cjs.map +1 -0
  377. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/everything.js +13 -6
  378. package/dist/node_modules/@openhands/extensions/integrations/catalog/everything.js.map +1 -0
  379. package/dist/node_modules/@openhands/extensions/integrations/catalog/exa.cjs +2 -0
  380. package/dist/node_modules/@openhands/extensions/integrations/catalog/exa.cjs.map +1 -0
  381. package/dist/node_modules/@openhands/extensions/integrations/catalog/exa.js +36 -0
  382. package/dist/node_modules/@openhands/extensions/integrations/catalog/exa.js.map +1 -0
  383. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/fetch.cjs +1 -1
  384. package/dist/node_modules/@openhands/extensions/integrations/catalog/fetch.cjs.map +1 -0
  385. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/fetch.js +13 -6
  386. package/dist/node_modules/@openhands/extensions/integrations/catalog/fetch.js.map +1 -0
  387. package/dist/node_modules/@openhands/extensions/integrations/catalog/figma.cjs +2 -0
  388. package/dist/node_modules/@openhands/extensions/integrations/catalog/figma.cjs.map +1 -0
  389. package/dist/node_modules/@openhands/extensions/integrations/catalog/figma.js +40 -0
  390. package/dist/node_modules/@openhands/extensions/integrations/catalog/figma.js.map +1 -0
  391. package/dist/node_modules/@openhands/extensions/integrations/catalog/filesystem.cjs +2 -0
  392. package/dist/node_modules/@openhands/extensions/integrations/catalog/filesystem.cjs.map +1 -0
  393. package/dist/node_modules/@openhands/extensions/integrations/catalog/filesystem.js +39 -0
  394. package/dist/node_modules/@openhands/extensions/integrations/catalog/filesystem.js.map +1 -0
  395. package/dist/node_modules/@openhands/extensions/integrations/catalog/firecrawl.cjs +2 -0
  396. package/dist/node_modules/@openhands/extensions/integrations/catalog/firecrawl.cjs.map +1 -0
  397. package/dist/node_modules/@openhands/extensions/integrations/catalog/firecrawl.js +36 -0
  398. package/dist/node_modules/@openhands/extensions/integrations/catalog/firecrawl.js.map +1 -0
  399. package/dist/node_modules/@openhands/extensions/integrations/catalog/git.cjs +2 -0
  400. package/dist/node_modules/@openhands/extensions/integrations/catalog/git.cjs.map +1 -0
  401. package/dist/node_modules/@openhands/extensions/integrations/catalog/git.js +40 -0
  402. package/dist/node_modules/@openhands/extensions/integrations/catalog/git.js.map +1 -0
  403. package/dist/node_modules/@openhands/extensions/integrations/catalog/github.cjs +2 -0
  404. package/dist/node_modules/@openhands/extensions/integrations/catalog/github.cjs.map +1 -0
  405. package/dist/node_modules/@openhands/extensions/integrations/catalog/github.js +47 -0
  406. package/dist/node_modules/@openhands/extensions/integrations/catalog/github.js.map +1 -0
  407. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/huggingface.cjs +1 -1
  408. package/dist/node_modules/@openhands/extensions/integrations/catalog/huggingface.cjs.map +1 -0
  409. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/huggingface.js +15 -5
  410. package/dist/node_modules/@openhands/extensions/integrations/catalog/huggingface.js.map +1 -0
  411. package/dist/node_modules/@openhands/extensions/integrations/catalog/kagi.cjs +2 -0
  412. package/dist/node_modules/@openhands/extensions/integrations/catalog/kagi.cjs.map +1 -0
  413. package/dist/node_modules/@openhands/extensions/integrations/catalog/kagi.js +36 -0
  414. package/dist/node_modules/@openhands/extensions/integrations/catalog/kagi.js.map +1 -0
  415. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/linear.cjs +1 -1
  416. package/dist/node_modules/@openhands/extensions/integrations/catalog/linear.cjs.map +1 -0
  417. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/linear.js +15 -5
  418. package/dist/node_modules/@openhands/extensions/integrations/catalog/linear.js.map +1 -0
  419. package/dist/node_modules/@openhands/extensions/integrations/catalog/memory.cjs +2 -0
  420. package/dist/node_modules/@openhands/extensions/integrations/catalog/memory.cjs.map +1 -0
  421. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/memory.js +13 -6
  422. package/dist/node_modules/@openhands/extensions/integrations/catalog/memory.js.map +1 -0
  423. package/dist/node_modules/@openhands/extensions/integrations/catalog/mongodb.cjs +2 -0
  424. package/dist/node_modules/@openhands/extensions/integrations/catalog/mongodb.cjs.map +1 -0
  425. package/dist/node_modules/@openhands/extensions/integrations/catalog/mongodb.js +36 -0
  426. package/dist/node_modules/@openhands/extensions/integrations/catalog/mongodb.js.map +1 -0
  427. package/dist/node_modules/@openhands/extensions/integrations/catalog/neon.cjs +2 -0
  428. package/dist/node_modules/@openhands/extensions/integrations/catalog/neon.cjs.map +1 -0
  429. package/dist/node_modules/@openhands/extensions/integrations/catalog/neon.js +40 -0
  430. package/dist/node_modules/@openhands/extensions/integrations/catalog/neon.js.map +1 -0
  431. package/dist/node_modules/@openhands/extensions/integrations/catalog/notion.cjs +2 -0
  432. package/dist/node_modules/@openhands/extensions/integrations/catalog/notion.cjs.map +1 -0
  433. package/dist/node_modules/@openhands/extensions/integrations/catalog/notion.js +39 -0
  434. package/dist/node_modules/@openhands/extensions/integrations/catalog/notion.js.map +1 -0
  435. package/dist/node_modules/@openhands/extensions/integrations/catalog/obsidian.cjs +2 -0
  436. package/dist/node_modules/@openhands/extensions/integrations/catalog/obsidian.cjs.map +1 -0
  437. package/dist/node_modules/@openhands/extensions/integrations/catalog/obsidian.js +38 -0
  438. package/dist/node_modules/@openhands/extensions/integrations/catalog/obsidian.js.map +1 -0
  439. package/dist/node_modules/@openhands/extensions/integrations/catalog/paypal.cjs +2 -0
  440. package/dist/node_modules/@openhands/extensions/integrations/catalog/paypal.cjs.map +1 -0
  441. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/paypal.js +15 -5
  442. package/dist/node_modules/@openhands/extensions/integrations/catalog/paypal.js.map +1 -0
  443. package/dist/node_modules/@openhands/extensions/integrations/catalog/playwright.cjs +2 -0
  444. package/dist/node_modules/@openhands/extensions/integrations/catalog/playwright.cjs.map +1 -0
  445. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/playwright.js +13 -6
  446. package/dist/node_modules/@openhands/extensions/integrations/catalog/playwright.js.map +1 -0
  447. package/dist/node_modules/@openhands/extensions/integrations/catalog/redis.cjs +2 -0
  448. package/dist/node_modules/@openhands/extensions/integrations/catalog/redis.cjs.map +1 -0
  449. package/dist/node_modules/@openhands/extensions/integrations/catalog/redis.js +43 -0
  450. package/dist/node_modules/@openhands/extensions/integrations/catalog/redis.js.map +1 -0
  451. package/dist/node_modules/@openhands/extensions/integrations/catalog/resend.cjs +2 -0
  452. package/dist/node_modules/@openhands/extensions/integrations/catalog/resend.cjs.map +1 -0
  453. package/dist/node_modules/@openhands/extensions/integrations/catalog/resend.js +41 -0
  454. package/dist/node_modules/@openhands/extensions/integrations/catalog/resend.js.map +1 -0
  455. package/dist/node_modules/@openhands/extensions/integrations/catalog/sentry.cjs +2 -0
  456. package/dist/node_modules/@openhands/extensions/integrations/catalog/sentry.cjs.map +1 -0
  457. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/sentry.js +15 -5
  458. package/dist/node_modules/@openhands/extensions/integrations/catalog/sentry.js.map +1 -0
  459. package/dist/node_modules/@openhands/extensions/integrations/catalog/sequential-thinking.cjs +2 -0
  460. package/dist/node_modules/@openhands/extensions/integrations/catalog/sequential-thinking.cjs.map +1 -0
  461. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/sequential-thinking.js +13 -6
  462. package/dist/node_modules/@openhands/extensions/integrations/catalog/sequential-thinking.js.map +1 -0
  463. package/dist/node_modules/@openhands/extensions/integrations/catalog/slack.cjs +2 -0
  464. package/dist/node_modules/@openhands/extensions/integrations/catalog/slack.cjs.map +1 -0
  465. package/dist/node_modules/@openhands/extensions/integrations/catalog/slack.js +45 -0
  466. package/dist/node_modules/@openhands/extensions/integrations/catalog/slack.js.map +1 -0
  467. package/dist/node_modules/@openhands/extensions/integrations/catalog/stripe.cjs +2 -0
  468. package/dist/node_modules/@openhands/extensions/integrations/catalog/stripe.cjs.map +1 -0
  469. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/stripe.js +15 -5
  470. package/dist/node_modules/@openhands/extensions/integrations/catalog/stripe.js.map +1 -0
  471. package/dist/node_modules/@openhands/extensions/integrations/catalog/supabase.cjs +2 -0
  472. package/dist/node_modules/@openhands/extensions/integrations/catalog/supabase.cjs.map +1 -0
  473. package/dist/node_modules/@openhands/extensions/integrations/catalog/supabase.js +37 -0
  474. package/dist/node_modules/@openhands/extensions/integrations/catalog/supabase.js.map +1 -0
  475. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/tavily.cjs +1 -1
  476. package/dist/node_modules/@openhands/extensions/integrations/catalog/tavily.cjs.map +1 -0
  477. package/dist/node_modules/@openhands/extensions/integrations/catalog/tavily.js +39 -0
  478. package/dist/node_modules/@openhands/extensions/integrations/catalog/tavily.js.map +1 -0
  479. package/dist/node_modules/@openhands/extensions/integrations/catalog/time.cjs +2 -0
  480. package/dist/node_modules/@openhands/extensions/integrations/catalog/time.cjs.map +1 -0
  481. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/catalog/time.js +13 -6
  482. package/dist/node_modules/@openhands/extensions/integrations/catalog/time.js.map +1 -0
  483. package/dist/node_modules/@openhands/extensions/integrations/index.cjs +2 -0
  484. package/dist/node_modules/@openhands/extensions/integrations/index.cjs.map +1 -0
  485. package/dist/node_modules/@openhands/extensions/integrations/index.js +175 -0
  486. package/dist/node_modules/@openhands/extensions/integrations/index.js.map +1 -0
  487. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/logos.cjs +1 -1
  488. package/dist/node_modules/@openhands/extensions/integrations/logos.cjs.map +1 -0
  489. package/dist/node_modules/@openhands/extensions/{mcps → integrations}/logos.js +2 -2
  490. package/dist/node_modules/@openhands/extensions/integrations/logos.js.map +1 -0
  491. package/dist/node_modules/@openhands/extensions/integrations/oauth-provider-catalog.cjs +2 -0
  492. package/dist/node_modules/@openhands/extensions/integrations/oauth-provider-catalog.cjs.map +1 -0
  493. package/dist/node_modules/@openhands/extensions/integrations/oauth-provider-catalog.js +548 -0
  494. package/dist/node_modules/@openhands/extensions/integrations/oauth-provider-catalog.js.map +1 -0
  495. package/dist/node_modules/@openhands/extensions/integrations/oauth-provider-registration-defaults.cjs +2 -0
  496. package/dist/node_modules/@openhands/extensions/integrations/oauth-provider-registration-defaults.cjs.map +1 -0
  497. package/dist/node_modules/@openhands/extensions/integrations/oauth-provider-registration-defaults.js +482 -0
  498. package/dist/node_modules/@openhands/extensions/integrations/oauth-provider-registration-defaults.js.map +1 -0
  499. package/dist/node_modules/@openhands/typescript-client/dist/client/conversation-client.cjs +1 -1
  500. package/dist/node_modules/@openhands/typescript-client/dist/client/conversation-client.cjs.map +1 -1
  501. package/dist/node_modules/@openhands/typescript-client/dist/client/conversation-client.js +3 -0
  502. package/dist/node_modules/@openhands/typescript-client/dist/client/conversation-client.js.map +1 -1
  503. package/dist/node_modules/@openhands/typescript-client/dist/client/mcp-client.cjs +2 -0
  504. package/dist/node_modules/@openhands/typescript-client/dist/client/mcp-client.cjs.map +1 -0
  505. package/dist/node_modules/@openhands/typescript-client/dist/client/mcp-client.js +22 -0
  506. package/dist/node_modules/@openhands/typescript-client/dist/client/mcp-client.js.map +1 -0
  507. package/dist/node_modules/@openhands/typescript-client/dist/index.cjs +1 -1
  508. package/dist/node_modules/@openhands/typescript-client/dist/index.js +1 -0
  509. package/dist/node_modules/@openhands/typescript-client/dist/models/acp-providers.cjs +1 -1
  510. package/dist/node_modules/@openhands/typescript-client/dist/models/acp-providers.cjs.map +1 -1
  511. package/dist/node_modules/@openhands/typescript-client/dist/models/acp-providers.js +3 -0
  512. package/dist/node_modules/@openhands/typescript-client/dist/models/acp-providers.js.map +1 -1
  513. package/dist/package.cjs +1 -1
  514. package/dist/package.cjs.map +1 -1
  515. package/dist/package.js +6 -4
  516. package/dist/package.js.map +1 -1
  517. package/dist/routes/mcp.cjs +1 -1
  518. package/dist/routes/mcp.cjs.map +1 -1
  519. package/dist/routes/mcp.js +1 -1
  520. package/dist/routes/mcp.js.map +1 -1
  521. package/dist/utils/mcp-marketplace-utils.cjs +1 -1
  522. package/dist/utils/mcp-marketplace-utils.cjs.map +1 -1
  523. package/dist/utils/mcp-marketplace-utils.d.ts +21 -1
  524. package/dist/utils/mcp-marketplace-utils.js +23 -13
  525. package/dist/utils/mcp-marketplace-utils.js.map +1 -1
  526. package/dist/utils/settings-utils.cjs.map +1 -1
  527. package/dist/utils/settings-utils.js.map +1 -1
  528. package/package.json +6 -4
  529. package/scripts/check-sdk-version-sync.mjs +6 -6
  530. package/scripts/dev-safe.mjs +25 -7
  531. package/scripts/dev-with-automation.mjs +6 -1
  532. package/tools/canvas_ui_tool.py +129 -0
  533. package/build/assets/add-backend-modal-CqjNjGqY.js +0 -1
  534. package/build/assets/conversation-COZAKz_K.js +0 -1
  535. package/build/assets/conversation-DWcvnmds.js +0 -19
  536. package/build/assets/conversation-panel-CZDStT0b.js +0 -1
  537. package/build/assets/declaration-C9nuq2Dj.js +0 -1
  538. package/build/assets/edit-automation-modal-C3bFxS2f.js +0 -1
  539. package/build/assets/git-control-bar-branch-button-Bm6rzSpo.js +0 -27
  540. package/build/assets/install-server-modal-VB5hOBpW.js +0 -1
  541. package/build/assets/llm-settings-CIdxmimN.js +0 -1
  542. package/build/assets/manifest-f041e61a.js +0 -1
  543. package/build/assets/mcp-BdfyCW1l.js +0 -9
  544. package/build/assets/messages-v-q35ObG.js +0 -36
  545. package/build/assets/recommended-automations-launcher-Cx7svuGE.js +0 -52
  546. package/build/assets/root-D2PVd51i.js +0 -2
  547. package/build/assets/root-DEotKI6b.css +0 -1
  548. package/build/assets/settings-service.api-Z6x0l0GU.js +0 -1
  549. package/build/assets/use-is-authed-BFoh8Ogh.js +0 -1
  550. package/build/assets/use-runtime-is-ready-BQWLEyqa.js +0 -1
  551. package/build/assets/use-user-conversation-BCYpbPT1.js +0 -1
  552. package/build/assets/vendor~home~mcp~automations-list-DRfWZRnF.js +0 -1
  553. package/build/assets/vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~dp08i1qy-BJm2mGIp.js +0 -48
  554. package/dist/node_modules/@openhands/extensions/mcps/catalog/airtable.cjs +0 -2
  555. package/dist/node_modules/@openhands/extensions/mcps/catalog/airtable.cjs.map +0 -1
  556. package/dist/node_modules/@openhands/extensions/mcps/catalog/airtable.js +0 -30
  557. package/dist/node_modules/@openhands/extensions/mcps/catalog/airtable.js.map +0 -1
  558. package/dist/node_modules/@openhands/extensions/mcps/catalog/apify.cjs +0 -2
  559. package/dist/node_modules/@openhands/extensions/mcps/catalog/apify.cjs.map +0 -1
  560. package/dist/node_modules/@openhands/extensions/mcps/catalog/apify.js +0 -29
  561. package/dist/node_modules/@openhands/extensions/mcps/catalog/apify.js.map +0 -1
  562. package/dist/node_modules/@openhands/extensions/mcps/catalog/atlassian.cjs.map +0 -1
  563. package/dist/node_modules/@openhands/extensions/mcps/catalog/atlassian.js.map +0 -1
  564. package/dist/node_modules/@openhands/extensions/mcps/catalog/brave-search.cjs +0 -2
  565. package/dist/node_modules/@openhands/extensions/mcps/catalog/brave-search.cjs.map +0 -1
  566. package/dist/node_modules/@openhands/extensions/mcps/catalog/brave-search.js +0 -29
  567. package/dist/node_modules/@openhands/extensions/mcps/catalog/brave-search.js.map +0 -1
  568. package/dist/node_modules/@openhands/extensions/mcps/catalog/browser-mcp.cjs +0 -2
  569. package/dist/node_modules/@openhands/extensions/mcps/catalog/browser-mcp.cjs.map +0 -1
  570. package/dist/node_modules/@openhands/extensions/mcps/catalog/browser-mcp.js +0 -24
  571. package/dist/node_modules/@openhands/extensions/mcps/catalog/browser-mcp.js.map +0 -1
  572. package/dist/node_modules/@openhands/extensions/mcps/catalog/clickhouse.cjs +0 -2
  573. package/dist/node_modules/@openhands/extensions/mcps/catalog/clickhouse.cjs.map +0 -1
  574. package/dist/node_modules/@openhands/extensions/mcps/catalog/clickhouse.js +0 -45
  575. package/dist/node_modules/@openhands/extensions/mcps/catalog/clickhouse.js.map +0 -1
  576. package/dist/node_modules/@openhands/extensions/mcps/catalog/cloudflare-bindings.cjs.map +0 -1
  577. package/dist/node_modules/@openhands/extensions/mcps/catalog/cloudflare-bindings.js.map +0 -1
  578. package/dist/node_modules/@openhands/extensions/mcps/catalog/cloudflare-browser-rendering.cjs +0 -2
  579. package/dist/node_modules/@openhands/extensions/mcps/catalog/cloudflare-browser-rendering.cjs.map +0 -1
  580. package/dist/node_modules/@openhands/extensions/mcps/catalog/cloudflare-browser-rendering.js.map +0 -1
  581. package/dist/node_modules/@openhands/extensions/mcps/catalog/cloudflare-builds.cjs.map +0 -1
  582. package/dist/node_modules/@openhands/extensions/mcps/catalog/cloudflare-builds.js.map +0 -1
  583. package/dist/node_modules/@openhands/extensions/mcps/catalog/cloudflare-docs.cjs.map +0 -1
  584. package/dist/node_modules/@openhands/extensions/mcps/catalog/cloudflare-docs.js.map +0 -1
  585. package/dist/node_modules/@openhands/extensions/mcps/catalog/cloudflare-observability.cjs +0 -2
  586. package/dist/node_modules/@openhands/extensions/mcps/catalog/cloudflare-observability.cjs.map +0 -1
  587. package/dist/node_modules/@openhands/extensions/mcps/catalog/cloudflare-observability.js.map +0 -1
  588. package/dist/node_modules/@openhands/extensions/mcps/catalog/deepwiki.cjs.map +0 -1
  589. package/dist/node_modules/@openhands/extensions/mcps/catalog/deepwiki.js.map +0 -1
  590. package/dist/node_modules/@openhands/extensions/mcps/catalog/elevenlabs.cjs +0 -2
  591. package/dist/node_modules/@openhands/extensions/mcps/catalog/elevenlabs.cjs.map +0 -1
  592. package/dist/node_modules/@openhands/extensions/mcps/catalog/elevenlabs.js +0 -29
  593. package/dist/node_modules/@openhands/extensions/mcps/catalog/elevenlabs.js.map +0 -1
  594. package/dist/node_modules/@openhands/extensions/mcps/catalog/everything.cjs.map +0 -1
  595. package/dist/node_modules/@openhands/extensions/mcps/catalog/everything.js.map +0 -1
  596. package/dist/node_modules/@openhands/extensions/mcps/catalog/exa.cjs +0 -2
  597. package/dist/node_modules/@openhands/extensions/mcps/catalog/exa.cjs.map +0 -1
  598. package/dist/node_modules/@openhands/extensions/mcps/catalog/exa.js +0 -29
  599. package/dist/node_modules/@openhands/extensions/mcps/catalog/exa.js.map +0 -1
  600. package/dist/node_modules/@openhands/extensions/mcps/catalog/fetch.cjs.map +0 -1
  601. package/dist/node_modules/@openhands/extensions/mcps/catalog/fetch.js.map +0 -1
  602. package/dist/node_modules/@openhands/extensions/mcps/catalog/figma.cjs +0 -2
  603. package/dist/node_modules/@openhands/extensions/mcps/catalog/figma.cjs.map +0 -1
  604. package/dist/node_modules/@openhands/extensions/mcps/catalog/figma.js +0 -33
  605. package/dist/node_modules/@openhands/extensions/mcps/catalog/figma.js.map +0 -1
  606. package/dist/node_modules/@openhands/extensions/mcps/catalog/filesystem.cjs +0 -2
  607. package/dist/node_modules/@openhands/extensions/mcps/catalog/filesystem.cjs.map +0 -1
  608. package/dist/node_modules/@openhands/extensions/mcps/catalog/filesystem.js +0 -32
  609. package/dist/node_modules/@openhands/extensions/mcps/catalog/filesystem.js.map +0 -1
  610. package/dist/node_modules/@openhands/extensions/mcps/catalog/firecrawl.cjs +0 -2
  611. package/dist/node_modules/@openhands/extensions/mcps/catalog/firecrawl.cjs.map +0 -1
  612. package/dist/node_modules/@openhands/extensions/mcps/catalog/firecrawl.js +0 -29
  613. package/dist/node_modules/@openhands/extensions/mcps/catalog/firecrawl.js.map +0 -1
  614. package/dist/node_modules/@openhands/extensions/mcps/catalog/git.cjs +0 -2
  615. package/dist/node_modules/@openhands/extensions/mcps/catalog/git.cjs.map +0 -1
  616. package/dist/node_modules/@openhands/extensions/mcps/catalog/git.js +0 -33
  617. package/dist/node_modules/@openhands/extensions/mcps/catalog/git.js.map +0 -1
  618. package/dist/node_modules/@openhands/extensions/mcps/catalog/github.cjs +0 -2
  619. package/dist/node_modules/@openhands/extensions/mcps/catalog/github.cjs.map +0 -1
  620. package/dist/node_modules/@openhands/extensions/mcps/catalog/github.js +0 -40
  621. package/dist/node_modules/@openhands/extensions/mcps/catalog/github.js.map +0 -1
  622. package/dist/node_modules/@openhands/extensions/mcps/catalog/huggingface.cjs.map +0 -1
  623. package/dist/node_modules/@openhands/extensions/mcps/catalog/huggingface.js.map +0 -1
  624. package/dist/node_modules/@openhands/extensions/mcps/catalog/kagi.cjs +0 -2
  625. package/dist/node_modules/@openhands/extensions/mcps/catalog/kagi.cjs.map +0 -1
  626. package/dist/node_modules/@openhands/extensions/mcps/catalog/kagi.js +0 -29
  627. package/dist/node_modules/@openhands/extensions/mcps/catalog/kagi.js.map +0 -1
  628. package/dist/node_modules/@openhands/extensions/mcps/catalog/linear.cjs.map +0 -1
  629. package/dist/node_modules/@openhands/extensions/mcps/catalog/linear.js.map +0 -1
  630. package/dist/node_modules/@openhands/extensions/mcps/catalog/memory.cjs +0 -2
  631. package/dist/node_modules/@openhands/extensions/mcps/catalog/memory.cjs.map +0 -1
  632. package/dist/node_modules/@openhands/extensions/mcps/catalog/memory.js.map +0 -1
  633. package/dist/node_modules/@openhands/extensions/mcps/catalog/mongodb.cjs +0 -2
  634. package/dist/node_modules/@openhands/extensions/mcps/catalog/mongodb.cjs.map +0 -1
  635. package/dist/node_modules/@openhands/extensions/mcps/catalog/mongodb.js +0 -29
  636. package/dist/node_modules/@openhands/extensions/mcps/catalog/mongodb.js.map +0 -1
  637. package/dist/node_modules/@openhands/extensions/mcps/catalog/neon.cjs +0 -2
  638. package/dist/node_modules/@openhands/extensions/mcps/catalog/neon.cjs.map +0 -1
  639. package/dist/node_modules/@openhands/extensions/mcps/catalog/neon.js +0 -33
  640. package/dist/node_modules/@openhands/extensions/mcps/catalog/neon.js.map +0 -1
  641. package/dist/node_modules/@openhands/extensions/mcps/catalog/notion.cjs +0 -2
  642. package/dist/node_modules/@openhands/extensions/mcps/catalog/notion.cjs.map +0 -1
  643. package/dist/node_modules/@openhands/extensions/mcps/catalog/notion.js +0 -32
  644. package/dist/node_modules/@openhands/extensions/mcps/catalog/notion.js.map +0 -1
  645. package/dist/node_modules/@openhands/extensions/mcps/catalog/obsidian.cjs +0 -2
  646. package/dist/node_modules/@openhands/extensions/mcps/catalog/obsidian.cjs.map +0 -1
  647. package/dist/node_modules/@openhands/extensions/mcps/catalog/obsidian.js +0 -31
  648. package/dist/node_modules/@openhands/extensions/mcps/catalog/obsidian.js.map +0 -1
  649. package/dist/node_modules/@openhands/extensions/mcps/catalog/paypal.cjs +0 -2
  650. package/dist/node_modules/@openhands/extensions/mcps/catalog/paypal.cjs.map +0 -1
  651. package/dist/node_modules/@openhands/extensions/mcps/catalog/paypal.js.map +0 -1
  652. package/dist/node_modules/@openhands/extensions/mcps/catalog/playwright.cjs +0 -2
  653. package/dist/node_modules/@openhands/extensions/mcps/catalog/playwright.cjs.map +0 -1
  654. package/dist/node_modules/@openhands/extensions/mcps/catalog/playwright.js.map +0 -1
  655. package/dist/node_modules/@openhands/extensions/mcps/catalog/redis.cjs +0 -2
  656. package/dist/node_modules/@openhands/extensions/mcps/catalog/redis.cjs.map +0 -1
  657. package/dist/node_modules/@openhands/extensions/mcps/catalog/redis.js +0 -36
  658. package/dist/node_modules/@openhands/extensions/mcps/catalog/redis.js.map +0 -1
  659. package/dist/node_modules/@openhands/extensions/mcps/catalog/resend.cjs +0 -2
  660. package/dist/node_modules/@openhands/extensions/mcps/catalog/resend.cjs.map +0 -1
  661. package/dist/node_modules/@openhands/extensions/mcps/catalog/resend.js +0 -34
  662. package/dist/node_modules/@openhands/extensions/mcps/catalog/resend.js.map +0 -1
  663. package/dist/node_modules/@openhands/extensions/mcps/catalog/sentry.cjs +0 -2
  664. package/dist/node_modules/@openhands/extensions/mcps/catalog/sentry.cjs.map +0 -1
  665. package/dist/node_modules/@openhands/extensions/mcps/catalog/sentry.js.map +0 -1
  666. package/dist/node_modules/@openhands/extensions/mcps/catalog/sequential-thinking.cjs +0 -2
  667. package/dist/node_modules/@openhands/extensions/mcps/catalog/sequential-thinking.cjs.map +0 -1
  668. package/dist/node_modules/@openhands/extensions/mcps/catalog/sequential-thinking.js.map +0 -1
  669. package/dist/node_modules/@openhands/extensions/mcps/catalog/slack.cjs +0 -2
  670. package/dist/node_modules/@openhands/extensions/mcps/catalog/slack.cjs.map +0 -1
  671. package/dist/node_modules/@openhands/extensions/mcps/catalog/slack.js +0 -38
  672. package/dist/node_modules/@openhands/extensions/mcps/catalog/slack.js.map +0 -1
  673. package/dist/node_modules/@openhands/extensions/mcps/catalog/stripe.cjs +0 -2
  674. package/dist/node_modules/@openhands/extensions/mcps/catalog/stripe.cjs.map +0 -1
  675. package/dist/node_modules/@openhands/extensions/mcps/catalog/stripe.js.map +0 -1
  676. package/dist/node_modules/@openhands/extensions/mcps/catalog/supabase.cjs +0 -2
  677. package/dist/node_modules/@openhands/extensions/mcps/catalog/supabase.cjs.map +0 -1
  678. package/dist/node_modules/@openhands/extensions/mcps/catalog/supabase.js +0 -30
  679. package/dist/node_modules/@openhands/extensions/mcps/catalog/supabase.js.map +0 -1
  680. package/dist/node_modules/@openhands/extensions/mcps/catalog/tavily.cjs.map +0 -1
  681. package/dist/node_modules/@openhands/extensions/mcps/catalog/tavily.js +0 -32
  682. package/dist/node_modules/@openhands/extensions/mcps/catalog/tavily.js.map +0 -1
  683. package/dist/node_modules/@openhands/extensions/mcps/catalog/time.cjs +0 -2
  684. package/dist/node_modules/@openhands/extensions/mcps/catalog/time.cjs.map +0 -1
  685. package/dist/node_modules/@openhands/extensions/mcps/catalog/time.js.map +0 -1
  686. package/dist/node_modules/@openhands/extensions/mcps/index.cjs +0 -2
  687. package/dist/node_modules/@openhands/extensions/mcps/index.cjs.map +0 -1
  688. package/dist/node_modules/@openhands/extensions/mcps/index.js +0 -87
  689. package/dist/node_modules/@openhands/extensions/mcps/index.js.map +0 -1
  690. package/dist/node_modules/@openhands/extensions/mcps/logos.cjs.map +0 -1
  691. package/dist/node_modules/@openhands/extensions/mcps/logos.js.map +0 -1
@@ -6,81 +6,76 @@ import { useOptionalConversationId as i } from "../../../../hooks/use-conversati
6
6
  import { useConversationStore as a } from "../../../../stores/conversation-store.js";
7
7
  import { useActiveBackend as o } from "../../../../contexts/active-backend-context.js";
8
8
  import { Cpu as s } from "../../../../node_modules/lucide-react/dist/esm/icons/cpu.js";
9
- import { labelForAcpModel as c } from "../../../../constants/acp-providers.js";
10
- import { useActiveConversation as ee } from "../../../../hooks/query/use-active-conversation.js";
11
- import { useAgentState as te } from "../../../../hooks/use-agent-state.js";
9
+ import { useAgentState as c } from "../../../../hooks/use-agent-state.js";
12
10
  import "../../../../utils/form-control-classes.js";
13
- import { useUnifiedWebSocketStatus as ne } from "../../../../hooks/use-unified-websocket-status.js";
14
- import re from "../../controls/agent-status.js";
15
- import l from "../../../../icons/lesson-plan.js";
16
- import { CodePillIcon as u } from "../../../../icons/code-pill.js";
17
- import { ContextMenu as d } from "../../../../ui/context-menu.js";
18
- import { ContextMenuListItem as f } from "../../context-menu/context-menu-list-item.js";
19
- import { useClickOutsideElement as ie } from "../../../../hooks/use-click-outside-element.js";
20
- import { useHandlePlanClick as ae } from "../../../../hooks/use-handle-plan-click.js";
21
- import { ChangeAgentButton as oe } from "../change-agent-button.js";
22
- import { useAcpModelContext as se } from "../../../../hooks/use-acp-model-context.js";
23
- import ce from "../../../../icons/settings-gear.js";
24
- import { NavigationLink as le } from "../../../shared/navigation-link.js";
25
- import { Divider as ue } from "../../../../ui/divider.js";
26
- import { ChatInputModel as de } from "./chat-input-model.js";
27
- import { SwitchProfileButton as fe } from "../switch-profile-button.js";
28
- import { useUnifiedPauseConversation as pe } from "../../../../hooks/mutation/use-unified-stop-conversation.js";
11
+ import { useUnifiedWebSocketStatus as ee } from "../../../../hooks/use-unified-websocket-status.js";
12
+ import te from "../../controls/agent-status.js";
13
+ import ne from "../../../../icons/lesson-plan.js";
14
+ import { CodePillIcon as l } from "../../../../icons/code-pill.js";
15
+ import { ContextMenu as u } from "../../../../ui/context-menu.js";
16
+ import { ContextMenuListItem as d } from "../../context-menu/context-menu-list-item.js";
17
+ import { useClickOutsideElement as re } from "../../../../hooks/use-click-outside-element.js";
18
+ import { useHandlePlanClick as f } from "../../../../hooks/use-handle-plan-click.js";
19
+ import { ChangeAgentButton as ie } from "../change-agent-button.js";
20
+ import { useChatInputModelState as ae } from "../../../../hooks/use-chat-input-model-state.js";
21
+ import { ChatInputModel as oe, ChatInputModelMenuContent as se } from "./chat-input-model.js";
22
+ import { SwitchProfileButton as ce } from "../switch-profile-button.js";
23
+ import { useUnifiedPauseConversation as le } from "../../../../hooks/mutation/use-unified-stop-conversation.js";
29
24
  import p from "../../../../icons/carret-right-fill.js";
30
25
  import { ToolsContextMenuIconText as m } from "../../controls/tools-context-menu-icon-text.js";
31
- import { ChatAddFileButton as me } from "../chat-add-file-button.js";
32
- import { ChatSendButton as he } from "../chat-send-button.js";
33
- import ge from "../../../../icons/three-dots-vertical.js";
34
- import { usePauseConversation as _e } from "../../../../hooks/mutation/use-pause-conversation.js";
35
- import { useResumeConversation as h } from "../../../../hooks/mutation/use-resume-conversation.js";
36
- import g from "react";
37
- import { jsx as _, jsxs as v } from "react/jsx-runtime";
38
- import ve from "react-dom";
26
+ import { ChatAddFileButton as ue } from "../chat-add-file-button.js";
27
+ import { ChatSendButton as de } from "../chat-send-button.js";
28
+ import fe from "../../../../icons/three-dots-vertical.js";
29
+ import { usePauseConversation as pe } from "../../../../hooks/mutation/use-pause-conversation.js";
30
+ import { useResumeConversation as me } from "../../../../hooks/mutation/use-resume-conversation.js";
31
+ import h from "react";
32
+ import { jsx as g, jsxs as _ } from "react/jsx-runtime";
33
+ import he from "react-dom";
39
34
  //#region src/components/features/chat/components/chat-input-actions.tsx
40
- function y({ disabled: y, canSubmit: ye = !0, onAddFileClick: be = () => {}, showButton: xe = !0, buttonClassName: Se = "", handleSubmit: Ce = () => {} }) {
41
- let { t: b } = e("openhands"), we = pe(), x = _e(), Te = h(), { conversationId: S } = i(), { data: C } = ee(), { backend: w } = o(), T = w.kind === "cloud", { isAcpContext: E, destinationPath: D, destinationLabel: O } = se(), Ee = E ? c(C?.acp_server, C?.llm_model) ?? C?.llm_model : C?.llm_model, k = T && !!S, De = ne(), { curAgentState: Oe } = te(), { conversationMode: ke, setConversationMode: Ae } = a(), { handlePlanClick: je, isCreatingConversation: Me } = ae(), A = g.useRef(null), j = g.useRef(null), M = g.useRef(null), N = g.useRef(null), P = g.useRef(null), F = g.useRef(null), [I, Ne] = g.useState(Infinity), [Pe, Fe] = g.useState(0), [Ie, Le] = g.useState(32), [L, Re] = g.useState(96), [R, ze] = g.useState(120), [z, B] = g.useState(!1), [V, H] = g.useState(null), [U, Be] = g.useState();
42
- g.useEffect(() => {
43
- let e = A.current, t = j.current, n = M.current, r = N.current, i = P.current;
44
- if (!e || !t || !n || !i || k && !r || typeof ResizeObserver > "u") return;
35
+ function v({ disabled: v, canSubmit: ge = !0, onAddFileClick: _e = () => {}, showButton: ve = !0, buttonClassName: ye = "", handleSubmit: be = () => {} }) {
36
+ let { t: y } = e("openhands"), xe = le(), b = pe(), Se = me(), { conversationId: x } = i(), { backend: Ce } = o(), S = Ce.kind === "cloud", C = ae(), w = S, T = ee(), { curAgentState: E } = c(), { conversationMode: D, setConversationMode: O } = a(), { handlePlanClick: k, isCreatingConversation: A } = f(), j = h.useRef(null), M = h.useRef(null), N = h.useRef(null), P = h.useRef(null), F = h.useRef(null), I = h.useRef(null), [L, we] = h.useState(Infinity), [Te, Ee] = h.useState(0), [De, Oe] = h.useState(32), [R, ke] = h.useState(96), [z, Ae] = h.useState(120), [B, V] = h.useState(!1), [H, U] = h.useState(null), [W, je] = h.useState();
37
+ h.useEffect(() => {
38
+ let e = j.current, t = M.current, n = N.current, r = P.current, i = F.current;
39
+ if (!e || !t || !n || !i || w && !r || typeof ResizeObserver > "u") return;
45
40
  let a = () => {
46
41
  let a = e.getBoundingClientRect().width, o = t.getBoundingClientRect().width, s = n.getBoundingClientRect().width, c = i.getBoundingClientRect().width;
47
- if (a > 0 && Ne(a), o > 0 && Fe(o), s > 0 && Le(s), c > 0 && ze(c), r) {
42
+ if (a > 0 && we(a), o > 0 && Ee(o), s > 0 && Oe(s), c > 0 && Ae(c), r) {
48
43
  let e = r.getBoundingClientRect().width;
49
- e > 0 && Re(e);
44
+ e > 0 && ke(e);
50
45
  }
51
46
  }, o = new ResizeObserver(() => {
52
47
  a();
53
48
  });
54
49
  return o.observe(e), o.observe(t), o.observe(n), o.observe(i), r && o.observe(r), a(), () => o.disconnect();
55
- }, [k]);
56
- let Ve = () => {
57
- S && x.mutate({ conversationId: S });
58
- }, He = () => {
59
- S && Te.mutate({ conversationId: S });
60
- }, Ue = we.isPending || x.isPending, W = g.useCallback((e) => {
50
+ }, [w]);
51
+ let Me = () => {
52
+ x && b.mutate({ conversationId: x });
53
+ }, Ne = () => {
54
+ x && Se.mutate({ conversationId: x });
55
+ }, Pe = xe.isPending || b.isPending, G = h.useCallback((e) => {
61
56
  let t = e, n = {
62
57
  showCodeInline: !1,
63
58
  showModelInline: !1
64
59
  };
65
- return k && t >= L && (n.showCodeInline = !0, t -= L + 12), t >= R && (n.showModelInline = !0), n;
60
+ return w && t >= R && (n.showCodeInline = !0, t -= R + 12), t >= z && (n.showModelInline = !0), n;
66
61
  }, [
67
- k,
68
- L,
69
- R
70
- ]), G = I - Pe - 8 - Ie - 12, K = W(G), q = (!k || K.showCodeInline) && K.showModelInline ? K : W(G - 28 - 12), J = k ? q.showCodeInline : !1, Y = q.showModelInline, X = I >= 360, Z = k && !J || !Y;
71
- g.useEffect(() => {
72
- Z || (B(!1), H(null));
62
+ w,
63
+ R,
64
+ z
65
+ ]), K = L - Te - 8 - De - 12, q = G(K), J = (!w || q.showCodeInline) && q.showModelInline ? q : G(K - 28 - 12), Y = w ? J.showCodeInline : !1, X = J.showModelInline, Fe = L >= 360, Z = w && !Y || !X;
66
+ h.useEffect(() => {
67
+ Z || (V(!1), U(null));
73
68
  }, [Z]);
74
- let We = ie(() => {
75
- B(!1), H(null);
76
- }), Q = Oe === n.RUNNING || Me || De !== "OPEN", $ = () => {
77
- H(null), B(!1);
69
+ let Ie = re(() => {
70
+ V(!1), U(null);
71
+ }), Q = E === n.RUNNING || A || T !== "OPEN", $ = () => {
72
+ U(null), V(!1);
78
73
  };
79
- g.useLayoutEffect(() => {
80
- if (!z || !F.current) return;
81
- let e = F.current, t = () => {
74
+ h.useLayoutEffect(() => {
75
+ if (!B || !I.current) return;
76
+ let e = I.current, t = () => {
82
77
  let t = e.getBoundingClientRect();
83
- Be({
78
+ je({
84
79
  position: "fixed",
85
80
  top: t.top - 8,
86
81
  left: t.left,
@@ -91,175 +86,158 @@ function y({ disabled: y, canSubmit: ye = !0, onAddFileClick: be = () => {}, sho
91
86
  return t(), window.addEventListener("resize", t), window.addEventListener("scroll", t, !0), () => {
92
87
  window.removeEventListener("resize", t), window.removeEventListener("scroll", t, !0);
93
88
  };
94
- }, [z]);
95
- let Ge = /* @__PURE__ */ v(d, {
96
- ref: We,
89
+ }, [B]);
90
+ let Le = /* @__PURE__ */ _(u, {
91
+ ref: Ie,
97
92
  testId: "chat-input-overflow-menu",
98
93
  position: "top",
99
94
  alignment: "left",
100
95
  className: "!static !top-auto !bottom-auto !left-auto !right-auto !mt-0 overflow-visible min-w-[200px]",
101
- children: [k && !J && /* @__PURE__ */ v("div", {
96
+ children: [w && !Y && /* @__PURE__ */ _("div", {
102
97
  className: "relative group/overflow-agent",
103
- children: [/* @__PURE__ */ _(f, {
98
+ children: [/* @__PURE__ */ g(d, {
104
99
  testId: "overflow-agent-button",
105
- onClick: () => H((e) => e === "agent" ? null : "agent"),
100
+ onClick: () => U((e) => e === "agent" ? null : "agent"),
106
101
  isDisabled: Q,
107
- children: /* @__PURE__ */ _(m, {
108
- icon: /* @__PURE__ */ _(u, { className: "h-[11px] w-[11px]" }),
109
- text: b(ke === "code" ? t.COMMON$CODE : t.COMMON$PLAN),
110
- rightIcon: /* @__PURE__ */ _(p, {
102
+ children: /* @__PURE__ */ g(m, {
103
+ icon: /* @__PURE__ */ g(l, { className: "h-[11px] w-[11px]" }),
104
+ text: y(D === "code" ? t.COMMON$CODE : t.COMMON$PLAN),
105
+ rightIcon: /* @__PURE__ */ g(p, {
111
106
  width: 10,
112
107
  height: 10
113
108
  })
114
109
  })
115
- }), !Q && /* @__PURE__ */ _("div", {
116
- className: r("absolute left-full top-[-4px] z-60 opacity-0 invisible pointer-events-none transition-all duration-200 ml-[1px]", "group-hover/overflow-agent:opacity-100 group-hover/overflow-agent:visible group-hover/overflow-agent:pointer-events-auto", "hover:opacity-100 hover:visible hover:pointer-events-auto", V === "agent" && "opacity-100 visible pointer-events-auto"),
117
- children: /* @__PURE__ */ v(d, {
110
+ }), !Q && /* @__PURE__ */ g("div", {
111
+ className: r("absolute left-full top-[-4px] z-60 opacity-0 invisible pointer-events-none transition-all duration-200 ml-[1px]", "group-hover/overflow-agent:opacity-100 group-hover/overflow-agent:visible group-hover/overflow-agent:pointer-events-auto", "hover:opacity-100 hover:visible hover:pointer-events-auto", H === "agent" && "opacity-100 visible pointer-events-auto"),
112
+ children: /* @__PURE__ */ _(u, {
118
113
  testId: "overflow-agent-submenu",
119
114
  className: "overflow-visible min-w-[195px] gap-0",
120
- children: [/* @__PURE__ */ _(f, {
115
+ children: [/* @__PURE__ */ g(d, {
121
116
  testId: "overflow-agent-code",
122
117
  onClick: (e) => {
123
- e.preventDefault(), e.stopPropagation(), Ae("code"), $();
118
+ e.preventDefault(), e.stopPropagation(), O("code"), $();
124
119
  },
125
- children: /* @__PURE__ */ _(m, {
126
- icon: /* @__PURE__ */ _(u, { className: "h-[11px] w-[11px]" }),
127
- text: b(t.COMMON$CODE)
120
+ children: /* @__PURE__ */ g(m, {
121
+ icon: /* @__PURE__ */ g(l, { className: "h-[11px] w-[11px]" }),
122
+ text: y(t.COMMON$CODE)
128
123
  })
129
- }), /* @__PURE__ */ _(f, {
124
+ }), /* @__PURE__ */ g(d, {
130
125
  testId: "overflow-agent-plan",
131
126
  onClick: (e) => {
132
- je(e), $();
127
+ k(e), $();
133
128
  },
134
- children: /* @__PURE__ */ _(m, {
135
- icon: /* @__PURE__ */ _(l, {
129
+ children: /* @__PURE__ */ g(m, {
130
+ icon: /* @__PURE__ */ g(ne, {
136
131
  width: 16,
137
132
  height: 16,
138
133
  color: "currentColor"
139
134
  }),
140
- text: b(t.COMMON$PLAN)
135
+ text: y(t.COMMON$PLAN)
141
136
  })
142
137
  })]
143
138
  })
144
139
  })]
145
- }), !Y && /* @__PURE__ */ v("div", {
140
+ }), !X && /* @__PURE__ */ _("div", {
146
141
  className: "relative group/overflow-model",
147
- children: [/* @__PURE__ */ _(f, {
142
+ children: [/* @__PURE__ */ g(d, {
148
143
  testId: "overflow-model-button",
149
- onClick: () => H((e) => e === "model" ? null : "model"),
150
- children: /* @__PURE__ */ _(m, {
151
- icon: /* @__PURE__ */ _(s, {
144
+ onClick: () => U((e) => e === "model" ? null : "model"),
145
+ children: /* @__PURE__ */ g(m, {
146
+ icon: /* @__PURE__ */ g(s, {
152
147
  width: 16,
153
148
  height: 16,
154
149
  strokeWidth: 2,
155
150
  "aria-hidden": !0
156
151
  }),
157
152
  text: "Model",
158
- rightIcon: /* @__PURE__ */ _(p, {
153
+ rightIcon: /* @__PURE__ */ g(p, {
159
154
  width: 10,
160
155
  height: 10
161
156
  })
162
157
  })
163
- }), /* @__PURE__ */ _("div", {
164
- className: r("absolute left-full top-[-4px] z-60 opacity-0 invisible pointer-events-none transition-all duration-200 ml-[1px]", "group-hover/overflow-model:opacity-100 group-hover/overflow-model:visible group-hover/overflow-model:pointer-events-auto", "hover:opacity-100 hover:visible hover:pointer-events-auto", V === "model" && "opacity-100 visible pointer-events-auto"),
165
- children: /* @__PURE__ */ v(d, {
158
+ }), /* @__PURE__ */ g("div", {
159
+ className: r("absolute left-full top-[-4px] z-60 opacity-0 invisible pointer-events-none transition-all duration-200 ml-[1px]", "group-hover/overflow-model:opacity-100 group-hover/overflow-model:visible group-hover/overflow-model:pointer-events-auto", "hover:opacity-100 hover:visible hover:pointer-events-auto", H === "model" && "opacity-100 visible pointer-events-auto"),
160
+ children: /* @__PURE__ */ g(u, {
166
161
  testId: "overflow-model-submenu",
167
- className: "overflow-visible min-w-[220px] max-w-[320px] gap-0",
168
- children: [
169
- /* @__PURE__ */ _("li", {
170
- className: "text-sm",
171
- children: /* @__PURE__ */ _("div", {
172
- className: "p-2 leading-5 text-[var(--oh-foreground)] break-all",
173
- children: Ee
174
- })
175
- }),
176
- /* @__PURE__ */ _(ue, { inset: "menu" }),
177
- /* @__PURE__ */ _("li", {
178
- className: "text-sm",
179
- children: /* @__PURE__ */ v(le, {
180
- to: D,
181
- onClick: $,
182
- className: r("group flex h-[30px] items-center gap-2 rounded p-2 leading-5 text-[var(--oh-foreground)] hover:bg-[var(--oh-interactive-hover)]", "transition-[background-color,border-color,box-shadow,opacity] duration-150 motion-reduce:transition-none"),
183
- children: [/* @__PURE__ */ _(ce, {
184
- width: 16,
185
- height: 16,
186
- className: r("shrink-0 text-[var(--oh-muted)] group-hover:text-[var(--oh-foreground)]", "transition-[background-color,border-color,box-shadow,opacity] duration-150 motion-reduce:transition-none"),
187
- "aria-hidden": !0
188
- }), /* @__PURE__ */ _("span", { children: O })]
189
- })
190
- })
191
- ]
162
+ className: "min-w-[220px] max-w-[320px] max-h-[60vh] overflow-y-auto gap-0",
163
+ children: /* @__PURE__ */ g(se, {
164
+ model: C,
165
+ onClose: $,
166
+ dividerInset: "menu",
167
+ settingsLinkClassName: r("group", "transition-[background-color,border-color,box-shadow,opacity] duration-150 motion-reduce:transition-none"),
168
+ settingsIconClassName: r("text-[var(--oh-muted)] group-hover:text-[var(--oh-foreground)]", "transition-[background-color,border-color,box-shadow,opacity] duration-150 motion-reduce:transition-none")
169
+ })
192
170
  })
193
171
  })]
194
172
  })]
195
173
  });
196
- return /* @__PURE__ */ v("div", {
197
- ref: A,
174
+ return /* @__PURE__ */ _("div", {
175
+ ref: j,
198
176
  className: "w-full min-w-0 flex items-center justify-between gap-2",
199
- children: [/* @__PURE__ */ _("div", {
177
+ children: [/* @__PURE__ */ g("div", {
200
178
  className: "flex min-w-0 items-center gap-1",
201
- children: /* @__PURE__ */ v("div", {
179
+ children: /* @__PURE__ */ _("div", {
202
180
  className: "flex min-w-0 items-center gap-3",
203
181
  children: [
204
- /* @__PURE__ */ _("div", {
205
- ref: M,
182
+ /* @__PURE__ */ g("div", {
183
+ ref: N,
206
184
  className: r(!1),
207
- children: /* @__PURE__ */ _(me, {
208
- disabled: y,
209
- handleFileIconClick: be
185
+ children: /* @__PURE__ */ g(ue, {
186
+ disabled: v,
187
+ handleFileIconClick: _e
210
188
  })
211
189
  }),
212
- k && /* @__PURE__ */ _("div", {
213
- ref: N,
214
- className: r(!J && "hidden"),
215
- children: /* @__PURE__ */ _(oe, {})
216
- }),
217
- /* @__PURE__ */ _("div", {
190
+ w && /* @__PURE__ */ g("div", {
218
191
  ref: P,
219
192
  className: r(!Y && "hidden"),
220
- children: _(T || E ? de : fe, {})
193
+ children: /* @__PURE__ */ g(ie, {})
194
+ }),
195
+ /* @__PURE__ */ g("div", {
196
+ ref: F,
197
+ className: r(!X && "hidden"),
198
+ children: S || C.isAcpContext ? /* @__PURE__ */ g(oe, {}) : /* @__PURE__ */ g(ce, {})
221
199
  }),
222
- Z && /* @__PURE__ */ v("div", {
200
+ Z && /* @__PURE__ */ _("div", {
223
201
  className: "relative shrink-0",
224
- children: [/* @__PURE__ */ _("button", {
225
- ref: F,
202
+ children: [/* @__PURE__ */ g("button", {
203
+ ref: I,
226
204
  type: "button",
227
205
  className: r("flex size-6 items-center justify-center rounded-full text-[var(--oh-muted)]", "transition-[background-color,border-color,box-shadow,opacity] duration-150 motion-reduce:transition-none", "hover:bg-white/10 hover:text-white cursor-pointer"),
228
206
  "aria-label": "More input actions",
229
- "aria-expanded": z,
207
+ "aria-expanded": B,
230
208
  "aria-haspopup": "menu",
231
209
  onClick: (e) => {
232
- e.preventDefault(), e.stopPropagation(), B((e) => !e);
210
+ e.preventDefault(), e.stopPropagation(), V((e) => !e);
233
211
  },
234
- children: /* @__PURE__ */ _(ge, {
212
+ children: /* @__PURE__ */ g(fe, {
235
213
  width: 16,
236
214
  height: 16,
237
215
  color: "currentColor"
238
216
  })
239
- }), z && typeof document < "u" && U && ve.createPortal(/* @__PURE__ */ _("div", {
240
- style: U,
241
- children: Ge
217
+ }), B && typeof document < "u" && W && he.createPortal(/* @__PURE__ */ g("div", {
218
+ style: W,
219
+ children: Le
242
220
  }), document.body)]
243
221
  })
244
222
  ]
245
223
  })
246
- }), /* @__PURE__ */ v("div", {
247
- ref: j,
224
+ }), /* @__PURE__ */ _("div", {
225
+ ref: M,
248
226
  className: "ml-auto flex shrink-0 items-center gap-2",
249
- children: [X && S && /* @__PURE__ */ _(re, {
250
- handleStop: Ve,
251
- handleResumeAgent: He,
252
- disabled: y,
253
- isPausing: Ue
254
- }), xe && /* @__PURE__ */ _(he, {
255
- buttonClassName: Se,
256
- handleSubmit: Ce,
257
- disabled: y || !ye
227
+ children: [Fe && x && /* @__PURE__ */ g(te, {
228
+ handleStop: Me,
229
+ handleResumeAgent: Ne,
230
+ disabled: v,
231
+ isPausing: Pe
232
+ }), ve && /* @__PURE__ */ g(de, {
233
+ buttonClassName: ye,
234
+ handleSubmit: be,
235
+ disabled: v || !ge
258
236
  })]
259
237
  })]
260
238
  });
261
239
  }
262
240
  //#endregion
263
- export { y as ChatInputActions };
241
+ export { v as ChatInputActions };
264
242
 
265
243
  //# sourceMappingURL=chat-input-actions.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"chat-input-actions.js","names":[],"sources":["../../../../../src/components/features/chat/components/chat-input-actions.tsx"],"sourcesContent":["import React from \"react\";\nimport ReactDOM from \"react-dom\";\nimport { useTranslation } from \"react-i18next\";\nimport { Cpu } from \"lucide-react\";\nimport { AgentStatus } from \"#/components/features/controls/agent-status\";\nimport { ChangeAgentButton } from \"../change-agent-button\";\nimport { ChatInputModel } from \"./chat-input-model\";\nimport { SwitchProfileButton } from \"../switch-profile-button\";\nimport { ChatAddFileButton } from \"../chat-add-file-button\";\nimport { ChatSendButton } from \"../chat-send-button\";\nimport { NavigationLink } from \"#/components/shared/navigation-link\";\nimport SettingsGearIcon from \"#/icons/settings-gear.svg?react\";\nimport CarretRightFillIcon from \"#/icons/carret-right-fill.svg?react\";\nimport LessonPlanIcon from \"#/icons/lesson-plan.svg?react\";\nimport ThreeDotsVerticalIcon from \"#/icons/three-dots-vertical.svg?react\";\nimport { CodePillIcon } from \"#/icons/code-pill\";\nimport { useUnifiedPauseConversation } from \"#/hooks/mutation/use-unified-stop-conversation\";\nimport { useOptionalConversationId } from \"#/hooks/use-conversation-id\";\nimport { usePauseConversation } from \"#/hooks/mutation/use-pause-conversation\";\nimport { useResumeConversation } from \"#/hooks/mutation/use-resume-conversation\";\nimport { useActiveBackend } from \"#/contexts/active-backend-context\";\nimport { useActiveConversation } from \"#/hooks/query/use-active-conversation\";\nimport { useAcpModelContext } from \"#/hooks/use-acp-model-context\";\nimport { labelForAcpModel } from \"#/constants/acp-providers\";\nimport { useConversationStore } from \"#/stores/conversation-store\";\nimport { useAgentState } from \"#/hooks/use-agent-state\";\nimport { AgentState } from \"#/types/agent-state\";\nimport { useUnifiedWebSocketStatus } from \"#/hooks/use-unified-websocket-status\";\nimport { useHandlePlanClick } from \"#/hooks/use-handle-plan-click\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { ToolsContextMenuIconText } from \"../../controls/tools-context-menu-icon-text\";\nimport { ContextMenuListItem } from \"../../context-menu/context-menu-list-item\";\nimport { ContextMenu } from \"#/ui/context-menu\";\nimport { Divider } from \"#/ui/divider\";\nimport { useClickOutsideElement } from \"#/hooks/use-click-outside-element\";\nimport { cn } from \"#/utils/utils\";\nimport { formControlTransitionClassName } from \"#/utils/form-control-classes\";\n\ninterface ChatInputActionsProps {\n disabled: boolean;\n canSubmit?: boolean;\n onAddFileClick?: () => void;\n showButton?: boolean;\n buttonClassName?: string;\n handleSubmit?: () => void;\n}\n\nexport function ChatInputActions({\n disabled,\n canSubmit = true,\n onAddFileClick = () => {},\n showButton = true,\n buttonClassName = \"\",\n handleSubmit = () => {},\n}: ChatInputActionsProps) {\n const { t } = useTranslation(\"openhands\");\n const unifiedPauseMutation = useUnifiedPauseConversation();\n const pauseConversationMutation = usePauseConversation();\n const resumeConversationMutation = useResumeConversation();\n const { conversationId } = useOptionalConversationId();\n const { data: conversation } = useActiveConversation();\n const { backend } = useActiveBackend();\n const isCloud = backend.kind === \"cloud\";\n // Shared with ChatInputModel: routes the model affordance to ChatInputModel\n // (which knows how to show the ACP model) instead of SwitchProfileButton for\n // ACP conversations — and for the home screen when Settings → Agent already\n // selects an ACP agent, since the next conversation will inherit it.\n const { isAcpContext, destinationPath, destinationLabel } =\n useAcpModelContext();\n // Mirror ChatInputModel: ACP conversations show the provider's human label\n // (e.g. \"Claude Opus 4.7\") in the overflow model submenu, not the raw\n // ``acp_model`` id. OpenHands keeps the raw model string.\n const overflowModelLabel = isAcpContext\n ? (labelForAcpModel(conversation?.acp_server, conversation?.llm_model) ??\n conversation?.llm_model)\n : conversation?.llm_model;\n // The change-agent button can never be enabled on the home page (no\n // conversation → no WebSocket → permanently disabled), so hide it there\n // entirely. It is still shown inside a conversation on cloud backends.\n const showChangeAgentButton = isCloud && Boolean(conversationId);\n const webSocketStatus = useUnifiedWebSocketStatus();\n const { curAgentState } = useAgentState();\n const { conversationMode, setConversationMode } = useConversationStore();\n const { handlePlanClick, isCreatingConversation } = useHandlePlanClick();\n\n const actionsRowRef = React.useRef<HTMLDivElement>(null);\n const rightSectionRef = React.useRef<HTMLDivElement>(null);\n const addFileRef = React.useRef<HTMLDivElement>(null);\n const codeRef = React.useRef<HTMLDivElement>(null);\n const modelRef = React.useRef<HTMLDivElement>(null);\n const overflowTriggerRef = React.useRef<HTMLButtonElement>(null);\n const [actionsRowWidth, setActionsRowWidth] = React.useState<number>(\n Number.POSITIVE_INFINITY,\n );\n const [rightSectionWidth, setRightSectionWidth] = React.useState(0);\n const [addFileWidth, setAddFileWidth] = React.useState(32);\n const [codeWidth, setCodeWidth] = React.useState(96);\n const [modelWidth, setModelWidth] = React.useState(120);\n const [isOverflowOpen, setIsOverflowOpen] = React.useState(false);\n const [activeSubmenu, setActiveSubmenu] = React.useState<\n \"agent\" | \"model\" | null\n >(null);\n const [overflowPortalStyle, setOverflowPortalStyle] =\n React.useState<React.CSSProperties>();\n\n React.useEffect(() => {\n const rowEl = actionsRowRef.current;\n const rightEl = rightSectionRef.current;\n const addEl = addFileRef.current;\n const codeEl = codeRef.current;\n const modelEl = modelRef.current;\n\n if (\n !rowEl ||\n !rightEl ||\n !addEl ||\n !modelEl ||\n (showChangeAgentButton && !codeEl) ||\n typeof ResizeObserver === \"undefined\"\n ) {\n return;\n }\n\n const syncWidths = () => {\n const nextRowWidth = rowEl.getBoundingClientRect().width;\n const nextRightWidth = rightEl.getBoundingClientRect().width;\n const nextAddWidth = addEl.getBoundingClientRect().width;\n const nextModelWidth = modelEl.getBoundingClientRect().width;\n\n if (nextRowWidth > 0) setActionsRowWidth(nextRowWidth);\n if (nextRightWidth > 0) setRightSectionWidth(nextRightWidth);\n if (nextAddWidth > 0) setAddFileWidth(nextAddWidth);\n if (nextModelWidth > 0) setModelWidth(nextModelWidth);\n\n if (codeEl) {\n const nextCodeWidth = codeEl.getBoundingClientRect().width;\n if (nextCodeWidth > 0) setCodeWidth(nextCodeWidth);\n }\n };\n\n const observer = new ResizeObserver(() => {\n syncWidths();\n });\n\n observer.observe(rowEl);\n observer.observe(rightEl);\n observer.observe(addEl);\n observer.observe(modelEl);\n if (codeEl) {\n observer.observe(codeEl);\n }\n\n syncWidths();\n\n return () => observer.disconnect();\n }, [showChangeAgentButton]);\n\n const handlePauseAgent = () => {\n if (!conversationId) return;\n pauseConversationMutation.mutate({ conversationId });\n };\n\n const handleResumeAgentClick = () => {\n if (!conversationId) return;\n resumeConversationMutation.mutate({ conversationId });\n };\n\n const isPausing =\n unifiedPauseMutation.isPending || pauseConversationMutation.isPending;\n\n const OVERFLOW_BUTTON_WIDTH = 28;\n const INLINE_GAP = 12;\n const ROOT_GAP = 8;\n\n const fitOptionalItems = React.useCallback(\n (availableWidth: number) => {\n let remaining = availableWidth;\n const next = {\n showCodeInline: false,\n showModelInline: false,\n };\n\n if (showChangeAgentButton && remaining >= codeWidth) {\n next.showCodeInline = true;\n remaining -= codeWidth + INLINE_GAP;\n }\n\n if (remaining >= modelWidth) {\n next.showModelInline = true;\n }\n\n return next;\n },\n [showChangeAgentButton, codeWidth, modelWidth],\n );\n\n const leftBaseWidth =\n actionsRowWidth - rightSectionWidth - ROOT_GAP - addFileWidth - INLINE_GAP;\n\n const fitWithoutOverflow = fitOptionalItems(leftBaseWidth);\n const allOptionalFit =\n (!showChangeAgentButton || fitWithoutOverflow.showCodeInline) &&\n fitWithoutOverflow.showModelInline;\n\n const fitWithOverflow = allOptionalFit\n ? fitWithoutOverflow\n : fitOptionalItems(leftBaseWidth - OVERFLOW_BUTTON_WIDTH - INLINE_GAP);\n\n const showCodeInline = !showChangeAgentButton\n ? false\n : fitWithOverflow.showCodeInline;\n const showModelInline = fitWithOverflow.showModelInline;\n const showAddFileInline = true;\n const showAgentStatusInline = actionsRowWidth >= 360;\n\n const hasOverflowItems =\n !showAddFileInline ||\n (showChangeAgentButton && !showCodeInline) ||\n !showModelInline;\n\n React.useEffect(() => {\n if (!hasOverflowItems) {\n setIsOverflowOpen(false);\n setActiveSubmenu(null);\n }\n }, [hasOverflowItems]);\n\n const overflowMenuRef = useClickOutsideElement<HTMLUListElement>(() => {\n setIsOverflowOpen(false);\n setActiveSubmenu(null);\n });\n\n const isAgentSwitcherDisabled =\n curAgentState === AgentState.RUNNING ||\n isCreatingConversation ||\n webSocketStatus !== \"OPEN\";\n\n const closeOverflowMenus = () => {\n setActiveSubmenu(null);\n setIsOverflowOpen(false);\n };\n\n React.useLayoutEffect(() => {\n if (!isOverflowOpen || !overflowTriggerRef.current) {\n return;\n }\n\n const trigger = overflowTriggerRef.current;\n\n const updatePosition = () => {\n const rect = trigger.getBoundingClientRect();\n const GAP = 8;\n setOverflowPortalStyle({\n position: \"fixed\",\n top: rect.top - GAP,\n left: rect.left,\n transform: \"translateY(-100%)\",\n zIndex: 9999,\n });\n };\n\n updatePosition();\n window.addEventListener(\"resize\", updatePosition);\n window.addEventListener(\"scroll\", updatePosition, true);\n\n return () => {\n window.removeEventListener(\"resize\", updatePosition);\n window.removeEventListener(\"scroll\", updatePosition, true);\n };\n }, [isOverflowOpen]);\n\n const overflowMenu = (\n <ContextMenu\n ref={overflowMenuRef}\n testId=\"chat-input-overflow-menu\"\n position=\"top\"\n alignment=\"left\"\n className=\"!static !top-auto !bottom-auto !left-auto !right-auto !mt-0 overflow-visible min-w-[200px]\"\n >\n {showChangeAgentButton && !showCodeInline && (\n <div className=\"relative group/overflow-agent\">\n <ContextMenuListItem\n testId=\"overflow-agent-button\"\n onClick={() =>\n setActiveSubmenu((current) =>\n current === \"agent\" ? null : \"agent\",\n )\n }\n isDisabled={isAgentSwitcherDisabled}\n >\n <ToolsContextMenuIconText\n icon={<CodePillIcon className=\"h-[11px] w-[11px]\" />}\n text={\n conversationMode === \"code\"\n ? t(I18nKey.COMMON$CODE)\n : t(I18nKey.COMMON$PLAN)\n }\n rightIcon={<CarretRightFillIcon width={10} height={10} />}\n />\n </ContextMenuListItem>\n {!isAgentSwitcherDisabled && (\n <div\n className={cn(\n \"absolute left-full top-[-4px] z-60 opacity-0 invisible pointer-events-none transition-all duration-200 ml-[1px]\",\n \"group-hover/overflow-agent:opacity-100 group-hover/overflow-agent:visible group-hover/overflow-agent:pointer-events-auto\",\n \"hover:opacity-100 hover:visible hover:pointer-events-auto\",\n activeSubmenu === \"agent\" &&\n \"opacity-100 visible pointer-events-auto\",\n )}\n >\n <ContextMenu\n testId=\"overflow-agent-submenu\"\n className=\"overflow-visible min-w-[195px] gap-0\"\n >\n <ContextMenuListItem\n testId=\"overflow-agent-code\"\n onClick={(event) => {\n event.preventDefault();\n event.stopPropagation();\n setConversationMode(\"code\");\n closeOverflowMenus();\n }}\n >\n <ToolsContextMenuIconText\n icon={<CodePillIcon className=\"h-[11px] w-[11px]\" />}\n text={t(I18nKey.COMMON$CODE)}\n />\n </ContextMenuListItem>\n <ContextMenuListItem\n testId=\"overflow-agent-plan\"\n onClick={(event) => {\n handlePlanClick(event);\n closeOverflowMenus();\n }}\n >\n <ToolsContextMenuIconText\n icon={\n <LessonPlanIcon\n width={16}\n height={16}\n color=\"currentColor\"\n />\n }\n text={t(I18nKey.COMMON$PLAN)}\n />\n </ContextMenuListItem>\n </ContextMenu>\n </div>\n )}\n </div>\n )}\n {!showModelInline && (\n <div className=\"relative group/overflow-model\">\n <ContextMenuListItem\n testId=\"overflow-model-button\"\n onClick={() =>\n setActiveSubmenu((current) =>\n current === \"model\" ? null : \"model\",\n )\n }\n >\n <ToolsContextMenuIconText\n icon={<Cpu width={16} height={16} strokeWidth={2} aria-hidden />}\n text=\"Model\"\n rightIcon={<CarretRightFillIcon width={10} height={10} />}\n />\n </ContextMenuListItem>\n <div\n className={cn(\n \"absolute left-full top-[-4px] z-60 opacity-0 invisible pointer-events-none transition-all duration-200 ml-[1px]\",\n \"group-hover/overflow-model:opacity-100 group-hover/overflow-model:visible group-hover/overflow-model:pointer-events-auto\",\n \"hover:opacity-100 hover:visible hover:pointer-events-auto\",\n activeSubmenu === \"model\" &&\n \"opacity-100 visible pointer-events-auto\",\n )}\n >\n <ContextMenu\n testId=\"overflow-model-submenu\"\n className=\"overflow-visible min-w-[220px] max-w-[320px] gap-0\"\n >\n <li className=\"text-sm\">\n <div className=\"p-2 leading-5 text-[var(--oh-foreground)] break-all\">\n {overflowModelLabel}\n </div>\n </li>\n <Divider inset=\"menu\" />\n <li className=\"text-sm\">\n <NavigationLink\n to={destinationPath}\n onClick={closeOverflowMenus}\n className={cn(\n \"group flex h-[30px] items-center gap-2 rounded p-2 leading-5 text-[var(--oh-foreground)] hover:bg-[var(--oh-interactive-hover)]\",\n formControlTransitionClassName,\n )}\n >\n <SettingsGearIcon\n width={16}\n height={16}\n className={cn(\n \"shrink-0 text-[var(--oh-muted)] group-hover:text-[var(--oh-foreground)]\",\n formControlTransitionClassName,\n )}\n aria-hidden\n />\n <span>{destinationLabel}</span>\n </NavigationLink>\n </li>\n </ContextMenu>\n </div>\n </div>\n )}\n </ContextMenu>\n );\n\n return (\n <div\n ref={actionsRowRef}\n className=\"w-full min-w-0 flex items-center justify-between gap-2\"\n >\n <div className=\"flex min-w-0 items-center gap-1\">\n <div className=\"flex min-w-0 items-center gap-3\">\n <div ref={addFileRef} className={cn(!showAddFileInline && \"hidden\")}>\n <ChatAddFileButton\n disabled={disabled}\n handleFileIconClick={onAddFileClick}\n />\n </div>\n {showChangeAgentButton && (\n <div ref={codeRef} className={cn(!showCodeInline && \"hidden\")}>\n <ChangeAgentButton />\n </div>\n )}\n <div ref={modelRef} className={cn(!showModelInline && \"hidden\")}>\n {isCloud || isAcpContext ? (\n <ChatInputModel />\n ) : (\n <SwitchProfileButton />\n )}\n </div>\n\n {hasOverflowItems && (\n <div className=\"relative shrink-0\">\n <button\n ref={overflowTriggerRef}\n type=\"button\"\n className={cn(\n \"flex size-6 items-center justify-center rounded-full text-[var(--oh-muted)]\",\n formControlTransitionClassName,\n \"hover:bg-white/10 hover:text-white cursor-pointer\",\n )}\n aria-label=\"More input actions\"\n aria-expanded={isOverflowOpen}\n aria-haspopup=\"menu\"\n onClick={(event) => {\n event.preventDefault();\n event.stopPropagation();\n setIsOverflowOpen((open) => !open);\n }}\n >\n <ThreeDotsVerticalIcon\n width={16}\n height={16}\n color=\"currentColor\"\n />\n </button>\n\n {isOverflowOpen &&\n typeof document !== \"undefined\" &&\n overflowPortalStyle &&\n ReactDOM.createPortal(\n <div style={overflowPortalStyle}>{overflowMenu}</div>,\n document.body,\n )}\n </div>\n )}\n </div>\n </div>\n <div\n ref={rightSectionRef}\n className=\"ml-auto flex shrink-0 items-center gap-2\"\n >\n {showAgentStatusInline && conversationId && (\n <AgentStatus\n handleStop={handlePauseAgent}\n handleResumeAgent={handleResumeAgentClick}\n disabled={disabled}\n isPausing={isPausing}\n />\n )}\n {showButton && (\n <ChatSendButton\n buttonClassName={buttonClassName}\n handleSubmit={handleSubmit}\n disabled={disabled || !canSubmit}\n />\n )}\n </div>\n </div>\n );\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"chat-input-actions.js","names":[],"sources":["../../../../../src/components/features/chat/components/chat-input-actions.tsx"],"sourcesContent":["import React from \"react\";\nimport ReactDOM from \"react-dom\";\nimport { useTranslation } from \"react-i18next\";\nimport { Cpu } from \"lucide-react\";\nimport { AgentStatus } from \"#/components/features/controls/agent-status\";\nimport { ChangeAgentButton } from \"../change-agent-button\";\nimport { ChatInputModel, ChatInputModelMenuContent } from \"./chat-input-model\";\nimport { SwitchProfileButton } from \"../switch-profile-button\";\nimport { ChatAddFileButton } from \"../chat-add-file-button\";\nimport { ChatSendButton } from \"../chat-send-button\";\nimport CarretRightFillIcon from \"#/icons/carret-right-fill.svg?react\";\nimport LessonPlanIcon from \"#/icons/lesson-plan.svg?react\";\nimport ThreeDotsVerticalIcon from \"#/icons/three-dots-vertical.svg?react\";\nimport { CodePillIcon } from \"#/icons/code-pill\";\nimport { useUnifiedPauseConversation } from \"#/hooks/mutation/use-unified-stop-conversation\";\nimport { useOptionalConversationId } from \"#/hooks/use-conversation-id\";\nimport { usePauseConversation } from \"#/hooks/mutation/use-pause-conversation\";\nimport { useResumeConversation } from \"#/hooks/mutation/use-resume-conversation\";\nimport { useActiveBackend } from \"#/contexts/active-backend-context\";\nimport { useChatInputModelState } from \"#/hooks/use-chat-input-model-state\";\nimport { useConversationStore } from \"#/stores/conversation-store\";\nimport { useAgentState } from \"#/hooks/use-agent-state\";\nimport { AgentState } from \"#/types/agent-state\";\nimport { useUnifiedWebSocketStatus } from \"#/hooks/use-unified-websocket-status\";\nimport { useHandlePlanClick } from \"#/hooks/use-handle-plan-click\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { ToolsContextMenuIconText } from \"../../controls/tools-context-menu-icon-text\";\nimport { ContextMenuListItem } from \"../../context-menu/context-menu-list-item\";\nimport { ContextMenu } from \"#/ui/context-menu\";\nimport { useClickOutsideElement } from \"#/hooks/use-click-outside-element\";\nimport { cn } from \"#/utils/utils\";\nimport { formControlTransitionClassName } from \"#/utils/form-control-classes\";\n\ninterface ChatInputActionsProps {\n disabled: boolean;\n canSubmit?: boolean;\n onAddFileClick?: () => void;\n showButton?: boolean;\n buttonClassName?: string;\n handleSubmit?: () => void;\n}\n\nexport function ChatInputActions({\n disabled,\n canSubmit = true,\n onAddFileClick = () => {},\n showButton = true,\n buttonClassName = \"\",\n handleSubmit = () => {},\n}: ChatInputActionsProps) {\n const { t } = useTranslation(\"openhands\");\n const unifiedPauseMutation = useUnifiedPauseConversation();\n const pauseConversationMutation = usePauseConversation();\n const resumeConversationMutation = useResumeConversation();\n const { conversationId } = useOptionalConversationId();\n const { backend } = useActiveBackend();\n const isCloud = backend.kind === \"cloud\";\n const modelState = useChatInputModelState();\n const showChangeAgentButton = isCloud;\n const webSocketStatus = useUnifiedWebSocketStatus();\n const { curAgentState } = useAgentState();\n const { conversationMode, setConversationMode } = useConversationStore();\n const { handlePlanClick, isCreatingConversation } = useHandlePlanClick();\n\n const actionsRowRef = React.useRef<HTMLDivElement>(null);\n const rightSectionRef = React.useRef<HTMLDivElement>(null);\n const addFileRef = React.useRef<HTMLDivElement>(null);\n const codeRef = React.useRef<HTMLDivElement>(null);\n const modelRef = React.useRef<HTMLDivElement>(null);\n const overflowTriggerRef = React.useRef<HTMLButtonElement>(null);\n const [actionsRowWidth, setActionsRowWidth] = React.useState<number>(\n Number.POSITIVE_INFINITY,\n );\n const [rightSectionWidth, setRightSectionWidth] = React.useState(0);\n const [addFileWidth, setAddFileWidth] = React.useState(32);\n const [codeWidth, setCodeWidth] = React.useState(96);\n const [modelWidth, setModelWidth] = React.useState(120);\n const [isOverflowOpen, setIsOverflowOpen] = React.useState(false);\n const [activeSubmenu, setActiveSubmenu] = React.useState<\n \"agent\" | \"model\" | null\n >(null);\n const [overflowPortalStyle, setOverflowPortalStyle] =\n React.useState<React.CSSProperties>();\n\n React.useEffect(() => {\n const rowEl = actionsRowRef.current;\n const rightEl = rightSectionRef.current;\n const addEl = addFileRef.current;\n const codeEl = codeRef.current;\n const modelEl = modelRef.current;\n\n if (\n !rowEl ||\n !rightEl ||\n !addEl ||\n !modelEl ||\n (showChangeAgentButton && !codeEl) ||\n typeof ResizeObserver === \"undefined\"\n ) {\n return;\n }\n\n const syncWidths = () => {\n const nextRowWidth = rowEl.getBoundingClientRect().width;\n const nextRightWidth = rightEl.getBoundingClientRect().width;\n const nextAddWidth = addEl.getBoundingClientRect().width;\n const nextModelWidth = modelEl.getBoundingClientRect().width;\n\n if (nextRowWidth > 0) setActionsRowWidth(nextRowWidth);\n if (nextRightWidth > 0) setRightSectionWidth(nextRightWidth);\n if (nextAddWidth > 0) setAddFileWidth(nextAddWidth);\n if (nextModelWidth > 0) setModelWidth(nextModelWidth);\n\n if (codeEl) {\n const nextCodeWidth = codeEl.getBoundingClientRect().width;\n if (nextCodeWidth > 0) setCodeWidth(nextCodeWidth);\n }\n };\n\n const observer = new ResizeObserver(() => {\n syncWidths();\n });\n\n observer.observe(rowEl);\n observer.observe(rightEl);\n observer.observe(addEl);\n observer.observe(modelEl);\n if (codeEl) {\n observer.observe(codeEl);\n }\n\n syncWidths();\n\n return () => observer.disconnect();\n }, [showChangeAgentButton]);\n\n const handlePauseAgent = () => {\n if (!conversationId) return;\n pauseConversationMutation.mutate({ conversationId });\n };\n\n const handleResumeAgentClick = () => {\n if (!conversationId) return;\n resumeConversationMutation.mutate({ conversationId });\n };\n\n const isPausing =\n unifiedPauseMutation.isPending || pauseConversationMutation.isPending;\n\n const OVERFLOW_BUTTON_WIDTH = 28;\n const INLINE_GAP = 12;\n const ROOT_GAP = 8;\n\n const fitOptionalItems = React.useCallback(\n (availableWidth: number) => {\n let remaining = availableWidth;\n const next = {\n showCodeInline: false,\n showModelInline: false,\n };\n\n if (showChangeAgentButton && remaining >= codeWidth) {\n next.showCodeInline = true;\n remaining -= codeWidth + INLINE_GAP;\n }\n\n if (remaining >= modelWidth) {\n next.showModelInline = true;\n }\n\n return next;\n },\n [showChangeAgentButton, codeWidth, modelWidth],\n );\n\n const leftBaseWidth =\n actionsRowWidth - rightSectionWidth - ROOT_GAP - addFileWidth - INLINE_GAP;\n\n const fitWithoutOverflow = fitOptionalItems(leftBaseWidth);\n const allOptionalFit =\n (!showChangeAgentButton || fitWithoutOverflow.showCodeInline) &&\n fitWithoutOverflow.showModelInline;\n\n const fitWithOverflow = allOptionalFit\n ? fitWithoutOverflow\n : fitOptionalItems(leftBaseWidth - OVERFLOW_BUTTON_WIDTH - INLINE_GAP);\n\n const showCodeInline = !showChangeAgentButton\n ? false\n : fitWithOverflow.showCodeInline;\n const showModelInline = fitWithOverflow.showModelInline;\n const showAddFileInline = true;\n const showAgentStatusInline = actionsRowWidth >= 360;\n\n const hasOverflowItems =\n !showAddFileInline ||\n (showChangeAgentButton && !showCodeInline) ||\n !showModelInline;\n\n React.useEffect(() => {\n if (!hasOverflowItems) {\n setIsOverflowOpen(false);\n setActiveSubmenu(null);\n }\n }, [hasOverflowItems]);\n\n const overflowMenuRef = useClickOutsideElement<HTMLUListElement>(() => {\n setIsOverflowOpen(false);\n setActiveSubmenu(null);\n });\n\n const isAgentSwitcherDisabled =\n curAgentState === AgentState.RUNNING ||\n isCreatingConversation ||\n webSocketStatus !== \"OPEN\";\n\n const closeOverflowMenus = () => {\n setActiveSubmenu(null);\n setIsOverflowOpen(false);\n };\n\n React.useLayoutEffect(() => {\n if (!isOverflowOpen || !overflowTriggerRef.current) {\n return;\n }\n\n const trigger = overflowTriggerRef.current;\n\n const updatePosition = () => {\n const rect = trigger.getBoundingClientRect();\n const GAP = 8;\n setOverflowPortalStyle({\n position: \"fixed\",\n top: rect.top - GAP,\n left: rect.left,\n transform: \"translateY(-100%)\",\n zIndex: 9999,\n });\n };\n\n updatePosition();\n window.addEventListener(\"resize\", updatePosition);\n window.addEventListener(\"scroll\", updatePosition, true);\n\n return () => {\n window.removeEventListener(\"resize\", updatePosition);\n window.removeEventListener(\"scroll\", updatePosition, true);\n };\n }, [isOverflowOpen]);\n\n const overflowMenu = (\n <ContextMenu\n ref={overflowMenuRef}\n testId=\"chat-input-overflow-menu\"\n position=\"top\"\n alignment=\"left\"\n className=\"!static !top-auto !bottom-auto !left-auto !right-auto !mt-0 overflow-visible min-w-[200px]\"\n >\n {showChangeAgentButton && !showCodeInline && (\n <div className=\"relative group/overflow-agent\">\n <ContextMenuListItem\n testId=\"overflow-agent-button\"\n onClick={() =>\n setActiveSubmenu((current) =>\n current === \"agent\" ? null : \"agent\",\n )\n }\n isDisabled={isAgentSwitcherDisabled}\n >\n <ToolsContextMenuIconText\n icon={<CodePillIcon className=\"h-[11px] w-[11px]\" />}\n text={\n conversationMode === \"code\"\n ? t(I18nKey.COMMON$CODE)\n : t(I18nKey.COMMON$PLAN)\n }\n rightIcon={<CarretRightFillIcon width={10} height={10} />}\n />\n </ContextMenuListItem>\n {!isAgentSwitcherDisabled && (\n <div\n className={cn(\n \"absolute left-full top-[-4px] z-60 opacity-0 invisible pointer-events-none transition-all duration-200 ml-[1px]\",\n \"group-hover/overflow-agent:opacity-100 group-hover/overflow-agent:visible group-hover/overflow-agent:pointer-events-auto\",\n \"hover:opacity-100 hover:visible hover:pointer-events-auto\",\n activeSubmenu === \"agent\" &&\n \"opacity-100 visible pointer-events-auto\",\n )}\n >\n <ContextMenu\n testId=\"overflow-agent-submenu\"\n className=\"overflow-visible min-w-[195px] gap-0\"\n >\n <ContextMenuListItem\n testId=\"overflow-agent-code\"\n onClick={(event) => {\n event.preventDefault();\n event.stopPropagation();\n setConversationMode(\"code\");\n closeOverflowMenus();\n }}\n >\n <ToolsContextMenuIconText\n icon={<CodePillIcon className=\"h-[11px] w-[11px]\" />}\n text={t(I18nKey.COMMON$CODE)}\n />\n </ContextMenuListItem>\n <ContextMenuListItem\n testId=\"overflow-agent-plan\"\n onClick={(event) => {\n handlePlanClick(event);\n closeOverflowMenus();\n }}\n >\n <ToolsContextMenuIconText\n icon={\n <LessonPlanIcon\n width={16}\n height={16}\n color=\"currentColor\"\n />\n }\n text={t(I18nKey.COMMON$PLAN)}\n />\n </ContextMenuListItem>\n </ContextMenu>\n </div>\n )}\n </div>\n )}\n {!showModelInline && (\n <div className=\"relative group/overflow-model\">\n <ContextMenuListItem\n testId=\"overflow-model-button\"\n onClick={() =>\n setActiveSubmenu((current) =>\n current === \"model\" ? null : \"model\",\n )\n }\n >\n <ToolsContextMenuIconText\n icon={<Cpu width={16} height={16} strokeWidth={2} aria-hidden />}\n text=\"Model\"\n rightIcon={<CarretRightFillIcon width={10} height={10} />}\n />\n </ContextMenuListItem>\n <div\n className={cn(\n \"absolute left-full top-[-4px] z-60 opacity-0 invisible pointer-events-none transition-all duration-200 ml-[1px]\",\n \"group-hover/overflow-model:opacity-100 group-hover/overflow-model:visible group-hover/overflow-model:pointer-events-auto\",\n \"hover:opacity-100 hover:visible hover:pointer-events-auto\",\n activeSubmenu === \"model\" &&\n \"opacity-100 visible pointer-events-auto\",\n )}\n >\n {/* overflow-y-auto (not overflow-visible) so a long ACP model list\n scrolls within the menu instead of overflowing the viewport.\n Safe because this menu has no floating children (tooltips /\n nested popovers) that would be clipped — only a flat model list\n + Settings link. Revisit if floating children are added here. */}\n <ContextMenu\n testId=\"overflow-model-submenu\"\n className=\"min-w-[220px] max-w-[320px] max-h-[60vh] overflow-y-auto gap-0\"\n >\n <ChatInputModelMenuContent\n model={modelState}\n onClose={closeOverflowMenus}\n dividerInset=\"menu\"\n settingsLinkClassName={cn(\n \"group\",\n formControlTransitionClassName,\n )}\n settingsIconClassName={cn(\n \"text-[var(--oh-muted)] group-hover:text-[var(--oh-foreground)]\",\n formControlTransitionClassName,\n )}\n />\n </ContextMenu>\n </div>\n </div>\n )}\n </ContextMenu>\n );\n\n return (\n <div\n ref={actionsRowRef}\n className=\"w-full min-w-0 flex items-center justify-between gap-2\"\n >\n <div className=\"flex min-w-0 items-center gap-1\">\n <div className=\"flex min-w-0 items-center gap-3\">\n <div ref={addFileRef} className={cn(!showAddFileInline && \"hidden\")}>\n <ChatAddFileButton\n disabled={disabled}\n handleFileIconClick={onAddFileClick}\n />\n </div>\n {showChangeAgentButton && (\n <div ref={codeRef} className={cn(!showCodeInline && \"hidden\")}>\n <ChangeAgentButton />\n </div>\n )}\n <div ref={modelRef} className={cn(!showModelInline && \"hidden\")}>\n {isCloud || modelState.isAcpContext ? (\n <ChatInputModel />\n ) : (\n <SwitchProfileButton />\n )}\n </div>\n\n {hasOverflowItems && (\n <div className=\"relative shrink-0\">\n <button\n ref={overflowTriggerRef}\n type=\"button\"\n className={cn(\n \"flex size-6 items-center justify-center rounded-full text-[var(--oh-muted)]\",\n formControlTransitionClassName,\n \"hover:bg-white/10 hover:text-white cursor-pointer\",\n )}\n aria-label=\"More input actions\"\n aria-expanded={isOverflowOpen}\n aria-haspopup=\"menu\"\n onClick={(event) => {\n event.preventDefault();\n event.stopPropagation();\n setIsOverflowOpen((open) => !open);\n }}\n >\n <ThreeDotsVerticalIcon\n width={16}\n height={16}\n color=\"currentColor\"\n />\n </button>\n\n {isOverflowOpen &&\n typeof document !== \"undefined\" &&\n overflowPortalStyle &&\n ReactDOM.createPortal(\n <div style={overflowPortalStyle}>{overflowMenu}</div>,\n document.body,\n )}\n </div>\n )}\n </div>\n </div>\n <div\n ref={rightSectionRef}\n className=\"ml-auto flex shrink-0 items-center gap-2\"\n >\n {showAgentStatusInline && conversationId && (\n <AgentStatus\n handleStop={handlePauseAgent}\n handleResumeAgent={handleResumeAgentClick}\n disabled={disabled}\n isPausing={isPausing}\n />\n )}\n {showButton && (\n <ChatSendButton\n buttonClassName={buttonClassName}\n handleSubmit={handleSubmit}\n disabled={disabled || !canSubmit}\n />\n )}\n </div>\n </div>\n );\n}\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- const e=require(`../../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../../utils/utils.cjs`),n=require(`../../../../constants/acp-providers.cjs`),r=require(`../../../../hooks/query/use-active-conversation.cjs`),i=require(`../../../../hooks/query/use-settings.cjs`),a=require(`../../../../ui/combobox-caret.cjs`),o=require(`../../../../ui/context-menu.cjs`),s=require(`../../../../hooks/use-click-outside-element.cjs`),c=require(`../../../../hooks/use-acp-model-context.cjs`),l=require(`../../../../icons/settings-gear.cjs`),u=require(`../../../shared/navigation-link.cjs`),d=require(`../../../../ui/divider.cjs`);let f=require(`react`);f=e.__toESM(f,1);let p=require(`react/jsx-runtime`);var m=10,h=22;function g(e,t=m){return e.length<=t?e:`${e.slice(0,t)}…`}function _(){let{data:e}=r.useActiveConversation(),{data:_}=i.useSettings(),{isActiveAcpConversation:v,isHomeAcp:y,isAcpContext:b,destinationPath:x,destinationLabel:S}=c.useAcpModelContext(),C=v?e?.acp_server:y&&typeof _?.agent_settings?.acp_server==`string`?_.agent_settings.acp_server:null,w=y?n.getAcpProvider(C):void 0,T;T=v?e?.llm_model:y?n.resolveEffectiveAcpModel({configured:typeof _?.agent_settings?.acp_model==`string`?_.agent_settings.acp_model:null,providerDefault:w?.default_model}):e?.llm_model??_?.llm_model;let[E,D]=f.default.useState(!1),O=s.useClickOutsideElement(()=>{D(!1)});if(!T)return null;let k=b?n.labelForAcpModel(C,T)??T:T,A=g(k,b?h:m);return(0,p.jsxs)(`div`,{className:`relative min-w-0`,children:[(0,p.jsxs)(`button`,{type:`button`,className:t.cn(`inline-flex items-center gap-1 rounded-[100px] border border-transparent px-1.5 text-sm font-normal leading-5 text-[var(--oh-muted)] whitespace-nowrap min-w-0 transition-[border-color,background-color,box-shadow,opacity] duration-150 motion-reduce:transition-none`,`hover:text-white hover:bg-white/10 cursor-pointer`),title:k,"data-testid":`chat-input-llm-model`,"aria-expanded":E,"aria-haspopup":`dialog`,onClick:e=>{e.preventDefault(),e.stopPropagation(),D(e=>!e)},children:[(0,p.jsx)(`span`,{children:A}),(0,p.jsx)(a.ComboboxCaretInline,{isOpen:E})]}),E&&(0,p.jsxs)(o.ContextMenu,{ref:O,testId:`chat-input-llm-model-popover`,position:`top`,alignment:`left`,spacing:`none`,className:`z-[60] mb-2 min-w-[200px] max-w-[320px]`,children:[(0,p.jsx)(`li`,{className:`text-sm`,children:(0,p.jsx)(`div`,{className:`p-2 leading-5 text-white break-all`,children:k})}),(0,p.jsx)(d.Divider,{}),(0,p.jsx)(`li`,{className:`text-sm`,children:(0,p.jsxs)(u.NavigationLink,{to:x,onClick:()=>D(!1),className:`flex h-[30px] items-center gap-2 rounded p-2 leading-5 text-white hover:bg-[var(--oh-interactive-hover)] transition-colors`,children:[(0,p.jsx)(l.default,{width:16,height:16,className:`shrink-0`,"aria-hidden":!0}),(0,p.jsx)(`span`,{children:S})]})})]})]})}exports.ChatInputModel=_;
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(`../../../../icons/checkmark.cjs`),a=require(`../../../../ui/typography.cjs`),o=require(`../../../../ui/combobox-caret.cjs`),s=require(`../../../../ui/context-menu.cjs`),c=require(`../../context-menu/context-menu-list-item.cjs`),l=require(`../../../../hooks/use-click-outside-element.cjs`),u=require(`../../../../hooks/use-chat-input-model-state.cjs`),d=require(`../../../../hooks/mutation/use-switch-acp-model.cjs`),f=require(`../../../../icons/settings-gear.cjs`),p=require(`../../../shared/navigation-link.cjs`),m=require(`../../../../ui/divider.cjs`);let h=require(`react`);h=e.__toESM(h,1);let g=require(`react/jsx-runtime`);var _=10,v=22;function y(e,t=_){return e.length<=t?e:`${e.slice(0,t)}…`}function b({model:e,onClose:o,dividerInset:s,settingsLinkClassName:l,settingsIconClassName:u}){let{t:h}=t.useTranslation(`openhands`),_=d.useSwitchAcpModel(),v=e.showAcpPicker||!!e.displayModel,y=t=>{t!==e.currentModelId&&_.mutate({conversationId:e.switchConversationId,model:t}),o()};return(0,g.jsxs)(g.Fragment,{children:[e.showAcpPicker?(0,g.jsxs)(g.Fragment,{children:[(0,g.jsx)(`li`,{role:`presentation`,className:`px-2 pt-1 pb-0.5`,children:(0,g.jsx)(a.Typography.Text,{className:`text-[11px] font-medium text-[var(--oh-text-dim)] uppercase tracking-wide leading-4`,children:h(n.I18nKey.MODEL$AVAILABLE_MODELS)})}),e.availableAcpModels.map(t=>{let n=t.id===e.currentModelId;return(0,g.jsxs)(c.ContextMenuListItem,{testId:`chat-input-acp-model-option-${t.id}`,onClick:e=>{e.preventDefault(),e.stopPropagation(),y(t.id)},className:r.cn(`flex items-center gap-2`,n&&`bg-[var(--oh-interactive-hover)]`),children:[(0,g.jsx)(`span`,{className:`flex-1 truncate text-sm leading-5`,title:t.label,children:t.label}),n&&(0,g.jsx)(i.default,{width:14,height:14,className:`shrink-0`,"aria-hidden":!0})]},t.id)})]}):e.displayModel?(0,g.jsx)(`li`,{className:`text-sm`,children:(0,g.jsx)(`div`,{className:`p-2 leading-5 text-[var(--oh-foreground)] break-all`,children:e.displayModel})}):null,v&&(0,g.jsx)(m.Divider,{inset:s}),(0,g.jsx)(`li`,{className:`text-sm`,children:(0,g.jsxs)(p.NavigationLink,{to:e.destinationPath,onClick:o,className:r.cn(`flex h-[30px] items-center gap-2 rounded p-2 leading-5 text-[var(--oh-foreground)] hover:bg-[var(--oh-interactive-hover)] transition-colors`,l),children:[(0,g.jsx)(f.default,{width:16,height:16,className:r.cn(`shrink-0`,u),"aria-hidden":!0}),(0,g.jsx)(`span`,{children:e.destinationLabel})]})})]})}function x(){let e=u.useChatInputModelState(),[t,n]=h.default.useState(!1),i=h.default.useRef(null),a=l.useClickOutsideElement(()=>n(!1),i);if(!e.displayModel)return null;let c=y(e.displayModel,e.isAcpContext?v:_);return(0,g.jsxs)(`div`,{className:`relative min-w-0`,children:[(0,g.jsxs)(`button`,{ref:i,type:`button`,className:r.cn(`inline-flex items-center gap-1 rounded-[100px] border border-transparent px-1.5 text-sm font-normal leading-5 text-[var(--oh-muted)] whitespace-nowrap min-w-0 transition-[border-color,background-color,box-shadow,opacity] duration-150 motion-reduce:transition-none`,`hover:text-white hover:bg-white/10 cursor-pointer`),title:e.displayModel,"data-testid":`chat-input-llm-model`,"aria-expanded":t,"aria-haspopup":`dialog`,onClick:e=>{e.preventDefault(),e.stopPropagation(),n(e=>!e)},children:[(0,g.jsx)(`span`,{children:c}),(0,g.jsx)(o.ComboboxCaretInline,{isOpen:t})]}),t&&(0,g.jsx)(s.ContextMenu,{ref:a,testId:`chat-input-llm-model-popover`,position:`top`,alignment:`left`,spacing:`none`,className:`z-[60] mb-2 min-w-[200px] max-w-[320px] max-h-[60vh] overflow-y-auto`,children:(0,g.jsx)(b,{model:e,onClose:()=>n(!1)})})]})}exports.ChatInputModel=x,exports.ChatInputModelMenuContent=b;
2
2
  //# sourceMappingURL=chat-input-model.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"chat-input-model.cjs","names":[],"sources":["../../../../../src/components/features/chat/components/chat-input-model.tsx"],"sourcesContent":["import { useActiveConversation } from \"#/hooks/query/use-active-conversation\";\nimport { useSettings } from \"#/hooks/query/use-settings\";\nimport { useAcpModelContext } from \"#/hooks/use-acp-model-context\";\nimport { ComboboxCaretInline } from \"#/ui/combobox-caret\";\nimport SettingsGearIcon from \"#/icons/settings-gear.svg?react\";\nimport { useClickOutsideElement } from \"#/hooks/use-click-outside-element\";\nimport { NavigationLink } from \"#/components/shared/navigation-link\";\nimport { ContextMenu } from \"#/ui/context-menu\";\nimport { Divider } from \"#/ui/divider\";\nimport {\n getAcpProvider,\n labelForAcpModel,\n resolveEffectiveAcpModel,\n} from \"#/constants/acp-providers\";\nimport { cn } from \"#/utils/utils\";\nimport React from \"react\";\n\nconst MODEL_LABEL_MAX_CHARS = 10;\n// ACP surfaces show the provider's human label (e.g. \"Claude Opus 4.7\"),\n// which is longer than a raw model id, so the inline button gets a wider cap\n// before truncating. The full string still shows in the title + popover.\nconst ACP_MODEL_LABEL_MAX_CHARS = 22;\n\nfunction truncateModelLabel(\n model: string,\n maxChars: number = MODEL_LABEL_MAX_CHARS,\n): string {\n if (model.length <= maxChars) {\n return model;\n }\n return `${model.slice(0, maxChars)}…`;\n}\n\nexport function ChatInputModel() {\n const { data: conversation } = useActiveConversation();\n // Home page has no active conversation; fall back to the user's default\n // model so the switcher renders consistently across both surfaces.\n const { data: settings } = useSettings();\n const {\n isActiveAcpConversation,\n isHomeAcp,\n isAcpContext,\n destinationPath,\n destinationLabel,\n } = useAcpModelContext();\n // ACP conversations do not use the OpenHands LLM profile. Resolve the model\n // label through the shared helper so the displayed value matches what the\n // conversation-creation path will actually send to the agent-server (the\n // helper applies provider defaults + filters out the SDK ``\"default\"``\n // placeholders + the ``\"acp-managed\"`` sentinel).\n //\n // The ACP server key whose registry owns the model label comes off the\n // active conversation when there is one, else the saved agent settings the\n // next home-page conversation will inherit.\n const acpServerKey = isActiveAcpConversation\n ? conversation?.acp_server\n : isHomeAcp\n ? typeof settings?.agent_settings?.acp_server === \"string\"\n ? settings.agent_settings.acp_server\n : null\n : null;\n const acpProvider = isHomeAcp ? getAcpProvider(acpServerKey) : undefined;\n let llmModel: string | null | undefined;\n if (isActiveAcpConversation) {\n llmModel = conversation?.llm_model;\n } else if (isHomeAcp) {\n llmModel = resolveEffectiveAcpModel({\n configured:\n typeof settings?.agent_settings?.acp_model === \"string\"\n ? settings.agent_settings.acp_model\n : null,\n providerDefault: acpProvider?.default_model,\n });\n } else {\n llmModel = conversation?.llm_model ?? settings?.llm_model;\n }\n const [isPopoverOpen, setIsPopoverOpen] = React.useState(false);\n\n const popoverRef = useClickOutsideElement<HTMLUListElement>(() => {\n setIsPopoverOpen(false);\n });\n\n if (!llmModel) {\n return null;\n }\n // For ACP, surface the provider's human label (matching the conversation\n // list chip) instead of the raw ``acp_model`` id; falls back to the raw\n // value for custom / unknown ids. OpenHands keeps the raw model string.\n const displayModel = isAcpContext\n ? (labelForAcpModel(acpServerKey, llmModel) ?? llmModel)\n : llmModel;\n const truncatedModelLabel = truncateModelLabel(\n displayModel,\n isAcpContext ? ACP_MODEL_LABEL_MAX_CHARS : MODEL_LABEL_MAX_CHARS,\n );\n\n return (\n <div className=\"relative min-w-0\">\n <button\n type=\"button\"\n className={cn(\n \"inline-flex items-center gap-1 rounded-[100px] border border-transparent px-1.5 text-sm font-normal leading-5 text-[var(--oh-muted)] whitespace-nowrap min-w-0 transition-[border-color,background-color,box-shadow,opacity] duration-150 motion-reduce:transition-none\",\n \"hover:text-white hover:bg-white/10 cursor-pointer\",\n )}\n title={displayModel}\n data-testid=\"chat-input-llm-model\"\n aria-expanded={isPopoverOpen}\n aria-haspopup=\"dialog\"\n onClick={(event) => {\n event.preventDefault();\n event.stopPropagation();\n setIsPopoverOpen((open) => !open);\n }}\n >\n <span>{truncatedModelLabel}</span>\n <ComboboxCaretInline isOpen={isPopoverOpen} />\n </button>\n\n {isPopoverOpen && (\n <ContextMenu\n ref={popoverRef}\n testId=\"chat-input-llm-model-popover\"\n position=\"top\"\n alignment=\"left\"\n spacing=\"none\"\n className=\"z-[60] mb-2 min-w-[200px] max-w-[320px]\"\n >\n <li className=\"text-sm\">\n <div className=\"p-2 leading-5 text-white break-all\">\n {displayModel}\n </div>\n </li>\n <Divider />\n <li className=\"text-sm\">\n <NavigationLink\n to={destinationPath}\n onClick={() => setIsPopoverOpen(false)}\n className=\"flex h-[30px] items-center gap-2 rounded p-2 leading-5 text-white hover:bg-[var(--oh-interactive-hover)] transition-colors\"\n >\n <SettingsGearIcon\n width={16}\n height={16}\n className=\"shrink-0\"\n aria-hidden\n />\n <span>{destinationLabel}</span>\n </NavigationLink>\n </li>\n </ContextMenu>\n )}\n </div>\n );\n}\n"],"mappings":"0rBAiBA,IAAM,EAAwB,GAIxB,EAA4B,GAElC,SAAS,EACP,EACA,EAAmB,EACX,CAIR,OAHI,EAAM,QAAU,EACX,EAEF,GAAG,EAAM,MAAM,EAAG,EAAS,CAAC,GAGrC,SAAgB,GAAiB,CAC/B,GAAM,CAAE,KAAM,GAAiB,EAAA,uBAAuB,CAGhD,CAAE,KAAM,GAAa,EAAA,aAAa,CAClC,CACJ,0BACA,YACA,eACA,kBACA,oBACE,EAAA,oBAAoB,CAUlB,EAAe,EACjB,GAAc,WACd,GACE,OAAO,GAAU,gBAAgB,YAAe,SAC9C,EAAS,eAAe,WACxB,KAEF,EAAc,EAAY,EAAA,eAAe,EAAa,CAAG,IAAA,GAC3D,EACJ,AAWE,EAXE,EACS,GAAc,UAChB,EACE,EAAA,yBAAyB,CAClC,WACE,OAAO,GAAU,gBAAgB,WAAc,SAC3C,EAAS,eAAe,UACxB,KACN,gBAAiB,GAAa,cAC/B,CAAC,CAES,GAAc,WAAa,GAAU,UAElD,GAAM,CAAC,EAAe,GAAoB,EAAA,QAAM,SAAS,GAAM,CAEzD,EAAa,EAAA,2BAA+C,CAChE,EAAiB,GAAM,EACvB,CAEF,GAAI,CAAC,EACH,OAAO,KAKT,IAAM,EAAe,EAChB,EAAA,iBAAiB,EAAc,EAAS,EAAI,EAC7C,EACE,EAAsB,EAC1B,EACA,EAAe,EAA4B,EAC5C,CAED,OACE,EAAA,EAAA,MAAC,MAAD,CAAK,UAAU,4BAAf,EACE,EAAA,EAAA,MAAC,SAAD,CACE,KAAK,SACL,UAAW,EAAA,GACT,0QACA,oDACD,CACD,MAAO,EACP,cAAY,uBACZ,gBAAe,EACf,gBAAc,SACd,QAAU,GAAU,CAClB,EAAM,gBAAgB,CACtB,EAAM,iBAAiB,CACvB,EAAkB,GAAS,CAAC,EAAK,WAbrC,EAgBE,EAAA,EAAA,KAAC,OAAD,CAAA,SAAO,EAA2B,CAAA,EAClC,EAAA,EAAA,KAAC,EAAA,oBAAD,CAAqB,OAAQ,EAAiB,CAAA,CACvC,GAER,IACC,EAAA,EAAA,MAAC,EAAA,YAAD,CACE,IAAK,EACL,OAAO,+BACP,SAAS,MACT,UAAU,OACV,QAAQ,OACR,UAAU,mDANZ,EAQE,EAAA,EAAA,KAAC,KAAD,CAAI,UAAU,oBACZ,EAAA,EAAA,KAAC,MAAD,CAAK,UAAU,8CACZ,EACG,CAAA,CACH,CAAA,EACL,EAAA,EAAA,KAAC,EAAA,QAAD,EAAW,CAAA,EACX,EAAA,EAAA,KAAC,KAAD,CAAI,UAAU,oBACZ,EAAA,EAAA,MAAC,EAAA,eAAD,CACE,GAAI,EACJ,YAAe,EAAiB,GAAM,CACtC,UAAU,sIAHZ,EAKE,EAAA,EAAA,KAAC,EAAA,QAAD,CACE,MAAO,GACP,OAAQ,GACR,UAAU,WACV,cAAA,GACA,CAAA,EACF,EAAA,EAAA,KAAC,OAAD,CAAA,SAAO,EAAwB,CAAA,CAChB,GACd,CAAA,CACO,GAEZ"}
1
+ {"version":3,"file":"chat-input-model.cjs","names":[],"sources":["../../../../../src/components/features/chat/components/chat-input-model.tsx"],"sourcesContent":["import { useTranslation } from \"react-i18next\";\nimport {\n useChatInputModelState,\n type ChatInputModelState,\n} from \"#/hooks/use-chat-input-model-state\";\nimport { useSwitchAcpModel } from \"#/hooks/mutation/use-switch-acp-model\";\nimport { ComboboxCaretInline } from \"#/ui/combobox-caret\";\nimport SettingsGearIcon from \"#/icons/settings-gear.svg?react\";\nimport CheckIcon from \"#/icons/checkmark.svg?react\";\nimport { useClickOutsideElement } from \"#/hooks/use-click-outside-element\";\nimport { NavigationLink } from \"#/components/shared/navigation-link\";\nimport { ContextMenu } from \"#/ui/context-menu\";\nimport { ContextMenuListItem } from \"#/components/features/context-menu/context-menu-list-item\";\nimport { Divider } from \"#/ui/divider\";\nimport { Typography } from \"#/ui/typography\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { cn } from \"#/utils/utils\";\nimport React from \"react\";\n\nconst MODEL_LABEL_MAX_CHARS = 10;\n// ACP surfaces show the provider's human label (e.g. \"Claude Opus 4.7\"),\n// which is longer than a raw model id, so the inline button gets a wider cap\n// before truncating. The full string still shows in the title + popover.\nconst ACP_MODEL_LABEL_MAX_CHARS = 22;\n\nfunction truncateModelLabel(\n model: string,\n maxChars: number = MODEL_LABEL_MAX_CHARS,\n): string {\n if (model.length <= maxChars) {\n return model;\n }\n return `${model.slice(0, maxChars)}…`;\n}\n\ninterface ChatInputModelMenuContentProps {\n model: ChatInputModelState;\n onClose: () => void;\n dividerInset?: \"menu\";\n settingsLinkClassName?: string;\n settingsIconClassName?: string;\n}\n\nexport function ChatInputModelMenuContent({\n model,\n onClose,\n dividerInset,\n settingsLinkClassName,\n settingsIconClassName,\n}: ChatInputModelMenuContentProps) {\n const { t } = useTranslation(\"openhands\");\n const switchAcpModel = useSwitchAcpModel();\n const hasModelRows = model.showAcpPicker || Boolean(model.displayModel);\n\n const handleSelectAcpModel = (modelId: string) => {\n if (modelId !== model.currentModelId) {\n switchAcpModel.mutate({\n conversationId: model.switchConversationId,\n model: modelId,\n });\n }\n onClose();\n };\n\n return (\n <>\n {model.showAcpPicker ? (\n <>\n {/* role=\"presentation\" keeps this a valid <li> child of the\n ContextMenu <ul> without exposing the section label as a\n selectable menu item (the label text is still announced). */}\n <li role=\"presentation\" className=\"px-2 pt-1 pb-0.5\">\n <Typography.Text className=\"text-[11px] font-medium text-[var(--oh-text-dim)] uppercase tracking-wide leading-4\">\n {t(I18nKey.MODEL$AVAILABLE_MODELS)}\n </Typography.Text>\n </li>\n {model.availableAcpModels.map((option) => {\n const isSelected = option.id === model.currentModelId;\n return (\n <ContextMenuListItem\n key={option.id}\n testId={`chat-input-acp-model-option-${option.id}`}\n onClick={(event) => {\n event.preventDefault();\n event.stopPropagation();\n handleSelectAcpModel(option.id);\n }}\n className={cn(\n \"flex items-center gap-2\",\n isSelected && \"bg-[var(--oh-interactive-hover)]\",\n )}\n >\n <span\n className=\"flex-1 truncate text-sm leading-5\"\n title={option.label}\n >\n {option.label}\n </span>\n {isSelected && (\n <CheckIcon\n width={14}\n height={14}\n className=\"shrink-0\"\n aria-hidden\n />\n )}\n </ContextMenuListItem>\n );\n })}\n </>\n ) : model.displayModel ? (\n <li className=\"text-sm\">\n <div className=\"p-2 leading-5 text-[var(--oh-foreground)] break-all\">\n {model.displayModel}\n </div>\n </li>\n ) : null}\n {hasModelRows && <Divider inset={dividerInset} />}\n <li className=\"text-sm\">\n <NavigationLink\n to={model.destinationPath}\n onClick={onClose}\n className={cn(\n \"flex h-[30px] items-center gap-2 rounded p-2 leading-5 text-[var(--oh-foreground)] hover:bg-[var(--oh-interactive-hover)] transition-colors\",\n settingsLinkClassName,\n )}\n >\n <SettingsGearIcon\n width={16}\n height={16}\n className={cn(\"shrink-0\", settingsIconClassName)}\n aria-hidden\n />\n <span>{model.destinationLabel}</span>\n </NavigationLink>\n </li>\n </>\n );\n}\n\nexport function ChatInputModel() {\n const model = useChatInputModelState();\n const [isPopoverOpen, setIsPopoverOpen] = React.useState(false);\n const triggerRef = React.useRef<HTMLButtonElement>(null);\n const popoverRef = useClickOutsideElement<HTMLUListElement>(\n () => setIsPopoverOpen(false),\n triggerRef,\n );\n\n if (!model.displayModel) {\n return null;\n }\n\n const truncatedModelLabel = truncateModelLabel(\n model.displayModel,\n model.isAcpContext ? ACP_MODEL_LABEL_MAX_CHARS : MODEL_LABEL_MAX_CHARS,\n );\n\n return (\n <div className=\"relative min-w-0\">\n <button\n ref={triggerRef}\n type=\"button\"\n className={cn(\n \"inline-flex items-center gap-1 rounded-[100px] border border-transparent px-1.5 text-sm font-normal leading-5 text-[var(--oh-muted)] whitespace-nowrap min-w-0 transition-[border-color,background-color,box-shadow,opacity] duration-150 motion-reduce:transition-none\",\n \"hover:text-white hover:bg-white/10 cursor-pointer\",\n )}\n title={model.displayModel}\n data-testid=\"chat-input-llm-model\"\n aria-expanded={isPopoverOpen}\n aria-haspopup=\"dialog\"\n onClick={(event) => {\n event.preventDefault();\n event.stopPropagation();\n setIsPopoverOpen((open) => !open);\n }}\n >\n <span>{truncatedModelLabel}</span>\n <ComboboxCaretInline isOpen={isPopoverOpen} />\n </button>\n\n {isPopoverOpen && (\n <ContextMenu\n ref={popoverRef}\n testId=\"chat-input-llm-model-popover\"\n position=\"top\"\n alignment=\"left\"\n spacing=\"none\"\n className=\"z-[60] mb-2 min-w-[200px] max-w-[320px] max-h-[60vh] overflow-y-auto\"\n >\n <ChatInputModelMenuContent\n model={model}\n onClose={() => setIsPopoverOpen(false)}\n />\n </ContextMenu>\n )}\n </div>\n );\n}\n"],"mappings":"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"}