@shepai/cli 1.152.0 → 1.153.0

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 (209) hide show
  1. package/dist/packages/core/src/application/ports/output/repositories/interactive-session-repository.interface.d.ts +5 -0
  2. package/dist/packages/core/src/application/ports/output/repositories/interactive-session-repository.interface.d.ts.map +1 -1
  3. package/dist/packages/core/src/application/ports/output/services/interactive-session-service.interface.d.ts +5 -0
  4. package/dist/packages/core/src/application/ports/output/services/interactive-session-service.interface.d.ts.map +1 -1
  5. package/dist/packages/core/src/infrastructure/repositories/sqlite-interactive-session.repository.d.ts +1 -0
  6. package/dist/packages/core/src/infrastructure/repositories/sqlite-interactive-session.repository.d.ts.map +1 -1
  7. package/dist/packages/core/src/infrastructure/repositories/sqlite-interactive-session.repository.js +15 -0
  8. package/dist/packages/core/src/infrastructure/services/agents/common/executors/claude-code-interactive-executor.service.d.ts.map +1 -1
  9. package/dist/packages/core/src/infrastructure/services/agents/common/executors/claude-code-interactive-executor.service.js +8 -0
  10. package/dist/packages/core/src/infrastructure/services/interactive/interactive-session.service.d.ts +1 -0
  11. package/dist/packages/core/src/infrastructure/services/interactive/interactive-session.service.d.ts.map +1 -1
  12. package/dist/packages/core/src/infrastructure/services/interactive/interactive-session.service.js +51 -5
  13. package/dist/src/presentation/web/app/api/interactive/chat/turn-statuses/route.d.ts +4 -5
  14. package/dist/src/presentation/web/app/api/interactive/chat/turn-statuses/route.d.ts.map +1 -1
  15. package/dist/src/presentation/web/app/api/interactive/chat/turn-statuses/route.js +5 -13
  16. package/dist/src/presentation/web/components/common/floating-action-button/floating-action-button.d.ts +8 -2
  17. package/dist/src/presentation/web/components/common/floating-action-button/floating-action-button.d.ts.map +1 -1
  18. package/dist/src/presentation/web/components/common/floating-action-button/floating-action-button.js +10 -7
  19. package/dist/src/presentation/web/components/common/repository-node/repository-node.d.ts.map +1 -1
  20. package/dist/src/presentation/web/components/common/repository-node/repository-node.js +2 -3
  21. package/dist/src/presentation/web/components/features/chat/ChatSheet.d.ts.map +1 -1
  22. package/dist/src/presentation/web/components/features/chat/ChatSheet.js +43 -30
  23. package/dist/src/presentation/web/components/features/control-center/control-center-inner.d.ts.map +1 -1
  24. package/dist/src/presentation/web/components/features/control-center/control-center-inner.js +66 -3
  25. package/dist/src/presentation/web/components/features/features-canvas/canvas-toolbar.d.ts +1 -6
  26. package/dist/src/presentation/web/components/features/features-canvas/canvas-toolbar.d.ts.map +1 -1
  27. package/dist/src/presentation/web/components/features/features-canvas/canvas-toolbar.js +5 -6
  28. package/dist/src/presentation/web/components/features/features-canvas/features-canvas.js +1 -1
  29. package/dist/src/presentation/web/components/layouts/app-shell/app-shell.d.ts.map +1 -1
  30. package/dist/src/presentation/web/components/layouts/app-shell/app-shell.js +9 -5
  31. package/dist/src/presentation/web/hooks/turn-statuses-provider.d.ts +4 -8
  32. package/dist/src/presentation/web/hooks/turn-statuses-provider.d.ts.map +1 -1
  33. package/dist/src/presentation/web/hooks/turn-statuses-provider.js +4 -4
  34. package/dist/src/presentation/web/hooks/use-turn-statuses.d.ts +4 -5
  35. package/dist/src/presentation/web/hooks/use-turn-statuses.d.ts.map +1 -1
  36. package/dist/src/presentation/web/hooks/use-turn-statuses.js +7 -12
  37. package/dist/tsconfig.build.tsbuildinfo +1 -1
  38. package/package.json +1 -1
  39. package/web/.next/BUILD_ID +1 -1
  40. package/web/.next/build-manifest.json +2 -2
  41. package/web/.next/fallback-build-manifest.json +2 -2
  42. package/web/.next/prerender-manifest.json +3 -3
  43. package/web/.next/required-server-files.js +2 -2
  44. package/web/.next/required-server-files.json +2 -2
  45. package/web/.next/server/app/(dashboard)/@drawer/adopt/page/server-reference-manifest.json +28 -28
  46. package/web/.next/server/app/(dashboard)/@drawer/adopt/page.js.nft.json +1 -1
  47. package/web/.next/server/app/(dashboard)/@drawer/adopt/page_client-reference-manifest.js +1 -1
  48. package/web/.next/server/app/(dashboard)/@drawer/chat/page/server-reference-manifest.json +26 -26
  49. package/web/.next/server/app/(dashboard)/@drawer/chat/page.js.nft.json +1 -1
  50. package/web/.next/server/app/(dashboard)/@drawer/chat/page_client-reference-manifest.js +1 -1
  51. package/web/.next/server/app/(dashboard)/@drawer/create/page/server-reference-manifest.json +29 -29
  52. package/web/.next/server/app/(dashboard)/@drawer/create/page.js.nft.json +1 -1
  53. package/web/.next/server/app/(dashboard)/@drawer/create/page_client-reference-manifest.js +1 -1
  54. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page/server-reference-manifest.json +36 -36
  55. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page.js.nft.json +1 -1
  56. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page_client-reference-manifest.js +1 -1
  57. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page/server-reference-manifest.json +36 -36
  58. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page.js.nft.json +1 -1
  59. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page_client-reference-manifest.js +1 -1
  60. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page/server-reference-manifest.json +26 -26
  61. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page.js.nft.json +1 -1
  62. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page_client-reference-manifest.js +1 -1
  63. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page/server-reference-manifest.json +26 -26
  64. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page.js.nft.json +1 -1
  65. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page_client-reference-manifest.js +1 -1
  66. package/web/.next/server/app/(dashboard)/chat/page/server-reference-manifest.json +26 -26
  67. package/web/.next/server/app/(dashboard)/chat/page.js.nft.json +1 -1
  68. package/web/.next/server/app/(dashboard)/chat/page_client-reference-manifest.js +1 -1
  69. package/web/.next/server/app/(dashboard)/create/page/server-reference-manifest.json +29 -29
  70. package/web/.next/server/app/(dashboard)/create/page.js.nft.json +1 -1
  71. package/web/.next/server/app/(dashboard)/create/page_client-reference-manifest.js +1 -1
  72. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page/server-reference-manifest.json +36 -36
  73. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page.js.nft.json +1 -1
  74. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page_client-reference-manifest.js +1 -1
  75. package/web/.next/server/app/(dashboard)/feature/[featureId]/page/server-reference-manifest.json +36 -36
  76. package/web/.next/server/app/(dashboard)/feature/[featureId]/page.js.nft.json +1 -1
  77. package/web/.next/server/app/(dashboard)/feature/[featureId]/page_client-reference-manifest.js +1 -1
  78. package/web/.next/server/app/(dashboard)/page/server-reference-manifest.json +26 -26
  79. package/web/.next/server/app/(dashboard)/page.js.nft.json +1 -1
  80. package/web/.next/server/app/(dashboard)/page_client-reference-manifest.js +1 -1
  81. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page/server-reference-manifest.json +26 -26
  82. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page.js.nft.json +1 -1
  83. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page_client-reference-manifest.js +1 -1
  84. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page/server-reference-manifest.json +26 -26
  85. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page.js.nft.json +1 -1
  86. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page_client-reference-manifest.js +1 -1
  87. package/web/.next/server/app/_global-error.html +2 -2
  88. package/web/.next/server/app/_global-error.rsc +1 -1
  89. package/web/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  90. package/web/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  91. package/web/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  92. package/web/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  93. package/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  94. package/web/.next/server/app/_not-found/page/server-reference-manifest.json +5 -5
  95. package/web/.next/server/app/_not-found/page.js.nft.json +1 -1
  96. package/web/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  97. package/web/.next/server/app/settings/page/server-reference-manifest.json +8 -8
  98. package/web/.next/server/app/settings/page.js.nft.json +1 -1
  99. package/web/.next/server/app/settings/page_client-reference-manifest.js +1 -1
  100. package/web/.next/server/app/skills/page/server-reference-manifest.json +10 -10
  101. package/web/.next/server/app/skills/page.js.nft.json +1 -1
  102. package/web/.next/server/app/skills/page_client-reference-manifest.js +1 -1
  103. package/web/.next/server/app/tools/page/server-reference-manifest.json +10 -10
  104. package/web/.next/server/app/tools/page.js.nft.json +1 -1
  105. package/web/.next/server/app/tools/page_client-reference-manifest.js +1 -1
  106. package/web/.next/server/app/version/page/server-reference-manifest.json +5 -5
  107. package/web/.next/server/app/version/page.js.nft.json +1 -1
  108. package/web/.next/server/app/version/page_client-reference-manifest.js +1 -1
  109. package/web/.next/server/chunks/[root-of-the-server]__a402b567._.js +1 -1
  110. package/web/.next/server/chunks/[root-of-the-server]__ab4951b1._.js +1 -1
  111. package/web/.next/server/chunks/[root-of-the-server]__ab4951b1._.js.map +1 -1
  112. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_create-drawer-client_tsx_5e26fc0a._.js +1 -1
  113. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_create-drawer-client_tsx_5e26fc0a._.js.map +1 -1
  114. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_feature-drawer-client_tsx_e9755fc8._.js +2 -2
  115. package/web/.next/server/chunks/ssr/744ca_web_components_common_control-center-drawer_feature-drawer-client_tsx_e9755fc8._.js.map +1 -1
  116. package/web/.next/server/chunks/ssr/[root-of-the-server]__17ed7ed1._.js +1 -1
  117. package/web/.next/server/chunks/ssr/[root-of-the-server]__17ed7ed1._.js.map +1 -1
  118. package/web/.next/server/chunks/ssr/[root-of-the-server]__28d0d265._.js +2 -2
  119. package/web/.next/server/chunks/ssr/[root-of-the-server]__357d99f9._.js +1 -1
  120. package/web/.next/server/chunks/ssr/[root-of-the-server]__42bf1807._.js +1 -1
  121. package/web/.next/server/chunks/ssr/[root-of-the-server]__42bf1807._.js.map +1 -1
  122. package/web/.next/server/chunks/ssr/[root-of-the-server]__56b70465._.js +1 -1
  123. package/web/.next/server/chunks/ssr/[root-of-the-server]__56b70465._.js.map +1 -1
  124. package/web/.next/server/chunks/ssr/[root-of-the-server]__88f7e8e6._.js +1 -1
  125. package/web/.next/server/chunks/ssr/[root-of-the-server]__88f7e8e6._.js.map +1 -1
  126. package/web/.next/server/chunks/ssr/[root-of-the-server]__8b0aac03._.js +1 -1
  127. package/web/.next/server/chunks/ssr/[root-of-the-server]__c30f1f82._.js +1 -1
  128. package/web/.next/server/chunks/ssr/[root-of-the-server]__c30f1f82._.js.map +1 -1
  129. package/web/.next/server/chunks/ssr/[root-of-the-server]__f80bfc75._.js +1 -1
  130. package/web/.next/server/chunks/ssr/[root-of-the-server]__f80bfc75._.js.map +1 -1
  131. package/web/.next/server/chunks/ssr/[root-of-the-server]__f8dd4422._.js +3 -0
  132. package/web/.next/server/chunks/ssr/[root-of-the-server]__f8dd4422._.js.map +1 -0
  133. package/web/.next/server/chunks/ssr/_05c23ad9._.js +1 -1
  134. package/web/.next/server/chunks/ssr/_05c23ad9._.js.map +1 -1
  135. package/web/.next/server/chunks/ssr/_16eb4fec._.js +1 -1
  136. package/web/.next/server/chunks/ssr/_16eb4fec._.js.map +1 -1
  137. package/web/.next/server/chunks/ssr/_3a0b989f._.js +2 -2
  138. package/web/.next/server/chunks/ssr/_3a0b989f._.js.map +1 -1
  139. package/web/.next/server/chunks/ssr/_56b9d60f._.js +1 -1
  140. package/web/.next/server/chunks/ssr/_56b9d60f._.js.map +1 -1
  141. package/web/.next/server/chunks/ssr/_5f69c13f._.js +1 -1
  142. package/web/.next/server/chunks/ssr/_5f69c13f._.js.map +1 -1
  143. package/web/.next/server/chunks/ssr/{_cf1c5b73._.js → _65e76c9a._.js} +2 -2
  144. package/web/.next/server/chunks/ssr/{_cf1c5b73._.js.map → _65e76c9a._.js.map} +1 -1
  145. package/web/.next/server/chunks/ssr/{_5fce01a7._.js → _75a563a9._.js} +2 -2
  146. package/web/.next/server/chunks/ssr/{_5fce01a7._.js.map → _75a563a9._.js.map} +1 -1
  147. package/web/.next/server/chunks/ssr/_7c5b97c6._.js +1 -1
  148. package/web/.next/server/chunks/ssr/_7c5b97c6._.js.map +1 -1
  149. package/web/.next/server/chunks/ssr/_82c57f10._.js +1 -1
  150. package/web/.next/server/chunks/ssr/_82c57f10._.js.map +1 -1
  151. package/web/.next/server/chunks/ssr/_9495d50b._.js +1 -1
  152. package/web/.next/server/chunks/ssr/_9495d50b._.js.map +1 -1
  153. package/web/.next/server/chunks/ssr/_a0e3f7e4._.js +1 -1
  154. package/web/.next/server/chunks/ssr/_a0e3f7e4._.js.map +1 -1
  155. package/web/.next/server/chunks/ssr/_ac4a3873._.js +1 -1
  156. package/web/.next/server/chunks/ssr/_ca0aa7f0._.js +1 -1
  157. package/web/.next/server/chunks/ssr/_ca0aa7f0._.js.map +1 -1
  158. package/web/.next/server/chunks/ssr/_cb5a021e._.js +1 -1
  159. package/web/.next/server/chunks/ssr/_cb5a021e._.js.map +1 -1
  160. package/web/.next/server/chunks/ssr/_d86175ae._.js +1 -1
  161. package/web/.next/server/chunks/ssr/_d86175ae._.js.map +1 -1
  162. package/web/.next/server/chunks/ssr/_d8bedf13._.js +1 -1
  163. package/web/.next/server/chunks/ssr/_d8bedf13._.js.map +1 -1
  164. package/web/.next/server/chunks/ssr/_d9337063._.js +3 -0
  165. package/web/.next/server/chunks/ssr/{_f78b4b9d._.js.map → _d9337063._.js.map} +1 -1
  166. package/web/.next/server/chunks/ssr/_e9a73a63._.js +1 -1
  167. package/web/.next/server/chunks/ssr/_e9a73a63._.js.map +1 -1
  168. package/web/.next/server/chunks/ssr/_fa7efce3._.js +2 -2
  169. package/web/.next/server/chunks/ssr/_fa7efce3._.js.map +1 -1
  170. package/web/.next/server/chunks/ssr/b1a17_presentation_web_components_features_settings_settings-page-client_tsx_6ed9d5f8._.js +1 -1
  171. package/web/.next/server/chunks/ssr/b1a17_presentation_web_components_features_settings_settings-page-client_tsx_6ed9d5f8._.js.map +1 -1
  172. package/web/.next/server/chunks/ssr/src_presentation_web_324a47da._.js +3 -0
  173. package/web/.next/server/chunks/ssr/src_presentation_web_324a47da._.js.map +1 -0
  174. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_skills_page_actions_cdc632e3.js +1 -1
  175. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_skills_page_actions_cdc632e3.js.map +1 -1
  176. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_tools_page_actions_39ca0924.js +1 -1
  177. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_tools_page_actions_39ca0924.js.map +1 -1
  178. package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_open-ide_ts_baaca5d5._.js +1 -1
  179. package/web/.next/server/chunks/ssr/src_presentation_web_components_357e3eb0._.js +1 -1
  180. package/web/.next/server/chunks/ssr/src_presentation_web_components_357e3eb0._.js.map +1 -1
  181. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_control-center_7ac3562e._.js +1 -1
  182. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_control-center_7ac3562e._.js.map +1 -1
  183. package/web/.next/server/pages/500.html +2 -2
  184. package/web/.next/server/server-reference-manifest.js +1 -1
  185. package/web/.next/server/server-reference-manifest.json +45 -45
  186. package/web/.next/static/chunks/{a2257ffb1349f838.js → 11074feeacea0319.js} +1 -1
  187. package/web/.next/static/chunks/18abd4f8b9c216a3.js +1 -0
  188. package/web/.next/static/chunks/2a54cf0384becb8f.js +7 -0
  189. package/web/.next/static/chunks/34417fd25d41b914.js +1 -0
  190. package/web/.next/static/chunks/{f33efe6a12242a8a.js → 51df7b00bbb7d365.js} +1 -1
  191. package/web/.next/static/chunks/{1b4429259bbf3064.js → 58adaad3bab50e74.js} +2 -2
  192. package/web/.next/static/chunks/{277a7f64d4ec189d.js → 634f6f485b81464a.js} +1 -1
  193. package/web/.next/static/chunks/8bbc916241b4c141.js +1 -0
  194. package/web/.next/static/chunks/{f9a80d3854a8d453.js → 9c45b599460d0f60.js} +1 -1
  195. package/web/.next/static/chunks/{80c4c8b3a5c8e0b6.js → a0101660264c178b.js} +2 -2
  196. package/web/.next/static/chunks/{ef1c9f43aafff65f.js → b70bc188ac05a8be.js} +2 -2
  197. package/web/.next/static/chunks/c86594475dcb03d5.css +1 -0
  198. package/web/.next/static/chunks/{6bf775818e4ad42e.js → ebdef1415f61f021.js} +1 -1
  199. package/web/.next/server/chunks/ssr/[root-of-the-server]__563f2f7a._.js +0 -3
  200. package/web/.next/server/chunks/ssr/[root-of-the-server]__563f2f7a._.js.map +0 -1
  201. package/web/.next/server/chunks/ssr/_f78b4b9d._.js +0 -3
  202. package/web/.next/static/chunks/4908997348bd55f8.js +0 -1
  203. package/web/.next/static/chunks/76858a51f2fbe99a.js +0 -7
  204. package/web/.next/static/chunks/a919a9df4ab12a5c.css +0 -1
  205. package/web/.next/static/chunks/bdd340ad42a34b41.js +0 -1
  206. package/web/.next/static/chunks/ee20803fb301d59e.js +0 -1
  207. /package/web/.next/static/{lPbWG8a1RwBDDcvRngp58 → zY7W9Btxu_CXSFrwelXeS}/_buildManifest.js +0 -0
  208. /package/web/.next/static/{lPbWG8a1RwBDDcvRngp58 → zY7W9Btxu_CXSFrwelXeS}/_clientMiddlewareManifest.json +0 -0
  209. /package/web/.next/static/{lPbWG8a1RwBDDcvRngp58 → zY7W9Btxu_CXSFrwelXeS}/_ssgManifest.js +0 -0
