@openhands/agent-canvas 1.0.0-beta.6 → 1.0.0-beta.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- 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-CgV8FyPK.js → recommended-automations-launcher-uTyODuzB.js} +3 -3
- package/build/assets/{root-dNntxffj.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-Cs-TO3fK.js → vendor~home~mcp~automations-list-CZSK-lT2.js} +1 -1
- package/build/assets/{vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-Z3nsiNNq.js → vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-CjJdFLoM.js} +1 -1
- package/build/assets/{vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-DbfELDJu.js → vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-m8dOii0J.js} +2 -2
- package/build/assets/{vendor~root-layout~home~conversation-panel~conversation-DjAjXS5J.js → vendor~root-layout~home~conversation-panel~conversation-B5WNMnt4.js} +1 -1
- package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~i4kjfqhl-CbAhtEMv.js +1 -0
- package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-6Rm8U_Sr.js +9 -0
- package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-BkQGKpye.js → vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-tTR8C6m0.js} +1 -1
- package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~k776hupu-Bbs7UJ5U.js → vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~k776hupu-BJbu9kpL.js} +2 -2
- package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~dp08i1qy-DTwbEEcX.js → vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~dp08i1qy-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 +141 -121
- package/dist/components/features/mcp-page/install-server-modal.js.map +1 -1
- package/dist/components/features/mcp-page/save-as-secret-toggle.cjs +2 -0
- package/dist/components/features/mcp-page/save-as-secret-toggle.cjs.map +1 -0
- package/dist/components/features/mcp-page/save-as-secret-toggle.d.ts +7 -0
- package/dist/components/features/mcp-page/save-as-secret-toggle.js +50 -0
- package/dist/components/features/mcp-page/save-as-secret-toggle.js.map +1 -0
- package/dist/components/features/onboarding/onboarding-modal.d.ts +2 -2
- package/dist/components/features/onboarding/steps/check-backend-step.d.ts +1 -1
- package/dist/components/features/onboarding/steps/choose-agent-step.d.ts +2 -1
- package/dist/components/features/onboarding/steps/setup-acp-secrets-step.d.ts +19 -10
- package/dist/components/features/settings/llm-profiles/llm-settings-local-view.cjs +1 -1
- package/dist/components/features/settings/llm-profiles/llm-settings-local-view.d.ts +5 -0
- package/dist/components/features/settings/llm-profiles/llm-settings-local-view.js +2 -0
- package/dist/components/features/settings/llm-profiles/profile-actions-menu.cjs +1 -1
- package/dist/components/features/settings/llm-profiles/profile-actions-menu.js +1 -0
- package/dist/components/features/skills/extensions-navigation.cjs +1 -1
- package/dist/components/features/skills/extensions-navigation.cjs.map +1 -1
- package/dist/components/features/skills/extensions-navigation.js +1 -1
- package/dist/components/features/skills/extensions-navigation.js.map +1 -1
- package/dist/components/shared/buttons/back-nav-button.cjs +2 -0
- package/dist/components/shared/buttons/back-nav-button.cjs.map +1 -0
- package/dist/components/shared/buttons/back-nav-button.d.ts +17 -0
- package/dist/components/shared/buttons/back-nav-button.js +33 -0
- package/dist/components/shared/buttons/back-nav-button.js.map +1 -0
- package/dist/components/shared/buttons/conversation-confirmation-buttons.cjs +1 -1
- package/dist/components/shared/buttons/conversation-confirmation-buttons.js +5 -5
- package/dist/components/shared/filters/enum-filter-dropdown.cjs +1 -1
- package/dist/components/shared/filters/enum-filter-dropdown.cjs.map +1 -1
- package/dist/components/shared/filters/enum-filter-dropdown.js +32 -31
- package/dist/components/shared/filters/enum-filter-dropdown.js.map +1 -1
- package/dist/components/shared/modals/confirmation-modals/base-modal.cjs +1 -1
- package/dist/components/shared/modals/confirmation-modals/base-modal.cjs.map +1 -1
- package/dist/components/shared/modals/confirmation-modals/base-modal.js +14 -13
- package/dist/components/shared/modals/confirmation-modals/base-modal.js.map +1 -1
- package/dist/components/shared/modals/settings/settings-modal.cjs +1 -1
- package/dist/components/shared/modals/settings/settings-modal.cjs.map +1 -1
- package/dist/components/shared/modals/settings/settings-modal.js +17 -16
- package/dist/components/shared/modals/settings/settings-modal.js.map +1 -1
- package/dist/components/shared/text-shimmer.cjs +2 -0
- package/dist/components/shared/text-shimmer.cjs.map +1 -0
- package/dist/components/shared/text-shimmer.d.ts +11 -0
- package/dist/components/shared/text-shimmer.js +43 -0
- package/dist/components/shared/text-shimmer.js.map +1 -0
- package/dist/constants/acp-providers.cjs +1 -1
- package/dist/constants/acp-providers.cjs.map +1 -1
- package/dist/constants/acp-providers.d.ts +16 -3
- package/dist/constants/acp-providers.js +0 -1
- package/dist/constants/acp-providers.js.map +1 -1
- package/dist/contexts/active-backend-context.cjs +1 -1
- package/dist/contexts/active-backend-context.cjs.map +1 -1
- package/dist/contexts/active-backend-context.js +32 -32
- package/dist/contexts/active-backend-context.js.map +1 -1
- package/dist/hooks/chat/use-chat-input-logic.cjs +1 -1
- package/dist/hooks/chat/use-chat-input-logic.cjs.map +1 -1
- package/dist/hooks/chat/use-chat-input-logic.js +13 -6
- package/dist/hooks/chat/use-chat-input-logic.js.map +1 -1
- package/dist/hooks/mutation/use-save-fields-as-secrets.cjs +2 -0
- package/dist/hooks/mutation/use-save-fields-as-secrets.cjs.map +1 -0
- package/dist/hooks/mutation/use-save-fields-as-secrets.d.ts +9 -0
- package/dist/hooks/mutation/use-save-fields-as-secrets.js +24 -0
- package/dist/hooks/mutation/use-save-fields-as-secrets.js.map +1 -0
- package/dist/hooks/mutation/use-unified-start-conversation.cjs +1 -1
- package/dist/hooks/mutation/use-unified-start-conversation.js +8 -8
- package/dist/hooks/mutation/use-unified-stop-conversation.cjs +1 -1
- package/dist/hooks/mutation/use-unified-stop-conversation.js +15 -15
- package/dist/hooks/query/use-acp-auth-status.d.ts +36 -0
- package/dist/hooks/query/use-agent-settings-schema.cjs +1 -1
- package/dist/hooks/query/use-agent-settings-schema.cjs.map +1 -1
- package/dist/hooks/query/use-agent-settings-schema.js +26 -16
- package/dist/hooks/query/use-agent-settings-schema.js.map +1 -1
- package/dist/hooks/query/use-backends-health.cjs +1 -1
- package/dist/hooks/query/use-backends-health.cjs.map +1 -1
- package/dist/hooks/query/use-backends-health.d.ts +2 -0
- package/dist/hooks/query/use-backends-health.js +31 -21
- package/dist/hooks/query/use-backends-health.js.map +1 -1
- package/dist/hooks/query/use-paginated-conversations.cjs +1 -1
- package/dist/hooks/query/use-paginated-conversations.cjs.map +1 -1
- package/dist/hooks/query/use-paginated-conversations.js +15 -14
- package/dist/hooks/query/use-paginated-conversations.js.map +1 -1
- package/dist/hooks/query/use-settings.cjs +1 -1
- package/dist/hooks/query/use-settings.cjs.map +1 -1
- package/dist/hooks/query/use-settings.js +65 -52
- package/dist/hooks/query/use-settings.js.map +1 -1
- package/dist/hooks/query/use-user-conversation.cjs +1 -1
- package/dist/hooks/query/use-user-conversation.cjs.map +1 -1
- package/dist/hooks/query/use-user-conversation.js +20 -11
- package/dist/hooks/query/use-user-conversation.js.map +1 -1
- package/dist/hooks/use-agent-state.cjs +1 -1
- package/dist/hooks/use-agent-state.js +13 -13
- package/dist/hooks/use-conversation-name-context-menu.cjs +1 -1
- package/dist/hooks/use-conversation-name-context-menu.js +10 -10
- package/dist/hooks/use-conversation-name-context-menu.js.map +1 -1
- package/dist/hooks/use-llm-configured.d.ts +25 -0
- package/dist/hooks/use-runtime-is-ready.cjs +1 -1
- package/dist/hooks/use-runtime-is-ready.js +5 -5
- package/dist/i18n/declaration.cjs +1 -1
- package/dist/i18n/declaration.cjs.map +1 -1
- package/dist/i18n/declaration.d.ts +19 -1
- package/dist/i18n/declaration.js +1 -1
- package/dist/i18n/declaration.js.map +1 -1
- package/dist/i18n/translation.cjs +3 -3
- package/dist/i18n/translation.cjs.map +1 -1
- package/dist/i18n/translation.js +321 -15
- package/dist/i18n/translation.js.map +1 -1
- package/dist/icons/stop-circle.cjs +1 -1
- package/dist/icons/stop-circle.cjs.map +1 -1
- package/dist/icons/stop-circle.js +7 -10
- package/dist/icons/stop-circle.js.map +1 -1
- package/dist/locales/ar/openhands.json +20 -2
- package/dist/locales/ca/openhands.json +20 -2
- package/dist/locales/de/openhands.json +20 -2
- package/dist/locales/en/openhands.json +20 -2
- package/dist/locales/es/openhands.json +20 -2
- package/dist/locales/fr/openhands.json +20 -2
- package/dist/locales/it/openhands.json +20 -2
- package/dist/locales/ja/openhands.json +20 -2
- package/dist/locales/ko-KR/openhands.json +20 -2
- package/dist/locales/no/openhands.json +20 -2
- package/dist/locales/pt/openhands.json +20 -2
- package/dist/locales/tr/openhands.json +20 -2
- package/dist/locales/uk/openhands.json +20 -2
- package/dist/locales/zh-CN/openhands.json +20 -2
- package/dist/locales/zh-TW/openhands.json +20 -2
- package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.cjs +2 -0
- package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.cjs.map +1 -0
- package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.js +15 -0
- package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.js.map +1 -0
- package/dist/package.cjs +1 -1
- package/dist/package.cjs.map +1 -1
- package/dist/package.js +1 -1
- package/dist/package.js.map +1 -1
- package/dist/routes/conversation.cjs +1 -1
- package/dist/routes/conversation.cjs.map +1 -1
- package/dist/routes/conversation.js +1 -1
- package/dist/routes/conversation.js.map +1 -1
- package/dist/routes/llm-settings.cjs +1 -1
- package/dist/routes/llm-settings.cjs.map +1 -1
- package/dist/routes/llm-settings.js +55 -54
- package/dist/routes/llm-settings.js.map +1 -1
- package/dist/routes/secrets-settings.cjs +1 -1
- package/dist/routes/secrets-settings.cjs.map +1 -1
- package/dist/routes/secrets-settings.js +19 -27
- package/dist/routes/secrets-settings.js.map +1 -1
- package/dist/stores/conversation-store.cjs +1 -1
- package/dist/stores/conversation-store.cjs.map +1 -1
- package/dist/stores/conversation-store.d.ts +4 -0
- package/dist/stores/conversation-store.js +6 -0
- package/dist/stores/conversation-store.js.map +1 -1
- package/dist/types/agent-server/core/events/acp-tool-call-event.d.ts +6 -4
- package/dist/types/agent-server/core/events/system-event.d.ts +5 -0
- package/dist/types/automation.d.ts +15 -0
- package/dist/types/settings.d.ts +3 -1
- package/dist/ui/combobox-caret.cjs +1 -1
- package/dist/ui/combobox-caret.cjs.map +1 -1
- package/dist/ui/combobox-caret.d.ts +1 -1
- package/dist/ui/combobox-caret.js +9 -8
- package/dist/ui/combobox-caret.js.map +1 -1
- package/dist/ui/context-menu.cjs +1 -1
- package/dist/ui/context-menu.cjs.map +1 -1
- package/dist/ui/context-menu.js +9 -8
- package/dist/ui/context-menu.js.map +1 -1
- package/dist/ui/dropdown/dropdown-menu.cjs +1 -1
- package/dist/ui/dropdown/dropdown-menu.cjs.map +1 -1
- package/dist/ui/dropdown/dropdown-menu.js +21 -17
- package/dist/ui/dropdown/dropdown-menu.js.map +1 -1
- package/dist/ui/dropdown/dropdown.cjs +1 -1
- package/dist/ui/dropdown/dropdown.cjs.map +1 -1
- package/dist/ui/dropdown/dropdown.js +2 -2
- package/dist/ui/dropdown/dropdown.js.map +1 -1
- package/dist/utils/automation-schedule.d.ts +1 -0
- package/dist/utils/dropdown-classes.cjs +2 -0
- package/dist/utils/dropdown-classes.cjs.map +1 -0
- package/dist/utils/dropdown-classes.d.ts +32 -0
- package/dist/utils/dropdown-classes.js +8 -0
- package/dist/utils/dropdown-classes.js.map +1 -0
- package/dist/utils/form-control-classes.cjs +1 -1
- package/dist/utils/form-control-classes.cjs.map +1 -1
- package/dist/utils/form-control-classes.d.ts +18 -2
- package/dist/utils/form-control-classes.js +4 -3
- package/dist/utils/form-control-classes.js.map +1 -1
- package/dist/utils/git-control-bar-classes.cjs +2 -0
- package/dist/utils/git-control-bar-classes.cjs.map +1 -0
- package/dist/utils/git-control-bar-classes.d.ts +4 -0
- package/dist/utils/git-control-bar-classes.js +14 -0
- package/dist/utils/git-control-bar-classes.js.map +1 -0
- package/dist/utils/handle-event-for-ui.cjs.map +1 -1
- package/dist/utils/handle-event-for-ui.d.ts +6 -3
- package/dist/utils/handle-event-for-ui.js.map +1 -1
- package/dist/utils/mobile-top-bar-icon-button-classes.cjs +1 -1
- package/dist/utils/mobile-top-bar-icon-button-classes.cjs.map +1 -1
- package/dist/utils/mobile-top-bar-icon-button-classes.js +3 -3
- package/dist/utils/mobile-top-bar-icon-button-classes.js.map +1 -1
- package/dist/utils/modal-classes.cjs +2 -0
- package/dist/utils/modal-classes.cjs.map +1 -0
- package/dist/utils/modal-classes.d.ts +8 -0
- package/dist/utils/modal-classes.js +7 -0
- package/dist/utils/modal-classes.js.map +1 -0
- package/dist/utils/openhands-llm.cjs +2 -0
- package/dist/utils/openhands-llm.cjs.map +1 -0
- package/dist/utils/openhands-llm.d.ts +2 -0
- package/dist/utils/openhands-llm.js +9 -0
- package/dist/utils/openhands-llm.js.map +1 -0
- package/dist/utils/redact-custom-secrets.cjs +2 -0
- package/dist/utils/redact-custom-secrets.cjs.map +1 -0
- package/dist/utils/redact-custom-secrets.d.ts +6 -0
- package/dist/utils/redact-custom-secrets.js +10 -0
- package/dist/utils/redact-custom-secrets.js.map +1 -0
- package/dist/utils/status.cjs +1 -1
- package/dist/utils/status.cjs.map +1 -1
- package/dist/utils/status.d.ts +2 -1
- package/dist/utils/status.js +9 -8
- package/dist/utils/status.js.map +1 -1
- package/dist/utils/system-message-adapter.cjs +1 -1
- package/dist/utils/system-message-adapter.cjs.map +1 -1
- package/dist/utils/system-message-adapter.js +10 -7
- package/dist/utils/system-message-adapter.js.map +1 -1
- package/dist/utils/utils.cjs +1 -1
- package/dist/utils/utils.cjs.map +1 -1
- package/dist/utils/utils.d.ts +2 -1
- package/dist/utils/utils.js +21 -20
- package/dist/utils/utils.js.map +1 -1
- package/package.json +1 -1
- package/scripts/dev-safe.mjs +3 -1
- package/scripts/dev-static.mjs +2 -2
- package/scripts/dev-with-automation.mjs +283 -108
- package/scripts/static-build.mjs +20 -19
- package/scripts/static-server.mjs +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-6FDbI5dc.js +0 -1
- package/build/assets/backend-form-modal-Dnk33xA_.js +0 -1
- package/build/assets/base-modal-_dYTw1ri.js +0 -1
- package/build/assets/brand-button-Br7f0kZJ.js +0 -1
- package/build/assets/browser-store-Couc4S5D.js +0 -1
- package/build/assets/clock-BRjCgHTc.js +0 -1
- package/build/assets/combobox-caret-to1O8irE.js +0 -1
- package/build/assets/context-menu-list-item-CWNFpuiC.js +0 -1
- package/build/assets/conversation-DVrKU0oz.js +0 -19
- package/build/assets/conversation-Dlys-D5A.js +0 -1
- package/build/assets/conversation-panel-iF09WjZ4.js +0 -1
- package/build/assets/conversation-service.api-CCfztilW.js +0 -1
- package/build/assets/conversation-state-store-u5jepov0.js +0 -1
- package/build/assets/conversation-store-Z5iMCRpc.js +0 -1
- package/build/assets/conversation-websocket-context-DhJhqUna.js +0 -3
- package/build/assets/declaration-BNMqORFE.js +0 -1
- package/build/assets/dist-BxBP7tFD.js +0 -1
- package/build/assets/edit-automation-modal-BGzR3nfZ.js +0 -1
- package/build/assets/ellipsis-button-ZyLMPURn.js +0 -1
- package/build/assets/entry.client-1VMHpktY.js +0 -2
- package/build/assets/enum-filter-dropdown-CEgCdu4A.js +0 -1
- package/build/assets/extensions-hub-C651jsVh.js +0 -1
- package/build/assets/files-tab-R5z0lLdY.js +0 -1
- package/build/assets/files-tab-store-CDyVTXNT.js +0 -1
- package/build/assets/git-control-bar-branch-button-COdRAYHb.js +0 -27
- package/build/assets/git-provider-icon-BzLbc0yC.js +0 -1
- package/build/assets/home-e-egNUXZ.js +0 -1
- package/build/assets/install-server-modal-DHlbgqVH.js +0 -1
- package/build/assets/launch-CshDse3e.js +0 -1
- package/build/assets/link-external-D2POYx4c.js +0 -1
- package/build/assets/llm-settings-Bql-vydt.js +0 -1
- package/build/assets/llm-settings-C_tal6Ds.js +0 -1
- package/build/assets/manage-backends-modal-l7RkKfwX.js +0 -1
- package/build/assets/manage-workspaces-modal-DhKF_8z3.js +0 -1
- package/build/assets/manifest-3bf30d69.js +0 -1
- package/build/assets/mcp-ByeBfdfU.js +0 -9
- package/build/assets/messages-D0rWot7s.js +0 -36
- package/build/assets/proxy-CxydCnis.js +0 -1
- package/build/assets/root-DHeCXo9N.css +0 -1
- package/build/assets/root-layout-Czo9Ma6Q.js +0 -2
- package/build/assets/secrets-service-BsnKFc2x.js +0 -1
- package/build/assets/secrets-settings-Bz_UohPJ.js +0 -1
- package/build/assets/settings-client-C73C7IgV.js +0 -1
- package/build/assets/settings-index-Dz0BmdJD.js +0 -1
- package/build/assets/settings-list-classes-Bf80tWtc.js +0 -1
- package/build/assets/settings-modal-Brzgh5Yw.js +0 -1
- package/build/assets/settings-service.api-CZ3uWx4v.js +0 -1
- package/build/assets/sidebar-mobile-menu-toggle-Do_aA9Zm.js +0 -1
- package/build/assets/skills-settings-DlA5hlXw.js +0 -2
- package/build/assets/status-hp6M6E7E.js +0 -1
- package/build/assets/use-agent-settings-schema-33Un7UF2.js +0 -1
- package/build/assets/use-is-authed-BggE5wPj.js +0 -1
- package/build/assets/use-llm-profiles-DDOol3gK.js +0 -1
- package/build/assets/use-runtime-is-ready-B7EF4BKU.js +0 -1
- package/build/assets/use-settings-DQIZmIov.js +0 -1
- package/build/assets/use-user-conversation-C6hrMMtn.js +0 -1
- package/build/assets/utils-i18rdUj2.js +0 -1
- package/build/assets/vendor~conversation-panel~conversation-a9SyrrhV.js +0 -1
- package/build/assets/vendor~conversation-panel~conversation~index-C23ZXO4R.js +0 -1
- package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~i4kjfqhl-BebWhFNT.js +0 -1
- package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-DzIXV3Ui.js +0 -9
- /package/build/assets/{automation-IdgZq6ZK.js → automation-XDPAjiZi.js} +0 -0
- /package/build/assets/{color-themes-DSaoIL6A.js → color-themes-B9pm9c-R.js} +0 -0
- /package/build/assets/{common-DR1t-EeP.js → common-DqjLSBOt.js} +0 -0
- /package/build/assets/{conversation-local-storage-UYl-SX-r.js → conversation-local-storage-YmOVXxxW.js} +0 -0
- /package/build/assets/{dist-C6t0EXL7.js → dist-C3NfioQC.js} +0 -0
- /package/build/assets/{environment-switch-store-C4ulFJKp.js → environment-switch-store-CiurvTtK.js} +0 -0
- /package/build/assets/{health-store-BDC2rM-X.js → health-store-B5f0S2FY.js} +0 -0
- /package/build/assets/{map-provider-COBVzZYo.js → map-provider-BJ_8KZKU.js} +0 -0
- /package/build/assets/{middleware-BC9EwbB9.js → middleware-CfatjPYZ.js} +0 -0
- /package/build/assets/{objectWithoutPropertiesLoose-Du6eBn-V.js → objectWithoutPropertiesLoose-DSQKyRhw.js} +0 -0
- /package/build/assets/{react-Do0CT17Y.js → react-Dy05vyj5.js} +0 -0
- /package/build/assets/{sdk-settings-field-metadata-CBPmeqYa.js → sdk-settings-field-metadata-DQiaIBie.js} +0 -0
- /package/build/assets/{settings-D_H-qsRm.js → settings-DGY6n4J2.js} +0 -0
- /package/build/assets/{settings-like-page-layout-classes-I0BDBEoq.js → settings-like-page-layout-classes-D7YjdTd0.js} +0 -0
- /package/build/assets/{use-breakpoint-DbJ6FkQ-.js → use-breakpoint-DF_RiQ6s.js} +0 -0
- /package/build/assets/{use-click-outside-element-DffgWWoZ.js → use-click-outside-element-DhxCUyWl.js} +0 -0
- /package/build/assets/{v4-CNn21NXa.js → v4-khGvL7i2.js} +0 -0
- /package/build/assets/{vendor~browser-DDiZgqD3.js → vendor~browser-DisFGEp9.js} +0 -0
- /package/build/assets/{vendor~browser-tab-BgwV1mxF.js → vendor~browser-tab-BxhTtM9_.js} +0 -0
- /package/build/assets/{vendor~conversation-panel~conversation~alert-banner-DbvX3OcM.js → vendor~conversation-panel~conversation~alert-banner-w-I2sY6c.js} +0 -0
- /package/build/assets/{vendor~entry.client~root~root-layout~home~conversation-panel~conversation~launch~skills-set~zm51vy4j-iOsylxCS.js → vendor~entry.client~root~root-layout~home~conversation-panel~conversation~launch~skills-set~zm51vy4j-BClAMeFe.js} +0 -0
- /package/build/assets/{vendor~files-tab-BGKayPiK.js → vendor~files-tab-BtkpAiMX.js} +0 -0
- /package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-BW6261Sb.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-CyZ-3lDQ.js} +0 -0
- /package/build/assets/{vendor~home~mcp~automations-list-DoPfwaXj.js → vendor~home~mcp~automations-list-BgV86Sti.js} +0 -0
- /package/build/assets/{vendor~launch-vdeRTWFu.js → vendor~launch-BXgl67Re.js} +0 -0
- /package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~ninslayh-D9P8e98a.js → vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~ninslayh-CLlsvdNP.js} +0 -0
- /package/build/assets/{vendor~terminal-DUrOWGFE.js → vendor~terminal-DZaJIY8A.js} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"conversation-store.cjs","names":[],"sources":["../../src/stores/conversation-store.ts"],"sourcesContent":["import { create } from \"zustand\";\nimport { devtools } from \"zustand/middleware\";\nimport {\n getConversationState,\n setConversationState,\n} from \"#/utils/conversation-local-storage\";\n\nexport type ConversationTab =\n | \"files\"\n | \"browser\"\n | \"vscode\"\n | \"terminal\"\n | \"planner\"\n | \"tasklist\";\n\nexport type ConversationMode = \"code\" | \"plan\";\n\nexport interface IMessageToSend {\n text: string;\n timestamp: number;\n}\n\ninterface ConversationState {\n isRightPanelShown: boolean;\n selectedTab: ConversationTab | null;\n images: File[];\n files: File[];\n /** Image file names (e.g. pasted screenshots) to send via file upload instead of vision embed. */\n imagesMarkedUploadAsFile: string[];\n /** Image file names attached in chat (controls per-image upload-as-file UI). */\n pastedImageNames: string[];\n loadingFiles: string[]; // File names currently being processed\n loadingImages: string[]; // Image names currently being processed\n messageToSend: IMessageToSend | null;\n shouldShownAgentLoading: boolean;\n submittedMessage: string | null;\n shouldHideSuggestions: boolean; // New state to hide suggestions when input expands\n hasRightPanelToggled: boolean;\n planContent: string | null;\n conversationMode: ConversationMode;\n subConversationTaskId: string | null; // Task ID for sub-conversation creation\n}\n\ninterface ConversationActions {\n setIsRightPanelShown: (isRightPanelShown: boolean) => void;\n setSelectedTab: (selectedTab: ConversationTab | null) => void;\n setShouldShownAgentLoading: (shouldShownAgentLoading: boolean) => void;\n setShouldHideSuggestions: (shouldHideSuggestions: boolean) => void;\n addImages: (images: File[]) => void;\n addFiles: (files: File[]) => void;\n toggleImageUploadAsFile: (fileName: string) => void;\n markImagesAsPasted: (fileNames: string[]) => void;\n removeImage: (index: number) => void;\n removeFile: (index: number) => void;\n clearImages: () => void;\n clearFiles: () => void;\n clearAllFiles: () => void;\n addFileLoading: (fileName: string) => void;\n removeFileLoading: (fileName: string) => void;\n addImageLoading: (imageName: string) => void;\n removeImageLoading: (imageName: string) => void;\n clearAllLoading: () => void;\n setMessageToSend: (text: string) => void;\n setSubmittedMessage: (message: string | null) => void;\n resetConversationState: () => void;\n setHasRightPanelToggled: (hasRightPanelToggled: boolean) => void;\n setConversationMode: (conversationMode: ConversationMode) => void;\n setSubConversationTaskId: (taskId: string | null) => void;\n setPlanContent: (planContent: string | null) => void;\n}\n\ntype ConversationStore = ConversationState & ConversationActions;\n\nconst getConversationIdFromLocation = (): string | null => {\n if (typeof window === \"undefined\") {\n return null;\n }\n\n const match = window.location.pathname.match(/\\/conversations\\/([^/]+)/);\n return match ? match[1] : null;\n};\n\nconst getInitialConversationMode = (): ConversationMode => {\n if (typeof window === \"undefined\") {\n return \"code\";\n }\n\n const conversationId = getConversationIdFromLocation();\n if (!conversationId) {\n return \"code\";\n }\n\n const state = getConversationState(conversationId);\n return state.conversationMode;\n};\n\nexport const useConversationStore = create<ConversationStore>()(\n devtools(\n (set) => ({\n // Initial state.\n //\n // The right-side drawer (`isRightPanelShown` / `hasRightPanelToggled`)\n // is intentionally *session-only* state: it always starts closed on\n // app load (or on opening a fresh/existing conversation after a\n // restart), but it survives in-app navigation because the Zustand\n // store stays alive across React Router transitions. Persisting the\n // open/closed state in localStorage made the panel feel sticky in\n // a way users didn't expect — they want a clean, focused chat view\n // when they come back to the app and only want the panel back when\n // they themselves opened it during the current session.\n isRightPanelShown: false,\n selectedTab: \"files\" as ConversationTab,\n images: [],\n files: [],\n imagesMarkedUploadAsFile: [],\n pastedImageNames: [],\n loadingFiles: [],\n loadingImages: [],\n messageToSend: null,\n shouldShownAgentLoading: false,\n submittedMessage: null,\n shouldHideSuggestions: false,\n hasRightPanelToggled: false,\n planContent: null,\n conversationMode: getInitialConversationMode(),\n subConversationTaskId: null,\n\n // Actions\n setIsRightPanelShown: (isRightPanelShown) =>\n set({ isRightPanelShown }, false, \"setIsRightPanelShown\"),\n\n setSelectedTab: (selectedTab) =>\n set({ selectedTab }, false, \"setSelectedTab\"),\n\n setShouldShownAgentLoading: (shouldShownAgentLoading) =>\n set({ shouldShownAgentLoading }, false, \"setShouldShownAgentLoading\"),\n\n setShouldHideSuggestions: (shouldHideSuggestions) =>\n set({ shouldHideSuggestions }, false, \"setShouldHideSuggestions\"),\n\n addImages: (images) =>\n set(\n (state) => ({ images: [...state.images, ...images] }),\n false,\n \"addImages\",\n ),\n\n addFiles: (files) =>\n set(\n (state) => ({ files: [...state.files, ...files] }),\n false,\n \"addFiles\",\n ),\n\n toggleImageUploadAsFile: (fileName) =>\n set(\n (state) => {\n const marked = new Set(state.imagesMarkedUploadAsFile);\n if (marked.has(fileName)) {\n marked.delete(fileName);\n } else {\n marked.add(fileName);\n }\n return { imagesMarkedUploadAsFile: [...marked] };\n },\n false,\n \"toggleImageUploadAsFile\",\n ),\n\n markImagesAsPasted: (fileNames) =>\n set(\n (state) => {\n const merged = new Set([...state.pastedImageNames, ...fileNames]);\n return { pastedImageNames: [...merged] };\n },\n false,\n \"markImagesAsPasted\",\n ),\n\n removeImage: (index) =>\n set(\n (state) => {\n const removed = state.images[index];\n const newImages = [...state.images];\n newImages.splice(index, 1);\n return {\n images: newImages,\n imagesMarkedUploadAsFile: removed\n ? state.imagesMarkedUploadAsFile.filter(\n (name) => name !== removed.name,\n )\n : state.imagesMarkedUploadAsFile,\n pastedImageNames: removed\n ? state.pastedImageNames.filter((name) => name !== removed.name)\n : state.pastedImageNames,\n };\n },\n false,\n \"removeImage\",\n ),\n\n removeFile: (index) =>\n set(\n (state) => {\n const newFiles = [...state.files];\n newFiles.splice(index, 1);\n return { files: newFiles };\n },\n false,\n \"removeFile\",\n ),\n\n clearImages: () => set({ images: [] }, false, \"clearImages\"),\n\n clearFiles: () => set({ files: [] }, false, \"clearFiles\"),\n\n clearAllFiles: () =>\n set(\n {\n images: [],\n files: [],\n imagesMarkedUploadAsFile: [],\n pastedImageNames: [],\n loadingFiles: [],\n loadingImages: [],\n },\n false,\n \"clearAllFiles\",\n ),\n\n addFileLoading: (fileName) =>\n set(\n (state) => {\n if (!state.loadingFiles.includes(fileName)) {\n return { loadingFiles: [...state.loadingFiles, fileName] };\n }\n return state;\n },\n false,\n \"addFileLoading\",\n ),\n\n removeFileLoading: (fileName) =>\n set(\n (state) => ({\n loadingFiles: state.loadingFiles.filter(\n (name) => name !== fileName,\n ),\n }),\n false,\n \"removeFileLoading\",\n ),\n\n addImageLoading: (imageName) =>\n set(\n (state) => {\n if (!state.loadingImages.includes(imageName)) {\n return { loadingImages: [...state.loadingImages, imageName] };\n }\n return state;\n },\n false,\n \"addImageLoading\",\n ),\n\n removeImageLoading: (imageName) =>\n set(\n (state) => ({\n loadingImages: state.loadingImages.filter(\n (name) => name !== imageName,\n ),\n }),\n false,\n \"removeImageLoading\",\n ),\n\n clearAllLoading: () =>\n set({ loadingFiles: [], loadingImages: [] }, false, \"clearAllLoading\"),\n\n setMessageToSend: (text) =>\n set(\n {\n messageToSend: {\n text,\n timestamp: Date.now(),\n },\n },\n false,\n \"setMessageToSend\",\n ),\n\n setSubmittedMessage: (submittedMessage) =>\n set({ submittedMessage }, false, \"setSubmittedMessage\"),\n\n resetConversationState: () =>\n set(\n {\n shouldHideSuggestions: false,\n conversationMode: getInitialConversationMode(),\n subConversationTaskId: null,\n planContent: null,\n },\n false,\n \"resetConversationState\",\n ),\n\n setHasRightPanelToggled: (hasRightPanelToggled) =>\n set({ hasRightPanelToggled }, false, \"setHasRightPanelToggled\"),\n\n setConversationMode: (conversationMode) => {\n const conversationId = getConversationIdFromLocation();\n if (conversationId) {\n setConversationState(conversationId, { conversationMode });\n }\n set({ conversationMode }, false, \"setConversationMode\");\n },\n\n setSubConversationTaskId: (subConversationTaskId) =>\n set({ subConversationTaskId }, false, \"setSubConversationTaskId\"),\n\n setPlanContent: (planContent) =>\n set({ planContent }, false, \"setPlanContent\"),\n }),\n {\n name: \"conversation-store\",\n },\n ),\n);\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"conversation-store.cjs","names":[],"sources":["../../src/stores/conversation-store.ts"],"sourcesContent":["import { create } from \"zustand\";\nimport { devtools } from \"zustand/middleware\";\nimport {\n getConversationState,\n setConversationState,\n} from \"#/utils/conversation-local-storage\";\n\nexport type ConversationTab =\n | \"files\"\n | \"browser\"\n | \"vscode\"\n | \"terminal\"\n | \"planner\"\n | \"tasklist\";\n\nexport type ConversationMode = \"code\" | \"plan\";\n\nexport interface IMessageToSend {\n text: string;\n timestamp: number;\n}\n\ninterface ConversationState {\n isRightPanelShown: boolean;\n selectedTab: ConversationTab | null;\n images: File[];\n files: File[];\n /** Image file names (e.g. pasted screenshots) to send via file upload instead of vision embed. */\n imagesMarkedUploadAsFile: string[];\n /** Image file names attached in chat (controls per-image upload-as-file UI). */\n pastedImageNames: string[];\n loadingFiles: string[]; // File names currently being processed\n loadingImages: string[]; // Image names currently being processed\n messageToSend: IMessageToSend | null;\n /** One-shot restore request consumed by the chat input when empty. */\n messageRestoreIfEmpty: IMessageToSend | null;\n shouldShownAgentLoading: boolean;\n submittedMessage: string | null;\n shouldHideSuggestions: boolean; // New state to hide suggestions when input expands\n hasRightPanelToggled: boolean;\n planContent: string | null;\n conversationMode: ConversationMode;\n subConversationTaskId: string | null; // Task ID for sub-conversation creation\n}\n\ninterface ConversationActions {\n setIsRightPanelShown: (isRightPanelShown: boolean) => void;\n setSelectedTab: (selectedTab: ConversationTab | null) => void;\n setShouldShownAgentLoading: (shouldShownAgentLoading: boolean) => void;\n setShouldHideSuggestions: (shouldHideSuggestions: boolean) => void;\n addImages: (images: File[]) => void;\n addFiles: (files: File[]) => void;\n toggleImageUploadAsFile: (fileName: string) => void;\n markImagesAsPasted: (fileNames: string[]) => void;\n removeImage: (index: number) => void;\n removeFile: (index: number) => void;\n clearImages: () => void;\n clearFiles: () => void;\n clearAllFiles: () => void;\n addFileLoading: (fileName: string) => void;\n removeFileLoading: (fileName: string) => void;\n addImageLoading: (imageName: string) => void;\n removeImageLoading: (imageName: string) => void;\n clearAllLoading: () => void;\n setMessageToSend: (text: string) => void;\n restoreMessageToInputIfEmpty: (text: string) => void;\n clearMessageRestoreIfEmpty: () => void;\n setSubmittedMessage: (message: string | null) => void;\n resetConversationState: () => void;\n setHasRightPanelToggled: (hasRightPanelToggled: boolean) => void;\n setConversationMode: (conversationMode: ConversationMode) => void;\n setSubConversationTaskId: (taskId: string | null) => void;\n setPlanContent: (planContent: string | null) => void;\n}\n\ntype ConversationStore = ConversationState & ConversationActions;\n\nconst getConversationIdFromLocation = (): string | null => {\n if (typeof window === \"undefined\") {\n return null;\n }\n\n const match = window.location.pathname.match(/\\/conversations\\/([^/]+)/);\n return match ? match[1] : null;\n};\n\nconst getInitialConversationMode = (): ConversationMode => {\n if (typeof window === \"undefined\") {\n return \"code\";\n }\n\n const conversationId = getConversationIdFromLocation();\n if (!conversationId) {\n return \"code\";\n }\n\n const state = getConversationState(conversationId);\n return state.conversationMode;\n};\n\nexport const useConversationStore = create<ConversationStore>()(\n devtools(\n (set) => ({\n // Initial state.\n //\n // The right-side drawer (`isRightPanelShown` / `hasRightPanelToggled`)\n // is intentionally *session-only* state: it always starts closed on\n // app load (or on opening a fresh/existing conversation after a\n // restart), but it survives in-app navigation because the Zustand\n // store stays alive across React Router transitions. Persisting the\n // open/closed state in localStorage made the panel feel sticky in\n // a way users didn't expect — they want a clean, focused chat view\n // when they come back to the app and only want the panel back when\n // they themselves opened it during the current session.\n isRightPanelShown: false,\n selectedTab: \"files\" as ConversationTab,\n images: [],\n files: [],\n imagesMarkedUploadAsFile: [],\n pastedImageNames: [],\n loadingFiles: [],\n loadingImages: [],\n messageToSend: null,\n messageRestoreIfEmpty: null,\n shouldShownAgentLoading: false,\n submittedMessage: null,\n shouldHideSuggestions: false,\n hasRightPanelToggled: false,\n planContent: null,\n conversationMode: getInitialConversationMode(),\n subConversationTaskId: null,\n\n // Actions\n setIsRightPanelShown: (isRightPanelShown) =>\n set({ isRightPanelShown }, false, \"setIsRightPanelShown\"),\n\n setSelectedTab: (selectedTab) =>\n set({ selectedTab }, false, \"setSelectedTab\"),\n\n setShouldShownAgentLoading: (shouldShownAgentLoading) =>\n set({ shouldShownAgentLoading }, false, \"setShouldShownAgentLoading\"),\n\n setShouldHideSuggestions: (shouldHideSuggestions) =>\n set({ shouldHideSuggestions }, false, \"setShouldHideSuggestions\"),\n\n addImages: (images) =>\n set(\n (state) => ({ images: [...state.images, ...images] }),\n false,\n \"addImages\",\n ),\n\n addFiles: (files) =>\n set(\n (state) => ({ files: [...state.files, ...files] }),\n false,\n \"addFiles\",\n ),\n\n toggleImageUploadAsFile: (fileName) =>\n set(\n (state) => {\n const marked = new Set(state.imagesMarkedUploadAsFile);\n if (marked.has(fileName)) {\n marked.delete(fileName);\n } else {\n marked.add(fileName);\n }\n return { imagesMarkedUploadAsFile: [...marked] };\n },\n false,\n \"toggleImageUploadAsFile\",\n ),\n\n markImagesAsPasted: (fileNames) =>\n set(\n (state) => {\n const merged = new Set([...state.pastedImageNames, ...fileNames]);\n return { pastedImageNames: [...merged] };\n },\n false,\n \"markImagesAsPasted\",\n ),\n\n removeImage: (index) =>\n set(\n (state) => {\n const removed = state.images[index];\n const newImages = [...state.images];\n newImages.splice(index, 1);\n return {\n images: newImages,\n imagesMarkedUploadAsFile: removed\n ? state.imagesMarkedUploadAsFile.filter(\n (name) => name !== removed.name,\n )\n : state.imagesMarkedUploadAsFile,\n pastedImageNames: removed\n ? state.pastedImageNames.filter((name) => name !== removed.name)\n : state.pastedImageNames,\n };\n },\n false,\n \"removeImage\",\n ),\n\n removeFile: (index) =>\n set(\n (state) => {\n const newFiles = [...state.files];\n newFiles.splice(index, 1);\n return { files: newFiles };\n },\n false,\n \"removeFile\",\n ),\n\n clearImages: () => set({ images: [] }, false, \"clearImages\"),\n\n clearFiles: () => set({ files: [] }, false, \"clearFiles\"),\n\n clearAllFiles: () =>\n set(\n {\n images: [],\n files: [],\n imagesMarkedUploadAsFile: [],\n pastedImageNames: [],\n loadingFiles: [],\n loadingImages: [],\n },\n false,\n \"clearAllFiles\",\n ),\n\n addFileLoading: (fileName) =>\n set(\n (state) => {\n if (!state.loadingFiles.includes(fileName)) {\n return { loadingFiles: [...state.loadingFiles, fileName] };\n }\n return state;\n },\n false,\n \"addFileLoading\",\n ),\n\n removeFileLoading: (fileName) =>\n set(\n (state) => ({\n loadingFiles: state.loadingFiles.filter(\n (name) => name !== fileName,\n ),\n }),\n false,\n \"removeFileLoading\",\n ),\n\n addImageLoading: (imageName) =>\n set(\n (state) => {\n if (!state.loadingImages.includes(imageName)) {\n return { loadingImages: [...state.loadingImages, imageName] };\n }\n return state;\n },\n false,\n \"addImageLoading\",\n ),\n\n removeImageLoading: (imageName) =>\n set(\n (state) => ({\n loadingImages: state.loadingImages.filter(\n (name) => name !== imageName,\n ),\n }),\n false,\n \"removeImageLoading\",\n ),\n\n clearAllLoading: () =>\n set({ loadingFiles: [], loadingImages: [] }, false, \"clearAllLoading\"),\n\n setMessageToSend: (text) =>\n set(\n {\n messageToSend: {\n text,\n timestamp: Date.now(),\n },\n },\n false,\n \"setMessageToSend\",\n ),\n\n restoreMessageToInputIfEmpty: (text) =>\n set(\n {\n messageRestoreIfEmpty: {\n text,\n timestamp: Date.now(),\n },\n },\n false,\n \"restoreMessageToInputIfEmpty\",\n ),\n\n clearMessageRestoreIfEmpty: () =>\n set(\n { messageRestoreIfEmpty: null },\n false,\n \"clearMessageRestoreIfEmpty\",\n ),\n\n setSubmittedMessage: (submittedMessage) =>\n set({ submittedMessage }, false, \"setSubmittedMessage\"),\n\n resetConversationState: () =>\n set(\n {\n shouldHideSuggestions: false,\n conversationMode: getInitialConversationMode(),\n subConversationTaskId: null,\n planContent: null,\n },\n false,\n \"resetConversationState\",\n ),\n\n setHasRightPanelToggled: (hasRightPanelToggled) =>\n set({ hasRightPanelToggled }, false, \"setHasRightPanelToggled\"),\n\n setConversationMode: (conversationMode) => {\n const conversationId = getConversationIdFromLocation();\n if (conversationId) {\n setConversationState(conversationId, { conversationMode });\n }\n set({ conversationMode }, false, \"setConversationMode\");\n },\n\n setSubConversationTaskId: (subConversationTaskId) =>\n set({ subConversationTaskId }, false, \"setSubConversationTaskId\"),\n\n setPlanContent: (planContent) =>\n set({ planContent }, false, \"setPlanContent\"),\n }),\n {\n name: \"conversation-store\",\n },\n ),\n);\n"],"mappings":"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"}
|
|
@@ -16,6 +16,8 @@ interface ConversationState {
|
|
|
16
16
|
loadingFiles: string[];
|
|
17
17
|
loadingImages: string[];
|
|
18
18
|
messageToSend: IMessageToSend | null;
|
|
19
|
+
/** One-shot restore request consumed by the chat input when empty. */
|
|
20
|
+
messageRestoreIfEmpty: IMessageToSend | null;
|
|
19
21
|
shouldShownAgentLoading: boolean;
|
|
20
22
|
submittedMessage: string | null;
|
|
21
23
|
shouldHideSuggestions: boolean;
|
|
@@ -44,6 +46,8 @@ interface ConversationActions {
|
|
|
44
46
|
removeImageLoading: (imageName: string) => void;
|
|
45
47
|
clearAllLoading: () => void;
|
|
46
48
|
setMessageToSend: (text: string) => void;
|
|
49
|
+
restoreMessageToInputIfEmpty: (text: string) => void;
|
|
50
|
+
clearMessageRestoreIfEmpty: () => void;
|
|
47
51
|
setSubmittedMessage: (message: string | null) => void;
|
|
48
52
|
resetConversationState: () => void;
|
|
49
53
|
setHasRightPanelToggled: (hasRightPanelToggled: boolean) => void;
|
|
@@ -20,6 +20,7 @@ var i = () => {
|
|
|
20
20
|
loadingFiles: [],
|
|
21
21
|
loadingImages: [],
|
|
22
22
|
messageToSend: null,
|
|
23
|
+
messageRestoreIfEmpty: null,
|
|
23
24
|
shouldShownAgentLoading: !1,
|
|
24
25
|
submittedMessage: null,
|
|
25
26
|
shouldHideSuggestions: !1,
|
|
@@ -72,6 +73,11 @@ var i = () => {
|
|
|
72
73
|
text: t,
|
|
73
74
|
timestamp: Date.now()
|
|
74
75
|
} }, !1, "setMessageToSend"),
|
|
76
|
+
restoreMessageToInputIfEmpty: (t) => e({ messageRestoreIfEmpty: {
|
|
77
|
+
text: t,
|
|
78
|
+
timestamp: Date.now()
|
|
79
|
+
} }, !1, "restoreMessageToInputIfEmpty"),
|
|
80
|
+
clearMessageRestoreIfEmpty: () => e({ messageRestoreIfEmpty: null }, !1, "clearMessageRestoreIfEmpty"),
|
|
75
81
|
setSubmittedMessage: (t) => e({ submittedMessage: t }, !1, "setSubmittedMessage"),
|
|
76
82
|
resetConversationState: () => e({
|
|
77
83
|
shouldHideSuggestions: !1,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"conversation-store.js","names":[],"sources":["../../src/stores/conversation-store.ts"],"sourcesContent":["import { create } from \"zustand\";\nimport { devtools } from \"zustand/middleware\";\nimport {\n getConversationState,\n setConversationState,\n} from \"#/utils/conversation-local-storage\";\n\nexport type ConversationTab =\n | \"files\"\n | \"browser\"\n | \"vscode\"\n | \"terminal\"\n | \"planner\"\n | \"tasklist\";\n\nexport type ConversationMode = \"code\" | \"plan\";\n\nexport interface IMessageToSend {\n text: string;\n timestamp: number;\n}\n\ninterface ConversationState {\n isRightPanelShown: boolean;\n selectedTab: ConversationTab | null;\n images: File[];\n files: File[];\n /** Image file names (e.g. pasted screenshots) to send via file upload instead of vision embed. */\n imagesMarkedUploadAsFile: string[];\n /** Image file names attached in chat (controls per-image upload-as-file UI). */\n pastedImageNames: string[];\n loadingFiles: string[]; // File names currently being processed\n loadingImages: string[]; // Image names currently being processed\n messageToSend: IMessageToSend | null;\n shouldShownAgentLoading: boolean;\n submittedMessage: string | null;\n shouldHideSuggestions: boolean; // New state to hide suggestions when input expands\n hasRightPanelToggled: boolean;\n planContent: string | null;\n conversationMode: ConversationMode;\n subConversationTaskId: string | null; // Task ID for sub-conversation creation\n}\n\ninterface ConversationActions {\n setIsRightPanelShown: (isRightPanelShown: boolean) => void;\n setSelectedTab: (selectedTab: ConversationTab | null) => void;\n setShouldShownAgentLoading: (shouldShownAgentLoading: boolean) => void;\n setShouldHideSuggestions: (shouldHideSuggestions: boolean) => void;\n addImages: (images: File[]) => void;\n addFiles: (files: File[]) => void;\n toggleImageUploadAsFile: (fileName: string) => void;\n markImagesAsPasted: (fileNames: string[]) => void;\n removeImage: (index: number) => void;\n removeFile: (index: number) => void;\n clearImages: () => void;\n clearFiles: () => void;\n clearAllFiles: () => void;\n addFileLoading: (fileName: string) => void;\n removeFileLoading: (fileName: string) => void;\n addImageLoading: (imageName: string) => void;\n removeImageLoading: (imageName: string) => void;\n clearAllLoading: () => void;\n setMessageToSend: (text: string) => void;\n setSubmittedMessage: (message: string | null) => void;\n resetConversationState: () => void;\n setHasRightPanelToggled: (hasRightPanelToggled: boolean) => void;\n setConversationMode: (conversationMode: ConversationMode) => void;\n setSubConversationTaskId: (taskId: string | null) => void;\n setPlanContent: (planContent: string | null) => void;\n}\n\ntype ConversationStore = ConversationState & ConversationActions;\n\nconst getConversationIdFromLocation = (): string | null => {\n if (typeof window === \"undefined\") {\n return null;\n }\n\n const match = window.location.pathname.match(/\\/conversations\\/([^/]+)/);\n return match ? match[1] : null;\n};\n\nconst getInitialConversationMode = (): ConversationMode => {\n if (typeof window === \"undefined\") {\n return \"code\";\n }\n\n const conversationId = getConversationIdFromLocation();\n if (!conversationId) {\n return \"code\";\n }\n\n const state = getConversationState(conversationId);\n return state.conversationMode;\n};\n\nexport const useConversationStore = create<ConversationStore>()(\n devtools(\n (set) => ({\n // Initial state.\n //\n // The right-side drawer (`isRightPanelShown` / `hasRightPanelToggled`)\n // is intentionally *session-only* state: it always starts closed on\n // app load (or on opening a fresh/existing conversation after a\n // restart), but it survives in-app navigation because the Zustand\n // store stays alive across React Router transitions. Persisting the\n // open/closed state in localStorage made the panel feel sticky in\n // a way users didn't expect — they want a clean, focused chat view\n // when they come back to the app and only want the panel back when\n // they themselves opened it during the current session.\n isRightPanelShown: false,\n selectedTab: \"files\" as ConversationTab,\n images: [],\n files: [],\n imagesMarkedUploadAsFile: [],\n pastedImageNames: [],\n loadingFiles: [],\n loadingImages: [],\n messageToSend: null,\n shouldShownAgentLoading: false,\n submittedMessage: null,\n shouldHideSuggestions: false,\n hasRightPanelToggled: false,\n planContent: null,\n conversationMode: getInitialConversationMode(),\n subConversationTaskId: null,\n\n // Actions\n setIsRightPanelShown: (isRightPanelShown) =>\n set({ isRightPanelShown }, false, \"setIsRightPanelShown\"),\n\n setSelectedTab: (selectedTab) =>\n set({ selectedTab }, false, \"setSelectedTab\"),\n\n setShouldShownAgentLoading: (shouldShownAgentLoading) =>\n set({ shouldShownAgentLoading }, false, \"setShouldShownAgentLoading\"),\n\n setShouldHideSuggestions: (shouldHideSuggestions) =>\n set({ shouldHideSuggestions }, false, \"setShouldHideSuggestions\"),\n\n addImages: (images) =>\n set(\n (state) => ({ images: [...state.images, ...images] }),\n false,\n \"addImages\",\n ),\n\n addFiles: (files) =>\n set(\n (state) => ({ files: [...state.files, ...files] }),\n false,\n \"addFiles\",\n ),\n\n toggleImageUploadAsFile: (fileName) =>\n set(\n (state) => {\n const marked = new Set(state.imagesMarkedUploadAsFile);\n if (marked.has(fileName)) {\n marked.delete(fileName);\n } else {\n marked.add(fileName);\n }\n return { imagesMarkedUploadAsFile: [...marked] };\n },\n false,\n \"toggleImageUploadAsFile\",\n ),\n\n markImagesAsPasted: (fileNames) =>\n set(\n (state) => {\n const merged = new Set([...state.pastedImageNames, ...fileNames]);\n return { pastedImageNames: [...merged] };\n },\n false,\n \"markImagesAsPasted\",\n ),\n\n removeImage: (index) =>\n set(\n (state) => {\n const removed = state.images[index];\n const newImages = [...state.images];\n newImages.splice(index, 1);\n return {\n images: newImages,\n imagesMarkedUploadAsFile: removed\n ? state.imagesMarkedUploadAsFile.filter(\n (name) => name !== removed.name,\n )\n : state.imagesMarkedUploadAsFile,\n pastedImageNames: removed\n ? state.pastedImageNames.filter((name) => name !== removed.name)\n : state.pastedImageNames,\n };\n },\n false,\n \"removeImage\",\n ),\n\n removeFile: (index) =>\n set(\n (state) => {\n const newFiles = [...state.files];\n newFiles.splice(index, 1);\n return { files: newFiles };\n },\n false,\n \"removeFile\",\n ),\n\n clearImages: () => set({ images: [] }, false, \"clearImages\"),\n\n clearFiles: () => set({ files: [] }, false, \"clearFiles\"),\n\n clearAllFiles: () =>\n set(\n {\n images: [],\n files: [],\n imagesMarkedUploadAsFile: [],\n pastedImageNames: [],\n loadingFiles: [],\n loadingImages: [],\n },\n false,\n \"clearAllFiles\",\n ),\n\n addFileLoading: (fileName) =>\n set(\n (state) => {\n if (!state.loadingFiles.includes(fileName)) {\n return { loadingFiles: [...state.loadingFiles, fileName] };\n }\n return state;\n },\n false,\n \"addFileLoading\",\n ),\n\n removeFileLoading: (fileName) =>\n set(\n (state) => ({\n loadingFiles: state.loadingFiles.filter(\n (name) => name !== fileName,\n ),\n }),\n false,\n \"removeFileLoading\",\n ),\n\n addImageLoading: (imageName) =>\n set(\n (state) => {\n if (!state.loadingImages.includes(imageName)) {\n return { loadingImages: [...state.loadingImages, imageName] };\n }\n return state;\n },\n false,\n \"addImageLoading\",\n ),\n\n removeImageLoading: (imageName) =>\n set(\n (state) => ({\n loadingImages: state.loadingImages.filter(\n (name) => name !== imageName,\n ),\n }),\n false,\n \"removeImageLoading\",\n ),\n\n clearAllLoading: () =>\n set({ loadingFiles: [], loadingImages: [] }, false, \"clearAllLoading\"),\n\n setMessageToSend: (text) =>\n set(\n {\n messageToSend: {\n text,\n timestamp: Date.now(),\n },\n },\n false,\n \"setMessageToSend\",\n ),\n\n setSubmittedMessage: (submittedMessage) =>\n set({ submittedMessage }, false, \"setSubmittedMessage\"),\n\n resetConversationState: () =>\n set(\n {\n shouldHideSuggestions: false,\n conversationMode: getInitialConversationMode(),\n subConversationTaskId: null,\n planContent: null,\n },\n false,\n \"resetConversationState\",\n ),\n\n setHasRightPanelToggled: (hasRightPanelToggled) =>\n set({ hasRightPanelToggled }, false, \"setHasRightPanelToggled\"),\n\n setConversationMode: (conversationMode) => {\n const conversationId = getConversationIdFromLocation();\n if (conversationId) {\n setConversationState(conversationId, { conversationMode });\n }\n set({ conversationMode }, false, \"setConversationMode\");\n },\n\n setSubConversationTaskId: (subConversationTaskId) =>\n set({ subConversationTaskId }, false, \"setSubConversationTaskId\"),\n\n setPlanContent: (planContent) =>\n set({ planContent }, false, \"setPlanContent\"),\n }),\n {\n name: \"conversation-store\",\n },\n ),\n);\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"conversation-store.js","names":[],"sources":["../../src/stores/conversation-store.ts"],"sourcesContent":["import { create } from \"zustand\";\nimport { devtools } from \"zustand/middleware\";\nimport {\n getConversationState,\n setConversationState,\n} from \"#/utils/conversation-local-storage\";\n\nexport type ConversationTab =\n | \"files\"\n | \"browser\"\n | \"vscode\"\n | \"terminal\"\n | \"planner\"\n | \"tasklist\";\n\nexport type ConversationMode = \"code\" | \"plan\";\n\nexport interface IMessageToSend {\n text: string;\n timestamp: number;\n}\n\ninterface ConversationState {\n isRightPanelShown: boolean;\n selectedTab: ConversationTab | null;\n images: File[];\n files: File[];\n /** Image file names (e.g. pasted screenshots) to send via file upload instead of vision embed. */\n imagesMarkedUploadAsFile: string[];\n /** Image file names attached in chat (controls per-image upload-as-file UI). */\n pastedImageNames: string[];\n loadingFiles: string[]; // File names currently being processed\n loadingImages: string[]; // Image names currently being processed\n messageToSend: IMessageToSend | null;\n /** One-shot restore request consumed by the chat input when empty. */\n messageRestoreIfEmpty: IMessageToSend | null;\n shouldShownAgentLoading: boolean;\n submittedMessage: string | null;\n shouldHideSuggestions: boolean; // New state to hide suggestions when input expands\n hasRightPanelToggled: boolean;\n planContent: string | null;\n conversationMode: ConversationMode;\n subConversationTaskId: string | null; // Task ID for sub-conversation creation\n}\n\ninterface ConversationActions {\n setIsRightPanelShown: (isRightPanelShown: boolean) => void;\n setSelectedTab: (selectedTab: ConversationTab | null) => void;\n setShouldShownAgentLoading: (shouldShownAgentLoading: boolean) => void;\n setShouldHideSuggestions: (shouldHideSuggestions: boolean) => void;\n addImages: (images: File[]) => void;\n addFiles: (files: File[]) => void;\n toggleImageUploadAsFile: (fileName: string) => void;\n markImagesAsPasted: (fileNames: string[]) => void;\n removeImage: (index: number) => void;\n removeFile: (index: number) => void;\n clearImages: () => void;\n clearFiles: () => void;\n clearAllFiles: () => void;\n addFileLoading: (fileName: string) => void;\n removeFileLoading: (fileName: string) => void;\n addImageLoading: (imageName: string) => void;\n removeImageLoading: (imageName: string) => void;\n clearAllLoading: () => void;\n setMessageToSend: (text: string) => void;\n restoreMessageToInputIfEmpty: (text: string) => void;\n clearMessageRestoreIfEmpty: () => void;\n setSubmittedMessage: (message: string | null) => void;\n resetConversationState: () => void;\n setHasRightPanelToggled: (hasRightPanelToggled: boolean) => void;\n setConversationMode: (conversationMode: ConversationMode) => void;\n setSubConversationTaskId: (taskId: string | null) => void;\n setPlanContent: (planContent: string | null) => void;\n}\n\ntype ConversationStore = ConversationState & ConversationActions;\n\nconst getConversationIdFromLocation = (): string | null => {\n if (typeof window === \"undefined\") {\n return null;\n }\n\n const match = window.location.pathname.match(/\\/conversations\\/([^/]+)/);\n return match ? match[1] : null;\n};\n\nconst getInitialConversationMode = (): ConversationMode => {\n if (typeof window === \"undefined\") {\n return \"code\";\n }\n\n const conversationId = getConversationIdFromLocation();\n if (!conversationId) {\n return \"code\";\n }\n\n const state = getConversationState(conversationId);\n return state.conversationMode;\n};\n\nexport const useConversationStore = create<ConversationStore>()(\n devtools(\n (set) => ({\n // Initial state.\n //\n // The right-side drawer (`isRightPanelShown` / `hasRightPanelToggled`)\n // is intentionally *session-only* state: it always starts closed on\n // app load (or on opening a fresh/existing conversation after a\n // restart), but it survives in-app navigation because the Zustand\n // store stays alive across React Router transitions. Persisting the\n // open/closed state in localStorage made the panel feel sticky in\n // a way users didn't expect — they want a clean, focused chat view\n // when they come back to the app and only want the panel back when\n // they themselves opened it during the current session.\n isRightPanelShown: false,\n selectedTab: \"files\" as ConversationTab,\n images: [],\n files: [],\n imagesMarkedUploadAsFile: [],\n pastedImageNames: [],\n loadingFiles: [],\n loadingImages: [],\n messageToSend: null,\n messageRestoreIfEmpty: null,\n shouldShownAgentLoading: false,\n submittedMessage: null,\n shouldHideSuggestions: false,\n hasRightPanelToggled: false,\n planContent: null,\n conversationMode: getInitialConversationMode(),\n subConversationTaskId: null,\n\n // Actions\n setIsRightPanelShown: (isRightPanelShown) =>\n set({ isRightPanelShown }, false, \"setIsRightPanelShown\"),\n\n setSelectedTab: (selectedTab) =>\n set({ selectedTab }, false, \"setSelectedTab\"),\n\n setShouldShownAgentLoading: (shouldShownAgentLoading) =>\n set({ shouldShownAgentLoading }, false, \"setShouldShownAgentLoading\"),\n\n setShouldHideSuggestions: (shouldHideSuggestions) =>\n set({ shouldHideSuggestions }, false, \"setShouldHideSuggestions\"),\n\n addImages: (images) =>\n set(\n (state) => ({ images: [...state.images, ...images] }),\n false,\n \"addImages\",\n ),\n\n addFiles: (files) =>\n set(\n (state) => ({ files: [...state.files, ...files] }),\n false,\n \"addFiles\",\n ),\n\n toggleImageUploadAsFile: (fileName) =>\n set(\n (state) => {\n const marked = new Set(state.imagesMarkedUploadAsFile);\n if (marked.has(fileName)) {\n marked.delete(fileName);\n } else {\n marked.add(fileName);\n }\n return { imagesMarkedUploadAsFile: [...marked] };\n },\n false,\n \"toggleImageUploadAsFile\",\n ),\n\n markImagesAsPasted: (fileNames) =>\n set(\n (state) => {\n const merged = new Set([...state.pastedImageNames, ...fileNames]);\n return { pastedImageNames: [...merged] };\n },\n false,\n \"markImagesAsPasted\",\n ),\n\n removeImage: (index) =>\n set(\n (state) => {\n const removed = state.images[index];\n const newImages = [...state.images];\n newImages.splice(index, 1);\n return {\n images: newImages,\n imagesMarkedUploadAsFile: removed\n ? state.imagesMarkedUploadAsFile.filter(\n (name) => name !== removed.name,\n )\n : state.imagesMarkedUploadAsFile,\n pastedImageNames: removed\n ? state.pastedImageNames.filter((name) => name !== removed.name)\n : state.pastedImageNames,\n };\n },\n false,\n \"removeImage\",\n ),\n\n removeFile: (index) =>\n set(\n (state) => {\n const newFiles = [...state.files];\n newFiles.splice(index, 1);\n return { files: newFiles };\n },\n false,\n \"removeFile\",\n ),\n\n clearImages: () => set({ images: [] }, false, \"clearImages\"),\n\n clearFiles: () => set({ files: [] }, false, \"clearFiles\"),\n\n clearAllFiles: () =>\n set(\n {\n images: [],\n files: [],\n imagesMarkedUploadAsFile: [],\n pastedImageNames: [],\n loadingFiles: [],\n loadingImages: [],\n },\n false,\n \"clearAllFiles\",\n ),\n\n addFileLoading: (fileName) =>\n set(\n (state) => {\n if (!state.loadingFiles.includes(fileName)) {\n return { loadingFiles: [...state.loadingFiles, fileName] };\n }\n return state;\n },\n false,\n \"addFileLoading\",\n ),\n\n removeFileLoading: (fileName) =>\n set(\n (state) => ({\n loadingFiles: state.loadingFiles.filter(\n (name) => name !== fileName,\n ),\n }),\n false,\n \"removeFileLoading\",\n ),\n\n addImageLoading: (imageName) =>\n set(\n (state) => {\n if (!state.loadingImages.includes(imageName)) {\n return { loadingImages: [...state.loadingImages, imageName] };\n }\n return state;\n },\n false,\n \"addImageLoading\",\n ),\n\n removeImageLoading: (imageName) =>\n set(\n (state) => ({\n loadingImages: state.loadingImages.filter(\n (name) => name !== imageName,\n ),\n }),\n false,\n \"removeImageLoading\",\n ),\n\n clearAllLoading: () =>\n set({ loadingFiles: [], loadingImages: [] }, false, \"clearAllLoading\"),\n\n setMessageToSend: (text) =>\n set(\n {\n messageToSend: {\n text,\n timestamp: Date.now(),\n },\n },\n false,\n \"setMessageToSend\",\n ),\n\n restoreMessageToInputIfEmpty: (text) =>\n set(\n {\n messageRestoreIfEmpty: {\n text,\n timestamp: Date.now(),\n },\n },\n false,\n \"restoreMessageToInputIfEmpty\",\n ),\n\n clearMessageRestoreIfEmpty: () =>\n set(\n { messageRestoreIfEmpty: null },\n false,\n \"clearMessageRestoreIfEmpty\",\n ),\n\n setSubmittedMessage: (submittedMessage) =>\n set({ submittedMessage }, false, \"setSubmittedMessage\"),\n\n resetConversationState: () =>\n set(\n {\n shouldHideSuggestions: false,\n conversationMode: getInitialConversationMode(),\n subConversationTaskId: null,\n planContent: null,\n },\n false,\n \"resetConversationState\",\n ),\n\n setHasRightPanelToggled: (hasRightPanelToggled) =>\n set({ hasRightPanelToggled }, false, \"setHasRightPanelToggled\"),\n\n setConversationMode: (conversationMode) => {\n const conversationId = getConversationIdFromLocation();\n if (conversationId) {\n setConversationState(conversationId, { conversationMode });\n }\n set({ conversationMode }, false, \"setConversationMode\");\n },\n\n setSubConversationTaskId: (subConversationTaskId) =>\n set({ subConversationTaskId }, false, \"setSubConversationTaskId\"),\n\n setPlanContent: (planContent) =>\n set({ planContent }, false, \"setPlanContent\"),\n }),\n {\n name: \"conversation-store\",\n },\n ),\n);\n"],"mappings":"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"}
|
|
@@ -6,11 +6,13 @@ import { BaseEvent } from "../base/event";
|
|
|
6
6
|
*/
|
|
7
7
|
export type ACPToolKind = "execute" | "edit" | "read" | "fetch" | "other";
|
|
8
8
|
/**
|
|
9
|
-
* Status of an ACP tool call.
|
|
10
|
-
*
|
|
11
|
-
*
|
|
9
|
+
* Status of an ACP tool call. The SDK persists two events per
|
|
10
|
+
* ``tool_call_id``: an early ``started`` event (``pending`` / ``in_progress``)
|
|
11
|
+
* and one terminal event (``completed`` / ``failed``) — the
|
|
12
|
+
* action->observation pair. Non-terminal statuses render the card as
|
|
13
|
+
* "running"; see ``getACPToolCallResult``.
|
|
12
14
|
*/
|
|
13
|
-
export type ACPToolCallStatus = "in_progress" | "completed" | "failed";
|
|
15
|
+
export type ACPToolCallStatus = "pending" | "in_progress" | "completed" | "failed";
|
|
14
16
|
/**
|
|
15
17
|
* An ACP content block as surfaced on ``ACPToolCallEvent.content``. ACP
|
|
16
18
|
* allows a mix of text, image, resource and resource_link blocks; only the
|
|
@@ -13,4 +13,9 @@ export interface SystemPromptEvent extends BaseEvent {
|
|
|
13
13
|
* List of tools in OpenAI tool format
|
|
14
14
|
*/
|
|
15
15
|
tools: ChatCompletionToolParam[];
|
|
16
|
+
/**
|
|
17
|
+
* Runtime-injected context appended to the system message (datetime, skills,
|
|
18
|
+
* runtime services, secrets). Optional for older persisted events.
|
|
19
|
+
*/
|
|
20
|
+
dynamic_context?: TextContent;
|
|
16
21
|
}
|
|
@@ -1,7 +1,22 @@
|
|
|
1
1
|
export interface AutomationTrigger {
|
|
2
|
+
/**
|
|
3
|
+
* Trigger kind. Known values are the schedule aliases "cron" / "schedule"
|
|
4
|
+
* (time-based) and "event" (webhook/event-driven). Kept as `string` rather
|
|
5
|
+
* than a closed union on purpose: the backend emits more than one
|
|
6
|
+
* scheduled-trigger alias and may introduce new kinds, so UI code branches
|
|
7
|
+
* on `type === "event"` and treats every other value as a schedule.
|
|
8
|
+
*/
|
|
2
9
|
type: string;
|
|
10
|
+
/** Cron expression (schedule triggers only). */
|
|
3
11
|
schedule?: string;
|
|
12
|
+
/** Human-readable schedule description (schedule triggers only). */
|
|
4
13
|
schedule_human?: string;
|
|
14
|
+
/** Event source, e.g. "github" (event triggers only). */
|
|
15
|
+
source?: string;
|
|
16
|
+
/** Event key pattern(s) to match, e.g. "pull_request.opened" or ["push", "release.*"]. */
|
|
17
|
+
on?: string | string[];
|
|
18
|
+
/** JMESPath filter expression evaluated against the raw webhook payload. */
|
|
19
|
+
filter?: string;
|
|
5
20
|
}
|
|
6
21
|
export interface Automation {
|
|
7
22
|
id: string;
|
package/dist/types/settings.d.ts
CHANGED
|
@@ -90,7 +90,9 @@ export type SettingsScope = "personal";
|
|
|
90
90
|
* - ``"acp"``: the conversation is driven by an external ACP subprocess
|
|
91
91
|
* (Claude Code / Codex / Gemini CLI / Custom). The LLM / condenser / MCP
|
|
92
92
|
* settings are inert; ``acp_command`` / ``acp_args`` / ``acp_model`` /
|
|
93
|
-
* ``
|
|
93
|
+
* ``acp_server`` apply instead. Provider credentials are supplied through the
|
|
94
|
+
* Secrets panel (``request.secrets`` / ``agent_context.secrets``), never
|
|
95
|
+
* through a per-agent env channel.
|
|
94
96
|
*/
|
|
95
97
|
export type AgentKind = "openhands" | "acp";
|
|
96
98
|
export type Settings = {
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
require(`../_virtual/_rolldown/runtime.cjs`);const e=require(`../utils/utils.cjs`);let
|
|
1
|
+
require(`../_virtual/_rolldown/runtime.cjs`);const e=require(`../utils/utils.cjs`),t=require(`../utils/form-control-classes.cjs`);let n=require(`react/jsx-runtime`);function r({className:e}){return(0,n.jsx)(`svg`,{"aria-hidden":!0,fill:`none`,focusable:`false`,height:`1em`,role:`presentation`,stroke:`currentColor`,strokeLinecap:`round`,strokeLinejoin:`round`,strokeWidth:1.5,viewBox:`0 0 24 24`,width:`1em`,className:e,children:(0,n.jsx)(`path`,{d:`m6 9 6 6 6-6`})})}var i=e.cn(`inline-flex items-center justify-center shrink-0 rounded-none bg-transparent px-1 min-w-0 w-auto h-auto text-medium cursor-pointer outline-none`,t.formControlTransformTransitionClassName),a=e.cn(i,`!rounded-none !bg-transparent data-[hover=true]:!bg-transparent`);function o({isOpen:i,className:a}){return(0,n.jsx)(r,{className:e.cn(`shrink-0`,t.formControlTransformTransitionClassName,i&&`rotate-180`,a)})}exports.ComboboxCaretIcon=r,exports.ComboboxCaretInline=o,exports.comboboxCaretButtonClassName=i,exports.heroUiAutocompleteSelectorButtonClassName=a;
|
|
2
2
|
//# sourceMappingURL=combobox-caret.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"combobox-caret.cjs","names":[],"sources":["../../src/ui/combobox-caret.tsx"],"sourcesContent":["import { cn } from \"#/utils/utils\";\n\nexport function ComboboxCaretIcon({ className }: { className?: string }) {\n return (\n <svg\n aria-hidden\n fill=\"none\"\n focusable=\"false\"\n height=\"1em\"\n role=\"presentation\"\n stroke=\"currentColor\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={1.5}\n viewBox=\"0 0 24 24\"\n width=\"1em\"\n className={className}\n >\n <path d=\"m6 9 6 6 6-6\" />\n </svg>\n );\n}\n\n/** Matches HeroUI Autocomplete selectorButton styling. */\nexport const comboboxCaretButtonClassName
|
|
1
|
+
{"version":3,"file":"combobox-caret.cjs","names":[],"sources":["../../src/ui/combobox-caret.tsx"],"sourcesContent":["import { cn } from \"#/utils/utils\";\nimport { formControlTransformTransitionClassName } from \"#/utils/form-control-classes\";\n\nexport function ComboboxCaretIcon({ className }: { className?: string }) {\n return (\n <svg\n aria-hidden\n fill=\"none\"\n focusable=\"false\"\n height=\"1em\"\n role=\"presentation\"\n stroke=\"currentColor\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={1.5}\n viewBox=\"0 0 24 24\"\n width=\"1em\"\n className={className}\n >\n <path d=\"m6 9 6 6 6-6\" />\n </svg>\n );\n}\n\n/** Matches HeroUI Autocomplete selectorButton styling. */\nexport const comboboxCaretButtonClassName = cn(\n \"inline-flex items-center justify-center shrink-0 rounded-none bg-transparent px-1 min-w-0 w-auto h-auto text-medium cursor-pointer outline-none\",\n formControlTransformTransitionClassName,\n);\n\n/** HeroUI Autocomplete selectorButton slot — keep only chevron rotation animated. */\nexport const heroUiAutocompleteSelectorButtonClassName = cn(\n comboboxCaretButtonClassName,\n \"!rounded-none !bg-transparent data-[hover=true]:!bg-transparent\",\n);\n\ninterface ComboboxCaretButtonProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n isOpen?: boolean;\n}\n\nexport function ComboboxCaretButton({\n isOpen,\n className,\n disabled,\n children,\n ...props\n}: ComboboxCaretButtonProps) {\n return (\n <button\n type=\"button\"\n disabled={disabled}\n className={cn(\n comboboxCaretButtonClassName,\n isOpen && \"rotate-180\",\n disabled && \"cursor-not-allowed opacity-60\",\n className,\n )}\n {...props}\n >\n {children ?? <ComboboxCaretIcon />}\n </button>\n );\n}\n\n/** Inline caret for buttons where only the icon rotates, not the whole control. */\nexport function ComboboxCaretInline({\n isOpen,\n className,\n}: {\n isOpen?: boolean;\n className?: string;\n}) {\n return (\n <ComboboxCaretIcon\n className={cn(\n \"shrink-0\",\n formControlTransformTransitionClassName,\n isOpen && \"rotate-180\",\n className,\n )}\n />\n );\n}\n"],"mappings":"qKAGA,SAAgB,EAAkB,CAAE,aAAqC,CACvE,OACE,EAAA,EAAA,KAAC,MAAD,CACE,cAAA,GACA,KAAK,OACL,UAAU,QACV,OAAO,MACP,KAAK,eACL,OAAO,eACP,cAAc,QACd,eAAe,QACf,YAAa,IACb,QAAQ,YACR,MAAM,MACK,sBAEX,EAAA,EAAA,KAAC,OAAD,CAAM,EAAE,eAAiB,CAAA,CACrB,CAAA,CAKV,IAAa,EAA+B,EAAA,GAC1C,kJACA,EAAA,wCACD,CAGY,EAA4C,EAAA,GACvD,EACA,kEACD,CA+BD,SAAgB,EAAoB,CAClC,SACA,aAIC,CACD,OACE,EAAA,EAAA,KAAC,EAAD,CACE,UAAW,EAAA,GACT,WACA,EAAA,wCACA,GAAU,aACV,EACD,CACD,CAAA"}
|
|
@@ -2,7 +2,7 @@ export declare function ComboboxCaretIcon({ className }: {
|
|
|
2
2
|
className?: string;
|
|
3
3
|
}): import("react/jsx-runtime").JSX.Element;
|
|
4
4
|
/** Matches HeroUI Autocomplete selectorButton styling. */
|
|
5
|
-
export declare const comboboxCaretButtonClassName
|
|
5
|
+
export declare const comboboxCaretButtonClassName: string;
|
|
6
6
|
/** HeroUI Autocomplete selectorButton slot — keep only chevron rotation animated. */
|
|
7
7
|
export declare const heroUiAutocompleteSelectorButtonClassName: string;
|
|
8
8
|
interface ComboboxCaretButtonProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { cn as e } from "../utils/utils.js";
|
|
2
|
-
import {
|
|
2
|
+
import { formControlTransformTransitionClassName as t } from "../utils/form-control-classes.js";
|
|
3
|
+
import { jsx as n } from "react/jsx-runtime";
|
|
3
4
|
//#region src/ui/combobox-caret.tsx
|
|
4
|
-
function
|
|
5
|
-
return /* @__PURE__ */
|
|
5
|
+
function r({ className: e }) {
|
|
6
|
+
return /* @__PURE__ */ n("svg", {
|
|
6
7
|
"aria-hidden": !0,
|
|
7
8
|
fill: "none",
|
|
8
9
|
focusable: "false",
|
|
@@ -15,14 +16,14 @@ function n({ className: e }) {
|
|
|
15
16
|
viewBox: "0 0 24 24",
|
|
16
17
|
width: "1em",
|
|
17
18
|
className: e,
|
|
18
|
-
children: /* @__PURE__ */
|
|
19
|
+
children: /* @__PURE__ */ n("path", { d: "m6 9 6 6 6-6" })
|
|
19
20
|
});
|
|
20
21
|
}
|
|
21
|
-
var
|
|
22
|
-
function
|
|
23
|
-
return /* @__PURE__ */
|
|
22
|
+
var i = e("inline-flex items-center justify-center shrink-0 rounded-none bg-transparent px-1 min-w-0 w-auto h-auto text-medium cursor-pointer outline-none", t), a = e(i, "!rounded-none !bg-transparent data-[hover=true]:!bg-transparent");
|
|
23
|
+
function o({ isOpen: i, className: a }) {
|
|
24
|
+
return /* @__PURE__ */ n(r, { className: e("shrink-0", t, i && "rotate-180", a) });
|
|
24
25
|
}
|
|
25
26
|
//#endregion
|
|
26
|
-
export {
|
|
27
|
+
export { r as ComboboxCaretIcon, o as ComboboxCaretInline, i as comboboxCaretButtonClassName, a as heroUiAutocompleteSelectorButtonClassName };
|
|
27
28
|
|
|
28
29
|
//# sourceMappingURL=combobox-caret.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"combobox-caret.js","names":[],"sources":["../../src/ui/combobox-caret.tsx"],"sourcesContent":["import { cn } from \"#/utils/utils\";\n\nexport function ComboboxCaretIcon({ className }: { className?: string }) {\n return (\n <svg\n aria-hidden\n fill=\"none\"\n focusable=\"false\"\n height=\"1em\"\n role=\"presentation\"\n stroke=\"currentColor\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={1.5}\n viewBox=\"0 0 24 24\"\n width=\"1em\"\n className={className}\n >\n <path d=\"m6 9 6 6 6-6\" />\n </svg>\n );\n}\n\n/** Matches HeroUI Autocomplete selectorButton styling. */\nexport const comboboxCaretButtonClassName
|
|
1
|
+
{"version":3,"file":"combobox-caret.js","names":[],"sources":["../../src/ui/combobox-caret.tsx"],"sourcesContent":["import { cn } from \"#/utils/utils\";\nimport { formControlTransformTransitionClassName } from \"#/utils/form-control-classes\";\n\nexport function ComboboxCaretIcon({ className }: { className?: string }) {\n return (\n <svg\n aria-hidden\n fill=\"none\"\n focusable=\"false\"\n height=\"1em\"\n role=\"presentation\"\n stroke=\"currentColor\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={1.5}\n viewBox=\"0 0 24 24\"\n width=\"1em\"\n className={className}\n >\n <path d=\"m6 9 6 6 6-6\" />\n </svg>\n );\n}\n\n/** Matches HeroUI Autocomplete selectorButton styling. */\nexport const comboboxCaretButtonClassName = cn(\n \"inline-flex items-center justify-center shrink-0 rounded-none bg-transparent px-1 min-w-0 w-auto h-auto text-medium cursor-pointer outline-none\",\n formControlTransformTransitionClassName,\n);\n\n/** HeroUI Autocomplete selectorButton slot — keep only chevron rotation animated. */\nexport const heroUiAutocompleteSelectorButtonClassName = cn(\n comboboxCaretButtonClassName,\n \"!rounded-none !bg-transparent data-[hover=true]:!bg-transparent\",\n);\n\ninterface ComboboxCaretButtonProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n isOpen?: boolean;\n}\n\nexport function ComboboxCaretButton({\n isOpen,\n className,\n disabled,\n children,\n ...props\n}: ComboboxCaretButtonProps) {\n return (\n <button\n type=\"button\"\n disabled={disabled}\n className={cn(\n comboboxCaretButtonClassName,\n isOpen && \"rotate-180\",\n disabled && \"cursor-not-allowed opacity-60\",\n className,\n )}\n {...props}\n >\n {children ?? <ComboboxCaretIcon />}\n </button>\n );\n}\n\n/** Inline caret for buttons where only the icon rotates, not the whole control. */\nexport function ComboboxCaretInline({\n isOpen,\n className,\n}: {\n isOpen?: boolean;\n className?: string;\n}) {\n return (\n <ComboboxCaretIcon\n className={cn(\n \"shrink-0\",\n formControlTransformTransitionClassName,\n isOpen && \"rotate-180\",\n className,\n )}\n />\n );\n}\n"],"mappings":";;;;AAGA,SAAgB,EAAkB,EAAE,gBAAqC;AACvE,QACE,kBAAC,OAAD;EACE,eAAA;EACA,MAAK;EACL,WAAU;EACV,QAAO;EACP,MAAK;EACL,QAAO;EACP,eAAc;EACd,gBAAe;EACf,aAAa;EACb,SAAQ;EACR,OAAM;EACK;YAEX,kBAAC,QAAD,EAAM,GAAE,gBAAiB,CAAA;EACrB,CAAA;;AAKV,IAAa,IAA+B,EAC1C,mJACA,EACD,EAGY,IAA4C,EACvD,GACA,kEACD;AA+BD,SAAgB,EAAoB,EAClC,WACA,gBAIC;AACD,QACE,kBAAC,GAAD,EACE,WAAW,EACT,YACA,GACA,KAAU,cACV,EACD,EACD,CAAA"}
|
package/dist/ui/context-menu.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
const e=require(`../_virtual/_rolldown/runtime.cjs`),t=require(`../utils/utils.cjs`),n=require(`../node_modules/class-variance-authority/dist/index.cjs`);let
|
|
1
|
+
const e=require(`../_virtual/_rolldown/runtime.cjs`),t=require(`../utils/utils.cjs`),n=require(`../node_modules/class-variance-authority/dist/index.cjs`),r=require(`../utils/dropdown-classes.cjs`);let i=require(`react`);i=e.__toESM(i,1);let a=require(`react/jsx-runtime`);var o=n.cva(`z-50 overflow-hidden text-[var(--oh-foreground)]`,{variants:{theme:{default:`absolute rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 shadow-lg`,naked:`relative`,popover:`relative rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 shadow-lg`},size:{compact:`py-1 px-1`,default:``},layout:{vertical:t.cn(`flex flex-col`,r.dropdownMenuListGapClassName)},position:{top:`bottom-full`,bottom:`top-full`,none:``},spacing:{default:`mt-2`,none:``},alignment:{left:`left-0`,right:`right-0`,none:``}},compoundVariants:[{theme:`naked`,className:`shadow-none`}],defaultVariants:{theme:`default`,size:`default`,layout:`vertical`,spacing:`default`}});function s({testId:e,children:n,className:r,style:i,ref:s,theme:c,size:l,layout:u,position:d,spacing:f,alignment:p}){return(0,a.jsx)(`ul`,{"data-testid":e,"data-position":d,ref:s,style:i,className:t.cn(o({theme:c,size:l,layout:u,position:d,spacing:f,alignment:p}),r),children:n})}exports.ContextMenu=s;
|
|
2
2
|
//# sourceMappingURL=context-menu.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context-menu.cjs","names":[],"sources":["../../src/ui/context-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport { cn } from \"#/utils/utils\";\n\nconst contextMenuVariants = cva(\n \"z-50 overflow-hidden text-[var(--oh-foreground)]\",\n {\n variants: {\n theme: {\n default:\n \"absolute rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 shadow-lg\",\n naked: \"relative\",\n /** In document-body portal; coordinates come from inline `style`. */\n popover:\n \"relative rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 shadow-lg\",\n },\n size: {\n compact: \"py-1 px-1\",\n default: \"\",\n },\n layout: {\n vertical: \"flex flex-col
|
|
1
|
+
{"version":3,"file":"context-menu.cjs","names":[],"sources":["../../src/ui/context-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport { cn } from \"#/utils/utils\";\nimport { dropdownMenuListGapClassName } from \"#/utils/dropdown-classes\";\n\nconst contextMenuVariants = cva(\n \"z-50 overflow-hidden text-[var(--oh-foreground)]\",\n {\n variants: {\n theme: {\n default:\n \"absolute rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 shadow-lg\",\n naked: \"relative\",\n /** In document-body portal; coordinates come from inline `style`. */\n popover:\n \"relative rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 shadow-lg\",\n },\n size: {\n compact: \"py-1 px-1\",\n default: \"\",\n },\n layout: {\n vertical: cn(\"flex flex-col\", dropdownMenuListGapClassName),\n },\n position: {\n top: \"bottom-full\",\n bottom: \"top-full\",\n none: \"\",\n },\n spacing: {\n default: \"mt-2\",\n none: \"\",\n },\n alignment: {\n left: \"left-0\",\n right: \"right-0\",\n none: \"\",\n },\n },\n compoundVariants: [\n {\n theme: \"naked\",\n className: \"shadow-none\",\n },\n ],\n defaultVariants: {\n theme: \"default\",\n size: \"default\",\n layout: \"vertical\",\n spacing: \"default\",\n },\n },\n);\n\ninterface ContextMenuProps {\n ref?: React.RefObject<HTMLUListElement | null>;\n testId?: string;\n children: React.ReactNode;\n className?: React.HTMLAttributes<HTMLUListElement>[\"className\"];\n style?: React.CSSProperties;\n theme?: VariantProps<typeof contextMenuVariants>[\"theme\"];\n size?: VariantProps<typeof contextMenuVariants>[\"size\"];\n layout?: VariantProps<typeof contextMenuVariants>[\"layout\"];\n position?: VariantProps<typeof contextMenuVariants>[\"position\"];\n spacing?: VariantProps<typeof contextMenuVariants>[\"spacing\"];\n alignment?: VariantProps<typeof contextMenuVariants>[\"alignment\"];\n}\n\nexport function ContextMenu({\n testId,\n children,\n className,\n style,\n ref,\n theme,\n size,\n layout,\n position,\n spacing,\n alignment,\n}: ContextMenuProps) {\n return (\n <ul\n data-testid={testId}\n data-position={position}\n ref={ref}\n style={style}\n className={cn(\n contextMenuVariants({\n theme,\n size,\n layout,\n position,\n spacing,\n alignment,\n }),\n className,\n )}\n >\n {children}\n </ul>\n );\n}\n"],"mappings":"gRAKA,IAAM,EAAsB,EAAA,IAC1B,mDACA,CACE,SAAU,CACR,MAAO,CACL,QACE,8FACF,MAAO,WAEP,QACE,8FACH,CACD,KAAM,CACJ,QAAS,YACT,QAAS,GACV,CACD,OAAQ,CACN,SAAU,EAAA,GAAG,gBAAiB,EAAA,6BAA6B,CAC5D,CACD,SAAU,CACR,IAAK,cACL,OAAQ,WACR,KAAM,GACP,CACD,QAAS,CACP,QAAS,OACT,KAAM,GACP,CACD,UAAW,CACT,KAAM,SACN,MAAO,UACP,KAAM,GACP,CACF,CACD,iBAAkB,CAChB,CACE,MAAO,QACP,UAAW,cACZ,CACF,CACD,gBAAiB,CACf,MAAO,UACP,KAAM,UACN,OAAQ,WACR,QAAS,UACV,CACF,CACF,CAgBD,SAAgB,EAAY,CAC1B,SACA,WACA,YACA,QACA,MACA,QACA,OACA,SACA,WACA,UACA,aACmB,CACnB,OACE,EAAA,EAAA,KAAC,KAAD,CACE,cAAa,EACb,gBAAe,EACV,MACE,QACP,UAAW,EAAA,GACT,EAAoB,CAClB,QACA,OACA,SACA,WACA,UACA,YACD,CAAC,CACF,EACD,CAEA,WACE,CAAA"}
|
package/dist/ui/context-menu.js
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { cn as e } from "../utils/utils.js";
|
|
2
2
|
import { cva as t } from "../node_modules/class-variance-authority/dist/index.js";
|
|
3
|
+
import { dropdownMenuListGapClassName as n } from "../utils/dropdown-classes.js";
|
|
3
4
|
import "react";
|
|
4
|
-
import { jsx as
|
|
5
|
+
import { jsx as r } from "react/jsx-runtime";
|
|
5
6
|
//#region src/ui/context-menu.tsx
|
|
6
|
-
var
|
|
7
|
+
var i = t("z-50 overflow-hidden text-[var(--oh-foreground)]", {
|
|
7
8
|
variants: {
|
|
8
9
|
theme: {
|
|
9
10
|
default: "absolute rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 shadow-lg",
|
|
@@ -14,7 +15,7 @@ var r = t("z-50 overflow-hidden text-[var(--oh-foreground)]", {
|
|
|
14
15
|
compact: "py-1 px-1",
|
|
15
16
|
default: ""
|
|
16
17
|
},
|
|
17
|
-
layout: { vertical: "flex flex-col
|
|
18
|
+
layout: { vertical: e("flex flex-col", n) },
|
|
18
19
|
position: {
|
|
19
20
|
top: "bottom-full",
|
|
20
21
|
bottom: "top-full",
|
|
@@ -41,13 +42,13 @@ var r = t("z-50 overflow-hidden text-[var(--oh-foreground)]", {
|
|
|
41
42
|
spacing: "default"
|
|
42
43
|
}
|
|
43
44
|
});
|
|
44
|
-
function
|
|
45
|
-
return /* @__PURE__ */
|
|
45
|
+
function a({ testId: t, children: n, className: a, style: o, ref: s, theme: c, size: l, layout: u, position: d, spacing: f, alignment: p }) {
|
|
46
|
+
return /* @__PURE__ */ r("ul", {
|
|
46
47
|
"data-testid": t,
|
|
47
48
|
"data-position": d,
|
|
48
49
|
ref: s,
|
|
49
50
|
style: o,
|
|
50
|
-
className: e(
|
|
51
|
+
className: e(i({
|
|
51
52
|
theme: c,
|
|
52
53
|
size: l,
|
|
53
54
|
layout: u,
|
|
@@ -55,10 +56,10 @@ function i({ testId: t, children: i, className: a, style: o, ref: s, theme: c, s
|
|
|
55
56
|
spacing: f,
|
|
56
57
|
alignment: p
|
|
57
58
|
}), a),
|
|
58
|
-
children:
|
|
59
|
+
children: n
|
|
59
60
|
});
|
|
60
61
|
}
|
|
61
62
|
//#endregion
|
|
62
|
-
export {
|
|
63
|
+
export { a as ContextMenu };
|
|
63
64
|
|
|
64
65
|
//# sourceMappingURL=context-menu.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context-menu.js","names":[],"sources":["../../src/ui/context-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport { cn } from \"#/utils/utils\";\n\nconst contextMenuVariants = cva(\n \"z-50 overflow-hidden text-[var(--oh-foreground)]\",\n {\n variants: {\n theme: {\n default:\n \"absolute rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 shadow-lg\",\n naked: \"relative\",\n /** In document-body portal; coordinates come from inline `style`. */\n popover:\n \"relative rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 shadow-lg\",\n },\n size: {\n compact: \"py-1 px-1\",\n default: \"\",\n },\n layout: {\n vertical: \"flex flex-col
|
|
1
|
+
{"version":3,"file":"context-menu.js","names":[],"sources":["../../src/ui/context-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport { cn } from \"#/utils/utils\";\nimport { dropdownMenuListGapClassName } from \"#/utils/dropdown-classes\";\n\nconst contextMenuVariants = cva(\n \"z-50 overflow-hidden text-[var(--oh-foreground)]\",\n {\n variants: {\n theme: {\n default:\n \"absolute rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 shadow-lg\",\n naked: \"relative\",\n /** In document-body portal; coordinates come from inline `style`. */\n popover:\n \"relative rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 shadow-lg\",\n },\n size: {\n compact: \"py-1 px-1\",\n default: \"\",\n },\n layout: {\n vertical: cn(\"flex flex-col\", dropdownMenuListGapClassName),\n },\n position: {\n top: \"bottom-full\",\n bottom: \"top-full\",\n none: \"\",\n },\n spacing: {\n default: \"mt-2\",\n none: \"\",\n },\n alignment: {\n left: \"left-0\",\n right: \"right-0\",\n none: \"\",\n },\n },\n compoundVariants: [\n {\n theme: \"naked\",\n className: \"shadow-none\",\n },\n ],\n defaultVariants: {\n theme: \"default\",\n size: \"default\",\n layout: \"vertical\",\n spacing: \"default\",\n },\n },\n);\n\ninterface ContextMenuProps {\n ref?: React.RefObject<HTMLUListElement | null>;\n testId?: string;\n children: React.ReactNode;\n className?: React.HTMLAttributes<HTMLUListElement>[\"className\"];\n style?: React.CSSProperties;\n theme?: VariantProps<typeof contextMenuVariants>[\"theme\"];\n size?: VariantProps<typeof contextMenuVariants>[\"size\"];\n layout?: VariantProps<typeof contextMenuVariants>[\"layout\"];\n position?: VariantProps<typeof contextMenuVariants>[\"position\"];\n spacing?: VariantProps<typeof contextMenuVariants>[\"spacing\"];\n alignment?: VariantProps<typeof contextMenuVariants>[\"alignment\"];\n}\n\nexport function ContextMenu({\n testId,\n children,\n className,\n style,\n ref,\n theme,\n size,\n layout,\n position,\n spacing,\n alignment,\n}: ContextMenuProps) {\n return (\n <ul\n data-testid={testId}\n data-position={position}\n ref={ref}\n style={style}\n className={cn(\n contextMenuVariants({\n theme,\n size,\n layout,\n position,\n spacing,\n alignment,\n }),\n className,\n )}\n >\n {children}\n </ul>\n );\n}\n"],"mappings":";;;;;;AAKA,IAAM,IAAsB,EAC1B,oDACA;CACE,UAAU;EACR,OAAO;GACL,SACE;GACF,OAAO;GAEP,SACE;GACH;EACD,MAAM;GACJ,SAAS;GACT,SAAS;GACV;EACD,QAAQ,EACN,UAAU,EAAG,iBAAiB,EAA6B,EAC5D;EACD,UAAU;GACR,KAAK;GACL,QAAQ;GACR,MAAM;GACP;EACD,SAAS;GACP,SAAS;GACT,MAAM;GACP;EACD,WAAW;GACT,MAAM;GACN,OAAO;GACP,MAAM;GACP;EACF;CACD,kBAAkB,CAChB;EACE,OAAO;EACP,WAAW;EACZ,CACF;CACD,iBAAiB;EACf,OAAO;EACP,MAAM;EACN,QAAQ;EACR,SAAS;EACV;CACF,CACF;AAgBD,SAAgB,EAAY,EAC1B,WACA,aACA,cACA,UACA,QACA,UACA,SACA,WACA,aACA,YACA,gBACmB;AACnB,QACE,kBAAC,MAAD;EACE,eAAa;EACb,iBAAe;EACV;EACE;EACP,WAAW,EACT,EAAoB;GAClB;GACA;GACA;GACA;GACA;GACA;GACD,CAAC,EACF,EACD;EAEA;EACE,CAAA"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
const e=require(`../../_virtual/_rolldown/runtime.cjs`),t=require(`../../utils/utils.cjs`),n=require(`../divider.cjs`);let
|
|
1
|
+
const e=require(`../../_virtual/_rolldown/runtime.cjs`),t=require(`../../utils/utils.cjs`),n=require(`../../utils/dropdown-classes.cjs`),r=require(`../divider.cjs`);let i=require(`react`);i=e.__toESM(i,1);let a=require(`react/jsx-runtime`);function o({isOpen:e,filteredOptions:i,selectedItem:o,emptyMessage:s,getMenuProps:c,getItemProps:l,footer:u,openUpward:d=!1,fitContent:f=!1}){return(0,a.jsxs)(`div`,{className:t.cn(`absolute z-50 overflow-hidden text-white`,f?`min-w-full w-max`:`w-full`,d?`bottom-full mb-1`:`mt-1`,`bg-tertiary rounded-[6px] context-menu-box-shadow p-1`,`max-h-60 overflow-auto`,!e&&`hidden`),children:[(0,a.jsxs)(`ul`,{...c({className:t.cn(`p-0`,n.dropdownMenuListClassName)}),children:[e&&i.length===0&&(0,a.jsx)(`li`,{className:`px-2 py-2 text-sm text-[var(--oh-muted)] italic`,children:s}),e&&i.map((e,r)=>(0,a.jsxs)(`li`,{...l({item:e,index:r,className:t.cn(n.dropdownMenuRowClassName,`focus:outline-none`,o?.value===e.value&&`bg-[var(--oh-interactive-selected)] text-white`)}),children:[e.prefix?(0,a.jsx)(`span`,{className:n.dropdownMenuRowIconWrapperClassName,children:e.prefix}):null,(0,a.jsx)(`span`,{className:`min-w-0 truncate`,children:e.label})]},e.value))]}),e&&u?(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(r.Divider,{inset:`menu`}),(0,a.jsx)(`div`,{className:`p-0`,children:u})]}):null]})}exports.DropdownMenu=o;
|
|
2
2
|
//# sourceMappingURL=dropdown-menu.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dropdown-menu.cjs","names":[],"sources":["../../../src/ui/dropdown/dropdown-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { Divider } from \"#/ui/divider\";\nimport { cn } from \"#/utils/utils\";\nimport { DropdownOption } from \"./types\";\n\ninterface DropdownMenuProps {\n isOpen: boolean;\n filteredOptions: DropdownOption[];\n selectedItem: DropdownOption | null;\n emptyMessage: string;\n getMenuProps: (props?: object) => object;\n getItemProps: (props: {\n item: DropdownOption;\n index: number;\n className?: string;\n }) => object;\n footer?: React.ReactNode;\n openUpward?: boolean;\n fitContent?: boolean;\n}\n\nexport function DropdownMenu({\n isOpen,\n filteredOptions,\n selectedItem,\n emptyMessage,\n getMenuProps,\n getItemProps,\n footer,\n openUpward = false,\n fitContent = false,\n}: DropdownMenuProps) {\n return (\n <div\n className={cn(\n \"absolute z-50 overflow-hidden text-white\",\n fitContent ? \"min-w-full w-max\" : \"w-full\",\n openUpward ? \"bottom-full mb-1\" : \"mt-1\",\n \"bg-tertiary rounded-[6px] context-menu-box-shadow p-1\",\n \"max-h-60 overflow-auto\",\n !isOpen && \"hidden\",\n )}\n >\n <ul
|
|
1
|
+
{"version":3,"file":"dropdown-menu.cjs","names":[],"sources":["../../../src/ui/dropdown/dropdown-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { Divider } from \"#/ui/divider\";\nimport { cn } from \"#/utils/utils\";\nimport { DropdownOption } from \"./types\";\nimport {\n dropdownMenuListClassName,\n dropdownMenuRowClassName,\n dropdownMenuRowIconWrapperClassName,\n} from \"#/utils/dropdown-classes\";\n\ninterface DropdownMenuProps {\n isOpen: boolean;\n filteredOptions: DropdownOption[];\n selectedItem: DropdownOption | null;\n emptyMessage: string;\n getMenuProps: (props?: object) => object;\n getItemProps: (props: {\n item: DropdownOption;\n index: number;\n className?: string;\n }) => object;\n footer?: React.ReactNode;\n openUpward?: boolean;\n fitContent?: boolean;\n}\n\nexport function DropdownMenu({\n isOpen,\n filteredOptions,\n selectedItem,\n emptyMessage,\n getMenuProps,\n getItemProps,\n footer,\n openUpward = false,\n fitContent = false,\n}: DropdownMenuProps) {\n return (\n <div\n className={cn(\n \"absolute z-50 overflow-hidden text-white\",\n fitContent ? \"min-w-full w-max\" : \"w-full\",\n openUpward ? \"bottom-full mb-1\" : \"mt-1\",\n \"bg-tertiary rounded-[6px] context-menu-box-shadow p-1\",\n \"max-h-60 overflow-auto\",\n !isOpen && \"hidden\",\n )}\n >\n <ul\n {...getMenuProps({ className: cn(\"p-0\", dropdownMenuListClassName) })}\n >\n {isOpen && filteredOptions.length === 0 && (\n <li className=\"px-2 py-2 text-sm text-[var(--oh-muted)] italic\">\n {emptyMessage}\n </li>\n )}\n {isOpen &&\n filteredOptions.map((option, index) => (\n <li\n key={option.value}\n {...getItemProps({\n item: option,\n index,\n className: cn(\n dropdownMenuRowClassName,\n \"focus:outline-none\",\n selectedItem?.value === option.value &&\n \"bg-[var(--oh-interactive-selected)] text-white\",\n ),\n })}\n >\n {option.prefix ? (\n <span className={dropdownMenuRowIconWrapperClassName}>\n {option.prefix}\n </span>\n ) : null}\n <span className=\"min-w-0 truncate\">{option.label}</span>\n </li>\n ))}\n </ul>\n {isOpen && footer ? (\n <>\n <Divider inset=\"menu\" />\n <div className=\"p-0\">{footer}</div>\n </>\n ) : null}\n </div>\n );\n}\n"],"mappings":"gPA0BA,SAAgB,EAAa,CAC3B,SACA,kBACA,eACA,eACA,eACA,eACA,SACA,aAAa,GACb,aAAa,IACO,CACpB,OACE,EAAA,EAAA,MAAC,MAAD,CACE,UAAW,EAAA,GACT,2CACA,EAAa,mBAAqB,SAClC,EAAa,mBAAqB,OAClC,wDACA,yBACA,CAAC,GAAU,SACZ,UARH,EAUE,EAAA,EAAA,MAAC,KAAD,CACE,GAAI,EAAa,CAAE,UAAW,EAAA,GAAG,MAAO,EAAA,0BAA0B,CAAE,CAAC,UADvE,CAGG,GAAU,EAAgB,SAAW,IACpC,EAAA,EAAA,KAAC,KAAD,CAAI,UAAU,2DACX,EACE,CAAA,CAEN,GACC,EAAgB,KAAK,EAAQ,KAC3B,EAAA,EAAA,MAAC,KAAD,CAEE,GAAI,EAAa,CACf,KAAM,EACN,QACA,UAAW,EAAA,GACT,EAAA,yBACA,qBACA,GAAc,QAAU,EAAO,OAC7B,iDACH,CACF,CAAC,UAXJ,CAaG,EAAO,QACN,EAAA,EAAA,KAAC,OAAD,CAAM,UAAW,EAAA,6CACd,EAAO,OACH,CAAA,CACL,MACJ,EAAA,EAAA,KAAC,OAAD,CAAM,UAAU,4BAAoB,EAAO,MAAa,CAAA,CACrD,EAlBE,EAAO,MAkBT,CACL,CACD,GACJ,GAAU,GACT,EAAA,EAAA,MAAA,EAAA,SAAA,CAAA,SAAA,EACE,EAAA,EAAA,KAAC,EAAA,QAAD,CAAS,MAAM,OAAS,CAAA,EACxB,EAAA,EAAA,KAAC,MAAD,CAAK,UAAU,eAAO,EAAa,CAAA,CAClC,CAAA,CAAA,CACD,KACA"}
|
|
@@ -1,34 +1,38 @@
|
|
|
1
1
|
import { cn as e } from "../../utils/utils.js";
|
|
2
|
-
import {
|
|
2
|
+
import { dropdownMenuListClassName as t, dropdownMenuRowClassName as n, dropdownMenuRowIconWrapperClassName as r } from "../../utils/dropdown-classes.js";
|
|
3
|
+
import { Divider as i } from "../divider.js";
|
|
3
4
|
import "react";
|
|
4
|
-
import { Fragment as
|
|
5
|
+
import { Fragment as a, jsx as o, jsxs as s } from "react/jsx-runtime";
|
|
5
6
|
//#region src/ui/dropdown/dropdown-menu.tsx
|
|
6
|
-
function
|
|
7
|
-
return /* @__PURE__ */
|
|
8
|
-
className: e("absolute z-50 overflow-hidden text-white",
|
|
9
|
-
children: [/* @__PURE__ */
|
|
10
|
-
...
|
|
11
|
-
children: [
|
|
7
|
+
function c({ isOpen: c, filteredOptions: l, selectedItem: u, emptyMessage: d, getMenuProps: f, getItemProps: p, footer: m, openUpward: h = !1, fitContent: g = !1 }) {
|
|
8
|
+
return /* @__PURE__ */ s("div", {
|
|
9
|
+
className: e("absolute z-50 overflow-hidden text-white", g ? "min-w-full w-max" : "w-full", h ? "bottom-full mb-1" : "mt-1", "bg-tertiary rounded-[6px] context-menu-box-shadow p-1", "max-h-60 overflow-auto", !c && "hidden"),
|
|
10
|
+
children: [/* @__PURE__ */ s("ul", {
|
|
11
|
+
...f({ className: e("p-0", t) }),
|
|
12
|
+
children: [c && l.length === 0 && /* @__PURE__ */ o("li", {
|
|
12
13
|
className: "px-2 py-2 text-sm text-[var(--oh-muted)] italic",
|
|
13
|
-
children:
|
|
14
|
-
}),
|
|
15
|
-
...
|
|
14
|
+
children: d
|
|
15
|
+
}), c && l.map((t, i) => /* @__PURE__ */ s("li", {
|
|
16
|
+
...p({
|
|
16
17
|
item: t,
|
|
17
|
-
index:
|
|
18
|
-
className: e(
|
|
18
|
+
index: i,
|
|
19
|
+
className: e(n, "focus:outline-none", u?.value === t.value && "bg-[var(--oh-interactive-selected)] text-white")
|
|
19
20
|
}),
|
|
20
|
-
children: [t.prefix
|
|
21
|
+
children: [t.prefix ? /* @__PURE__ */ o("span", {
|
|
22
|
+
className: r,
|
|
23
|
+
children: t.prefix
|
|
24
|
+
}) : null, /* @__PURE__ */ o("span", {
|
|
21
25
|
className: "min-w-0 truncate",
|
|
22
26
|
children: t.label
|
|
23
27
|
})]
|
|
24
28
|
}, t.value))]
|
|
25
|
-
}),
|
|
29
|
+
}), c && m ? /* @__PURE__ */ s(a, { children: [/* @__PURE__ */ o(i, { inset: "menu" }), /* @__PURE__ */ o("div", {
|
|
26
30
|
className: "p-0",
|
|
27
|
-
children:
|
|
31
|
+
children: m
|
|
28
32
|
})] }) : null]
|
|
29
33
|
});
|
|
30
34
|
}
|
|
31
35
|
//#endregion
|
|
32
|
-
export {
|
|
36
|
+
export { c as DropdownMenu };
|
|
33
37
|
|
|
34
38
|
//# sourceMappingURL=dropdown-menu.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dropdown-menu.js","names":[],"sources":["../../../src/ui/dropdown/dropdown-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { Divider } from \"#/ui/divider\";\nimport { cn } from \"#/utils/utils\";\nimport { DropdownOption } from \"./types\";\n\ninterface DropdownMenuProps {\n isOpen: boolean;\n filteredOptions: DropdownOption[];\n selectedItem: DropdownOption | null;\n emptyMessage: string;\n getMenuProps: (props?: object) => object;\n getItemProps: (props: {\n item: DropdownOption;\n index: number;\n className?: string;\n }) => object;\n footer?: React.ReactNode;\n openUpward?: boolean;\n fitContent?: boolean;\n}\n\nexport function DropdownMenu({\n isOpen,\n filteredOptions,\n selectedItem,\n emptyMessage,\n getMenuProps,\n getItemProps,\n footer,\n openUpward = false,\n fitContent = false,\n}: DropdownMenuProps) {\n return (\n <div\n className={cn(\n \"absolute z-50 overflow-hidden text-white\",\n fitContent ? \"min-w-full w-max\" : \"w-full\",\n openUpward ? \"bottom-full mb-1\" : \"mt-1\",\n \"bg-tertiary rounded-[6px] context-menu-box-shadow p-1\",\n \"max-h-60 overflow-auto\",\n !isOpen && \"hidden\",\n )}\n >\n <ul
|
|
1
|
+
{"version":3,"file":"dropdown-menu.js","names":[],"sources":["../../../src/ui/dropdown/dropdown-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { Divider } from \"#/ui/divider\";\nimport { cn } from \"#/utils/utils\";\nimport { DropdownOption } from \"./types\";\nimport {\n dropdownMenuListClassName,\n dropdownMenuRowClassName,\n dropdownMenuRowIconWrapperClassName,\n} from \"#/utils/dropdown-classes\";\n\ninterface DropdownMenuProps {\n isOpen: boolean;\n filteredOptions: DropdownOption[];\n selectedItem: DropdownOption | null;\n emptyMessage: string;\n getMenuProps: (props?: object) => object;\n getItemProps: (props: {\n item: DropdownOption;\n index: number;\n className?: string;\n }) => object;\n footer?: React.ReactNode;\n openUpward?: boolean;\n fitContent?: boolean;\n}\n\nexport function DropdownMenu({\n isOpen,\n filteredOptions,\n selectedItem,\n emptyMessage,\n getMenuProps,\n getItemProps,\n footer,\n openUpward = false,\n fitContent = false,\n}: DropdownMenuProps) {\n return (\n <div\n className={cn(\n \"absolute z-50 overflow-hidden text-white\",\n fitContent ? \"min-w-full w-max\" : \"w-full\",\n openUpward ? \"bottom-full mb-1\" : \"mt-1\",\n \"bg-tertiary rounded-[6px] context-menu-box-shadow p-1\",\n \"max-h-60 overflow-auto\",\n !isOpen && \"hidden\",\n )}\n >\n <ul\n {...getMenuProps({ className: cn(\"p-0\", dropdownMenuListClassName) })}\n >\n {isOpen && filteredOptions.length === 0 && (\n <li className=\"px-2 py-2 text-sm text-[var(--oh-muted)] italic\">\n {emptyMessage}\n </li>\n )}\n {isOpen &&\n filteredOptions.map((option, index) => (\n <li\n key={option.value}\n {...getItemProps({\n item: option,\n index,\n className: cn(\n dropdownMenuRowClassName,\n \"focus:outline-none\",\n selectedItem?.value === option.value &&\n \"bg-[var(--oh-interactive-selected)] text-white\",\n ),\n })}\n >\n {option.prefix ? (\n <span className={dropdownMenuRowIconWrapperClassName}>\n {option.prefix}\n </span>\n ) : null}\n <span className=\"min-w-0 truncate\">{option.label}</span>\n </li>\n ))}\n </ul>\n {isOpen && footer ? (\n <>\n <Divider inset=\"menu\" />\n <div className=\"p-0\">{footer}</div>\n </>\n ) : null}\n </div>\n );\n}\n"],"mappings":";;;;;;AA0BA,SAAgB,EAAa,EAC3B,WACA,oBACA,iBACA,iBACA,iBACA,iBACA,WACA,gBAAa,IACb,gBAAa,MACO;AACpB,QACE,kBAAC,OAAD;EACE,WAAW,EACT,4CACA,IAAa,qBAAqB,UAClC,IAAa,qBAAqB,QAClC,yDACA,0BACA,CAAC,KAAU,SACZ;YARH,CAUE,kBAAC,MAAD;GACE,GAAI,EAAa,EAAE,WAAW,EAAG,OAAO,EAA0B,EAAE,CAAC;aADvE,CAGG,KAAU,EAAgB,WAAW,KACpC,kBAAC,MAAD;IAAI,WAAU;cACX;IACE,CAAA,EAEN,KACC,EAAgB,KAAK,GAAQ,MAC3B,kBAAC,MAAD;IAEE,GAAI,EAAa;KACf,MAAM;KACN;KACA,WAAW,EACT,GACA,sBACA,GAAc,UAAU,EAAO,SAC7B,iDACH;KACF,CAAC;cAXJ,CAaG,EAAO,SACN,kBAAC,QAAD;KAAM,WAAW;eACd,EAAO;KACH,CAAA,GACL,MACJ,kBAAC,QAAD;KAAM,WAAU;eAAoB,EAAO;KAAa,CAAA,CACrD;MAlBE,EAAO,MAkBT,CACL,CACD;MACJ,KAAU,IACT,kBAAA,GAAA,EAAA,UAAA,CACE,kBAAC,GAAD,EAAS,OAAM,QAAS,CAAA,EACxB,kBAAC,OAAD;GAAK,WAAU;aAAO;GAAa,CAAA,CAClC,EAAA,CAAA,GACD,KACA"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
const e=require(`../../_virtual/_rolldown/runtime.cjs`),t=require(`../../utils/utils.cjs`),n=require(`../../utils/
|
|
1
|
+
const e=require(`../../_virtual/_rolldown/runtime.cjs`),t=require(`../../utils/utils.cjs`),n=require(`../../utils/dropdown-classes.cjs`),r=require(`../../node_modules/downshift/dist/downshift.esm.cjs`),i=require(`./loading-spinner.cjs`),a=require(`./clear-button.cjs`),o=require(`./toggle-button.cjs`),s=require(`./dropdown-menu.cjs`),c=require(`./dropdown-input.cjs`);let l=require(`react`);l=e.__toESM(l,1);let u=require(`react/jsx-runtime`);var d={position:`absolute`,width:1,height:1,padding:0,margin:-1,overflow:`hidden`,clip:`rect(0, 0, 0, 0)`,whiteSpace:`nowrap`,border:0};function f({options:e,emptyMessage:f=`No options`,clearable:p=!1,loading:m=!1,disabled:h=!1,placeholder:g,defaultValue:_,onChange:v,testId:y,className:b,footer:x,openUpward:S=!1,hideTrigger:C=!1,defaultOpen:w=!1,openOnHover:T=!1,italicPlaceholder:E=!0,fitContent:D=!1}){let O=l.default.useRef(null),[k,A]=(0,l.useState)(_?.label??``),[j,M]=(0,l.useState)(``),N=e.filter(e=>e.label.toLowerCase().includes(j.toLowerCase())),{isOpen:P,selectedItem:F,selectItem:I,openMenu:L,closeMenu:R,getToggleButtonProps:z,getMenuProps:B,getItemProps:V,getInputProps:H}=r.useCombobox({items:N,itemToString:e=>e?.label??``,inputValue:k,stateReducer:(e,t)=>t.type===r.useCombobox.stateChangeTypes.InputClick&&e.isOpen?{...t.changes,isOpen:!0}:t.changes,initialIsOpen:w,onInputValueChange:({inputValue:e})=>{A(e??``),M(e??``)},defaultSelectedItem:_,onSelectedItemChange:({selectedItem:e})=>{v?.(e??null)},onIsOpenChange:({isOpen:e,selectedItem:t})=>{e?(A(``),M(``)):(A(t?.label??``),M(``))}}),U=m||h,W=F?e.find(e=>e.value===F.value)??F:null,G=e=>H({...e,onChange:e=>{A(e.target.value),M(e.target.value)}});return(0,u.jsxs)(`div`,{className:t.cn(`relative`,D?`inline-block w-auto`:`w-full`),"data-testid":y,onMouseEnter:T?()=>{O.current&&=(clearTimeout(O.current),null),L()}:void 0,onMouseLeave:T?()=>{O.current=setTimeout(()=>R(),150)}:void 0,children:[C?(0,u.jsxs)(u.Fragment,{children:[(0,u.jsx)(`input`,{...G({"aria-label":g??`Filter options`,tabIndex:-1}),style:d}),(0,u.jsx)(`button`,{type:`button`,...z({tabIndex:-1}),style:d,"aria-hidden":!0})]}):(0,u.jsxs)(`div`,{className:t.cn(n.dropdownTriggerShellClassName,D?`w-auto`:`w-full`,U&&`cursor-not-allowed opacity-60`,b),children:[W?.prefix?(0,u.jsx)(`span`,{className:`flex items-center shrink-0`,children:W.prefix}):null,(0,u.jsx)(c.DropdownInput,{placeholder:g,isDisabled:U,getInputProps:G,italicPlaceholder:E,fitContent:D}),m&&(0,u.jsx)(i.LoadingSpinner,{}),p&&F&&(0,u.jsx)(a.ClearButton,{onClear:()=>I(null)}),(0,u.jsx)(o.ToggleButton,{isOpen:P,isDisabled:U,getToggleButtonProps:z})]}),(0,u.jsx)(s.DropdownMenu,{isOpen:P,filteredOptions:N,selectedItem:F,emptyMessage:f,getMenuProps:B,getItemProps:V,footer:x,openUpward:S,fitContent:D})]})}exports.Dropdown=f;
|
|
2
2
|
//# sourceMappingURL=dropdown.cjs.map
|