@yancyyu/openhermit 1.6.41 → 1.6.43
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +98 -89
- package/bin/hermit.mjs +96 -0
- package/dist-renderer/assets/{ProjectEditorOverlay-Br0X83Jf.js → ProjectEditorOverlay-C98qSs7-.js} +1 -1
- package/dist-renderer/assets/{TeamGraphOverlay-DHMTbZPZ.js → TeamGraphOverlay-CsBbZwcL.js} +1 -1
- package/dist-renderer/assets/{_basePickBy-DzIiX7yH.js → _basePickBy-ZOyLWjMK.js} +1 -1
- package/dist-renderer/assets/{_baseUniq-6hZuzTLU.js → _baseUniq-DBb726rt.js} +1 -1
- package/dist-renderer/assets/{arc-CXgO6fx_.js → arc-CdiTaR_R.js} +1 -1
- package/dist-renderer/assets/{architectureDiagram-VXUJARFQ-DKWgtDHr.js → architectureDiagram-VXUJARFQ-Cz3sc5TH.js} +1 -1
- package/dist-renderer/assets/{blockDiagram-VD42YOAC-DOMUcC40.js → blockDiagram-VD42YOAC-DE4c-KJ3.js} +1 -1
- package/dist-renderer/assets/{c4Diagram-YG6GDRKO-B_k2L7qX.js → c4Diagram-YG6GDRKO-CmTMDTrV.js} +1 -1
- package/dist-renderer/assets/channel-KTpqi9eT.js +1 -0
- package/dist-renderer/assets/{chunk-4BX2VUAB-BeD_ccFy.js → chunk-4BX2VUAB-rhHy3tFl.js} +1 -1
- package/dist-renderer/assets/{chunk-55IACEB6-ClZfkA5w.js → chunk-55IACEB6-fLZBzuo_.js} +1 -1
- package/dist-renderer/assets/{chunk-B4BG7PRW-5XluxXsn.js → chunk-B4BG7PRW-DOzxQhim.js} +1 -1
- package/dist-renderer/assets/{chunk-DI55MBZ5-BzIjjNVm.js → chunk-DI55MBZ5-COQCcXC5.js} +1 -1
- package/dist-renderer/assets/{chunk-FMBD7UC4-HgH3MK_H.js → chunk-FMBD7UC4-IKU9U_Y4.js} +1 -1
- package/dist-renderer/assets/{chunk-QN33PNHL-WeC5T3Ba.js → chunk-QN33PNHL-D6WV154X.js} +1 -1
- package/dist-renderer/assets/{chunk-QZHKN3VN-Cu1ApHfW.js → chunk-QZHKN3VN-D90_2DQp.js} +1 -1
- package/dist-renderer/assets/{chunk-TZMSLE5B-BOhlynJM.js → chunk-TZMSLE5B-BQEil57G.js} +1 -1
- package/dist-renderer/assets/classDiagram-2ON5EDUG-lpzulY5X.js +1 -0
- package/dist-renderer/assets/classDiagram-v2-WZHVMYZB-lpzulY5X.js +1 -0
- package/dist-renderer/assets/clone-CriGymY9.js +1 -0
- package/dist-renderer/assets/{cose-bilkent-S5V4N54A-DGZSihDQ.js → cose-bilkent-S5V4N54A-6WiK6U2P.js} +1 -1
- package/dist-renderer/assets/{dagre-6UL2VRFP-CnxwCbku.js → dagre-6UL2VRFP-DF4MMuTn.js} +1 -1
- package/dist-renderer/assets/{diagram-PSM6KHXK-DsIhoxdI.js → diagram-PSM6KHXK-CcF1eZ7E.js} +1 -1
- package/dist-renderer/assets/{diagram-QEK2KX5R-Cmh9KUF5.js → diagram-QEK2KX5R-DYlOVPQB.js} +1 -1
- package/dist-renderer/assets/{diagram-S2PKOQOG-CKxV456A.js → diagram-S2PKOQOG-BHXWsZOP.js} +1 -1
- package/dist-renderer/assets/{erDiagram-Q2GNP2WA-EnvYjOjc.js → erDiagram-Q2GNP2WA-GjmuBx8d.js} +1 -1
- package/dist-renderer/assets/{flowDiagram-NV44I4VS-BmNeWY_A.js → flowDiagram-NV44I4VS-BuS7YVHk.js} +1 -1
- package/dist-renderer/assets/{ganttDiagram-JELNMOA3-D30fyK-u.js → ganttDiagram-JELNMOA3-3Teu5tAa.js} +1 -1
- package/dist-renderer/assets/{gitGraphDiagram-V2S2FVAM-CrUNiYg1.js → gitGraphDiagram-V2S2FVAM-BiLdCYu5.js} +1 -1
- package/dist-renderer/assets/{graph-CY1gTfTb.js → graph-CDP_R8ct.js} +1 -1
- package/dist-renderer/assets/{index-CaEbzwAU.js → index-BSZdT-g-.js} +1 -1
- package/dist-renderer/assets/{index-D5K-SjBG.js → index-BhWvMqsz.js} +1 -1
- package/dist-renderer/assets/{index-9_hO4N1e.js → index-C2_AupSj.js} +1 -1
- package/dist-renderer/assets/{index-59r209c1.js → index-C5ujiwAR.js} +580 -588
- package/dist-renderer/assets/index-CIS2CTK9.css +1 -0
- package/dist-renderer/assets/{index-DMR9B1UP.js → index-CVNjLwkq.js} +1 -1
- package/dist-renderer/assets/{index-BC2hXmg_.js → index-CwG3se0q.js} +1 -1
- package/dist-renderer/assets/{infoDiagram-HS3SLOUP-By_XUlcD.js → infoDiagram-HS3SLOUP-DLHUFo72.js} +1 -1
- package/dist-renderer/assets/{journeyDiagram-XKPGCS4Q-BM1LJE9m.js → journeyDiagram-XKPGCS4Q-BE07RpJD.js} +1 -1
- package/dist-renderer/assets/{kanban-definition-3W4ZIXB7-DHIW3aTA.js → kanban-definition-3W4ZIXB7-DDHZy4NB.js} +1 -1
- package/dist-renderer/assets/{layout-DAKiL_Mo.js → layout-5nA5wUxO.js} +1 -1
- package/dist-renderer/assets/{linear-DwOaRYea.js → linear-BtF1i2qN.js} +1 -1
- package/dist-renderer/assets/{mindmap-definition-VGOIOE7T-b7bJ2cha.js → mindmap-definition-VGOIOE7T-Z1Ui9Sqy.js} +1 -1
- package/dist-renderer/assets/{pieDiagram-ADFJNKIX-DxyL9Zr2.js → pieDiagram-ADFJNKIX-LCjxckWv.js} +1 -1
- package/dist-renderer/assets/{quadrantDiagram-AYHSOK5B-CR33pHlF.js → quadrantDiagram-AYHSOK5B-BOwKjSco.js} +1 -1
- package/dist-renderer/assets/{requirementDiagram-UZGBJVZJ-BAiSRSlh.js → requirementDiagram-UZGBJVZJ-pChP8Znd.js} +1 -1
- package/dist-renderer/assets/{sankeyDiagram-TZEHDZUN-C8JmDjoa.js → sankeyDiagram-TZEHDZUN-DifZ2qpo.js} +1 -1
- package/dist-renderer/assets/{sequenceDiagram-WL72ISMW-c1d0Wi1m.js → sequenceDiagram-WL72ISMW-CJg-WYyY.js} +1 -1
- package/dist-renderer/assets/{splashScene-D0YB9uxm.js → splashScene-94xWCzLA.js} +1 -1
- package/dist-renderer/assets/{stateDiagram-FKZM4ZOC-nT8BiH2O.js → stateDiagram-FKZM4ZOC-DWHOoFdv.js} +1 -1
- package/dist-renderer/assets/stateDiagram-v2-4FDKWEC3-CGYZOoMb.js +1 -0
- package/dist-renderer/assets/{timeline-definition-IT6M3QCI-DpoRepUA.js → timeline-definition-IT6M3QCI-CPgokIo8.js} +1 -1
- package/dist-renderer/assets/{treemap-GDKQZRPO-C41UJeIH.js → treemap-GDKQZRPO-DAVqSR9L.js} +1 -1
- package/dist-renderer/assets/{xychartDiagram-PRI3JC2R-KMjGARKN.js → xychartDiagram-PRI3JC2R-CCOcGbrD.js} +1 -1
- package/dist-renderer/chat-community-qr.jpg +0 -0
- package/dist-renderer/fonts/Agave-Bold.ttf +0 -0
- package/dist-renderer/fonts/Agave-Regular.ttf +0 -0
- package/dist-renderer/icon.png +0 -0
- package/dist-renderer/icon.rar +0 -0
- package/dist-renderer/index.html +3 -3
- package/package.json +21 -26
- package/src/features/worker-society/core/application/WorkerSocietyService.test.ts +802 -0
- package/src/features/worker-society/core/application/WorkerSocietyService.ts +428 -0
- package/src/features/worker-society/core/application/fakes.ts +101 -0
- package/src/features/worker-society/core/application/ports.ts +70 -0
- package/src/features/worker-society/core/domain/models/society.ts +141 -0
- package/src/features/worker-society/core/domain/policies/societyPolicies.test.ts +739 -0
- package/src/features/worker-society/core/domain/policies/societyPolicies.ts +496 -0
- package/src/features/worker-society/main/adapters/input/societyMcp.test.ts +317 -0
- package/src/features/worker-society/main/adapters/input/societyMcp.ts +257 -0
- package/src/features/worker-society/main/adapters/input/societyRoutes.test.ts +695 -0
- package/src/features/worker-society/main/adapters/input/societyRoutes.ts +194 -0
- package/src/features/worker-society/main/composition/societyComposition.test.ts +74 -0
- package/src/features/worker-society/main/composition/societyComposition.ts +70 -0
- package/src/features/worker-society/main/composition/workerSocietyPlugin.test.ts +69 -0
- package/src/features/worker-society/main/composition/workerSocietyPlugin.ts +67 -0
- package/src/features/worker-society/main/infrastructure/crossTeamMessageGateway.test.ts +132 -0
- package/src/features/worker-society/main/infrastructure/crossTeamMessageGateway.ts +84 -0
- package/src/features/worker-society/main/infrastructure/fsStores.test.ts +216 -0
- package/src/features/worker-society/main/infrastructure/fsStores.ts +113 -0
- package/src/features/worker-society/main/infrastructure/mergingProfileStore.test.ts +195 -0
- package/src/features/worker-society/main/infrastructure/mergingProfileStore.ts +96 -0
- package/src/features/worker-society/renderer/SocietyGraph.tsx +166 -0
- package/src/features/worker-society/renderer/SocietyNodeLabels.tsx +139 -0
- package/src/features/worker-society/renderer/SocietyNodeOverlay.tsx +339 -0
- package/src/features/worker-society/renderer/SocietyView.tsx +437 -0
- package/src/features/worker-society/renderer/index.ts +11 -0
- package/src/features/worker-society/renderer/societyApi.test.ts +259 -0
- package/src/features/worker-society/renderer/societyApi.ts +144 -0
- package/src/features/worker-society/renderer/societyGraphAdapter.test.ts +321 -0
- package/src/features/worker-society/renderer/societyGraphAdapter.ts +240 -0
- package/src/features/worker-society/renderer/societyOverlayActions.test.ts +57 -0
- package/src/features/worker-society/renderer/societyOverlayActions.ts +49 -0
- package/src/features/worker-society/renderer/societyStore.test.ts +218 -0
- package/src/features/worker-society/renderer/societyStore.ts +146 -0
- package/src/features/worker-society/renderer/societyViewUtils.test.ts +81 -0
- package/src/features/worker-society/renderer/societyViewUtils.ts +68 -0
- package/src/main/ipc/extensions.ts +27 -0
- package/src/main/server.ts +1731 -539
- package/src/main/services/ccConnect/CcConnectBridge.ts +26 -11
- package/src/main/services/ccConnect/CcConnectClient.ts +9 -2
- package/src/main/services/ccConnect/workDirReconcile.test.ts +57 -0
- package/src/main/services/ccConnect/workDirReconcile.ts +36 -0
- package/src/main/services/direct-cli/DirectCliSessionManager.test.ts +397 -0
- package/src/main/services/direct-cli/DirectCliSessionManager.ts +508 -0
- package/src/main/services/direct-cli/DirectCliSessionStore.test.ts +79 -0
- package/src/main/services/direct-cli/DirectCliSessionStore.ts +97 -0
- package/src/main/services/direct-cli/__tests__/directCliMessageId.test.ts +40 -0
- package/src/main/services/direct-cli/directCliMessageId.ts +21 -0
- package/src/main/services/direct-cli/index.ts +17 -0
- package/src/main/services/extensions/capability-packs/CapabilityPackLoaderService.ts +637 -0
- package/src/main/services/extensions/catalog/PluginCatalogService.ts +2 -2
- package/src/main/services/loop-assets/LoopAssetsScannerService.ts +657 -0
- package/src/main/services/runtime/providerAwareCliEnv.ts +33 -5
- package/src/main/services/session-intelligence/LocalSessionScanner.ts +156 -71
- package/src/main/services/session-intelligence/SessionUsageParser.ts +103 -8
- package/src/main/services/session-intelligence/UsageTelemetryService.ts +11 -0
- package/src/main/services/session-intelligence/__tests__/teamSessionListMapper.test.ts +104 -0
- package/src/main/services/session-intelligence/teamSessionListMapper.ts +78 -0
- package/src/main/services/system-manager/AdminLoopInitializer.ts +95 -0
- package/src/main/services/system-manager/BuiltinWorkflowSeeder.ts +744 -0
- package/src/main/services/system-manager/SystemManagerConfigService.ts +19 -1
- package/src/main/services/system-manager/WorkflowPromptService.ts +58 -5
- package/src/main/services/system-manager/__tests__/AdminLoopInitializer.test.ts +129 -0
- package/src/main/services/system-manager/__tests__/SystemManagerConfigService.test.ts +60 -0
- package/src/main/services/teams-mvp/CollaborationBoardService.ts +2 -0
- package/src/main/services/teams-mvp/OpsRunbookContext.ts +60 -0
- package/src/main/services/teams-mvp/TaskDispatchService.test.ts +305 -0
- package/src/main/services/teams-mvp/TaskDispatchService.ts +250 -131
- package/src/main/services/teams-mvp/TeamProvisioningService.ts +12 -2
- package/src/main/services/teams-mvp/TeamWorkspaceService.test.ts +207 -0
- package/src/main/services/teams-mvp/TeamWorkspaceService.ts +104 -51
- package/src/main/services/teams-mvp/index.ts +6 -0
- package/src/main/utils/externalPlatformSessionRouting.ts +92 -0
- package/src/main/utils/toolApprovalRules.ts +151 -0
- package/src/renderer/App.tsx +24 -89
- package/src/renderer/api/httpClient.ts +132 -52
- package/src/renderer/api/providers.ts +5 -16
- package/src/renderer/components/chat/CommunityChatView.tsx +81 -0
- package/src/renderer/components/dashboard/DashboardView.tsx +130 -84
- package/src/renderer/components/extensions/ExtensionStoreView.tsx +39 -5
- package/src/renderer/components/extensions/ExtensionsSubTabTrigger.tsx +2 -1
- package/src/renderer/components/extensions/capability-packs/CapabilityPacksPanel.tsx +170 -0
- package/src/renderer/components/layout/PaneContent.tsx +10 -2
- package/src/renderer/components/layout/SortableTab.tsx +4 -0
- package/src/renderer/components/layout/TabBarActions.tsx +13 -16
- package/src/renderer/components/runtime/ProviderRuntimeSettingsDialog.tsx +4 -135
- package/src/renderer/components/schedules/SchedulesView.tsx +22 -14
- package/src/renderer/components/schedules/calendar/CalendarEventBlock.tsx +7 -6
- package/src/renderer/components/settings/SettingsTabs.tsx +24 -21
- package/src/renderer/components/settings/SettingsView.tsx +22 -13
- package/src/renderer/components/settings/components/SettingRow.tsx +13 -5
- package/src/renderer/components/settings/components/SettingsSectionCard.tsx +53 -0
- package/src/renderer/components/settings/components/SettingsSectionHeader.tsx +10 -6
- package/src/renderer/components/settings/components/SettingsSelect.tsx +12 -9
- package/src/renderer/components/settings/components/SettingsToggle.tsx +6 -5
- package/src/renderer/components/settings/components/index.ts +1 -0
- package/src/renderer/components/settings/sections/AdvancedSection.tsx +78 -59
- package/src/renderer/components/settings/sections/CliStatusSection.tsx +32 -44
- package/src/renderer/components/settings/sections/ConfigEditorDialog.tsx +1 -1
- package/src/renderer/components/settings/sections/GeneralSection.tsx +216 -186
- package/src/renderer/components/settings/sections/PlatformsSection.tsx +25 -17
- package/src/renderer/components/settings/sections/TaskBusSection.tsx +63 -22
- package/src/renderer/components/sidebar/SidebarSessions.tsx +120 -80
- package/src/renderer/components/sidebar/SidebarTaskItem.tsx +1 -1
- package/src/renderer/components/splash/splashScene.ts +6 -2
- package/src/renderer/components/system-manager/SystemManagerView.tsx +169 -255
- package/src/renderer/components/tasks/TasksView.tsx +63 -37
- package/src/renderer/components/team/CcSessionsSection.tsx +124 -89
- package/src/renderer/components/team/HarnessBrandLogos.tsx +318 -0
- package/src/renderer/components/team/HarnessSelect.tsx +25 -26
- package/src/renderer/components/team/TeamDetailView.tsx +137 -153
- package/src/renderer/components/team/TeamEmptyState.tsx +9 -37
- package/src/renderer/components/team/TeamListView.tsx +144 -30
- package/src/renderer/components/team/__tests__/CcSessionsSection.hasLocalFile.test.tsx +128 -0
- package/src/renderer/components/team/activity/ActivityItem.tsx +21 -9
- package/src/renderer/components/team/activity/ActivityTimeline.tsx +2 -2
- package/src/renderer/components/team/dialogs/AdvancedCliSection.tsx +1 -1
- package/src/renderer/components/team/dialogs/CreateTaskDialog.tsx +13 -10
- package/src/renderer/components/team/dialogs/CreateTeamDialog.tsx +189 -57
- package/src/renderer/components/team/dialogs/EditTeamDialog.tsx +9 -157
- package/src/renderer/components/team/dialogs/LaunchTeamDialog.tsx +19 -15
- package/src/renderer/components/team/dialogs/PlatformBindingDialog.tsx +48 -10
- package/src/renderer/components/team/dialogs/PlatformManualForm.tsx +11 -12
- package/src/renderer/components/team/dialogs/PlatformSetupQR.tsx +39 -37
- package/src/renderer/components/team/dialogs/RuntimeConfigDialog.tsx +434 -64
- package/src/renderer/components/team/dialogs/SendMessageDialog.tsx +12 -10
- package/src/renderer/components/team/dialogs/TaskDetailDialog.tsx +2 -2
- package/src/renderer/components/team/dialogs/__tests__/CreateTeamDialog.bindProject.test.tsx +399 -0
- package/src/renderer/components/team/dialogs/__tests__/CreateTeamDialog.chineseRepro.test.tsx +253 -0
- package/src/renderer/components/team/dialogs/platformAllowUtils.ts +91 -0
- package/src/renderer/components/team/dialogs/teammateRuntimeCompatibility.tsx +1 -1
- package/src/renderer/components/team/kanban/KanbanTaskCard.test.tsx +41 -0
- package/src/renderer/components/team/kanban/KanbanTaskCard.tsx +41 -86
- package/src/renderer/components/team/loop-console/LoopCommandComposer.tsx +310 -0
- package/src/renderer/components/team/loop-console/LoopConsolePanel.tsx +372 -0
- package/src/renderer/components/team/loop-console/loopSendIntent.test.ts +85 -0
- package/src/renderer/components/team/loop-console/loopSendIntent.ts +221 -0
- package/src/renderer/components/team/loop-console/useLeadSessionToolActivity.ts +74 -0
- package/src/renderer/components/team/loop-console/useLoopCommandSuggestions.ts +165 -0
- package/src/renderer/components/team/loop-console/useLoopConsoleController.ts +266 -0
- package/src/renderer/components/team/members/LeadModelRow.test.tsx +1 -1
- package/src/renderer/components/team/members/LeadModelRow.tsx +5 -3
- package/src/renderer/components/team/members/MemberDetailDialog.tsx +11 -0
- package/src/renderer/components/team/members/MemberDetailStats.tsx +13 -3
- package/src/renderer/components/team/members/MemberDraftRow.test.tsx +1 -1
- package/src/renderer/components/team/members/MemberDraftRow.tsx +1 -1
- package/src/renderer/components/team/members/MemberMessagesTab.tsx +2 -2
- package/src/renderer/components/team/members/MemberStatsTab.tsx +1 -1
- package/src/renderer/components/team/messages/MessageComposer.tsx +150 -44
- package/src/renderer/components/team/messages/MessagesFilterPopover.tsx +2 -2
- package/src/renderer/components/team/messages/MessagesPanel.tsx +34 -28
- package/src/renderer/components/team/schedule/CcCronScheduleDialog.tsx +6 -6
- package/src/renderer/components/team/taskLogs/ExactTaskLogCard.tsx +2 -2
- package/src/renderer/components/team/taskLogs/TaskLogStreamSection.tsx +1 -1
- package/src/renderer/components/terminal/TerminalPanel.tsx +2 -3
- package/src/renderer/components/ui/MentionableTextarea.tsx +5 -1
- package/src/renderer/constants/teamColors.ts +5 -5
- package/src/renderer/hooks/useExtensionsTabState.ts +1 -1
- package/src/renderer/hooks/useMentionDetection.ts +5 -1
- package/src/renderer/hooks/useProjectWorkflowCommands.ts +57 -0
- package/src/renderer/hooks/useTeamSuggestions.ts +2 -0
- package/src/renderer/index.css +19 -2
- package/src/renderer/main.tsx +7 -1
- package/src/renderer/store/index.ts +18 -1
- package/src/renderer/store/slices/extensionsSlice.ts +83 -0
- package/src/renderer/store/slices/tabSlice.ts +61 -0
- package/src/renderer/store/slices/teamSlice.ts +138 -9
- package/src/renderer/types/mention.ts +8 -0
- package/src/renderer/types/tabs.ts +3 -1
- package/src/renderer/utils/__tests__/bindProjectSlug.test.ts +69 -0
- package/src/renderer/utils/__tests__/groupTransformer.test.ts +148 -0
- package/src/renderer/utils/__tests__/initialRoute.test.ts +101 -0
- package/src/renderer/utils/__tests__/leadToolActivity.test.ts +124 -0
- package/src/renderer/utils/__tests__/mergeTeamMessages.test.ts +81 -0
- package/src/renderer/utils/__tests__/teamMessageFiltering.test.ts +213 -0
- package/src/renderer/utils/__tests__/teamMessageKey.test.ts +75 -0
- package/src/renderer/utils/__tests__/workflowCommandExecution.test.ts +173 -0
- package/src/renderer/utils/__tests__/workflowCommandSuggestions.test.ts +59 -0
- package/src/renderer/utils/bindProjectSlug.ts +57 -0
- package/src/renderer/utils/capabilityCommandExecution.ts +113 -0
- package/src/renderer/utils/initialRoute.ts +89 -0
- package/src/renderer/utils/leadToolActivity.ts +117 -0
- package/src/renderer/utils/loopShortcutSuggestions.ts +106 -0
- package/src/renderer/utils/mentionSuggestions.ts +1 -1
- package/src/renderer/utils/slashCommandRegistry.ts +231 -0
- package/src/renderer/utils/teamMentionDirective.ts +31 -0
- package/src/renderer/utils/workflowCommandExecution.ts +96 -0
- package/src/renderer/utils/workflowCommandSuggestions.ts +49 -0
- package/src/shared/types/api.ts +79 -4
- package/src/shared/types/ccConnect.ts +1 -0
- package/src/shared/types/extensions/api.ts +19 -0
- package/src/shared/types/extensions/capabilityPack.ts +118 -0
- package/src/shared/types/extensions/index.ts +29 -1
- package/src/shared/types/index.ts +6 -0
- package/src/shared/types/loopAssets.ts +54 -0
- package/src/shared/types/providers.ts +0 -16
- package/src/shared/types/systemManager.ts +26 -1
- package/src/shared/types/team.ts +43 -3
- package/src/shared/types/terminal.ts +2 -36
- package/src/shared/types/worker.test.ts +28 -0
- package/src/shared/types/worker.ts +3 -0
- package/src/shared/utils/__tests__/effortLevels.test.ts +88 -0
- package/src/shared/utils/__tests__/providerBackend.test.ts +88 -0
- package/src/shared/utils/__tests__/providerLaunchArgs.test.ts +220 -0
- package/src/shared/utils/claudeStreamJson.test.ts +187 -0
- package/src/shared/utils/claudeStreamJson.ts +153 -0
- package/src/shared/utils/providerLaunchArgs.ts +217 -0
- package/src/shared/utils/slashCommands.ts +10 -0
- package/src/types/node-pty.d.ts +8 -0
- package/dist-renderer/assets/channel-D0XS_akr.js +0 -1
- package/dist-renderer/assets/classDiagram-2ON5EDUG-D13Ffs0U.js +0 -1
- package/dist-renderer/assets/classDiagram-v2-WZHVMYZB-D13Ffs0U.js +0 -1
- package/dist-renderer/assets/clone-B1ZrxI1D.js +0 -1
- package/dist-renderer/assets/index-iyjkpSus.css +0 -32
- package/dist-renderer/assets/stateDiagram-v2-4FDKWEC3-Dmibmlso.js +0 -1
- package/src/main/services/system-manager/SystemManagerPtyService.ts +0 -233
- package/src/renderer/components/common/TerminalPane.tsx +0 -213
- package/src/renderer/components/team/dialogs/useTeamEditForm.ts +0 -292
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* teamSessionListMapper — mergeLocalAndCcSessions invariant tests.
|
|
3
|
+
*
|
|
4
|
+
* Regression guard for #20: a cc-only session (e.g. a Feishu listening
|
|
5
|
+
* session that has no local Claude JSONL yet) is listed so the user can see
|
|
6
|
+
* it is listening, but expanding it must NOT try to read a local detail file
|
|
7
|
+
* (which 404s and surfaces the misleading "会话文件已不存在"). The merged
|
|
8
|
+
* CcSession must therefore tag whether each entry is backed by a local file
|
|
9
|
+
* via `hasLocalFile`.
|
|
10
|
+
*/
|
|
11
|
+
import { describe, expect, it } from 'vitest';
|
|
12
|
+
|
|
13
|
+
import type { CcSessionListItem } from '@shared/types/ccConnect';
|
|
14
|
+
|
|
15
|
+
import type { LocalSessionSummary } from '../LocalSessionScanner';
|
|
16
|
+
import { mergeLocalAndCcSessions } from '../teamSessionListMapper';
|
|
17
|
+
|
|
18
|
+
const PROJECT = 'team-x';
|
|
19
|
+
|
|
20
|
+
function localSummary(id: string): LocalSessionSummary {
|
|
21
|
+
return {
|
|
22
|
+
id,
|
|
23
|
+
title: id,
|
|
24
|
+
projectId: PROJECT,
|
|
25
|
+
messageCount: 3,
|
|
26
|
+
userMessageCount: 1,
|
|
27
|
+
assistantMessageCount: 2,
|
|
28
|
+
inputTokens: 10,
|
|
29
|
+
outputTokens: 20,
|
|
30
|
+
cacheReadTokens: 0,
|
|
31
|
+
cacheCreationTokens: 0,
|
|
32
|
+
totalTokens: 30,
|
|
33
|
+
model: 'claude-sonnet',
|
|
34
|
+
active: false,
|
|
35
|
+
live: false,
|
|
36
|
+
startTime: null,
|
|
37
|
+
endTime: null,
|
|
38
|
+
createdAt: '2026-06-14T10:00:00Z',
|
|
39
|
+
updatedAt: '2026-06-14T10:00:00Z',
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
function ccItem(id: string, platform = 'feishu'): CcSessionListItem {
|
|
44
|
+
return {
|
|
45
|
+
id,
|
|
46
|
+
name: id,
|
|
47
|
+
session_key: id,
|
|
48
|
+
agent_session_id: id,
|
|
49
|
+
agent_type: 'claude-code' as CcSessionListItem['agent_type'],
|
|
50
|
+
active: true,
|
|
51
|
+
live: true,
|
|
52
|
+
history_count: 0,
|
|
53
|
+
created_at: '2026-06-14T10:00:00Z',
|
|
54
|
+
updated_at: '2026-06-14T10:00:00Z',
|
|
55
|
+
last_message: null,
|
|
56
|
+
platform,
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
describe('mergeLocalAndCcSessions — hasLocalFile flag (#20)', () => {
|
|
61
|
+
it('tags a cc-only session (no local JSONL) as hasLocalFile=false', () => {
|
|
62
|
+
// A Feishu listening session reported by cc-connect but with no local
|
|
63
|
+
// Claude JSONL yet. Expanding it must not attempt a local detail read.
|
|
64
|
+
const merged = mergeLocalAndCcSessions([], [ccItem('oc_feishu_only')], PROJECT);
|
|
65
|
+
|
|
66
|
+
const feishu = merged.find((s) => s.id === 'oc_feishu_only');
|
|
67
|
+
expect(feishu, 'cc-only session present in merged list').toBeDefined();
|
|
68
|
+
expect(feishu?.hasLocalFile).toBe(false);
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
it('tags a local session (JSONL-backed) as hasLocalFile=true', () => {
|
|
72
|
+
const merged = mergeLocalAndCcSessions([localSummary('local-1')], [], PROJECT);
|
|
73
|
+
|
|
74
|
+
const local = merged.find((s) => s.id === 'local-1');
|
|
75
|
+
expect(local, 'local session present in merged list').toBeDefined();
|
|
76
|
+
expect(local?.hasLocalFile).toBe(true);
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
it('tags a session backed by BOTH a local file and cc-connect as hasLocalFile=true', () => {
|
|
80
|
+
// Same agent_session_id appears in the local scan AND cc-connect: the
|
|
81
|
+
// local JSONL is authoritative, detail reads from it.
|
|
82
|
+
const sharedId = 'shared-1';
|
|
83
|
+
const merged = mergeLocalAndCcSessions([localSummary(sharedId)], [ccItem(sharedId)], PROJECT);
|
|
84
|
+
|
|
85
|
+
const shared = merged.find((s) => s.id === sharedId);
|
|
86
|
+
expect(shared, 'shared session appears once').toBeDefined();
|
|
87
|
+
expect(merged.filter((s) => s.id === sharedId)).toHaveLength(1);
|
|
88
|
+
expect(shared?.hasLocalFile).toBe(true);
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
it('flags each entry correctly in a mixed list', () => {
|
|
92
|
+
const merged = mergeLocalAndCcSessions(
|
|
93
|
+
[localSummary('local-a'), localSummary('shared-b')],
|
|
94
|
+
[ccItem('shared-b'), ccItem('feishu-c'), ccItem('feishu-d')],
|
|
95
|
+
PROJECT
|
|
96
|
+
);
|
|
97
|
+
|
|
98
|
+
const byId = new Map(merged.map((s) => [s.id, s.hasLocalFile]));
|
|
99
|
+
expect(byId.get('local-a')).toBe(true);
|
|
100
|
+
expect(byId.get('shared-b')).toBe(true);
|
|
101
|
+
expect(byId.get('feishu-c')).toBe(false);
|
|
102
|
+
expect(byId.get('feishu-d')).toBe(false);
|
|
103
|
+
});
|
|
104
|
+
});
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import type { LocalSessionSummary } from './LocalSessionScanner';
|
|
2
|
+
import type { CcSessionListItem } from '@shared/types/ccConnect';
|
|
3
|
+
import type { CcSession } from '@shared/types/api';
|
|
4
|
+
|
|
5
|
+
function toLastMessage(session: CcSessionListItem): CcSession['lastMessage'] {
|
|
6
|
+
return session.last_message
|
|
7
|
+
? {
|
|
8
|
+
role: session.last_message.role,
|
|
9
|
+
content: session.last_message.content,
|
|
10
|
+
timestamp: session.last_message.timestamp,
|
|
11
|
+
}
|
|
12
|
+
: null;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
function timestampMs(value: string): number {
|
|
16
|
+
const parsed = Date.parse(value);
|
|
17
|
+
return Number.isFinite(parsed) ? parsed : 0;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
function mapCcOnlySession(session: CcSessionListItem, projectId: string): CcSession {
|
|
21
|
+
return {
|
|
22
|
+
id: session.agent_session_id || session.id,
|
|
23
|
+
title: session.name || session.session_key,
|
|
24
|
+
projectId,
|
|
25
|
+
sessionKey: session.session_key,
|
|
26
|
+
platform: session.platform,
|
|
27
|
+
userName: session.user_name ?? null,
|
|
28
|
+
chatName: session.chat_name ?? null,
|
|
29
|
+
active: session.active,
|
|
30
|
+
live: session.live,
|
|
31
|
+
historyCount: session.history_count,
|
|
32
|
+
createdAt: session.created_at,
|
|
33
|
+
updatedAt: session.updated_at,
|
|
34
|
+
lastMessage: toLastMessage(session),
|
|
35
|
+
hasLocalFile: false,
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
export function mergeLocalAndCcSessions(
|
|
40
|
+
localSessions: LocalSessionSummary[],
|
|
41
|
+
ccSessions: CcSessionListItem[],
|
|
42
|
+
projectId: string
|
|
43
|
+
): CcSession[] {
|
|
44
|
+
const localSessionIds = new Set(localSessions.map((session) => session.id));
|
|
45
|
+
const ccByLocalSessionId = new Map(
|
|
46
|
+
ccSessions
|
|
47
|
+
.map((session) => [session.agent_session_id || session.id, session] as const)
|
|
48
|
+
.filter(([localSessionId]) => localSessionIds.has(localSessionId))
|
|
49
|
+
);
|
|
50
|
+
|
|
51
|
+
const localResults = localSessions.map((session): CcSession => {
|
|
52
|
+
const ccMeta = ccByLocalSessionId.get(session.id);
|
|
53
|
+
return {
|
|
54
|
+
id: session.id,
|
|
55
|
+
title: session.title || session.id,
|
|
56
|
+
projectId,
|
|
57
|
+
sessionKey: ccMeta?.session_key ?? session.id,
|
|
58
|
+
platform: ccMeta?.platform ?? 'local',
|
|
59
|
+
userName: ccMeta?.user_name ?? null,
|
|
60
|
+
chatName: ccMeta?.chat_name ?? null,
|
|
61
|
+
active: session.active,
|
|
62
|
+
live: session.live,
|
|
63
|
+
historyCount: session.messageCount,
|
|
64
|
+
createdAt: session.createdAt,
|
|
65
|
+
updatedAt: session.updatedAt,
|
|
66
|
+
lastMessage: ccMeta ? toLastMessage(ccMeta) : null,
|
|
67
|
+
hasLocalFile: true,
|
|
68
|
+
};
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
const ccOnlyResults = ccSessions
|
|
72
|
+
.filter((session) => !localSessionIds.has(session.agent_session_id || session.id))
|
|
73
|
+
.map((session) => mapCcOnlySession(session, projectId));
|
|
74
|
+
|
|
75
|
+
return [...localResults, ...ccOnlyResults].sort(
|
|
76
|
+
(a, b) => timestampMs(b.updatedAt) - timestampMs(a.updatedAt)
|
|
77
|
+
);
|
|
78
|
+
}
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import type { SystemManagerConfig, SystemManagerConfigPatch } from '@shared/types/systemManager';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Helm Loop bootstrap.
|
|
5
|
+
*
|
|
6
|
+
* On first open of the admin console, the GitHub Pages ops guide is fetched and
|
|
7
|
+
* fed to the admin lead session as its first turn, so the agent can seed its own
|
|
8
|
+
* CLAUDE.md from the manual. After a successful feed the `adminInitialized`
|
|
9
|
+
* marker is set so it never repeats.
|
|
10
|
+
*
|
|
11
|
+
* Extracted from server.ts as a pure, dependency-injected unit so the
|
|
12
|
+
* idempotency and failure semantics are unit-testable without spawning the
|
|
13
|
+
* direct-CLI runtime or hitting the network.
|
|
14
|
+
*/
|
|
15
|
+
|
|
16
|
+
/** Deterministic id for the bootstrap message (one-shot, never reused). */
|
|
17
|
+
export const ADMIN_INIT_MESSAGE_ID = 'helm-loop-init';
|
|
18
|
+
|
|
19
|
+
/** Lightweight HTML → plain text: strip script/style, drop tags, decode entities, collapse whitespace. */
|
|
20
|
+
export function htmlToPlainText(html: string): string {
|
|
21
|
+
return html
|
|
22
|
+
.replace(/<script[\s\S]*?<\/script>/gi, ' ')
|
|
23
|
+
.replace(/<style[\s\S]*?<\/style>/gi, ' ')
|
|
24
|
+
.replace(/<!--[\s\S]*?-->/g, ' ')
|
|
25
|
+
.replace(/<\/(p|div|li|h[1-6]|tr|br)>/gi, '\n')
|
|
26
|
+
.replace(/<[^>]+>/g, ' ')
|
|
27
|
+
.replace(/ /gi, ' ')
|
|
28
|
+
.replace(/&/gi, '&')
|
|
29
|
+
.replace(/</gi, '<')
|
|
30
|
+
.replace(/>/gi, '>')
|
|
31
|
+
.replace(/"/gi, '"')
|
|
32
|
+
.replace(/'/gi, "'")
|
|
33
|
+
.replace(/[ \t\f\v]+/g, ' ')
|
|
34
|
+
.replace(/\s*\n\s*/g, '\n')
|
|
35
|
+
.replace(/\n{3,}/g, '\n\n')
|
|
36
|
+
.trim();
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
/** Build the bootstrap prompt wrapping the guide text. Pure — tested directly. */
|
|
40
|
+
export function buildAdminInitMessage(guideText: string): string {
|
|
41
|
+
return [
|
|
42
|
+
'【Helm Loop 初始化】以下是 Hermit 运维手册全文。请通读并据此在你的工作目录初始化 CLAUDE.md,',
|
|
43
|
+
'建立对团队治理、消息路由、Loop 工作流的整体认知。',
|
|
44
|
+
'随后可用 `/workers` 查看所有数字员工及其工作路径,用 `@workerId` 直接调度对应员工。',
|
|
45
|
+
'',
|
|
46
|
+
'--- 运维手册 ---',
|
|
47
|
+
guideText,
|
|
48
|
+
].join('\n');
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
export interface AdminLoopInitDeps {
|
|
52
|
+
getConfig: () => Promise<SystemManagerConfig>;
|
|
53
|
+
updateConfig: (patch: SystemManagerConfigPatch) => Promise<SystemManagerConfig>;
|
|
54
|
+
/** Fetch the ops guide. Resolves with statusCode + raw body; rejects on network error. */
|
|
55
|
+
fetchGuide: () => Promise<{ statusCode: number; body: string }>;
|
|
56
|
+
/** Deliver the bootstrap message to the admin lead session. */
|
|
57
|
+
dispatch: (message: { text: string; messageId: string }) => Promise<void>;
|
|
58
|
+
/** Optional diagnostic sink (warnings only). */
|
|
59
|
+
log?: (message: string) => void;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
/**
|
|
63
|
+
* Run the one-shot bootstrap if it hasn't run yet.
|
|
64
|
+
*
|
|
65
|
+
* - Idempotent: returns immediately when `adminInitialized` is already set —
|
|
66
|
+
* does NOT fetch or dispatch.
|
|
67
|
+
* - Failure-tolerant: a network error, non-2xx status, or empty body returns
|
|
68
|
+
* WITHOUT setting the marker, so the next console open retries. Only a
|
|
69
|
+
* successful fetch + dispatch sets the flag.
|
|
70
|
+
*/
|
|
71
|
+
export async function ensureAdminLoopInitialized(deps: AdminLoopInitDeps): Promise<void> {
|
|
72
|
+
const config = await deps.getConfig();
|
|
73
|
+
if (config.adminInitialized) return;
|
|
74
|
+
|
|
75
|
+
let body = '';
|
|
76
|
+
try {
|
|
77
|
+
const res = await deps.fetchGuide();
|
|
78
|
+
if (res.statusCode >= 200 && res.statusCode < 300) {
|
|
79
|
+
body = htmlToPlainText(res.body);
|
|
80
|
+
}
|
|
81
|
+
} catch (err) {
|
|
82
|
+
deps.log?.(
|
|
83
|
+
`helm loop init: fetch failed (${err instanceof Error ? err.message : String(err)})`
|
|
84
|
+
);
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
if (!body.trim()) {
|
|
89
|
+
deps.log?.('helm loop init: empty guide body, will retry next open');
|
|
90
|
+
return;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
await deps.dispatch({ text: buildAdminInitMessage(body), messageId: ADMIN_INIT_MESSAGE_ID });
|
|
94
|
+
await deps.updateConfig({ adminInitialized: true });
|
|
95
|
+
}
|