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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (802) hide show
  1. package/README.md +24 -7
  2. package/README.windows.md +27 -0
  3. package/bin/agent-canvas.mjs +26 -3
  4. package/build/assets/{QueryClientProvider-CkGuhXg-.js → QueryClientProvider-Cnr-Yl3j.js} +1 -1
  5. package/build/assets/{Trans-Cvm_-SMi.js → Trans-4jmk54WC.js} +1 -1
  6. package/build/assets/acp-providers-CPdgcp13.js +1 -0
  7. package/build/assets/{acp-route-guard-B2yoBZ_4.js → acp-route-guard-BoVmCn0e.js} +1 -1
  8. package/build/assets/active-backend-context-Beu-LZL-.js +1 -0
  9. package/build/assets/add-backend-modal-BheqYXHK.js +1 -0
  10. package/build/assets/agent-server-client-options-HEOwGVIU.js +1 -0
  11. package/build/assets/agent-server-compatibility-CdI3N7dr.js +1 -0
  12. package/build/assets/agent-server-conversation-service.api-CORdqJZg.js +5 -0
  13. package/build/assets/{agent-settings-CnGSCmK8.js → agent-settings-UFvcGjoI.js} +1 -1
  14. package/build/assets/{alert-banner-DtzAX654.js → alert-banner-DFnn_lC6.js} +1 -1
  15. package/build/assets/{analytics-consent-form-modal-CHZ3I37v.js → analytics-consent-form-modal-CVNugqzu.js} +1 -1
  16. package/build/assets/api-key-entry-screen-M6su2VSf.js +1 -0
  17. package/build/assets/{app-settings-Db9ITeJH.js → app-settings-BlvBhBdc.js} +1 -1
  18. package/build/assets/automation-detail-BWrQk4Oa.js +1 -0
  19. package/build/assets/automations-list-ux9KvYsU.js +1 -0
  20. package/build/assets/back-nav-button-7dQJ2k3O.js +1 -0
  21. package/build/assets/backend-form-modal-CDnEYjaU.js +1 -0
  22. package/build/assets/{backend-synced-settings-badge-Dc6c7GT4.js → backend-synced-settings-badge-BTIj-Ffq.js} +1 -1
  23. package/build/assets/base-modal-C2oy2EBG.js +1 -0
  24. package/build/assets/brand-button-DJ_S16rO.js +1 -0
  25. package/build/assets/{browser-D810xUYt.js → browser-CGM-k-sH.js} +2 -2
  26. package/build/assets/browser-store-DAsixKdU.js +1 -0
  27. package/build/assets/{browser-tab-B-aIqXRl.js → browser-tab-dvSPdvkm.js} +1 -1
  28. package/build/assets/{checkmark-DL7acQA7.js → checkmark-Dus0b6jt.js} +1 -1
  29. package/build/assets/{chevron-left-small-CVWf8TI6.js → chevron-left-small-_uvG7RVM.js} +1 -1
  30. package/build/assets/{circle-plus-check-toggle-P7ZZToV4.js → circle-plus-check-toggle-DKS8MAVV.js} +1 -1
  31. package/build/assets/{close-B5LROHR3.js → close-BU5iTc66.js} +1 -1
  32. package/build/assets/code-tag-BzyqOtPD.js +1 -0
  33. package/build/assets/combobox-caret-BJC7XJsz.js +1 -0
  34. package/build/assets/{command-store-DFN_17p1.js → command-store-CE1weJy8.js} +1 -1
  35. package/build/assets/{condenser-settings-wnEKhBof.js → condenser-settings-BolbDvm5.js} +1 -1
  36. package/build/assets/{confirmation-modal-Dau3w_sa.js → confirmation-modal-B5Ca6qFE.js} +1 -1
  37. package/build/assets/context-menu-list-item-7tAcm2c3.js +1 -0
  38. package/build/assets/conversation-D0N4dw_p.js +19 -0
  39. package/build/assets/conversation-DhRJuZLG.js +1 -0
  40. package/build/assets/conversation-panel-CNqHbS_Z.js +1 -0
  41. package/build/assets/conversation-service.api-BsJy6uuL.js +1 -0
  42. package/build/assets/conversation-state-store-D-w0uurj.js +1 -0
  43. package/build/assets/conversation-store-CC-isCnP.js +1 -0
  44. package/build/assets/{conversation-tab-empty-state-DyssnnWa.js → conversation-tab-empty-state-CStQLPVW.js} +1 -1
  45. package/build/assets/conversation-websocket-context-DvHgx_FE.js +3 -0
  46. package/build/assets/{copy-DYgmUdIw.js → copy-Chg-sFu3.js} +1 -1
  47. package/build/assets/{custom-toast-handlers-C-SZFmto.js → custom-toast-handlers-ufGJ6_Rc.js} +1 -1
  48. package/build/assets/declaration-CR6HMp29.js +1 -0
  49. package/build/assets/{device-verify-DqDlphsG.js → device-verify-C6mj28zv.js} +1 -1
  50. package/build/assets/dist-DNeWJ2bh.js +1 -0
  51. package/build/assets/dropdown-classes-BsVmxlNG.js +1 -0
  52. package/build/assets/edit-automation-modal-BpX-t-HD.js +1 -0
  53. package/build/assets/ellipsis-button-Vh5MvRZa.js +1 -0
  54. package/build/assets/entry.client-Ck9rQCg-.js +2 -0
  55. package/build/assets/enum-filter-dropdown-5JeF2RLb.js +1 -0
  56. package/build/assets/{environment-switch-overlay-XL8yCGP6.js → environment-switch-overlay-Tf_BIfeR.js} +1 -1
  57. package/build/assets/extensions-hub-CE9QOb5n.js +1 -0
  58. package/build/assets/{extensions-navigation-BYR8Giqq.js → extensions-navigation-DSLGNGbS.js} +1 -1
  59. package/build/assets/file-BTY6Gyy9.js +1 -0
  60. package/build/assets/files-tab-cL668j1I.js +1 -0
  61. package/build/assets/files-tab-store-m0ARqX_E.js +1 -0
  62. package/build/assets/{folder-ZZJVGgd7.js → folder-D1T2W1cj.js} +1 -1
  63. package/build/assets/git-control-bar-branch-button-DtIrOrie.js +27 -0
  64. package/build/assets/git-provider-icon-CHdGBdU2.js +1 -0
  65. package/build/assets/globe-Bzj_0oXT.js +1 -0
  66. package/build/assets/home-Cz2Veg56.js +1 -0
  67. package/build/assets/{i18n-CTohRuoO.js → i18n-DET2iOyh.js} +1 -1
  68. package/build/assets/install-server-modal-B9nXCS3u.js +1 -0
  69. package/build/assets/launch-CWz0dm4o.js +1 -0
  70. package/build/assets/{lesson-plan-dH5Bj0pN.js → lesson-plan-duSsqWVs.js} +1 -1
  71. package/build/assets/link-external-DGxVm4Ps.js +1 -0
  72. package/build/assets/{llm-client-DaH1TuyR.js → llm-client-CYEaUjGx.js} +1 -1
  73. package/build/assets/llm-settings-DFkXHuvT.js +1 -0
  74. package/build/assets/llm-settings-DhrdCXqX.js +1 -0
  75. package/build/assets/{loading-spinner-BPtYORNK.js → loading-spinner-5GT9q1xy.js} +1 -1
  76. package/build/assets/manage-backends-modal-DpBD_vR9.js +1 -0
  77. package/build/assets/manage-workspaces-modal-CtRbxREx.js +1 -0
  78. package/build/assets/manifest-eed90ff5.js +1 -0
  79. package/build/assets/{markdown-renderer-DMzf2i4x.js → markdown-renderer-B3IAVfv4.js} +1 -1
  80. package/build/assets/mcp-BUe7kiYM.js +9 -0
  81. package/build/assets/messages-dqp_KYyl.js +36 -0
  82. package/build/assets/{modal-backdrop-BAbgYsqB.js → modal-backdrop-RfNCrSpK.js} +1 -1
  83. package/build/assets/{modal-body-BI6Ru2Qr.js → modal-body-aoa2fx5W.js} +1 -1
  84. package/build/assets/modal-classes-6YqcqA6y.js +1 -0
  85. package/build/assets/{modal-close-button-t1Gh3qmL.js → modal-close-button-CtWOUMmw.js} +1 -1
  86. package/build/assets/{model-selector-SM9IUz-q.js → model-selector-BvSTrkhT.js} +1 -1
  87. package/build/assets/{navigation-context-D0YWpT8d.js → navigation-context-BdKYH32C.js} +1 -1
  88. package/build/assets/{navigation-link-Cn7KP3c5.js → navigation-link-U4vY9i_C.js} +1 -1
  89. package/build/assets/{openhands-logo-CnrF6LKb.js → openhands-logo-CCo0wJZX.js} +1 -1
  90. package/build/assets/{option-service.api-KvY_mZMY.js → option-service.api-DmNVxAvS.js} +1 -1
  91. package/build/assets/{organization-service.api-DzYTHTYC.js → organization-service.api-DbnougaQ.js} +1 -1
  92. package/build/assets/{path-utils-C3bQf6lJ.js → path-utils-onx24uF5.js} +1 -1
  93. package/build/assets/{plan-components-atxXCF0R.js → plan-components-CRDMQzsS.js} +1 -1
  94. package/build/assets/{planner-tab-BlrCpv-7.js → planner-tab-CmIjLz7q.js} +1 -1
  95. package/build/assets/{profiles-client-D6IkTJof.js → profiles-client-fEmgWkCW.js} +1 -1
  96. package/build/assets/{providers-Bx6EfrzZ.js → providers-CbD7fiic.js} +1 -1
  97. package/build/assets/proxy-BAdHH8QB.js +1 -0
  98. package/build/assets/{query-client-config-B7u9asM0.js → query-client-config-CRnGSujB.js} +1 -1
  99. package/build/assets/{recommended-automations-launcher-CgV8FyPK.js → recommended-automations-launcher-uTyODuzB.js} +3 -3
  100. package/build/assets/{root-dNntxffj.js → root-DmjpFpTu.js} +2 -2
  101. package/build/assets/root-Z2VHU4R3.css +1 -0
  102. package/build/assets/root-layout-DejMsKhy.js +2 -0
  103. package/build/assets/{sdk-section-page-DOIKvwSL.js → sdk-section-page-BgDlMhcq.js} +1 -1
  104. package/build/assets/{sdk-settings-schema-DsUf9wu1.js → sdk-settings-schema-CLmJ9sho.js} +1 -1
  105. package/build/assets/{search-27Owlc3A.js → search-SuJctqNJ.js} +1 -1
  106. package/build/assets/secrets-service-B7CxNinp.js +1 -0
  107. package/build/assets/secrets-settings-yK7CqIpm.js +1 -0
  108. package/build/assets/{server-client-DyAQ3NZ_.js → server-client-Kh4QSwDJ.js} +1 -1
  109. package/build/assets/{settings-BYkVX7vW.js → settings-DN5PpgRD.js} +1 -1
  110. package/build/assets/{settings-dropdown-input-BJYvGdg-.js → settings-dropdown-input-BtoovFre.js} +1 -1
  111. package/build/assets/{settings-gear-C77PgE_O.js → settings-gear-Dd8K2_8B.js} +1 -1
  112. package/build/assets/settings-index-DKC8IY1P.js +1 -0
  113. package/build/assets/{settings-input-Bn7F5C75.js → settings-input-CehsXnb3.js} +1 -1
  114. package/build/assets/settings-list-classes-E3v_f6QG.js +1 -0
  115. package/build/assets/settings-modal-DJ4kGzUx.js +1 -0
  116. package/build/assets/{settings-section-header-context-BgZe5YkE.js → settings-section-header-context-DewwJ0-F.js} +1 -1
  117. package/build/assets/settings-service.api-C3rxTtPj.js +1 -0
  118. package/build/assets/{settings-switch-BeIKrWms.js → settings-switch-BiBuS3xa.js} +1 -1
  119. package/build/assets/{settings-utils-B6Nl07io.js → settings-utils-DY04tWG1.js} +1 -1
  120. package/build/assets/{shared-conversation-AMyqXvpk.js → shared-conversation-h9YnBtCU.js} +1 -1
  121. package/build/assets/sidebar-mobile-menu-toggle-D0-AvsnT.js +1 -0
  122. package/build/assets/{sidebar-nav-link-BGjiJq-4.js → sidebar-nav-link-OhIeFyna.js} +1 -1
  123. package/build/assets/{sidebar-store-Uy3v0AOV.js → sidebar-store-DnQAJAE5.js} +1 -1
  124. package/build/assets/{skill-card-pill-row-DF1axQCG.js → skill-card-pill-row-BW9qvhoK.js} +1 -1
  125. package/build/assets/{skills-ChIKZPK4.js → skills-0GRKX5Xj.js} +1 -1
  126. package/build/assets/{skills-plugins-CcI_19lM.js → skills-plugins-DNcsNF88.js} +1 -1
  127. package/build/assets/skills-settings-7liFiSY6.js +2 -0
  128. package/build/assets/{styled-tooltip-CBzrri6o.js → styled-tooltip-hdfMXPQC.js} +1 -1
  129. package/build/assets/{switch-skeleton-DnC9wLp7.js → switch-skeleton-DSKqSx2A.js} +1 -1
  130. package/build/assets/{task-list-tab-DUJn1sgz.js → task-list-tab-DT6_zfUs.js} +1 -1
  131. package/build/assets/{terminal-DgQk1Ay6.js → terminal-CDhQGDua.js} +2 -2
  132. package/build/assets/{terminal-RmuaSdhJ.js → terminal-CPYWdo4j.js} +1 -1
  133. package/build/assets/{toggle-switch-Pvyp2RAN.js → toggle-switch-T2v6sJ6l.js} +1 -1
  134. package/build/assets/{typography-gpuWmrQO.js → typography-BDgnT7Yp.js} +1 -1
  135. package/build/assets/{u-check-circle-IUIfACQQ.js → u-check-circle-DOauqQKb.js} +1 -1
  136. package/build/assets/{u-check-circle-half-C1YxB6py.js → u-check-circle-half-steSK_JB.js} +1 -1
  137. package/build/assets/{u-circuit-BmVikJHu.js → u-circuit-x3ExjBbU.js} +1 -1
  138. package/build/assets/{u-edit-CFvXHqZk.js → u-edit-BbrptMCa.js} +1 -1
  139. package/build/assets/{use-active-conversation-BEFNwnFk.js → use-active-conversation-DHGcmjCK.js} +1 -1
  140. package/build/assets/use-agent-settings-schema-CLoTOSJI.js +1 -0
  141. package/build/assets/{use-agent-state-Bkrd1FZq.js → use-agent-state-PKrUPMJ3.js} +1 -1
  142. package/build/assets/{use-cloud-current-user-id-CvkXFnTT.js → use-cloud-current-user-id-Ddr75hEz.js} +1 -1
  143. package/build/assets/{use-config-Co1O8-Ey.js → use-config-OIMQLQ2s.js} +1 -1
  144. package/build/assets/{use-create-conversation-CEgXpkfH.js → use-create-conversation-Bszyp13O.js} +1 -1
  145. package/build/assets/{use-event-store-BT_gV3ut.js → use-event-store-BomO7ywK.js} +1 -1
  146. package/build/assets/{use-get-secrets-DuhdIA59.js → use-get-secrets-8Jby8ele.js} +1 -1
  147. package/build/assets/{use-handle-plan-click-Ckkm5eIY.js → use-handle-plan-click-CohJPvvW.js} +1 -1
  148. package/build/assets/use-is-authed-dw2026rR.js +1 -0
  149. package/build/assets/{use-is-creating-conversation-BZ5hB_Bg.js → use-is-creating-conversation-DX2qSlfL.js} +1 -1
  150. package/build/assets/{use-launch-skill-in-chat-fNN_xGZG.js → use-launch-skill-in-chat-sQNEOLGD.js} +1 -1
  151. package/build/assets/use-llm-profiles-C861aFAq.js +1 -0
  152. package/build/assets/use-runtime-is-ready-Do2h_hRl.js +1 -0
  153. package/build/assets/{use-save-settings-VUrj_QNG.js → use-save-settings-DkAOEfD9.js} +1 -1
  154. package/build/assets/use-settings-D5hbTS9t.js +1 -0
  155. package/build/assets/{use-settings-nav-items-1ZvovKSr.js → use-settings-nav-items-BcSbo02d.js} +1 -1
  156. package/build/assets/{use-skills-DAMLFjKU.js → use-skills-D7PS0fH0.js} +1 -1
  157. package/build/assets/{use-task-list-CLJbuJgM.js → use-task-list-CsT10CBb.js} +1 -1
  158. package/build/assets/{use-unified-vscode-url-DdSRw-6P.js → use-unified-vscode-url-DEoe-NRI.js} +1 -1
  159. package/build/assets/use-user-conversation-Cs5H1pUF.js +1 -0
  160. package/build/assets/{useMutation-DqrumCWD.js → useMutation-GSSKKebK.js} +1 -1
  161. package/build/assets/{useTranslation-DCOdSSMl.js → useTranslation-B6voJV4y.js} +1 -1
  162. package/build/assets/utils-DCVfKFRt.js +1 -0
  163. package/build/assets/{vendor~browser-BNjNhjFU.js → vendor~browser-BrOJLj3y.js} +1 -1
  164. package/build/assets/vendor~conversation-panel~conversation-C9o-K1hW.js +1 -0
  165. package/build/assets/vendor~conversation-panel~conversation~index-RXYdJYxU.js +1 -0
  166. package/build/assets/{vendor~entry.client~root~root-layout~home~conversation-panel~conversation~launch~skills-set~jfc6hidu-VnmIZrq3.js → vendor~entry.client~root~root-layout~home~conversation-panel~conversation~launch~skills-set~jfc6hidu-DJS-rJdI.js} +1 -1
  167. package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-DpAdkv8m.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-6ByzelMS.js} +1 -1
  168. package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-B92czPCF.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-BED5W_c4.js} +1 -1
  169. package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-By5W2oHN.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-CCbqAFiI.js} +1 -1
  170. package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-BbFOrAjI.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-CG96FCly.js} +1 -1
  171. package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-smY2r837.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-E4d6IEfI.js} +1 -1
  172. package/build/assets/{vendor~home~mcp~automations-list-Cs-TO3fK.js → vendor~home~mcp~automations-list-CZSK-lT2.js} +1 -1
  173. package/build/assets/{vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-Z3nsiNNq.js → vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-CjJdFLoM.js} +1 -1
  174. package/build/assets/{vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-DbfELDJu.js → vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-m8dOii0J.js} +2 -2
  175. package/build/assets/{vendor~root-layout~home~conversation-panel~conversation-DjAjXS5J.js → vendor~root-layout~home~conversation-panel~conversation-B5WNMnt4.js} +1 -1
  176. package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~i4kjfqhl-CbAhtEMv.js +1 -0
  177. package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-6Rm8U_Sr.js +9 -0
  178. package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-BkQGKpye.js → vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-tTR8C6m0.js} +1 -1
  179. package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~k776hupu-Bbs7UJ5U.js → vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~k776hupu-BJbu9kpL.js} +2 -2
  180. package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~dp08i1qy-DTwbEEcX.js → vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~dp08i1qy-hTzSytKK.js} +1 -1
  181. package/build/assets/{vendor~root~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-s~f2l2lr17-CDXvdvb2.js → vendor~root~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-s~f2l2lr17-DYXOLEck.js} +1 -1
  182. package/build/assets/{verification-settings-CsbvQcYS.js → verification-settings-Dlt8pINd.js} +1 -1
  183. package/build/assets/{vscode-tab-DjNArCgY.js → vscode-tab-DgepcYtF.js} +1 -1
  184. package/build/assets/{waiting-for-runtime-message-CntjExbU.js → waiting-for-runtime-message-CdK3btDZ.js} +1 -1
  185. package/build/assets/{x-mark-CrpjscNc.js → x-mark-BrkSPIiT.js} +1 -1
  186. package/build/index.html +4 -4
  187. package/build/locales/ar/openhands.json +20 -2
  188. package/build/locales/ca/openhands.json +20 -2
  189. package/build/locales/de/openhands.json +20 -2
  190. package/build/locales/en/openhands.json +20 -2
  191. package/build/locales/es/openhands.json +20 -2
  192. package/build/locales/fr/openhands.json +20 -2
  193. package/build/locales/it/openhands.json +20 -2
  194. package/build/locales/ja/openhands.json +20 -2
  195. package/build/locales/ko-KR/openhands.json +20 -2
  196. package/build/locales/no/openhands.json +20 -2
  197. package/build/locales/pt/openhands.json +20 -2
  198. package/build/locales/tr/openhands.json +20 -2
  199. package/build/locales/uk/openhands.json +20 -2
  200. package/build/locales/zh-CN/openhands.json +20 -2
  201. package/build/locales/zh-TW/openhands.json +20 -2
  202. package/dist/api/acp-service/acp-service.api.d.ts +18 -0
  203. package/dist/api/agent-server-adapter.cjs +3 -3
  204. package/dist/api/agent-server-adapter.cjs.map +1 -1
  205. package/dist/api/agent-server-adapter.js +54 -55
  206. package/dist/api/agent-server-adapter.js.map +1 -1
  207. package/dist/api/agent-server-client-options.cjs +1 -1
  208. package/dist/api/agent-server-client-options.cjs.map +1 -1
  209. package/dist/api/agent-server-client-options.d.ts +4 -0
  210. package/dist/api/agent-server-client-options.js +18 -12
  211. package/dist/api/agent-server-client-options.js.map +1 -1
  212. package/dist/api/agent-server-compatibility.cjs +1 -1
  213. package/dist/api/agent-server-compatibility.cjs.map +1 -1
  214. package/dist/api/agent-server-compatibility.d.ts +1 -1
  215. package/dist/api/agent-server-compatibility.js +30 -25
  216. package/dist/api/agent-server-compatibility.js.map +1 -1
  217. package/dist/api/agent-server-config.cjs +1 -1
  218. package/dist/api/agent-server-config.cjs.map +1 -1
  219. package/dist/api/agent-server-config.d.ts +1 -51
  220. package/dist/api/agent-server-config.js +20 -70
  221. package/dist/api/agent-server-config.js.map +1 -1
  222. package/dist/api/backend-registry/active-store.cjs +1 -1
  223. package/dist/api/backend-registry/active-store.cjs.map +1 -1
  224. package/dist/api/backend-registry/active-store.d.ts +11 -5
  225. package/dist/api/backend-registry/active-store.js +36 -27
  226. package/dist/api/backend-registry/active-store.js.map +1 -1
  227. package/dist/api/backend-registry/auth.cjs +1 -1
  228. package/dist/api/backend-registry/auth.cjs.map +1 -1
  229. package/dist/api/backend-registry/auth.js +3 -9
  230. package/dist/api/backend-registry/auth.js.map +1 -1
  231. package/dist/api/backend-registry/default-backend.cjs +1 -1
  232. package/dist/api/backend-registry/default-backend.cjs.map +1 -1
  233. package/dist/api/backend-registry/default-backend.d.ts +9 -16
  234. package/dist/api/backend-registry/default-backend.js +5 -4
  235. package/dist/api/backend-registry/default-backend.js.map +1 -1
  236. package/dist/api/backend-registry/storage.cjs +1 -1
  237. package/dist/api/backend-registry/storage.cjs.map +1 -1
  238. package/dist/api/backend-registry/storage.js +67 -34
  239. package/dist/api/backend-registry/storage.js.map +1 -1
  240. package/dist/api/cloud/conversation-service.api.cjs.map +1 -1
  241. package/dist/api/cloud/conversation-service.api.d.ts +8 -13
  242. package/dist/api/cloud/conversation-service.api.js.map +1 -1
  243. package/dist/api/cloud/organization-service.api.cjs.map +1 -1
  244. package/dist/api/cloud/organization-service.api.d.ts +1 -2
  245. package/dist/api/cloud/organization-service.api.js.map +1 -1
  246. package/dist/api/cloud/proxy.cjs +1 -1
  247. package/dist/api/cloud/proxy.cjs.map +1 -1
  248. package/dist/api/cloud/proxy.d.ts +6 -6
  249. package/dist/api/cloud/proxy.js +33 -24
  250. package/dist/api/cloud/proxy.js.map +1 -1
  251. package/dist/api/cloud/sandbox-service.api.cjs.map +1 -1
  252. package/dist/api/cloud/sandbox-service.api.d.ts +3 -3
  253. package/dist/api/cloud/sandbox-service.api.js.map +1 -1
  254. package/dist/api/cloud/secrets-service.api.cjs.map +1 -1
  255. package/dist/api/cloud/secrets-service.api.d.ts +3 -4
  256. package/dist/api/cloud/secrets-service.api.js.map +1 -1
  257. package/dist/api/cloud/settings-service.api.cjs +1 -1
  258. package/dist/api/cloud/settings-service.api.cjs.map +1 -1
  259. package/dist/api/cloud/settings-service.api.js +5 -1
  260. package/dist/api/cloud/settings-service.api.js.map +1 -1
  261. package/dist/api/cloud/skills-service.api.cjs.map +1 -1
  262. package/dist/api/cloud/skills-service.api.d.ts +5 -5
  263. package/dist/api/cloud/skills-service.api.js.map +1 -1
  264. package/dist/api/conversation-service/agent-server-conversation-service.api.cjs +1 -1
  265. package/dist/api/conversation-service/agent-server-conversation-service.api.cjs.map +1 -1
  266. package/dist/api/conversation-service/agent-server-conversation-service.api.js +115 -108
  267. package/dist/api/conversation-service/agent-server-conversation-service.api.js.map +1 -1
  268. package/dist/api/device-flow-client.cjs +1 -1
  269. package/dist/api/device-flow-client.cjs.map +1 -1
  270. package/dist/api/device-flow-client.d.ts +3 -5
  271. package/dist/api/device-flow-client.js +55 -66
  272. package/dist/api/device-flow-client.js.map +1 -1
  273. package/dist/api/event-service/event-service.api.cjs +1 -1
  274. package/dist/api/event-service/event-service.api.cjs.map +1 -1
  275. package/dist/api/event-service/event-service.api.d.ts +3 -3
  276. package/dist/api/event-service/event-service.api.js +17 -17
  277. package/dist/api/event-service/event-service.api.js.map +1 -1
  278. package/dist/api/git-service/agent-server-git-service.api.cjs +1 -1
  279. package/dist/api/git-service/agent-server-git-service.api.js +11 -11
  280. package/dist/api/runtime-service/agent-server-runtime-service.cjs +1 -1
  281. package/dist/api/runtime-service/agent-server-runtime-service.js +6 -6
  282. package/dist/components/conversation-events/chat/event-content-helpers/get-action-content.cjs +2 -2
  283. package/dist/components/conversation-events/chat/event-content-helpers/get-action-content.js +10 -10
  284. package/dist/components/conversation-events/chat/event-content-helpers/get-observation-result.cjs.map +1 -1
  285. package/dist/components/conversation-events/chat/event-content-helpers/get-observation-result.d.ts +5 -5
  286. package/dist/components/conversation-events/chat/event-content-helpers/get-observation-result.js.map +1 -1
  287. package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.cjs +1 -1
  288. package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.cjs.map +1 -1
  289. package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.js +1 -1
  290. package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.js.map +1 -1
  291. package/dist/components/features/automations/automation-action-button-classes.d.ts +2 -2
  292. package/dist/components/features/backends/backend-form-modal.cjs +1 -1
  293. package/dist/components/features/backends/backend-form-modal.cjs.map +1 -1
  294. package/dist/components/features/backends/backend-form-modal.d.ts +1 -0
  295. package/dist/components/features/backends/backend-form-modal.js +203 -140
  296. package/dist/components/features/backends/backend-form-modal.js.map +1 -1
  297. package/dist/components/features/backends/backend-selector.cjs +1 -1
  298. package/dist/components/features/backends/backend-selector.cjs.map +1 -1
  299. package/dist/components/features/backends/backend-selector.js +117 -105
  300. package/dist/components/features/backends/backend-selector.js.map +1 -1
  301. package/dist/components/features/backends/backend-status-dot.cjs +1 -1
  302. package/dist/components/features/backends/backend-status-dot.cjs.map +1 -1
  303. package/dist/components/features/backends/backend-status-dot.d.ts +1 -1
  304. package/dist/components/features/backends/backend-status-dot.js +1 -1
  305. package/dist/components/features/backends/backend-status-dot.js.map +1 -1
  306. package/dist/components/features/backends/manage-backends-modal.cjs +1 -1
  307. package/dist/components/features/backends/manage-backends-modal.cjs.map +1 -1
  308. package/dist/components/features/backends/manage-backends-modal.js +81 -70
  309. package/dist/components/features/backends/manage-backends-modal.js.map +1 -1
  310. package/dist/components/features/chat/change-agent-button.cjs +1 -1
  311. package/dist/components/features/chat/change-agent-button.cjs.map +1 -1
  312. package/dist/components/features/chat/change-agent-button.js +59 -57
  313. package/dist/components/features/chat/change-agent-button.js.map +1 -1
  314. package/dist/components/features/chat/change-agent-context-menu.cjs +1 -1
  315. package/dist/components/features/chat/change-agent-context-menu.cjs.map +1 -1
  316. package/dist/components/features/chat/change-agent-context-menu.d.ts +3 -1
  317. package/dist/components/features/chat/change-agent-context-menu.js +30 -25
  318. package/dist/components/features/chat/change-agent-context-menu.js.map +1 -1
  319. package/dist/components/features/chat/chat-add-file-button.cjs +1 -1
  320. package/dist/components/features/chat/chat-add-file-button.cjs.map +1 -1
  321. package/dist/components/features/chat/chat-add-file-button.js +39 -38
  322. package/dist/components/features/chat/chat-add-file-button.js.map +1 -1
  323. package/dist/components/features/chat/chat-message.cjs +1 -1
  324. package/dist/components/features/chat/chat-message.cjs.map +1 -1
  325. package/dist/components/features/chat/chat-message.d.ts +2 -1
  326. package/dist/components/features/chat/chat-message.js +185 -57
  327. package/dist/components/features/chat/chat-message.js.map +1 -1
  328. package/dist/components/features/chat/components/chat-input-actions.cjs +1 -1
  329. package/dist/components/features/chat/components/chat-input-actions.cjs.map +1 -1
  330. package/dist/components/features/chat/components/chat-input-actions.js +113 -113
  331. package/dist/components/features/chat/components/chat-input-actions.js.map +1 -1
  332. package/dist/components/features/chat/components/chat-input-model.cjs +1 -1
  333. package/dist/components/features/chat/components/chat-input-model.cjs.map +1 -1
  334. package/dist/components/features/chat/components/chat-input-model.js +52 -51
  335. package/dist/components/features/chat/components/chat-input-model.js.map +1 -1
  336. package/dist/components/features/chat/components/slash-command-menu.cjs +2 -2
  337. package/dist/components/features/chat/components/slash-command-menu.cjs.map +1 -1
  338. package/dist/components/features/chat/components/slash-command-menu.js +38 -34
  339. package/dist/components/features/chat/components/slash-command-menu.js.map +1 -1
  340. package/dist/components/features/chat/git-control-bar-pr-button.cjs +1 -1
  341. package/dist/components/features/chat/git-control-bar-pr-button.cjs.map +1 -1
  342. package/dist/components/features/chat/git-control-bar-pr-button.js +16 -15
  343. package/dist/components/features/chat/git-control-bar-pr-button.js.map +1 -1
  344. package/dist/components/features/chat/git-control-bar-pull-button.cjs +1 -1
  345. package/dist/components/features/chat/git-control-bar-pull-button.cjs.map +1 -1
  346. package/dist/components/features/chat/git-control-bar-pull-button.js +16 -15
  347. package/dist/components/features/chat/git-control-bar-pull-button.js.map +1 -1
  348. package/dist/components/features/chat/git-control-bar-push-button.cjs +1 -1
  349. package/dist/components/features/chat/git-control-bar-push-button.cjs.map +1 -1
  350. package/dist/components/features/chat/git-control-bar-push-button.js +16 -15
  351. package/dist/components/features/chat/git-control-bar-push-button.js.map +1 -1
  352. package/dist/components/features/chat/git-control-bar.cjs +1 -1
  353. package/dist/components/features/chat/git-control-bar.cjs.map +1 -1
  354. package/dist/components/features/chat/git-control-bar.js +63 -62
  355. package/dist/components/features/chat/git-control-bar.js.map +1 -1
  356. package/dist/components/features/chat/pending-user-messages.cjs +1 -1
  357. package/dist/components/features/chat/pending-user-messages.cjs.map +1 -1
  358. package/dist/components/features/chat/pending-user-messages.js +27 -23
  359. package/dist/components/features/chat/pending-user-messages.js.map +1 -1
  360. package/dist/components/features/chat/switch-profile-button.cjs +1 -1
  361. package/dist/components/features/chat/switch-profile-button.cjs.map +1 -1
  362. package/dist/components/features/chat/switch-profile-button.js +26 -25
  363. package/dist/components/features/chat/switch-profile-button.js.map +1 -1
  364. package/dist/components/features/chat/switch-profile-context-menu.cjs +1 -1
  365. package/dist/components/features/chat/switch-profile-context-menu.cjs.map +1 -1
  366. package/dist/components/features/chat/switch-profile-context-menu.js +77 -67
  367. package/dist/components/features/chat/switch-profile-context-menu.js.map +1 -1
  368. package/dist/components/features/context-menu/context-menu-icon-text-with-description.cjs +1 -1
  369. package/dist/components/features/context-menu/context-menu-icon-text-with-description.cjs.map +1 -1
  370. package/dist/components/features/context-menu/context-menu-icon-text-with-description.d.ts +2 -1
  371. package/dist/components/features/context-menu/context-menu-icon-text-with-description.js +3 -2
  372. package/dist/components/features/context-menu/context-menu-icon-text-with-description.js.map +1 -1
  373. package/dist/components/features/context-menu/context-menu-icon-text.cjs +1 -1
  374. package/dist/components/features/context-menu/context-menu-icon-text.cjs.map +1 -1
  375. package/dist/components/features/context-menu/context-menu-icon-text.d.ts +2 -1
  376. package/dist/components/features/context-menu/context-menu-icon-text.js +20 -10
  377. package/dist/components/features/context-menu/context-menu-icon-text.js.map +1 -1
  378. package/dist/components/features/context-menu/context-menu-list-item.cjs +1 -1
  379. package/dist/components/features/context-menu/context-menu-list-item.cjs.map +1 -1
  380. package/dist/components/features/context-menu/context-menu-list-item.js +10 -9
  381. package/dist/components/features/context-menu/context-menu-list-item.js.map +1 -1
  382. package/dist/components/features/controls/agent-status.cjs +1 -1
  383. package/dist/components/features/controls/agent-status.js +12 -12
  384. package/dist/components/features/controls/git-tools-submenu.cjs +1 -1
  385. package/dist/components/features/controls/git-tools-submenu.cjs.map +1 -1
  386. package/dist/components/features/controls/git-tools-submenu.js +1 -1
  387. package/dist/components/features/controls/git-tools-submenu.js.map +1 -1
  388. package/dist/components/features/controls/macros-submenu.cjs +1 -1
  389. package/dist/components/features/controls/macros-submenu.cjs.map +1 -1
  390. package/dist/components/features/controls/macros-submenu.js +1 -1
  391. package/dist/components/features/controls/macros-submenu.js.map +1 -1
  392. package/dist/components/features/controls/server-status-context-menu-icon-text.cjs +1 -1
  393. package/dist/components/features/controls/server-status-context-menu-icon-text.cjs.map +1 -1
  394. package/dist/components/features/controls/server-status-context-menu-icon-text.js +14 -15
  395. package/dist/components/features/controls/server-status-context-menu-icon-text.js.map +1 -1
  396. package/dist/components/features/controls/server-status-context-menu.cjs +1 -1
  397. package/dist/components/features/controls/server-status-context-menu.js +4 -4
  398. package/dist/components/features/controls/server-status.cjs +1 -1
  399. package/dist/components/features/controls/server-status.js +7 -7
  400. package/dist/components/features/controls/tools-context-menu-icon-text.cjs +1 -1
  401. package/dist/components/features/controls/tools-context-menu-icon-text.cjs.map +1 -1
  402. package/dist/components/features/controls/tools-context-menu-icon-text.js +16 -16
  403. package/dist/components/features/controls/tools-context-menu-icon-text.js.map +1 -1
  404. package/dist/components/features/conversation/conversation-name-context-menu-icon-text.cjs +1 -1
  405. package/dist/components/features/conversation/conversation-name-context-menu-icon-text.cjs.map +1 -1
  406. package/dist/components/features/conversation/conversation-name-context-menu-icon-text.js +11 -11
  407. package/dist/components/features/conversation/conversation-name-context-menu-icon-text.js.map +1 -1
  408. package/dist/components/features/conversation/conversation-name-with-status.cjs +1 -1
  409. package/dist/components/features/conversation/conversation-name-with-status.js +11 -11
  410. package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.cjs +1 -1
  411. package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.cjs.map +1 -1
  412. package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.js +60 -47
  413. package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.js.map +1 -1
  414. package/dist/components/features/conversation-panel/cloud-new-conversation-menu.cjs +1 -1
  415. package/dist/components/features/conversation-panel/cloud-new-conversation-menu.cjs.map +1 -1
  416. package/dist/components/features/conversation-panel/cloud-new-conversation-menu.js +86 -82
  417. package/dist/components/features/conversation-panel/cloud-new-conversation-menu.js.map +1 -1
  418. package/dist/components/features/conversation-panel/conversation-card/conversation-card-actions.cjs +1 -1
  419. package/dist/components/features/conversation-panel/conversation-card/conversation-card-actions.js +4 -4
  420. package/dist/components/features/conversation-panel/conversation-card/conversation-card-footer.cjs +1 -1
  421. package/dist/components/features/conversation-panel/conversation-card/conversation-card-footer.js +9 -9
  422. package/dist/components/features/conversation-panel/conversation-panel-filter-menu.cjs +1 -1
  423. package/dist/components/features/conversation-panel/conversation-panel-filter-menu.cjs.map +1 -1
  424. package/dist/components/features/conversation-panel/conversation-panel-filter-menu.js +93 -93
  425. package/dist/components/features/conversation-panel/conversation-panel-filter-menu.js.map +1 -1
  426. package/dist/components/features/conversation-panel/conversation-panel.cjs +1 -1
  427. package/dist/components/features/conversation-panel/conversation-panel.cjs.map +1 -1
  428. package/dist/components/features/conversation-panel/conversation-panel.js +177 -177
  429. package/dist/components/features/conversation-panel/conversation-panel.js.map +1 -1
  430. package/dist/components/features/conversation-panel/ellipsis-button.cjs +1 -1
  431. package/dist/components/features/conversation-panel/ellipsis-button.cjs.map +1 -1
  432. package/dist/components/features/conversation-panel/ellipsis-button.js +13 -13
  433. package/dist/components/features/conversation-panel/ellipsis-button.js.map +1 -1
  434. package/dist/components/features/conversation-panel/local-new-conversation-menu.cjs +1 -1
  435. package/dist/components/features/conversation-panel/local-new-conversation-menu.cjs.map +1 -1
  436. package/dist/components/features/conversation-panel/local-new-conversation-menu.js +57 -53
  437. package/dist/components/features/conversation-panel/local-new-conversation-menu.js.map +1 -1
  438. package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.cjs +1 -1
  439. package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.cjs.map +1 -1
  440. package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.js +3 -2
  441. package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.js.map +1 -1
  442. package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.cjs +1 -1
  443. package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.cjs.map +1 -1
  444. package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.js +11 -8
  445. package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.js.map +1 -1
  446. package/dist/components/features/conversation-panel/system-message-modal/tab-content.cjs.map +1 -1
  447. package/dist/components/features/conversation-panel/system-message-modal/tab-content.d.ts +2 -5
  448. package/dist/components/features/conversation-panel/system-message-modal/tab-content.js.map +1 -1
  449. package/dist/components/features/files-tab/file-content-viewer.cjs +1 -1
  450. package/dist/components/features/files-tab/file-content-viewer.cjs.map +1 -1
  451. package/dist/components/features/files-tab/file-content-viewer.js +45 -42
  452. package/dist/components/features/files-tab/file-content-viewer.js.map +1 -1
  453. package/dist/components/features/home/llm-not-configured-banner.d.ts +11 -0
  454. package/dist/components/features/home/shared/dropdown-item.cjs +1 -1
  455. package/dist/components/features/home/shared/dropdown-item.cjs.map +1 -1
  456. package/dist/components/features/home/shared/dropdown-item.js +20 -16
  457. package/dist/components/features/home/shared/dropdown-item.js.map +1 -1
  458. package/dist/components/features/home/shared/generic-dropdown-menu.cjs +1 -1
  459. package/dist/components/features/home/shared/generic-dropdown-menu.cjs.map +1 -1
  460. package/dist/components/features/home/shared/generic-dropdown-menu.js +23 -22
  461. package/dist/components/features/home/shared/generic-dropdown-menu.js.map +1 -1
  462. package/dist/components/features/home/workspace-dropdown/folder-browser-modal.cjs +1 -1
  463. package/dist/components/features/home/workspace-dropdown/folder-browser-modal.cjs.map +1 -1
  464. package/dist/components/features/home/workspace-dropdown/folder-browser-modal.js +103 -102
  465. package/dist/components/features/home/workspace-dropdown/folder-browser-modal.js.map +1 -1
  466. package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.cjs +1 -1
  467. package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.cjs.map +1 -1
  468. package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.js +68 -67
  469. package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.js.map +1 -1
  470. package/dist/components/features/mcp-page/custom-server-editor.cjs +1 -1
  471. package/dist/components/features/mcp-page/custom-server-editor.cjs.map +1 -1
  472. package/dist/components/features/mcp-page/custom-server-editor.js +62 -60
  473. package/dist/components/features/mcp-page/custom-server-editor.js.map +1 -1
  474. package/dist/components/features/mcp-page/index.cjs +1 -1
  475. package/dist/components/features/mcp-page/index.d.ts +1 -0
  476. package/dist/components/features/mcp-page/index.js +1 -0
  477. package/dist/components/features/mcp-page/install-server-modal.cjs +1 -1
  478. package/dist/components/features/mcp-page/install-server-modal.cjs.map +1 -1
  479. package/dist/components/features/mcp-page/install-server-modal.js +141 -121
  480. package/dist/components/features/mcp-page/install-server-modal.js.map +1 -1
  481. package/dist/components/features/mcp-page/save-as-secret-toggle.cjs +2 -0
  482. package/dist/components/features/mcp-page/save-as-secret-toggle.cjs.map +1 -0
  483. package/dist/components/features/mcp-page/save-as-secret-toggle.d.ts +7 -0
  484. package/dist/components/features/mcp-page/save-as-secret-toggle.js +50 -0
  485. package/dist/components/features/mcp-page/save-as-secret-toggle.js.map +1 -0
  486. package/dist/components/features/onboarding/onboarding-modal.d.ts +2 -2
  487. package/dist/components/features/onboarding/steps/check-backend-step.d.ts +1 -1
  488. package/dist/components/features/onboarding/steps/choose-agent-step.d.ts +2 -1
  489. package/dist/components/features/onboarding/steps/setup-acp-secrets-step.d.ts +19 -10
  490. package/dist/components/features/settings/llm-profiles/llm-settings-local-view.cjs +1 -1
  491. package/dist/components/features/settings/llm-profiles/llm-settings-local-view.d.ts +5 -0
  492. package/dist/components/features/settings/llm-profiles/llm-settings-local-view.js +2 -0
  493. package/dist/components/features/settings/llm-profiles/profile-actions-menu.cjs +1 -1
  494. package/dist/components/features/settings/llm-profiles/profile-actions-menu.js +1 -0
  495. package/dist/components/features/skills/extensions-navigation.cjs +1 -1
  496. package/dist/components/features/skills/extensions-navigation.cjs.map +1 -1
  497. package/dist/components/features/skills/extensions-navigation.js +1 -1
  498. package/dist/components/features/skills/extensions-navigation.js.map +1 -1
  499. package/dist/components/shared/buttons/back-nav-button.cjs +2 -0
  500. package/dist/components/shared/buttons/back-nav-button.cjs.map +1 -0
  501. package/dist/components/shared/buttons/back-nav-button.d.ts +17 -0
  502. package/dist/components/shared/buttons/back-nav-button.js +33 -0
  503. package/dist/components/shared/buttons/back-nav-button.js.map +1 -0
  504. package/dist/components/shared/buttons/conversation-confirmation-buttons.cjs +1 -1
  505. package/dist/components/shared/buttons/conversation-confirmation-buttons.js +5 -5
  506. package/dist/components/shared/filters/enum-filter-dropdown.cjs +1 -1
  507. package/dist/components/shared/filters/enum-filter-dropdown.cjs.map +1 -1
  508. package/dist/components/shared/filters/enum-filter-dropdown.js +32 -31
  509. package/dist/components/shared/filters/enum-filter-dropdown.js.map +1 -1
  510. package/dist/components/shared/modals/confirmation-modals/base-modal.cjs +1 -1
  511. package/dist/components/shared/modals/confirmation-modals/base-modal.cjs.map +1 -1
  512. package/dist/components/shared/modals/confirmation-modals/base-modal.js +14 -13
  513. package/dist/components/shared/modals/confirmation-modals/base-modal.js.map +1 -1
  514. package/dist/components/shared/modals/settings/settings-modal.cjs +1 -1
  515. package/dist/components/shared/modals/settings/settings-modal.cjs.map +1 -1
  516. package/dist/components/shared/modals/settings/settings-modal.js +17 -16
  517. package/dist/components/shared/modals/settings/settings-modal.js.map +1 -1
  518. package/dist/components/shared/text-shimmer.cjs +2 -0
  519. package/dist/components/shared/text-shimmer.cjs.map +1 -0
  520. package/dist/components/shared/text-shimmer.d.ts +11 -0
  521. package/dist/components/shared/text-shimmer.js +43 -0
  522. package/dist/components/shared/text-shimmer.js.map +1 -0
  523. package/dist/constants/acp-providers.cjs +1 -1
  524. package/dist/constants/acp-providers.cjs.map +1 -1
  525. package/dist/constants/acp-providers.d.ts +16 -3
  526. package/dist/constants/acp-providers.js +0 -1
  527. package/dist/constants/acp-providers.js.map +1 -1
  528. package/dist/contexts/active-backend-context.cjs +1 -1
  529. package/dist/contexts/active-backend-context.cjs.map +1 -1
  530. package/dist/contexts/active-backend-context.js +32 -32
  531. package/dist/contexts/active-backend-context.js.map +1 -1
  532. package/dist/hooks/chat/use-chat-input-logic.cjs +1 -1
  533. package/dist/hooks/chat/use-chat-input-logic.cjs.map +1 -1
  534. package/dist/hooks/chat/use-chat-input-logic.js +13 -6
  535. package/dist/hooks/chat/use-chat-input-logic.js.map +1 -1
  536. package/dist/hooks/mutation/use-save-fields-as-secrets.cjs +2 -0
  537. package/dist/hooks/mutation/use-save-fields-as-secrets.cjs.map +1 -0
  538. package/dist/hooks/mutation/use-save-fields-as-secrets.d.ts +9 -0
  539. package/dist/hooks/mutation/use-save-fields-as-secrets.js +24 -0
  540. package/dist/hooks/mutation/use-save-fields-as-secrets.js.map +1 -0
  541. package/dist/hooks/mutation/use-unified-start-conversation.cjs +1 -1
  542. package/dist/hooks/mutation/use-unified-start-conversation.js +8 -8
  543. package/dist/hooks/mutation/use-unified-stop-conversation.cjs +1 -1
  544. package/dist/hooks/mutation/use-unified-stop-conversation.js +15 -15
  545. package/dist/hooks/query/use-acp-auth-status.d.ts +36 -0
  546. package/dist/hooks/query/use-agent-settings-schema.cjs +1 -1
  547. package/dist/hooks/query/use-agent-settings-schema.cjs.map +1 -1
  548. package/dist/hooks/query/use-agent-settings-schema.js +26 -16
  549. package/dist/hooks/query/use-agent-settings-schema.js.map +1 -1
  550. package/dist/hooks/query/use-backends-health.cjs +1 -1
  551. package/dist/hooks/query/use-backends-health.cjs.map +1 -1
  552. package/dist/hooks/query/use-backends-health.d.ts +2 -0
  553. package/dist/hooks/query/use-backends-health.js +31 -21
  554. package/dist/hooks/query/use-backends-health.js.map +1 -1
  555. package/dist/hooks/query/use-paginated-conversations.cjs +1 -1
  556. package/dist/hooks/query/use-paginated-conversations.cjs.map +1 -1
  557. package/dist/hooks/query/use-paginated-conversations.js +15 -14
  558. package/dist/hooks/query/use-paginated-conversations.js.map +1 -1
  559. package/dist/hooks/query/use-settings.cjs +1 -1
  560. package/dist/hooks/query/use-settings.cjs.map +1 -1
  561. package/dist/hooks/query/use-settings.js +65 -52
  562. package/dist/hooks/query/use-settings.js.map +1 -1
  563. package/dist/hooks/query/use-user-conversation.cjs +1 -1
  564. package/dist/hooks/query/use-user-conversation.cjs.map +1 -1
  565. package/dist/hooks/query/use-user-conversation.js +20 -11
  566. package/dist/hooks/query/use-user-conversation.js.map +1 -1
  567. package/dist/hooks/use-agent-state.cjs +1 -1
  568. package/dist/hooks/use-agent-state.js +13 -13
  569. package/dist/hooks/use-conversation-name-context-menu.cjs +1 -1
  570. package/dist/hooks/use-conversation-name-context-menu.js +10 -10
  571. package/dist/hooks/use-conversation-name-context-menu.js.map +1 -1
  572. package/dist/hooks/use-llm-configured.d.ts +25 -0
  573. package/dist/hooks/use-runtime-is-ready.cjs +1 -1
  574. package/dist/hooks/use-runtime-is-ready.js +5 -5
  575. package/dist/i18n/declaration.cjs +1 -1
  576. package/dist/i18n/declaration.cjs.map +1 -1
  577. package/dist/i18n/declaration.d.ts +19 -1
  578. package/dist/i18n/declaration.js +1 -1
  579. package/dist/i18n/declaration.js.map +1 -1
  580. package/dist/i18n/translation.cjs +3 -3
  581. package/dist/i18n/translation.cjs.map +1 -1
  582. package/dist/i18n/translation.js +321 -15
  583. package/dist/i18n/translation.js.map +1 -1
  584. package/dist/icons/stop-circle.cjs +1 -1
  585. package/dist/icons/stop-circle.cjs.map +1 -1
  586. package/dist/icons/stop-circle.js +7 -10
  587. package/dist/icons/stop-circle.js.map +1 -1
  588. package/dist/locales/ar/openhands.json +20 -2
  589. package/dist/locales/ca/openhands.json +20 -2
  590. package/dist/locales/de/openhands.json +20 -2
  591. package/dist/locales/en/openhands.json +20 -2
  592. package/dist/locales/es/openhands.json +20 -2
  593. package/dist/locales/fr/openhands.json +20 -2
  594. package/dist/locales/it/openhands.json +20 -2
  595. package/dist/locales/ja/openhands.json +20 -2
  596. package/dist/locales/ko-KR/openhands.json +20 -2
  597. package/dist/locales/no/openhands.json +20 -2
  598. package/dist/locales/pt/openhands.json +20 -2
  599. package/dist/locales/tr/openhands.json +20 -2
  600. package/dist/locales/uk/openhands.json +20 -2
  601. package/dist/locales/zh-CN/openhands.json +20 -2
  602. package/dist/locales/zh-TW/openhands.json +20 -2
  603. package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.cjs +2 -0
  604. package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.cjs.map +1 -0
  605. package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.js +15 -0
  606. package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.js.map +1 -0
  607. package/dist/package.cjs +1 -1
  608. package/dist/package.cjs.map +1 -1
  609. package/dist/package.js +1 -1
  610. package/dist/package.js.map +1 -1
  611. package/dist/routes/conversation.cjs +1 -1
  612. package/dist/routes/conversation.cjs.map +1 -1
  613. package/dist/routes/conversation.js +1 -1
  614. package/dist/routes/conversation.js.map +1 -1
  615. package/dist/routes/llm-settings.cjs +1 -1
  616. package/dist/routes/llm-settings.cjs.map +1 -1
  617. package/dist/routes/llm-settings.js +55 -54
  618. package/dist/routes/llm-settings.js.map +1 -1
  619. package/dist/routes/secrets-settings.cjs +1 -1
  620. package/dist/routes/secrets-settings.cjs.map +1 -1
  621. package/dist/routes/secrets-settings.js +19 -27
  622. package/dist/routes/secrets-settings.js.map +1 -1
  623. package/dist/stores/conversation-store.cjs +1 -1
  624. package/dist/stores/conversation-store.cjs.map +1 -1
  625. package/dist/stores/conversation-store.d.ts +4 -0
  626. package/dist/stores/conversation-store.js +6 -0
  627. package/dist/stores/conversation-store.js.map +1 -1
  628. package/dist/types/agent-server/core/events/acp-tool-call-event.d.ts +6 -4
  629. package/dist/types/agent-server/core/events/system-event.d.ts +5 -0
  630. package/dist/types/automation.d.ts +15 -0
  631. package/dist/types/settings.d.ts +3 -1
  632. package/dist/ui/combobox-caret.cjs +1 -1
  633. package/dist/ui/combobox-caret.cjs.map +1 -1
  634. package/dist/ui/combobox-caret.d.ts +1 -1
  635. package/dist/ui/combobox-caret.js +9 -8
  636. package/dist/ui/combobox-caret.js.map +1 -1
  637. package/dist/ui/context-menu.cjs +1 -1
  638. package/dist/ui/context-menu.cjs.map +1 -1
  639. package/dist/ui/context-menu.js +9 -8
  640. package/dist/ui/context-menu.js.map +1 -1
  641. package/dist/ui/dropdown/dropdown-menu.cjs +1 -1
  642. package/dist/ui/dropdown/dropdown-menu.cjs.map +1 -1
  643. package/dist/ui/dropdown/dropdown-menu.js +21 -17
  644. package/dist/ui/dropdown/dropdown-menu.js.map +1 -1
  645. package/dist/ui/dropdown/dropdown.cjs +1 -1
  646. package/dist/ui/dropdown/dropdown.cjs.map +1 -1
  647. package/dist/ui/dropdown/dropdown.js +2 -2
  648. package/dist/ui/dropdown/dropdown.js.map +1 -1
  649. package/dist/utils/automation-schedule.d.ts +1 -0
  650. package/dist/utils/dropdown-classes.cjs +2 -0
  651. package/dist/utils/dropdown-classes.cjs.map +1 -0
  652. package/dist/utils/dropdown-classes.d.ts +32 -0
  653. package/dist/utils/dropdown-classes.js +8 -0
  654. package/dist/utils/dropdown-classes.js.map +1 -0
  655. package/dist/utils/form-control-classes.cjs +1 -1
  656. package/dist/utils/form-control-classes.cjs.map +1 -1
  657. package/dist/utils/form-control-classes.d.ts +18 -2
  658. package/dist/utils/form-control-classes.js +4 -3
  659. package/dist/utils/form-control-classes.js.map +1 -1
  660. package/dist/utils/git-control-bar-classes.cjs +2 -0
  661. package/dist/utils/git-control-bar-classes.cjs.map +1 -0
  662. package/dist/utils/git-control-bar-classes.d.ts +4 -0
  663. package/dist/utils/git-control-bar-classes.js +14 -0
  664. package/dist/utils/git-control-bar-classes.js.map +1 -0
  665. package/dist/utils/handle-event-for-ui.cjs.map +1 -1
  666. package/dist/utils/handle-event-for-ui.d.ts +6 -3
  667. package/dist/utils/handle-event-for-ui.js.map +1 -1
  668. package/dist/utils/mobile-top-bar-icon-button-classes.cjs +1 -1
  669. package/dist/utils/mobile-top-bar-icon-button-classes.cjs.map +1 -1
  670. package/dist/utils/mobile-top-bar-icon-button-classes.js +3 -3
  671. package/dist/utils/mobile-top-bar-icon-button-classes.js.map +1 -1
  672. package/dist/utils/modal-classes.cjs +2 -0
  673. package/dist/utils/modal-classes.cjs.map +1 -0
  674. package/dist/utils/modal-classes.d.ts +8 -0
  675. package/dist/utils/modal-classes.js +7 -0
  676. package/dist/utils/modal-classes.js.map +1 -0
  677. package/dist/utils/openhands-llm.cjs +2 -0
  678. package/dist/utils/openhands-llm.cjs.map +1 -0
  679. package/dist/utils/openhands-llm.d.ts +2 -0
  680. package/dist/utils/openhands-llm.js +9 -0
  681. package/dist/utils/openhands-llm.js.map +1 -0
  682. package/dist/utils/redact-custom-secrets.cjs +2 -0
  683. package/dist/utils/redact-custom-secrets.cjs.map +1 -0
  684. package/dist/utils/redact-custom-secrets.d.ts +6 -0
  685. package/dist/utils/redact-custom-secrets.js +10 -0
  686. package/dist/utils/redact-custom-secrets.js.map +1 -0
  687. package/dist/utils/status.cjs +1 -1
  688. package/dist/utils/status.cjs.map +1 -1
  689. package/dist/utils/status.d.ts +2 -1
  690. package/dist/utils/status.js +9 -8
  691. package/dist/utils/status.js.map +1 -1
  692. package/dist/utils/system-message-adapter.cjs +1 -1
  693. package/dist/utils/system-message-adapter.cjs.map +1 -1
  694. package/dist/utils/system-message-adapter.js +10 -7
  695. package/dist/utils/system-message-adapter.js.map +1 -1
  696. package/dist/utils/utils.cjs +1 -1
  697. package/dist/utils/utils.cjs.map +1 -1
  698. package/dist/utils/utils.d.ts +2 -1
  699. package/dist/utils/utils.js +21 -20
  700. package/dist/utils/utils.js.map +1 -1
  701. package/package.json +1 -1
  702. package/scripts/dev-safe.mjs +3 -1
  703. package/scripts/dev-static.mjs +2 -2
  704. package/scripts/dev-with-automation.mjs +283 -108
  705. package/scripts/static-build.mjs +20 -19
  706. package/scripts/static-server.mjs +50 -3
  707. package/build/assets/acp-providers-CbiRekh9.js +0 -1
  708. package/build/assets/active-backend-context-cCM1vYYZ.js +0 -1
  709. package/build/assets/add-backend-modal-DIUQzMPa.js +0 -1
  710. package/build/assets/agent-server-client-options-Bc5ZorQZ.js +0 -1
  711. package/build/assets/agent-server-compatibility-BlkUsrX2.js +0 -1
  712. package/build/assets/agent-server-conversation-service.api-C2V5SlHu.js +0 -5
  713. package/build/assets/api-key-entry-screen-B2gynaCp.js +0 -1
  714. package/build/assets/automation-detail-DJvbVSYK.js +0 -1
  715. package/build/assets/automations-list-6FDbI5dc.js +0 -1
  716. package/build/assets/backend-form-modal-Dnk33xA_.js +0 -1
  717. package/build/assets/base-modal-_dYTw1ri.js +0 -1
  718. package/build/assets/brand-button-Br7f0kZJ.js +0 -1
  719. package/build/assets/browser-store-Couc4S5D.js +0 -1
  720. package/build/assets/clock-BRjCgHTc.js +0 -1
  721. package/build/assets/combobox-caret-to1O8irE.js +0 -1
  722. package/build/assets/context-menu-list-item-CWNFpuiC.js +0 -1
  723. package/build/assets/conversation-DVrKU0oz.js +0 -19
  724. package/build/assets/conversation-Dlys-D5A.js +0 -1
  725. package/build/assets/conversation-panel-iF09WjZ4.js +0 -1
  726. package/build/assets/conversation-service.api-CCfztilW.js +0 -1
  727. package/build/assets/conversation-state-store-u5jepov0.js +0 -1
  728. package/build/assets/conversation-store-Z5iMCRpc.js +0 -1
  729. package/build/assets/conversation-websocket-context-DhJhqUna.js +0 -3
  730. package/build/assets/declaration-BNMqORFE.js +0 -1
  731. package/build/assets/dist-BxBP7tFD.js +0 -1
  732. package/build/assets/edit-automation-modal-BGzR3nfZ.js +0 -1
  733. package/build/assets/ellipsis-button-ZyLMPURn.js +0 -1
  734. package/build/assets/entry.client-1VMHpktY.js +0 -2
  735. package/build/assets/enum-filter-dropdown-CEgCdu4A.js +0 -1
  736. package/build/assets/extensions-hub-C651jsVh.js +0 -1
  737. package/build/assets/files-tab-R5z0lLdY.js +0 -1
  738. package/build/assets/files-tab-store-CDyVTXNT.js +0 -1
  739. package/build/assets/git-control-bar-branch-button-COdRAYHb.js +0 -27
  740. package/build/assets/git-provider-icon-BzLbc0yC.js +0 -1
  741. package/build/assets/home-e-egNUXZ.js +0 -1
  742. package/build/assets/install-server-modal-DHlbgqVH.js +0 -1
  743. package/build/assets/launch-CshDse3e.js +0 -1
  744. package/build/assets/link-external-D2POYx4c.js +0 -1
  745. package/build/assets/llm-settings-Bql-vydt.js +0 -1
  746. package/build/assets/llm-settings-C_tal6Ds.js +0 -1
  747. package/build/assets/manage-backends-modal-l7RkKfwX.js +0 -1
  748. package/build/assets/manage-workspaces-modal-DhKF_8z3.js +0 -1
  749. package/build/assets/manifest-3bf30d69.js +0 -1
  750. package/build/assets/mcp-ByeBfdfU.js +0 -9
  751. package/build/assets/messages-D0rWot7s.js +0 -36
  752. package/build/assets/proxy-CxydCnis.js +0 -1
  753. package/build/assets/root-DHeCXo9N.css +0 -1
  754. package/build/assets/root-layout-Czo9Ma6Q.js +0 -2
  755. package/build/assets/secrets-service-BsnKFc2x.js +0 -1
  756. package/build/assets/secrets-settings-Bz_UohPJ.js +0 -1
  757. package/build/assets/settings-client-C73C7IgV.js +0 -1
  758. package/build/assets/settings-index-Dz0BmdJD.js +0 -1
  759. package/build/assets/settings-list-classes-Bf80tWtc.js +0 -1
  760. package/build/assets/settings-modal-Brzgh5Yw.js +0 -1
  761. package/build/assets/settings-service.api-CZ3uWx4v.js +0 -1
  762. package/build/assets/sidebar-mobile-menu-toggle-Do_aA9Zm.js +0 -1
  763. package/build/assets/skills-settings-DlA5hlXw.js +0 -2
  764. package/build/assets/status-hp6M6E7E.js +0 -1
  765. package/build/assets/use-agent-settings-schema-33Un7UF2.js +0 -1
  766. package/build/assets/use-is-authed-BggE5wPj.js +0 -1
  767. package/build/assets/use-llm-profiles-DDOol3gK.js +0 -1
  768. package/build/assets/use-runtime-is-ready-B7EF4BKU.js +0 -1
  769. package/build/assets/use-settings-DQIZmIov.js +0 -1
  770. package/build/assets/use-user-conversation-C6hrMMtn.js +0 -1
  771. package/build/assets/utils-i18rdUj2.js +0 -1
  772. package/build/assets/vendor~conversation-panel~conversation-a9SyrrhV.js +0 -1
  773. package/build/assets/vendor~conversation-panel~conversation~index-C23ZXO4R.js +0 -1
  774. package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~i4kjfqhl-BebWhFNT.js +0 -1
  775. package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-DzIXV3Ui.js +0 -9
  776. /package/build/assets/{automation-IdgZq6ZK.js → automation-XDPAjiZi.js} +0 -0
  777. /package/build/assets/{color-themes-DSaoIL6A.js → color-themes-B9pm9c-R.js} +0 -0
  778. /package/build/assets/{common-DR1t-EeP.js → common-DqjLSBOt.js} +0 -0
  779. /package/build/assets/{conversation-local-storage-UYl-SX-r.js → conversation-local-storage-YmOVXxxW.js} +0 -0
  780. /package/build/assets/{dist-C6t0EXL7.js → dist-C3NfioQC.js} +0 -0
  781. /package/build/assets/{environment-switch-store-C4ulFJKp.js → environment-switch-store-CiurvTtK.js} +0 -0
  782. /package/build/assets/{health-store-BDC2rM-X.js → health-store-B5f0S2FY.js} +0 -0
  783. /package/build/assets/{map-provider-COBVzZYo.js → map-provider-BJ_8KZKU.js} +0 -0
  784. /package/build/assets/{middleware-BC9EwbB9.js → middleware-CfatjPYZ.js} +0 -0
  785. /package/build/assets/{objectWithoutPropertiesLoose-Du6eBn-V.js → objectWithoutPropertiesLoose-DSQKyRhw.js} +0 -0
  786. /package/build/assets/{react-Do0CT17Y.js → react-Dy05vyj5.js} +0 -0
  787. /package/build/assets/{sdk-settings-field-metadata-CBPmeqYa.js → sdk-settings-field-metadata-DQiaIBie.js} +0 -0
  788. /package/build/assets/{settings-D_H-qsRm.js → settings-DGY6n4J2.js} +0 -0
  789. /package/build/assets/{settings-like-page-layout-classes-I0BDBEoq.js → settings-like-page-layout-classes-D7YjdTd0.js} +0 -0
  790. /package/build/assets/{use-breakpoint-DbJ6FkQ-.js → use-breakpoint-DF_RiQ6s.js} +0 -0
  791. /package/build/assets/{use-click-outside-element-DffgWWoZ.js → use-click-outside-element-DhxCUyWl.js} +0 -0
  792. /package/build/assets/{v4-CNn21NXa.js → v4-khGvL7i2.js} +0 -0
  793. /package/build/assets/{vendor~browser-DDiZgqD3.js → vendor~browser-DisFGEp9.js} +0 -0
  794. /package/build/assets/{vendor~browser-tab-BgwV1mxF.js → vendor~browser-tab-BxhTtM9_.js} +0 -0
  795. /package/build/assets/{vendor~conversation-panel~conversation~alert-banner-DbvX3OcM.js → vendor~conversation-panel~conversation~alert-banner-w-I2sY6c.js} +0 -0
  796. /package/build/assets/{vendor~entry.client~root~root-layout~home~conversation-panel~conversation~launch~skills-set~zm51vy4j-iOsylxCS.js → vendor~entry.client~root~root-layout~home~conversation-panel~conversation~launch~skills-set~zm51vy4j-BClAMeFe.js} +0 -0
  797. /package/build/assets/{vendor~files-tab-BGKayPiK.js → vendor~files-tab-BtkpAiMX.js} +0 -0
  798. /package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-BW6261Sb.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-CyZ-3lDQ.js} +0 -0
  799. /package/build/assets/{vendor~home~mcp~automations-list-DoPfwaXj.js → vendor~home~mcp~automations-list-BgV86Sti.js} +0 -0
  800. /package/build/assets/{vendor~launch-vdeRTWFu.js → vendor~launch-BXgl67Re.js} +0 -0
  801. /package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~ninslayh-D9P8e98a.js → vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~ninslayh-CLlsvdNP.js} +0 -0
  802. /package/build/assets/{vendor~terminal-DUrOWGFE.js → vendor~terminal-DZaJIY8A.js} +0 -0
