@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.
- package/README.md +24 -7
- package/README.windows.md +27 -0
- package/bin/agent-canvas.mjs +26 -3
- package/build/assets/{QueryClientProvider-CkGuhXg-.js → QueryClientProvider-Cnr-Yl3j.js} +1 -1
- package/build/assets/{Trans-Cvm_-SMi.js → Trans-4jmk54WC.js} +1 -1
- package/build/assets/acp-providers-CPdgcp13.js +1 -0
- package/build/assets/{acp-route-guard-B2yoBZ_4.js → acp-route-guard-BoVmCn0e.js} +1 -1
- package/build/assets/active-backend-context-Beu-LZL-.js +1 -0
- package/build/assets/add-backend-modal-BheqYXHK.js +1 -0
- package/build/assets/agent-server-client-options-HEOwGVIU.js +1 -0
- package/build/assets/agent-server-compatibility-CdI3N7dr.js +1 -0
- package/build/assets/agent-server-conversation-service.api-CORdqJZg.js +5 -0
- package/build/assets/{agent-settings-CnGSCmK8.js → agent-settings-UFvcGjoI.js} +1 -1
- package/build/assets/{alert-banner-DtzAX654.js → alert-banner-DFnn_lC6.js} +1 -1
- package/build/assets/{analytics-consent-form-modal-CHZ3I37v.js → analytics-consent-form-modal-CVNugqzu.js} +1 -1
- package/build/assets/api-key-entry-screen-M6su2VSf.js +1 -0
- package/build/assets/{app-settings-Db9ITeJH.js → app-settings-BlvBhBdc.js} +1 -1
- package/build/assets/automation-detail-BWrQk4Oa.js +1 -0
- package/build/assets/automations-list-ux9KvYsU.js +1 -0
- package/build/assets/back-nav-button-7dQJ2k3O.js +1 -0
- package/build/assets/backend-form-modal-CDnEYjaU.js +1 -0
- package/build/assets/{backend-synced-settings-badge-Dc6c7GT4.js → backend-synced-settings-badge-BTIj-Ffq.js} +1 -1
- package/build/assets/base-modal-C2oy2EBG.js +1 -0
- package/build/assets/brand-button-DJ_S16rO.js +1 -0
- package/build/assets/{browser-D810xUYt.js → browser-CGM-k-sH.js} +2 -2
- package/build/assets/browser-store-DAsixKdU.js +1 -0
- package/build/assets/{browser-tab-B-aIqXRl.js → browser-tab-dvSPdvkm.js} +1 -1
- package/build/assets/{checkmark-DL7acQA7.js → checkmark-Dus0b6jt.js} +1 -1
- package/build/assets/{chevron-left-small-CVWf8TI6.js → chevron-left-small-_uvG7RVM.js} +1 -1
- package/build/assets/{circle-plus-check-toggle-P7ZZToV4.js → circle-plus-check-toggle-DKS8MAVV.js} +1 -1
- package/build/assets/{close-B5LROHR3.js → close-BU5iTc66.js} +1 -1
- package/build/assets/code-tag-BzyqOtPD.js +1 -0
- package/build/assets/combobox-caret-BJC7XJsz.js +1 -0
- package/build/assets/{command-store-DFN_17p1.js → command-store-CE1weJy8.js} +1 -1
- package/build/assets/{condenser-settings-wnEKhBof.js → condenser-settings-BolbDvm5.js} +1 -1
- package/build/assets/{confirmation-modal-Dau3w_sa.js → confirmation-modal-B5Ca6qFE.js} +1 -1
- package/build/assets/context-menu-list-item-7tAcm2c3.js +1 -0
- package/build/assets/conversation-D0N4dw_p.js +19 -0
- package/build/assets/conversation-DhRJuZLG.js +1 -0
- package/build/assets/conversation-panel-CNqHbS_Z.js +1 -0
- package/build/assets/conversation-service.api-BsJy6uuL.js +1 -0
- package/build/assets/conversation-state-store-D-w0uurj.js +1 -0
- package/build/assets/conversation-store-CC-isCnP.js +1 -0
- package/build/assets/{conversation-tab-empty-state-DyssnnWa.js → conversation-tab-empty-state-CStQLPVW.js} +1 -1
- package/build/assets/conversation-websocket-context-DvHgx_FE.js +3 -0
- package/build/assets/{copy-DYgmUdIw.js → copy-Chg-sFu3.js} +1 -1
- package/build/assets/{custom-toast-handlers-C-SZFmto.js → custom-toast-handlers-ufGJ6_Rc.js} +1 -1
- package/build/assets/declaration-CR6HMp29.js +1 -0
- package/build/assets/{device-verify-DqDlphsG.js → device-verify-C6mj28zv.js} +1 -1
- package/build/assets/dist-DNeWJ2bh.js +1 -0
- package/build/assets/dropdown-classes-BsVmxlNG.js +1 -0
- package/build/assets/edit-automation-modal-BpX-t-HD.js +1 -0
- package/build/assets/ellipsis-button-Vh5MvRZa.js +1 -0
- package/build/assets/entry.client-Ck9rQCg-.js +2 -0
- package/build/assets/enum-filter-dropdown-5JeF2RLb.js +1 -0
- package/build/assets/{environment-switch-overlay-XL8yCGP6.js → environment-switch-overlay-Tf_BIfeR.js} +1 -1
- package/build/assets/extensions-hub-CE9QOb5n.js +1 -0
- package/build/assets/{extensions-navigation-BYR8Giqq.js → extensions-navigation-DSLGNGbS.js} +1 -1
- package/build/assets/file-BTY6Gyy9.js +1 -0
- package/build/assets/files-tab-cL668j1I.js +1 -0
- package/build/assets/files-tab-store-m0ARqX_E.js +1 -0
- package/build/assets/{folder-ZZJVGgd7.js → folder-D1T2W1cj.js} +1 -1
- package/build/assets/git-control-bar-branch-button-DtIrOrie.js +27 -0
- package/build/assets/git-provider-icon-CHdGBdU2.js +1 -0
- package/build/assets/globe-Bzj_0oXT.js +1 -0
- package/build/assets/home-Cz2Veg56.js +1 -0
- package/build/assets/{i18n-CTohRuoO.js → i18n-DET2iOyh.js} +1 -1
- package/build/assets/install-server-modal-B9nXCS3u.js +1 -0
- package/build/assets/launch-CWz0dm4o.js +1 -0
- package/build/assets/{lesson-plan-dH5Bj0pN.js → lesson-plan-duSsqWVs.js} +1 -1
- package/build/assets/link-external-DGxVm4Ps.js +1 -0
- package/build/assets/{llm-client-DaH1TuyR.js → llm-client-CYEaUjGx.js} +1 -1
- package/build/assets/llm-settings-DFkXHuvT.js +1 -0
- package/build/assets/llm-settings-DhrdCXqX.js +1 -0
- package/build/assets/{loading-spinner-BPtYORNK.js → loading-spinner-5GT9q1xy.js} +1 -1
- package/build/assets/manage-backends-modal-DpBD_vR9.js +1 -0
- package/build/assets/manage-workspaces-modal-CtRbxREx.js +1 -0
- package/build/assets/manifest-eed90ff5.js +1 -0
- package/build/assets/{markdown-renderer-DMzf2i4x.js → markdown-renderer-B3IAVfv4.js} +1 -1
- package/build/assets/mcp-BUe7kiYM.js +9 -0
- package/build/assets/messages-dqp_KYyl.js +36 -0
- package/build/assets/{modal-backdrop-BAbgYsqB.js → modal-backdrop-RfNCrSpK.js} +1 -1
- package/build/assets/{modal-body-BI6Ru2Qr.js → modal-body-aoa2fx5W.js} +1 -1
- package/build/assets/modal-classes-6YqcqA6y.js +1 -0
- package/build/assets/{modal-close-button-t1Gh3qmL.js → modal-close-button-CtWOUMmw.js} +1 -1
- package/build/assets/{model-selector-SM9IUz-q.js → model-selector-BvSTrkhT.js} +1 -1
- package/build/assets/{navigation-context-D0YWpT8d.js → navigation-context-BdKYH32C.js} +1 -1
- package/build/assets/{navigation-link-Cn7KP3c5.js → navigation-link-U4vY9i_C.js} +1 -1
- package/build/assets/{openhands-logo-CnrF6LKb.js → openhands-logo-CCo0wJZX.js} +1 -1
- package/build/assets/{option-service.api-KvY_mZMY.js → option-service.api-DmNVxAvS.js} +1 -1
- package/build/assets/{organization-service.api-DzYTHTYC.js → organization-service.api-DbnougaQ.js} +1 -1
- package/build/assets/{path-utils-C3bQf6lJ.js → path-utils-onx24uF5.js} +1 -1
- package/build/assets/{plan-components-atxXCF0R.js → plan-components-CRDMQzsS.js} +1 -1
- package/build/assets/{planner-tab-BlrCpv-7.js → planner-tab-CmIjLz7q.js} +1 -1
- package/build/assets/{profiles-client-D6IkTJof.js → profiles-client-fEmgWkCW.js} +1 -1
- package/build/assets/{providers-Bx6EfrzZ.js → providers-CbD7fiic.js} +1 -1
- package/build/assets/proxy-BAdHH8QB.js +1 -0
- package/build/assets/{query-client-config-B7u9asM0.js → query-client-config-CRnGSujB.js} +1 -1
- package/build/assets/{recommended-automations-launcher-BQChv2rc.js → recommended-automations-launcher-uTyODuzB.js} +3 -3
- package/build/assets/{root-BgEbw3S0.js → root-DmjpFpTu.js} +2 -2
- package/build/assets/root-Z2VHU4R3.css +1 -0
- package/build/assets/root-layout-DejMsKhy.js +2 -0
- package/build/assets/{sdk-section-page-DOIKvwSL.js → sdk-section-page-BgDlMhcq.js} +1 -1
- package/build/assets/{sdk-settings-schema-DsUf9wu1.js → sdk-settings-schema-CLmJ9sho.js} +1 -1
- package/build/assets/{search-27Owlc3A.js → search-SuJctqNJ.js} +1 -1
- package/build/assets/secrets-service-B7CxNinp.js +1 -0
- package/build/assets/secrets-settings-yK7CqIpm.js +1 -0
- package/build/assets/{server-client-DyAQ3NZ_.js → server-client-Kh4QSwDJ.js} +1 -1
- package/build/assets/{settings-BYkVX7vW.js → settings-DN5PpgRD.js} +1 -1
- package/build/assets/{settings-dropdown-input-BJYvGdg-.js → settings-dropdown-input-BtoovFre.js} +1 -1
- package/build/assets/{settings-gear-C77PgE_O.js → settings-gear-Dd8K2_8B.js} +1 -1
- package/build/assets/settings-index-DKC8IY1P.js +1 -0
- package/build/assets/{settings-input-Bn7F5C75.js → settings-input-CehsXnb3.js} +1 -1
- package/build/assets/settings-list-classes-E3v_f6QG.js +1 -0
- package/build/assets/settings-modal-DJ4kGzUx.js +1 -0
- package/build/assets/{settings-section-header-context-BgZe5YkE.js → settings-section-header-context-DewwJ0-F.js} +1 -1
- package/build/assets/settings-service.api-C3rxTtPj.js +1 -0
- package/build/assets/{settings-switch-BeIKrWms.js → settings-switch-BiBuS3xa.js} +1 -1
- package/build/assets/{settings-utils-B6Nl07io.js → settings-utils-DY04tWG1.js} +1 -1
- package/build/assets/{shared-conversation-AMyqXvpk.js → shared-conversation-h9YnBtCU.js} +1 -1
- package/build/assets/sidebar-mobile-menu-toggle-D0-AvsnT.js +1 -0
- package/build/assets/{sidebar-nav-link-BGjiJq-4.js → sidebar-nav-link-OhIeFyna.js} +1 -1
- package/build/assets/{sidebar-store-Uy3v0AOV.js → sidebar-store-DnQAJAE5.js} +1 -1
- package/build/assets/{skill-card-pill-row-DF1axQCG.js → skill-card-pill-row-BW9qvhoK.js} +1 -1
- package/build/assets/{skills-ChIKZPK4.js → skills-0GRKX5Xj.js} +1 -1
- package/build/assets/{skills-plugins-CcI_19lM.js → skills-plugins-DNcsNF88.js} +1 -1
- package/build/assets/skills-settings-7liFiSY6.js +2 -0
- package/build/assets/{styled-tooltip-CBzrri6o.js → styled-tooltip-hdfMXPQC.js} +1 -1
- package/build/assets/{switch-skeleton-DnC9wLp7.js → switch-skeleton-DSKqSx2A.js} +1 -1
- package/build/assets/{task-list-tab-DUJn1sgz.js → task-list-tab-DT6_zfUs.js} +1 -1
- package/build/assets/{terminal-DgQk1Ay6.js → terminal-CDhQGDua.js} +2 -2
- package/build/assets/{terminal-RmuaSdhJ.js → terminal-CPYWdo4j.js} +1 -1
- package/build/assets/{toggle-switch-Pvyp2RAN.js → toggle-switch-T2v6sJ6l.js} +1 -1
- package/build/assets/{typography-gpuWmrQO.js → typography-BDgnT7Yp.js} +1 -1
- package/build/assets/{u-check-circle-IUIfACQQ.js → u-check-circle-DOauqQKb.js} +1 -1
- package/build/assets/{u-check-circle-half-C1YxB6py.js → u-check-circle-half-steSK_JB.js} +1 -1
- package/build/assets/{u-circuit-BmVikJHu.js → u-circuit-x3ExjBbU.js} +1 -1
- package/build/assets/{u-edit-CFvXHqZk.js → u-edit-BbrptMCa.js} +1 -1
- package/build/assets/{use-active-conversation-BEFNwnFk.js → use-active-conversation-DHGcmjCK.js} +1 -1
- package/build/assets/use-agent-settings-schema-CLoTOSJI.js +1 -0
- package/build/assets/{use-agent-state-Bkrd1FZq.js → use-agent-state-PKrUPMJ3.js} +1 -1
- package/build/assets/{use-cloud-current-user-id-CvkXFnTT.js → use-cloud-current-user-id-Ddr75hEz.js} +1 -1
- package/build/assets/{use-config-Co1O8-Ey.js → use-config-OIMQLQ2s.js} +1 -1
- package/build/assets/{use-create-conversation-CEgXpkfH.js → use-create-conversation-Bszyp13O.js} +1 -1
- package/build/assets/{use-event-store-BT_gV3ut.js → use-event-store-BomO7ywK.js} +1 -1
- package/build/assets/{use-get-secrets-DuhdIA59.js → use-get-secrets-8Jby8ele.js} +1 -1
- package/build/assets/{use-handle-plan-click-Ckkm5eIY.js → use-handle-plan-click-CohJPvvW.js} +1 -1
- package/build/assets/use-is-authed-dw2026rR.js +1 -0
- package/build/assets/{use-is-creating-conversation-BZ5hB_Bg.js → use-is-creating-conversation-DX2qSlfL.js} +1 -1
- package/build/assets/{use-launch-skill-in-chat-fNN_xGZG.js → use-launch-skill-in-chat-sQNEOLGD.js} +1 -1
- package/build/assets/use-llm-profiles-C861aFAq.js +1 -0
- package/build/assets/use-runtime-is-ready-Do2h_hRl.js +1 -0
- package/build/assets/{use-save-settings-VUrj_QNG.js → use-save-settings-DkAOEfD9.js} +1 -1
- package/build/assets/use-settings-D5hbTS9t.js +1 -0
- package/build/assets/{use-settings-nav-items-1ZvovKSr.js → use-settings-nav-items-BcSbo02d.js} +1 -1
- package/build/assets/{use-skills-DAMLFjKU.js → use-skills-D7PS0fH0.js} +1 -1
- package/build/assets/{use-task-list-CLJbuJgM.js → use-task-list-CsT10CBb.js} +1 -1
- package/build/assets/{use-unified-vscode-url-DdSRw-6P.js → use-unified-vscode-url-DEoe-NRI.js} +1 -1
- package/build/assets/use-user-conversation-Cs5H1pUF.js +1 -0
- package/build/assets/{useMutation-DqrumCWD.js → useMutation-GSSKKebK.js} +1 -1
- package/build/assets/{useTranslation-DCOdSSMl.js → useTranslation-B6voJV4y.js} +1 -1
- package/build/assets/utils-DCVfKFRt.js +1 -0
- package/build/assets/{vendor~browser-BNjNhjFU.js → vendor~browser-BrOJLj3y.js} +1 -1
- package/build/assets/vendor~conversation-panel~conversation-C9o-K1hW.js +1 -0
- package/build/assets/vendor~conversation-panel~conversation~index-RXYdJYxU.js +1 -0
- 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
- 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
- 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
- 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
- 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
- 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
- package/build/assets/vendor~home~mcp~automations-list-CZSK-lT2.js +1 -0
- 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
- 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
- package/build/assets/{vendor~root-layout~home~conversation-panel~conversation-DjAjXS5J.js → vendor~root-layout~home~conversation-panel~conversation-B5WNMnt4.js} +1 -1
- package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~i4kjfqhl-CbAhtEMv.js +1 -0
- package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-6Rm8U_Sr.js +9 -0
- 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
- 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
- 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
- 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
- package/build/assets/{verification-settings-CsbvQcYS.js → verification-settings-Dlt8pINd.js} +1 -1
- package/build/assets/{vscode-tab-DjNArCgY.js → vscode-tab-DgepcYtF.js} +1 -1
- package/build/assets/{waiting-for-runtime-message-CntjExbU.js → waiting-for-runtime-message-CdK3btDZ.js} +1 -1
- package/build/assets/{x-mark-CrpjscNc.js → x-mark-BrkSPIiT.js} +1 -1
- package/build/index.html +4 -4
- package/build/locales/ar/openhands.json +20 -2
- package/build/locales/ca/openhands.json +20 -2
- package/build/locales/de/openhands.json +20 -2
- package/build/locales/en/openhands.json +20 -2
- package/build/locales/es/openhands.json +20 -2
- package/build/locales/fr/openhands.json +20 -2
- package/build/locales/it/openhands.json +20 -2
- package/build/locales/ja/openhands.json +20 -2
- package/build/locales/ko-KR/openhands.json +20 -2
- package/build/locales/no/openhands.json +20 -2
- package/build/locales/pt/openhands.json +20 -2
- package/build/locales/tr/openhands.json +20 -2
- package/build/locales/uk/openhands.json +20 -2
- package/build/locales/zh-CN/openhands.json +20 -2
- package/build/locales/zh-TW/openhands.json +20 -2
- package/dist/api/acp-service/acp-service.api.d.ts +18 -0
- package/dist/api/agent-server-adapter.cjs +3 -3
- package/dist/api/agent-server-adapter.cjs.map +1 -1
- package/dist/api/agent-server-adapter.js +54 -55
- package/dist/api/agent-server-adapter.js.map +1 -1
- package/dist/api/agent-server-client-options.cjs +1 -1
- package/dist/api/agent-server-client-options.cjs.map +1 -1
- package/dist/api/agent-server-client-options.d.ts +4 -0
- package/dist/api/agent-server-client-options.js +18 -12
- package/dist/api/agent-server-client-options.js.map +1 -1
- package/dist/api/agent-server-compatibility.cjs +1 -1
- package/dist/api/agent-server-compatibility.cjs.map +1 -1
- package/dist/api/agent-server-compatibility.d.ts +1 -1
- package/dist/api/agent-server-compatibility.js +30 -25
- package/dist/api/agent-server-compatibility.js.map +1 -1
- package/dist/api/agent-server-config.cjs +1 -1
- package/dist/api/agent-server-config.cjs.map +1 -1
- package/dist/api/agent-server-config.d.ts +1 -51
- package/dist/api/agent-server-config.js +20 -70
- package/dist/api/agent-server-config.js.map +1 -1
- package/dist/api/backend-registry/active-store.cjs +1 -1
- package/dist/api/backend-registry/active-store.cjs.map +1 -1
- package/dist/api/backend-registry/active-store.d.ts +11 -5
- package/dist/api/backend-registry/active-store.js +36 -27
- package/dist/api/backend-registry/active-store.js.map +1 -1
- package/dist/api/backend-registry/auth.cjs +1 -1
- package/dist/api/backend-registry/auth.cjs.map +1 -1
- package/dist/api/backend-registry/auth.js +3 -9
- package/dist/api/backend-registry/auth.js.map +1 -1
- package/dist/api/backend-registry/default-backend.cjs +1 -1
- package/dist/api/backend-registry/default-backend.cjs.map +1 -1
- package/dist/api/backend-registry/default-backend.d.ts +9 -16
- package/dist/api/backend-registry/default-backend.js +5 -4
- package/dist/api/backend-registry/default-backend.js.map +1 -1
- package/dist/api/backend-registry/storage.cjs +1 -1
- package/dist/api/backend-registry/storage.cjs.map +1 -1
- package/dist/api/backend-registry/storage.js +67 -34
- package/dist/api/backend-registry/storage.js.map +1 -1
- package/dist/api/cloud/conversation-service.api.cjs.map +1 -1
- package/dist/api/cloud/conversation-service.api.d.ts +8 -13
- package/dist/api/cloud/conversation-service.api.js.map +1 -1
- package/dist/api/cloud/organization-service.api.cjs.map +1 -1
- package/dist/api/cloud/organization-service.api.d.ts +1 -2
- package/dist/api/cloud/organization-service.api.js.map +1 -1
- package/dist/api/cloud/proxy.cjs +1 -1
- package/dist/api/cloud/proxy.cjs.map +1 -1
- package/dist/api/cloud/proxy.d.ts +6 -6
- package/dist/api/cloud/proxy.js +33 -24
- package/dist/api/cloud/proxy.js.map +1 -1
- package/dist/api/cloud/sandbox-service.api.cjs.map +1 -1
- package/dist/api/cloud/sandbox-service.api.d.ts +3 -3
- package/dist/api/cloud/sandbox-service.api.js.map +1 -1
- package/dist/api/cloud/secrets-service.api.cjs.map +1 -1
- package/dist/api/cloud/secrets-service.api.d.ts +3 -4
- package/dist/api/cloud/secrets-service.api.js.map +1 -1
- package/dist/api/cloud/settings-service.api.cjs +1 -1
- package/dist/api/cloud/settings-service.api.cjs.map +1 -1
- package/dist/api/cloud/settings-service.api.js +5 -1
- package/dist/api/cloud/settings-service.api.js.map +1 -1
- package/dist/api/cloud/skills-service.api.cjs.map +1 -1
- package/dist/api/cloud/skills-service.api.d.ts +5 -5
- package/dist/api/cloud/skills-service.api.js.map +1 -1
- package/dist/api/conversation-service/agent-server-conversation-service.api.cjs +1 -1
- package/dist/api/conversation-service/agent-server-conversation-service.api.cjs.map +1 -1
- package/dist/api/conversation-service/agent-server-conversation-service.api.js +115 -108
- package/dist/api/conversation-service/agent-server-conversation-service.api.js.map +1 -1
- package/dist/api/device-flow-client.cjs +1 -1
- package/dist/api/device-flow-client.cjs.map +1 -1
- package/dist/api/device-flow-client.d.ts +3 -5
- package/dist/api/device-flow-client.js +55 -66
- package/dist/api/device-flow-client.js.map +1 -1
- package/dist/api/event-service/event-service.api.cjs +1 -1
- package/dist/api/event-service/event-service.api.cjs.map +1 -1
- package/dist/api/event-service/event-service.api.d.ts +3 -3
- package/dist/api/event-service/event-service.api.js +17 -17
- package/dist/api/event-service/event-service.api.js.map +1 -1
- package/dist/api/git-service/agent-server-git-service.api.cjs +1 -1
- package/dist/api/git-service/agent-server-git-service.api.js +11 -11
- package/dist/api/runtime-service/agent-server-runtime-service.cjs +1 -1
- package/dist/api/runtime-service/agent-server-runtime-service.js +6 -6
- package/dist/components/conversation-events/chat/event-content-helpers/get-action-content.cjs +2 -2
- package/dist/components/conversation-events/chat/event-content-helpers/get-action-content.js +10 -10
- package/dist/components/conversation-events/chat/event-content-helpers/get-observation-result.cjs.map +1 -1
- package/dist/components/conversation-events/chat/event-content-helpers/get-observation-result.d.ts +5 -5
- package/dist/components/conversation-events/chat/event-content-helpers/get-observation-result.js.map +1 -1
- package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.cjs +1 -1
- package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.cjs.map +1 -1
- package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.js +1 -1
- package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.js.map +1 -1
- package/dist/components/features/automations/automation-action-button-classes.d.ts +2 -2
- package/dist/components/features/backends/backend-form-modal.cjs +1 -1
- package/dist/components/features/backends/backend-form-modal.cjs.map +1 -1
- package/dist/components/features/backends/backend-form-modal.d.ts +1 -0
- package/dist/components/features/backends/backend-form-modal.js +203 -140
- package/dist/components/features/backends/backend-form-modal.js.map +1 -1
- package/dist/components/features/backends/backend-selector.cjs +1 -1
- package/dist/components/features/backends/backend-selector.cjs.map +1 -1
- package/dist/components/features/backends/backend-selector.js +117 -105
- package/dist/components/features/backends/backend-selector.js.map +1 -1
- package/dist/components/features/backends/backend-status-dot.cjs +1 -1
- package/dist/components/features/backends/backend-status-dot.cjs.map +1 -1
- package/dist/components/features/backends/backend-status-dot.d.ts +1 -1
- package/dist/components/features/backends/backend-status-dot.js +1 -1
- package/dist/components/features/backends/backend-status-dot.js.map +1 -1
- package/dist/components/features/backends/manage-backends-modal.cjs +1 -1
- package/dist/components/features/backends/manage-backends-modal.cjs.map +1 -1
- package/dist/components/features/backends/manage-backends-modal.js +81 -70
- package/dist/components/features/backends/manage-backends-modal.js.map +1 -1
- package/dist/components/features/chat/change-agent-button.cjs +1 -1
- package/dist/components/features/chat/change-agent-button.cjs.map +1 -1
- package/dist/components/features/chat/change-agent-button.js +59 -57
- package/dist/components/features/chat/change-agent-button.js.map +1 -1
- package/dist/components/features/chat/change-agent-context-menu.cjs +1 -1
- package/dist/components/features/chat/change-agent-context-menu.cjs.map +1 -1
- package/dist/components/features/chat/change-agent-context-menu.d.ts +3 -1
- package/dist/components/features/chat/change-agent-context-menu.js +30 -25
- package/dist/components/features/chat/change-agent-context-menu.js.map +1 -1
- package/dist/components/features/chat/chat-add-file-button.cjs +1 -1
- package/dist/components/features/chat/chat-add-file-button.cjs.map +1 -1
- package/dist/components/features/chat/chat-add-file-button.js +39 -38
- package/dist/components/features/chat/chat-add-file-button.js.map +1 -1
- package/dist/components/features/chat/chat-message.cjs +1 -1
- package/dist/components/features/chat/chat-message.cjs.map +1 -1
- package/dist/components/features/chat/chat-message.d.ts +2 -1
- package/dist/components/features/chat/chat-message.js +185 -57
- package/dist/components/features/chat/chat-message.js.map +1 -1
- package/dist/components/features/chat/components/chat-input-actions.cjs +1 -1
- package/dist/components/features/chat/components/chat-input-actions.cjs.map +1 -1
- package/dist/components/features/chat/components/chat-input-actions.js +113 -113
- package/dist/components/features/chat/components/chat-input-actions.js.map +1 -1
- package/dist/components/features/chat/components/chat-input-model.cjs +1 -1
- package/dist/components/features/chat/components/chat-input-model.cjs.map +1 -1
- package/dist/components/features/chat/components/chat-input-model.js +52 -51
- package/dist/components/features/chat/components/chat-input-model.js.map +1 -1
- package/dist/components/features/chat/components/slash-command-menu.cjs +2 -2
- package/dist/components/features/chat/components/slash-command-menu.cjs.map +1 -1
- package/dist/components/features/chat/components/slash-command-menu.js +38 -34
- package/dist/components/features/chat/components/slash-command-menu.js.map +1 -1
- package/dist/components/features/chat/git-control-bar-pr-button.cjs +1 -1
- package/dist/components/features/chat/git-control-bar-pr-button.cjs.map +1 -1
- package/dist/components/features/chat/git-control-bar-pr-button.js +16 -15
- package/dist/components/features/chat/git-control-bar-pr-button.js.map +1 -1
- package/dist/components/features/chat/git-control-bar-pull-button.cjs +1 -1
- package/dist/components/features/chat/git-control-bar-pull-button.cjs.map +1 -1
- package/dist/components/features/chat/git-control-bar-pull-button.js +16 -15
- package/dist/components/features/chat/git-control-bar-pull-button.js.map +1 -1
- package/dist/components/features/chat/git-control-bar-push-button.cjs +1 -1
- package/dist/components/features/chat/git-control-bar-push-button.cjs.map +1 -1
- package/dist/components/features/chat/git-control-bar-push-button.js +16 -15
- package/dist/components/features/chat/git-control-bar-push-button.js.map +1 -1
- package/dist/components/features/chat/git-control-bar.cjs +1 -1
- package/dist/components/features/chat/git-control-bar.cjs.map +1 -1
- package/dist/components/features/chat/git-control-bar.js +63 -62
- package/dist/components/features/chat/git-control-bar.js.map +1 -1
- package/dist/components/features/chat/pending-user-messages.cjs +1 -1
- package/dist/components/features/chat/pending-user-messages.cjs.map +1 -1
- package/dist/components/features/chat/pending-user-messages.js +27 -23
- package/dist/components/features/chat/pending-user-messages.js.map +1 -1
- package/dist/components/features/chat/switch-profile-button.cjs +1 -1
- package/dist/components/features/chat/switch-profile-button.cjs.map +1 -1
- package/dist/components/features/chat/switch-profile-button.js +26 -25
- package/dist/components/features/chat/switch-profile-button.js.map +1 -1
- package/dist/components/features/chat/switch-profile-context-menu.cjs +1 -1
- package/dist/components/features/chat/switch-profile-context-menu.cjs.map +1 -1
- package/dist/components/features/chat/switch-profile-context-menu.js +77 -67
- package/dist/components/features/chat/switch-profile-context-menu.js.map +1 -1
- package/dist/components/features/context-menu/context-menu-icon-text-with-description.cjs +1 -1
- package/dist/components/features/context-menu/context-menu-icon-text-with-description.cjs.map +1 -1
- package/dist/components/features/context-menu/context-menu-icon-text-with-description.d.ts +2 -1
- package/dist/components/features/context-menu/context-menu-icon-text-with-description.js +3 -2
- package/dist/components/features/context-menu/context-menu-icon-text-with-description.js.map +1 -1
- package/dist/components/features/context-menu/context-menu-icon-text.cjs +1 -1
- package/dist/components/features/context-menu/context-menu-icon-text.cjs.map +1 -1
- package/dist/components/features/context-menu/context-menu-icon-text.d.ts +2 -1
- package/dist/components/features/context-menu/context-menu-icon-text.js +20 -10
- package/dist/components/features/context-menu/context-menu-icon-text.js.map +1 -1
- package/dist/components/features/context-menu/context-menu-list-item.cjs +1 -1
- package/dist/components/features/context-menu/context-menu-list-item.cjs.map +1 -1
- package/dist/components/features/context-menu/context-menu-list-item.js +10 -9
- package/dist/components/features/context-menu/context-menu-list-item.js.map +1 -1
- package/dist/components/features/controls/agent-status.cjs +1 -1
- package/dist/components/features/controls/agent-status.js +12 -12
- package/dist/components/features/controls/git-tools-submenu.cjs +1 -1
- package/dist/components/features/controls/git-tools-submenu.cjs.map +1 -1
- package/dist/components/features/controls/git-tools-submenu.js +1 -1
- package/dist/components/features/controls/git-tools-submenu.js.map +1 -1
- package/dist/components/features/controls/macros-submenu.cjs +1 -1
- package/dist/components/features/controls/macros-submenu.cjs.map +1 -1
- package/dist/components/features/controls/macros-submenu.js +1 -1
- package/dist/components/features/controls/macros-submenu.js.map +1 -1
- package/dist/components/features/controls/server-status-context-menu-icon-text.cjs +1 -1
- package/dist/components/features/controls/server-status-context-menu-icon-text.cjs.map +1 -1
- package/dist/components/features/controls/server-status-context-menu-icon-text.js +14 -15
- package/dist/components/features/controls/server-status-context-menu-icon-text.js.map +1 -1
- package/dist/components/features/controls/server-status-context-menu.cjs +1 -1
- package/dist/components/features/controls/server-status-context-menu.js +4 -4
- package/dist/components/features/controls/server-status.cjs +1 -1
- package/dist/components/features/controls/server-status.js +7 -7
- package/dist/components/features/controls/tools-context-menu-icon-text.cjs +1 -1
- package/dist/components/features/controls/tools-context-menu-icon-text.cjs.map +1 -1
- package/dist/components/features/controls/tools-context-menu-icon-text.js +16 -16
- package/dist/components/features/controls/tools-context-menu-icon-text.js.map +1 -1
- package/dist/components/features/conversation/conversation-name-context-menu-icon-text.cjs +1 -1
- package/dist/components/features/conversation/conversation-name-context-menu-icon-text.cjs.map +1 -1
- package/dist/components/features/conversation/conversation-name-context-menu-icon-text.js +11 -11
- package/dist/components/features/conversation/conversation-name-context-menu-icon-text.js.map +1 -1
- package/dist/components/features/conversation/conversation-name-with-status.cjs +1 -1
- package/dist/components/features/conversation/conversation-name-with-status.js +11 -11
- package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.cjs +1 -1
- package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.cjs.map +1 -1
- package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.js +60 -47
- package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.js.map +1 -1
- package/dist/components/features/conversation-panel/cloud-new-conversation-menu.cjs +1 -1
- package/dist/components/features/conversation-panel/cloud-new-conversation-menu.cjs.map +1 -1
- package/dist/components/features/conversation-panel/cloud-new-conversation-menu.js +86 -82
- package/dist/components/features/conversation-panel/cloud-new-conversation-menu.js.map +1 -1
- package/dist/components/features/conversation-panel/conversation-card/conversation-card-actions.cjs +1 -1
- package/dist/components/features/conversation-panel/conversation-card/conversation-card-actions.js +4 -4
- package/dist/components/features/conversation-panel/conversation-card/conversation-card-footer.cjs +1 -1
- package/dist/components/features/conversation-panel/conversation-card/conversation-card-footer.js +9 -9
- package/dist/components/features/conversation-panel/conversation-panel-filter-menu.cjs +1 -1
- package/dist/components/features/conversation-panel/conversation-panel-filter-menu.cjs.map +1 -1
- package/dist/components/features/conversation-panel/conversation-panel-filter-menu.js +93 -93
- package/dist/components/features/conversation-panel/conversation-panel-filter-menu.js.map +1 -1
- package/dist/components/features/conversation-panel/conversation-panel.cjs +1 -1
- package/dist/components/features/conversation-panel/conversation-panel.cjs.map +1 -1
- package/dist/components/features/conversation-panel/conversation-panel.js +177 -177
- package/dist/components/features/conversation-panel/conversation-panel.js.map +1 -1
- package/dist/components/features/conversation-panel/ellipsis-button.cjs +1 -1
- package/dist/components/features/conversation-panel/ellipsis-button.cjs.map +1 -1
- package/dist/components/features/conversation-panel/ellipsis-button.js +13 -13
- package/dist/components/features/conversation-panel/ellipsis-button.js.map +1 -1
- package/dist/components/features/conversation-panel/local-new-conversation-menu.cjs +1 -1
- package/dist/components/features/conversation-panel/local-new-conversation-menu.cjs.map +1 -1
- package/dist/components/features/conversation-panel/local-new-conversation-menu.js +57 -53
- package/dist/components/features/conversation-panel/local-new-conversation-menu.js.map +1 -1
- package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.cjs +1 -1
- package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.cjs.map +1 -1
- package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.js +3 -2
- package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.js.map +1 -1
- package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.cjs +1 -1
- package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.cjs.map +1 -1
- package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.js +11 -8
- package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.js.map +1 -1
- package/dist/components/features/conversation-panel/system-message-modal/tab-content.cjs.map +1 -1
- package/dist/components/features/conversation-panel/system-message-modal/tab-content.d.ts +2 -5
- package/dist/components/features/conversation-panel/system-message-modal/tab-content.js.map +1 -1
- package/dist/components/features/files-tab/file-content-viewer.cjs +1 -1
- package/dist/components/features/files-tab/file-content-viewer.cjs.map +1 -1
- package/dist/components/features/files-tab/file-content-viewer.js +45 -42
- package/dist/components/features/files-tab/file-content-viewer.js.map +1 -1
- package/dist/components/features/home/llm-not-configured-banner.d.ts +11 -0
- package/dist/components/features/home/shared/dropdown-item.cjs +1 -1
- package/dist/components/features/home/shared/dropdown-item.cjs.map +1 -1
- package/dist/components/features/home/shared/dropdown-item.js +20 -16
- package/dist/components/features/home/shared/dropdown-item.js.map +1 -1
- package/dist/components/features/home/shared/generic-dropdown-menu.cjs +1 -1
- package/dist/components/features/home/shared/generic-dropdown-menu.cjs.map +1 -1
- package/dist/components/features/home/shared/generic-dropdown-menu.js +23 -22
- package/dist/components/features/home/shared/generic-dropdown-menu.js.map +1 -1
- package/dist/components/features/home/workspace-dropdown/folder-browser-modal.cjs +1 -1
- package/dist/components/features/home/workspace-dropdown/folder-browser-modal.cjs.map +1 -1
- package/dist/components/features/home/workspace-dropdown/folder-browser-modal.js +103 -102
- package/dist/components/features/home/workspace-dropdown/folder-browser-modal.js.map +1 -1
- package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.cjs +1 -1
- package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.cjs.map +1 -1
- package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.js +68 -67
- package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.js.map +1 -1
- package/dist/components/features/mcp-page/custom-server-editor.cjs +1 -1
- package/dist/components/features/mcp-page/custom-server-editor.cjs.map +1 -1
- package/dist/components/features/mcp-page/custom-server-editor.js +62 -60
- package/dist/components/features/mcp-page/custom-server-editor.js.map +1 -1
- package/dist/components/features/mcp-page/index.cjs +1 -1
- package/dist/components/features/mcp-page/index.d.ts +1 -0
- package/dist/components/features/mcp-page/index.js +1 -0
- package/dist/components/features/mcp-page/install-server-modal.cjs +1 -1
- package/dist/components/features/mcp-page/install-server-modal.cjs.map +1 -1
- package/dist/components/features/mcp-page/install-server-modal.js +150 -119
- package/dist/components/features/mcp-page/install-server-modal.js.map +1 -1
- package/dist/components/features/mcp-page/save-as-secret-toggle.cjs +2 -0
- package/dist/components/features/mcp-page/save-as-secret-toggle.cjs.map +1 -0
- package/dist/components/features/mcp-page/save-as-secret-toggle.d.ts +7 -0
- package/dist/components/features/mcp-page/save-as-secret-toggle.js +50 -0
- package/dist/components/features/mcp-page/save-as-secret-toggle.js.map +1 -0
- package/dist/components/features/onboarding/onboarding-modal.d.ts +2 -2
- package/dist/components/features/onboarding/steps/check-backend-step.d.ts +1 -1
- package/dist/components/features/onboarding/steps/choose-agent-step.d.ts +2 -1
- package/dist/components/features/onboarding/steps/setup-acp-secrets-step.d.ts +19 -10
- package/dist/components/features/settings/llm-profiles/llm-settings-local-view.cjs +1 -1
- package/dist/components/features/settings/llm-profiles/llm-settings-local-view.d.ts +5 -0
- package/dist/components/features/settings/llm-profiles/llm-settings-local-view.js +2 -0
- package/dist/components/features/settings/llm-profiles/profile-actions-menu.cjs +1 -1
- package/dist/components/features/settings/llm-profiles/profile-actions-menu.js +1 -0
- package/dist/components/features/skills/extensions-navigation.cjs +1 -1
- package/dist/components/features/skills/extensions-navigation.cjs.map +1 -1
- package/dist/components/features/skills/extensions-navigation.js +1 -1
- package/dist/components/features/skills/extensions-navigation.js.map +1 -1
- package/dist/components/shared/buttons/back-nav-button.cjs +2 -0
- package/dist/components/shared/buttons/back-nav-button.cjs.map +1 -0
- package/dist/components/shared/buttons/back-nav-button.d.ts +17 -0
- package/dist/components/shared/buttons/back-nav-button.js +33 -0
- package/dist/components/shared/buttons/back-nav-button.js.map +1 -0
- package/dist/components/shared/buttons/conversation-confirmation-buttons.cjs +1 -1
- package/dist/components/shared/buttons/conversation-confirmation-buttons.js +5 -5
- package/dist/components/shared/filters/enum-filter-dropdown.cjs +1 -1
- package/dist/components/shared/filters/enum-filter-dropdown.cjs.map +1 -1
- package/dist/components/shared/filters/enum-filter-dropdown.js +32 -31
- package/dist/components/shared/filters/enum-filter-dropdown.js.map +1 -1
- package/dist/components/shared/modals/confirmation-modals/base-modal.cjs +1 -1
- package/dist/components/shared/modals/confirmation-modals/base-modal.cjs.map +1 -1
- package/dist/components/shared/modals/confirmation-modals/base-modal.js +14 -13
- package/dist/components/shared/modals/confirmation-modals/base-modal.js.map +1 -1
- package/dist/components/shared/modals/settings/settings-modal.cjs +1 -1
- package/dist/components/shared/modals/settings/settings-modal.cjs.map +1 -1
- package/dist/components/shared/modals/settings/settings-modal.js +17 -16
- package/dist/components/shared/modals/settings/settings-modal.js.map +1 -1
- package/dist/components/shared/text-shimmer.cjs +2 -0
- package/dist/components/shared/text-shimmer.cjs.map +1 -0
- package/dist/components/shared/text-shimmer.d.ts +11 -0
- package/dist/components/shared/text-shimmer.js +43 -0
- package/dist/components/shared/text-shimmer.js.map +1 -0
- package/dist/constants/acp-providers.cjs +1 -1
- package/dist/constants/acp-providers.cjs.map +1 -1
- package/dist/constants/acp-providers.d.ts +16 -3
- package/dist/constants/acp-providers.js +0 -1
- package/dist/constants/acp-providers.js.map +1 -1
- package/dist/contexts/active-backend-context.cjs +1 -1
- package/dist/contexts/active-backend-context.cjs.map +1 -1
- package/dist/contexts/active-backend-context.js +32 -32
- package/dist/contexts/active-backend-context.js.map +1 -1
- package/dist/hooks/chat/use-chat-input-logic.cjs +1 -1
- package/dist/hooks/chat/use-chat-input-logic.cjs.map +1 -1
- package/dist/hooks/chat/use-chat-input-logic.js +13 -6
- package/dist/hooks/chat/use-chat-input-logic.js.map +1 -1
- package/dist/hooks/mutation/use-save-fields-as-secrets.cjs +2 -0
- package/dist/hooks/mutation/use-save-fields-as-secrets.cjs.map +1 -0
- package/dist/hooks/mutation/use-save-fields-as-secrets.d.ts +9 -0
- package/dist/hooks/mutation/use-save-fields-as-secrets.js +24 -0
- package/dist/hooks/mutation/use-save-fields-as-secrets.js.map +1 -0
- package/dist/hooks/mutation/use-unified-start-conversation.cjs +1 -1
- package/dist/hooks/mutation/use-unified-start-conversation.js +8 -8
- package/dist/hooks/mutation/use-unified-stop-conversation.cjs +1 -1
- package/dist/hooks/mutation/use-unified-stop-conversation.js +15 -15
- package/dist/hooks/query/use-acp-auth-status.d.ts +36 -0
- package/dist/hooks/query/use-agent-settings-schema.cjs +1 -1
- package/dist/hooks/query/use-agent-settings-schema.cjs.map +1 -1
- package/dist/hooks/query/use-agent-settings-schema.js +26 -16
- package/dist/hooks/query/use-agent-settings-schema.js.map +1 -1
- package/dist/hooks/query/use-backends-health.cjs +1 -1
- package/dist/hooks/query/use-backends-health.cjs.map +1 -1
- package/dist/hooks/query/use-backends-health.d.ts +2 -0
- package/dist/hooks/query/use-backends-health.js +31 -21
- package/dist/hooks/query/use-backends-health.js.map +1 -1
- package/dist/hooks/query/use-paginated-conversations.cjs +1 -1
- package/dist/hooks/query/use-paginated-conversations.cjs.map +1 -1
- package/dist/hooks/query/use-paginated-conversations.js +15 -14
- package/dist/hooks/query/use-paginated-conversations.js.map +1 -1
- package/dist/hooks/query/use-settings.cjs +1 -1
- package/dist/hooks/query/use-settings.cjs.map +1 -1
- package/dist/hooks/query/use-settings.js +65 -52
- package/dist/hooks/query/use-settings.js.map +1 -1
- package/dist/hooks/query/use-user-conversation.cjs +1 -1
- package/dist/hooks/query/use-user-conversation.cjs.map +1 -1
- package/dist/hooks/query/use-user-conversation.js +20 -11
- package/dist/hooks/query/use-user-conversation.js.map +1 -1
- package/dist/hooks/use-agent-state.cjs +1 -1
- package/dist/hooks/use-agent-state.js +13 -13
- package/dist/hooks/use-conversation-name-context-menu.cjs +1 -1
- package/dist/hooks/use-conversation-name-context-menu.js +10 -10
- package/dist/hooks/use-conversation-name-context-menu.js.map +1 -1
- package/dist/hooks/use-llm-configured.d.ts +25 -0
- package/dist/hooks/use-runtime-is-ready.cjs +1 -1
- package/dist/hooks/use-runtime-is-ready.js +5 -5
- package/dist/i18n/declaration.cjs +1 -1
- package/dist/i18n/declaration.cjs.map +1 -1
- package/dist/i18n/declaration.d.ts +19 -1
- package/dist/i18n/declaration.js +1 -1
- package/dist/i18n/declaration.js.map +1 -1
- package/dist/i18n/translation.cjs +3 -3
- package/dist/i18n/translation.cjs.map +1 -1
- package/dist/i18n/translation.js +321 -15
- package/dist/i18n/translation.js.map +1 -1
- package/dist/icons/stop-circle.cjs +1 -1
- package/dist/icons/stop-circle.cjs.map +1 -1
- package/dist/icons/stop-circle.js +7 -10
- package/dist/icons/stop-circle.js.map +1 -1
- package/dist/locales/ar/openhands.json +20 -2
- package/dist/locales/ca/openhands.json +20 -2
- package/dist/locales/de/openhands.json +20 -2
- package/dist/locales/en/openhands.json +20 -2
- package/dist/locales/es/openhands.json +20 -2
- package/dist/locales/fr/openhands.json +20 -2
- package/dist/locales/it/openhands.json +20 -2
- package/dist/locales/ja/openhands.json +20 -2
- package/dist/locales/ko-KR/openhands.json +20 -2
- package/dist/locales/no/openhands.json +20 -2
- package/dist/locales/pt/openhands.json +20 -2
- package/dist/locales/tr/openhands.json +20 -2
- package/dist/locales/uk/openhands.json +20 -2
- package/dist/locales/zh-CN/openhands.json +20 -2
- package/dist/locales/zh-TW/openhands.json +20 -2
- package/dist/node_modules/@openhands/extensions/integrations/catalog/airtable.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/airtable.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/airtable.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/airtable.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/apify.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/apify.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/apify.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/apify.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/brave-search.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/brave-search.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/brave-search.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/brave-search.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/clickhouse.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/clickhouse.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/clickhouse.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/clickhouse.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/elevenlabs.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/elevenlabs.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/elevenlabs.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/elevenlabs.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/exa.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/exa.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/exa.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/exa.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/figma.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/figma.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/figma.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/figma.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/firecrawl.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/firecrawl.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/firecrawl.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/firecrawl.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/github.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/github.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/github.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/github.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/kagi.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/kagi.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/kagi.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/kagi.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/mongodb.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/mongodb.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/mongodb.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/mongodb.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/neon.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/neon.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/neon.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/neon.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/notion.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/notion.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/notion.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/notion.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/obsidian.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/obsidian.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/obsidian.js +2 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/obsidian.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/redis.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/redis.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/redis.js +2 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/redis.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/resend.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/resend.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/resend.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/resend.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/slack.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/slack.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/slack.js +8 -7
- package/dist/node_modules/@openhands/extensions/integrations/catalog/slack.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/supabase.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/supabase.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/supabase.js +2 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/supabase.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/tavily.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/tavily.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/tavily.js +4 -2
- package/dist/node_modules/@openhands/extensions/integrations/catalog/tavily.js.map +1 -1
- package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.cjs +2 -0
- package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.cjs.map +1 -0
- package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.js +15 -0
- package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.js.map +1 -0
- package/dist/package.cjs +1 -1
- package/dist/package.cjs.map +1 -1
- package/dist/package.js +2 -2
- package/dist/package.js.map +1 -1
- package/dist/routes/conversation.cjs +1 -1
- package/dist/routes/conversation.cjs.map +1 -1
- package/dist/routes/conversation.js +1 -1
- package/dist/routes/conversation.js.map +1 -1
- package/dist/routes/llm-settings.cjs +1 -1
- package/dist/routes/llm-settings.cjs.map +1 -1
- package/dist/routes/llm-settings.js +55 -54
- package/dist/routes/llm-settings.js.map +1 -1
- package/dist/routes/secrets-settings.cjs +1 -1
- package/dist/routes/secrets-settings.cjs.map +1 -1
- package/dist/routes/secrets-settings.js +19 -27
- package/dist/routes/secrets-settings.js.map +1 -1
- package/dist/stores/conversation-store.cjs +1 -1
- package/dist/stores/conversation-store.cjs.map +1 -1
- package/dist/stores/conversation-store.d.ts +4 -0
- package/dist/stores/conversation-store.js +6 -0
- package/dist/stores/conversation-store.js.map +1 -1
- package/dist/types/agent-server/core/events/acp-tool-call-event.d.ts +6 -4
- package/dist/types/agent-server/core/events/system-event.d.ts +5 -0
- package/dist/types/automation.d.ts +15 -0
- package/dist/types/settings.d.ts +3 -1
- package/dist/ui/combobox-caret.cjs +1 -1
- package/dist/ui/combobox-caret.cjs.map +1 -1
- package/dist/ui/combobox-caret.d.ts +1 -1
- package/dist/ui/combobox-caret.js +9 -8
- package/dist/ui/combobox-caret.js.map +1 -1
- package/dist/ui/context-menu.cjs +1 -1
- package/dist/ui/context-menu.cjs.map +1 -1
- package/dist/ui/context-menu.js +9 -8
- package/dist/ui/context-menu.js.map +1 -1
- package/dist/ui/dropdown/dropdown-menu.cjs +1 -1
- package/dist/ui/dropdown/dropdown-menu.cjs.map +1 -1
- package/dist/ui/dropdown/dropdown-menu.js +21 -17
- package/dist/ui/dropdown/dropdown-menu.js.map +1 -1
- package/dist/ui/dropdown/dropdown.cjs +1 -1
- package/dist/ui/dropdown/dropdown.cjs.map +1 -1
- package/dist/ui/dropdown/dropdown.js +2 -2
- package/dist/ui/dropdown/dropdown.js.map +1 -1
- package/dist/utils/automation-schedule.d.ts +1 -0
- package/dist/utils/dropdown-classes.cjs +2 -0
- package/dist/utils/dropdown-classes.cjs.map +1 -0
- package/dist/utils/dropdown-classes.d.ts +32 -0
- package/dist/utils/dropdown-classes.js +8 -0
- package/dist/utils/dropdown-classes.js.map +1 -0
- package/dist/utils/form-control-classes.cjs +1 -1
- package/dist/utils/form-control-classes.cjs.map +1 -1
- package/dist/utils/form-control-classes.d.ts +18 -2
- package/dist/utils/form-control-classes.js +4 -3
- package/dist/utils/form-control-classes.js.map +1 -1
- package/dist/utils/git-control-bar-classes.cjs +2 -0
- package/dist/utils/git-control-bar-classes.cjs.map +1 -0
- package/dist/utils/git-control-bar-classes.d.ts +4 -0
- package/dist/utils/git-control-bar-classes.js +14 -0
- package/dist/utils/git-control-bar-classes.js.map +1 -0
- package/dist/utils/handle-event-for-ui.cjs.map +1 -1
- package/dist/utils/handle-event-for-ui.d.ts +6 -3
- package/dist/utils/handle-event-for-ui.js.map +1 -1
- package/dist/utils/mobile-top-bar-icon-button-classes.cjs +1 -1
- package/dist/utils/mobile-top-bar-icon-button-classes.cjs.map +1 -1
- package/dist/utils/mobile-top-bar-icon-button-classes.js +3 -3
- package/dist/utils/mobile-top-bar-icon-button-classes.js.map +1 -1
- package/dist/utils/modal-classes.cjs +2 -0
- package/dist/utils/modal-classes.cjs.map +1 -0
- package/dist/utils/modal-classes.d.ts +8 -0
- package/dist/utils/modal-classes.js +7 -0
- package/dist/utils/modal-classes.js.map +1 -0
- package/dist/utils/openhands-llm.cjs +2 -0
- package/dist/utils/openhands-llm.cjs.map +1 -0
- package/dist/utils/openhands-llm.d.ts +2 -0
- package/dist/utils/openhands-llm.js +9 -0
- package/dist/utils/openhands-llm.js.map +1 -0
- package/dist/utils/redact-custom-secrets.cjs +2 -0
- package/dist/utils/redact-custom-secrets.cjs.map +1 -0
- package/dist/utils/redact-custom-secrets.d.ts +6 -0
- package/dist/utils/redact-custom-secrets.js +10 -0
- package/dist/utils/redact-custom-secrets.js.map +1 -0
- package/dist/utils/status.cjs +1 -1
- package/dist/utils/status.cjs.map +1 -1
- package/dist/utils/status.d.ts +2 -1
- package/dist/utils/status.js +9 -8
- package/dist/utils/status.js.map +1 -1
- package/dist/utils/system-message-adapter.cjs +1 -1
- package/dist/utils/system-message-adapter.cjs.map +1 -1
- package/dist/utils/system-message-adapter.js +10 -7
- package/dist/utils/system-message-adapter.js.map +1 -1
- package/dist/utils/utils.cjs +1 -1
- package/dist/utils/utils.cjs.map +1 -1
- package/dist/utils/utils.d.ts +2 -1
- package/dist/utils/utils.js +21 -20
- package/dist/utils/utils.js.map +1 -1
- package/package.json +2 -2
- package/scripts/dev-safe.mjs +3 -1
- package/scripts/dev-static.mjs +2 -2
- package/scripts/dev-with-automation.mjs +283 -108
- package/scripts/static-build.mjs +20 -19
- package/scripts/static-server.mjs +50 -3
- package/build/assets/acp-providers-CbiRekh9.js +0 -1
- package/build/assets/active-backend-context-cCM1vYYZ.js +0 -1
- package/build/assets/add-backend-modal-DIUQzMPa.js +0 -1
- package/build/assets/agent-server-client-options-Bc5ZorQZ.js +0 -1
- package/build/assets/agent-server-compatibility-BlkUsrX2.js +0 -1
- package/build/assets/agent-server-conversation-service.api-C2V5SlHu.js +0 -5
- package/build/assets/api-key-entry-screen-B2gynaCp.js +0 -1
- package/build/assets/automation-detail-DJvbVSYK.js +0 -1
- package/build/assets/automations-list-rMki-8au.js +0 -1
- package/build/assets/backend-form-modal-Dnk33xA_.js +0 -1
- package/build/assets/base-modal-_dYTw1ri.js +0 -1
- package/build/assets/brand-button-Br7f0kZJ.js +0 -1
- package/build/assets/browser-store-Couc4S5D.js +0 -1
- package/build/assets/clock-BRjCgHTc.js +0 -1
- package/build/assets/combobox-caret-to1O8irE.js +0 -1
- package/build/assets/context-menu-list-item-CWNFpuiC.js +0 -1
- package/build/assets/conversation-DVrKU0oz.js +0 -19
- package/build/assets/conversation-Dlys-D5A.js +0 -1
- package/build/assets/conversation-panel-iF09WjZ4.js +0 -1
- package/build/assets/conversation-service.api-CCfztilW.js +0 -1
- package/build/assets/conversation-state-store-u5jepov0.js +0 -1
- package/build/assets/conversation-store-Z5iMCRpc.js +0 -1
- package/build/assets/conversation-websocket-context-DhJhqUna.js +0 -3
- package/build/assets/declaration-BNMqORFE.js +0 -1
- package/build/assets/dist-BxBP7tFD.js +0 -1
- package/build/assets/edit-automation-modal-BGzR3nfZ.js +0 -1
- package/build/assets/ellipsis-button-ZyLMPURn.js +0 -1
- package/build/assets/entry.client-1VMHpktY.js +0 -2
- package/build/assets/enum-filter-dropdown-CEgCdu4A.js +0 -1
- package/build/assets/extensions-hub-C651jsVh.js +0 -1
- package/build/assets/files-tab-R5z0lLdY.js +0 -1
- package/build/assets/files-tab-store-CDyVTXNT.js +0 -1
- package/build/assets/git-control-bar-branch-button-COdRAYHb.js +0 -27
- package/build/assets/git-provider-icon-BzLbc0yC.js +0 -1
- package/build/assets/home-XxBpNOVq.js +0 -1
- package/build/assets/install-server-modal-f31_CLrW.js +0 -1
- package/build/assets/launch-CshDse3e.js +0 -1
- package/build/assets/link-external-D2POYx4c.js +0 -1
- package/build/assets/llm-settings-Bql-vydt.js +0 -1
- package/build/assets/llm-settings-C_tal6Ds.js +0 -1
- package/build/assets/manage-backends-modal-l7RkKfwX.js +0 -1
- package/build/assets/manage-workspaces-modal-DhKF_8z3.js +0 -1
- package/build/assets/manifest-d9077852.js +0 -1
- package/build/assets/mcp-D2onbwVk.js +0 -9
- package/build/assets/messages-D0rWot7s.js +0 -36
- package/build/assets/proxy-CxydCnis.js +0 -1
- package/build/assets/root-DHeCXo9N.css +0 -1
- package/build/assets/root-layout-Czo9Ma6Q.js +0 -2
- package/build/assets/secrets-service-BsnKFc2x.js +0 -1
- package/build/assets/secrets-settings-Bz_UohPJ.js +0 -1
- package/build/assets/settings-client-C73C7IgV.js +0 -1
- package/build/assets/settings-index-Dz0BmdJD.js +0 -1
- package/build/assets/settings-list-classes-Bf80tWtc.js +0 -1
- package/build/assets/settings-modal-Brzgh5Yw.js +0 -1
- package/build/assets/settings-service.api-CZ3uWx4v.js +0 -1
- package/build/assets/sidebar-mobile-menu-toggle-Do_aA9Zm.js +0 -1
- package/build/assets/skills-settings-DlA5hlXw.js +0 -2
- package/build/assets/status-hp6M6E7E.js +0 -1
- package/build/assets/use-agent-settings-schema-33Un7UF2.js +0 -1
- package/build/assets/use-is-authed-BggE5wPj.js +0 -1
- package/build/assets/use-llm-profiles-DDOol3gK.js +0 -1
- package/build/assets/use-runtime-is-ready-B7EF4BKU.js +0 -1
- package/build/assets/use-settings-DQIZmIov.js +0 -1
- package/build/assets/use-user-conversation-C6hrMMtn.js +0 -1
- package/build/assets/utils-i18rdUj2.js +0 -1
- package/build/assets/vendor~conversation-panel~conversation-a9SyrrhV.js +0 -1
- package/build/assets/vendor~conversation-panel~conversation~index-C23ZXO4R.js +0 -1
- package/build/assets/vendor~home~mcp~automations-list-Ccy2I0KU.js +0 -1
- package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~i4kjfqhl-BebWhFNT.js +0 -1
- package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-DzIXV3Ui.js +0 -9
- /package/build/assets/{automation-IdgZq6ZK.js → automation-XDPAjiZi.js} +0 -0
- /package/build/assets/{color-themes-DSaoIL6A.js → color-themes-B9pm9c-R.js} +0 -0
- /package/build/assets/{common-DR1t-EeP.js → common-DqjLSBOt.js} +0 -0
- /package/build/assets/{conversation-local-storage-UYl-SX-r.js → conversation-local-storage-YmOVXxxW.js} +0 -0
- /package/build/assets/{dist-C6t0EXL7.js → dist-C3NfioQC.js} +0 -0
- /package/build/assets/{environment-switch-store-C4ulFJKp.js → environment-switch-store-CiurvTtK.js} +0 -0
- /package/build/assets/{health-store-BDC2rM-X.js → health-store-B5f0S2FY.js} +0 -0
- /package/build/assets/{map-provider-COBVzZYo.js → map-provider-BJ_8KZKU.js} +0 -0
- /package/build/assets/{middleware-BC9EwbB9.js → middleware-CfatjPYZ.js} +0 -0
- /package/build/assets/{objectWithoutPropertiesLoose-Du6eBn-V.js → objectWithoutPropertiesLoose-DSQKyRhw.js} +0 -0
- /package/build/assets/{react-Do0CT17Y.js → react-Dy05vyj5.js} +0 -0
- /package/build/assets/{sdk-settings-field-metadata-CBPmeqYa.js → sdk-settings-field-metadata-DQiaIBie.js} +0 -0
- /package/build/assets/{settings-D_H-qsRm.js → settings-DGY6n4J2.js} +0 -0
- /package/build/assets/{settings-like-page-layout-classes-I0BDBEoq.js → settings-like-page-layout-classes-D7YjdTd0.js} +0 -0
- /package/build/assets/{use-breakpoint-DbJ6FkQ-.js → use-breakpoint-DF_RiQ6s.js} +0 -0
- /package/build/assets/{use-click-outside-element-DffgWWoZ.js → use-click-outside-element-DhxCUyWl.js} +0 -0
- /package/build/assets/{v4-CNn21NXa.js → v4-khGvL7i2.js} +0 -0
- /package/build/assets/{vendor~browser-DDiZgqD3.js → vendor~browser-DisFGEp9.js} +0 -0
- /package/build/assets/{vendor~browser-tab-BgwV1mxF.js → vendor~browser-tab-BxhTtM9_.js} +0 -0
- /package/build/assets/{vendor~conversation-panel~conversation~alert-banner-DbvX3OcM.js → vendor~conversation-panel~conversation~alert-banner-w-I2sY6c.js} +0 -0
- /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
- /package/build/assets/{vendor~files-tab-BGKayPiK.js → vendor~files-tab-BtkpAiMX.js} +0 -0
- /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
- /package/build/assets/{vendor~home~mcp~automations-list-DoPfwaXj.js → vendor~home~mcp~automations-list-BgV86Sti.js} +0 -0
- /package/build/assets/{vendor~launch-vdeRTWFu.js → vendor~launch-BXgl67Re.js} +0 -0
- /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
- /package/build/assets/{vendor~terminal-DUrOWGFE.js → vendor~terminal-DZaJIY8A.js} +0 -0
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
const e=require(`../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),n=require(`../../../i18n/declaration.cjs`),r=require(`../../../icons/lesson-plan.cjs`),
|
|
1
|
+
const e=require(`../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),n=require(`../../../i18n/declaration.cjs`),r=require(`../../../utils/utils.cjs`),i=require(`../../../icons/lesson-plan.cjs`),a=require(`../../../icons/code-tag.cjs`),o=require(`../../../ui/context-menu.cjs`),s=require(`../context-menu/context-menu-list-item.cjs`),c=require(`../context-menu/context-menu-icon-text-with-description.cjs`),l=require(`../../../hooks/use-click-outside-element.cjs`);let u=require(`react`);u=e.__toESM(u,1);let d=require(`react/jsx-runtime`);function f({activeMode:e,onClose:u,onCodeClick:f,onPlanClick:p}){let{t:m}=t.useTranslation(`openhands`),h=l.useClickOutsideElement(u);return(0,d.jsxs)(o.ContextMenu,{ref:h,testId:`change-agent-context-menu`,position:`top`,alignment:`left`,className:`min-h-fit mb-2 min-w-[195px] max-w-[195px]`,children:[(0,d.jsx)(s.ContextMenuListItem,{testId:`code-option`,onClick:e=>{e.preventDefault(),e.stopPropagation(),f?.(e),u()},className:r.cn(e===`code`&&`bg-[var(--oh-interactive-hover)]`),children:(0,d.jsx)(c.ContextMenuIconTextWithDescription,{icon:a.default,title:m(n.I18nKey.COMMON$CODE),description:m(n.I18nKey.COMMON$CODE_AGENT_DESCRIPTION),isActive:e===`code`})}),(0,d.jsx)(s.ContextMenuListItem,{testId:`plan-option`,onClick:e=>{e.preventDefault(),e.stopPropagation(),p?.(e),u()},className:r.cn(e===`plan`&&`bg-[var(--oh-interactive-hover)]`),children:(0,d.jsx)(c.ContextMenuIconTextWithDescription,{icon:i.default,title:m(n.I18nKey.COMMON$PLAN),description:m(n.I18nKey.COMMON$PLAN_AGENT_DESCRIPTION),isActive:e===`plan`})})]})}exports.ChangeAgentContextMenu=f;
|
|
2
2
|
//# sourceMappingURL=change-agent-context-menu.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"change-agent-context-menu.cjs","names":[],"sources":["../../../../src/components/features/chat/change-agent-context-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport CodeTagIcon from \"#/icons/code-tag.svg?react\";\nimport LessonPlanIcon from \"#/icons/lesson-plan.svg?react\";\nimport { ContextMenu } from \"#/ui/context-menu\";\nimport { ContextMenuListItem } from \"../context-menu/context-menu-list-item\";\nimport { ContextMenuIconTextWithDescription } from \"../context-menu/context-menu-icon-text-with-description\";\nimport { useClickOutsideElement } from \"#/hooks/use-click-outside-element\";\n\ninterface ChangeAgentContextMenuProps {\n onClose: () => void;\n onCodeClick?: (event: React.MouseEvent<HTMLButtonElement>) => void;\n onPlanClick?: (event: React.MouseEvent<HTMLButtonElement>) => void;\n}\n\nexport function ChangeAgentContextMenu({\n onClose,\n onCodeClick,\n onPlanClick,\n}: ChangeAgentContextMenuProps) {\n const { t } = useTranslation(\"openhands\");\n const menuRef = useClickOutsideElement<HTMLUListElement>(onClose);\n\n const handleCodeClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n event.preventDefault();\n event.stopPropagation();\n onCodeClick?.(event);\n onClose();\n };\n\n const handlePlanClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n event.preventDefault();\n event.stopPropagation();\n onPlanClick?.(event);\n onClose();\n };\n\n return (\n <ContextMenu\n ref={menuRef}\n testId=\"change-agent-context-menu\"\n position=\"top\"\n alignment=\"left\"\n className=\"min-h-fit mb-2 min-w-[195px] max-w-[195px]
|
|
1
|
+
{"version":3,"file":"change-agent-context-menu.cjs","names":[],"sources":["../../../../src/components/features/chat/change-agent-context-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport CodeTagIcon from \"#/icons/code-tag.svg?react\";\nimport LessonPlanIcon from \"#/icons/lesson-plan.svg?react\";\nimport { ContextMenu } from \"#/ui/context-menu\";\nimport { ContextMenuListItem } from \"../context-menu/context-menu-list-item\";\nimport { ContextMenuIconTextWithDescription } from \"../context-menu/context-menu-icon-text-with-description\";\nimport { useClickOutsideElement } from \"#/hooks/use-click-outside-element\";\nimport { cn } from \"#/utils/utils\";\nimport type { ConversationMode } from \"#/stores/conversation-store\";\n\ninterface ChangeAgentContextMenuProps {\n activeMode: ConversationMode;\n onClose: () => void;\n onCodeClick?: (event: React.MouseEvent<HTMLButtonElement>) => void;\n onPlanClick?: (event: React.MouseEvent<HTMLButtonElement>) => void;\n}\n\nexport function ChangeAgentContextMenu({\n activeMode,\n onClose,\n onCodeClick,\n onPlanClick,\n}: ChangeAgentContextMenuProps) {\n const { t } = useTranslation(\"openhands\");\n const menuRef = useClickOutsideElement<HTMLUListElement>(onClose);\n\n const handleCodeClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n event.preventDefault();\n event.stopPropagation();\n onCodeClick?.(event);\n onClose();\n };\n\n const handlePlanClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n event.preventDefault();\n event.stopPropagation();\n onPlanClick?.(event);\n onClose();\n };\n\n return (\n <ContextMenu\n ref={menuRef}\n testId=\"change-agent-context-menu\"\n position=\"top\"\n alignment=\"left\"\n className=\"min-h-fit mb-2 min-w-[195px] max-w-[195px]\"\n >\n <ContextMenuListItem\n testId=\"code-option\"\n onClick={handleCodeClick}\n className={cn(\n activeMode === \"code\" && \"bg-[var(--oh-interactive-hover)]\",\n )}\n >\n <ContextMenuIconTextWithDescription\n icon={CodeTagIcon}\n title={t(I18nKey.COMMON$CODE)}\n description={t(I18nKey.COMMON$CODE_AGENT_DESCRIPTION)}\n isActive={activeMode === \"code\"}\n />\n </ContextMenuListItem>\n <ContextMenuListItem\n testId=\"plan-option\"\n onClick={handlePlanClick}\n className={cn(\n activeMode === \"plan\" && \"bg-[var(--oh-interactive-hover)]\",\n )}\n >\n <ContextMenuIconTextWithDescription\n icon={LessonPlanIcon}\n title={t(I18nKey.COMMON$PLAN)}\n description={t(I18nKey.COMMON$PLAN_AGENT_DESCRIPTION)}\n isActive={activeMode === \"plan\"}\n />\n </ContextMenuListItem>\n </ContextMenu>\n );\n}\n"],"mappings":"6lBAmBA,SAAgB,EAAuB,CACrC,aACA,UACA,cACA,eAC8B,CAC9B,GAAM,CAAE,KAAM,EAAA,eAAe,YAAY,CACnC,EAAU,EAAA,uBAAyC,EAAQ,CAgBjE,OACE,EAAA,EAAA,MAAC,EAAA,YAAD,CACE,IAAK,EACL,OAAO,4BACP,SAAS,MACT,UAAU,OACV,UAAU,sDALZ,EAOE,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,cACP,QAxBmB,GAA+C,CACtE,EAAM,gBAAgB,CACtB,EAAM,iBAAiB,CACvB,IAAc,EAAM,CACpB,GAAS,EAqBL,UAAW,EAAA,GACT,IAAe,QAAU,mCAC1B,WAED,EAAA,EAAA,KAAC,EAAA,mCAAD,CACE,KAAM,EAAA,QACN,MAAO,EAAE,EAAA,QAAQ,YAAY,CAC7B,YAAa,EAAE,EAAA,QAAQ,8BAA8B,CACrD,SAAU,IAAe,OACzB,CAAA,CACkB,CAAA,EACtB,EAAA,EAAA,KAAC,EAAA,oBAAD,CACE,OAAO,cACP,QA/BmB,GAA+C,CACtE,EAAM,gBAAgB,CACtB,EAAM,iBAAiB,CACvB,IAAc,EAAM,CACpB,GAAS,EA4BL,UAAW,EAAA,GACT,IAAe,QAAU,mCAC1B,WAED,EAAA,EAAA,KAAC,EAAA,mCAAD,CACE,KAAM,EAAA,QACN,MAAO,EAAE,EAAA,QAAQ,YAAY,CAC7B,YAAa,EAAE,EAAA,QAAQ,8BAA8B,CACrD,SAAU,IAAe,OACzB,CAAA,CACkB,CAAA,CACV"}
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import React from "react";
|
|
2
|
+
import type { ConversationMode } from "#/stores/conversation-store";
|
|
2
3
|
interface ChangeAgentContextMenuProps {
|
|
4
|
+
activeMode: ConversationMode;
|
|
3
5
|
onClose: () => void;
|
|
4
6
|
onCodeClick?: (event: React.MouseEvent<HTMLButtonElement>) => void;
|
|
5
7
|
onPlanClick?: (event: React.MouseEvent<HTMLButtonElement>) => void;
|
|
6
8
|
}
|
|
7
|
-
export declare function ChangeAgentContextMenu({ onClose, onCodeClick, onPlanClick, }: ChangeAgentContextMenuProps): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
export declare function ChangeAgentContextMenu({ activeMode, onClose, onCodeClick, onPlanClick, }: ChangeAgentContextMenuProps): import("react/jsx-runtime").JSX.Element;
|
|
8
10
|
export {};
|
|
@@ -1,46 +1,51 @@
|
|
|
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 n from "../../../
|
|
4
|
-
import r from "../../../icons/
|
|
5
|
-
import
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
3
|
+
import { cn as n } from "../../../utils/utils.js";
|
|
4
|
+
import r from "../../../icons/lesson-plan.js";
|
|
5
|
+
import i from "../../../icons/code-tag.js";
|
|
6
|
+
import { ContextMenu as a } from "../../../ui/context-menu.js";
|
|
7
|
+
import { ContextMenuListItem as o } from "../context-menu/context-menu-list-item.js";
|
|
8
|
+
import { ContextMenuIconTextWithDescription as s } from "../context-menu/context-menu-icon-text-with-description.js";
|
|
9
|
+
import { useClickOutsideElement as c } from "../../../hooks/use-click-outside-element.js";
|
|
9
10
|
import "react";
|
|
10
|
-
import { jsx as
|
|
11
|
+
import { jsx as l, jsxs as u } from "react/jsx-runtime";
|
|
11
12
|
//#region src/components/features/chat/change-agent-context-menu.tsx
|
|
12
|
-
function
|
|
13
|
-
let { t:
|
|
14
|
-
return /* @__PURE__ */
|
|
15
|
-
ref:
|
|
13
|
+
function d({ activeMode: d, onClose: f, onCodeClick: p, onPlanClick: m }) {
|
|
14
|
+
let { t: h } = e("openhands");
|
|
15
|
+
return /* @__PURE__ */ u(a, {
|
|
16
|
+
ref: c(f),
|
|
16
17
|
testId: "change-agent-context-menu",
|
|
17
18
|
position: "top",
|
|
18
19
|
alignment: "left",
|
|
19
|
-
className: "min-h-fit mb-2 min-w-[195px] max-w-[195px]
|
|
20
|
-
children: [/* @__PURE__ */
|
|
20
|
+
className: "min-h-fit mb-2 min-w-[195px] max-w-[195px]",
|
|
21
|
+
children: [/* @__PURE__ */ l(o, {
|
|
21
22
|
testId: "code-option",
|
|
22
23
|
onClick: (e) => {
|
|
23
|
-
e.preventDefault(), e.stopPropagation(),
|
|
24
|
+
e.preventDefault(), e.stopPropagation(), p?.(e), f();
|
|
24
25
|
},
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
26
|
+
className: n(d === "code" && "bg-[var(--oh-interactive-hover)]"),
|
|
27
|
+
children: /* @__PURE__ */ l(s, {
|
|
28
|
+
icon: i,
|
|
29
|
+
title: h(t.COMMON$CODE),
|
|
30
|
+
description: h(t.COMMON$CODE_AGENT_DESCRIPTION),
|
|
31
|
+
isActive: d === "code"
|
|
29
32
|
})
|
|
30
|
-
}), /* @__PURE__ */
|
|
33
|
+
}), /* @__PURE__ */ l(o, {
|
|
31
34
|
testId: "plan-option",
|
|
32
35
|
onClick: (e) => {
|
|
33
|
-
e.preventDefault(), e.stopPropagation(),
|
|
36
|
+
e.preventDefault(), e.stopPropagation(), m?.(e), f();
|
|
34
37
|
},
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
38
|
+
className: n(d === "plan" && "bg-[var(--oh-interactive-hover)]"),
|
|
39
|
+
children: /* @__PURE__ */ l(s, {
|
|
40
|
+
icon: r,
|
|
41
|
+
title: h(t.COMMON$PLAN),
|
|
42
|
+
description: h(t.COMMON$PLAN_AGENT_DESCRIPTION),
|
|
43
|
+
isActive: d === "plan"
|
|
39
44
|
})
|
|
40
45
|
})]
|
|
41
46
|
});
|
|
42
47
|
}
|
|
43
48
|
//#endregion
|
|
44
|
-
export {
|
|
49
|
+
export { d as ChangeAgentContextMenu };
|
|
45
50
|
|
|
46
51
|
//# sourceMappingURL=change-agent-context-menu.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"change-agent-context-menu.js","names":[],"sources":["../../../../src/components/features/chat/change-agent-context-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport CodeTagIcon from \"#/icons/code-tag.svg?react\";\nimport LessonPlanIcon from \"#/icons/lesson-plan.svg?react\";\nimport { ContextMenu } from \"#/ui/context-menu\";\nimport { ContextMenuListItem } from \"../context-menu/context-menu-list-item\";\nimport { ContextMenuIconTextWithDescription } from \"../context-menu/context-menu-icon-text-with-description\";\nimport { useClickOutsideElement } from \"#/hooks/use-click-outside-element\";\n\ninterface ChangeAgentContextMenuProps {\n onClose: () => void;\n onCodeClick?: (event: React.MouseEvent<HTMLButtonElement>) => void;\n onPlanClick?: (event: React.MouseEvent<HTMLButtonElement>) => void;\n}\n\nexport function ChangeAgentContextMenu({\n onClose,\n onCodeClick,\n onPlanClick,\n}: ChangeAgentContextMenuProps) {\n const { t } = useTranslation(\"openhands\");\n const menuRef = useClickOutsideElement<HTMLUListElement>(onClose);\n\n const handleCodeClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n event.preventDefault();\n event.stopPropagation();\n onCodeClick?.(event);\n onClose();\n };\n\n const handlePlanClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n event.preventDefault();\n event.stopPropagation();\n onPlanClick?.(event);\n onClose();\n };\n\n return (\n <ContextMenu\n ref={menuRef}\n testId=\"change-agent-context-menu\"\n position=\"top\"\n alignment=\"left\"\n className=\"min-h-fit mb-2 min-w-[195px] max-w-[195px]
|
|
1
|
+
{"version":3,"file":"change-agent-context-menu.js","names":[],"sources":["../../../../src/components/features/chat/change-agent-context-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport CodeTagIcon from \"#/icons/code-tag.svg?react\";\nimport LessonPlanIcon from \"#/icons/lesson-plan.svg?react\";\nimport { ContextMenu } from \"#/ui/context-menu\";\nimport { ContextMenuListItem } from \"../context-menu/context-menu-list-item\";\nimport { ContextMenuIconTextWithDescription } from \"../context-menu/context-menu-icon-text-with-description\";\nimport { useClickOutsideElement } from \"#/hooks/use-click-outside-element\";\nimport { cn } from \"#/utils/utils\";\nimport type { ConversationMode } from \"#/stores/conversation-store\";\n\ninterface ChangeAgentContextMenuProps {\n activeMode: ConversationMode;\n onClose: () => void;\n onCodeClick?: (event: React.MouseEvent<HTMLButtonElement>) => void;\n onPlanClick?: (event: React.MouseEvent<HTMLButtonElement>) => void;\n}\n\nexport function ChangeAgentContextMenu({\n activeMode,\n onClose,\n onCodeClick,\n onPlanClick,\n}: ChangeAgentContextMenuProps) {\n const { t } = useTranslation(\"openhands\");\n const menuRef = useClickOutsideElement<HTMLUListElement>(onClose);\n\n const handleCodeClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n event.preventDefault();\n event.stopPropagation();\n onCodeClick?.(event);\n onClose();\n };\n\n const handlePlanClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n event.preventDefault();\n event.stopPropagation();\n onPlanClick?.(event);\n onClose();\n };\n\n return (\n <ContextMenu\n ref={menuRef}\n testId=\"change-agent-context-menu\"\n position=\"top\"\n alignment=\"left\"\n className=\"min-h-fit mb-2 min-w-[195px] max-w-[195px]\"\n >\n <ContextMenuListItem\n testId=\"code-option\"\n onClick={handleCodeClick}\n className={cn(\n activeMode === \"code\" && \"bg-[var(--oh-interactive-hover)]\",\n )}\n >\n <ContextMenuIconTextWithDescription\n icon={CodeTagIcon}\n title={t(I18nKey.COMMON$CODE)}\n description={t(I18nKey.COMMON$CODE_AGENT_DESCRIPTION)}\n isActive={activeMode === \"code\"}\n />\n </ContextMenuListItem>\n <ContextMenuListItem\n testId=\"plan-option\"\n onClick={handlePlanClick}\n className={cn(\n activeMode === \"plan\" && \"bg-[var(--oh-interactive-hover)]\",\n )}\n >\n <ContextMenuIconTextWithDescription\n icon={LessonPlanIcon}\n title={t(I18nKey.COMMON$PLAN)}\n description={t(I18nKey.COMMON$PLAN_AGENT_DESCRIPTION)}\n isActive={activeMode === \"plan\"}\n />\n </ContextMenuListItem>\n </ContextMenu>\n );\n}\n"],"mappings":";;;;;;;;;;;;AAmBA,SAAgB,EAAuB,EACrC,eACA,YACA,gBACA,kBAC8B;CAC9B,IAAM,EAAE,SAAM,EAAe,YAAY;AAiBzC,QACE,kBAAC,GAAD;EACE,KAlBY,EAAyC,EAkBhD;EACL,QAAO;EACP,UAAS;EACT,WAAU;EACV,WAAU;YALZ,CAOE,kBAAC,GAAD;GACE,QAAO;GACP,UAxBmB,MAA+C;AAItE,IAHA,EAAM,gBAAgB,EACtB,EAAM,iBAAiB,EACvB,IAAc,EAAM,EACpB,GAAS;;GAqBL,WAAW,EACT,MAAe,UAAU,mCAC1B;aAED,kBAAC,GAAD;IACE,MAAM;IACN,OAAO,EAAE,EAAQ,YAAY;IAC7B,aAAa,EAAE,EAAQ,8BAA8B;IACrD,UAAU,MAAe;IACzB,CAAA;GACkB,CAAA,EACtB,kBAAC,GAAD;GACE,QAAO;GACP,UA/BmB,MAA+C;AAItE,IAHA,EAAM,gBAAgB,EACtB,EAAM,iBAAiB,EACvB,IAAc,EAAM,EACpB,GAAS;;GA4BL,WAAW,EACT,MAAe,UAAU,mCAC1B;aAED,kBAAC,GAAD;IACE,MAAM;IACN,OAAO,EAAE,EAAQ,YAAY;IAC7B,aAAa,EAAE,EAAQ,8BAA8B;IACrD,UAAU,MAAe;IACzB,CAAA;GACkB,CAAA,CACV"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
const e=require(`../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),n=require(`../../../i18n/declaration.cjs`),r=require(`../../../utils/utils.cjs`),i=require(`../../../hooks/use-conversation-id.cjs`),a=require(`../../../node_modules/lucide-react/dist/esm/icons/paperclip.cjs`),o=require(`../../../node_modules/lucide-react/dist/esm/icons/plus.cjs`),s=require(`../../../hooks/query/use-active-conversation.cjs`),c=require(`../../../hooks/use-conversation-name-context-menu.cjs`),
|
|
1
|
+
const e=require(`../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),n=require(`../../../i18n/declaration.cjs`),r=require(`../../../utils/utils.cjs`),i=require(`../../../hooks/use-conversation-id.cjs`),a=require(`../../../node_modules/lucide-react/dist/esm/icons/paperclip.cjs`),o=require(`../../../node_modules/lucide-react/dist/esm/icons/plus.cjs`),s=require(`../../../hooks/query/use-active-conversation.cjs`),c=require(`../../../utils/form-control-classes.cjs`),l=require(`../../../hooks/use-conversation-name-context-menu.cjs`),u=require(`../controls/tools-context-menu.cjs`),d=require(`../conversation-panel/system-message-modal.cjs`),f=require(`../conversation-panel/skills-modal.cjs`),p=require(`../conversation-panel/hooks-modal.cjs`);let m=require(`react`);m=e.__toESM(m,1);let h=require(`react/jsx-runtime`);function g({handleFileIconClick:e,disabled:g=!1}){let{t:_}=t.useTranslation(`openhands`),{conversationId:v}=i.useOptionalConversationId(),{data:y}=s.useActiveConversation(),[b,x]=m.default.useState(!1),{handleShowAgentTools:S,handleShowSkills:C,handleShowHooks:w,systemModalVisible:T,setSystemModalVisible:E,skillsModalVisible:D,setSkillsModalVisible:O,hooksModalVisible:k,setHooksModalVisible:A,systemMessage:j,shouldShowAgentTools:M,shouldShowHooks:N}=l.useConversationNameContextMenu({conversationId:v??void 0,executionStatus:y?.execution_status,showOptions:!0,onContextMenuToggle:x});return(0,h.jsxs)(`div`,{className:`relative`,children:[(0,h.jsx)(`button`,{type:`button`,className:r.cn(c.chatInputIconButtonClassName,`relative shrink-0 size-6`,g?`cursor-not-allowed text-[var(--oh-text-subtle)]`:void 0,b&&!g&&`text-white bg-white/10`),"aria-label":_(n.I18nKey.CHAT_INTERFACE$PLUS_MENU),"aria-expanded":b,"aria-haspopup":`menu`,"data-testid":`chat-plus-button`,onClick:e=>{e.preventDefault(),e.stopPropagation(),!g&&x(e=>!e)},disabled:g,children:(0,h.jsx)(`span`,{className:`flex h-full w-full items-center justify-center`,children:(0,h.jsx)(o.Plus,{className:`h-[13px] w-[13px] shrink-0`,strokeWidth:2})})}),b&&(0,h.jsx)(u.ToolsContextMenu,{onClose:()=>x(!1),onShowSkills:C,onShowHooks:w,onShowAgentTools:S,shouldShowAgentTools:M,shouldShowHooks:N,footerAction:{testId:`add-files-and-images-button`,icon:(0,h.jsx)(a.Paperclip,{className:`h-4 w-4 shrink-0`,strokeWidth:2,"aria-hidden":!0}),label:_(n.I18nKey.CHAT_INTERFACE$ADD_FILES_AND_IMAGES),onClick:e}}),(0,h.jsx)(d.SystemMessageModal,{isOpen:T,onClose:()=>E(!1),systemMessage:j||null}),D&&(0,h.jsx)(f.SkillsModal,{onClose:()=>O(!1)}),k&&(0,h.jsx)(p.HooksModal,{onClose:()=>A(!1)})]})}exports.ChatAddFileButton=g;
|
|
2
2
|
//# sourceMappingURL=chat-add-file-button.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chat-add-file-button.cjs","names":[],"sources":["../../../../src/components/features/chat/chat-add-file-button.tsx"],"sourcesContent":["import React from \"react\";\nimport { Paperclip, Plus } from \"lucide-react\";\nimport { useTranslation } from \"react-i18next\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { cn } from \"#/utils/utils\";\nimport { useOptionalConversationId } from \"#/hooks/use-conversation-id\";\nimport { useActiveConversation } from \"#/hooks/query/use-active-conversation\";\nimport { useConversationNameContextMenu } from \"#/hooks/use-conversation-name-context-menu\";\nimport { ToolsContextMenu } from \"#/components/features/controls/tools-context-menu\";\nimport { SystemMessageModal } from \"#/components/features/conversation-panel/system-message-modal\";\nimport { SkillsModal } from \"#/components/features/conversation-panel/skills-modal\";\nimport { HooksModal } from \"#/components/features/conversation-panel/hooks-modal\";\n\nexport interface ChatAddFileButtonProps {\n handleFileIconClick: () => void;\n disabled?: boolean;\n}\n\nexport function ChatAddFileButton({\n handleFileIconClick,\n disabled = false,\n}: ChatAddFileButtonProps) {\n const { t } = useTranslation(\"openhands\");\n const { conversationId } = useOptionalConversationId();\n const { data: conversation } = useActiveConversation();\n const [menuOpen, setMenuOpen] = React.useState(false);\n\n const {\n handleShowAgentTools,\n handleShowSkills,\n handleShowHooks,\n systemModalVisible,\n setSystemModalVisible,\n skillsModalVisible,\n setSkillsModalVisible,\n hooksModalVisible,\n setHooksModalVisible,\n systemMessage,\n shouldShowAgentTools,\n shouldShowHooks,\n } = useConversationNameContextMenu({\n conversationId: conversationId ?? undefined,\n executionStatus: conversation?.execution_status,\n showOptions: true,\n onContextMenuToggle: setMenuOpen,\n });\n\n const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n event.preventDefault();\n event.stopPropagation();\n if (disabled) return;\n setMenuOpen((open) => !open);\n };\n\n return (\n <div className=\"relative\">\n <button\n type=\"button\"\n className={cn(\n \"relative shrink-0 size-6
|
|
1
|
+
{"version":3,"file":"chat-add-file-button.cjs","names":[],"sources":["../../../../src/components/features/chat/chat-add-file-button.tsx"],"sourcesContent":["import React from \"react\";\nimport { Paperclip, Plus } from \"lucide-react\";\nimport { useTranslation } from \"react-i18next\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { cn } from \"#/utils/utils\";\nimport { chatInputIconButtonClassName } from \"#/utils/form-control-classes\";\nimport { useOptionalConversationId } from \"#/hooks/use-conversation-id\";\nimport { useActiveConversation } from \"#/hooks/query/use-active-conversation\";\nimport { useConversationNameContextMenu } from \"#/hooks/use-conversation-name-context-menu\";\nimport { ToolsContextMenu } from \"#/components/features/controls/tools-context-menu\";\nimport { SystemMessageModal } from \"#/components/features/conversation-panel/system-message-modal\";\nimport { SkillsModal } from \"#/components/features/conversation-panel/skills-modal\";\nimport { HooksModal } from \"#/components/features/conversation-panel/hooks-modal\";\n\nexport interface ChatAddFileButtonProps {\n handleFileIconClick: () => void;\n disabled?: boolean;\n}\n\nexport function ChatAddFileButton({\n handleFileIconClick,\n disabled = false,\n}: ChatAddFileButtonProps) {\n const { t } = useTranslation(\"openhands\");\n const { conversationId } = useOptionalConversationId();\n const { data: conversation } = useActiveConversation();\n const [menuOpen, setMenuOpen] = React.useState(false);\n\n const {\n handleShowAgentTools,\n handleShowSkills,\n handleShowHooks,\n systemModalVisible,\n setSystemModalVisible,\n skillsModalVisible,\n setSkillsModalVisible,\n hooksModalVisible,\n setHooksModalVisible,\n systemMessage,\n shouldShowAgentTools,\n shouldShowHooks,\n } = useConversationNameContextMenu({\n conversationId: conversationId ?? undefined,\n executionStatus: conversation?.execution_status,\n showOptions: true,\n onContextMenuToggle: setMenuOpen,\n });\n\n const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n event.preventDefault();\n event.stopPropagation();\n if (disabled) return;\n setMenuOpen((open) => !open);\n };\n\n return (\n <div className=\"relative\">\n <button\n type=\"button\"\n className={cn(\n chatInputIconButtonClassName,\n \"relative shrink-0 size-6\",\n disabled\n ? \"cursor-not-allowed text-[var(--oh-text-subtle)]\"\n : undefined,\n menuOpen && !disabled && \"text-white bg-white/10\",\n )}\n aria-label={t(I18nKey.CHAT_INTERFACE$PLUS_MENU)}\n aria-expanded={menuOpen}\n aria-haspopup=\"menu\"\n data-testid=\"chat-plus-button\"\n onClick={handleClick}\n disabled={disabled}\n >\n <span className=\"flex h-full w-full items-center justify-center\">\n <Plus className=\"h-[13px] w-[13px] shrink-0\" strokeWidth={2} />\n </span>\n </button>\n\n {menuOpen && (\n <ToolsContextMenu\n onClose={() => setMenuOpen(false)}\n onShowSkills={handleShowSkills}\n onShowHooks={handleShowHooks}\n onShowAgentTools={handleShowAgentTools}\n shouldShowAgentTools={shouldShowAgentTools}\n shouldShowHooks={shouldShowHooks}\n footerAction={{\n testId: \"add-files-and-images-button\",\n icon: (\n <Paperclip\n className=\"h-4 w-4 shrink-0\"\n strokeWidth={2}\n aria-hidden\n />\n ),\n label: t(I18nKey.CHAT_INTERFACE$ADD_FILES_AND_IMAGES),\n onClick: handleFileIconClick,\n }}\n />\n )}\n\n <SystemMessageModal\n isOpen={systemModalVisible}\n onClose={() => setSystemModalVisible(false)}\n systemMessage={systemMessage || null}\n />\n {skillsModalVisible && (\n <SkillsModal onClose={() => setSkillsModalVisible(false)} />\n )}\n {hooksModalVisible && (\n <HooksModal onClose={() => setHooksModalVisible(false)} />\n )}\n </div>\n );\n}\n"],"mappings":"q3BAmBA,SAAgB,EAAkB,CAChC,sBACA,WAAW,IACc,CACzB,GAAM,CAAE,KAAM,EAAA,eAAe,YAAY,CACnC,CAAE,kBAAmB,EAAA,2BAA2B,CAChD,CAAE,KAAM,GAAiB,EAAA,uBAAuB,CAChD,CAAC,EAAU,GAAe,EAAA,QAAM,SAAS,GAAM,CAE/C,CACJ,uBACA,mBACA,kBACA,qBACA,wBACA,qBACA,wBACA,oBACA,uBACA,gBACA,uBACA,mBACE,EAAA,+BAA+B,CACjC,eAAgB,GAAkB,IAAA,GAClC,gBAAiB,GAAc,iBAC/B,YAAa,GACb,oBAAqB,EACtB,CAAC,CASF,OACE,EAAA,EAAA,MAAC,MAAD,CAAK,UAAU,oBAAf,EACE,EAAA,EAAA,KAAC,SAAD,CACE,KAAK,SACL,UAAW,EAAA,GACT,EAAA,6BACA,2BACA,EACI,kDACA,IAAA,GACJ,GAAY,CAAC,GAAY,yBAC1B,CACD,aAAY,EAAE,EAAA,QAAQ,yBAAyB,CAC/C,gBAAe,EACf,gBAAc,OACd,cAAY,mBACZ,QAvBe,GAA+C,CAClE,EAAM,gBAAgB,CACtB,EAAM,iBAAiB,CACnB,IACJ,EAAa,GAAS,CAAC,EAAK,EAoBd,qBAEV,EAAA,EAAA,KAAC,OAAD,CAAM,UAAU,2DACd,EAAA,EAAA,KAAC,EAAA,KAAD,CAAM,UAAU,6BAA6B,YAAa,EAAK,CAAA,CAC1D,CAAA,CACA,CAAA,CAER,IACC,EAAA,EAAA,KAAC,EAAA,iBAAD,CACE,YAAe,EAAY,GAAM,CACjC,aAAc,EACd,YAAa,EACb,iBAAkB,EACI,uBACL,kBACjB,aAAc,CACZ,OAAQ,8BACR,MACE,EAAA,EAAA,KAAC,EAAA,UAAD,CACE,UAAU,mBACV,YAAa,EACb,cAAA,GACA,CAAA,CAEJ,MAAO,EAAE,EAAA,QAAQ,oCAAoC,CACrD,QAAS,EACV,CACD,CAAA,EAGJ,EAAA,EAAA,KAAC,EAAA,mBAAD,CACE,OAAQ,EACR,YAAe,EAAsB,GAAM,CAC3C,cAAe,GAAiB,KAChC,CAAA,CACD,IACC,EAAA,EAAA,KAAC,EAAA,YAAD,CAAa,YAAe,EAAsB,GAAM,CAAI,CAAA,CAE7D,IACC,EAAA,EAAA,KAAC,EAAA,WAAD,CAAY,YAAe,EAAqB,GAAM,CAAI,CAAA,CAExD"}
|
|
@@ -5,72 +5,73 @@ import { useOptionalConversationId as r } from "../../../hooks/use-conversation-
|
|
|
5
5
|
import { Paperclip as i } from "../../../node_modules/lucide-react/dist/esm/icons/paperclip.js";
|
|
6
6
|
import { Plus as a } from "../../../node_modules/lucide-react/dist/esm/icons/plus.js";
|
|
7
7
|
import { useActiveConversation as o } from "../../../hooks/query/use-active-conversation.js";
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
12
|
-
import {
|
|
13
|
-
import f from "
|
|
14
|
-
import
|
|
8
|
+
import { chatInputIconButtonClassName as s } from "../../../utils/form-control-classes.js";
|
|
9
|
+
import { useConversationNameContextMenu as c } from "../../../hooks/use-conversation-name-context-menu.js";
|
|
10
|
+
import { ToolsContextMenu as l } from "../controls/tools-context-menu.js";
|
|
11
|
+
import { SystemMessageModal as u } from "../conversation-panel/system-message-modal.js";
|
|
12
|
+
import { SkillsModal as d } from "../conversation-panel/skills-modal.js";
|
|
13
|
+
import { HooksModal as f } from "../conversation-panel/hooks-modal.js";
|
|
14
|
+
import p from "react";
|
|
15
|
+
import { jsx as m, jsxs as h } from "react/jsx-runtime";
|
|
15
16
|
//#region src/components/features/chat/chat-add-file-button.tsx
|
|
16
|
-
function
|
|
17
|
-
let { t:
|
|
18
|
-
conversationId:
|
|
19
|
-
executionStatus:
|
|
17
|
+
function g({ handleFileIconClick: g, disabled: _ = !1 }) {
|
|
18
|
+
let { t: v } = e("openhands"), { conversationId: y } = r(), { data: b } = o(), [x, S] = p.useState(!1), { handleShowAgentTools: C, handleShowSkills: w, handleShowHooks: T, systemModalVisible: E, setSystemModalVisible: D, skillsModalVisible: O, setSkillsModalVisible: k, hooksModalVisible: A, setHooksModalVisible: j, systemMessage: M, shouldShowAgentTools: N, shouldShowHooks: P } = c({
|
|
19
|
+
conversationId: y ?? void 0,
|
|
20
|
+
executionStatus: b?.execution_status,
|
|
20
21
|
showOptions: !0,
|
|
21
|
-
onContextMenuToggle:
|
|
22
|
+
onContextMenuToggle: S
|
|
22
23
|
});
|
|
23
|
-
return /* @__PURE__ */
|
|
24
|
+
return /* @__PURE__ */ h("div", {
|
|
24
25
|
className: "relative",
|
|
25
26
|
children: [
|
|
26
|
-
/* @__PURE__ */
|
|
27
|
+
/* @__PURE__ */ m("button", {
|
|
27
28
|
type: "button",
|
|
28
|
-
className: n("relative shrink-0 size-6
|
|
29
|
-
"aria-label":
|
|
30
|
-
"aria-expanded":
|
|
29
|
+
className: n(s, "relative shrink-0 size-6", _ ? "cursor-not-allowed text-[var(--oh-text-subtle)]" : void 0, x && !_ && "text-white bg-white/10"),
|
|
30
|
+
"aria-label": v(t.CHAT_INTERFACE$PLUS_MENU),
|
|
31
|
+
"aria-expanded": x,
|
|
31
32
|
"aria-haspopup": "menu",
|
|
32
33
|
"data-testid": "chat-plus-button",
|
|
33
34
|
onClick: (e) => {
|
|
34
|
-
e.preventDefault(), e.stopPropagation(), !
|
|
35
|
+
e.preventDefault(), e.stopPropagation(), !_ && S((e) => !e);
|
|
35
36
|
},
|
|
36
|
-
disabled:
|
|
37
|
-
children: /* @__PURE__ */
|
|
37
|
+
disabled: _,
|
|
38
|
+
children: /* @__PURE__ */ m("span", {
|
|
38
39
|
className: "flex h-full w-full items-center justify-center",
|
|
39
|
-
children: /* @__PURE__ */
|
|
40
|
+
children: /* @__PURE__ */ m(a, {
|
|
40
41
|
className: "h-[13px] w-[13px] shrink-0",
|
|
41
42
|
strokeWidth: 2
|
|
42
43
|
})
|
|
43
44
|
})
|
|
44
45
|
}),
|
|
45
|
-
|
|
46
|
-
onClose: () =>
|
|
47
|
-
onShowSkills:
|
|
48
|
-
onShowHooks:
|
|
49
|
-
onShowAgentTools:
|
|
50
|
-
shouldShowAgentTools:
|
|
51
|
-
shouldShowHooks:
|
|
46
|
+
x && /* @__PURE__ */ m(l, {
|
|
47
|
+
onClose: () => S(!1),
|
|
48
|
+
onShowSkills: w,
|
|
49
|
+
onShowHooks: T,
|
|
50
|
+
onShowAgentTools: C,
|
|
51
|
+
shouldShowAgentTools: N,
|
|
52
|
+
shouldShowHooks: P,
|
|
52
53
|
footerAction: {
|
|
53
54
|
testId: "add-files-and-images-button",
|
|
54
|
-
icon: /* @__PURE__ */
|
|
55
|
+
icon: /* @__PURE__ */ m(i, {
|
|
55
56
|
className: "h-4 w-4 shrink-0",
|
|
56
57
|
strokeWidth: 2,
|
|
57
58
|
"aria-hidden": !0
|
|
58
59
|
}),
|
|
59
|
-
label:
|
|
60
|
-
onClick:
|
|
60
|
+
label: v(t.CHAT_INTERFACE$ADD_FILES_AND_IMAGES),
|
|
61
|
+
onClick: g
|
|
61
62
|
}
|
|
62
63
|
}),
|
|
63
|
-
/* @__PURE__ */
|
|
64
|
-
isOpen:
|
|
65
|
-
onClose: () =>
|
|
66
|
-
systemMessage:
|
|
64
|
+
/* @__PURE__ */ m(u, {
|
|
65
|
+
isOpen: E,
|
|
66
|
+
onClose: () => D(!1),
|
|
67
|
+
systemMessage: M || null
|
|
67
68
|
}),
|
|
68
|
-
|
|
69
|
-
|
|
69
|
+
O && /* @__PURE__ */ m(d, { onClose: () => k(!1) }),
|
|
70
|
+
A && /* @__PURE__ */ m(f, { onClose: () => j(!1) })
|
|
70
71
|
]
|
|
71
72
|
});
|
|
72
73
|
}
|
|
73
74
|
//#endregion
|
|
74
|
-
export {
|
|
75
|
+
export { g as ChatAddFileButton };
|
|
75
76
|
|
|
76
77
|
//# sourceMappingURL=chat-add-file-button.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chat-add-file-button.js","names":[],"sources":["../../../../src/components/features/chat/chat-add-file-button.tsx"],"sourcesContent":["import React from \"react\";\nimport { Paperclip, Plus } from \"lucide-react\";\nimport { useTranslation } from \"react-i18next\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { cn } from \"#/utils/utils\";\nimport { useOptionalConversationId } from \"#/hooks/use-conversation-id\";\nimport { useActiveConversation } from \"#/hooks/query/use-active-conversation\";\nimport { useConversationNameContextMenu } from \"#/hooks/use-conversation-name-context-menu\";\nimport { ToolsContextMenu } from \"#/components/features/controls/tools-context-menu\";\nimport { SystemMessageModal } from \"#/components/features/conversation-panel/system-message-modal\";\nimport { SkillsModal } from \"#/components/features/conversation-panel/skills-modal\";\nimport { HooksModal } from \"#/components/features/conversation-panel/hooks-modal\";\n\nexport interface ChatAddFileButtonProps {\n handleFileIconClick: () => void;\n disabled?: boolean;\n}\n\nexport function ChatAddFileButton({\n handleFileIconClick,\n disabled = false,\n}: ChatAddFileButtonProps) {\n const { t } = useTranslation(\"openhands\");\n const { conversationId } = useOptionalConversationId();\n const { data: conversation } = useActiveConversation();\n const [menuOpen, setMenuOpen] = React.useState(false);\n\n const {\n handleShowAgentTools,\n handleShowSkills,\n handleShowHooks,\n systemModalVisible,\n setSystemModalVisible,\n skillsModalVisible,\n setSkillsModalVisible,\n hooksModalVisible,\n setHooksModalVisible,\n systemMessage,\n shouldShowAgentTools,\n shouldShowHooks,\n } = useConversationNameContextMenu({\n conversationId: conversationId ?? undefined,\n executionStatus: conversation?.execution_status,\n showOptions: true,\n onContextMenuToggle: setMenuOpen,\n });\n\n const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n event.preventDefault();\n event.stopPropagation();\n if (disabled) return;\n setMenuOpen((open) => !open);\n };\n\n return (\n <div className=\"relative\">\n <button\n type=\"button\"\n className={cn(\n \"relative shrink-0 size-6
|
|
1
|
+
{"version":3,"file":"chat-add-file-button.js","names":[],"sources":["../../../../src/components/features/chat/chat-add-file-button.tsx"],"sourcesContent":["import React from \"react\";\nimport { Paperclip, Plus } from \"lucide-react\";\nimport { useTranslation } from \"react-i18next\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { cn } from \"#/utils/utils\";\nimport { chatInputIconButtonClassName } from \"#/utils/form-control-classes\";\nimport { useOptionalConversationId } from \"#/hooks/use-conversation-id\";\nimport { useActiveConversation } from \"#/hooks/query/use-active-conversation\";\nimport { useConversationNameContextMenu } from \"#/hooks/use-conversation-name-context-menu\";\nimport { ToolsContextMenu } from \"#/components/features/controls/tools-context-menu\";\nimport { SystemMessageModal } from \"#/components/features/conversation-panel/system-message-modal\";\nimport { SkillsModal } from \"#/components/features/conversation-panel/skills-modal\";\nimport { HooksModal } from \"#/components/features/conversation-panel/hooks-modal\";\n\nexport interface ChatAddFileButtonProps {\n handleFileIconClick: () => void;\n disabled?: boolean;\n}\n\nexport function ChatAddFileButton({\n handleFileIconClick,\n disabled = false,\n}: ChatAddFileButtonProps) {\n const { t } = useTranslation(\"openhands\");\n const { conversationId } = useOptionalConversationId();\n const { data: conversation } = useActiveConversation();\n const [menuOpen, setMenuOpen] = React.useState(false);\n\n const {\n handleShowAgentTools,\n handleShowSkills,\n handleShowHooks,\n systemModalVisible,\n setSystemModalVisible,\n skillsModalVisible,\n setSkillsModalVisible,\n hooksModalVisible,\n setHooksModalVisible,\n systemMessage,\n shouldShowAgentTools,\n shouldShowHooks,\n } = useConversationNameContextMenu({\n conversationId: conversationId ?? undefined,\n executionStatus: conversation?.execution_status,\n showOptions: true,\n onContextMenuToggle: setMenuOpen,\n });\n\n const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n event.preventDefault();\n event.stopPropagation();\n if (disabled) return;\n setMenuOpen((open) => !open);\n };\n\n return (\n <div className=\"relative\">\n <button\n type=\"button\"\n className={cn(\n chatInputIconButtonClassName,\n \"relative shrink-0 size-6\",\n disabled\n ? \"cursor-not-allowed text-[var(--oh-text-subtle)]\"\n : undefined,\n menuOpen && !disabled && \"text-white bg-white/10\",\n )}\n aria-label={t(I18nKey.CHAT_INTERFACE$PLUS_MENU)}\n aria-expanded={menuOpen}\n aria-haspopup=\"menu\"\n data-testid=\"chat-plus-button\"\n onClick={handleClick}\n disabled={disabled}\n >\n <span className=\"flex h-full w-full items-center justify-center\">\n <Plus className=\"h-[13px] w-[13px] shrink-0\" strokeWidth={2} />\n </span>\n </button>\n\n {menuOpen && (\n <ToolsContextMenu\n onClose={() => setMenuOpen(false)}\n onShowSkills={handleShowSkills}\n onShowHooks={handleShowHooks}\n onShowAgentTools={handleShowAgentTools}\n shouldShowAgentTools={shouldShowAgentTools}\n shouldShowHooks={shouldShowHooks}\n footerAction={{\n testId: \"add-files-and-images-button\",\n icon: (\n <Paperclip\n className=\"h-4 w-4 shrink-0\"\n strokeWidth={2}\n aria-hidden\n />\n ),\n label: t(I18nKey.CHAT_INTERFACE$ADD_FILES_AND_IMAGES),\n onClick: handleFileIconClick,\n }}\n />\n )}\n\n <SystemMessageModal\n isOpen={systemModalVisible}\n onClose={() => setSystemModalVisible(false)}\n systemMessage={systemMessage || null}\n />\n {skillsModalVisible && (\n <SkillsModal onClose={() => setSkillsModalVisible(false)} />\n )}\n {hooksModalVisible && (\n <HooksModal onClose={() => setHooksModalVisible(false)} />\n )}\n </div>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;AAmBA,SAAgB,EAAkB,EAChC,wBACA,cAAW,MACc;CACzB,IAAM,EAAE,SAAM,EAAe,YAAY,EACnC,EAAE,sBAAmB,GAA2B,EAChD,EAAE,MAAM,MAAiB,GAAuB,EAChD,CAAC,GAAU,KAAe,EAAM,SAAS,GAAM,EAE/C,EACJ,yBACA,qBACA,oBACA,uBACA,0BACA,uBACA,0BACA,sBACA,yBACA,kBACA,yBACA,uBACE,EAA+B;EACjC,gBAAgB,KAAkB,KAAA;EAClC,iBAAiB,GAAc;EAC/B,aAAa;EACb,qBAAqB;EACtB,CAAC;AASF,QACE,kBAAC,OAAD;EAAK,WAAU;YAAf;GACE,kBAAC,UAAD;IACE,MAAK;IACL,WAAW,EACT,GACA,4BACA,IACI,oDACA,KAAA,GACJ,KAAY,CAAC,KAAY,yBAC1B;IACD,cAAY,EAAE,EAAQ,yBAAyB;IAC/C,iBAAe;IACf,iBAAc;IACd,eAAY;IACZ,UAvBe,MAA+C;AAClE,OAAM,gBAAgB,EACtB,EAAM,iBAAiB,EACnB,MACJ,GAAa,MAAS,CAAC,EAAK;;IAoBd;cAEV,kBAAC,QAAD;KAAM,WAAU;eACd,kBAAC,GAAD;MAAM,WAAU;MAA6B,aAAa;MAAK,CAAA;KAC1D,CAAA;IACA,CAAA;GAER,KACC,kBAAC,GAAD;IACE,eAAe,EAAY,GAAM;IACjC,cAAc;IACd,aAAa;IACb,kBAAkB;IACI;IACL;IACjB,cAAc;KACZ,QAAQ;KACR,MACE,kBAAC,GAAD;MACE,WAAU;MACV,aAAa;MACb,eAAA;MACA,CAAA;KAEJ,OAAO,EAAE,EAAQ,oCAAoC;KACrD,SAAS;KACV;IACD,CAAA;GAGJ,kBAAC,GAAD;IACE,QAAQ;IACR,eAAe,EAAsB,GAAM;IAC3C,eAAe,KAAiB;IAChC,CAAA;GACD,KACC,kBAAC,GAAD,EAAa,eAAe,EAAsB,GAAM,EAAI,CAAA;GAE7D,KACC,kBAAC,GAAD,EAAY,eAAe,EAAqB,GAAM,EAAI,CAAA;GAExD"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
const e=require(`../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),n=require(`../../../i18n/declaration.cjs`),r=require(`../../../utils/utils.cjs`),i=require(`../../shared/buttons/copy-to-clipboard-button.cjs`),a=require(`../markdown/markdown-renderer.cjs`),o=require(`../../shared/buttons/styled-tooltip.cjs`);let
|
|
1
|
+
const e=require(`../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),n=require(`../../../i18n/declaration.cjs`),r=require(`../../../utils/utils.cjs`),i=require(`../../shared/buttons/copy-to-clipboard-button.cjs`),a=require(`../markdown/markdown-renderer.cjs`),o=require(`../../shared/buttons/styled-tooltip.cjs`),s=require(`../../shared/text-shimmer.cjs`);let c=require(`react`);c=e.__toESM(c,1);let l=require(`react/jsx-runtime`);var u=3,d=24;function f({className:e}){return(0,l.jsxs)(`svg`,{xmlns:`http://www.w3.org/2000/svg`,viewBox:`0 0 24 24`,fill:`none`,"aria-hidden":!0,className:e,children:[(0,l.jsx)(`circle`,{cx:`12`,cy:`12`,r:`10`,className:`fill-[var(--oh-foreground)] transition-colors duration-150 group-hover:fill-[var(--oh-text-secondary)]`}),(0,l.jsx)(`rect`,{x:`9`,y:`9`,width:`6`,height:`6`,rx:`1`,className:`fill-[var(--oh-color-tertiary)]`})]})}var p={p:({children:e})=>(0,l.jsx)(`p`,{className:`m-0 leading-6`,children:e})};function m({message:e,isHovering:i,isExpanded:o,onTruncatableChange:s}){let{t:f}=t.useTranslation(`openhands`),m=c.default.useRef(null),[h,g]=c.default.useState(!1);c.default.useLayoutEffect(()=>{let t=m.current;if(!t||o){g(!1),s(!1);return}let n=()=>{let n=Number.parseFloat(getComputedStyle(t).lineHeight),r=u*(Number.isFinite(n)&&n>0?n:d),i=(e.match(/\n/g)??[]).length,a=t.scrollHeight>r+1||i>=u||e.trim().length>220;g(e=>(e!==a&&s(a),a))};n();let r=new ResizeObserver(n);return r.observe(t),()=>r.disconnect()},[e,o,s]);let _=h&&!o;return(0,l.jsxs)(`div`,{className:`relative min-w-0`,children:[(0,l.jsx)(`div`,{ref:m,className:r.cn(`text-sm leading-6 whitespace-normal [word-break:break-word]`,_&&`line-clamp-3`),children:(0,l.jsx)(a.MarkdownRenderer,{includeStandard:!0,includeHeadings:!0,components:p,children:e})}),_?(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(`div`,{"aria-hidden":!0,"data-testid":`chat-message-truncation-gradient`,className:`pointer-events-none absolute inset-x-0 bottom-0 h-10 bg-gradient-to-t from-tertiary to-transparent`}),(0,l.jsx)(`span`,{"data-testid":`chat-message-view-more`,className:r.cn(`pointer-events-none absolute bottom-1 left-1/2 z-10 inline-flex -translate-x-1/2 items-center rounded-full border border-[var(--oh-border-subtle)] bg-[var(--oh-surface-raised)] px-2.5 py-0.5 text-xs font-normal text-[var(--oh-foreground)] transition-opacity duration-150`,i?`opacity-100`:`opacity-0`),children:f(n.I18nKey.COMMON$VIEW_MORE)})]}):null]})}function h({type:e,message:u,children:h,actions:g,isFromPlanningAgent:_=!1,pendingStatus:v,onRetry:y,onStop:b}){let{t:x}=t.useTranslation(`openhands`),[S,C]=c.default.useState(!1),[w,T]=c.default.useState(!1),[E,D]=c.default.useState(!1),[O,k]=c.default.useState(!1),[A,j]=c.default.useState(!0),M=c.default.useRef(null);c.default.useEffect(()=>{D(!1)},[u]);let N=async()=>{await navigator.clipboard.writeText(u),T(!0)};c.default.useEffect(()=>{let e;return w&&(e=setTimeout(()=>{T(!1)},2e3)),()=>{clearTimeout(e)}},[w]);let P=e===`user`&&(v===`error`||v===`sending`),F=v===`sending`&&b!=null,I=F&&S,L=e===`user`&&v==null,R=L&&O&&!E,z=c.default.Children.count(h)>0;c.default.useLayoutEffect(()=>{if(!F||L)return;let e=M.current;if(!e)return;let t=()=>{let t=Number.parseFloat(getComputedStyle(e).lineHeight),n=Number.isFinite(t)&&t>0?t:d;j(e.scrollHeight<=n+1)};t();let n=new ResizeObserver(t);return n.observe(e),()=>n.disconnect()},[u,F,L]);let B=L?(0,l.jsx)(m,{message:u,isHovering:S,isExpanded:E,onTruncatableChange:k}):(0,l.jsx)(`div`,{ref:M,className:`min-w-0 text-sm leading-6 whitespace-normal [word-break:break-word]`,children:(0,l.jsx)(a.MarkdownRenderer,{includeStandard:!0,includeHeadings:!0,components:p,children:u})}),V=(0,l.jsxs)(`article`,{"data-testid":`${e}-message`,"data-pending-status":v,onMouseEnter:()=>C(!0),onMouseLeave:()=>C(!1),className:r.cn(`rounded-xl relative w-fit max-w-full flex flex-col`,z&&`gap-2`,e===`user`&&`mt-6 bg-tertiary self-end px-4 py-2.5`,e===`agent`&&`mt-6 w-full max-w-full bg-transparent`,_&&e===`agent`&&`border border-[#597ff4] bg-tertiary p-4 mt-2`,v===`error`&&`border border-[var(--oh-status-error)]/40`,!P&&`last:mb-4`),children:[(0,l.jsxs)(`div`,{className:r.cn(`absolute -top-2.5 -right-2.5 z-10`,!S||v===`sending`?`hidden`:`flex`,`items-center gap-1`),onClick:e=>e.stopPropagation(),children:[g?.map((e,t)=>e.tooltip?(0,l.jsx)(o.StyledTooltip,{content:e.tooltip,placement:`top`,children:(0,l.jsx)(`button`,{type:`button`,onClick:e.onClick,className:`button-base p-1 cursor-pointer`,"aria-label":e.tooltip,children:e.icon})},t):(0,l.jsx)(`button`,{type:`button`,onClick:e.onClick,className:`button-base p-1 cursor-pointer`,"aria-label":`Action ${t+1}`,children:e.icon},t)),(0,l.jsx)(i.CopyToClipboardButton,{isHidden:!S,isDisabled:w,onClick:N,mode:w?`copied`:`copy`})]}),B,F?(0,l.jsx)(`button`,{type:`button`,onClick:e=>{e.stopPropagation(),b?.()},"data-testid":`chat-message-stop`,"aria-label":x(n.I18nKey.BUTTON$STOP),"aria-hidden":!I,tabIndex:I?0:-1,className:r.cn(`group absolute z-10 inline-flex h-7 w-7 cursor-pointer items-center justify-center rounded-full bg-[var(--oh-color-tertiary)] text-[var(--oh-foreground)] transition-opacity duration-150`,A?`right-3 top-1/2 -translate-y-1/2`:`right-3 bottom-2.5`,I?`opacity-100`:`pointer-events-none opacity-0`),children:(0,l.jsx)(f,{className:`block h-7 w-7 max-w-none`})}):null,R?(0,l.jsx)(`button`,{type:`button`,"data-testid":`chat-message-expand`,"aria-expanded":!1,"aria-label":x(n.I18nKey.COMMON$VIEW_MORE),className:`absolute inset-0 z-[1] cursor-pointer rounded-xl border-0 bg-transparent p-0`,onClick:()=>D(!0)}):null,h]});return e===`user`&&v===`error`?(0,l.jsxs)(`div`,{className:`flex w-fit max-w-full flex-col items-end gap-1.5 self-end last:mb-4`,children:[V,(0,l.jsxs)(`div`,{role:`alert`,"data-testid":`chat-message-error`,className:`flex items-center gap-2 text-xs text-[var(--oh-status-error)]`,children:[(0,l.jsx)(`span`,{children:x(n.I18nKey.CHAT_INTERFACE$MESSAGE_SEND_FAILED)}),y?(0,l.jsx)(`button`,{type:`button`,onClick:y,className:`cursor-pointer rounded-md border border-[var(--oh-border)] px-2 py-1 text-xs font-normal text-[var(--oh-foreground)] hover:bg-[var(--oh-interactive-hover)]`,"data-testid":`chat-message-retry`,children:x(n.I18nKey.CHAT_INTERFACE$MESSAGE_RETRY)}):null]})]}):e===`user`&&v===`sending`?(0,l.jsxs)(`div`,{className:`flex w-full max-w-full flex-col last:mb-4`,children:[V,(0,l.jsx)(`div`,{className:`my-1 w-full py-1 text-sm`,children:(0,l.jsx)(s.TextShimmer,{as:`p`,role:`status`,"aria-live":`polite`,"data-testid":`chat-message-sending`,className:`block w-full text-sm font-normal`,duration:1,spread:2,children:x(n.I18nKey.CHAT_INTERFACE$MESSAGE_SENDING)})})]}):V}exports.ChatMessage=h;
|
|
2
2
|
//# sourceMappingURL=chat-message.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chat-message.cjs","names":[],"sources":["../../../../src/components/features/chat/chat-message.tsx"],"sourcesContent":["import React from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { cn } from \"#/utils/utils\";\nimport { CopyToClipboardButton } from \"#/components/shared/buttons/copy-to-clipboard-button\";\nimport type { SourceType } from \"#/types/agent-server/core/base/common\";\nimport { StyledTooltip } from \"#/components/shared/buttons/styled-tooltip\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { MarkdownRenderer } from \"../markdown/markdown-renderer\";\n\nexport type ChatMessagePendingStatus = \"sending\" | \"error\";\n\ninterface ChatMessageProps {\n type: SourceType;\n message: string;\n actions?: Array<{\n icon: React.ReactNode;\n onClick: () => void;\n tooltip?: string;\n }>;\n isFromPlanningAgent?: boolean;\n pendingStatus?: ChatMessagePendingStatus;\n onRetry?: () => void;\n}\n\nexport function ChatMessage({\n type,\n message,\n children,\n actions,\n isFromPlanningAgent = false,\n pendingStatus,\n onRetry,\n}: React.PropsWithChildren<ChatMessageProps>) {\n const { t } = useTranslation(\"openhands\");\n const [isHovering, setIsHovering] = React.useState(false);\n const [isCopy, setIsCopy] = React.useState(false);\n\n const handleCopyToClipboard = async () => {\n await navigator.clipboard.writeText(message);\n setIsCopy(true);\n };\n\n React.useEffect(() => {\n let timeout: NodeJS.Timeout;\n\n if (isCopy) {\n timeout = setTimeout(() => {\n setIsCopy(false);\n }, 2000);\n }\n\n return () => {\n clearTimeout(timeout);\n };\n }, [isCopy]);\n\n return (\n <article\n data-testid={`${type}-message`}\n data-pending-status={pendingStatus}\n onMouseEnter={() => setIsHovering(true)}\n onMouseLeave={() => setIsHovering(false)}\n className={cn(\n \"rounded-xl relative w-fit max-w-full last:mb-4\",\n \"flex flex-col gap-2\",\n type === \"user\" && \"p-4 bg-tertiary self-end\",\n type === \"agent\" && \"mt-6 w-full max-w-full bg-transparent\",\n isFromPlanningAgent &&\n type === \"agent\" &&\n \"border border-[#597ff4] bg-tertiary p-4 mt-2\",\n pendingStatus === \"sending\" && \"opacity-60\",\n pendingStatus === \"error\" && \"border border-status-fail-border\",\n )}\n >\n <div\n className={cn(\n \"absolute -top-2.5 -right-2.5\",\n !isHovering ? \"hidden\" : \"flex\",\n \"items-center gap-1\",\n )}\n >\n {actions?.map((action, index) =>\n action.tooltip ? (\n <StyledTooltip key={index} content={action.tooltip} placement=\"top\">\n <button\n type=\"button\"\n onClick={action.onClick}\n className=\"button-base p-1 cursor-pointer\"\n aria-label={action.tooltip}\n >\n {action.icon}\n </button>\n </StyledTooltip>\n ) : (\n <button\n key={index}\n type=\"button\"\n onClick={action.onClick}\n className=\"button-base p-1 cursor-pointer\"\n aria-label={`Action ${index + 1}`}\n >\n {action.icon}\n </button>\n ),\n )}\n\n <CopyToClipboardButton\n isHidden={!isHovering}\n isDisabled={isCopy}\n onClick={handleCopyToClipboard}\n mode={isCopy ? \"copied\" : \"copy\"}\n />\n </div>\n\n <div className=\"text-sm whitespace-normal [word-break:break-word]\">\n <MarkdownRenderer includeStandard includeHeadings>\n {message}\n </MarkdownRenderer>\n </div>\n\n {pendingStatus === \"sending\" && (\n <span\n role=\"status\"\n aria-live=\"polite\"\n data-testid=\"chat-message-sending\"\n className=\"self-end text-xs italic text-content-muted\"\n >\n {t(I18nKey.CHAT_INTERFACE$MESSAGE_SENDING)}\n </span>\n )}\n\n {pendingStatus === \"error\" && (\n <span\n role=\"alert\"\n data-testid=\"chat-message-error\"\n className=\"self-end text-xs text-status-fail-text\"\n >\n {t(I18nKey.CHAT_INTERFACE$MESSAGE_SEND_FAILED)}{\" \"}\n {onRetry && (\n <button\n type=\"button\"\n onClick={onRetry}\n className=\"underline cursor-pointer\"\n data-testid=\"chat-message-retry\"\n >\n {t(I18nKey.CHAT_INTERFACE$MESSAGE_RETRY)}\n </button>\n )}\n </span>\n )}\n\n {children}\n </article>\n );\n}\n"],"mappings":"scAwBA,SAAgB,EAAY,CAC1B,OACA,UACA,WACA,UACA,sBAAsB,GACtB,gBACA,WAC4C,CAC5C,GAAM,CAAE,KAAM,EAAA,eAAe,YAAY,CACnC,CAAC,EAAY,GAAiB,EAAA,QAAM,SAAS,GAAM,CACnD,CAAC,EAAQ,GAAa,EAAA,QAAM,SAAS,GAAM,CAqBjD,OAdA,EAAA,QAAM,cAAgB,CACpB,IAAI,EAQJ,OANI,IACF,EAAU,eAAiB,CACzB,EAAU,GAAM,EACf,IAAK,MAGG,CACX,aAAa,EAAQ,GAEtB,CAAC,EAAO,CAAC,EAGV,EAAA,EAAA,MAAC,UAAD,CACE,cAAa,GAAG,EAAK,UACrB,sBAAqB,EACrB,iBAAoB,EAAc,GAAK,CACvC,iBAAoB,EAAc,GAAM,CACxC,UAAW,EAAA,GACT,iDACA,sBACA,IAAS,QAAU,2BACnB,IAAS,SAAW,wCACpB,GACE,IAAS,SACT,+CACF,IAAkB,WAAa,aAC/B,IAAkB,SAAW,mCAC9B,UAfH,EAiBE,EAAA,EAAA,MAAC,MAAD,CACE,UAAW,EAAA,GACT,+BACC,EAAwB,OAAX,SACd,qBACD,UALH,CAOG,GAAS,KAAK,EAAQ,IACrB,EAAO,SACL,EAAA,EAAA,KAAC,EAAA,cAAD,CAA2B,QAAS,EAAO,QAAS,UAAU,gBAC5D,EAAA,EAAA,KAAC,SAAD,CACE,KAAK,SACL,QAAS,EAAO,QAChB,UAAU,iCACV,aAAY,EAAO,iBAElB,EAAO,KACD,CAAA,CACK,CATI,EASJ,EAEhB,EAAA,EAAA,KAAC,SAAD,CAEE,KAAK,SACL,QAAS,EAAO,QAChB,UAAU,iCACV,aAAY,UAAU,EAAQ,aAE7B,EAAO,KACD,CAPF,EAOE,CAEZ,EAED,EAAA,EAAA,KAAC,EAAA,sBAAD,CACE,SAAU,CAAC,EACX,WAAY,EACZ,QAAS,SAxEyB,CACxC,MAAM,UAAU,UAAU,UAAU,EAAQ,CAC5C,EAAU,GAAK,EAuET,KAAM,EAAS,SAAW,OAC1B,CAAA,CACE,IAEN,EAAA,EAAA,KAAC,MAAD,CAAK,UAAU,8DACb,EAAA,EAAA,KAAC,EAAA,iBAAD,CAAkB,gBAAA,GAAgB,gBAAA,YAC/B,EACgB,CAAA,CACf,CAAA,CAEL,IAAkB,YACjB,EAAA,EAAA,KAAC,OAAD,CACE,KAAK,SACL,YAAU,SACV,cAAY,uBACZ,UAAU,sDAET,EAAE,EAAA,QAAQ,+BAA+B,CACrC,CAAA,CAGR,IAAkB,UACjB,EAAA,EAAA,MAAC,OAAD,CACE,KAAK,QACL,cAAY,qBACZ,UAAU,kDAHZ,CAKG,EAAE,EAAA,QAAQ,mCAAmC,CAAE,IAC/C,IACC,EAAA,EAAA,KAAC,SAAD,CACE,KAAK,SACL,QAAS,EACT,UAAU,2BACV,cAAY,8BAEX,EAAE,EAAA,QAAQ,6BAA6B,CACjC,CAAA,CAEN,GAGR,EACO"}
|
|
1
|
+
{"version":3,"file":"chat-message.cjs","names":[],"sources":["../../../../src/components/features/chat/chat-message.tsx"],"sourcesContent":["import React from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { cn } from \"#/utils/utils\";\nimport { CopyToClipboardButton } from \"#/components/shared/buttons/copy-to-clipboard-button\";\nimport type { SourceType } from \"#/types/agent-server/core/base/common\";\nimport { StyledTooltip } from \"#/components/shared/buttons/styled-tooltip\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { TextShimmer } from \"#/components/shared/text-shimmer\";\nimport { MarkdownRenderer } from \"../markdown/markdown-renderer\";\n\nexport type ChatMessagePendingStatus = \"sending\" | \"error\";\n\nconst USER_MESSAGE_MAX_LINES = 3;\nconst USER_MESSAGE_LINE_HEIGHT_PX = 24;\n\nfunction PendingStopIcon({ className }: { className?: string }) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n aria-hidden\n className={className}\n >\n <circle\n cx=\"12\"\n cy=\"12\"\n r=\"10\"\n className=\"fill-[var(--oh-foreground)] transition-colors duration-150 group-hover:fill-[var(--oh-text-secondary)]\"\n />\n <rect\n x=\"9\"\n y=\"9\"\n width=\"6\"\n height=\"6\"\n rx=\"1\"\n className=\"fill-[var(--oh-color-tertiary)]\"\n />\n </svg>\n );\n}\n\nconst chatBubbleMarkdownComponents = {\n p: ({ children }: React.ComponentProps<\"p\">) => (\n <p className=\"m-0 leading-6\">{children}</p>\n ),\n};\n\nfunction UserMessageBody({\n message,\n isHovering,\n isExpanded,\n onTruncatableChange,\n}: {\n message: string;\n isHovering: boolean;\n isExpanded: boolean;\n onTruncatableChange: (truncatable: boolean) => void;\n}) {\n const { t } = useTranslation(\"openhands\");\n const contentRef = React.useRef<HTMLDivElement>(null);\n const [isTruncatable, setIsTruncatable] = React.useState(false);\n\n React.useLayoutEffect(() => {\n const content = contentRef.current;\n if (!content || isExpanded) {\n setIsTruncatable(false);\n onTruncatableChange(false);\n return undefined;\n }\n\n const measure = () => {\n const lineHeight = Number.parseFloat(\n getComputedStyle(content).lineHeight,\n );\n const linePx =\n Number.isFinite(lineHeight) && lineHeight > 0\n ? lineHeight\n : USER_MESSAGE_LINE_HEIGHT_PX;\n const maxHeight = USER_MESSAGE_MAX_LINES * linePx;\n const newlineCount = (message.match(/\\n/g) ?? []).length;\n\n const truncatable =\n content.scrollHeight > maxHeight + 1 ||\n newlineCount >= USER_MESSAGE_MAX_LINES ||\n message.trim().length > 220;\n\n setIsTruncatable((previous) => {\n if (previous !== truncatable) {\n onTruncatableChange(truncatable);\n }\n return truncatable;\n });\n };\n\n measure();\n\n const observer = new ResizeObserver(measure);\n observer.observe(content);\n\n return () => observer.disconnect();\n }, [message, isExpanded, onTruncatableChange]);\n\n const isCollapsed = isTruncatable && !isExpanded;\n\n return (\n <div className=\"relative min-w-0\">\n <div\n ref={contentRef}\n className={cn(\n \"text-sm leading-6 whitespace-normal [word-break:break-word]\",\n isCollapsed && \"line-clamp-3\",\n )}\n >\n <MarkdownRenderer\n includeStandard\n includeHeadings\n components={chatBubbleMarkdownComponents}\n >\n {message}\n </MarkdownRenderer>\n </div>\n\n {isCollapsed ? (\n <>\n <div\n aria-hidden\n data-testid=\"chat-message-truncation-gradient\"\n className=\"pointer-events-none absolute inset-x-0 bottom-0 h-10 bg-gradient-to-t from-tertiary to-transparent\"\n />\n <span\n data-testid=\"chat-message-view-more\"\n className={cn(\n \"pointer-events-none absolute bottom-1 left-1/2 z-10 inline-flex -translate-x-1/2 items-center rounded-full border border-[var(--oh-border-subtle)] bg-[var(--oh-surface-raised)] px-2.5 py-0.5 text-xs font-normal text-[var(--oh-foreground)] transition-opacity duration-150\",\n isHovering ? \"opacity-100\" : \"opacity-0\",\n )}\n >\n {t(I18nKey.COMMON$VIEW_MORE)}\n </span>\n </>\n ) : null}\n </div>\n );\n}\n\ninterface ChatMessageProps {\n type: SourceType;\n message: string;\n actions?: Array<{\n icon: React.ReactNode;\n onClick: () => void;\n tooltip?: string;\n }>;\n isFromPlanningAgent?: boolean;\n pendingStatus?: ChatMessagePendingStatus;\n onRetry?: () => void;\n onStop?: () => void;\n}\n\nexport function ChatMessage({\n type,\n message,\n children,\n actions,\n isFromPlanningAgent = false,\n pendingStatus,\n onRetry,\n onStop,\n}: React.PropsWithChildren<ChatMessageProps>) {\n const { t } = useTranslation(\"openhands\");\n const [isHovering, setIsHovering] = React.useState(false);\n const [isCopy, setIsCopy] = React.useState(false);\n const [isExpanded, setIsExpanded] = React.useState(false);\n const [isTruncatable, setIsTruncatable] = React.useState(false);\n const [isSingleLinePendingMessage, setIsSingleLinePendingMessage] =\n React.useState(true);\n const pendingMessageContentRef = React.useRef<HTMLDivElement>(null);\n\n React.useEffect(() => {\n setIsExpanded(false);\n }, [message]);\n\n const handleCopyToClipboard = async () => {\n await navigator.clipboard.writeText(message);\n setIsCopy(true);\n };\n\n React.useEffect(() => {\n let timeout: NodeJS.Timeout;\n\n if (isCopy) {\n timeout = setTimeout(() => {\n setIsCopy(false);\n }, 2000);\n }\n\n return () => {\n clearTimeout(timeout);\n };\n }, [isCopy]);\n\n const isPendingUserMessage =\n type === \"user\" &&\n (pendingStatus === \"error\" || pendingStatus === \"sending\");\n const canStopPendingMessage = pendingStatus === \"sending\" && onStop != null;\n const showStopButton = canStopPendingMessage && isHovering;\n const useTruncatedUserBody = type === \"user\" && pendingStatus == null;\n const isCollapsed = useTruncatedUserBody && isTruncatable && !isExpanded;\n const hasBubbleChildren = React.Children.count(children) > 0;\n\n React.useLayoutEffect(() => {\n if (!canStopPendingMessage || useTruncatedUserBody) {\n return undefined;\n }\n\n const content = pendingMessageContentRef.current;\n if (!content) {\n return undefined;\n }\n\n const measure = () => {\n const lineHeight = Number.parseFloat(\n getComputedStyle(content).lineHeight,\n );\n const linePx =\n Number.isFinite(lineHeight) && lineHeight > 0\n ? lineHeight\n : USER_MESSAGE_LINE_HEIGHT_PX;\n\n setIsSingleLinePendingMessage(content.scrollHeight <= linePx + 1);\n };\n\n measure();\n\n const observer = new ResizeObserver(measure);\n observer.observe(content);\n\n return () => observer.disconnect();\n }, [message, canStopPendingMessage, useTruncatedUserBody]);\n\n const messageContent = useTruncatedUserBody ? (\n <UserMessageBody\n message={message}\n isHovering={isHovering}\n isExpanded={isExpanded}\n onTruncatableChange={setIsTruncatable}\n />\n ) : (\n <div\n ref={pendingMessageContentRef}\n className=\"min-w-0 text-sm leading-6 whitespace-normal [word-break:break-word]\"\n >\n <MarkdownRenderer\n includeStandard\n includeHeadings\n components={chatBubbleMarkdownComponents}\n >\n {message}\n </MarkdownRenderer>\n </div>\n );\n\n const renderedMessageContent = messageContent;\n\n const messageBubble = (\n <article\n data-testid={`${type}-message`}\n data-pending-status={pendingStatus}\n onMouseEnter={() => setIsHovering(true)}\n onMouseLeave={() => setIsHovering(false)}\n className={cn(\n \"rounded-xl relative w-fit max-w-full flex flex-col\",\n hasBubbleChildren && \"gap-2\",\n type === \"user\" && \"mt-6 bg-tertiary self-end px-4 py-2.5\",\n type === \"agent\" && \"mt-6 w-full max-w-full bg-transparent\",\n isFromPlanningAgent &&\n type === \"agent\" &&\n \"border border-[#597ff4] bg-tertiary p-4 mt-2\",\n pendingStatus === \"error\" &&\n \"border border-[var(--oh-status-error)]/40\",\n !isPendingUserMessage && \"last:mb-4\",\n )}\n >\n <div\n className={cn(\n \"absolute -top-2.5 -right-2.5 z-10\",\n !isHovering || pendingStatus === \"sending\" ? \"hidden\" : \"flex\",\n \"items-center gap-1\",\n )}\n onClick={(event) => event.stopPropagation()}\n >\n {actions?.map((action, index) =>\n action.tooltip ? (\n <StyledTooltip key={index} content={action.tooltip} placement=\"top\">\n <button\n type=\"button\"\n onClick={action.onClick}\n className=\"button-base p-1 cursor-pointer\"\n aria-label={action.tooltip}\n >\n {action.icon}\n </button>\n </StyledTooltip>\n ) : (\n <button\n key={index}\n type=\"button\"\n onClick={action.onClick}\n className=\"button-base p-1 cursor-pointer\"\n aria-label={`Action ${index + 1}`}\n >\n {action.icon}\n </button>\n ),\n )}\n\n <CopyToClipboardButton\n isHidden={!isHovering}\n isDisabled={isCopy}\n onClick={handleCopyToClipboard}\n mode={isCopy ? \"copied\" : \"copy\"}\n />\n </div>\n\n {renderedMessageContent}\n\n {canStopPendingMessage ? (\n <button\n type=\"button\"\n onClick={(event) => {\n event.stopPropagation();\n onStop?.();\n }}\n data-testid=\"chat-message-stop\"\n aria-label={t(I18nKey.BUTTON$STOP)}\n aria-hidden={!showStopButton}\n tabIndex={showStopButton ? 0 : -1}\n className={cn(\n \"group absolute z-10 inline-flex h-7 w-7 cursor-pointer items-center justify-center rounded-full bg-[var(--oh-color-tertiary)] text-[var(--oh-foreground)] transition-opacity duration-150\",\n isSingleLinePendingMessage\n ? \"right-3 top-1/2 -translate-y-1/2\"\n : \"right-3 bottom-2.5\",\n showStopButton ? \"opacity-100\" : \"pointer-events-none opacity-0\",\n )}\n >\n <PendingStopIcon className=\"block h-7 w-7 max-w-none\" />\n </button>\n ) : null}\n\n {isCollapsed ? (\n <button\n type=\"button\"\n data-testid=\"chat-message-expand\"\n aria-expanded={false}\n aria-label={t(I18nKey.COMMON$VIEW_MORE)}\n className=\"absolute inset-0 z-[1] cursor-pointer rounded-xl border-0 bg-transparent p-0\"\n onClick={() => setIsExpanded(true)}\n />\n ) : null}\n\n {children}\n </article>\n );\n\n if (type === \"user\" && pendingStatus === \"error\") {\n return (\n <div className=\"flex w-fit max-w-full flex-col items-end gap-1.5 self-end last:mb-4\">\n {messageBubble}\n <div\n role=\"alert\"\n data-testid=\"chat-message-error\"\n className=\"flex items-center gap-2 text-xs text-[var(--oh-status-error)]\"\n >\n <span>{t(I18nKey.CHAT_INTERFACE$MESSAGE_SEND_FAILED)}</span>\n {onRetry ? (\n <button\n type=\"button\"\n onClick={onRetry}\n className=\"cursor-pointer rounded-md border border-[var(--oh-border)] px-2 py-1 text-xs font-normal text-[var(--oh-foreground)] hover:bg-[var(--oh-interactive-hover)]\"\n data-testid=\"chat-message-retry\"\n >\n {t(I18nKey.CHAT_INTERFACE$MESSAGE_RETRY)}\n </button>\n ) : null}\n </div>\n </div>\n );\n }\n\n if (type === \"user\" && pendingStatus === \"sending\") {\n return (\n <div className=\"flex w-full max-w-full flex-col last:mb-4\">\n {messageBubble}\n <div className=\"my-1 w-full py-1 text-sm\">\n <TextShimmer\n as=\"p\"\n role=\"status\"\n aria-live=\"polite\"\n data-testid=\"chat-message-sending\"\n className=\"block w-full text-sm font-normal\"\n duration={1}\n spread={2}\n >\n {t(I18nKey.CHAT_INTERFACE$MESSAGE_SENDING)}\n </TextShimmer>\n </div>\n </div>\n );\n }\n\n return messageBubble;\n}\n"],"mappings":"ifAYA,IAAM,EAAyB,EACzB,EAA8B,GAEpC,SAAS,EAAgB,CAAE,aAAqC,CAC9D,OACE,EAAA,EAAA,MAAC,MAAD,CACE,MAAM,6BACN,QAAQ,YACR,KAAK,OACL,cAAA,GACW,qBALb,EAOE,EAAA,EAAA,KAAC,SAAD,CACE,GAAG,KACH,GAAG,KACH,EAAE,KACF,UAAU,yGACV,CAAA,EACF,EAAA,EAAA,KAAC,OAAD,CACE,EAAE,IACF,EAAE,IACF,MAAM,IACN,OAAO,IACP,GAAG,IACH,UAAU,kCACV,CAAA,CACE,GAIV,IAAM,EAA+B,CACnC,GAAI,CAAE,eACJ,EAAA,EAAA,KAAC,IAAD,CAAG,UAAU,gBAAiB,WAAa,CAAA,CAE9C,CAED,SAAS,EAAgB,CACvB,UACA,aACA,aACA,uBAMC,CACD,GAAM,CAAE,KAAM,EAAA,eAAe,YAAY,CACnC,EAAa,EAAA,QAAM,OAAuB,KAAK,CAC/C,CAAC,EAAe,GAAoB,EAAA,QAAM,SAAS,GAAM,CAE/D,EAAA,QAAM,oBAAsB,CAC1B,IAAM,EAAU,EAAW,QAC3B,GAAI,CAAC,GAAW,EAAY,CAC1B,EAAiB,GAAM,CACvB,EAAoB,GAAM,CAC1B,OAGF,IAAM,MAAgB,CACpB,IAAM,EAAa,OAAO,WACxB,iBAAiB,EAAQ,CAAC,WAC3B,CAKK,EAAY,GAHhB,OAAO,SAAS,EAAW,EAAI,EAAa,EACxC,EACA,GAEA,GAAgB,EAAQ,MAAM,MAAM,EAAI,EAAE,EAAE,OAE5C,EACJ,EAAQ,aAAe,EAAY,GACnC,GAAgB,GAChB,EAAQ,MAAM,CAAC,OAAS,IAE1B,EAAkB,IACZ,IAAa,GACf,EAAoB,EAAY,CAE3B,GACP,EAGJ,GAAS,CAET,IAAM,EAAW,IAAI,eAAe,EAAQ,CAG5C,OAFA,EAAS,QAAQ,EAAQ,KAEZ,EAAS,YAAY,EACjC,CAAC,EAAS,EAAY,EAAoB,CAAC,CAE9C,IAAM,EAAc,GAAiB,CAAC,EAEtC,OACE,EAAA,EAAA,MAAC,MAAD,CAAK,UAAU,4BAAf,EACE,EAAA,EAAA,KAAC,MAAD,CACE,IAAK,EACL,UAAW,EAAA,GACT,8DACA,GAAe,eAChB,WAED,EAAA,EAAA,KAAC,EAAA,iBAAD,CACE,gBAAA,GACA,gBAAA,GACA,WAAY,WAEX,EACgB,CAAA,CACf,CAAA,CAEL,GACC,EAAA,EAAA,MAAA,EAAA,SAAA,CAAA,SAAA,EACE,EAAA,EAAA,KAAC,MAAD,CACE,cAAA,GACA,cAAY,mCACZ,UAAU,qGACV,CAAA,EACF,EAAA,EAAA,KAAC,OAAD,CACE,cAAY,yBACZ,UAAW,EAAA,GACT,iRACA,EAAa,cAAgB,YAC9B,UAEA,EAAE,EAAA,QAAQ,iBAAiB,CACvB,CAAA,CACN,CAAA,CAAA,CACD,KACA,GAkBV,SAAgB,EAAY,CAC1B,OACA,UACA,WACA,UACA,sBAAsB,GACtB,gBACA,UACA,UAC4C,CAC5C,GAAM,CAAE,KAAM,EAAA,eAAe,YAAY,CACnC,CAAC,EAAY,GAAiB,EAAA,QAAM,SAAS,GAAM,CACnD,CAAC,EAAQ,GAAa,EAAA,QAAM,SAAS,GAAM,CAC3C,CAAC,EAAY,GAAiB,EAAA,QAAM,SAAS,GAAM,CACnD,CAAC,EAAe,GAAoB,EAAA,QAAM,SAAS,GAAM,CACzD,CAAC,EAA4B,GACjC,EAAA,QAAM,SAAS,GAAK,CAChB,EAA2B,EAAA,QAAM,OAAuB,KAAK,CAEnE,EAAA,QAAM,cAAgB,CACpB,EAAc,GAAM,EACnB,CAAC,EAAQ,CAAC,CAEb,IAAM,EAAwB,SAAY,CACxC,MAAM,UAAU,UAAU,UAAU,EAAQ,CAC5C,EAAU,GAAK,EAGjB,EAAA,QAAM,cAAgB,CACpB,IAAI,EAQJ,OANI,IACF,EAAU,eAAiB,CACzB,EAAU,GAAM,EACf,IAAK,MAGG,CACX,aAAa,EAAQ,GAEtB,CAAC,EAAO,CAAC,CAEZ,IAAM,EACJ,IAAS,SACR,IAAkB,SAAW,IAAkB,WAC5C,EAAwB,IAAkB,WAAa,GAAU,KACjE,EAAiB,GAAyB,EAC1C,EAAuB,IAAS,QAAU,GAAiB,KAC3D,EAAc,GAAwB,GAAiB,CAAC,EACxD,EAAoB,EAAA,QAAM,SAAS,MAAM,EAAS,CAAG,EAE3D,EAAA,QAAM,oBAAsB,CAC1B,GAAI,CAAC,GAAyB,EAC5B,OAGF,IAAM,EAAU,EAAyB,QACzC,GAAI,CAAC,EACH,OAGF,IAAM,MAAgB,CACpB,IAAM,EAAa,OAAO,WACxB,iBAAiB,EAAQ,CAAC,WAC3B,CACK,EACJ,OAAO,SAAS,EAAW,EAAI,EAAa,EACxC,EACA,EAEN,EAA8B,EAAQ,cAAgB,EAAS,EAAE,EAGnE,GAAS,CAET,IAAM,EAAW,IAAI,eAAe,EAAQ,CAG5C,OAFA,EAAS,QAAQ,EAAQ,KAEZ,EAAS,YAAY,EACjC,CAAC,EAAS,EAAuB,EAAqB,CAAC,CAwB1D,IAAM,EAtBiB,GACrB,EAAA,EAAA,KAAC,EAAD,CACW,UACG,aACA,aACZ,oBAAqB,EACrB,CAAA,EAEF,EAAA,EAAA,KAAC,MAAD,CACE,IAAK,EACL,UAAU,gFAEV,EAAA,EAAA,KAAC,EAAA,iBAAD,CACE,gBAAA,GACA,gBAAA,GACA,WAAY,WAEX,EACgB,CAAA,CACf,CAAA,CAKF,GACJ,EAAA,EAAA,MAAC,UAAD,CACE,cAAa,GAAG,EAAK,UACrB,sBAAqB,EACrB,iBAAoB,EAAc,GAAK,CACvC,iBAAoB,EAAc,GAAM,CACxC,UAAW,EAAA,GACT,qDACA,GAAqB,QACrB,IAAS,QAAU,wCACnB,IAAS,SAAW,wCACpB,GACE,IAAS,SACT,+CACF,IAAkB,SAChB,4CACF,CAAC,GAAwB,YAC1B,UAhBH,EAkBE,EAAA,EAAA,MAAC,MAAD,CACE,UAAW,EAAA,GACT,oCACA,CAAC,GAAc,IAAkB,UAAY,SAAW,OACxD,qBACD,CACD,QAAU,GAAU,EAAM,iBAAiB,UAN7C,CAQG,GAAS,KAAK,EAAQ,IACrB,EAAO,SACL,EAAA,EAAA,KAAC,EAAA,cAAD,CAA2B,QAAS,EAAO,QAAS,UAAU,gBAC5D,EAAA,EAAA,KAAC,SAAD,CACE,KAAK,SACL,QAAS,EAAO,QAChB,UAAU,iCACV,aAAY,EAAO,iBAElB,EAAO,KACD,CAAA,CACK,CATI,EASJ,EAEhB,EAAA,EAAA,KAAC,SAAD,CAEE,KAAK,SACL,QAAS,EAAO,QAChB,UAAU,iCACV,aAAY,UAAU,EAAQ,aAE7B,EAAO,KACD,CAPF,EAOE,CAEZ,EAED,EAAA,EAAA,KAAC,EAAA,sBAAD,CACE,SAAU,CAAC,EACX,WAAY,EACZ,QAAS,EACT,KAAM,EAAS,SAAW,OAC1B,CAAA,CACE,GAEL,EAEA,GACC,EAAA,EAAA,KAAC,SAAD,CACE,KAAK,SACL,QAAU,GAAU,CAClB,EAAM,iBAAiB,CACvB,KAAU,EAEZ,cAAY,oBACZ,aAAY,EAAE,EAAA,QAAQ,YAAY,CAClC,cAAa,CAAC,EACd,SAAU,EAAiB,EAAI,GAC/B,UAAW,EAAA,GACT,4LACA,EACI,mCACA,qBACJ,EAAiB,cAAgB,gCAClC,WAED,EAAA,EAAA,KAAC,EAAD,CAAiB,UAAU,2BAA6B,CAAA,CACjD,CAAA,CACP,KAEH,GACC,EAAA,EAAA,KAAC,SAAD,CACE,KAAK,SACL,cAAY,sBACZ,gBAAe,GACf,aAAY,EAAE,EAAA,QAAQ,iBAAiB,CACvC,UAAU,+EACV,YAAe,EAAc,GAAK,CAClC,CAAA,CACA,KAEH,EACO,GAiDZ,OA9CI,IAAS,QAAU,IAAkB,SAErC,EAAA,EAAA,MAAC,MAAD,CAAK,UAAU,+EAAf,CACG,GACD,EAAA,EAAA,MAAC,MAAD,CACE,KAAK,QACL,cAAY,qBACZ,UAAU,yEAHZ,EAKE,EAAA,EAAA,KAAC,OAAD,CAAA,SAAO,EAAE,EAAA,QAAQ,mCAAmC,CAAQ,CAAA,CAC3D,GACC,EAAA,EAAA,KAAC,SAAD,CACE,KAAK,SACL,QAAS,EACT,UAAU,8JACV,cAAY,8BAEX,EAAE,EAAA,QAAQ,6BAA6B,CACjC,CAAA,CACP,KACA,GACF,GAIN,IAAS,QAAU,IAAkB,WAErC,EAAA,EAAA,MAAC,MAAD,CAAK,UAAU,qDAAf,CACG,GACD,EAAA,EAAA,KAAC,MAAD,CAAK,UAAU,qCACb,EAAA,EAAA,KAAC,EAAA,YAAD,CACE,GAAG,IACH,KAAK,SACL,YAAU,SACV,cAAY,uBACZ,UAAU,mCACV,SAAU,EACV,OAAQ,WAEP,EAAE,EAAA,QAAQ,+BAA+B,CAC9B,CAAA,CACV,CAAA,CACF,GAIH"}
|
|
@@ -12,6 +12,7 @@ interface ChatMessageProps {
|
|
|
12
12
|
isFromPlanningAgent?: boolean;
|
|
13
13
|
pendingStatus?: ChatMessagePendingStatus;
|
|
14
14
|
onRetry?: () => void;
|
|
15
|
+
onStop?: () => void;
|
|
15
16
|
}
|
|
16
|
-
export declare function ChatMessage({ type, message, children, actions, isFromPlanningAgent, pendingStatus, onRetry, }: React.PropsWithChildren<ChatMessageProps>): import("react/jsx-runtime").JSX.Element;
|
|
17
|
+
export declare function ChatMessage({ type, message, children, actions, isFromPlanningAgent, pendingStatus, onRetry, onStop, }: React.PropsWithChildren<ChatMessageProps>): import("react/jsx-runtime").JSX.Element;
|
|
17
18
|
export {};
|