@openhands/agent-canvas 1.0.0-beta.6 → 1.0.0-beta.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (802) hide show
  1. package/README.md +24 -7
  2. package/README.windows.md +27 -0
  3. package/bin/agent-canvas.mjs +26 -3
  4. package/build/assets/{QueryClientProvider-CkGuhXg-.js → QueryClientProvider-Cnr-Yl3j.js} +1 -1
  5. package/build/assets/{Trans-Cvm_-SMi.js → Trans-4jmk54WC.js} +1 -1
  6. package/build/assets/acp-providers-BAX8OU5C.js +1 -0
  7. package/build/assets/{acp-route-guard-B2yoBZ_4.js → acp-route-guard-HPk6TV-L.js} +1 -1
  8. package/build/assets/active-backend-context-BSPE-W72.js +1 -0
  9. package/build/assets/add-backend-modal-mXKmfMI2.js +1 -0
  10. package/build/assets/agent-server-client-options-9agOSarV.js +1 -0
  11. package/build/assets/agent-server-compatibility-B7QStIcH.js +1 -0
  12. package/build/assets/agent-server-conversation-service.api-B9TUYJon.js +5 -0
  13. package/build/assets/{agent-settings-CnGSCmK8.js → agent-settings-g3F623RJ.js} +1 -1
  14. package/build/assets/{alert-banner-DtzAX654.js → alert-banner-DFnn_lC6.js} +1 -1
  15. package/build/assets/{analytics-consent-form-modal-CHZ3I37v.js → analytics-consent-form-modal-BQCNeNVt.js} +1 -1
  16. package/build/assets/api-key-entry-screen-myuWMqzW.js +1 -0
  17. package/build/assets/{app-settings-Db9ITeJH.js → app-settings-CCcX8ZEH.js} +1 -1
  18. package/build/assets/automation-detail-BDHLHSJd.js +1 -0
  19. package/build/assets/automations-list-CiNtQhq_.js +1 -0
  20. package/build/assets/back-nav-button-7dQJ2k3O.js +1 -0
  21. package/build/assets/backend-form-modal-D3bDMO3C.js +1 -0
  22. package/build/assets/{backend-synced-settings-badge-Dc6c7GT4.js → backend-synced-settings-badge-BkW5evM0.js} +1 -1
  23. package/build/assets/base-modal-C2oy2EBG.js +1 -0
  24. package/build/assets/brand-button-DJ_S16rO.js +1 -0
  25. package/build/assets/{browser-D810xUYt.js → browser-CGM-k-sH.js} +2 -2
  26. package/build/assets/browser-store-DAsixKdU.js +1 -0
  27. package/build/assets/{browser-tab-B-aIqXRl.js → browser-tab-dvSPdvkm.js} +1 -1
  28. package/build/assets/{checkmark-DL7acQA7.js → checkmark-Dus0b6jt.js} +1 -1
  29. package/build/assets/{chevron-left-small-CVWf8TI6.js → chevron-left-small-_uvG7RVM.js} +1 -1
  30. package/build/assets/{circle-plus-check-toggle-P7ZZToV4.js → circle-plus-check-toggle-DKS8MAVV.js} +1 -1
  31. package/build/assets/{close-B5LROHR3.js → close-BU5iTc66.js} +1 -1
  32. package/build/assets/code-tag-BzyqOtPD.js +1 -0
  33. package/build/assets/combobox-caret-BJC7XJsz.js +1 -0
  34. package/build/assets/{command-store-DFN_17p1.js → command-store-CE1weJy8.js} +1 -1
  35. package/build/assets/{condenser-settings-wnEKhBof.js → condenser-settings-DCTulgLO.js} +1 -1
  36. package/build/assets/{confirmation-modal-Dau3w_sa.js → confirmation-modal-B5Ca6qFE.js} +1 -1
  37. package/build/assets/context-menu-list-item-7tAcm2c3.js +1 -0
  38. package/build/assets/conversation-BKhikfYl.js +1 -0
  39. package/build/assets/conversation-DTn8jN8L.js +19 -0
  40. package/build/assets/conversation-panel-DfHR42mG.js +1 -0
  41. package/build/assets/conversation-service.api-B6CkzaKD.js +1 -0
  42. package/build/assets/conversation-state-store-D-w0uurj.js +1 -0
  43. package/build/assets/conversation-store-CC-isCnP.js +1 -0
  44. package/build/assets/{conversation-tab-empty-state-DyssnnWa.js → conversation-tab-empty-state-CStQLPVW.js} +1 -1
  45. package/build/assets/conversation-websocket-context-DShEuLjh.js +3 -0
  46. package/build/assets/{copy-DYgmUdIw.js → copy-Chg-sFu3.js} +1 -1
  47. package/build/assets/{custom-toast-handlers-C-SZFmto.js → custom-toast-handlers-ufGJ6_Rc.js} +1 -1
  48. package/build/assets/declaration-CR6HMp29.js +1 -0
  49. package/build/assets/{device-verify-DqDlphsG.js → device-verify-C6mj28zv.js} +1 -1
  50. package/build/assets/dist-DNeWJ2bh.js +1 -0
  51. package/build/assets/dropdown-classes-BsVmxlNG.js +1 -0
  52. package/build/assets/edit-automation-modal-DamwL0s0.js +1 -0
  53. package/build/assets/ellipsis-button-Vh5MvRZa.js +1 -0
  54. package/build/assets/entry.client-Cn71WM8q.js +2 -0
  55. package/build/assets/enum-filter-dropdown-5JeF2RLb.js +1 -0
  56. package/build/assets/{environment-switch-overlay-XL8yCGP6.js → environment-switch-overlay-Tf_BIfeR.js} +1 -1
  57. package/build/assets/extensions-hub-CUEmfvGy.js +1 -0
  58. package/build/assets/{extensions-navigation-BYR8Giqq.js → extensions-navigation-VQ-3umJ7.js} +1 -1
  59. package/build/assets/file-BTY6Gyy9.js +1 -0
  60. package/build/assets/files-tab-C47fQEeL.js +1 -0
  61. package/build/assets/files-tab-store-m0ARqX_E.js +1 -0
  62. package/build/assets/{folder-ZZJVGgd7.js → folder-D1T2W1cj.js} +1 -1
  63. package/build/assets/git-control-bar-branch-button-BT0aWH-o.js +27 -0
  64. package/build/assets/git-provider-icon-Pi-Cxpgv.js +1 -0
  65. package/build/assets/globe-Bzj_0oXT.js +1 -0
  66. package/build/assets/home-C3k6sFvB.js +1 -0
  67. package/build/assets/{i18n-CTohRuoO.js → i18n-DET2iOyh.js} +1 -1
  68. package/build/assets/install-server-modal-6fuq-TU6.js +1 -0
  69. package/build/assets/launch-DGghLfGx.js +1 -0
  70. package/build/assets/{lesson-plan-dH5Bj0pN.js → lesson-plan-duSsqWVs.js} +1 -1
  71. package/build/assets/link-external-DGxVm4Ps.js +1 -0
  72. package/build/assets/{llm-client-DaH1TuyR.js → llm-client-BqyLKgUN.js} +1 -1
  73. package/build/assets/llm-settings-BKraGtOu.js +1 -0
  74. package/build/assets/llm-settings-DRQTgOF1.js +1 -0
  75. package/build/assets/{loading-spinner-BPtYORNK.js → loading-spinner-5GT9q1xy.js} +1 -1
  76. package/build/assets/manage-backends-modal-CRMwyU0t.js +1 -0
  77. package/build/assets/manage-workspaces-modal-BYmGD1W7.js +1 -0
  78. package/build/assets/manifest-99b06a11.js +1 -0
  79. package/build/assets/{markdown-renderer-DMzf2i4x.js → markdown-renderer-B3IAVfv4.js} +1 -1
  80. package/build/assets/mcp-CfDRAmPn.js +9 -0
  81. package/build/assets/messages-Ba1vaw6t.js +36 -0
  82. package/build/assets/{modal-backdrop-BAbgYsqB.js → modal-backdrop-RfNCrSpK.js} +1 -1
  83. package/build/assets/{modal-body-BI6Ru2Qr.js → modal-body-aoa2fx5W.js} +1 -1
  84. package/build/assets/modal-classes-6YqcqA6y.js +1 -0
  85. package/build/assets/{modal-close-button-t1Gh3qmL.js → modal-close-button-CtWOUMmw.js} +1 -1
  86. package/build/assets/{model-selector-SM9IUz-q.js → model-selector-DcztJSxT.js} +1 -1
  87. package/build/assets/{navigation-context-D0YWpT8d.js → navigation-context-BdKYH32C.js} +1 -1
  88. package/build/assets/{navigation-link-Cn7KP3c5.js → navigation-link-U4vY9i_C.js} +1 -1
  89. package/build/assets/{openhands-logo-CnrF6LKb.js → openhands-logo-CCo0wJZX.js} +1 -1
  90. package/build/assets/{option-service.api-KvY_mZMY.js → option-service.api-CGNANEcT.js} +1 -1
  91. package/build/assets/{organization-service.api-DzYTHTYC.js → organization-service.api-BeuMC9QL.js} +1 -1
  92. package/build/assets/{path-utils-C3bQf6lJ.js → path-utils-z12iCrQO.js} +1 -1
  93. package/build/assets/{plan-components-atxXCF0R.js → plan-components-CRDMQzsS.js} +1 -1
  94. package/build/assets/{planner-tab-BlrCpv-7.js → planner-tab-Dte6Vzza.js} +1 -1
  95. package/build/assets/{profiles-client-D6IkTJof.js → profiles-client-BrqNmaDV.js} +1 -1
  96. package/build/assets/{providers-Bx6EfrzZ.js → providers-eUyo6pgr.js} +1 -1
  97. package/build/assets/proxy-BqDMnUY-.js +1 -0
  98. package/build/assets/{query-client-config-B7u9asM0.js → query-client-config-CRnGSujB.js} +1 -1
  99. package/build/assets/{recommended-automations-launcher-CgV8FyPK.js → recommended-automations-launcher-D5ADbXao.js} +3 -3
  100. package/build/assets/{root-dNntxffj.js → root-BmhaEJJ8.js} +2 -2
  101. package/build/assets/root-Z2VHU4R3.css +1 -0
  102. package/build/assets/root-layout-CNggm0d8.js +2 -0
  103. package/build/assets/{sdk-section-page-DOIKvwSL.js → sdk-section-page-CRCRY3PG.js} +1 -1
  104. package/build/assets/{sdk-settings-schema-DsUf9wu1.js → sdk-settings-schema-CLmJ9sho.js} +1 -1
  105. package/build/assets/{search-27Owlc3A.js → search-SuJctqNJ.js} +1 -1
  106. package/build/assets/secrets-service-B9AFn9OE.js +1 -0
  107. package/build/assets/secrets-settings-0UrKMS60.js +1 -0
  108. package/build/assets/{server-client-DyAQ3NZ_.js → server-client-DYv_GHPl.js} +1 -1
  109. package/build/assets/{settings-BYkVX7vW.js → settings-6t6LGW04.js} +1 -1
  110. package/build/assets/{settings-dropdown-input-BJYvGdg-.js → settings-dropdown-input-BtoovFre.js} +1 -1
  111. package/build/assets/{settings-gear-C77PgE_O.js → settings-gear-Dd8K2_8B.js} +1 -1
  112. package/build/assets/settings-index-CR6Ou73o.js +1 -0
  113. package/build/assets/{settings-input-Bn7F5C75.js → settings-input-CehsXnb3.js} +1 -1
  114. package/build/assets/settings-list-classes-E3v_f6QG.js +1 -0
  115. package/build/assets/settings-modal-T_Yk1Zfo.js +1 -0
  116. package/build/assets/{settings-section-header-context-BgZe5YkE.js → settings-section-header-context-DewwJ0-F.js} +1 -1
  117. package/build/assets/settings-service.api-DwtyDeGh.js +1 -0
  118. package/build/assets/{settings-switch-BeIKrWms.js → settings-switch-BiBuS3xa.js} +1 -1
  119. package/build/assets/{settings-utils-B6Nl07io.js → settings-utils-DY04tWG1.js} +1 -1
  120. package/build/assets/{shared-conversation-AMyqXvpk.js → shared-conversation-BzccsVej.js} +1 -1
  121. package/build/assets/sidebar-mobile-menu-toggle-DGlRg6jG.js +1 -0
  122. package/build/assets/{sidebar-nav-link-BGjiJq-4.js → sidebar-nav-link-dgVb8Fpy.js} +1 -1
  123. package/build/assets/{sidebar-store-Uy3v0AOV.js → sidebar-store-DnQAJAE5.js} +1 -1
  124. package/build/assets/{skill-card-pill-row-DF1axQCG.js → skill-card-pill-row-BW9qvhoK.js} +1 -1
  125. package/build/assets/{skills-ChIKZPK4.js → skills-0GRKX5Xj.js} +1 -1
  126. package/build/assets/{skills-plugins-CcI_19lM.js → skills-plugins-DctDrZ8Y.js} +1 -1
  127. package/build/assets/skills-settings-rvxImDj_.js +2 -0
  128. package/build/assets/{styled-tooltip-CBzrri6o.js → styled-tooltip-hdfMXPQC.js} +1 -1
  129. package/build/assets/{switch-skeleton-DnC9wLp7.js → switch-skeleton-DSKqSx2A.js} +1 -1
  130. package/build/assets/{task-list-tab-DUJn1sgz.js → task-list-tab-DT6_zfUs.js} +1 -1
  131. package/build/assets/{terminal-RmuaSdhJ.js → terminal-CPYWdo4j.js} +1 -1
  132. package/build/assets/{terminal-DgQk1Ay6.js → terminal-KldRPIRT.js} +2 -2
  133. package/build/assets/{toggle-switch-Pvyp2RAN.js → toggle-switch-T2v6sJ6l.js} +1 -1
  134. package/build/assets/{typography-gpuWmrQO.js → typography-BDgnT7Yp.js} +1 -1
  135. package/build/assets/{u-check-circle-IUIfACQQ.js → u-check-circle-DOauqQKb.js} +1 -1
  136. package/build/assets/{u-check-circle-half-C1YxB6py.js → u-check-circle-half-steSK_JB.js} +1 -1
  137. package/build/assets/{u-circuit-BmVikJHu.js → u-circuit-x3ExjBbU.js} +1 -1
  138. package/build/assets/{u-edit-CFvXHqZk.js → u-edit-BbrptMCa.js} +1 -1
  139. package/build/assets/{use-active-conversation-BEFNwnFk.js → use-active-conversation-sPgfSkql.js} +1 -1
  140. package/build/assets/use-agent-settings-schema-B66kGIi_.js +1 -0
  141. package/build/assets/{use-agent-state-Bkrd1FZq.js → use-agent-state-Dp3pD1h3.js} +1 -1
  142. package/build/assets/{use-cloud-current-user-id-CvkXFnTT.js → use-cloud-current-user-id-ClKFPjFz.js} +1 -1
  143. package/build/assets/{use-config-Co1O8-Ey.js → use-config-C9pvb0Sm.js} +1 -1
  144. package/build/assets/{use-create-conversation-CEgXpkfH.js → use-create-conversation-B-lwTnfE.js} +1 -1
  145. package/build/assets/{use-event-store-BT_gV3ut.js → use-event-store-BomO7ywK.js} +1 -1
  146. package/build/assets/{use-get-secrets-DuhdIA59.js → use-get-secrets-oyC7PFRz.js} +1 -1
  147. package/build/assets/{use-handle-plan-click-Ckkm5eIY.js → use-handle-plan-click-DP6Rs-YP.js} +1 -1
  148. package/build/assets/use-is-authed-dw2026rR.js +1 -0
  149. package/build/assets/{use-is-creating-conversation-BZ5hB_Bg.js → use-is-creating-conversation-DX2qSlfL.js} +1 -1
  150. package/build/assets/{use-launch-skill-in-chat-fNN_xGZG.js → use-launch-skill-in-chat-sQNEOLGD.js} +1 -1
  151. package/build/assets/use-llm-profiles-Bh5JqZUZ.js +1 -0
  152. package/build/assets/use-runtime-is-ready-BakOUVU-.js +1 -0
  153. package/build/assets/{use-save-settings-VUrj_QNG.js → use-save-settings-uXXkqvD7.js} +1 -1
  154. package/build/assets/use-settings-DeO7nvpM.js +1 -0
  155. package/build/assets/{use-settings-nav-items-1ZvovKSr.js → use-settings-nav-items-BGMFn25b.js} +1 -1
  156. package/build/assets/{use-skills-DAMLFjKU.js → use-skills-DWIK3l3a.js} +1 -1
  157. package/build/assets/{use-task-list-CLJbuJgM.js → use-task-list-CsT10CBb.js} +1 -1
  158. package/build/assets/{use-unified-vscode-url-DdSRw-6P.js → use-unified-vscode-url-DXPtB317.js} +1 -1
  159. package/build/assets/use-user-conversation-DJen4YIP.js +1 -0
  160. package/build/assets/{useMutation-DqrumCWD.js → useMutation-GSSKKebK.js} +1 -1
  161. package/build/assets/{useTranslation-DCOdSSMl.js → useTranslation-B6voJV4y.js} +1 -1
  162. package/build/assets/utils-DCVfKFRt.js +1 -0
  163. package/build/assets/{vendor~browser-BNjNhjFU.js → vendor~browser-BrOJLj3y.js} +1 -1
  164. package/build/assets/vendor~conversation-panel~conversation-C9o-K1hW.js +1 -0
  165. package/build/assets/vendor~conversation-panel~conversation~index-RXYdJYxU.js +1 -0
  166. package/build/assets/{vendor~entry.client~root~root-layout~home~conversation-panel~conversation~launch~skills-set~jfc6hidu-VnmIZrq3.js → vendor~entry.client~root~root-layout~home~conversation-panel~conversation~launch~skills-set~jfc6hidu-DJS-rJdI.js} +1 -1
  167. package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-DpAdkv8m.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-6ByzelMS.js} +1 -1
  168. package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-B92czPCF.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-BED5W_c4.js} +1 -1
  169. package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-By5W2oHN.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-CCbqAFiI.js} +1 -1
  170. package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-BbFOrAjI.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-CG96FCly.js} +1 -1
  171. package/build/assets/{vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-smY2r837.js → vendor~home~conversation-panel~conversation~shared-conversation~planner-tab~files-tab-E4d6IEfI.js} +1 -1
  172. package/build/assets/{vendor~home~mcp~automations-list-Cs-TO3fK.js → vendor~home~mcp~automations-list-CZSK-lT2.js} +1 -1
  173. package/build/assets/{vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-Z3nsiNNq.js → vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-CjJdFLoM.js} +1 -1
  174. package/build/assets/{vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-DbfELDJu.js → vendor~home~mcp~llm-settings~agent-settings~condenser-settings~verification-settings~app-se~ocm3mykx-m8dOii0J.js} +2 -2
  175. package/build/assets/{vendor~root-layout~home~conversation-panel~conversation-DjAjXS5J.js → vendor~root-layout~home~conversation-panel~conversation-B5WNMnt4.js} +1 -1
  176. package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~i4kjfqhl-CbAhtEMv.js +1 -0
  177. package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-6Rm8U_Sr.js +9 -0
  178. package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-BkQGKpye.js → vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-tTR8C6m0.js} +1 -1
  179. package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~k776hupu-Bbs7UJ5U.js → vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~k776hupu-BJbu9kpL.js} +2 -2
  180. package/build/assets/{vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~dp08i1qy-DTwbEEcX.js → vendor~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-settin~dp08i1qy-D8soyAAx.js} +1 -1
  181. package/build/assets/{vendor~root~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-s~f2l2lr17-CDXvdvb2.js → vendor~root~root-layout~home~conversation-panel~conversation~launch~extensions-hub~skills-s~f2l2lr17-DYXOLEck.js} +1 -1
  182. package/build/assets/{verification-settings-CsbvQcYS.js → verification-settings-C_zHuDx9.js} +1 -1
  183. package/build/assets/{vscode-tab-DjNArCgY.js → vscode-tab-DH9x7xXS.js} +1 -1
  184. package/build/assets/{waiting-for-runtime-message-CntjExbU.js → waiting-for-runtime-message-CdK3btDZ.js} +1 -1
  185. package/build/assets/{x-mark-CrpjscNc.js → x-mark-BrkSPIiT.js} +1 -1
  186. package/build/index.html +4 -4
  187. package/build/locales/ar/openhands.json +20 -2
  188. package/build/locales/ca/openhands.json +20 -2
  189. package/build/locales/de/openhands.json +20 -2
  190. package/build/locales/en/openhands.json +20 -2
  191. package/build/locales/es/openhands.json +20 -2
  192. package/build/locales/fr/openhands.json +20 -2
  193. package/build/locales/it/openhands.json +20 -2
  194. package/build/locales/ja/openhands.json +20 -2
  195. package/build/locales/ko-KR/openhands.json +20 -2
  196. package/build/locales/no/openhands.json +20 -2
  197. package/build/locales/pt/openhands.json +20 -2
  198. package/build/locales/tr/openhands.json +20 -2
  199. package/build/locales/uk/openhands.json +20 -2
  200. package/build/locales/zh-CN/openhands.json +20 -2
  201. package/build/locales/zh-TW/openhands.json +20 -2
  202. package/dist/api/acp-service/acp-service.api.d.ts +18 -0
  203. package/dist/api/agent-server-adapter.cjs +3 -3
  204. package/dist/api/agent-server-adapter.cjs.map +1 -1
  205. package/dist/api/agent-server-adapter.js +54 -55
  206. package/dist/api/agent-server-adapter.js.map +1 -1
  207. package/dist/api/agent-server-client-options.cjs +1 -1
  208. package/dist/api/agent-server-client-options.cjs.map +1 -1
  209. package/dist/api/agent-server-client-options.d.ts +4 -0
  210. package/dist/api/agent-server-client-options.js +18 -12
  211. package/dist/api/agent-server-client-options.js.map +1 -1
  212. package/dist/api/agent-server-compatibility.cjs +1 -1
  213. package/dist/api/agent-server-compatibility.cjs.map +1 -1
  214. package/dist/api/agent-server-compatibility.d.ts +1 -1
  215. package/dist/api/agent-server-compatibility.js +30 -25
  216. package/dist/api/agent-server-compatibility.js.map +1 -1
  217. package/dist/api/agent-server-config.cjs +1 -1
  218. package/dist/api/agent-server-config.cjs.map +1 -1
  219. package/dist/api/agent-server-config.d.ts +15 -48
  220. package/dist/api/agent-server-config.js +25 -69
  221. package/dist/api/agent-server-config.js.map +1 -1
  222. package/dist/api/backend-registry/active-store.cjs +1 -1
  223. package/dist/api/backend-registry/active-store.cjs.map +1 -1
  224. package/dist/api/backend-registry/active-store.d.ts +11 -5
  225. package/dist/api/backend-registry/active-store.js +36 -27
  226. package/dist/api/backend-registry/active-store.js.map +1 -1
  227. package/dist/api/backend-registry/auth.cjs +1 -1
  228. package/dist/api/backend-registry/auth.cjs.map +1 -1
  229. package/dist/api/backend-registry/auth.js +3 -9
  230. package/dist/api/backend-registry/auth.js.map +1 -1
  231. package/dist/api/backend-registry/default-backend.cjs +1 -1
  232. package/dist/api/backend-registry/default-backend.cjs.map +1 -1
  233. package/dist/api/backend-registry/default-backend.d.ts +9 -16
  234. package/dist/api/backend-registry/default-backend.js +5 -4
  235. package/dist/api/backend-registry/default-backend.js.map +1 -1
  236. package/dist/api/backend-registry/storage.cjs +1 -1
  237. package/dist/api/backend-registry/storage.cjs.map +1 -1
  238. package/dist/api/backend-registry/storage.js +67 -34
  239. package/dist/api/backend-registry/storage.js.map +1 -1
  240. package/dist/api/cloud/conversation-service.api.cjs.map +1 -1
  241. package/dist/api/cloud/conversation-service.api.d.ts +8 -13
  242. package/dist/api/cloud/conversation-service.api.js.map +1 -1
  243. package/dist/api/cloud/organization-service.api.cjs.map +1 -1
  244. package/dist/api/cloud/organization-service.api.d.ts +1 -2
  245. package/dist/api/cloud/organization-service.api.js.map +1 -1
  246. package/dist/api/cloud/proxy.cjs +1 -1
  247. package/dist/api/cloud/proxy.cjs.map +1 -1
  248. package/dist/api/cloud/proxy.d.ts +6 -6
  249. package/dist/api/cloud/proxy.js +33 -24
  250. package/dist/api/cloud/proxy.js.map +1 -1
  251. package/dist/api/cloud/sandbox-service.api.cjs.map +1 -1
  252. package/dist/api/cloud/sandbox-service.api.d.ts +3 -3
  253. package/dist/api/cloud/sandbox-service.api.js.map +1 -1
  254. package/dist/api/cloud/secrets-service.api.cjs.map +1 -1
  255. package/dist/api/cloud/secrets-service.api.d.ts +3 -4
  256. package/dist/api/cloud/secrets-service.api.js.map +1 -1
  257. package/dist/api/cloud/settings-service.api.cjs +1 -1
  258. package/dist/api/cloud/settings-service.api.cjs.map +1 -1
  259. package/dist/api/cloud/settings-service.api.js +5 -1
  260. package/dist/api/cloud/settings-service.api.js.map +1 -1
  261. package/dist/api/cloud/skills-service.api.cjs.map +1 -1
  262. package/dist/api/cloud/skills-service.api.d.ts +5 -5
  263. package/dist/api/cloud/skills-service.api.js.map +1 -1
  264. package/dist/api/conversation-service/agent-server-conversation-service.api.cjs +1 -1
  265. package/dist/api/conversation-service/agent-server-conversation-service.api.cjs.map +1 -1
  266. package/dist/api/conversation-service/agent-server-conversation-service.api.js +115 -108
  267. package/dist/api/conversation-service/agent-server-conversation-service.api.js.map +1 -1
  268. package/dist/api/device-flow-client.cjs +1 -1
  269. package/dist/api/device-flow-client.cjs.map +1 -1
  270. package/dist/api/device-flow-client.d.ts +3 -5
  271. package/dist/api/device-flow-client.js +55 -66
  272. package/dist/api/device-flow-client.js.map +1 -1
  273. package/dist/api/event-service/event-service.api.cjs +1 -1
  274. package/dist/api/event-service/event-service.api.cjs.map +1 -1
  275. package/dist/api/event-service/event-service.api.d.ts +3 -3
  276. package/dist/api/event-service/event-service.api.js +17 -17
  277. package/dist/api/event-service/event-service.api.js.map +1 -1
  278. package/dist/api/git-service/agent-server-git-service.api.cjs +1 -1
  279. package/dist/api/git-service/agent-server-git-service.api.js +11 -11
  280. package/dist/api/runtime-service/agent-server-runtime-service.cjs +1 -1
  281. package/dist/api/runtime-service/agent-server-runtime-service.js +6 -6
  282. package/dist/components/conversation-events/chat/event-content-helpers/get-action-content.cjs +2 -2
  283. package/dist/components/conversation-events/chat/event-content-helpers/get-action-content.js +10 -10
  284. package/dist/components/conversation-events/chat/event-content-helpers/get-observation-result.cjs.map +1 -1
  285. package/dist/components/conversation-events/chat/event-content-helpers/get-observation-result.d.ts +5 -5
  286. package/dist/components/conversation-events/chat/event-content-helpers/get-observation-result.js.map +1 -1
  287. package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.cjs +1 -1
  288. package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.cjs.map +1 -1
  289. package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.js +1 -1
  290. package/dist/components/conversation-events/chat/event-content-helpers/should-render-event.js.map +1 -1
  291. package/dist/components/features/automations/automation-action-button-classes.d.ts +2 -2
  292. package/dist/components/features/backends/backend-form-modal.cjs +1 -1
  293. package/dist/components/features/backends/backend-form-modal.cjs.map +1 -1
  294. package/dist/components/features/backends/backend-form-modal.d.ts +1 -0
  295. package/dist/components/features/backends/backend-form-modal.js +203 -140
  296. package/dist/components/features/backends/backend-form-modal.js.map +1 -1
  297. package/dist/components/features/backends/backend-selector.cjs +1 -1
  298. package/dist/components/features/backends/backend-selector.cjs.map +1 -1
  299. package/dist/components/features/backends/backend-selector.js +117 -105
  300. package/dist/components/features/backends/backend-selector.js.map +1 -1
  301. package/dist/components/features/backends/backend-status-dot.cjs +1 -1
  302. package/dist/components/features/backends/backend-status-dot.cjs.map +1 -1
  303. package/dist/components/features/backends/backend-status-dot.d.ts +1 -1
  304. package/dist/components/features/backends/backend-status-dot.js +1 -1
  305. package/dist/components/features/backends/backend-status-dot.js.map +1 -1
  306. package/dist/components/features/backends/manage-backends-modal.cjs +1 -1
  307. package/dist/components/features/backends/manage-backends-modal.cjs.map +1 -1
  308. package/dist/components/features/backends/manage-backends-modal.js +81 -70
  309. package/dist/components/features/backends/manage-backends-modal.js.map +1 -1
  310. package/dist/components/features/chat/change-agent-button.cjs +1 -1
  311. package/dist/components/features/chat/change-agent-button.cjs.map +1 -1
  312. package/dist/components/features/chat/change-agent-button.js +59 -57
  313. package/dist/components/features/chat/change-agent-button.js.map +1 -1
  314. package/dist/components/features/chat/change-agent-context-menu.cjs +1 -1
  315. package/dist/components/features/chat/change-agent-context-menu.cjs.map +1 -1
  316. package/dist/components/features/chat/change-agent-context-menu.d.ts +3 -1
  317. package/dist/components/features/chat/change-agent-context-menu.js +30 -25
  318. package/dist/components/features/chat/change-agent-context-menu.js.map +1 -1
  319. package/dist/components/features/chat/chat-add-file-button.cjs +1 -1
  320. package/dist/components/features/chat/chat-add-file-button.cjs.map +1 -1
  321. package/dist/components/features/chat/chat-add-file-button.js +39 -38
  322. package/dist/components/features/chat/chat-add-file-button.js.map +1 -1
  323. package/dist/components/features/chat/chat-message.cjs +1 -1
  324. package/dist/components/features/chat/chat-message.cjs.map +1 -1
  325. package/dist/components/features/chat/chat-message.d.ts +2 -1
  326. package/dist/components/features/chat/chat-message.js +185 -57
  327. package/dist/components/features/chat/chat-message.js.map +1 -1
  328. package/dist/components/features/chat/components/chat-input-actions.cjs +1 -1
  329. package/dist/components/features/chat/components/chat-input-actions.cjs.map +1 -1
  330. package/dist/components/features/chat/components/chat-input-actions.js +113 -113
  331. package/dist/components/features/chat/components/chat-input-actions.js.map +1 -1
  332. package/dist/components/features/chat/components/chat-input-model.cjs +1 -1
  333. package/dist/components/features/chat/components/chat-input-model.cjs.map +1 -1
  334. package/dist/components/features/chat/components/chat-input-model.js +52 -51
  335. package/dist/components/features/chat/components/chat-input-model.js.map +1 -1
  336. package/dist/components/features/chat/components/slash-command-menu.cjs +2 -2
  337. package/dist/components/features/chat/components/slash-command-menu.cjs.map +1 -1
  338. package/dist/components/features/chat/components/slash-command-menu.js +38 -34
  339. package/dist/components/features/chat/components/slash-command-menu.js.map +1 -1
  340. package/dist/components/features/chat/git-control-bar-pr-button.cjs +1 -1
  341. package/dist/components/features/chat/git-control-bar-pr-button.cjs.map +1 -1
  342. package/dist/components/features/chat/git-control-bar-pr-button.js +16 -15
  343. package/dist/components/features/chat/git-control-bar-pr-button.js.map +1 -1
  344. package/dist/components/features/chat/git-control-bar-pull-button.cjs +1 -1
  345. package/dist/components/features/chat/git-control-bar-pull-button.cjs.map +1 -1
  346. package/dist/components/features/chat/git-control-bar-pull-button.js +16 -15
  347. package/dist/components/features/chat/git-control-bar-pull-button.js.map +1 -1
  348. package/dist/components/features/chat/git-control-bar-push-button.cjs +1 -1
  349. package/dist/components/features/chat/git-control-bar-push-button.cjs.map +1 -1
  350. package/dist/components/features/chat/git-control-bar-push-button.js +16 -15
  351. package/dist/components/features/chat/git-control-bar-push-button.js.map +1 -1
  352. package/dist/components/features/chat/git-control-bar.cjs +1 -1
  353. package/dist/components/features/chat/git-control-bar.cjs.map +1 -1
  354. package/dist/components/features/chat/git-control-bar.js +63 -62
  355. package/dist/components/features/chat/git-control-bar.js.map +1 -1
  356. package/dist/components/features/chat/pending-user-messages.cjs +1 -1
  357. package/dist/components/features/chat/pending-user-messages.cjs.map +1 -1
  358. package/dist/components/features/chat/pending-user-messages.js +27 -23
  359. package/dist/components/features/chat/pending-user-messages.js.map +1 -1
  360. package/dist/components/features/chat/switch-profile-button.cjs +1 -1
  361. package/dist/components/features/chat/switch-profile-button.cjs.map +1 -1
  362. package/dist/components/features/chat/switch-profile-button.js +26 -25
  363. package/dist/components/features/chat/switch-profile-button.js.map +1 -1
  364. package/dist/components/features/chat/switch-profile-context-menu.cjs +1 -1
  365. package/dist/components/features/chat/switch-profile-context-menu.cjs.map +1 -1
  366. package/dist/components/features/chat/switch-profile-context-menu.js +77 -67
  367. package/dist/components/features/chat/switch-profile-context-menu.js.map +1 -1
  368. package/dist/components/features/context-menu/context-menu-icon-text-with-description.cjs +1 -1
  369. package/dist/components/features/context-menu/context-menu-icon-text-with-description.cjs.map +1 -1
  370. package/dist/components/features/context-menu/context-menu-icon-text-with-description.d.ts +2 -1
  371. package/dist/components/features/context-menu/context-menu-icon-text-with-description.js +3 -2
  372. package/dist/components/features/context-menu/context-menu-icon-text-with-description.js.map +1 -1
  373. package/dist/components/features/context-menu/context-menu-icon-text.cjs +1 -1
  374. package/dist/components/features/context-menu/context-menu-icon-text.cjs.map +1 -1
  375. package/dist/components/features/context-menu/context-menu-icon-text.d.ts +2 -1
  376. package/dist/components/features/context-menu/context-menu-icon-text.js +20 -10
  377. package/dist/components/features/context-menu/context-menu-icon-text.js.map +1 -1
  378. package/dist/components/features/context-menu/context-menu-list-item.cjs +1 -1
  379. package/dist/components/features/context-menu/context-menu-list-item.cjs.map +1 -1
  380. package/dist/components/features/context-menu/context-menu-list-item.js +10 -9
  381. package/dist/components/features/context-menu/context-menu-list-item.js.map +1 -1
  382. package/dist/components/features/controls/agent-status.cjs +1 -1
  383. package/dist/components/features/controls/agent-status.js +12 -12
  384. package/dist/components/features/controls/git-tools-submenu.cjs +1 -1
  385. package/dist/components/features/controls/git-tools-submenu.cjs.map +1 -1
  386. package/dist/components/features/controls/git-tools-submenu.js +1 -1
  387. package/dist/components/features/controls/git-tools-submenu.js.map +1 -1
  388. package/dist/components/features/controls/macros-submenu.cjs +1 -1
  389. package/dist/components/features/controls/macros-submenu.cjs.map +1 -1
  390. package/dist/components/features/controls/macros-submenu.js +1 -1
  391. package/dist/components/features/controls/macros-submenu.js.map +1 -1
  392. package/dist/components/features/controls/server-status-context-menu-icon-text.cjs +1 -1
  393. package/dist/components/features/controls/server-status-context-menu-icon-text.cjs.map +1 -1
  394. package/dist/components/features/controls/server-status-context-menu-icon-text.js +14 -15
  395. package/dist/components/features/controls/server-status-context-menu-icon-text.js.map +1 -1
  396. package/dist/components/features/controls/server-status-context-menu.cjs +1 -1
  397. package/dist/components/features/controls/server-status-context-menu.js +4 -4
  398. package/dist/components/features/controls/server-status.cjs +1 -1
  399. package/dist/components/features/controls/server-status.js +7 -7
  400. package/dist/components/features/controls/tools-context-menu-icon-text.cjs +1 -1
  401. package/dist/components/features/controls/tools-context-menu-icon-text.cjs.map +1 -1
  402. package/dist/components/features/controls/tools-context-menu-icon-text.js +16 -16
  403. package/dist/components/features/controls/tools-context-menu-icon-text.js.map +1 -1
  404. package/dist/components/features/conversation/conversation-name-context-menu-icon-text.cjs +1 -1
  405. package/dist/components/features/conversation/conversation-name-context-menu-icon-text.cjs.map +1 -1
  406. package/dist/components/features/conversation/conversation-name-context-menu-icon-text.js +11 -11
  407. package/dist/components/features/conversation/conversation-name-context-menu-icon-text.js.map +1 -1
  408. package/dist/components/features/conversation/conversation-name-with-status.cjs +1 -1
  409. package/dist/components/features/conversation/conversation-name-with-status.js +11 -11
  410. package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.cjs +1 -1
  411. package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.cjs.map +1 -1
  412. package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.js +60 -47
  413. package/dist/components/features/conversation/conversation-tabs/conversation-tabs-context-menu.js.map +1 -1
  414. package/dist/components/features/conversation-panel/cloud-new-conversation-menu.cjs +1 -1
  415. package/dist/components/features/conversation-panel/cloud-new-conversation-menu.cjs.map +1 -1
  416. package/dist/components/features/conversation-panel/cloud-new-conversation-menu.js +86 -82
  417. package/dist/components/features/conversation-panel/cloud-new-conversation-menu.js.map +1 -1
  418. package/dist/components/features/conversation-panel/conversation-card/conversation-card-actions.cjs +1 -1
  419. package/dist/components/features/conversation-panel/conversation-card/conversation-card-actions.js +4 -4
  420. package/dist/components/features/conversation-panel/conversation-card/conversation-card-footer.cjs +1 -1
  421. package/dist/components/features/conversation-panel/conversation-card/conversation-card-footer.js +9 -9
  422. package/dist/components/features/conversation-panel/conversation-panel-filter-menu.cjs +1 -1
  423. package/dist/components/features/conversation-panel/conversation-panel-filter-menu.cjs.map +1 -1
  424. package/dist/components/features/conversation-panel/conversation-panel-filter-menu.js +93 -93
  425. package/dist/components/features/conversation-panel/conversation-panel-filter-menu.js.map +1 -1
  426. package/dist/components/features/conversation-panel/conversation-panel.cjs +1 -1
  427. package/dist/components/features/conversation-panel/conversation-panel.cjs.map +1 -1
  428. package/dist/components/features/conversation-panel/conversation-panel.js +177 -177
  429. package/dist/components/features/conversation-panel/conversation-panel.js.map +1 -1
  430. package/dist/components/features/conversation-panel/ellipsis-button.cjs +1 -1
  431. package/dist/components/features/conversation-panel/ellipsis-button.cjs.map +1 -1
  432. package/dist/components/features/conversation-panel/ellipsis-button.js +13 -13
  433. package/dist/components/features/conversation-panel/ellipsis-button.js.map +1 -1
  434. package/dist/components/features/conversation-panel/local-new-conversation-menu.cjs +1 -1
  435. package/dist/components/features/conversation-panel/local-new-conversation-menu.cjs.map +1 -1
  436. package/dist/components/features/conversation-panel/local-new-conversation-menu.js +57 -53
  437. package/dist/components/features/conversation-panel/local-new-conversation-menu.js.map +1 -1
  438. package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.cjs +1 -1
  439. package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.cjs.map +1 -1
  440. package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.js +3 -2
  441. package/dist/components/features/conversation-panel/new-conversation-dropdown-styles.js.map +1 -1
  442. package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.cjs +1 -1
  443. package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.cjs.map +1 -1
  444. package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.js +11 -8
  445. package/dist/components/features/conversation-panel/start-task-card/start-task-status-badge.js.map +1 -1
  446. package/dist/components/features/conversation-panel/system-message-modal/tab-content.cjs.map +1 -1
  447. package/dist/components/features/conversation-panel/system-message-modal/tab-content.d.ts +2 -5
  448. package/dist/components/features/conversation-panel/system-message-modal/tab-content.js.map +1 -1
  449. package/dist/components/features/files-tab/file-content-viewer.cjs +1 -1
  450. package/dist/components/features/files-tab/file-content-viewer.cjs.map +1 -1
  451. package/dist/components/features/files-tab/file-content-viewer.js +45 -42
  452. package/dist/components/features/files-tab/file-content-viewer.js.map +1 -1
  453. package/dist/components/features/home/llm-not-configured-banner.d.ts +11 -0
  454. package/dist/components/features/home/shared/dropdown-item.cjs +1 -1
  455. package/dist/components/features/home/shared/dropdown-item.cjs.map +1 -1
  456. package/dist/components/features/home/shared/dropdown-item.js +20 -16
  457. package/dist/components/features/home/shared/dropdown-item.js.map +1 -1
  458. package/dist/components/features/home/shared/generic-dropdown-menu.cjs +1 -1
  459. package/dist/components/features/home/shared/generic-dropdown-menu.cjs.map +1 -1
  460. package/dist/components/features/home/shared/generic-dropdown-menu.js +23 -22
  461. package/dist/components/features/home/shared/generic-dropdown-menu.js.map +1 -1
  462. package/dist/components/features/home/workspace-dropdown/folder-browser-modal.cjs +1 -1
  463. package/dist/components/features/home/workspace-dropdown/folder-browser-modal.cjs.map +1 -1
  464. package/dist/components/features/home/workspace-dropdown/folder-browser-modal.js +103 -102
  465. package/dist/components/features/home/workspace-dropdown/folder-browser-modal.js.map +1 -1
  466. package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.cjs +1 -1
  467. package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.cjs.map +1 -1
  468. package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.js +68 -67
  469. package/dist/components/features/home/workspace-dropdown/manage-workspaces-modal.js.map +1 -1
  470. package/dist/components/features/mcp-page/custom-server-editor.cjs +1 -1
  471. package/dist/components/features/mcp-page/custom-server-editor.cjs.map +1 -1
  472. package/dist/components/features/mcp-page/custom-server-editor.js +62 -60
  473. package/dist/components/features/mcp-page/custom-server-editor.js.map +1 -1
  474. package/dist/components/features/mcp-page/index.cjs +1 -1
  475. package/dist/components/features/mcp-page/index.d.ts +1 -0
  476. package/dist/components/features/mcp-page/index.js +1 -0
  477. package/dist/components/features/mcp-page/install-server-modal.cjs +1 -1
  478. package/dist/components/features/mcp-page/install-server-modal.cjs.map +1 -1
  479. package/dist/components/features/mcp-page/install-server-modal.js +141 -121
  480. package/dist/components/features/mcp-page/install-server-modal.js.map +1 -1
  481. package/dist/components/features/mcp-page/save-as-secret-toggle.cjs +2 -0
  482. package/dist/components/features/mcp-page/save-as-secret-toggle.cjs.map +1 -0
  483. package/dist/components/features/mcp-page/save-as-secret-toggle.d.ts +7 -0
  484. package/dist/components/features/mcp-page/save-as-secret-toggle.js +50 -0
  485. package/dist/components/features/mcp-page/save-as-secret-toggle.js.map +1 -0
  486. package/dist/components/features/onboarding/onboarding-modal.d.ts +2 -2
  487. package/dist/components/features/onboarding/steps/check-backend-step.d.ts +1 -1
  488. package/dist/components/features/onboarding/steps/choose-agent-step.d.ts +2 -1
  489. package/dist/components/features/onboarding/steps/setup-acp-secrets-step.d.ts +19 -10
  490. package/dist/components/features/settings/llm-profiles/llm-settings-local-view.cjs +1 -1
  491. package/dist/components/features/settings/llm-profiles/llm-settings-local-view.d.ts +5 -0
  492. package/dist/components/features/settings/llm-profiles/llm-settings-local-view.js +2 -0
  493. package/dist/components/features/settings/llm-profiles/profile-actions-menu.cjs +1 -1
  494. package/dist/components/features/settings/llm-profiles/profile-actions-menu.js +1 -0
  495. package/dist/components/features/skills/extensions-navigation.cjs +1 -1
  496. package/dist/components/features/skills/extensions-navigation.cjs.map +1 -1
  497. package/dist/components/features/skills/extensions-navigation.js +1 -1
  498. package/dist/components/features/skills/extensions-navigation.js.map +1 -1
  499. package/dist/components/shared/buttons/back-nav-button.cjs +2 -0
  500. package/dist/components/shared/buttons/back-nav-button.cjs.map +1 -0
  501. package/dist/components/shared/buttons/back-nav-button.d.ts +17 -0
  502. package/dist/components/shared/buttons/back-nav-button.js +33 -0
  503. package/dist/components/shared/buttons/back-nav-button.js.map +1 -0
  504. package/dist/components/shared/buttons/conversation-confirmation-buttons.cjs +1 -1
  505. package/dist/components/shared/buttons/conversation-confirmation-buttons.js +5 -5
  506. package/dist/components/shared/filters/enum-filter-dropdown.cjs +1 -1
  507. package/dist/components/shared/filters/enum-filter-dropdown.cjs.map +1 -1
  508. package/dist/components/shared/filters/enum-filter-dropdown.js +32 -31
  509. package/dist/components/shared/filters/enum-filter-dropdown.js.map +1 -1
  510. package/dist/components/shared/modals/confirmation-modals/base-modal.cjs +1 -1
  511. package/dist/components/shared/modals/confirmation-modals/base-modal.cjs.map +1 -1
  512. package/dist/components/shared/modals/confirmation-modals/base-modal.js +14 -13
  513. package/dist/components/shared/modals/confirmation-modals/base-modal.js.map +1 -1
  514. package/dist/components/shared/modals/settings/settings-modal.cjs +1 -1
  515. package/dist/components/shared/modals/settings/settings-modal.cjs.map +1 -1
  516. package/dist/components/shared/modals/settings/settings-modal.js +17 -16
  517. package/dist/components/shared/modals/settings/settings-modal.js.map +1 -1
  518. package/dist/components/shared/text-shimmer.cjs +2 -0
  519. package/dist/components/shared/text-shimmer.cjs.map +1 -0
  520. package/dist/components/shared/text-shimmer.d.ts +11 -0
  521. package/dist/components/shared/text-shimmer.js +43 -0
  522. package/dist/components/shared/text-shimmer.js.map +1 -0
  523. package/dist/constants/acp-providers.cjs +1 -1
  524. package/dist/constants/acp-providers.cjs.map +1 -1
  525. package/dist/constants/acp-providers.d.ts +16 -3
  526. package/dist/constants/acp-providers.js +0 -1
  527. package/dist/constants/acp-providers.js.map +1 -1
  528. package/dist/contexts/active-backend-context.cjs +1 -1
  529. package/dist/contexts/active-backend-context.cjs.map +1 -1
  530. package/dist/contexts/active-backend-context.js +32 -32
  531. package/dist/contexts/active-backend-context.js.map +1 -1
  532. package/dist/hooks/chat/use-chat-input-logic.cjs +1 -1
  533. package/dist/hooks/chat/use-chat-input-logic.cjs.map +1 -1
  534. package/dist/hooks/chat/use-chat-input-logic.js +13 -6
  535. package/dist/hooks/chat/use-chat-input-logic.js.map +1 -1
  536. package/dist/hooks/mutation/use-save-fields-as-secrets.cjs +2 -0
  537. package/dist/hooks/mutation/use-save-fields-as-secrets.cjs.map +1 -0
  538. package/dist/hooks/mutation/use-save-fields-as-secrets.d.ts +9 -0
  539. package/dist/hooks/mutation/use-save-fields-as-secrets.js +24 -0
  540. package/dist/hooks/mutation/use-save-fields-as-secrets.js.map +1 -0
  541. package/dist/hooks/mutation/use-unified-start-conversation.cjs +1 -1
  542. package/dist/hooks/mutation/use-unified-start-conversation.js +8 -8
  543. package/dist/hooks/mutation/use-unified-stop-conversation.cjs +1 -1
  544. package/dist/hooks/mutation/use-unified-stop-conversation.js +15 -15
  545. package/dist/hooks/query/use-acp-auth-status.d.ts +36 -0
  546. package/dist/hooks/query/use-agent-settings-schema.cjs +1 -1
  547. package/dist/hooks/query/use-agent-settings-schema.cjs.map +1 -1
  548. package/dist/hooks/query/use-agent-settings-schema.js +26 -16
  549. package/dist/hooks/query/use-agent-settings-schema.js.map +1 -1
  550. package/dist/hooks/query/use-backends-health.cjs +1 -1
  551. package/dist/hooks/query/use-backends-health.cjs.map +1 -1
  552. package/dist/hooks/query/use-backends-health.d.ts +2 -0
  553. package/dist/hooks/query/use-backends-health.js +31 -21
  554. package/dist/hooks/query/use-backends-health.js.map +1 -1
  555. package/dist/hooks/query/use-paginated-conversations.cjs +1 -1
  556. package/dist/hooks/query/use-paginated-conversations.cjs.map +1 -1
  557. package/dist/hooks/query/use-paginated-conversations.js +15 -14
  558. package/dist/hooks/query/use-paginated-conversations.js.map +1 -1
  559. package/dist/hooks/query/use-settings.cjs +1 -1
  560. package/dist/hooks/query/use-settings.cjs.map +1 -1
  561. package/dist/hooks/query/use-settings.js +65 -52
  562. package/dist/hooks/query/use-settings.js.map +1 -1
  563. package/dist/hooks/query/use-user-conversation.cjs +1 -1
  564. package/dist/hooks/query/use-user-conversation.cjs.map +1 -1
  565. package/dist/hooks/query/use-user-conversation.js +20 -11
  566. package/dist/hooks/query/use-user-conversation.js.map +1 -1
  567. package/dist/hooks/use-agent-state.cjs +1 -1
  568. package/dist/hooks/use-agent-state.js +13 -13
  569. package/dist/hooks/use-conversation-name-context-menu.cjs +1 -1
  570. package/dist/hooks/use-conversation-name-context-menu.js +10 -10
  571. package/dist/hooks/use-conversation-name-context-menu.js.map +1 -1
  572. package/dist/hooks/use-llm-configured.d.ts +25 -0
  573. package/dist/hooks/use-runtime-is-ready.cjs +1 -1
  574. package/dist/hooks/use-runtime-is-ready.js +5 -5
  575. package/dist/i18n/declaration.cjs +1 -1
  576. package/dist/i18n/declaration.cjs.map +1 -1
  577. package/dist/i18n/declaration.d.ts +19 -1
  578. package/dist/i18n/declaration.js +1 -1
  579. package/dist/i18n/declaration.js.map +1 -1
  580. package/dist/i18n/translation.cjs +3 -3
  581. package/dist/i18n/translation.cjs.map +1 -1
  582. package/dist/i18n/translation.js +321 -15
  583. package/dist/i18n/translation.js.map +1 -1
  584. package/dist/icons/stop-circle.cjs +1 -1
  585. package/dist/icons/stop-circle.cjs.map +1 -1
  586. package/dist/icons/stop-circle.js +7 -10
  587. package/dist/icons/stop-circle.js.map +1 -1
  588. package/dist/locales/ar/openhands.json +20 -2
  589. package/dist/locales/ca/openhands.json +20 -2
  590. package/dist/locales/de/openhands.json +20 -2
  591. package/dist/locales/en/openhands.json +20 -2
  592. package/dist/locales/es/openhands.json +20 -2
  593. package/dist/locales/fr/openhands.json +20 -2
  594. package/dist/locales/it/openhands.json +20 -2
  595. package/dist/locales/ja/openhands.json +20 -2
  596. package/dist/locales/ko-KR/openhands.json +20 -2
  597. package/dist/locales/no/openhands.json +20 -2
  598. package/dist/locales/pt/openhands.json +20 -2
  599. package/dist/locales/tr/openhands.json +20 -2
  600. package/dist/locales/uk/openhands.json +20 -2
  601. package/dist/locales/zh-CN/openhands.json +20 -2
  602. package/dist/locales/zh-TW/openhands.json +20 -2
  603. package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.cjs +2 -0
  604. package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.cjs.map +1 -0
  605. package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.js +15 -0
  606. package/dist/node_modules/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.js.map +1 -0
  607. package/dist/package.cjs +1 -1
  608. package/dist/package.cjs.map +1 -1
  609. package/dist/package.js +1 -1
  610. package/dist/package.js.map +1 -1
  611. package/dist/routes/conversation.cjs +1 -1
  612. package/dist/routes/conversation.cjs.map +1 -1
  613. package/dist/routes/conversation.js +1 -1
  614. package/dist/routes/conversation.js.map +1 -1
  615. package/dist/routes/llm-settings.cjs +1 -1
  616. package/dist/routes/llm-settings.cjs.map +1 -1
  617. package/dist/routes/llm-settings.js +55 -54
  618. package/dist/routes/llm-settings.js.map +1 -1
  619. package/dist/routes/secrets-settings.cjs +1 -1
  620. package/dist/routes/secrets-settings.cjs.map +1 -1
  621. package/dist/routes/secrets-settings.js +19 -27
  622. package/dist/routes/secrets-settings.js.map +1 -1
  623. package/dist/stores/conversation-store.cjs +1 -1
  624. package/dist/stores/conversation-store.cjs.map +1 -1
  625. package/dist/stores/conversation-store.d.ts +4 -0
  626. package/dist/stores/conversation-store.js +6 -0
  627. package/dist/stores/conversation-store.js.map +1 -1
  628. package/dist/types/agent-server/core/events/acp-tool-call-event.d.ts +6 -4
  629. package/dist/types/agent-server/core/events/system-event.d.ts +5 -0
  630. package/dist/types/automation.d.ts +15 -0
  631. package/dist/types/settings.d.ts +3 -1
  632. package/dist/ui/combobox-caret.cjs +1 -1
  633. package/dist/ui/combobox-caret.cjs.map +1 -1
  634. package/dist/ui/combobox-caret.d.ts +1 -1
  635. package/dist/ui/combobox-caret.js +9 -8
  636. package/dist/ui/combobox-caret.js.map +1 -1
  637. package/dist/ui/context-menu.cjs +1 -1
  638. package/dist/ui/context-menu.cjs.map +1 -1
  639. package/dist/ui/context-menu.js +9 -8
  640. package/dist/ui/context-menu.js.map +1 -1
  641. package/dist/ui/dropdown/dropdown-menu.cjs +1 -1
  642. package/dist/ui/dropdown/dropdown-menu.cjs.map +1 -1
  643. package/dist/ui/dropdown/dropdown-menu.js +21 -17
  644. package/dist/ui/dropdown/dropdown-menu.js.map +1 -1
  645. package/dist/ui/dropdown/dropdown.cjs +1 -1
  646. package/dist/ui/dropdown/dropdown.cjs.map +1 -1
  647. package/dist/ui/dropdown/dropdown.js +2 -2
  648. package/dist/ui/dropdown/dropdown.js.map +1 -1
  649. package/dist/utils/automation-schedule.d.ts +1 -0
  650. package/dist/utils/dropdown-classes.cjs +2 -0
  651. package/dist/utils/dropdown-classes.cjs.map +1 -0
  652. package/dist/utils/dropdown-classes.d.ts +32 -0
  653. package/dist/utils/dropdown-classes.js +8 -0
  654. package/dist/utils/dropdown-classes.js.map +1 -0
  655. package/dist/utils/form-control-classes.cjs +1 -1
  656. package/dist/utils/form-control-classes.cjs.map +1 -1
  657. package/dist/utils/form-control-classes.d.ts +18 -2
  658. package/dist/utils/form-control-classes.js +4 -3
  659. package/dist/utils/form-control-classes.js.map +1 -1
  660. package/dist/utils/git-control-bar-classes.cjs +2 -0
  661. package/dist/utils/git-control-bar-classes.cjs.map +1 -0
  662. package/dist/utils/git-control-bar-classes.d.ts +4 -0
  663. package/dist/utils/git-control-bar-classes.js +14 -0
  664. package/dist/utils/git-control-bar-classes.js.map +1 -0
  665. package/dist/utils/handle-event-for-ui.cjs.map +1 -1
  666. package/dist/utils/handle-event-for-ui.d.ts +6 -3
  667. package/dist/utils/handle-event-for-ui.js.map +1 -1
  668. package/dist/utils/mobile-top-bar-icon-button-classes.cjs +1 -1
  669. package/dist/utils/mobile-top-bar-icon-button-classes.cjs.map +1 -1
  670. package/dist/utils/mobile-top-bar-icon-button-classes.js +3 -3
  671. package/dist/utils/mobile-top-bar-icon-button-classes.js.map +1 -1
  672. package/dist/utils/modal-classes.cjs +2 -0
  673. package/dist/utils/modal-classes.cjs.map +1 -0
  674. package/dist/utils/modal-classes.d.ts +8 -0
  675. package/dist/utils/modal-classes.js +7 -0
  676. package/dist/utils/modal-classes.js.map +1 -0
  677. package/dist/utils/openhands-llm.cjs +2 -0
  678. package/dist/utils/openhands-llm.cjs.map +1 -0
  679. package/dist/utils/openhands-llm.d.ts +2 -0
  680. package/dist/utils/openhands-llm.js +9 -0
  681. package/dist/utils/openhands-llm.js.map +1 -0
  682. package/dist/utils/redact-custom-secrets.cjs +2 -0
  683. package/dist/utils/redact-custom-secrets.cjs.map +1 -0
  684. package/dist/utils/redact-custom-secrets.d.ts +6 -0
  685. package/dist/utils/redact-custom-secrets.js +10 -0
  686. package/dist/utils/redact-custom-secrets.js.map +1 -0
  687. package/dist/utils/status.cjs +1 -1
  688. package/dist/utils/status.cjs.map +1 -1
  689. package/dist/utils/status.d.ts +2 -1
  690. package/dist/utils/status.js +9 -8
  691. package/dist/utils/status.js.map +1 -1
  692. package/dist/utils/system-message-adapter.cjs +1 -1
  693. package/dist/utils/system-message-adapter.cjs.map +1 -1
  694. package/dist/utils/system-message-adapter.js +10 -7
  695. package/dist/utils/system-message-adapter.js.map +1 -1
  696. package/dist/utils/utils.cjs +1 -1
  697. package/dist/utils/utils.cjs.map +1 -1
  698. package/dist/utils/utils.d.ts +2 -1
  699. package/dist/utils/utils.js +21 -20
  700. package/dist/utils/utils.js.map +1 -1
  701. package/package.json +1 -1
  702. package/scripts/dev-safe.mjs +3 -1
  703. package/scripts/dev-static.mjs +2 -2
  704. package/scripts/dev-with-automation.mjs +283 -108
  705. package/scripts/static-build.mjs +20 -19
  706. package/scripts/static-server.mjs +65 -6
  707. package/build/assets/acp-providers-CbiRekh9.js +0 -1
  708. package/build/assets/active-backend-context-cCM1vYYZ.js +0 -1
  709. package/build/assets/add-backend-modal-DIUQzMPa.js +0 -1
  710. package/build/assets/agent-server-client-options-Bc5ZorQZ.js +0 -1
  711. package/build/assets/agent-server-compatibility-BlkUsrX2.js +0 -1
  712. package/build/assets/agent-server-conversation-service.api-C2V5SlHu.js +0 -5
  713. package/build/assets/api-key-entry-screen-B2gynaCp.js +0 -1
  714. package/build/assets/automation-detail-DJvbVSYK.js +0 -1
  715. package/build/assets/automations-list-6FDbI5dc.js +0 -1
  716. package/build/assets/backend-form-modal-Dnk33xA_.js +0 -1
  717. package/build/assets/base-modal-_dYTw1ri.js +0 -1
  718. package/build/assets/brand-button-Br7f0kZJ.js +0 -1
  719. package/build/assets/browser-store-Couc4S5D.js +0 -1
  720. package/build/assets/clock-BRjCgHTc.js +0 -1
  721. package/build/assets/combobox-caret-to1O8irE.js +0 -1
  722. package/build/assets/context-menu-list-item-CWNFpuiC.js +0 -1
  723. package/build/assets/conversation-DVrKU0oz.js +0 -19
  724. package/build/assets/conversation-Dlys-D5A.js +0 -1
  725. package/build/assets/conversation-panel-iF09WjZ4.js +0 -1
  726. package/build/assets/conversation-service.api-CCfztilW.js +0 -1
  727. package/build/assets/conversation-state-store-u5jepov0.js +0 -1
  728. package/build/assets/conversation-store-Z5iMCRpc.js +0 -1
  729. package/build/assets/conversation-websocket-context-DhJhqUna.js +0 -3
  730. package/build/assets/declaration-BNMqORFE.js +0 -1
  731. package/build/assets/dist-BxBP7tFD.js +0 -1
  732. package/build/assets/edit-automation-modal-BGzR3nfZ.js +0 -1
  733. package/build/assets/ellipsis-button-ZyLMPURn.js +0 -1
  734. package/build/assets/entry.client-1VMHpktY.js +0 -2
  735. package/build/assets/enum-filter-dropdown-CEgCdu4A.js +0 -1
  736. package/build/assets/extensions-hub-C651jsVh.js +0 -1
  737. package/build/assets/files-tab-R5z0lLdY.js +0 -1
  738. package/build/assets/files-tab-store-CDyVTXNT.js +0 -1
  739. package/build/assets/git-control-bar-branch-button-COdRAYHb.js +0 -27
  740. package/build/assets/git-provider-icon-BzLbc0yC.js +0 -1
  741. package/build/assets/home-e-egNUXZ.js +0 -1
  742. package/build/assets/install-server-modal-DHlbgqVH.js +0 -1
  743. package/build/assets/launch-CshDse3e.js +0 -1
  744. package/build/assets/link-external-D2POYx4c.js +0 -1
  745. package/build/assets/llm-settings-Bql-vydt.js +0 -1
  746. package/build/assets/llm-settings-C_tal6Ds.js +0 -1
  747. package/build/assets/manage-backends-modal-l7RkKfwX.js +0 -1
  748. package/build/assets/manage-workspaces-modal-DhKF_8z3.js +0 -1
  749. package/build/assets/manifest-3bf30d69.js +0 -1
  750. package/build/assets/mcp-ByeBfdfU.js +0 -9
  751. package/build/assets/messages-D0rWot7s.js +0 -36
  752. package/build/assets/proxy-CxydCnis.js +0 -1
  753. package/build/assets/root-DHeCXo9N.css +0 -1
  754. package/build/assets/root-layout-Czo9Ma6Q.js +0 -2
  755. package/build/assets/secrets-service-BsnKFc2x.js +0 -1
  756. package/build/assets/secrets-settings-Bz_UohPJ.js +0 -1
  757. package/build/assets/settings-client-C73C7IgV.js +0 -1
  758. package/build/assets/settings-index-Dz0BmdJD.js +0 -1
  759. package/build/assets/settings-list-classes-Bf80tWtc.js +0 -1
  760. package/build/assets/settings-modal-Brzgh5Yw.js +0 -1
  761. package/build/assets/settings-service.api-CZ3uWx4v.js +0 -1
  762. package/build/assets/sidebar-mobile-menu-toggle-Do_aA9Zm.js +0 -1
  763. package/build/assets/skills-settings-DlA5hlXw.js +0 -2
  764. package/build/assets/status-hp6M6E7E.js +0 -1
  765. package/build/assets/use-agent-settings-schema-33Un7UF2.js +0 -1
  766. package/build/assets/use-is-authed-BggE5wPj.js +0 -1
  767. package/build/assets/use-llm-profiles-DDOol3gK.js +0 -1
  768. package/build/assets/use-runtime-is-ready-B7EF4BKU.js +0 -1
  769. package/build/assets/use-settings-DQIZmIov.js +0 -1
  770. package/build/assets/use-user-conversation-C6hrMMtn.js +0 -1
  771. package/build/assets/utils-i18rdUj2.js +0 -1
  772. package/build/assets/vendor~conversation-panel~conversation-a9SyrrhV.js +0 -1
  773. package/build/assets/vendor~conversation-panel~conversation~index-C23ZXO4R.js +0 -1
  774. package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~i4kjfqhl-BebWhFNT.js +0 -1
  775. package/build/assets/vendor~root-layout~home~conversation-panel~conversation~extensions-hub~skills-settings~skil~iguv7bgw-DzIXV3Ui.js +0 -9
  776. /package/build/assets/{automation-IdgZq6ZK.js → automation-XDPAjiZi.js} +0 -0
  777. /package/build/assets/{color-themes-DSaoIL6A.js → color-themes-B9pm9c-R.js} +0 -0
  778. /package/build/assets/{common-DR1t-EeP.js → common-DqjLSBOt.js} +0 -0
  779. /package/build/assets/{conversation-local-storage-UYl-SX-r.js → conversation-local-storage-YmOVXxxW.js} +0 -0
  780. /package/build/assets/{dist-C6t0EXL7.js → dist-C3NfioQC.js} +0 -0
  781. /package/build/assets/{environment-switch-store-C4ulFJKp.js → environment-switch-store-CiurvTtK.js} +0 -0
  782. /package/build/assets/{health-store-BDC2rM-X.js → health-store-B5f0S2FY.js} +0 -0
  783. /package/build/assets/{map-provider-COBVzZYo.js → map-provider-BJ_8KZKU.js} +0 -0
  784. /package/build/assets/{middleware-BC9EwbB9.js → middleware-CfatjPYZ.js} +0 -0
  785. /package/build/assets/{objectWithoutPropertiesLoose-Du6eBn-V.js → objectWithoutPropertiesLoose-DSQKyRhw.js} +0 -0
  786. /package/build/assets/{react-Do0CT17Y.js → react-Dy05vyj5.js} +0 -0
  787. /package/build/assets/{sdk-settings-field-metadata-CBPmeqYa.js → sdk-settings-field-metadata-DQiaIBie.js} +0 -0
  788. /package/build/assets/{settings-D_H-qsRm.js → settings-DGY6n4J2.js} +0 -0
  789. /package/build/assets/{settings-like-page-layout-classes-I0BDBEoq.js → settings-like-page-layout-classes-D7YjdTd0.js} +0 -0
  790. /package/build/assets/{use-breakpoint-DbJ6FkQ-.js → use-breakpoint-DF_RiQ6s.js} +0 -0
  791. /package/build/assets/{use-click-outside-element-DffgWWoZ.js → use-click-outside-element-DhxCUyWl.js} +0 -0
  792. /package/build/assets/{v4-CNn21NXa.js → v4-khGvL7i2.js} +0 -0
  793. /package/build/assets/{vendor~browser-DDiZgqD3.js → vendor~browser-DisFGEp9.js} +0 -0
  794. /package/build/assets/{vendor~browser-tab-BgwV1mxF.js → vendor~browser-tab-BxhTtM9_.js} +0 -0
  795. /package/build/assets/{vendor~conversation-panel~conversation~alert-banner-DbvX3OcM.js → vendor~conversation-panel~conversation~alert-banner-w-I2sY6c.js} +0 -0
  796. /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
  797. /package/build/assets/{vendor~files-tab-BGKayPiK.js → vendor~files-tab-BtkpAiMX.js} +0 -0
  798. /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
  799. /package/build/assets/{vendor~home~mcp~automations-list-DoPfwaXj.js → vendor~home~mcp~automations-list-BgV86Sti.js} +0 -0
  800. /package/build/assets/{vendor~launch-vdeRTWFu.js → vendor~launch-BXgl67Re.js} +0 -0
  801. /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
  802. /package/build/assets/{vendor~terminal-DUrOWGFE.js → vendor~terminal-DZaJIY8A.js} +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"conversation-panel-filter-menu.cjs","names":[],"sources":["../../../../src/components/features/conversation-panel/conversation-panel-filter-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport {\n Bot,\n CalendarArrowDown,\n Check,\n Clock3,\n ClockArrowDown,\n Eye,\n EyeOff,\n Folder,\n GitBranch,\n ListFilter,\n MessageCircle,\n Star,\n Trash2,\n} from \"lucide-react\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport type { BackendKind } from \"#/api/backend-registry/types\";\nimport { Divider } from \"#/ui/divider\";\nimport { cn } from \"#/utils/utils\";\nimport { formControlTransitionClassName } from \"#/utils/form-control-classes\";\nimport type {\n ConversationSortField,\n OrganizeMode,\n ThreadScope,\n} from \"./conversation-panel-list-helpers\";\n\nconst capitalizeLabel = (label: string) =>\n label.length > 0 ? label.charAt(0).toUpperCase() + label.slice(1) : label;\n\nconst MENU_SECTION_HEADING_PADDING = \"px-2 pb-1 pt-1\";\nconst MENU_SECTION_HEADING_TEXT =\n \"text-[11px] font-semibold uppercase tracking-wide text-[var(--oh-muted)]\";\n\nfunction MenuHeading({\n children,\n suffix,\n}: {\n children: React.ReactNode;\n suffix?: React.ReactNode;\n}) {\n if (suffix != null) {\n return (\n <div\n role=\"presentation\"\n className={cn(\n \"flex items-baseline justify-between gap-2\",\n MENU_SECTION_HEADING_PADDING,\n )}\n >\n <span\n className={cn(\n \"min-w-0 truncate text-left\",\n MENU_SECTION_HEADING_TEXT,\n )}\n >\n {children}\n </span>\n {suffix}\n </div>\n );\n }\n\n return (\n <div\n role=\"presentation\"\n className={cn(MENU_SECTION_HEADING_PADDING, MENU_SECTION_HEADING_TEXT)}\n >\n {children}\n </div>\n );\n}\n\nfunction MenuSeparator() {\n return <Divider inset=\"menu\" />;\n}\n\nfunction MenuRow({\n icon: Icon,\n label,\n selected,\n onClick,\n testId,\n disabled,\n}: {\n icon: React.ComponentType<{ className?: string; \"aria-hidden\"?: boolean }>;\n label: string;\n selected?: boolean;\n onClick: () => void;\n testId?: string;\n disabled?: boolean;\n}) {\n // Rows that show a selection checkmark are toggleable preferences, so\n // they get `role=\"menuitemradio\"` when they're part of a selectable\n // group and `role=\"menuitemcheckbox\"` when they're a standalone toggle.\n // For simplicity we use `menuitemradio` whenever `selected` is provided\n // (every selectable row in this menu is part of a mutually exclusive\n // group in practice) and fall back to plain `menuitem` otherwise.\n const role = selected === undefined ? \"menuitem\" : \"menuitemradio\";\n return (\n <button\n type=\"button\"\n role={role}\n aria-checked={selected === undefined ? undefined : Boolean(selected)}\n data-testid={testId}\n disabled={disabled}\n onClick={onClick}\n className={cn(\n \"group flex w-full items-center gap-2 rounded px-2 py-2 text-left text-sm text-[var(--oh-foreground)]\",\n \"hover:bg-[var(--oh-interactive-hover)] disabled:cursor-not-allowed disabled:opacity-50\",\n )}\n >\n <Icon\n className={cn(\n \"h-3.5 w-3.5 shrink-0 text-[var(--oh-muted)] group-hover:text-[var(--oh-foreground)] group-focus-visible:text-[var(--oh-foreground)]\",\n formControlTransitionClassName,\n )}\n aria-hidden\n />\n <span className=\"min-w-0 flex-1 truncate\">{label}</span>\n {selected ? (\n <Check\n className=\"ml-auto h-3.5 w-3.5 shrink-0 text-[var(--oh-foreground)]\"\n aria-hidden\n />\n ) : null}\n </button>\n );\n}\n\nexport interface ConversationPanelFilterMenuProps {\n filterMenuOpen: boolean;\n setFilterMenuOpen: (open: boolean) => void;\n menuRef: React.RefObject<HTMLDivElement | null>;\n backendKind: BackendKind;\n organizeMode: OrganizeMode;\n setOrganizeMode: (mode: OrganizeMode) => void;\n conversationSort: ConversationSortField;\n setConversationSort: (sort: ConversationSortField) => void;\n threadScope: ThreadScope;\n setThreadScope: (scope: ThreadScope) => void;\n showOlderConversations: boolean;\n toggleShowOlderConversations: () => void;\n showRepoBranchMetadata: boolean;\n toggleShowRepoBranchMetadata: () => void;\n showLlmProfiles: boolean;\n toggleShowLlmProfiles: () => void;\n totalConversationsCount: number;\n onRequestDeleteAll: () => void;\n}\n\nexport function ConversationPanelFilterMenu({\n filterMenuOpen,\n setFilterMenuOpen,\n menuRef,\n backendKind,\n organizeMode,\n setOrganizeMode,\n conversationSort,\n setConversationSort,\n threadScope,\n setThreadScope,\n showOlderConversations,\n toggleShowOlderConversations,\n showRepoBranchMetadata,\n toggleShowRepoBranchMetadata,\n showLlmProfiles,\n toggleShowLlmProfiles,\n totalConversationsCount,\n onRequestDeleteAll,\n}: ConversationPanelFilterMenuProps) {\n const { t } = useTranslation(\"openhands\");\n\n const groupedLabel =\n backendKind === \"local\"\n ? t(I18nKey.CONVERSATION_PANEL$BY_WORKSPACE)\n : t(I18nKey.CONVERSATION_PANEL$BY_REPOSITORY);\n\n const triggerRef = React.useRef<HTMLButtonElement>(null);\n const menuContentRef = React.useRef<HTMLDivElement>(null);\n\n // When the menu opens, move keyboard focus into it so screen-reader /\n // keyboard-only users can interact with the options immediately. When\n // it closes, return focus to the trigger so Tab order picks up where\n // the user left off.\n const wasOpenRef = React.useRef(filterMenuOpen);\n React.useEffect(() => {\n if (filterMenuOpen) {\n const firstItem =\n menuContentRef.current?.querySelector<HTMLButtonElement>(\n '[role=\"menuitem\"], [role=\"menuitemradio\"]',\n );\n firstItem?.focus();\n } else if (wasOpenRef.current) {\n // Only return focus on a real open→close transition (not the\n // mount-with-open=false case).\n triggerRef.current?.focus();\n }\n wasOpenRef.current = filterMenuOpen;\n }, [filterMenuOpen]);\n\n // Roving Arrow Up/Down + Escape across the menu items. Tab still works\n // natively; Escape closes the menu and returns focus to the trigger\n // (via the effect above).\n const handleMenuKeyDown = (event: React.KeyboardEvent<HTMLDivElement>) => {\n if (event.key === \"Escape\") {\n event.preventDefault();\n setFilterMenuOpen(false);\n return;\n }\n if (event.key !== \"ArrowDown\" && event.key !== \"ArrowUp\") return;\n const container = menuContentRef.current;\n if (!container) return;\n const items = Array.from(\n container.querySelectorAll<HTMLButtonElement>(\n '[role=\"menuitem\"], [role=\"menuitemradio\"]',\n ),\n ).filter((el) => !el.disabled);\n if (items.length === 0) return;\n const currentIdx = items.indexOf(\n document.activeElement as HTMLButtonElement,\n );\n const delta = event.key === \"ArrowDown\" ? 1 : -1;\n const start = currentIdx === -1 ? 0 : currentIdx;\n const nextIdx = (start + delta + items.length) % items.length;\n event.preventDefault();\n items[nextIdx]?.focus();\n };\n\n return (\n <div ref={menuRef} className=\"relative shrink-0 pr-0.5\">\n <button\n ref={triggerRef}\n type=\"button\"\n data-testid=\"older-conversations-filter-toggle\"\n aria-label={t(I18nKey.CONVERSATION_PANEL$FILTER_LABEL)}\n aria-haspopup=\"menu\"\n aria-expanded={filterMenuOpen}\n onClick={() => setFilterMenuOpen(!filterMenuOpen)}\n className={cn(\n \"inline-flex h-7 w-7 items-center justify-center rounded-md text-[var(--oh-muted)] hover:text-white hover:bg-[var(--oh-surface-raised)]\",\n formControlTransitionClassName,\n )}\n >\n <ListFilter\n className=\"lucide lucide-list-filter shrink-0\"\n width={14}\n height={14}\n strokeWidth={2}\n aria-hidden\n />\n </button>\n\n {filterMenuOpen ? (\n <div\n ref={menuContentRef}\n role=\"menu\"\n aria-orientation=\"vertical\"\n aria-label={t(I18nKey.CONVERSATION_PANEL$FILTER_LABEL)}\n // `role=\"menu\"` is an interactive ARIA role, so the container\n // must be focusable to satisfy jsx-a11y. `-1` keeps it out of\n // the natural Tab order (the menu items themselves are\n // `<button>`s and tabbable on their own) but still allows the\n // open-effect to focus it / its children programmatically.\n tabIndex={-1}\n data-testid=\"older-conversations-filter-menu\"\n onKeyDown={handleMenuKeyDown}\n className=\"absolute right-0 top-full z-50 mt-0 w-64 rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 text-[var(--oh-foreground)] shadow-lg\"\n >\n <MenuHeading>{t(I18nKey.CONVERSATION_PANEL$ORGANIZE)}</MenuHeading>\n <MenuRow\n icon={Folder}\n label={groupedLabel}\n selected={organizeMode === \"grouped\"}\n onClick={() => {\n setOrganizeMode(\"grouped\");\n setFilterMenuOpen(false);\n }}\n />\n <MenuRow\n icon={Clock3}\n label={t(I18nKey.CONVERSATION_PANEL$CHRONOLOGICAL)}\n selected={organizeMode === \"chronological\"}\n onClick={() => {\n setOrganizeMode(\"chronological\");\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuHeading>{t(I18nKey.CONVERSATION_PANEL$SORT_BY)}</MenuHeading>\n <MenuRow\n icon={CalendarArrowDown}\n label={t(I18nKey.CONVERSATION_PANEL$SORT_CREATED)}\n selected={conversationSort === \"created\"}\n onClick={() => {\n setConversationSort(\"created\");\n setFilterMenuOpen(false);\n }}\n />\n <MenuRow\n icon={ClockArrowDown}\n label={t(I18nKey.CONVERSATION_PANEL$SORT_UPDATED)}\n selected={conversationSort === \"updated\"}\n onClick={() => {\n setConversationSort(\"updated\");\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuHeading>{t(I18nKey.CONVERSATION_PANEL$SHOW)}</MenuHeading>\n <MenuRow\n icon={MessageCircle}\n label={t(I18nKey.CONVERSATION_PANEL$ALL_THREADS)}\n selected={threadScope === \"all\"}\n onClick={() => {\n setThreadScope(\"all\");\n setFilterMenuOpen(false);\n }}\n />\n <MenuRow\n icon={Star}\n label={t(I18nKey.CONVERSATION_PANEL$RELEVANT_THREADS)}\n selected={threadScope === \"relevant\"}\n onClick={() => {\n setThreadScope(\"relevant\");\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuHeading>{t(I18nKey.CONVERSATION_PANEL$METADATA)}</MenuHeading>\n <MenuRow\n icon={Bot}\n label={t(I18nKey.CONVERSATION_PANEL$LLM_MODEL)}\n selected={showLlmProfiles}\n testId=\"toggle-llm-profiles\"\n onClick={() => {\n toggleShowLlmProfiles();\n setFilterMenuOpen(false);\n }}\n />\n <MenuRow\n icon={GitBranch}\n label={t(I18nKey.CONVERSATION_PANEL$REPO_BRANCH)}\n selected={showRepoBranchMetadata}\n testId=\"toggle-repo-branch-metadata\"\n onClick={() => {\n toggleShowRepoBranchMetadata();\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuHeading\n suffix={\n <span className=\"shrink-0 text-right text-[10px] font-medium normal-case tracking-normal text-[var(--oh-muted)]/70\">\n {t(I18nKey.CONVERSATION_PANEL$OLDER_OVER_ONE_HOUR)}\n </span>\n }\n >\n {t(I18nKey.CONVERSATION_PANEL$OLDER_SECTION)}\n </MenuHeading>\n <MenuRow\n testId=\"toggle-older-conversations\"\n icon={showOlderConversations ? EyeOff : Eye}\n label={\n showOlderConversations\n ? capitalizeLabel(t(I18nKey.CONVERSATION$HIDE))\n : capitalizeLabel(t(I18nKey.CONVERSATION$SHOW_ALL))\n }\n onClick={() => {\n toggleShowOlderConversations();\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuRow\n testId=\"delete-all-conversations\"\n icon={Trash2}\n label={capitalizeLabel(t(I18nKey.CONVERSATION$DELETE_ALL))}\n disabled={totalConversationsCount === 0}\n onClick={() => {\n if (totalConversationsCount === 0) return;\n onRequestDeleteAll();\n setFilterMenuOpen(false);\n }}\n />\n </div>\n ) : null}\n </div>\n );\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"conversation-panel-filter-menu.cjs","names":[],"sources":["../../../../src/components/features/conversation-panel/conversation-panel-filter-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport {\n Bot,\n CalendarArrowDown,\n Check,\n Clock3,\n ClockArrowDown,\n Eye,\n EyeOff,\n Folder,\n GitBranch,\n ListFilter,\n MessageCircle,\n Star,\n Trash2,\n} from \"lucide-react\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport type { BackendKind } from \"#/api/backend-registry/types\";\nimport { Divider } from \"#/ui/divider\";\nimport { cn } from \"#/utils/utils\";\nimport {\n dropdownMenuRowClassName,\n dropdownMenuRowIconClassName,\n dropdownInstantColorClassName,\n dropdownMenuListClassName,\n dropdownMenuViewportScrollClassName,\n} from \"#/utils/dropdown-classes\";\nimport type {\n ConversationSortField,\n OrganizeMode,\n ThreadScope,\n} from \"./conversation-panel-list-helpers\";\n\nconst capitalizeLabel = (label: string) =>\n label.length > 0 ? label.charAt(0).toUpperCase() + label.slice(1) : label;\n\nconst MENU_SECTION_HEADING_PADDING = \"px-2 pb-1 pt-1\";\nconst MENU_SECTION_HEADING_TEXT =\n \"text-[11px] font-semibold uppercase tracking-wide text-[var(--oh-muted)]\";\n\nfunction MenuHeading({\n children,\n suffix,\n}: {\n children: React.ReactNode;\n suffix?: React.ReactNode;\n}) {\n if (suffix != null) {\n return (\n <div\n role=\"presentation\"\n className={cn(\n \"flex items-baseline justify-between gap-2\",\n MENU_SECTION_HEADING_PADDING,\n )}\n >\n <span\n className={cn(\n \"min-w-0 truncate text-left\",\n MENU_SECTION_HEADING_TEXT,\n )}\n >\n {children}\n </span>\n {suffix}\n </div>\n );\n }\n\n return (\n <div\n role=\"presentation\"\n className={cn(MENU_SECTION_HEADING_PADDING, MENU_SECTION_HEADING_TEXT)}\n >\n {children}\n </div>\n );\n}\n\nfunction MenuSeparator() {\n return <Divider inset=\"menu\" />;\n}\n\nfunction MenuRow({\n icon: Icon,\n label,\n selected,\n onClick,\n testId,\n disabled,\n}: {\n icon: React.ComponentType<{ className?: string; \"aria-hidden\"?: boolean }>;\n label: string;\n selected?: boolean;\n onClick: () => void;\n testId?: string;\n disabled?: boolean;\n}) {\n // Rows that show a selection checkmark are toggleable preferences, so\n // they get `role=\"menuitemradio\"` when they're part of a selectable\n // group and `role=\"menuitemcheckbox\"` when they're a standalone toggle.\n // For simplicity we use `menuitemradio` whenever `selected` is provided\n // (every selectable row in this menu is part of a mutually exclusive\n // group in practice) and fall back to plain `menuitem` otherwise.\n const role = selected === undefined ? \"menuitem\" : \"menuitemradio\";\n return (\n <button\n type=\"button\"\n role={role}\n aria-checked={selected === undefined ? undefined : Boolean(selected)}\n data-testid={testId}\n disabled={disabled}\n onClick={onClick}\n className={cn(\n \"group\",\n dropdownMenuRowClassName,\n \"text-[var(--oh-foreground)] disabled:opacity-50\",\n )}\n >\n <Icon\n className={cn(\"h-3.5 w-3.5\", dropdownMenuRowIconClassName)}\n aria-hidden\n />\n <span className=\"min-w-0 flex-1 truncate\">{label}</span>\n {selected ? (\n <Check\n className=\"ml-auto h-3.5 w-3.5 shrink-0 text-white\"\n aria-hidden\n />\n ) : null}\n </button>\n );\n}\n\nexport interface ConversationPanelFilterMenuProps {\n filterMenuOpen: boolean;\n setFilterMenuOpen: (open: boolean) => void;\n menuRef: React.RefObject<HTMLDivElement | null>;\n backendKind: BackendKind;\n organizeMode: OrganizeMode;\n setOrganizeMode: (mode: OrganizeMode) => void;\n conversationSort: ConversationSortField;\n setConversationSort: (sort: ConversationSortField) => void;\n threadScope: ThreadScope;\n setThreadScope: (scope: ThreadScope) => void;\n showOlderConversations: boolean;\n toggleShowOlderConversations: () => void;\n showRepoBranchMetadata: boolean;\n toggleShowRepoBranchMetadata: () => void;\n showLlmProfiles: boolean;\n toggleShowLlmProfiles: () => void;\n totalConversationsCount: number;\n onRequestDeleteAll: () => void;\n}\n\nexport function ConversationPanelFilterMenu({\n filterMenuOpen,\n setFilterMenuOpen,\n menuRef,\n backendKind,\n organizeMode,\n setOrganizeMode,\n conversationSort,\n setConversationSort,\n threadScope,\n setThreadScope,\n showOlderConversations,\n toggleShowOlderConversations,\n showRepoBranchMetadata,\n toggleShowRepoBranchMetadata,\n showLlmProfiles,\n toggleShowLlmProfiles,\n totalConversationsCount,\n onRequestDeleteAll,\n}: ConversationPanelFilterMenuProps) {\n const { t } = useTranslation(\"openhands\");\n\n const groupedLabel =\n backendKind === \"local\"\n ? t(I18nKey.CONVERSATION_PANEL$BY_WORKSPACE)\n : t(I18nKey.CONVERSATION_PANEL$BY_REPOSITORY);\n\n const triggerRef = React.useRef<HTMLButtonElement>(null);\n const menuContentRef = React.useRef<HTMLDivElement>(null);\n\n // When the menu opens, move keyboard focus into it so screen-reader /\n // keyboard-only users can interact with the options immediately. When\n // it closes, return focus to the trigger so Tab order picks up where\n // the user left off.\n const wasOpenRef = React.useRef(filterMenuOpen);\n React.useEffect(() => {\n if (filterMenuOpen) {\n const firstItem =\n menuContentRef.current?.querySelector<HTMLButtonElement>(\n '[role=\"menuitem\"], [role=\"menuitemradio\"]',\n );\n firstItem?.focus();\n } else if (wasOpenRef.current) {\n // Only return focus on a real open→close transition (not the\n // mount-with-open=false case).\n triggerRef.current?.focus();\n }\n wasOpenRef.current = filterMenuOpen;\n }, [filterMenuOpen]);\n\n // Roving Arrow Up/Down + Escape across the menu items. Tab still works\n // natively; Escape closes the menu and returns focus to the trigger\n // (via the effect above).\n const handleMenuKeyDown = (event: React.KeyboardEvent<HTMLDivElement>) => {\n if (event.key === \"Escape\") {\n event.preventDefault();\n setFilterMenuOpen(false);\n return;\n }\n if (event.key !== \"ArrowDown\" && event.key !== \"ArrowUp\") return;\n const container = menuContentRef.current;\n if (!container) return;\n const items = Array.from(\n container.querySelectorAll<HTMLButtonElement>(\n '[role=\"menuitem\"], [role=\"menuitemradio\"]',\n ),\n ).filter((el) => !el.disabled);\n if (items.length === 0) return;\n const currentIdx = items.indexOf(\n document.activeElement as HTMLButtonElement,\n );\n const delta = event.key === \"ArrowDown\" ? 1 : -1;\n const start = currentIdx === -1 ? 0 : currentIdx;\n const nextIdx = (start + delta + items.length) % items.length;\n event.preventDefault();\n items[nextIdx]?.focus();\n };\n\n return (\n <div ref={menuRef} className=\"relative shrink-0 pr-0.5\">\n <button\n ref={triggerRef}\n type=\"button\"\n data-testid=\"older-conversations-filter-toggle\"\n aria-label={t(I18nKey.CONVERSATION_PANEL$FILTER_LABEL)}\n aria-haspopup=\"menu\"\n aria-expanded={filterMenuOpen}\n onClick={() => setFilterMenuOpen(!filterMenuOpen)}\n className={cn(\n \"inline-flex h-7 w-7 items-center justify-center rounded-md text-[var(--oh-muted)] hover:text-white hover:bg-[var(--oh-surface-raised)]\",\n dropdownInstantColorClassName,\n )}\n >\n <ListFilter\n className=\"lucide lucide-list-filter shrink-0\"\n width={14}\n height={14}\n strokeWidth={2}\n aria-hidden\n />\n </button>\n\n {filterMenuOpen ? (\n <div\n ref={menuContentRef}\n role=\"menu\"\n aria-orientation=\"vertical\"\n aria-label={t(I18nKey.CONVERSATION_PANEL$FILTER_LABEL)}\n // `role=\"menu\"` is an interactive ARIA role, so the container\n // must be focusable to satisfy jsx-a11y. `-1` keeps it out of\n // the natural Tab order (the menu items themselves are\n // `<button>`s and tabbable on their own) but still allows the\n // open-effect to focus it / its children programmatically.\n tabIndex={-1}\n data-testid=\"older-conversations-filter-menu\"\n onKeyDown={handleMenuKeyDown}\n className={cn(\n \"absolute right-0 top-full z-50 mt-0 w-64 rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 text-[var(--oh-foreground)] shadow-lg\",\n dropdownMenuListClassName,\n dropdownMenuViewportScrollClassName,\n )}\n >\n <MenuHeading>{t(I18nKey.CONVERSATION_PANEL$ORGANIZE)}</MenuHeading>\n <MenuRow\n icon={Folder}\n label={groupedLabel}\n selected={organizeMode === \"grouped\"}\n onClick={() => {\n setOrganizeMode(\"grouped\");\n setFilterMenuOpen(false);\n }}\n />\n <MenuRow\n icon={Clock3}\n label={t(I18nKey.CONVERSATION_PANEL$CHRONOLOGICAL)}\n selected={organizeMode === \"chronological\"}\n onClick={() => {\n setOrganizeMode(\"chronological\");\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuHeading>{t(I18nKey.CONVERSATION_PANEL$SORT_BY)}</MenuHeading>\n <MenuRow\n icon={CalendarArrowDown}\n label={t(I18nKey.CONVERSATION_PANEL$SORT_CREATED)}\n selected={conversationSort === \"created\"}\n onClick={() => {\n setConversationSort(\"created\");\n setFilterMenuOpen(false);\n }}\n />\n <MenuRow\n icon={ClockArrowDown}\n label={t(I18nKey.CONVERSATION_PANEL$SORT_UPDATED)}\n selected={conversationSort === \"updated\"}\n onClick={() => {\n setConversationSort(\"updated\");\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuHeading>{t(I18nKey.CONVERSATION_PANEL$SHOW)}</MenuHeading>\n <MenuRow\n icon={MessageCircle}\n label={t(I18nKey.CONVERSATION_PANEL$ALL_THREADS)}\n selected={threadScope === \"all\"}\n onClick={() => {\n setThreadScope(\"all\");\n setFilterMenuOpen(false);\n }}\n />\n <MenuRow\n icon={Star}\n label={t(I18nKey.CONVERSATION_PANEL$RELEVANT_THREADS)}\n selected={threadScope === \"relevant\"}\n onClick={() => {\n setThreadScope(\"relevant\");\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuHeading>{t(I18nKey.CONVERSATION_PANEL$METADATA)}</MenuHeading>\n <MenuRow\n icon={Bot}\n label={t(I18nKey.CONVERSATION_PANEL$LLM_MODEL)}\n selected={showLlmProfiles}\n testId=\"toggle-llm-profiles\"\n onClick={() => {\n toggleShowLlmProfiles();\n setFilterMenuOpen(false);\n }}\n />\n <MenuRow\n icon={GitBranch}\n label={t(I18nKey.CONVERSATION_PANEL$REPO_BRANCH)}\n selected={showRepoBranchMetadata}\n testId=\"toggle-repo-branch-metadata\"\n onClick={() => {\n toggleShowRepoBranchMetadata();\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuHeading\n suffix={\n <span className=\"shrink-0 text-right text-[10px] font-medium normal-case tracking-normal text-[var(--oh-muted)]/70\">\n {t(I18nKey.CONVERSATION_PANEL$OLDER_OVER_ONE_HOUR)}\n </span>\n }\n >\n {t(I18nKey.CONVERSATION_PANEL$OLDER_SECTION)}\n </MenuHeading>\n <MenuRow\n testId=\"toggle-older-conversations\"\n icon={showOlderConversations ? EyeOff : Eye}\n label={\n showOlderConversations\n ? capitalizeLabel(t(I18nKey.CONVERSATION$HIDE))\n : capitalizeLabel(t(I18nKey.CONVERSATION$SHOW_ALL))\n }\n onClick={() => {\n toggleShowOlderConversations();\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuRow\n testId=\"delete-all-conversations\"\n icon={Trash2}\n label={capitalizeLabel(t(I18nKey.CONVERSATION$DELETE_ALL))}\n disabled={totalConversationsCount === 0}\n onClick={() => {\n if (totalConversationsCount === 0) return;\n onRequestDeleteAll();\n setFilterMenuOpen(false);\n }}\n />\n </div>\n ) : null}\n </div>\n );\n}\n"],"mappings":"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"}