@@ -1,16 +1,20 @@
1
1
  'use client';
2
- import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
3
3
  import { useCallback, useEffect, useMemo, useRef, useState } from 'react';
4
4
  import { useRouter, usePathname } from 'next/navigation';
5
+ import { Sparkles, FolderPlus, Github, GitBranch } from 'lucide-react';
5
6
  import { useReactFlow } from '@xyflow/react';
6
7
  import { FeaturesCanvas } from '../../features/features-canvas/index.js';
7
8
  import { CanvasToolbar } from '../../features/features-canvas/canvas-toolbar.js';
9
+ import { FloatingActionButton, } from '../../common/floating-action-button/index.js';
8
10
  import { useSidebarFeaturesContext, mapNodeStateToSidebarStatus, } from '../../../hooks/sidebar-features-context.js';
11
+ import { useFeatureFlags } from '../../../hooks/feature-flags-context.js';
9
12
  import { useSelectedFeatureId } from '../../../hooks/use-selected-feature-id.js';
10
13
  import { useSelectedRepository } from '../../../hooks/use-selected-repository.js';
11
14
  import { useSoundAction } from '../../../hooks/use-sound-action.js';
12
15
  import { useDrawerCloseGuard } from '../../../hooks/drawer-close-guard.js';
13
16
  import { useViewportPersistence } from '../../../hooks/use-viewport-persistence.js';
