@openhands/agent-canvas 1.0.0-beta.5 → 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 (879) 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-BQChv2rc.js → recommended-automations-launcher-uTyODuzB.js} +3 -3
  100. package/build/assets/{root-BgEbw3S0.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-CZSK-lT2.js +1 -0
  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 +150 -119
  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/@openhands/extensions/integrations/catalog/airtable.cjs +1 -1
  604. package/dist/node_modules/@openhands/extensions/integrations/catalog/airtable.cjs.map +1 -1
  605. package/dist/node_modules/@openhands/extensions/integrations/catalog/airtable.js +3 -1
  606. package/dist/node_modules/@openhands/extensions/integrations/catalog/airtable.js.map +1 -1
  607. package/dist/node_modules/@openhands/extensions/integrations/catalog/apify.cjs +1 -1
  608. package/dist/node_modules/@openhands/extensions/integrations/catalog/apify.cjs.map +1 -1
  609. package/dist/node_modules/@openhands/extensions/integrations/catalog/apify.js +3 -1
  610. package/dist/node_modules/@openhands/extensions/integrations/catalog/apify.js.map +1 -1
  611. package/dist/node_modules/@openhands/extensions/integrations/catalog/brave-search.cjs +1 -1
  612. package/dist/node_modules/@openhands/extensions/integrations/catalog/brave-search.cjs.map +1 -1
  613. package/dist/node_modules/@openhands/extensions/integrations/catalog/brave-search.js +3 -1
  614. package/dist/node_modules/@openhands/extensions/integrations/catalog/brave-search.js.map +1 -1
  615. package/dist/node_modules/@openhands/extensions/integrations/catalog/clickhouse.cjs +1 -1
  616. package/dist/node_modules/@openhands/extensions/integrations/catalog/clickhouse.cjs.map +1 -1
  617. package/dist/node_modules/@openhands/extensions/integrations/catalog/clickhouse.js +3 -1
  618. package/dist/node_modules/@openhands/extensions/integrations/catalog/clickhouse.js.map +1 -1
  619. package/dist/node_modules/@openhands/extensions/integrations/catalog/elevenlabs.cjs +1 -1
  620. package/dist/node_modules/@openhands/extensions/integrations/catalog/elevenlabs.cjs.map +1 -1
  621. package/dist/node_modules/@openhands/extensions/integrations/catalog/elevenlabs.js +3 -1
  622. package/dist/node_modules/@openhands/extensions/integrations/catalog/elevenlabs.js.map +1 -1
  623. package/dist/node_modules/@openhands/extensions/integrations/catalog/exa.cjs +1 -1
  624. package/dist/node_modules/@openhands/extensions/integrations/catalog/exa.cjs.map +1 -1
  625. package/dist/node_modules/@openhands/extensions/integrations/catalog/exa.js +3 -1
  626. package/dist/node_modules/@openhands/extensions/integrations/catalog/exa.js.map +1 -1
  627. package/dist/node_modules/@openhands/extensions/integrations/catalog/figma.cjs +1 -1
  628. package/dist/node_modules/@openhands/extensions/integrations/catalog/figma.cjs.map +1 -1
  629. package/dist/node_modules/@openhands/extensions/integrations/catalog/figma.js +3 -1
  630. package/dist/node_modules/@openhands/extensions/integrations/catalog/figma.js.map +1 -1
  631. package/dist/node_modules/@openhands/extensions/integrations/catalog/firecrawl.cjs +1 -1
  632. package/dist/node_modules/@openhands/extensions/integrations/catalog/firecrawl.cjs.map +1 -1
  633. package/dist/node_modules/@openhands/extensions/integrations/catalog/firecrawl.js +3 -1
  634. package/dist/node_modules/@openhands/extensions/integrations/catalog/firecrawl.js.map +1 -1
  635. package/dist/node_modules/@openhands/extensions/integrations/catalog/github.cjs +1 -1
  636. package/dist/node_modules/@openhands/extensions/integrations/catalog/github.cjs.map +1 -1
  637. package/dist/node_modules/@openhands/extensions/integrations/catalog/github.js +3 -1
  638. package/dist/node_modules/@openhands/extensions/integrations/catalog/github.js.map +1 -1
  639. package/dist/node_modules/@openhands/extensions/integrations/catalog/kagi.cjs +1 -1
  640. package/dist/node_modules/@openhands/extensions/integrations/catalog/kagi.cjs.map +1 -1
  641. package/dist/node_modules/@openhands/extensions/integrations/catalog/kagi.js +3 -1
  642. package/dist/node_modules/@openhands/extensions/integrations/catalog/kagi.js.map +1 -1
  643. package/dist/node_modules/@openhands/extensions/integrations/catalog/mongodb.cjs +1 -1
  644. package/dist/node_modules/@openhands/extensions/integrations/catalog/mongodb.cjs.map +1 -1
  645. package/dist/node_modules/@openhands/extensions/integrations/catalog/mongodb.js +3 -1
  646. package/dist/node_modules/@openhands/extensions/integrations/catalog/mongodb.js.map +1 -1
  647. package/dist/node_modules/@openhands/extensions/integrations/catalog/neon.cjs +1 -1
  648. package/dist/node_modules/@openhands/extensions/integrations/catalog/neon.cjs.map +1 -1
  649. package/dist/node_modules/@openhands/extensions/integrations/catalog/neon.js +3 -1
  650. package/dist/node_modules/@openhands/extensions/integrations/catalog/neon.js.map +1 -1
  651. package/dist/node_modules/@openhands/extensions/integrations/catalog/notion.cjs +1 -1
  652. package/dist/node_modules/@openhands/extensions/integrations/catalog/notion.cjs.map +1 -1
  653. package/dist/node_modules/@openhands/extensions/integrations/catalog/notion.js +3 -1
  654. package/dist/node_modules/@openhands/extensions/integrations/catalog/notion.js.map +1 -1
  655. package/dist/node_modules/@openhands/extensions/integrations/catalog/obsidian.cjs +1 -1
  656. package/dist/node_modules/@openhands/extensions/integrations/catalog/obsidian.cjs.map +1 -1
  657. package/dist/node_modules/@openhands/extensions/integrations/catalog/obsidian.js +2 -1
  658. package/dist/node_modules/@openhands/extensions/integrations/catalog/obsidian.js.map +1 -1
  659. package/dist/node_modules/@openhands/extensions/integrations/catalog/redis.cjs +1 -1
  660. package/dist/node_modules/@openhands/extensions/integrations/catalog/redis.cjs.map +1 -1
  661. package/dist/node_modules/@openhands/extensions/integrations/catalog/redis.js +2 -1
  662. package/dist/node_modules/@openhands/extensions/integrations/catalog/redis.js.map +1 -1
  663. package/dist/node_modules/@openhands/extensions/integrations/catalog/resend.cjs +1 -1
  664. package/dist/node_modules/@openhands/extensions/integrations/catalog/resend.cjs.map +1 -1
  665. package/dist/node_modules/@openhands/extensions/integrations/catalog/resend.js +3 -1
  666. package/dist/node_modules/@openhands/extensions/integrations/catalog/resend.js.map +1 -1
  667. package/dist/node_modules/@openhands/extensions/integrations/catalog/slack.cjs +1 -1
  668. package/dist/node_modules/@openhands/extensions/integrations/catalog/slack.cjs.map +1 -1
  669. package/dist/node_modules/@openhands/extensions/integrations/catalog/slack.js +8 -7
  670. package/dist/node_modules/@openhands/extensions/integrations/catalog/slack.js.map +1 -1
  671. package/dist/node_modules/@openhands/extensions/integrations/catalog/supabase.cjs +1 -1
  672. package/dist/node_modules/@openhands/extensions/integrations/catalog/supabase.cjs.map +1 -1
  673. package/dist/node_modules/@openhands/extensions/integrations/catalog/supabase.js +2 -1
  674. package/dist/node_modules/@openhands/extensions/integrations/catalog/supabase.js.map +1 -1
  675. package/dist/node_modules/@openhands/extensions/integrations/catalog/tavily.cjs +1 -1
  676. package/dist/node_modules/@openhands/extensions/integrations/catalog/tavily.cjs.map +1 -1
  677. package/dist/node_modules/@openhands/extensions/integrations/catalog/tavily.js +4 -2
  678. package/dist/node_modules/@openhands/extensions/integrations/catalog/tavily.js.map +1 -1
  679. package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.cjs +2 -0
  680. package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.cjs.map +1 -0
  681. package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.js +15 -0
  682. package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.js.map +1 -0
  683. package/dist/package.cjs +1 -1
  684. package/dist/package.cjs.map +1 -1
  685. package/dist/package.js +2 -2
  686. package/dist/package.js.map +1 -1
  687. package/dist/routes/conversation.cjs +1 -1
  688. package/dist/routes/conversation.cjs.map +1 -1
  689. package/dist/routes/conversation.js +1 -1
  690. package/dist/routes/conversation.js.map +1 -1
  691. package/dist/routes/llm-settings.cjs +1 -1
  692. package/dist/routes/llm-settings.cjs.map +1 -1
  693. package/dist/routes/llm-settings.js +55 -54
  694. package/dist/routes/llm-settings.js.map +1 -1
  695. package/dist/routes/secrets-settings.cjs +1 -1
  696. package/dist/routes/secrets-settings.cjs.map +1 -1
  697. package/dist/routes/secrets-settings.js +19 -27
  698. package/dist/routes/secrets-settings.js.map +1 -1
  699. package/dist/stores/conversation-store.cjs +1 -1
  700. package/dist/stores/conversation-store.cjs.map +1 -1
  701. package/dist/stores/conversation-store.d.ts +4 -0
  702. package/dist/stores/conversation-store.js +6 -0
  703. package/dist/stores/conversation-store.js.map +1 -1
  704. package/dist/types/agent-server/core/events/acp-tool-call-event.d.ts +6 -4
  705. package/dist/types/agent-server/core/events/system-event.d.ts +5 -0
  706. package/dist/types/automation.d.ts +15 -0
  707. package/dist/types/settings.d.ts +3 -1
  708. package/dist/ui/combobox-caret.cjs +1 -1
  709. package/dist/ui/combobox-caret.cjs.map +1 -1
  710. package/dist/ui/combobox-caret.d.ts +1 -1
  711. package/dist/ui/combobox-caret.js +9 -8
  712. package/dist/ui/combobox-caret.js.map +1 -1
  713. package/dist/ui/context-menu.cjs +1 -1
  714. package/dist/ui/context-menu.cjs.map +1 -1
  715. package/dist/ui/context-menu.js +9 -8
  716. package/dist/ui/context-menu.js.map +1 -1
  717. package/dist/ui/dropdown/dropdown-menu.cjs +1 -1
  718. package/dist/ui/dropdown/dropdown-menu.cjs.map +1 -1
  719. package/dist/ui/dropdown/dropdown-menu.js +21 -17
  720. package/dist/ui/dropdown/dropdown-menu.js.map +1 -1
  721. package/dist/ui/dropdown/dropdown.cjs +1 -1
  722. package/dist/ui/dropdown/dropdown.cjs.map +1 -1
  723. package/dist/ui/dropdown/dropdown.js +2 -2
  724. package/dist/ui/dropdown/dropdown.js.map +1 -1
  725. package/dist/utils/automation-schedule.d.ts +1 -0
  726. package/dist/utils/dropdown-classes.cjs +2 -0
  727. package/dist/utils/dropdown-classes.cjs.map +1 -0
  728. package/dist/utils/dropdown-classes.d.ts +32 -0
  729. package/dist/utils/dropdown-classes.js +8 -0
  730. package/dist/utils/dropdown-classes.js.map +1 -0
  731. package/dist/utils/form-control-classes.cjs +1 -1
  732. package/dist/utils/form-control-classes.cjs.map +1 -1
  733. package/dist/utils/form-control-classes.d.ts +18 -2
  734. package/dist/utils/form-control-classes.js +4 -3
  735. package/dist/utils/form-control-classes.js.map +1 -1
  736. package/dist/utils/git-control-bar-classes.cjs +2 -0
  737. package/dist/utils/git-control-bar-classes.cjs.map +1 -0
  738. package/dist/utils/git-control-bar-classes.d.ts +4 -0
  739. package/dist/utils/git-control-bar-classes.js +14 -0
  740. package/dist/utils/git-control-bar-classes.js.map +1 -0
  741. package/dist/utils/handle-event-for-ui.cjs.map +1 -1
  742. package/dist/utils/handle-event-for-ui.d.ts +6 -3
  743. package/dist/utils/handle-event-for-ui.js.map +1 -1
  744. package/dist/utils/mobile-top-bar-icon-button-classes.cjs +1 -1
  745. package/dist/utils/mobile-top-bar-icon-button-classes.cjs.map +1 -1
  746. package/dist/utils/mobile-top-bar-icon-button-classes.js +3 -3
  747. package/dist/utils/mobile-top-bar-icon-button-classes.js.map +1 -1
  748. package/dist/utils/modal-classes.cjs +2 -0
  749. package/dist/utils/modal-classes.cjs.map +1 -0
  750. package/dist/utils/modal-classes.d.ts +8 -0
  751. package/dist/utils/modal-classes.js +7 -0
  752. package/dist/utils/modal-classes.js.map +1 -0
  753. package/dist/utils/openhands-llm.cjs +2 -0
  754. package/dist/utils/openhands-llm.cjs.map +1 -0
  755. package/dist/utils/openhands-llm.d.ts +2 -0
  756. package/dist/utils/openhands-llm.js +9 -0
  757. package/dist/utils/openhands-llm.js.map +1 -0
  758. package/dist/utils/redact-custom-secrets.cjs +2 -0
  759. package/dist/utils/redact-custom-secrets.cjs.map +1 -0
  760. package/dist/utils/redact-custom-secrets.d.ts +6 -0
  761. package/dist/utils/redact-custom-secrets.js +10 -0
  762. package/dist/utils/redact-custom-secrets.js.map +1 -0
  763. package/dist/utils/status.cjs +1 -1
  764. package/dist/utils/status.cjs.map +1 -1
  765. package/dist/utils/status.d.ts +2 -1
  766. package/dist/utils/status.js +9 -8
  767. package/dist/utils/status.js.map +1 -1
  768. package/dist/utils/system-message-adapter.cjs +1 -1
  769. package/dist/utils/system-message-adapter.cjs.map +1 -1
  770. package/dist/utils/system-message-adapter.js +10 -7
  771. package/dist/utils/system-message-adapter.js.map +1 -1
  772. package/dist/utils/utils.cjs +1 -1
  773. package/dist/utils/utils.cjs.map +1 -1
  774. package/dist/utils/utils.d.ts +2 -1
  775. package/dist/utils/utils.js +21 -20
  776. package/dist/utils/utils.js.map +1 -1
  777. package/package.json +2 -2
  778. package/scripts/dev-safe.mjs +3 -1
  779. package/scripts/dev-static.mjs +2 -2
  780. package/scripts/dev-with-automation.mjs +283 -108
  781. package/scripts/static-build.mjs +20 -19
  782. package/scripts/static-server.mjs +50 -3
  783. package/build/assets/acp-providers-CbiRekh9.js +0 -1
  784. package/build/assets/active-backend-context-cCM1vYYZ.js +0 -1
  785. package/build/assets/add-backend-modal-DIUQzMPa.js +0 -1
  786. package/build/assets/agent-server-client-options-Bc5ZorQZ.js +0 -1
  787. package/build/assets/agent-server-compatibility-BlkUsrX2.js +0 -1
  788. package/build/assets/agent-server-conversation-service.api-C2V5SlHu.js +0 -5
  789. package/build/assets/api-key-entry-screen-B2gynaCp.js +0 -1
  790. package/build/assets/automation-detail-DJvbVSYK.js +0 -1
  791. package/build/assets/automations-list-rMki-8au.js +0 -1
  792. package/build/assets/backend-form-modal-Dnk33xA_.js +0 -1
  793. package/build/assets/base-modal-_dYTw1ri.js +0 -1
  794. package/build/assets/brand-button-Br7f0kZJ.js +0 -1
  795. package/build/assets/browser-store-Couc4S5D.js +0 -1
  796. package/build/assets/clock-BRjCgHTc.js +0 -1
  797. package/build/assets/combobox-caret-to1O8irE.js +0 -1
  798. package/build/assets/context-menu-list-item-CWNFpuiC.js +0 -1
  799. package/build/assets/conversation-DVrKU0oz.js +0 -19
  800. package/build/assets/conversation-Dlys-D5A.js +0 -1
  801. package/build/assets/conversation-panel-iF09WjZ4.js +0 -1
  802. package/build/assets/conversation-service.api-CCfztilW.js +0 -1
  803. package/build/assets/conversation-state-store-u5jepov0.js +0 -1
  804. package/build/assets/conversation-store-Z5iMCRpc.js +0 -1
  805. package/build/assets/conversation-websocket-context-DhJhqUna.js +0 -3
  806. package/build/assets/declaration-BNMqORFE.js +0 -1
  807. package/build/assets/dist-BxBP7tFD.js +0 -1
  808. package/build/assets/edit-automation-modal-BGzR3nfZ.js +0 -1
  809. package/build/assets/ellipsis-button-ZyLMPURn.js +0 -1
  810. package/build/assets/entry.client-1VMHpktY.js +0 -2
  811. package/build/assets/enum-filter-dropdown-CEgCdu4A.js +0 -1
  812. package/build/assets/extensions-hub-C651jsVh.js +0 -1
  813. package/build/assets/files-tab-R5z0lLdY.js +0 -1
  814. package/build/assets/files-tab-store-CDyVTXNT.js +0 -1
  815. package/build/assets/git-control-bar-branch-button-COdRAYHb.js +0 -27
  816. package/build/assets/git-provider-icon-BzLbc0yC.js +0 -1
  817. package/build/assets/home-XxBpNOVq.js +0 -1
  818. package/build/assets/install-server-modal-f31_CLrW.js +0 -1
  819. package/build/assets/launch-CshDse3e.js +0 -1
  820. package/build/assets/link-external-D2POYx4c.js +0 -1
  821. package/build/assets/llm-settings-Bql-vydt.js +0 -1
  822. package/build/assets/llm-settings-C_tal6Ds.js +0 -1
  823. package/build/assets/manage-backends-modal-l7RkKfwX.js +0 -1
  824. package/build/assets/manage-workspaces-modal-DhKF_8z3.js +0 -1
  825. package/build/assets/manifest-d9077852.js +0 -1
  826. package/build/assets/mcp-D2onbwVk.js +0 -9
  827. package/build/assets/messages-D0rWot7s.js +0 -36
  828. package/build/assets/proxy-CxydCnis.js +0 -1
  829. package/build/assets/root-DHeCXo9N.css +0 -1
  830. package/build/assets/root-layout-Czo9Ma6Q.js +0 -2
  831. package/build/assets/secrets-service-BsnKFc2x.js +0 -1
  832. package/build/assets/secrets-settings-Bz_UohPJ.js +0 -1
  833. package/build/assets/settings-client-C73C7IgV.js +0 -1
  834. package/build/assets/settings-index-Dz0BmdJD.js +0 -1
  835. package/build/assets/settings-list-classes-Bf80tWtc.js +0 -1
  836. package/build/assets/settings-modal-Brzgh5Yw.js +0 -1
  837. package/build/assets/settings-service.api-CZ3uWx4v.js +0 -1
  838. package/build/assets/sidebar-mobile-menu-toggle-Do_aA9Zm.js +0 -1
  839. package/build/assets/skills-settings-DlA5hlXw.js +0 -2
  840. package/build/assets/status-hp6M6E7E.js +0 -1
  841. package/build/assets/use-agent-settings-schema-33Un7UF2.js +0 -1
  842. package/build/assets/use-is-authed-BggE5wPj.js +0 -1
  843. package/build/assets/use-llm-profiles-DDOol3gK.js +0 -1
  844. package/build/assets/use-runtime-is-ready-B7EF4BKU.js +0 -1
  845. package/build/assets/use-settings-DQIZmIov.js +0 -1
  846. package/build/assets/use-user-conversation-C6hrMMtn.js +0 -1
  847. package/build/assets/utils-i18rdUj2.js +0 -1
  848. package/build/assets/vendor~conversation-panel~conversation-a9SyrrhV.js +0 -1
  849. package/build/assets/vendor~conversation-panel~conversation~index-C23ZXO4R.js +0 -1
  850. package/build/assets/vendor~home~mcp~automations-list-Ccy2I0KU.js +0 -1
  851. package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~i4kjfqhl-BebWhFNT.js +0 -1
  852. package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-DzIXV3Ui.js +0 -9
  853. /package/build/assets/{automation-IdgZq6ZK.js → automation-XDPAjiZi.js} +0 -0
  854. /package/build/assets/{color-themes-DSaoIL6A.js → color-themes-B9pm9c-R.js} +0 -0
  855. /package/build/assets/{common-DR1t-EeP.js → common-DqjLSBOt.js} +0 -0
  856. /package/build/assets/{conversation-local-storage-UYl-SX-r.js → conversation-local-storage-YmOVXxxW.js} +0 -0
  857. /package/build/assets/{dist-C6t0EXL7.js → dist-C3NfioQC.js} +0 -0
  858. /package/build/assets/{environment-switch-store-C4ulFJKp.js → environment-switch-store-CiurvTtK.js} +0 -0
  859. /package/build/assets/{health-store-BDC2rM-X.js → health-store-B5f0S2FY.js} +0 -0
  860. /package/build/assets/{map-provider-COBVzZYo.js → map-provider-BJ_8KZKU.js} +0 -0
  861. /package/build/assets/{middleware-BC9EwbB9.js → middleware-CfatjPYZ.js} +0 -0
  862. /package/build/assets/{objectWithoutPropertiesLoose-Du6eBn-V.js → objectWithoutPropertiesLoose-DSQKyRhw.js} +0 -0
  863. /package/build/assets/{react-Do0CT17Y.js → react-Dy05vyj5.js} +0 -0
  864. /package/build/assets/{sdk-settings-field-metadata-CBPmeqYa.js → sdk-settings-field-metadata-DQiaIBie.js} +0 -0
  865. /package/build/assets/{settings-D_H-qsRm.js → settings-DGY6n4J2.js} +0 -0
  866. /package/build/assets/{settings-like-page-layout-classes-I0BDBEoq.js → settings-like-page-layout-classes-D7YjdTd0.js} +0 -0
  867. /package/build/assets/{use-breakpoint-DbJ6FkQ-.js → use-breakpoint-DF_RiQ6s.js} +0 -0
  868. /package/build/assets/{use-click-outside-element-DffgWWoZ.js → use-click-outside-element-DhxCUyWl.js} +0 -0
  869. /package/build/assets/{v4-CNn21NXa.js → v4-khGvL7i2.js} +0 -0
  870. /package/build/assets/{vendor~browser-DDiZgqD3.js → vendor~browser-DisFGEp9.js} +0 -0
  871. /package/build/assets/{vendor~browser-tab-BgwV1mxF.js → vendor~browser-tab-BxhTtM9_.js} +0 -0
  872. /package/build/assets/{vendor~conversation-panel~conversation~alert-banner-DbvX3OcM.js → vendor~conversation-panel~conversation~alert-banner-w-I2sY6c.js} +0 -0
  873. /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
  874. /package/build/assets/{vendor~files-tab-BGKayPiK.js → vendor~files-tab-BtkpAiMX.js} +0 -0
  875. /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
  876. /package/build/assets/{vendor~home~mcp~automations-list-DoPfwaXj.js → vendor~home~mcp~automations-list-BgV86Sti.js} +0 -0
  877. /package/build/assets/{vendor~launch-vdeRTWFu.js → vendor~launch-BXgl67Re.js} +0 -0
  878. /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
  879. /package/build/assets/{vendor~terminal-DUrOWGFE.js → vendor~terminal-DZaJIY8A.js} +0 -0
@@ -7,6 +7,7 @@ interface ContextMenuIconTextWithDescriptionProps {
7
7
  description: string;
8
8
  className?: string;
9
9
  iconClassName?: string;
10
+ isActive?: boolean;
10
11
  }
11
- export declare function ContextMenuIconTextWithDescription({ icon, title, description, className, iconClassName, }: ContextMenuIconTextWithDescriptionProps): import("react/jsx-runtime").JSX.Element;
12
+ export declare function ContextMenuIconTextWithDescription({ icon, title, description, className, iconClassName, isActive, }: ContextMenuIconTextWithDescriptionProps): import("react/jsx-runtime").JSX.Element;
12
13
  export {};
@@ -4,14 +4,15 @@ import { ContextMenuIconText as n } from "./context-menu-icon-text.js";
4
4
  import "react";
5
5
  import { jsx as r, jsxs as i } from "react/jsx-runtime";
6
6
  //#region src/components/features/context-menu/context-menu-icon-text-with-description.tsx
7
- function a({ icon: a, title: o, description: s, className: c, iconClassName: l }) {
7
+ function a({ icon: a, title: o, description: s, className: c, iconClassName: l, isActive: u = !1 }) {
8
8
  return /* @__PURE__ */ i("div", {
9
9
  className: e("flex min-w-0 w-full flex-col justify-center gap-1", c),
10
10
  children: [/* @__PURE__ */ r(n, {
11
11
  icon: a,
12
12
  text: o,
13
13
  className: "px-0",
14
- iconClassName: l
14
+ iconClassName: l,
15
+ isActive: u
15
16
  }), /* @__PURE__ */ r(t.Text, {
16
17
  className: "text-[var(--oh-muted)] text-[10px] font-normal whitespace-pre-wrap break-words",
17
18
  children: s
@@ -1 +1 @@
1
- {"version":3,"file":"context-menu-icon-text-with-description.js","names":[],"sources":["../../../../src/components/features/context-menu/context-menu-icon-text-with-description.tsx"],"sourcesContent":["import React from \"react\";\nimport { ContextMenuIconText } from \"./context-menu-icon-text\";\nimport { Typography } from \"#/ui/typography\";\nimport { cn } from \"#/utils/utils\";\n\ninterface ContextMenuIconTextWithDescriptionProps {\n icon: React.ComponentType<{ className?: string }>;\n title: string;\n description: string;\n className?: string;\n iconClassName?: string;\n}\n\nexport function ContextMenuIconTextWithDescription({\n icon,\n title,\n description,\n className,\n iconClassName,\n}: ContextMenuIconTextWithDescriptionProps) {\n return (\n <div\n className={cn(\n \"flex min-w-0 w-full flex-col justify-center gap-1\",\n className,\n )}\n >\n <ContextMenuIconText\n icon={icon}\n text={title}\n className=\"px-0\"\n iconClassName={iconClassName}\n />\n <Typography.Text className=\"text-[var(--oh-muted)] text-[10px] font-normal whitespace-pre-wrap break-words\">\n {description}\n </Typography.Text>\n </div>\n );\n}\n"],"mappings":";;;;;;AAaA,SAAgB,EAAmC,EACjD,SACA,UACA,gBACA,cACA,oBAC0C;AAC1C,QACE,kBAAC,OAAD;EACE,WAAW,EACT,qDACA,EACD;YAJH,CAME,kBAAC,GAAD;GACQ;GACN,MAAM;GACN,WAAU;GACK;GACf,CAAA,EACF,kBAAC,EAAW,MAAZ;GAAiB,WAAU;aACxB;GACe,CAAA,CACd"}
1
+ {"version":3,"file":"context-menu-icon-text-with-description.js","names":[],"sources":["../../../../src/components/features/context-menu/context-menu-icon-text-with-description.tsx"],"sourcesContent":["import React from \"react\";\nimport { ContextMenuIconText } from \"./context-menu-icon-text\";\nimport { Typography } from \"#/ui/typography\";\nimport { cn } from \"#/utils/utils\";\n\ninterface ContextMenuIconTextWithDescriptionProps {\n icon: React.ComponentType<{ className?: string }>;\n title: string;\n description: string;\n className?: string;\n iconClassName?: string;\n isActive?: boolean;\n}\n\nexport function ContextMenuIconTextWithDescription({\n icon,\n title,\n description,\n className,\n iconClassName,\n isActive = false,\n}: ContextMenuIconTextWithDescriptionProps) {\n return (\n <div\n className={cn(\n \"flex min-w-0 w-full flex-col justify-center gap-1\",\n className,\n )}\n >\n <ContextMenuIconText\n icon={icon}\n text={title}\n className=\"px-0\"\n iconClassName={iconClassName}\n isActive={isActive}\n />\n <Typography.Text className=\"text-[var(--oh-muted)] text-[10px] font-normal whitespace-pre-wrap break-words\">\n {description}\n </Typography.Text>\n </div>\n );\n}\n"],"mappings":";;;;;;AAcA,SAAgB,EAAmC,EACjD,SACA,UACA,gBACA,cACA,kBACA,cAAW,MAC+B;AAC1C,QACE,kBAAC,OAAD;EACE,WAAW,EACT,qDACA,EACD;YAJH,CAME,kBAAC,GAAD;GACQ;GACN,MAAM;GACN,WAAU;GACK;GACL;GACV,CAAA,EACF,kBAAC,EAAW,MAAZ;GAAiB,WAAU;aACxB;GACe,CAAA,CACd"}
@@ -1,2 +1,2 @@
1
- require(`../../../_virtual/_rolldown/runtime.cjs`);const e=require(`../../../utils/utils.cjs`),t=require(`../../../utils/form-control-classes.cjs`);let n=require(`react/jsx-runtime`);function r({icon:r,text:i,className:a,iconClassName:o}){return(0,n.jsxs)(`div`,{className:e.cn(`flex min-w-0 items-center gap-2`,a),children:[(0,n.jsx)(r,{className:e.cn(`h-4 w-4 shrink-0 text-[var(--oh-muted)] group-hover:text-[var(--oh-foreground)] group-focus-visible:text-[var(--oh-foreground)]`,t.formControlTransitionClassName,o)}),(0,n.jsx)(`span`,{className:`min-w-0 flex-1 leading-5`,children:i})]})}exports.ContextMenuIconText=r;
1
+ require(`../../../_virtual/_rolldown/runtime.cjs`);const e=require(`../../../utils/utils.cjs`),t=require(`../../../icons/checkmark.cjs`),n=require(`../../../utils/dropdown-classes.cjs`);let r=require(`react/jsx-runtime`);function i({icon:i,text:a,className:o,iconClassName:s,isActive:c=!1}){return(0,r.jsxs)(`div`,{className:e.cn(`flex min-w-0 items-center`,n.dropdownMenuRowGapClassName,o),children:[(0,r.jsx)(i,{className:e.cn(`h-4 w-4`,n.dropdownMenuRowIconWrapperClassName,s)}),(0,r.jsx)(`span`,{className:`min-w-0 flex-1 leading-5`,children:a}),c&&(0,r.jsx)(t.default,{width:14,height:14,className:`shrink-0`,"aria-hidden":!0})]})}exports.ContextMenuIconText=i;
2
2
  //# sourceMappingURL=context-menu-icon-text.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"context-menu-icon-text.cjs","names":[],"sources":["../../../../src/components/features/context-menu/context-menu-icon-text.tsx"],"sourcesContent":["import { cn } from \"#/utils/utils\";\nimport { formControlTransitionClassName } from \"#/utils/form-control-classes\";\n\ninterface ContextMenuIconTextProps {\n icon: React.ComponentType<{ className?: string }>;\n text: string;\n className?: string;\n iconClassName?: string;\n}\n\nexport function ContextMenuIconText({\n icon: Icon,\n text,\n className,\n iconClassName,\n}: ContextMenuIconTextProps) {\n return (\n <div className={cn(\"flex min-w-0 items-center gap-2\", className)}>\n <Icon\n className={cn(\n \"h-4 w-4 shrink-0 text-[var(--oh-muted)] group-hover:text-[var(--oh-foreground)] group-focus-visible:text-[var(--oh-foreground)]\",\n formControlTransitionClassName,\n iconClassName,\n )}\n />\n <span className=\"min-w-0 flex-1 leading-5\">{text}</span>\n </div>\n );\n}\n"],"mappings":"uLAUA,SAAgB,EAAoB,CAClC,KAAM,EACN,OACA,YACA,iBAC2B,CAC3B,OACE,EAAA,EAAA,MAAC,MAAD,CAAK,UAAW,EAAA,GAAG,kCAAmC,EAAU,UAAhE,EACE,EAAA,EAAA,KAAC,EAAD,CACE,UAAW,EAAA,GACT,kIACA,EAAA,+BACA,EACD,CACD,CAAA,EACF,EAAA,EAAA,KAAC,OAAD,CAAM,UAAU,oCAA4B,EAAY,CAAA,CACpD"}
1
+ {"version":3,"file":"context-menu-icon-text.cjs","names":[],"sources":["../../../../src/components/features/context-menu/context-menu-icon-text.tsx"],"sourcesContent":["import { cn } from \"#/utils/utils\";\nimport {\n dropdownMenuRowGapClassName,\n dropdownMenuRowIconWrapperClassName,\n} from \"#/utils/dropdown-classes\";\nimport CheckIcon from \"#/icons/checkmark.svg?react\";\n\ninterface ContextMenuIconTextProps {\n icon: React.ComponentType<{ className?: string }>;\n text: string;\n className?: string;\n iconClassName?: string;\n isActive?: boolean;\n}\n\nexport function ContextMenuIconText({\n icon: Icon,\n text,\n className,\n iconClassName,\n isActive = false,\n}: ContextMenuIconTextProps) {\n return (\n <div\n className={cn(\n \"flex min-w-0 items-center\",\n dropdownMenuRowGapClassName,\n className,\n )}\n >\n <Icon\n className={cn(\n \"h-4 w-4\",\n dropdownMenuRowIconWrapperClassName,\n iconClassName,\n )}\n />\n <span className=\"min-w-0 flex-1 leading-5\">{text}</span>\n {isActive && (\n <CheckIcon width={14} height={14} className=\"shrink-0\" aria-hidden />\n )}\n </div>\n );\n}\n"],"mappings":"6NAeA,SAAgB,EAAoB,CAClC,KAAM,EACN,OACA,YACA,gBACA,WAAW,IACgB,CAC3B,OACE,EAAA,EAAA,MAAC,MAAD,CACE,UAAW,EAAA,GACT,4BACA,EAAA,4BACA,EACD,UALH,EAOE,EAAA,EAAA,KAAC,EAAD,CACE,UAAW,EAAA,GACT,UACA,EAAA,oCACA,EACD,CACD,CAAA,EACF,EAAA,EAAA,KAAC,OAAD,CAAM,UAAU,oCAA4B,EAAY,CAAA,CACvD,IACC,EAAA,EAAA,KAAC,EAAA,QAAD,CAAW,MAAO,GAAI,OAAQ,GAAI,UAAU,WAAW,cAAA,GAAc,CAAA,CAEnE"}
@@ -5,6 +5,7 @@ interface ContextMenuIconTextProps {
5
5
  text: string;
6
6
  className?: string;
7
7
  iconClassName?: string;
8
+ isActive?: boolean;
8
9
  }
9
- export declare function ContextMenuIconText({ icon: Icon, text, className, iconClassName, }: ContextMenuIconTextProps): import("react/jsx-runtime").JSX.Element;
10
+ export declare function ContextMenuIconText({ icon: Icon, text, className, iconClassName, isActive, }: ContextMenuIconTextProps): import("react/jsx-runtime").JSX.Element;
10
11
  export {};
@@ -1,17 +1,27 @@
1
1
  import { cn as e } from "../../../utils/utils.js";
2
- import { formControlTransitionClassName as t } from "../../../utils/form-control-classes.js";
3
- import { jsx as n, jsxs as r } from "react/jsx-runtime";
2
+ import t from "../../../icons/checkmark.js";
3
+ import { dropdownMenuRowGapClassName as n, dropdownMenuRowIconWrapperClassName as r } from "../../../utils/dropdown-classes.js";
4
+ import { jsx as i, jsxs as a } from "react/jsx-runtime";
4
5
  //#region src/components/features/context-menu/context-menu-icon-text.tsx
5
- function i({ icon: i, text: a, className: o, iconClassName: s }) {
6
- return /* @__PURE__ */ r("div", {
7
- className: e("flex min-w-0 items-center gap-2", o),
8
- children: [/* @__PURE__ */ n(i, { className: e("h-4 w-4 shrink-0 text-[var(--oh-muted)] group-hover:text-[var(--oh-foreground)] group-focus-visible:text-[var(--oh-foreground)]", t, s) }), /* @__PURE__ */ n("span", {
9
- className: "min-w-0 flex-1 leading-5",
10
- children: a
11
- })]
6
+ function o({ icon: o, text: s, className: c, iconClassName: l, isActive: u = !1 }) {
7
+ return /* @__PURE__ */ a("div", {
8
+ className: e("flex min-w-0 items-center", n, c),
9
+ children: [
10
+ /* @__PURE__ */ i(o, { className: e("h-4 w-4", r, l) }),
11
+ /* @__PURE__ */ i("span", {
12
+ className: "min-w-0 flex-1 leading-5",
13
+ children: s
14
+ }),
15
+ u && /* @__PURE__ */ i(t, {
16
+ width: 14,
17
+ height: 14,
18
+ className: "shrink-0",
19
+ "aria-hidden": !0
20
+ })
21
+ ]
12
22
  });
13
23
  }
14
24
  //#endregion
15
- export { i as ContextMenuIconText };
25
+ export { o as ContextMenuIconText };
16
26
 
17
27
  //# sourceMappingURL=context-menu-icon-text.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"context-menu-icon-text.js","names":[],"sources":["../../../../src/components/features/context-menu/context-menu-icon-text.tsx"],"sourcesContent":["import { cn } from \"#/utils/utils\";\nimport { formControlTransitionClassName } from \"#/utils/form-control-classes\";\n\ninterface ContextMenuIconTextProps {\n icon: React.ComponentType<{ className?: string }>;\n text: string;\n className?: string;\n iconClassName?: string;\n}\n\nexport function ContextMenuIconText({\n icon: Icon,\n text,\n className,\n iconClassName,\n}: ContextMenuIconTextProps) {\n return (\n <div className={cn(\"flex min-w-0 items-center gap-2\", className)}>\n <Icon\n className={cn(\n \"h-4 w-4 shrink-0 text-[var(--oh-muted)] group-hover:text-[var(--oh-foreground)] group-focus-visible:text-[var(--oh-foreground)]\",\n formControlTransitionClassName,\n iconClassName,\n )}\n />\n <span className=\"min-w-0 flex-1 leading-5\">{text}</span>\n </div>\n );\n}\n"],"mappings":";;;;AAUA,SAAgB,EAAoB,EAClC,MAAM,GACN,SACA,cACA,oBAC2B;AAC3B,QACE,kBAAC,OAAD;EAAK,WAAW,EAAG,mCAAmC,EAAU;YAAhE,CACE,kBAAC,GAAD,EACE,WAAW,EACT,mIACA,GACA,EACD,EACD,CAAA,EACF,kBAAC,QAAD;GAAM,WAAU;aAA4B;GAAY,CAAA,CACpD"}
1
+ {"version":3,"file":"context-menu-icon-text.js","names":[],"sources":["../../../../src/components/features/context-menu/context-menu-icon-text.tsx"],"sourcesContent":["import { cn } from \"#/utils/utils\";\nimport {\n dropdownMenuRowGapClassName,\n dropdownMenuRowIconWrapperClassName,\n} from \"#/utils/dropdown-classes\";\nimport CheckIcon from \"#/icons/checkmark.svg?react\";\n\ninterface ContextMenuIconTextProps {\n icon: React.ComponentType<{ className?: string }>;\n text: string;\n className?: string;\n iconClassName?: string;\n isActive?: boolean;\n}\n\nexport function ContextMenuIconText({\n icon: Icon,\n text,\n className,\n iconClassName,\n isActive = false,\n}: ContextMenuIconTextProps) {\n return (\n <div\n className={cn(\n \"flex min-w-0 items-center\",\n dropdownMenuRowGapClassName,\n className,\n )}\n >\n <Icon\n className={cn(\n \"h-4 w-4\",\n dropdownMenuRowIconWrapperClassName,\n iconClassName,\n )}\n />\n <span className=\"min-w-0 flex-1 leading-5\">{text}</span>\n {isActive && (\n <CheckIcon width={14} height={14} className=\"shrink-0\" aria-hidden />\n )}\n </div>\n );\n}\n"],"mappings":";;;;;AAeA,SAAgB,EAAoB,EAClC,MAAM,GACN,SACA,cACA,kBACA,cAAW,MACgB;AAC3B,QACE,kBAAC,OAAD;EACE,WAAW,EACT,6BACA,GACA,EACD;YALH;GAOE,kBAAC,GAAD,EACE,WAAW,EACT,WACA,GACA,EACD,EACD,CAAA;GACF,kBAAC,QAAD;IAAM,WAAU;cAA4B;IAAY,CAAA;GACvD,KACC,kBAAC,GAAD;IAAW,OAAO;IAAI,QAAQ;IAAI,WAAU;IAAW,eAAA;IAAc,CAAA;GAEnE"}
@@ -1,2 +1,2 @@
1
- require(`../../../_virtual/_rolldown/runtime.cjs`);const e=require(`../../../utils/utils.cjs`);let t=require(`react/jsx-runtime`);function n({children:n,testId:r,onClick:i,isDisabled:a,className:o}){return(0,t.jsx)(`button`,{"data-testid":r||`context-menu-list-item`,type:`button`,onClick:i,disabled:a,className:e.cn(`group w-full cursor-pointer rounded px-2 py-2 text-start text-nowrap text-sm font-normal`,`text-[var(--oh-foreground)] hover:bg-[var(--oh-interactive-hover)]`,`disabled:cursor-not-allowed disabled:opacity-50 disabled:hover:bg-transparent`,o),children:n})}exports.ContextMenuListItem=n;
1
+ require(`../../../_virtual/_rolldown/runtime.cjs`);const e=require(`../../../utils/utils.cjs`),t=require(`../../../utils/dropdown-classes.cjs`);let n=require(`react/jsx-runtime`);function r({children:r,testId:i,onClick:a,isDisabled:o,className:s}){return(0,n.jsx)(`button`,{"data-testid":i||`context-menu-list-item`,type:`button`,onClick:a,disabled:o,className:e.cn(t.dropdownMenuRowForegroundClassName,`text-nowrap`,s),children:r})}exports.ContextMenuListItem=r;
2
2
  //# sourceMappingURL=context-menu-list-item.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"context-menu-list-item.cjs","names":[],"sources":["../../../../src/components/features/context-menu/context-menu-list-item.tsx"],"sourcesContent":["import { cn } from \"#/utils/utils\";\n\ninterface ContextMenuListItemProps {\n testId?: string;\n onClick: (event: React.MouseEvent<HTMLButtonElement>) => void;\n isDisabled?: boolean;\n className?: string;\n}\n\nexport function ContextMenuListItem({\n children,\n testId,\n onClick,\n isDisabled,\n className,\n}: React.PropsWithChildren<ContextMenuListItemProps>) {\n return (\n <button\n data-testid={testId || \"context-menu-list-item\"}\n type=\"button\"\n onClick={onClick}\n disabled={isDisabled}\n className={cn(\n \"group w-full cursor-pointer rounded px-2 py-2 text-start text-nowrap text-sm font-normal\",\n \"text-[var(--oh-foreground)] hover:bg-[var(--oh-interactive-hover)]\",\n \"disabled:cursor-not-allowed disabled:opacity-50 disabled:hover:bg-transparent\",\n className,\n )}\n >\n {children}\n </button>\n );\n}\n"],"mappings":"kIASA,SAAgB,EAAoB,CAClC,WACA,SACA,UACA,aACA,aACoD,CACpD,OACE,EAAA,EAAA,KAAC,SAAD,CACE,cAAa,GAAU,yBACvB,KAAK,SACI,UACT,SAAU,EACV,UAAW,EAAA,GACT,2FACA,qEACA,gFACA,EACD,CAEA,WACM,CAAA"}
1
+ {"version":3,"file":"context-menu-list-item.cjs","names":[],"sources":["../../../../src/components/features/context-menu/context-menu-list-item.tsx"],"sourcesContent":["import { cn } from \"#/utils/utils\";\nimport { dropdownMenuRowForegroundClassName } from \"#/utils/dropdown-classes\";\n\ninterface ContextMenuListItemProps {\n testId?: string;\n onClick: (event: React.MouseEvent<HTMLButtonElement>) => void;\n isDisabled?: boolean;\n className?: string;\n}\n\nexport function ContextMenuListItem({\n children,\n testId,\n onClick,\n isDisabled,\n className,\n}: React.PropsWithChildren<ContextMenuListItemProps>) {\n return (\n <button\n data-testid={testId || \"context-menu-list-item\"}\n type=\"button\"\n onClick={onClick}\n disabled={isDisabled}\n className={cn(\n dropdownMenuRowForegroundClassName,\n \"text-nowrap\",\n className,\n )}\n >\n {children}\n </button>\n );\n}\n"],"mappings":"mLAUA,SAAgB,EAAoB,CAClC,WACA,SACA,UACA,aACA,aACoD,CACpD,OACE,EAAA,EAAA,KAAC,SAAD,CACE,cAAa,GAAU,yBACvB,KAAK,SACI,UACT,SAAU,EACV,UAAW,EAAA,GACT,EAAA,mCACA,cACA,EACD,CAEA,WACM,CAAA"}
@@ -1,17 +1,18 @@
1
1
  import { cn as e } from "../../../utils/utils.js";
2
- import { jsx as t } from "react/jsx-runtime";
2
+ import { dropdownMenuRowForegroundClassName as t } from "../../../utils/dropdown-classes.js";
3
+ import { jsx as n } from "react/jsx-runtime";
3
4
  //#region src/components/features/context-menu/context-menu-list-item.tsx
4
- function n({ children: n, testId: r, onClick: i, isDisabled: a, className: o }) {
5
- return /* @__PURE__ */ t("button", {
6
- "data-testid": r || "context-menu-list-item",
5
+ function r({ children: r, testId: i, onClick: a, isDisabled: o, className: s }) {
6
+ return /* @__PURE__ */ n("button", {
7
+ "data-testid": i || "context-menu-list-item",
7
8
  type: "button",
8
- onClick: i,
9
- disabled: a,
10
- className: e("group w-full cursor-pointer rounded px-2 py-2 text-start text-nowrap text-sm font-normal", "text-[var(--oh-foreground)] hover:bg-[var(--oh-interactive-hover)]", "disabled:cursor-not-allowed disabled:opacity-50 disabled:hover:bg-transparent", o),
11
- children: n
9
+ onClick: a,
10
+ disabled: o,
11
+ className: e(t, "text-nowrap", s),
12
+ children: r
12
13
  });
13
14
  }
14
15
  //#endregion
15
- export { n as ContextMenuListItem };
16
+ export { r as ContextMenuListItem };
16
17
 
17
18
  //# sourceMappingURL=context-menu-list-item.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"context-menu-list-item.js","names":[],"sources":["../../../../src/components/features/context-menu/context-menu-list-item.tsx"],"sourcesContent":["import { cn } from \"#/utils/utils\";\n\ninterface ContextMenuListItemProps {\n testId?: string;\n onClick: (event: React.MouseEvent<HTMLButtonElement>) => void;\n isDisabled?: boolean;\n className?: string;\n}\n\nexport function ContextMenuListItem({\n children,\n testId,\n onClick,\n isDisabled,\n className,\n}: React.PropsWithChildren<ContextMenuListItemProps>) {\n return (\n <button\n data-testid={testId || \"context-menu-list-item\"}\n type=\"button\"\n onClick={onClick}\n disabled={isDisabled}\n className={cn(\n \"group w-full cursor-pointer rounded px-2 py-2 text-start text-nowrap text-sm font-normal\",\n \"text-[var(--oh-foreground)] hover:bg-[var(--oh-interactive-hover)]\",\n \"disabled:cursor-not-allowed disabled:opacity-50 disabled:hover:bg-transparent\",\n className,\n )}\n >\n {children}\n </button>\n );\n}\n"],"mappings":";;;AASA,SAAgB,EAAoB,EAClC,aACA,WACA,YACA,eACA,gBACoD;AACpD,QACE,kBAAC,UAAD;EACE,eAAa,KAAU;EACvB,MAAK;EACI;EACT,UAAU;EACV,WAAW,EACT,4FACA,sEACA,iFACA,EACD;EAEA;EACM,CAAA"}
1
+ {"version":3,"file":"context-menu-list-item.js","names":[],"sources":["../../../../src/components/features/context-menu/context-menu-list-item.tsx"],"sourcesContent":["import { cn } from \"#/utils/utils\";\nimport { dropdownMenuRowForegroundClassName } from \"#/utils/dropdown-classes\";\n\ninterface ContextMenuListItemProps {\n testId?: string;\n onClick: (event: React.MouseEvent<HTMLButtonElement>) => void;\n isDisabled?: boolean;\n className?: string;\n}\n\nexport function ContextMenuListItem({\n children,\n testId,\n onClick,\n isDisabled,\n className,\n}: React.PropsWithChildren<ContextMenuListItemProps>) {\n return (\n <button\n data-testid={testId || \"context-menu-list-item\"}\n type=\"button\"\n onClick={onClick}\n disabled={isDisabled}\n className={cn(\n dropdownMenuRowForegroundClassName,\n \"text-nowrap\",\n className,\n )}\n >\n {children}\n </button>\n );\n}\n"],"mappings":";;;;AAUA,SAAgB,EAAoB,EAClC,aACA,WACA,YACA,eACA,gBACoD;AACpD,QACE,kBAAC,UAAD;EACE,eAAa,KAAU;EACvB,MAAK;EACI;EACT,UAAU;EACV,WAAW,EACT,GACA,eACA,EACD;EAEA;EACM,CAAA"}
@@ -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(`../../../types/agent-state.cjs`),r=require(`../../../utils/utils.cjs`),i=require(`../../../stores/conversation-store.cjs`),a=require(`../../../node_modules/lucide-react/dist/esm/icons/circle-check.cjs`),o=require(`../../../hooks/query/use-active-conversation.cjs`),s=require(`../../../hooks/use-agent-state.cjs`),c=require(`../../../hooks/query/use-task-polling.cjs`),l=require(`../../../utils/status.cjs`),u=require(`../chat/chat-stop-button.cjs`),d=require(`../../../icons/u-clock-three.cjs`),f=require(`../chat/chat-play-button.cjs`),p=require(`./agent-loading.cjs`),m=require(`../../../icons/circle-error.cjs`),h=require(`../../../hooks/use-unified-websocket-status.cjs`),g=require(`../../../hooks/query/use-sub-conversation-task-polling.cjs`),_=require(`../../../hooks/use-agent-notification.cjs`);let v=require(`react`),y=require(`react/jsx-runtime`);function b({className:b=``,handleStop:x,handleResumeAgent:S,disabled:C=!1,isPausing:w=!1}){let{t:T}=e.useTranslation(`openhands`),{setShouldShownAgentLoading:E}=i.useConversationStore(),{curAgentState:D,executionStatus:O}=s.useAgentState();_.useAgentNotification(D);let k=h.useUnifiedWebSocketStatus(),{data:A}=o.useActiveConversation(),{taskStatus:j}=c.useTaskPolling(),{subConversationTaskId:M}=i.useConversationStore(),{taskStatus:N}=g.useSubConversationTaskPolling(M,A?.id||null),P=l.getStatusCode(k,O??null,j,N),F=D===n.AgentState.INIT||D===n.AgentState.LOADING||k===`CONNECTING`&&j!==`ERROR`||r.isTaskPolling(j)||r.isTaskPolling(N),I=F||w,L=D===n.AgentState.ERROR||D===n.AgentState.RATE_LIMITED||k===`CLOSED`||j===`ERROR`,R=!L&&D===n.AgentState.RUNNING,z=!L&&(D===n.AgentState.STOPPED||D===n.AgentState.PAUSED),B=!I&&(R||z),V=P===t.I18nKey.CHAT_INTERFACE$AGENT_FINISHED_MESSAGE,H=P===t.I18nKey.AGENT_STATUS$WAITING_FOR_TASK,U=V||H,[W,G]=(0,v.useState)(!0),[K,q]=(0,v.useState)(!1);return(0,v.useEffect)(()=>{E(!!F)},[F,E]),(0,v.useEffect)(()=>{if(!U){G(!0),q(!1);return}G(!0),q(!1);let e=window.setTimeout(()=>{q(!0)},1e3),t=window.setTimeout(()=>{G(!1)},1500);return()=>{window.clearTimeout(e),window.clearTimeout(t)}},[U]),U&&!W?null:(0,y.jsxs)(`div`,{className:r.cn(`flex items-center gap-1 min-w-0`,U&&`transition-opacity duration-500`,K&&`opacity-0`,b),children:[(0,y.jsx)(`span`,{className:`text-[11px] text-[var(--oh-muted)] font-normal leading-5 min-w-0 max-w-full truncate`,title:T(P),children:T(P)}),(0,y.jsxs)(`div`,{className:r.cn(`box-border content-stretch flex flex-row gap-[3px] items-center justify-center overflow-clip px-0.5 py-1 relative rounded-[100px] shrink-0 size-6 transition-all duration-200 active:scale-95 bg-transparent text-[var(--oh-muted)] hover:bg-white/10 hover:text-white`,B?`cursor-pointer`:`cursor-default`),children:[I&&(0,y.jsx)(p.AgentLoading,{}),!I&&R&&(0,y.jsx)(u.ChatStopButton,{handleStop:x}),!I&&z&&(0,y.jsx)(f.ChatResumeAgentButton,{onAgentResumed:S,disabled:C}),!I&&L&&(0,y.jsx)(m.default,{className:`w-4 h-4 text-current`,"data-testid":`circle-error-icon`}),!I&&!R&&!z&&!L&&(U?(0,y.jsx)(a.CircleCheck,{className:`w-4 h-4 text-current`}):(0,y.jsx)(d.default,{className:`w-4 h-4 text-current`}))]})]})}exports.default=b;
1
+ require(`../../../_virtual/_rolldown/runtime.cjs`);const e=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),t=require(`../../../i18n/declaration.cjs`),n=require(`../../../types/agent-state.cjs`),r=require(`../../../utils/status.cjs`),i=require(`../../../utils/utils.cjs`),a=require(`../../../stores/conversation-store.cjs`),o=require(`../../../node_modules/lucide-react/dist/esm/icons/circle-check.cjs`),s=require(`../../../hooks/query/use-active-conversation.cjs`),c=require(`../../../hooks/use-agent-state.cjs`),l=require(`../../../hooks/query/use-task-polling.cjs`),u=require(`../chat/chat-stop-button.cjs`),d=require(`../../../icons/u-clock-three.cjs`),f=require(`../chat/chat-play-button.cjs`),p=require(`./agent-loading.cjs`),m=require(`../../../icons/circle-error.cjs`),h=require(`../../../hooks/use-unified-websocket-status.cjs`),g=require(`../../../hooks/query/use-sub-conversation-task-polling.cjs`),_=require(`../../../hooks/use-agent-notification.cjs`);let v=require(`react`),y=require(`react/jsx-runtime`);function b({className:b=``,handleStop:x,handleResumeAgent:S,disabled:C=!1,isPausing:w=!1}){let{t:T}=e.useTranslation(`openhands`),{setShouldShownAgentLoading:E}=a.useConversationStore(),{curAgentState:D,executionStatus:O}=c.useAgentState();_.useAgentNotification(D);let k=h.useUnifiedWebSocketStatus(),{data:A}=s.useActiveConversation(),{taskStatus:j}=l.useTaskPolling(),{subConversationTaskId:M}=a.useConversationStore(),{taskStatus:N}=g.useSubConversationTaskPolling(M,A?.id||null),P=r.getStatusCode(k,O??null,j,N),F=D===n.AgentState.INIT||D===n.AgentState.LOADING||k===`CONNECTING`&&j!==`ERROR`||i.isTaskPolling(j)||i.isTaskPolling(N),I=F||w,L=D===n.AgentState.ERROR||D===n.AgentState.RATE_LIMITED||k===`CLOSED`||j===`ERROR`,R=!L&&D===n.AgentState.RUNNING,z=!L&&(D===n.AgentState.STOPPED||D===n.AgentState.PAUSED),B=!I&&(R||z),V=P===t.I18nKey.CHAT_INTERFACE$AGENT_FINISHED_MESSAGE,H=P===t.I18nKey.AGENT_STATUS$WAITING_FOR_TASK,U=V||H,[W,G]=(0,v.useState)(!0),[K,q]=(0,v.useState)(!1);return(0,v.useEffect)(()=>{E(!!F)},[F,E]),(0,v.useEffect)(()=>{if(!U){G(!0),q(!1);return}G(!0),q(!1);let e=window.setTimeout(()=>{q(!0)},1e3),t=window.setTimeout(()=>{G(!1)},1500);return()=>{window.clearTimeout(e),window.clearTimeout(t)}},[U]),U&&!W?null:(0,y.jsxs)(`div`,{className:i.cn(`flex items-center gap-1 min-w-0`,U&&`transition-opacity duration-500`,K&&`opacity-0`,b),children:[(0,y.jsx)(`span`,{className:`text-[11px] text-[var(--oh-muted)] font-normal leading-5 min-w-0 max-w-full truncate`,title:T(P),children:T(P)}),(0,y.jsxs)(`div`,{className:i.cn(`box-border content-stretch flex flex-row gap-[3px] items-center justify-center overflow-clip px-0.5 py-1 relative rounded-[100px] shrink-0 size-6 transition-all duration-200 active:scale-95 bg-transparent text-[var(--oh-muted)] hover:bg-white/10 hover:text-white`,B?`cursor-pointer`:`cursor-default`),children:[I&&(0,y.jsx)(p.AgentLoading,{}),!I&&R&&(0,y.jsx)(u.ChatStopButton,{handleStop:x}),!I&&z&&(0,y.jsx)(f.ChatResumeAgentButton,{onAgentResumed:S,disabled:C}),!I&&L&&(0,y.jsx)(m.default,{className:`w-4 h-4 text-current`,"data-testid":`circle-error-icon`}),!I&&!R&&!z&&!L&&(U?(0,y.jsx)(o.CircleCheck,{className:`w-4 h-4 text-current`}):(0,y.jsx)(d.default,{className:`w-4 h-4 text-current`}))]})]})}exports.default=b;
2
2
  //# sourceMappingURL=agent-status.cjs.map
@@ -1,13 +1,13 @@
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 { AgentState as n } from "../../../types/agent-state.js";
4
- import { cn as r, isTaskPolling as i } from "../../../utils/utils.js";
5
- import { useConversationStore as a } from "../../../stores/conversation-store.js";
6
- import { CircleCheck as o } from "../../../node_modules/lucide-react/dist/esm/icons/circle-check.js";
7
- import { useActiveConversation as s } from "../../../hooks/query/use-active-conversation.js";
8
- import { useAgentState as c } from "../../../hooks/use-agent-state.js";
9
- import { useTaskPolling as l } from "../../../hooks/query/use-task-polling.js";
10
- import { getStatusCode as u } from "../../../utils/status.js";
4
+ import { getStatusCode as r } from "../../../utils/status.js";
5
+ import { cn as i, isTaskPolling as a } from "../../../utils/utils.js";
6
+ import { useConversationStore as o } from "../../../stores/conversation-store.js";
7
+ import { CircleCheck as s } from "../../../node_modules/lucide-react/dist/esm/icons/circle-check.js";
8
+ import { useActiveConversation as c } from "../../../hooks/query/use-active-conversation.js";
9
+ import { useAgentState as l } from "../../../hooks/use-agent-state.js";
10
+ import { useTaskPolling as u } from "../../../hooks/query/use-task-polling.js";
11
11
  import { ChatStopButton as d } from "../chat/chat-stop-button.js";
12
12
  import f from "../../../icons/u-clock-three.js";
13
13
  import { ChatResumeAgentButton as p } from "../chat/chat-play-button.js";
@@ -20,9 +20,9 @@ import { useEffect as y, useState as b } from "react";
20
20
  import { jsx as x, jsxs as S } from "react/jsx-runtime";
21
21
  //#region src/components/features/controls/agent-status.tsx
22
22
  function C({ className: C = "", handleStop: w, handleResumeAgent: T, disabled: E = !1, isPausing: D = !1 }) {
23
- let { t: O } = e("openhands"), { setShouldShownAgentLoading: k } = a(), { curAgentState: A, executionStatus: j } = c();
23
+ let { t: O } = e("openhands"), { setShouldShownAgentLoading: k } = o(), { curAgentState: A, executionStatus: j } = l();
24
24
  v(A);
25
- let M = g(), { data: N } = s(), { taskStatus: P } = l(), { subConversationTaskId: F } = a(), { taskStatus: I } = _(F, N?.id || null), L = u(M, j ?? null, P, I), R = A === n.INIT || A === n.LOADING || M === "CONNECTING" && P !== "ERROR" || i(P) || i(I), z = R || D, B = A === n.ERROR || A === n.RATE_LIMITED || M === "CLOSED" || P === "ERROR", V = !B && A === n.RUNNING, H = !B && (A === n.STOPPED || A === n.PAUSED), U = !z && (V || H), W = L === t.CHAT_INTERFACE$AGENT_FINISHED_MESSAGE, G = L === t.AGENT_STATUS$WAITING_FOR_TASK, K = W || G, [q, J] = b(!0), [Y, X] = b(!1);
25
+ let M = g(), { data: N } = c(), { taskStatus: P } = u(), { subConversationTaskId: F } = o(), { taskStatus: I } = _(F, N?.id || null), L = r(M, j ?? null, P, I), R = A === n.INIT || A === n.LOADING || M === "CONNECTING" && P !== "ERROR" || a(P) || a(I), z = R || D, B = A === n.ERROR || A === n.RATE_LIMITED || M === "CLOSED" || P === "ERROR", V = !B && A === n.RUNNING, H = !B && (A === n.STOPPED || A === n.PAUSED), U = !z && (V || H), W = L === t.CHAT_INTERFACE$AGENT_FINISHED_MESSAGE, G = L === t.AGENT_STATUS$WAITING_FOR_TASK, K = W || G, [q, J] = b(!0), [Y, X] = b(!1);
26
26
  return y(() => {
27
27
  k(!!R);
28
28
  }, [R, k]), y(() => {
@@ -40,13 +40,13 @@ function C({ className: C = "", handleStop: w, handleResumeAgent: T, disabled: E
40
40
  window.clearTimeout(e), window.clearTimeout(t);
41
41
  };
42
42
  }, [K]), K && !q ? null : /* @__PURE__ */ S("div", {
43
- className: r("flex items-center gap-1 min-w-0", K && "transition-opacity duration-500", Y && "opacity-0", C),
43
+ className: i("flex items-center gap-1 min-w-0", K && "transition-opacity duration-500", Y && "opacity-0", C),
44
44
  children: [/* @__PURE__ */ x("span", {
45
45
  className: "text-[11px] text-[var(--oh-muted)] font-normal leading-5 min-w-0 max-w-full truncate",
46
46
  title: O(L),
47
47
  children: O(L)
48
48
  }), /* @__PURE__ */ S("div", {
49
- className: r("box-border content-stretch flex flex-row gap-[3px] items-center justify-center overflow-clip px-0.5 py-1 relative rounded-[100px] shrink-0 size-6 transition-all duration-200 active:scale-95 bg-transparent text-[var(--oh-muted)] hover:bg-white/10 hover:text-white", U ? "cursor-pointer" : "cursor-default"),
49
+ className: i("box-border content-stretch flex flex-row gap-[3px] items-center justify-center overflow-clip px-0.5 py-1 relative rounded-[100px] shrink-0 size-6 transition-all duration-200 active:scale-95 bg-transparent text-[var(--oh-muted)] hover:bg-white/10 hover:text-white", U ? "cursor-pointer" : "cursor-default"),
50
50
  children: [
51
51
  z && /* @__PURE__ */ x(m, {}),
52
52
  !z && V && /* @__PURE__ */ x(d, { handleStop: w }),
@@ -58,7 +58,7 @@ function C({ className: C = "", handleStop: w, handleResumeAgent: T, disabled: E
58
58
  className: "w-4 h-4 text-current",
59
59
  "data-testid": "circle-error-icon"
60
60
  }),
61
- !z && !V && !H && !B && x(K ? o : f, { className: "w-4 h-4 text-current" })
61
+ !z && !V && !H && !B && x(K ? s : f, { className: "w-4 h-4 text-current" })
62
62
  ]
63
63
  })]
64
64
  });
@@ -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(`../../../stores/conversation-store.cjs`),i=require(`../../../hooks/query/use-active-conversation.cjs`),a=require(`../../../ui/context-menu.cjs`),o=require(`../context-menu/context-menu-list-item.cjs`),s=require(`../../../icons/u-code-branch.cjs`),c=require(`./tools-context-menu-icon-text.cjs`),l=require(`../../../icons/u-arrow-up.cjs`),u=require(`../../../icons/u-arrow-down.cjs`),d=require(`../../../icons/u-pr.cjs`);let f=require(`react/jsx-runtime`);var p=`!w-auto whitespace-nowrap`;function m({onClose:m}){let{t:h}=e.useTranslation(`openhands`),{setMessageToSend:g}=r.useConversationStore(),{data:_}=i.useActiveConversation(),v=_?.git_provider;return(0,f.jsxs)(a.ContextMenu,{testId:`git-tools-submenu`,className:`w-max gap-0`,children:[(0,f.jsx)(o.ContextMenuListItem,{testId:`git-pull-button`,onClick:()=>{g(n.getGitPullPrompt()),m()},className:p,children:(0,f.jsx)(c.ToolsContextMenuIconText,{icon:(0,f.jsx)(u.default,{width:16,height:16}),text:h(t.I18nKey.COMMON$GIT_PULL)})}),(0,f.jsx)(o.ContextMenuListItem,{testId:`git-push-button`,onClick:()=>{g(n.getGitPushPrompt(v)),m()},className:p,children:(0,f.jsx)(c.ToolsContextMenuIconText,{icon:(0,f.jsx)(l.default,{width:16,height:16}),text:h(t.I18nKey.COMMON$GIT_PUSH)})}),(0,f.jsx)(o.ContextMenuListItem,{testId:`create-pr-button`,onClick:()=>{g(n.getCreatePRPrompt(v)),m()},className:p,children:(0,f.jsx)(c.ToolsContextMenuIconText,{icon:(0,f.jsx)(d.default,{width:16,height:16}),text:h(t.I18nKey.COMMON$CREATE_PR)})}),(0,f.jsx)(o.ContextMenuListItem,{testId:`create-new-branch-button`,onClick:()=>{g(n.getCreateNewBranchPrompt()),m()},className:p,children:(0,f.jsx)(c.ToolsContextMenuIconText,{icon:(0,f.jsx)(s.default,{width:16,height:16}),text:h(t.I18nKey.COMMON$CREATE_NEW_BRANCH)})})]})}exports.GitToolsSubmenu=m;
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(`../../../stores/conversation-store.cjs`),i=require(`../../../hooks/query/use-active-conversation.cjs`),a=require(`../../../ui/context-menu.cjs`),o=require(`../context-menu/context-menu-list-item.cjs`),s=require(`../../../icons/u-code-branch.cjs`),c=require(`./tools-context-menu-icon-text.cjs`),l=require(`../../../icons/u-arrow-up.cjs`),u=require(`../../../icons/u-arrow-down.cjs`),d=require(`../../../icons/u-pr.cjs`);let f=require(`react/jsx-runtime`);var p=`!w-auto whitespace-nowrap`;function m({onClose:m}){let{t:h}=e.useTranslation(`openhands`),{setMessageToSend:g}=r.useConversationStore(),{data:_}=i.useActiveConversation(),v=_?.git_provider;return(0,f.jsxs)(a.ContextMenu,{testId:`git-tools-submenu`,className:`w-max`,children:[(0,f.jsx)(o.ContextMenuListItem,{testId:`git-pull-button`,onClick:()=>{g(n.getGitPullPrompt()),m()},className:p,children:(0,f.jsx)(c.ToolsContextMenuIconText,{icon:(0,f.jsx)(u.default,{width:16,height:16}),text:h(t.I18nKey.COMMON$GIT_PULL)})}),(0,f.jsx)(o.ContextMenuListItem,{testId:`git-push-button`,onClick:()=>{g(n.getGitPushPrompt(v)),m()},className:p,children:(0,f.jsx)(c.ToolsContextMenuIconText,{icon:(0,f.jsx)(l.default,{width:16,height:16}),text:h(t.I18nKey.COMMON$GIT_PUSH)})}),(0,f.jsx)(o.ContextMenuListItem,{testId:`create-pr-button`,onClick:()=>{g(n.getCreatePRPrompt(v)),m()},className:p,children:(0,f.jsx)(c.ToolsContextMenuIconText,{icon:(0,f.jsx)(d.default,{width:16,height:16}),text:h(t.I18nKey.COMMON$CREATE_PR)})}),(0,f.jsx)(o.ContextMenuListItem,{testId:`create-new-branch-button`,onClick:()=>{g(n.getCreateNewBranchPrompt()),m()},className:p,children:(0,f.jsx)(c.ToolsContextMenuIconText,{icon:(0,f.jsx)(s.default,{width:16,height:16}),text:h(t.I18nKey.COMMON$CREATE_NEW_BRANCH)})})]})}exports.GitToolsSubmenu=m;
2
2
  //# sourceMappingURL=git-tools-submenu.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"git-tools-submenu.cjs","names":[],"sources":["../../../../src/components/features/controls/git-tools-submenu.tsx"],"sourcesContent":["import { useTranslation } from \"react-i18next\";\nimport { ContextMenu } from \"#/ui/context-menu\";\nimport { ContextMenuListItem } from \"../context-menu/context-menu-list-item\";\nimport { ToolsContextMenuIconText } from \"./tools-context-menu-icon-text\";\nimport { useActiveConversation } from \"#/hooks/query/use-active-conversation\";\nimport { Provider } from \"#/types/settings\";\nimport {\n getGitPullPrompt,\n getGitPushPrompt,\n getCreatePRPrompt,\n getCreateNewBranchPrompt,\n} from \"#/utils/utils\";\nimport { useConversationStore } from \"#/stores/conversation-store\";\n\nimport ArrowUpIcon from \"#/icons/u-arrow-up.svg?react\";\nimport ArrowDownIcon from \"#/icons/u-arrow-down.svg?react\";\nimport PrIcon from \"#/icons/u-pr.svg?react\";\nimport CodeBranchIcon from \"#/icons/u-code-branch.svg?react\";\nimport { I18nKey } from \"#/i18n/declaration\";\n\nconst submenuListItemClassName = \"!w-auto whitespace-nowrap\";\n\ninterface GitToolsSubmenuProps {\n onClose: () => void;\n}\n\nexport function GitToolsSubmenu({ onClose }: GitToolsSubmenuProps) {\n const { t } = useTranslation(\"openhands\");\n const { setMessageToSend } = useConversationStore();\n const { data: conversation } = useActiveConversation();\n\n const currentGitProvider = conversation?.git_provider as Provider;\n\n const onGitPull = () => {\n setMessageToSend(getGitPullPrompt());\n onClose();\n };\n\n const onGitPush = () => {\n setMessageToSend(getGitPushPrompt(currentGitProvider));\n onClose();\n };\n\n const onCreatePR = () => {\n setMessageToSend(getCreatePRPrompt(currentGitProvider));\n onClose();\n };\n\n const onCreateNewBranch = () => {\n setMessageToSend(getCreateNewBranchPrompt());\n onClose();\n };\n\n return (\n <ContextMenu testId=\"git-tools-submenu\" className=\"w-max gap-0\">\n <ContextMenuListItem\n testId=\"git-pull-button\"\n onClick={onGitPull}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<ArrowDownIcon width={16} height={16} />}\n text={t(I18nKey.COMMON$GIT_PULL)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"git-push-button\"\n onClick={onGitPush}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<ArrowUpIcon width={16} height={16} />}\n text={t(I18nKey.COMMON$GIT_PUSH)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"create-pr-button\"\n onClick={onCreatePR}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<PrIcon width={16} height={16} />}\n text={t(I18nKey.COMMON$CREATE_PR)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"create-new-branch-button\"\n onClick={onCreateNewBranch}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<CodeBranchIcon width={16} height={16} />}\n text={t(I18nKey.COMMON$CREATE_NEW_BRANCH)}\n />\n </ContextMenuListItem>\n </ContextMenu>\n );\n}\n"],"mappings":"wqBAoBA,IAAM,EAA2B,4BAMjC,SAAgB,EAAgB,CAAE,WAAiC,CACjE,GAAM,CAAE,KAAM,EAAA,eAAe,YAAY,CACnC,CAAE,oBAAqB,EAAA,sBAAsB,CAC7C,CAAE,KAAM,GAAiB,EAAA,uBAAuB,CAEhD,EAAqB,GAAc,aAsBzC,OACE,EAAA,EAAA,MAAC,EAAA,YAAD,CAAa,OAAO,oBAAoB,UAAU,uBAAlD,EACE,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,kBACP,YAxBkB,CACtB,EAAiB,EAAA,kBAAkB,CAAC,CACpC,GAAS,EAuBL,UAAW,YAEX,EAAA,EAAA,KAAC,EAAA,yBAAD,CACE,MAAM,EAAA,EAAA,KAAC,EAAA,QAAD,CAAe,MAAO,GAAI,OAAQ,GAAM,CAAA,CAC9C,KAAM,EAAE,EAAA,QAAQ,gBAAgB,CAChC,CAAA,CACkB,CAAA,EAEtB,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,kBACP,YA9BkB,CACtB,EAAiB,EAAA,iBAAiB,EAAmB,CAAC,CACtD,GAAS,EA6BL,UAAW,YAEX,EAAA,EAAA,KAAC,EAAA,yBAAD,CACE,MAAM,EAAA,EAAA,KAAC,EAAA,QAAD,CAAa,MAAO,GAAI,OAAQ,GAAM,CAAA,CAC5C,KAAM,EAAE,EAAA,QAAQ,gBAAgB,CAChC,CAAA,CACkB,CAAA,EAEtB,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,mBACP,YApCmB,CACvB,EAAiB,EAAA,kBAAkB,EAAmB,CAAC,CACvD,GAAS,EAmCL,UAAW,YAEX,EAAA,EAAA,KAAC,EAAA,yBAAD,CACE,MAAM,EAAA,EAAA,KAAC,EAAA,QAAD,CAAQ,MAAO,GAAI,OAAQ,GAAM,CAAA,CACvC,KAAM,EAAE,EAAA,QAAQ,iBAAiB,CACjC,CAAA,CACkB,CAAA,EAEtB,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,2BACP,YA1C0B,CAC9B,EAAiB,EAAA,0BAA0B,CAAC,CAC5C,GAAS,EAyCL,UAAW,YAEX,EAAA,EAAA,KAAC,EAAA,yBAAD,CACE,MAAM,EAAA,EAAA,KAAC,EAAA,QAAD,CAAgB,MAAO,GAAI,OAAQ,GAAM,CAAA,CAC/C,KAAM,EAAE,EAAA,QAAQ,yBAAyB,CACzC,CAAA,CACkB,CAAA,CACV"}
1
+ {"version":3,"file":"git-tools-submenu.cjs","names":[],"sources":["../../../../src/components/features/controls/git-tools-submenu.tsx"],"sourcesContent":["import { useTranslation } from \"react-i18next\";\nimport { ContextMenu } from \"#/ui/context-menu\";\nimport { ContextMenuListItem } from \"../context-menu/context-menu-list-item\";\nimport { ToolsContextMenuIconText } from \"./tools-context-menu-icon-text\";\nimport { useActiveConversation } from \"#/hooks/query/use-active-conversation\";\nimport { Provider } from \"#/types/settings\";\nimport {\n getGitPullPrompt,\n getGitPushPrompt,\n getCreatePRPrompt,\n getCreateNewBranchPrompt,\n} from \"#/utils/utils\";\nimport { useConversationStore } from \"#/stores/conversation-store\";\n\nimport ArrowUpIcon from \"#/icons/u-arrow-up.svg?react\";\nimport ArrowDownIcon from \"#/icons/u-arrow-down.svg?react\";\nimport PrIcon from \"#/icons/u-pr.svg?react\";\nimport CodeBranchIcon from \"#/icons/u-code-branch.svg?react\";\nimport { I18nKey } from \"#/i18n/declaration\";\n\nconst submenuListItemClassName = \"!w-auto whitespace-nowrap\";\n\ninterface GitToolsSubmenuProps {\n onClose: () => void;\n}\n\nexport function GitToolsSubmenu({ onClose }: GitToolsSubmenuProps) {\n const { t } = useTranslation(\"openhands\");\n const { setMessageToSend } = useConversationStore();\n const { data: conversation } = useActiveConversation();\n\n const currentGitProvider = conversation?.git_provider as Provider;\n\n const onGitPull = () => {\n setMessageToSend(getGitPullPrompt());\n onClose();\n };\n\n const onGitPush = () => {\n setMessageToSend(getGitPushPrompt(currentGitProvider));\n onClose();\n };\n\n const onCreatePR = () => {\n setMessageToSend(getCreatePRPrompt(currentGitProvider));\n onClose();\n };\n\n const onCreateNewBranch = () => {\n setMessageToSend(getCreateNewBranchPrompt());\n onClose();\n };\n\n return (\n <ContextMenu testId=\"git-tools-submenu\" className=\"w-max\">\n <ContextMenuListItem\n testId=\"git-pull-button\"\n onClick={onGitPull}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<ArrowDownIcon width={16} height={16} />}\n text={t(I18nKey.COMMON$GIT_PULL)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"git-push-button\"\n onClick={onGitPush}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<ArrowUpIcon width={16} height={16} />}\n text={t(I18nKey.COMMON$GIT_PUSH)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"create-pr-button\"\n onClick={onCreatePR}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<PrIcon width={16} height={16} />}\n text={t(I18nKey.COMMON$CREATE_PR)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"create-new-branch-button\"\n onClick={onCreateNewBranch}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<CodeBranchIcon width={16} height={16} />}\n text={t(I18nKey.COMMON$CREATE_NEW_BRANCH)}\n />\n </ContextMenuListItem>\n </ContextMenu>\n );\n}\n"],"mappings":"wqBAoBA,IAAM,EAA2B,4BAMjC,SAAgB,EAAgB,CAAE,WAAiC,CACjE,GAAM,CAAE,KAAM,EAAA,eAAe,YAAY,CACnC,CAAE,oBAAqB,EAAA,sBAAsB,CAC7C,CAAE,KAAM,GAAiB,EAAA,uBAAuB,CAEhD,EAAqB,GAAc,aAsBzC,OACE,EAAA,EAAA,MAAC,EAAA,YAAD,CAAa,OAAO,oBAAoB,UAAU,iBAAlD,EACE,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,kBACP,YAxBkB,CACtB,EAAiB,EAAA,kBAAkB,CAAC,CACpC,GAAS,EAuBL,UAAW,YAEX,EAAA,EAAA,KAAC,EAAA,yBAAD,CACE,MAAM,EAAA,EAAA,KAAC,EAAA,QAAD,CAAe,MAAO,GAAI,OAAQ,GAAM,CAAA,CAC9C,KAAM,EAAE,EAAA,QAAQ,gBAAgB,CAChC,CAAA,CACkB,CAAA,EAEtB,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,kBACP,YA9BkB,CACtB,EAAiB,EAAA,iBAAiB,EAAmB,CAAC,CACtD,GAAS,EA6BL,UAAW,YAEX,EAAA,EAAA,KAAC,EAAA,yBAAD,CACE,MAAM,EAAA,EAAA,KAAC,EAAA,QAAD,CAAa,MAAO,GAAI,OAAQ,GAAM,CAAA,CAC5C,KAAM,EAAE,EAAA,QAAQ,gBAAgB,CAChC,CAAA,CACkB,CAAA,EAEtB,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,mBACP,YApCmB,CACvB,EAAiB,EAAA,kBAAkB,EAAmB,CAAC,CACvD,GAAS,EAmCL,UAAW,YAEX,EAAA,EAAA,KAAC,EAAA,yBAAD,CACE,MAAM,EAAA,EAAA,KAAC,EAAA,QAAD,CAAQ,MAAO,GAAI,OAAQ,GAAM,CAAA,CACvC,KAAM,EAAE,EAAA,QAAQ,iBAAiB,CACjC,CAAA,CACkB,CAAA,EAEtB,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,2BACP,YA1C0B,CAC9B,EAAiB,EAAA,0BAA0B,CAAC,CAC5C,GAAS,EAyCL,UAAW,YAEX,EAAA,EAAA,KAAC,EAAA,yBAAD,CACE,MAAM,EAAA,EAAA,KAAC,EAAA,QAAD,CAAgB,MAAO,GAAI,OAAQ,GAAM,CAAA,CAC/C,KAAM,EAAE,EAAA,QAAQ,yBAAyB,CACzC,CAAA,CACkB,CAAA,CACV"}
@@ -17,7 +17,7 @@ function v({ onClose: v }) {
17
17
  let { t: y } = e("openhands"), { setMessageToSend: b } = o(), { data: x } = s(), S = x?.git_provider;
18
18
  return /* @__PURE__ */ g(c, {
19
19
  testId: "git-tools-submenu",
20
- className: "w-max gap-0",
20
+ className: "w-max",
21
21
  children: [
22
22
  /* @__PURE__ */ h(l, {
23
23
  testId: "git-pull-button",
@@ -1 +1 @@
1
- {"version":3,"file":"git-tools-submenu.js","names":[],"sources":["../../../../src/components/features/controls/git-tools-submenu.tsx"],"sourcesContent":["import { useTranslation } from \"react-i18next\";\nimport { ContextMenu } from \"#/ui/context-menu\";\nimport { ContextMenuListItem } from \"../context-menu/context-menu-list-item\";\nimport { ToolsContextMenuIconText } from \"./tools-context-menu-icon-text\";\nimport { useActiveConversation } from \"#/hooks/query/use-active-conversation\";\nimport { Provider } from \"#/types/settings\";\nimport {\n getGitPullPrompt,\n getGitPushPrompt,\n getCreatePRPrompt,\n getCreateNewBranchPrompt,\n} from \"#/utils/utils\";\nimport { useConversationStore } from \"#/stores/conversation-store\";\n\nimport ArrowUpIcon from \"#/icons/u-arrow-up.svg?react\";\nimport ArrowDownIcon from \"#/icons/u-arrow-down.svg?react\";\nimport PrIcon from \"#/icons/u-pr.svg?react\";\nimport CodeBranchIcon from \"#/icons/u-code-branch.svg?react\";\nimport { I18nKey } from \"#/i18n/declaration\";\n\nconst submenuListItemClassName = \"!w-auto whitespace-nowrap\";\n\ninterface GitToolsSubmenuProps {\n onClose: () => void;\n}\n\nexport function GitToolsSubmenu({ onClose }: GitToolsSubmenuProps) {\n const { t } = useTranslation(\"openhands\");\n const { setMessageToSend } = useConversationStore();\n const { data: conversation } = useActiveConversation();\n\n const currentGitProvider = conversation?.git_provider as Provider;\n\n const onGitPull = () => {\n setMessageToSend(getGitPullPrompt());\n onClose();\n };\n\n const onGitPush = () => {\n setMessageToSend(getGitPushPrompt(currentGitProvider));\n onClose();\n };\n\n const onCreatePR = () => {\n setMessageToSend(getCreatePRPrompt(currentGitProvider));\n onClose();\n };\n\n const onCreateNewBranch = () => {\n setMessageToSend(getCreateNewBranchPrompt());\n onClose();\n };\n\n return (\n <ContextMenu testId=\"git-tools-submenu\" className=\"w-max gap-0\">\n <ContextMenuListItem\n testId=\"git-pull-button\"\n onClick={onGitPull}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<ArrowDownIcon width={16} height={16} />}\n text={t(I18nKey.COMMON$GIT_PULL)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"git-push-button\"\n onClick={onGitPush}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<ArrowUpIcon width={16} height={16} />}\n text={t(I18nKey.COMMON$GIT_PUSH)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"create-pr-button\"\n onClick={onCreatePR}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<PrIcon width={16} height={16} />}\n text={t(I18nKey.COMMON$CREATE_PR)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"create-new-branch-button\"\n onClick={onCreateNewBranch}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<CodeBranchIcon width={16} height={16} />}\n text={t(I18nKey.COMMON$CREATE_NEW_BRANCH)}\n />\n </ContextMenuListItem>\n </ContextMenu>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;AAoBA,IAAM,IAA2B;AAMjC,SAAgB,EAAgB,EAAE,cAAiC;CACjE,IAAM,EAAE,SAAM,EAAe,YAAY,EACnC,EAAE,wBAAqB,GAAsB,EAC7C,EAAE,MAAM,MAAiB,GAAuB,EAEhD,IAAqB,GAAc;AAsBzC,QACE,kBAAC,GAAD;EAAa,QAAO;EAAoB,WAAU;YAAlD;GACE,kBAAC,GAAD;IACE,QAAO;IACP,eAxBkB;AAEtB,KADA,EAAiB,GAAkB,CAAC,EACpC,GAAS;;IAuBL,WAAW;cAEX,kBAAC,GAAD;KACE,MAAM,kBAAC,GAAD;MAAe,OAAO;MAAI,QAAQ;MAAM,CAAA;KAC9C,MAAM,EAAE,EAAQ,gBAAgB;KAChC,CAAA;IACkB,CAAA;GAEtB,kBAAC,GAAD;IACE,QAAO;IACP,eA9BkB;AAEtB,KADA,EAAiB,EAAiB,EAAmB,CAAC,EACtD,GAAS;;IA6BL,WAAW;cAEX,kBAAC,GAAD;KACE,MAAM,kBAAC,GAAD;MAAa,OAAO;MAAI,QAAQ;MAAM,CAAA;KAC5C,MAAM,EAAE,EAAQ,gBAAgB;KAChC,CAAA;IACkB,CAAA;GAEtB,kBAAC,GAAD;IACE,QAAO;IACP,eApCmB;AAEvB,KADA,EAAiB,EAAkB,EAAmB,CAAC,EACvD,GAAS;;IAmCL,WAAW;cAEX,kBAAC,GAAD;KACE,MAAM,kBAAC,GAAD;MAAQ,OAAO;MAAI,QAAQ;MAAM,CAAA;KACvC,MAAM,EAAE,EAAQ,iBAAiB;KACjC,CAAA;IACkB,CAAA;GAEtB,kBAAC,GAAD;IACE,QAAO;IACP,eA1C0B;AAE9B,KADA,EAAiB,GAA0B,CAAC,EAC5C,GAAS;;IAyCL,WAAW;cAEX,kBAAC,GAAD;KACE,MAAM,kBAAC,GAAD;MAAgB,OAAO;MAAI,QAAQ;MAAM,CAAA;KAC/C,MAAM,EAAE,EAAQ,yBAAyB;KACzC,CAAA;IACkB,CAAA;GACV"}
1
+ {"version":3,"file":"git-tools-submenu.js","names":[],"sources":["../../../../src/components/features/controls/git-tools-submenu.tsx"],"sourcesContent":["import { useTranslation } from \"react-i18next\";\nimport { ContextMenu } from \"#/ui/context-menu\";\nimport { ContextMenuListItem } from \"../context-menu/context-menu-list-item\";\nimport { ToolsContextMenuIconText } from \"./tools-context-menu-icon-text\";\nimport { useActiveConversation } from \"#/hooks/query/use-active-conversation\";\nimport { Provider } from \"#/types/settings\";\nimport {\n getGitPullPrompt,\n getGitPushPrompt,\n getCreatePRPrompt,\n getCreateNewBranchPrompt,\n} from \"#/utils/utils\";\nimport { useConversationStore } from \"#/stores/conversation-store\";\n\nimport ArrowUpIcon from \"#/icons/u-arrow-up.svg?react\";\nimport ArrowDownIcon from \"#/icons/u-arrow-down.svg?react\";\nimport PrIcon from \"#/icons/u-pr.svg?react\";\nimport CodeBranchIcon from \"#/icons/u-code-branch.svg?react\";\nimport { I18nKey } from \"#/i18n/declaration\";\n\nconst submenuListItemClassName = \"!w-auto whitespace-nowrap\";\n\ninterface GitToolsSubmenuProps {\n onClose: () => void;\n}\n\nexport function GitToolsSubmenu({ onClose }: GitToolsSubmenuProps) {\n const { t } = useTranslation(\"openhands\");\n const { setMessageToSend } = useConversationStore();\n const { data: conversation } = useActiveConversation();\n\n const currentGitProvider = conversation?.git_provider as Provider;\n\n const onGitPull = () => {\n setMessageToSend(getGitPullPrompt());\n onClose();\n };\n\n const onGitPush = () => {\n setMessageToSend(getGitPushPrompt(currentGitProvider));\n onClose();\n };\n\n const onCreatePR = () => {\n setMessageToSend(getCreatePRPrompt(currentGitProvider));\n onClose();\n };\n\n const onCreateNewBranch = () => {\n setMessageToSend(getCreateNewBranchPrompt());\n onClose();\n };\n\n return (\n <ContextMenu testId=\"git-tools-submenu\" className=\"w-max\">\n <ContextMenuListItem\n testId=\"git-pull-button\"\n onClick={onGitPull}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<ArrowDownIcon width={16} height={16} />}\n text={t(I18nKey.COMMON$GIT_PULL)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"git-push-button\"\n onClick={onGitPush}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<ArrowUpIcon width={16} height={16} />}\n text={t(I18nKey.COMMON$GIT_PUSH)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"create-pr-button\"\n onClick={onCreatePR}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<PrIcon width={16} height={16} />}\n text={t(I18nKey.COMMON$CREATE_PR)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"create-new-branch-button\"\n onClick={onCreateNewBranch}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<CodeBranchIcon width={16} height={16} />}\n text={t(I18nKey.COMMON$CREATE_NEW_BRANCH)}\n />\n </ContextMenuListItem>\n </ContextMenu>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;AAoBA,IAAM,IAA2B;AAMjC,SAAgB,EAAgB,EAAE,cAAiC;CACjE,IAAM,EAAE,SAAM,EAAe,YAAY,EACnC,EAAE,wBAAqB,GAAsB,EAC7C,EAAE,MAAM,MAAiB,GAAuB,EAEhD,IAAqB,GAAc;AAsBzC,QACE,kBAAC,GAAD;EAAa,QAAO;EAAoB,WAAU;YAAlD;GACE,kBAAC,GAAD;IACE,QAAO;IACP,eAxBkB;AAEtB,KADA,EAAiB,GAAkB,CAAC,EACpC,GAAS;;IAuBL,WAAW;cAEX,kBAAC,GAAD;KACE,MAAM,kBAAC,GAAD;MAAe,OAAO;MAAI,QAAQ;MAAM,CAAA;KAC9C,MAAM,EAAE,EAAQ,gBAAgB;KAChC,CAAA;IACkB,CAAA;GAEtB,kBAAC,GAAD;IACE,QAAO;IACP,eA9BkB;AAEtB,KADA,EAAiB,EAAiB,EAAmB,CAAC,EACtD,GAAS;;IA6BL,WAAW;cAEX,kBAAC,GAAD;KACE,MAAM,kBAAC,GAAD;MAAa,OAAO;MAAI,QAAQ;MAAM,CAAA;KAC5C,MAAM,EAAE,EAAQ,gBAAgB;KAChC,CAAA;IACkB,CAAA;GAEtB,kBAAC,GAAD;IACE,QAAO;IACP,eApCmB;AAEvB,KADA,EAAiB,EAAkB,EAAmB,CAAC,EACvD,GAAS;;IAmCL,WAAW;cAEX,kBAAC,GAAD;KACE,MAAM,kBAAC,GAAD;MAAQ,OAAO;MAAI,QAAQ;MAAM,CAAA;KACvC,MAAM,EAAE,EAAQ,iBAAiB;KACjC,CAAA;IACkB,CAAA;GAEtB,kBAAC,GAAD;IACE,QAAO;IACP,eA1C0B;AAE9B,KADA,EAAiB,GAA0B,CAAC,EAC5C,GAAS;;IAyCL,WAAW;cAEX,kBAAC,GAAD;KACE,MAAM,kBAAC,GAAD;MAAgB,OAAO;MAAI,QAAQ;MAAM,CAAA;KAC/C,MAAM,EAAE,EAAQ,yBAAyB;KACzC,CAAA;IACkB,CAAA;GACV"}
@@ -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(`../../../stores/conversation-store.cjs`),r=require(`../../../ui/context-menu.cjs`),i=require(`../context-menu/context-menu-list-item.cjs`),a=require(`./tools-context-menu-icon-text.cjs`),o=require(`../../../icons/tachometer-fast.cjs`),s=require(`../../../icons/pr-status.cjs`),c=require(`../../../icons/document.cjs`),l=require(`../../../icons/u-water.cjs`),u=require(`../../../utils/suggestions/repo-suggestions.cjs`);let d=require(`react/jsx-runtime`);var f=`!w-auto whitespace-nowrap`;function p({onClose:p}){let{t:m}=e.useTranslation(`openhands`),{setMessageToSend:h}=n.useConversationStore();return(0,d.jsxs)(r.ContextMenu,{testId:`macros-submenu`,className:`overflow-visible gap-0`,children:[(0,d.jsx)(i.ContextMenuListItem,{testId:`increase-test-coverage-button`,onClick:()=>{h(u.REPO_SUGGESTIONS.INCREASE_TEST_COVERAGE),p()},className:f,children:(0,d.jsx)(a.ToolsContextMenuIconText,{icon:(0,d.jsx)(o.default,{width:16,height:16}),text:m(t.I18nKey.INCREASE_TEST_COVERAGE)})}),(0,d.jsx)(i.ContextMenuListItem,{testId:`fix-readme-button`,onClick:()=>{h(u.REPO_SUGGESTIONS.FIX_README),p()},className:f,children:(0,d.jsx)(a.ToolsContextMenuIconText,{icon:(0,d.jsx)(c.default,{width:16,height:16}),text:m(t.I18nKey.FIX_README)})}),(0,d.jsx)(i.ContextMenuListItem,{testId:`auto-merge-prs-button`,onClick:()=>{h(u.REPO_SUGGESTIONS.AUTO_MERGE_PRS),p()},className:f,children:(0,d.jsx)(a.ToolsContextMenuIconText,{icon:(0,d.jsx)(s.default,{width:16,height:16}),text:m(t.I18nKey.AUTO_MERGE_PRS)})}),(0,d.jsx)(i.ContextMenuListItem,{testId:`clean-dependencies-button`,onClick:()=>{h(u.REPO_SUGGESTIONS.CLEAN_DEPENDENCIES),p()},className:f,children:(0,d.jsx)(a.ToolsContextMenuIconText,{icon:(0,d.jsx)(l.default,{width:16,height:16}),text:m(t.I18nKey.CLEAN_DEPENDENCIES)})})]})}exports.MacrosSubmenu=p;
1
+ require(`../../../_virtual/_rolldown/runtime.cjs`);const e=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),t=require(`../../../i18n/declaration.cjs`),n=require(`../../../stores/conversation-store.cjs`),r=require(`../../../ui/context-menu.cjs`),i=require(`../context-menu/context-menu-list-item.cjs`),a=require(`./tools-context-menu-icon-text.cjs`),o=require(`../../../icons/tachometer-fast.cjs`),s=require(`../../../icons/pr-status.cjs`),c=require(`../../../icons/document.cjs`),l=require(`../../../icons/u-water.cjs`),u=require(`../../../utils/suggestions/repo-suggestions.cjs`);let d=require(`react/jsx-runtime`);var f=`!w-auto whitespace-nowrap`;function p({onClose:p}){let{t:m}=e.useTranslation(`openhands`),{setMessageToSend:h}=n.useConversationStore();return(0,d.jsxs)(r.ContextMenu,{testId:`macros-submenu`,className:`overflow-visible`,children:[(0,d.jsx)(i.ContextMenuListItem,{testId:`increase-test-coverage-button`,onClick:()=>{h(u.REPO_SUGGESTIONS.INCREASE_TEST_COVERAGE),p()},className:f,children:(0,d.jsx)(a.ToolsContextMenuIconText,{icon:(0,d.jsx)(o.default,{width:16,height:16}),text:m(t.I18nKey.INCREASE_TEST_COVERAGE)})}),(0,d.jsx)(i.ContextMenuListItem,{testId:`fix-readme-button`,onClick:()=>{h(u.REPO_SUGGESTIONS.FIX_README),p()},className:f,children:(0,d.jsx)(a.ToolsContextMenuIconText,{icon:(0,d.jsx)(c.default,{width:16,height:16}),text:m(t.I18nKey.FIX_README)})}),(0,d.jsx)(i.ContextMenuListItem,{testId:`auto-merge-prs-button`,onClick:()=>{h(u.REPO_SUGGESTIONS.AUTO_MERGE_PRS),p()},className:f,children:(0,d.jsx)(a.ToolsContextMenuIconText,{icon:(0,d.jsx)(s.default,{width:16,height:16}),text:m(t.I18nKey.AUTO_MERGE_PRS)})}),(0,d.jsx)(i.ContextMenuListItem,{testId:`clean-dependencies-button`,onClick:()=>{h(u.REPO_SUGGESTIONS.CLEAN_DEPENDENCIES),p()},className:f,children:(0,d.jsx)(a.ToolsContextMenuIconText,{icon:(0,d.jsx)(l.default,{width:16,height:16}),text:m(t.I18nKey.CLEAN_DEPENDENCIES)})})]})}exports.MacrosSubmenu=p;
2
2
  //# sourceMappingURL=macros-submenu.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"macros-submenu.cjs","names":[],"sources":["../../../../src/components/features/controls/macros-submenu.tsx"],"sourcesContent":["import { useTranslation } from \"react-i18next\";\nimport { ContextMenu } from \"#/ui/context-menu\";\nimport { ContextMenuListItem } from \"../context-menu/context-menu-list-item\";\nimport { ToolsContextMenuIconText } from \"./tools-context-menu-icon-text\";\n\nimport TachometerFastIcon from \"#/icons/tachometer-fast.svg?react\";\nimport PrStatusIcon from \"#/icons/pr-status.svg?react\";\nimport DocumentIcon from \"#/icons/document.svg?react\";\nimport WaterIcon from \"#/icons/u-water.svg?react\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { useConversationStore } from \"#/stores/conversation-store\";\nimport { REPO_SUGGESTIONS } from \"#/utils/suggestions/repo-suggestions\";\n\nconst submenuListItemClassName = \"!w-auto whitespace-nowrap\";\n\ninterface MacrosSubmenuProps {\n onClose: () => void;\n}\n\nexport function MacrosSubmenu({ onClose }: MacrosSubmenuProps) {\n const { t } = useTranslation(\"openhands\");\n const { setMessageToSend } = useConversationStore();\n\n const onIncreaseTestCoverage = () => {\n setMessageToSend(REPO_SUGGESTIONS.INCREASE_TEST_COVERAGE);\n onClose();\n };\n const onFixReadme = () => {\n setMessageToSend(REPO_SUGGESTIONS.FIX_README);\n onClose();\n };\n const onAutoMergePRs = () => {\n setMessageToSend(REPO_SUGGESTIONS.AUTO_MERGE_PRS);\n onClose();\n };\n const onCleanDependencies = () => {\n setMessageToSend(REPO_SUGGESTIONS.CLEAN_DEPENDENCIES);\n onClose();\n };\n\n return (\n <ContextMenu testId=\"macros-submenu\" className=\"overflow-visible gap-0\">\n <ContextMenuListItem\n testId=\"increase-test-coverage-button\"\n onClick={onIncreaseTestCoverage}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<TachometerFastIcon width={16} height={16} />}\n text={t(I18nKey.INCREASE_TEST_COVERAGE)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"fix-readme-button\"\n onClick={onFixReadme}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<DocumentIcon width={16} height={16} />}\n text={t(I18nKey.FIX_README)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"auto-merge-prs-button\"\n onClick={onAutoMergePRs}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<PrStatusIcon width={16} height={16} />}\n text={t(I18nKey.AUTO_MERGE_PRS)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"clean-dependencies-button\"\n onClick={onCleanDependencies}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<WaterIcon width={16} height={16} />}\n text={t(I18nKey.CLEAN_DEPENDENCIES)}\n />\n </ContextMenuListItem>\n </ContextMenu>\n );\n}\n"],"mappings":"ioBAaA,IAAM,EAA2B,4BAMjC,SAAgB,EAAc,CAAE,WAA+B,CAC7D,GAAM,CAAE,KAAM,EAAA,eAAe,YAAY,CACnC,CAAE,oBAAqB,EAAA,sBAAsB,CAmBnD,OACE,EAAA,EAAA,MAAC,EAAA,YAAD,CAAa,OAAO,iBAAiB,UAAU,kCAA/C,EACE,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,gCACP,YArB+B,CACnC,EAAiB,EAAA,iBAAiB,uBAAuB,CACzD,GAAS,EAoBL,UAAW,YAEX,EAAA,EAAA,KAAC,EAAA,yBAAD,CACE,MAAM,EAAA,EAAA,KAAC,EAAA,QAAD,CAAoB,MAAO,GAAI,OAAQ,GAAM,CAAA,CACnD,KAAM,EAAE,EAAA,QAAQ,uBAAuB,CACvC,CAAA,CACkB,CAAA,EAEtB,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,oBACP,YA5BoB,CACxB,EAAiB,EAAA,iBAAiB,WAAW,CAC7C,GAAS,EA2BL,UAAW,YAEX,EAAA,EAAA,KAAC,EAAA,yBAAD,CACE,MAAM,EAAA,EAAA,KAAC,EAAA,QAAD,CAAc,MAAO,GAAI,OAAQ,GAAM,CAAA,CAC7C,KAAM,EAAE,EAAA,QAAQ,WAAW,CAC3B,CAAA,CACkB,CAAA,EAEtB,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,wBACP,YAnCuB,CAC3B,EAAiB,EAAA,iBAAiB,eAAe,CACjD,GAAS,EAkCL,UAAW,YAEX,EAAA,EAAA,KAAC,EAAA,yBAAD,CACE,MAAM,EAAA,EAAA,KAAC,EAAA,QAAD,CAAc,MAAO,GAAI,OAAQ,GAAM,CAAA,CAC7C,KAAM,EAAE,EAAA,QAAQ,eAAe,CAC/B,CAAA,CACkB,CAAA,EAEtB,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,4BACP,YA1C4B,CAChC,EAAiB,EAAA,iBAAiB,mBAAmB,CACrD,GAAS,EAyCL,UAAW,YAEX,EAAA,EAAA,KAAC,EAAA,yBAAD,CACE,MAAM,EAAA,EAAA,KAAC,EAAA,QAAD,CAAW,MAAO,GAAI,OAAQ,GAAM,CAAA,CAC1C,KAAM,EAAE,EAAA,QAAQ,mBAAmB,CACnC,CAAA,CACkB,CAAA,CACV"}
1
+ {"version":3,"file":"macros-submenu.cjs","names":[],"sources":["../../../../src/components/features/controls/macros-submenu.tsx"],"sourcesContent":["import { useTranslation } from \"react-i18next\";\nimport { ContextMenu } from \"#/ui/context-menu\";\nimport { ContextMenuListItem } from \"../context-menu/context-menu-list-item\";\nimport { ToolsContextMenuIconText } from \"./tools-context-menu-icon-text\";\n\nimport TachometerFastIcon from \"#/icons/tachometer-fast.svg?react\";\nimport PrStatusIcon from \"#/icons/pr-status.svg?react\";\nimport DocumentIcon from \"#/icons/document.svg?react\";\nimport WaterIcon from \"#/icons/u-water.svg?react\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { useConversationStore } from \"#/stores/conversation-store\";\nimport { REPO_SUGGESTIONS } from \"#/utils/suggestions/repo-suggestions\";\n\nconst submenuListItemClassName = \"!w-auto whitespace-nowrap\";\n\ninterface MacrosSubmenuProps {\n onClose: () => void;\n}\n\nexport function MacrosSubmenu({ onClose }: MacrosSubmenuProps) {\n const { t } = useTranslation(\"openhands\");\n const { setMessageToSend } = useConversationStore();\n\n const onIncreaseTestCoverage = () => {\n setMessageToSend(REPO_SUGGESTIONS.INCREASE_TEST_COVERAGE);\n onClose();\n };\n const onFixReadme = () => {\n setMessageToSend(REPO_SUGGESTIONS.FIX_README);\n onClose();\n };\n const onAutoMergePRs = () => {\n setMessageToSend(REPO_SUGGESTIONS.AUTO_MERGE_PRS);\n onClose();\n };\n const onCleanDependencies = () => {\n setMessageToSend(REPO_SUGGESTIONS.CLEAN_DEPENDENCIES);\n onClose();\n };\n\n return (\n <ContextMenu testId=\"macros-submenu\" className=\"overflow-visible\">\n <ContextMenuListItem\n testId=\"increase-test-coverage-button\"\n onClick={onIncreaseTestCoverage}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<TachometerFastIcon width={16} height={16} />}\n text={t(I18nKey.INCREASE_TEST_COVERAGE)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"fix-readme-button\"\n onClick={onFixReadme}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<DocumentIcon width={16} height={16} />}\n text={t(I18nKey.FIX_README)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"auto-merge-prs-button\"\n onClick={onAutoMergePRs}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<PrStatusIcon width={16} height={16} />}\n text={t(I18nKey.AUTO_MERGE_PRS)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"clean-dependencies-button\"\n onClick={onCleanDependencies}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<WaterIcon width={16} height={16} />}\n text={t(I18nKey.CLEAN_DEPENDENCIES)}\n />\n </ContextMenuListItem>\n </ContextMenu>\n );\n}\n"],"mappings":"ioBAaA,IAAM,EAA2B,4BAMjC,SAAgB,EAAc,CAAE,WAA+B,CAC7D,GAAM,CAAE,KAAM,EAAA,eAAe,YAAY,CACnC,CAAE,oBAAqB,EAAA,sBAAsB,CAmBnD,OACE,EAAA,EAAA,MAAC,EAAA,YAAD,CAAa,OAAO,iBAAiB,UAAU,4BAA/C,EACE,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,gCACP,YArB+B,CACnC,EAAiB,EAAA,iBAAiB,uBAAuB,CACzD,GAAS,EAoBL,UAAW,YAEX,EAAA,EAAA,KAAC,EAAA,yBAAD,CACE,MAAM,EAAA,EAAA,KAAC,EAAA,QAAD,CAAoB,MAAO,GAAI,OAAQ,GAAM,CAAA,CACnD,KAAM,EAAE,EAAA,QAAQ,uBAAuB,CACvC,CAAA,CACkB,CAAA,EAEtB,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,oBACP,YA5BoB,CACxB,EAAiB,EAAA,iBAAiB,WAAW,CAC7C,GAAS,EA2BL,UAAW,YAEX,EAAA,EAAA,KAAC,EAAA,yBAAD,CACE,MAAM,EAAA,EAAA,KAAC,EAAA,QAAD,CAAc,MAAO,GAAI,OAAQ,GAAM,CAAA,CAC7C,KAAM,EAAE,EAAA,QAAQ,WAAW,CAC3B,CAAA,CACkB,CAAA,EAEtB,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,wBACP,YAnCuB,CAC3B,EAAiB,EAAA,iBAAiB,eAAe,CACjD,GAAS,EAkCL,UAAW,YAEX,EAAA,EAAA,KAAC,EAAA,yBAAD,CACE,MAAM,EAAA,EAAA,KAAC,EAAA,QAAD,CAAc,MAAO,GAAI,OAAQ,GAAM,CAAA,CAC7C,KAAM,EAAE,EAAA,QAAQ,eAAe,CAC/B,CAAA,CACkB,CAAA,EAEtB,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,4BACP,YA1C4B,CAChC,EAAiB,EAAA,iBAAiB,mBAAmB,CACrD,GAAS,EAyCL,UAAW,YAEX,EAAA,EAAA,KAAC,EAAA,yBAAD,CACE,MAAM,EAAA,EAAA,KAAC,EAAA,QAAD,CAAW,MAAO,GAAI,OAAQ,GAAM,CAAA,CAC1C,KAAM,EAAE,EAAA,QAAQ,mBAAmB,CACnC,CAAA,CACkB,CAAA,CACV"}
@@ -16,7 +16,7 @@ function m({ onClose: m }) {
16
16
  let { t: h } = e("openhands"), { setMessageToSend: g } = n();
17
17
  return /* @__PURE__ */ f(r, {
18
18
  testId: "macros-submenu",
19
- className: "overflow-visible gap-0",
19
+ className: "overflow-visible",
20
20
  children: [
21
21
  /* @__PURE__ */ d(i, {
22
22
  testId: "increase-test-coverage-button",
@@ -1 +1 @@
1
- {"version":3,"file":"macros-submenu.js","names":[],"sources":["../../../../src/components/features/controls/macros-submenu.tsx"],"sourcesContent":["import { useTranslation } from \"react-i18next\";\nimport { ContextMenu } from \"#/ui/context-menu\";\nimport { ContextMenuListItem } from \"../context-menu/context-menu-list-item\";\nimport { ToolsContextMenuIconText } from \"./tools-context-menu-icon-text\";\n\nimport TachometerFastIcon from \"#/icons/tachometer-fast.svg?react\";\nimport PrStatusIcon from \"#/icons/pr-status.svg?react\";\nimport DocumentIcon from \"#/icons/document.svg?react\";\nimport WaterIcon from \"#/icons/u-water.svg?react\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { useConversationStore } from \"#/stores/conversation-store\";\nimport { REPO_SUGGESTIONS } from \"#/utils/suggestions/repo-suggestions\";\n\nconst submenuListItemClassName = \"!w-auto whitespace-nowrap\";\n\ninterface MacrosSubmenuProps {\n onClose: () => void;\n}\n\nexport function MacrosSubmenu({ onClose }: MacrosSubmenuProps) {\n const { t } = useTranslation(\"openhands\");\n const { setMessageToSend } = useConversationStore();\n\n const onIncreaseTestCoverage = () => {\n setMessageToSend(REPO_SUGGESTIONS.INCREASE_TEST_COVERAGE);\n onClose();\n };\n const onFixReadme = () => {\n setMessageToSend(REPO_SUGGESTIONS.FIX_README);\n onClose();\n };\n const onAutoMergePRs = () => {\n setMessageToSend(REPO_SUGGESTIONS.AUTO_MERGE_PRS);\n onClose();\n };\n const onCleanDependencies = () => {\n setMessageToSend(REPO_SUGGESTIONS.CLEAN_DEPENDENCIES);\n onClose();\n };\n\n return (\n <ContextMenu testId=\"macros-submenu\" className=\"overflow-visible gap-0\">\n <ContextMenuListItem\n testId=\"increase-test-coverage-button\"\n onClick={onIncreaseTestCoverage}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<TachometerFastIcon width={16} height={16} />}\n text={t(I18nKey.INCREASE_TEST_COVERAGE)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"fix-readme-button\"\n onClick={onFixReadme}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<DocumentIcon width={16} height={16} />}\n text={t(I18nKey.FIX_README)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"auto-merge-prs-button\"\n onClick={onAutoMergePRs}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<PrStatusIcon width={16} height={16} />}\n text={t(I18nKey.AUTO_MERGE_PRS)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"clean-dependencies-button\"\n onClick={onCleanDependencies}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<WaterIcon width={16} height={16} />}\n text={t(I18nKey.CLEAN_DEPENDENCIES)}\n />\n </ContextMenuListItem>\n </ContextMenu>\n );\n}\n"],"mappings":";;;;;;;;;;;;;AAaA,IAAM,IAA2B;AAMjC,SAAgB,EAAc,EAAE,cAA+B;CAC7D,IAAM,EAAE,SAAM,EAAe,YAAY,EACnC,EAAE,wBAAqB,GAAsB;AAmBnD,QACE,kBAAC,GAAD;EAAa,QAAO;EAAiB,WAAU;YAA/C;GACE,kBAAC,GAAD;IACE,QAAO;IACP,eArB+B;AAEnC,KADA,EAAiB,EAAiB,uBAAuB,EACzD,GAAS;;IAoBL,WAAW;cAEX,kBAAC,GAAD;KACE,MAAM,kBAAC,GAAD;MAAoB,OAAO;MAAI,QAAQ;MAAM,CAAA;KACnD,MAAM,EAAE,EAAQ,uBAAuB;KACvC,CAAA;IACkB,CAAA;GAEtB,kBAAC,GAAD;IACE,QAAO;IACP,eA5BoB;AAExB,KADA,EAAiB,EAAiB,WAAW,EAC7C,GAAS;;IA2BL,WAAW;cAEX,kBAAC,GAAD;KACE,MAAM,kBAAC,GAAD;MAAc,OAAO;MAAI,QAAQ;MAAM,CAAA;KAC7C,MAAM,EAAE,EAAQ,WAAW;KAC3B,CAAA;IACkB,CAAA;GAEtB,kBAAC,GAAD;IACE,QAAO;IACP,eAnCuB;AAE3B,KADA,EAAiB,EAAiB,eAAe,EACjD,GAAS;;IAkCL,WAAW;cAEX,kBAAC,GAAD;KACE,MAAM,kBAAC,GAAD;MAAc,OAAO;MAAI,QAAQ;MAAM,CAAA;KAC7C,MAAM,EAAE,EAAQ,eAAe;KAC/B,CAAA;IACkB,CAAA;GAEtB,kBAAC,GAAD;IACE,QAAO;IACP,eA1C4B;AAEhC,KADA,EAAiB,EAAiB,mBAAmB,EACrD,GAAS;;IAyCL,WAAW;cAEX,kBAAC,GAAD;KACE,MAAM,kBAAC,GAAD;MAAW,OAAO;MAAI,QAAQ;MAAM,CAAA;KAC1C,MAAM,EAAE,EAAQ,mBAAmB;KACnC,CAAA;IACkB,CAAA;GACV"}
1
+ {"version":3,"file":"macros-submenu.js","names":[],"sources":["../../../../src/components/features/controls/macros-submenu.tsx"],"sourcesContent":["import { useTranslation } from \"react-i18next\";\nimport { ContextMenu } from \"#/ui/context-menu\";\nimport { ContextMenuListItem } from \"../context-menu/context-menu-list-item\";\nimport { ToolsContextMenuIconText } from \"./tools-context-menu-icon-text\";\n\nimport TachometerFastIcon from \"#/icons/tachometer-fast.svg?react\";\nimport PrStatusIcon from \"#/icons/pr-status.svg?react\";\nimport DocumentIcon from \"#/icons/document.svg?react\";\nimport WaterIcon from \"#/icons/u-water.svg?react\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { useConversationStore } from \"#/stores/conversation-store\";\nimport { REPO_SUGGESTIONS } from \"#/utils/suggestions/repo-suggestions\";\n\nconst submenuListItemClassName = \"!w-auto whitespace-nowrap\";\n\ninterface MacrosSubmenuProps {\n onClose: () => void;\n}\n\nexport function MacrosSubmenu({ onClose }: MacrosSubmenuProps) {\n const { t } = useTranslation(\"openhands\");\n const { setMessageToSend } = useConversationStore();\n\n const onIncreaseTestCoverage = () => {\n setMessageToSend(REPO_SUGGESTIONS.INCREASE_TEST_COVERAGE);\n onClose();\n };\n const onFixReadme = () => {\n setMessageToSend(REPO_SUGGESTIONS.FIX_README);\n onClose();\n };\n const onAutoMergePRs = () => {\n setMessageToSend(REPO_SUGGESTIONS.AUTO_MERGE_PRS);\n onClose();\n };\n const onCleanDependencies = () => {\n setMessageToSend(REPO_SUGGESTIONS.CLEAN_DEPENDENCIES);\n onClose();\n };\n\n return (\n <ContextMenu testId=\"macros-submenu\" className=\"overflow-visible\">\n <ContextMenuListItem\n testId=\"increase-test-coverage-button\"\n onClick={onIncreaseTestCoverage}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<TachometerFastIcon width={16} height={16} />}\n text={t(I18nKey.INCREASE_TEST_COVERAGE)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"fix-readme-button\"\n onClick={onFixReadme}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<DocumentIcon width={16} height={16} />}\n text={t(I18nKey.FIX_README)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"auto-merge-prs-button\"\n onClick={onAutoMergePRs}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<PrStatusIcon width={16} height={16} />}\n text={t(I18nKey.AUTO_MERGE_PRS)}\n />\n </ContextMenuListItem>\n\n <ContextMenuListItem\n testId=\"clean-dependencies-button\"\n onClick={onCleanDependencies}\n className={submenuListItemClassName}\n >\n <ToolsContextMenuIconText\n icon={<WaterIcon width={16} height={16} />}\n text={t(I18nKey.CLEAN_DEPENDENCIES)}\n />\n </ContextMenuListItem>\n </ContextMenu>\n );\n}\n"],"mappings":";;;;;;;;;;;;;AAaA,IAAM,IAA2B;AAMjC,SAAgB,EAAc,EAAE,cAA+B;CAC7D,IAAM,EAAE,SAAM,EAAe,YAAY,EACnC,EAAE,wBAAqB,GAAsB;AAmBnD,QACE,kBAAC,GAAD;EAAa,QAAO;EAAiB,WAAU;YAA/C;GACE,kBAAC,GAAD;IACE,QAAO;IACP,eArB+B;AAEnC,KADA,EAAiB,EAAiB,uBAAuB,EACzD,GAAS;;IAoBL,WAAW;cAEX,kBAAC,GAAD;KACE,MAAM,kBAAC,GAAD;MAAoB,OAAO;MAAI,QAAQ;MAAM,CAAA;KACnD,MAAM,EAAE,EAAQ,uBAAuB;KACvC,CAAA;IACkB,CAAA;GAEtB,kBAAC,GAAD;IACE,QAAO;IACP,eA5BoB;AAExB,KADA,EAAiB,EAAiB,WAAW,EAC7C,GAAS;;IA2BL,WAAW;cAEX,kBAAC,GAAD;KACE,MAAM,kBAAC,GAAD;MAAc,OAAO;MAAI,QAAQ;MAAM,CAAA;KAC7C,MAAM,EAAE,EAAQ,WAAW;KAC3B,CAAA;IACkB,CAAA;GAEtB,kBAAC,GAAD;IACE,QAAO;IACP,eAnCuB;AAE3B,KADA,EAAiB,EAAiB,eAAe,EACjD,GAAS;;IAkCL,WAAW;cAEX,kBAAC,GAAD;KACE,MAAM,kBAAC,GAAD;MAAc,OAAO;MAAI,QAAQ;MAAM,CAAA;KAC7C,MAAM,EAAE,EAAQ,eAAe;KAC/B,CAAA;IACkB,CAAA;GAEtB,kBAAC,GAAD;IACE,QAAO;IACP,eA1C4B;AAEhC,KADA,EAAiB,EAAiB,mBAAmB,EACrD,GAAS;;IAyCL,WAAW;cAEX,kBAAC,GAAD;KACE,MAAM,kBAAC,GAAD;MAAW,OAAO;MAAI,QAAQ;MAAM,CAAA;KAC1C,MAAM,EAAE,EAAQ,mBAAmB;KACnC,CAAA;IACkB,CAAA;GACV"}
@@ -1,2 +1,2 @@
1
- require(`../../../_virtual/_rolldown/runtime.cjs`);const e=require(`../../../utils/utils.cjs`),t=require(`../../../utils/form-control-classes.cjs`),n=require(`../context-menu/context-menu-list-item.cjs`);let r=require(`react/jsx-runtime`);function i({icon:i,text:a,onClick:o,testId:s}){return(0,r.jsx)(n.ContextMenuListItem,{testId:s,onClick:o,children:(0,r.jsxs)(`div`,{className:`flex min-w-0 w-full items-center justify-between gap-2`,children:[(0,r.jsx)(`span`,{className:`min-w-0 truncate`,children:a}),(0,r.jsx)(`span`,{className:e.cn(`flex shrink-0 items-center text-[var(--oh-muted)] group-hover:text-[var(--oh-foreground)] group-focus-visible:text-[var(--oh-foreground)] [&_svg]:text-current`,t.formControlTransitionClassName),"aria-hidden":!0,children:i})]})})}exports.ServerStatusContextMenuIconText=i;
1
+ require(`../../../_virtual/_rolldown/runtime.cjs`);const e=require(`../../../utils/dropdown-classes.cjs`),t=require(`../context-menu/context-menu-list-item.cjs`);let n=require(`react/jsx-runtime`);function r({icon:r,text:i,onClick:a,testId:o}){return(0,n.jsx)(t.ContextMenuListItem,{testId:o,onClick:a,children:(0,n.jsxs)(`div`,{className:`flex min-w-0 w-full items-center justify-between gap-2`,children:[(0,n.jsx)(`span`,{className:`min-w-0 truncate`,children:i}),(0,n.jsx)(`span`,{className:e.dropdownMenuRowIconWrapperClassName,"aria-hidden":!0,children:r})]})})}exports.ServerStatusContextMenuIconText=r;
2
2
  //# sourceMappingURL=server-status-context-menu-icon-text.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"server-status-context-menu-icon-text.cjs","names":[],"sources":["../../../../src/components/features/controls/server-status-context-menu-icon-text.tsx"],"sourcesContent":["import { ContextMenuListItem } from \"#/components/features/context-menu/context-menu-list-item\";\nimport { formControlTransitionClassName } from \"#/utils/form-control-classes\";\nimport { cn } from \"#/utils/utils\";\n\ninterface ServerStatusContextMenuIconTextProps {\n icon: React.ReactNode;\n text: string;\n onClick: (event: React.MouseEvent<HTMLButtonElement>) => void;\n testId?: string;\n}\n\nexport function ServerStatusContextMenuIconText({\n icon,\n text,\n onClick,\n testId,\n}: ServerStatusContextMenuIconTextProps) {\n return (\n <ContextMenuListItem testId={testId} onClick={onClick}>\n <div className=\"flex min-w-0 w-full items-center justify-between gap-2\">\n <span className=\"min-w-0 truncate\">{text}</span>\n <span\n className={cn(\n \"flex shrink-0 items-center text-[var(--oh-muted)] group-hover:text-[var(--oh-foreground)] group-focus-visible:text-[var(--oh-foreground)] [&_svg]:text-current\",\n formControlTransitionClassName,\n )}\n aria-hidden\n >\n {icon}\n </span>\n </div>\n </ContextMenuListItem>\n );\n}\n"],"mappings":"+OAWA,SAAgB,EAAgC,CAC9C,OACA,OACA,UACA,UACuC,CACvC,OACE,EAAA,EAAA,KAAC,EAAA,oBAAD,CAA6B,SAAiB,oBAC5C,EAAA,EAAA,MAAC,MAAD,CAAK,UAAU,kEAAf,EACE,EAAA,EAAA,KAAC,OAAD,CAAM,UAAU,4BAAoB,EAAY,CAAA,EAChD,EAAA,EAAA,KAAC,OAAD,CACE,UAAW,EAAA,GACT,iKACA,EAAA,+BACD,CACD,cAAA,YAEC,EACI,CAAA,CACH,GACc,CAAA"}
1
+ {"version":3,"file":"server-status-context-menu-icon-text.cjs","names":[],"sources":["../../../../src/components/features/controls/server-status-context-menu-icon-text.tsx"],"sourcesContent":["import { ContextMenuListItem } from \"#/components/features/context-menu/context-menu-list-item\";\nimport { dropdownMenuRowIconWrapperClassName } from \"#/utils/dropdown-classes\";\n\ninterface ServerStatusContextMenuIconTextProps {\n icon: React.ReactNode;\n text: string;\n onClick: (event: React.MouseEvent<HTMLButtonElement>) => void;\n testId?: string;\n}\n\nexport function ServerStatusContextMenuIconText({\n icon,\n text,\n onClick,\n testId,\n}: ServerStatusContextMenuIconTextProps) {\n return (\n <ContextMenuListItem testId={testId} onClick={onClick}>\n <div className=\"flex min-w-0 w-full items-center justify-between gap-2\">\n <span className=\"min-w-0 truncate\">{text}</span>\n <span className={dropdownMenuRowIconWrapperClassName} aria-hidden>\n {icon}\n </span>\n </div>\n </ContextMenuListItem>\n );\n}\n"],"mappings":"qMAUA,SAAgB,EAAgC,CAC9C,OACA,OACA,UACA,UACuC,CACvC,OACE,EAAA,EAAA,KAAC,EAAA,oBAAD,CAA6B,SAAiB,oBAC5C,EAAA,EAAA,MAAC,MAAD,CAAK,UAAU,kEAAf,EACE,EAAA,EAAA,KAAC,OAAD,CAAM,UAAU,4BAAoB,EAAY,CAAA,EAChD,EAAA,EAAA,KAAC,OAAD,CAAM,UAAW,EAAA,oCAAqC,cAAA,YACnD,EACI,CAAA,CACH,GACc,CAAA"}
@@ -1,26 +1,25 @@
1
- import { cn as e } from "../../../utils/utils.js";
2
- import { formControlTransitionClassName as t } from "../../../utils/form-control-classes.js";
3
- import { ContextMenuListItem as n } from "../context-menu/context-menu-list-item.js";
4
- import { jsx as r, jsxs as i } from "react/jsx-runtime";
1
+ import { dropdownMenuRowIconWrapperClassName as e } from "../../../utils/dropdown-classes.js";
2
+ import { ContextMenuListItem as t } from "../context-menu/context-menu-list-item.js";
3
+ import { jsx as n, jsxs as r } from "react/jsx-runtime";
5
4
  //#region src/components/features/controls/server-status-context-menu-icon-text.tsx
6
- function a({ icon: a, text: o, onClick: s, testId: c }) {
7
- return /* @__PURE__ */ r(n, {
8
- testId: c,
9
- onClick: s,
10
- children: /* @__PURE__ */ i("div", {
5
+ function i({ icon: i, text: a, onClick: o, testId: s }) {
6
+ return /* @__PURE__ */ n(t, {
7
+ testId: s,
8
+ onClick: o,
9
+ children: /* @__PURE__ */ r("div", {
11
10
  className: "flex min-w-0 w-full items-center justify-between gap-2",
12
- children: [/* @__PURE__ */ r("span", {
11
+ children: [/* @__PURE__ */ n("span", {
13
12
  className: "min-w-0 truncate",
14
- children: o
15
- }), /* @__PURE__ */ r("span", {
16
- className: e("flex shrink-0 items-center text-[var(--oh-muted)] group-hover:text-[var(--oh-foreground)] group-focus-visible:text-[var(--oh-foreground)] [&_svg]:text-current", t),
17
- "aria-hidden": !0,
18
13
  children: a
14
+ }), /* @__PURE__ */ n("span", {
15
+ className: e,
16
+ "aria-hidden": !0,
17
+ children: i
19
18
  })]
20
19
  })
21
20
  });
22
21
  }
23
22
  //#endregion
24
- export { a as ServerStatusContextMenuIconText };
23
+ export { i as ServerStatusContextMenuIconText };
25
24
 
26
25
  //# sourceMappingURL=server-status-context-menu-icon-text.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"server-status-context-menu-icon-text.js","names":[],"sources":["../../../../src/components/features/controls/server-status-context-menu-icon-text.tsx"],"sourcesContent":["import { ContextMenuListItem } from \"#/components/features/context-menu/context-menu-list-item\";\nimport { formControlTransitionClassName } from \"#/utils/form-control-classes\";\nimport { cn } from \"#/utils/utils\";\n\ninterface ServerStatusContextMenuIconTextProps {\n icon: React.ReactNode;\n text: string;\n onClick: (event: React.MouseEvent<HTMLButtonElement>) => void;\n testId?: string;\n}\n\nexport function ServerStatusContextMenuIconText({\n icon,\n text,\n onClick,\n testId,\n}: ServerStatusContextMenuIconTextProps) {\n return (\n <ContextMenuListItem testId={testId} onClick={onClick}>\n <div className=\"flex min-w-0 w-full items-center justify-between gap-2\">\n <span className=\"min-w-0 truncate\">{text}</span>\n <span\n className={cn(\n \"flex shrink-0 items-center text-[var(--oh-muted)] group-hover:text-[var(--oh-foreground)] group-focus-visible:text-[var(--oh-foreground)] [&_svg]:text-current\",\n formControlTransitionClassName,\n )}\n aria-hidden\n >\n {icon}\n </span>\n </div>\n </ContextMenuListItem>\n );\n}\n"],"mappings":";;;;;AAWA,SAAgB,EAAgC,EAC9C,SACA,SACA,YACA,aACuC;AACvC,QACE,kBAAC,GAAD;EAA6B;EAAiB;YAC5C,kBAAC,OAAD;GAAK,WAAU;aAAf,CACE,kBAAC,QAAD;IAAM,WAAU;cAAoB;IAAY,CAAA,EAChD,kBAAC,QAAD;IACE,WAAW,EACT,kKACA,EACD;IACD,eAAA;cAEC;IACI,CAAA,CACH;;EACc,CAAA"}
1
+ {"version":3,"file":"server-status-context-menu-icon-text.js","names":[],"sources":["../../../../src/components/features/controls/server-status-context-menu-icon-text.tsx"],"sourcesContent":["import { ContextMenuListItem } from \"#/components/features/context-menu/context-menu-list-item\";\nimport { dropdownMenuRowIconWrapperClassName } from \"#/utils/dropdown-classes\";\n\ninterface ServerStatusContextMenuIconTextProps {\n icon: React.ReactNode;\n text: string;\n onClick: (event: React.MouseEvent<HTMLButtonElement>) => void;\n testId?: string;\n}\n\nexport function ServerStatusContextMenuIconText({\n icon,\n text,\n onClick,\n testId,\n}: ServerStatusContextMenuIconTextProps) {\n return (\n <ContextMenuListItem testId={testId} onClick={onClick}>\n <div className=\"flex min-w-0 w-full items-center justify-between gap-2\">\n <span className=\"min-w-0 truncate\">{text}</span>\n <span className={dropdownMenuRowIconWrapperClassName} aria-hidden>\n {icon}\n </span>\n </div>\n </ContextMenuListItem>\n );\n}\n"],"mappings":";;;;AAUA,SAAgB,EAAgC,EAC9C,SACA,SACA,YACA,aACuC;AACvC,QACE,kBAAC,GAAD;EAA6B;EAAiB;YAC5C,kBAAC,OAAD;GAAK,WAAU;aAAf,CACE,kBAAC,QAAD;IAAM,WAAU;cAAoB;IAAY,CAAA,EAChD,kBAAC,QAAD;IAAM,WAAW;IAAqC,eAAA;cACnD;IACI,CAAA,CACH;;EACc,CAAA"}
@@ -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(`../../../utils/status.cjs`),i=require(`../../../ui/context-menu.cjs`),a=require(`../../../hooks/use-click-outside-element.cjs`),o=require(`../../../ui/divider.cjs`),s=require(`../../../icons/stop-circle.cjs`),c=require(`../../../icons/play-circle.cjs`),l=require(`./server-status-context-menu-icon-text.cjs`),u=require(`./server-status.cjs`);let d=require(`react/jsx-runtime`);function f({onClose:f,onStopServer:p,onStartServer:m,executionStatus:h,position:g=`top`,className:_=``,isPausing:v=!1}){let{t:y}=e.useTranslation(`openhands`),b=a.useClickOutsideElement(f),x=r.isExecutionActive(h),S=r.isExecutionPaused(h),C=x||S;return(0,d.jsxs)(i.ContextMenu,{ref:b,testId:`server-status-context-menu`,position:g,alignment:`left`,size:`default`,className:n.cn(`left-2 w-fit min-w-42`,_),children:[(0,d.jsx)(u.default,{executionStatus:h,isPausing:v,className:`pl-0 pr-2 py-1`}),C&&(0,d.jsxs)(d.Fragment,{children:[(0,d.jsx)(o.Divider,{inset:`menu`}),x&&p&&(0,d.jsx)(l.ServerStatusContextMenuIconText,{icon:(0,d.jsx)(s.default,{width:18,height:18}),text:y(t.I18nKey.COMMON$STOP_RUNTIME),onClick:p,testId:`stop-server-button`}),S&&m&&(0,d.jsx)(l.ServerStatusContextMenuIconText,{icon:(0,d.jsx)(c.default,{width:18,height:18}),text:y(t.I18nKey.COMMON$START_RUNTIME),onClick:m,testId:`start-server-button`})]})]})}exports.ServerStatusContextMenu=f;
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/status.cjs`),r=require(`../../../utils/utils.cjs`),i=require(`../../../ui/context-menu.cjs`),a=require(`../../../hooks/use-click-outside-element.cjs`),o=require(`../../../ui/divider.cjs`),s=require(`../../../icons/stop-circle.cjs`),c=require(`../../../icons/play-circle.cjs`),l=require(`./server-status-context-menu-icon-text.cjs`),u=require(`./server-status.cjs`);let d=require(`react/jsx-runtime`);function f({onClose:f,onStopServer:p,onStartServer:m,executionStatus:h,position:g=`top`,className:_=``,isPausing:v=!1}){let{t:y}=e.useTranslation(`openhands`),b=a.useClickOutsideElement(f),x=n.isExecutionActive(h),S=n.isExecutionPaused(h),C=x||S;return(0,d.jsxs)(i.ContextMenu,{ref:b,testId:`server-status-context-menu`,position:g,alignment:`left`,size:`default`,className:r.cn(`left-2 w-fit min-w-42`,_),children:[(0,d.jsx)(u.default,{executionStatus:h,isPausing:v,className:`pl-0 pr-2 py-1`}),C&&(0,d.jsxs)(d.Fragment,{children:[(0,d.jsx)(o.Divider,{inset:`menu`}),x&&p&&(0,d.jsx)(l.ServerStatusContextMenuIconText,{icon:(0,d.jsx)(s.default,{width:18,height:18}),text:y(t.I18nKey.COMMON$STOP_RUNTIME),onClick:p,testId:`stop-server-button`}),S&&m&&(0,d.jsx)(l.ServerStatusContextMenuIconText,{icon:(0,d.jsx)(c.default,{width:18,height:18}),text:y(t.I18nKey.COMMON$START_RUNTIME),onClick:m,testId:`start-server-button`})]})]})}exports.ServerStatusContextMenu=f;
2
2
  //# sourceMappingURL=server-status-context-menu.cjs.map
@@ -1,7 +1,7 @@
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
- import { cn as n } from "../../../utils/utils.js";
4
- import { isExecutionActive as r, isExecutionPaused as i } from "../../../utils/status.js";
3
+ import { isExecutionActive as n, isExecutionPaused as r } from "../../../utils/status.js";
4
+ import { cn as i } from "../../../utils/utils.js";
5
5
  import { ContextMenu as a } from "../../../ui/context-menu.js";
6
6
  import { useClickOutsideElement as o } from "../../../hooks/use-click-outside-element.js";
7
7
  import { Divider as s } from "../../../ui/divider.js";
@@ -12,14 +12,14 @@ import d from "./server-status.js";
12
12
  import { Fragment as f, jsx as p, jsxs as m } from "react/jsx-runtime";
13
13
  //#region src/components/features/controls/server-status-context-menu.tsx
14
14
  function h({ onClose: h, onStopServer: g, onStartServer: _, executionStatus: v, position: y = "top", className: b = "", isPausing: x = !1 }) {
15
- let { t: S } = e("openhands"), C = o(h), w = r(v), T = i(v), E = w || T;
15
+ let { t: S } = e("openhands"), C = o(h), w = n(v), T = r(v), E = w || T;
16
16
  return /* @__PURE__ */ m(a, {
17
17
  ref: C,
18
18
  testId: "server-status-context-menu",
19
19
  position: y,
20
20
  alignment: "left",
21
21
  size: "default",
22
- className: n("left-2 w-fit min-w-42", b),
22
+ className: i("left-2 w-fit min-w-42", b),
23
23
  children: [/* @__PURE__ */ p(d, {
24
24
  executionStatus: v,
25
25
  isPausing: x,
@@ -1,2 +1,2 @@
1
- require(`../../../_virtual/_rolldown/runtime.cjs`);const e=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),t=require(`../../../types/agent-state.cjs`),n=require(`../../../utils/utils.cjs`),r=require(`../../../stores/error-message-store.cjs`),i=require(`../../../hooks/use-agent-state.cjs`),a=require(`../../../hooks/query/use-task-polling.cjs`),o=require(`../../../utils/status.cjs`),s=require(`../../../icons/debug-stackframe-dot.cjs`);let c=require(`react/jsx-runtime`);function l({className:l=``,executionStatus:u,isPausing:d=!1}){let{curAgentState:f}=i.useAgentState(),{isTask:p,taskStatus:m,taskDetail:h}=a.useTaskPolling(),{t:g}=e.useTranslation(`openhands`),{errorMessage:_}=r.useErrorMessageStore(),v=f===t.AgentState.LOADING||f===t.AgentState.INIT,y=o.isExecutionErrored(u)||o.isExecutionPaused(u),b=n.getStatusColor({isPausing:d,isTask:p,taskStatus:m,isStartingStatus:v,isStopStatus:y,curAgentState:f}),x=n.getStatusText({isPausing:d,isTask:p,taskStatus:m,taskDetail:h,isStartingStatus:v,isStopStatus:y,curAgentState:f,errorMessage:_,t:g});return(0,c.jsx)(`div`,{className:l,"data-testid":`server-status`,children:(0,c.jsxs)(`div`,{className:`flex items-center`,children:[(0,c.jsx)(s.default,{className:`w-6 h-6 shrink-0`,color:b}),(0,c.jsx)(`span`,{className:`text-[13px] text-white font-normal`,children:x})]})})}exports.default=l;
1
+ require(`../../../_virtual/_rolldown/runtime.cjs`);const e=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),t=require(`../../../types/agent-state.cjs`),n=require(`../../../utils/status.cjs`),r=require(`../../../utils/utils.cjs`),i=require(`../../../stores/error-message-store.cjs`),a=require(`../../../hooks/use-agent-state.cjs`),o=require(`../../../hooks/query/use-task-polling.cjs`),s=require(`../../../icons/debug-stackframe-dot.cjs`);let c=require(`react/jsx-runtime`);function l({className:l=``,executionStatus:u,isPausing:d=!1}){let{curAgentState:f}=a.useAgentState(),{isTask:p,taskStatus:m,taskDetail:h}=o.useTaskPolling(),{t:g}=e.useTranslation(`openhands`),{errorMessage:_}=i.useErrorMessageStore(),v=f===t.AgentState.LOADING||f===t.AgentState.INIT,y=n.isExecutionErrored(u)||n.isExecutionPaused(u),b=r.getStatusColor({isPausing:d,isTask:p,taskStatus:m,isStartingStatus:v,isStopStatus:y,curAgentState:f}),x=r.getStatusText({isPausing:d,isTask:p,taskStatus:m,taskDetail:h,isStartingStatus:v,isStopStatus:y,curAgentState:f,errorMessage:_,t:g});return(0,c.jsx)(`div`,{className:l,"data-testid":`server-status`,children:(0,c.jsxs)(`div`,{className:`flex items-center`,children:[(0,c.jsx)(s.default,{className:`w-6 h-6 shrink-0`,color:b}),(0,c.jsx)(`span`,{className:`text-[13px] text-white font-normal`,children:x})]})})}exports.default=l;
2
2
  //# sourceMappingURL=server-status.cjs.map
@@ -1,22 +1,22 @@
1
1
  import { useTranslation as e } from "../../../node_modules/react-i18next/dist/es/useTranslation.js";
2
2
  import { AgentState as t } from "../../../types/agent-state.js";
3
- import { getStatusColor as n, getStatusText as r } from "../../../utils/utils.js";
4
- import { useErrorMessageStore as i } from "../../../stores/error-message-store.js";
5
- import { useAgentState as a } from "../../../hooks/use-agent-state.js";
6
- import { useTaskPolling as o } from "../../../hooks/query/use-task-polling.js";
7
- import { isExecutionErrored as s, isExecutionPaused as c } from "../../../utils/status.js";
3
+ import { isExecutionErrored as n, isExecutionPaused as r } from "../../../utils/status.js";
4
+ import { getStatusColor as i, getStatusText as a } from "../../../utils/utils.js";
5
+ import { useErrorMessageStore as o } from "../../../stores/error-message-store.js";
6
+ import { useAgentState as s } from "../../../hooks/use-agent-state.js";
7
+ import { useTaskPolling as c } from "../../../hooks/query/use-task-polling.js";
8
8
  import l from "../../../icons/debug-stackframe-dot.js";
9
9
  import { jsx as u, jsxs as d } from "react/jsx-runtime";
10
10
  //#region src/components/features/controls/server-status.tsx
11
11
  function f({ className: f = "", executionStatus: p, isPausing: m = !1 }) {
12
- let { curAgentState: h } = a(), { isTask: g, taskStatus: _, taskDetail: v } = o(), { t: y } = e("openhands"), { errorMessage: b } = i(), x = h === t.LOADING || h === t.INIT, S = s(p) || c(p), C = n({
12
+ let { curAgentState: h } = s(), { isTask: g, taskStatus: _, taskDetail: v } = c(), { t: y } = e("openhands"), { errorMessage: b } = o(), x = h === t.LOADING || h === t.INIT, S = n(p) || r(p), C = i({
13
13
  isPausing: m,
14
14
  isTask: g,
15
15
  taskStatus: _,
16
16
  isStartingStatus: x,
17
17
  isStopStatus: S,
18
18
  curAgentState: h
19
- }), w = r({
19
+ }), w = a({
20
20
  isPausing: m,
21
21
  isTask: g,
22
22
  taskStatus: _,