@openhands/agent-canvas 1.0.0-beta.5 → 1.0.0-beta.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +24 -7
- package/README.windows.md +27 -0
- package/bin/agent-canvas.mjs +26 -3
- package/build/assets/{QueryClientProvider-CkGuhXg-.js → QueryClientProvider-Cnr-Yl3j.js} +1 -1
- package/build/assets/{Trans-Cvm_-SMi.js → Trans-4jmk54WC.js} +1 -1
- package/build/assets/acp-providers-CPdgcp13.js +1 -0
- package/build/assets/{acp-route-guard-B2yoBZ_4.js → acp-route-guard-BoVmCn0e.js} +1 -1
- package/build/assets/active-backend-context-Beu-LZL-.js +1 -0
- package/build/assets/add-backend-modal-BheqYXHK.js +1 -0
- package/build/assets/agent-server-client-options-HEOwGVIU.js +1 -0
- package/build/assets/agent-server-compatibility-CdI3N7dr.js +1 -0
- package/build/assets/agent-server-conversation-service.api-CORdqJZg.js +5 -0
- package/build/assets/{agent-settings-CnGSCmK8.js → agent-settings-UFvcGjoI.js} +1 -1
- package/build/assets/{alert-banner-DtzAX654.js → alert-banner-DFnn_lC6.js} +1 -1
- package/build/assets/{analytics-consent-form-modal-CHZ3I37v.js → analytics-consent-form-modal-CVNugqzu.js} +1 -1
- package/build/assets/api-key-entry-screen-M6su2VSf.js +1 -0
- package/build/assets/{app-settings-Db9ITeJH.js → app-settings-BlvBhBdc.js} +1 -1
- package/build/assets/automation-detail-BWrQk4Oa.js +1 -0
- package/build/assets/automations-list-ux9KvYsU.js +1 -0
- package/build/assets/back-nav-button-7dQJ2k3O.js +1 -0
- package/build/assets/backend-form-modal-CDnEYjaU.js +1 -0
- package/build/assets/{backend-synced-settings-badge-Dc6c7GT4.js → backend-synced-settings-badge-BTIj-Ffq.js} +1 -1
- package/build/assets/base-modal-C2oy2EBG.js +1 -0
- package/build/assets/brand-button-DJ_S16rO.js +1 -0
- package/build/assets/{browser-D810xUYt.js → browser-CGM-k-sH.js} +2 -2
- package/build/assets/browser-store-DAsixKdU.js +1 -0
- package/build/assets/{browser-tab-B-aIqXRl.js → browser-tab-dvSPdvkm.js} +1 -1
- package/build/assets/{checkmark-DL7acQA7.js → checkmark-Dus0b6jt.js} +1 -1
- package/build/assets/{chevron-left-small-CVWf8TI6.js → chevron-left-small-_uvG7RVM.js} +1 -1
- package/build/assets/{circle-plus-check-toggle-P7ZZToV4.js → circle-plus-check-toggle-DKS8MAVV.js} +1 -1
- package/build/assets/{close-B5LROHR3.js → close-BU5iTc66.js} +1 -1
- package/build/assets/code-tag-BzyqOtPD.js +1 -0
- package/build/assets/combobox-caret-BJC7XJsz.js +1 -0
- package/build/assets/{command-store-DFN_17p1.js → command-store-CE1weJy8.js} +1 -1
- package/build/assets/{condenser-settings-wnEKhBof.js → condenser-settings-BolbDvm5.js} +1 -1
- package/build/assets/{confirmation-modal-Dau3w_sa.js → confirmation-modal-B5Ca6qFE.js} +1 -1
- package/build/assets/context-menu-list-item-7tAcm2c3.js +1 -0
- package/build/assets/conversation-D0N4dw_p.js +19 -0
- package/build/assets/conversation-DhRJuZLG.js +1 -0
- package/build/assets/conversation-panel-CNqHbS_Z.js +1 -0
- package/build/assets/conversation-service.api-BsJy6uuL.js +1 -0
- package/build/assets/conversation-state-store-D-w0uurj.js +1 -0
- package/build/assets/conversation-store-CC-isCnP.js +1 -0
- package/build/assets/{conversation-tab-empty-state-DyssnnWa.js → conversation-tab-empty-state-CStQLPVW.js} +1 -1
- package/build/assets/conversation-websocket-context-DvHgx_FE.js +3 -0
- package/build/assets/{copy-DYgmUdIw.js → copy-Chg-sFu3.js} +1 -1
- package/build/assets/{custom-toast-handlers-C-SZFmto.js → custom-toast-handlers-ufGJ6_Rc.js} +1 -1
- package/build/assets/declaration-CR6HMp29.js +1 -0
- package/build/assets/{device-verify-DqDlphsG.js → device-verify-C6mj28zv.js} +1 -1
- package/build/assets/dist-DNeWJ2bh.js +1 -0
- package/build/assets/dropdown-classes-BsVmxlNG.js +1 -0
- package/build/assets/edit-automation-modal-BpX-t-HD.js +1 -0
- package/build/assets/ellipsis-button-Vh5MvRZa.js +1 -0
- package/build/assets/entry.client-Ck9rQCg-.js +2 -0
- package/build/assets/enum-filter-dropdown-5JeF2RLb.js +1 -0
- package/build/assets/{environment-switch-overlay-XL8yCGP6.js → environment-switch-overlay-Tf_BIfeR.js} +1 -1
- package/build/assets/extensions-hub-CE9QOb5n.js +1 -0
- package/build/assets/{extensions-navigation-BYR8Giqq.js → extensions-navigation-DSLGNGbS.js} +1 -1
- package/build/assets/file-BTY6Gyy9.js +1 -0
- package/build/assets/files-tab-cL668j1I.js +1 -0
- package/build/assets/files-tab-store-m0ARqX_E.js +1 -0
- package/build/assets/{folder-ZZJVGgd7.js → folder-D1T2W1cj.js} +1 -1
- package/build/assets/git-control-bar-branch-button-DtIrOrie.js +27 -0
- package/build/assets/git-provider-icon-CHdGBdU2.js +1 -0
- package/build/assets/globe-Bzj_0oXT.js +1 -0
- package/build/assets/home-Cz2Veg56.js +1 -0
- package/build/assets/{i18n-CTohRuoO.js → i18n-DET2iOyh.js} +1 -1
- package/build/assets/install-server-modal-B9nXCS3u.js +1 -0
- package/build/assets/launch-CWz0dm4o.js +1 -0
- package/build/assets/{lesson-plan-dH5Bj0pN.js → lesson-plan-duSsqWVs.js} +1 -1
- package/build/assets/link-external-DGxVm4Ps.js +1 -0
- package/build/assets/{llm-client-DaH1TuyR.js → llm-client-CYEaUjGx.js} +1 -1
- package/build/assets/llm-settings-DFkXHuvT.js +1 -0
- package/build/assets/llm-settings-DhrdCXqX.js +1 -0
- package/build/assets/{loading-spinner-BPtYORNK.js → loading-spinner-5GT9q1xy.js} +1 -1
- package/build/assets/manage-backends-modal-DpBD_vR9.js +1 -0
- package/build/assets/manage-workspaces-modal-CtRbxREx.js +1 -0
- package/build/assets/manifest-eed90ff5.js +1 -0
- package/build/assets/{markdown-renderer-DMzf2i4x.js → markdown-renderer-B3IAVfv4.js} +1 -1
- package/build/assets/mcp-BUe7kiYM.js +9 -0
- package/build/assets/messages-dqp_KYyl.js +36 -0
- package/build/assets/{modal-backdrop-BAbgYsqB.js → modal-backdrop-RfNCrSpK.js} +1 -1
- package/build/assets/{modal-body-BI6Ru2Qr.js → modal-body-aoa2fx5W.js} +1 -1
- package/build/assets/modal-classes-6YqcqA6y.js +1 -0
- package/build/assets/{modal-close-button-t1Gh3qmL.js → modal-close-button-CtWOUMmw.js} +1 -1
- package/build/assets/{model-selector-SM9IUz-q.js → model-selector-BvSTrkhT.js} +1 -1
- package/build/assets/{navigation-context-D0YWpT8d.js → navigation-context-BdKYH32C.js} +1 -1
- package/build/assets/{navigation-link-Cn7KP3c5.js → navigation-link-U4vY9i_C.js} +1 -1
- package/build/assets/{openhands-logo-CnrF6LKb.js → openhands-logo-CCo0wJZX.js} +1 -1
- package/build/assets/{option-service.api-KvY_mZMY.js → option-service.api-DmNVxAvS.js} +1 -1
- package/build/assets/{organization-service.api-DzYTHTYC.js → organization-service.api-DbnougaQ.js} +1 -1
- package/build/assets/{path-utils-C3bQf6lJ.js → path-utils-onx24uF5.js} +1 -1
- package/build/assets/{plan-components-atxXCF0R.js → plan-components-CRDMQzsS.js} +1 -1
- package/build/assets/{planner-tab-BlrCpv-7.js → planner-tab-CmIjLz7q.js} +1 -1
- package/build/assets/{profiles-client-D6IkTJof.js → profiles-client-fEmgWkCW.js} +1 -1
- package/build/assets/{providers-Bx6EfrzZ.js → providers-CbD7fiic.js} +1 -1
- package/build/assets/proxy-BAdHH8QB.js +1 -0
- package/build/assets/{query-client-config-B7u9asM0.js → query-client-config-CRnGSujB.js} +1 -1
- package/build/assets/{recommended-automations-launcher-BQChv2rc.js → recommended-automations-launcher-uTyODuzB.js} +3 -3
- package/build/assets/{root-BgEbw3S0.js → root-DmjpFpTu.js} +2 -2
- package/build/assets/root-Z2VHU4R3.css +1 -0
- package/build/assets/root-layout-DejMsKhy.js +2 -0
- package/build/assets/{sdk-section-page-DOIKvwSL.js → sdk-section-page-BgDlMhcq.js} +1 -1
- package/build/assets/{sdk-settings-schema-DsUf9wu1.js → sdk-settings-schema-CLmJ9sho.js} +1 -1
- package/build/assets/{search-27Owlc3A.js → search-SuJctqNJ.js} +1 -1
- package/build/assets/secrets-service-B7CxNinp.js +1 -0
- package/build/assets/secrets-settings-yK7CqIpm.js +1 -0
- package/build/assets/{server-client-DyAQ3NZ_.js → server-client-Kh4QSwDJ.js} +1 -1
- package/build/assets/{settings-BYkVX7vW.js → settings-DN5PpgRD.js} +1 -1
- package/build/assets/{settings-dropdown-input-BJYvGdg-.js → settings-dropdown-input-BtoovFre.js} +1 -1
- package/build/assets/{settings-gear-C77PgE_O.js → settings-gear-Dd8K2_8B.js} +1 -1
- package/build/assets/settings-index-DKC8IY1P.js +1 -0
- package/build/assets/{settings-input-Bn7F5C75.js → settings-input-CehsXnb3.js} +1 -1
- package/build/assets/settings-list-classes-E3v_f6QG.js +1 -0
- package/build/assets/settings-modal-DJ4kGzUx.js +1 -0
- package/build/assets/{settings-section-header-context-BgZe5YkE.js → settings-section-header-context-DewwJ0-F.js} +1 -1
- package/build/assets/settings-service.api-C3rxTtPj.js +1 -0
- package/build/assets/{settings-switch-BeIKrWms.js → settings-switch-BiBuS3xa.js} +1 -1
- package/build/assets/{settings-utils-B6Nl07io.js → settings-utils-DY04tWG1.js} +1 -1
- package/build/assets/{shared-conversation-AMyqXvpk.js → shared-conversation-h9YnBtCU.js} +1 -1
- package/build/assets/sidebar-mobile-menu-toggle-D0-AvsnT.js +1 -0
- package/build/assets/{sidebar-nav-link-BGjiJq-4.js → sidebar-nav-link-OhIeFyna.js} +1 -1
- package/build/assets/{sidebar-store-Uy3v0AOV.js → sidebar-store-DnQAJAE5.js} +1 -1
- package/build/assets/{skill-card-pill-row-DF1axQCG.js → skill-card-pill-row-BW9qvhoK.js} +1 -1
- package/build/assets/{skills-ChIKZPK4.js → skills-0GRKX5Xj.js} +1 -1
- package/build/assets/{skills-plugins-CcI_19lM.js → skills-plugins-DNcsNF88.js} +1 -1
- package/build/assets/skills-settings-7liFiSY6.js +2 -0
- package/build/assets/{styled-tooltip-CBzrri6o.js → styled-tooltip-hdfMXPQC.js} +1 -1
- package/build/assets/{switch-skeleton-DnC9wLp7.js → switch-skeleton-DSKqSx2A.js} +1 -1
- package/build/assets/{task-list-tab-DUJn1sgz.js → task-list-tab-DT6_zfUs.js} +1 -1
- package/build/assets/{terminal-DgQk1Ay6.js → terminal-CDhQGDua.js} +2 -2
- package/build/assets/{terminal-RmuaSdhJ.js → terminal-CPYWdo4j.js} +1 -1
- package/build/assets/{toggle-switch-Pvyp2RAN.js → toggle-switch-T2v6sJ6l.js} +1 -1
- package/build/assets/{typography-gpuWmrQO.js → typography-BDgnT7Yp.js} +1 -1
- package/build/assets/{u-check-circle-IUIfACQQ.js → u-check-circle-DOauqQKb.js} +1 -1
- package/build/assets/{u-check-circle-half-C1YxB6py.js → u-check-circle-half-steSK_JB.js} +1 -1
- package/build/assets/{u-circuit-BmVikJHu.js → u-circuit-x3ExjBbU.js} +1 -1
- package/build/assets/{u-edit-CFvXHqZk.js → u-edit-BbrptMCa.js} +1 -1
- package/build/assets/{use-active-conversation-BEFNwnFk.js → use-active-conversation-DHGcmjCK.js} +1 -1
- package/build/assets/use-agent-settings-schema-CLoTOSJI.js +1 -0
- package/build/assets/{use-agent-state-Bkrd1FZq.js → use-agent-state-PKrUPMJ3.js} +1 -1
- package/build/assets/{use-cloud-current-user-id-CvkXFnTT.js → use-cloud-current-user-id-Ddr75hEz.js} +1 -1
- package/build/assets/{use-config-Co1O8-Ey.js → use-config-OIMQLQ2s.js} +1 -1
- package/build/assets/{use-create-conversation-CEgXpkfH.js → use-create-conversation-Bszyp13O.js} +1 -1
- package/build/assets/{use-event-store-BT_gV3ut.js → use-event-store-BomO7ywK.js} +1 -1
- package/build/assets/{use-get-secrets-DuhdIA59.js → use-get-secrets-8Jby8ele.js} +1 -1
- package/build/assets/{use-handle-plan-click-Ckkm5eIY.js → use-handle-plan-click-CohJPvvW.js} +1 -1
- package/build/assets/use-is-authed-dw2026rR.js +1 -0
- package/build/assets/{use-is-creating-conversation-BZ5hB_Bg.js → use-is-creating-conversation-DX2qSlfL.js} +1 -1
- package/build/assets/{use-launch-skill-in-chat-fNN_xGZG.js → use-launch-skill-in-chat-sQNEOLGD.js} +1 -1
- package/build/assets/use-llm-profiles-C861aFAq.js +1 -0
- package/build/assets/use-runtime-is-ready-Do2h_hRl.js +1 -0
- package/build/assets/{use-save-settings-VUrj_QNG.js → use-save-settings-DkAOEfD9.js} +1 -1
- package/build/assets/use-settings-D5hbTS9t.js +1 -0
- package/build/assets/{use-settings-nav-items-1ZvovKSr.js → use-settings-nav-items-BcSbo02d.js} +1 -1
- package/build/assets/{use-skills-DAMLFjKU.js → use-skills-D7PS0fH0.js} +1 -1
- package/build/assets/{use-task-list-CLJbuJgM.js → use-task-list-CsT10CBb.js} +1 -1
- package/build/assets/{use-unified-vscode-url-DdSRw-6P.js → use-unified-vscode-url-DEoe-NRI.js} +1 -1
- package/build/assets/use-user-conversation-Cs5H1pUF.js +1 -0
- package/build/assets/{useMutation-DqrumCWD.js → useMutation-GSSKKebK.js} +1 -1
- package/build/assets/{useTranslation-DCOdSSMl.js → useTranslation-B6voJV4y.js} +1 -1
- package/build/assets/utils-DCVfKFRt.js +1 -0
- package/build/assets/{vendor~browser-BNjNhjFU.js → vendor~browser-BrOJLj3y.js} +1 -1
- package/build/assets/vendor~conversation-panel~conversation-C9o-K1hW.js +1 -0
- package/build/assets/vendor~conversation-panel~conversation~index-RXYdJYxU.js +1 -0
- package/build/assets/{vendor~entry.client~root~root-layout~home~conversation-panel~conversation~launch~skills-set~jfc6hidu-VnmIZrq3.js → vendor~entry.client~root~root-layout~home~conversation-panel~conversation~launch~skills-set~jfc6hidu-DJS-rJdI.js} +1 -1
- package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-DpAdkv8m.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-6ByzelMS.js} +1 -1
- package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-B92czPCF.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-BED5W_c4.js} +1 -1
- package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-By5W2oHN.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-CCbqAFiI.js} +1 -1
- package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-BbFOrAjI.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-CG96FCly.js} +1 -1
- package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-smY2r837.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-E4d6IEfI.js} +1 -1
- package/build/assets/vendor~home~mcp~automations-list-CZSK-lT2.js +1 -0
- package/build/assets/{vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-Z3nsiNNq.js → vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-CjJdFLoM.js} +1 -1
- package/build/assets/{vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-DbfELDJu.js → vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-m8dOii0J.js} +2 -2
- package/build/assets/{vendor~root-layout~home~conversation-panel~conversation-DjAjXS5J.js → vendor~root-layout~home~conversation-panel~conversation-B5WNMnt4.js} +1 -1
- package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~i4kjfqhl-CbAhtEMv.js +1 -0
- package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-6Rm8U_Sr.js +9 -0
- package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-BkQGKpye.js → vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-tTR8C6m0.js} +1 -1
- package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~k776hupu-Bbs7UJ5U.js → vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~k776hupu-BJbu9kpL.js} +2 -2
- package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~dp08i1qy-DTwbEEcX.js → vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~dp08i1qy-hTzSytKK.js} +1 -1
- package/build/assets/{vendor~root~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-s~f2l2lr17-CDXvdvb2.js → vendor~root~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-s~f2l2lr17-DYXOLEck.js} +1 -1
- package/build/assets/{verification-settings-CsbvQcYS.js → verification-settings-Dlt8pINd.js} +1 -1
- package/build/assets/{vscode-tab-DjNArCgY.js → vscode-tab-DgepcYtF.js} +1 -1
- package/build/assets/{waiting-for-runtime-message-CntjExbU.js → waiting-for-runtime-message-CdK3btDZ.js} +1 -1
- package/build/assets/{x-mark-CrpjscNc.js → x-mark-BrkSPIiT.js} +1 -1
- package/build/index.html +4 -4
- package/build/locales/ar/openhands.json +20 -2
- package/build/locales/ca/openhands.json +20 -2
- package/build/locales/de/openhands.json +20 -2
- package/build/locales/en/openhands.json +20 -2
- package/build/locales/es/openhands.json +20 -2
- package/build/locales/fr/openhands.json +20 -2
- package/build/locales/it/openhands.json +20 -2
- package/build/locales/ja/openhands.json +20 -2
- package/build/locales/ko-KR/openhands.json +20 -2
- package/build/locales/no/openhands.json +20 -2
- package/build/locales/pt/openhands.json +20 -2
- package/build/locales/tr/openhands.json +20 -2
- package/build/locales/uk/openhands.json +20 -2
- package/build/locales/zh-CN/openhands.json +20 -2
- package/build/locales/zh-TW/openhands.json +20 -2
- package/dist/api/acp-service/acp-service.api.d.ts +18 -0
- package/dist/api/agent-server-adapter.cjs +3 -3
- package/dist/api/agent-server-adapter.cjs.map +1 -1
- package/dist/api/agent-server-adapter.js +54 -55
- package/dist/api/agent-server-adapter.js.map +1 -1
- package/dist/api/agent-server-client-options.cjs +1 -1
- package/dist/api/agent-server-client-options.cjs.map +1 -1
- package/dist/api/agent-server-client-options.d.ts +4 -0
- package/dist/api/agent-server-client-options.js +18 -12
- package/dist/api/agent-server-client-options.js.map +1 -1
- package/dist/api/agent-server-compatibility.cjs +1 -1
- package/dist/api/agent-server-compatibility.cjs.map +1 -1
- package/dist/api/agent-server-compatibility.d.ts +1 -1
- package/dist/api/agent-server-compatibility.js +30 -25
- package/dist/api/agent-server-compatibility.js.map +1 -1
- package/dist/api/agent-server-config.cjs +1 -1
- package/dist/api/agent-server-config.cjs.map +1 -1
- package/dist/api/agent-server-config.d.ts +1 -51
- package/dist/api/agent-server-config.js +20 -70
- package/dist/api/agent-server-config.js.map +1 -1
- package/dist/api/backend-registry/active-store.cjs +1 -1
- package/dist/api/backend-registry/active-store.cjs.map +1 -1
- package/dist/api/backend-registry/active-store.d.ts +11 -5
- package/dist/api/backend-registry/active-store.js +36 -27
- package/dist/api/backend-registry/active-store.js.map +1 -1
- package/dist/api/backend-registry/auth.cjs +1 -1
- package/dist/api/backend-registry/auth.cjs.map +1 -1
- package/dist/api/backend-registry/auth.js +3 -9
- package/dist/api/backend-registry/auth.js.map +1 -1
- package/dist/api/backend-registry/default-backend.cjs +1 -1
- package/dist/api/backend-registry/default-backend.cjs.map +1 -1
- package/dist/api/backend-registry/default-backend.d.ts +9 -16
- package/dist/api/backend-registry/default-backend.js +5 -4
- package/dist/api/backend-registry/default-backend.js.map +1 -1
- package/dist/api/backend-registry/storage.cjs +1 -1
- package/dist/api/backend-registry/storage.cjs.map +1 -1
- package/dist/api/backend-registry/storage.js +67 -34
- package/dist/api/backend-registry/storage.js.map +1 -1
- package/dist/api/cloud/conversation-service.api.cjs.map +1 -1
- package/dist/api/cloud/conversation-service.api.d.ts +8 -13
- package/dist/api/cloud/conversation-service.api.js.map +1 -1
- package/dist/api/cloud/organization-service.api.cjs.map +1 -1
- package/dist/api/cloud/organization-service.api.d.ts +1 -2
- package/dist/api/cloud/organization-service.api.js.map +1 -1
- package/dist/api/cloud/proxy.cjs +1 -1
- package/dist/api/cloud/proxy.cjs.map +1 -1
- package/dist/api/cloud/proxy.d.ts +6 -6
- package/dist/api/cloud/proxy.js +33 -24
- package/dist/api/cloud/proxy.js.map +1 -1
- package/dist/api/cloud/sandbox-service.api.cjs.map +1 -1
- package/dist/api/cloud/sandbox-service.api.d.ts +3 -3
- package/dist/api/cloud/sandbox-service.api.js.map +1 -1
- package/dist/api/cloud/secrets-service.api.cjs.map +1 -1
- package/dist/api/cloud/secrets-service.api.d.ts +3 -4
- package/dist/api/cloud/secrets-service.api.js.map +1 -1
- package/dist/api/cloud/settings-service.api.cjs +1 -1
- package/dist/api/cloud/settings-service.api.cjs.map +1 -1
- package/dist/api/cloud/settings-service.api.js +5 -1
- package/dist/api/cloud/settings-service.api.js.map +1 -1
- package/dist/api/cloud/skills-service.api.cjs.map +1 -1
- package/dist/api/cloud/skills-service.api.d.ts +5 -5
- package/dist/api/cloud/skills-service.api.js.map +1 -1
- package/dist/api/conversation-service/agent-server-conversation-service.api.cjs +1 -1
- package/dist/api/conversation-service/agent-server-conversation-service.api.cjs.map +1 -1
- package/dist/api/conversation-service/agent-server-conversation-service.api.js +115 -108
- package/dist/api/conversation-service/agent-server-conversation-service.api.js.map +1 -1
- package/dist/api/device-flow-client.cjs +1 -1
- package/dist/api/device-flow-client.cjs.map +1 -1
- package/dist/api/device-flow-client.d.ts +3 -5
- package/dist/api/device-flow-client.js +55 -66
- package/dist/api/device-flow-client.js.map +1 -1
- package/dist/api/event-service/event-service.api.cjs +1 -1
- package/dist/api/event-service/event-service.api.cjs.map +1 -1
- package/dist/api/event-service/event-service.api.d.ts +3 -3
- package/dist/api/event-service/event-service.api.js +17 -17
- package/dist/api/event-service/event-service.api.js.map +1 -1
- package/dist/api/git-service/agent-server-git-service.api.cjs +1 -1
- package/dist/api/git-service/agent-server-git-service.api.js +11 -11
- package/dist/api/runtime-service/agent-server-runtime-service.cjs +1 -1
- package/dist/api/runtime-service/agent-server-runtime-service.js +6 -6
- package/dist/components/conversation-events/chat/event-content-helpers/get-action-content.cjs +2 -2
- package/dist/components/conversation-events/chat/event-content-helpers/get-action-content.js +10 -10
- package/dist/components/conversation-events/chat/event-content-helpers/get-observation-result.cjs.map +1 -1
- package/dist/components/conversation-events/chat/event-content-helpers/get-observation-result.d.ts +5 -5
- package/dist/components/conversation-events/chat/event-content-helpers/get-observation-result.js.map +1 -1
- package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.cjs +1 -1
- package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.cjs.map +1 -1
- package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.js +1 -1
- package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.js.map +1 -1
- package/dist/components/features/automations/automation-action-button-classes.d.ts +2 -2
- package/dist/components/features/backends/backend-form-modal.cjs +1 -1
- package/dist/components/features/backends/backend-form-modal.cjs.map +1 -1
- package/dist/components/features/backends/backend-form-modal.d.ts +1 -0
- package/dist/components/features/backends/backend-form-modal.js +203 -140
- package/dist/components/features/backends/backend-form-modal.js.map +1 -1
- package/dist/components/features/backends/backend-selector.cjs +1 -1
- package/dist/components/features/backends/backend-selector.cjs.map +1 -1
- package/dist/components/features/backends/backend-selector.js +117 -105
- package/dist/components/features/backends/backend-selector.js.map +1 -1
- package/dist/components/features/backends/backend-status-dot.cjs +1 -1
- package/dist/components/features/backends/backend-status-dot.cjs.map +1 -1
- package/dist/components/features/backends/backend-status-dot.d.ts +1 -1
- package/dist/components/features/backends/backend-status-dot.js +1 -1
- package/dist/components/features/backends/backend-status-dot.js.map +1 -1
- package/dist/components/features/backends/manage-backends-modal.cjs +1 -1
- package/dist/components/features/backends/manage-backends-modal.cjs.map +1 -1
- package/dist/components/features/backends/manage-backends-modal.js +81 -70
- package/dist/components/features/backends/manage-backends-modal.js.map +1 -1
- package/dist/components/features/chat/change-agent-button.cjs +1 -1
- package/dist/components/features/chat/change-agent-button.cjs.map +1 -1
- package/dist/components/features/chat/change-agent-button.js +59 -57
- package/dist/components/features/chat/change-agent-button.js.map +1 -1
- package/dist/components/features/chat/change-agent-context-menu.cjs +1 -1
- package/dist/components/features/chat/change-agent-context-menu.cjs.map +1 -1
- package/dist/components/features/chat/change-agent-context-menu.d.ts +3 -1
- package/dist/components/features/chat/change-agent-context-menu.js +30 -25
- package/dist/components/features/chat/change-agent-context-menu.js.map +1 -1
- package/dist/components/features/chat/chat-add-file-button.cjs +1 -1
- package/dist/components/features/chat/chat-add-file-button.cjs.map +1 -1
- package/dist/components/features/chat/chat-add-file-button.js +39 -38
- package/dist/components/features/chat/chat-add-file-button.js.map +1 -1
- package/dist/components/features/chat/chat-message.cjs +1 -1
- package/dist/components/features/chat/chat-message.cjs.map +1 -1
- package/dist/components/features/chat/chat-message.d.ts +2 -1
- package/dist/components/features/chat/chat-message.js +185 -57
- package/dist/components/features/chat/chat-message.js.map +1 -1
- package/dist/components/features/chat/components/chat-input-actions.cjs +1 -1
- package/dist/components/features/chat/components/chat-input-actions.cjs.map +1 -1
- package/dist/components/features/chat/components/chat-input-actions.js +113 -113
- package/dist/components/features/chat/components/chat-input-actions.js.map +1 -1
- package/dist/components/features/chat/components/chat-input-model.cjs +1 -1
- package/dist/components/features/chat/components/chat-input-model.cjs.map +1 -1
- package/dist/components/features/chat/components/chat-input-model.js +52 -51
- package/dist/components/features/chat/components/chat-input-model.js.map +1 -1
- package/dist/components/features/chat/components/slash-command-menu.cjs +2 -2
- package/dist/components/features/chat/components/slash-command-menu.cjs.map +1 -1
- package/dist/components/features/chat/components/slash-command-menu.js +38 -34
- package/dist/components/features/chat/components/slash-command-menu.js.map +1 -1
- package/dist/components/features/chat/git-control-bar-pr-button.cjs +1 -1
- package/dist/components/features/chat/git-control-bar-pr-button.cjs.map +1 -1
- package/dist/components/features/chat/git-control-bar-pr-button.js +16 -15
- package/dist/components/features/chat/git-control-bar-pr-button.js.map +1 -1
- package/dist/components/features/chat/git-control-bar-pull-button.cjs +1 -1
- package/dist/components/features/chat/git-control-bar-pull-button.cjs.map +1 -1
- package/dist/components/features/chat/git-control-bar-pull-button.js +16 -15
- package/dist/components/features/chat/git-control-bar-pull-button.js.map +1 -1
- package/dist/components/features/chat/git-control-bar-push-button.cjs +1 -1
- package/dist/components/features/chat/git-control-bar-push-button.cjs.map +1 -1
- package/dist/components/features/chat/git-control-bar-push-button.js +16 -15
- package/dist/components/features/chat/git-control-bar-push-button.js.map +1 -1
- package/dist/components/features/chat/git-control-bar.cjs +1 -1
- package/dist/components/features/chat/git-control-bar.cjs.map +1 -1
- package/dist/components/features/chat/git-control-bar.js +63 -62
- package/dist/components/features/chat/git-control-bar.js.map +1 -1
- package/dist/components/features/chat/pending-user-messages.cjs +1 -1
- package/dist/components/features/chat/pending-user-messages.cjs.map +1 -1
- package/dist/components/features/chat/pending-user-messages.js +27 -23
- package/dist/components/features/chat/pending-user-messages.js.map +1 -1
- package/dist/components/features/chat/switch-profile-button.cjs +1 -1
- package/dist/components/features/chat/switch-profile-button.cjs.map +1 -1
- package/dist/components/features/chat/switch-profile-button.js +26 -25
- package/dist/components/features/chat/switch-profile-button.js.map +1 -1
- package/dist/components/features/chat/switch-profile-context-menu.cjs +1 -1
- package/dist/components/features/chat/switch-profile-context-menu.cjs.map +1 -1
- package/dist/components/features/chat/switch-profile-context-menu.js +77 -67
- package/dist/components/features/chat/switch-profile-context-menu.js.map +1 -1
- package/dist/components/features/context-menu/context-menu-icon-text-with-description.cjs +1 -1
- package/dist/components/features/context-menu/context-menu-icon-text-with-description.cjs.map +1 -1
- package/dist/components/features/context-menu/context-menu-icon-text-with-description.d.ts +2 -1
- package/dist/components/features/context-menu/context-menu-icon-text-with-description.js +3 -2
- package/dist/components/features/context-menu/context-menu-icon-text-with-description.js.map +1 -1
- package/dist/components/features/context-menu/context-menu-icon-text.cjs +1 -1
- package/dist/components/features/context-menu/context-menu-icon-text.cjs.map +1 -1
- package/dist/components/features/context-menu/context-menu-icon-text.d.ts +2 -1
- package/dist/components/features/context-menu/context-menu-icon-text.js +20 -10
- package/dist/components/features/context-menu/context-menu-icon-text.js.map +1 -1
- package/dist/components/features/context-menu/context-menu-list-item.cjs +1 -1
- package/dist/components/features/context-menu/context-menu-list-item.cjs.map +1 -1
- package/dist/components/features/context-menu/context-menu-list-item.js +10 -9
- package/dist/components/features/context-menu/context-menu-list-item.js.map +1 -1
- package/dist/components/features/controls/agent-status.cjs +1 -1
- package/dist/components/features/controls/agent-status.js +12 -12
- package/dist/components/features/controls/git-tools-submenu.cjs +1 -1
- package/dist/components/features/controls/git-tools-submenu.cjs.map +1 -1
- package/dist/components/features/controls/git-tools-submenu.js +1 -1
- package/dist/components/features/controls/git-tools-submenu.js.map +1 -1
- package/dist/components/features/controls/macros-submenu.cjs +1 -1
- package/dist/components/features/controls/macros-submenu.cjs.map +1 -1
- package/dist/components/features/controls/macros-submenu.js +1 -1
- package/dist/components/features/controls/macros-submenu.js.map +1 -1
- package/dist/components/features/controls/server-status-context-menu-icon-text.cjs +1 -1
- package/dist/components/features/controls/server-status-context-menu-icon-text.cjs.map +1 -1
- package/dist/components/features/controls/server-status-context-menu-icon-text.js +14 -15
- package/dist/components/features/controls/server-status-context-menu-icon-text.js.map +1 -1
- package/dist/components/features/controls/server-status-context-menu.cjs +1 -1
- package/dist/components/features/controls/server-status-context-menu.js +4 -4
- package/dist/components/features/controls/server-status.cjs +1 -1
- package/dist/components/features/controls/server-status.js +7 -7
- package/dist/components/features/controls/tools-context-menu-icon-text.cjs +1 -1
- package/dist/components/features/controls/tools-context-menu-icon-text.cjs.map +1 -1
- package/dist/components/features/controls/tools-context-menu-icon-text.js +16 -16
- package/dist/components/features/controls/tools-context-menu-icon-text.js.map +1 -1
- package/dist/components/features/conversation/conversation-name-context-menu-icon-text.cjs +1 -1
- package/dist/components/features/conversation/conversation-name-context-menu-icon-text.cjs.map +1 -1
- package/dist/components/features/conversation/conversation-name-context-menu-icon-text.js +11 -11
- package/dist/components/features/conversation/conversation-name-context-menu-icon-text.js.map +1 -1
- package/dist/components/features/conversation/conversation-name-with-status.cjs +1 -1
- package/dist/components/features/conversation/conversation-name-with-status.js +11 -11
- package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.cjs +1 -1
- package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.cjs.map +1 -1
- package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.js +60 -47
- package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.js.map +1 -1
- package/dist/components/features/conversation-panel/cloud-new-conversation-menu.cjs +1 -1
- package/dist/components/features/conversation-panel/cloud-new-conversation-menu.cjs.map +1 -1
- package/dist/components/features/conversation-panel/cloud-new-conversation-menu.js +86 -82
- package/dist/components/features/conversation-panel/cloud-new-conversation-menu.js.map +1 -1
- package/dist/components/features/conversation-panel/conversation-card/conversation-card-actions.cjs +1 -1
- package/dist/components/features/conversation-panel/conversation-card/conversation-card-actions.js +4 -4
- package/dist/components/features/conversation-panel/conversation-card/conversation-card-footer.cjs +1 -1
- package/dist/components/features/conversation-panel/conversation-card/conversation-card-footer.js +9 -9
- package/dist/components/features/conversation-panel/conversation-panel-filter-menu.cjs +1 -1
- package/dist/components/features/conversation-panel/conversation-panel-filter-menu.cjs.map +1 -1
- package/dist/components/features/conversation-panel/conversation-panel-filter-menu.js +93 -93
- package/dist/components/features/conversation-panel/conversation-panel-filter-menu.js.map +1 -1
- package/dist/components/features/conversation-panel/conversation-panel.cjs +1 -1
- package/dist/components/features/conversation-panel/conversation-panel.cjs.map +1 -1
- package/dist/components/features/conversation-panel/conversation-panel.js +177 -177
- package/dist/components/features/conversation-panel/conversation-panel.js.map +1 -1
- package/dist/components/features/conversation-panel/ellipsis-button.cjs +1 -1
- package/dist/components/features/conversation-panel/ellipsis-button.cjs.map +1 -1
- package/dist/components/features/conversation-panel/ellipsis-button.js +13 -13
- package/dist/components/features/conversation-panel/ellipsis-button.js.map +1 -1
- package/dist/components/features/conversation-panel/local-new-conversation-menu.cjs +1 -1
- package/dist/components/features/conversation-panel/local-new-conversation-menu.cjs.map +1 -1
- package/dist/components/features/conversation-panel/local-new-conversation-menu.js +57 -53
- package/dist/components/features/conversation-panel/local-new-conversation-menu.js.map +1 -1
- package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.cjs +1 -1
- package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.cjs.map +1 -1
- package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.js +3 -2
- package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.js.map +1 -1
- package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.cjs +1 -1
- package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.cjs.map +1 -1
- package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.js +11 -8
- package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.js.map +1 -1
- package/dist/components/features/conversation-panel/system-message-modal/tab-content.cjs.map +1 -1
- package/dist/components/features/conversation-panel/system-message-modal/tab-content.d.ts +2 -5
- package/dist/components/features/conversation-panel/system-message-modal/tab-content.js.map +1 -1
- package/dist/components/features/files-tab/file-content-viewer.cjs +1 -1
- package/dist/components/features/files-tab/file-content-viewer.cjs.map +1 -1
- package/dist/components/features/files-tab/file-content-viewer.js +45 -42
- package/dist/components/features/files-tab/file-content-viewer.js.map +1 -1
- package/dist/components/features/home/llm-not-configured-banner.d.ts +11 -0
- package/dist/components/features/home/shared/dropdown-item.cjs +1 -1
- package/dist/components/features/home/shared/dropdown-item.cjs.map +1 -1
- package/dist/components/features/home/shared/dropdown-item.js +20 -16
- package/dist/components/features/home/shared/dropdown-item.js.map +1 -1
- package/dist/components/features/home/shared/generic-dropdown-menu.cjs +1 -1
- package/dist/components/features/home/shared/generic-dropdown-menu.cjs.map +1 -1
- package/dist/components/features/home/shared/generic-dropdown-menu.js +23 -22
- package/dist/components/features/home/shared/generic-dropdown-menu.js.map +1 -1
- package/dist/components/features/home/workspace-dropdown/folder-browser-modal.cjs +1 -1
- package/dist/components/features/home/workspace-dropdown/folder-browser-modal.cjs.map +1 -1
- package/dist/components/features/home/workspace-dropdown/folder-browser-modal.js +103 -102
- package/dist/components/features/home/workspace-dropdown/folder-browser-modal.js.map +1 -1
- package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.cjs +1 -1
- package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.cjs.map +1 -1
- package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.js +68 -67
- package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.js.map +1 -1
- package/dist/components/features/mcp-page/custom-server-editor.cjs +1 -1
- package/dist/components/features/mcp-page/custom-server-editor.cjs.map +1 -1
- package/dist/components/features/mcp-page/custom-server-editor.js +62 -60
- package/dist/components/features/mcp-page/custom-server-editor.js.map +1 -1
- package/dist/components/features/mcp-page/index.cjs +1 -1
- package/dist/components/features/mcp-page/index.d.ts +1 -0
- package/dist/components/features/mcp-page/index.js +1 -0
- package/dist/components/features/mcp-page/install-server-modal.cjs +1 -1
- package/dist/components/features/mcp-page/install-server-modal.cjs.map +1 -1
- package/dist/components/features/mcp-page/install-server-modal.js +150 -119
- package/dist/components/features/mcp-page/install-server-modal.js.map +1 -1
- package/dist/components/features/mcp-page/save-as-secret-toggle.cjs +2 -0
- package/dist/components/features/mcp-page/save-as-secret-toggle.cjs.map +1 -0
- package/dist/components/features/mcp-page/save-as-secret-toggle.d.ts +7 -0
- package/dist/components/features/mcp-page/save-as-secret-toggle.js +50 -0
- package/dist/components/features/mcp-page/save-as-secret-toggle.js.map +1 -0
- package/dist/components/features/onboarding/onboarding-modal.d.ts +2 -2
- package/dist/components/features/onboarding/steps/check-backend-step.d.ts +1 -1
- package/dist/components/features/onboarding/steps/choose-agent-step.d.ts +2 -1
- package/dist/components/features/onboarding/steps/setup-acp-secrets-step.d.ts +19 -10
- package/dist/components/features/settings/llm-profiles/llm-settings-local-view.cjs +1 -1
- package/dist/components/features/settings/llm-profiles/llm-settings-local-view.d.ts +5 -0
- package/dist/components/features/settings/llm-profiles/llm-settings-local-view.js +2 -0
- package/dist/components/features/settings/llm-profiles/profile-actions-menu.cjs +1 -1
- package/dist/components/features/settings/llm-profiles/profile-actions-menu.js +1 -0
- package/dist/components/features/skills/extensions-navigation.cjs +1 -1
- package/dist/components/features/skills/extensions-navigation.cjs.map +1 -1
- package/dist/components/features/skills/extensions-navigation.js +1 -1
- package/dist/components/features/skills/extensions-navigation.js.map +1 -1
- package/dist/components/shared/buttons/back-nav-button.cjs +2 -0
- package/dist/components/shared/buttons/back-nav-button.cjs.map +1 -0
- package/dist/components/shared/buttons/back-nav-button.d.ts +17 -0
- package/dist/components/shared/buttons/back-nav-button.js +33 -0
- package/dist/components/shared/buttons/back-nav-button.js.map +1 -0
- package/dist/components/shared/buttons/conversation-confirmation-buttons.cjs +1 -1
- package/dist/components/shared/buttons/conversation-confirmation-buttons.js +5 -5
- package/dist/components/shared/filters/enum-filter-dropdown.cjs +1 -1
- package/dist/components/shared/filters/enum-filter-dropdown.cjs.map +1 -1
- package/dist/components/shared/filters/enum-filter-dropdown.js +32 -31
- package/dist/components/shared/filters/enum-filter-dropdown.js.map +1 -1
- package/dist/components/shared/modals/confirmation-modals/base-modal.cjs +1 -1
- package/dist/components/shared/modals/confirmation-modals/base-modal.cjs.map +1 -1
- package/dist/components/shared/modals/confirmation-modals/base-modal.js +14 -13
- package/dist/components/shared/modals/confirmation-modals/base-modal.js.map +1 -1
- package/dist/components/shared/modals/settings/settings-modal.cjs +1 -1
- package/dist/components/shared/modals/settings/settings-modal.cjs.map +1 -1
- package/dist/components/shared/modals/settings/settings-modal.js +17 -16
- package/dist/components/shared/modals/settings/settings-modal.js.map +1 -1
- package/dist/components/shared/text-shimmer.cjs +2 -0
- package/dist/components/shared/text-shimmer.cjs.map +1 -0
- package/dist/components/shared/text-shimmer.d.ts +11 -0
- package/dist/components/shared/text-shimmer.js +43 -0
- package/dist/components/shared/text-shimmer.js.map +1 -0
- package/dist/constants/acp-providers.cjs +1 -1
- package/dist/constants/acp-providers.cjs.map +1 -1
- package/dist/constants/acp-providers.d.ts +16 -3
- package/dist/constants/acp-providers.js +0 -1
- package/dist/constants/acp-providers.js.map +1 -1
- package/dist/contexts/active-backend-context.cjs +1 -1
- package/dist/contexts/active-backend-context.cjs.map +1 -1
- package/dist/contexts/active-backend-context.js +32 -32
- package/dist/contexts/active-backend-context.js.map +1 -1
- package/dist/hooks/chat/use-chat-input-logic.cjs +1 -1
- package/dist/hooks/chat/use-chat-input-logic.cjs.map +1 -1
- package/dist/hooks/chat/use-chat-input-logic.js +13 -6
- package/dist/hooks/chat/use-chat-input-logic.js.map +1 -1
- package/dist/hooks/mutation/use-save-fields-as-secrets.cjs +2 -0
- package/dist/hooks/mutation/use-save-fields-as-secrets.cjs.map +1 -0
- package/dist/hooks/mutation/use-save-fields-as-secrets.d.ts +9 -0
- package/dist/hooks/mutation/use-save-fields-as-secrets.js +24 -0
- package/dist/hooks/mutation/use-save-fields-as-secrets.js.map +1 -0
- package/dist/hooks/mutation/use-unified-start-conversation.cjs +1 -1
- package/dist/hooks/mutation/use-unified-start-conversation.js +8 -8
- package/dist/hooks/mutation/use-unified-stop-conversation.cjs +1 -1
- package/dist/hooks/mutation/use-unified-stop-conversation.js +15 -15
- package/dist/hooks/query/use-acp-auth-status.d.ts +36 -0
- package/dist/hooks/query/use-agent-settings-schema.cjs +1 -1
- package/dist/hooks/query/use-agent-settings-schema.cjs.map +1 -1
- package/dist/hooks/query/use-agent-settings-schema.js +26 -16
- package/dist/hooks/query/use-agent-settings-schema.js.map +1 -1
- package/dist/hooks/query/use-backends-health.cjs +1 -1
- package/dist/hooks/query/use-backends-health.cjs.map +1 -1
- package/dist/hooks/query/use-backends-health.d.ts +2 -0
- package/dist/hooks/query/use-backends-health.js +31 -21
- package/dist/hooks/query/use-backends-health.js.map +1 -1
- package/dist/hooks/query/use-paginated-conversations.cjs +1 -1
- package/dist/hooks/query/use-paginated-conversations.cjs.map +1 -1
- package/dist/hooks/query/use-paginated-conversations.js +15 -14
- package/dist/hooks/query/use-paginated-conversations.js.map +1 -1
- package/dist/hooks/query/use-settings.cjs +1 -1
- package/dist/hooks/query/use-settings.cjs.map +1 -1
- package/dist/hooks/query/use-settings.js +65 -52
- package/dist/hooks/query/use-settings.js.map +1 -1
- package/dist/hooks/query/use-user-conversation.cjs +1 -1
- package/dist/hooks/query/use-user-conversation.cjs.map +1 -1
- package/dist/hooks/query/use-user-conversation.js +20 -11
- package/dist/hooks/query/use-user-conversation.js.map +1 -1
- package/dist/hooks/use-agent-state.cjs +1 -1
- package/dist/hooks/use-agent-state.js +13 -13
- package/dist/hooks/use-conversation-name-context-menu.cjs +1 -1
- package/dist/hooks/use-conversation-name-context-menu.js +10 -10
- package/dist/hooks/use-conversation-name-context-menu.js.map +1 -1
- package/dist/hooks/use-llm-configured.d.ts +25 -0
- package/dist/hooks/use-runtime-is-ready.cjs +1 -1
- package/dist/hooks/use-runtime-is-ready.js +5 -5
- package/dist/i18n/declaration.cjs +1 -1
- package/dist/i18n/declaration.cjs.map +1 -1
- package/dist/i18n/declaration.d.ts +19 -1
- package/dist/i18n/declaration.js +1 -1
- package/dist/i18n/declaration.js.map +1 -1
- package/dist/i18n/translation.cjs +3 -3
- package/dist/i18n/translation.cjs.map +1 -1
- package/dist/i18n/translation.js +321 -15
- package/dist/i18n/translation.js.map +1 -1
- package/dist/icons/stop-circle.cjs +1 -1
- package/dist/icons/stop-circle.cjs.map +1 -1
- package/dist/icons/stop-circle.js +7 -10
- package/dist/icons/stop-circle.js.map +1 -1
- package/dist/locales/ar/openhands.json +20 -2
- package/dist/locales/ca/openhands.json +20 -2
- package/dist/locales/de/openhands.json +20 -2
- package/dist/locales/en/openhands.json +20 -2
- package/dist/locales/es/openhands.json +20 -2
- package/dist/locales/fr/openhands.json +20 -2
- package/dist/locales/it/openhands.json +20 -2
- package/dist/locales/ja/openhands.json +20 -2
- package/dist/locales/ko-KR/openhands.json +20 -2
- package/dist/locales/no/openhands.json +20 -2
- package/dist/locales/pt/openhands.json +20 -2
- package/dist/locales/tr/openhands.json +20 -2
- package/dist/locales/uk/openhands.json +20 -2
- package/dist/locales/zh-CN/openhands.json +20 -2
- package/dist/locales/zh-TW/openhands.json +20 -2
- package/dist/node_modules/@openhands/extensions/integrations/catalog/airtable.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/airtable.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/airtable.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/airtable.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/apify.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/apify.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/apify.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/apify.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/brave-search.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/brave-search.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/brave-search.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/brave-search.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/clickhouse.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/clickhouse.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/clickhouse.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/clickhouse.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/elevenlabs.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/elevenlabs.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/elevenlabs.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/elevenlabs.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/exa.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/exa.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/exa.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/exa.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/figma.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/figma.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/figma.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/figma.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/firecrawl.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/firecrawl.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/firecrawl.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/firecrawl.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/github.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/github.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/github.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/github.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/kagi.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/kagi.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/kagi.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/kagi.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/mongodb.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/mongodb.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/mongodb.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/mongodb.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/neon.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/neon.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/neon.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/neon.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/notion.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/notion.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/notion.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/notion.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/obsidian.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/obsidian.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/obsidian.js +2 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/obsidian.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/redis.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/redis.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/redis.js +2 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/redis.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/resend.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/resend.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/resend.js +3 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/resend.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/slack.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/slack.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/slack.js +8 -7
- package/dist/node_modules/@openhands/extensions/integrations/catalog/slack.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/supabase.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/supabase.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/supabase.js +2 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/supabase.js.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/tavily.cjs +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/tavily.cjs.map +1 -1
- package/dist/node_modules/@openhands/extensions/integrations/catalog/tavily.js +4 -2
- package/dist/node_modules/@openhands/extensions/integrations/catalog/tavily.js.map +1 -1
- package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.cjs +2 -0
- package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.cjs.map +1 -0
- package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.js +15 -0
- package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.js.map +1 -0
- package/dist/package.cjs +1 -1
- package/dist/package.cjs.map +1 -1
- package/dist/package.js +2 -2
- package/dist/package.js.map +1 -1
- package/dist/routes/conversation.cjs +1 -1
- package/dist/routes/conversation.cjs.map +1 -1
- package/dist/routes/conversation.js +1 -1
- package/dist/routes/conversation.js.map +1 -1
- package/dist/routes/llm-settings.cjs +1 -1
- package/dist/routes/llm-settings.cjs.map +1 -1
- package/dist/routes/llm-settings.js +55 -54
- package/dist/routes/llm-settings.js.map +1 -1
- package/dist/routes/secrets-settings.cjs +1 -1
- package/dist/routes/secrets-settings.cjs.map +1 -1
- package/dist/routes/secrets-settings.js +19 -27
- package/dist/routes/secrets-settings.js.map +1 -1
- package/dist/stores/conversation-store.cjs +1 -1
- package/dist/stores/conversation-store.cjs.map +1 -1
- package/dist/stores/conversation-store.d.ts +4 -0
- package/dist/stores/conversation-store.js +6 -0
- package/dist/stores/conversation-store.js.map +1 -1
- package/dist/types/agent-server/core/events/acp-tool-call-event.d.ts +6 -4
- package/dist/types/agent-server/core/events/system-event.d.ts +5 -0
- package/dist/types/automation.d.ts +15 -0
- package/dist/types/settings.d.ts +3 -1
- package/dist/ui/combobox-caret.cjs +1 -1
- package/dist/ui/combobox-caret.cjs.map +1 -1
- package/dist/ui/combobox-caret.d.ts +1 -1
- package/dist/ui/combobox-caret.js +9 -8
- package/dist/ui/combobox-caret.js.map +1 -1
- package/dist/ui/context-menu.cjs +1 -1
- package/dist/ui/context-menu.cjs.map +1 -1
- package/dist/ui/context-menu.js +9 -8
- package/dist/ui/context-menu.js.map +1 -1
- package/dist/ui/dropdown/dropdown-menu.cjs +1 -1
- package/dist/ui/dropdown/dropdown-menu.cjs.map +1 -1
- package/dist/ui/dropdown/dropdown-menu.js +21 -17
- package/dist/ui/dropdown/dropdown-menu.js.map +1 -1
- package/dist/ui/dropdown/dropdown.cjs +1 -1
- package/dist/ui/dropdown/dropdown.cjs.map +1 -1
- package/dist/ui/dropdown/dropdown.js +2 -2
- package/dist/ui/dropdown/dropdown.js.map +1 -1
- package/dist/utils/automation-schedule.d.ts +1 -0
- package/dist/utils/dropdown-classes.cjs +2 -0
- package/dist/utils/dropdown-classes.cjs.map +1 -0
- package/dist/utils/dropdown-classes.d.ts +32 -0
- package/dist/utils/dropdown-classes.js +8 -0
- package/dist/utils/dropdown-classes.js.map +1 -0
- package/dist/utils/form-control-classes.cjs +1 -1
- package/dist/utils/form-control-classes.cjs.map +1 -1
- package/dist/utils/form-control-classes.d.ts +18 -2
- package/dist/utils/form-control-classes.js +4 -3
- package/dist/utils/form-control-classes.js.map +1 -1
- package/dist/utils/git-control-bar-classes.cjs +2 -0
- package/dist/utils/git-control-bar-classes.cjs.map +1 -0
- package/dist/utils/git-control-bar-classes.d.ts +4 -0
- package/dist/utils/git-control-bar-classes.js +14 -0
- package/dist/utils/git-control-bar-classes.js.map +1 -0
- package/dist/utils/handle-event-for-ui.cjs.map +1 -1
- package/dist/utils/handle-event-for-ui.d.ts +6 -3
- package/dist/utils/handle-event-for-ui.js.map +1 -1
- package/dist/utils/mobile-top-bar-icon-button-classes.cjs +1 -1
- package/dist/utils/mobile-top-bar-icon-button-classes.cjs.map +1 -1
- package/dist/utils/mobile-top-bar-icon-button-classes.js +3 -3
- package/dist/utils/mobile-top-bar-icon-button-classes.js.map +1 -1
- package/dist/utils/modal-classes.cjs +2 -0
- package/dist/utils/modal-classes.cjs.map +1 -0
- package/dist/utils/modal-classes.d.ts +8 -0
- package/dist/utils/modal-classes.js +7 -0
- package/dist/utils/modal-classes.js.map +1 -0
- package/dist/utils/openhands-llm.cjs +2 -0
- package/dist/utils/openhands-llm.cjs.map +1 -0
- package/dist/utils/openhands-llm.d.ts +2 -0
- package/dist/utils/openhands-llm.js +9 -0
- package/dist/utils/openhands-llm.js.map +1 -0
- package/dist/utils/redact-custom-secrets.cjs +2 -0
- package/dist/utils/redact-custom-secrets.cjs.map +1 -0
- package/dist/utils/redact-custom-secrets.d.ts +6 -0
- package/dist/utils/redact-custom-secrets.js +10 -0
- package/dist/utils/redact-custom-secrets.js.map +1 -0
- package/dist/utils/status.cjs +1 -1
- package/dist/utils/status.cjs.map +1 -1
- package/dist/utils/status.d.ts +2 -1
- package/dist/utils/status.js +9 -8
- package/dist/utils/status.js.map +1 -1
- package/dist/utils/system-message-adapter.cjs +1 -1
- package/dist/utils/system-message-adapter.cjs.map +1 -1
- package/dist/utils/system-message-adapter.js +10 -7
- package/dist/utils/system-message-adapter.js.map +1 -1
- package/dist/utils/utils.cjs +1 -1
- package/dist/utils/utils.cjs.map +1 -1
- package/dist/utils/utils.d.ts +2 -1
- package/dist/utils/utils.js +21 -20
- package/dist/utils/utils.js.map +1 -1
- package/package.json +2 -2
- package/scripts/dev-safe.mjs +3 -1
- package/scripts/dev-static.mjs +2 -2
- package/scripts/dev-with-automation.mjs +283 -108
- package/scripts/static-build.mjs +20 -19
- package/scripts/static-server.mjs +50 -3
- package/build/assets/acp-providers-CbiRekh9.js +0 -1
- package/build/assets/active-backend-context-cCM1vYYZ.js +0 -1
- package/build/assets/add-backend-modal-DIUQzMPa.js +0 -1
- package/build/assets/agent-server-client-options-Bc5ZorQZ.js +0 -1
- package/build/assets/agent-server-compatibility-BlkUsrX2.js +0 -1
- package/build/assets/agent-server-conversation-service.api-C2V5SlHu.js +0 -5
- package/build/assets/api-key-entry-screen-B2gynaCp.js +0 -1
- package/build/assets/automation-detail-DJvbVSYK.js +0 -1
- package/build/assets/automations-list-rMki-8au.js +0 -1
- package/build/assets/backend-form-modal-Dnk33xA_.js +0 -1
- package/build/assets/base-modal-_dYTw1ri.js +0 -1
- package/build/assets/brand-button-Br7f0kZJ.js +0 -1
- package/build/assets/browser-store-Couc4S5D.js +0 -1
- package/build/assets/clock-BRjCgHTc.js +0 -1
- package/build/assets/combobox-caret-to1O8irE.js +0 -1
- package/build/assets/context-menu-list-item-CWNFpuiC.js +0 -1
- package/build/assets/conversation-DVrKU0oz.js +0 -19
- package/build/assets/conversation-Dlys-D5A.js +0 -1
- package/build/assets/conversation-panel-iF09WjZ4.js +0 -1
- package/build/assets/conversation-service.api-CCfztilW.js +0 -1
- package/build/assets/conversation-state-store-u5jepov0.js +0 -1
- package/build/assets/conversation-store-Z5iMCRpc.js +0 -1
- package/build/assets/conversation-websocket-context-DhJhqUna.js +0 -3
- package/build/assets/declaration-BNMqORFE.js +0 -1
- package/build/assets/dist-BxBP7tFD.js +0 -1
- package/build/assets/edit-automation-modal-BGzR3nfZ.js +0 -1
- package/build/assets/ellipsis-button-ZyLMPURn.js +0 -1
- package/build/assets/entry.client-1VMHpktY.js +0 -2
- package/build/assets/enum-filter-dropdown-CEgCdu4A.js +0 -1
- package/build/assets/extensions-hub-C651jsVh.js +0 -1
- package/build/assets/files-tab-R5z0lLdY.js +0 -1
- package/build/assets/files-tab-store-CDyVTXNT.js +0 -1
- package/build/assets/git-control-bar-branch-button-COdRAYHb.js +0 -27
- package/build/assets/git-provider-icon-BzLbc0yC.js +0 -1
- package/build/assets/home-XxBpNOVq.js +0 -1
- package/build/assets/install-server-modal-f31_CLrW.js +0 -1
- package/build/assets/launch-CshDse3e.js +0 -1
- package/build/assets/link-external-D2POYx4c.js +0 -1
- package/build/assets/llm-settings-Bql-vydt.js +0 -1
- package/build/assets/llm-settings-C_tal6Ds.js +0 -1
- package/build/assets/manage-backends-modal-l7RkKfwX.js +0 -1
- package/build/assets/manage-workspaces-modal-DhKF_8z3.js +0 -1
- package/build/assets/manifest-d9077852.js +0 -1
- package/build/assets/mcp-D2onbwVk.js +0 -9
- package/build/assets/messages-D0rWot7s.js +0 -36
- package/build/assets/proxy-CxydCnis.js +0 -1
- package/build/assets/root-DHeCXo9N.css +0 -1
- package/build/assets/root-layout-Czo9Ma6Q.js +0 -2
- package/build/assets/secrets-service-BsnKFc2x.js +0 -1
- package/build/assets/secrets-settings-Bz_UohPJ.js +0 -1
- package/build/assets/settings-client-C73C7IgV.js +0 -1
- package/build/assets/settings-index-Dz0BmdJD.js +0 -1
- package/build/assets/settings-list-classes-Bf80tWtc.js +0 -1
- package/build/assets/settings-modal-Brzgh5Yw.js +0 -1
- package/build/assets/settings-service.api-CZ3uWx4v.js +0 -1
- package/build/assets/sidebar-mobile-menu-toggle-Do_aA9Zm.js +0 -1
- package/build/assets/skills-settings-DlA5hlXw.js +0 -2
- package/build/assets/status-hp6M6E7E.js +0 -1
- package/build/assets/use-agent-settings-schema-33Un7UF2.js +0 -1
- package/build/assets/use-is-authed-BggE5wPj.js +0 -1
- package/build/assets/use-llm-profiles-DDOol3gK.js +0 -1
- package/build/assets/use-runtime-is-ready-B7EF4BKU.js +0 -1
- package/build/assets/use-settings-DQIZmIov.js +0 -1
- package/build/assets/use-user-conversation-C6hrMMtn.js +0 -1
- package/build/assets/utils-i18rdUj2.js +0 -1
- package/build/assets/vendor~conversation-panel~conversation-a9SyrrhV.js +0 -1
- package/build/assets/vendor~conversation-panel~conversation~index-C23ZXO4R.js +0 -1
- package/build/assets/vendor~home~mcp~automations-list-Ccy2I0KU.js +0 -1
- package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~i4kjfqhl-BebWhFNT.js +0 -1
- package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-DzIXV3Ui.js +0 -9
- /package/build/assets/{automation-IdgZq6ZK.js → automation-XDPAjiZi.js} +0 -0
- /package/build/assets/{color-themes-DSaoIL6A.js → color-themes-B9pm9c-R.js} +0 -0
- /package/build/assets/{common-DR1t-EeP.js → common-DqjLSBOt.js} +0 -0
- /package/build/assets/{conversation-local-storage-UYl-SX-r.js → conversation-local-storage-YmOVXxxW.js} +0 -0
- /package/build/assets/{dist-C6t0EXL7.js → dist-C3NfioQC.js} +0 -0
- /package/build/assets/{environment-switch-store-C4ulFJKp.js → environment-switch-store-CiurvTtK.js} +0 -0
- /package/build/assets/{health-store-BDC2rM-X.js → health-store-B5f0S2FY.js} +0 -0
- /package/build/assets/{map-provider-COBVzZYo.js → map-provider-BJ_8KZKU.js} +0 -0
- /package/build/assets/{middleware-BC9EwbB9.js → middleware-CfatjPYZ.js} +0 -0
- /package/build/assets/{objectWithoutPropertiesLoose-Du6eBn-V.js → objectWithoutPropertiesLoose-DSQKyRhw.js} +0 -0
- /package/build/assets/{react-Do0CT17Y.js → react-Dy05vyj5.js} +0 -0
- /package/build/assets/{sdk-settings-field-metadata-CBPmeqYa.js → sdk-settings-field-metadata-DQiaIBie.js} +0 -0
- /package/build/assets/{settings-D_H-qsRm.js → settings-DGY6n4J2.js} +0 -0
- /package/build/assets/{settings-like-page-layout-classes-I0BDBEoq.js → settings-like-page-layout-classes-D7YjdTd0.js} +0 -0
- /package/build/assets/{use-breakpoint-DbJ6FkQ-.js → use-breakpoint-DF_RiQ6s.js} +0 -0
- /package/build/assets/{use-click-outside-element-DffgWWoZ.js → use-click-outside-element-DhxCUyWl.js} +0 -0
- /package/build/assets/{v4-CNn21NXa.js → v4-khGvL7i2.js} +0 -0
- /package/build/assets/{vendor~browser-DDiZgqD3.js → vendor~browser-DisFGEp9.js} +0 -0
- /package/build/assets/{vendor~browser-tab-BgwV1mxF.js → vendor~browser-tab-BxhTtM9_.js} +0 -0
- /package/build/assets/{vendor~conversation-panel~conversation~alert-banner-DbvX3OcM.js → vendor~conversation-panel~conversation~alert-banner-w-I2sY6c.js} +0 -0
- /package/build/assets/{vendor~entry.client~root~root-layout~home~conversation-panel~conversation~launch~skills-set~zm51vy4j-iOsylxCS.js → vendor~entry.client~root~root-layout~home~conversation-panel~conversation~launch~skills-set~zm51vy4j-BClAMeFe.js} +0 -0
- /package/build/assets/{vendor~files-tab-BGKayPiK.js → vendor~files-tab-BtkpAiMX.js} +0 -0
- /package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-BW6261Sb.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-CyZ-3lDQ.js} +0 -0
- /package/build/assets/{vendor~home~mcp~automations-list-DoPfwaXj.js → vendor~home~mcp~automations-list-BgV86Sti.js} +0 -0
- /package/build/assets/{vendor~launch-vdeRTWFu.js → vendor~launch-BXgl67Re.js} +0 -0
- /package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~ninslayh-D9P8e98a.js → vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~ninslayh-CLlsvdNP.js} +0 -0
- /package/build/assets/{vendor~terminal-DUrOWGFE.js → vendor~terminal-DZaJIY8A.js} +0 -0
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
const e=require(`../../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../../utils/utils.cjs`);let
|
|
1
|
+
const e=require(`../../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../../utils/utils.cjs`),n=require(`../../../../utils/dropdown-classes.cjs`);let r=require(`react`);r=e.__toESM(r,1);let i=require(`react/jsx-runtime`);function a({isOpen:e,filteredItems:a,inputValue:o,highlightedIndex:s,selectedItem:c,getMenuProps:l,getItemProps:u,onScroll:d,menuRef:f,renderItem:p,renderEmptyState:m,stickyTopItem:h,stickyFooterItem:g,testId:_,numberOfRecentItems:v=0,itemKey:y}){let b=!(a.length>0)&&!h&&!g;return e?(0,i.jsx)(`div`,{className:`relative`,children:(0,i.jsxs)(`div`,{className:t.cn(`absolute z-10 w-full bg-tertiary border border-[var(--oh-border-input)] rounded-lg shadow-none`,`focus:outline-none mt-1 z-[9999]`,`max-h-60`),children:[(0,i.jsx)(`ul`,{...l({ref:f,className:t.cn(`w-full overflow-auto p-1 custom-scrollbar-always`,n.dropdownMenuListClassName,h||g?`max-h-[calc(15rem-3rem)]`:`max-h-60`),onScroll:d,"data-testid":_}),children:b?m(o):(0,i.jsxs)(i.Fragment,{children:[h,a.map((e,t)=>{let n=y(e);return(0,i.jsxs)(r.default.Fragment,{children:[p(e,t,s,c,u),v>0&&t===v-1&&(0,i.jsx)(`div`,{className:`border-b border-[var(--oh-border-input)] bg-tertiary pb-1 mb-1 h-[1px]`})]},n)})]})}),g&&(0,i.jsx)(`div`,{className:`border-t border-[var(--oh-border-input)] bg-tertiary p-1 rounded-b-lg`,children:g})]})}):(0,i.jsx)(`div`,{className:`relative`,children:(0,i.jsx)(`ul`,{...l({ref:f,className:`hidden`,"data-testid":_})})})}exports.GenericDropdownMenu=a;
|
|
2
2
|
//# sourceMappingURL=generic-dropdown-menu.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generic-dropdown-menu.cjs","names":[],"sources":["../../../../../src/components/features/home/shared/generic-dropdown-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport {\n UseComboboxGetMenuPropsOptions,\n UseComboboxGetItemPropsOptions,\n} from \"downshift\";\nimport { cn } from \"#/utils/utils\";\n\nexport interface GenericDropdownMenuProps<T> {\n isOpen: boolean;\n filteredItems: T[];\n inputValue: string;\n highlightedIndex: number;\n selectedItem: T | null;\n getMenuProps: <Options>(\n options?: UseComboboxGetMenuPropsOptions & Options,\n ) => any; // eslint-disable-line @typescript-eslint/no-explicit-any\n getItemProps: <Options>(\n options: UseComboboxGetItemPropsOptions<T> & Options,\n ) => any; // eslint-disable-line @typescript-eslint/no-explicit-any\n onScroll?: (event: React.UIEvent<HTMLUListElement>) => void;\n menuRef?: React.RefObject<HTMLUListElement | null>;\n renderItem: (\n item: T,\n index: number,\n highlightedIndex: number,\n selectedItem: T | null,\n getItemProps: <Options>(\n options: UseComboboxGetItemPropsOptions<T> & Options,\n ) => any, // eslint-disable-line @typescript-eslint/no-explicit-any\n ) => React.ReactNode;\n renderEmptyState: (inputValue: string) => React.ReactNode;\n stickyTopItem?: React.ReactNode;\n stickyFooterItem?: React.ReactNode;\n testId?: string;\n numberOfRecentItems?: number;\n itemKey: (item: T) => string | number;\n}\n\nexport function GenericDropdownMenu<T>({\n isOpen,\n filteredItems,\n inputValue,\n highlightedIndex,\n selectedItem,\n getMenuProps,\n getItemProps,\n onScroll,\n menuRef,\n renderItem,\n renderEmptyState,\n stickyTopItem,\n stickyFooterItem,\n testId,\n numberOfRecentItems = 0,\n itemKey,\n}: GenericDropdownMenuProps<T>) {\n const hasItems = filteredItems.length > 0;\n const showEmptyState = !hasItems && !stickyTopItem && !stickyFooterItem;\n\n // Always render the menu container (even when closed) so getMenuProps is always called\n // This prevents the downshift warning about forgetting to call getMenuProps\n if (!isOpen) {\n return (\n <div className=\"relative\">\n <ul\n {...getMenuProps({\n ref: menuRef,\n className: \"hidden\",\n \"data-testid\": testId,\n })}\n />\n </div>\n );\n }\n\n return (\n <div className=\"relative\">\n <div\n className={cn(\n \"absolute z-10 w-full bg-tertiary border border-[var(--oh-border-input)] rounded-lg shadow-none\",\n \"focus:outline-none mt-1 z-[9999]\",\n stickyTopItem || stickyFooterItem ? \"max-h-60\" : \"max-h-60\",\n )}\n >\n <ul\n {...getMenuProps({\n ref: menuRef,\n className: cn(\n \"w-full overflow-auto p-1 custom-scrollbar-always\",\n stickyTopItem || stickyFooterItem\n ? \"max-h-[calc(15rem-3rem)]\"\n : \"max-h-60\", // Reserve space for sticky items\n ),\n onScroll,\n \"data-testid\": testId,\n })}\n >\n {showEmptyState ? (\n renderEmptyState(inputValue)\n ) : (\n <>\n {stickyTopItem}\n {filteredItems.map((item, index) => {\n const key = itemKey(item);\n return (\n <React.Fragment key={key}>\n {renderItem(\n item,\n index,\n highlightedIndex,\n selectedItem,\n getItemProps,\n )}\n {numberOfRecentItems > 0 &&\n index === numberOfRecentItems - 1 && (\n <div className=\"border-b border-[var(--oh-border-input)] bg-tertiary pb-1 mb-1 h-[1px]\" />\n )}\n </React.Fragment>\n );\n })}\n </>\n )}\n </ul>\n {stickyFooterItem && (\n <div className=\"border-t border-[var(--oh-border-input)] bg-tertiary p-1 rounded-b-lg\">\n {stickyFooterItem}\n </div>\n )}\n </div>\n </div>\n );\n}\n"],"mappings":"
|
|
1
|
+
{"version":3,"file":"generic-dropdown-menu.cjs","names":[],"sources":["../../../../../src/components/features/home/shared/generic-dropdown-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport {\n UseComboboxGetMenuPropsOptions,\n UseComboboxGetItemPropsOptions,\n} from \"downshift\";\nimport { cn } from \"#/utils/utils\";\nimport { dropdownMenuListClassName } from \"#/utils/dropdown-classes\";\n\nexport interface GenericDropdownMenuProps<T> {\n isOpen: boolean;\n filteredItems: T[];\n inputValue: string;\n highlightedIndex: number;\n selectedItem: T | null;\n getMenuProps: <Options>(\n options?: UseComboboxGetMenuPropsOptions & Options,\n ) => any; // eslint-disable-line @typescript-eslint/no-explicit-any\n getItemProps: <Options>(\n options: UseComboboxGetItemPropsOptions<T> & Options,\n ) => any; // eslint-disable-line @typescript-eslint/no-explicit-any\n onScroll?: (event: React.UIEvent<HTMLUListElement>) => void;\n menuRef?: React.RefObject<HTMLUListElement | null>;\n renderItem: (\n item: T,\n index: number,\n highlightedIndex: number,\n selectedItem: T | null,\n getItemProps: <Options>(\n options: UseComboboxGetItemPropsOptions<T> & Options,\n ) => any, // eslint-disable-line @typescript-eslint/no-explicit-any\n ) => React.ReactNode;\n renderEmptyState: (inputValue: string) => React.ReactNode;\n stickyTopItem?: React.ReactNode;\n stickyFooterItem?: React.ReactNode;\n testId?: string;\n numberOfRecentItems?: number;\n itemKey: (item: T) => string | number;\n}\n\nexport function GenericDropdownMenu<T>({\n isOpen,\n filteredItems,\n inputValue,\n highlightedIndex,\n selectedItem,\n getMenuProps,\n getItemProps,\n onScroll,\n menuRef,\n renderItem,\n renderEmptyState,\n stickyTopItem,\n stickyFooterItem,\n testId,\n numberOfRecentItems = 0,\n itemKey,\n}: GenericDropdownMenuProps<T>) {\n const hasItems = filteredItems.length > 0;\n const showEmptyState = !hasItems && !stickyTopItem && !stickyFooterItem;\n\n // Always render the menu container (even when closed) so getMenuProps is always called\n // This prevents the downshift warning about forgetting to call getMenuProps\n if (!isOpen) {\n return (\n <div className=\"relative\">\n <ul\n {...getMenuProps({\n ref: menuRef,\n className: \"hidden\",\n \"data-testid\": testId,\n })}\n />\n </div>\n );\n }\n\n return (\n <div className=\"relative\">\n <div\n className={cn(\n \"absolute z-10 w-full bg-tertiary border border-[var(--oh-border-input)] rounded-lg shadow-none\",\n \"focus:outline-none mt-1 z-[9999]\",\n stickyTopItem || stickyFooterItem ? \"max-h-60\" : \"max-h-60\",\n )}\n >\n <ul\n {...getMenuProps({\n ref: menuRef,\n className: cn(\n \"w-full overflow-auto p-1 custom-scrollbar-always\",\n dropdownMenuListClassName,\n stickyTopItem || stickyFooterItem\n ? \"max-h-[calc(15rem-3rem)]\"\n : \"max-h-60\", // Reserve space for sticky items\n ),\n onScroll,\n \"data-testid\": testId,\n })}\n >\n {showEmptyState ? (\n renderEmptyState(inputValue)\n ) : (\n <>\n {stickyTopItem}\n {filteredItems.map((item, index) => {\n const key = itemKey(item);\n return (\n <React.Fragment key={key}>\n {renderItem(\n item,\n index,\n highlightedIndex,\n selectedItem,\n getItemProps,\n )}\n {numberOfRecentItems > 0 &&\n index === numberOfRecentItems - 1 && (\n <div className=\"border-b border-[var(--oh-border-input)] bg-tertiary pb-1 mb-1 h-[1px]\" />\n )}\n </React.Fragment>\n );\n })}\n </>\n )}\n </ul>\n {stickyFooterItem && (\n <div className=\"border-t border-[var(--oh-border-input)] bg-tertiary p-1 rounded-b-lg\">\n {stickyFooterItem}\n </div>\n )}\n </div>\n </div>\n );\n}\n"],"mappings":"sOAuCA,SAAgB,EAAuB,CACrC,SACA,gBACA,aACA,mBACA,eACA,eACA,eACA,WACA,UACA,aACA,mBACA,gBACA,mBACA,SACA,sBAAsB,EACtB,WAC8B,CAE9B,IAAM,EAAiB,EADN,EAAc,OAAS,IACJ,CAAC,GAAiB,CAAC,EAkBvD,OAdK,GAeH,EAAA,EAAA,KAAC,MAAD,CAAK,UAAU,qBACb,EAAA,EAAA,MAAC,MAAD,CACE,UAAW,EAAA,GACT,iGACA,mCACoC,WACrC,UALH,EAOE,EAAA,EAAA,KAAC,KAAD,CACE,GAAI,EAAa,CACf,IAAK,EACL,UAAW,EAAA,GACT,mDACA,EAAA,0BACA,GAAiB,EACb,2BACA,WACL,CACD,WACA,cAAe,EAChB,CAAC,UAED,EACC,EAAiB,EAAW,EAE5B,EAAA,EAAA,MAAA,EAAA,SAAA,CAAA,SAAA,CACG,EACA,EAAc,KAAK,EAAM,IAAU,CAClC,IAAM,EAAM,EAAQ,EAAK,CACzB,OACE,EAAA,EAAA,MAAC,EAAA,QAAM,SAAP,CAAA,SAAA,CACG,EACC,EACA,EACA,EACA,EACA,EACD,CACA,EAAsB,GACrB,IAAU,EAAsB,IAC9B,EAAA,EAAA,KAAC,MAAD,CAAK,UAAU,yEAA2E,CAAA,CAE/E,CAAA,CAZI,EAYJ,EAEnB,CACD,CAAA,CAAA,CAEF,CAAA,CACJ,IACC,EAAA,EAAA,KAAC,MAAD,CAAK,UAAU,iFACZ,EACG,CAAA,CAEJ,GACF,CAAA,EAnEJ,EAAA,EAAA,KAAC,MAAD,CAAK,UAAU,qBACb,EAAA,EAAA,KAAC,KAAD,CACE,GAAI,EAAa,CACf,IAAK,EACL,UAAW,SACX,cAAe,EAChB,CAAC,CACF,CAAA,CACE,CAAA"}
|
|
@@ -1,39 +1,40 @@
|
|
|
1
1
|
import { cn as e } from "../../../../utils/utils.js";
|
|
2
|
-
import t from "
|
|
3
|
-
import
|
|
2
|
+
import { dropdownMenuListClassName as t } from "../../../../utils/dropdown-classes.js";
|
|
3
|
+
import n from "react";
|
|
4
|
+
import { Fragment as r, jsx as i, jsxs as a } from "react/jsx-runtime";
|
|
4
5
|
//#region src/components/features/home/shared/generic-dropdown-menu.tsx
|
|
5
|
-
function
|
|
6
|
-
let
|
|
7
|
-
return
|
|
6
|
+
function o({ isOpen: o, filteredItems: s, inputValue: c, highlightedIndex: l, selectedItem: u, getMenuProps: d, getItemProps: f, onScroll: p, menuRef: m, renderItem: h, renderEmptyState: g, stickyTopItem: _, stickyFooterItem: v, testId: y, numberOfRecentItems: b = 0, itemKey: x }) {
|
|
7
|
+
let S = !(s.length > 0) && !_ && !v;
|
|
8
|
+
return o ? /* @__PURE__ */ i("div", {
|
|
8
9
|
className: "relative",
|
|
9
|
-
children: /* @__PURE__ */
|
|
10
|
+
children: /* @__PURE__ */ a("div", {
|
|
10
11
|
className: e("absolute z-10 w-full bg-tertiary border border-[var(--oh-border-input)] rounded-lg shadow-none", "focus:outline-none mt-1 z-[9999]", "max-h-60"),
|
|
11
|
-
children: [/* @__PURE__ */
|
|
12
|
-
...
|
|
13
|
-
ref:
|
|
14
|
-
className: e("w-full overflow-auto p-1 custom-scrollbar-always",
|
|
15
|
-
onScroll:
|
|
16
|
-
"data-testid":
|
|
12
|
+
children: [/* @__PURE__ */ i("ul", {
|
|
13
|
+
...d({
|
|
14
|
+
ref: m,
|
|
15
|
+
className: e("w-full overflow-auto p-1 custom-scrollbar-always", t, _ || v ? "max-h-[calc(15rem-3rem)]" : "max-h-60"),
|
|
16
|
+
onScroll: p,
|
|
17
|
+
"data-testid": y
|
|
17
18
|
}),
|
|
18
|
-
children:
|
|
19
|
-
let
|
|
20
|
-
return /* @__PURE__ */
|
|
19
|
+
children: S ? g(c) : /* @__PURE__ */ a(r, { children: [_, s.map((e, t) => {
|
|
20
|
+
let r = x(e);
|
|
21
|
+
return /* @__PURE__ */ a(n.Fragment, { children: [h(e, t, l, u, f), b > 0 && t === b - 1 && /* @__PURE__ */ i("div", { className: "border-b border-[var(--oh-border-input)] bg-tertiary pb-1 mb-1 h-[1px]" })] }, r);
|
|
21
22
|
})] })
|
|
22
|
-
}),
|
|
23
|
+
}), v && /* @__PURE__ */ i("div", {
|
|
23
24
|
className: "border-t border-[var(--oh-border-input)] bg-tertiary p-1 rounded-b-lg",
|
|
24
|
-
children:
|
|
25
|
+
children: v
|
|
25
26
|
})]
|
|
26
27
|
})
|
|
27
|
-
}) : /* @__PURE__ */
|
|
28
|
+
}) : /* @__PURE__ */ i("div", {
|
|
28
29
|
className: "relative",
|
|
29
|
-
children: /* @__PURE__ */
|
|
30
|
-
ref:
|
|
30
|
+
children: /* @__PURE__ */ i("ul", { ...d({
|
|
31
|
+
ref: m,
|
|
31
32
|
className: "hidden",
|
|
32
|
-
"data-testid":
|
|
33
|
+
"data-testid": y
|
|
33
34
|
}) })
|
|
34
35
|
});
|
|
35
36
|
}
|
|
36
37
|
//#endregion
|
|
37
|
-
export {
|
|
38
|
+
export { o as GenericDropdownMenu };
|
|
38
39
|
|
|
39
40
|
//# sourceMappingURL=generic-dropdown-menu.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generic-dropdown-menu.js","names":[],"sources":["../../../../../src/components/features/home/shared/generic-dropdown-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport {\n UseComboboxGetMenuPropsOptions,\n UseComboboxGetItemPropsOptions,\n} from \"downshift\";\nimport { cn } from \"#/utils/utils\";\n\nexport interface GenericDropdownMenuProps<T> {\n isOpen: boolean;\n filteredItems: T[];\n inputValue: string;\n highlightedIndex: number;\n selectedItem: T | null;\n getMenuProps: <Options>(\n options?: UseComboboxGetMenuPropsOptions & Options,\n ) => any; // eslint-disable-line @typescript-eslint/no-explicit-any\n getItemProps: <Options>(\n options: UseComboboxGetItemPropsOptions<T> & Options,\n ) => any; // eslint-disable-line @typescript-eslint/no-explicit-any\n onScroll?: (event: React.UIEvent<HTMLUListElement>) => void;\n menuRef?: React.RefObject<HTMLUListElement | null>;\n renderItem: (\n item: T,\n index: number,\n highlightedIndex: number,\n selectedItem: T | null,\n getItemProps: <Options>(\n options: UseComboboxGetItemPropsOptions<T> & Options,\n ) => any, // eslint-disable-line @typescript-eslint/no-explicit-any\n ) => React.ReactNode;\n renderEmptyState: (inputValue: string) => React.ReactNode;\n stickyTopItem?: React.ReactNode;\n stickyFooterItem?: React.ReactNode;\n testId?: string;\n numberOfRecentItems?: number;\n itemKey: (item: T) => string | number;\n}\n\nexport function GenericDropdownMenu<T>({\n isOpen,\n filteredItems,\n inputValue,\n highlightedIndex,\n selectedItem,\n getMenuProps,\n getItemProps,\n onScroll,\n menuRef,\n renderItem,\n renderEmptyState,\n stickyTopItem,\n stickyFooterItem,\n testId,\n numberOfRecentItems = 0,\n itemKey,\n}: GenericDropdownMenuProps<T>) {\n const hasItems = filteredItems.length > 0;\n const showEmptyState = !hasItems && !stickyTopItem && !stickyFooterItem;\n\n // Always render the menu container (even when closed) so getMenuProps is always called\n // This prevents the downshift warning about forgetting to call getMenuProps\n if (!isOpen) {\n return (\n <div className=\"relative\">\n <ul\n {...getMenuProps({\n ref: menuRef,\n className: \"hidden\",\n \"data-testid\": testId,\n })}\n />\n </div>\n );\n }\n\n return (\n <div className=\"relative\">\n <div\n className={cn(\n \"absolute z-10 w-full bg-tertiary border border-[var(--oh-border-input)] rounded-lg shadow-none\",\n \"focus:outline-none mt-1 z-[9999]\",\n stickyTopItem || stickyFooterItem ? \"max-h-60\" : \"max-h-60\",\n )}\n >\n <ul\n {...getMenuProps({\n ref: menuRef,\n className: cn(\n \"w-full overflow-auto p-1 custom-scrollbar-always\",\n stickyTopItem || stickyFooterItem\n ? \"max-h-[calc(15rem-3rem)]\"\n : \"max-h-60\", // Reserve space for sticky items\n ),\n onScroll,\n \"data-testid\": testId,\n })}\n >\n {showEmptyState ? (\n renderEmptyState(inputValue)\n ) : (\n <>\n {stickyTopItem}\n {filteredItems.map((item, index) => {\n const key = itemKey(item);\n return (\n <React.Fragment key={key}>\n {renderItem(\n item,\n index,\n highlightedIndex,\n selectedItem,\n getItemProps,\n )}\n {numberOfRecentItems > 0 &&\n index === numberOfRecentItems - 1 && (\n <div className=\"border-b border-[var(--oh-border-input)] bg-tertiary pb-1 mb-1 h-[1px]\" />\n )}\n </React.Fragment>\n );\n })}\n </>\n )}\n </ul>\n {stickyFooterItem && (\n <div className=\"border-t border-[var(--oh-border-input)] bg-tertiary p-1 rounded-b-lg\">\n {stickyFooterItem}\n </div>\n )}\n </div>\n </div>\n );\n}\n"],"mappings":"
|
|
1
|
+
{"version":3,"file":"generic-dropdown-menu.js","names":[],"sources":["../../../../../src/components/features/home/shared/generic-dropdown-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport {\n UseComboboxGetMenuPropsOptions,\n UseComboboxGetItemPropsOptions,\n} from \"downshift\";\nimport { cn } from \"#/utils/utils\";\nimport { dropdownMenuListClassName } from \"#/utils/dropdown-classes\";\n\nexport interface GenericDropdownMenuProps<T> {\n isOpen: boolean;\n filteredItems: T[];\n inputValue: string;\n highlightedIndex: number;\n selectedItem: T | null;\n getMenuProps: <Options>(\n options?: UseComboboxGetMenuPropsOptions & Options,\n ) => any; // eslint-disable-line @typescript-eslint/no-explicit-any\n getItemProps: <Options>(\n options: UseComboboxGetItemPropsOptions<T> & Options,\n ) => any; // eslint-disable-line @typescript-eslint/no-explicit-any\n onScroll?: (event: React.UIEvent<HTMLUListElement>) => void;\n menuRef?: React.RefObject<HTMLUListElement | null>;\n renderItem: (\n item: T,\n index: number,\n highlightedIndex: number,\n selectedItem: T | null,\n getItemProps: <Options>(\n options: UseComboboxGetItemPropsOptions<T> & Options,\n ) => any, // eslint-disable-line @typescript-eslint/no-explicit-any\n ) => React.ReactNode;\n renderEmptyState: (inputValue: string) => React.ReactNode;\n stickyTopItem?: React.ReactNode;\n stickyFooterItem?: React.ReactNode;\n testId?: string;\n numberOfRecentItems?: number;\n itemKey: (item: T) => string | number;\n}\n\nexport function GenericDropdownMenu<T>({\n isOpen,\n filteredItems,\n inputValue,\n highlightedIndex,\n selectedItem,\n getMenuProps,\n getItemProps,\n onScroll,\n menuRef,\n renderItem,\n renderEmptyState,\n stickyTopItem,\n stickyFooterItem,\n testId,\n numberOfRecentItems = 0,\n itemKey,\n}: GenericDropdownMenuProps<T>) {\n const hasItems = filteredItems.length > 0;\n const showEmptyState = !hasItems && !stickyTopItem && !stickyFooterItem;\n\n // Always render the menu container (even when closed) so getMenuProps is always called\n // This prevents the downshift warning about forgetting to call getMenuProps\n if (!isOpen) {\n return (\n <div className=\"relative\">\n <ul\n {...getMenuProps({\n ref: menuRef,\n className: \"hidden\",\n \"data-testid\": testId,\n })}\n />\n </div>\n );\n }\n\n return (\n <div className=\"relative\">\n <div\n className={cn(\n \"absolute z-10 w-full bg-tertiary border border-[var(--oh-border-input)] rounded-lg shadow-none\",\n \"focus:outline-none mt-1 z-[9999]\",\n stickyTopItem || stickyFooterItem ? \"max-h-60\" : \"max-h-60\",\n )}\n >\n <ul\n {...getMenuProps({\n ref: menuRef,\n className: cn(\n \"w-full overflow-auto p-1 custom-scrollbar-always\",\n dropdownMenuListClassName,\n stickyTopItem || stickyFooterItem\n ? \"max-h-[calc(15rem-3rem)]\"\n : \"max-h-60\", // Reserve space for sticky items\n ),\n onScroll,\n \"data-testid\": testId,\n })}\n >\n {showEmptyState ? (\n renderEmptyState(inputValue)\n ) : (\n <>\n {stickyTopItem}\n {filteredItems.map((item, index) => {\n const key = itemKey(item);\n return (\n <React.Fragment key={key}>\n {renderItem(\n item,\n index,\n highlightedIndex,\n selectedItem,\n getItemProps,\n )}\n {numberOfRecentItems > 0 &&\n index === numberOfRecentItems - 1 && (\n <div className=\"border-b border-[var(--oh-border-input)] bg-tertiary pb-1 mb-1 h-[1px]\" />\n )}\n </React.Fragment>\n );\n })}\n </>\n )}\n </ul>\n {stickyFooterItem && (\n <div className=\"border-t border-[var(--oh-border-input)] bg-tertiary p-1 rounded-b-lg\">\n {stickyFooterItem}\n </div>\n )}\n </div>\n </div>\n );\n}\n"],"mappings":";;;;;AAuCA,SAAgB,EAAuB,EACrC,WACA,kBACA,eACA,qBACA,iBACA,iBACA,iBACA,aACA,YACA,eACA,qBACA,kBACA,qBACA,WACA,yBAAsB,GACtB,cAC8B;CAE9B,IAAM,IAAiB,EADN,EAAc,SAAS,MACJ,CAAC,KAAiB,CAAC;AAkBvD,QAdK,IAeH,kBAAC,OAAD;EAAK,WAAU;YACb,kBAAC,OAAD;GACE,WAAW,EACT,kGACA,oCACoC,WACrC;aALH,CAOE,kBAAC,MAAD;IACE,GAAI,EAAa;KACf,KAAK;KACL,WAAW,EACT,oDACA,GACA,KAAiB,IACb,6BACA,WACL;KACD;KACA,eAAe;KAChB,CAAC;cAED,IACC,EAAiB,EAAW,GAE5B,kBAAA,GAAA,EAAA,UAAA,CACG,GACA,EAAc,KAAK,GAAM,MAAU;KAClC,IAAM,IAAM,EAAQ,EAAK;AACzB,YACE,kBAAC,EAAM,UAAP,EAAA,UAAA,CACG,EACC,GACA,GACA,GACA,GACA,EACD,EACA,IAAsB,KACrB,MAAU,IAAsB,KAC9B,kBAAC,OAAD,EAAK,WAAU,0EAA2E,CAAA,CAE/E,EAAA,EAZI,EAYJ;MAEnB,CACD,EAAA,CAAA;IAEF,CAAA,EACJ,KACC,kBAAC,OAAD;IAAK,WAAU;cACZ;IACG,CAAA,CAEJ;;EACF,CAAA,GAnEJ,kBAAC,OAAD;EAAK,WAAU;YACb,kBAAC,MAAD,EACE,GAAI,EAAa;GACf,KAAK;GACL,WAAW;GACX,eAAe;GAChB,CAAC,EACF,CAAA;EACE,CAAA"}
|
|
@@ -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(`../../../../contexts/active-backend-context.cjs`),a=require(`../../../shared/modals/modal-backdrop.cjs`),o=require(`../../../shared/modals/modal-body.cjs`),s=require(`../../../shared/modals/confirmation-modals/base-modal.cjs`),
|
|
1
|
+
const e=require(`../../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),n=require(`../../../../i18n/declaration.cjs`),r=require(`../../../../utils/utils.cjs`),i=require(`../../../../contexts/active-backend-context.cjs`),a=require(`../../../shared/modals/modal-backdrop.cjs`),o=require(`../../../shared/modals/modal-body.cjs`),s=require(`../../../../utils/modal-classes.cjs`),c=require(`../../../shared/modals/confirmation-modals/base-modal.cjs`),l=require(`../../settings/brand-button.cjs`),u=require(`../../../../hooks/query/use-search-subdirs.cjs`),d=require(`../../../../icons/folder.cjs`),f=require(`../../../../icons/chevron-left-small.cjs`);let p=require(`react`);p=e.__toESM(p,1);let m=require(`react/jsx-runtime`);var h=`/projects`;function g({label:e,entries:t,currentPath:n,onPick:i}){return t.length===0?null:(0,m.jsxs)(`div`,{className:`px-2 pb-3`,children:[(0,m.jsx)(`div`,{className:`px-2 pb-1 text-[11px] uppercase tracking-wide text-[var(--oh-muted)] font-semibold`,children:e}),(0,m.jsx)(`ul`,{children:t.map(e=>{let t=n===e.path;return(0,m.jsx)(`li`,{children:(0,m.jsxs)(`button`,{type:`button`,onClick:()=>i(e.path),"data-testid":`folder-browser-sidebar-${e.label.toLowerCase()}`,className:r.cn(`flex items-center gap-2 w-full px-2 py-1 rounded text-sm cursor-pointer`,t?`bg-tertiary text-white`:`text-[var(--oh-text-tertiary)] hover:bg-[var(--oh-surface-raised)]`),children:[(0,m.jsx)(d.default,{width:14,height:14,className:`shrink-0`}),(0,m.jsx)(`span`,{className:`truncate`,children:e.label})]})},e.path)})})]})}function _(e){let t=e.replace(/\/+$/,``);if(!t||t===`/`)return null;let n=t.lastIndexOf(`/`);return n<=0?`/`:t.slice(0,n)}function v(e){return e?.home===`/home/openhands`}function y({isOpen:e,onClose:y,onAdd:b,onAddParent:x}){let{t:S}=t.useTranslation(`openhands`),[C,w]=(0,p.useState)(null),T=i.useActiveBackend(),{data:E}=u.useHomeDirectory();(0,p.useEffect)(()=>{e&&E?.home&&C===null&&w(v(E)?h:E.home),e||w(null)},[e,E?.home,C]),(0,p.useEffect)(()=>{w(null)},[T.backend.id,T.orgId]);let{data:D,isLoading:O,isError:k,error:A}=u.useSearchSubdirs(e?C:null),j=(0,p.useMemo)(()=>{if(!E?.home)return[];let e=[{label:`Home`,path:E.home.replace(/[\\/]+$/,``)||E.home},...E.favorites??[]];return v(E)&&!e.some(e=>e.path===h)&&e.push({label:h,path:h}),e},[E]),M=E?.locations??[];if(!e)return null;let N=D?.items??[],P=C?_(C):null,F=E?.home===`/home/openhands`&&(E?.favorites?.length??0)===0&&C===E?.home&&!O&&!k&&N.length===0,I=e=>{let t=e.replace(/\/+$/,``);if(!t)return`/`;let n=t.lastIndexOf(`/`);return n>=0?t.slice(n+1)||`/`:t};return(0,m.jsx)(a.ModalBackdrop,{onClose:y,"aria-label":S(n.I18nKey.HOME$ADD_WORKSPACES_TITLE),children:(0,m.jsxs)(`div`,{"data-testid":`folder-browser-modal`,className:r.cn(`flex flex-col bg-[var(--oh-surface)] border border-[var(--oh-border-input)] rounded-xl`,o.modalWidthClassName(`xl`),o.MODAL_MAX_WIDTH_VIEWPORT,`h-[480px]`),children:[(0,m.jsx)(`div`,{className:`flex items-center justify-between px-5 py-3 border-b border-[var(--oh-border-input)]`,children:(0,m.jsx)(c.BaseModalTitle,{className:s.modalTitleSmClassName,title:S(n.I18nKey.HOME$ADD_WORKSPACES_TITLE)})}),(0,m.jsxs)(`div`,{className:`flex flex-1 min-h-0`,children:[(0,m.jsxs)(`aside`,{"data-testid":`folder-browser-sidebar`,className:`w-[180px] shrink-0 border-r border-[var(--oh-border-input)] bg-[var(--oh-surface)] py-3 overflow-y-auto`,children:[(0,m.jsx)(g,{label:S(n.I18nKey.HOME$FAVORITES),entries:j,currentPath:C,onPick:w}),(0,m.jsx)(g,{label:S(n.I18nKey.HOME$LOCATIONS),entries:M,currentPath:C,onPick:w})]}),(0,m.jsxs)(`div`,{className:`flex-1 flex flex-col min-w-0`,children:[(0,m.jsxs)(`div`,{className:`flex items-center gap-2 px-4 py-2 border-b border-[var(--oh-border-input)]`,children:[(0,m.jsx)(`button`,{type:`button`,"data-testid":`folder-browser-up`,onClick:()=>P&&w(P),disabled:!P,"aria-label":`Up`,className:`p-1 rounded hover:bg-[var(--oh-interactive-hover)] text-white disabled:opacity-40 disabled:cursor-not-allowed cursor-pointer`,children:(0,m.jsx)(f.default,{width:16,height:16})}),(0,m.jsx)(`span`,{className:`text-xs text-[var(--oh-muted)] truncate`,"data-testid":`folder-browser-current-path`,children:C??``})]}),(0,m.jsxs)(`div`,{className:`grid grid-cols-[1fr_120px] px-4 py-1 border-b border-[var(--oh-border-input)] text-xs text-[var(--oh-text-secondary)] font-semibold`,children:[(0,m.jsx)(`span`,{children:S(n.I18nKey.HOME$NAME)}),(0,m.jsx)(`span`,{children:S(n.I18nKey.HOME$KIND)})]}),(0,m.jsxs)(`ul`,{className:`flex-1 overflow-auto custom-scrollbar-always`,"data-testid":`folder-browser-list`,children:[O&&(0,m.jsx)(`li`,{className:`px-4 py-2 text-sm text-[var(--oh-text-secondary)]`,children:S(n.I18nKey.HOME$LOADING)}),k&&(0,m.jsx)(`li`,{className:`px-4 py-2 text-sm text-red-400`,"data-testid":`folder-browser-error`,children:A?.message??`Failed to load`}),!O&&!k&&N.length===0&&(0,m.jsx)(`li`,{className:`px-4 py-2 text-sm text-[var(--oh-text-secondary)]`,"data-testid":F?`folder-browser-host-home-hint`:`folder-browser-empty`,children:S(F?n.I18nKey.HOME$HOST_HOME_NOT_MOUNTED_HINT:n.I18nKey.HOME$NO_WORKSPACES)}),N.map(e=>(0,m.jsx)(`li`,{children:(0,m.jsxs)(`button`,{type:`button`,onClick:()=>w(e.path),className:`grid grid-cols-[1fr_120px] items-center w-full text-left px-4 py-1.5 text-sm text-white hover:bg-[var(--oh-interactive-hover)] cursor-pointer`,"data-testid":`folder-browser-entry-${e.name}`,children:[(0,m.jsxs)(`span`,{className:`flex items-center gap-2 min-w-0`,children:[(0,m.jsx)(d.default,{width:16,height:16,className:`shrink-0`}),(0,m.jsx)(`span`,{className:`truncate`,children:e.name})]}),(0,m.jsx)(`span`,{className:`text-[var(--oh-text-secondary)] text-xs`,children:S(n.I18nKey.HOME$FOLDER)})]})},e.path))]})]})]}),(0,m.jsxs)(`div`,{className:`flex items-center justify-end gap-2 px-5 py-3 border-t border-[var(--oh-border-input)]`,children:[(0,m.jsx)(l.BrandButton,{type:`button`,variant:`secondary`,onClick:y,testId:`folder-browser-cancel`,children:S(n.I18nKey.HOME$CANCEL)}),x&&(0,m.jsx)(l.BrandButton,{type:`button`,variant:`secondary`,onClick:()=>{!C||!x||(x([{id:C,name:I(C),path:C}]),y())},isDisabled:!C||O,testId:`folder-browser-add-all-subdirs`,children:S(n.I18nKey.HOME$ADD_ALL_SUBDIRECTORIES)}),(0,m.jsx)(l.BrandButton,{type:`button`,variant:`primary`,onClick:()=>{C&&(b([{id:C,name:I(C),path:C}]),y())},isDisabled:!C||O,testId:`folder-browser-use`,children:S(n.I18nKey.HOME$ADD_THIS_DIRECTORY)})]})]})})}exports.FolderBrowserModal=y;
|
|
2
2
|
//# sourceMappingURL=folder-browser-modal.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"folder-browser-modal.cjs","names":[],"sources":["../../../../../src/components/features/home/workspace-dropdown/folder-browser-modal.tsx"],"sourcesContent":["import React, { useEffect, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\n\nimport { BaseModalTitle } from \"#/components/shared/modals/confirmation-modals/base-modal\";\nimport { ModalBackdrop } from \"#/components/shared/modals/modal-backdrop\";\nimport {\n MODAL_MAX_WIDTH_VIEWPORT,\n modalWidthClassName,\n} from \"#/components/shared/modals/modal-body\";\nimport { BrandButton } from \"#/components/features/settings/brand-button\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { LocalWorkspace, LocalWorkspaceParent } from \"#/types/workspace\";\nimport {\n type HomeDirectoryResponse,\n useHomeDirectory,\n useSearchSubdirs,\n} from \"#/hooks/query/use-search-subdirs\";\nimport { useActiveBackend } from \"#/contexts/active-backend-context\";\nimport { cn } from \"#/utils/utils\";\nimport FolderIcon from \"#/icons/folder.svg?react\";\nimport ChevronLeft from \"#/icons/chevron-left-small.svg?react\";\n\nconst PROJECTS_PATH = \"/projects\";\n\ninterface FolderBrowserModalProps {\n isOpen: boolean;\n onClose: () => void;\n onAdd: (items: LocalWorkspace[]) => void;\n onAddParent?: (items: LocalWorkspaceParent[]) => void;\n}\n\ninterface SidebarEntry {\n label: string;\n path: string;\n}\n\ninterface SidebarSectionProps {\n label: string;\n entries: SidebarEntry[];\n currentPath: string | null;\n onPick: (path: string) => void;\n}\n\nfunction SidebarSection({\n label,\n entries,\n currentPath,\n onPick,\n}: SidebarSectionProps) {\n if (entries.length === 0) return null;\n return (\n <div className=\"px-2 pb-3\">\n <div className=\"px-2 pb-1 text-[11px] uppercase tracking-wide text-[var(--oh-muted)] font-semibold\">\n {label}\n </div>\n <ul>\n {entries.map((entry) => {\n const isActive = currentPath === entry.path;\n return (\n <li key={entry.path}>\n <button\n type=\"button\"\n onClick={() => onPick(entry.path)}\n data-testid={`folder-browser-sidebar-${entry.label.toLowerCase()}`}\n className={cn(\n \"flex items-center gap-2 w-full px-2 py-1 rounded text-sm cursor-pointer\",\n isActive\n ? \"bg-tertiary text-white\"\n : \"text-[var(--oh-text-tertiary)] hover:bg-[var(--oh-surface-raised)]\",\n )}\n >\n <FolderIcon width={14} height={14} className=\"shrink-0\" />\n <span className=\"truncate\">{entry.label}</span>\n </button>\n </li>\n );\n })}\n </ul>\n </div>\n );\n}\n\nfunction getParentPath(path: string): string | null {\n const trimmed = path.replace(/\\/+$/, \"\");\n if (!trimmed || trimmed === \"/\") return null;\n const idx = trimmed.lastIndexOf(\"/\");\n if (idx <= 0) return \"/\";\n return trimmed.slice(0, idx);\n}\n\nfunction shouldDefaultToProjectsPath(\n homeData: HomeDirectoryResponse | undefined,\n): boolean {\n return homeData?.home === \"/home/openhands\";\n}\n\nexport function FolderBrowserModal({\n isOpen,\n onClose,\n onAdd,\n onAddParent,\n}: FolderBrowserModalProps) {\n const { t } = useTranslation(\"openhands\");\n const [currentPath, setCurrentPath] = useState<string | null>(null);\n const active = useActiveBackend();\n\n const { data: homeData } = useHomeDirectory();\n\n // Initialize / reset to home each time the modal is opened\n useEffect(() => {\n if (isOpen && homeData?.home && currentPath === null) {\n setCurrentPath(\n shouldDefaultToProjectsPath(homeData) ? PROJECTS_PATH : homeData.home,\n );\n }\n if (!isOpen) {\n setCurrentPath(null);\n }\n }, [isOpen, homeData?.home, currentPath]);\n\n // A backend switch invalidates the previous path — clear it so the\n // open/close effect can re-seed from the new backend's homeData.home.\n useEffect(() => {\n setCurrentPath(null);\n }, [active.backend.id, active.orgId]);\n\n const {\n data: listing,\n isLoading,\n isError,\n error,\n } = useSearchSubdirs(isOpen ? currentPath : null);\n\n const favorites: SidebarEntry[] = useMemo(() => {\n if (!homeData?.home) return [];\n const trimmed = homeData.home.replace(/[\\\\/]+$/, \"\") || homeData.home;\n const backendFavorites = [\n { label: \"Home\", path: trimmed },\n ...(homeData.favorites ?? []),\n ];\n if (\n shouldDefaultToProjectsPath(homeData) &&\n !backendFavorites.some((entry) => entry.path === PROJECTS_PATH)\n ) {\n backendFavorites.push({\n label: PROJECTS_PATH,\n path: PROJECTS_PATH,\n });\n }\n\n return backendFavorites;\n }, [homeData]);\n\n const locations: SidebarEntry[] = homeData?.locations ?? [];\n\n if (!isOpen) return null;\n\n const subdirs = listing?.items ?? [];\n const parent = currentPath ? getParentPath(currentPath) : null;\n\n // Signal that we're inside a container environment without the host\n // home mounted: the agent server reports `/home/openhands` as home and\n // returns no favorites (the only contents are hidden credential dirs).\n // In that case there's nothing useful for the user to browse, so we\n // surface a hint instead of the generic empty state.\n const showHostHomeHint =\n homeData?.home === \"/home/openhands\" &&\n (homeData?.favorites?.length ?? 0) === 0 &&\n currentPath === homeData?.home &&\n !isLoading &&\n !isError &&\n subdirs.length === 0;\n\n const getBasename = (path: string): string => {\n const trimmed = path.replace(/\\/+$/, \"\");\n if (!trimmed) return \"/\";\n const idx = trimmed.lastIndexOf(\"/\");\n return idx >= 0 ? trimmed.slice(idx + 1) || \"/\" : trimmed;\n };\n\n const handleAddDirectory = () => {\n if (!currentPath) return;\n const item: LocalWorkspace = {\n id: currentPath,\n name: getBasename(currentPath),\n path: currentPath,\n };\n onAdd([item]);\n onClose();\n };\n\n const handleAddAllSubdirectories = () => {\n if (!currentPath || !onAddParent) return;\n onAddParent([\n {\n id: currentPath,\n name: getBasename(currentPath),\n path: currentPath,\n },\n ]);\n onClose();\n };\n\n return (\n <ModalBackdrop\n onClose={onClose}\n aria-label={t(I18nKey.HOME$ADD_WORKSPACES_TITLE)}\n >\n <div\n data-testid=\"folder-browser-modal\"\n className={cn(\n \"flex flex-col bg-[var(--oh-surface)] border border-[var(--oh-border-input)] rounded-xl\",\n modalWidthClassName(\"xl\"),\n MODAL_MAX_WIDTH_VIEWPORT,\n \"h-[480px]\",\n )}\n >\n {/* Title bar */}\n <div className=\"flex items-center justify-between px-5 py-3 border-b border-[var(--oh-border-input)]\">\n <BaseModalTitle\n className=\"text-sm font-medium text-white\"\n title={t(I18nKey.HOME$ADD_WORKSPACES_TITLE)}\n />\n </div>\n\n {/* Body: sidebar + main */}\n <div className=\"flex flex-1 min-h-0\">\n {/* Sidebar */}\n <aside\n data-testid=\"folder-browser-sidebar\"\n className=\"w-[180px] shrink-0 border-r border-[var(--oh-border-input)] bg-[var(--oh-surface)] py-3 overflow-y-auto\"\n >\n <SidebarSection\n label={t(I18nKey.HOME$FAVORITES)}\n entries={favorites}\n currentPath={currentPath}\n onPick={setCurrentPath}\n />\n <SidebarSection\n label={t(I18nKey.HOME$LOCATIONS)}\n entries={locations}\n currentPath={currentPath}\n onPick={setCurrentPath}\n />\n </aside>\n\n {/* Main */}\n <div className=\"flex-1 flex flex-col min-w-0\">\n {/* Nav row */}\n <div className=\"flex items-center gap-2 px-4 py-2 border-b border-[var(--oh-border-input)]\">\n <button\n type=\"button\"\n data-testid=\"folder-browser-up\"\n onClick={() => parent && setCurrentPath(parent)}\n disabled={!parent}\n aria-label=\"Up\"\n className=\"p-1 rounded hover:bg-[var(--oh-interactive-hover)] text-white disabled:opacity-40 disabled:cursor-not-allowed cursor-pointer\"\n >\n <ChevronLeft width={16} height={16} />\n </button>\n <span\n className=\"text-xs text-[var(--oh-muted)] truncate\"\n data-testid=\"folder-browser-current-path\"\n >\n {currentPath ?? \"\"}\n </span>\n </div>\n\n {/* Column headers */}\n <div className=\"grid grid-cols-[1fr_120px] px-4 py-1 border-b border-[var(--oh-border-input)] text-xs text-[var(--oh-text-secondary)] font-semibold\">\n <span>{t(I18nKey.HOME$NAME)}</span>\n <span>{t(I18nKey.HOME$KIND)}</span>\n </div>\n\n {/* List */}\n <ul\n className=\"flex-1 overflow-auto custom-scrollbar-always\"\n data-testid=\"folder-browser-list\"\n >\n {isLoading && (\n <li className=\"px-4 py-2 text-sm text-[var(--oh-text-secondary)]\">\n {t(I18nKey.HOME$LOADING)}\n </li>\n )}\n {isError && (\n <li\n className=\"px-4 py-2 text-sm text-red-400\"\n data-testid=\"folder-browser-error\"\n >\n {(error as Error | undefined)?.message ?? \"Failed to load\"}\n </li>\n )}\n {!isLoading && !isError && subdirs.length === 0 && (\n <li\n className=\"px-4 py-2 text-sm text-[var(--oh-text-secondary)]\"\n data-testid={\n showHostHomeHint\n ? \"folder-browser-host-home-hint\"\n : \"folder-browser-empty\"\n }\n >\n {showHostHomeHint\n ? t(I18nKey.HOME$HOST_HOME_NOT_MOUNTED_HINT)\n : t(I18nKey.HOME$NO_WORKSPACES)}\n </li>\n )}\n {subdirs.map((entry) => (\n <li key={entry.path}>\n <button\n type=\"button\"\n onClick={() => setCurrentPath(entry.path)}\n className=\"grid grid-cols-[1fr_120px] items-center w-full text-left px-4 py-1.5 text-sm text-white hover:bg-[var(--oh-interactive-hover)] cursor-pointer\"\n data-testid={`folder-browser-entry-${entry.name}`}\n >\n <span className=\"flex items-center gap-2 min-w-0\">\n <FolderIcon width={16} height={16} className=\"shrink-0\" />\n <span className=\"truncate\">{entry.name}</span>\n </span>\n <span className=\"text-[var(--oh-text-secondary)] text-xs\">\n {t(I18nKey.HOME$FOLDER)}\n </span>\n </button>\n </li>\n ))}\n </ul>\n </div>\n </div>\n\n {/* Footer */}\n <div className=\"flex items-center justify-end gap-2 px-5 py-3 border-t border-[var(--oh-border-input)]\">\n <BrandButton\n type=\"button\"\n variant=\"secondary\"\n onClick={onClose}\n testId=\"folder-browser-cancel\"\n >\n {t(I18nKey.HOME$CANCEL)}\n </BrandButton>\n {onAddParent && (\n <BrandButton\n type=\"button\"\n variant=\"secondary\"\n onClick={handleAddAllSubdirectories}\n isDisabled={!currentPath || isLoading}\n testId=\"folder-browser-add-all-subdirs\"\n >\n {t(I18nKey.HOME$ADD_ALL_SUBDIRECTORIES)}\n </BrandButton>\n )}\n <BrandButton\n type=\"button\"\n variant=\"primary\"\n onClick={handleAddDirectory}\n isDisabled={!currentPath || isLoading}\n testId=\"folder-browser-use\"\n >\n {t(I18nKey.HOME$ADD_THIS_DIRECTORY)}\n </BrandButton>\n </div>\n </div>\n </ModalBackdrop>\n );\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"folder-browser-modal.cjs","names":[],"sources":["../../../../../src/components/features/home/workspace-dropdown/folder-browser-modal.tsx"],"sourcesContent":["import React, { useEffect, useMemo, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\n\nimport { BaseModalTitle } from \"#/components/shared/modals/confirmation-modals/base-modal\";\nimport { ModalBackdrop } from \"#/components/shared/modals/modal-backdrop\";\nimport {\n MODAL_MAX_WIDTH_VIEWPORT,\n modalWidthClassName,\n} from \"#/components/shared/modals/modal-body\";\nimport { BrandButton } from \"#/components/features/settings/brand-button\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport { LocalWorkspace, LocalWorkspaceParent } from \"#/types/workspace\";\nimport {\n type HomeDirectoryResponse,\n useHomeDirectory,\n useSearchSubdirs,\n} from \"#/hooks/query/use-search-subdirs\";\nimport { useActiveBackend } from \"#/contexts/active-backend-context\";\nimport { cn } from \"#/utils/utils\";\nimport { modalTitleSmClassName } from \"#/utils/modal-classes\";\nimport FolderIcon from \"#/icons/folder.svg?react\";\nimport ChevronLeft from \"#/icons/chevron-left-small.svg?react\";\n\nconst PROJECTS_PATH = \"/projects\";\n\ninterface FolderBrowserModalProps {\n isOpen: boolean;\n onClose: () => void;\n onAdd: (items: LocalWorkspace[]) => void;\n onAddParent?: (items: LocalWorkspaceParent[]) => void;\n}\n\ninterface SidebarEntry {\n label: string;\n path: string;\n}\n\ninterface SidebarSectionProps {\n label: string;\n entries: SidebarEntry[];\n currentPath: string | null;\n onPick: (path: string) => void;\n}\n\nfunction SidebarSection({\n label,\n entries,\n currentPath,\n onPick,\n}: SidebarSectionProps) {\n if (entries.length === 0) return null;\n return (\n <div className=\"px-2 pb-3\">\n <div className=\"px-2 pb-1 text-[11px] uppercase tracking-wide text-[var(--oh-muted)] font-semibold\">\n {label}\n </div>\n <ul>\n {entries.map((entry) => {\n const isActive = currentPath === entry.path;\n return (\n <li key={entry.path}>\n <button\n type=\"button\"\n onClick={() => onPick(entry.path)}\n data-testid={`folder-browser-sidebar-${entry.label.toLowerCase()}`}\n className={cn(\n \"flex items-center gap-2 w-full px-2 py-1 rounded text-sm cursor-pointer\",\n isActive\n ? \"bg-tertiary text-white\"\n : \"text-[var(--oh-text-tertiary)] hover:bg-[var(--oh-surface-raised)]\",\n )}\n >\n <FolderIcon width={14} height={14} className=\"shrink-0\" />\n <span className=\"truncate\">{entry.label}</span>\n </button>\n </li>\n );\n })}\n </ul>\n </div>\n );\n}\n\nfunction getParentPath(path: string): string | null {\n const trimmed = path.replace(/\\/+$/, \"\");\n if (!trimmed || trimmed === \"/\") return null;\n const idx = trimmed.lastIndexOf(\"/\");\n if (idx <= 0) return \"/\";\n return trimmed.slice(0, idx);\n}\n\nfunction shouldDefaultToProjectsPath(\n homeData: HomeDirectoryResponse | undefined,\n): boolean {\n return homeData?.home === \"/home/openhands\";\n}\n\nexport function FolderBrowserModal({\n isOpen,\n onClose,\n onAdd,\n onAddParent,\n}: FolderBrowserModalProps) {\n const { t } = useTranslation(\"openhands\");\n const [currentPath, setCurrentPath] = useState<string | null>(null);\n const active = useActiveBackend();\n\n const { data: homeData } = useHomeDirectory();\n\n // Initialize / reset to home each time the modal is opened\n useEffect(() => {\n if (isOpen && homeData?.home && currentPath === null) {\n setCurrentPath(\n shouldDefaultToProjectsPath(homeData) ? PROJECTS_PATH : homeData.home,\n );\n }\n if (!isOpen) {\n setCurrentPath(null);\n }\n }, [isOpen, homeData?.home, currentPath]);\n\n // A backend switch invalidates the previous path — clear it so the\n // open/close effect can re-seed from the new backend's homeData.home.\n useEffect(() => {\n setCurrentPath(null);\n }, [active.backend.id, active.orgId]);\n\n const {\n data: listing,\n isLoading,\n isError,\n error,\n } = useSearchSubdirs(isOpen ? currentPath : null);\n\n const favorites: SidebarEntry[] = useMemo(() => {\n if (!homeData?.home) return [];\n const trimmed = homeData.home.replace(/[\\\\/]+$/, \"\") || homeData.home;\n const backendFavorites = [\n { label: \"Home\", path: trimmed },\n ...(homeData.favorites ?? []),\n ];\n if (\n shouldDefaultToProjectsPath(homeData) &&\n !backendFavorites.some((entry) => entry.path === PROJECTS_PATH)\n ) {\n backendFavorites.push({\n label: PROJECTS_PATH,\n path: PROJECTS_PATH,\n });\n }\n\n return backendFavorites;\n }, [homeData]);\n\n const locations: SidebarEntry[] = homeData?.locations ?? [];\n\n if (!isOpen) return null;\n\n const subdirs = listing?.items ?? [];\n const parent = currentPath ? getParentPath(currentPath) : null;\n\n // Signal that we're inside a container environment without the host\n // home mounted: the agent server reports `/home/openhands` as home and\n // returns no favorites (the only contents are hidden credential dirs).\n // In that case there's nothing useful for the user to browse, so we\n // surface a hint instead of the generic empty state.\n const showHostHomeHint =\n homeData?.home === \"/home/openhands\" &&\n (homeData?.favorites?.length ?? 0) === 0 &&\n currentPath === homeData?.home &&\n !isLoading &&\n !isError &&\n subdirs.length === 0;\n\n const getBasename = (path: string): string => {\n const trimmed = path.replace(/\\/+$/, \"\");\n if (!trimmed) return \"/\";\n const idx = trimmed.lastIndexOf(\"/\");\n return idx >= 0 ? trimmed.slice(idx + 1) || \"/\" : trimmed;\n };\n\n const handleAddDirectory = () => {\n if (!currentPath) return;\n const item: LocalWorkspace = {\n id: currentPath,\n name: getBasename(currentPath),\n path: currentPath,\n };\n onAdd([item]);\n onClose();\n };\n\n const handleAddAllSubdirectories = () => {\n if (!currentPath || !onAddParent) return;\n onAddParent([\n {\n id: currentPath,\n name: getBasename(currentPath),\n path: currentPath,\n },\n ]);\n onClose();\n };\n\n return (\n <ModalBackdrop\n onClose={onClose}\n aria-label={t(I18nKey.HOME$ADD_WORKSPACES_TITLE)}\n >\n <div\n data-testid=\"folder-browser-modal\"\n className={cn(\n \"flex flex-col bg-[var(--oh-surface)] border border-[var(--oh-border-input)] rounded-xl\",\n modalWidthClassName(\"xl\"),\n MODAL_MAX_WIDTH_VIEWPORT,\n \"h-[480px]\",\n )}\n >\n {/* Title bar */}\n <div className=\"flex items-center justify-between px-5 py-3 border-b border-[var(--oh-border-input)]\">\n <BaseModalTitle\n className={modalTitleSmClassName}\n title={t(I18nKey.HOME$ADD_WORKSPACES_TITLE)}\n />\n </div>\n\n {/* Body: sidebar + main */}\n <div className=\"flex flex-1 min-h-0\">\n {/* Sidebar */}\n <aside\n data-testid=\"folder-browser-sidebar\"\n className=\"w-[180px] shrink-0 border-r border-[var(--oh-border-input)] bg-[var(--oh-surface)] py-3 overflow-y-auto\"\n >\n <SidebarSection\n label={t(I18nKey.HOME$FAVORITES)}\n entries={favorites}\n currentPath={currentPath}\n onPick={setCurrentPath}\n />\n <SidebarSection\n label={t(I18nKey.HOME$LOCATIONS)}\n entries={locations}\n currentPath={currentPath}\n onPick={setCurrentPath}\n />\n </aside>\n\n {/* Main */}\n <div className=\"flex-1 flex flex-col min-w-0\">\n {/* Nav row */}\n <div className=\"flex items-center gap-2 px-4 py-2 border-b border-[var(--oh-border-input)]\">\n <button\n type=\"button\"\n data-testid=\"folder-browser-up\"\n onClick={() => parent && setCurrentPath(parent)}\n disabled={!parent}\n aria-label=\"Up\"\n className=\"p-1 rounded hover:bg-[var(--oh-interactive-hover)] text-white disabled:opacity-40 disabled:cursor-not-allowed cursor-pointer\"\n >\n <ChevronLeft width={16} height={16} />\n </button>\n <span\n className=\"text-xs text-[var(--oh-muted)] truncate\"\n data-testid=\"folder-browser-current-path\"\n >\n {currentPath ?? \"\"}\n </span>\n </div>\n\n {/* Column headers */}\n <div className=\"grid grid-cols-[1fr_120px] px-4 py-1 border-b border-[var(--oh-border-input)] text-xs text-[var(--oh-text-secondary)] font-semibold\">\n <span>{t(I18nKey.HOME$NAME)}</span>\n <span>{t(I18nKey.HOME$KIND)}</span>\n </div>\n\n {/* List */}\n <ul\n className=\"flex-1 overflow-auto custom-scrollbar-always\"\n data-testid=\"folder-browser-list\"\n >\n {isLoading && (\n <li className=\"px-4 py-2 text-sm text-[var(--oh-text-secondary)]\">\n {t(I18nKey.HOME$LOADING)}\n </li>\n )}\n {isError && (\n <li\n className=\"px-4 py-2 text-sm text-red-400\"\n data-testid=\"folder-browser-error\"\n >\n {(error as Error | undefined)?.message ?? \"Failed to load\"}\n </li>\n )}\n {!isLoading && !isError && subdirs.length === 0 && (\n <li\n className=\"px-4 py-2 text-sm text-[var(--oh-text-secondary)]\"\n data-testid={\n showHostHomeHint\n ? \"folder-browser-host-home-hint\"\n : \"folder-browser-empty\"\n }\n >\n {showHostHomeHint\n ? t(I18nKey.HOME$HOST_HOME_NOT_MOUNTED_HINT)\n : t(I18nKey.HOME$NO_WORKSPACES)}\n </li>\n )}\n {subdirs.map((entry) => (\n <li key={entry.path}>\n <button\n type=\"button\"\n onClick={() => setCurrentPath(entry.path)}\n className=\"grid grid-cols-[1fr_120px] items-center w-full text-left px-4 py-1.5 text-sm text-white hover:bg-[var(--oh-interactive-hover)] cursor-pointer\"\n data-testid={`folder-browser-entry-${entry.name}`}\n >\n <span className=\"flex items-center gap-2 min-w-0\">\n <FolderIcon width={16} height={16} className=\"shrink-0\" />\n <span className=\"truncate\">{entry.name}</span>\n </span>\n <span className=\"text-[var(--oh-text-secondary)] text-xs\">\n {t(I18nKey.HOME$FOLDER)}\n </span>\n </button>\n </li>\n ))}\n </ul>\n </div>\n </div>\n\n {/* Footer */}\n <div className=\"flex items-center justify-end gap-2 px-5 py-3 border-t border-[var(--oh-border-input)]\">\n <BrandButton\n type=\"button\"\n variant=\"secondary\"\n onClick={onClose}\n testId=\"folder-browser-cancel\"\n >\n {t(I18nKey.HOME$CANCEL)}\n </BrandButton>\n {onAddParent && (\n <BrandButton\n type=\"button\"\n variant=\"secondary\"\n onClick={handleAddAllSubdirectories}\n isDisabled={!currentPath || isLoading}\n testId=\"folder-browser-add-all-subdirs\"\n >\n {t(I18nKey.HOME$ADD_ALL_SUBDIRECTORIES)}\n </BrandButton>\n )}\n <BrandButton\n type=\"button\"\n variant=\"primary\"\n onClick={handleAddDirectory}\n isDisabled={!currentPath || isLoading}\n testId=\"folder-browser-use\"\n >\n {t(I18nKey.HOME$ADD_THIS_DIRECTORY)}\n </BrandButton>\n </div>\n </div>\n </ModalBackdrop>\n );\n}\n"],"mappings":"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"}
|
|
@@ -4,33 +4,34 @@ import { cn as n } from "../../../../utils/utils.js";
|
|
|
4
4
|
import { useActiveBackend as r } from "../../../../contexts/active-backend-context.js";
|
|
5
5
|
import { ModalBackdrop as i } from "../../../shared/modals/modal-backdrop.js";
|
|
6
6
|
import { MODAL_MAX_WIDTH_VIEWPORT as a, modalWidthClassName as o } from "../../../shared/modals/modal-body.js";
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
10
|
-
import d from "../../../../
|
|
11
|
-
import f from "../../../../icons/
|
|
12
|
-
import
|
|
13
|
-
import {
|
|
7
|
+
import { modalTitleSmClassName as s } from "../../../../utils/modal-classes.js";
|
|
8
|
+
import { BaseModalTitle as c } from "../../../shared/modals/confirmation-modals/base-modal.js";
|
|
9
|
+
import { BrandButton as l } from "../../settings/brand-button.js";
|
|
10
|
+
import { useHomeDirectory as u, useSearchSubdirs as d } from "../../../../hooks/query/use-search-subdirs.js";
|
|
11
|
+
import f from "../../../../icons/folder.js";
|
|
12
|
+
import p from "../../../../icons/chevron-left-small.js";
|
|
13
|
+
import { useEffect as m, useMemo as h, useState as g } from "react";
|
|
14
|
+
import { jsx as _, jsxs as v } from "react/jsx-runtime";
|
|
14
15
|
//#region src/components/features/home/workspace-dropdown/folder-browser-modal.tsx
|
|
15
|
-
var
|
|
16
|
-
function
|
|
17
|
-
return t.length === 0 ? null : /* @__PURE__ */
|
|
16
|
+
var y = "/projects";
|
|
17
|
+
function b({ label: e, entries: t, currentPath: r, onPick: i }) {
|
|
18
|
+
return t.length === 0 ? null : /* @__PURE__ */ v("div", {
|
|
18
19
|
className: "px-2 pb-3",
|
|
19
|
-
children: [/* @__PURE__ */
|
|
20
|
+
children: [/* @__PURE__ */ _("div", {
|
|
20
21
|
className: "px-2 pb-1 text-[11px] uppercase tracking-wide text-[var(--oh-muted)] font-semibold",
|
|
21
22
|
children: e
|
|
22
|
-
}), /* @__PURE__ */
|
|
23
|
+
}), /* @__PURE__ */ _("ul", { children: t.map((e) => {
|
|
23
24
|
let t = r === e.path;
|
|
24
|
-
return /* @__PURE__ */
|
|
25
|
+
return /* @__PURE__ */ _("li", { children: /* @__PURE__ */ v("button", {
|
|
25
26
|
type: "button",
|
|
26
27
|
onClick: () => i(e.path),
|
|
27
28
|
"data-testid": `folder-browser-sidebar-${e.label.toLowerCase()}`,
|
|
28
29
|
className: n("flex items-center gap-2 w-full px-2 py-1 rounded text-sm cursor-pointer", t ? "bg-tertiary text-white" : "text-[var(--oh-text-tertiary)] hover:bg-[var(--oh-surface-raised)]"),
|
|
29
|
-
children: [/* @__PURE__ */
|
|
30
|
+
children: [/* @__PURE__ */ _(f, {
|
|
30
31
|
width: 14,
|
|
31
32
|
height: 14,
|
|
32
33
|
className: "shrink-0"
|
|
33
|
-
}), /* @__PURE__ */
|
|
34
|
+
}), /* @__PURE__ */ _("span", {
|
|
34
35
|
className: "truncate",
|
|
35
36
|
children: e.label
|
|
36
37
|
})]
|
|
@@ -38,136 +39,136 @@ function y({ label: e, entries: t, currentPath: r, onPick: i }) {
|
|
|
38
39
|
}) })]
|
|
39
40
|
});
|
|
40
41
|
}
|
|
41
|
-
function
|
|
42
|
+
function x(e) {
|
|
42
43
|
let t = e.replace(/\/+$/, "");
|
|
43
44
|
if (!t || t === "/") return null;
|
|
44
45
|
let n = t.lastIndexOf("/");
|
|
45
46
|
return n <= 0 ? "/" : t.slice(0, n);
|
|
46
47
|
}
|
|
47
|
-
function
|
|
48
|
+
function S(e) {
|
|
48
49
|
return e?.home === "/home/openhands";
|
|
49
50
|
}
|
|
50
|
-
function
|
|
51
|
-
let { t:
|
|
52
|
-
|
|
53
|
-
|
|
51
|
+
function C({ isOpen: C, onClose: w, onAdd: T, onAddParent: E }) {
|
|
52
|
+
let { t: D } = e("openhands"), [O, k] = g(null), A = r(), { data: j } = u();
|
|
53
|
+
m(() => {
|
|
54
|
+
C && j?.home && O === null && k(S(j) ? y : j.home), C || k(null);
|
|
54
55
|
}, [
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
]),
|
|
59
|
-
|
|
60
|
-
}, [
|
|
61
|
-
let { data:
|
|
62
|
-
if (!
|
|
56
|
+
C,
|
|
57
|
+
j?.home,
|
|
58
|
+
O
|
|
59
|
+
]), m(() => {
|
|
60
|
+
k(null);
|
|
61
|
+
}, [A.backend.id, A.orgId]);
|
|
62
|
+
let { data: M, isLoading: N, isError: P, error: F } = d(C ? O : null), I = h(() => {
|
|
63
|
+
if (!j?.home) return [];
|
|
63
64
|
let e = [{
|
|
64
65
|
label: "Home",
|
|
65
|
-
path:
|
|
66
|
-
}, ...
|
|
67
|
-
return
|
|
68
|
-
label:
|
|
69
|
-
path:
|
|
66
|
+
path: j.home.replace(/[\\/]+$/, "") || j.home
|
|
67
|
+
}, ...j.favorites ?? []];
|
|
68
|
+
return S(j) && !e.some((e) => e.path === y) && e.push({
|
|
69
|
+
label: y,
|
|
70
|
+
path: y
|
|
70
71
|
}), e;
|
|
71
|
-
}, [
|
|
72
|
-
if (!
|
|
73
|
-
let
|
|
72
|
+
}, [j]), L = j?.locations ?? [];
|
|
73
|
+
if (!C) return null;
|
|
74
|
+
let R = M?.items ?? [], z = O ? x(O) : null, B = j?.home === "/home/openhands" && (j?.favorites?.length ?? 0) === 0 && O === j?.home && !N && !P && R.length === 0, V = (e) => {
|
|
74
75
|
let t = e.replace(/\/+$/, "");
|
|
75
76
|
if (!t) return "/";
|
|
76
77
|
let n = t.lastIndexOf("/");
|
|
77
78
|
return n >= 0 ? t.slice(n + 1) || "/" : t;
|
|
78
79
|
};
|
|
79
|
-
return /* @__PURE__ */
|
|
80
|
-
onClose:
|
|
81
|
-
"aria-label":
|
|
82
|
-
children: /* @__PURE__ */
|
|
80
|
+
return /* @__PURE__ */ _(i, {
|
|
81
|
+
onClose: w,
|
|
82
|
+
"aria-label": D(t.HOME$ADD_WORKSPACES_TITLE),
|
|
83
|
+
children: /* @__PURE__ */ v("div", {
|
|
83
84
|
"data-testid": "folder-browser-modal",
|
|
84
85
|
className: n("flex flex-col bg-[var(--oh-surface)] border border-[var(--oh-border-input)] rounded-xl", o("xl"), a, "h-[480px]"),
|
|
85
86
|
children: [
|
|
86
|
-
/* @__PURE__ */
|
|
87
|
+
/* @__PURE__ */ _("div", {
|
|
87
88
|
className: "flex items-center justify-between px-5 py-3 border-b border-[var(--oh-border-input)]",
|
|
88
|
-
children: /* @__PURE__ */
|
|
89
|
-
className:
|
|
90
|
-
title:
|
|
89
|
+
children: /* @__PURE__ */ _(c, {
|
|
90
|
+
className: s,
|
|
91
|
+
title: D(t.HOME$ADD_WORKSPACES_TITLE)
|
|
91
92
|
})
|
|
92
93
|
}),
|
|
93
|
-
/* @__PURE__ */
|
|
94
|
+
/* @__PURE__ */ v("div", {
|
|
94
95
|
className: "flex flex-1 min-h-0",
|
|
95
|
-
children: [/* @__PURE__ */
|
|
96
|
+
children: [/* @__PURE__ */ v("aside", {
|
|
96
97
|
"data-testid": "folder-browser-sidebar",
|
|
97
98
|
className: "w-[180px] shrink-0 border-r border-[var(--oh-border-input)] bg-[var(--oh-surface)] py-3 overflow-y-auto",
|
|
98
|
-
children: [/* @__PURE__ */
|
|
99
|
-
label:
|
|
100
|
-
entries: F,
|
|
101
|
-
currentPath: D,
|
|
102
|
-
onPick: O
|
|
103
|
-
}), /* @__PURE__ */ g(y, {
|
|
104
|
-
label: E(t.HOME$LOCATIONS),
|
|
99
|
+
children: [/* @__PURE__ */ _(b, {
|
|
100
|
+
label: D(t.HOME$FAVORITES),
|
|
105
101
|
entries: I,
|
|
106
|
-
currentPath:
|
|
107
|
-
onPick:
|
|
102
|
+
currentPath: O,
|
|
103
|
+
onPick: k
|
|
104
|
+
}), /* @__PURE__ */ _(b, {
|
|
105
|
+
label: D(t.HOME$LOCATIONS),
|
|
106
|
+
entries: L,
|
|
107
|
+
currentPath: O,
|
|
108
|
+
onPick: k
|
|
108
109
|
})]
|
|
109
|
-
}), /* @__PURE__ */
|
|
110
|
+
}), /* @__PURE__ */ v("div", {
|
|
110
111
|
className: "flex-1 flex flex-col min-w-0",
|
|
111
112
|
children: [
|
|
112
|
-
/* @__PURE__ */
|
|
113
|
+
/* @__PURE__ */ v("div", {
|
|
113
114
|
className: "flex items-center gap-2 px-4 py-2 border-b border-[var(--oh-border-input)]",
|
|
114
|
-
children: [/* @__PURE__ */
|
|
115
|
+
children: [/* @__PURE__ */ _("button", {
|
|
115
116
|
type: "button",
|
|
116
117
|
"data-testid": "folder-browser-up",
|
|
117
|
-
onClick: () =>
|
|
118
|
-
disabled: !
|
|
118
|
+
onClick: () => z && k(z),
|
|
119
|
+
disabled: !z,
|
|
119
120
|
"aria-label": "Up",
|
|
120
121
|
className: "p-1 rounded hover:bg-[var(--oh-interactive-hover)] text-white disabled:opacity-40 disabled:cursor-not-allowed cursor-pointer",
|
|
121
|
-
children: /* @__PURE__ */
|
|
122
|
+
children: /* @__PURE__ */ _(p, {
|
|
122
123
|
width: 16,
|
|
123
124
|
height: 16
|
|
124
125
|
})
|
|
125
|
-
}), /* @__PURE__ */
|
|
126
|
+
}), /* @__PURE__ */ _("span", {
|
|
126
127
|
className: "text-xs text-[var(--oh-muted)] truncate",
|
|
127
128
|
"data-testid": "folder-browser-current-path",
|
|
128
|
-
children:
|
|
129
|
+
children: O ?? ""
|
|
129
130
|
})]
|
|
130
131
|
}),
|
|
131
|
-
/* @__PURE__ */
|
|
132
|
+
/* @__PURE__ */ v("div", {
|
|
132
133
|
className: "grid grid-cols-[1fr_120px] px-4 py-1 border-b border-[var(--oh-border-input)] text-xs text-[var(--oh-text-secondary)] font-semibold",
|
|
133
|
-
children: [/* @__PURE__ */
|
|
134
|
+
children: [/* @__PURE__ */ _("span", { children: D(t.HOME$NAME) }), /* @__PURE__ */ _("span", { children: D(t.HOME$KIND) })]
|
|
134
135
|
}),
|
|
135
|
-
/* @__PURE__ */
|
|
136
|
+
/* @__PURE__ */ v("ul", {
|
|
136
137
|
className: "flex-1 overflow-auto custom-scrollbar-always",
|
|
137
138
|
"data-testid": "folder-browser-list",
|
|
138
139
|
children: [
|
|
139
|
-
|
|
140
|
+
N && /* @__PURE__ */ _("li", {
|
|
140
141
|
className: "px-4 py-2 text-sm text-[var(--oh-text-secondary)]",
|
|
141
|
-
children:
|
|
142
|
+
children: D(t.HOME$LOADING)
|
|
142
143
|
}),
|
|
143
|
-
|
|
144
|
+
P && /* @__PURE__ */ _("li", {
|
|
144
145
|
className: "px-4 py-2 text-sm text-red-400",
|
|
145
146
|
"data-testid": "folder-browser-error",
|
|
146
|
-
children:
|
|
147
|
+
children: F?.message ?? "Failed to load"
|
|
147
148
|
}),
|
|
148
|
-
!
|
|
149
|
+
!N && !P && R.length === 0 && /* @__PURE__ */ _("li", {
|
|
149
150
|
className: "px-4 py-2 text-sm text-[var(--oh-text-secondary)]",
|
|
150
|
-
"data-testid":
|
|
151
|
-
children:
|
|
151
|
+
"data-testid": B ? "folder-browser-host-home-hint" : "folder-browser-empty",
|
|
152
|
+
children: D(B ? t.HOME$HOST_HOME_NOT_MOUNTED_HINT : t.HOME$NO_WORKSPACES)
|
|
152
153
|
}),
|
|
153
|
-
|
|
154
|
+
R.map((e) => /* @__PURE__ */ _("li", { children: /* @__PURE__ */ v("button", {
|
|
154
155
|
type: "button",
|
|
155
|
-
onClick: () =>
|
|
156
|
+
onClick: () => k(e.path),
|
|
156
157
|
className: "grid grid-cols-[1fr_120px] items-center w-full text-left px-4 py-1.5 text-sm text-white hover:bg-[var(--oh-interactive-hover)] cursor-pointer",
|
|
157
158
|
"data-testid": `folder-browser-entry-${e.name}`,
|
|
158
|
-
children: [/* @__PURE__ */
|
|
159
|
+
children: [/* @__PURE__ */ v("span", {
|
|
159
160
|
className: "flex items-center gap-2 min-w-0",
|
|
160
|
-
children: [/* @__PURE__ */
|
|
161
|
+
children: [/* @__PURE__ */ _(f, {
|
|
161
162
|
width: 16,
|
|
162
163
|
height: 16,
|
|
163
164
|
className: "shrink-0"
|
|
164
|
-
}), /* @__PURE__ */
|
|
165
|
+
}), /* @__PURE__ */ _("span", {
|
|
165
166
|
className: "truncate",
|
|
166
167
|
children: e.name
|
|
167
168
|
})]
|
|
168
|
-
}), /* @__PURE__ */
|
|
169
|
+
}), /* @__PURE__ */ _("span", {
|
|
169
170
|
className: "text-[var(--oh-text-secondary)] text-xs",
|
|
170
|
-
children:
|
|
171
|
+
children: D(t.HOME$FOLDER)
|
|
171
172
|
})]
|
|
172
173
|
}) }, e.path))
|
|
173
174
|
]
|
|
@@ -175,43 +176,43 @@ function S({ isOpen: S, onClose: C, onAdd: w, onAddParent: T }) {
|
|
|
175
176
|
]
|
|
176
177
|
})]
|
|
177
178
|
}),
|
|
178
|
-
/* @__PURE__ */
|
|
179
|
+
/* @__PURE__ */ v("div", {
|
|
179
180
|
className: "flex items-center justify-end gap-2 px-5 py-3 border-t border-[var(--oh-border-input)]",
|
|
180
181
|
children: [
|
|
181
|
-
/* @__PURE__ */
|
|
182
|
+
/* @__PURE__ */ _(l, {
|
|
182
183
|
type: "button",
|
|
183
184
|
variant: "secondary",
|
|
184
|
-
onClick:
|
|
185
|
+
onClick: w,
|
|
185
186
|
testId: "folder-browser-cancel",
|
|
186
|
-
children:
|
|
187
|
+
children: D(t.HOME$CANCEL)
|
|
187
188
|
}),
|
|
188
|
-
|
|
189
|
+
E && /* @__PURE__ */ _(l, {
|
|
189
190
|
type: "button",
|
|
190
191
|
variant: "secondary",
|
|
191
192
|
onClick: () => {
|
|
192
|
-
!
|
|
193
|
-
id:
|
|
194
|
-
name:
|
|
195
|
-
path:
|
|
196
|
-
}]),
|
|
193
|
+
!O || !E || (E([{
|
|
194
|
+
id: O,
|
|
195
|
+
name: V(O),
|
|
196
|
+
path: O
|
|
197
|
+
}]), w());
|
|
197
198
|
},
|
|
198
|
-
isDisabled: !
|
|
199
|
+
isDisabled: !O || N,
|
|
199
200
|
testId: "folder-browser-add-all-subdirs",
|
|
200
|
-
children:
|
|
201
|
+
children: D(t.HOME$ADD_ALL_SUBDIRECTORIES)
|
|
201
202
|
}),
|
|
202
|
-
/* @__PURE__ */
|
|
203
|
+
/* @__PURE__ */ _(l, {
|
|
203
204
|
type: "button",
|
|
204
205
|
variant: "primary",
|
|
205
206
|
onClick: () => {
|
|
206
|
-
|
|
207
|
-
id:
|
|
208
|
-
name:
|
|
209
|
-
path:
|
|
210
|
-
}]),
|
|
207
|
+
O && (T([{
|
|
208
|
+
id: O,
|
|
209
|
+
name: V(O),
|
|
210
|
+
path: O
|
|
211
|
+
}]), w());
|
|
211
212
|
},
|
|
212
|
-
isDisabled: !
|
|
213
|
+
isDisabled: !O || N,
|
|
213
214
|
testId: "folder-browser-use",
|
|
214
|
-
children:
|
|
215
|
+
children: D(t.HOME$ADD_THIS_DIRECTORY)
|
|
215
216
|
})
|
|
216
217
|
]
|
|
217
218
|
})
|
|
@@ -220,6 +221,6 @@ function S({ isOpen: S, onClose: C, onAdd: w, onAddParent: T }) {
|
|
|
220
221
|
});
|
|
221
222
|
}
|
|
222
223
|
//#endregion
|
|
223
|
-
export {
|
|
224
|
+
export { C as FolderBrowserModal };
|
|
224
225
|
|
|
225
226
|
//# sourceMappingURL=folder-browser-modal.js.map
|