17
+ import { useSidebar } from '../../ui/sidebar.js';
14
18
  import { ControlCenterEmptyState } from './control-center-empty-state.js';
15
19
  import { useControlCenterState } from './use-control-center-state.js';
16
20
  const AUTO_FOCUS_OPTIONS = {
@@ -291,6 +295,65 @@ export function ControlCenterInner({ initialNodes, initialEdges }) {
291
295
  const handlePickFolder = useCallback(() => {
292
296
  window.dispatchEvent(new CustomEvent('shep:pick-folder'));
293
297
  }, []);
294
- const canvasToolbar = (_jsx(CanvasToolbar, { showArchived: showArchived, onToggleArchived: () => setShowArchived(!showArchived), onAddFeature: handleAddFeature, onAddRepository: handlePickFolder, onResetViewport: resetViewport }));
295
- return (_jsx(FeaturesCanvas, { nodes: showCanvas ? displayNodes : [], edges: showCanvas ? edges : [], selectedFeatureId: selectedFeatureId, selectedRepository: selectedRepository, defaultViewport: defaultViewport, onNodesChange: onNodesChange, onConnect: handleConnect, onAddFeature: handleAddFeature, onNodeClick: handleNodeClick, onPaneClick: handleClearDrawers, onMoveEnd: handleMoveEnd, toolbar: canvasToolbar, emptyState: _jsx(ControlCenterEmptyState, { onRepositorySelect: addRepoAndFocus }) }));
298
+ const featureFlags = useFeatureFlags();
299
+ // (+) FAB actions only visible on control center
300
+ const fabActions = useMemo(() => {
301
+ const actions = [
302
+ {
303
+ id: 'new-feature',
304
+ label: 'New Feature',
305
+ icon: _jsx(Sparkles, { className: "h-4 w-4" }),
306
+ onClick: () => {
307
+ clickSound.play();
308
+ guardedNavigate(() => router.push('/create'));
309
+ },
310
+ },
311
+ {
312
+ id: 'add-local-repo',
313
+ label: 'Local Folder',
314
+ icon: _jsx(FolderPlus, { className: "h-4 w-4" }),
315
+ onClick: handlePickFolder,
316
+ },
317
+ ];
318
+ if (featureFlags.adoptBranch) {
319
+ actions.push({
320
+ id: 'adopt-branch',
321
+ label: 'Adopt Branch',
322
+ icon: _jsx(GitBranch, { className: "h-4 w-4" }),
323
+ onClick: () => {
324
+ guardedNavigate(() => router.push('/adopt'));
325
+ },
326
+ });
327
+ }
328
+ if (featureFlags.githubImport) {
329
+ actions.push({
330
+ id: 'add-github-repo',
331
+ label: 'From GitHub',
332
+ icon: _jsx(Github, { className: "h-4 w-4" }),
333
+ onClick: () => {
334
+ window.dispatchEvent(new CustomEvent('shep:open-github-import'));
335
+ },
336
+ });
337
+ }
338
+ return actions;
339
+ }, [
340
+ clickSound,
341
+ guardedNavigate,
342
+ router,
343
+ handlePickFolder,
344
+ featureFlags.adoptBranch,
345
+ featureFlags.githubImport,
346
+ ]);
347
+ const canvasToolbar = (_jsx(CanvasToolbar, { showArchived: showArchived, onToggleArchived: () => setShowArchived(!showArchived), onResetViewport: resetViewport }));
348
+ return (_jsxs(_Fragment, { children: [_jsx(FeaturesCanvas, { nodes: showCanvas ? displayNodes : [], edges: showCanvas ? edges : [], selectedFeatureId: selectedFeatureId, selectedRepository: selectedRepository, defaultViewport: defaultViewport, onNodesChange: onNodesChange, onConnect: handleConnect, onAddFeature: handleAddFeature, onNodeClick: handleNodeClick, onPaneClick: handleClearDrawers, onMoveEnd: handleMoveEnd, toolbar: canvasToolbar, emptyState: _jsx(ControlCenterEmptyState, { onRepositorySelect: addRepoAndFocus }) }), showCanvas ? _jsx(CreateFab, { actions: fabActions }) : null] }));
349
+ }
350
+ /** (+) FAB that tracks sidebar width via CSS var + transition. */
351
+ function CreateFab({ actions }) {
352
+ const { state } = useSidebar();
353
+ // Sidebar expanded = var(--sidebar-width) = 16rem, collapsed = var(--sidebar-width-icon) = 3rem
354
+ // Position just outside the sidebar edge with 16px gap
355
+ const left = state === 'expanded'
356
+ ? 'calc(var(--sidebar-width) + 32px)'
357
+ : 'calc(var(--sidebar-width-icon) + 32px)';
358
+ return (_jsx(FloatingActionButton, { actions: actions, className: "!fixed bottom-6", style: { left, transition: 'left 200ms ease-in-out' } }));
296
359
  }
@@ -2,12 +2,7 @@ import type { Viewport } from '@xyflow/react';
2
2
  export interface CanvasToolbarProps {
3
3
  showArchived: boolean;
4
4
  onToggleArchived: () => void;
5
- onAddFeature: () => void;
6
- onAddRepository: () => void;
7
- addingRepo?: boolean;
8
5
  onResetViewport?: () => Viewport;
9
- /** Extra action buttons (adopt branch, github import, etc.) */
10
- extraActions?: React.ReactNode;
11
6
  }
12
- export declare function CanvasToolbar({ showArchived, onToggleArchived, onAddFeature, onAddRepository, addingRepo, onResetViewport, extraActions, }: CanvasToolbarProps): import("react/jsx-runtime").JSX.Element;
7
+ export declare function CanvasToolbar({ showArchived, onToggleArchived, onResetViewport, }: CanvasToolbarProps): import("react/jsx-runtime").JSX.Element;
13
8
  //# sourceMappingURL=canvas-toolbar.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"canvas-toolbar.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/features-canvas/canvas-toolbar.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAK9C,MAAM,WAAW,kBAAkB;IACjC,YAAY,EAAE,OAAO,CAAC;IACtB,gBAAgB,EAAE,MAAM,IAAI,CAAC;IAC7B,YAAY,EAAE,MAAM,IAAI,CAAC;IACzB,eAAe,EAAE,MAAM,IAAI,CAAC;IAC5B,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,eAAe,CAAC,EAAE,MAAM,QAAQ,CAAC;IACjC,+DAA+D;IAC/D,YAAY,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAChC;AAED,wBAAgB,aAAa,CAAC,EAC5B,YAAY,EACZ,gBAAgB,EAChB,YAAY,EACZ,eAAe,EACf,UAAU,EACV,eAAe,EACf,YAAY,GACb,EAAE,kBAAkB,2CAoEpB"}
1
+ {"version":3,"file":"canvas-toolbar.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/features-canvas/canvas-toolbar.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAI9C,MAAM,WAAW,kBAAkB;IACjC,YAAY,EAAE,OAAO,CAAC;IACtB,gBAAgB,EAAE,MAAM,IAAI,CAAC;IAC7B,eAAe,CAAC,EAAE,MAAM,QAAQ,CAAC;CAClC;AAED,wBAAgB,aAAa,CAAC,EAC5B,YAAY,EACZ,gBAAgB,EAChB,eAAe,GAChB,EAAE,kBAAkB,2CAqDpB"}
@@ -2,10 +2,9 @@
2
2
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
3
  import { useCallback } from 'react';
4
4
  import { useReactFlow } from '@xyflow/react';
5
- import { Plus, FolderPlus, Eye, EyeOff, ZoomIn, ZoomOut, Maximize, RotateCcw } from 'lucide-react';
5
+ import { Eye, EyeOff, ZoomIn, ZoomOut, Maximize, RotateCcw } from 'lucide-react';
6
6
  import { cn } from '../../../lib/utils.js';
7
- import { Separator } from '../../ui/separator.js';
8
- export function CanvasToolbar({ showArchived, onToggleArchived, onAddFeature, onAddRepository, addingRepo, onResetViewport, extraActions, }) {
7
+ export function CanvasToolbar({ showArchived, onToggleArchived, onResetViewport, }) {
9
8
  const { zoomIn, zoomOut, fitView, setViewport } = useReactFlow();
10
9
  const handleZoomIn = useCallback(() => {
11
10
  zoomIn({ duration: 200 });
@@ -22,9 +21,9 @@ export function CanvasToolbar({ showArchived, onToggleArchived, onAddFeature, on
22
21
  setViewport(viewport, { duration: 400 });
23
22
  }
24
23
  }, [onResetViewport, setViewport]);
25
- return (_jsxs("div", { className: "bg-background flex items-center gap-1 rounded-xl border px-2 py-1.5 shadow-md dark:bg-neutral-900", children: [_jsx(ToolbarButton, { onClick: onAddFeature, title: "New Feature", label: "New", children: _jsx(Plus, { className: "h-4 w-4" }) }), _jsx(ToolbarButton, { onClick: onAddRepository, title: "Add Repository", label: "Repo", disabled: addingRepo, children: _jsx(FolderPlus, { className: "h-4 w-4" }) }), extraActions, _jsx(Separator, { orientation: "vertical", className: "mx-1 h-6" }), _jsx(ToolbarButton, { onClick: onToggleArchived, title: showArchived ? 'Hide archived' : 'Show archived', active: showArchived, children: showArchived ? _jsx(Eye, { className: "h-4 w-4" }) : _jsx(EyeOff, { className: "h-4 w-4" }) }), _jsx(Separator, { orientation: "vertical", className: "mx-1 h-6" }), _jsx(ToolbarButton, { onClick: handleZoomOut, title: "Zoom out", children: _jsx(ZoomOut, { className: "h-4 w-4" }) }), _jsx(ToolbarButton, { onClick: handleZoomIn, title: "Zoom in", children: _jsx(ZoomIn, { className: "h-4 w-4" }) }), _jsx(ToolbarButton, { onClick: handleFitView, title: "Fit view", children: _jsx(Maximize, { className: "h-4 w-4" }) }), onResetViewport ? (_jsx(ToolbarButton, { onClick: handleReset, title: "Reset view", children: _jsx(RotateCcw, { className: "h-4 w-4" }) })) : null] }));
24
+ return (_jsxs("div", { className: "bg-background flex items-center gap-1 rounded-xl border px-2 py-1.5 shadow-md dark:bg-neutral-900", children: [_jsx(ToolbarButton, { onClick: onToggleArchived, title: showArchived ? 'Hide archived' : 'Show archived', active: showArchived, label: showArchived ? 'Hide Archived' : 'Show Archived', children: showArchived ? _jsx(Eye, { className: "h-4 w-4" }) : _jsx(EyeOff, { className: "h-4 w-4" }) }), _jsx("div", { className: "bg-border mx-1 h-5 w-px" }), _jsx(ToolbarButton, { onClick: handleZoomOut, title: "Zoom out", children: _jsx(ZoomOut, { className: "h-4 w-4" }) }), _jsx(ToolbarButton, { onClick: handleZoomIn, title: "Zoom in", children: _jsx(ZoomIn, { className: "h-4 w-4" }) }), _jsx(ToolbarButton, { onClick: handleFitView, title: "Fit view", children: _jsx(Maximize, { className: "h-4 w-4" }) }), onResetViewport ? (_jsx(ToolbarButton, { onClick: handleReset, title: "Reset view", children: _jsx(RotateCcw, { className: "h-4 w-4" }) })) : null] }));
26
25
  }
27
26
  // ── Internal button ──────────────────────────────────────────────────────
28
- function ToolbarButton({ children, onClick, title, label, active, disabled, }) {
29
- return (_jsxs("button", { type: "button", onClick: onClick, title: title, disabled: disabled, className: cn('inline-flex items-center gap-1.5 rounded-lg px-2 py-1.5 text-xs font-medium transition-colors', 'hover:bg-accent hover:text-accent-foreground', 'disabled:pointer-events-none disabled:opacity-50', active ? 'text-primary bg-primary/10' : 'text-muted-foreground'), children: [children, label ? _jsx("span", { children: label }) : null] }));
27
+ function ToolbarButton({ children, onClick, title, label, active, }) {
28
+ return (_jsxs("button", { type: "button", onClick: onClick, title: title, className: cn('inline-flex items-center gap-1.5 rounded-lg px-2 py-1.5 text-xs font-medium transition-colors', 'hover:bg-accent hover:text-accent-foreground', active ? 'text-primary bg-primary/10' : 'text-muted-foreground'), children: [children, label ? _jsx("span", { children: label }) : null] }));
30
29
  }
@@ -69,5 +69,5 @@ export function FeaturesCanvas({ nodes, edges, selectedFeatureId, selectedReposi
69
69
  }, [isEmpty]);
70
70
  const fallbackEmptyState = isEmpty && !emptyState ? (_jsx(EmptyState, { title: "No features yet", description: "Get started by creating your first feature.", action: _jsxs(Button, { onClick: onAddFeature, children: [_jsx(Plus, { className: "mr-2 h-4 w-4" }), "New Feature"] }) })) : null;
71
71
  const overlayContent = emptyState ?? fallbackEmptyState;
72
- return (_jsxs("div", { "data-testid": isEmpty ? 'features-canvas-empty' : 'features-canvas', "data-no-drawer-close": true, className: "dark:bg-background pointer-events-auto relative h-full w-full bg-[#f6f7f8]", children: [_jsxs(ReactFlow, { nodes: enrichedNodes, edges: edges, nodeTypes: nodeTypes, edgeTypes: edgeTypes, onConnect: onConnect, onNodesChange: onNodesChange, onNodeClick: onNodeClick, onPaneClick: onPaneClick, onMoveStart: onCanvasDrag, onMoveEnd: onMoveEnd, defaultViewport: defaultViewport ?? FALLBACK_VIEWPORT, nodesDraggable: false, nodesConnectable: false, elementsSelectable: false, proOptions: { hideAttribution: true }, className: "[&_.react-flow__pane]:!cursor-default", children: [_jsx(Background, { variant: BackgroundVariant.Dots, gap: 24, size: 1, color: "#b8bcc4", className: "dark:[&_circle]:!fill-white/[0.1]" }), !isEmpty && toolbar ? (_jsx(Panel, { position: "bottom-center", className: "!mb-4", children: toolbar })) : null] }), showOverlay && overlayContent ? (_jsx("div", { className: cn('pointer-events-none absolute inset-0 z-10 flex items-center justify-center transition-opacity duration-300', overlayExiting ? 'opacity-0' : 'animate-in fade-in opacity-100 duration-200'), children: _jsx("div", { className: "pointer-events-auto h-full w-full", children: overlayContent }) })) : null] }));
72
+ return (_jsxs("div", { "data-testid": isEmpty ? 'features-canvas-empty' : 'features-canvas', "data-no-drawer-close": true, className: "dark:bg-background pointer-events-auto relative h-full w-full bg-[#f6f7f8]", children: [_jsxs(ReactFlow, { nodes: enrichedNodes, edges: edges, nodeTypes: nodeTypes, edgeTypes: edgeTypes, onConnect: onConnect, onNodesChange: onNodesChange, onNodeClick: onNodeClick, onPaneClick: onPaneClick, onMoveStart: onCanvasDrag, onMoveEnd: onMoveEnd, defaultViewport: defaultViewport ?? FALLBACK_VIEWPORT, nodesDraggable: false, nodesConnectable: false, elementsSelectable: false, proOptions: { hideAttribution: true }, className: "[&_.react-flow__pane]:!cursor-default", children: [_jsx(Background, { variant: BackgroundVariant.Dots, gap: 24, size: 1, color: "#b8bcc4", className: "dark:[&_circle]:!fill-white/[0.1]" }), !isEmpty && toolbar ? (_jsx(Panel, { position: "top-right", className: "!mt-3 !mr-3", children: toolbar })) : null] }), showOverlay && overlayContent ? (_jsx("div", { className: cn('pointer-events-none absolute inset-0 z-10 flex items-center justify-center transition-opacity duration-300', overlayExiting ? 'opacity-0' : 'animate-in fade-in opacity-100 duration-200'), children: _jsx("div", { className: "pointer-events-auto h-full w-full", children: overlayContent }) })) : null] }));
73
73
  }
@@ -1 +1 @@
1
- {"version":3,"file":"app-shell.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/layouts/app-shell/app-shell.tsx"],"names":[],"mappings":"AAEA,OAAO,EAA6C,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAmBlF,UAAU,aAAa;IACrB,QAAQ,EAAE,SAAS,CAAC;IACpB,6CAA6C;IAC7C,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB;AA4GD,wBAAgB,QAAQ,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,EAAE,aAAa,2CAYhE"}
1
+ {"version":3,"file":"app-shell.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/layouts/app-shell/app-shell.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAoC,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAmBzE,UAAU,aAAa;IACrB,QAAQ,EAAE,SAAS,CAAC;IACpB,6CAA6C;IAC7C,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB;AAiHD,wBAAgB,QAAQ,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,EAAE,aAAa,2CAYhE"}
@@ -1,6 +1,6 @@
1
1
  'use client';
2
2
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
- import { useCallback, useEffect, useMemo, useState } from 'react';
3
+ import { useCallback, useEffect, useState } from 'react';
4
4
  import { useRouter } from 'next/navigation';
5
5
  import { SidebarProvider, SidebarInset } from '../../ui/sidebar.js';
6
6
  import { AppSidebar } from '../../layouts/app-sidebar/index.js';
@@ -57,6 +57,12 @@ function AppShellInner({ children, sidebarOpen }) {
57
57
  window.addEventListener('shep:pick-folder', handler);
58
58
  return () => window.removeEventListener('shep:pick-folder', handler);
59
59
  }, [handleAddRepository]);
60
+ // Listen for GitHub import event from (+) FAB
61
+ useEffect(() => {
62
+ const handler = () => setGithubDialogOpen(true);
63
+ window.addEventListener('shep:open-github-import', handler);
64
+ return () => window.removeEventListener('shep:open-github-import', handler);
65
+ }, []);
60
66
  const handleReactPickerSelect = useCallback((path) => {
61
67
  if (path) {
62
68
  window.dispatchEvent(new CustomEvent('shep:add-repository', { detail: { path } }));
@@ -73,11 +79,9 @@ function AppShellInner({ children, sidebarOpen }) {
73
79
  setShowReactPicker(false);
74
80
  }, onSelect: handleReactPickerSelect })] }));