@@ -14,196 +14,196 @@ import { ListFilter as f } from "../../../node_modules/lucide-react/dist/esm/ico
14
14
  import { MessageCircle as p } from "../../../node_modules/lucide-react/dist/esm/icons/message-circle.js";
15
15
  import { Star as m } from "../../../node_modules/lucide-react/dist/esm/icons/star.js";
16
16
  import { Trash2 as h } from "../../../node_modules/lucide-react/dist/esm/icons/trash-2.js";
17
- import { formControlTransitionClassName as g } from "../../../utils/form-control-classes.js";
18
- import { Divider as _ } from "../../../ui/divider.js";
19
- import v from "react";
20
- import { jsx as y, jsxs as b } from "react/jsx-runtime";
17
+ import { dropdownInstantColorClassName as g, dropdownMenuListClassName as _, dropdownMenuRowClassName as v, dropdownMenuRowIconClassName as y, dropdownMenuViewportScrollClassName as b } from "../../../utils/dropdown-classes.js";
18
+ import { Divider as x } from "../../../ui/divider.js";
19
+ import S from "react";
20
+ import { jsx as C, jsxs as w } from "react/jsx-runtime";
21
21
  //#region src/components/features/conversation-panel/conversation-panel-filter-menu.tsx
22
- var x = (e) => e.length > 0 ? e.charAt(0).toUpperCase() + e.slice(1) : e, S = "px-2 pb-1 pt-1", C = "text-[11px] font-semibold uppercase tracking-wide text-[var(--oh-muted)]";
23
- function w({ children: e, suffix: t }) {
24
- return t == null ? /* @__PURE__ */ y("div", {
22
+ var T = (e) => e.length > 0 ? e.charAt(0).toUpperCase() + e.slice(1) : e, E = "px-2 pb-1 pt-1", D = "text-[11px] font-semibold uppercase tracking-wide text-[var(--oh-muted)]";
23
+ function O({ children: e, suffix: t }) {
24
+ return t == null ? /* @__PURE__ */ C("div", {
25
25
  role: "presentation",
26
- className: n(S, C),
26
+ className: n(E, D),
27
27
  children: e
28
- }) : /* @__PURE__ */ b("div", {
28
+ }) : /* @__PURE__ */ w("div", {
29
29
  role: "presentation",
30
- className: n("flex items-baseline justify-between gap-2", S),
31
- children: [/* @__PURE__ */ y("span", {
32
- className: n("min-w-0 truncate text-left", C),
30
+ className: n("flex items-baseline justify-between gap-2", E),
31
+ children: [/* @__PURE__ */ C("span", {
32
+ className: n("min-w-0 truncate text-left", D),
33
33
  children: e
34
34
  }), t]
35
35
  });
36
36
  }
37
- function T() {
38
- return /* @__PURE__ */ y(_, { inset: "menu" });
37
+ function k() {
38
+ return /* @__PURE__ */ C(x, { inset: "menu" });
39
39
  }
40
- function E({ icon: e, label: t, selected: r, onClick: i, testId: o, disabled: s }) {
41
- return /* @__PURE__ */ b("button", {
40
+ function A({ icon: e, label: t, selected: r, onClick: i, testId: o, disabled: s }) {
41
+ return /* @__PURE__ */ w("button", {
42
42
  type: "button",
43
43
  role: r === void 0 ? "menuitem" : "menuitemradio",
44
44
  "aria-checked": r === void 0 ? void 0 : !!r,
45
45
  "data-testid": o,
46
46
  disabled: s,
47
47
  onClick: i,
48
- className: n("group flex w-full items-center gap-2 rounded px-2 py-2 text-left text-sm text-[var(--oh-foreground)]", "hover:bg-[var(--oh-interactive-hover)] disabled:cursor-not-allowed disabled:opacity-50"),
48
+ className: n("group", v, "text-[var(--oh-foreground)] disabled:opacity-50"),
49
49
  children: [
50
- /* @__PURE__ */ y(e, {
51
- className: n("h-3.5 w-3.5 shrink-0 text-[var(--oh-muted)] group-hover:text-[var(--oh-foreground)] group-focus-visible:text-[var(--oh-foreground)]", g),
50
+ /* @__PURE__ */ C(e, {
51
+ className: n("h-3.5 w-3.5", y),
52
52
  "aria-hidden": !0
53
53
  }),
54
- /* @__PURE__ */ y("span", {
54
+ /* @__PURE__ */ C("span", {
55
55
  className: "min-w-0 flex-1 truncate",
56
56
  children: t
57
57
  }),
58
- r ? /* @__PURE__ */ y(a, {
59
- className: "ml-auto h-3.5 w-3.5 shrink-0 text-[var(--oh-foreground)]",
58
+ r ? /* @__PURE__ */ C(a, {
59
+ className: "ml-auto h-3.5 w-3.5 shrink-0 text-white",
60
60
  "aria-hidden": !0
61
61
  }) : null
62
62
  ]
63
63
  });
64
64
  }
65
- function D({ filterMenuOpen: a, setFilterMenuOpen: _, menuRef: S, backendKind: C, organizeMode: D, setOrganizeMode: O, conversationSort: k, setConversationSort: A, threadScope: j, setThreadScope: M, showOlderConversations: N, toggleShowOlderConversations: P, showRepoBranchMetadata: F, toggleShowRepoBranchMetadata: I, showLlmProfiles: L, toggleShowLlmProfiles: R, totalConversationsCount: z, onRequestDeleteAll: B }) {
66
- let { t: V } = e("openhands"), H = V(C === "local" ? t.CONVERSATION_PANEL$BY_WORKSPACE : t.CONVERSATION_PANEL$BY_REPOSITORY), U = v.useRef(null), W = v.useRef(null), G = v.useRef(a);
67
- return v.useEffect(() => {
68
- a ? (W.current?.querySelector("[role=\"menuitem\"], [role=\"menuitemradio\"]"))?.focus() : G.current && U.current?.focus(), G.current = a;
69
- }, [a]), /* @__PURE__ */ b("div", {
70
- ref: S,
65
+ function j({ filterMenuOpen: a, setFilterMenuOpen: v, menuRef: y, backendKind: x, organizeMode: E, setOrganizeMode: D, conversationSort: j, setConversationSort: M, threadScope: N, setThreadScope: P, showOlderConversations: F, toggleShowOlderConversations: I, showRepoBranchMetadata: L, toggleShowRepoBranchMetadata: R, showLlmProfiles: z, toggleShowLlmProfiles: B, totalConversationsCount: V, onRequestDeleteAll: H }) {
66
+ let { t: U } = e("openhands"), W = U(x === "local" ? t.CONVERSATION_PANEL$BY_WORKSPACE : t.CONVERSATION_PANEL$BY_REPOSITORY), G = S.useRef(null), K = S.useRef(null), q = S.useRef(a);
67
+ return S.useEffect(() => {
68
+ a ? (K.current?.querySelector("[role=\"menuitem\"], [role=\"menuitemradio\"]"))?.focus() : q.current && G.current?.focus(), q.current = a;
69
+ }, [a]), /* @__PURE__ */ w("div", {
70
+ ref: y,
71
71
  className: "relative shrink-0 pr-0.5",
72
- children: [/* @__PURE__ */ y("button", {
73
- ref: U,
72
+ children: [/* @__PURE__ */ C("button", {
73
+ ref: G,
74
74
  type: "button",
75
75
  "data-testid": "older-conversations-filter-toggle",
76
- "aria-label": V(t.CONVERSATION_PANEL$FILTER_LABEL),
76
+ "aria-label": U(t.CONVERSATION_PANEL$FILTER_LABEL),
77
77
  "aria-haspopup": "menu",
78
78
  "aria-expanded": a,
79
- onClick: () => _(!a),
79
+ onClick: () => v(!a),
80
80
  className: n("inline-flex h-7 w-7 items-center justify-center rounded-md text-[var(--oh-muted)] hover:text-white hover:bg-[var(--oh-surface-raised)]", g),
81
- children: /* @__PURE__ */ y(f, {
81
+ children: /* @__PURE__ */ C(f, {
82
82
  className: "lucide lucide-list-filter shrink-0",
83
83
  width: 14,
84
84
  height: 14,
85
85
  strokeWidth: 2,
86
86
  "aria-hidden": !0
87
87
  })
88
- }), a ? /* @__PURE__ */ b("div", {
89
- ref: W,
88
+ }), a ? /* @__PURE__ */ w("div", {
89
+ ref: K,
90
90
  role: "menu",
91
91
  "aria-orientation": "vertical",
92
- "aria-label": V(t.CONVERSATION_PANEL$FILTER_LABEL),
92
+ "aria-label": U(t.CONVERSATION_PANEL$FILTER_LABEL),
93
93
  tabIndex: -1,
94
94
  "data-testid": "older-conversations-filter-menu",
95
95
  onKeyDown: (e) => {
96
96
  if (e.key === "Escape") {
97
- e.preventDefault(), _(!1);
97
+ e.preventDefault(), v(!1);
98
98
  return;
99
99
  }
100
100
  if (e.key !== "ArrowDown" && e.key !== "ArrowUp") return;
101
- let t = W.current;
101
+ let t = K.current;
102
102
  if (!t) return;
103
103
  let n = Array.from(t.querySelectorAll("[role=\"menuitem\"], [role=\"menuitemradio\"]")).filter((e) => !e.disabled);
104
104
  if (n.length === 0) return;
105
105
  let r = n.indexOf(document.activeElement), i = e.key === "ArrowDown" ? 1 : -1, a = ((r === -1 ? 0 : r) + i + n.length) % n.length;
106
106
  e.preventDefault(), n[a]?.focus();
107
107
  },
108
- className: "absolute right-0 top-full z-50 mt-0 w-64 rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 text-[var(--oh-foreground)] shadow-lg",
108
+ className: n("absolute right-0 top-full z-50 mt-0 w-64 rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 text-[var(--oh-foreground)] shadow-lg", _, b),
109
109
  children: [
110
- /* @__PURE__ */ y(w, { children: V(t.CONVERSATION_PANEL$ORGANIZE) }),
111
- /* @__PURE__ */ y(E, {
110
+ /* @__PURE__ */ C(O, { children: U(t.CONVERSATION_PANEL$ORGANIZE) }),
111
+ /* @__PURE__ */ C(A, {
112
112
  icon: u,
113
- label: H,
114
- selected: D === "grouped",
113
+ label: W,
114
+ selected: E === "grouped",
115
115
  onClick: () => {
116
- O("grouped"), _(!1);
116
+ D("grouped"), v(!1);
117
117
  }
118
118
  }),
119
- /* @__PURE__ */ y(E, {
119
+ /* @__PURE__ */ C(A, {
120
120
  icon: o,
121
- label: V(t.CONVERSATION_PANEL$CHRONOLOGICAL),
122
- selected: D === "chronological",
121
+ label: U(t.CONVERSATION_PANEL$CHRONOLOGICAL),
122
+ selected: E === "chronological",
123
123
  onClick: () => {
124
- O("chronological"), _(!1);
124
+ D("chronological"), v(!1);
125
125
  }
126
126
  }),
127
- /* @__PURE__ */ y(T, {}),
128
- /* @__PURE__ */ y(w, { children: V(t.CONVERSATION_PANEL$SORT_BY) }),
129
- /* @__PURE__ */ y(E, {
127
+ /* @__PURE__ */ C(k, {}),
128
+ /* @__PURE__ */ C(O, { children: U(t.CONVERSATION_PANEL$SORT_BY) }),
129
+ /* @__PURE__ */ C(A, {
130
130
  icon: i,
131
- label: V(t.CONVERSATION_PANEL$SORT_CREATED),
132
- selected: k === "created",
131
+ label: U(t.CONVERSATION_PANEL$SORT_CREATED),
132
+ selected: j === "created",
133
133
  onClick: () => {
134
- A("created"), _(!1);
134
+ M("created"), v(!1);
135
135
  }
136
136
  }),
137
- /* @__PURE__ */ y(E, {
137
+ /* @__PURE__ */ C(A, {
138
138
  icon: s,
139
- label: V(t.CONVERSATION_PANEL$SORT_UPDATED),
140
- selected: k === "updated",
139
+ label: U(t.CONVERSATION_PANEL$SORT_UPDATED),
140
+ selected: j === "updated",
141
141
  onClick: () => {
142
- A("updated"), _(!1);
142
+ M("updated"), v(!1);
143
143
  }
144
144
  }),
145
- /* @__PURE__ */ y(T, {}),
146
- /* @__PURE__ */ y(w, { children: V(t.CONVERSATION_PANEL$SHOW) }),
147
- /* @__PURE__ */ y(E, {
145
+ /* @__PURE__ */ C(k, {}),
146
+ /* @__PURE__ */ C(O, { children: U(t.CONVERSATION_PANEL$SHOW) }),
147
+ /* @__PURE__ */ C(A, {
148
148
  icon: p,
149
- label: V(t.CONVERSATION_PANEL$ALL_THREADS),
150
- selected: j === "all",
149
+ label: U(t.CONVERSATION_PANEL$ALL_THREADS),
150
+ selected: N === "all",
151
151
  onClick: () => {
152
- M("all"), _(!1);
152
+ P("all"), v(!1);
153
153
  }
154
154
  }),
155
- /* @__PURE__ */ y(E, {
155
+ /* @__PURE__ */ C(A, {
156
156
  icon: m,
157
- label: V(t.CONVERSATION_PANEL$RELEVANT_THREADS),
158
- selected: j === "relevant",
157
+ label: U(t.CONVERSATION_PANEL$RELEVANT_THREADS),
158
+ selected: N === "relevant",
159
159
  onClick: () => {
160
- M("relevant"), _(!1);
160
+ P("relevant"), v(!1);
161
161
  }
162
162
  }),
163
- /* @__PURE__ */ y(T, {}),
164
- /* @__PURE__ */ y(w, { children: V(t.CONVERSATION_PANEL$METADATA) }),
165
- /* @__PURE__ */ y(E, {
163
+ /* @__PURE__ */ C(k, {}),
164
+ /* @__PURE__ */ C(O, { children: U(t.CONVERSATION_PANEL$METADATA) }),
165
+ /* @__PURE__ */ C(A, {
166
166
  icon: r,
167
- label: V(t.CONVERSATION_PANEL$LLM_MODEL),
168
- selected: L,
167
+ label: U(t.CONVERSATION_PANEL$LLM_MODEL),
168
+ selected: z,
169
169
  testId: "toggle-llm-profiles",
170
170
  onClick: () => {
171
- R(), _(!1);
171
+ B(), v(!1);
172
172
  }
173
173
  }),
174
- /* @__PURE__ */ y(E, {
174
+ /* @__PURE__ */ C(A, {
175
175
  icon: d,
176
- label: V(t.CONVERSATION_PANEL$REPO_BRANCH),
177
- selected: F,
176
+ label: U(t.CONVERSATION_PANEL$REPO_BRANCH),
177
+ selected: L,
178
178
  testId: "toggle-repo-branch-metadata",
179
179
  onClick: () => {
180
- I(), _(!1);
180
+ R(), v(!1);
181
181
  }
182
182
  }),
183
- /* @__PURE__ */ y(T, {}),
184
- /* @__PURE__ */ y(w, {
185
- suffix: /* @__PURE__ */ y("span", {
183
+ /* @__PURE__ */ C(k, {}),
184
+ /* @__PURE__ */ C(O, {
185
+ suffix: /* @__PURE__ */ C("span", {
186
186
  className: "shrink-0 text-right text-[10px] font-medium normal-case tracking-normal text-[var(--oh-muted)]/70",
187
- children: V(t.CONVERSATION_PANEL$OLDER_OVER_ONE_HOUR)
187
+ children: U(t.CONVERSATION_PANEL$OLDER_OVER_ONE_HOUR)
188
188
  }),
189
- children: V(t.CONVERSATION_PANEL$OLDER_SECTION)
189
+ children: U(t.CONVERSATION_PANEL$OLDER_SECTION)
190
190
  }),
191
- /* @__PURE__ */ y(E, {
191
+ /* @__PURE__ */ C(A, {
192
192
  testId: "toggle-older-conversations",
193
- icon: N ? c : l,
194
- label: x(V(N ? t.CONVERSATION$HIDE : t.CONVERSATION$SHOW_ALL)),
193
+ icon: F ? c : l,
194
+ label: T(U(F ? t.CONVERSATION$HIDE : t.CONVERSATION$SHOW_ALL)),
195
195
  onClick: () => {
196
- P(), _(!1);
196
+ I(), v(!1);
197
197
  }
198
198
  }),
199
- /* @__PURE__ */ y(T, {}),
200
- /* @__PURE__ */ y(E, {
199
+ /* @__PURE__ */ C(k, {}),
200
+ /* @__PURE__ */ C(A, {
201
201
  testId: "delete-all-conversations",
202
202
  icon: h,
203
- label: x(V(t.CONVERSATION$DELETE_ALL)),
204
- disabled: z === 0,
203
+ label: T(U(t.CONVERSATION$DELETE_ALL)),
204
+ disabled: V === 0,
205
205
  onClick: () => {
206
- z !== 0 && (B(), _(!1));
206
+ V !== 0 && (H(), v(!1));
207
207
  }
208
208
  })
209
209
  ]
@@ -211,6 +211,6 @@ function D({ filterMenuOpen: a, setFilterMenuOpen: _, menuRef: S, backendKind: C
211
211
  });
212
212
  }
213
213
  //#endregion
214
- export { D as ConversationPanelFilterMenu };
214
+ export { j as ConversationPanelFilterMenu };
215
215
 
216
216
  //# sourceMappingURL=conversation-panel-filter-menu.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"conversation-panel-filter-menu.js","names":[],"sources":["../../../../src/components/features/conversation-panel/conversation-panel-filter-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport {\n Bot,\n CalendarArrowDown,\n Check,\n Clock3,\n ClockArrowDown,\n Eye,\n EyeOff,\n Folder,\n GitBranch,\n ListFilter,\n MessageCircle,\n Star,\n Trash2,\n} from \"lucide-react\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport type { BackendKind } from \"#/api/backend-registry/types\";\nimport { Divider } from \"#/ui/divider\";\nimport { cn } from \"#/utils/utils\";\nimport { formControlTransitionClassName } from \"#/utils/form-control-classes\";\nimport type {\n ConversationSortField,\n OrganizeMode,\n ThreadScope,\n} from \"./conversation-panel-list-helpers\";\n\nconst capitalizeLabel = (label: string) =>\n label.length > 0 ? label.charAt(0).toUpperCase() + label.slice(1) : label;\n\nconst MENU_SECTION_HEADING_PADDING = \"px-2 pb-1 pt-1\";\nconst MENU_SECTION_HEADING_TEXT =\n \"text-[11px] font-semibold uppercase tracking-wide text-[var(--oh-muted)]\";\n\nfunction MenuHeading({\n children,\n suffix,\n}: {\n children: React.ReactNode;\n suffix?: React.ReactNode;\n}) {\n if (suffix != null) {\n return (\n <div\n role=\"presentation\"\n className={cn(\n \"flex items-baseline justify-between gap-2\",\n MENU_SECTION_HEADING_PADDING,\n )}\n >\n <span\n className={cn(\n \"min-w-0 truncate text-left\",\n MENU_SECTION_HEADING_TEXT,\n )}\n >\n {children}\n </span>\n {suffix}\n </div>\n );\n }\n\n return (\n <div\n role=\"presentation\"\n className={cn(MENU_SECTION_HEADING_PADDING, MENU_SECTION_HEADING_TEXT)}\n >\n {children}\n </div>\n );\n}\n\nfunction MenuSeparator() {\n return <Divider inset=\"menu\" />;\n}\n\nfunction MenuRow({\n icon: Icon,\n label,\n selected,\n onClick,\n testId,\n disabled,\n}: {\n icon: React.ComponentType<{ className?: string; \"aria-hidden\"?: boolean }>;\n label: string;\n selected?: boolean;\n onClick: () => void;\n testId?: string;\n disabled?: boolean;\n}) {\n // Rows that show a selection checkmark are toggleable preferences, so\n // they get `role=\"menuitemradio\"` when they're part of a selectable\n // group and `role=\"menuitemcheckbox\"` when they're a standalone toggle.\n // For simplicity we use `menuitemradio` whenever `selected` is provided\n // (every selectable row in this menu is part of a mutually exclusive\n // group in practice) and fall back to plain `menuitem` otherwise.\n const role = selected === undefined ? \"menuitem\" : \"menuitemradio\";\n return (\n <button\n type=\"button\"\n role={role}\n aria-checked={selected === undefined ? undefined : Boolean(selected)}\n data-testid={testId}\n disabled={disabled}\n onClick={onClick}\n className={cn(\n \"group flex w-full items-center gap-2 rounded px-2 py-2 text-left text-sm text-[var(--oh-foreground)]\",\n \"hover:bg-[var(--oh-interactive-hover)] disabled:cursor-not-allowed disabled:opacity-50\",\n )}\n >\n <Icon\n className={cn(\n \"h-3.5 w-3.5 shrink-0 text-[var(--oh-muted)] group-hover:text-[var(--oh-foreground)] group-focus-visible:text-[var(--oh-foreground)]\",\n formControlTransitionClassName,\n )}\n aria-hidden\n />\n <span className=\"min-w-0 flex-1 truncate\">{label}</span>\n {selected ? (\n <Check\n className=\"ml-auto h-3.5 w-3.5 shrink-0 text-[var(--oh-foreground)]\"\n aria-hidden\n />\n ) : null}\n </button>\n );\n}\n\nexport interface ConversationPanelFilterMenuProps {\n filterMenuOpen: boolean;\n setFilterMenuOpen: (open: boolean) => void;\n menuRef: React.RefObject<HTMLDivElement | null>;\n backendKind: BackendKind;\n organizeMode: OrganizeMode;\n setOrganizeMode: (mode: OrganizeMode) => void;\n conversationSort: ConversationSortField;\n setConversationSort: (sort: ConversationSortField) => void;\n threadScope: ThreadScope;\n setThreadScope: (scope: ThreadScope) => void;\n showOlderConversations: boolean;\n toggleShowOlderConversations: () => void;\n showRepoBranchMetadata: boolean;\n toggleShowRepoBranchMetadata: () => void;\n showLlmProfiles: boolean;\n toggleShowLlmProfiles: () => void;\n totalConversationsCount: number;\n onRequestDeleteAll: () => void;\n}\n\nexport function ConversationPanelFilterMenu({\n filterMenuOpen,\n setFilterMenuOpen,\n menuRef,\n backendKind,\n organizeMode,\n setOrganizeMode,\n conversationSort,\n setConversationSort,\n threadScope,\n setThreadScope,\n showOlderConversations,\n toggleShowOlderConversations,\n showRepoBranchMetadata,\n toggleShowRepoBranchMetadata,\n showLlmProfiles,\n toggleShowLlmProfiles,\n totalConversationsCount,\n onRequestDeleteAll,\n}: ConversationPanelFilterMenuProps) {\n const { t } = useTranslation(\"openhands\");\n\n const groupedLabel =\n backendKind === \"local\"\n ? t(I18nKey.CONVERSATION_PANEL$BY_WORKSPACE)\n : t(I18nKey.CONVERSATION_PANEL$BY_REPOSITORY);\n\n const triggerRef = React.useRef<HTMLButtonElement>(null);\n const menuContentRef = React.useRef<HTMLDivElement>(null);\n\n // When the menu opens, move keyboard focus into it so screen-reader /\n // keyboard-only users can interact with the options immediately. When\n // it closes, return focus to the trigger so Tab order picks up where\n // the user left off.\n const wasOpenRef = React.useRef(filterMenuOpen);\n React.useEffect(() => {\n if (filterMenuOpen) {\n const firstItem =\n menuContentRef.current?.querySelector<HTMLButtonElement>(\n '[role=\"menuitem\"], [role=\"menuitemradio\"]',\n );\n firstItem?.focus();\n } else if (wasOpenRef.current) {\n // Only return focus on a real open→close transition (not the\n // mount-with-open=false case).\n triggerRef.current?.focus();\n }\n wasOpenRef.current = filterMenuOpen;\n }, [filterMenuOpen]);\n\n // Roving Arrow Up/Down + Escape across the menu items. Tab still works\n // natively; Escape closes the menu and returns focus to the trigger\n // (via the effect above).\n const handleMenuKeyDown = (event: React.KeyboardEvent<HTMLDivElement>) => {\n if (event.key === \"Escape\") {\n event.preventDefault();\n setFilterMenuOpen(false);\n return;\n }\n if (event.key !== \"ArrowDown\" && event.key !== \"ArrowUp\") return;\n const container = menuContentRef.current;\n if (!container) return;\n const items = Array.from(\n container.querySelectorAll<HTMLButtonElement>(\n '[role=\"menuitem\"], [role=\"menuitemradio\"]',\n ),\n ).filter((el) => !el.disabled);\n if (items.length === 0) return;\n const currentIdx = items.indexOf(\n document.activeElement as HTMLButtonElement,\n );\n const delta = event.key === \"ArrowDown\" ? 1 : -1;\n const start = currentIdx === -1 ? 0 : currentIdx;\n const nextIdx = (start + delta + items.length) % items.length;\n event.preventDefault();\n items[nextIdx]?.focus();\n };\n\n return (\n <div ref={menuRef} className=\"relative shrink-0 pr-0.5\">\n <button\n ref={triggerRef}\n type=\"button\"\n data-testid=\"older-conversations-filter-toggle\"\n aria-label={t(I18nKey.CONVERSATION_PANEL$FILTER_LABEL)}\n aria-haspopup=\"menu\"\n aria-expanded={filterMenuOpen}\n onClick={() => setFilterMenuOpen(!filterMenuOpen)}\n className={cn(\n \"inline-flex h-7 w-7 items-center justify-center rounded-md text-[var(--oh-muted)] hover:text-white hover:bg-[var(--oh-surface-raised)]\",\n formControlTransitionClassName,\n )}\n >\n <ListFilter\n className=\"lucide lucide-list-filter shrink-0\"\n width={14}\n height={14}\n strokeWidth={2}\n aria-hidden\n />\n </button>\n\n {filterMenuOpen ? (\n <div\n ref={menuContentRef}\n role=\"menu\"\n aria-orientation=\"vertical\"\n aria-label={t(I18nKey.CONVERSATION_PANEL$FILTER_LABEL)}\n // `role=\"menu\"` is an interactive ARIA role, so the container\n // must be focusable to satisfy jsx-a11y. `-1` keeps it out of\n // the natural Tab order (the menu items themselves are\n // `<button>`s and tabbable on their own) but still allows the\n // open-effect to focus it / its children programmatically.\n tabIndex={-1}\n data-testid=\"older-conversations-filter-menu\"\n onKeyDown={handleMenuKeyDown}\n className=\"absolute right-0 top-full z-50 mt-0 w-64 rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 text-[var(--oh-foreground)] shadow-lg\"\n >\n <MenuHeading>{t(I18nKey.CONVERSATION_PANEL$ORGANIZE)}</MenuHeading>\n <MenuRow\n icon={Folder}\n label={groupedLabel}\n selected={organizeMode === \"grouped\"}\n onClick={() => {\n setOrganizeMode(\"grouped\");\n setFilterMenuOpen(false);\n }}\n />\n <MenuRow\n icon={Clock3}\n label={t(I18nKey.CONVERSATION_PANEL$CHRONOLOGICAL)}\n selected={organizeMode === \"chronological\"}\n onClick={() => {\n setOrganizeMode(\"chronological\");\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuHeading>{t(I18nKey.CONVERSATION_PANEL$SORT_BY)}</MenuHeading>\n <MenuRow\n icon={CalendarArrowDown}\n label={t(I18nKey.CONVERSATION_PANEL$SORT_CREATED)}\n selected={conversationSort === \"created\"}\n onClick={() => {\n setConversationSort(\"created\");\n setFilterMenuOpen(false);\n }}\n />\n <MenuRow\n icon={ClockArrowDown}\n label={t(I18nKey.CONVERSATION_PANEL$SORT_UPDATED)}\n selected={conversationSort === \"updated\"}\n onClick={() => {\n setConversationSort(\"updated\");\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuHeading>{t(I18nKey.CONVERSATION_PANEL$SHOW)}</MenuHeading>\n <MenuRow\n icon={MessageCircle}\n label={t(I18nKey.CONVERSATION_PANEL$ALL_THREADS)}\n selected={threadScope === \"all\"}\n onClick={() => {\n setThreadScope(\"all\");\n setFilterMenuOpen(false);\n }}\n />\n <MenuRow\n icon={Star}\n label={t(I18nKey.CONVERSATION_PANEL$RELEVANT_THREADS)}\n selected={threadScope === \"relevant\"}\n onClick={() => {\n setThreadScope(\"relevant\");\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuHeading>{t(I18nKey.CONVERSATION_PANEL$METADATA)}</MenuHeading>\n <MenuRow\n icon={Bot}\n label={t(I18nKey.CONVERSATION_PANEL$LLM_MODEL)}\n selected={showLlmProfiles}\n testId=\"toggle-llm-profiles\"\n onClick={() => {\n toggleShowLlmProfiles();\n setFilterMenuOpen(false);\n }}\n />\n <MenuRow\n icon={GitBranch}\n label={t(I18nKey.CONVERSATION_PANEL$REPO_BRANCH)}\n selected={showRepoBranchMetadata}\n testId=\"toggle-repo-branch-metadata\"\n onClick={() => {\n toggleShowRepoBranchMetadata();\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuHeading\n suffix={\n <span className=\"shrink-0 text-right text-[10px] font-medium normal-case tracking-normal text-[var(--oh-muted)]/70\">\n {t(I18nKey.CONVERSATION_PANEL$OLDER_OVER_ONE_HOUR)}\n </span>\n }\n >\n {t(I18nKey.CONVERSATION_PANEL$OLDER_SECTION)}\n </MenuHeading>\n <MenuRow\n testId=\"toggle-older-conversations\"\n icon={showOlderConversations ? EyeOff : Eye}\n label={\n showOlderConversations\n ? capitalizeLabel(t(I18nKey.CONVERSATION$HIDE))\n : capitalizeLabel(t(I18nKey.CONVERSATION$SHOW_ALL))\n }\n onClick={() => {\n toggleShowOlderConversations();\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuRow\n testId=\"delete-all-conversations\"\n icon={Trash2}\n label={capitalizeLabel(t(I18nKey.CONVERSATION$DELETE_ALL))}\n disabled={totalConversationsCount === 0}\n onClick={() => {\n if (totalConversationsCount === 0) return;\n onRequestDeleteAll();\n setFilterMenuOpen(false);\n }}\n />\n </div>\n ) : null}\n </div>\n );\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"conversation-panel-filter-menu.js","names":[],"sources":["../../../../src/components/features/conversation-panel/conversation-panel-filter-menu.tsx"],"sourcesContent":["import React from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport {\n Bot,\n CalendarArrowDown,\n Check,\n Clock3,\n ClockArrowDown,\n Eye,\n EyeOff,\n Folder,\n GitBranch,\n ListFilter,\n MessageCircle,\n Star,\n Trash2,\n} from \"lucide-react\";\nimport { I18nKey } from \"#/i18n/declaration\";\nimport type { BackendKind } from \"#/api/backend-registry/types\";\nimport { Divider } from \"#/ui/divider\";\nimport { cn } from \"#/utils/utils\";\nimport {\n dropdownMenuRowClassName,\n dropdownMenuRowIconClassName,\n dropdownInstantColorClassName,\n dropdownMenuListClassName,\n dropdownMenuViewportScrollClassName,\n} from \"#/utils/dropdown-classes\";\nimport type {\n ConversationSortField,\n OrganizeMode,\n ThreadScope,\n} from \"./conversation-panel-list-helpers\";\n\nconst capitalizeLabel = (label: string) =>\n label.length > 0 ? label.charAt(0).toUpperCase() + label.slice(1) : label;\n\nconst MENU_SECTION_HEADING_PADDING = \"px-2 pb-1 pt-1\";\nconst MENU_SECTION_HEADING_TEXT =\n \"text-[11px] font-semibold uppercase tracking-wide text-[var(--oh-muted)]\";\n\nfunction MenuHeading({\n children,\n suffix,\n}: {\n children: React.ReactNode;\n suffix?: React.ReactNode;\n}) {\n if (suffix != null) {\n return (\n <div\n role=\"presentation\"\n className={cn(\n \"flex items-baseline justify-between gap-2\",\n MENU_SECTION_HEADING_PADDING,\n )}\n >\n <span\n className={cn(\n \"min-w-0 truncate text-left\",\n MENU_SECTION_HEADING_TEXT,\n )}\n >\n {children}\n </span>\n {suffix}\n </div>\n );\n }\n\n return (\n <div\n role=\"presentation\"\n className={cn(MENU_SECTION_HEADING_PADDING, MENU_SECTION_HEADING_TEXT)}\n >\n {children}\n </div>\n );\n}\n\nfunction MenuSeparator() {\n return <Divider inset=\"menu\" />;\n}\n\nfunction MenuRow({\n icon: Icon,\n label,\n selected,\n onClick,\n testId,\n disabled,\n}: {\n icon: React.ComponentType<{ className?: string; \"aria-hidden\"?: boolean }>;\n label: string;\n selected?: boolean;\n onClick: () => void;\n testId?: string;\n disabled?: boolean;\n}) {\n // Rows that show a selection checkmark are toggleable preferences, so\n // they get `role=\"menuitemradio\"` when they're part of a selectable\n // group and `role=\"menuitemcheckbox\"` when they're a standalone toggle.\n // For simplicity we use `menuitemradio` whenever `selected` is provided\n // (every selectable row in this menu is part of a mutually exclusive\n // group in practice) and fall back to plain `menuitem` otherwise.\n const role = selected === undefined ? \"menuitem\" : \"menuitemradio\";\n return (\n <button\n type=\"button\"\n role={role}\n aria-checked={selected === undefined ? undefined : Boolean(selected)}\n data-testid={testId}\n disabled={disabled}\n onClick={onClick}\n className={cn(\n \"group\",\n dropdownMenuRowClassName,\n \"text-[var(--oh-foreground)] disabled:opacity-50\",\n )}\n >\n <Icon\n className={cn(\"h-3.5 w-3.5\", dropdownMenuRowIconClassName)}\n aria-hidden\n />\n <span className=\"min-w-0 flex-1 truncate\">{label}</span>\n {selected ? (\n <Check\n className=\"ml-auto h-3.5 w-3.5 shrink-0 text-white\"\n aria-hidden\n />\n ) : null}\n </button>\n );\n}\n\nexport interface ConversationPanelFilterMenuProps {\n filterMenuOpen: boolean;\n setFilterMenuOpen: (open: boolean) => void;\n menuRef: React.RefObject<HTMLDivElement | null>;\n backendKind: BackendKind;\n organizeMode: OrganizeMode;\n setOrganizeMode: (mode: OrganizeMode) => void;\n conversationSort: ConversationSortField;\n setConversationSort: (sort: ConversationSortField) => void;\n threadScope: ThreadScope;\n setThreadScope: (scope: ThreadScope) => void;\n showOlderConversations: boolean;\n toggleShowOlderConversations: () => void;\n showRepoBranchMetadata: boolean;\n toggleShowRepoBranchMetadata: () => void;\n showLlmProfiles: boolean;\n toggleShowLlmProfiles: () => void;\n totalConversationsCount: number;\n onRequestDeleteAll: () => void;\n}\n\nexport function ConversationPanelFilterMenu({\n filterMenuOpen,\n setFilterMenuOpen,\n menuRef,\n backendKind,\n organizeMode,\n setOrganizeMode,\n conversationSort,\n setConversationSort,\n threadScope,\n setThreadScope,\n showOlderConversations,\n toggleShowOlderConversations,\n showRepoBranchMetadata,\n toggleShowRepoBranchMetadata,\n showLlmProfiles,\n toggleShowLlmProfiles,\n totalConversationsCount,\n onRequestDeleteAll,\n}: ConversationPanelFilterMenuProps) {\n const { t } = useTranslation(\"openhands\");\n\n const groupedLabel =\n backendKind === \"local\"\n ? t(I18nKey.CONVERSATION_PANEL$BY_WORKSPACE)\n : t(I18nKey.CONVERSATION_PANEL$BY_REPOSITORY);\n\n const triggerRef = React.useRef<HTMLButtonElement>(null);\n const menuContentRef = React.useRef<HTMLDivElement>(null);\n\n // When the menu opens, move keyboard focus into it so screen-reader /\n // keyboard-only users can interact with the options immediately. When\n // it closes, return focus to the trigger so Tab order picks up where\n // the user left off.\n const wasOpenRef = React.useRef(filterMenuOpen);\n React.useEffect(() => {\n if (filterMenuOpen) {\n const firstItem =\n menuContentRef.current?.querySelector<HTMLButtonElement>(\n '[role=\"menuitem\"], [role=\"menuitemradio\"]',\n );\n firstItem?.focus();\n } else if (wasOpenRef.current) {\n // Only return focus on a real open→close transition (not the\n // mount-with-open=false case).\n triggerRef.current?.focus();\n }\n wasOpenRef.current = filterMenuOpen;\n }, [filterMenuOpen]);\n\n // Roving Arrow Up/Down + Escape across the menu items. Tab still works\n // natively; Escape closes the menu and returns focus to the trigger\n // (via the effect above).\n const handleMenuKeyDown = (event: React.KeyboardEvent<HTMLDivElement>) => {\n if (event.key === \"Escape\") {\n event.preventDefault();\n setFilterMenuOpen(false);\n return;\n }\n if (event.key !== \"ArrowDown\" && event.key !== \"ArrowUp\") return;\n const container = menuContentRef.current;\n if (!container) return;\n const items = Array.from(\n container.querySelectorAll<HTMLButtonElement>(\n '[role=\"menuitem\"], [role=\"menuitemradio\"]',\n ),\n ).filter((el) => !el.disabled);\n if (items.length === 0) return;\n const currentIdx = items.indexOf(\n document.activeElement as HTMLButtonElement,\n );\n const delta = event.key === \"ArrowDown\" ? 1 : -1;\n const start = currentIdx === -1 ? 0 : currentIdx;\n const nextIdx = (start + delta + items.length) % items.length;\n event.preventDefault();\n items[nextIdx]?.focus();\n };\n\n return (\n <div ref={menuRef} className=\"relative shrink-0 pr-0.5\">\n <button\n ref={triggerRef}\n type=\"button\"\n data-testid=\"older-conversations-filter-toggle\"\n aria-label={t(I18nKey.CONVERSATION_PANEL$FILTER_LABEL)}\n aria-haspopup=\"menu\"\n aria-expanded={filterMenuOpen}\n onClick={() => setFilterMenuOpen(!filterMenuOpen)}\n className={cn(\n \"inline-flex h-7 w-7 items-center justify-center rounded-md text-[var(--oh-muted)] hover:text-white hover:bg-[var(--oh-surface-raised)]\",\n dropdownInstantColorClassName,\n )}\n >\n <ListFilter\n className=\"lucide lucide-list-filter shrink-0\"\n width={14}\n height={14}\n strokeWidth={2}\n aria-hidden\n />\n </button>\n\n {filterMenuOpen ? (\n <div\n ref={menuContentRef}\n role=\"menu\"\n aria-orientation=\"vertical\"\n aria-label={t(I18nKey.CONVERSATION_PANEL$FILTER_LABEL)}\n // `role=\"menu\"` is an interactive ARIA role, so the container\n // must be focusable to satisfy jsx-a11y. `-1` keeps it out of\n // the natural Tab order (the menu items themselves are\n // `<button>`s and tabbable on their own) but still allows the\n // open-effect to focus it / its children programmatically.\n tabIndex={-1}\n data-testid=\"older-conversations-filter-menu\"\n onKeyDown={handleMenuKeyDown}\n className={cn(\n \"absolute right-0 top-full z-50 mt-0 w-64 rounded-md border border-[var(--oh-border-subtle)] bg-tertiary px-1 py-1 text-[var(--oh-foreground)] shadow-lg\",\n dropdownMenuListClassName,\n dropdownMenuViewportScrollClassName,\n )}\n >\n <MenuHeading>{t(I18nKey.CONVERSATION_PANEL$ORGANIZE)}</MenuHeading>\n <MenuRow\n icon={Folder}\n label={groupedLabel}\n selected={organizeMode === \"grouped\"}\n onClick={() => {\n setOrganizeMode(\"grouped\");\n setFilterMenuOpen(false);\n }}\n />\n <MenuRow\n icon={Clock3}\n label={t(I18nKey.CONVERSATION_PANEL$CHRONOLOGICAL)}\n selected={organizeMode === \"chronological\"}\n onClick={() => {\n setOrganizeMode(\"chronological\");\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuHeading>{t(I18nKey.CONVERSATION_PANEL$SORT_BY)}</MenuHeading>\n <MenuRow\n icon={CalendarArrowDown}\n label={t(I18nKey.CONVERSATION_PANEL$SORT_CREATED)}\n selected={conversationSort === \"created\"}\n onClick={() => {\n setConversationSort(\"created\");\n setFilterMenuOpen(false);\n }}\n />\n <MenuRow\n icon={ClockArrowDown}\n label={t(I18nKey.CONVERSATION_PANEL$SORT_UPDATED)}\n selected={conversationSort === \"updated\"}\n onClick={() => {\n setConversationSort(\"updated\");\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuHeading>{t(I18nKey.CONVERSATION_PANEL$SHOW)}</MenuHeading>\n <MenuRow\n icon={MessageCircle}\n label={t(I18nKey.CONVERSATION_PANEL$ALL_THREADS)}\n selected={threadScope === \"all\"}\n onClick={() => {\n setThreadScope(\"all\");\n setFilterMenuOpen(false);\n }}\n />\n <MenuRow\n icon={Star}\n label={t(I18nKey.CONVERSATION_PANEL$RELEVANT_THREADS)}\n selected={threadScope === \"relevant\"}\n onClick={() => {\n setThreadScope(\"relevant\");\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuHeading>{t(I18nKey.CONVERSATION_PANEL$METADATA)}</MenuHeading>\n <MenuRow\n icon={Bot}\n label={t(I18nKey.CONVERSATION_PANEL$LLM_MODEL)}\n selected={showLlmProfiles}\n testId=\"toggle-llm-profiles\"\n onClick={() => {\n toggleShowLlmProfiles();\n setFilterMenuOpen(false);\n }}\n />\n <MenuRow\n icon={GitBranch}\n label={t(I18nKey.CONVERSATION_PANEL$REPO_BRANCH)}\n selected={showRepoBranchMetadata}\n testId=\"toggle-repo-branch-metadata\"\n onClick={() => {\n toggleShowRepoBranchMetadata();\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuHeading\n suffix={\n <span className=\"shrink-0 text-right text-[10px] font-medium normal-case tracking-normal text-[var(--oh-muted)]/70\">\n {t(I18nKey.CONVERSATION_PANEL$OLDER_OVER_ONE_HOUR)}\n </span>\n }\n >\n {t(I18nKey.CONVERSATION_PANEL$OLDER_SECTION)}\n </MenuHeading>\n <MenuRow\n testId=\"toggle-older-conversations\"\n icon={showOlderConversations ? EyeOff : Eye}\n label={\n showOlderConversations\n ? capitalizeLabel(t(I18nKey.CONVERSATION$HIDE))\n : capitalizeLabel(t(I18nKey.CONVERSATION$SHOW_ALL))\n }\n onClick={() => {\n toggleShowOlderConversations();\n setFilterMenuOpen(false);\n }}\n />\n\n <MenuSeparator />\n <MenuRow\n testId=\"delete-all-conversations\"\n icon={Trash2}\n label={capitalizeLabel(t(I18nKey.CONVERSATION$DELETE_ALL))}\n disabled={totalConversationsCount === 0}\n onClick={() => {\n if (totalConversationsCount === 0) return;\n onRequestDeleteAll();\n setFilterMenuOpen(false);\n }}\n />\n </div>\n ) : null}\n </div>\n );\n}\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- const e=require(`../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),n=require(`../../../i18n/declaration.cjs`),r=require(`../../../utils/utils.cjs`),i=require(`../../../context/navigation-context.cjs`),a=require(`../../../contexts/active-backend-context.cjs`),ee=require(`../../../node_modules/lucide-react/dist/esm/icons/folder.cjs`),te=require(`../../../node_modules/lucide-react/dist/esm/icons/plus.cjs`),o=require(`../../../utils/custom-toast-handlers.cjs`),s=require(`../../../utils/status.cjs`),c=require(`../../../hooks/use-click-outside-element.cjs`),l=require(`../../../hooks/mutation/use-create-conversation.cjs`),ne=require(`../../shared/navigation-link.cjs`),re=require(`../../../hooks/mutation/use-delete-conversation.cjs`),ie=require(`../../../hooks/mutation/use-unified-stop-conversation.cjs`),ae=require(`../../shared/loading-spinner.cjs`),oe=require(`../../../hooks/mutation/use-update-conversation.cjs`),u=require(`./confirm-delete-modal.cjs`),se=require(`./confirm-stop-modal.cjs`),ce=require(`../../../hooks/query/use-paginated-conversations.cjs`),le=require(`../../../hooks/query/use-start-tasks.cjs`),ue=require(`./exit-conversation-modal.cjs`),de=require(`../../../hooks/use-is-creating-conversation.cjs`),fe=require(`./conversation-card/conversation-card.cjs`),pe=require(`./start-task-card/start-task-card.cjs`),me=require(`./conversation-card/conversation-card-skeleton.cjs`),he=require(`./compact-conversation-row.cjs`),d=require(`../../../stores/conversation-panel-preferences-store.cjs`),ge=require(`./conversation-panel-filter-menu.cjs`),_e=require(`./conversation-panel-new-thread-picker.cjs`),f=require(`./conversation-panel-list-helpers.cjs`);let p=require(`react`);p=e.__toESM(p,1);let m=require(`react/jsx-runtime`);var ve=()=>{},h=3600*1e3,ye=e=>{let t=Date.now()-h,n=[],r=[];for(let i of e){let e=i.updated_at?Date.parse(i.updated_at):NaN;Number.isFinite(e)&&e<t?r.push(i):n.push(i)}return{recent:n,older:r}};function g({onClose:e,compact:h=!1}){let{t:g}=t.useTranslation(`openhands`),{conversationId:_,navigate:v}=i.useNavigation(),{backend:y}=a.useActiveBackend(),be=c.useClickOutsideElement(e??ve),[xe,b]=p.default.useState(!1),[Se,x]=p.default.useState(!1),[Ce,S]=p.default.useState(!1),[we,C]=p.default.useState(!1),w=d.useConversationPanelPreferencesStore(e=>e.showOlderConversations),Te=d.useConversationPanelPreferencesStore(e=>e.toggleShowOlderConversations),T=d.useConversationPanelPreferencesStore(e=>e.showRepoBranchMetadata),Ee=d.useConversationPanelPreferencesStore(e=>e.toggleShowRepoBranchMetadata),E=d.useConversationPanelPreferencesStore(e=>e.showLlmProfiles),De=d.useConversationPanelPreferencesStore(e=>e.toggleShowLlmProfiles),D=d.useConversationPanelPreferencesStore(e=>e.organizeMode),Oe=d.useConversationPanelPreferencesStore(e=>e.setOrganizeMode),O=d.useConversationPanelPreferencesStore(e=>e.conversationSort),ke=d.useConversationPanelPreferencesStore(e=>e.setConversationSort),k=d.useConversationPanelPreferencesStore(e=>e.threadScope),Ae=d.useConversationPanelPreferencesStore(e=>e.setThreadScope),[je,A]=p.default.useState(!1),[Me,Ne]=p.default.useState(!1),Pe=c.useClickOutsideElement(()=>{A(!1)}),[Fe,j]=p.default.useState(()=>new Set),[Ie,M]=p.default.useState(()=>new Set),Le=p.default.useCallback(e=>{j(t=>{let n=new Set(t);return n.has(e)?n.delete(e):n.add(e),n})},[]),Re=p.default.useCallback(e=>{M(t=>{let n=new Set(t);return n.has(e)?n.delete(e):n.add(e),n})},[]);p.default.useEffect(()=>{D!==`grouped`&&(j(new Set),M(new Set))},[D]);let ze=p.default.useRef(null),[N,P]=p.default.useState(null),[Be,F]=p.default.useState(null),[Ve,He]=p.default.useState(null),{data:I,isLoading:L,isFetched:R,hasNextPage:Ue,isFetchingNextPage:We,fetchNextPage:Ge}=ce.usePaginatedConversations(),{data:z}=le.useStartTasks(),B=p.default.useMemo(()=>I?.pages.flatMap(e=>e.items)??[],[I]),V=p.default.useMemo(()=>k===`relevant`?B.filter(e=>s.isExecutionActive(e.execution_status)):B,[B,k]),{recent:H,older:U}=p.default.useMemo(()=>ye(V),[V]),W=p.default.useMemo(()=>f.sortConversationsByField(w?[...H,...U]:H,O),[H,U,w,O]),G=p.default.useMemo(()=>({emptyWorkspace:g(n.I18nKey.CONVERSATION_PANEL$NO_WORKSPACE),emptyRepository:g(n.I18nKey.CONVERSATION_PANEL$NO_REPOSITORY)}),[g]),K=p.default.useMemo(()=>h||D!==`grouped`?null:f.groupConversations([...H,...w?U:[]],y.kind,O,G),[y.kind,h,O,G,U,D,H,w]),Ke=p.default.useMemo(()=>f.sortConversationsByField(H.filter(e=>s.isExecutionActive(e.execution_status)),O),[O,H]),qe=W.length,Je=p.default.useMemo(()=>K?K.reduce((e,t)=>e+t.conversations.length,0):0,[K]),q=D===`grouped`&&!h?Je===0:qe===0,{mutate:Ye,mutateAsync:Xe}=re.useDeleteConversation(),{mutate:Ze}=ie.useUnifiedPauseConversation(),{mutate:J}=oe.useUpdateConversation(),Qe=U.length>0&&!w,$e=!!Ue&&!Qe&&!h&&!q,{mutate:Y}=l.useCreateConversation(),X=de.useIsCreatingConversation(),et=p.default.useCallback(e=>{X||Y({workingDir:e.workingDir,repository:e.repository},{onSuccess:e=>{v(`/conversations/${e.conversation_id}`)}})},[Y,X,v]),Z=p.default.useCallback((e,t)=>{b(!0),P(e),F(t)},[]),tt=p.default.useCallback(e=>{x(!0),P(e)},[]),nt=p.default.useCallback((e,t)=>{J({conversationId:e,newTitle:t},{onSuccess:()=>{o.displaySuccessToast(g(n.I18nKey.CONVERSATION$TITLE_UPDATED))}})},[g,J]),rt=()=>{N&&Ye({conversationId:N},{onSuccess:()=>{N===_&&v(`/conversations`)}})},it=()=>{N&&Ze({conversationId:N})},at=async()=>{let e=B.map(e=>e.id),t=await Promise.allSettled(e.map(e=>Xe({conversationId:e}))),n=t.flatMap((t,n)=>t.status===`fulfilled`?[e[n]]:[]),r=t.length-n.length;_!==null&&n.includes(_)&&v(`/conversations`),r>0&&o.displayErrorToast(`${r} conversation${r===1?``:`s`} could not be deleted.`)},Q=p.default.useCallback(t=>h?(0,m.jsx)(he.CompactConversationRow,{conversationId:t.id,title:t.title??``,selectedRepository:{selected_repository:t.selected_repository,selected_branch:t.selected_branch,git_provider:t.git_provider},executionStatus:t.execution_status,sandboxStatus:t.sandbox_status,lastUpdatedAt:t.updated_at,createdAt:t.created_at,workspaceWorkingDir:t.selected_workspace??t.workspace?.working_dir,isActive:t.id===_,onClose:e,showRepositoryMetadata:T,llmModel:t.llm_model,showLlmProfiles:E,agentKind:t.agent_kind,acpServer:t.acp_server},t.id):(0,m.jsx)(ne.NavigationLink,{to:`/conversations/${t.id}`,onClick:e,className:`block`,children:(0,m.jsx)(fe.ConversationCard,{onDelete:()=>Z(t.id,t.title??``),onStop:()=>tt(t.id),onChangeTitle:e=>nt(t.id,e),title:t.title??``,selectedRepository:{selected_repository:t.selected_repository,selected_branch:t.selected_branch,git_provider:t.git_provider},lastUpdatedAt:t.updated_at,createdAt:t.created_at,executionStatus:t.execution_status,sandboxStatus:t.sandbox_status,conversationId:t.id,contextMenuOpen:Ve===t.id,onContextMenuToggle:e=>He(e?t.id:null),isActive:t.id===_,workspaceWorkingDir:t.selected_workspace??t.workspace?.working_dir,showRepositoryMetadata:T,llmModel:t.llm_model,showLlmProfiles:E,agentKind:t.agent_kind,acpServer:t.acp_server})},t.id),[h,_,nt,Z,tt,e,Ve,T,E]),$=L||!R,ot=R&&!L&&!h&&q&&!z?.length;return(0,m.jsxs)(`div`,{ref:be,"data-testid":`conversation-panel`,className:`flex h-full min-h-0 w-full flex-col`,children:[!h&&(0,m.jsx)(`div`,{className:r.cn(`-ml-2.5 w-[calc(100%+0.625rem)] max-w-none box-border border-b`,Me?`border-[var(--oh-border)]`:`border-transparent`),children:(0,m.jsxs)(`div`,{"data-testid":`older-conversations-summary`,className:`flex min-w-0 flex-nowrap items-center gap-x-2 py-2 pl-4 pr-2.5 text-[var(--oh-muted)]`,children:[(0,m.jsx)(`span`,{className:`min-w-0 truncate text-sm font-medium text-[var(--oh-muted)]`,children:g(n.I18nKey.SIDEBAR$CONVERSATIONS)}),(0,m.jsxs)(`div`,{className:`ml-auto flex shrink-0 items-center gap-0.5`,children:[(0,m.jsx)(_e.ConversationPanelNewThreadPicker,{backendKind:y.kind}),(0,m.jsx)(ge.ConversationPanelFilterMenu,{filterMenuOpen:je,setFilterMenuOpen:A,menuRef:Pe,backendKind:y.kind,organizeMode:D,setOrganizeMode:Oe,conversationSort:O,setConversationSort:ke,threadScope:k,setThreadScope:Ae,showOlderConversations:w,toggleShowOlderConversations:Te,showRepoBranchMetadata:T,toggleShowRepoBranchMetadata:Ee,showLlmProfiles:E,toggleShowLlmProfiles:De,totalConversationsCount:B.length,onRequestDeleteAll:()=>C(!0)})]})]})}),(0,m.jsxs)(`div`,{ref:ze,"data-testid":`conversation-panel-list-scroll`,onScroll:e=>{Ne(e.currentTarget.scrollTop>0)},className:r.cn(`flex min-h-0 flex-1 flex-col overflow-y-auto overflow-x-hidden overscroll-contain custom-scrollbar-always`,!h&&`conversation-panel-list-scroll`),children:[$&&(0,m.jsx)(me.ConversationCardSkeleton,{compact:h}),!h&&ot&&(0,m.jsx)(`div`,{"data-testid":`conversation-panel-empty-state`,className:`flex min-h-0 flex-1 flex-col items-center justify-center px-4 py-8`,children:(0,m.jsx)(`p`,{className:`text-xs text-[var(--oh-muted)]`,children:g(n.I18nKey.CONVERSATION$NO_CONVERSATIONS)})}),!h&&z?.map(t=>(0,m.jsx)(ne.NavigationLink,{to:`/conversations/task-${t.id}`,onClick:e,className:`block`,children:(0,m.jsx)(pe.StartTaskCard,{task:t})},t.id)),!$&&h?Ke.map(Q):null,!$&&!h&&D===`grouped`&&K&&K.length>0?(0,m.jsx)(`nav`,{"aria-label":g(n.I18nKey.SIDEBAR$CONVERSATIONS),className:`space-y-1 md:space-y-0.5 pb-1`,children:K.map(e=>{let t=`thread-folder-${e.id.replace(/[^a-zA-Z0-9_-]/g,`-`)}`,i=e.id.replace(/[^a-zA-Z0-9_-]/g,`-`),a=!Fe.has(e.id),o=Ie.has(e.id),{visibleConversations:s,isPreviewTruncated:c,isShowingAll:l}=f.getGroupConversationPreview(e.conversations,{expanded:o,activeConversationId:_});return(0,m.jsxs)(`section`,{"aria-labelledby":t,children:[(0,m.jsxs)(`div`,{className:r.cn(`flex h-8 w-full min-w-0 items-center gap-0.5 rounded-md pl-2 pr-1 text-sm font-normal`,`text-[var(--oh-muted)] transition-colors`,`hover:bg-[var(--oh-surface-raised)] hover:text-white`),children:[(0,m.jsxs)(`button`,{type:`button`,id:t,"aria-expanded":a,onClick:()=>Le(e.id),className:`flex min-h-8 min-w-0 flex-1 items-center gap-2 rounded-md py-1 text-left text-inherit outline-none transition-colors focus-visible:ring-1 focus-visible:ring-[var(--oh-border)]`,children:[(0,m.jsx)(ee.Folder,{className:`h-4 w-4 shrink-0`,"aria-hidden":!0}),(0,m.jsx)(`span`,{className:`truncate`,children:e.label})]}),(0,m.jsx)(`button`,{type:`button`,className:r.cn(`inline-flex h-6 w-6 shrink-0 cursor-pointer items-center justify-center rounded-md`,`text-inherit transition-colors`,`hover:bg-white/10 hover:text-white`,`focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-[var(--oh-border)]`,`disabled:cursor-not-allowed disabled:opacity-50`),disabled:X,"aria-label":g(n.I18nKey.CONVERSATION_PANEL$ADD_CONVERSATION_TO_GROUP,{label:e.label}),"data-testid":`add-conversation-to-group-${e.id.replace(/[^a-zA-Z0-9_-]/g,`-`)}`,onClick:t=>{t.preventDefault(),t.stopPropagation(),et(e.launch)},children:(0,m.jsx)(te.Plus,{className:`h-3.5 w-3.5 shrink-0`,"aria-hidden":!0,strokeWidth:2})})]}),a?(0,m.jsxs)(`div`,{className:`mt-0.5 space-y-0.5`,children:[s.map(Q),c?(0,m.jsx)(`div`,{className:`pl-2`,children:(0,m.jsx)(`button`,{type:`button`,"data-testid":`thread-folder-view-more-${i}`,onClick:()=>Re(e.id),className:`ml-[26px] cursor-pointer text-xs text-[var(--oh-text-dim)] hover:text-white`,children:g(l?n.I18nKey.CONVERSATION_PANEL$LESS:n.I18nKey.CONVERSATION_PANEL$MORE)})}):null]}):null]},e.id)})}):null,!$&&!h&&D===`chronological`?(0,m.jsx)(`div`,{className:`space-y-0.5`,children:W.map(Q)}):null,$e&&(0,m.jsx)(`div`,{className:`flex justify-center py-4`,children:We?(0,m.jsx)(ae.LoadingSpinner,{size:`small`}):(0,m.jsx)(`button`,{type:`button`,"data-testid":`load-more-conversations`,onClick:()=>Ge(),className:`text-xs text-[var(--oh-muted)] hover:text-white`,children:g(n.I18nKey.CONVERSATION$LOAD_MORE)})})]}),xe&&(0,m.jsx)(u.ConfirmDeleteModal,{onConfirm:()=>{rt(),b(!1),F(null)},onCancel:()=>{b(!1),F(null)},conversationTitle:Be??void 0}),we&&(0,m.jsx)(u.ConfirmDeleteModal,{title:g(n.I18nKey.CONVERSATION$CONFIRM_DELETE_ALL_TITLE),description:g(n.I18nKey.CONVERSATION$CONFIRM_DELETE_ALL_DESC,{count:B.length}),onConfirm:async()=>{await at(),C(!1)},onCancel:()=>C(!1)}),Se&&(0,m.jsx)(se.ConfirmStopModal,{onConfirm:()=>{it(),x(!1)},onCancel:()=>x(!1)}),Ce&&(0,m.jsx)(ue.ExitConversationModal,{onConfirm:()=>{e?.()},onClose:()=>S(!1),onCancel:()=>S(!1)})]})}exports.ConversationPanel=g;
1
+ const e=require(`../../../_virtual/_rolldown/runtime.cjs`),t=require(`../../../node_modules/react-i18next/dist/es/useTranslation.cjs`),n=require(`../../../i18n/declaration.cjs`),r=require(`../../../utils/status.cjs`),i=require(`../../../utils/utils.cjs`),a=require(`../../../context/navigation-context.cjs`),o=require(`../../../contexts/active-backend-context.cjs`),ee=require(`../../../node_modules/lucide-react/dist/esm/icons/folder.cjs`),te=require(`../../../node_modules/lucide-react/dist/esm/icons/plus.cjs`),s=require(`../../../utils/custom-toast-handlers.cjs`),c=require(`../../../hooks/use-click-outside-element.cjs`),l=require(`../../../hooks/mutation/use-create-conversation.cjs`),ne=require(`../../shared/navigation-link.cjs`),re=require(`../../../hooks/mutation/use-delete-conversation.cjs`),ie=require(`../../../hooks/mutation/use-unified-stop-conversation.cjs`),ae=require(`../../shared/loading-spinner.cjs`),oe=require(`../../../hooks/mutation/use-update-conversation.cjs`),u=require(`./confirm-delete-modal.cjs`),se=require(`./confirm-stop-modal.cjs`),ce=require(`../../../hooks/query/use-paginated-conversations.cjs`),le=require(`../../../hooks/query/use-start-tasks.cjs`),ue=require(`./exit-conversation-modal.cjs`),de=require(`../../../hooks/use-is-creating-conversation.cjs`),fe=require(`./conversation-card/conversation-card.cjs`),pe=require(`./start-task-card/start-task-card.cjs`),me=require(`./conversation-card/conversation-card-skeleton.cjs`),he=require(`./compact-conversation-row.cjs`),d=require(`../../../stores/conversation-panel-preferences-store.cjs`),ge=require(`./conversation-panel-filter-menu.cjs`),_e=require(`./conversation-panel-new-thread-picker.cjs`),f=require(`./conversation-panel-list-helpers.cjs`);let p=require(`react`);p=e.__toESM(p,1);let m=require(`react/jsx-runtime`);var ve=()=>{},h=3600*1e3,ye=e=>{let t=Date.now()-h,n=[],r=[];for(let i of e){let e=i.updated_at?Date.parse(i.updated_at):NaN;Number.isFinite(e)&&e<t?r.push(i):n.push(i)}return{recent:n,older:r}};function g({onClose:e,compact:h=!1}){let{t:g}=t.useTranslation(`openhands`),{conversationId:_,navigate:v}=a.useNavigation(),{backend:y}=o.useActiveBackend(),be=c.useClickOutsideElement(e??ve),[xe,b]=p.default.useState(!1),[Se,x]=p.default.useState(!1),[Ce,S]=p.default.useState(!1),[we,C]=p.default.useState(!1),w=d.useConversationPanelPreferencesStore(e=>e.showOlderConversations),Te=d.useConversationPanelPreferencesStore(e=>e.toggleShowOlderConversations),T=d.useConversationPanelPreferencesStore(e=>e.showRepoBranchMetadata),Ee=d.useConversationPanelPreferencesStore(e=>e.toggleShowRepoBranchMetadata),E=d.useConversationPanelPreferencesStore(e=>e.showLlmProfiles),De=d.useConversationPanelPreferencesStore(e=>e.toggleShowLlmProfiles),D=d.useConversationPanelPreferencesStore(e=>e.organizeMode),Oe=d.useConversationPanelPreferencesStore(e=>e.setOrganizeMode),O=d.useConversationPanelPreferencesStore(e=>e.conversationSort),ke=d.useConversationPanelPreferencesStore(e=>e.setConversationSort),k=d.useConversationPanelPreferencesStore(e=>e.threadScope),Ae=d.useConversationPanelPreferencesStore(e=>e.setThreadScope),[je,A]=p.default.useState(!1),[Me,Ne]=p.default.useState(!1),Pe=c.useClickOutsideElement(()=>{A(!1)}),[Fe,j]=p.default.useState(()=>new Set),[Ie,M]=p.default.useState(()=>new Set),Le=p.default.useCallback(e=>{j(t=>{let n=new Set(t);return n.has(e)?n.delete(e):n.add(e),n})},[]),Re=p.default.useCallback(e=>{M(t=>{let n=new Set(t);return n.has(e)?n.delete(e):n.add(e),n})},[]);p.default.useEffect(()=>{D!==`grouped`&&(j(new Set),M(new Set))},[D]);let ze=p.default.useRef(null),[N,Be]=p.default.useState(null),[Ve,P]=p.default.useState(null),[F,He]=p.default.useState(null),{data:I,isLoading:L,isFetched:R,hasNextPage:Ue,isFetchingNextPage:We,fetchNextPage:Ge}=ce.usePaginatedConversations(),{data:z}=le.useStartTasks(),B=p.default.useMemo(()=>I?.pages.flatMap(e=>e.items)??[],[I]),V=p.default.useMemo(()=>k===`relevant`?B.filter(e=>r.isExecutionActive(e.execution_status)):B,[B,k]),{recent:H,older:U}=p.default.useMemo(()=>ye(V),[V]),W=p.default.useMemo(()=>f.sortConversationsByField(w?[...H,...U]:H,O),[H,U,w,O]),G=p.default.useMemo(()=>({emptyWorkspace:g(n.I18nKey.CONVERSATION_PANEL$NO_WORKSPACE),emptyRepository:g(n.I18nKey.CONVERSATION_PANEL$NO_REPOSITORY)}),[g]),K=p.default.useMemo(()=>h||D!==`grouped`?null:f.groupConversations([...H,...w?U:[]],y.kind,O,G),[y.kind,h,O,G,U,D,H,w]),Ke=p.default.useMemo(()=>f.sortConversationsByField(H.filter(e=>r.isExecutionActive(e.execution_status)),O),[O,H]),qe=W.length,Je=p.default.useMemo(()=>K?K.reduce((e,t)=>e+t.conversations.length,0):0,[K]),q=D===`grouped`&&!h?Je===0:qe===0,{mutate:Ye,mutateAsync:Xe}=re.useDeleteConversation(),{mutate:Ze}=ie.useUnifiedPauseConversation(),{mutate:J}=oe.useUpdateConversation(),Qe=U.length>0&&!w,$e=!!Ue&&!Qe&&!h&&!q,{mutate:Y}=l.useCreateConversation(),X=de.useIsCreatingConversation(),et=p.default.useCallback(e=>{X||Y({workingDir:e.workingDir,repository:e.repository},{onSuccess:e=>{v(`/conversations/${e.conversation_id}`)}})},[Y,X,v]),Z=p.default.useCallback((e,t)=>{b(!0),Be(e),P(t)},[]),tt=p.default.useCallback(e=>{x(!0),Be(e)},[]),nt=p.default.useCallback((e,t)=>{J({conversationId:e,newTitle:t},{onSuccess:()=>{s.displaySuccessToast(g(n.I18nKey.CONVERSATION$TITLE_UPDATED))}})},[g,J]),rt=()=>{N&&Ye({conversationId:N},{onSuccess:()=>{N===_&&v(`/conversations`)}})},it=()=>{N&&Ze({conversationId:N})},at=async()=>{let e=B.map(e=>e.id),t=await Promise.allSettled(e.map(e=>Xe({conversationId:e}))),n=t.flatMap((t,n)=>t.status===`fulfilled`?[e[n]]:[]),r=t.length-n.length;_!==null&&n.includes(_)&&v(`/conversations`),r>0&&s.displayErrorToast(`${r} conversation${r===1?``:`s`} could not be deleted.`)},Q=p.default.useCallback(t=>h?(0,m.jsx)(he.CompactConversationRow,{conversationId:t.id,title:t.title??``,selectedRepository:{selected_repository:t.selected_repository,selected_branch:t.selected_branch,git_provider:t.git_provider},executionStatus:t.execution_status,sandboxStatus:t.sandbox_status,lastUpdatedAt:t.updated_at,createdAt:t.created_at,workspaceWorkingDir:t.selected_workspace??t.workspace?.working_dir,isActive:t.id===_,onClose:e,showRepositoryMetadata:T,llmModel:t.llm_model,showLlmProfiles:E,agentKind:t.agent_kind,acpServer:t.acp_server},t.id):(0,m.jsx)(ne.NavigationLink,{to:`/conversations/${t.id}`,onClick:e,className:`block`,children:(0,m.jsx)(fe.ConversationCard,{onDelete:()=>Z(t.id,t.title??``),onStop:()=>tt(t.id),onChangeTitle:e=>nt(t.id,e),title:t.title??``,selectedRepository:{selected_repository:t.selected_repository,selected_branch:t.selected_branch,git_provider:t.git_provider},lastUpdatedAt:t.updated_at,createdAt:t.created_at,executionStatus:t.execution_status,sandboxStatus:t.sandbox_status,conversationId:t.id,contextMenuOpen:F===t.id,onContextMenuToggle:e=>He(e?t.id:null),isActive:t.id===_,workspaceWorkingDir:t.selected_workspace??t.workspace?.working_dir,showRepositoryMetadata:T,llmModel:t.llm_model,showLlmProfiles:E,agentKind:t.agent_kind,acpServer:t.acp_server})},t.id),[h,_,nt,Z,tt,e,F,T,E]),$=L||!R,ot=R&&!L&&!h&&q&&!z?.length;return(0,m.jsxs)(`div`,{ref:be,"data-testid":`conversation-panel`,className:`flex h-full min-h-0 w-full flex-col`,children:[!h&&(0,m.jsx)(`div`,{className:i.cn(`-ml-2.5 w-[calc(100%+0.625rem)] max-w-none box-border border-b`,Me?`border-[var(--oh-border)]`:`border-transparent`),children:(0,m.jsxs)(`div`,{"data-testid":`older-conversations-summary`,className:`flex min-w-0 flex-nowrap items-center gap-x-2 py-2 pl-4 pr-2.5 text-[var(--oh-muted)]`,children:[(0,m.jsx)(`span`,{className:`min-w-0 truncate text-sm font-medium text-[var(--oh-muted)]`,children:g(n.I18nKey.SIDEBAR$CONVERSATIONS)}),(0,m.jsxs)(`div`,{className:`ml-auto flex shrink-0 items-center gap-0.5`,children:[(0,m.jsx)(_e.ConversationPanelNewThreadPicker,{backendKind:y.kind}),(0,m.jsx)(ge.ConversationPanelFilterMenu,{filterMenuOpen:je,setFilterMenuOpen:A,menuRef:Pe,backendKind:y.kind,organizeMode:D,setOrganizeMode:Oe,conversationSort:O,setConversationSort:ke,threadScope:k,setThreadScope:Ae,showOlderConversations:w,toggleShowOlderConversations:Te,showRepoBranchMetadata:T,toggleShowRepoBranchMetadata:Ee,showLlmProfiles:E,toggleShowLlmProfiles:De,totalConversationsCount:B.length,onRequestDeleteAll:()=>C(!0)})]})]})}),(0,m.jsxs)(`div`,{ref:ze,"data-testid":`conversation-panel-list-scroll`,onScroll:e=>{Ne(e.currentTarget.scrollTop>0)},className:i.cn(`flex min-h-0 flex-1 flex-col overflow-y-auto overflow-x-hidden overscroll-contain custom-scrollbar-always`,!h&&`conversation-panel-list-scroll`),children:[$&&(0,m.jsx)(me.ConversationCardSkeleton,{compact:h}),!h&&ot&&(0,m.jsx)(`div`,{"data-testid":`conversation-panel-empty-state`,className:`flex min-h-0 flex-1 flex-col items-center justify-center px-4 py-8`,children:(0,m.jsx)(`p`,{className:`text-xs text-[var(--oh-muted)]`,children:g(n.I18nKey.CONVERSATION$NO_CONVERSATIONS)})}),!h&&z?.map(t=>(0,m.jsx)(ne.NavigationLink,{to:`/conversations/task-${t.id}`,onClick:e,className:`block`,children:(0,m.jsx)(pe.StartTaskCard,{task:t})},t.id)),!$&&h?Ke.map(Q):null,!$&&!h&&D===`grouped`&&K&&K.length>0?(0,m.jsx)(`nav`,{"aria-label":g(n.I18nKey.SIDEBAR$CONVERSATIONS),className:`space-y-1 md:space-y-0.5 pb-1`,children:K.map(e=>{let t=`thread-folder-${e.id.replace(/[^a-zA-Z0-9_-]/g,`-`)}`,r=e.id.replace(/[^a-zA-Z0-9_-]/g,`-`),a=!Fe.has(e.id),o=Ie.has(e.id),{visibleConversations:s,isPreviewTruncated:c,isShowingAll:l}=f.getGroupConversationPreview(e.conversations,{expanded:o,activeConversationId:_});return(0,m.jsxs)(`section`,{"aria-labelledby":t,children:[(0,m.jsxs)(`div`,{className:i.cn(`flex h-8 w-full min-w-0 items-center gap-0.5 rounded-md pl-2 pr-1 text-sm font-normal`,`text-[var(--oh-muted)] transition-colors`,`hover:bg-[var(--oh-surface-raised)] hover:text-white`),children:[(0,m.jsxs)(`button`,{type:`button`,id:t,"aria-expanded":a,onClick:()=>Le(e.id),className:`flex min-h-8 min-w-0 flex-1 items-center gap-2 rounded-md py-1 text-left text-inherit outline-none transition-colors focus-visible:ring-1 focus-visible:ring-[var(--oh-border)]`,children:[(0,m.jsx)(ee.Folder,{className:`h-4 w-4 shrink-0`,"aria-hidden":!0}),(0,m.jsx)(`span`,{className:`truncate`,children:e.label})]}),(0,m.jsx)(`button`,{type:`button`,className:i.cn(`inline-flex h-6 w-6 shrink-0 cursor-pointer items-center justify-center rounded-md`,`text-inherit transition-colors`,`hover:bg-white/10 hover:text-white`,`focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-[var(--oh-border)]`,`disabled:cursor-not-allowed disabled:opacity-50`),disabled:X,"aria-label":g(n.I18nKey.CONVERSATION_PANEL$ADD_CONVERSATION_TO_GROUP,{label:e.label}),"data-testid":`add-conversation-to-group-${e.id.replace(/[^a-zA-Z0-9_-]/g,`-`)}`,onClick:t=>{t.preventDefault(),t.stopPropagation(),et(e.launch)},children:(0,m.jsx)(te.Plus,{className:`h-3.5 w-3.5 shrink-0`,"aria-hidden":!0,strokeWidth:2})})]}),a?(0,m.jsxs)(`div`,{className:`mt-0.5 space-y-0.5`,children:[s.map(Q),c?(0,m.jsx)(`div`,{className:`pl-2`,children:(0,m.jsx)(`button`,{type:`button`,"data-testid":`thread-folder-view-more-${r}`,onClick:()=>Re(e.id),className:`ml-[26px] cursor-pointer text-xs text-[var(--oh-text-dim)] hover:text-white`,children:g(l?n.I18nKey.CONVERSATION_PANEL$LESS:n.I18nKey.CONVERSATION_PANEL$MORE)})}):null]}):null]},e.id)})}):null,!$&&!h&&D===`chronological`?(0,m.jsx)(`div`,{className:`space-y-0.5`,children:W.map(Q)}):null,$e&&(0,m.jsx)(`div`,{className:`flex justify-center py-4`,children:We?(0,m.jsx)(ae.LoadingSpinner,{size:`small`}):(0,m.jsx)(`button`,{type:`button`,"data-testid":`load-more-conversations`,onClick:()=>Ge(),className:`text-xs text-[var(--oh-muted)] hover:text-white`,children:g(n.I18nKey.CONVERSATION$LOAD_MORE)})})]}),xe&&(0,m.jsx)(u.ConfirmDeleteModal,{onConfirm:()=>{rt(),b(!1),P(null)},onCancel:()=>{b(!1),P(null)},conversationTitle:Ve??void 0}),we&&(0,m.jsx)(u.ConfirmDeleteModal,{title:g(n.I18nKey.CONVERSATION$CONFIRM_DELETE_ALL_TITLE),description:g(n.I18nKey.CONVERSATION$CONFIRM_DELETE_ALL_DESC,{count:B.length}),onConfirm:async()=>{await at(),C(!1)},onCancel:()=>C(!1)}),Se&&(0,m.jsx)(se.ConfirmStopModal,{onConfirm:()=>{it(),x(!1)},onCancel:()=>x(!1)}),Ce&&(0,m.jsx)(ue.ExitConversationModal,{onConfirm:()=>{e?.()},onClose:()=>S(!1),onCancel:()=>S(!1)})]})}exports.ConversationPanel=g;
2
2
  //# sourceMappingURL=conversation-panel.cjs.map