@openhands/agent-canvas 1.0.0-beta.6 → 1.0.0-beta.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- 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-BAX8OU5C.js +1 -0
- package/build/assets/{acp-route-guard-B2yoBZ_4.js → acp-route-guard-HPk6TV-L.js} +1 -1
- package/build/assets/active-backend-context-BSPE-W72.js +1 -0
- package/build/assets/add-backend-modal-mXKmfMI2.js +1 -0
- package/build/assets/agent-server-client-options-9agOSarV.js +1 -0
- package/build/assets/agent-server-compatibility-B7QStIcH.js +1 -0
- package/build/assets/agent-server-conversation-service.api-B9TUYJon.js +5 -0
- package/build/assets/{agent-settings-CnGSCmK8.js → agent-settings-g3F623RJ.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-BQCNeNVt.js} +1 -1
- package/build/assets/api-key-entry-screen-myuWMqzW.js +1 -0
- package/build/assets/{app-settings-Db9ITeJH.js → app-settings-CCcX8ZEH.js} +1 -1
- package/build/assets/automation-detail-BDHLHSJd.js +1 -0
- package/build/assets/automations-list-CiNtQhq_.js +1 -0
- package/build/assets/back-nav-button-7dQJ2k3O.js +1 -0
- package/build/assets/backend-form-modal-D3bDMO3C.js +1 -0
- package/build/assets/{backend-synced-settings-badge-Dc6c7GT4.js → backend-synced-settings-badge-BkW5evM0.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-DCTulgLO.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-BKhikfYl.js +1 -0
- package/build/assets/conversation-DTn8jN8L.js +19 -0
- package/build/assets/conversation-panel-DfHR42mG.js +1 -0
- package/build/assets/conversation-service.api-B6CkzaKD.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-DShEuLjh.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-DamwL0s0.js +1 -0
- package/build/assets/ellipsis-button-Vh5MvRZa.js +1 -0
- package/build/assets/entry.client-Cn71WM8q.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-CUEmfvGy.js +1 -0
- package/build/assets/{extensions-navigation-BYR8Giqq.js → extensions-navigation-VQ-3umJ7.js} +1 -1
- package/build/assets/file-BTY6Gyy9.js +1 -0
- package/build/assets/files-tab-C47fQEeL.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-BT0aWH-o.js +27 -0
- package/build/assets/git-provider-icon-Pi-Cxpgv.js +1 -0
- package/build/assets/globe-Bzj_0oXT.js +1 -0
- package/build/assets/home-C3k6sFvB.js +1 -0
- package/build/assets/{i18n-CTohRuoO.js → i18n-DET2iOyh.js} +1 -1
- package/build/assets/install-server-modal-6fuq-TU6.js +1 -0
- package/build/assets/launch-DGghLfGx.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-BqyLKgUN.js} +1 -1
- package/build/assets/llm-settings-BKraGtOu.js +1 -0
- package/build/assets/llm-settings-DRQTgOF1.js +1 -0
- package/build/assets/{loading-spinner-BPtYORNK.js → loading-spinner-5GT9q1xy.js} +1 -1
- package/build/assets/manage-backends-modal-CRMwyU0t.js +1 -0
- package/build/assets/manage-workspaces-modal-BYmGD1W7.js +1 -0
- package/build/assets/manifest-99b06a11.js +1 -0
- package/build/assets/{markdown-renderer-DMzf2i4x.js → markdown-renderer-B3IAVfv4.js} +1 -1
- package/build/assets/mcp-CfDRAmPn.js +9 -0
- package/build/assets/messages-Ba1vaw6t.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-DcztJSxT.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-CGNANEcT.js} +1 -1
- package/build/assets/{organization-service.api-DzYTHTYC.js → organization-service.api-BeuMC9QL.js} +1 -1
- package/build/assets/{path-utils-C3bQf6lJ.js → path-utils-z12iCrQO.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-Dte6Vzza.js} +1 -1
- package/build/assets/{profiles-client-D6IkTJof.js → profiles-client-BrqNmaDV.js} +1 -1
- package/build/assets/{providers-Bx6EfrzZ.js → providers-eUyo6pgr.js} +1 -1
- package/build/assets/proxy-BqDMnUY-.js +1 -0
- package/build/assets/{query-client-config-B7u9asM0.js → query-client-config-CRnGSujB.js} +1 -1
- package/build/assets/{recommended-automations-launcher-CgV8FyPK.js → recommended-automations-launcher-D5ADbXao.js} +3 -3
- package/build/assets/{root-dNntxffj.js → root-BmhaEJJ8.js} +2 -2
- package/build/assets/root-Z2VHU4R3.css +1 -0
- package/build/assets/root-layout-CNggm0d8.js +2 -0
- package/build/assets/{sdk-section-page-DOIKvwSL.js → sdk-section-page-CRCRY3PG.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-B9AFn9OE.js +1 -0
- package/build/assets/secrets-settings-0UrKMS60.js +1 -0
- package/build/assets/{server-client-DyAQ3NZ_.js → server-client-DYv_GHPl.js} +1 -1
- package/build/assets/{settings-BYkVX7vW.js → settings-6t6LGW04.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-CR6Ou73o.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-T_Yk1Zfo.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-DwtyDeGh.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-BzccsVej.js} +1 -1
- package/build/assets/sidebar-mobile-menu-toggle-DGlRg6jG.js +1 -0
- package/build/assets/{sidebar-nav-link-BGjiJq-4.js → sidebar-nav-link-dgVb8Fpy.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-DctDrZ8Y.js} +1 -1
- package/build/assets/skills-settings-rvxImDj_.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-RmuaSdhJ.js → terminal-CPYWdo4j.js} +1 -1
- package/build/assets/{terminal-DgQk1Ay6.js → terminal-KldRPIRT.js} +2 -2
- 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-sPgfSkql.js} +1 -1
- package/build/assets/use-agent-settings-schema-B66kGIi_.js +1 -0
- package/build/assets/{use-agent-state-Bkrd1FZq.js → use-agent-state-Dp3pD1h3.js} +1 -1
- package/build/assets/{use-cloud-current-user-id-CvkXFnTT.js → use-cloud-current-user-id-ClKFPjFz.js} +1 -1
- package/build/assets/{use-config-Co1O8-Ey.js → use-config-C9pvb0Sm.js} +1 -1
- package/build/assets/{use-create-conversation-CEgXpkfH.js → use-create-conversation-B-lwTnfE.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-oyC7PFRz.js} +1 -1
- package/build/assets/{use-handle-plan-click-Ckkm5eIY.js → use-handle-plan-click-DP6Rs-YP.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-Bh5JqZUZ.js +1 -0
- package/build/assets/use-runtime-is-ready-BakOUVU-.js +1 -0
- package/build/assets/{use-save-settings-VUrj_QNG.js → use-save-settings-uXXkqvD7.js} +1 -1
- package/build/assets/use-settings-DeO7nvpM.js +1 -0
- package/build/assets/{use-settings-nav-items-1ZvovKSr.js → use-settings-nav-items-BGMFn25b.js} +1 -1
- package/build/assets/{use-skills-DAMLFjKU.js → use-skills-DWIK3l3a.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-DXPtB317.js} +1 -1
- package/build/assets/use-user-conversation-DJen4YIP.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-Cs-TO3fK.js → vendor~home~mcp~automations-list-CZSK-lT2.js} +1 -1
- 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-D8soyAAx.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-C_zHuDx9.js} +1 -1
- package/build/assets/{vscode-tab-DjNArCgY.js → vscode-tab-DH9x7xXS.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 +15 -48
- package/dist/api/agent-server-config.js +25 -69
- 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 +141 -121
- 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/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 +1 -1
- 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 +1 -1
- 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 +65 -6
- 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-6FDbI5dc.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-e-egNUXZ.js +0 -1
- package/build/assets/install-server-modal-DHlbgqVH.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-3bf30d69.js +0 -1
- package/build/assets/mcp-ByeBfdfU.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~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 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cloud-new-conversation-menu.cjs","names":[],"sources":["../../../../src/components/features/conversation-panel/cloud-new-conversation-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { useTranslation } from \"react-i18next\";\n\nimport { useCreateConversation } from \"#/hooks/mutation/use-create-conversation\";\nimport { useNavigation } from \"#/context/navigation-context\";\nimport { useIsCreatingConversation } from \"#/hooks/use-is-creating-conversation\";\nimport { useGitRepositories } from \"#/hooks/query/use-git-repositories\";\nimport { useSearchRepositories } from \"#/hooks/query/use-search-repositories\";\nimport { useUserProviders } from \"#/hooks/use-user-providers\";\nimport { useDebounce } from \"#/hooks/use-debounce\";\nimport { useHomeStore } from \"#/stores/home-store\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { cn } from \"#/utils/utils\";\nimport { GitRepository } from \"#/types/git\";\nimport { Provider } from \"#/types/settings\";\nimport RepoIcon from \"#/icons/repo.svg?react\";\nimport SearchIcon from \"#/icons/search.svg?react\";\nimport { GitProviderIcon } from \"#/components/shared/git-provider-icon\";\nimport { Divider } from \"#/ui/divider\";\nimport { NEW_CONVERSATION_DROPDOWN_SURFACE } from \"./new-conversation-dropdown-styles\";\nimport { usePopoverFixedPlacement } from \"#/hooks/use-popover-fixed-placement\";\n\nexport type CloudNewConversationMenuTriggerProps = {\n onClick: () => void;\n \"aria-expanded\": boolean;\n \"aria-haspopup\": \"menu\";\n disabled?: boolean;\n};\n\nexport interface CloudNewConversationMenuProps {\n trigger: (props: CloudNewConversationMenuTriggerProps) => React.ReactNode;\n className?: string;\n popoverClassName: string;\n popoverTestId?: string;\n useFixedPlacement?: boolean;\n}\n\ninterface RepoListItemProps {\n repo: GitRepository;\n disabled: boolean;\n onSelect: (repo: GitRepository) => void;\n itemClass: string;\n}\n\nfunction RepoListItem({\n repo,\n disabled,\n onSelect,\n itemClass,\n}: RepoListItemProps) {\n return (\n <li>\n <button\n type=\"button\"\n disabled={disabled}\n data-testid=\"launch-repository\"\n data-repo-name={repo.full_name}\n onClick={() => onSelect(repo)}\n className={itemClass}\n >\n <RepoIcon width={14} height={14} className=\"shrink-0\" />\n <span className=\"truncate\">{repo.full_name}</span>\n </button>\n </li>\n );\n}\n\n/**\n * Repository search + launch flow for cloud backends.\n * Shared by the sidebar \"+ New conversation\" control and the conversation\n * panel \"new thread folder\" opener.\n */\nexport function CloudNewConversationMenu({\n trigger,\n className,\n popoverClassName,\n popoverTestId = \"new-conversation-popover\",\n useFixedPlacement = false,\n}: CloudNewConversationMenuProps) {\n const { t } = useTranslation(\"openhands\");\n const { navigate } = useNavigation();\n\n const { providers } = useUserProviders();\n const { lastSelectedProvider, setLastSelectedProvider } = useHomeStore();\n\n const [open, setOpen] = React.useState(false);\n const popoverRef = React.useRef<HTMLDivElement>(null);\n const triggerWrapRef = React.useRef<HTMLSpanElement>(null);\n const fixedBox = usePopoverFixedPlacement(triggerWrapRef, {\n open,\n enabled: useFixedPlacement,\n });\n const [selectedProvider, setSelectedProvider] =\n React.useState<Provider | null>(lastSelectedProvider ?? null);\n const [query, setQuery] = React.useState(\"\");\n const debouncedQuery = useDebounce(query, 300);\n\n React.useEffect(() => {\n if (providers.length === 0) {\n if (selectedProvider !== null) setSelectedProvider(null);\n return;\n }\n if (selectedProvider && providers.includes(selectedProvider)) return;\n const fallback =\n lastSelectedProvider && providers.includes(lastSelectedProvider)\n ? lastSelectedProvider\n : providers[0];\n setSelectedProvider(fallback);\n }, [providers, selectedProvider, lastSelectedProvider]);\n\n const {\n data: repoPages,\n isLoading,\n isError,\n hasNextPage,\n isFetchingNextPage,\n fetchNextPage,\n } = useGitRepositories({ provider: selectedProvider });\n\n const { data: searchResults, isLoading: isSearchLoading } =\n useSearchRepositories(debouncedQuery, selectedProvider);\n\n const allRepositories = React.useMemo(\n () => repoPages?.pages.flatMap((page) => page.items) ?? [],\n [repoPages],\n );\n\n const repositories = debouncedQuery ? (searchResults ?? []) : allRepositories;\n\n const { mutate: createConversation, isPending } = useCreateConversation();\n const isCreatingElsewhere = useIsCreatingConversation();\n const isCreating = isPending || isCreatingElsewhere;\n\n React.useEffect(() => {\n if (!open) return undefined;\n const onDown = (e: MouseEvent) => {\n if (\n popoverRef.current &&\n !popoverRef.current.contains(e.target as Node)\n ) {\n setOpen(false);\n }\n };\n document.addEventListener(\"mousedown\", onDown);\n return () => document.removeEventListener(\"mousedown\", onDown);\n }, [open]);\n\n React.useEffect(() => {\n if (!open) return undefined;\n const onKeyDown = (event: KeyboardEvent) => {\n if (event.key === \"Escape\") setOpen(false);\n };\n window.addEventListener(\"keydown\", onKeyDown);\n return () => window.removeEventListener(\"keydown\", onKeyDown);\n }, [open]);\n\n const launchRepository = (repo: GitRepository) => {\n if (isCreating) return;\n createConversation(\n {\n repository: {\n name: repo.full_name,\n gitProvider: repo.git_provider,\n branch: repo.main_branch ?? \"main\",\n },\n },\n {\n onSuccess: (data) => {\n setOpen(false);\n navigate(`/conversations/${data.conversation_id}`);\n },\n },\n );\n };\n\n const handleProviderChange = (provider: Provider) => {\n setSelectedProvider(provider);\n setLastSelectedProvider(provider);\n setQuery(\"\");\n };\n\n const itemClass = cn(\n \"flex w-full cursor-pointer items-center gap-2 rounded px-2 py-2 text-left text-sm text-white\",\n \"font-normal transition-colors hover:bg-[var(--oh-interactive-hover)]\",\n \"disabled:cursor-not-allowed disabled:opacity-60\",\n );\n\n React.useEffect(() => {\n if (!open) return;\n if (debouncedQuery) return;\n if (!hasNextPage || isFetchingNextPage || isLoading) return;\n if (repositories.length === 0 || repositories.length >= 10) return;\n fetchNextPage();\n }, [\n open,\n debouncedQuery,\n hasNextPage,\n isFetchingNextPage,\n isLoading,\n repositories.length,\n fetchNextPage,\n ]);\n\n const isListLoading = debouncedQuery ? isSearchLoading : isLoading;\n const showLoadMore =\n !debouncedQuery && hasNextPage && repositories.length > 0;\n\n const toggleOpen = React.useCallback(() => {\n setOpen((o) => !o);\n }, []);\n\n const showPopover = open && (!useFixedPlacement || fixedBox !== null);\n\n const fixedStyle: React.CSSProperties | undefined =\n useFixedPlacement && fixedBox\n ? {\n position: \"fixed\",\n top: fixedBox.top,\n left: fixedBox.left,\n width: fixedBox.width,\n }\n : undefined;\n\n return (\n <div\n className={cn(!useFixedPlacement && \"relative\", className)}\n ref={popoverRef}\n >\n <span ref={triggerWrapRef} className=\"inline-flex\">\n {trigger({\n onClick: toggleOpen,\n \"aria-expanded\": open,\n \"aria-haspopup\": \"menu\",\n disabled: isCreating,\n })}\n </span>\n\n {showPopover && (\n <div\n data-testid={popoverTestId}\n className={cn(\n NEW_CONVERSATION_DROPDOWN_SURFACE,\n !useFixedPlacement &&\n cn(\"absolute top-full mt-0\", popoverClassName),\n )}\n style={fixedStyle}\n >\n {providers.length > 1 && (\n <div\n className=\"flex items-center gap-1 px-1 py-1\"\n data-testid=\"cloud-provider-tabs\"\n >\n {providers.map((provider) => {\n const isActive = provider === selectedProvider;\n return (\n <button\n key={provider}\n type=\"button\"\n data-testid={`cloud-provider-tab-${provider}`}\n onClick={() => handleProviderChange(provider)}\n className={cn(\n \"flex items-center gap-1 rounded px-2 py-1 text-xs\",\n \"border transition-colors\",\n isActive\n ? \"border-[var(--oh-border-subtle)] bg-[var(--oh-interactive-hover)] text-white\"\n : \"border-transparent text-[var(--oh-text-secondary)] hover:text-white\",\n )}\n >\n <GitProviderIcon gitProvider={provider} />\n <span className=\"capitalize\">{provider}</span>\n </button>\n );\n })}\n </div>\n )}\n\n <div className=\"px-2\">\n <div className=\"relative\">\n <SearchIcon\n width={16}\n height={16}\n aria-hidden\n className=\"pointer-events-none absolute left-0 top-1/2 -translate-y-1/2 text-[var(--oh-muted)]\"\n />\n <input\n type=\"text\"\n data-testid=\"cloud-repo-search-input\"\n value={query}\n onChange={(e) => setQuery(e.target.value)}\n placeholder={t(I18nKey.COMMON$SEARCH_REPOSITORIES)}\n disabled={!selectedProvider}\n className={cn(\n \"w-full border-0 bg-transparent py-1.5 pl-6 pr-0 text-sm text-white\",\n \"outline-none placeholder:text-[var(--oh-muted)]\",\n \"focus:outline-none focus:ring-0\",\n \"disabled:cursor-not-allowed disabled:opacity-60\",\n )}\n />\n </div>\n </div>\n\n <Divider inset=\"menu\" />\n\n <ul className=\"flex max-h-[40vh] flex-col overflow-y-auto custom-scrollbar-always sm:max-h-[280px]\">\n {isListLoading && repositories.length === 0 && (\n <li\n className=\"px-2 py-2 text-sm text-[var(--oh-muted)] italic\"\n data-testid=\"cloud-repo-loading\"\n >\n {t(I18nKey.HOME$LOADING_REPOSITORIES)}\n </li>\n )}\n {isError && (\n <li\n className=\"px-2 py-2 text-sm text-[#F87171]\"\n data-testid=\"cloud-repo-error\"\n >\n {t(I18nKey.HOME$FAILED_TO_LOAD_REPOSITORIES)}\n </li>\n )}\n {!isListLoading &&\n !isError &&\n repositories.length === 0 &&\n !!selectedProvider && (\n <li\n className=\"px-2 py-2 text-sm text-[var(--oh-muted)] italic\"\n data-testid=\"cloud-repo-empty\"\n >\n {t(I18nKey.GITHUB$NO_RESULTS)}\n </li>\n )}\n {repositories.map((repo) => (\n <RepoListItem\n key={`${repo.git_provider}:${repo.id}`}\n repo={repo}\n disabled={isCreating}\n onSelect={launchRepository}\n itemClass={itemClass}\n />\n ))}\n {showLoadMore && (\n <li>\n <button\n type=\"button\"\n data-testid=\"cloud-repo-load-more\"\n disabled={isFetchingNextPage}\n onClick={() => fetchNextPage()}\n className={itemClass}\n >\n <span className=\"text-[var(--oh-text-secondary)]\">\n {isFetchingNextPage\n ? t(I18nKey.HOME$LOADING_MORE_REPOSITORIES)\n : t(I18nKey.CONVERSATION$LOAD_MORE)}\n </span>\n </button>\n </li>\n )}\n </ul>\n </div>\n )}\n </div>\n );\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"cloud-new-conversation-menu.cjs","names":[],"sources":["../../../../src/components/features/conversation-panel/cloud-new-conversation-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { useTranslation } from \"react-i18next\";\n\nimport { useCreateConversation } from \"#/hooks/mutation/use-create-conversation\";\nimport { useNavigation } from \"#/context/navigation-context\";\nimport { useIsCreatingConversation } from \"#/hooks/use-is-creating-conversation\";\nimport { useGitRepositories } from \"#/hooks/query/use-git-repositories\";\nimport { useSearchRepositories } from \"#/hooks/query/use-search-repositories\";\nimport { useUserProviders } from \"#/hooks/use-user-providers\";\nimport { useDebounce } from \"#/hooks/use-debounce\";\nimport { useHomeStore } from \"#/stores/home-store\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { cn } from \"#/utils/utils\";\nimport {\n dropdownMenuRowClassName,\n dropdownInstantColorClassName,\n dropdownMenuListClassName,\n dropdownMenuRowIconWrapperClassName,\n} from \"#/utils/dropdown-classes\";\nimport { GitRepository } from \"#/types/git\";\nimport { Provider } from \"#/types/settings\";\nimport RepoIcon from \"#/icons/repo.svg?react\";\nimport SearchIcon from \"#/icons/search.svg?react\";\nimport { GitProviderIcon } from \"#/components/shared/git-provider-icon\";\nimport { Divider } from \"#/ui/divider\";\nimport { NEW_CONVERSATION_DROPDOWN_SURFACE } from \"./new-conversation-dropdown-styles\";\nimport { usePopoverFixedPlacement } from \"#/hooks/use-popover-fixed-placement\";\n\nexport type CloudNewConversationMenuTriggerProps = {\n onClick: () => void;\n \"aria-expanded\": boolean;\n \"aria-haspopup\": \"menu\";\n disabled?: boolean;\n};\n\nexport interface CloudNewConversationMenuProps {\n trigger: (props: CloudNewConversationMenuTriggerProps) => React.ReactNode;\n className?: string;\n popoverClassName: string;\n popoverTestId?: string;\n useFixedPlacement?: boolean;\n}\n\ninterface RepoListItemProps {\n repo: GitRepository;\n disabled: boolean;\n onSelect: (repo: GitRepository) => void;\n itemClass: string;\n}\n\nfunction RepoListItem({\n repo,\n disabled,\n onSelect,\n itemClass,\n}: RepoListItemProps) {\n return (\n <li>\n <button\n type=\"button\"\n disabled={disabled}\n data-testid=\"launch-repository\"\n data-repo-name={repo.full_name}\n onClick={() => onSelect(repo)}\n className={itemClass}\n >\n <span className={dropdownMenuRowIconWrapperClassName} aria-hidden>\n <RepoIcon width={14} height={14} />\n </span>\n <span className=\"truncate\">{repo.full_name}</span>\n </button>\n </li>\n );\n}\n\n/**\n * Repository search + launch flow for cloud backends.\n * Shared by the sidebar \"+ New conversation\" control and the conversation\n * panel \"new thread folder\" opener.\n */\nexport function CloudNewConversationMenu({\n trigger,\n className,\n popoverClassName,\n popoverTestId = \"new-conversation-popover\",\n useFixedPlacement = false,\n}: CloudNewConversationMenuProps) {\n const { t } = useTranslation(\"openhands\");\n const { navigate } = useNavigation();\n\n const { providers } = useUserProviders();\n const { lastSelectedProvider, setLastSelectedProvider } = useHomeStore();\n\n const [open, setOpen] = React.useState(false);\n const popoverRef = React.useRef<HTMLDivElement>(null);\n const triggerWrapRef = React.useRef<HTMLSpanElement>(null);\n const fixedBox = usePopoverFixedPlacement(triggerWrapRef, {\n open,\n enabled: useFixedPlacement,\n });\n const [selectedProvider, setSelectedProvider] =\n React.useState<Provider | null>(lastSelectedProvider ?? null);\n const [query, setQuery] = React.useState(\"\");\n const debouncedQuery = useDebounce(query, 300);\n\n React.useEffect(() => {\n if (providers.length === 0) {\n if (selectedProvider !== null) setSelectedProvider(null);\n return;\n }\n if (selectedProvider && providers.includes(selectedProvider)) return;\n const fallback =\n lastSelectedProvider && providers.includes(lastSelectedProvider)\n ? lastSelectedProvider\n : providers[0];\n setSelectedProvider(fallback);\n }, [providers, selectedProvider, lastSelectedProvider]);\n\n const {\n data: repoPages,\n isLoading,\n isError,\n hasNextPage,\n isFetchingNextPage,\n fetchNextPage,\n } = useGitRepositories({ provider: selectedProvider });\n\n const { data: searchResults, isLoading: isSearchLoading } =\n useSearchRepositories(debouncedQuery, selectedProvider);\n\n const allRepositories = React.useMemo(\n () => repoPages?.pages.flatMap((page) => page.items) ?? [],\n [repoPages],\n );\n\n const repositories = debouncedQuery ? (searchResults ?? []) : allRepositories;\n\n const { mutate: createConversation, isPending } = useCreateConversation();\n const isCreatingElsewhere = useIsCreatingConversation();\n const isCreating = isPending || isCreatingElsewhere;\n\n React.useEffect(() => {\n if (!open) return undefined;\n const onDown = (e: MouseEvent) => {\n if (\n popoverRef.current &&\n !popoverRef.current.contains(e.target as Node)\n ) {\n setOpen(false);\n }\n };\n document.addEventListener(\"mousedown\", onDown);\n return () => document.removeEventListener(\"mousedown\", onDown);\n }, [open]);\n\n React.useEffect(() => {\n if (!open) return undefined;\n const onKeyDown = (event: KeyboardEvent) => {\n if (event.key === \"Escape\") setOpen(false);\n };\n window.addEventListener(\"keydown\", onKeyDown);\n return () => window.removeEventListener(\"keydown\", onKeyDown);\n }, [open]);\n\n const launchRepository = (repo: GitRepository) => {\n if (isCreating) return;\n createConversation(\n {\n repository: {\n name: repo.full_name,\n gitProvider: repo.git_provider,\n branch: repo.main_branch ?? \"main\",\n },\n },\n {\n onSuccess: (data) => {\n setOpen(false);\n navigate(`/conversations/${data.conversation_id}`);\n },\n },\n );\n };\n\n const handleProviderChange = (provider: Provider) => {\n setSelectedProvider(provider);\n setLastSelectedProvider(provider);\n setQuery(\"\");\n };\n\n const itemClass = dropdownMenuRowClassName;\n\n React.useEffect(() => {\n if (!open) return;\n if (debouncedQuery) return;\n if (!hasNextPage || isFetchingNextPage || isLoading) return;\n if (repositories.length === 0 || repositories.length >= 10) return;\n fetchNextPage();\n }, [\n open,\n debouncedQuery,\n hasNextPage,\n isFetchingNextPage,\n isLoading,\n repositories.length,\n fetchNextPage,\n ]);\n\n const isListLoading = debouncedQuery ? isSearchLoading : isLoading;\n const showLoadMore =\n !debouncedQuery && hasNextPage && repositories.length > 0;\n\n const toggleOpen = React.useCallback(() => {\n setOpen((o) => !o);\n }, []);\n\n const showPopover = open && (!useFixedPlacement || fixedBox !== null);\n\n const fixedStyle: React.CSSProperties | undefined =\n useFixedPlacement && fixedBox\n ? {\n position: \"fixed\",\n top: fixedBox.top,\n left: fixedBox.left,\n width: fixedBox.width,\n }\n : undefined;\n\n return (\n <div\n className={cn(!useFixedPlacement && \"relative\", className)}\n ref={popoverRef}\n >\n <span ref={triggerWrapRef} className=\"inline-flex\">\n {trigger({\n onClick: toggleOpen,\n \"aria-expanded\": open,\n \"aria-haspopup\": \"menu\",\n disabled: isCreating,\n })}\n </span>\n\n {showPopover && (\n <div\n data-testid={popoverTestId}\n className={cn(\n NEW_CONVERSATION_DROPDOWN_SURFACE,\n !useFixedPlacement &&\n cn(\"absolute top-full mt-0\", popoverClassName),\n )}\n style={fixedStyle}\n >\n {providers.length > 1 && (\n <div\n className=\"flex items-center gap-1 px-1 py-1\"\n data-testid=\"cloud-provider-tabs\"\n >\n {providers.map((provider) => {\n const isActive = provider === selectedProvider;\n return (\n <button\n key={provider}\n type=\"button\"\n data-testid={`cloud-provider-tab-${provider}`}\n onClick={() => handleProviderChange(provider)}\n className={cn(\n \"flex items-center gap-1 rounded border px-2 py-1 text-xs\",\n dropdownInstantColorClassName,\n isActive\n ? \"border-[var(--oh-border-subtle)] bg-[var(--oh-interactive-hover)] text-white\"\n : \"border-transparent text-[var(--oh-text-secondary)] hover:text-white\",\n )}\n >\n <GitProviderIcon gitProvider={provider} />\n <span className=\"capitalize\">{provider}</span>\n </button>\n );\n })}\n </div>\n )}\n\n <div className=\"px-2\">\n <div className=\"relative\">\n <SearchIcon\n width={16}\n height={16}\n aria-hidden\n className=\"pointer-events-none absolute left-0 top-1/2 -translate-y-1/2 text-[var(--oh-muted)]\"\n />\n <input\n type=\"text\"\n data-testid=\"cloud-repo-search-input\"\n value={query}\n onChange={(e) => setQuery(e.target.value)}\n placeholder={t(I18nKey.COMMON$SEARCH_REPOSITORIES)}\n disabled={!selectedProvider}\n className={cn(\n \"w-full border-0 bg-transparent py-1.5 pl-6 pr-0 text-sm text-white\",\n \"outline-none placeholder:text-[var(--oh-muted)]\",\n \"focus:outline-none focus:ring-0\",\n \"disabled:cursor-not-allowed disabled:opacity-60\",\n )}\n />\n </div>\n </div>\n\n <Divider inset=\"menu\" />\n\n <ul\n className={cn(\n \"max-h-[40vh] overflow-y-auto custom-scrollbar-always sm:max-h-[280px]\",\n dropdownMenuListClassName,\n )}\n >\n {isListLoading && repositories.length === 0 && (\n <li\n className=\"px-2 py-2 text-sm text-[var(--oh-muted)] italic\"\n data-testid=\"cloud-repo-loading\"\n >\n {t(I18nKey.HOME$LOADING_REPOSITORIES)}\n </li>\n )}\n {isError && (\n <li\n className=\"px-2 py-2 text-sm text-[#F87171]\"\n data-testid=\"cloud-repo-error\"\n >\n {t(I18nKey.HOME$FAILED_TO_LOAD_REPOSITORIES)}\n </li>\n )}\n {!isListLoading &&\n !isError &&\n repositories.length === 0 &&\n !!selectedProvider && (\n <li\n className=\"px-2 py-2 text-sm text-[var(--oh-muted)] italic\"\n data-testid=\"cloud-repo-empty\"\n >\n {t(I18nKey.GITHUB$NO_RESULTS)}\n </li>\n )}\n {repositories.map((repo) => (\n <RepoListItem\n key={`${repo.git_provider}:${repo.id}`}\n repo={repo}\n disabled={isCreating}\n onSelect={launchRepository}\n itemClass={itemClass}\n />\n ))}\n {showLoadMore && (\n <li>\n <button\n type=\"button\"\n data-testid=\"cloud-repo-load-more\"\n disabled={isFetchingNextPage}\n onClick={() => fetchNextPage()}\n className={itemClass}\n >\n <span className=\"text-[var(--oh-text-secondary)]\">\n {isFetchingNextPage\n ? t(I18nKey.HOME$LOADING_MORE_REPOSITORIES)\n : t(I18nKey.CONVERSATION$LOAD_MORE)}\n </span>\n </button>\n </li>\n )}\n </ul>\n </div>\n )}\n </div>\n );\n}\n"],"mappings":"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"}
|
|
@@ -2,82 +2,86 @@ import { useTranslation as e } from "../../../node_modules/react-i18next/dist/es
|
|
|
2
2
|
import { I18nKey as t } from "../../../i18n/declaration.js";
|
|
3
3
|
import { cn as n } from "../../../utils/utils.js";
|
|
4
4
|
import { useNavigation as r } from "../../../context/navigation-context.js";
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
12
|
-
import
|
|
13
|
-
import
|
|
14
|
-
import {
|
|
15
|
-
import {
|
|
16
|
-
import {
|
|
17
|
-
import h from "../../../
|
|
18
|
-
import g from "
|
|
19
|
-
import
|
|
5
|
+
import { dropdownMenuListClassName as i, dropdownMenuRowClassName as ee, dropdownMenuRowIconWrapperClassName as a } from "../../../utils/dropdown-classes.js";
|
|
6
|
+
import { useCreateConversation as o } from "../../../hooks/mutation/use-create-conversation.js";
|
|
7
|
+
import { Divider as s } from "../../../ui/divider.js";
|
|
8
|
+
import { useUserProviders as c } from "../../../hooks/use-user-providers.js";
|
|
9
|
+
import { GitProviderIcon as l } from "../../shared/git-provider-icon.js";
|
|
10
|
+
import { useDebounce as u } from "../../../hooks/use-debounce.js";
|
|
11
|
+
import { useGitRepositories as d } from "../../../hooks/query/use-git-repositories.js";
|
|
12
|
+
import { useSearchRepositories as f } from "../../../hooks/query/use-search-repositories.js";
|
|
13
|
+
import p from "../../../icons/repo.js";
|
|
14
|
+
import { useHomeStore as te } from "../../../stores/home-store.js";
|
|
15
|
+
import { useIsCreatingConversation as ne } from "../../../hooks/use-is-creating-conversation.js";
|
|
16
|
+
import { NEW_CONVERSATION_DROPDOWN_SURFACE as m } from "./new-conversation-dropdown-styles.js";
|
|
17
|
+
import { usePopoverFixedPlacement as h } from "../../../hooks/use-popover-fixed-placement.js";
|
|
18
|
+
import g from "../../../icons/search.js";
|
|
19
|
+
import _ from "react";
|
|
20
|
+
import { jsx as v, jsxs as y } from "react/jsx-runtime";
|
|
20
21
|
//#region src/components/features/conversation-panel/cloud-new-conversation-menu.tsx
|
|
21
|
-
function
|
|
22
|
-
return /* @__PURE__ */
|
|
22
|
+
function b({ repo: e, disabled: t, onSelect: n, itemClass: r }) {
|
|
23
|
+
return /* @__PURE__ */ v("li", { children: /* @__PURE__ */ y("button", {
|
|
23
24
|
type: "button",
|
|
24
25
|
disabled: t,
|
|
25
26
|
"data-testid": "launch-repository",
|
|
26
27
|
"data-repo-name": e.full_name,
|
|
27
28
|
onClick: () => n(e),
|
|
28
29
|
className: r,
|
|
29
|
-
children: [/* @__PURE__ */
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
30
|
+
children: [/* @__PURE__ */ v("span", {
|
|
31
|
+
className: a,
|
|
32
|
+
"aria-hidden": !0,
|
|
33
|
+
children: /* @__PURE__ */ v(p, {
|
|
34
|
+
width: 14,
|
|
35
|
+
height: 14
|
|
36
|
+
})
|
|
37
|
+
}), /* @__PURE__ */ v("span", {
|
|
34
38
|
className: "truncate",
|
|
35
39
|
children: e.full_name
|
|
36
40
|
})]
|
|
37
41
|
}) });
|
|
38
42
|
}
|
|
39
|
-
function
|
|
40
|
-
let { t:
|
|
43
|
+
function x({ trigger: a, className: p, popoverClassName: x, popoverTestId: S = "new-conversation-popover", useFixedPlacement: C = !1 }) {
|
|
44
|
+
let { t: w } = e("openhands"), { navigate: T } = r(), { providers: E } = c(), { lastSelectedProvider: D, setLastSelectedProvider: re } = te(), [O, k] = _.useState(!1), A = _.useRef(null), j = _.useRef(null), M = h(j, {
|
|
41
45
|
open: O,
|
|
42
|
-
enabled:
|
|
43
|
-
}), [N, P] =
|
|
44
|
-
|
|
45
|
-
if (
|
|
46
|
+
enabled: C
|
|
47
|
+
}), [N, P] = _.useState(D ?? null), [F, I] = _.useState(""), L = u(F, 300);
|
|
48
|
+
_.useEffect(() => {
|
|
49
|
+
if (E.length === 0) {
|
|
46
50
|
N !== null && P(null);
|
|
47
51
|
return;
|
|
48
52
|
}
|
|
49
|
-
N &&
|
|
53
|
+
N && E.includes(N) || P(D && E.includes(D) ? D : E[0]);
|
|
50
54
|
}, [
|
|
51
|
-
|
|
55
|
+
E,
|
|
52
56
|
N,
|
|
53
|
-
|
|
57
|
+
D
|
|
54
58
|
]);
|
|
55
|
-
let { data: R, isLoading: z, isError: B, hasNextPage: V, isFetchingNextPage: H, fetchNextPage: U } =
|
|
56
|
-
|
|
59
|
+
let { data: R, isLoading: z, isError: B, hasNextPage: V, isFetchingNextPage: H, fetchNextPage: U } = d({ provider: N }), { data: W, isLoading: G } = f(L, N), K = _.useMemo(() => R?.pages.flatMap((e) => e.items) ?? [], [R]), q = L ? W ?? [] : K, { mutate: J, isPending: Y } = o(), ie = ne(), X = Y || ie;
|
|
60
|
+
_.useEffect(() => {
|
|
57
61
|
if (!O) return;
|
|
58
62
|
let e = (e) => {
|
|
59
63
|
A.current && !A.current.contains(e.target) && k(!1);
|
|
60
64
|
};
|
|
61
65
|
return document.addEventListener("mousedown", e), () => document.removeEventListener("mousedown", e);
|
|
62
|
-
}, [O]),
|
|
66
|
+
}, [O]), _.useEffect(() => {
|
|
63
67
|
if (!O) return;
|
|
64
68
|
let e = (e) => {
|
|
65
69
|
e.key === "Escape" && k(!1);
|
|
66
70
|
};
|
|
67
71
|
return window.addEventListener("keydown", e), () => window.removeEventListener("keydown", e);
|
|
68
72
|
}, [O]);
|
|
69
|
-
let
|
|
70
|
-
|
|
73
|
+
let ae = (e) => {
|
|
74
|
+
X || J({ repository: {
|
|
71
75
|
name: e.full_name,
|
|
72
76
|
gitProvider: e.git_provider,
|
|
73
77
|
branch: e.main_branch ?? "main"
|
|
74
78
|
} }, { onSuccess: (e) => {
|
|
75
|
-
k(!1),
|
|
79
|
+
k(!1), T(`/conversations/${e.conversation_id}`);
|
|
76
80
|
} });
|
|
77
|
-
},
|
|
78
|
-
P(e),
|
|
79
|
-
},
|
|
80
|
-
|
|
81
|
+
}, oe = (e) => {
|
|
82
|
+
P(e), re(e), I("");
|
|
83
|
+
}, Z = ee;
|
|
84
|
+
_.useEffect(() => {
|
|
81
85
|
O && (L || !V || H || z || q.length === 0 || q.length >= 10 || U());
|
|
82
86
|
}, [
|
|
83
87
|
O,
|
|
@@ -88,102 +92,102 @@ function y({ trigger: d, className: y, popoverClassName: b, popoverTestId: x = "
|
|
|
88
92
|
q.length,
|
|
89
93
|
U
|
|
90
94
|
]);
|
|
91
|
-
let
|
|
95
|
+
let Q = L ? G : z, $ = !L && V && q.length > 0, se = _.useCallback(() => {
|
|
92
96
|
k((e) => !e);
|
|
93
|
-
}, []),
|
|
97
|
+
}, []), ce = O && (!C || M !== null), le = C && M ? {
|
|
94
98
|
position: "fixed",
|
|
95
99
|
top: M.top,
|
|
96
100
|
left: M.left,
|
|
97
101
|
width: M.width
|
|
98
102
|
} : void 0;
|
|
99
|
-
return /* @__PURE__ */
|
|
100
|
-
className: n(!
|
|
103
|
+
return /* @__PURE__ */ y("div", {
|
|
104
|
+
className: n(!C && "relative", p),
|
|
101
105
|
ref: A,
|
|
102
|
-
children: [/* @__PURE__ */
|
|
106
|
+
children: [/* @__PURE__ */ v("span", {
|
|
103
107
|
ref: j,
|
|
104
108
|
className: "inline-flex",
|
|
105
|
-
children:
|
|
106
|
-
onClick:
|
|
109
|
+
children: a({
|
|
110
|
+
onClick: se,
|
|
107
111
|
"aria-expanded": O,
|
|
108
112
|
"aria-haspopup": "menu",
|
|
109
|
-
disabled:
|
|
113
|
+
disabled: X
|
|
110
114
|
})
|
|
111
|
-
}),
|
|
112
|
-
"data-testid":
|
|
113
|
-
className: n(
|
|
114
|
-
style:
|
|
115
|
+
}), ce && /* @__PURE__ */ y("div", {
|
|
116
|
+
"data-testid": S,
|
|
117
|
+
className: n(m, !C && n("absolute top-full mt-0", x)),
|
|
118
|
+
style: le,
|
|
115
119
|
children: [
|
|
116
|
-
|
|
120
|
+
E.length > 1 && /* @__PURE__ */ v("div", {
|
|
117
121
|
className: "flex items-center gap-1 px-1 py-1",
|
|
118
122
|
"data-testid": "cloud-provider-tabs",
|
|
119
|
-
children:
|
|
123
|
+
children: E.map((e) => {
|
|
120
124
|
let t = e === N;
|
|
121
|
-
return /* @__PURE__ */
|
|
125
|
+
return /* @__PURE__ */ y("button", {
|
|
122
126
|
type: "button",
|
|
123
127
|
"data-testid": `cloud-provider-tab-${e}`,
|
|
124
|
-
onClick: () =>
|
|
125
|
-
className: n("flex items-center gap-1 rounded px-2 py-1 text-xs", "
|
|
126
|
-
children: [/* @__PURE__ */
|
|
128
|
+
onClick: () => oe(e),
|
|
129
|
+
className: n("flex items-center gap-1 rounded border px-2 py-1 text-xs", "transition-none", t ? "border-[var(--oh-border-subtle)] bg-[var(--oh-interactive-hover)] text-white" : "border-transparent text-[var(--oh-text-secondary)] hover:text-white"),
|
|
130
|
+
children: [/* @__PURE__ */ v(l, { gitProvider: e }), /* @__PURE__ */ v("span", {
|
|
127
131
|
className: "capitalize",
|
|
128
132
|
children: e
|
|
129
133
|
})]
|
|
130
134
|
}, e);
|
|
131
135
|
})
|
|
132
136
|
}),
|
|
133
|
-
/* @__PURE__ */
|
|
137
|
+
/* @__PURE__ */ v("div", {
|
|
134
138
|
className: "px-2",
|
|
135
|
-
children: /* @__PURE__ */
|
|
139
|
+
children: /* @__PURE__ */ y("div", {
|
|
136
140
|
className: "relative",
|
|
137
|
-
children: [/* @__PURE__ */
|
|
141
|
+
children: [/* @__PURE__ */ v(g, {
|
|
138
142
|
width: 16,
|
|
139
143
|
height: 16,
|
|
140
144
|
"aria-hidden": !0,
|
|
141
145
|
className: "pointer-events-none absolute left-0 top-1/2 -translate-y-1/2 text-[var(--oh-muted)]"
|
|
142
|
-
}), /* @__PURE__ */
|
|
146
|
+
}), /* @__PURE__ */ v("input", {
|
|
143
147
|
type: "text",
|
|
144
148
|
"data-testid": "cloud-repo-search-input",
|
|
145
149
|
value: F,
|
|
146
150
|
onChange: (e) => I(e.target.value),
|
|
147
|
-
placeholder:
|
|
151
|
+
placeholder: w(t.COMMON$SEARCH_REPOSITORIES),
|
|
148
152
|
disabled: !N,
|
|
149
153
|
className: n("w-full border-0 bg-transparent py-1.5 pl-6 pr-0 text-sm text-white", "outline-none placeholder:text-[var(--oh-muted)]", "focus:outline-none focus:ring-0", "disabled:cursor-not-allowed disabled:opacity-60")
|
|
150
154
|
})]
|
|
151
155
|
})
|
|
152
156
|
}),
|
|
153
|
-
/* @__PURE__ */
|
|
154
|
-
/* @__PURE__ */
|
|
155
|
-
className: "
|
|
157
|
+
/* @__PURE__ */ v(s, { inset: "menu" }),
|
|
158
|
+
/* @__PURE__ */ y("ul", {
|
|
159
|
+
className: n("max-h-[40vh] overflow-y-auto custom-scrollbar-always sm:max-h-[280px]", i),
|
|
156
160
|
children: [
|
|
157
|
-
|
|
161
|
+
Q && q.length === 0 && /* @__PURE__ */ v("li", {
|
|
158
162
|
className: "px-2 py-2 text-sm text-[var(--oh-muted)] italic",
|
|
159
163
|
"data-testid": "cloud-repo-loading",
|
|
160
|
-
children:
|
|
164
|
+
children: w(t.HOME$LOADING_REPOSITORIES)
|
|
161
165
|
}),
|
|
162
|
-
B && /* @__PURE__ */
|
|
166
|
+
B && /* @__PURE__ */ v("li", {
|
|
163
167
|
className: "px-2 py-2 text-sm text-[#F87171]",
|
|
164
168
|
"data-testid": "cloud-repo-error",
|
|
165
|
-
children:
|
|
169
|
+
children: w(t.HOME$FAILED_TO_LOAD_REPOSITORIES)
|
|
166
170
|
}),
|
|
167
|
-
|
|
171
|
+
!Q && !B && q.length === 0 && !!N && /* @__PURE__ */ v("li", {
|
|
168
172
|
className: "px-2 py-2 text-sm text-[var(--oh-muted)] italic",
|
|
169
173
|
"data-testid": "cloud-repo-empty",
|
|
170
|
-
children:
|
|
174
|
+
children: w(t.GITHUB$NO_RESULTS)
|
|
171
175
|
}),
|
|
172
|
-
q.map((e) => /* @__PURE__ */
|
|
176
|
+
q.map((e) => /* @__PURE__ */ v(b, {
|
|
173
177
|
repo: e,
|
|
174
|
-
disabled:
|
|
175
|
-
onSelect:
|
|
176
|
-
itemClass:
|
|
178
|
+
disabled: X,
|
|
179
|
+
onSelect: ae,
|
|
180
|
+
itemClass: Z
|
|
177
181
|
}, `${e.git_provider}:${e.id}`)),
|
|
178
|
-
|
|
182
|
+
$ && /* @__PURE__ */ v("li", { children: /* @__PURE__ */ v("button", {
|
|
179
183
|
type: "button",
|
|
180
184
|
"data-testid": "cloud-repo-load-more",
|
|
181
185
|
disabled: H,
|
|
182
186
|
onClick: () => U(),
|
|
183
|
-
className:
|
|
184
|
-
children: /* @__PURE__ */
|
|
187
|
+
className: Z,
|
|
188
|
+
children: /* @__PURE__ */ v("span", {
|
|
185
189
|
className: "text-[var(--oh-text-secondary)]",
|
|
186
|
-
children:
|
|
190
|
+
children: w(H ? t.HOME$LOADING_MORE_REPOSITORIES : t.CONVERSATION$LOAD_MORE)
|
|
187
191
|
})
|
|
188
192
|
}) })
|
|
189
193
|
]
|
|
@@ -193,6 +197,6 @@ function y({ trigger: d, className: y, popoverClassName: b, popoverTestId: x = "
|
|
|
193
197
|
});
|
|
194
198
|
}
|
|
195
199
|
//#endregion
|
|
196
|
-
export {
|
|
200
|
+
export { x as CloudNewConversationMenu };
|
|
197
201
|
|
|
198
202
|
//# sourceMappingURL=cloud-new-conversation-menu.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cloud-new-conversation-menu.js","names":[],"sources":["../../../../src/components/features/conversation-panel/cloud-new-conversation-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { useTranslation } from \"react-i18next\";\n\nimport { useCreateConversation } from \"#/hooks/mutation/use-create-conversation\";\nimport { useNavigation } from \"#/context/navigation-context\";\nimport { useIsCreatingConversation } from \"#/hooks/use-is-creating-conversation\";\nimport { useGitRepositories } from \"#/hooks/query/use-git-repositories\";\nimport { useSearchRepositories } from \"#/hooks/query/use-search-repositories\";\nimport { useUserProviders } from \"#/hooks/use-user-providers\";\nimport { useDebounce } from \"#/hooks/use-debounce\";\nimport { useHomeStore } from \"#/stores/home-store\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { cn } from \"#/utils/utils\";\nimport { GitRepository } from \"#/types/git\";\nimport { Provider } from \"#/types/settings\";\nimport RepoIcon from \"#/icons/repo.svg?react\";\nimport SearchIcon from \"#/icons/search.svg?react\";\nimport { GitProviderIcon } from \"#/components/shared/git-provider-icon\";\nimport { Divider } from \"#/ui/divider\";\nimport { NEW_CONVERSATION_DROPDOWN_SURFACE } from \"./new-conversation-dropdown-styles\";\nimport { usePopoverFixedPlacement } from \"#/hooks/use-popover-fixed-placement\";\n\nexport type CloudNewConversationMenuTriggerProps = {\n onClick: () => void;\n \"aria-expanded\": boolean;\n \"aria-haspopup\": \"menu\";\n disabled?: boolean;\n};\n\nexport interface CloudNewConversationMenuProps {\n trigger: (props: CloudNewConversationMenuTriggerProps) => React.ReactNode;\n className?: string;\n popoverClassName: string;\n popoverTestId?: string;\n useFixedPlacement?: boolean;\n}\n\ninterface RepoListItemProps {\n repo: GitRepository;\n disabled: boolean;\n onSelect: (repo: GitRepository) => void;\n itemClass: string;\n}\n\nfunction RepoListItem({\n repo,\n disabled,\n onSelect,\n itemClass,\n}: RepoListItemProps) {\n return (\n <li>\n <button\n type=\"button\"\n disabled={disabled}\n data-testid=\"launch-repository\"\n data-repo-name={repo.full_name}\n onClick={() => onSelect(repo)}\n className={itemClass}\n >\n <RepoIcon width={14} height={14} className=\"shrink-0\" />\n <span className=\"truncate\">{repo.full_name}</span>\n </button>\n </li>\n );\n}\n\n/**\n * Repository search + launch flow for cloud backends.\n * Shared by the sidebar \"+ New conversation\" control and the conversation\n * panel \"new thread folder\" opener.\n */\nexport function CloudNewConversationMenu({\n trigger,\n className,\n popoverClassName,\n popoverTestId = \"new-conversation-popover\",\n useFixedPlacement = false,\n}: CloudNewConversationMenuProps) {\n const { t } = useTranslation(\"openhands\");\n const { navigate } = useNavigation();\n\n const { providers } = useUserProviders();\n const { lastSelectedProvider, setLastSelectedProvider } = useHomeStore();\n\n const [open, setOpen] = React.useState(false);\n const popoverRef = React.useRef<HTMLDivElement>(null);\n const triggerWrapRef = React.useRef<HTMLSpanElement>(null);\n const fixedBox = usePopoverFixedPlacement(triggerWrapRef, {\n open,\n enabled: useFixedPlacement,\n });\n const [selectedProvider, setSelectedProvider] =\n React.useState<Provider | null>(lastSelectedProvider ?? null);\n const [query, setQuery] = React.useState(\"\");\n const debouncedQuery = useDebounce(query, 300);\n\n React.useEffect(() => {\n if (providers.length === 0) {\n if (selectedProvider !== null) setSelectedProvider(null);\n return;\n }\n if (selectedProvider && providers.includes(selectedProvider)) return;\n const fallback =\n lastSelectedProvider && providers.includes(lastSelectedProvider)\n ? lastSelectedProvider\n : providers[0];\n setSelectedProvider(fallback);\n }, [providers, selectedProvider, lastSelectedProvider]);\n\n const {\n data: repoPages,\n isLoading,\n isError,\n hasNextPage,\n isFetchingNextPage,\n fetchNextPage,\n } = useGitRepositories({ provider: selectedProvider });\n\n const { data: searchResults, isLoading: isSearchLoading } =\n useSearchRepositories(debouncedQuery, selectedProvider);\n\n const allRepositories = React.useMemo(\n () => repoPages?.pages.flatMap((page) => page.items) ?? [],\n [repoPages],\n );\n\n const repositories = debouncedQuery ? (searchResults ?? []) : allRepositories;\n\n const { mutate: createConversation, isPending } = useCreateConversation();\n const isCreatingElsewhere = useIsCreatingConversation();\n const isCreating = isPending || isCreatingElsewhere;\n\n React.useEffect(() => {\n if (!open) return undefined;\n const onDown = (e: MouseEvent) => {\n if (\n popoverRef.current &&\n !popoverRef.current.contains(e.target as Node)\n ) {\n setOpen(false);\n }\n };\n document.addEventListener(\"mousedown\", onDown);\n return () => document.removeEventListener(\"mousedown\", onDown);\n }, [open]);\n\n React.useEffect(() => {\n if (!open) return undefined;\n const onKeyDown = (event: KeyboardEvent) => {\n if (event.key === \"Escape\") setOpen(false);\n };\n window.addEventListener(\"keydown\", onKeyDown);\n return () => window.removeEventListener(\"keydown\", onKeyDown);\n }, [open]);\n\n const launchRepository = (repo: GitRepository) => {\n if (isCreating) return;\n createConversation(\n {\n repository: {\n name: repo.full_name,\n gitProvider: repo.git_provider,\n branch: repo.main_branch ?? \"main\",\n },\n },\n {\n onSuccess: (data) => {\n setOpen(false);\n navigate(`/conversations/${data.conversation_id}`);\n },\n },\n );\n };\n\n const handleProviderChange = (provider: Provider) => {\n setSelectedProvider(provider);\n setLastSelectedProvider(provider);\n setQuery(\"\");\n };\n\n const itemClass = cn(\n \"flex w-full cursor-pointer items-center gap-2 rounded px-2 py-2 text-left text-sm text-white\",\n \"font-normal transition-colors hover:bg-[var(--oh-interactive-hover)]\",\n \"disabled:cursor-not-allowed disabled:opacity-60\",\n );\n\n React.useEffect(() => {\n if (!open) return;\n if (debouncedQuery) return;\n if (!hasNextPage || isFetchingNextPage || isLoading) return;\n if (repositories.length === 0 || repositories.length >= 10) return;\n fetchNextPage();\n }, [\n open,\n debouncedQuery,\n hasNextPage,\n isFetchingNextPage,\n isLoading,\n repositories.length,\n fetchNextPage,\n ]);\n\n const isListLoading = debouncedQuery ? isSearchLoading : isLoading;\n const showLoadMore =\n !debouncedQuery && hasNextPage && repositories.length > 0;\n\n const toggleOpen = React.useCallback(() => {\n setOpen((o) => !o);\n }, []);\n\n const showPopover = open && (!useFixedPlacement || fixedBox !== null);\n\n const fixedStyle: React.CSSProperties | undefined =\n useFixedPlacement && fixedBox\n ? {\n position: \"fixed\",\n top: fixedBox.top,\n left: fixedBox.left,\n width: fixedBox.width,\n }\n : undefined;\n\n return (\n <div\n className={cn(!useFixedPlacement && \"relative\", className)}\n ref={popoverRef}\n >\n <span ref={triggerWrapRef} className=\"inline-flex\">\n {trigger({\n onClick: toggleOpen,\n \"aria-expanded\": open,\n \"aria-haspopup\": \"menu\",\n disabled: isCreating,\n })}\n </span>\n\n {showPopover && (\n <div\n data-testid={popoverTestId}\n className={cn(\n NEW_CONVERSATION_DROPDOWN_SURFACE,\n !useFixedPlacement &&\n cn(\"absolute top-full mt-0\", popoverClassName),\n )}\n style={fixedStyle}\n >\n {providers.length > 1 && (\n <div\n className=\"flex items-center gap-1 px-1 py-1\"\n data-testid=\"cloud-provider-tabs\"\n >\n {providers.map((provider) => {\n const isActive = provider === selectedProvider;\n return (\n <button\n key={provider}\n type=\"button\"\n data-testid={`cloud-provider-tab-${provider}`}\n onClick={() => handleProviderChange(provider)}\n className={cn(\n \"flex items-center gap-1 rounded px-2 py-1 text-xs\",\n \"border transition-colors\",\n isActive\n ? \"border-[var(--oh-border-subtle)] bg-[var(--oh-interactive-hover)] text-white\"\n : \"border-transparent text-[var(--oh-text-secondary)] hover:text-white\",\n )}\n >\n <GitProviderIcon gitProvider={provider} />\n <span className=\"capitalize\">{provider}</span>\n </button>\n );\n })}\n </div>\n )}\n\n <div className=\"px-2\">\n <div className=\"relative\">\n <SearchIcon\n width={16}\n height={16}\n aria-hidden\n className=\"pointer-events-none absolute left-0 top-1/2 -translate-y-1/2 text-[var(--oh-muted)]\"\n />\n <input\n type=\"text\"\n data-testid=\"cloud-repo-search-input\"\n value={query}\n onChange={(e) => setQuery(e.target.value)}\n placeholder={t(I18nKey.COMMON$SEARCH_REPOSITORIES)}\n disabled={!selectedProvider}\n className={cn(\n \"w-full border-0 bg-transparent py-1.5 pl-6 pr-0 text-sm text-white\",\n \"outline-none placeholder:text-[var(--oh-muted)]\",\n \"focus:outline-none focus:ring-0\",\n \"disabled:cursor-not-allowed disabled:opacity-60\",\n )}\n />\n </div>\n </div>\n\n <Divider inset=\"menu\" />\n\n <ul className=\"flex max-h-[40vh] flex-col overflow-y-auto custom-scrollbar-always sm:max-h-[280px]\">\n {isListLoading && repositories.length === 0 && (\n <li\n className=\"px-2 py-2 text-sm text-[var(--oh-muted)] italic\"\n data-testid=\"cloud-repo-loading\"\n >\n {t(I18nKey.HOME$LOADING_REPOSITORIES)}\n </li>\n )}\n {isError && (\n <li\n className=\"px-2 py-2 text-sm text-[#F87171]\"\n data-testid=\"cloud-repo-error\"\n >\n {t(I18nKey.HOME$FAILED_TO_LOAD_REPOSITORIES)}\n </li>\n )}\n {!isListLoading &&\n !isError &&\n repositories.length === 0 &&\n !!selectedProvider && (\n <li\n className=\"px-2 py-2 text-sm text-[var(--oh-muted)] italic\"\n data-testid=\"cloud-repo-empty\"\n >\n {t(I18nKey.GITHUB$NO_RESULTS)}\n </li>\n )}\n {repositories.map((repo) => (\n <RepoListItem\n key={`${repo.git_provider}:${repo.id}`}\n repo={repo}\n disabled={isCreating}\n onSelect={launchRepository}\n itemClass={itemClass}\n />\n ))}\n {showLoadMore && (\n <li>\n <button\n type=\"button\"\n data-testid=\"cloud-repo-load-more\"\n disabled={isFetchingNextPage}\n onClick={() => fetchNextPage()}\n className={itemClass}\n >\n <span className=\"text-[var(--oh-text-secondary)]\">\n {isFetchingNextPage\n ? t(I18nKey.HOME$LOADING_MORE_REPOSITORIES)\n : t(I18nKey.CONVERSATION$LOAD_MORE)}\n </span>\n </button>\n </li>\n )}\n </ul>\n </div>\n )}\n </div>\n );\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"cloud-new-conversation-menu.js","names":[],"sources":["../../../../src/components/features/conversation-panel/cloud-new-conversation-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { useTranslation } from \"react-i18next\";\n\nimport { useCreateConversation } from \"#/hooks/mutation/use-create-conversation\";\nimport { useNavigation } from \"#/context/navigation-context\";\nimport { useIsCreatingConversation } from \"#/hooks/use-is-creating-conversation\";\nimport { useGitRepositories } from \"#/hooks/query/use-git-repositories\";\nimport { useSearchRepositories } from \"#/hooks/query/use-search-repositories\";\nimport { useUserProviders } from \"#/hooks/use-user-providers\";\nimport { useDebounce } from \"#/hooks/use-debounce\";\nimport { useHomeStore } from \"#/stores/home-store\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { cn } from \"#/utils/utils\";\nimport {\n dropdownMenuRowClassName,\n dropdownInstantColorClassName,\n dropdownMenuListClassName,\n dropdownMenuRowIconWrapperClassName,\n} from \"#/utils/dropdown-classes\";\nimport { GitRepository } from \"#/types/git\";\nimport { Provider } from \"#/types/settings\";\nimport RepoIcon from \"#/icons/repo.svg?react\";\nimport SearchIcon from \"#/icons/search.svg?react\";\nimport { GitProviderIcon } from \"#/components/shared/git-provider-icon\";\nimport { Divider } from \"#/ui/divider\";\nimport { NEW_CONVERSATION_DROPDOWN_SURFACE } from \"./new-conversation-dropdown-styles\";\nimport { usePopoverFixedPlacement } from \"#/hooks/use-popover-fixed-placement\";\n\nexport type CloudNewConversationMenuTriggerProps = {\n onClick: () => void;\n \"aria-expanded\": boolean;\n \"aria-haspopup\": \"menu\";\n disabled?: boolean;\n};\n\nexport interface CloudNewConversationMenuProps {\n trigger: (props: CloudNewConversationMenuTriggerProps) => React.ReactNode;\n className?: string;\n popoverClassName: string;\n popoverTestId?: string;\n useFixedPlacement?: boolean;\n}\n\ninterface RepoListItemProps {\n repo: GitRepository;\n disabled: boolean;\n onSelect: (repo: GitRepository) => void;\n itemClass: string;\n}\n\nfunction RepoListItem({\n repo,\n disabled,\n onSelect,\n itemClass,\n}: RepoListItemProps) {\n return (\n <li>\n <button\n type=\"button\"\n disabled={disabled}\n data-testid=\"launch-repository\"\n data-repo-name={repo.full_name}\n onClick={() => onSelect(repo)}\n className={itemClass}\n >\n <span className={dropdownMenuRowIconWrapperClassName} aria-hidden>\n <RepoIcon width={14} height={14} />\n </span>\n <span className=\"truncate\">{repo.full_name}</span>\n </button>\n </li>\n );\n}\n\n/**\n * Repository search + launch flow for cloud backends.\n * Shared by the sidebar \"+ New conversation\" control and the conversation\n * panel \"new thread folder\" opener.\n */\nexport function CloudNewConversationMenu({\n trigger,\n className,\n popoverClassName,\n popoverTestId = \"new-conversation-popover\",\n useFixedPlacement = false,\n}: CloudNewConversationMenuProps) {\n const { t } = useTranslation(\"openhands\");\n const { navigate } = useNavigation();\n\n const { providers } = useUserProviders();\n const { lastSelectedProvider, setLastSelectedProvider } = useHomeStore();\n\n const [open, setOpen] = React.useState(false);\n const popoverRef = React.useRef<HTMLDivElement>(null);\n const triggerWrapRef = React.useRef<HTMLSpanElement>(null);\n const fixedBox = usePopoverFixedPlacement(triggerWrapRef, {\n open,\n enabled: useFixedPlacement,\n });\n const [selectedProvider, setSelectedProvider] =\n React.useState<Provider | null>(lastSelectedProvider ?? null);\n const [query, setQuery] = React.useState(\"\");\n const debouncedQuery = useDebounce(query, 300);\n\n React.useEffect(() => {\n if (providers.length === 0) {\n if (selectedProvider !== null) setSelectedProvider(null);\n return;\n }\n if (selectedProvider && providers.includes(selectedProvider)) return;\n const fallback =\n lastSelectedProvider && providers.includes(lastSelectedProvider)\n ? lastSelectedProvider\n : providers[0];\n setSelectedProvider(fallback);\n }, [providers, selectedProvider, lastSelectedProvider]);\n\n const {\n data: repoPages,\n isLoading,\n isError,\n hasNextPage,\n isFetchingNextPage,\n fetchNextPage,\n } = useGitRepositories({ provider: selectedProvider });\n\n const { data: searchResults, isLoading: isSearchLoading } =\n useSearchRepositories(debouncedQuery, selectedProvider);\n\n const allRepositories = React.useMemo(\n () => repoPages?.pages.flatMap((page) => page.items) ?? [],\n [repoPages],\n );\n\n const repositories = debouncedQuery ? (searchResults ?? []) : allRepositories;\n\n const { mutate: createConversation, isPending } = useCreateConversation();\n const isCreatingElsewhere = useIsCreatingConversation();\n const isCreating = isPending || isCreatingElsewhere;\n\n React.useEffect(() => {\n if (!open) return undefined;\n const onDown = (e: MouseEvent) => {\n if (\n popoverRef.current &&\n !popoverRef.current.contains(e.target as Node)\n ) {\n setOpen(false);\n }\n };\n document.addEventListener(\"mousedown\", onDown);\n return () => document.removeEventListener(\"mousedown\", onDown);\n }, [open]);\n\n React.useEffect(() => {\n if (!open) return undefined;\n const onKeyDown = (event: KeyboardEvent) => {\n if (event.key === \"Escape\") setOpen(false);\n };\n window.addEventListener(\"keydown\", onKeyDown);\n return () => window.removeEventListener(\"keydown\", onKeyDown);\n }, [open]);\n\n const launchRepository = (repo: GitRepository) => {\n if (isCreating) return;\n createConversation(\n {\n repository: {\n name: repo.full_name,\n gitProvider: repo.git_provider,\n branch: repo.main_branch ?? \"main\",\n },\n },\n {\n onSuccess: (data) => {\n setOpen(false);\n navigate(`/conversations/${data.conversation_id}`);\n },\n },\n );\n };\n\n const handleProviderChange = (provider: Provider) => {\n setSelectedProvider(provider);\n setLastSelectedProvider(provider);\n setQuery(\"\");\n };\n\n const itemClass = dropdownMenuRowClassName;\n\n React.useEffect(() => {\n if (!open) return;\n if (debouncedQuery) return;\n if (!hasNextPage || isFetchingNextPage || isLoading) return;\n if (repositories.length === 0 || repositories.length >= 10) return;\n fetchNextPage();\n }, [\n open,\n debouncedQuery,\n hasNextPage,\n isFetchingNextPage,\n isLoading,\n repositories.length,\n fetchNextPage,\n ]);\n\n const isListLoading = debouncedQuery ? isSearchLoading : isLoading;\n const showLoadMore =\n !debouncedQuery && hasNextPage && repositories.length > 0;\n\n const toggleOpen = React.useCallback(() => {\n setOpen((o) => !o);\n }, []);\n\n const showPopover = open && (!useFixedPlacement || fixedBox !== null);\n\n const fixedStyle: React.CSSProperties | undefined =\n useFixedPlacement && fixedBox\n ? {\n position: \"fixed\",\n top: fixedBox.top,\n left: fixedBox.left,\n width: fixedBox.width,\n }\n : undefined;\n\n return (\n <div\n className={cn(!useFixedPlacement && \"relative\", className)}\n ref={popoverRef}\n >\n <span ref={triggerWrapRef} className=\"inline-flex\">\n {trigger({\n onClick: toggleOpen,\n \"aria-expanded\": open,\n \"aria-haspopup\": \"menu\",\n disabled: isCreating,\n })}\n </span>\n\n {showPopover && (\n <div\n data-testid={popoverTestId}\n className={cn(\n NEW_CONVERSATION_DROPDOWN_SURFACE,\n !useFixedPlacement &&\n cn(\"absolute top-full mt-0\", popoverClassName),\n )}\n style={fixedStyle}\n >\n {providers.length > 1 && (\n <div\n className=\"flex items-center gap-1 px-1 py-1\"\n data-testid=\"cloud-provider-tabs\"\n >\n {providers.map((provider) => {\n const isActive = provider === selectedProvider;\n return (\n <button\n key={provider}\n type=\"button\"\n data-testid={`cloud-provider-tab-${provider}`}\n onClick={() => handleProviderChange(provider)}\n className={cn(\n \"flex items-center gap-1 rounded border px-2 py-1 text-xs\",\n dropdownInstantColorClassName,\n isActive\n ? \"border-[var(--oh-border-subtle)] bg-[var(--oh-interactive-hover)] text-white\"\n : \"border-transparent text-[var(--oh-text-secondary)] hover:text-white\",\n )}\n >\n <GitProviderIcon gitProvider={provider} />\n <span className=\"capitalize\">{provider}</span>\n </button>\n );\n })}\n </div>\n )}\n\n <div className=\"px-2\">\n <div className=\"relative\">\n <SearchIcon\n width={16}\n height={16}\n aria-hidden\n className=\"pointer-events-none absolute left-0 top-1/2 -translate-y-1/2 text-[var(--oh-muted)]\"\n />\n <input\n type=\"text\"\n data-testid=\"cloud-repo-search-input\"\n value={query}\n onChange={(e) => setQuery(e.target.value)}\n placeholder={t(I18nKey.COMMON$SEARCH_REPOSITORIES)}\n disabled={!selectedProvider}\n className={cn(\n \"w-full border-0 bg-transparent py-1.5 pl-6 pr-0 text-sm text-white\",\n \"outline-none placeholder:text-[var(--oh-muted)]\",\n \"focus:outline-none focus:ring-0\",\n \"disabled:cursor-not-allowed disabled:opacity-60\",\n )}\n />\n </div>\n </div>\n\n <Divider inset=\"menu\" />\n\n <ul\n className={cn(\n \"max-h-[40vh] overflow-y-auto custom-scrollbar-always sm:max-h-[280px]\",\n dropdownMenuListClassName,\n )}\n >\n {isListLoading && repositories.length === 0 && (\n <li\n className=\"px-2 py-2 text-sm text-[var(--oh-muted)] italic\"\n data-testid=\"cloud-repo-loading\"\n >\n {t(I18nKey.HOME$LOADING_REPOSITORIES)}\n </li>\n )}\n {isError && (\n <li\n className=\"px-2 py-2 text-sm text-[#F87171]\"\n data-testid=\"cloud-repo-error\"\n >\n {t(I18nKey.HOME$FAILED_TO_LOAD_REPOSITORIES)}\n </li>\n )}\n {!isListLoading &&\n !isError &&\n repositories.length === 0 &&\n !!selectedProvider && (\n <li\n className=\"px-2 py-2 text-sm text-[var(--oh-muted)] italic\"\n data-testid=\"cloud-repo-empty\"\n >\n {t(I18nKey.GITHUB$NO_RESULTS)}\n </li>\n )}\n {repositories.map((repo) => (\n <RepoListItem\n key={`${repo.git_provider}:${repo.id}`}\n repo={repo}\n disabled={isCreating}\n onSelect={launchRepository}\n itemClass={itemClass}\n />\n ))}\n {showLoadMore && (\n <li>\n <button\n type=\"button\"\n data-testid=\"cloud-repo-load-more\"\n disabled={isFetchingNextPage}\n onClick={() => fetchNextPage()}\n className={itemClass}\n >\n <span className=\"text-[var(--oh-text-secondary)]\">\n {isFetchingNextPage\n ? t(I18nKey.HOME$LOADING_MORE_REPOSITORIES)\n : t(I18nKey.CONVERSATION$LOAD_MORE)}\n </span>\n </button>\n </li>\n )}\n </ul>\n </div>\n )}\n </div>\n );\n}\n"],"mappings":"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"}
|
package/dist/components/features/conversation-panel/conversation-card/conversation-card-actions.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
const e=require(`../../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../../utils/
|
|
1
|
+
const e=require(`../../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../../utils/status.cjs`),n=require(`../../../../utils/utils.cjs`),r=require(`../ellipsis-button.cjs`),i=require(`./conversation-card-context-menu.cjs`);let a=require(`react`);a=e.__toESM(a,1);let o=require(`react/jsx-runtime`),s=require(`react-dom`);function c({contextMenuOpen:e,onContextMenuToggle:c,onDelete:l,onStop:u,onEdit:d,onDownloadViaVSCode:f,onDownloadConversation:p,executionStatus:m,conversationId:h,showOptions:g}){let _=t.isExecutionPaused(m),v=t.isExecutionActive(m),y=(0,a.useRef)(null),[,b]=(0,a.useReducer)(e=>e+1,0);(0,a.useLayoutEffect)(()=>{if(!e)return;b();let t=0,n=()=>{t||=window.requestAnimationFrame(()=>{t=0,b()})};return window.addEventListener(`resize`,n),window.addEventListener(`scroll`,n,!0),()=>{t&&window.cancelAnimationFrame(t),window.removeEventListener(`resize`,n),window.removeEventListener(`scroll`,n,!0)}},[e]);let x=(()=>{if(!e||!y.current)return;let t=y.current.getBoundingClientRect(),n=Number(window.innerWidth)||0,r=Number(window.innerHeight)||0,i=Number(t.bottom)||0,a=Number(t.right)||0;return{position:`fixed`,top:i+280+8>r?Math.max(8,t.top-280-4):i+4,right:Math.max(8,n-a),zIndex:1e5}})(),S=typeof document<`u`?document.body:null;return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(r.EllipsisButton,{ref:y,onClick:t=>{t.preventDefault(),t.stopPropagation(),c(!e)},className:n.cn(_&&`opacity-60`)}),e&&x&&S?(0,s.createPortal)((0,o.jsx)(i.ConversationCardContextMenu,{ignoreOutsideClickRef:y,floatingStyle:x,onClose:()=>c(!1),onDelete:l,onStop:v?u:void 0,onEdit:d,onDownloadViaVSCode:h&&g?f:void 0,onDownloadConversation:h?p:void 0,position:`bottom`}),S):null]})}exports.ConversationCardActions=c;
|
|
2
2
|
//# sourceMappingURL=conversation-card-actions.cjs.map
|
package/dist/components/features/conversation-panel/conversation-card/conversation-card-actions.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { isExecutionActive as e, isExecutionPaused as t } from "../../../../utils/status.js";
|
|
2
|
+
import { cn as n } from "../../../../utils/utils.js";
|
|
3
3
|
import { EllipsisButton as r } from "../ellipsis-button.js";
|
|
4
4
|
import { ConversationCardContextMenu as i } from "./conversation-card-context-menu.js";
|
|
5
5
|
import { useLayoutEffect as a, useReducer as o, useRef as s } from "react";
|
|
@@ -7,7 +7,7 @@ import { Fragment as c, jsx as l, jsxs as u } from "react/jsx-runtime";
|
|
|
7
7
|
import { createPortal as d } from "react-dom";
|
|
8
8
|
//#region src/components/features/conversation-panel/conversation-card/conversation-card-actions.tsx
|
|
9
9
|
function f({ contextMenuOpen: f, onContextMenuToggle: p, onDelete: m, onStop: h, onEdit: g, onDownloadViaVSCode: _, onDownloadConversation: v, executionStatus: y, conversationId: b, showOptions: x }) {
|
|
10
|
-
let S =
|
|
10
|
+
let S = t(y), C = e(y), w = s(null), [, T] = o((e) => e + 1, 0);
|
|
11
11
|
a(() => {
|
|
12
12
|
if (!f) return;
|
|
13
13
|
T();
|
|
@@ -35,7 +35,7 @@ function f({ contextMenuOpen: f, onContextMenuToggle: p, onDelete: m, onStop: h,
|
|
|
35
35
|
onClick: (e) => {
|
|
36
36
|
e.preventDefault(), e.stopPropagation(), p(!f);
|
|
37
37
|
},
|
|
38
|
-
className:
|
|
38
|
+
className: n(S && "opacity-60")
|
|
39
39
|
}), f && E && D ? d(/* @__PURE__ */ l(i, {
|
|
40
40
|
ignoreOutsideClickRef: w,
|
|
41
41
|
floatingStyle: E,
|
package/dist/components/features/conversation-panel/conversation-card/conversation-card-footer.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
require(`../../../../_virtual/_rolldown/runtime.cjs`);const e=require(`../../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),t=require(`../../../../i18n/declaration.cjs`),n=require(`../../../../utils/
|
|
1
|
+
require(`../../../../_virtual/_rolldown/runtime.cjs`);const e=require(`../../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),t=require(`../../../../i18n/declaration.cjs`),n=require(`../../../../utils/status.cjs`),r=require(`../../../../utils/utils.cjs`),i=require(`../../../../constants/acp-providers.cjs`),a=require(`../../../../utils/format-time-delta.cjs`),o=require(`../../../shared/agent-brand-icon.cjs`),s=require(`./conversation-repo-link.cjs`),c=require(`./no-repository.cjs`);let l=require(`react/jsx-runtime`);function u({selectedRepository:u,lastUpdatedAt:d,createdAt:f,executionStatus:p,workspaceWorkingDir:m,showRepositoryMetadata:h=!0,showTimestamp:g=!0,llmModel:_,showAgentChip:v=!1,agentKind:y=null,acpServer:b=null}){let{t:x}=e.useTranslation(`openhands`),S=n.isExecutionPaused(p),C=null;if(v)if(y===`acp`){let e=i.getAcpProviderDisplayName(b)??x(t.I18nKey.CONVERSATION$ACP_AGENT_GENERIC),n=i.labelForAcpModel(b,_),r=n??e;C={kind:i.resolveAcpProviderIcon(b),text:r,tooltip:n?`${e} · ${n}`:e}}else _&&(C={kind:`openhands`,text:_,tooltip:_});let w=p===void 0?void 0:`pl-[26px]`;return(0,l.jsxs)(`div`,{className:r.cn(`flex flex-col gap-0.5 mt-0.5 w-full min-w-0`,S&&`opacity-60`),children:[C?(0,l.jsx)(`div`,{className:w,children:(0,l.jsxs)(`span`,{"data-testid":`conversation-card-agent-chip`,className:`inline-flex items-center gap-1 text-xs text-[var(--oh-muted)] max-w-full min-w-0`,title:C.tooltip,children:[(0,l.jsx)(o.AgentBrandIcon,{kind:C.kind}),(0,l.jsx)(`span`,{className:`truncate`,children:C.text})]})}):null,(0,l.jsxs)(`div`,{className:r.cn(`flex flex-row items-center gap-2 w-full min-w-0`,h&&w),children:[h&&(u?.selected_repository?(0,l.jsx)(s.ConversationRepoLink,{selectedRepository:u}):(0,l.jsx)(c.NoRepository,{workspaceWorkingDir:m})),(0,l.jsx)(`div`,{className:`flex items-center gap-2 shrink-0 ml-auto`,children:g&&(f??d)&&(0,l.jsx)(`p`,{className:`text-xs text-[var(--oh-muted)] text-right`,children:(0,l.jsx)(`time`,{children:`${a.formatTimeDelta(d??f)} ${x(t.I18nKey.CONVERSATION$AGO)}`})})})]})]})}exports.ConversationCardFooter=u;
|
|
2
2
|
//# sourceMappingURL=conversation-card-footer.cjs.map
|
package/dist/components/features/conversation-panel/conversation-card/conversation-card-footer.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
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 {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
3
|
+
import { isExecutionPaused as n } from "../../../../utils/status.js";
|
|
4
|
+
import { cn as r } from "../../../../utils/utils.js";
|
|
5
|
+
import { getAcpProviderDisplayName as i, labelForAcpModel as a, resolveAcpProviderIcon as o } from "../../../../constants/acp-providers.js";
|
|
6
6
|
import { formatTimeDelta as s } from "../../../../utils/format-time-delta.js";
|
|
7
7
|
import { AgentBrandIcon as c } from "../../../shared/agent-brand-icon.js";
|
|
8
8
|
import { ConversationRepoLink as l } from "./conversation-repo-link.js";
|
|
@@ -10,12 +10,12 @@ import { NoRepository as u } from "./no-repository.js";
|
|
|
10
10
|
import { jsx as d, jsxs as f } from "react/jsx-runtime";
|
|
11
11
|
//#region src/components/features/conversation-panel/conversation-card/conversation-card-footer.tsx
|
|
12
12
|
function p({ selectedRepository: p, lastUpdatedAt: m, createdAt: h, executionStatus: g, workspaceWorkingDir: _, showRepositoryMetadata: v = !0, showTimestamp: y = !0, llmModel: b, showAgentChip: x = !1, agentKind: S = null, acpServer: C = null }) {
|
|
13
|
-
let { t: w } = e("openhands"), T =
|
|
13
|
+
let { t: w } = e("openhands"), T = n(g), E = null;
|
|
14
14
|
if (x) if (S === "acp") {
|
|
15
|
-
let e =
|
|
15
|
+
let e = i(C) ?? w(t.CONVERSATION$ACP_AGENT_GENERIC), n = a(C, b), r = n ?? e;
|
|
16
16
|
E = {
|
|
17
|
-
kind:
|
|
18
|
-
text:
|
|
17
|
+
kind: o(C),
|
|
18
|
+
text: r,
|
|
19
19
|
tooltip: n ? `${e} · ${n}` : e
|
|
20
20
|
};
|
|
21
21
|
} else b && (E = {
|
|
@@ -25,7 +25,7 @@ function p({ selectedRepository: p, lastUpdatedAt: m, createdAt: h, executionSta
|
|
|
25
25
|
});
|
|
26
26
|
let D = g === void 0 ? void 0 : "pl-[26px]";
|
|
27
27
|
return /* @__PURE__ */ f("div", {
|
|
28
|
-
className:
|
|
28
|
+
className: r("flex flex-col gap-0.5 mt-0.5 w-full min-w-0", T && "opacity-60"),
|
|
29
29
|
children: [E ? /* @__PURE__ */ d("div", {
|
|
30
30
|
className: D,
|
|
31
31
|
children: /* @__PURE__ */ f("span", {
|
|
@@ -38,7 +38,7 @@ function p({ selectedRepository: p, lastUpdatedAt: m, createdAt: h, executionSta
|
|
|
38
38
|
})]
|
|
39
39
|
})
|
|
40
40
|
}) : null, /* @__PURE__ */ f("div", {
|
|
41
|
-
className:
|
|
41
|
+
className: r("flex flex-row items-center gap-2 w-full min-w-0", v && D),
|
|
42
42
|
children: [v && (p?.selected_repository ? /* @__PURE__ */ d(l, { selectedRepository: p }) : /* @__PURE__ */ d(u, { workspaceWorkingDir: _ })), /* @__PURE__ */ d("div", {
|
|
43
43
|
className: "flex items-center gap-2 shrink-0 ml-auto",
|
|
44
44
|
children: y && (h ?? m) && /* @__PURE__ */ d("p", {
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
const e=require(`../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),n=require(`../../../i18n/declaration.cjs`),r=require(`../../../utils/utils.cjs`),i=require(`../../../node_modules/lucide-react/dist/esm/icons/bot.cjs`),a=require(`../../../node_modules/lucide-react/dist/esm/icons/calendar-arrow-down.cjs`),o=require(`../../../node_modules/lucide-react/dist/esm/icons/check.cjs`),s=require(`../../../node_modules/lucide-react/dist/esm/icons/clock-3.cjs`),c=require(`../../../node_modules/lucide-react/dist/esm/icons/clock-arrow-down.cjs`),l=require(`../../../node_modules/lucide-react/dist/esm/icons/eye-off.cjs`),u=require(`../../../node_modules/lucide-react/dist/esm/icons/eye.cjs`),d=require(`../../../node_modules/lucide-react/dist/esm/icons/folder.cjs`),f=require(`../../../node_modules/lucide-react/dist/esm/icons/git-branch.cjs`),p=require(`../../../node_modules/lucide-react/dist/esm/icons/list-filter.cjs`),m=require(`../../../node_modules/lucide-react/dist/esm/icons/message-circle.cjs`),h=require(`../../../node_modules/lucide-react/dist/esm/icons/star.cjs`),g=require(`../../../node_modules/lucide-react/dist/esm/icons/trash-2.cjs`),_=require(`../../../utils/
|
|
1
|
+
const e=require(`../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),n=require(`../../../i18n/declaration.cjs`),r=require(`../../../utils/utils.cjs`),i=require(`../../../node_modules/lucide-react/dist/esm/icons/bot.cjs`),a=require(`../../../node_modules/lucide-react/dist/esm/icons/calendar-arrow-down.cjs`),o=require(`../../../node_modules/lucide-react/dist/esm/icons/check.cjs`),s=require(`../../../node_modules/lucide-react/dist/esm/icons/clock-3.cjs`),c=require(`../../../node_modules/lucide-react/dist/esm/icons/clock-arrow-down.cjs`),l=require(`../../../node_modules/lucide-react/dist/esm/icons/eye-off.cjs`),u=require(`../../../node_modules/lucide-react/dist/esm/icons/eye.cjs`),d=require(`../../../node_modules/lucide-react/dist/esm/icons/folder.cjs`),f=require(`../../../node_modules/lucide-react/dist/esm/icons/git-branch.cjs`),p=require(`../../../node_modules/lucide-react/dist/esm/icons/list-filter.cjs`),m=require(`../../../node_modules/lucide-react/dist/esm/icons/message-circle.cjs`),h=require(`../../../node_modules/lucide-react/dist/esm/icons/star.cjs`),g=require(`../../../node_modules/lucide-react/dist/esm/icons/trash-2.cjs`),_=require(`../../../utils/dropdown-classes.cjs`),v=require(`../../../ui/divider.cjs`);let y=require(`react`);y=e.__toESM(y,1);let b=require(`react/jsx-runtime`);var x=e=>e.length>0?e.charAt(0).toUpperCase()+e.slice(1):e,S=`px-2 pb-1 pt-1`,C=`text-[11px] font-semibold uppercase tracking-wide text-[var(--oh-muted)]`;function w({children:e,suffix:t}){return t==null?(0,b.jsx)(`div`,{role:`presentation`,className:r.cn(S,C),children:e}):(0,b.jsxs)(`div`,{role:`presentation`,className:r.cn(`flex items-baseline justify-between gap-2`,S),children:[(0,b.jsx)(`span`,{className:r.cn(`min-w-0 truncate text-left`,C),children:e}),t]})}function T(){return(0,b.jsx)(v.Divider,{inset:`menu`})}function E({icon:e,label:t,selected:n,onClick:i,testId:a,disabled:s}){return(0,b.jsxs)(`button`,{type:`button`,role:n===void 0?`menuitem`:`menuitemradio`,"aria-checked":n===void 0?void 0:!!n,"data-testid":a,disabled:s,onClick:i,className:r.cn(`group`,_.dropdownMenuRowClassName,`text-[var(--oh-foreground)] disabled:opacity-50`),children:[(0,b.jsx)(e,{className:r.cn(`h-3.5 w-3.5`,_.dropdownMenuRowIconClassName),"aria-hidden":!0}),(0,b.jsx)(`span`,{className:`min-w-0 flex-1 truncate`,children:t}),n?(0,b.jsx)(o.Check,{className:`ml-auto h-3.5 w-3.5 shrink-0 text-white`,"aria-hidden":!0}):null]})}function D({filterMenuOpen:e,setFilterMenuOpen:o,menuRef:v,backendKind:S,organizeMode:C,setOrganizeMode:D,conversationSort:O,setConversationSort:k,threadScope:A,setThreadScope:j,showOlderConversations:M,toggleShowOlderConversations:N,showRepoBranchMetadata:P,toggleShowRepoBranchMetadata:F,showLlmProfiles:I,toggleShowLlmProfiles:L,totalConversationsCount:R,onRequestDeleteAll:z}){let{t:B}=t.useTranslation(`openhands`),V=B(S===`local`?n.I18nKey.CONVERSATION_PANEL$BY_WORKSPACE:n.I18nKey.CONVERSATION_PANEL$BY_REPOSITORY),H=y.default.useRef(null),U=y.default.useRef(null),W=y.default.useRef(e);return y.default.useEffect(()=>{e?(U.current?.querySelector(`[role="menuitem"], [role="menuitemradio"]`))?.focus():W.current&&H.current?.focus(),W.current=e},[e]),(0,b.jsxs)(`div`,{ref:v,className:`relative shrink-0 pr-0.5`,children:[(0,b.jsx)(`button`,{ref:H,type:`button`,"data-testid":`older-conversations-filter-toggle`,"aria-label":B(n.I18nKey.CONVERSATION_PANEL$FILTER_LABEL),"aria-haspopup":`menu`,"aria-expanded":e,onClick:()=>o(!e),className:r.cn(`inline-flex h-7 w-7 items-center justify-center rounded-md text-[var(--oh-muted)] hover:text-white hover:bg-[var(--oh-surface-raised)]`,_.dropdownInstantColorClassName),children:(0,b.jsx)(p.ListFilter,{className:`lucide lucide-list-filter shrink-0`,width:14,height:14,strokeWidth:2,"aria-hidden":!0})}),e?(0,b.jsxs)(`div`,{ref:U,role:`menu`,"aria-orientation":`vertical`,"aria-label":B(n.I18nKey.CONVERSATION_PANEL$FILTER_LABEL),tabIndex:-1,"data-testid":`older-conversations-filter-menu`,onKeyDown:e=>{if(e.key===`Escape`){e.preventDefault(),o(!1);return}if(e.key!==`ArrowDown`&&e.key!==`ArrowUp`)return;let t=U.current;if(!t)return;let n=Array.from(t.querySelectorAll(`[role="menuitem"], [role="menuitemradio"]`)).filter(e=>!e.disabled);if(n.length===0)return;let r=n.indexOf(document.activeElement),i=e.key===`ArrowDown`?1:-1,a=((r===-1?0:r)+i+n.length)%n.length;e.preventDefault(),n[a]?.focus()},className:r.cn(`absolute right-0 top-full z-50 mt-0 w-64 rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 text-[var(--oh-foreground)] shadow-lg`,_.dropdownMenuListClassName,_.dropdownMenuViewportScrollClassName),children:[(0,b.jsx)(w,{children:B(n.I18nKey.CONVERSATION_PANEL$ORGANIZE)}),(0,b.jsx)(E,{icon:d.Folder,label:V,selected:C===`grouped`,onClick:()=>{D(`grouped`),o(!1)}}),(0,b.jsx)(E,{icon:s.Clock3,label:B(n.I18nKey.CONVERSATION_PANEL$CHRONOLOGICAL),selected:C===`chronological`,onClick:()=>{D(`chronological`),o(!1)}}),(0,b.jsx)(T,{}),(0,b.jsx)(w,{children:B(n.I18nKey.CONVERSATION_PANEL$SORT_BY)}),(0,b.jsx)(E,{icon:a.CalendarArrowDown,label:B(n.I18nKey.CONVERSATION_PANEL$SORT_CREATED),selected:O===`created`,onClick:()=>{k(`created`),o(!1)}}),(0,b.jsx)(E,{icon:c.ClockArrowDown,label:B(n.I18nKey.CONVERSATION_PANEL$SORT_UPDATED),selected:O===`updated`,onClick:()=>{k(`updated`),o(!1)}}),(0,b.jsx)(T,{}),(0,b.jsx)(w,{children:B(n.I18nKey.CONVERSATION_PANEL$SHOW)}),(0,b.jsx)(E,{icon:m.MessageCircle,label:B(n.I18nKey.CONVERSATION_PANEL$ALL_THREADS),selected:A===`all`,onClick:()=>{j(`all`),o(!1)}}),(0,b.jsx)(E,{icon:h.Star,label:B(n.I18nKey.CONVERSATION_PANEL$RELEVANT_THREADS),selected:A===`relevant`,onClick:()=>{j(`relevant`),o(!1)}}),(0,b.jsx)(T,{}),(0,b.jsx)(w,{children:B(n.I18nKey.CONVERSATION_PANEL$METADATA)}),(0,b.jsx)(E,{icon:i.Bot,label:B(n.I18nKey.CONVERSATION_PANEL$LLM_MODEL),selected:I,testId:`toggle-llm-profiles`,onClick:()=>{L(),o(!1)}}),(0,b.jsx)(E,{icon:f.GitBranch,label:B(n.I18nKey.CONVERSATION_PANEL$REPO_BRANCH),selected:P,testId:`toggle-repo-branch-metadata`,onClick:()=>{F(),o(!1)}}),(0,b.jsx)(T,{}),(0,b.jsx)(w,{suffix:(0,b.jsx)(`span`,{className:`shrink-0 text-right text-[10px] font-medium normal-case tracking-normal text-[var(--oh-muted)]/70`,children:B(n.I18nKey.CONVERSATION_PANEL$OLDER_OVER_ONE_HOUR)}),children:B(n.I18nKey.CONVERSATION_PANEL$OLDER_SECTION)}),(0,b.jsx)(E,{testId:`toggle-older-conversations`,icon:M?l.EyeOff:u.Eye,label:x(B(M?n.I18nKey.CONVERSATION$HIDE:n.I18nKey.CONVERSATION$SHOW_ALL)),onClick:()=>{N(),o(!1)}}),(0,b.jsx)(T,{}),(0,b.jsx)(E,{testId:`delete-all-conversations`,icon:g.Trash2,label:x(B(n.I18nKey.CONVERSATION$DELETE_ALL)),disabled:R===0,onClick:()=>{R!==0&&(z(),o(!1))}})]}):null]})}exports.ConversationPanelFilterMenu=D;
|
|
2
2
|
//# sourceMappingURL=conversation-panel-filter-menu.cjs.map
|