codingbuddy 4.4.0 → 5.0.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 (201) hide show
  1. package/dist/src/agent/agent.module.js +3 -1
  2. package/dist/src/agent/agent.module.js.map +1 -1
  3. package/dist/src/agent/agent.service.d.ts +13 -4
  4. package/dist/src/agent/agent.service.js +125 -12
  5. package/dist/src/agent/agent.service.js.map +1 -1
  6. package/dist/src/agent/agent.types.d.ts +53 -0
  7. package/dist/src/agent/agent.types.js.map +1 -1
  8. package/dist/src/collaboration/discussion-engine.d.ts +14 -0
  9. package/dist/src/collaboration/discussion-engine.js +49 -0
  10. package/dist/src/collaboration/discussion-engine.js.map +1 -0
  11. package/dist/src/collaboration/index.d.ts +5 -0
  12. package/dist/src/collaboration/index.js +22 -0
  13. package/dist/src/collaboration/index.js.map +1 -0
  14. package/dist/src/collaboration/opinion-adapter.d.ts +14 -0
  15. package/dist/src/collaboration/opinion-adapter.js +56 -0
  16. package/dist/src/collaboration/opinion-adapter.js.map +1 -0
  17. package/dist/src/collaboration/terminal-formatter.d.ts +5 -0
  18. package/dist/src/collaboration/terminal-formatter.js +57 -0
  19. package/dist/src/collaboration/terminal-formatter.js.map +1 -0
  20. package/dist/src/collaboration/types.d.ts +50 -0
  21. package/dist/src/collaboration/types.js +53 -0
  22. package/dist/src/collaboration/types.js.map +1 -0
  23. package/dist/src/config/config.schema.d.ts +8 -0
  24. package/dist/src/config/config.schema.js +4 -0
  25. package/dist/src/config/config.schema.js.map +1 -1
  26. package/dist/src/context/context-document.service.d.ts +1 -1
  27. package/dist/src/context/context-document.service.js +6 -2
  28. package/dist/src/context/context-document.service.js.map +1 -1
  29. package/dist/src/context/context-document.types.d.ts +18 -0
  30. package/dist/src/context/context-document.types.js +13 -1
  31. package/dist/src/context/context-document.types.js.map +1 -1
  32. package/dist/src/context/context-parser.utils.js +32 -0
  33. package/dist/src/context/context-parser.utils.js.map +1 -1
  34. package/dist/src/context/context-serializer.utils.d.ts +3 -2
  35. package/dist/src/context/context-serializer.utils.js +25 -1
  36. package/dist/src/context/context-serializer.utils.js.map +1 -1
  37. package/dist/src/keyword/explicit-pattern-matcher.d.ts +3 -0
  38. package/dist/src/keyword/explicit-pattern-matcher.js +34 -0
  39. package/dist/src/keyword/explicit-pattern-matcher.js.map +1 -0
  40. package/dist/src/keyword/keyword.module.js +17 -1
  41. package/dist/src/keyword/keyword.module.js.map +1 -1
  42. package/dist/src/keyword/keyword.service.d.ts +2 -0
  43. package/dist/src/keyword/keyword.service.js +15 -0
  44. package/dist/src/keyword/keyword.service.js.map +1 -1
  45. package/dist/src/keyword/keyword.types.d.ts +6 -1
  46. package/dist/src/keyword/keyword.types.js +7 -1
  47. package/dist/src/keyword/keyword.types.js.map +1 -1
  48. package/dist/src/keyword/primary-agent-resolver.d.ts +5 -2
  49. package/dist/src/keyword/primary-agent-resolver.js +22 -1
  50. package/dist/src/keyword/primary-agent-resolver.js.map +1 -1
  51. package/dist/src/keyword/strategies/act-agent.strategy.js +8 -0
  52. package/dist/src/keyword/strategies/act-agent.strategy.js.map +1 -1
  53. package/dist/src/keyword/strategies/index.d.ts +1 -1
  54. package/dist/src/keyword/strategies/index.js.map +1 -1
  55. package/dist/src/keyword/strategies/resolution-strategy.interface.d.ts +3 -0
  56. package/dist/src/keyword/taskmaestro-detector.d.ts +1 -0
  57. package/dist/src/keyword/taskmaestro-detector.js +16 -0
  58. package/dist/src/keyword/taskmaestro-detector.js.map +1 -0
  59. package/dist/src/mcp/handlers/agent.handler.d.ts +1 -0
  60. package/dist/src/mcp/handlers/agent.handler.js +51 -2
  61. package/dist/src/mcp/handlers/agent.handler.js.map +1 -1
  62. package/dist/src/mcp/handlers/context-document.handler.d.ts +3 -0
  63. package/dist/src/mcp/handlers/context-document.handler.js +91 -10
  64. package/dist/src/mcp/handlers/context-document.handler.js.map +1 -1
  65. package/dist/src/mcp/handlers/discussion.handler.d.ts +14 -0
  66. package/dist/src/mcp/handlers/discussion.handler.js +168 -0
  67. package/dist/src/mcp/handlers/discussion.handler.js.map +1 -0
  68. package/dist/src/mcp/handlers/discussion.types.d.ts +18 -0
  69. package/dist/src/mcp/handlers/discussion.types.js +11 -0
  70. package/dist/src/mcp/handlers/discussion.types.js.map +1 -0
  71. package/dist/src/mcp/handlers/index.d.ts +3 -0
  72. package/dist/src/mcp/handlers/index.js +7 -1
  73. package/dist/src/mcp/handlers/index.js.map +1 -1
  74. package/dist/src/mcp/handlers/mode.handler.d.ts +3 -0
  75. package/dist/src/mcp/handlers/mode.handler.js +58 -0
  76. package/dist/src/mcp/handlers/mode.handler.js.map +1 -1
  77. package/dist/src/mcp/handlers/pipeline.handler.d.ts +14 -0
  78. package/dist/src/mcp/handlers/pipeline.handler.js +137 -0
  79. package/dist/src/mcp/handlers/pipeline.handler.js.map +1 -0
  80. package/dist/src/mcp/mcp.module.js +5 -0
  81. package/dist/src/mcp/mcp.module.js.map +1 -1
  82. package/dist/src/mcp/sse-auth.guard.js +4 -6
  83. package/dist/src/mcp/sse-auth.guard.js.map +1 -1
  84. package/dist/src/parallel-validation/extract-file-paths.d.ts +1 -0
  85. package/dist/src/parallel-validation/extract-file-paths.js +19 -0
  86. package/dist/src/parallel-validation/extract-file-paths.js.map +1 -0
  87. package/dist/src/parallel-validation/index.d.ts +5 -0
  88. package/dist/src/parallel-validation/index.js +12 -0
  89. package/dist/src/parallel-validation/index.js.map +1 -0
  90. package/dist/src/parallel-validation/overlap-matrix.d.ts +10 -0
  91. package/dist/src/parallel-validation/overlap-matrix.js +23 -0
  92. package/dist/src/parallel-validation/overlap-matrix.js.map +1 -0
  93. package/dist/src/parallel-validation/parallel-validation.handler.d.ts +8 -0
  94. package/dist/src/parallel-validation/parallel-validation.handler.js +84 -0
  95. package/dist/src/parallel-validation/parallel-validation.handler.js.map +1 -0
  96. package/dist/src/parallel-validation/parallel-validation.types.d.ts +12 -0
  97. package/dist/src/parallel-validation/parallel-validation.types.js +3 -0
  98. package/dist/src/parallel-validation/parallel-validation.types.js.map +1 -0
  99. package/dist/src/parallel-validation/wave-splitter.d.ts +2 -0
  100. package/dist/src/parallel-validation/wave-splitter.js +39 -0
  101. package/dist/src/parallel-validation/wave-splitter.js.map +1 -0
  102. package/dist/src/pipeline/index.d.ts +5 -0
  103. package/dist/src/pipeline/index.js +14 -0
  104. package/dist/src/pipeline/index.js.map +1 -0
  105. package/dist/src/pipeline/pipeline.executors.d.ts +2 -0
  106. package/dist/src/pipeline/pipeline.executors.js +79 -0
  107. package/dist/src/pipeline/pipeline.executors.js.map +1 -0
  108. package/dist/src/pipeline/pipeline.module.d.ts +2 -0
  109. package/dist/src/pipeline/pipeline.module.js +21 -0
  110. package/dist/src/pipeline/pipeline.module.js.map +1 -0
  111. package/dist/src/pipeline/pipeline.service.d.ts +8 -0
  112. package/dist/src/pipeline/pipeline.service.js +89 -0
  113. package/dist/src/pipeline/pipeline.service.js.map +1 -0
  114. package/dist/src/pipeline/pipeline.types.d.ts +47 -0
  115. package/dist/src/pipeline/pipeline.types.js +33 -0
  116. package/dist/src/pipeline/pipeline.types.js.map +1 -0
  117. package/dist/src/rules/rule-tracker.d.ts +24 -0
  118. package/dist/src/rules/rule-tracker.js +74 -0
  119. package/dist/src/rules/rule-tracker.js.map +1 -0
  120. package/dist/src/shared/event-bridge-reader.d.ts +17 -0
  121. package/dist/src/shared/event-bridge-reader.js +56 -0
  122. package/dist/src/shared/event-bridge-reader.js.map +1 -0
  123. package/dist/src/shared/version.d.ts +1 -1
  124. package/dist/src/shared/version.js +1 -1
  125. package/dist/src/tui/components/AgentDiscussionPanel.d.ts +8 -0
  126. package/dist/src/tui/components/AgentDiscussionPanel.js +21 -0
  127. package/dist/src/tui/components/AgentDiscussionPanel.js.map +1 -0
  128. package/dist/src/tui/components/AgentDiscussionPanel.spec.js +85 -0
  129. package/dist/src/tui/components/AgentDiscussionPanel.spec.js.map +1 -0
  130. package/dist/src/tui/components/FlowMap.d.ts +3 -1
  131. package/dist/src/tui/components/FlowMap.js +30 -3
  132. package/dist/src/tui/components/FlowMap.js.map +1 -1
  133. package/dist/src/tui/components/FlowMap.spec.js +88 -0
  134. package/dist/src/tui/components/FlowMap.spec.js.map +1 -1
  135. package/dist/src/tui/components/FocusedAgentPanel.d.ts +3 -1
  136. package/dist/src/tui/components/FocusedAgentPanel.js +8 -3
  137. package/dist/src/tui/components/FocusedAgentPanel.js.map +1 -1
  138. package/dist/src/tui/components/FocusedAgentPanel.spec.js +76 -0
  139. package/dist/src/tui/components/FocusedAgentPanel.spec.js.map +1 -1
  140. package/dist/src/tui/components/HeaderBar.d.ts +3 -1
  141. package/dist/src/tui/components/HeaderBar.js +12 -6
  142. package/dist/src/tui/components/HeaderBar.js.map +1 -1
  143. package/dist/src/tui/components/HeaderBar.spec.js +31 -13
  144. package/dist/src/tui/components/HeaderBar.spec.js.map +1 -1
  145. package/dist/src/tui/components/StageHealthBar.d.ts +5 -1
  146. package/dist/src/tui/components/StageHealthBar.js +6 -1
  147. package/dist/src/tui/components/StageHealthBar.js.map +1 -1
  148. package/dist/src/tui/components/StageHealthBar.spec.js +22 -0
  149. package/dist/src/tui/components/StageHealthBar.spec.js.map +1 -1
  150. package/dist/src/tui/components/agent-discussion-panel.pure.d.ts +10 -0
  151. package/dist/src/tui/components/agent-discussion-panel.pure.js +94 -0
  152. package/dist/src/tui/components/agent-discussion-panel.pure.js.map +1 -0
  153. package/dist/src/tui/components/focused-agent.pure.d.ts +1 -0
  154. package/dist/src/tui/components/focused-agent.pure.js +11 -0
  155. package/dist/src/tui/components/focused-agent.pure.js.map +1 -1
  156. package/dist/src/tui/components/index.d.ts +5 -1
  157. package/dist/src/tui/components/index.js +18 -1
  158. package/dist/src/tui/components/index.js.map +1 -1
  159. package/dist/src/tui/components/live.pure.d.ts +9 -0
  160. package/dist/src/tui/components/live.pure.js +70 -0
  161. package/dist/src/tui/components/live.pure.js.map +1 -0
  162. package/dist/src/tui/dashboard-app.js +10 -6
  163. package/dist/src/tui/dashboard-app.js.map +1 -1
  164. package/dist/src/tui/dashboard-app.spec.js +14 -0
  165. package/dist/src/tui/dashboard-app.spec.js.map +1 -1
  166. package/dist/src/tui/dashboard-types.d.ts +8 -0
  167. package/dist/src/tui/dashboard-types.js.map +1 -1
  168. package/dist/src/tui/eventbus-ui.integration.spec.js +3 -0
  169. package/dist/src/tui/eventbus-ui.integration.spec.js.map +1 -1
  170. package/dist/src/tui/events/index.d.ts +1 -1
  171. package/dist/src/tui/events/index.js.map +1 -1
  172. package/dist/src/tui/events/types.d.ts +6 -0
  173. package/dist/src/tui/events/types.js +1 -0
  174. package/dist/src/tui/events/types.js.map +1 -1
  175. package/dist/src/tui/hooks/index.d.ts +1 -1
  176. package/dist/src/tui/hooks/index.js +3 -3
  177. package/dist/src/tui/hooks/index.js.map +1 -1
  178. package/dist/src/tui/hooks/use-dashboard-state.d.ts +4 -1
  179. package/dist/src/tui/hooks/use-dashboard-state.js +26 -0
  180. package/dist/src/tui/hooks/use-dashboard-state.js.map +1 -1
  181. package/dist/src/tui/hooks/use-tick.d.ts +1 -0
  182. package/dist/src/tui/hooks/use-tick.js +15 -0
  183. package/dist/src/tui/hooks/use-tick.js.map +1 -0
  184. package/dist/src/tui/hooks/use-tick.spec.d.ts +1 -0
  185. package/dist/src/tui/hooks/use-tick.spec.js +70 -0
  186. package/dist/src/tui/hooks/use-tick.spec.js.map +1 -0
  187. package/dist/src/tui/index.d.ts +1 -1
  188. package/dist/src/tui/index.js +2 -2
  189. package/dist/src/tui/index.js.map +1 -1
  190. package/dist/src/tui-bundle.mjs +468 -133
  191. package/dist/tsconfig.build.tsbuildinfo +1 -1
  192. package/package.json +15 -14
  193. package/dist/src/tui/components/header-bar.pure.d.ts +0 -1
  194. package/dist/src/tui/components/header-bar.pure.js +0 -9
  195. package/dist/src/tui/components/header-bar.pure.js.map +0 -1
  196. package/dist/src/tui/hooks/use-clock.d.ts +0 -1
  197. package/dist/src/tui/hooks/use-clock.js +0 -16
  198. package/dist/src/tui/hooks/use-clock.js.map +0 -1
  199. package/dist/src/tui/hooks/use-clock.spec.js +0 -43
  200. package/dist/src/tui/hooks/use-clock.spec.js.map +0 -1
  201. /package/dist/src/tui/{hooks/use-clock.spec.d.ts → components/AgentDiscussionPanel.spec.d.ts} +0 -0
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.executeStage = executeStage;
4
+ const child_process_1 = require("child_process");
5
+ async function executeStage(stage, input) {
6
+ const startedAt = new Date().toISOString();
7
+ const startTime = Date.now();
8
+ try {
9
+ let output;
10
+ switch (stage.type) {
11
+ case 'command':
12
+ output = executeCommandStage(stage.config, input);
13
+ break;
14
+ case 'agent':
15
+ output = executeAgentStage(stage.config, input);
16
+ break;
17
+ case 'skill':
18
+ output = executeSkillStage(stage.config, input);
19
+ break;
20
+ default:
21
+ return {
22
+ stageId: stage.id,
23
+ status: 'failed',
24
+ error: `Unknown stage type: ${stage.type}`,
25
+ startedAt,
26
+ completedAt: new Date().toISOString(),
27
+ durationMs: Date.now() - startTime,
28
+ };
29
+ }
30
+ return {
31
+ stageId: stage.id,
32
+ status: 'completed',
33
+ output,
34
+ startedAt,
35
+ completedAt: new Date().toISOString(),
36
+ durationMs: Date.now() - startTime,
37
+ };
38
+ }
39
+ catch (error) {
40
+ return {
41
+ stageId: stage.id,
42
+ status: 'failed',
43
+ error: error instanceof Error ? error.message : String(error),
44
+ startedAt,
45
+ completedAt: new Date().toISOString(),
46
+ durationMs: Date.now() - startTime,
47
+ };
48
+ }
49
+ }
50
+ function executeCommandStage(config, input) {
51
+ const env = { ...process.env };
52
+ if (input !== undefined) {
53
+ env.PIPELINE_INPUT = input;
54
+ }
55
+ const result = (0, child_process_1.execSync)(config.command, {
56
+ encoding: 'utf-8',
57
+ env,
58
+ timeout: 60_000,
59
+ });
60
+ return result;
61
+ }
62
+ function executeAgentStage(config, input) {
63
+ const parts = [`[Agent: ${config.agentName}]`, `[Prompt: ${config.prompt}]`];
64
+ if (input !== undefined) {
65
+ parts.push(`[Input: ${input}]`);
66
+ }
67
+ return parts.join('\n');
68
+ }
69
+ function executeSkillStage(config, input) {
70
+ const parts = [`[Skill: ${config.skillName}]`];
71
+ if (config.args) {
72
+ parts.push(`[Args: ${config.args}]`);
73
+ }
74
+ if (input !== undefined) {
75
+ parts.push(`[Input: ${input}]`);
76
+ }
77
+ return parts.join('\n');
78
+ }
79
+ //# sourceMappingURL=pipeline.executors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pipeline.executors.js","sourceRoot":"","sources":["../../../src/pipeline/pipeline.executors.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare class PipelineModule {
2
+ }
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.PipelineModule = void 0;
10
+ const common_1 = require("@nestjs/common");
11
+ const pipeline_service_1 = require("./pipeline.service");
12
+ let PipelineModule = class PipelineModule {
13
+ };
14
+ exports.PipelineModule = PipelineModule;
15
+ exports.PipelineModule = PipelineModule = __decorate([
16
+ (0, common_1.Module)({
17
+ providers: [pipeline_service_1.PipelineService],
18
+ exports: [pipeline_service_1.PipelineService],
19
+ })
20
+ ], PipelineModule);
21
+ //# sourceMappingURL=pipeline.module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pipeline.module.js","sourceRoot":"","sources":["../../../src/pipeline/pipeline.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,yDAAqD;AAM9C,IAAM,cAAc,GAApB,MAAM,cAAc;CAAG,CAAA;AAAjB,wCAAc;yBAAd,cAAc;IAJ1B,IAAA,eAAM,EAAC;QACN,SAAS,EAAE,CAAC,kCAAe,CAAC;QAC5B,OAAO,EAAE,CAAC,kCAAe,CAAC;KAC3B,CAAC;GACW,cAAc,CAAG"}
@@ -0,0 +1,8 @@
1
+ import type { PipelineDefinition, PipelineExecution } from './pipeline.types';
2
+ export declare class PipelineService {
3
+ private readonly executions;
4
+ runPipeline(definition: PipelineDefinition): Promise<PipelineExecution>;
5
+ getStatus(executionId: string): PipelineExecution | undefined;
6
+ resumePipeline(executionId: string, updatedDefinition: PipelineDefinition): Promise<PipelineExecution>;
7
+ private executeFromStage;
8
+ }
@@ -0,0 +1,89 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.PipelineService = void 0;
10
+ const common_1 = require("@nestjs/common");
11
+ const crypto_1 = require("crypto");
12
+ const pipeline_executors_1 = require("./pipeline.executors");
13
+ let PipelineService = class PipelineService {
14
+ constructor() {
15
+ this.executions = new Map();
16
+ }
17
+ async runPipeline(definition) {
18
+ const executionId = (0, crypto_1.randomUUID)();
19
+ const startedAt = new Date().toISOString();
20
+ const execution = await this.executeFromStage(executionId, definition, 0, [], startedAt);
21
+ this.executions.set(executionId, execution);
22
+ return execution;
23
+ }
24
+ getStatus(executionId) {
25
+ return this.executions.get(executionId);
26
+ }
27
+ async resumePipeline(executionId, updatedDefinition) {
28
+ const existing = this.executions.get(executionId);
29
+ if (!existing) {
30
+ throw new Error('Execution not found');
31
+ }
32
+ if (existing.status !== 'failed') {
33
+ throw new Error('Pipeline is not in a failed state');
34
+ }
35
+ const failedIndex = existing.stageResults.findIndex(r => r.status === 'failed');
36
+ const preservedResults = existing.stageResults.slice(0, failedIndex);
37
+ const execution = await this.executeFromStage(executionId, updatedDefinition, failedIndex, [...preservedResults], existing.startedAt);
38
+ this.executions.set(executionId, execution);
39
+ return execution;
40
+ }
41
+ async executeFromStage(executionId, definition, startIndex, previousResults, startedAt) {
42
+ const stageResults = [...previousResults];
43
+ let lastOutput;
44
+ if (previousResults.length > 0) {
45
+ const lastResult = previousResults[previousResults.length - 1];
46
+ lastOutput = lastResult.output?.trim();
47
+ }
48
+ for (let i = startIndex; i < definition.stages.length; i++) {
49
+ const stage = definition.stages[i];
50
+ const inProgress = {
51
+ id: executionId,
52
+ pipelineId: definition.id,
53
+ status: 'running',
54
+ currentStageIndex: i,
55
+ stageResults: [...stageResults],
56
+ startedAt,
57
+ };
58
+ this.executions.set(executionId, inProgress);
59
+ const result = await (0, pipeline_executors_1.executeStage)(stage, lastOutput);
60
+ stageResults.push(result);
61
+ if (result.status === 'failed') {
62
+ return {
63
+ id: executionId,
64
+ pipelineId: definition.id,
65
+ status: 'failed',
66
+ currentStageIndex: i,
67
+ stageResults,
68
+ startedAt,
69
+ completedAt: new Date().toISOString(),
70
+ };
71
+ }
72
+ lastOutput = result.output?.trim();
73
+ }
74
+ return {
75
+ id: executionId,
76
+ pipelineId: definition.id,
77
+ status: 'completed',
78
+ currentStageIndex: definition.stages.length - 1,
79
+ stageResults,
80
+ startedAt,
81
+ completedAt: new Date().toISOString(),
82
+ };
83
+ }
84
+ };
85
+ exports.PipelineService = PipelineService;
86
+ exports.PipelineService = PipelineService = __decorate([
87
+ (0, common_1.Injectable)()
88
+ ], PipelineService);
89
+ //# sourceMappingURL=pipeline.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pipeline.service.js","sourceRoot":"","sources":["../../../src/pipeline/pipeline.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,47 @@
1
+ export type PipelineStageType = 'command' | 'agent' | 'skill';
2
+ export interface CommandStageConfig {
3
+ readonly command: string;
4
+ }
5
+ export interface AgentStageConfig {
6
+ readonly agentName: string;
7
+ readonly prompt: string;
8
+ }
9
+ export interface SkillStageConfig {
10
+ readonly skillName: string;
11
+ readonly args?: string;
12
+ }
13
+ export type PipelineStageConfig = CommandStageConfig | AgentStageConfig | SkillStageConfig;
14
+ export interface PipelineStage {
15
+ readonly id: string;
16
+ readonly name: string;
17
+ readonly type: PipelineStageType;
18
+ readonly config: PipelineStageConfig;
19
+ }
20
+ export interface PipelineDefinition {
21
+ readonly id: string;
22
+ readonly name: string;
23
+ readonly stages: readonly PipelineStage[];
24
+ }
25
+ export type PipelineStageStatus = 'pending' | 'running' | 'completed' | 'failed' | 'skipped';
26
+ export interface PipelineStageResult {
27
+ readonly stageId: string;
28
+ readonly status: PipelineStageStatus;
29
+ readonly output?: string;
30
+ readonly error?: string;
31
+ readonly startedAt: string;
32
+ readonly completedAt?: string;
33
+ readonly durationMs?: number;
34
+ }
35
+ export type PipelineExecutionStatus = 'running' | 'completed' | 'failed' | 'paused';
36
+ export interface PipelineExecution {
37
+ readonly id: string;
38
+ readonly pipelineId: string;
39
+ readonly status: PipelineExecutionStatus;
40
+ readonly currentStageIndex: number;
41
+ readonly stageResults: readonly PipelineStageResult[];
42
+ readonly startedAt: string;
43
+ readonly completedAt?: string;
44
+ }
45
+ export declare function isValidStageType(value: unknown): value is PipelineStageType;
46
+ export declare function isValidPipelineStage(value: unknown): value is PipelineStage;
47
+ export declare function isValidPipelineDefinition(value: unknown): value is PipelineDefinition;
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isValidStageType = isValidStageType;
4
+ exports.isValidPipelineStage = isValidPipelineStage;
5
+ exports.isValidPipelineDefinition = isValidPipelineDefinition;
6
+ const VALID_STAGE_TYPES = ['command', 'agent', 'skill'];
7
+ function isValidStageType(value) {
8
+ return typeof value === 'string' && VALID_STAGE_TYPES.includes(value);
9
+ }
10
+ function isValidPipelineStage(value) {
11
+ if (typeof value !== 'object' || value === null)
12
+ return false;
13
+ const obj = value;
14
+ return (typeof obj.id === 'string' &&
15
+ obj.id.length > 0 &&
16
+ typeof obj.name === 'string' &&
17
+ obj.name.length > 0 &&
18
+ isValidStageType(obj.type) &&
19
+ typeof obj.config === 'object' &&
20
+ obj.config !== null);
21
+ }
22
+ function isValidPipelineDefinition(value) {
23
+ if (typeof value !== 'object' || value === null)
24
+ return false;
25
+ const obj = value;
26
+ return (typeof obj.id === 'string' &&
27
+ obj.id.length > 0 &&
28
+ typeof obj.name === 'string' &&
29
+ obj.name.length > 0 &&
30
+ Array.isArray(obj.stages) &&
31
+ obj.stages.every((stage) => isValidPipelineStage(stage)));
32
+ }
33
+ //# sourceMappingURL=pipeline.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pipeline.types.js","sourceRoot":"","sources":["../../../src/pipeline/pipeline.types.ts"],"names":[],"mappings":";;AA0HA,4CAEC;AAKD,oDAYC;AAKD,8DAWC;AAxCD,MAAM,iBAAiB,GAAiC,CAAC,SAAS,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;AAKtF,SAAgB,gBAAgB,CAAC,KAAc;IAC7C,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAI,iBAAiB,CAAC,QAAQ,CAAC,KAA0B,CAAC,CAAC;AAC7F,CAAC;AAKD,SAAgB,oBAAoB,CAAC,KAAc;IACjD,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI;QAAE,OAAO,KAAK,CAAC;IAC9D,MAAM,GAAG,GAAG,KAAgC,CAAC;IAC7C,OAAO,CACL,OAAO,GAAG,CAAC,EAAE,KAAK,QAAQ;QAC1B,GAAG,CAAC,EAAE,CAAC,MAAM,GAAG,CAAC;QACjB,OAAO,GAAG,CAAC,IAAI,KAAK,QAAQ;QAC5B,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC;QACnB,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC;QAC1B,OAAO,GAAG,CAAC,MAAM,KAAK,QAAQ;QAC9B,GAAG,CAAC,MAAM,KAAK,IAAI,CACpB,CAAC;AACJ,CAAC;AAKD,SAAgB,yBAAyB,CAAC,KAAc;IACtD,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI;QAAE,OAAO,KAAK,CAAC;IAC9D,MAAM,GAAG,GAAG,KAAgC,CAAC;IAC7C,OAAO,CACL,OAAO,GAAG,CAAC,EAAE,KAAK,QAAQ;QAC1B,GAAG,CAAC,EAAE,CAAC,MAAM,GAAG,CAAC;QACjB,OAAO,GAAG,CAAC,IAAI,KAAK,QAAQ;QAC5B,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC;QACnB,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC;QACzB,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,KAAc,EAAE,EAAE,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,CAClE,CAAC;AACJ,CAAC"}
@@ -0,0 +1,24 @@
1
+ export interface RuleStats {
2
+ count: number;
3
+ lastUsed: number;
4
+ }
5
+ export interface RuleEffectivenessReport {
6
+ totalRulesTracked: number;
7
+ generatedAt: number;
8
+ entries: Array<{
9
+ name: string;
10
+ count: number;
11
+ lastUsed: number;
12
+ }>;
13
+ }
14
+ export declare class RuleTracker {
15
+ private readonly statsPath;
16
+ private stats;
17
+ constructor(statsPath: string);
18
+ static fromFile(statsPath: string): Promise<RuleTracker>;
19
+ trackRuleUsage(ruleNames: string[]): void;
20
+ getStats(): Record<string, RuleStats>;
21
+ detectUnusedRules(allRuleNames: string[], thresholdDays: number): string[];
22
+ generateReport(): RuleEffectivenessReport;
23
+ save(): Promise<void>;
24
+ }
@@ -0,0 +1,74 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RuleTracker = void 0;
4
+ const promises_1 = require("fs/promises");
5
+ const fs_1 = require("fs");
6
+ const path_1 = require("path");
7
+ class RuleTracker {
8
+ constructor(statsPath) {
9
+ this.statsPath = statsPath;
10
+ this.stats = {};
11
+ }
12
+ static async fromFile(statsPath) {
13
+ const tracker = new RuleTracker(statsPath);
14
+ try {
15
+ const raw = await (0, promises_1.readFile)(statsPath, 'utf-8');
16
+ tracker.stats = JSON.parse(raw);
17
+ }
18
+ catch {
19
+ }
20
+ return tracker;
21
+ }
22
+ trackRuleUsage(ruleNames) {
23
+ const now = Date.now();
24
+ for (const name of ruleNames) {
25
+ if (!name)
26
+ continue;
27
+ if (this.stats[name]) {
28
+ this.stats[name].count += 1;
29
+ this.stats[name].lastUsed = now;
30
+ }
31
+ else {
32
+ this.stats[name] = { count: 1, lastUsed: now };
33
+ }
34
+ }
35
+ }
36
+ getStats() {
37
+ return JSON.parse(JSON.stringify(this.stats));
38
+ }
39
+ detectUnusedRules(allRuleNames, thresholdDays) {
40
+ const thresholdMs = thresholdDays * 24 * 60 * 60 * 1000;
41
+ const now = Date.now();
42
+ const unused = [];
43
+ for (const name of allRuleNames) {
44
+ const stat = this.stats[name];
45
+ if (!stat || now - stat.lastUsed > thresholdMs) {
46
+ unused.push(name);
47
+ }
48
+ }
49
+ return unused;
50
+ }
51
+ generateReport() {
52
+ const entries = Object.entries(this.stats)
53
+ .map(([name, stat]) => ({
54
+ name,
55
+ count: stat.count,
56
+ lastUsed: stat.lastUsed,
57
+ }))
58
+ .sort((a, b) => b.count - a.count);
59
+ return {
60
+ totalRulesTracked: entries.length,
61
+ generatedAt: Date.now(),
62
+ entries,
63
+ };
64
+ }
65
+ async save() {
66
+ const dir = (0, path_1.dirname)(this.statsPath);
67
+ if (!(0, fs_1.existsSync)(dir)) {
68
+ (0, fs_1.mkdirSync)(dir, { recursive: true });
69
+ }
70
+ await (0, promises_1.writeFile)(this.statsPath, JSON.stringify(this.stats, null, 2), 'utf-8');
71
+ }
72
+ }
73
+ exports.RuleTracker = RuleTracker;
74
+ //# sourceMappingURL=rule-tracker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rule-tracker.js","sourceRoot":"","sources":["../../../src/rules/rule-tracker.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ export declare const EVENT_TYPES: readonly ["tool_call", "session_start", "session_end", "pattern_detected", "rule_suggested"];
2
+ export type EventType = (typeof EVENT_TYPES)[number];
3
+ export interface BridgeEvent {
4
+ ts: string;
5
+ type: EventType;
6
+ session_id: string;
7
+ payload: Record<string, unknown>;
8
+ }
9
+ export declare class EventBridgeReader {
10
+ readonly eventsDir: string;
11
+ private readonly sessionId;
12
+ private offset;
13
+ constructor(sessionId: string, eventsDir?: string);
14
+ private get filePath();
15
+ readNewEvents(): Promise<BridgeEvent[]>;
16
+ cleanup(): Promise<void>;
17
+ }
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EventBridgeReader = exports.EVENT_TYPES = void 0;
4
+ const fs_1 = require("fs");
5
+ const path_1 = require("path");
6
+ const os_1 = require("os");
7
+ exports.EVENT_TYPES = [
8
+ 'tool_call',
9
+ 'session_start',
10
+ 'session_end',
11
+ 'pattern_detected',
12
+ 'rule_suggested',
13
+ ];
14
+ class EventBridgeReader {
15
+ constructor(sessionId, eventsDir) {
16
+ this.offset = 0;
17
+ this.sessionId = sessionId;
18
+ this.eventsDir = eventsDir ?? (0, path_1.join)((0, os_1.homedir)(), '.codingbuddy', 'events');
19
+ }
20
+ get filePath() {
21
+ return (0, path_1.join)(this.eventsDir, `${this.sessionId}.jsonl`);
22
+ }
23
+ async readNewEvents() {
24
+ let content;
25
+ try {
26
+ const buffer = await fs_1.promises.readFile(this.filePath, 'utf-8');
27
+ content = buffer.slice(this.offset);
28
+ this.offset = buffer.length;
29
+ }
30
+ catch {
31
+ return [];
32
+ }
33
+ if (!content) {
34
+ return [];
35
+ }
36
+ const events = [];
37
+ const lines = content.split('\n').filter(line => line.trim().length > 0);
38
+ for (const line of lines) {
39
+ try {
40
+ events.push(JSON.parse(line));
41
+ }
42
+ catch {
43
+ }
44
+ }
45
+ return events;
46
+ }
47
+ async cleanup() {
48
+ try {
49
+ await fs_1.promises.unlink(this.filePath);
50
+ }
51
+ catch {
52
+ }
53
+ }
54
+ }
55
+ exports.EventBridgeReader = EventBridgeReader;
56
+ //# sourceMappingURL=event-bridge-reader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"event-bridge-reader.js","sourceRoot":"","sources":["../../../src/shared/event-bridge-reader.ts"],"names":[],"mappings":";;;AAMA,2BAAoC;AACpC,+BAA4B;AAC5B,2BAA6B;AAGhB,QAAA,WAAW,GAAG;IACzB,WAAW;IACX,eAAe;IACf,aAAa;IACb,kBAAkB;IAClB,gBAAgB;CACR,CAAC;AAgBX,MAAa,iBAAiB;IAK5B,YAAY,SAAiB,EAAE,SAAkB;QAFzC,WAAM,GAAG,CAAC,CAAC;QAGjB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,SAAS,GAAG,SAAS,IAAI,IAAA,WAAI,EAAC,IAAA,YAAO,GAAE,EAAE,cAAc,EAAE,QAAQ,CAAC,CAAC;IAC1E,CAAC;IAED,IAAY,QAAQ;QAClB,OAAO,IAAA,WAAI,EAAC,IAAI,CAAC,SAAS,EAAE,GAAG,IAAI,CAAC,SAAS,QAAQ,CAAC,CAAC;IACzD,CAAC;IAOD,KAAK,CAAC,aAAa;QACjB,IAAI,OAAe,CAAC;QACpB,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,aAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;YACzD,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACpC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;QAC9B,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,MAAM,MAAM,GAAkB,EAAE,CAAC;QACjC,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAEzE,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,IAAI,CAAC;gBACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAgB,CAAC,CAAC;YAC/C,CAAC;YAAC,MAAM,CAAC;YAET,CAAC;QACH,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAGD,KAAK,CAAC,OAAO;QACX,IAAI,CAAC;YACH,MAAM,aAAE,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACjC,CAAC;QAAC,MAAM,CAAC;QAET,CAAC;IACH,CAAC;CACF;AAvDD,8CAuDC"}
@@ -1 +1 @@
1
- export declare const VERSION = "4.4.0";
1
+ export declare const VERSION = "4.5.0";
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.VERSION = void 0;
4
- exports.VERSION = '4.4.0';
4
+ exports.VERSION = '4.5.0';
5
5
  //# sourceMappingURL=version.js.map
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ import type { DiscussionRound } from '../../collaboration/types';
3
+ export interface AgentDiscussionPanelProps {
4
+ rounds: readonly DiscussionRound[];
5
+ width: number;
6
+ height: number;
7
+ }
8
+ export declare function AgentDiscussionPanel({ rounds, width, height, }: AgentDiscussionPanelProps): React.ReactElement;
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AgentDiscussionPanel = AgentDiscussionPanel;
4
+ const react_1 = require("react");
5
+ const ink_1 = require("ink");
6
+ const theme_1 = require("../utils/theme");
7
+ const agent_discussion_panel_pure_1 = require("./agent-discussion-panel.pure");
8
+ const LINE_COLORS = {
9
+ opinion: 'white',
10
+ 'cross-review': 'cyan',
11
+ consensus: 'green',
12
+ header: 'magenta',
13
+ empty: 'gray',
14
+ };
15
+ function AgentDiscussionPanel({ rounds, width, height, }) {
16
+ const lines = (0, react_1.useMemo)(() => (0, agent_discussion_panel_pure_1.renderDiscussionPanel)(rounds, width), [rounds, width]);
17
+ const maxLines = Math.max(0, height - 2);
18
+ const visibleLines = lines.slice(0, maxLines);
19
+ return (react_1.default.createElement(ink_1.Box, { flexDirection: "column", width: width, height: height, borderStyle: "round", borderColor: theme_1.BORDER_COLORS.panel }, visibleLines.map((line, i) => (react_1.default.createElement(ink_1.Text, { key: i, color: LINE_COLORS[line.type], bold: line.type === 'header' || line.type === 'consensus', dimColor: line.type === 'empty', wrap: "truncate" }, line.text)))));
20
+ }
21
+ //# sourceMappingURL=AgentDiscussionPanel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AgentDiscussionPanel.js","sourceRoot":"","sources":["../../../../src/tui/components/AgentDiscussionPanel.tsx"],"names":[],"mappings":";;AA+BA,oDAmCC;AA5DD,iCAAuC;AACvC,6BAAgC;AAEhC,0CAA+C;AAC/C,+EAA2F;AAS3F,MAAM,WAAW,GAA2C;IAC1D,OAAO,EAAE,OAAO;IAChB,cAAc,EAAE,MAAM;IACtB,SAAS,EAAE,OAAO;IAClB,MAAM,EAAE,SAAS;IACjB,KAAK,EAAE,MAAM;CACd,CAAC;AAMF,SAAgB,oBAAoB,CAAC,EACnC,MAAM,EACN,KAAK,EACL,MAAM,GACoB;IAC1B,MAAM,KAAK,GAAG,IAAA,eAAO,EACnB,GAAG,EAAE,CAAC,IAAA,mDAAqB,EAAC,MAAM,EAAE,KAAK,CAAC,EAC1C,CAAC,MAAM,EAAE,KAAK,CAAC,CAChB,CAAC;IAGF,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC;IACzC,MAAM,YAAY,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;IAE9C,OAAO,CACL,8BAAC,SAAG,IACF,aAAa,EAAC,QAAQ,EACtB,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,MAAM,EACd,WAAW,EAAC,OAAO,EACnB,WAAW,EAAE,qBAAa,CAAC,KAAK,IAE/B,YAAY,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CAC7B,8BAAC,UAAI,IACH,GAAG,EAAE,CAAC,EACN,KAAK,EAAE,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAC7B,IAAI,EAAE,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,IAAI,CAAC,IAAI,KAAK,WAAW,EACzD,QAAQ,EAAE,IAAI,CAAC,IAAI,KAAK,OAAO,EAC/B,IAAI,EAAC,UAAU,IAEd,IAAI,CAAC,IAAI,CACL,CACR,CAAC,CACE,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const react_1 = require("react");
4
+ const vitest_1 = require("vitest");
5
+ const ink_testing_library_1 = require("ink-testing-library");
6
+ const AgentDiscussionPanel_1 = require("./AgentDiscussionPanel");
7
+ const types_1 = require("../../collaboration/types");
8
+ function makeRound() {
9
+ return {
10
+ roundNumber: 1,
11
+ opinions: [
12
+ (0, types_1.createAgentOpinion)({
13
+ agentId: 'arch-1',
14
+ agentName: 'architecture',
15
+ stance: 'approve',
16
+ reasoning: 'Clean design',
17
+ }),
18
+ (0, types_1.createAgentOpinion)({
19
+ agentId: 'sec-1',
20
+ agentName: 'security',
21
+ stance: 'concern',
22
+ reasoning: 'Auth needs review',
23
+ }),
24
+ (0, types_1.createAgentOpinion)({
25
+ agentId: 'test-1',
26
+ agentName: 'test-strategy',
27
+ stance: 'approve',
28
+ reasoning: 'Good testability',
29
+ }),
30
+ ],
31
+ crossReviews: [
32
+ (0, types_1.createCrossReview)({
33
+ fromAgentId: 'arch-1',
34
+ toAgentId: 'sec-1',
35
+ stance: 'approve',
36
+ comment: 'Middleware pattern solves it',
37
+ }),
38
+ ],
39
+ };
40
+ }
41
+ (0, vitest_1.describe)('tui/components/AgentDiscussionPanel', () => {
42
+ (0, vitest_1.it)('should render discussion with agent opinions', () => {
43
+ const { lastFrame } = (0, ink_testing_library_1.render)(react_1.default.createElement(AgentDiscussionPanel_1.AgentDiscussionPanel, { rounds: [makeRound()], width: 80, height: 20 }));
44
+ const frame = lastFrame() ?? '';
45
+ (0, vitest_1.expect)(frame).toContain('Agent Discussion');
46
+ (0, vitest_1.expect)(frame).toContain('architecture');
47
+ (0, vitest_1.expect)(frame).toContain('security');
48
+ (0, vitest_1.expect)(frame).toContain('test-strategy');
49
+ });
50
+ (0, vitest_1.it)('should render consensus line', () => {
51
+ const { lastFrame } = (0, ink_testing_library_1.render)(react_1.default.createElement(AgentDiscussionPanel_1.AgentDiscussionPanel, { rounds: [makeRound()], width: 80, height: 20 }));
52
+ const frame = lastFrame() ?? '';
53
+ (0, vitest_1.expect)(frame).toContain('Consensus');
54
+ (0, vitest_1.expect)(frame).toContain('2/3');
55
+ });
56
+ (0, vitest_1.it)('should render cross-review with arrow', () => {
57
+ const { lastFrame } = (0, ink_testing_library_1.render)(react_1.default.createElement(AgentDiscussionPanel_1.AgentDiscussionPanel, { rounds: [makeRound()], width: 80, height: 20 }));
58
+ const frame = lastFrame() ?? '';
59
+ (0, vitest_1.expect)(frame).toContain('→');
60
+ (0, vitest_1.expect)(frame).toContain('agrees');
61
+ });
62
+ (0, vitest_1.it)('should render empty state when no rounds', () => {
63
+ const { lastFrame } = (0, ink_testing_library_1.render)(react_1.default.createElement(AgentDiscussionPanel_1.AgentDiscussionPanel, { rounds: [], width: 80, height: 10 }));
64
+ const frame = lastFrame() ?? '';
65
+ (0, vitest_1.expect)(frame).toContain('No agent discussion yet');
66
+ });
67
+ (0, vitest_1.it)('should truncate lines to fit height', () => {
68
+ const manyOpinions = Array.from({ length: 20 }, (_, i) => (0, types_1.createAgentOpinion)({
69
+ agentId: `a${i}`,
70
+ agentName: `agent-${i}`,
71
+ stance: 'approve',
72
+ reasoning: `Reason ${i}`,
73
+ }));
74
+ const round = {
75
+ roundNumber: 1,
76
+ opinions: manyOpinions,
77
+ crossReviews: [],
78
+ };
79
+ const { lastFrame } = (0, ink_testing_library_1.render)(react_1.default.createElement(AgentDiscussionPanel_1.AgentDiscussionPanel, { rounds: [round], width: 80, height: 8 }));
80
+ const frame = lastFrame() ?? '';
81
+ const lines = frame.split('\n');
82
+ (0, vitest_1.expect)(lines.length).toBeLessThanOrEqual(10);
83
+ });
84
+ });
85
+ //# sourceMappingURL=AgentDiscussionPanel.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AgentDiscussionPanel.spec.js","sourceRoot":"","sources":["../../../../src/tui/components/AgentDiscussionPanel.spec.tsx"],"names":[],"mappings":"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"}
@@ -8,5 +8,7 @@ export interface FlowMapProps {
8
8
  width: number;
9
9
  height: number;
10
10
  activeStage?: Mode | null;
11
+ tick?: number;
12
+ now?: number;
11
13
  }
12
- export declare function FlowMap({ agents, edges, layoutMode, width, height, activeStage, }: FlowMapProps): React.ReactElement;
14
+ export declare function FlowMap({ agents, edges, layoutMode, width, height, activeStage, tick, now, }: FlowMapProps): React.ReactElement;