@@ -1,115 +1,116 @@
1
1
  import { useTranslation as e } from "../../../../node_modules/react-i18next/dist/es/useTranslation.js";
2
2
  import { I18nKey as t } from "../../../../i18n/declaration.js";
3
3
  import { cn as n } from "../../../../utils/utils.js";
4
- import r from "../../../../icons/checkmark.js";
5
- import { Typography as i } from "../../../../ui/typography.js";
6
- import { ComboboxCaretInline as a } from "../../../../ui/combobox-caret.js";
7
- import { ContextMenu as o } from "../../../../ui/context-menu.js";
8
- import { ContextMenuListItem as s } from "../../context-menu/context-menu-list-item.js";
9
- import { useClickOutsideElement as c } from "../../../../hooks/use-click-outside-element.js";
10
- import { useChatInputModelState as l } from "../../../../hooks/use-chat-input-model-state.js";
11
- import { useSwitchAcpModel as u } from "../../../../hooks/mutation/use-switch-acp-model.js";
12
- import d from "../../../../icons/settings-gear.js";
13
- import { NavigationLink as f } from "../../../shared/navigation-link.js";
14
- import { Divider as p } from "../../../../ui/divider.js";
15
- import m from "react";
16
- import { Fragment as h, jsx as g, jsxs as _ } from "react/jsx-runtime";
4
+ import { chatInputPillButtonClassName as r } from "../../../../utils/form-control-classes.js";
5
+ import i from "../../../../icons/checkmark.js";
6
+ import { Typography as a } from "../../../../ui/typography.js";
7
+ import { ComboboxCaretInline as o } from "../../../../ui/combobox-caret.js";
8
+ import { ContextMenu as s } from "../../../../ui/context-menu.js";
9
+ import { ContextMenuListItem as c } from "../../context-menu/context-menu-list-item.js";
10
+ import { useClickOutsideElement as l } from "../../../../hooks/use-click-outside-element.js";
11
+ import { useChatInputModelState as u } from "../../../../hooks/use-chat-input-model-state.js";
12
+ import { useSwitchAcpModel as d } from "../../../../hooks/mutation/use-switch-acp-model.js";
13
+ import f from "../../../../icons/settings-gear.js";
14
+ import { NavigationLink as p } from "../../../shared/navigation-link.js";
15
+ import { Divider as m } from "../../../../ui/divider.js";
16
+ import h from "react";
17
+ import { Fragment as g, jsx as _, jsxs as v } from "react/jsx-runtime";
17
18
  //#region src/components/features/chat/components/chat-input-model.tsx