75
81
  }
76
- /** Wraps children with TurnStatusesProvider, collecting scope IDs from sidebar features. */
82
+ /** Wraps children with TurnStatusesProvider (polls all active statuses from backend). */
77
83
  function TurnStatusesBridge({ children }) {
78
- const { features } = useSidebarFeaturesContext();
79
- const scopeIds = useMemo(() => ['global', ...features.map((f) => f.featureId)], [features]);
80
- return _jsx(TurnStatusesProvider, { scopeIds: scopeIds, children: children });
84
+ return _jsx(TurnStatusesProvider, { children: children });
81
85
  }
82
86
  export function AppShell({ children, sidebarOpen }) {
83
87
  return (_jsx(AgentEventsProvider, { children: _jsx(DrawerCloseGuardProvider, { children: _jsx(SidebarFeaturesProvider, { children: _jsx(TurnStatusesBridge, { children: _jsx(AppShellInner, { sidebarOpen: sidebarOpen, children: children }) }) }) }) }));
@@ -1,19 +1,15 @@
1
1
  import { type ReactNode } from 'react';
2
2
  import { type TurnStatus } from './use-turn-statuses.js';
3
- interface TurnStatusesProviderProps {
4
- /** All scope IDs to poll turn statuses for */
5
- scopeIds: string[];
6
- children: ReactNode;
7
- }
8
3
  /**
9
- * Polls turn statuses for all provided scope IDs in a single API call.
4
+ * Polls ALL active turn statuses in a single API call (no IDs needed).
10
5
  * Children use `useTurnStatus(scopeId)` to read individual statuses.
11
6
  */
12
- export declare function TurnStatusesProvider({ scopeIds, children }: TurnStatusesProviderProps): import("react/jsx-runtime").JSX.Element;
7
+ export declare function TurnStatusesProvider({ children }: {
8
+ children: ReactNode;
9
+ }): import("react/jsx-runtime").JSX.Element;
13
10
  /**
14
11
  * Get the turn status for a specific scope ID.
15
12
  * Must be used within a TurnStatusesProvider.
16
13
  */
17
14
  export declare function useTurnStatus(scopeId: string): TurnStatus;
18
- export {};
19
15
  //# sourceMappingURL=turn-statuses-provider.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"turn-statuses-provider.d.ts","sourceRoot":"","sources":["../../../../../src/presentation/web/hooks/turn-statuses-provider.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAsC,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAC3E,OAAO,EAAmB,KAAK,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAWvE,UAAU,yBAAyB;IACjC,8CAA8C;IAC9C,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED;;;GAGG;AACH,wBAAgB,oBAAoB,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,EAAE,yBAAyB,2CAWrF;AAED;;;GAGG;AACH,wBAAgB,aAAa,CAAC,OAAO,EAAE,MAAM,GAAG,UAAU,CAGzD"}
1
+ {"version":3,"file":"turn-statuses-provider.d.ts","sourceRoot":"","sources":["../../../../../src/presentation/web/hooks/turn-statuses-provider.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAsC,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAC3E,OAAO,EAAsB,KAAK,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAW1E;;;GAGG;AACH,wBAAgB,oBAAoB,CAAC,EAAE,QAAQ,EAAE,EAAE;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,2CAWzE;AAED;;;GAGG;AACH,wBAAgB,aAAa,CAAC,OAAO,EAAE,MAAM,GAAG,UAAU,CAGzD"}
@@ -1,16 +1,16 @@
1
1
  'use client';
2
2
  import { jsx as _jsx } from "react/jsx-runtime";
3
3
  import { createContext, useContext, useMemo } from 'react';
4
- import { useTurnStatuses } from './use-turn-statuses.js';
4
+ import { useAllTurnStatuses } from './use-turn-statuses.js';
5
5
  const TurnStatusesContext = createContext({
6
6
  getStatus: () => 'idle',
7
7
  });
8
8
  /**
9
- * Polls turn statuses for all provided scope IDs in a single API call.
9
+ * Polls ALL active turn statuses in a single API call (no IDs needed).
10
10
  * Children use `useTurnStatus(scopeId)` to read individual statuses.
11
11
  */
12
- export function TurnStatusesProvider({ scopeIds, children }) {
13
- const statuses = useTurnStatuses(scopeIds);
12
+ export function TurnStatusesProvider({ children }) {
13
+ const statuses = useAllTurnStatuses();
14
14
  const value = useMemo(() => ({
15
15
  getStatus: (scopeId) => statuses[scopeId] ?? 'idle',
16
16
  }), [statuses]);
@@ -1,11 +1,10 @@
1
1
  export type TurnStatus = 'idle' | 'processing' | 'unread';
2
2
  /**
3
- * Polls turn statuses for multiple feature/scope IDs.
4
- * Returns a map of featureId TurnStatus for dot indicator rendering.
5
- *
6
- * Polls every 3 seconds to keep indicators responsive.
3
+ * Polls ALL active turn statuses from the backend.
4
+ * No IDs needed the backend returns every non-idle session status.
5
+ * Returns a map of scopeId → TurnStatus.
7
6
  */
8
- export declare function useTurnStatuses(featureIds: string[]): Record<string, TurnStatus>;
7
+ export declare function useAllTurnStatuses(): Record<string, TurnStatus>;
9
8
  /**
10
9
  * Marks a feature's chat as read (clears 'unread' → 'idle').
11
10
  */
@@ -1 +1 @@
1
- {"version":3,"file":"use-turn-statuses.d.ts","sourceRoot":"","sources":["../../../../../src/presentation/web/hooks/use-turn-statuses.ts"],"names":[],"mappings":"AAIA,MAAM,MAAM,UAAU,GAAG,MAAM,GAAG,YAAY,GAAG,QAAQ,CAAC;AAE1D;;;;;GAKG;AACH,wBAAgB,eAAe,CAAC,UAAU,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,CAgBhF;AAED;;GAEG;AACH,wBAAsB,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAEnE"}
1
+ {"version":3,"file":"use-turn-statuses.d.ts","sourceRoot":"","sources":["../../../../../src/presentation/web/hooks/use-turn-statuses.ts"],"names":[],"mappings":"AAIA,MAAM,MAAM,UAAU,GAAG,MAAM,GAAG,YAAY,GAAG,QAAQ,CAAC;AAE1D;;;;GAIG;AACH,wBAAgB,kBAAkB,IAAI,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,CAY/D;AAED;;GAEG;AACH,wBAAsB,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAEnE"}
@@ -1,25 +1,20 @@
1
1
  'use client';
2
2
  import { useQuery } from '@tanstack/react-query';
3
3
  /**
4
- * Polls turn statuses for multiple feature/scope IDs.
5
- * Returns a map of featureId TurnStatus for dot indicator rendering.
6
- *
7
- * Polls every 3 seconds to keep indicators responsive.
4
+ * Polls ALL active turn statuses from the backend.
5
+ * No IDs needed the backend returns every non-idle session status.
6
+ * Returns a map of scopeId → TurnStatus.
8
7
  */
9
- export function useTurnStatuses(featureIds) {
10
- const sortedIds = [...featureIds].sort().join(',');
8
+ export function useAllTurnStatuses() {
11
9
  const { data } = useQuery({
12
- queryKey: ['turn-statuses', sortedIds],
10
+ queryKey: ['turn-statuses'],
13
11
  queryFn: async () => {
14
- if (!sortedIds)
15
- return {};
16
- const res = await fetch(`/api/interactive/chat/turn-statuses?featureIds=${sortedIds}`);
12
+ const res = await fetch('/api/interactive/chat/turn-statuses');
17
13
  if (!res.ok)
18
14
  return {};
19
15
  return res.json();
20
16
  },
21
- refetchInterval: 3_000,
22
- enabled: featureIds.length > 0,
17
+ refetchInterval: 5_000,
23
18
  });
24
19
  return data ?? {};
25
20
  }