codehere 0.3.0 → 0.5.0-alpha.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.
- package/README.md +230 -42
- package/dist/application/agents/documentation-agent.d.ts +24 -0
- package/dist/application/agents/documentation-agent.d.ts.map +1 -0
- package/dist/application/agents/documentation-agent.js +399 -0
- package/dist/application/agents/documentation-agent.js.map +1 -0
- package/dist/application/agents/execution-agent.d.ts +11 -0
- package/dist/application/agents/execution-agent.d.ts.map +1 -1
- package/dist/application/agents/execution-agent.js +289 -80
- package/dist/application/agents/execution-agent.js.map +1 -1
- package/dist/application/agents/multi-agent-orchestrator.d.ts +3 -0
- package/dist/application/agents/multi-agent-orchestrator.d.ts.map +1 -1
- package/dist/application/agents/multi-agent-orchestrator.js +86 -0
- package/dist/application/agents/multi-agent-orchestrator.js.map +1 -1
- package/dist/application/agents/planning-agent.d.ts +3 -0
- package/dist/application/agents/planning-agent.d.ts.map +1 -1
- package/dist/application/agents/planning-agent.js +146 -70
- package/dist/application/agents/planning-agent.js.map +1 -1
- package/dist/application/agents/product-requirements-agent.d.ts +21 -0
- package/dist/application/agents/product-requirements-agent.d.ts.map +1 -0
- package/dist/application/agents/product-requirements-agent.js +247 -0
- package/dist/application/agents/product-requirements-agent.js.map +1 -0
- package/dist/application/agents/validation-agent.d.ts +5 -1
- package/dist/application/agents/validation-agent.d.ts.map +1 -1
- package/dist/application/agents/validation-agent.js +156 -21
- package/dist/application/agents/validation-agent.js.map +1 -1
- package/dist/application/services/dependency-container.d.ts +46 -2
- package/dist/application/services/dependency-container.d.ts.map +1 -1
- package/dist/application/services/dependency-container.js +177 -7
- package/dist/application/services/dependency-container.js.map +1 -1
- package/dist/application/services/intelligent-router.d.ts +13 -0
- package/dist/application/services/intelligent-router.d.ts.map +1 -1
- package/dist/application/services/intelligent-router.js +306 -90
- package/dist/application/services/intelligent-router.js.map +1 -1
- package/dist/application/use-cases/ask-question-use-case.d.ts +19 -0
- package/dist/application/use-cases/ask-question-use-case.d.ts.map +1 -1
- package/dist/application/use-cases/ask-question-use-case.js +125 -46
- package/dist/application/use-cases/ask-question-use-case.js.map +1 -1
- package/dist/application/use-cases/edit-file-use-case.d.ts.map +1 -1
- package/dist/application/use-cases/edit-file-use-case.js +16 -1
- package/dist/application/use-cases/edit-file-use-case.js.map +1 -1
- package/dist/domain/entities/documentation.d.ts +35 -0
- package/dist/domain/entities/documentation.d.ts.map +1 -0
- package/dist/domain/entities/documentation.js +6 -0
- package/dist/domain/entities/documentation.js.map +1 -0
- package/dist/domain/entities/product-requirements.d.ts +50 -0
- package/dist/domain/entities/product-requirements.d.ts.map +1 -0
- package/dist/domain/entities/product-requirements.js +6 -0
- package/dist/domain/entities/product-requirements.js.map +1 -0
- package/dist/domain/entities/task.d.ts +152 -0
- package/dist/domain/entities/task.d.ts.map +1 -0
- package/dist/domain/entities/task.js +61 -0
- package/dist/domain/entities/task.js.map +1 -0
- package/dist/domain/errors/embeddings-not-found-error.d.ts +9 -0
- package/dist/domain/errors/embeddings-not-found-error.d.ts.map +1 -0
- package/dist/domain/errors/embeddings-not-found-error.js +13 -0
- package/dist/domain/errors/embeddings-not-found-error.js.map +1 -0
- package/dist/domain/interfaces/agent.interface.d.ts +15 -0
- package/dist/domain/interfaces/agent.interface.d.ts.map +1 -0
- package/dist/domain/interfaces/agent.interface.js +6 -0
- package/dist/domain/interfaces/agent.interface.js.map +1 -0
- package/dist/domain/interfaces/embedding-repository.interface.d.ts +5 -0
- package/dist/domain/interfaces/embedding-repository.interface.d.ts.map +1 -1
- package/dist/domain/services/environment-mode-manager.d.ts +12 -0
- package/dist/domain/services/environment-mode-manager.d.ts.map +1 -0
- package/dist/domain/services/environment-mode-manager.js +22 -0
- package/dist/domain/services/environment-mode-manager.js.map +1 -0
- package/dist/domain/services/risk-tier-detector.d.ts +17 -0
- package/dist/domain/services/risk-tier-detector.d.ts.map +1 -0
- package/dist/domain/services/risk-tier-detector.js +78 -0
- package/dist/domain/services/risk-tier-detector.js.map +1 -0
- package/dist/embed.d.ts.map +1 -1
- package/dist/embed.js +18 -8
- package/dist/embed.js.map +1 -1
- package/dist/formatter.d.ts.map +1 -1
- package/dist/formatter.js +10 -3
- package/dist/formatter.js.map +1 -1
- package/dist/index.js +398 -164
- package/dist/index.js.map +1 -1
- package/dist/infrastructure/ai/cohere-ai-service.d.ts.map +1 -1
- package/dist/infrastructure/ai/cohere-ai-service.js +18 -5
- package/dist/infrastructure/ai/cohere-ai-service.js.map +1 -1
- package/dist/infrastructure/ai/fake-ai-service.d.ts +22 -0
- package/dist/infrastructure/ai/fake-ai-service.d.ts.map +1 -0
- package/dist/infrastructure/ai/fake-ai-service.js +59 -0
- package/dist/infrastructure/ai/fake-ai-service.js.map +1 -0
- package/dist/infrastructure/ai/provider-ai-service.d.ts +59 -0
- package/dist/infrastructure/ai/provider-ai-service.d.ts.map +1 -0
- package/dist/infrastructure/ai/provider-ai-service.js +477 -0
- package/dist/infrastructure/ai/provider-ai-service.js.map +1 -0
- package/dist/infrastructure/cache/embedding-cache.d.ts +13 -1
- package/dist/infrastructure/cache/embedding-cache.d.ts.map +1 -1
- package/dist/infrastructure/cache/embedding-cache.js +80 -9
- package/dist/infrastructure/cache/embedding-cache.js.map +1 -1
- package/dist/infrastructure/cache/query-result-cache.d.ts +14 -55
- package/dist/infrastructure/cache/query-result-cache.d.ts.map +1 -1
- package/dist/infrastructure/cache/query-result-cache.js +40 -112
- package/dist/infrastructure/cache/query-result-cache.js.map +1 -1
- package/dist/infrastructure/cache/response-cache.d.ts +18 -0
- package/dist/infrastructure/cache/response-cache.d.ts.map +1 -0
- package/dist/infrastructure/cache/response-cache.js +48 -0
- package/dist/infrastructure/cache/response-cache.js.map +1 -0
- package/dist/infrastructure/cache/security-scan-cache.d.ts +8 -49
- package/dist/infrastructure/cache/security-scan-cache.d.ts.map +1 -1
- package/dist/infrastructure/cache/security-scan-cache.js +25 -102
- package/dist/infrastructure/cache/security-scan-cache.js.map +1 -1
- package/dist/infrastructure/completion/bash-completion.d.ts +2 -3
- package/dist/infrastructure/completion/bash-completion.d.ts.map +1 -1
- package/dist/infrastructure/completion/bash-completion.js +11 -87
- package/dist/infrastructure/completion/bash-completion.js.map +1 -1
- package/dist/infrastructure/completion/fish-completion.d.ts +2 -3
- package/dist/infrastructure/completion/fish-completion.d.ts.map +1 -1
- package/dist/infrastructure/completion/fish-completion.js +15 -58
- package/dist/infrastructure/completion/fish-completion.js.map +1 -1
- package/dist/infrastructure/completion/zsh-completion.d.ts +2 -3
- package/dist/infrastructure/completion/zsh-completion.d.ts.map +1 -1
- package/dist/infrastructure/completion/zsh-completion.js +18 -73
- package/dist/infrastructure/completion/zsh-completion.js.map +1 -1
- package/dist/infrastructure/config/config-manager.js +2 -2
- package/dist/infrastructure/config/config-manager.js.map +1 -1
- package/dist/infrastructure/context/conversation-context.d.ts +54 -0
- package/dist/infrastructure/context/conversation-context.d.ts.map +1 -0
- package/dist/infrastructure/context/conversation-context.js +128 -0
- package/dist/infrastructure/context/conversation-context.js.map +1 -0
- package/dist/infrastructure/context/session-manager.d.ts +42 -0
- package/dist/infrastructure/context/session-manager.d.ts.map +1 -0
- package/dist/infrastructure/context/session-manager.js +94 -0
- package/dist/infrastructure/context/session-manager.js.map +1 -0
- package/dist/infrastructure/cost/cost-tracker.d.ts +1 -0
- package/dist/infrastructure/cost/cost-tracker.d.ts.map +1 -1
- package/dist/infrastructure/cost/cost-tracker.js +12 -5
- package/dist/infrastructure/cost/cost-tracker.js.map +1 -1
- package/dist/infrastructure/governance/nist-ai-rmf.d.ts +6 -8
- package/dist/infrastructure/governance/nist-ai-rmf.d.ts.map +1 -1
- package/dist/infrastructure/governance/nist-ai-rmf.js +6 -8
- package/dist/infrastructure/governance/nist-ai-rmf.js.map +1 -1
- package/dist/infrastructure/governance/policy-as-code.d.ts +6 -8
- package/dist/infrastructure/governance/policy-as-code.d.ts.map +1 -1
- package/dist/infrastructure/governance/policy-as-code.js +6 -8
- package/dist/infrastructure/governance/policy-as-code.js.map +1 -1
- package/dist/infrastructure/governance/prompt-to-code-lineage.d.ts +7 -9
- package/dist/infrastructure/governance/prompt-to-code-lineage.d.ts.map +1 -1
- package/dist/infrastructure/governance/prompt-to-code-lineage.js +7 -9
- package/dist/infrastructure/governance/prompt-to-code-lineage.js.map +1 -1
- package/dist/infrastructure/providers/cohere-provider.d.ts +39 -0
- package/dist/infrastructure/providers/cohere-provider.d.ts.map +1 -0
- package/dist/infrastructure/providers/cohere-provider.js +444 -0
- package/dist/infrastructure/providers/cohere-provider.js.map +1 -0
- package/dist/infrastructure/providers/fake-provider.d.ts +43 -0
- package/dist/infrastructure/providers/fake-provider.d.ts.map +1 -0
- package/dist/infrastructure/providers/fake-provider.js +130 -0
- package/dist/infrastructure/providers/fake-provider.js.map +1 -0
- package/dist/infrastructure/providers/local-llm-provider.d.ts +49 -0
- package/dist/infrastructure/providers/local-llm-provider.d.ts.map +1 -0
- package/dist/infrastructure/providers/local-llm-provider.js +330 -0
- package/dist/infrastructure/providers/local-llm-provider.js.map +1 -0
- package/dist/infrastructure/providers/model-config.types.d.ts +70 -0
- package/dist/infrastructure/providers/model-config.types.d.ts.map +1 -0
- package/dist/infrastructure/providers/model-config.types.js +9 -0
- package/dist/infrastructure/providers/model-config.types.js.map +1 -0
- package/dist/infrastructure/providers/model-provider.interface.d.ts +113 -0
- package/dist/infrastructure/providers/model-provider.interface.d.ts.map +1 -0
- package/dist/infrastructure/providers/model-provider.interface.js +8 -0
- package/dist/infrastructure/providers/model-provider.interface.js.map +1 -0
- package/dist/infrastructure/providers/openai-provider.d.ts +38 -0
- package/dist/infrastructure/providers/openai-provider.d.ts.map +1 -0
- package/dist/infrastructure/providers/openai-provider.js +413 -0
- package/dist/infrastructure/providers/openai-provider.js.map +1 -0
- package/dist/infrastructure/providers/openrouter-provider.d.ts +42 -0
- package/dist/infrastructure/providers/openrouter-provider.d.ts.map +1 -0
- package/dist/infrastructure/providers/openrouter-provider.js +399 -0
- package/dist/infrastructure/providers/openrouter-provider.js.map +1 -0
- package/dist/infrastructure/providers/operation-provider-resolver.d.ts +48 -0
- package/dist/infrastructure/providers/operation-provider-resolver.d.ts.map +1 -0
- package/dist/infrastructure/providers/operation-provider-resolver.js +105 -0
- package/dist/infrastructure/providers/operation-provider-resolver.js.map +1 -0
- package/dist/infrastructure/providers/provider-config-loader.d.ts +37 -0
- package/dist/infrastructure/providers/provider-config-loader.d.ts.map +1 -0
- package/dist/infrastructure/providers/provider-config-loader.js +120 -0
- package/dist/infrastructure/providers/provider-config-loader.js.map +1 -0
- package/dist/infrastructure/providers/provider-registry.d.ts +53 -0
- package/dist/infrastructure/providers/provider-registry.d.ts.map +1 -0
- package/dist/infrastructure/providers/provider-registry.js +88 -0
- package/dist/infrastructure/providers/provider-registry.js.map +1 -0
- package/dist/infrastructure/serialization/toon-serializer.d.ts +45 -0
- package/dist/infrastructure/serialization/toon-serializer.d.ts.map +1 -0
- package/dist/infrastructure/serialization/toon-serializer.js +119 -0
- package/dist/infrastructure/serialization/toon-serializer.js.map +1 -0
- package/dist/infrastructure/storage/embeddings-path.d.ts +18 -0
- package/dist/infrastructure/storage/embeddings-path.d.ts.map +1 -0
- package/dist/infrastructure/storage/embeddings-path.js +37 -0
- package/dist/infrastructure/storage/embeddings-path.js.map +1 -0
- package/dist/infrastructure/storage/plan-repository.d.ts +2 -0
- package/dist/infrastructure/storage/plan-repository.d.ts.map +1 -1
- package/dist/infrastructure/storage/plan-repository.js +36 -73
- package/dist/infrastructure/storage/plan-repository.js.map +1 -1
- package/dist/infrastructure/storage/sqlite-embedding-repository.d.ts +10 -1
- package/dist/infrastructure/storage/sqlite-embedding-repository.d.ts.map +1 -1
- package/dist/infrastructure/storage/sqlite-embedding-repository.js +37 -3
- package/dist/infrastructure/storage/sqlite-embedding-repository.js.map +1 -1
- package/dist/infrastructure/storage/task-helpers.d.ts +69 -0
- package/dist/infrastructure/storage/task-helpers.d.ts.map +1 -0
- package/dist/infrastructure/storage/task-helpers.js +197 -0
- package/dist/infrastructure/storage/task-helpers.js.map +1 -0
- package/dist/infrastructure/storage/task-repository.d.ts +67 -0
- package/dist/infrastructure/storage/task-repository.d.ts.map +1 -0
- package/dist/infrastructure/storage/task-repository.js +205 -0
- package/dist/infrastructure/storage/task-repository.js.map +1 -0
- package/dist/infrastructure/ux/bi-directional-learning.d.ts +22 -0
- package/dist/infrastructure/ux/bi-directional-learning.d.ts.map +1 -1
- package/dist/infrastructure/ux/bi-directional-learning.js +144 -7
- package/dist/infrastructure/ux/bi-directional-learning.js.map +1 -1
- package/dist/infrastructure/ux/capability-boundaries.d.ts +22 -0
- package/dist/infrastructure/ux/capability-boundaries.d.ts.map +1 -0
- package/dist/infrastructure/ux/capability-boundaries.js +42 -0
- package/dist/infrastructure/ux/capability-boundaries.js.map +1 -0
- package/dist/infrastructure/ux/comprehensive-formatter.d.ts +21 -0
- package/dist/infrastructure/ux/comprehensive-formatter.d.ts.map +1 -0
- package/dist/infrastructure/ux/comprehensive-formatter.js +117 -0
- package/dist/infrastructure/ux/comprehensive-formatter.js.map +1 -0
- package/dist/infrastructure/ux/contextual-feature-discovery.d.ts +5 -18
- package/dist/infrastructure/ux/contextual-feature-discovery.d.ts.map +1 -1
- package/dist/infrastructure/ux/contextual-feature-discovery.js +5 -139
- package/dist/infrastructure/ux/contextual-feature-discovery.js.map +1 -1
- package/dist/infrastructure/ux/feature-discovery.d.ts +3 -33
- package/dist/infrastructure/ux/feature-discovery.d.ts.map +1 -1
- package/dist/infrastructure/ux/feature-discovery.js +5 -181
- package/dist/infrastructure/ux/feature-discovery.js.map +1 -1
- package/dist/infrastructure/ux/feedback-prompt.d.ts +26 -0
- package/dist/infrastructure/ux/feedback-prompt.d.ts.map +1 -0
- package/dist/infrastructure/ux/feedback-prompt.js +45 -0
- package/dist/infrastructure/ux/feedback-prompt.js.map +1 -0
- package/dist/infrastructure/ux/hitl-review-portal.d.ts.map +1 -1
- package/dist/infrastructure/ux/hitl-review-portal.js +4 -1
- package/dist/infrastructure/ux/hitl-review-portal.js.map +1 -1
- package/dist/infrastructure/ux/hitl-validation.d.ts +35 -0
- package/dist/infrastructure/ux/hitl-validation.d.ts.map +1 -1
- package/dist/infrastructure/ux/hitl-validation.js +86 -0
- package/dist/infrastructure/ux/hitl-validation.js.map +1 -1
- package/dist/infrastructure/ux/progress-indicator.d.ts +4 -5
- package/dist/infrastructure/ux/progress-indicator.d.ts.map +1 -1
- package/dist/infrastructure/ux/progress-indicator.js +35 -40
- package/dist/infrastructure/ux/progress-indicator.js.map +1 -1
- package/dist/infrastructure/ux/proportional-friction.d.ts +73 -0
- package/dist/infrastructure/ux/proportional-friction.d.ts.map +1 -0
- package/dist/infrastructure/ux/proportional-friction.js +200 -0
- package/dist/infrastructure/ux/proportional-friction.js.map +1 -0
- package/dist/infrastructure/ux/review-checkpoint.d.ts +3 -1
- package/dist/infrastructure/ux/review-checkpoint.d.ts.map +1 -1
- package/dist/infrastructure/ux/review-checkpoint.js +33 -80
- package/dist/infrastructure/ux/review-checkpoint.js.map +1 -1
- package/dist/infrastructure/ux/staged-feature-intro.d.ts +14 -39
- package/dist/infrastructure/ux/staged-feature-intro.d.ts.map +1 -1
- package/dist/infrastructure/ux/staged-feature-intro.js +12 -132
- package/dist/infrastructure/ux/staged-feature-intro.js.map +1 -1
- package/dist/infrastructure/ux/syntax-highlighter.d.ts +1 -2
- package/dist/infrastructure/ux/syntax-highlighter.d.ts.map +1 -1
- package/dist/infrastructure/ux/syntax-highlighter.js +67 -148
- package/dist/infrastructure/ux/syntax-highlighter.js.map +1 -1
- package/dist/infrastructure/validation/agent-feedback.d.ts +51 -0
- package/dist/infrastructure/validation/agent-feedback.d.ts.map +1 -0
- package/dist/infrastructure/validation/agent-feedback.js +55 -0
- package/dist/infrastructure/validation/agent-feedback.js.map +1 -0
- package/dist/infrastructure/validation/agent-validation-helper.d.ts +75 -0
- package/dist/infrastructure/validation/agent-validation-helper.d.ts.map +1 -0
- package/dist/infrastructure/validation/agent-validation-helper.js +137 -0
- package/dist/infrastructure/validation/agent-validation-helper.js.map +1 -0
- package/dist/infrastructure/validation/feedback-stats.d.ts +99 -0
- package/dist/infrastructure/validation/feedback-stats.d.ts.map +1 -0
- package/dist/infrastructure/validation/feedback-stats.js +173 -0
- package/dist/infrastructure/validation/feedback-stats.js.map +1 -0
- package/dist/infrastructure/validation/review-handler.d.ts +26 -0
- package/dist/infrastructure/validation/review-handler.d.ts.map +1 -0
- package/dist/infrastructure/validation/review-handler.js +40 -0
- package/dist/infrastructure/validation/review-handler.js.map +1 -0
- package/dist/infrastructure/validation/summary-aggregator.d.ts +45 -0
- package/dist/infrastructure/validation/summary-aggregator.d.ts.map +1 -0
- package/dist/infrastructure/validation/summary-aggregator.js +70 -0
- package/dist/infrastructure/validation/summary-aggregator.js.map +1 -0
- package/dist/infrastructure/validation/summary-extractor.d.ts +24 -0
- package/dist/infrastructure/validation/summary-extractor.d.ts.map +1 -0
- package/dist/infrastructure/validation/summary-extractor.js +45 -0
- package/dist/infrastructure/validation/summary-extractor.js.map +1 -0
- package/dist/infrastructure/validation/trace-summary.d.ts +45 -0
- package/dist/infrastructure/validation/trace-summary.d.ts.map +1 -0
- package/dist/infrastructure/validation/trace-summary.js +52 -0
- package/dist/infrastructure/validation/trace-summary.js.map +1 -0
- package/dist/infrastructure/validation/trust-config.d.ts +27 -0
- package/dist/infrastructure/validation/trust-config.d.ts.map +1 -0
- package/dist/infrastructure/validation/trust-config.js +113 -0
- package/dist/infrastructure/validation/trust-config.js.map +1 -0
- package/dist/infrastructure/xai/attention-visualizer.d.ts +6 -8
- package/dist/infrastructure/xai/attention-visualizer.d.ts.map +1 -1
- package/dist/infrastructure/xai/attention-visualizer.js +6 -8
- package/dist/infrastructure/xai/attention-visualizer.js.map +1 -1
- package/dist/infrastructure/xai/cot-visualizer.d.ts +6 -9
- package/dist/infrastructure/xai/cot-visualizer.d.ts.map +1 -1
- package/dist/infrastructure/xai/cot-visualizer.js +6 -9
- package/dist/infrastructure/xai/cot-visualizer.js.map +1 -1
- package/dist/infrastructure/xai/decision-tree-log.d.ts +6 -10
- package/dist/infrastructure/xai/decision-tree-log.d.ts.map +1 -1
- package/dist/infrastructure/xai/decision-tree-log.js +6 -10
- package/dist/infrastructure/xai/decision-tree-log.js.map +1 -1
- package/dist/infrastructure/xai/interactive-xai.d.ts +6 -8
- package/dist/infrastructure/xai/interactive-xai.d.ts.map +1 -1
- package/dist/infrastructure/xai/interactive-xai.js +6 -8
- package/dist/infrastructure/xai/interactive-xai.js.map +1 -1
- package/dist/infrastructure/xai/uncertainty-quantifier.d.ts +6 -9
- package/dist/infrastructure/xai/uncertainty-quantifier.d.ts.map +1 -1
- package/dist/infrastructure/xai/uncertainty-quantifier.js +6 -9
- package/dist/infrastructure/xai/uncertainty-quantifier.js.map +1 -1
- package/dist/monitoring.d.ts +1 -1
- package/dist/monitoring.d.ts.map +1 -1
- package/dist/monitoring.js +12 -9
- package/dist/monitoring.js.map +1 -1
- package/dist/parallel-processor.d.ts.map +1 -1
- package/dist/parallel-processor.js +124 -45
- package/dist/parallel-processor.js.map +1 -1
- package/dist/presentation/cli/commands/ask-command.d.ts.map +1 -1
- package/dist/presentation/cli/commands/ask-command.js +225 -86
- package/dist/presentation/cli/commands/ask-command.js.map +1 -1
- package/dist/presentation/cli/commands/config-command.d.ts.map +1 -1
- package/dist/presentation/cli/commands/config-command.js +8 -6
- package/dist/presentation/cli/commands/config-command.js.map +1 -1
- package/dist/presentation/cli/commands/docs-command.d.ts +14 -0
- package/dist/presentation/cli/commands/docs-command.d.ts.map +1 -0
- package/dist/presentation/cli/commands/docs-command.js +25 -0
- package/dist/presentation/cli/commands/docs-command.js.map +1 -0
- package/dist/presentation/cli/commands/fix-command.d.ts +10 -0
- package/dist/presentation/cli/commands/fix-command.d.ts.map +1 -0
- package/dist/presentation/cli/commands/fix-command.js +53 -0
- package/dist/presentation/cli/commands/fix-command.js.map +1 -0
- package/dist/presentation/cli/commands/help-command.d.ts.map +1 -1
- package/dist/presentation/cli/commands/help-command.js +2 -0
- package/dist/presentation/cli/commands/help-command.js.map +1 -1
- package/dist/presentation/cli/commands/models-command.d.ts +13 -0
- package/dist/presentation/cli/commands/models-command.d.ts.map +1 -0
- package/dist/presentation/cli/commands/models-command.js +194 -0
- package/dist/presentation/cli/commands/models-command.js.map +1 -0
- package/dist/presentation/cli/commands/orchestrate-command.d.ts +1 -0
- package/dist/presentation/cli/commands/orchestrate-command.d.ts.map +1 -1
- package/dist/presentation/cli/commands/orchestrate-command.js +68 -7
- package/dist/presentation/cli/commands/orchestrate-command.js.map +1 -1
- package/dist/presentation/cli/commands/plan-command.d.ts +1 -0
- package/dist/presentation/cli/commands/plan-command.d.ts.map +1 -1
- package/dist/presentation/cli/commands/plan-command.js +88 -8
- package/dist/presentation/cli/commands/plan-command.js.map +1 -1
- package/dist/presentation/cli/commands/product-command.d.ts +14 -0
- package/dist/presentation/cli/commands/product-command.d.ts.map +1 -0
- package/dist/presentation/cli/commands/product-command.js +22 -0
- package/dist/presentation/cli/commands/product-command.js.map +1 -0
- package/dist/presentation/cli/commands/react-command.d.ts.map +1 -1
- package/dist/presentation/cli/commands/react-command.js +3 -1
- package/dist/presentation/cli/commands/react-command.js.map +1 -1
- package/dist/presentation/cli/commands/review-command.d.ts +14 -0
- package/dist/presentation/cli/commands/review-command.d.ts.map +1 -0
- package/dist/presentation/cli/commands/review-command.js +154 -0
- package/dist/presentation/cli/commands/review-command.js.map +1 -0
- package/dist/presentation/cli/commands/run-command.d.ts +13 -0
- package/dist/presentation/cli/commands/run-command.d.ts.map +1 -0
- package/dist/presentation/cli/commands/run-command.js +188 -0
- package/dist/presentation/cli/commands/run-command.js.map +1 -0
- package/dist/presentation/cli/commands/setup-command.d.ts.map +1 -1
- package/dist/presentation/cli/commands/setup-command.js +15 -0
- package/dist/presentation/cli/commands/setup-command.js.map +1 -1
- package/dist/presentation/cli/commands/smart-command.d.ts +3 -1
- package/dist/presentation/cli/commands/smart-command.d.ts.map +1 -1
- package/dist/presentation/cli/commands/smart-command.js +92 -6
- package/dist/presentation/cli/commands/smart-command.js.map +1 -1
- package/dist/presentation/cli/commands/status-command.d.ts +14 -0
- package/dist/presentation/cli/commands/status-command.d.ts.map +1 -0
- package/dist/presentation/cli/commands/status-command.js +167 -0
- package/dist/presentation/cli/commands/status-command.js.map +1 -0
- package/dist/presentation/cli/commands/suggest-command.d.ts +11 -0
- package/dist/presentation/cli/commands/suggest-command.d.ts.map +1 -0
- package/dist/presentation/cli/commands/suggest-command.js +138 -0
- package/dist/presentation/cli/commands/suggest-command.js.map +1 -0
- package/dist/presentation/cli/error-display.d.ts.map +1 -1
- package/dist/presentation/cli/error-display.js +43 -0
- package/dist/presentation/cli/error-display.js.map +1 -1
- package/dist/search.d.ts.map +1 -1
- package/dist/search.js +6 -1
- package/dist/search.js.map +1 -1
- package/dist/session.js +19 -2
- package/dist/session.js.map +1 -1
- package/dist/ui.d.ts +6 -0
- package/dist/ui.d.ts.map +1 -1
- package/dist/ui.js +43 -6
- package/dist/ui.js.map +1 -1
- package/package.json +16 -3
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Infrastructure: Proportional Friction Enhancement
|
|
3
|
+
* Task 5.2: Higher friction for high-risk actions, lower friction for safe operations
|
|
4
|
+
*
|
|
5
|
+
* Features:
|
|
6
|
+
* - User-configurable friction levels
|
|
7
|
+
* - Risk-proportional friction calculation
|
|
8
|
+
* - Consistent application across operations
|
|
9
|
+
*/
|
|
10
|
+
import { AppropriateFriction } from './appropriate-friction.js';
|
|
11
|
+
import { readFileSync, writeFileSync, existsSync, mkdirSync } from 'fs';
|
|
12
|
+
import { join } from 'path';
|
|
13
|
+
/**
|
|
14
|
+
* Enhanced Proportional Friction System
|
|
15
|
+
* Extends AppropriateFriction with user-configurable proportional scaling
|
|
16
|
+
*/
|
|
17
|
+
export class ProportionalFriction extends AppropriateFriction {
|
|
18
|
+
config;
|
|
19
|
+
configPath;
|
|
20
|
+
constructor(configPath) {
|
|
21
|
+
super();
|
|
22
|
+
this.configPath = configPath || join(process.cwd(), 'data', 'friction-config.json');
|
|
23
|
+
this.config = this.loadConfiguration();
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Get friction point adjusted for user preferences
|
|
27
|
+
* Scales friction level based on user configuration and risk
|
|
28
|
+
*/
|
|
29
|
+
getProportionalFriction(operation, context) {
|
|
30
|
+
const baseFriction = this.needsFriction(operation, context);
|
|
31
|
+
if (!baseFriction) {
|
|
32
|
+
return null; // No friction needed
|
|
33
|
+
}
|
|
34
|
+
// Adjust friction level based on user preference
|
|
35
|
+
const adjustedLevel = this.adjustFrictionLevel(baseFriction.level, context.riskLevel || 'medium', this.config);
|
|
36
|
+
// Adjust confirmation requirements based on preference
|
|
37
|
+
const requiresConfirmation = this.shouldRequireConfirmation(baseFriction.requiresExplicitConfirmation, adjustedLevel, this.config);
|
|
38
|
+
// Adjust timeout based on preference
|
|
39
|
+
const timeout = this.adjustTimeout(baseFriction.timeout, adjustedLevel, this.config);
|
|
40
|
+
return {
|
|
41
|
+
...baseFriction,
|
|
42
|
+
level: adjustedLevel,
|
|
43
|
+
requiresExplicitConfirmation: requiresConfirmation,
|
|
44
|
+
timeout: timeout,
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Adjust friction level based on user preference
|
|
49
|
+
*/
|
|
50
|
+
adjustFrictionLevel(baseLevel, riskLevel, config) {
|
|
51
|
+
// For critical operations, always use heavy friction regardless of preference
|
|
52
|
+
if (riskLevel === 'critical') {
|
|
53
|
+
return 'heavy';
|
|
54
|
+
}
|
|
55
|
+
switch (config.preference) {
|
|
56
|
+
case 'minimal':
|
|
57
|
+
// Reduce friction levels
|
|
58
|
+
if (baseLevel === 'heavy')
|
|
59
|
+
return 'moderate';
|
|
60
|
+
if (baseLevel === 'moderate')
|
|
61
|
+
return 'light';
|
|
62
|
+
if (baseLevel === 'light')
|
|
63
|
+
return 'none';
|
|
64
|
+
return baseLevel;
|
|
65
|
+
case 'strict':
|
|
66
|
+
// Increase friction levels
|
|
67
|
+
if (baseLevel === 'light')
|
|
68
|
+
return 'moderate';
|
|
69
|
+
if (baseLevel === 'moderate')
|
|
70
|
+
return 'heavy';
|
|
71
|
+
if (baseLevel === 'none' && riskLevel !== 'low')
|
|
72
|
+
return 'light';
|
|
73
|
+
return baseLevel;
|
|
74
|
+
case 'balanced':
|
|
75
|
+
default:
|
|
76
|
+
// Use base level as-is (default behavior)
|
|
77
|
+
return baseLevel;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Determine if explicit confirmation should be required
|
|
82
|
+
*/
|
|
83
|
+
shouldRequireConfirmation(baseRequirement, frictionLevel, config) {
|
|
84
|
+
// Minimal preference allows auto-proceed for moderate friction
|
|
85
|
+
if (config.preference === 'minimal' && config.allowAutoProceed) {
|
|
86
|
+
if (frictionLevel === 'light' || frictionLevel === 'moderate') {
|
|
87
|
+
return false; // Allow auto-proceed
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
// Strict preference always requires confirmation for any friction
|
|
91
|
+
if (config.preference === 'strict') {
|
|
92
|
+
return frictionLevel !== 'none';
|
|
93
|
+
}
|
|
94
|
+
// Balanced: Use base requirement
|
|
95
|
+
return baseRequirement;
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Adjust timeout based on user preference
|
|
99
|
+
*/
|
|
100
|
+
adjustTimeout(baseTimeout, frictionLevel, config) {
|
|
101
|
+
if (!baseTimeout) {
|
|
102
|
+
return undefined; // No timeout
|
|
103
|
+
}
|
|
104
|
+
// Minimal: Shorter timeout
|
|
105
|
+
if (config.preference === 'minimal') {
|
|
106
|
+
return Math.max(1000, baseTimeout * 0.5); // 50% of base timeout
|
|
107
|
+
}
|
|
108
|
+
// Strict: Longer timeout
|
|
109
|
+
if (config.preference === 'strict') {
|
|
110
|
+
return baseTimeout * 2; // 200% of base timeout
|
|
111
|
+
}
|
|
112
|
+
// Balanced: Use base timeout
|
|
113
|
+
return baseTimeout;
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Update friction configuration
|
|
117
|
+
*/
|
|
118
|
+
updateConfiguration(config) {
|
|
119
|
+
this.config = {
|
|
120
|
+
...this.config,
|
|
121
|
+
...config,
|
|
122
|
+
};
|
|
123
|
+
this.saveConfiguration();
|
|
124
|
+
}
|
|
125
|
+
/**
|
|
126
|
+
* Get current configuration
|
|
127
|
+
*/
|
|
128
|
+
getConfiguration() {
|
|
129
|
+
return { ...this.config };
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Set user preference
|
|
133
|
+
*/
|
|
134
|
+
setPreference(preference) {
|
|
135
|
+
this.config.preference = preference;
|
|
136
|
+
this.saveConfiguration();
|
|
137
|
+
}
|
|
138
|
+
/**
|
|
139
|
+
* Calculate friction intensity score (0-1)
|
|
140
|
+
* Higher score = more friction
|
|
141
|
+
*/
|
|
142
|
+
calculateFrictionScore(riskLevel, isDestructive, affectsMultipleFiles, modifiesSecuritySensitiveCode, uncertainty) {
|
|
143
|
+
let score = 0;
|
|
144
|
+
// Risk level contribution (40%)
|
|
145
|
+
const riskScores = { low: 0.1, medium: 0.3, high: 0.6, critical: 1.0 };
|
|
146
|
+
score += riskScores[riskLevel] * 0.4;
|
|
147
|
+
// Destructive operation (20%)
|
|
148
|
+
if (isDestructive)
|
|
149
|
+
score += 0.2;
|
|
150
|
+
// Multi-file impact (15%)
|
|
151
|
+
if (affectsMultipleFiles)
|
|
152
|
+
score += 0.15;
|
|
153
|
+
// Security-sensitive (20%)
|
|
154
|
+
if (modifiesSecuritySensitiveCode)
|
|
155
|
+
score += 0.2;
|
|
156
|
+
// Uncertainty (5%)
|
|
157
|
+
score += Math.min(uncertainty, 1.0) * 0.05;
|
|
158
|
+
// Apply user preference scaling
|
|
159
|
+
const preferenceScale = {
|
|
160
|
+
minimal: 0.7, // 30% reduction
|
|
161
|
+
balanced: 1.0, // No change
|
|
162
|
+
strict: 1.3, // 30% increase
|
|
163
|
+
};
|
|
164
|
+
score *= preferenceScale[this.config.preference];
|
|
165
|
+
return Math.min(score, 1.0); // Cap at 1.0
|
|
166
|
+
}
|
|
167
|
+
// Configuration persistence
|
|
168
|
+
loadConfiguration() {
|
|
169
|
+
try {
|
|
170
|
+
if (existsSync(this.configPath)) {
|
|
171
|
+
const data = JSON.parse(readFileSync(this.configPath, 'utf-8'));
|
|
172
|
+
return {
|
|
173
|
+
preference: data.preference || 'balanced',
|
|
174
|
+
allowAutoProceed: data.allowAutoProceed ?? true,
|
|
175
|
+
customThresholds: data.customThresholds,
|
|
176
|
+
};
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
catch {
|
|
180
|
+
// Use defaults if config doesn't exist or can't be read
|
|
181
|
+
}
|
|
182
|
+
return {
|
|
183
|
+
preference: 'balanced',
|
|
184
|
+
allowAutoProceed: true,
|
|
185
|
+
};
|
|
186
|
+
}
|
|
187
|
+
saveConfiguration() {
|
|
188
|
+
try {
|
|
189
|
+
const configDir = join(this.configPath, '..');
|
|
190
|
+
if (!existsSync(configDir)) {
|
|
191
|
+
mkdirSync(configDir, { recursive: true });
|
|
192
|
+
}
|
|
193
|
+
writeFileSync(this.configPath, JSON.stringify(this.config, null, 2));
|
|
194
|
+
}
|
|
195
|
+
catch {
|
|
196
|
+
// Silently fail - configuration is optional
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
//# sourceMappingURL=proportional-friction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"proportional-friction.js","sourceRoot":"","sources":["../../../src/infrastructure/ux/proportional-friction.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"review-checkpoint.d.ts","sourceRoot":"","sources":["../../../src/infrastructure/ux/review-checkpoint.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"review-checkpoint.d.ts","sourceRoot":"","sources":["../../../src/infrastructure/ux/review-checkpoint.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,MAAM,WAAW,WAAW;IAC1B,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,oBAAoB;IACnC,aAAa,EAAE,WAAW,EAAE,CAAC;IAC7B,kBAAkB,EAAE,OAAO,CAAC;IAC5B,gBAAgB,EAAE,OAAO,CAAC;IAC1B,SAAS,EAAE,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,UAAU,CAAC;IAClD,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED;;GAEG;AACH,wBAAgB,uBAAuB,CAAC,IAAI,EAAE,oBAAoB,GAAG,IAAI,CA8BxE;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG;IAC5E,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC;CACtB,CA4BA;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,WAAW,GAAG,MAAM,CAE9D"}
|
|
@@ -1,66 +1,37 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Review Checkpoint UI
|
|
3
|
-
* Shows summary before applying edits
|
|
3
|
+
* Shows summary before applying edits
|
|
4
|
+
*
|
|
5
|
+
* Phase 1: v0.5.0-alpha.0
|
|
4
6
|
*/
|
|
5
|
-
import { colors, separator
|
|
7
|
+
import { colors, separator } from '../../ui.js';
|
|
6
8
|
/**
|
|
7
9
|
* Display review checkpoint before applying edits
|
|
8
10
|
*/
|
|
9
11
|
export function displayReviewCheckpoint(info) {
|
|
10
|
-
|
|
12
|
+
console.log('\n' + separator('═', 80));
|
|
13
|
+
console.log(colors.bold('📋 Review Checkpoint'));
|
|
11
14
|
console.log(separator('═', 80));
|
|
12
|
-
console.log(colors.bold('📝 Review Changes'));
|
|
13
|
-
console.log(separator('═', 80));
|
|
14
|
-
newline();
|
|
15
15
|
// Files summary
|
|
16
|
-
console.log(colors.bold(
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
],
|
|
34
|
-
[
|
|
35
|
-
'Compilation',
|
|
36
|
-
info.compilationValid ? success('✓ Valid') : error('✗ Invalid'),
|
|
37
|
-
],
|
|
38
|
-
];
|
|
39
|
-
const statusTable = createTable(['Check', 'Status'], statusRows);
|
|
40
|
-
console.log(statusTable.toString());
|
|
41
|
-
newline();
|
|
42
|
-
// Risk level indicator
|
|
43
|
-
const riskColors = {
|
|
44
|
-
low: colors.green,
|
|
45
|
-
medium: colors.yellow,
|
|
46
|
-
high: colors.yellow,
|
|
47
|
-
critical: colors.red,
|
|
48
|
-
};
|
|
49
|
-
const riskLabels = {
|
|
50
|
-
low: 'Low Risk',
|
|
51
|
-
medium: 'Medium Risk',
|
|
52
|
-
high: 'High Risk',
|
|
53
|
-
critical: 'Critical Risk',
|
|
54
|
-
};
|
|
55
|
-
console.log(colors.bold('Risk Level: ') +
|
|
56
|
-
riskColors[info.riskLevel](riskLabels[info.riskLevel]));
|
|
57
|
-
if (info.uncertainty && info.uncertainty > 0.5) {
|
|
58
|
-
const percent = (info.uncertainty * 100).toFixed(0);
|
|
59
|
-
console.log(warning(`⚠️ Uncertainty: ${percent}% - Please verify output carefully`));
|
|
16
|
+
console.log(`\n${colors.bold('Files to modify:')} ${info.filesToModify.length}`);
|
|
17
|
+
info.filesToModify.forEach((file, idx) => {
|
|
18
|
+
console.log(` ${idx + 1}. ${file.filepath}`);
|
|
19
|
+
console.log(` +${file.linesAdded} -${file.linesRemoved} ~${file.linesChanged}`);
|
|
20
|
+
});
|
|
21
|
+
// Validation status
|
|
22
|
+
console.log(`\n${colors.bold('Validation:')}`);
|
|
23
|
+
console.log(` Security scan: ${info.securityScanPassed ? colors.green('✓ Passed') : colors.red('✗ Failed')}`);
|
|
24
|
+
console.log(` Compilation: ${info.compilationValid ? colors.green('✓ Valid') : colors.red('✗ Invalid')}`);
|
|
25
|
+
// Risk level
|
|
26
|
+
const riskColor = info.riskLevel === 'low' ? colors.green :
|
|
27
|
+
info.riskLevel === 'medium' ? colors.yellow :
|
|
28
|
+
info.riskLevel === 'high' ? colors.red :
|
|
29
|
+
colors.red;
|
|
30
|
+
console.log(` Risk level: ${riskColor(info.riskLevel.toUpperCase())}`);
|
|
31
|
+
if (info.uncertainty !== undefined) {
|
|
32
|
+
console.log(` Uncertainty: ${(info.uncertainty * 100).toFixed(1)}%`);
|
|
60
33
|
}
|
|
61
|
-
|
|
62
|
-
console.log(separator('═', 80));
|
|
63
|
-
newline();
|
|
34
|
+
console.log(separator('═', 80) + '\n');
|
|
64
35
|
}
|
|
65
36
|
/**
|
|
66
37
|
* Calculate diff summary from old and new content
|
|
@@ -71,26 +42,18 @@ export function calculateDiffSummary(oldContent, newContent) {
|
|
|
71
42
|
let linesAdded = 0;
|
|
72
43
|
let linesRemoved = 0;
|
|
73
44
|
let linesChanged = 0;
|
|
74
|
-
// Simple line-
|
|
75
|
-
const
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
if (
|
|
45
|
+
// Simple line-by-line comparison
|
|
46
|
+
const maxLen = Math.max(oldLines.length, newLines.length);
|
|
47
|
+
for (let i = 0; i < maxLen; i++) {
|
|
48
|
+
const oldLine = oldLines[i];
|
|
49
|
+
const newLine = newLines[i];
|
|
50
|
+
if (oldLine === undefined) {
|
|
80
51
|
linesAdded++;
|
|
81
52
|
}
|
|
82
|
-
|
|
83
|
-
// Count removed lines (in old but not in new)
|
|
84
|
-
for (const line of oldLines) {
|
|
85
|
-
if (!newSet.has(line)) {
|
|
53
|
+
else if (newLine === undefined) {
|
|
86
54
|
linesRemoved++;
|
|
87
55
|
}
|
|
88
|
-
|
|
89
|
-
// Changed lines = lines that exist in both but at different positions
|
|
90
|
-
// Simplified: count lines that are in both but position differs
|
|
91
|
-
const minLength = Math.min(oldLines.length, newLines.length);
|
|
92
|
-
for (let i = 0; i < minLength; i++) {
|
|
93
|
-
if (oldLines[i] !== newLines[i] && oldSet.has(newLines[i])) {
|
|
56
|
+
else if (oldLine !== newLine) {
|
|
94
57
|
linesChanged++;
|
|
95
58
|
}
|
|
96
59
|
}
|
|
@@ -104,16 +67,6 @@ export function calculateDiffSummary(oldContent, newContent) {
|
|
|
104
67
|
* Format edit summary for display
|
|
105
68
|
*/
|
|
106
69
|
export function formatEditSummary(summary) {
|
|
107
|
-
|
|
108
|
-
if (summary.linesAdded > 0) {
|
|
109
|
-
changes.push(`${summary.linesAdded} added`);
|
|
110
|
-
}
|
|
111
|
-
if (summary.linesRemoved > 0) {
|
|
112
|
-
changes.push(`${summary.linesRemoved} removed`);
|
|
113
|
-
}
|
|
114
|
-
if (summary.linesChanged > 0) {
|
|
115
|
-
changes.push(`${summary.linesChanged} changed`);
|
|
116
|
-
}
|
|
117
|
-
return changes.length > 0 ? changes.join(', ') : 'No changes';
|
|
70
|
+
return `${summary.filepath}: +${summary.linesAdded} -${summary.linesRemoved} ~${summary.linesChanged}`;
|
|
118
71
|
}
|
|
119
72
|
//# sourceMappingURL=review-checkpoint.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"review-checkpoint.js","sourceRoot":"","sources":["../../../src/infrastructure/ux/review-checkpoint.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"review-checkpoint.js","sourceRoot":"","sources":["../../../src/infrastructure/ux/review-checkpoint.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,47 +1,22 @@
|
|
|
1
1
|
/**
|
|
2
|
-
*
|
|
2
|
+
* Staged Feature Introduction
|
|
3
|
+
* Checks feature access and displays availability
|
|
3
4
|
*
|
|
4
|
-
*
|
|
5
|
-
* Task 2.3: Show feature levels and gate features based on user experience
|
|
5
|
+
* Phase 1: v0.5.0-alpha.0
|
|
6
6
|
*/
|
|
7
|
-
import { ProgressiveDisclosure
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
*/
|
|
15
|
-
export declare function displayUserLevel(level: UserLevel): string;
|
|
16
|
-
/**
|
|
17
|
-
* Display feature gating message when feature is not available
|
|
18
|
-
*/
|
|
19
|
-
export declare function displayFeatureGatingMessage(featureId: string, featureName: string, reason: string, suggestedLevel?: UserLevel, currentLevel?: UserLevel): void;
|
|
20
|
-
/**
|
|
21
|
-
* Display feature availability message
|
|
22
|
-
*/
|
|
23
|
-
export declare function displayFeatureAvailability(featureName: string, capability: FeatureCapability, userLevel: UserLevel): void;
|
|
24
|
-
/**
|
|
25
|
-
* Display upgrade notification when user levels up
|
|
26
|
-
*/
|
|
27
|
-
export declare function displayLevelUpNotification(oldLevel: UserLevel, newLevel: UserLevel, newFeatures: Array<{
|
|
28
|
-
name: string;
|
|
29
|
-
capability: FeatureCapability;
|
|
30
|
-
}>): void;
|
|
7
|
+
import type { ProgressiveDisclosure } from './progressive-disclosure.js';
|
|
8
|
+
export interface FeatureAvailability {
|
|
9
|
+
available: boolean;
|
|
10
|
+
message?: string;
|
|
11
|
+
upgradePath?: string;
|
|
12
|
+
shouldContinue?: boolean;
|
|
13
|
+
}
|
|
31
14
|
/**
|
|
32
|
-
* Check
|
|
15
|
+
* Check feature access
|
|
33
16
|
*/
|
|
34
|
-
export declare function checkFeatureAccess(progressiveDisclosure: ProgressiveDisclosure, userId: string,
|
|
35
|
-
available: boolean;
|
|
36
|
-
shouldContinue: boolean;
|
|
37
|
-
};
|
|
17
|
+
export declare function checkFeatureAccess(progressiveDisclosure: ProgressiveDisclosure, userId: string, feature: string): FeatureAvailability;
|
|
38
18
|
/**
|
|
39
|
-
*
|
|
19
|
+
* Display feature availability
|
|
40
20
|
*/
|
|
41
|
-
export declare function
|
|
42
|
-
userLevel: UserLevel;
|
|
43
|
-
totalFeatures: number;
|
|
44
|
-
availableFeatures: number;
|
|
45
|
-
nextLevelFeatures: number;
|
|
46
|
-
};
|
|
21
|
+
export declare function displayFeatureAvailability(featureName: string, capability: string, userLevel?: string): void;
|
|
47
22
|
//# sourceMappingURL=staged-feature-intro.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"staged-feature-intro.d.ts","sourceRoot":"","sources":["../../../src/infrastructure/ux/staged-feature-intro.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,
|
|
1
|
+
{"version":3,"file":"staged-feature-intro.d.ts","sourceRoot":"","sources":["../../../src/infrastructure/ux/staged-feature-intro.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAEzE,MAAM,WAAW,mBAAmB;IAClC,SAAS,EAAE,OAAO,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,cAAc,CAAC,EAAE,OAAO,CAAC;CAC1B;AAED;;GAEG;AACH,wBAAgB,kBAAkB,CAChC,qBAAqB,EAAE,qBAAqB,EAC5C,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,MAAM,GACd,mBAAmB,CAMrB;AAED;;GAEG;AACH,wBAAgB,0BAA0B,CACxC,WAAW,EAAE,MAAM,EACnB,UAAU,EAAE,MAAM,EAClB,SAAS,CAAC,EAAE,MAAM,GACjB,IAAI,CAGN"}
|
|
@@ -1,144 +1,24 @@
|
|
|
1
1
|
/**
|
|
2
|
-
*
|
|
2
|
+
* Staged Feature Introduction
|
|
3
|
+
* Checks feature access and displays availability
|
|
3
4
|
*
|
|
4
|
-
*
|
|
5
|
-
* Task 2.3: Show feature levels and gate features based on user experience
|
|
5
|
+
* Phase 1: v0.5.0-alpha.0
|
|
6
6
|
*/
|
|
7
|
-
import { colors, separator } from '../../ui.js';
|
|
8
7
|
/**
|
|
9
|
-
*
|
|
8
|
+
* Check feature access
|
|
10
9
|
*/
|
|
11
|
-
export function
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
experimental: colors.magenta,
|
|
17
|
-
};
|
|
18
|
-
const levelLabels = {
|
|
19
|
-
basic: 'Basic',
|
|
20
|
-
standard: 'Standard',
|
|
21
|
-
advanced: 'Advanced',
|
|
22
|
-
experimental: 'Experimental',
|
|
23
|
-
};
|
|
24
|
-
const colorFn = levelColors[capability] || colors.gray;
|
|
25
|
-
const label = levelLabels[capability] || capability;
|
|
26
|
-
return colorFn(`[${label}]`);
|
|
27
|
-
}
|
|
28
|
-
/**
|
|
29
|
-
* Display user level indicator
|
|
30
|
-
*/
|
|
31
|
-
export function displayUserLevel(level) {
|
|
32
|
-
const levelColors = {
|
|
33
|
-
beginner: colors.cyan,
|
|
34
|
-
intermediate: colors.blue,
|
|
35
|
-
advanced: colors.yellow,
|
|
36
|
-
expert: colors.magenta,
|
|
10
|
+
export function checkFeatureAccess(progressiveDisclosure, userId, feature) {
|
|
11
|
+
// In alpha, all features are available
|
|
12
|
+
return {
|
|
13
|
+
available: true,
|
|
14
|
+
shouldContinue: true,
|
|
37
15
|
};
|
|
38
|
-
const colorFn = levelColors[level] || colors.gray;
|
|
39
|
-
return colorFn(level.charAt(0).toUpperCase() + level.slice(1));
|
|
40
16
|
}
|
|
41
17
|
/**
|
|
42
|
-
* Display feature
|
|
43
|
-
*/
|
|
44
|
-
export function displayFeatureGatingMessage(featureId, featureName, reason, suggestedLevel, currentLevel) {
|
|
45
|
-
console.log('');
|
|
46
|
-
console.log(separator('═', 80));
|
|
47
|
-
console.log(colors.yellow(`⚠️ Feature Unavailable: ${featureName}`));
|
|
48
|
-
console.log(separator('═', 80));
|
|
49
|
-
console.log('');
|
|
50
|
-
console.log(colors.dim(`Reason: ${reason}`));
|
|
51
|
-
if (suggestedLevel && currentLevel) {
|
|
52
|
-
console.log('');
|
|
53
|
-
console.log(colors.bold('Upgrade Path:'));
|
|
54
|
-
console.log(` Current Level: ${displayUserLevel(currentLevel)}`);
|
|
55
|
-
console.log(` Required Level: ${displayUserLevel(suggestedLevel)}`);
|
|
56
|
-
console.log('');
|
|
57
|
-
console.log(colors.dim('Keep using Codehere to unlock more features!'));
|
|
58
|
-
console.log(colors.dim(` • Use basic features to progress to intermediate`));
|
|
59
|
-
console.log(colors.dim(` • Explore new capabilities to advance your level`));
|
|
60
|
-
}
|
|
61
|
-
console.log('');
|
|
62
|
-
console.log(separator('═', 80));
|
|
63
|
-
console.log('');
|
|
64
|
-
}
|
|
65
|
-
/**
|
|
66
|
-
* Display feature availability message
|
|
18
|
+
* Display feature availability
|
|
67
19
|
*/
|
|
68
20
|
export function displayFeatureAvailability(featureName, capability, userLevel) {
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
// Only show for non-basic features to reduce noise
|
|
72
|
-
if (capability !== 'basic') {
|
|
73
|
-
console.log(colors.dim(`${levelBadge} Feature: ${featureName} (${userBadge} level)`));
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
/**
|
|
77
|
-
* Display upgrade notification when user levels up
|
|
78
|
-
*/
|
|
79
|
-
export function displayLevelUpNotification(oldLevel, newLevel, newFeatures) {
|
|
80
|
-
console.log('');
|
|
81
|
-
console.log(separator('═', 80));
|
|
82
|
-
console.log(colors.green(`🎉 Level Up! You're now ${displayUserLevel(newLevel)}`));
|
|
83
|
-
console.log(separator('═', 80));
|
|
84
|
-
console.log('');
|
|
85
|
-
if (newFeatures.length > 0) {
|
|
86
|
-
console.log(colors.bold('New Features Unlocked:'));
|
|
87
|
-
console.log('');
|
|
88
|
-
newFeatures.forEach(feature => {
|
|
89
|
-
const badge = displayFeatureLevel(feature.capability);
|
|
90
|
-
console.log(` ${badge} ${feature.name}`);
|
|
91
|
-
});
|
|
92
|
-
console.log('');
|
|
93
|
-
}
|
|
94
|
-
console.log(colors.dim('Keep exploring to unlock even more advanced capabilities!'));
|
|
95
|
-
console.log('');
|
|
96
|
-
console.log(separator('═', 80));
|
|
97
|
-
console.log('');
|
|
98
|
-
}
|
|
99
|
-
/**
|
|
100
|
-
* Check if feature is available and show appropriate message
|
|
101
|
-
*/
|
|
102
|
-
export function checkFeatureAccess(progressiveDisclosure, userId, featureId) {
|
|
103
|
-
const check = progressiveDisclosure.shouldShowFeature(userId, featureId);
|
|
104
|
-
if (!check.show) {
|
|
105
|
-
const profile = progressiveDisclosure.getUserProfile(userId);
|
|
106
|
-
// Get feature from available features to find name
|
|
107
|
-
const availableFeatures = progressiveDisclosure.getAvailableFeatures(userId);
|
|
108
|
-
const allFeatures = [...availableFeatures];
|
|
109
|
-
const unavailableFeatures = progressiveDisclosure.getNextSuggestedFeatures(userId, 100);
|
|
110
|
-
const feature = [...allFeatures, ...unavailableFeatures].find(f => f.featureId === featureId);
|
|
111
|
-
if (feature) {
|
|
112
|
-
displayFeatureGatingMessage(featureId, feature.featureName, check.reason || 'Feature not available', check.suggestedLevel, profile.level);
|
|
113
|
-
}
|
|
114
|
-
else {
|
|
115
|
-
// Fallback if feature not found
|
|
116
|
-
displayFeatureGatingMessage(featureId, featureId.replace(/-/g, ' ').replace(/\b\w/g, l => l.toUpperCase()), check.reason || 'Feature not available', check.suggestedLevel, profile.level);
|
|
117
|
-
}
|
|
118
|
-
return { available: false, shouldContinue: false };
|
|
119
|
-
}
|
|
120
|
-
return { available: true, shouldContinue: true };
|
|
121
|
-
}
|
|
122
|
-
/**
|
|
123
|
-
* Get features summary for user
|
|
124
|
-
*/
|
|
125
|
-
export function getFeaturesSummary(progressiveDisclosure, userId) {
|
|
126
|
-
const profile = progressiveDisclosure.getUserProfile(userId);
|
|
127
|
-
const available = progressiveDisclosure.getAvailableFeatures(userId);
|
|
128
|
-
const allFeatures = Array.from(progressiveDisclosure.featureRegistry?.values() || []);
|
|
129
|
-
// Count features for next level
|
|
130
|
-
const levelOrder = ['beginner', 'intermediate', 'advanced', 'expert'];
|
|
131
|
-
const currentIndex = levelOrder.indexOf(profile.level);
|
|
132
|
-
const nextLevel = currentIndex < levelOrder.length - 1 ? levelOrder[currentIndex + 1] : null;
|
|
133
|
-
let nextLevelFeatures = 0;
|
|
134
|
-
if (nextLevel) {
|
|
135
|
-
nextLevelFeatures = allFeatures.filter((f) => f.requiredLevel === nextLevel).length;
|
|
136
|
-
}
|
|
137
|
-
return {
|
|
138
|
-
userLevel: profile.level,
|
|
139
|
-
totalFeatures: allFeatures.length,
|
|
140
|
-
availableFeatures: available.length,
|
|
141
|
-
nextLevelFeatures,
|
|
142
|
-
};
|
|
21
|
+
// In alpha, no-op
|
|
22
|
+
// Can be enhanced later to show feature introductions
|
|
143
23
|
}
|
|
144
24
|
//# sourceMappingURL=staged-feature-intro.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"staged-feature-intro.js","sourceRoot":"","sources":["../../../src/infrastructure/ux/staged-feature-intro.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;
|
|
1
|
+
{"version":3,"file":"staged-feature-intro.js","sourceRoot":"","sources":["../../../src/infrastructure/ux/staged-feature-intro.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAYH;;GAEG;AACH,MAAM,UAAU,kBAAkB,CAChC,qBAA4C,EAC5C,MAAc,EACd,OAAe;IAEf,uCAAuC;IACvC,OAAO;QACL,SAAS,EAAE,IAAI;QACf,cAAc,EAAE,IAAI;KACrB,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,0BAA0B,CACxC,WAAmB,EACnB,UAAkB,EAClB,SAAkB;IAElB,kBAAkB;IAClB,sDAAsD;AACxD,CAAC"}
|