18
- var v = 10, y = 22;
19
- function b(e, t = v) {
19
+ var y = 10, b = 22;
20
+ function x(e, t = y) {
20
21
  return e.length <= t ? e : `${e.slice(0, t)}…`;
21
22
  }
22
- function x({ model: a, onClose: o, dividerInset: c, settingsLinkClassName: l, settingsIconClassName: m }) {
23
- let { t: v } = e("openhands"), y = u(), b = a.showAcpPicker || !!a.displayModel, x = (e) => {
24
- e !== a.currentModelId && y.mutate({
25
- conversationId: a.switchConversationId,
23
+ function S({ model: r, onClose: o, dividerInset: s, settingsLinkClassName: l, settingsIconClassName: u }) {
24
+ let { t: h } = e("openhands"), y = d(), b = r.showAcpPicker || !!r.displayModel, x = (e) => {
25
+ e !== r.currentModelId && y.mutate({
26
+ conversationId: r.switchConversationId,
26
27
  model: e
27
28
  }), o();
28
29
  };
29
- return /* @__PURE__ */ _(h, { children: [
30
- a.showAcpPicker ? /* @__PURE__ */ _(h, { children: [/* @__PURE__ */ g("li", {
30
+ return /* @__PURE__ */ v(g, { children: [
31
+ r.showAcpPicker ? /* @__PURE__ */ v(g, { children: [/* @__PURE__ */ _("li", {
31
32
  role: "presentation",
32
33
  className: "px-2 pt-1 pb-0.5",
33
- children: /* @__PURE__ */ g(i.Text, {
34
+ children: /* @__PURE__ */ _(a.Text, {
34
35
  className: "text-[11px] font-medium text-[var(--oh-text-dim)] uppercase tracking-wide leading-4",
35
- children: v(t.MODEL$AVAILABLE_MODELS)
36
+ children: h(t.MODEL$AVAILABLE_MODELS)
36
37
  })
37
- }), a.availableAcpModels.map((e) => {
38
- let t = e.id === a.currentModelId;
39
- return /* @__PURE__ */ _(s, {
38
+ }), r.availableAcpModels.map((e) => {
39
+ let t = e.id === r.currentModelId;
40
+ return /* @__PURE__ */ v(c, {
40
41
  testId: `chat-input-acp-model-option-${e.id}`,
41
42
  onClick: (t) => {
42
43
  t.preventDefault(), t.stopPropagation(), x(e.id);
43
44
  },
44
45
  className: n("flex items-center gap-2", t && "bg-[var(--oh-interactive-hover)]"),
45
- children: [/* @__PURE__ */ g("span", {
46
+ children: [/* @__PURE__ */ _("span", {
46
47
  className: "flex-1 truncate text-sm leading-5",
47
48
  title: e.label,
48
49
  children: e.label
49
- }), t && /* @__PURE__ */ g(r, {
50
+ }), t && /* @__PURE__ */ _(i, {
50
51
  width: 14,
51
52
  height: 14,
52
53
  className: "shrink-0",
53
54
  "aria-hidden": !0
54
55
  })]
55
56
  }, e.id);
56
- })] }) : a.displayModel ? /* @__PURE__ */ g("li", {
57
+ })] }) : r.displayModel ? /* @__PURE__ */ _("li", {
57
58
  className: "text-sm",
58
- children: /* @__PURE__ */ g("div", {
59
+ children: /* @__PURE__ */ _("div", {
59
60
  className: "p-2 leading-5 text-[var(--oh-foreground)] break-all",
60
- children: a.displayModel
61
+ children: r.displayModel
61
62
  })
62
63
  }) : null,
63
- b && /* @__PURE__ */ g(p, { inset: c }),
64
- /* @__PURE__ */ g("li", {
64
+ b && /* @__PURE__ */ _(m, { inset: s }),
65
+ /* @__PURE__ */ _("li", {
65
66
  className: "text-sm",
66
- children: /* @__PURE__ */ _(f, {
67
- to: a.destinationPath,
67
+ children: /* @__PURE__ */ v(p, {
68
+ to: r.destinationPath,
68
69
  onClick: o,
69
70
  className: 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", l),
70
- children: [/* @__PURE__ */ g(d, {
71
+ children: [/* @__PURE__ */ _(f, {
71
72
  width: 16,
72
73
  height: 16,
73
- className: n("shrink-0", m),
74
+ className: n("shrink-0", u),
74
75
  "aria-hidden": !0
75
- }), /* @__PURE__ */ g("span", { children: a.destinationLabel })]
76
+ }), /* @__PURE__ */ _("span", { children: r.destinationLabel })]
76
77
  })
77
78
  })
78
79
  ] });
79
80
  }
80
- function S() {
81
- let e = l(), [t, r] = m.useState(!1), i = m.useRef(null), s = c(() => r(!1), i);
81
+ function C() {
82
+ let e = u(), [t, n] = h.useState(!1), i = h.useRef(null), a = l(() => n(!1), i);
82
83
  if (!e.displayModel) return null;
83
- let u = b(e.displayModel, e.isAcpContext ? y : v);
84
- return /* @__PURE__ */ _("div", {
84
+ let c = x(e.displayModel, e.isAcpContext ? b : y);
85
+ return /* @__PURE__ */ v("div", {
85
86
  className: "relative min-w-0",
86
- children: [/* @__PURE__ */ _("button", {
87
+ children: [/* @__PURE__ */ v("button", {
87
88
  ref: i,
88
89
  type: "button",
89
- className: 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", "hover:text-white hover:bg-white/10 cursor-pointer"),
90
+ className: r,
90
91
  title: e.displayModel,
91
92
  "data-testid": "chat-input-llm-model",
92
93
  "aria-expanded": t,
93
94
  "aria-haspopup": "dialog",
94
95
  onClick: (e) => {
95
- e.preventDefault(), e.stopPropagation(), r((e) => !e);
96
+ e.preventDefault(), e.stopPropagation(), n((e) => !e);
96
97
  },
97
- children: [/* @__PURE__ */ g("span", { children: u }), /* @__PURE__ */ g(a, { isOpen: t })]
98
- }), t && /* @__PURE__ */ g(o, {
99
- ref: s,
98
+ children: [/* @__PURE__ */ _("span", { children: c }), /* @__PURE__ */ _(o, { isOpen: t })]
99
+ }), t && /* @__PURE__ */ _(s, {
100
+ ref: a,
100
101
  testId: "chat-input-llm-model-popover",
101
102
  position: "top",
102
103
  alignment: "left",
103
104
  spacing: "none",
104
105
  className: "z-[60] mb-2 min-w-[200px] max-w-[320px] max-h-[60vh] overflow-y-auto",
105
- children: /* @__PURE__ */ g(x, {
106
+ children: /* @__PURE__ */ _(S, {
106
107
  model: e,
107
- onClose: () => r(!1)
108
+ onClose: () => n(!1)
108
109
  })
109
110
  })]
110
111
  });
111
112
  }
112
113
  //#endregion
113
- export { S as ChatInputModel, x as ChatInputModelMenuContent };
114
+ export { C as ChatInputModel, S as ChatInputModelMenuContent };
114
115
 
115
116
  //# sourceMappingURL=chat-input-model.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"chat-input-model.js","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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"}
1
+ {"version":3,"file":"chat-input-model.js","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 { chatInputPillButtonClassName } from \"#/utils/form-control-classes\";\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={chatInputPillButtonClassName}\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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"}
@@ -1,3 +1,3 @@
1
- const e=require(`../../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),n=require(`../../../../utils/utils.cjs`),r=require(`../../../../ui/typography.cjs`);let i=require(`react`);i=e.__toESM(i,1);let a=require(`react/jsx-runtime`);function o(e){return e.replace(/!\[([^\]]*)\]\([^)]*\)/g,`$1`).replace(/\[([^\]]*)\]\([^)]*\)/g,`$1`).replace(/\*{3}(.+?)\*{3}/g,`$1`).replace(/\*{2}(.+?)\*{2}/g,`$1`).replace(/\*(.+?)\*/g,`$1`).replace(/_{3}(.+?)_{3}/g,`$1`).replace(/_{2}(.+?)_{2}/g,`$1`).replace(/_(.+?)_/g,`$1`).replace(/`(.+?)`/g,`$1`).replace(/~~(.+?)~~/g,`$1`)}function s(e){let t=e,n=e.match(/^---\s*\n([\s\S]*?)\n---/);if(n){let r=n[1].match(/^description:\s*(.+)$/m);if(r){let e=r[1].trim();return(e.startsWith(`"`)&&e.endsWith(`"`)||e.startsWith(`'`)&&e.endsWith(`'`))&&(e=e.slice(1,-1)),o(e)}t=e.slice(n[0].length)}let r=t.split(`
2
- `).map(e=>e.trim()).find(e=>e.length>0&&!e.startsWith(`#`)&&e!==`---`);if(!r)return null;let i=o(r);return i.match(/^[^.!?\n]*[.!?]/)?.[0]||i}function c({item:e,isSelected:t,onSelect:c,ref:l}){let u=(0,i.useMemo)(()=>`description`in e.skill&&e.skill.description?o(e.skill.description):`content`in e.skill&&e.skill.content?s(e.skill.content):null,[e.skill]);return(0,a.jsxs)(`button`,{role:`option`,"aria-selected":t,ref:l,type:`button`,className:n.cn(`w-full px-3 py-2.5 text-left transition-colors`,t?`bg-tertiary`:`hover:bg-[var(--oh-surface-raised)]`),onMouseDown:t=>{t.preventDefault(),c(e)},children:[(0,a.jsx)(r.Text,{className:`font-normal`,children:e.command}),u&&(0,a.jsx)(r.Text,{className:`text-xs text-[var(--oh-muted)] mt-0.5 truncate block`,children:u})]})}function l({items:e,selectedIndex:n,onSelect:r}){let{t:o}=t.useTranslation(`openhands`),s=(0,i.useRef)([]);return(0,i.useEffect)(()=>{s.current=s.current.slice(0,e.length)},[e.length]),(0,i.useEffect)(()=>{let e=s.current[n];e&&e.scrollIntoView({block:`nearest`})},[n]),e.length===0?null:(0,a.jsxs)(`div`,{role:`listbox`,"aria-label":o(`CHAT_INTERFACE$COMMANDS`),className:`absolute bottom-full left-0 w-full mb-1 bg-[var(--oh-surface)] border border-[var(--oh-border-subtle)] rounded-lg shadow-lg max-h-[300px] overflow-y-auto custom-scrollbar z-50`,"data-testid":`slash-command-menu`,children:[(0,a.jsx)(`div`,{className:`px-3 py-2 text-xs text-[var(--oh-muted)] border-b border-[var(--oh-border-subtle)]`,children:o(`CHAT_INTERFACE$COMMANDS`)}),e.map((e,t)=>(0,a.jsx)(c,{item:e,isSelected:t===n,onSelect:r,ref:e=>{s.current[t]=e}},e.command))]})}exports.SlashCommandMenu=l;
1
+ const e=require(`../../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),n=require(`../../../../utils/utils.cjs`),r=require(`../../../../ui/typography.cjs`),i=require(`../../../../utils/dropdown-classes.cjs`);let a=require(`react`);a=e.__toESM(a,1);let o=require(`react/jsx-runtime`);function s(e){return e.replace(/!\[([^\]]*)\]\([^)]*\)/g,`$1`).replace(/\[([^\]]*)\]\([^)]*\)/g,`$1`).replace(/\*{3}(.+?)\*{3}/g,`$1`).replace(/\*{2}(.+?)\*{2}/g,`$1`).replace(/\*(.+?)\*/g,`$1`).replace(/_{3}(.+?)_{3}/g,`$1`).replace(/_{2}(.+?)_{2}/g,`$1`).replace(/_(.+?)_/g,`$1`).replace(/`(.+?)`/g,`$1`).replace(/~~(.+?)~~/g,`$1`)}function c(e){let t=e,n=e.match(/^---\s*\n([\s\S]*?)\n---/);if(n){let r=n[1].match(/^description:\s*(.+)$/m);if(r){let e=r[1].trim();return(e.startsWith(`"`)&&e.endsWith(`"`)||e.startsWith(`'`)&&e.endsWith(`'`))&&(e=e.slice(1,-1)),s(e)}t=e.slice(n[0].length)}let r=t.split(`
2
+ `).map(e=>e.trim()).find(e=>e.length>0&&!e.startsWith(`#`)&&e!==`---`);if(!r)return null;let i=s(r);return i.match(/^[^.!?\n]*[.!?]/)?.[0]||i}function l({item:e,isSelected:t,onSelect:l,ref:u}){let d=(0,a.useMemo)(()=>`description`in e.skill&&e.skill.description?s(e.skill.description):`content`in e.skill&&e.skill.content?c(e.skill.content):null,[e.skill]);return(0,o.jsxs)(`button`,{role:`option`,"aria-selected":t,ref:u,type:`button`,className:n.cn(`w-full px-3 py-2.5 text-left`,i.dropdownInstantColorClassName,t?`bg-tertiary`:`hover:bg-[var(--oh-surface-raised)]`),onMouseDown:t=>{t.preventDefault(),l(e)},children:[(0,o.jsx)(r.Text,{className:`font-normal`,children:e.command}),d&&(0,o.jsx)(r.Text,{className:`text-xs text-[var(--oh-muted)] mt-0.5 truncate block`,children:d})]})}function u({items:e,selectedIndex:n,onSelect:r}){let{t:s}=t.useTranslation(`openhands`),c=(0,a.useRef)([]);return(0,a.useEffect)(()=>{c.current=c.current.slice(0,e.length)},[e.length]),(0,a.useEffect)(()=>{let e=c.current[n];e&&e.scrollIntoView({block:`nearest`})},[n]),e.length===0?null:(0,o.jsxs)(`div`,{role:`listbox`,"aria-label":s(`CHAT_INTERFACE$COMMANDS`),className:`absolute bottom-full left-0 w-full mb-1 bg-[var(--oh-surface)] border border-[var(--oh-border-subtle)] rounded-lg shadow-lg max-h-[300px] overflow-y-auto custom-scrollbar z-50`,"data-testid":`slash-command-menu`,children:[(0,o.jsx)(`div`,{className:`px-3 py-2 text-xs text-[var(--oh-muted)] border-b border-[var(--oh-border-subtle)]`,children:s(`CHAT_INTERFACE$COMMANDS`)}),(0,o.jsx)(`div`,{className:i.dropdownMenuListClassName,children:e.map((e,t)=>(0,o.jsx)(l,{item:e,isSelected:t===n,onSelect:r,ref:e=>{c.current[t]=e}},e.command))})]})}exports.SlashCommandMenu=u;
3
3
  //# sourceMappingURL=slash-command-menu.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"slash-command-menu.cjs","names":[],"sources":["../../../../../src/components/features/chat/components/slash-command-menu.tsx"],"sourcesContent":["import React, { useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { cn } from \"#/utils/utils\";\nimport { Text } from \"#/ui/typography\";\nimport { SlashCommandItem } from \"#/hooks/chat/use-slash-command\";\n\n/**\n * Strip common inline Markdown syntax so descriptions render as plain text.\n * Handles: bold, italic, inline code, links, and images.\n */\nexport function stripMarkdown(text: string): string {\n return (\n text\n // Images: ![alt](url) → alt\n .replace(/!\\[([^\\]]*)\\]\\([^)]*\\)/g, \"$1\")\n // Links: [text](url) → text\n .replace(/\\[([^\\]]*)\\]\\([^)]*\\)/g, \"$1\")\n // Bold/italic: ***text***, **text**, *text*, ___text___, __text__, _text_\n .replace(/\\*{3}(.+?)\\*{3}/g, \"$1\")\n .replace(/\\*{2}(.+?)\\*{2}/g, \"$1\")\n .replace(/\\*(.+?)\\*/g, \"$1\")\n .replace(/_{3}(.+?)_{3}/g, \"$1\")\n .replace(/_{2}(.+?)_{2}/g, \"$1\")\n .replace(/_(.+?)_/g, \"$1\")\n // Inline code: `text` → text\n .replace(/`(.+?)`/g, \"$1\")\n // Strikethrough: ~~text~~ → text\n .replace(/~~(.+?)~~/g, \"$1\")\n );\n}\n\n/**\n * Extract a short description from skill content.\n * Tries YAML frontmatter \"description:\" first, then falls back\n * to the first meaningful line after headers and frontmatter.\n * Returns plain text with Markdown formatting stripped.\n */\nexport function getSkillDescription(content: string): string | null {\n let body = content;\n\n // Try to extract description from YAML frontmatter\n const frontmatterMatch = content.match(/^---\\s*\\n([\\s\\S]*?)\\n---/);\n if (frontmatterMatch) {\n const descMatch = frontmatterMatch[1].match(/^description:\\s*(.+)$/m);\n if (descMatch) {\n let desc = descMatch[1].trim();\n // Strip surrounding quotes from YAML values\n if (\n (desc.startsWith('\"') && desc.endsWith('\"')) ||\n (desc.startsWith(\"'\") && desc.endsWith(\"'\"))\n ) {\n desc = desc.slice(1, -1);\n }\n return stripMarkdown(desc);\n }\n // Skip frontmatter for body parsing\n body = content.slice(frontmatterMatch[0].length);\n }\n\n // Fall back to first meaningful line (skip headers, empty lines, frontmatter delimiters)\n const meaningful = body\n .split(\"\\n\")\n .map((line) => line.trim())\n .find((line) => line.length > 0 && !line.startsWith(\"#\") && line !== \"---\");\n\n if (!meaningful) return null;\n\n // Strip Markdown first so URLs inside links don't confuse sentence detection\n const stripped = stripMarkdown(meaningful);\n const sentence = stripped.match(/^[^.!?\\n]*[.!?]/);\n return sentence?.[0] || stripped;\n}\n\ninterface SlashCommandMenuItemProps {\n item: SlashCommandItem;\n isSelected: boolean;\n onSelect: (item: SlashCommandItem) => void;\n ref?: React.Ref<HTMLButtonElement>;\n}\n\nfunction SlashCommandMenuItem({\n item,\n isSelected,\n onSelect,\n ref,\n}: SlashCommandMenuItemProps) {\n const description = useMemo(() => {\n if (\"description\" in item.skill && item.skill.description) {\n return stripMarkdown(item.skill.description);\n }\n if (\"content\" in item.skill && item.skill.content) {\n return getSkillDescription(item.skill.content);\n }\n return null;\n }, [item.skill]);\n\n return (\n <button\n role=\"option\"\n aria-selected={isSelected}\n ref={ref}\n type=\"button\"\n className={cn(\n \"w-full px-3 py-2.5 text-left transition-colors\",\n isSelected ? \"bg-tertiary\" : \"hover:bg-[var(--oh-surface-raised)]\",\n )}\n onMouseDown={(e) => {\n // Use mouseDown instead of click to fire before input blur\n e.preventDefault();\n onSelect(item);\n }}\n >\n <Text className=\"font-normal\">{item.command}</Text>\n {description && (\n <Text className=\"text-xs text-[var(--oh-muted)] mt-0.5 truncate block\">\n {description}\n </Text>\n )}\n </button>\n );\n}\n\ninterface SlashCommandMenuProps {\n items: SlashCommandItem[];\n selectedIndex: number;\n onSelect: (item: SlashCommandItem) => void;\n}\n\nexport function SlashCommandMenu({\n items,\n selectedIndex,\n onSelect,\n}: SlashCommandMenuProps) {\n const { t } = useTranslation(\"openhands\");\n const itemRefs = useRef<(HTMLButtonElement | null)[]>([]);\n\n // Keep refs array in sync with items length\n useEffect(() => {\n itemRefs.current = itemRefs.current.slice(0, items.length);\n }, [items.length]);\n\n // Scroll selected item into view\n useEffect(() => {\n const selectedItem = itemRefs.current[selectedIndex];\n if (selectedItem) {\n selectedItem.scrollIntoView({ block: \"nearest\" });\n }\n }, [selectedIndex]);\n\n if (items.length === 0) return null;\n\n return (\n <div\n role=\"listbox\"\n aria-label={t(\"CHAT_INTERFACE$COMMANDS\")}\n className=\"absolute bottom-full left-0 w-full mb-1 bg-[var(--oh-surface)] border border-[var(--oh-border-subtle)] rounded-lg shadow-lg max-h-[300px] overflow-y-auto custom-scrollbar z-50\"\n data-testid=\"slash-command-menu\"\n >\n <div className=\"px-3 py-2 text-xs text-[var(--oh-muted)] border-b border-[var(--oh-border-subtle)]\">\n {t(\"CHAT_INTERFACE$COMMANDS\")}\n </div>\n {items.map((item, index) => (\n <SlashCommandMenuItem\n key={item.command}\n item={item}\n isSelected={index === selectedIndex}\n onSelect={onSelect}\n ref={(el) => {\n itemRefs.current[index] = el;\n }}\n />\n ))}\n </div>\n );\n}\n"],"mappings":"4SAUA,SAAgB,EAAc,EAAsB,CAClD,OACE,EAEG,QAAQ,0BAA2B,KAAK,CAExC,QAAQ,yBAA0B,KAAK,CAEvC,QAAQ,mBAAoB,KAAK,CACjC,QAAQ,mBAAoB,KAAK,CACjC,QAAQ,aAAc,KAAK,CAC3B,QAAQ,iBAAkB,KAAK,CAC/B,QAAQ,iBAAkB,KAAK,CAC/B,QAAQ,WAAY,KAAK,CAEzB,QAAQ,WAAY,KAAK,CAEzB,QAAQ,aAAc,KAAK,CAUlC,SAAgB,EAAoB,EAAgC,CAClE,IAAI,EAAO,EAGL,EAAmB,EAAQ,MAAM,2BAA2B,CAClE,GAAI,EAAkB,CACpB,IAAM,EAAY,EAAiB,GAAG,MAAM,yBAAyB,CACrE,GAAI,EAAW,CACb,IAAI,EAAO,EAAU,GAAG,MAAM,CAQ9B,OALG,EAAK,WAAW,IAAI,EAAI,EAAK,SAAS,IAAI,EAC1C,EAAK,WAAW,IAAI,EAAI,EAAK,SAAS,IAAI,IAE3C,EAAO,EAAK,MAAM,EAAG,GAAG,EAEnB,EAAc,EAAK,CAG5B,EAAO,EAAQ,MAAM,EAAiB,GAAG,OAAO,CAIlD,IAAM,EAAa,EAChB,MAAM;EAAK,CACX,IAAK,GAAS,EAAK,MAAM,CAAC,CAC1B,KAAM,GAAS,EAAK,OAAS,GAAK,CAAC,EAAK,WAAW,IAAI,EAAI,IAAS,MAAM,CAE7E,GAAI,CAAC,EAAY,OAAO,KAGxB,IAAM,EAAW,EAAc,EAAW,CAE1C,OADiB,EAAS,MAAM,kBACzB,GAAW,IAAM,EAU1B,SAAS,EAAqB,CAC5B,OACA,aACA,WACA,OAC4B,CAC5B,IAAM,GAAA,EAAA,EAAA,aACA,gBAAiB,EAAK,OAAS,EAAK,MAAM,YACrC,EAAc,EAAK,MAAM,YAAY,CAE1C,YAAa,EAAK,OAAS,EAAK,MAAM,QACjC,EAAoB,EAAK,MAAM,QAAQ,CAEzC,KACN,CAAC,EAAK,MAAM,CAAC,CAEhB,OACE,EAAA,EAAA,MAAC,SAAD,CACE,KAAK,SACL,gBAAe,EACV,MACL,KAAK,SACL,UAAW,EAAA,GACT,iDACA,EAAa,cAAgB,sCAC9B,CACD,YAAc,GAAM,CAElB,EAAE,gBAAgB,CAClB,EAAS,EAAK,WAZlB,EAeE,EAAA,EAAA,KAAC,EAAA,KAAD,CAAM,UAAU,uBAAe,EAAK,QAAe,CAAA,CAClD,IACC,EAAA,EAAA,KAAC,EAAA,KAAD,CAAM,UAAU,gEACb,EACI,CAAA,CAEF,GAUb,SAAgB,EAAiB,CAC/B,QACA,gBACA,YACwB,CACxB,GAAM,CAAE,KAAM,EAAA,eAAe,YAAY,CACnC,GAAA,EAAA,EAAA,QAAgD,EAAE,CAAC,CAiBzD,OAdA,EAAA,EAAA,eAAgB,CACd,EAAS,QAAU,EAAS,QAAQ,MAAM,EAAG,EAAM,OAAO,EACzD,CAAC,EAAM,OAAO,CAAC,EAGlB,EAAA,EAAA,eAAgB,CACd,IAAM,EAAe,EAAS,QAAQ,GAClC,GACF,EAAa,eAAe,CAAE,MAAO,UAAW,CAAC,EAElD,CAAC,EAAc,CAAC,CAEf,EAAM,SAAW,EAAU,MAG7B,EAAA,EAAA,MAAC,MAAD,CACE,KAAK,UACL,aAAY,EAAE,0BAA0B,CACxC,UAAU,kLACV,cAAY,8BAJd,EAME,EAAA,EAAA,KAAC,MAAD,CAAK,UAAU,8FACZ,EAAE,0BAA0B,CACzB,CAAA,CACL,EAAM,KAAK,EAAM,KAChB,EAAA,EAAA,KAAC,EAAD,CAEQ,OACN,WAAY,IAAU,EACZ,WACV,IAAM,GAAO,CACX,EAAS,QAAQ,GAAS,GAE5B,CAPK,EAAK,QAOV,CACF,CACE"}
1
+ {"version":3,"file":"slash-command-menu.cjs","names":[],"sources":["../../../../../src/components/features/chat/components/slash-command-menu.tsx"],"sourcesContent":["import React, { useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { cn } from \"#/utils/utils\";\nimport {\n dropdownInstantColorClassName,\n dropdownMenuListClassName,\n} from \"#/utils/dropdown-classes\";\nimport { Text } from \"#/ui/typography\";\nimport { SlashCommandItem } from \"#/hooks/chat/use-slash-command\";\n\n/**\n * Strip common inline Markdown syntax so descriptions render as plain text.\n * Handles: bold, italic, inline code, links, and images.\n */\nexport function stripMarkdown(text: string): string {\n return (\n text\n // Images: ![alt](url) → alt\n .replace(/!\\[([^\\]]*)\\]\\([^)]*\\)/g, \"$1\")\n // Links: [text](url) → text\n .replace(/\\[([^\\]]*)\\]\\([^)]*\\)/g, \"$1\")\n // Bold/italic: ***text***, **text**, *text*, ___text___, __text__, _text_\n .replace(/\\*{3}(.+?)\\*{3}/g, \"$1\")\n .replace(/\\*{2}(.+?)\\*{2}/g, \"$1\")\n .replace(/\\*(.+?)\\*/g, \"$1\")\n .replace(/_{3}(.+?)_{3}/g, \"$1\")\n .replace(/_{2}(.+?)_{2}/g, \"$1\")\n .replace(/_(.+?)_/g, \"$1\")\n // Inline code: `text` → text\n .replace(/`(.+?)`/g, \"$1\")\n // Strikethrough: ~~text~~ → text\n .replace(/~~(.+?)~~/g, \"$1\")\n );\n}\n\n/**\n * Extract a short description from skill content.\n * Tries YAML frontmatter \"description:\" first, then falls back\n * to the first meaningful line after headers and frontmatter.\n * Returns plain text with Markdown formatting stripped.\n */\nexport function getSkillDescription(content: string): string | null {\n let body = content;\n\n // Try to extract description from YAML frontmatter\n const frontmatterMatch = content.match(/^---\\s*\\n([\\s\\S]*?)\\n---/);\n if (frontmatterMatch) {\n const descMatch = frontmatterMatch[1].match(/^description:\\s*(.+)$/m);\n if (descMatch) {\n let desc = descMatch[1].trim();\n // Strip surrounding quotes from YAML values\n if (\n (desc.startsWith('\"') && desc.endsWith('\"')) ||\n (desc.startsWith(\"'\") && desc.endsWith(\"'\"))\n ) {\n desc = desc.slice(1, -1);\n }\n return stripMarkdown(desc);\n }\n // Skip frontmatter for body parsing\n body = content.slice(frontmatterMatch[0].length);\n }\n\n // Fall back to first meaningful line (skip headers, empty lines, frontmatter delimiters)\n const meaningful = body\n .split(\"\\n\")\n .map((line) => line.trim())\n .find((line) => line.length > 0 && !line.startsWith(\"#\") && line !== \"---\");\n\n if (!meaningful) return null;\n\n // Strip Markdown first so URLs inside links don't confuse sentence detection\n const stripped = stripMarkdown(meaningful);\n const sentence = stripped.match(/^[^.!?\\n]*[.!?]/);\n return sentence?.[0] || stripped;\n}\n\ninterface SlashCommandMenuItemProps {\n item: SlashCommandItem;\n isSelected: boolean;\n onSelect: (item: SlashCommandItem) => void;\n ref?: React.Ref<HTMLButtonElement>;\n}\n\nfunction SlashCommandMenuItem({\n item,\n isSelected,\n onSelect,\n ref,\n}: SlashCommandMenuItemProps) {\n const description = useMemo(() => {\n if (\"description\" in item.skill && item.skill.description) {\n return stripMarkdown(item.skill.description);\n }\n if (\"content\" in item.skill && item.skill.content) {\n return getSkillDescription(item.skill.content);\n }\n return null;\n }, [item.skill]);\n\n return (\n <button\n role=\"option\"\n aria-selected={isSelected}\n ref={ref}\n type=\"button\"\n className={cn(\n \"w-full px-3 py-2.5 text-left\",\n dropdownInstantColorClassName,\n isSelected ? \"bg-tertiary\" : \"hover:bg-[var(--oh-surface-raised)]\",\n )}\n onMouseDown={(e) => {\n // Use mouseDown instead of click to fire before input blur\n e.preventDefault();\n onSelect(item);\n }}\n >\n <Text className=\"font-normal\">{item.command}</Text>\n {description && (\n <Text className=\"text-xs text-[var(--oh-muted)] mt-0.5 truncate block\">\n {description}\n </Text>\n )}\n </button>\n );\n}\n\ninterface SlashCommandMenuProps {\n items: SlashCommandItem[];\n selectedIndex: number;\n onSelect: (item: SlashCommandItem) => void;\n}\n\nexport function SlashCommandMenu({\n items,\n selectedIndex,\n onSelect,\n}: SlashCommandMenuProps) {\n const { t } = useTranslation(\"openhands\");\n const itemRefs = useRef<(HTMLButtonElement | null)[]>([]);\n\n // Keep refs array in sync with items length\n useEffect(() => {\n itemRefs.current = itemRefs.current.slice(0, items.length);\n }, [items.length]);\n\n // Scroll selected item into view\n useEffect(() => {\n const selectedItem = itemRefs.current[selectedIndex];\n if (selectedItem) {\n selectedItem.scrollIntoView({ block: \"nearest\" });\n }\n }, [selectedIndex]);\n\n if (items.length === 0) return null;\n\n return (\n <div\n role=\"listbox\"\n aria-label={t(\"CHAT_INTERFACE$COMMANDS\")}\n className=\"absolute bottom-full left-0 w-full mb-1 bg-[var(--oh-surface)] border border-[var(--oh-border-subtle)] rounded-lg shadow-lg max-h-[300px] overflow-y-auto custom-scrollbar z-50\"\n data-testid=\"slash-command-menu\"\n >\n <div className=\"px-3 py-2 text-xs text-[var(--oh-muted)] border-b border-[var(--oh-border-subtle)]\">\n {t(\"CHAT_INTERFACE$COMMANDS\")}\n </div>\n <div className={dropdownMenuListClassName}>\n {items.map((item, index) => (\n <SlashCommandMenuItem\n key={item.command}\n item={item}\n isSelected={index === selectedIndex}\n onSelect={onSelect}\n ref={(el) => {\n itemRefs.current[index] = el;\n }}\n />\n ))}\n </div>\n </div>\n );\n}\n"],"mappings":"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"}
@@ -1,73 +1,77 @@
1
1
  import { useTranslation as e } from "../../../../node_modules/react-i18next/dist/es/useTranslation.js";
2
2
  import { cn as t } from "../../../../utils/utils.js";
3
3
  import { Text as n } from "../../../../ui/typography.js";
4
- import { useEffect as r, useMemo as i, useRef as a } from "react";
5
- import { jsx as o, jsxs as s } from "react/jsx-runtime";
4
+ import { dropdownInstantColorClassName as r, dropdownMenuListClassName as i } from "../../../../utils/dropdown-classes.js";
5
+ import { useEffect as a, useMemo as o, useRef as s } from "react";
6
+ import { jsx as c, jsxs as l } from "react/jsx-runtime";
6
7
  //#region src/components/features/chat/components/slash-command-menu.tsx
7
- function c(e) {
8
+ function u(e) {
8
9
  return e.replace(/!\[([^\]]*)\]\([^)]*\)/g, "$1").replace(/\[([^\]]*)\]\([^)]*\)/g, "$1").replace(/\*{3}(.+?)\*{3}/g, "$1").replace(/\*{2}(.+?)\*{2}/g, "$1").replace(/\*(.+?)\*/g, "$1").replace(/_{3}(.+?)_{3}/g, "$1").replace(/_{2}(.+?)_{2}/g, "$1").replace(/_(.+?)_/g, "$1").replace(/`(.+?)`/g, "$1").replace(/~~(.+?)~~/g, "$1");
9
10
  }
10
- function l(e) {
11
+ function d(e) {
11
12
  let t = e, n = e.match(/^---\s*\n([\s\S]*?)\n---/);
12
13
  if (n) {
13
14
  let r = n[1].match(/^description:\s*(.+)$/m);
14
15
  if (r) {
15
16
  let e = r[1].trim();
16
- return (e.startsWith("\"") && e.endsWith("\"") || e.startsWith("'") && e.endsWith("'")) && (e = e.slice(1, -1)), c(e);
17
+ return (e.startsWith("\"") && e.endsWith("\"") || e.startsWith("'") && e.endsWith("'")) && (e = e.slice(1, -1)), u(e);
17
18
  }
18
19
  t = e.slice(n[0].length);
19
20
  }
20
21
  let r = t.split("\n").map((e) => e.trim()).find((e) => e.length > 0 && !e.startsWith("#") && e !== "---");
21
22
  if (!r) return null;
22
- let i = c(r);
23
+ let i = u(r);
23
24
  return i.match(/^[^.!?\n]*[.!?]/)?.[0] || i;
24
25
  }
25
- function u({ item: e, isSelected: r, onSelect: a, ref: u }) {
26
- let d = i(() => "description" in e.skill && e.skill.description ? c(e.skill.description) : "content" in e.skill && e.skill.content ? l(e.skill.content) : null, [e.skill]);
27
- return /* @__PURE__ */ s("button", {
26
+ function f({ item: e, isSelected: i, onSelect: a, ref: s }) {
27
+ let f = o(() => "description" in e.skill && e.skill.description ? u(e.skill.description) : "content" in e.skill && e.skill.content ? d(e.skill.content) : null, [e.skill]);
28
+ return /* @__PURE__ */ l("button", {
28
29
  role: "option",
29
- "aria-selected": r,
30
- ref: u,
30
+ "aria-selected": i,
31
+ ref: s,
31
32
  type: "button",
32
- className: t("w-full px-3 py-2.5 text-left transition-colors", r ? "bg-tertiary" : "hover:bg-[var(--oh-surface-raised)]"),
33
+ className: t("w-full px-3 py-2.5 text-left", r, i ? "bg-tertiary" : "hover:bg-[var(--oh-surface-raised)]"),
33
34
  onMouseDown: (t) => {
34
35
  t.preventDefault(), a(e);
35
36
  },
36
- children: [/* @__PURE__ */ o(n, {
37
+ children: [/* @__PURE__ */ c(n, {
37
38
  className: "font-normal",
38
39
  children: e.command
39
- }), d && /* @__PURE__ */ o(n, {
40
+ }), f && /* @__PURE__ */ c(n, {
40
41
  className: "text-xs text-[var(--oh-muted)] mt-0.5 truncate block",
41
- children: d
42
+ children: f
42
43
  })]
43
44
  });
44
45
  }
45
- function d({ items: t, selectedIndex: n, onSelect: i }) {
46
- let { t: c } = e("openhands"), l = a([]);
47
- return r(() => {
48
- l.current = l.current.slice(0, t.length);
49
- }, [t.length]), r(() => {
50
- let e = l.current[n];
46
+ function p({ items: t, selectedIndex: n, onSelect: r }) {
47
+ let { t: o } = e("openhands"), u = s([]);
48
+ return a(() => {
49
+ u.current = u.current.slice(0, t.length);
50
+ }, [t.length]), a(() => {
51
+ let e = u.current[n];
51
52
  e && e.scrollIntoView({ block: "nearest" });
52
- }, [n]), t.length === 0 ? null : /* @__PURE__ */ s("div", {
53
+ }, [n]), t.length === 0 ? null : /* @__PURE__ */ l("div", {
53
54
  role: "listbox",
54
- "aria-label": c("CHAT_INTERFACE$COMMANDS"),
55
+ "aria-label": o("CHAT_INTERFACE$COMMANDS"),
55
56
  className: "absolute bottom-full left-0 w-full mb-1 bg-[var(--oh-surface)] border border-[var(--oh-border-subtle)] rounded-lg shadow-lg max-h-[300px] overflow-y-auto custom-scrollbar z-50",
56
57
  "data-testid": "slash-command-menu",
57
- children: [/* @__PURE__ */ o("div", {
58
+ children: [/* @__PURE__ */ c("div", {
58
59
  className: "px-3 py-2 text-xs text-[var(--oh-muted)] border-b border-[var(--oh-border-subtle)]",
59
- children: c("CHAT_INTERFACE$COMMANDS")
60
- }), t.map((e, t) => /* @__PURE__ */ o(u, {
61
- item: e,
62
- isSelected: t === n,
63
- onSelect: i,
64
- ref: (e) => {
65
- l.current[t] = e;
66
- }
67
- }, e.command))]
60
+ children: o("CHAT_INTERFACE$COMMANDS")
61
+ }), /* @__PURE__ */ c("div", {
62
+ className: i,
63
+ children: t.map((e, t) => /* @__PURE__ */ c(f, {
64
+ item: e,
65
+ isSelected: t === n,
66
+ onSelect: r,
67
+ ref: (e) => {
68
+ u.current[t] = e;
69
+ }
70
+ }, e.command))
71
+ })]
68
72
  });
69
73
  }
70
74
  //#endregion
71
- export { d as SlashCommandMenu };
75
+ export { p as SlashCommandMenu };
72
76
 
73
77
  //# sourceMappingURL=slash-command-menu.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"slash-command-menu.js","names":[],"sources":["../../../../../src/components/features/chat/components/slash-command-menu.tsx"],"sourcesContent":["import React, { useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { cn } from \"#/utils/utils\";\nimport { Text } from \"#/ui/typography\";\nimport { SlashCommandItem } from \"#/hooks/chat/use-slash-command\";\n\n/**\n * Strip common inline Markdown syntax so descriptions render as plain text.\n * Handles: bold, italic, inline code, links, and images.\n */\nexport function stripMarkdown(text: string): string {\n return (\n text\n // Images: ![alt](url) → alt\n .replace(/!\\[([^\\]]*)\\]\\([^)]*\\)/g, \"$1\")\n // Links: [text](url) → text\n .replace(/\\[([^\\]]*)\\]\\([^)]*\\)/g, \"$1\")\n // Bold/italic: ***text***, **text**, *text*, ___text___, __text__, _text_\n .replace(/\\*{3}(.+?)\\*{3}/g, \"$1\")\n .replace(/\\*{2}(.+?)\\*{2}/g, \"$1\")\n .replace(/\\*(.+?)\\*/g, \"$1\")\n .replace(/_{3}(.+?)_{3}/g, \"$1\")\n .replace(/_{2}(.+?)_{2}/g, \"$1\")\n .replace(/_(.+?)_/g, \"$1\")\n // Inline code: `text` → text\n .replace(/`(.+?)`/g, \"$1\")\n // Strikethrough: ~~text~~ → text\n .replace(/~~(.+?)~~/g, \"$1\")\n );\n}\n\n/**\n * Extract a short description from skill content.\n * Tries YAML frontmatter \"description:\" first, then falls back\n * to the first meaningful line after headers and frontmatter.\n * Returns plain text with Markdown formatting stripped.\n */\nexport function getSkillDescription(content: string): string | null {\n let body = content;\n\n // Try to extract description from YAML frontmatter\n const frontmatterMatch = content.match(/^---\\s*\\n([\\s\\S]*?)\\n---/);\n if (frontmatterMatch) {\n const descMatch = frontmatterMatch[1].match(/^description:\\s*(.+)$/m);\n if (descMatch) {\n let desc = descMatch[1].trim();\n // Strip surrounding quotes from YAML values\n if (\n (desc.startsWith('\"') && desc.endsWith('\"')) ||\n (desc.startsWith(\"'\") && desc.endsWith(\"'\"))\n ) {\n desc = desc.slice(1, -1);\n }\n return stripMarkdown(desc);\n }\n // Skip frontmatter for body parsing\n body = content.slice(frontmatterMatch[0].length);\n }\n\n // Fall back to first meaningful line (skip headers, empty lines, frontmatter delimiters)\n const meaningful = body\n .split(\"\\n\")\n .map((line) => line.trim())\n .find((line) => line.length > 0 && !line.startsWith(\"#\") && line !== \"---\");\n\n if (!meaningful) return null;\n\n // Strip Markdown first so URLs inside links don't confuse sentence detection\n const stripped = stripMarkdown(meaningful);\n const sentence = stripped.match(/^[^.!?\\n]*[.!?]/);\n return sentence?.[0] || stripped;\n}\n\ninterface SlashCommandMenuItemProps {\n item: SlashCommandItem;\n isSelected: boolean;\n onSelect: (item: SlashCommandItem) => void;\n ref?: React.Ref<HTMLButtonElement>;\n}\n\nfunction SlashCommandMenuItem({\n item,\n isSelected,\n onSelect,\n ref,\n}: SlashCommandMenuItemProps) {\n const description = useMemo(() => {\n if (\"description\" in item.skill && item.skill.description) {\n return stripMarkdown(item.skill.description);\n }\n if (\"content\" in item.skill && item.skill.content) {\n return getSkillDescription(item.skill.content);\n }\n return null;\n }, [item.skill]);\n\n return (\n <button\n role=\"option\"\n aria-selected={isSelected}\n ref={ref}\n type=\"button\"\n className={cn(\n \"w-full px-3 py-2.5 text-left transition-colors\",\n isSelected ? \"bg-tertiary\" : \"hover:bg-[var(--oh-surface-raised)]\",\n )}\n onMouseDown={(e) => {\n // Use mouseDown instead of click to fire before input blur\n e.preventDefault();\n onSelect(item);\n }}\n >\n <Text className=\"font-normal\">{item.command}</Text>\n {description && (\n <Text className=\"text-xs text-[var(--oh-muted)] mt-0.5 truncate block\">\n {description}\n </Text>\n )}\n </button>\n );\n}\n\ninterface SlashCommandMenuProps {\n items: SlashCommandItem[];\n selectedIndex: number;\n onSelect: (item: SlashCommandItem) => void;\n}\n\nexport function SlashCommandMenu({\n items,\n selectedIndex,\n onSelect,\n}: SlashCommandMenuProps) {\n const { t } = useTranslation(\"openhands\");\n const itemRefs = useRef<(HTMLButtonElement | null)[]>([]);\n\n // Keep refs array in sync with items length\n useEffect(() => {\n itemRefs.current = itemRefs.current.slice(0, items.length);\n }, [items.length]);\n\n // Scroll selected item into view\n useEffect(() => {\n const selectedItem = itemRefs.current[selectedIndex];\n if (selectedItem) {\n selectedItem.scrollIntoView({ block: \"nearest\" });\n }\n }, [selectedIndex]);\n\n if (items.length === 0) return null;\n\n return (\n <div\n role=\"listbox\"\n aria-label={t(\"CHAT_INTERFACE$COMMANDS\")}\n className=\"absolute bottom-full left-0 w-full mb-1 bg-[var(--oh-surface)] border border-[var(--oh-border-subtle)] rounded-lg shadow-lg max-h-[300px] overflow-y-auto custom-scrollbar z-50\"\n data-testid=\"slash-command-menu\"\n >\n <div className=\"px-3 py-2 text-xs text-[var(--oh-muted)] border-b border-[var(--oh-border-subtle)]\">\n {t(\"CHAT_INTERFACE$COMMANDS\")}\n </div>\n {items.map((item, index) => (\n <SlashCommandMenuItem\n key={item.command}\n item={item}\n isSelected={index === selectedIndex}\n onSelect={onSelect}\n ref={(el) => {\n itemRefs.current[index] = el;\n }}\n />\n ))}\n </div>\n );\n}\n"],"mappings":";;;;;;AAUA,SAAgB,EAAc,GAAsB;AAClD,QACE,EAEG,QAAQ,2BAA2B,KAAK,CAExC,QAAQ,0BAA0B,KAAK,CAEvC,QAAQ,oBAAoB,KAAK,CACjC,QAAQ,oBAAoB,KAAK,CACjC,QAAQ,cAAc,KAAK,CAC3B,QAAQ,kBAAkB,KAAK,CAC/B,QAAQ,kBAAkB,KAAK,CAC/B,QAAQ,YAAY,KAAK,CAEzB,QAAQ,YAAY,KAAK,CAEzB,QAAQ,cAAc,KAAK;;AAUlC,SAAgB,EAAoB,GAAgC;CAClE,IAAI,IAAO,GAGL,IAAmB,EAAQ,MAAM,2BAA2B;AAClE,KAAI,GAAkB;EACpB,IAAM,IAAY,EAAiB,GAAG,MAAM,yBAAyB;AACrE,MAAI,GAAW;GACb,IAAI,IAAO,EAAU,GAAG,MAAM;AAQ9B,WALG,EAAK,WAAW,KAAI,IAAI,EAAK,SAAS,KAAI,IAC1C,EAAK,WAAW,IAAI,IAAI,EAAK,SAAS,IAAI,MAE3C,IAAO,EAAK,MAAM,GAAG,GAAG,GAEnB,EAAc,EAAK;;AAG5B,MAAO,EAAQ,MAAM,EAAiB,GAAG,OAAO;;CAIlD,IAAM,IAAa,EAChB,MAAM,KAAK,CACX,KAAK,MAAS,EAAK,MAAM,CAAC,CAC1B,MAAM,MAAS,EAAK,SAAS,KAAK,CAAC,EAAK,WAAW,IAAI,IAAI,MAAS,MAAM;AAE7E,KAAI,CAAC,EAAY,QAAO;CAGxB,IAAM,IAAW,EAAc,EAAW;AAE1C,QADiB,EAAS,MAAM,kBACzB,GAAW,MAAM;;AAU1B,SAAS,EAAqB,EAC5B,SACA,eACA,aACA,UAC4B;CAC5B,IAAM,IAAc,QACd,iBAAiB,EAAK,SAAS,EAAK,MAAM,cACrC,EAAc,EAAK,MAAM,YAAY,GAE1C,aAAa,EAAK,SAAS,EAAK,MAAM,UACjC,EAAoB,EAAK,MAAM,QAAQ,GAEzC,MACN,CAAC,EAAK,MAAM,CAAC;AAEhB,QACE,kBAAC,UAAD;EACE,MAAK;EACL,iBAAe;EACV;EACL,MAAK;EACL,WAAW,EACT,kDACA,IAAa,gBAAgB,sCAC9B;EACD,cAAc,MAAM;AAGlB,GADA,EAAE,gBAAgB,EAClB,EAAS,EAAK;;YAZlB,CAeE,kBAAC,GAAD;GAAM,WAAU;aAAe,EAAK;GAAe,CAAA,EAClD,KACC,kBAAC,GAAD;GAAM,WAAU;aACb;GACI,CAAA,CAEF;;;AAUb,SAAgB,EAAiB,EAC/B,UACA,kBACA,eACwB;CACxB,IAAM,EAAE,SAAM,EAAe,YAAY,EACnC,IAAW,EAAqC,EAAE,CAAC;AAiBzD,QAdA,QAAgB;AACd,IAAS,UAAU,EAAS,QAAQ,MAAM,GAAG,EAAM,OAAO;IACzD,CAAC,EAAM,OAAO,CAAC,EAGlB,QAAgB;EACd,IAAM,IAAe,EAAS,QAAQ;AACtC,EAAI,KACF,EAAa,eAAe,EAAE,OAAO,WAAW,CAAC;IAElD,CAAC,EAAc,CAAC,EAEf,EAAM,WAAW,IAAU,OAG7B,kBAAC,OAAD;EACE,MAAK;EACL,cAAY,EAAE,0BAA0B;EACxC,WAAU;EACV,eAAY;YAJd,CAME,kBAAC,OAAD;GAAK,WAAU;aACZ,EAAE,0BAA0B;GACzB,CAAA,EACL,EAAM,KAAK,GAAM,MAChB,kBAAC,GAAD;GAEQ;GACN,YAAY,MAAU;GACZ;GACV,MAAM,MAAO;AACX,MAAS,QAAQ,KAAS;;GAE5B,EAPK,EAAK,QAOV,CACF,CACE"}
1
+ {"version":3,"file":"slash-command-menu.js","names":[],"sources":["../../../../../src/components/features/chat/components/slash-command-menu.tsx"],"sourcesContent":["import React, { useEffect, useMemo, useRef } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { cn } from \"#/utils/utils\";\nimport {\n dropdownInstantColorClassName,\n dropdownMenuListClassName,\n} from \"#/utils/dropdown-classes\";\nimport { Text } from \"#/ui/typography\";\nimport { SlashCommandItem } from \"#/hooks/chat/use-slash-command\";\n\n/**\n * Strip common inline Markdown syntax so descriptions render as plain text.\n * Handles: bold, italic, inline code, links, and images.\n */\nexport function stripMarkdown(text: string): string {\n return (\n text\n // Images: ![alt](url) → alt\n .replace(/!\\[([^\\]]*)\\]\\([^)]*\\)/g, \"$1\")\n // Links: [text](url) → text\n .replace(/\\[([^\\]]*)\\]\\([^)]*\\)/g, \"$1\")\n // Bold/italic: ***text***, **text**, *text*, ___text___, __text__, _text_\n .replace(/\\*{3}(.+?)\\*{3}/g, \"$1\")\n .replace(/\\*{2}(.+?)\\*{2}/g, \"$1\")\n .replace(/\\*(.+?)\\*/g, \"$1\")\n .replace(/_{3}(.+?)_{3}/g, \"$1\")\n .replace(/_{2}(.+?)_{2}/g, \"$1\")\n .replace(/_(.+?)_/g, \"$1\")\n // Inline code: `text` → text\n .replace(/`(.+?)`/g, \"$1\")\n // Strikethrough: ~~text~~ → text\n .replace(/~~(.+?)~~/g, \"$1\")\n );\n}\n\n/**\n * Extract a short description from skill content.\n * Tries YAML frontmatter \"description:\" first, then falls back\n * to the first meaningful line after headers and frontmatter.\n * Returns plain text with Markdown formatting stripped.\n */\nexport function getSkillDescription(content: string): string | null {\n let body = content;\n\n // Try to extract description from YAML frontmatter\n const frontmatterMatch = content.match(/^---\\s*\\n([\\s\\S]*?)\\n---/);\n if (frontmatterMatch) {\n const descMatch = frontmatterMatch[1].match(/^description:\\s*(.+)$/m);\n if (descMatch) {\n let desc = descMatch[1].trim();\n // Strip surrounding quotes from YAML values\n if (\n (desc.startsWith('\"') && desc.endsWith('\"')) ||\n (desc.startsWith(\"'\") && desc.endsWith(\"'\"))\n ) {\n desc = desc.slice(1, -1);\n }\n return stripMarkdown(desc);\n }\n // Skip frontmatter for body parsing\n body = content.slice(frontmatterMatch[0].length);\n }\n\n // Fall back to first meaningful line (skip headers, empty lines, frontmatter delimiters)\n const meaningful = body\n .split(\"\\n\")\n .map((line) => line.trim())\n .find((line) => line.length > 0 && !line.startsWith(\"#\") && line !== \"---\");\n\n if (!meaningful) return null;\n\n // Strip Markdown first so URLs inside links don't confuse sentence detection\n const stripped = stripMarkdown(meaningful);\n const sentence = stripped.match(/^[^.!?\\n]*[.!?]/);\n return sentence?.[0] || stripped;\n}\n\ninterface SlashCommandMenuItemProps {\n item: SlashCommandItem;\n isSelected: boolean;\n onSelect: (item: SlashCommandItem) => void;\n ref?: React.Ref<HTMLButtonElement>;\n}\n\nfunction SlashCommandMenuItem({\n item,\n isSelected,\n onSelect,\n ref,\n}: SlashCommandMenuItemProps) {\n const description = useMemo(() => {\n if (\"description\" in item.skill && item.skill.description) {\n return stripMarkdown(item.skill.description);\n }\n if (\"content\" in item.skill && item.skill.content) {\n return getSkillDescription(item.skill.content);\n }\n return null;\n }, [item.skill]);\n\n return (\n <button\n role=\"option\"\n aria-selected={isSelected}\n ref={ref}\n type=\"button\"\n className={cn(\n \"w-full px-3 py-2.5 text-left\",\n dropdownInstantColorClassName,\n isSelected ? \"bg-tertiary\" : \"hover:bg-[var(--oh-surface-raised)]\",\n )}\n onMouseDown={(e) => {\n // Use mouseDown instead of click to fire before input blur\n e.preventDefault();\n onSelect(item);\n }}\n >\n <Text className=\"font-normal\">{item.command}</Text>\n {description && (\n <Text className=\"text-xs text-[var(--oh-muted)] mt-0.5 truncate block\">\n {description}\n </Text>\n )}\n </button>\n );\n}\n\ninterface SlashCommandMenuProps {\n items: SlashCommandItem[];\n selectedIndex: number;\n onSelect: (item: SlashCommandItem) => void;\n}\n\nexport function SlashCommandMenu({\n items,\n selectedIndex,\n onSelect,\n}: SlashCommandMenuProps) {\n const { t } = useTranslation(\"openhands\");\n const itemRefs = useRef<(HTMLButtonElement | null)[]>([]);\n\n // Keep refs array in sync with items length\n useEffect(() => {\n itemRefs.current = itemRefs.current.slice(0, items.length);\n }, [items.length]);\n\n // Scroll selected item into view\n useEffect(() => {\n const selectedItem = itemRefs.current[selectedIndex];\n if (selectedItem) {\n selectedItem.scrollIntoView({ block: \"nearest\" });\n }\n }, [selectedIndex]);\n\n if (items.length === 0) return null;\n\n return (\n <div\n role=\"listbox\"\n aria-label={t(\"CHAT_INTERFACE$COMMANDS\")}\n className=\"absolute bottom-full left-0 w-full mb-1 bg-[var(--oh-surface)] border border-[var(--oh-border-subtle)] rounded-lg shadow-lg max-h-[300px] overflow-y-auto custom-scrollbar z-50\"\n data-testid=\"slash-command-menu\"\n >\n <div className=\"px-3 py-2 text-xs text-[var(--oh-muted)] border-b border-[var(--oh-border-subtle)]\">\n {t(\"CHAT_INTERFACE$COMMANDS\")}\n </div>\n <div className={dropdownMenuListClassName}>\n {items.map((item, index) => (\n <SlashCommandMenuItem\n key={item.command}\n item={item}\n isSelected={index === selectedIndex}\n onSelect={onSelect}\n ref={(el) => {\n itemRefs.current[index] = el;\n }}\n />\n ))}\n </div>\n </div>\n );\n}\n"],"mappings":";;;;;;;AAcA,SAAgB,EAAc,GAAsB;AAClD,QACE,EAEG,QAAQ,2BAA2B,KAAK,CAExC,QAAQ,0BAA0B,KAAK,CAEvC,QAAQ,oBAAoB,KAAK,CACjC,QAAQ,oBAAoB,KAAK,CACjC,QAAQ,cAAc,KAAK,CAC3B,QAAQ,kBAAkB,KAAK,CAC/B,QAAQ,kBAAkB,KAAK,CAC/B,QAAQ,YAAY,KAAK,CAEzB,QAAQ,YAAY,KAAK,CAEzB,QAAQ,cAAc,KAAK;;AAUlC,SAAgB,EAAoB,GAAgC;CAClE,IAAI,IAAO,GAGL,IAAmB,EAAQ,MAAM,2BAA2B;AAClE,KAAI,GAAkB;EACpB,IAAM,IAAY,EAAiB,GAAG,MAAM,yBAAyB;AACrE,MAAI,GAAW;GACb,IAAI,IAAO,EAAU,GAAG,MAAM;AAQ9B,WALG,EAAK,WAAW,KAAI,IAAI,EAAK,SAAS,KAAI,IAC1C,EAAK,WAAW,IAAI,IAAI,EAAK,SAAS,IAAI,MAE3C,IAAO,EAAK,MAAM,GAAG,GAAG,GAEnB,EAAc,EAAK;;AAG5B,MAAO,EAAQ,MAAM,EAAiB,GAAG,OAAO;;CAIlD,IAAM,IAAa,EAChB,MAAM,KAAK,CACX,KAAK,MAAS,EAAK,MAAM,CAAC,CAC1B,MAAM,MAAS,EAAK,SAAS,KAAK,CAAC,EAAK,WAAW,IAAI,IAAI,MAAS,MAAM;AAE7E,KAAI,CAAC,EAAY,QAAO;CAGxB,IAAM,IAAW,EAAc,EAAW;AAE1C,QADiB,EAAS,MAAM,kBACzB,GAAW,MAAM;;AAU1B,SAAS,EAAqB,EAC5B,SACA,eACA,aACA,UAC4B;CAC5B,IAAM,IAAc,QACd,iBAAiB,EAAK,SAAS,EAAK,MAAM,cACrC,EAAc,EAAK,MAAM,YAAY,GAE1C,aAAa,EAAK,SAAS,EAAK,MAAM,UACjC,EAAoB,EAAK,MAAM,QAAQ,GAEzC,MACN,CAAC,EAAK,MAAM,CAAC;AAEhB,QACE,kBAAC,UAAD;EACE,MAAK;EACL,iBAAe;EACV;EACL,MAAK;EACL,WAAW,EACT,gCACA,GACA,IAAa,gBAAgB,sCAC9B;EACD,cAAc,MAAM;AAGlB,GADA,EAAE,gBAAgB,EAClB,EAAS,EAAK;;YAblB,CAgBE,kBAAC,GAAD;GAAM,WAAU;aAAe,EAAK;GAAe,CAAA,EAClD,KACC,kBAAC,GAAD;GAAM,WAAU;aACb;GACI,CAAA,CAEF;;;AAUb,SAAgB,EAAiB,EAC/B,UACA,kBACA,eACwB;CACxB,IAAM,EAAE,SAAM,EAAe,YAAY,EACnC,IAAW,EAAqC,EAAE,CAAC;AAiBzD,QAdA,QAAgB;AACd,IAAS,UAAU,EAAS,QAAQ,MAAM,GAAG,EAAM,OAAO;IACzD,CAAC,EAAM,OAAO,CAAC,EAGlB,QAAgB;EACd,IAAM,IAAe,EAAS,QAAQ;AACtC,EAAI,KACF,EAAa,eAAe,EAAE,OAAO,WAAW,CAAC;IAElD,CAAC,EAAc,CAAC,EAEf,EAAM,WAAW,IAAU,OAG7B,kBAAC,OAAD;EACE,MAAK;EACL,cAAY,EAAE,0BAA0B;EACxC,WAAU;EACV,eAAY;YAJd,CAME,kBAAC,OAAD;GAAK,WAAU;aACZ,EAAE,0BAA0B;GACzB,CAAA,EACN,kBAAC,OAAD;GAAK,WAAW;aACb,EAAM,KAAK,GAAM,MAChB,kBAAC,GAAD;IAEQ;IACN,YAAY,MAAU;IACZ;IACV,MAAM,MAAO;AACX,OAAS,QAAQ,KAAS;;IAE5B,EAPK,EAAK,QAOV,CACF;GACE,CAAA,CACF"}
@@ -1,2 +1,2 @@
1
- require(`../../../_virtual/_rolldown/runtime.cjs`);const e=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),t=require(`../../../i18n/declaration.cjs`),n=require(`../../../utils/utils.cjs`),r=require(`../../../hooks/use-tracking.cjs`),i=require(`../../../icons/u-pr.cjs`);let a=require(`react/jsx-runtime`);function o({onSuggestionsClick:o,hasRepository:s,providerTokensReady:c,currentGitProvider:l,isConversationReady:u=!0}){let{t:d}=e.useTranslation(`openhands`),{trackCreatePrButtonClick:f}=r.useTracking(),p=c&&s&&u;return(0,a.jsxs)(`button`,{type:`button`,onClick:()=>{f(),o(n.getCreatePRPrompt(l))},disabled:!p,className:n.cn(`flex flex-row gap-1 items-center justify-center px-2 py-1 rounded-[100px] w-[126px] min-w-[126px] h-7`,p?`bg-[var(--oh-surface)] hover:bg-tertiary cursor-pointer`:`bg-[rgba(71,74,84,0.50)] cursor-not-allowed`),children:[(0,a.jsx)(`div`,{className:`w-3 h-3 flex items-center justify-center`,children:(0,a.jsx)(i.default,{width:12,height:12,color:`white`})}),(0,a.jsx)(`div`,{className:`font-normal text-white text-sm leading-5 max-w-[126px] truncate`,title:d(t.I18nKey.COMMON$PULL_REQUEST),children:d(t.I18nKey.COMMON$PULL_REQUEST)})]})}exports.GitControlBarPrButton=o;
1
+ require(`../../../_virtual/_rolldown/runtime.cjs`);const e=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),t=require(`../../../i18n/declaration.cjs`),n=require(`../../../utils/utils.cjs`),r=require(`../../../hooks/use-tracking.cjs`),i=require(`../../../icons/u-pr.cjs`),a=require(`../../../utils/git-control-bar-classes.cjs`);let o=require(`react/jsx-runtime`);function s({onSuggestionsClick:s,hasRepository:c,providerTokensReady:l,currentGitProvider:u,isConversationReady:d=!0}){let{t:f}=e.useTranslation(`openhands`),{trackCreatePrButtonClick:p}=r.useTracking(),m=l&&c&&d;return(0,o.jsxs)(`button`,{type:`button`,onClick:()=>{p(),s(n.getCreatePRPrompt(u))},disabled:!m,className:n.cn(a.gitControlBarActionButtonClassName(m),`px-2 py-1 w-[126px] min-w-[126px] h-7`),children:[(0,o.jsx)(`div`,{className:`w-3 h-3 flex items-center justify-center`,children:(0,o.jsx)(i.default,{width:12,height:12,color:a.gitControlBarActionIconColor(m)})}),(0,o.jsx)(`div`,{className:n.cn(a.gitControlBarActionLabelClassName,`max-w-[126px]`),title:f(t.I18nKey.COMMON$PULL_REQUEST),children:f(t.I18nKey.COMMON$PULL_REQUEST)})]})}exports.GitControlBarPrButton=s;
2
2
  //# sourceMappingURL=git-control-bar-pr-button.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"git-control-bar-pr-button.cjs","names":[],"sources":["../../../../src/components/features/chat/git-control-bar-pr-button.tsx"],"sourcesContent":["import { useTranslation } from \"react-i18next\";\nimport PRIcon from \"#/icons/u-pr.svg?react\";\nimport { cn, getCreatePRPrompt } from \"#/utils/utils\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { Provider } from \"#/types/settings\";\nimport { useTracking } from \"#/hooks/use-tracking\";\n\ninterface GitControlBarPrButtonProps {\n onSuggestionsClick: (value: string) => void;\n hasRepository: boolean;\n providerTokensReady: boolean;\n currentGitProvider: Provider;\n isConversationReady?: boolean;\n}\n\nexport function GitControlBarPrButton({\n onSuggestionsClick,\n hasRepository,\n providerTokensReady,\n currentGitProvider,\n isConversationReady = true,\n}: GitControlBarPrButtonProps) {\n const { t } = useTranslation(\"openhands\");\n const { trackCreatePrButtonClick } = useTracking();\n\n const isButtonEnabled =\n providerTokensReady && hasRepository && isConversationReady;\n\n const handlePrClick = () => {\n trackCreatePrButtonClick();\n onSuggestionsClick(getCreatePRPrompt(currentGitProvider));\n };\n\n return (\n <button\n type=\"button\"\n onClick={handlePrClick}\n disabled={!isButtonEnabled}\n className={cn(\n \"flex flex-row gap-1 items-center justify-center px-2 py-1 rounded-[100px] w-[126px] min-w-[126px] h-7\",\n isButtonEnabled\n ? \"bg-[var(--oh-surface)] hover:bg-tertiary cursor-pointer\"\n : \"bg-[rgba(71,74,84,0.50)] cursor-not-allowed\",\n )}\n >\n <div className=\"w-3 h-3 flex items-center justify-center\">\n <PRIcon width={12} height={12} color=\"white\" />\n </div>\n <div\n className=\"font-normal text-white text-sm leading-5 max-w-[126px] truncate\"\n title={t(I18nKey.COMMON$PULL_REQUEST)}\n >\n {t(I18nKey.COMMON$PULL_REQUEST)}\n </div>\n </button>\n );\n}\n"],"mappings":"2UAeA,SAAgB,EAAsB,CACpC,qBACA,gBACA,sBACA,qBACA,sBAAsB,IACO,CAC7B,GAAM,CAAE,KAAM,EAAA,eAAe,YAAY,CACnC,CAAE,4BAA6B,EAAA,aAAa,CAE5C,EACJ,GAAuB,GAAiB,EAO1C,OACE,EAAA,EAAA,MAAC,SAAD,CACE,KAAK,SACL,YARwB,CAC1B,GAA0B,CAC1B,EAAmB,EAAA,kBAAkB,EAAmB,CAAC,EAOvD,SAAU,CAAC,EACX,UAAW,EAAA,GACT,wGACA,EACI,0DACA,8CACL,UATH,EAWE,EAAA,EAAA,KAAC,MAAD,CAAK,UAAU,qDACb,EAAA,EAAA,KAAC,EAAA,QAAD,CAAQ,MAAO,GAAI,OAAQ,GAAI,MAAM,QAAU,CAAA,CAC3C,CAAA,EACN,EAAA,EAAA,KAAC,MAAD,CACE,UAAU,kEACV,MAAO,EAAE,EAAA,QAAQ,oBAAoB,UAEpC,EAAE,EAAA,QAAQ,oBAAoB,CAC3B,CAAA,CACC"}
1
+ {"version":3,"file":"git-control-bar-pr-button.cjs","names":[],"sources":["../../../../src/components/features/chat/git-control-bar-pr-button.tsx"],"sourcesContent":["import { useTranslation } from \"react-i18next\";\nimport PRIcon from \"#/icons/u-pr.svg?react\";\nimport { cn, getCreatePRPrompt } from \"#/utils/utils\";\nimport {\n gitControlBarActionButtonClassName,\n gitControlBarActionIconColor,\n gitControlBarActionLabelClassName,\n} from \"#/utils/git-control-bar-classes\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { Provider } from \"#/types/settings\";\nimport { useTracking } from \"#/hooks/use-tracking\";\n\ninterface GitControlBarPrButtonProps {\n onSuggestionsClick: (value: string) => void;\n hasRepository: boolean;\n providerTokensReady: boolean;\n currentGitProvider: Provider;\n isConversationReady?: boolean;\n}\n\nexport function GitControlBarPrButton({\n onSuggestionsClick,\n hasRepository,\n providerTokensReady,\n currentGitProvider,\n isConversationReady = true,\n}: GitControlBarPrButtonProps) {\n const { t } = useTranslation(\"openhands\");\n const { trackCreatePrButtonClick } = useTracking();\n\n const isButtonEnabled =\n providerTokensReady && hasRepository && isConversationReady;\n\n const handlePrClick = () => {\n trackCreatePrButtonClick();\n onSuggestionsClick(getCreatePRPrompt(currentGitProvider));\n };\n\n return (\n <button\n type=\"button\"\n onClick={handlePrClick}\n disabled={!isButtonEnabled}\n className={cn(\n gitControlBarActionButtonClassName(isButtonEnabled),\n \"px-2 py-1 w-[126px] min-w-[126px] h-7\",\n )}\n >\n <div className=\"w-3 h-3 flex items-center justify-center\">\n <PRIcon\n width={12}\n height={12}\n color={gitControlBarActionIconColor(isButtonEnabled)}\n />\n </div>\n <div\n className={cn(gitControlBarActionLabelClassName, \"max-w-[126px]\")}\n title={t(I18nKey.COMMON$PULL_REQUEST)}\n >\n {t(I18nKey.COMMON$PULL_REQUEST)}\n </div>\n </button>\n );\n}\n"],"mappings":"mYAoBA,SAAgB,EAAsB,CACpC,qBACA,gBACA,sBACA,qBACA,sBAAsB,IACO,CAC7B,GAAM,CAAE,KAAM,EAAA,eAAe,YAAY,CACnC,CAAE,4BAA6B,EAAA,aAAa,CAE5C,EACJ,GAAuB,GAAiB,EAO1C,OACE,EAAA,EAAA,MAAC,SAAD,CACE,KAAK,SACL,YARwB,CAC1B,GAA0B,CAC1B,EAAmB,EAAA,kBAAkB,EAAmB,CAAC,EAOvD,SAAU,CAAC,EACX,UAAW,EAAA,GACT,EAAA,mCAAmC,EAAgB,CACnD,wCACD,UAPH,EASE,EAAA,EAAA,KAAC,MAAD,CAAK,UAAU,qDACb,EAAA,EAAA,KAAC,EAAA,QAAD,CACE,MAAO,GACP,OAAQ,GACR,MAAO,EAAA,6BAA6B,EAAgB,CACpD,CAAA,CACE,CAAA,EACN,EAAA,EAAA,KAAC,MAAD,CACE,UAAW,EAAA,GAAG,EAAA,kCAAmC,gBAAgB,CACjE,MAAO,EAAE,EAAA,QAAQ,oBAAoB,UAEpC,EAAE,EAAA,QAAQ,oBAAoB,CAC3B,CAAA,CACC"}
@@ -3,32 +3,33 @@ import { I18nKey as t } from "../../../i18n/declaration.js";
3
3
  import { cn as n, getCreatePRPrompt as r } from "../../../utils/utils.js";
4
4
  import { useTracking as i } from "../../../hooks/use-tracking.js";
5
5
  import a from "../../../icons/u-pr.js";
6
- import { jsx as o, jsxs as s } from "react/jsx-runtime";
6
+ import { gitControlBarActionButtonClassName as o, gitControlBarActionIconColor as s, gitControlBarActionLabelClassName as c } from "../../../utils/git-control-bar-classes.js";
7
+ import { jsx as l, jsxs as u } from "react/jsx-runtime";
7
8
  //#region src/components/features/chat/git-control-bar-pr-button.tsx
8
- function c({ onSuggestionsClick: c, hasRepository: l, providerTokensReady: u, currentGitProvider: d, isConversationReady: f = !0 }) {
9
- let { t: p } = e("openhands"), { trackCreatePrButtonClick: m } = i(), h = u && l && f;
10
- return /* @__PURE__ */ s("button", {
9
+ function d({ onSuggestionsClick: d, hasRepository: f, providerTokensReady: p, currentGitProvider: m, isConversationReady: h = !0 }) {
10
+ let { t: g } = e("openhands"), { trackCreatePrButtonClick: _ } = i(), v = p && f && h;
11
+ return /* @__PURE__ */ u("button", {
11
12
  type: "button",
12
13
  onClick: () => {
13
- m(), c(r(d));
14
+ _(), d(r(m));
14
15
  },
15
- disabled: !h,
16
- className: n("flex flex-row gap-1 items-center justify-center px-2 py-1 rounded-[100px] w-[126px] min-w-[126px] h-7", h ? "bg-[var(--oh-surface)] hover:bg-tertiary cursor-pointer" : "bg-[rgba(71,74,84,0.50)] cursor-not-allowed"),
17
- children: [/* @__PURE__ */ o("div", {
16
+ disabled: !v,
17
+ className: n(o(v), "px-2 py-1 w-[126px] min-w-[126px] h-7"),
18
+ children: [/* @__PURE__ */ l("div", {
18
19
  className: "w-3 h-3 flex items-center justify-center",
19
- children: /* @__PURE__ */ o(a, {
20
+ children: /* @__PURE__ */ l(a, {
20
21
  width: 12,
21
22
  height: 12,
22
- color: "white"
23
+ color: s(v)
23
24
  })
24
- }), /* @__PURE__ */ o("div", {
25
- className: "font-normal text-white text-sm leading-5 max-w-[126px] truncate",
26
- title: p(t.COMMON$PULL_REQUEST),
27
- children: p(t.COMMON$PULL_REQUEST)
25
+ }), /* @__PURE__ */ l("div", {
26
+ className: n(c, "max-w-[126px]"),
27
+ title: g(t.COMMON$PULL_REQUEST),
28
+ children: g(t.COMMON$PULL_REQUEST)
28
29
  })]
29
30
  });
30
31
  }
31
32
  //#endregion
32
- export { c as GitControlBarPrButton };
33
+ export { d as GitControlBarPrButton };
33
34
 
34
35
  //# sourceMappingURL=git-control-bar-pr-button.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"git-control-bar-pr-button.js","names":[],"sources":["../../../../src/components/features/chat/git-control-bar-pr-button.tsx"],"sourcesContent":["import { useTranslation } from \"react-i18next\";\nimport PRIcon from \"#/icons/u-pr.svg?react\";\nimport { cn, getCreatePRPrompt } from \"#/utils/utils\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { Provider } from \"#/types/settings\";\nimport { useTracking } from \"#/hooks/use-tracking\";\n\ninterface GitControlBarPrButtonProps {\n onSuggestionsClick: (value: string) => void;\n hasRepository: boolean;\n providerTokensReady: boolean;\n currentGitProvider: Provider;\n isConversationReady?: boolean;\n}\n\nexport function GitControlBarPrButton({\n onSuggestionsClick,\n hasRepository,\n providerTokensReady,\n currentGitProvider,\n isConversationReady = true,\n}: GitControlBarPrButtonProps) {\n const { t } = useTranslation(\"openhands\");\n const { trackCreatePrButtonClick } = useTracking();\n\n const isButtonEnabled =\n providerTokensReady && hasRepository && isConversationReady;\n\n const handlePrClick = () => {\n trackCreatePrButtonClick();\n onSuggestionsClick(getCreatePRPrompt(currentGitProvider));\n };\n\n return (\n <button\n type=\"button\"\n onClick={handlePrClick}\n disabled={!isButtonEnabled}\n className={cn(\n \"flex flex-row gap-1 items-center justify-center px-2 py-1 rounded-[100px] w-[126px] min-w-[126px] h-7\",\n isButtonEnabled\n ? \"bg-[var(--oh-surface)] hover:bg-tertiary cursor-pointer\"\n : \"bg-[rgba(71,74,84,0.50)] cursor-not-allowed\",\n )}\n >\n <div className=\"w-3 h-3 flex items-center justify-center\">\n <PRIcon width={12} height={12} color=\"white\" />\n </div>\n <div\n className=\"font-normal text-white text-sm leading-5 max-w-[126px] truncate\"\n title={t(I18nKey.COMMON$PULL_REQUEST)}\n >\n {t(I18nKey.COMMON$PULL_REQUEST)}\n </div>\n </button>\n );\n}\n"],"mappings":";;;;;;;AAeA,SAAgB,EAAsB,EACpC,uBACA,kBACA,wBACA,uBACA,yBAAsB,MACO;CAC7B,IAAM,EAAE,SAAM,EAAe,YAAY,EACnC,EAAE,gCAA6B,GAAa,EAE5C,IACJ,KAAuB,KAAiB;AAO1C,QACE,kBAAC,UAAD;EACE,MAAK;EACL,eARwB;AAE1B,GADA,GAA0B,EAC1B,EAAmB,EAAkB,EAAmB,CAAC;;EAOvD,UAAU,CAAC;EACX,WAAW,EACT,yGACA,IACI,4DACA,8CACL;YATH,CAWE,kBAAC,OAAD;GAAK,WAAU;aACb,kBAAC,GAAD;IAAQ,OAAO;IAAI,QAAQ;IAAI,OAAM;IAAU,CAAA;GAC3C,CAAA,EACN,kBAAC,OAAD;GACE,WAAU;GACV,OAAO,EAAE,EAAQ,oBAAoB;aAEpC,EAAE,EAAQ,oBAAoB;GAC3B,CAAA,CACC"}
1
+ {"version":3,"file":"git-control-bar-pr-button.js","names":[],"sources":["../../../../src/components/features/chat/git-control-bar-pr-button.tsx"],"sourcesContent":["import { useTranslation } from \"react-i18next\";\nimport PRIcon from \"#/icons/u-pr.svg?react\";\nimport { cn, getCreatePRPrompt } from \"#/utils/utils\";\nimport {\n gitControlBarActionButtonClassName,\n gitControlBarActionIconColor,\n gitControlBarActionLabelClassName,\n} from \"#/utils/git-control-bar-classes\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { Provider } from \"#/types/settings\";\nimport { useTracking } from \"#/hooks/use-tracking\";\n\ninterface GitControlBarPrButtonProps {\n onSuggestionsClick: (value: string) => void;\n hasRepository: boolean;\n providerTokensReady: boolean;\n currentGitProvider: Provider;\n isConversationReady?: boolean;\n}\n\nexport function GitControlBarPrButton({\n onSuggestionsClick,\n hasRepository,\n providerTokensReady,\n currentGitProvider,\n isConversationReady = true,\n}: GitControlBarPrButtonProps) {\n const { t } = useTranslation(\"openhands\");\n const { trackCreatePrButtonClick } = useTracking();\n\n const isButtonEnabled =\n providerTokensReady && hasRepository && isConversationReady;\n\n const handlePrClick = () => {\n trackCreatePrButtonClick();\n onSuggestionsClick(getCreatePRPrompt(currentGitProvider));\n };\n\n return (\n <button\n type=\"button\"\n onClick={handlePrClick}\n disabled={!isButtonEnabled}\n className={cn(\n gitControlBarActionButtonClassName(isButtonEnabled),\n \"px-2 py-1 w-[126px] min-w-[126px] h-7\",\n )}\n >\n <div className=\"w-3 h-3 flex items-center justify-center\">\n <PRIcon\n width={12}\n height={12}\n color={gitControlBarActionIconColor(isButtonEnabled)}\n />\n </div>\n <div\n className={cn(gitControlBarActionLabelClassName, \"max-w-[126px]\")}\n title={t(I18nKey.COMMON$PULL_REQUEST)}\n >\n {t(I18nKey.COMMON$PULL_REQUEST)}\n </div>\n </button>\n );\n}\n"],"mappings":";;;;;;;;AAoBA,SAAgB,EAAsB,EACpC,uBACA,kBACA,wBACA,uBACA,yBAAsB,MACO;CAC7B,IAAM,EAAE,SAAM,EAAe,YAAY,EACnC,EAAE,gCAA6B,GAAa,EAE5C,IACJ,KAAuB,KAAiB;AAO1C,QACE,kBAAC,UAAD;EACE,MAAK;EACL,eARwB;AAE1B,GADA,GAA0B,EAC1B,EAAmB,EAAkB,EAAmB,CAAC;;EAOvD,UAAU,CAAC;EACX,WAAW,EACT,EAAmC,EAAgB,EACnD,wCACD;YAPH,CASE,kBAAC,OAAD;GAAK,WAAU;aACb,kBAAC,GAAD;IACE,OAAO;IACP,QAAQ;IACR,OAAO,EAA6B,EAAgB;IACpD,CAAA;GACE,CAAA,EACN,kBAAC,OAAD;GACE,WAAW,EAAG,GAAmC,gBAAgB;GACjE,OAAO,EAAE,EAAQ,oBAAoB;aAEpC,EAAE,EAAQ,oBAAoB;GAC3B,CAAA,CACC"}
@@ -1,2 +1,2 @@
1
- require(`../../../_virtual/_rolldown/runtime.cjs`);const e=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),t=require(`../../../i18n/declaration.cjs`),n=require(`../../../utils/utils.cjs`),r=require(`../../../hooks/use-tracking.cjs`),i=require(`../../../icons/u-arrow-down.cjs`);let a=require(`react/jsx-runtime`);function o({onSuggestionsClick:o,hasRepository:s,providerTokensReady:c,isConversationReady:l=!0}){let{t:u}=e.useTranslation(`openhands`),{trackPullButtonClick:d}=r.useTracking(),f=c&&s&&l;return(0,a.jsxs)(`button`,{type:`button`,onClick:()=>{d(),o(n.getGitPullPrompt())},disabled:!f,className:n.cn(`flex flex-row gap-1 items-center justify-center px-0.5 py-1 rounded-[100px] w-[76px] min-w-[76px]`,f?`bg-[var(--oh-surface)] hover:bg-tertiary cursor-pointer`:`bg-[rgba(71,74,84,0.50)] cursor-not-allowed`),children:[(0,a.jsx)(`div`,{className:`w-3 h-3 flex items-center justify-center`,children:(0,a.jsx)(i.default,{width:12,height:12,color:`white`})}),(0,a.jsx)(`div`,{className:`font-normal text-white text-sm leading-5 max-w-[76px] truncate`,title:u(t.I18nKey.COMMON$PULL),children:u(t.I18nKey.COMMON$PULL)})]})}exports.GitControlBarPullButton=o;
1
+ require(`../../../_virtual/_rolldown/runtime.cjs`);const e=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),t=require(`../../../i18n/declaration.cjs`),n=require(`../../../utils/utils.cjs`),r=require(`../../../hooks/use-tracking.cjs`),i=require(`../../../icons/u-arrow-down.cjs`),a=require(`../../../utils/git-control-bar-classes.cjs`);let o=require(`react/jsx-runtime`);function s({onSuggestionsClick:s,hasRepository:c,providerTokensReady:l,isConversationReady:u=!0}){let{t:d}=e.useTranslation(`openhands`),{trackPullButtonClick:f}=r.useTracking(),p=l&&c&&u;return(0,o.jsxs)(`button`,{type:`button`,onClick:()=>{f(),s(n.getGitPullPrompt())},disabled:!p,className:n.cn(a.gitControlBarActionButtonClassName(p),`px-0.5 py-1 w-[76px] min-w-[76px]`),children:[(0,o.jsx)(`div`,{className:`w-3 h-3 flex items-center justify-center`,children:(0,o.jsx)(i.default,{width:12,height:12,color:a.gitControlBarActionIconColor(p)})}),(0,o.jsx)(`div`,{className:n.cn(a.gitControlBarActionLabelClassName,`max-w-[76px]`),title:d(t.I18nKey.COMMON$PULL),children:d(t.I18nKey.COMMON$PULL)})]})}exports.GitControlBarPullButton=s;
2
2
  //# sourceMappingURL=git-control-bar-pull-button.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"git-control-bar-pull-button.cjs","names":[],"sources":["../../../../src/components/features/chat/git-control-bar-pull-button.tsx"],"sourcesContent":["import { useTranslation } from \"react-i18next\";\nimport ArrowDownIcon from \"#/icons/u-arrow-down.svg?react\";\nimport { cn, getGitPullPrompt } from \"#/utils/utils\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { useTracking } from \"#/hooks/use-tracking\";\n\ninterface GitControlBarPullButtonProps {\n onSuggestionsClick: (value: string) => void;\n hasRepository: boolean;\n providerTokensReady: boolean;\n isConversationReady?: boolean;\n}\n\nexport function GitControlBarPullButton({\n onSuggestionsClick,\n hasRepository,\n providerTokensReady,\n isConversationReady = true,\n}: GitControlBarPullButtonProps) {\n const { t } = useTranslation(\"openhands\");\n const { trackPullButtonClick } = useTracking();\n\n const isButtonEnabled =\n providerTokensReady && hasRepository && isConversationReady;\n\n const handlePullClick = () => {\n trackPullButtonClick();\n onSuggestionsClick(getGitPullPrompt());\n };\n\n return (\n <button\n type=\"button\"\n onClick={handlePullClick}\n disabled={!isButtonEnabled}\n className={cn(\n \"flex flex-row gap-1 items-center justify-center px-0.5 py-1 rounded-[100px] w-[76px] min-w-[76px]\",\n isButtonEnabled\n ? \"bg-[var(--oh-surface)] hover:bg-tertiary cursor-pointer\"\n : \"bg-[rgba(71,74,84,0.50)] cursor-not-allowed\",\n )}\n >\n <div className=\"w-3 h-3 flex items-center justify-center\">\n <ArrowDownIcon width={12} height={12} color=\"white\" />\n </div>\n <div\n className=\"font-normal text-white text-sm leading-5 max-w-[76px] truncate\"\n title={t(I18nKey.COMMON$PULL)}\n >\n {t(I18nKey.COMMON$PULL)}\n </div>\n </button>\n );\n}\n"],"mappings":"mVAaA,SAAgB,EAAwB,CACtC,qBACA,gBACA,sBACA,sBAAsB,IACS,CAC/B,GAAM,CAAE,KAAM,EAAA,eAAe,YAAY,CACnC,CAAE,wBAAyB,EAAA,aAAa,CAExC,EACJ,GAAuB,GAAiB,EAO1C,OACE,EAAA,EAAA,MAAC,SAAD,CACE,KAAK,SACL,YAR0B,CAC5B,GAAsB,CACtB,EAAmB,EAAA,kBAAkB,CAAC,EAOpC,SAAU,CAAC,EACX,UAAW,EAAA,GACT,oGACA,EACI,0DACA,8CACL,UATH,EAWE,EAAA,EAAA,KAAC,MAAD,CAAK,UAAU,qDACb,EAAA,EAAA,KAAC,EAAA,QAAD,CAAe,MAAO,GAAI,OAAQ,GAAI,MAAM,QAAU,CAAA,CAClD,CAAA,EACN,EAAA,EAAA,KAAC,MAAD,CACE,UAAU,iEACV,MAAO,EAAE,EAAA,QAAQ,YAAY,UAE5B,EAAE,EAAA,QAAQ,YAAY,CACnB,CAAA,CACC"}
1
+ {"version":3,"file":"git-control-bar-pull-button.cjs","names":[],"sources":["../../../../src/components/features/chat/git-control-bar-pull-button.tsx"],"sourcesContent":["import { useTranslation } from \"react-i18next\";\nimport ArrowDownIcon from \"#/icons/u-arrow-down.svg?react\";\nimport { cn, getGitPullPrompt } from \"#/utils/utils\";\nimport {\n gitControlBarActionButtonClassName,\n gitControlBarActionIconColor,\n gitControlBarActionLabelClassName,\n} from \"#/utils/git-control-bar-classes\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { useTracking } from \"#/hooks/use-tracking\";\n\ninterface GitControlBarPullButtonProps {\n onSuggestionsClick: (value: string) => void;\n hasRepository: boolean;\n providerTokensReady: boolean;\n isConversationReady?: boolean;\n}\n\nexport function GitControlBarPullButton({\n onSuggestionsClick,\n hasRepository,\n providerTokensReady,\n isConversationReady = true,\n}: GitControlBarPullButtonProps) {\n const { t } = useTranslation(\"openhands\");\n const { trackPullButtonClick } = useTracking();\n\n const isButtonEnabled =\n providerTokensReady && hasRepository && isConversationReady;\n\n const handlePullClick = () => {\n trackPullButtonClick();\n onSuggestionsClick(getGitPullPrompt());\n };\n\n return (\n <button\n type=\"button\"\n onClick={handlePullClick}\n disabled={!isButtonEnabled}\n className={cn(\n gitControlBarActionButtonClassName(isButtonEnabled),\n \"px-0.5 py-1 w-[76px] min-w-[76px]\",\n )}\n >\n <div className=\"w-3 h-3 flex items-center justify-center\">\n <ArrowDownIcon\n width={12}\n height={12}\n color={gitControlBarActionIconColor(isButtonEnabled)}\n />\n </div>\n <div\n className={cn(gitControlBarActionLabelClassName, \"max-w-[76px]\")}\n title={t(I18nKey.COMMON$PULL)}\n >\n {t(I18nKey.COMMON$PULL)}\n </div>\n </button>\n );\n}\n"],"mappings":"2YAkBA,SAAgB,EAAwB,CACtC,qBACA,gBACA,sBACA,sBAAsB,IACS,CAC/B,GAAM,CAAE,KAAM,EAAA,eAAe,YAAY,CACnC,CAAE,wBAAyB,EAAA,aAAa,CAExC,EACJ,GAAuB,GAAiB,EAO1C,OACE,EAAA,EAAA,MAAC,SAAD,CACE,KAAK,SACL,YAR0B,CAC5B,GAAsB,CACtB,EAAmB,EAAA,kBAAkB,CAAC,EAOpC,SAAU,CAAC,EACX,UAAW,EAAA,GACT,EAAA,mCAAmC,EAAgB,CACnD,oCACD,UAPH,EASE,EAAA,EAAA,KAAC,MAAD,CAAK,UAAU,qDACb,EAAA,EAAA,KAAC,EAAA,QAAD,CACE,MAAO,GACP,OAAQ,GACR,MAAO,EAAA,6BAA6B,EAAgB,CACpD,CAAA,CACE,CAAA,EACN,EAAA,EAAA,KAAC,MAAD,CACE,UAAW,EAAA,GAAG,EAAA,kCAAmC,eAAe,CAChE,MAAO,EAAE,EAAA,QAAQ,YAAY,UAE5B,EAAE,EAAA,QAAQ,YAAY,CACnB,CAAA,CACC"}