prism-pr 1.0.0-alpha.47
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 +964 -0
- package/bin/run.js +9 -0
- package/dist/ai/agents/architecture-reviewer.d.ts +3 -0
- package/dist/ai/agents/architecture-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/architecture-reviewer.js +67 -0
- package/dist/ai/agents/architecture-reviewer.js.map +1 -0
- package/dist/ai/agents/blade-reviewer.d.ts +3 -0
- package/dist/ai/agents/blade-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/blade-reviewer.js +59 -0
- package/dist/ai/agents/blade-reviewer.js.map +1 -0
- package/dist/ai/agents/config-reviewer.d.ts +3 -0
- package/dist/ai/agents/config-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/config-reviewer.js +106 -0
- package/dist/ai/agents/config-reviewer.js.map +1 -0
- package/dist/ai/agents/csharp-reviewer.d.ts +3 -0
- package/dist/ai/agents/csharp-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/csharp-reviewer.js +59 -0
- package/dist/ai/agents/csharp-reviewer.js.map +1 -0
- package/dist/ai/agents/css-reviewer.d.ts +3 -0
- package/dist/ai/agents/css-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/css-reviewer.js +65 -0
- package/dist/ai/agents/css-reviewer.js.map +1 -0
- package/dist/ai/agents/framework-rules/index.d.ts +33 -0
- package/dist/ai/agents/framework-rules/index.d.ts.map +1 -0
- package/dist/ai/agents/framework-rules/index.js +67 -0
- package/dist/ai/agents/framework-rules/index.js.map +1 -0
- package/dist/ai/agents/framework-rules/normalize.d.ts +40 -0
- package/dist/ai/agents/framework-rules/normalize.d.ts.map +1 -0
- package/dist/ai/agents/framework-rules/normalize.js +102 -0
- package/dist/ai/agents/framework-rules/normalize.js.map +1 -0
- package/dist/ai/agents/framework-rules/routing-map.d.ts +3 -0
- package/dist/ai/agents/framework-rules/routing-map.d.ts.map +1 -0
- package/dist/ai/agents/framework-rules/routing-map.js +15 -0
- package/dist/ai/agents/framework-rules/routing-map.js.map +1 -0
- package/dist/ai/agents/html-reviewer.d.ts +3 -0
- package/dist/ai/agents/html-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/html-reviewer.js +61 -0
- package/dist/ai/agents/html-reviewer.js.map +1 -0
- package/dist/ai/agents/performance-reviewer.d.ts +3 -0
- package/dist/ai/agents/performance-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/performance-reviewer.js +60 -0
- package/dist/ai/agents/performance-reviewer.js.map +1 -0
- package/dist/ai/agents/php-reviewer.d.ts +3 -0
- package/dist/ai/agents/php-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/php-reviewer.js +62 -0
- package/dist/ai/agents/php-reviewer.js.map +1 -0
- package/dist/ai/agents/prompts/architecture-reviewer.txt +39 -0
- package/dist/ai/agents/prompts/blade-reviewer.txt +39 -0
- package/dist/ai/agents/prompts/config-reviewer.txt +47 -0
- package/dist/ai/agents/prompts/csharp-reviewer.txt +39 -0
- package/dist/ai/agents/prompts/css-reviewer.txt +41 -0
- package/dist/ai/agents/prompts/html-reviewer.txt +43 -0
- package/dist/ai/agents/prompts/performance-reviewer.txt +38 -0
- package/dist/ai/agents/prompts/php-reviewer.txt +87 -0
- package/dist/ai/agents/prompts/python-reviewer.txt +42 -0
- package/dist/ai/agents/prompts/security-reviewer.txt +36 -0
- package/dist/ai/agents/prompts/sql-reviewer.txt +43 -0
- package/dist/ai/agents/prompts/testing-reviewer.txt +38 -0
- package/dist/ai/agents/prompts/ts-reviewer.txt +54 -0
- package/dist/ai/agents/prompts/ux-text-reviewer.txt +68 -0
- package/dist/ai/agents/python-reviewer.d.ts +3 -0
- package/dist/ai/agents/python-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/python-reviewer.js +59 -0
- package/dist/ai/agents/python-reviewer.js.map +1 -0
- package/dist/ai/agents/registry.d.ts +20 -0
- package/dist/ai/agents/registry.d.ts.map +1 -0
- package/dist/ai/agents/registry.js +65 -0
- package/dist/ai/agents/registry.js.map +1 -0
- package/dist/ai/agents/security-reviewer.d.ts +3 -0
- package/dist/ai/agents/security-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/security-reviewer.js +69 -0
- package/dist/ai/agents/security-reviewer.js.map +1 -0
- package/dist/ai/agents/shared/content-builder.d.ts +14 -0
- package/dist/ai/agents/shared/content-builder.d.ts.map +1 -0
- package/dist/ai/agents/shared/content-builder.js +158 -0
- package/dist/ai/agents/shared/content-builder.js.map +1 -0
- package/dist/ai/agents/shared/finding-schema.d.ts +54 -0
- package/dist/ai/agents/shared/finding-schema.d.ts.map +1 -0
- package/dist/ai/agents/shared/finding-schema.js +65 -0
- package/dist/ai/agents/shared/finding-schema.js.map +1 -0
- package/dist/ai/agents/shared/line-validator.d.ts +8 -0
- package/dist/ai/agents/shared/line-validator.d.ts.map +1 -0
- package/dist/ai/agents/shared/line-validator.js +12 -0
- package/dist/ai/agents/shared/line-validator.js.map +1 -0
- package/dist/ai/agents/shared/prompt-builder.d.ts +3 -0
- package/dist/ai/agents/shared/prompt-builder.d.ts.map +1 -0
- package/dist/ai/agents/shared/prompt-builder.js +68 -0
- package/dist/ai/agents/shared/prompt-builder.js.map +1 -0
- package/dist/ai/agents/sql-reviewer.d.ts +3 -0
- package/dist/ai/agents/sql-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/sql-reviewer.js +61 -0
- package/dist/ai/agents/sql-reviewer.js.map +1 -0
- package/dist/ai/agents/testing-reviewer.d.ts +3 -0
- package/dist/ai/agents/testing-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/testing-reviewer.js +80 -0
- package/dist/ai/agents/testing-reviewer.js.map +1 -0
- package/dist/ai/agents/ts-reviewer.d.ts +3 -0
- package/dist/ai/agents/ts-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/ts-reviewer.js +63 -0
- package/dist/ai/agents/ts-reviewer.js.map +1 -0
- package/dist/ai/agents/ux-text-reviewer.d.ts +3 -0
- package/dist/ai/agents/ux-text-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/ux-text-reviewer.js +116 -0
- package/dist/ai/agents/ux-text-reviewer.js.map +1 -0
- package/dist/ai/orchestrator/agent-classifier.d.ts +28 -0
- package/dist/ai/orchestrator/agent-classifier.d.ts.map +1 -0
- package/dist/ai/orchestrator/agent-classifier.js +137 -0
- package/dist/ai/orchestrator/agent-classifier.js.map +1 -0
- package/dist/ai/orchestrator/consolidation.d.ts +12 -0
- package/dist/ai/orchestrator/consolidation.d.ts.map +1 -0
- package/dist/ai/orchestrator/consolidation.js +34 -0
- package/dist/ai/orchestrator/consolidation.js.map +1 -0
- package/dist/ai/orchestrator/context-analyzer.d.ts +47 -0
- package/dist/ai/orchestrator/context-analyzer.d.ts.map +1 -0
- package/dist/ai/orchestrator/context-analyzer.js +368 -0
- package/dist/ai/orchestrator/context-analyzer.js.map +1 -0
- package/dist/ai/orchestrator/deduplicator.d.ts +43 -0
- package/dist/ai/orchestrator/deduplicator.d.ts.map +1 -0
- package/dist/ai/orchestrator/deduplicator.js +97 -0
- package/dist/ai/orchestrator/deduplicator.js.map +1 -0
- package/dist/ai/orchestrator/orchestrator.d.ts +57 -0
- package/dist/ai/orchestrator/orchestrator.d.ts.map +1 -0
- package/dist/ai/orchestrator/orchestrator.js +181 -0
- package/dist/ai/orchestrator/orchestrator.js.map +1 -0
- package/dist/ai/orchestrator/rule-based-strategy.d.ts +20 -0
- package/dist/ai/orchestrator/rule-based-strategy.d.ts.map +1 -0
- package/dist/ai/orchestrator/rule-based-strategy.js +55 -0
- package/dist/ai/orchestrator/rule-based-strategy.js.map +1 -0
- package/dist/ai/orchestrator/semaphore.d.ts +25 -0
- package/dist/ai/orchestrator/semaphore.d.ts.map +1 -0
- package/dist/ai/orchestrator/semaphore.js +52 -0
- package/dist/ai/orchestrator/semaphore.js.map +1 -0
- package/dist/ai/orchestrator/severity-pipeline.d.ts +21 -0
- package/dist/ai/orchestrator/severity-pipeline.d.ts.map +1 -0
- package/dist/ai/orchestrator/severity-pipeline.js +69 -0
- package/dist/ai/orchestrator/severity-pipeline.js.map +1 -0
- package/dist/ai/orchestrator/strategy.d.ts +20 -0
- package/dist/ai/orchestrator/strategy.d.ts.map +1 -0
- package/dist/ai/orchestrator/strategy.js +2 -0
- package/dist/ai/orchestrator/strategy.js.map +1 -0
- package/dist/ai/providers/anthropic-provider.d.ts +14 -0
- package/dist/ai/providers/anthropic-provider.d.ts.map +1 -0
- package/dist/ai/providers/anthropic-provider.js +108 -0
- package/dist/ai/providers/anthropic-provider.js.map +1 -0
- package/dist/ai/providers/claude-code-provider.d.ts +12 -0
- package/dist/ai/providers/claude-code-provider.d.ts.map +1 -0
- package/dist/ai/providers/claude-code-provider.js +103 -0
- package/dist/ai/providers/claude-code-provider.js.map +1 -0
- package/dist/ai/providers/errors.d.ts +22 -0
- package/dist/ai/providers/errors.d.ts.map +1 -0
- package/dist/ai/providers/errors.js +44 -0
- package/dist/ai/providers/errors.js.map +1 -0
- package/dist/ai/skills/skill-registry.d.ts +21 -0
- package/dist/ai/skills/skill-registry.d.ts.map +1 -0
- package/dist/ai/skills/skill-registry.js +27 -0
- package/dist/ai/skills/skill-registry.js.map +1 -0
- package/dist/ai/text-extractor/extractor.d.ts +15 -0
- package/dist/ai/text-extractor/extractor.d.ts.map +1 -0
- package/dist/ai/text-extractor/extractor.js +63 -0
- package/dist/ai/text-extractor/extractor.js.map +1 -0
- package/dist/ai/text-extractor/index.d.ts +4 -0
- package/dist/ai/text-extractor/index.d.ts.map +1 -0
- package/dist/ai/text-extractor/index.js +3 -0
- package/dist/ai/text-extractor/index.js.map +1 -0
- package/dist/ai/text-extractor/patterns.d.ts +21 -0
- package/dist/ai/text-extractor/patterns.d.ts.map +1 -0
- package/dist/ai/text-extractor/patterns.js +169 -0
- package/dist/ai/text-extractor/patterns.js.map +1 -0
- package/dist/ai/text-extractor/types.d.ts +47 -0
- package/dist/ai/text-extractor/types.d.ts.map +1 -0
- package/dist/ai/text-extractor/types.js +2 -0
- package/dist/ai/text-extractor/types.js.map +1 -0
- package/dist/bitbucket/client.d.ts +38 -0
- package/dist/bitbucket/client.d.ts.map +1 -0
- package/dist/bitbucket/client.js +448 -0
- package/dist/bitbucket/client.js.map +1 -0
- package/dist/bitbucket/errors.d.ts +75 -0
- package/dist/bitbucket/errors.d.ts.map +1 -0
- package/dist/bitbucket/errors.js +127 -0
- package/dist/bitbucket/errors.js.map +1 -0
- package/dist/bitbucket/mappers.d.ts +3 -0
- package/dist/bitbucket/mappers.d.ts.map +1 -0
- package/dist/bitbucket/mappers.js +14 -0
- package/dist/bitbucket/mappers.js.map +1 -0
- package/dist/commands/guard/check.d.ts +19 -0
- package/dist/commands/guard/check.d.ts.map +1 -0
- package/dist/commands/guard/check.js +224 -0
- package/dist/commands/guard/check.js.map +1 -0
- package/dist/commands/guard/index.d.ts +7 -0
- package/dist/commands/guard/index.d.ts.map +1 -0
- package/dist/commands/guard/index.js +65 -0
- package/dist/commands/guard/index.js.map +1 -0
- package/dist/commands/interactive.d.ts +10 -0
- package/dist/commands/interactive.d.ts.map +1 -0
- package/dist/commands/interactive.js +88 -0
- package/dist/commands/interactive.js.map +1 -0
- package/dist/commands/login.d.ts +35 -0
- package/dist/commands/login.d.ts.map +1 -0
- package/dist/commands/login.js +164 -0
- package/dist/commands/login.js.map +1 -0
- package/dist/commands/logout.d.ts +12 -0
- package/dist/commands/logout.d.ts.map +1 -0
- package/dist/commands/logout.js +23 -0
- package/dist/commands/logout.js.map +1 -0
- package/dist/commands/review/start.d.ts +22 -0
- package/dist/commands/review/start.d.ts.map +1 -0
- package/dist/commands/review/start.js +120 -0
- package/dist/commands/review/start.js.map +1 -0
- package/dist/commands/rules/push.d.ts +13 -0
- package/dist/commands/rules/push.d.ts.map +1 -0
- package/dist/commands/rules/push.js +75 -0
- package/dist/commands/rules/push.js.map +1 -0
- package/dist/commands/rules/stats.d.ts +14 -0
- package/dist/commands/rules/stats.d.ts.map +1 -0
- package/dist/commands/rules/stats.js +101 -0
- package/dist/commands/rules/stats.js.map +1 -0
- package/dist/commands/rules/sync.d.ts +15 -0
- package/dist/commands/rules/sync.d.ts.map +1 -0
- package/dist/commands/rules/sync.js +144 -0
- package/dist/commands/rules/sync.js.map +1 -0
- package/dist/config/config-manager.d.ts +14 -0
- package/dist/config/config-manager.d.ts.map +1 -0
- package/dist/config/config-manager.js +85 -0
- package/dist/config/config-manager.js.map +1 -0
- package/dist/config/convention-builder.d.ts +13 -0
- package/dist/config/convention-builder.d.ts.map +1 -0
- package/dist/config/convention-builder.js +31 -0
- package/dist/config/convention-builder.js.map +1 -0
- package/dist/config/credentials.d.ts +14 -0
- package/dist/config/credentials.d.ts.map +1 -0
- package/dist/config/credentials.js +85 -0
- package/dist/config/credentials.js.map +1 -0
- package/dist/config/encryption.d.ts +20 -0
- package/dist/config/encryption.d.ts.map +1 -0
- package/dist/config/encryption.js +94 -0
- package/dist/config/encryption.js.map +1 -0
- package/dist/config/repo-config-loader.d.ts +34 -0
- package/dist/config/repo-config-loader.d.ts.map +1 -0
- package/dist/config/repo-config-loader.js +103 -0
- package/dist/config/repo-config-loader.js.map +1 -0
- package/dist/core/cli-workflow-callbacks.d.ts +35 -0
- package/dist/core/cli-workflow-callbacks.d.ts.map +1 -0
- package/dist/core/cli-workflow-callbacks.js +141 -0
- package/dist/core/cli-workflow-callbacks.js.map +1 -0
- package/dist/core/comment-publisher.d.ts +61 -0
- package/dist/core/comment-publisher.d.ts.map +1 -0
- package/dist/core/comment-publisher.js +172 -0
- package/dist/core/comment-publisher.js.map +1 -0
- package/dist/core/integrity-checker.d.ts +22 -0
- package/dist/core/integrity-checker.d.ts.map +1 -0
- package/dist/core/integrity-checker.js +83 -0
- package/dist/core/integrity-checker.js.map +1 -0
- package/dist/core/review-workflow.d.ts +34 -0
- package/dist/core/review-workflow.d.ts.map +1 -0
- package/dist/core/review-workflow.js +21 -0
- package/dist/core/review-workflow.js.map +1 -0
- package/dist/core/session-manager.d.ts +107 -0
- package/dist/core/session-manager.d.ts.map +1 -0
- package/dist/core/session-manager.js +164 -0
- package/dist/core/session-manager.js.map +1 -0
- package/dist/core/workflow-callbacks.d.ts +74 -0
- package/dist/core/workflow-callbacks.d.ts.map +1 -0
- package/dist/core/workflow-callbacks.js +2 -0
- package/dist/core/workflow-callbacks.js.map +1 -0
- package/dist/core/workflow-engine.d.ts +48 -0
- package/dist/core/workflow-engine.d.ts.map +1 -0
- package/dist/core/workflow-engine.js +442 -0
- package/dist/core/workflow-engine.js.map +1 -0
- package/dist/errors/base.d.ts +6 -0
- package/dist/errors/base.d.ts.map +1 -0
- package/dist/errors/base.js +13 -0
- package/dist/errors/base.js.map +1 -0
- package/dist/errors/config-error.d.ts +5 -0
- package/dist/errors/config-error.d.ts.map +1 -0
- package/dist/errors/config-error.js +9 -0
- package/dist/errors/config-error.js.map +1 -0
- package/dist/errors/index.d.ts +5 -0
- package/dist/errors/index.d.ts.map +1 -0
- package/dist/errors/index.js +5 -0
- package/dist/errors/index.js.map +1 -0
- package/dist/errors/validation-error.d.ts +5 -0
- package/dist/errors/validation-error.d.ts.map +1 -0
- package/dist/errors/validation-error.js +9 -0
- package/dist/errors/validation-error.js.map +1 -0
- package/dist/errors/workflow-error.d.ts +6 -0
- package/dist/errors/workflow-error.d.ts.map +1 -0
- package/dist/errors/workflow-error.js +11 -0
- package/dist/errors/workflow-error.js.map +1 -0
- package/dist/guard/ast-grep-strategy.d.ts +25 -0
- package/dist/guard/ast-grep-strategy.d.ts.map +1 -0
- package/dist/guard/ast-grep-strategy.js +112 -0
- package/dist/guard/ast-grep-strategy.js.map +1 -0
- package/dist/guard/diff-pattern-matcher.d.ts +52 -0
- package/dist/guard/diff-pattern-matcher.d.ts.map +1 -0
- package/dist/guard/diff-pattern-matcher.js +325 -0
- package/dist/guard/diff-pattern-matcher.js.map +1 -0
- package/dist/guard/file-fetcher.d.ts +3 -0
- package/dist/guard/file-fetcher.d.ts.map +1 -0
- package/dist/guard/file-fetcher.js +21 -0
- package/dist/guard/file-fetcher.js.map +1 -0
- package/dist/guard/guard-engine.d.ts +8 -0
- package/dist/guard/guard-engine.d.ts.map +1 -0
- package/dist/guard/guard-engine.js +78 -0
- package/dist/guard/guard-engine.js.map +1 -0
- package/dist/guard/match-strategy.d.ts +14 -0
- package/dist/guard/match-strategy.d.ts.map +1 -0
- package/dist/guard/match-strategy.js +7 -0
- package/dist/guard/match-strategy.js.map +1 -0
- package/dist/guard/patterns-loader.d.ts +16 -0
- package/dist/guard/patterns-loader.d.ts.map +1 -0
- package/dist/guard/patterns-loader.js +61 -0
- package/dist/guard/patterns-loader.js.map +1 -0
- package/dist/guard/types.d.ts +61 -0
- package/dist/guard/types.d.ts.map +1 -0
- package/dist/guard/types.js +2 -0
- package/dist/guard/types.js.map +1 -0
- package/dist/memory/engram-client.d.ts +15 -0
- package/dist/memory/engram-client.d.ts.map +1 -0
- package/dist/memory/engram-client.js +167 -0
- package/dist/memory/engram-client.js.map +1 -0
- package/dist/memory/review-memory-service.d.ts +13 -0
- package/dist/memory/review-memory-service.d.ts.map +1 -0
- package/dist/memory/review-memory-service.js +43 -0
- package/dist/memory/review-memory-service.js.map +1 -0
- package/dist/persistence/database.d.ts +8 -0
- package/dist/persistence/database.d.ts.map +1 -0
- package/dist/persistence/database.js +58 -0
- package/dist/persistence/database.js.map +1 -0
- package/dist/persistence/false-positive-repository.d.ts +12 -0
- package/dist/persistence/false-positive-repository.d.ts.map +1 -0
- package/dist/persistence/false-positive-repository.js +58 -0
- package/dist/persistence/false-positive-repository.js.map +1 -0
- package/dist/persistence/migrations/0000_peaceful_blur.sql +66 -0
- package/dist/persistence/migrations/0001_phase3a_schema.sql +15 -0
- package/dist/persistence/migrations/0002_stack_profile.sql +1 -0
- package/dist/persistence/migrations/0003_known_workspaces.sql +5 -0
- package/dist/persistence/migrations/0004_review_memory.sql +24 -0
- package/dist/persistence/migrations/meta/0000_snapshot.json +468 -0
- package/dist/persistence/migrations/meta/_journal.json +41 -0
- package/dist/persistence/profile-repository.d.ts +33 -0
- package/dist/persistence/profile-repository.d.ts.map +1 -0
- package/dist/persistence/profile-repository.js +94 -0
- package/dist/persistence/profile-repository.js.map +1 -0
- package/dist/persistence/repository.d.ts +70 -0
- package/dist/persistence/repository.d.ts.map +1 -0
- package/dist/persistence/repository.js +225 -0
- package/dist/persistence/repository.js.map +1 -0
- package/dist/persistence/schema.d.ts +1333 -0
- package/dist/persistence/schema.d.ts.map +1 -0
- package/dist/persistence/schema.js +92 -0
- package/dist/persistence/schema.js.map +1 -0
- package/dist/persistence/workspace-repository.d.ts +14 -0
- package/dist/persistence/workspace-repository.d.ts.map +1 -0
- package/dist/persistence/workspace-repository.js +30 -0
- package/dist/persistence/workspace-repository.js.map +1 -0
- package/dist/rules-engine/finding-aggregator.d.ts +13 -0
- package/dist/rules-engine/finding-aggregator.d.ts.map +1 -0
- package/dist/rules-engine/finding-aggregator.js +135 -0
- package/dist/rules-engine/finding-aggregator.js.map +1 -0
- package/dist/rules-engine/pattern-generator.d.ts +26 -0
- package/dist/rules-engine/pattern-generator.d.ts.map +1 -0
- package/dist/rules-engine/pattern-generator.js +116 -0
- package/dist/rules-engine/pattern-generator.js.map +1 -0
- package/dist/rules-engine/rule-prompt-builder.d.ts +32 -0
- package/dist/rules-engine/rule-prompt-builder.d.ts.map +1 -0
- package/dist/rules-engine/rule-prompt-builder.js +124 -0
- package/dist/rules-engine/rule-prompt-builder.js.map +1 -0
- package/dist/rules-engine/types.d.ts +80 -0
- package/dist/rules-engine/types.d.ts.map +1 -0
- package/dist/rules-engine/types.js +18 -0
- package/dist/rules-engine/types.js.map +1 -0
- package/dist/rules-repo/rules-cache.d.ts +14 -0
- package/dist/rules-repo/rules-cache.d.ts.map +1 -0
- package/dist/rules-repo/rules-cache.js +43 -0
- package/dist/rules-repo/rules-cache.js.map +1 -0
- package/dist/rules-repo/rules-repo-client.d.ts +27 -0
- package/dist/rules-repo/rules-repo-client.d.ts.map +1 -0
- package/dist/rules-repo/rules-repo-client.js +85 -0
- package/dist/rules-repo/rules-repo-client.js.map +1 -0
- package/dist/rules-repo/types.d.ts +16 -0
- package/dist/rules-repo/types.d.ts.map +1 -0
- package/dist/rules-repo/types.js +10 -0
- package/dist/rules-repo/types.js.map +1 -0
- package/dist/stack-detector/ai-stack-fallback.d.ts +12 -0
- package/dist/stack-detector/ai-stack-fallback.d.ts.map +1 -0
- package/dist/stack-detector/ai-stack-fallback.js +67 -0
- package/dist/stack-detector/ai-stack-fallback.js.map +1 -0
- package/dist/stack-detector/ai-stack-schema.d.ts +28 -0
- package/dist/stack-detector/ai-stack-schema.d.ts.map +1 -0
- package/dist/stack-detector/ai-stack-schema.js +13 -0
- package/dist/stack-detector/ai-stack-schema.js.map +1 -0
- package/dist/stack-detector/formatter.d.ts +7 -0
- package/dist/stack-detector/formatter.d.ts.map +1 -0
- package/dist/stack-detector/formatter.js +37 -0
- package/dist/stack-detector/formatter.js.map +1 -0
- package/dist/stack-detector/index.d.ts +7 -0
- package/dist/stack-detector/index.d.ts.map +1 -0
- package/dist/stack-detector/index.js +5 -0
- package/dist/stack-detector/index.js.map +1 -0
- package/dist/stack-detector/merge-profiles.d.ts +5 -0
- package/dist/stack-detector/merge-profiles.d.ts.map +1 -0
- package/dist/stack-detector/merge-profiles.js +36 -0
- package/dist/stack-detector/merge-profiles.js.map +1 -0
- package/dist/stack-detector/parsers.d.ts +12 -0
- package/dist/stack-detector/parsers.d.ts.map +1 -0
- package/dist/stack-detector/parsers.js +259 -0
- package/dist/stack-detector/parsers.js.map +1 -0
- package/dist/stack-detector/stack-detector.d.ts +11 -0
- package/dist/stack-detector/stack-detector.d.ts.map +1 -0
- package/dist/stack-detector/stack-detector.js +83 -0
- package/dist/stack-detector/stack-detector.js.map +1 -0
- package/dist/stack-detector/types.d.ts +13 -0
- package/dist/stack-detector/types.d.ts.map +1 -0
- package/dist/stack-detector/types.js +2 -0
- package/dist/stack-detector/types.js.map +1 -0
- package/dist/tui/app.d.ts +9 -0
- package/dist/tui/app.d.ts.map +1 -0
- package/dist/tui/app.js +45 -0
- package/dist/tui/app.js.map +1 -0
- package/dist/tui/callbacks/tui-workflow-callbacks.d.ts +32 -0
- package/dist/tui/callbacks/tui-workflow-callbacks.d.ts.map +1 -0
- package/dist/tui/callbacks/tui-workflow-callbacks.js +88 -0
- package/dist/tui/callbacks/tui-workflow-callbacks.js.map +1 -0
- package/dist/tui/components/key-hint.d.ts +7 -0
- package/dist/tui/components/key-hint.d.ts.map +1 -0
- package/dist/tui/components/key-hint.js +6 -0
- package/dist/tui/components/key-hint.js.map +1 -0
- package/dist/tui/components/scroll-list.d.ts +20 -0
- package/dist/tui/components/scroll-list.d.ts.map +1 -0
- package/dist/tui/components/scroll-list.js +85 -0
- package/dist/tui/components/scroll-list.js.map +1 -0
- package/dist/tui/components/searchable-list.d.ts +15 -0
- package/dist/tui/components/searchable-list.d.ts.map +1 -0
- package/dist/tui/components/searchable-list.js +97 -0
- package/dist/tui/components/searchable-list.js.map +1 -0
- package/dist/tui/components/severity-badge.d.ts +6 -0
- package/dist/tui/components/severity-badge.d.ts.map +1 -0
- package/dist/tui/components/severity-badge.js +17 -0
- package/dist/tui/components/severity-badge.js.map +1 -0
- package/dist/tui/components/severity-selector.d.ts +9 -0
- package/dist/tui/components/severity-selector.d.ts.map +1 -0
- package/dist/tui/components/severity-selector.js +29 -0
- package/dist/tui/components/severity-selector.js.map +1 -0
- package/dist/tui/components/spinner.d.ts +6 -0
- package/dist/tui/components/spinner.d.ts.map +1 -0
- package/dist/tui/components/spinner.js +19 -0
- package/dist/tui/components/spinner.js.map +1 -0
- package/dist/tui/components/status-bar.d.ts +10 -0
- package/dist/tui/components/status-bar.d.ts.map +1 -0
- package/dist/tui/components/status-bar.js +7 -0
- package/dist/tui/components/status-bar.js.map +1 -0
- package/dist/tui/deps-context.d.ts +27 -0
- package/dist/tui/deps-context.d.ts.map +1 -0
- package/dist/tui/deps-context.js +9 -0
- package/dist/tui/deps-context.js.map +1 -0
- package/dist/tui/error-boundary.d.ts +16 -0
- package/dist/tui/error-boundary.d.ts.map +1 -0
- package/dist/tui/error-boundary.js +30 -0
- package/dist/tui/error-boundary.js.map +1 -0
- package/dist/tui/hooks/use-agent-recommendations.d.ts +10 -0
- package/dist/tui/hooks/use-agent-recommendations.d.ts.map +1 -0
- package/dist/tui/hooks/use-agent-recommendations.js +66 -0
- package/dist/tui/hooks/use-agent-recommendations.js.map +1 -0
- package/dist/tui/hooks/use-auth.d.ts +14 -0
- package/dist/tui/hooks/use-auth.d.ts.map +1 -0
- package/dist/tui/hooks/use-auth.js +32 -0
- package/dist/tui/hooks/use-auth.js.map +1 -0
- package/dist/tui/hooks/use-bitbucket.d.ts +18 -0
- package/dist/tui/hooks/use-bitbucket.d.ts.map +1 -0
- package/dist/tui/hooks/use-bitbucket.js +31 -0
- package/dist/tui/hooks/use-bitbucket.js.map +1 -0
- package/dist/tui/hooks/use-review.d.ts +6 -0
- package/dist/tui/hooks/use-review.d.ts.map +1 -0
- package/dist/tui/hooks/use-review.js +24 -0
- package/dist/tui/hooks/use-review.js.map +1 -0
- package/dist/tui/hooks/use-session.d.ts +47 -0
- package/dist/tui/hooks/use-session.d.ts.map +1 -0
- package/dist/tui/hooks/use-session.js +17 -0
- package/dist/tui/hooks/use-session.js.map +1 -0
- package/dist/tui/screen-router.d.ts +3 -0
- package/dist/tui/screen-router.d.ts.map +1 -0
- package/dist/tui/screen-router.js +73 -0
- package/dist/tui/screen-router.js.map +1 -0
- package/dist/tui/screens/agent-select.d.ts +3 -0
- package/dist/tui/screens/agent-select.d.ts.map +1 -0
- package/dist/tui/screens/agent-select.js +173 -0
- package/dist/tui/screens/agent-select.js.map +1 -0
- package/dist/tui/screens/finding-detail.d.ts +3 -0
- package/dist/tui/screens/finding-detail.d.ts.map +1 -0
- package/dist/tui/screens/finding-detail.js +48 -0
- package/dist/tui/screens/finding-detail.js.map +1 -0
- package/dist/tui/screens/findings-list.d.ts +3 -0
- package/dist/tui/screens/findings-list.d.ts.map +1 -0
- package/dist/tui/screens/findings-list.js +108 -0
- package/dist/tui/screens/findings-list.js.map +1 -0
- package/dist/tui/screens/guard-detail.d.ts +3 -0
- package/dist/tui/screens/guard-detail.d.ts.map +1 -0
- package/dist/tui/screens/guard-detail.js +41 -0
- package/dist/tui/screens/guard-detail.js.map +1 -0
- package/dist/tui/screens/guard-home.d.ts +3 -0
- package/dist/tui/screens/guard-home.d.ts.map +1 -0
- package/dist/tui/screens/guard-home.js +81 -0
- package/dist/tui/screens/guard-home.js.map +1 -0
- package/dist/tui/screens/guard-results.d.ts +3 -0
- package/dist/tui/screens/guard-results.d.ts.map +1 -0
- package/dist/tui/screens/guard-results.js +103 -0
- package/dist/tui/screens/guard-results.js.map +1 -0
- package/dist/tui/screens/guard-running.d.ts +3 -0
- package/dist/tui/screens/guard-running.d.ts.map +1 -0
- package/dist/tui/screens/guard-running.js +92 -0
- package/dist/tui/screens/guard-running.js.map +1 -0
- package/dist/tui/screens/home.d.ts +3 -0
- package/dist/tui/screens/home.d.ts.map +1 -0
- package/dist/tui/screens/home.js +44 -0
- package/dist/tui/screens/home.js.map +1 -0
- package/dist/tui/screens/integrity-report.d.ts +3 -0
- package/dist/tui/screens/integrity-report.d.ts.map +1 -0
- package/dist/tui/screens/integrity-report.js +29 -0
- package/dist/tui/screens/integrity-report.js.map +1 -0
- package/dist/tui/screens/login.d.ts +3 -0
- package/dist/tui/screens/login.d.ts.map +1 -0
- package/dist/tui/screens/login.js +81 -0
- package/dist/tui/screens/login.js.map +1 -0
- package/dist/tui/screens/pr-list.d.ts +3 -0
- package/dist/tui/screens/pr-list.d.ts.map +1 -0
- package/dist/tui/screens/pr-list.js +76 -0
- package/dist/tui/screens/pr-list.js.map +1 -0
- package/dist/tui/screens/publish-confirm.d.ts +3 -0
- package/dist/tui/screens/publish-confirm.d.ts.map +1 -0
- package/dist/tui/screens/publish-confirm.js +42 -0
- package/dist/tui/screens/publish-confirm.js.map +1 -0
- package/dist/tui/screens/publishing.d.ts +3 -0
- package/dist/tui/screens/publishing.d.ts.map +1 -0
- package/dist/tui/screens/publishing.js +50 -0
- package/dist/tui/screens/publishing.js.map +1 -0
- package/dist/tui/screens/repo-select.d.ts +3 -0
- package/dist/tui/screens/repo-select.d.ts.map +1 -0
- package/dist/tui/screens/repo-select.js +76 -0
- package/dist/tui/screens/repo-select.js.map +1 -0
- package/dist/tui/screens/review-running.d.ts +3 -0
- package/dist/tui/screens/review-running.d.ts.map +1 -0
- package/dist/tui/screens/review-running.js +187 -0
- package/dist/tui/screens/review-running.js.map +1 -0
- package/dist/tui/screens/session-detail.d.ts +7 -0
- package/dist/tui/screens/session-detail.d.ts.map +1 -0
- package/dist/tui/screens/session-detail.js +28 -0
- package/dist/tui/screens/session-detail.js.map +1 -0
- package/dist/tui/screens/session-list.d.ts +7 -0
- package/dist/tui/screens/session-list.d.ts.map +1 -0
- package/dist/tui/screens/session-list.js +38 -0
- package/dist/tui/screens/session-list.js.map +1 -0
- package/dist/tui/screens/url-input.d.ts +3 -0
- package/dist/tui/screens/url-input.d.ts.map +1 -0
- package/dist/tui/screens/url-input.js +111 -0
- package/dist/tui/screens/url-input.js.map +1 -0
- package/dist/tui/screens/welcome.d.ts +3 -0
- package/dist/tui/screens/welcome.d.ts.map +1 -0
- package/dist/tui/screens/welcome.js +48 -0
- package/dist/tui/screens/welcome.js.map +1 -0
- package/dist/tui/screens/workspace-select.d.ts +3 -0
- package/dist/tui/screens/workspace-select.d.ts.map +1 -0
- package/dist/tui/screens/workspace-select.js +128 -0
- package/dist/tui/screens/workspace-select.js.map +1 -0
- package/dist/tui/state/router-context.d.ts +14 -0
- package/dist/tui/state/router-context.d.ts.map +1 -0
- package/dist/tui/state/router-context.js +9 -0
- package/dist/tui/state/router-context.js.map +1 -0
- package/dist/tui/state/router-reducer.d.ts +23 -0
- package/dist/tui/state/router-reducer.d.ts.map +1 -0
- package/dist/tui/state/router-reducer.js +21 -0
- package/dist/tui/state/router-reducer.js.map +1 -0
- package/dist/tui/state/tui-context.d.ts +11 -0
- package/dist/tui/state/tui-context.d.ts.map +1 -0
- package/dist/tui/state/tui-context.js +9 -0
- package/dist/tui/state/tui-context.js.map +1 -0
- package/dist/tui/state/tui-reducer.d.ts +212 -0
- package/dist/tui/state/tui-reducer.d.ts.map +1 -0
- package/dist/tui/state/tui-reducer.js +321 -0
- package/dist/tui/state/tui-reducer.js.map +1 -0
- package/dist/tui/utils/group-by-file.d.ts +7 -0
- package/dist/tui/utils/group-by-file.d.ts.map +1 -0
- package/dist/tui/utils/group-by-file.js +18 -0
- package/dist/tui/utils/group-by-file.js.map +1 -0
- package/dist/tui/utils/group-matches-by-file.d.ts +7 -0
- package/dist/tui/utils/group-matches-by-file.d.ts.map +1 -0
- package/dist/tui/utils/group-matches-by-file.js +18 -0
- package/dist/tui/utils/group-matches-by-file.js.map +1 -0
- package/dist/tui/utils/group-repos-by-project.d.ts +9 -0
- package/dist/tui/utils/group-repos-by-project.d.ts.map +1 -0
- package/dist/tui/utils/group-repos-by-project.js +48 -0
- package/dist/tui/utils/group-repos-by-project.js.map +1 -0
- package/dist/types/agent.d.ts +46 -0
- package/dist/types/agent.d.ts.map +1 -0
- package/dist/types/agent.js +2 -0
- package/dist/types/agent.js.map +1 -0
- package/dist/types/bitbucket.d.ts +90 -0
- package/dist/types/bitbucket.d.ts.map +1 -0
- package/dist/types/bitbucket.js +2 -0
- package/dist/types/bitbucket.js.map +1 -0
- package/dist/types/config.d.ts +17 -0
- package/dist/types/config.d.ts.map +1 -0
- package/dist/types/config.js +2 -0
- package/dist/types/config.js.map +1 -0
- package/dist/types/diff.d.ts +24 -0
- package/dist/types/diff.d.ts.map +1 -0
- package/dist/types/diff.js +2 -0
- package/dist/types/diff.js.map +1 -0
- package/dist/types/engram.d.ts +29 -0
- package/dist/types/engram.d.ts.map +1 -0
- package/dist/types/engram.js +2 -0
- package/dist/types/engram.js.map +1 -0
- package/dist/types/false-positive.d.ts +12 -0
- package/dist/types/false-positive.d.ts.map +1 -0
- package/dist/types/false-positive.js +2 -0
- package/dist/types/false-positive.js.map +1 -0
- package/dist/types/index.d.ts +14 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +3 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/provider.d.ts +31 -0
- package/dist/types/provider.d.ts.map +1 -0
- package/dist/types/provider.js +2 -0
- package/dist/types/provider.js.map +1 -0
- package/dist/types/repo-config.d.ts +336 -0
- package/dist/types/repo-config.d.ts.map +1 -0
- package/dist/types/repo-config.js +62 -0
- package/dist/types/repo-config.js.map +1 -0
- package/dist/types/review-finding.d.ts +34 -0
- package/dist/types/review-finding.d.ts.map +1 -0
- package/dist/types/review-finding.js +11 -0
- package/dist/types/review-finding.js.map +1 -0
- package/dist/types/review-session.d.ts +21 -0
- package/dist/types/review-session.d.ts.map +1 -0
- package/dist/types/review-session.js +2 -0
- package/dist/types/review-session.js.map +1 -0
- package/dist/types/skill.d.ts +7 -0
- package/dist/types/skill.d.ts.map +1 -0
- package/dist/types/skill.js +2 -0
- package/dist/types/skill.js.map +1 -0
- package/dist/utils/comment-formatter.d.ts +19 -0
- package/dist/utils/comment-formatter.d.ts.map +1 -0
- package/dist/utils/comment-formatter.js +53 -0
- package/dist/utils/comment-formatter.js.map +1 -0
- package/dist/utils/cost-estimator.d.ts +19 -0
- package/dist/utils/cost-estimator.d.ts.map +1 -0
- package/dist/utils/cost-estimator.js +32 -0
- package/dist/utils/cost-estimator.js.map +1 -0
- package/dist/utils/diff-parser.d.ts +7 -0
- package/dist/utils/diff-parser.d.ts.map +1 -0
- package/dist/utils/diff-parser.js +175 -0
- package/dist/utils/diff-parser.js.map +1 -0
- package/dist/utils/file-filter.d.ts +16 -0
- package/dist/utils/file-filter.d.ts.map +1 -0
- package/dist/utils/file-filter.js +64 -0
- package/dist/utils/file-filter.js.map +1 -0
- package/dist/utils/hash.d.ts +25 -0
- package/dist/utils/hash.d.ts.map +1 -0
- package/dist/utils/hash.js +45 -0
- package/dist/utils/hash.js.map +1 -0
- package/dist/utils/logger.d.ts +17 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +40 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/parse-bitbucket-url.d.ts +12 -0
- package/dist/utils/parse-bitbucket-url.d.ts.map +1 -0
- package/dist/utils/parse-bitbucket-url.js +41 -0
- package/dist/utils/parse-bitbucket-url.js.map +1 -0
- package/dist/utils/paths.d.ts +6 -0
- package/dist/utils/paths.d.ts.map +1 -0
- package/dist/utils/paths.js +27 -0
- package/dist/utils/paths.js.map +1 -0
- package/dist/utils/summary-generator.d.ts +17 -0
- package/dist/utils/summary-generator.d.ts.map +1 -0
- package/dist/utils/summary-generator.js +76 -0
- package/dist/utils/summary-generator.js.map +1 -0
- package/oclif.manifest.json +467 -0
- package/package.json +100 -0
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { useTUI } from '../state/tui-context.js';
|
|
2
|
+
import { useRouter } from '../state/router-context.js';
|
|
3
|
+
export function useAuth(deps) {
|
|
4
|
+
const { state, dispatch } = useTUI();
|
|
5
|
+
const router = useRouter();
|
|
6
|
+
const checkCredentials = async () => {
|
|
7
|
+
const creds = await deps.credentialManager.load();
|
|
8
|
+
if (!creds)
|
|
9
|
+
return false;
|
|
10
|
+
dispatch({ type: 'AUTH_SUCCESS', payload: { username: creds.username } });
|
|
11
|
+
return true;
|
|
12
|
+
};
|
|
13
|
+
const login = async (username, password) => {
|
|
14
|
+
const client = deps.createBitbucketClient(username, password);
|
|
15
|
+
const user = await client.validateCredentials();
|
|
16
|
+
await deps.credentialManager.save(username, password);
|
|
17
|
+
dispatch({ type: 'AUTH_SUCCESS', payload: { username: user.username } });
|
|
18
|
+
};
|
|
19
|
+
const logout = async () => {
|
|
20
|
+
deps.credentialManager.delete();
|
|
21
|
+
dispatch({ type: 'AUTH_LOGOUT' });
|
|
22
|
+
router.reset({ name: 'welcome', params: {} });
|
|
23
|
+
};
|
|
24
|
+
return {
|
|
25
|
+
checkCredentials,
|
|
26
|
+
login,
|
|
27
|
+
logout,
|
|
28
|
+
isAuthenticated: state.isAuthenticated,
|
|
29
|
+
username: state.username,
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=use-auth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-auth.js","sourceRoot":"","sources":["../../../src/tui/hooks/use-auth.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AASvD,MAAM,UAAU,OAAO,CAAC,IAAiB;IACvC,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,MAAM,EAAE,CAAC;IACrC,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;IAE3B,MAAM,gBAAgB,GAAG,KAAK,IAAsB,EAAE;QACpD,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;QAClD,IAAI,CAAC,KAAK;YAAE,OAAO,KAAK,CAAC;QACzB,QAAQ,CAAC,EAAE,IAAI,EAAE,cAAc,EAAE,OAAO,EAAE,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QAC1E,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;IAEF,MAAM,KAAK,GAAG,KAAK,EAAE,QAAgB,EAAE,QAAgB,EAAiB,EAAE;QACxE,MAAM,MAAM,GAAG,IAAI,CAAC,qBAAqB,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAC9D,MAAM,IAAI,GAAG,MAAM,MAAM,CAAC,mBAAmB,EAAE,CAAC;QAChD,MAAM,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QACtD,QAAQ,CAAC,EAAE,IAAI,EAAE,cAAc,EAAE,OAAO,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IAC3E,CAAC,CAAC;IAEF,MAAM,MAAM,GAAG,KAAK,IAAmB,EAAE;QACvC,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,CAAC;QAChC,QAAQ,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC,CAAC;QAClC,MAAM,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC;IAChD,CAAC,CAAC;IAEF,OAAO;QACL,gBAAgB;QAChB,KAAK;QACL,MAAM;QACN,eAAe,EAAE,KAAK,CAAC,eAAe;QACtC,QAAQ,EAAE,KAAK,CAAC,QAAQ;KACzB,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { BitbucketClient } from '../../bitbucket/client.js';
|
|
2
|
+
export declare function useBitbucket(): {
|
|
3
|
+
validateWorkspace: (bbClient: BitbucketClient, slug: string) => Promise<void>;
|
|
4
|
+
loadRepositories: (bbClient: BitbucketClient, workspace: string) => Promise<void>;
|
|
5
|
+
loadPullRequests: (bbClient: BitbucketClient, workspace: string, repo: string) => Promise<void>;
|
|
6
|
+
workspaces: import("../../types/bitbucket.js").BitbucketWorkspace[];
|
|
7
|
+
repositories: import("../../types/bitbucket.js").BitbucketRepository[];
|
|
8
|
+
pullRequests: import("../../types/bitbucket.js").BitbucketPullRequestSummary[];
|
|
9
|
+
loading: {
|
|
10
|
+
workspaces: boolean;
|
|
11
|
+
repositories: boolean;
|
|
12
|
+
pullRequests: boolean;
|
|
13
|
+
};
|
|
14
|
+
selectedWorkspace: string | null;
|
|
15
|
+
selectedRepo: string | null;
|
|
16
|
+
selectedPR: import("../../types/bitbucket.js").BitbucketPullRequestSummary | null;
|
|
17
|
+
};
|
|
18
|
+
//# sourceMappingURL=use-bitbucket.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-bitbucket.d.ts","sourceRoot":"","sources":["../../../src/tui/hooks/use-bitbucket.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAEjE,wBAAgB,YAAY;kCAGiB,eAAe,QAAQ,MAAM,KAAG,OAAO,CAAC,IAAI,CAAC;iCAK9C,eAAe,aAAa,MAAM,KAAG,OAAO,CAAC,IAAI,CAAC;iCAOhF,eAAe,aACd,MAAM,QACX,MAAM,KACX,OAAO,CAAC,IAAI,CAAC;;;;;;;;;;;;EAkBjB"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { useTUI } from '../state/tui-context.js';
|
|
2
|
+
export function useBitbucket() {
|
|
3
|
+
const { state, dispatch } = useTUI();
|
|
4
|
+
const validateWorkspace = async (bbClient, slug) => {
|
|
5
|
+
const ws = await bbClient.getWorkspace(slug);
|
|
6
|
+
dispatch({ type: 'SELECT_WORKSPACE', payload: ws.slug });
|
|
7
|
+
};
|
|
8
|
+
const loadRepositories = async (bbClient, workspace) => {
|
|
9
|
+
dispatch({ type: 'REPOS_LOADING' });
|
|
10
|
+
const repos = await bbClient.listRepositories(workspace);
|
|
11
|
+
dispatch({ type: 'REPOS_LOADED', payload: repos });
|
|
12
|
+
};
|
|
13
|
+
const loadPullRequests = async (bbClient, workspace, repo) => {
|
|
14
|
+
dispatch({ type: 'PRS_LOADING' });
|
|
15
|
+
const prs = await bbClient.listPullRequests(workspace, repo);
|
|
16
|
+
dispatch({ type: 'PRS_LOADED', payload: prs });
|
|
17
|
+
};
|
|
18
|
+
return {
|
|
19
|
+
validateWorkspace,
|
|
20
|
+
loadRepositories,
|
|
21
|
+
loadPullRequests,
|
|
22
|
+
workspaces: state.workspaces,
|
|
23
|
+
repositories: state.repositories,
|
|
24
|
+
pullRequests: state.pullRequests,
|
|
25
|
+
loading: state.loading,
|
|
26
|
+
selectedWorkspace: state.selectedWorkspace,
|
|
27
|
+
selectedRepo: state.selectedRepo,
|
|
28
|
+
selectedPR: state.selectedPR,
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=use-bitbucket.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-bitbucket.js","sourceRoot":"","sources":["../../../src/tui/hooks/use-bitbucket.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AAGjD,MAAM,UAAU,YAAY;IAC1B,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,MAAM,EAAE,CAAC;IAErC,MAAM,iBAAiB,GAAG,KAAK,EAAE,QAAyB,EAAE,IAAY,EAAiB,EAAE;QACzF,MAAM,EAAE,GAAG,MAAM,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;QAC7C,QAAQ,CAAC,EAAE,IAAI,EAAE,kBAAkB,EAAE,OAAO,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;IAC3D,CAAC,CAAC;IAEF,MAAM,gBAAgB,GAAG,KAAK,EAAE,QAAyB,EAAE,SAAiB,EAAiB,EAAE;QAC7F,QAAQ,CAAC,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC,CAAC;QACpC,MAAM,KAAK,GAAG,MAAM,QAAQ,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC;QACzD,QAAQ,CAAC,EAAE,IAAI,EAAE,cAAc,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;IACrD,CAAC,CAAC;IAEF,MAAM,gBAAgB,GAAG,KAAK,EAC5B,QAAyB,EACzB,SAAiB,EACjB,IAAY,EACG,EAAE;QACjB,QAAQ,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC,CAAC;QAClC,MAAM,GAAG,GAAG,MAAM,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QAC7D,QAAQ,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC;IACjD,CAAC,CAAC;IAEF,OAAO;QACL,iBAAiB;QACjB,gBAAgB;QAChB,gBAAgB;QAChB,UAAU,EAAE,KAAK,CAAC,UAAU;QAC5B,YAAY,EAAE,KAAK,CAAC,YAAY;QAChC,YAAY,EAAE,KAAK,CAAC,YAAY;QAChC,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;QAC1C,YAAY,EAAE,KAAK,CAAC,YAAY;QAChC,UAAU,EAAE,KAAK,CAAC,UAAU;KAC7B,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { TUIWorkflowCallbacks } from '../callbacks/tui-workflow-callbacks.js';
|
|
2
|
+
import type { WorkflowEngineDeps, WorkflowInput } from '../../core/workflow-engine.js';
|
|
3
|
+
export declare function useReview(): {
|
|
4
|
+
startReview: (deps: WorkflowEngineDeps, input: WorkflowInput) => Promise<TUIWorkflowCallbacks>;
|
|
5
|
+
};
|
|
6
|
+
//# sourceMappingURL=use-review.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-review.d.ts","sourceRoot":"","sources":["../../../src/tui/hooks/use-review.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAE9E,OAAO,KAAK,EAAE,kBAAkB,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAEvF,wBAAgB,SAAS;wBAIf,kBAAkB,SACjB,aAAa,KACnB,OAAO,CAAC,oBAAoB,CAAC;EAiBjC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { useTUI } from '../state/tui-context.js';
|
|
2
|
+
import { TUIWorkflowCallbacks } from '../callbacks/tui-workflow-callbacks.js';
|
|
3
|
+
import { WorkflowEngine } from '../../core/workflow-engine.js';
|
|
4
|
+
export function useReview() {
|
|
5
|
+
const { state, dispatch } = useTUI();
|
|
6
|
+
const startReview = async (deps, input) => {
|
|
7
|
+
const thisReviewId = state.workflow.reviewId + 1;
|
|
8
|
+
dispatch({ type: 'WORKFLOW_START' });
|
|
9
|
+
const callbacks = new TUIWorkflowCallbacks(dispatch, thisReviewId);
|
|
10
|
+
const engine = new WorkflowEngine(deps, callbacks);
|
|
11
|
+
try {
|
|
12
|
+
await engine.execute(input);
|
|
13
|
+
}
|
|
14
|
+
catch (err) {
|
|
15
|
+
dispatch({
|
|
16
|
+
type: 'WORKFLOW_ERROR',
|
|
17
|
+
payload: err instanceof Error ? err.message : 'Unknown error',
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
return callbacks;
|
|
21
|
+
};
|
|
22
|
+
return { startReview };
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=use-review.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-review.js","sourceRoot":"","sources":["../../../src/tui/hooks/use-review.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AACjD,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAC9E,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAG/D,MAAM,UAAU,SAAS;IACvB,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,MAAM,EAAE,CAAC;IAErC,MAAM,WAAW,GAAG,KAAK,EACvB,IAAwB,EACxB,KAAoB,EACW,EAAE;QACjC,MAAM,YAAY,GAAG,KAAK,CAAC,QAAQ,CAAC,QAAQ,GAAG,CAAC,CAAC;QACjD,QAAQ,CAAC,EAAE,IAAI,EAAE,gBAAgB,EAAE,CAAC,CAAC;QACrC,MAAM,SAAS,GAAG,IAAI,oBAAoB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;QACnE,MAAM,MAAM,GAAG,IAAI,cAAc,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;QACnD,IAAI,CAAC;YACH,MAAM,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,QAAQ,CAAC;gBACP,IAAI,EAAE,gBAAgB;gBACtB,OAAO,EAAE,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe;aAC9D,CAAC,CAAC;QACL,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC,CAAC;IAEF,OAAO,EAAE,WAAW,EAAE,CAAC;AACzB,CAAC"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import type { SessionManager } from '../../core/session-manager.js';
|
|
2
|
+
import type { SessionRow, FindingRow, SessionListFilter } from '../../persistence/repository.js';
|
|
3
|
+
export declare function useSession(): {
|
|
4
|
+
sessions: {
|
|
5
|
+
status: string;
|
|
6
|
+
id: string;
|
|
7
|
+
agentIds: string;
|
|
8
|
+
model: string;
|
|
9
|
+
findingsCount: number;
|
|
10
|
+
workspace: string;
|
|
11
|
+
repo: string;
|
|
12
|
+
prId: number;
|
|
13
|
+
prTitle: string | null;
|
|
14
|
+
prUrl: string | null;
|
|
15
|
+
publishedCount: number;
|
|
16
|
+
inputTokens: number | null;
|
|
17
|
+
outputTokens: number | null;
|
|
18
|
+
costUsd: number | null;
|
|
19
|
+
memorySaved: number;
|
|
20
|
+
createdAt: string;
|
|
21
|
+
completedAt: string | null;
|
|
22
|
+
}[];
|
|
23
|
+
currentFindings: {
|
|
24
|
+
category: string;
|
|
25
|
+
status: string;
|
|
26
|
+
severity: string;
|
|
27
|
+
id: string;
|
|
28
|
+
filePath: string;
|
|
29
|
+
lineNumber: number;
|
|
30
|
+
title: string;
|
|
31
|
+
problem: string;
|
|
32
|
+
rationale: string;
|
|
33
|
+
suggestion: string;
|
|
34
|
+
agentId: string;
|
|
35
|
+
createdAt: string;
|
|
36
|
+
sessionId: string;
|
|
37
|
+
dedupHash: string;
|
|
38
|
+
skipReason: string | null;
|
|
39
|
+
bitbucketCommentId: number | null;
|
|
40
|
+
}[];
|
|
41
|
+
loadSessions: (sessionManager: SessionManager, filter?: SessionListFilter) => void;
|
|
42
|
+
loadSessionDetail: (sessionManager: SessionManager, sessionId: string) => {
|
|
43
|
+
session: SessionRow | undefined;
|
|
44
|
+
findings: FindingRow[];
|
|
45
|
+
};
|
|
46
|
+
};
|
|
47
|
+
//# sourceMappingURL=use-session.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-session.d.ts","sourceRoot":"","sources":["../../../src/tui/hooks/use-session.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AACpE,OAAO,KAAK,EAAE,UAAU,EAAE,UAAU,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AAEjG,wBAAgB,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mCAIc,cAAc,WAAW,iBAAiB,KAAG,IAAI;wCAMrE,cAAc,aACnB,MAAM,KAChB;QAAE,OAAO,EAAE,UAAU,GAAG,SAAS,CAAC;QAAC,QAAQ,EAAE,UAAU,EAAE,CAAA;KAAE;EAQ/D"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { useState } from 'react';
|
|
2
|
+
export function useSession() {
|
|
3
|
+
const [sessions, setSessions] = useState([]);
|
|
4
|
+
const [currentFindings, setCurrentFindings] = useState([]);
|
|
5
|
+
const loadSessions = (sessionManager, filter) => {
|
|
6
|
+
const result = sessionManager.listSessions(filter);
|
|
7
|
+
setSessions(result);
|
|
8
|
+
};
|
|
9
|
+
const loadSessionDetail = (sessionManager, sessionId) => {
|
|
10
|
+
const session = sessionManager.getSessionById(sessionId);
|
|
11
|
+
const findings = sessionManager.getFindings(sessionId);
|
|
12
|
+
setCurrentFindings(findings);
|
|
13
|
+
return { session, findings };
|
|
14
|
+
};
|
|
15
|
+
return { sessions, currentFindings, loadSessions, loadSessionDetail };
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=use-session.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-session.js","sourceRoot":"","sources":["../../../src/tui/hooks/use-session.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAIjC,MAAM,UAAU,UAAU;IACxB,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAe,EAAE,CAAC,CAAC;IAC3D,MAAM,CAAC,eAAe,EAAE,kBAAkB,CAAC,GAAG,QAAQ,CAAe,EAAE,CAAC,CAAC;IAEzE,MAAM,YAAY,GAAG,CAAC,cAA8B,EAAE,MAA0B,EAAQ,EAAE;QACxF,MAAM,MAAM,GAAG,cAAc,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QACnD,WAAW,CAAC,MAAM,CAAC,CAAC;IACtB,CAAC,CAAC;IAEF,MAAM,iBAAiB,GAAG,CACxB,cAA8B,EAC9B,SAAiB,EAC4C,EAAE;QAC/D,MAAM,OAAO,GAAG,cAAc,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;QACzD,MAAM,QAAQ,GAAG,cAAc,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;QACvD,kBAAkB,CAAC,QAAQ,CAAC,CAAC;QAC7B,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC;IAC/B,CAAC,CAAC;IAEF,OAAO,EAAE,QAAQ,EAAE,eAAe,EAAE,YAAY,EAAE,iBAAiB,EAAE,CAAC;AACxE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"screen-router.d.ts","sourceRoot":"","sources":["../../src/tui/screen-router.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAwB1B,wBAAgB,YAAY,IAAI,KAAK,CAAC,YAAY,CAiDjD"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Text } from 'ink';
|
|
3
|
+
import { useRouter } from './state/router-context.js';
|
|
4
|
+
import { WelcomeScreen } from './screens/welcome.js';
|
|
5
|
+
import { LoginScreen } from './screens/login.js';
|
|
6
|
+
import { HomeScreen } from './screens/home.js';
|
|
7
|
+
import { WorkspaceScreen } from './screens/workspace-select.js';
|
|
8
|
+
import { RepoScreen } from './screens/repo-select.js';
|
|
9
|
+
import { PRListScreen } from './screens/pr-list.js';
|
|
10
|
+
import { AgentSelectScreen } from './screens/agent-select.js';
|
|
11
|
+
import { ReviewRunningScreen } from './screens/review-running.js';
|
|
12
|
+
import { FindingsListScreen } from './screens/findings-list.js';
|
|
13
|
+
import { FindingDetailScreen } from './screens/finding-detail.js';
|
|
14
|
+
import { PublishConfirmScreen } from './screens/publish-confirm.js';
|
|
15
|
+
import { PublishingScreen } from './screens/publishing.js';
|
|
16
|
+
import { IntegrityReportScreen } from './screens/integrity-report.js';
|
|
17
|
+
import { SessionListScreen } from './screens/session-list.js';
|
|
18
|
+
import { SessionDetailScreen } from './screens/session-detail.js';
|
|
19
|
+
import { UrlInputScreen } from './screens/url-input.js';
|
|
20
|
+
import { GuardHomeScreen } from './screens/guard-home.js';
|
|
21
|
+
import { GuardRunningScreen } from './screens/guard-running.js';
|
|
22
|
+
import { GuardResultsScreen } from './screens/guard-results.js';
|
|
23
|
+
import { GuardDetailScreen } from './screens/guard-detail.js';
|
|
24
|
+
export function ScreenRouter() {
|
|
25
|
+
const { currentScreen } = useRouter();
|
|
26
|
+
switch (currentScreen.name) {
|
|
27
|
+
case 'welcome':
|
|
28
|
+
return _jsx(WelcomeScreen, {});
|
|
29
|
+
case 'login':
|
|
30
|
+
return _jsx(LoginScreen, {});
|
|
31
|
+
case 'home':
|
|
32
|
+
return _jsx(HomeScreen, {});
|
|
33
|
+
case 'workspace-select':
|
|
34
|
+
return _jsx(WorkspaceScreen, {});
|
|
35
|
+
case 'repo-select':
|
|
36
|
+
return _jsx(RepoScreen, {});
|
|
37
|
+
case 'pr-list':
|
|
38
|
+
return _jsx(PRListScreen, {});
|
|
39
|
+
case 'url-input':
|
|
40
|
+
return _jsx(UrlInputScreen, {});
|
|
41
|
+
case 'agent-select':
|
|
42
|
+
return _jsx(AgentSelectScreen, {});
|
|
43
|
+
case 'review-running':
|
|
44
|
+
return _jsx(ReviewRunningScreen, {});
|
|
45
|
+
case 'integrity-report':
|
|
46
|
+
return _jsx(IntegrityReportScreen, {});
|
|
47
|
+
case 'findings-list':
|
|
48
|
+
return _jsx(FindingsListScreen, {});
|
|
49
|
+
case 'finding-detail':
|
|
50
|
+
return _jsx(FindingDetailScreen, {});
|
|
51
|
+
case 'publish-confirm':
|
|
52
|
+
return _jsx(PublishConfirmScreen, {});
|
|
53
|
+
case 'publishing':
|
|
54
|
+
return _jsx(PublishingScreen, {});
|
|
55
|
+
case 'session-list':
|
|
56
|
+
return _jsx(SessionListScreen, {});
|
|
57
|
+
case 'session-detail':
|
|
58
|
+
return _jsx(SessionDetailScreen, {});
|
|
59
|
+
case 'guard-home':
|
|
60
|
+
return _jsx(GuardHomeScreen, {});
|
|
61
|
+
case 'guard-running':
|
|
62
|
+
return _jsx(GuardRunningScreen, {});
|
|
63
|
+
case 'guard-results':
|
|
64
|
+
return _jsx(GuardResultsScreen, {});
|
|
65
|
+
case 'guard-detail':
|
|
66
|
+
return _jsx(GuardDetailScreen, {});
|
|
67
|
+
default: {
|
|
68
|
+
const _exhaustive = currentScreen.name;
|
|
69
|
+
return _jsxs(Text, { children: ["Unknown Screen: ", String(_exhaustive)] });
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
//# sourceMappingURL=screen-router.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"screen-router.js","sourceRoot":"","sources":["../../src/tui/screen-router.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-select.d.ts","sourceRoot":"","sources":["../../../src/tui/screens/agent-select.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAyC,MAAM,OAAO,CAAC;AA2E9D,wBAAgB,iBAAiB,IAAI,KAAK,CAAC,YAAY,CAoOtD"}
|
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useCallback, useMemo } from 'react';
|
|
3
|
+
import { Box, Text, useInput } from 'ink';
|
|
4
|
+
import { useRouter } from '../state/router-context.js';
|
|
5
|
+
import { useTUI } from '../state/tui-context.js';
|
|
6
|
+
import { Spinner } from '../components/spinner.js';
|
|
7
|
+
import { SeveritySelector } from '../components/severity-selector.js';
|
|
8
|
+
import { useAgentRecommendations } from '../hooks/use-agent-recommendations.js';
|
|
9
|
+
function TierSection({ title, agents, tier, selectedAgents, cursorId, }) {
|
|
10
|
+
if (agents.length === 0)
|
|
11
|
+
return null;
|
|
12
|
+
const isNotApplicable = tier === 'not-applicable';
|
|
13
|
+
return (_jsxs(Box, { flexDirection: "column", children: [_jsxs(Text, { dimColor: true, children: [`── ${title} (${agents.length}) `, '─'.repeat(Math.max(0, 32 - title.length - String(agents.length).length - 6))] }), agents.map(({ agent, reason }) => {
|
|
14
|
+
const isSelected = selectedAgents.has(agent.id);
|
|
15
|
+
const isCursor = agent.id === cursorId;
|
|
16
|
+
if (isNotApplicable) {
|
|
17
|
+
return (_jsxs(Box, { flexDirection: "row", gap: 1, children: [_jsx(Text, { dimColor: true, children: ' ╌ ' }), _jsx(Text, { dimColor: true, bold: false, children: agent.displayName }), _jsxs(Text, { dimColor: true, children: [' ', reason] })] }, agent.id));
|
|
18
|
+
}
|
|
19
|
+
const checkbox = isSelected ? '[✓]' : '[ ]';
|
|
20
|
+
return (_jsxs(Box, { flexDirection: "row", gap: 1, children: [isCursor ? _jsx(Text, { color: "cyan", children: '>' }) : _jsx(Text, { children: ' ' }), isSelected && isCursor
|
|
21
|
+
? _jsx(Text, { color: "cyan", children: checkbox })
|
|
22
|
+
: isSelected
|
|
23
|
+
? _jsx(Text, { color: "green", children: checkbox })
|
|
24
|
+
: _jsx(Text, { children: checkbox }), isCursor
|
|
25
|
+
? _jsx(Text, { color: "cyan", bold: true, children: agent.displayName })
|
|
26
|
+
: isSelected
|
|
27
|
+
? _jsx(Text, { color: "green", children: agent.displayName })
|
|
28
|
+
: _jsx(Text, { children: agent.displayName }), _jsxs(Text, { dimColor: true, children: [' ', agent.description] })] }, agent.id));
|
|
29
|
+
})] }));
|
|
30
|
+
}
|
|
31
|
+
// ── Main screen ──────────────────────────────────────────────────────────────
|
|
32
|
+
export function AgentSelectScreen() {
|
|
33
|
+
const { push, pop, currentScreen } = useRouter();
|
|
34
|
+
const { state } = useTUI();
|
|
35
|
+
const isActive = currentScreen.name === 'agent-select';
|
|
36
|
+
const { selectedPR, selectedWorkspace, selectedRepo } = state;
|
|
37
|
+
// Fetch recommendations
|
|
38
|
+
const workspace = selectedWorkspace ?? '';
|
|
39
|
+
const repo = selectedRepo ?? '';
|
|
40
|
+
const prId = selectedPR?.id ?? 0;
|
|
41
|
+
const recommendations = useAgentRecommendations(workspace, repo, prId);
|
|
42
|
+
// Derive selectable agents (recommended + available) — not-applicable excluded
|
|
43
|
+
const selectableAgents = useMemo(() => {
|
|
44
|
+
return recommendations.classified.filter(c => c.tier !== 'not-applicable');
|
|
45
|
+
}, [recommendations.classified]);
|
|
46
|
+
const recommendedAgents = useMemo(() => {
|
|
47
|
+
return recommendations.classified.filter(c => c.tier === 'recommended');
|
|
48
|
+
}, [recommendations.classified]);
|
|
49
|
+
const availableAgents = useMemo(() => {
|
|
50
|
+
return recommendations.classified.filter(c => c.tier === 'available');
|
|
51
|
+
}, [recommendations.classified]);
|
|
52
|
+
const notApplicableAgents = useMemo(() => {
|
|
53
|
+
return recommendations.classified.filter(c => c.tier === 'not-applicable');
|
|
54
|
+
}, [recommendations.classified]);
|
|
55
|
+
// Initialize selected agents with all recommended IDs
|
|
56
|
+
const [selectedAgents, setSelectedAgents] = useState(() => new Set(recommendedAgents.map(c => c.agent.id)));
|
|
57
|
+
// Update selection when recommendations load
|
|
58
|
+
const [initialized, setInitialized] = useState(false);
|
|
59
|
+
if (recommendations.status === 'ready' && !initialized) {
|
|
60
|
+
setInitialized(true);
|
|
61
|
+
setSelectedAgents(new Set(recommendedAgents.map(c => c.agent.id)));
|
|
62
|
+
}
|
|
63
|
+
const [cursorIndex, setCursorIndex] = useState(0);
|
|
64
|
+
const [minSeverity, setMinSeverity] = useState('info');
|
|
65
|
+
const [focusRow, setFocusRow] = useState('agents');
|
|
66
|
+
const cursorId = focusRow === 'agents'
|
|
67
|
+
? (selectableAgents[cursorIndex]?.agent.id ?? null)
|
|
68
|
+
: null;
|
|
69
|
+
const toggleAgent = useCallback((id) => {
|
|
70
|
+
setSelectedAgents(prev => {
|
|
71
|
+
const next = new Set(prev);
|
|
72
|
+
if (next.has(id)) {
|
|
73
|
+
next.delete(id);
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
next.add(id);
|
|
77
|
+
}
|
|
78
|
+
return next;
|
|
79
|
+
});
|
|
80
|
+
}, []);
|
|
81
|
+
const toggleAll = useCallback(() => {
|
|
82
|
+
setSelectedAgents(prev => {
|
|
83
|
+
const allSelectableIds = selectableAgents.map(c => c.agent.id);
|
|
84
|
+
const allSelected = allSelectableIds.every(id => prev.has(id));
|
|
85
|
+
if (allSelected) {
|
|
86
|
+
return new Set();
|
|
87
|
+
}
|
|
88
|
+
return new Set(allSelectableIds);
|
|
89
|
+
});
|
|
90
|
+
}, [selectableAgents]);
|
|
91
|
+
const selectRecommendedOnly = useCallback(() => {
|
|
92
|
+
setSelectedAgents(new Set(recommendedAgents.map(c => c.agent.id)));
|
|
93
|
+
}, [recommendedAgents]);
|
|
94
|
+
useInput((input, key) => {
|
|
95
|
+
if (key.escape) {
|
|
96
|
+
pop();
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
if (!selectedPR)
|
|
100
|
+
return;
|
|
101
|
+
if (focusRow === 'severity') {
|
|
102
|
+
// s or up exit severity row; left/right are consumed by SeveritySelector
|
|
103
|
+
if (input === 's' || key.upArrow) {
|
|
104
|
+
setFocusRow('agents');
|
|
105
|
+
}
|
|
106
|
+
// Enter works from severity row too
|
|
107
|
+
if (key.return) {
|
|
108
|
+
if (selectedAgents.size === 0)
|
|
109
|
+
return;
|
|
110
|
+
push({ name: 'review-running', params: { agentIds: Array.from(selectedAgents), minSeverity } });
|
|
111
|
+
}
|
|
112
|
+
return;
|
|
113
|
+
}
|
|
114
|
+
// focusRow === 'agents'
|
|
115
|
+
if (key.return) {
|
|
116
|
+
if (selectedAgents.size === 0)
|
|
117
|
+
return;
|
|
118
|
+
push({ name: 'review-running', params: { agentIds: Array.from(selectedAgents), minSeverity } });
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
121
|
+
if (key.downArrow) {
|
|
122
|
+
if (selectableAgents.length > 0) {
|
|
123
|
+
const nextIndex = cursorIndex + 1;
|
|
124
|
+
if (nextIndex >= selectableAgents.length) {
|
|
125
|
+
// Past last agent → move to severity row
|
|
126
|
+
setFocusRow('severity');
|
|
127
|
+
}
|
|
128
|
+
else {
|
|
129
|
+
setCursorIndex(nextIndex);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
return;
|
|
133
|
+
}
|
|
134
|
+
if (key.upArrow) {
|
|
135
|
+
if (selectableAgents.length > 0) {
|
|
136
|
+
setCursorIndex(prev => (prev - 1 + selectableAgents.length) % selectableAgents.length);
|
|
137
|
+
}
|
|
138
|
+
return;
|
|
139
|
+
}
|
|
140
|
+
if (input === ' ') {
|
|
141
|
+
const agent = selectableAgents[cursorIndex];
|
|
142
|
+
if (agent !== undefined) {
|
|
143
|
+
toggleAgent(agent.agent.id);
|
|
144
|
+
}
|
|
145
|
+
return;
|
|
146
|
+
}
|
|
147
|
+
if (input === 'a') {
|
|
148
|
+
toggleAll();
|
|
149
|
+
return;
|
|
150
|
+
}
|
|
151
|
+
if (input === 'r') {
|
|
152
|
+
selectRecommendedOnly();
|
|
153
|
+
return;
|
|
154
|
+
}
|
|
155
|
+
if (input === 's') {
|
|
156
|
+
setFocusRow('severity');
|
|
157
|
+
return;
|
|
158
|
+
}
|
|
159
|
+
}, { isActive });
|
|
160
|
+
// ── No PR selected ──────────────────────────────────────────────────────────
|
|
161
|
+
if (!selectedPR) {
|
|
162
|
+
return (_jsxs(Box, { flexDirection: "column", gap: 1, children: [_jsx(Text, { bold: true, color: "yellow", children: "No PR selected" }), _jsx(Text, { dimColor: true, children: "Please go back and select a pull request first." }), _jsx(Text, { dimColor: true, children: "[Esc] Back" })] }));
|
|
163
|
+
}
|
|
164
|
+
// ── PR info header ──────────────────────────────────────────────────────────
|
|
165
|
+
const prHeader = (_jsxs(Box, { flexDirection: "column", children: [_jsxs(Text, { bold: true, color: "cyan", children: ["PR #", selectedPR.id, ": ", selectedPR.title] }), _jsxs(Text, { dimColor: true, children: [selectedPR.sourceBranch, " \u2192 ", selectedPR.targetBranch, recommendations.fileCount > 0 ? ` | ${recommendations.fileCount} files` : '', ` | by ${selectedPR.author.displayName}`] })] }));
|
|
166
|
+
// ── Loading ─────────────────────────────────────────────────────────────────
|
|
167
|
+
if (recommendations.status === 'loading') {
|
|
168
|
+
return (_jsxs(Box, { flexDirection: "column", gap: 1, children: [prHeader, _jsx(Box, { flexDirection: "row", gap: 1, children: _jsx(Spinner, { label: "Loading PR diff stats..." }) })] }));
|
|
169
|
+
}
|
|
170
|
+
// ── Ready / Error ───────────────────────────────────────────────────────────
|
|
171
|
+
return (_jsxs(Box, { flexDirection: "column", gap: 1, children: [prHeader, _jsxs(Box, { flexDirection: "column", gap: 1, children: [_jsx(TierSection, { title: "Recommended", agents: recommendedAgents, tier: "recommended", selectedAgents: selectedAgents, cursorId: cursorId }), _jsx(TierSection, { title: "Available", agents: availableAgents, tier: "available", selectedAgents: selectedAgents, cursorId: cursorId }), _jsx(TierSection, { title: "Not Applicable", agents: notApplicableAgents, tier: "not-applicable", selectedAgents: selectedAgents, cursorId: cursorId })] }), recommendations.status === 'error' && recommendations.error !== null && (_jsxs(Text, { dimColor: true, children: ["\u26A0 ", recommendations.error, " \u2014 showing fallback agent list"] })), _jsx(SeveritySelector, { value: minSeverity, onChange: setMinSeverity, isActive: focusRow === 'severity' }), _jsx(Text, { dimColor: true, children: "\u2191\u2193 navigate \u2423 toggle r recommended a all s severity \u23CE start Esc back" })] }));
|
|
172
|
+
}
|
|
173
|
+
//# sourceMappingURL=agent-select.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-select.js","sourceRoot":"","sources":["../../../src/tui/screens/agent-select.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"finding-detail.d.ts","sourceRoot":"","sources":["../../../src/tui/screens/finding-detail.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAO1B,wBAAgB,mBAAmB,IAAI,KAAK,CAAC,YAAY,CA2FxD"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Box, Text, useInput } from 'ink';
|
|
3
|
+
import { useRouter } from '../state/router-context.js';
|
|
4
|
+
import { useTUI } from '../state/tui-context.js';
|
|
5
|
+
import { SeverityBadge } from '../components/severity-badge.js';
|
|
6
|
+
import { StatusBar } from '../components/status-bar.js';
|
|
7
|
+
export function FindingDetailScreen() {
|
|
8
|
+
const { state, dispatch } = useTUI();
|
|
9
|
+
const { pop, replace, currentScreen } = useRouter();
|
|
10
|
+
const isActive = currentScreen.name === 'finding-detail';
|
|
11
|
+
const findings = state.workflow.summary?.findings ?? [];
|
|
12
|
+
const rawIndex = currentScreen.params['findingIndex'];
|
|
13
|
+
const findingIndex = typeof rawIndex === 'number' ? rawIndex : 0;
|
|
14
|
+
const finding = findings[findingIndex];
|
|
15
|
+
const fpMessage = state.workflow.fpMessage;
|
|
16
|
+
useInput((input, key) => {
|
|
17
|
+
if (key.escape) {
|
|
18
|
+
pop();
|
|
19
|
+
}
|
|
20
|
+
else if (input === 'n') {
|
|
21
|
+
const nextIndex = findingIndex + 1;
|
|
22
|
+
if (nextIndex < findings.length) {
|
|
23
|
+
replace({ name: 'finding-detail', params: { findingIndex: nextIndex } });
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
else if (input === 'p') {
|
|
27
|
+
const prevIndex = findingIndex - 1;
|
|
28
|
+
if (prevIndex >= 0) {
|
|
29
|
+
replace({ name: 'finding-detail', params: { findingIndex: prevIndex } });
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
else if (input === 'f' && finding !== undefined) {
|
|
33
|
+
dispatch({ type: 'MARK_FALSE_POSITIVE', payload: { finding } });
|
|
34
|
+
dispatch({ type: 'FALSE_POSITIVE_SAVED', payload: { message: 'Marked as false positive' } });
|
|
35
|
+
pop();
|
|
36
|
+
}
|
|
37
|
+
}, { isActive });
|
|
38
|
+
if (finding === undefined) {
|
|
39
|
+
return (_jsxs(Box, { flexDirection: "column", gap: 1, children: [_jsx(Text, { bold: true, color: "red", children: "Finding not found" }), _jsx(StatusBar, { items: [{ key: 'Esc', label: 'back' }] })] }));
|
|
40
|
+
}
|
|
41
|
+
return (_jsxs(Box, { flexDirection: "column", gap: 1, children: [_jsxs(Box, { flexDirection: "row", gap: 1, children: [_jsx(SeverityBadge, { severity: finding.severity }), _jsx(Text, { bold: true, children: finding.category }), _jsxs(Text, { dimColor: true, children: ["by ", finding.agentId] })] }), _jsxs(Box, { flexDirection: "row", gap: 1, children: [_jsx(Text, { dimColor: true, children: "File:" }), _jsx(Text, { color: "blue", children: finding.filePath }), _jsxs(Text, { dimColor: true, children: ["line ", finding.lineNumber] })] }), _jsx(Text, { bold: true, children: finding.title }), _jsxs(Box, { flexDirection: "column", children: [_jsx(Text, { bold: true, color: "yellow", children: "Problem" }), _jsx(Text, { children: finding.problem })] }), _jsxs(Box, { flexDirection: "column", children: [_jsx(Text, { bold: true, color: "cyan", children: "Rationale" }), _jsx(Text, { children: finding.rationale })] }), _jsxs(Box, { flexDirection: "column", children: [_jsx(Text, { bold: true, color: "green", children: "Suggestion" }), _jsx(Text, { children: finding.suggestion })] }), _jsx(Box, { flexDirection: "row", gap: 1, children: _jsxs(Text, { dimColor: true, children: [findingIndex + 1, " / ", findings.length] }) }), fpMessage !== null && (_jsx(Text, { color: "green", children: fpMessage })), _jsx(StatusBar, { items: [
|
|
42
|
+
{ key: 'p', label: 'previous' },
|
|
43
|
+
{ key: 'n', label: 'next' },
|
|
44
|
+
{ key: 'f', label: 'mark false positive' },
|
|
45
|
+
{ key: 'Esc', label: 'back' },
|
|
46
|
+
] })] }));
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=finding-detail.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"finding-detail.js","sourceRoot":"","sources":["../../../src/tui/screens/finding-detail.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"findings-list.d.ts","sourceRoot":"","sources":["../../../src/tui/screens/findings-list.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAgC,MAAM,OAAO,CAAC;AAuCrD,wBAAgB,kBAAkB,IAAI,KAAK,CAAC,YAAY,CAoIvD"}
|