@guidemode/session-processing 0.1.43
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +108 -0
- package/dist/cjs/ai-models/base/index.d.ts +4 -0
- package/dist/cjs/ai-models/base/index.d.ts.map +1 -0
- package/dist/cjs/ai-models/base/index.js +8 -0
- package/dist/cjs/ai-models/base/index.js.map +1 -0
- package/dist/cjs/ai-models/base/model-adapter.d.ts +47 -0
- package/dist/cjs/ai-models/base/model-adapter.d.ts.map +1 -0
- package/dist/cjs/ai-models/base/model-adapter.js +79 -0
- package/dist/cjs/ai-models/base/model-adapter.js.map +1 -0
- package/dist/cjs/ai-models/base/model-task.d.ts +35 -0
- package/dist/cjs/ai-models/base/model-task.d.ts.map +1 -0
- package/dist/cjs/ai-models/base/model-task.js +40 -0
- package/dist/cjs/ai-models/base/model-task.js.map +1 -0
- package/dist/cjs/ai-models/base/types.d.ts +78 -0
- package/dist/cjs/ai-models/base/types.d.ts.map +1 -0
- package/dist/cjs/ai-models/base/types.js +3 -0
- package/dist/cjs/ai-models/base/types.js.map +1 -0
- package/dist/cjs/ai-models/index.d.ts +9 -0
- package/dist/cjs/ai-models/index.d.ts.map +1 -0
- package/dist/cjs/ai-models/index.js +38 -0
- package/dist/cjs/ai-models/index.js.map +1 -0
- package/dist/cjs/ai-models/providers/claude/client.d.ts +122 -0
- package/dist/cjs/ai-models/providers/claude/client.d.ts.map +1 -0
- package/dist/cjs/ai-models/providers/claude/client.js +140 -0
- package/dist/cjs/ai-models/providers/claude/client.js.map +1 -0
- package/dist/cjs/ai-models/providers/claude/index.d.ts +38 -0
- package/dist/cjs/ai-models/providers/claude/index.d.ts.map +1 -0
- package/dist/cjs/ai-models/providers/claude/index.js +144 -0
- package/dist/cjs/ai-models/providers/claude/index.js.map +1 -0
- package/dist/cjs/ai-models/providers/claude/tasks/index.d.ts +5 -0
- package/dist/cjs/ai-models/providers/claude/tasks/index.d.ts.map +1 -0
- package/dist/cjs/ai-models/providers/claude/tasks/index.js +21 -0
- package/dist/cjs/ai-models/providers/claude/tasks/index.js.map +1 -0
- package/dist/cjs/ai-models/providers/claude/tasks/intent-extraction.d.ts +27 -0
- package/dist/cjs/ai-models/providers/claude/tasks/intent-extraction.d.ts.map +1 -0
- package/dist/cjs/ai-models/providers/claude/tasks/intent-extraction.js +145 -0
- package/dist/cjs/ai-models/providers/claude/tasks/intent-extraction.js.map +1 -0
- package/dist/cjs/ai-models/providers/claude/tasks/quality-assessment.d.ts +31 -0
- package/dist/cjs/ai-models/providers/claude/tasks/quality-assessment.d.ts.map +1 -0
- package/dist/cjs/ai-models/providers/claude/tasks/quality-assessment.js +160 -0
- package/dist/cjs/ai-models/providers/claude/tasks/quality-assessment.js.map +1 -0
- package/dist/cjs/ai-models/providers/claude/tasks/session-phase-analysis.d.ts +67 -0
- package/dist/cjs/ai-models/providers/claude/tasks/session-phase-analysis.d.ts.map +1 -0
- package/dist/cjs/ai-models/providers/claude/tasks/session-phase-analysis.js +279 -0
- package/dist/cjs/ai-models/providers/claude/tasks/session-phase-analysis.js.map +1 -0
- package/dist/cjs/ai-models/providers/claude/tasks/session-summary.d.ts +26 -0
- package/dist/cjs/ai-models/providers/claude/tasks/session-summary.d.ts.map +1 -0
- package/dist/cjs/ai-models/providers/claude/tasks/session-summary.js +178 -0
- package/dist/cjs/ai-models/providers/claude/tasks/session-summary.js.map +1 -0
- package/dist/cjs/ai-models/providers/gemini/client.d.ts +127 -0
- package/dist/cjs/ai-models/providers/gemini/client.d.ts.map +1 -0
- package/dist/cjs/ai-models/providers/gemini/client.js +211 -0
- package/dist/cjs/ai-models/providers/gemini/client.js.map +1 -0
- package/dist/cjs/ai-models/providers/gemini/index.d.ts +38 -0
- package/dist/cjs/ai-models/providers/gemini/index.d.ts.map +1 -0
- package/dist/cjs/ai-models/providers/gemini/index.js +144 -0
- package/dist/cjs/ai-models/providers/gemini/index.js.map +1 -0
- package/dist/cjs/ai-models/providers/gemini/tasks/index.d.ts +2 -0
- package/dist/cjs/ai-models/providers/gemini/tasks/index.d.ts.map +1 -0
- package/dist/cjs/ai-models/providers/gemini/tasks/index.js +11 -0
- package/dist/cjs/ai-models/providers/gemini/tasks/index.js.map +1 -0
- package/dist/cjs/ai-models/providers/index.d.ts +5 -0
- package/dist/cjs/ai-models/providers/index.d.ts.map +1 -0
- package/dist/cjs/ai-models/providers/index.js +26 -0
- package/dist/cjs/ai-models/providers/index.js.map +1 -0
- package/dist/cjs/ai-models/providers/openai/client.d.ts +120 -0
- package/dist/cjs/ai-models/providers/openai/client.d.ts.map +1 -0
- package/dist/cjs/ai-models/providers/openai/client.js +195 -0
- package/dist/cjs/ai-models/providers/openai/client.js.map +1 -0
- package/dist/cjs/ai-models/providers/openai/index.d.ts +38 -0
- package/dist/cjs/ai-models/providers/openai/index.d.ts.map +1 -0
- package/dist/cjs/ai-models/providers/openai/index.js +144 -0
- package/dist/cjs/ai-models/providers/openai/index.js.map +1 -0
- package/dist/cjs/ai-models/providers/openai/tasks/index.d.ts +5 -0
- package/dist/cjs/ai-models/providers/openai/tasks/index.d.ts.map +1 -0
- package/dist/cjs/ai-models/providers/openai/tasks/index.js +6 -0
- package/dist/cjs/ai-models/providers/openai/tasks/index.js.map +1 -0
- package/dist/cjs/index.d.ts +7 -0
- package/dist/cjs/index.d.ts.map +1 -0
- package/dist/cjs/index.js +49 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/package.json +1 -0
- package/dist/cjs/parsers/base/BaseParser.d.ts +67 -0
- package/dist/cjs/parsers/base/BaseParser.d.ts.map +1 -0
- package/dist/cjs/parsers/base/BaseParser.js +205 -0
- package/dist/cjs/parsers/base/BaseParser.js.map +1 -0
- package/dist/cjs/parsers/base/index.d.ts +3 -0
- package/dist/cjs/parsers/base/index.d.ts.map +1 -0
- package/dist/cjs/parsers/base/index.js +6 -0
- package/dist/cjs/parsers/base/index.js.map +1 -0
- package/dist/cjs/parsers/base/types.d.ts +112 -0
- package/dist/cjs/parsers/base/types.d.ts.map +1 -0
- package/dist/cjs/parsers/base/types.js +9 -0
- package/dist/cjs/parsers/base/types.js.map +1 -0
- package/dist/cjs/parsers/canonical/index.d.ts +8 -0
- package/dist/cjs/parsers/canonical/index.d.ts.map +1 -0
- package/dist/cjs/parsers/canonical/index.js +11 -0
- package/dist/cjs/parsers/canonical/index.js.map +1 -0
- package/dist/cjs/parsers/canonical/parser.d.ts +60 -0
- package/dist/cjs/parsers/canonical/parser.d.ts.map +1 -0
- package/dist/cjs/parsers/canonical/parser.js +423 -0
- package/dist/cjs/parsers/canonical/parser.js.map +1 -0
- package/dist/cjs/parsers/canonical/types.d.ts +99 -0
- package/dist/cjs/parsers/canonical/types.d.ts.map +1 -0
- package/dist/cjs/parsers/canonical/types.js +9 -0
- package/dist/cjs/parsers/canonical/types.js.map +1 -0
- package/dist/cjs/parsers/index.d.ts +13 -0
- package/dist/cjs/parsers/index.d.ts.map +1 -0
- package/dist/cjs/parsers/index.js +21 -0
- package/dist/cjs/parsers/index.js.map +1 -0
- package/dist/cjs/parsers/registry.d.ts +34 -0
- package/dist/cjs/parsers/registry.d.ts.map +1 -0
- package/dist/cjs/parsers/registry.js +89 -0
- package/dist/cjs/parsers/registry.js.map +1 -0
- package/dist/cjs/processors/base/git-diff-processor.d.ts +38 -0
- package/dist/cjs/processors/base/git-diff-processor.d.ts.map +1 -0
- package/dist/cjs/processors/base/git-diff-processor.js +131 -0
- package/dist/cjs/processors/base/git-diff-processor.js.map +1 -0
- package/dist/cjs/processors/base/index.d.ts +5 -0
- package/dist/cjs/processors/base/index.d.ts.map +1 -0
- package/dist/cjs/processors/base/index.js +10 -0
- package/dist/cjs/processors/base/index.js.map +1 -0
- package/dist/cjs/processors/base/metric-processor.d.ts +42 -0
- package/dist/cjs/processors/base/metric-processor.d.ts.map +1 -0
- package/dist/cjs/processors/base/metric-processor.js +83 -0
- package/dist/cjs/processors/base/metric-processor.js.map +1 -0
- package/dist/cjs/processors/base/provider-processor.d.ts +45 -0
- package/dist/cjs/processors/base/provider-processor.d.ts.map +1 -0
- package/dist/cjs/processors/base/provider-processor.js +109 -0
- package/dist/cjs/processors/base/provider-processor.js.map +1 -0
- package/dist/cjs/processors/base/types.d.ts +2 -0
- package/dist/cjs/processors/base/types.d.ts.map +1 -0
- package/dist/cjs/processors/base/types.js +3 -0
- package/dist/cjs/processors/base/types.js.map +1 -0
- package/dist/cjs/processors/canonical/index.d.ts +24 -0
- package/dist/cjs/processors/canonical/index.d.ts.map +1 -0
- package/dist/cjs/processors/canonical/index.js +49 -0
- package/dist/cjs/processors/canonical/index.js.map +1 -0
- package/dist/cjs/processors/canonical/metrics/context.d.ts +38 -0
- package/dist/cjs/processors/canonical/metrics/context.d.ts.map +1 -0
- package/dist/cjs/processors/canonical/metrics/context.js +160 -0
- package/dist/cjs/processors/canonical/metrics/context.js.map +1 -0
- package/dist/cjs/processors/canonical/metrics/engagement.d.ts +32 -0
- package/dist/cjs/processors/canonical/metrics/engagement.d.ts.map +1 -0
- package/dist/cjs/processors/canonical/metrics/engagement.js +121 -0
- package/dist/cjs/processors/canonical/metrics/engagement.js.map +1 -0
- package/dist/cjs/processors/canonical/metrics/error.d.ts +48 -0
- package/dist/cjs/processors/canonical/metrics/error.d.ts.map +1 -0
- package/dist/cjs/processors/canonical/metrics/error.js +206 -0
- package/dist/cjs/processors/canonical/metrics/error.js.map +1 -0
- package/dist/cjs/processors/canonical/metrics/performance.d.ts +24 -0
- package/dist/cjs/processors/canonical/metrics/performance.d.ts.map +1 -0
- package/dist/cjs/processors/canonical/metrics/performance.js +74 -0
- package/dist/cjs/processors/canonical/metrics/performance.js.map +1 -0
- package/dist/cjs/processors/canonical/metrics/quality.d.ts +52 -0
- package/dist/cjs/processors/canonical/metrics/quality.d.ts.map +1 -0
- package/dist/cjs/processors/canonical/metrics/quality.js +283 -0
- package/dist/cjs/processors/canonical/metrics/quality.js.map +1 -0
- package/dist/cjs/processors/canonical/metrics/usage.d.ts +64 -0
- package/dist/cjs/processors/canonical/metrics/usage.d.ts.map +1 -0
- package/dist/cjs/processors/canonical/metrics/usage.js +327 -0
- package/dist/cjs/processors/canonical/metrics/usage.js.map +1 -0
- package/dist/cjs/processors/index.d.ts +10 -0
- package/dist/cjs/processors/index.d.ts.map +1 -0
- package/dist/cjs/processors/index.js +46 -0
- package/dist/cjs/processors/index.js.map +1 -0
- package/dist/cjs/processors/providers/claude-code/index.d.ts +39 -0
- package/dist/cjs/processors/providers/claude-code/index.d.ts.map +1 -0
- package/dist/cjs/processors/providers/claude-code/index.js +199 -0
- package/dist/cjs/processors/providers/claude-code/index.js.map +1 -0
- package/dist/cjs/processors/providers/codex/index.d.ts +11 -0
- package/dist/cjs/processors/providers/codex/index.d.ts.map +1 -0
- package/dist/cjs/processors/providers/codex/index.js +34 -0
- package/dist/cjs/processors/providers/codex/index.js.map +1 -0
- package/dist/cjs/processors/providers/cursor/index.d.ts +16 -0
- package/dist/cjs/processors/providers/cursor/index.d.ts.map +1 -0
- package/dist/cjs/processors/providers/cursor/index.js +95 -0
- package/dist/cjs/processors/providers/cursor/index.js.map +1 -0
- package/dist/cjs/processors/providers/gemini/index.d.ts +16 -0
- package/dist/cjs/processors/providers/gemini/index.d.ts.map +1 -0
- package/dist/cjs/processors/providers/gemini/index.js +111 -0
- package/dist/cjs/processors/providers/gemini/index.js.map +1 -0
- package/dist/cjs/processors/providers/github-copilot/index.d.ts +11 -0
- package/dist/cjs/processors/providers/github-copilot/index.d.ts.map +1 -0
- package/dist/cjs/processors/providers/github-copilot/index.js +34 -0
- package/dist/cjs/processors/providers/github-copilot/index.js.map +1 -0
- package/dist/cjs/processors/providers/opencode/index.d.ts +11 -0
- package/dist/cjs/processors/providers/opencode/index.d.ts.map +1 -0
- package/dist/cjs/processors/providers/opencode/index.js +34 -0
- package/dist/cjs/processors/providers/opencode/index.js.map +1 -0
- package/dist/cjs/processors/registry.d.ts +95 -0
- package/dist/cjs/processors/registry.d.ts.map +1 -0
- package/dist/cjs/processors/registry.js +214 -0
- package/dist/cjs/processors/registry.js.map +1 -0
- package/dist/cjs/ui/components/DateFilter.d.ts +19 -0
- package/dist/cjs/ui/components/DateFilter.d.ts.map +1 -0
- package/dist/cjs/ui/components/DateFilter.js +81 -0
- package/dist/cjs/ui/components/DateFilter.js.map +1 -0
- package/dist/cjs/ui/components/QuickRatingPopover.d.ts +17 -0
- package/dist/cjs/ui/components/QuickRatingPopover.d.ts.map +1 -0
- package/dist/cjs/ui/components/QuickRatingPopover.js +58 -0
- package/dist/cjs/ui/components/QuickRatingPopover.js.map +1 -0
- package/dist/cjs/ui/components/RatingBadge.d.ts +17 -0
- package/dist/cjs/ui/components/RatingBadge.d.ts.map +1 -0
- package/dist/cjs/ui/components/RatingBadge.js +122 -0
- package/dist/cjs/ui/components/RatingBadge.js.map +1 -0
- package/dist/cjs/ui/components/ScrollToTopButton.d.ts +17 -0
- package/dist/cjs/ui/components/ScrollToTopButton.d.ts.map +1 -0
- package/dist/cjs/ui/components/ScrollToTopButton.js +63 -0
- package/dist/cjs/ui/components/ScrollToTopButton.js.map +1 -0
- package/dist/cjs/ui/components/SessionCard.d.ts +60 -0
- package/dist/cjs/ui/components/SessionCard.d.ts.map +1 -0
- package/dist/cjs/ui/components/SessionCard.js +252 -0
- package/dist/cjs/ui/components/SessionCard.js.map +1 -0
- package/dist/cjs/ui/components/SessionDetailHeader.d.ts +57 -0
- package/dist/cjs/ui/components/SessionDetailHeader.d.ts.map +1 -0
- package/dist/cjs/ui/components/SessionDetailHeader.js +100 -0
- package/dist/cjs/ui/components/SessionDetailHeader.js.map +1 -0
- package/dist/cjs/ui/components/SessionTodosTab.d.ts +9 -0
- package/dist/cjs/ui/components/SessionTodosTab.d.ts.map +1 -0
- package/dist/cjs/ui/components/SessionTodosTab.js +69 -0
- package/dist/cjs/ui/components/SessionTodosTab.js.map +1 -0
- package/dist/cjs/ui/components/TokenUsageChart.d.ts +20 -0
- package/dist/cjs/ui/components/TokenUsageChart.d.ts.map +1 -0
- package/dist/cjs/ui/components/TokenUsageChart.js +126 -0
- package/dist/cjs/ui/components/TokenUsageChart.js.map +1 -0
- package/dist/cjs/ui/components/assessment/AssessmentModal.d.ts +3 -0
- package/dist/cjs/ui/components/assessment/AssessmentModal.d.ts.map +1 -0
- package/dist/cjs/ui/components/assessment/AssessmentModal.js +144 -0
- package/dist/cjs/ui/components/assessment/AssessmentModal.js.map +1 -0
- package/dist/cjs/ui/components/assessment/ChoiceResponse.d.ts +9 -0
- package/dist/cjs/ui/components/assessment/ChoiceResponse.d.ts.map +1 -0
- package/dist/cjs/ui/components/assessment/ChoiceResponse.js +30 -0
- package/dist/cjs/ui/components/assessment/ChoiceResponse.js.map +1 -0
- package/dist/cjs/ui/components/assessment/LikertScale.d.ts +3 -0
- package/dist/cjs/ui/components/assessment/LikertScale.d.ts.map +1 -0
- package/dist/cjs/ui/components/assessment/LikertScale.js +76 -0
- package/dist/cjs/ui/components/assessment/LikertScale.js.map +1 -0
- package/dist/cjs/ui/components/assessment/ProgressBar.d.ts +3 -0
- package/dist/cjs/ui/components/assessment/ProgressBar.d.ts.map +1 -0
- package/dist/cjs/ui/components/assessment/ProgressBar.js +9 -0
- package/dist/cjs/ui/components/assessment/ProgressBar.js.map +1 -0
- package/dist/cjs/ui/components/assessment/QuestionCard.d.ts +3 -0
- package/dist/cjs/ui/components/assessment/QuestionCard.d.ts.map +1 -0
- package/dist/cjs/ui/components/assessment/QuestionCard.js +127 -0
- package/dist/cjs/ui/components/assessment/QuestionCard.js.map +1 -0
- package/dist/cjs/ui/components/assessment/TextResponse.d.ts +3 -0
- package/dist/cjs/ui/components/assessment/TextResponse.d.ts.map +1 -0
- package/dist/cjs/ui/components/assessment/TextResponse.js +8 -0
- package/dist/cjs/ui/components/assessment/TextResponse.js.map +1 -0
- package/dist/cjs/ui/components/assessment/VersionSelector.d.ts +7 -0
- package/dist/cjs/ui/components/assessment/VersionSelector.d.ts.map +1 -0
- package/dist/cjs/ui/components/assessment/VersionSelector.js +71 -0
- package/dist/cjs/ui/components/assessment/VersionSelector.js.map +1 -0
- package/dist/cjs/ui/components/assessment/index.d.ts +9 -0
- package/dist/cjs/ui/components/assessment/index.d.ts.map +1 -0
- package/dist/cjs/ui/components/assessment/index.js +19 -0
- package/dist/cjs/ui/components/assessment/index.js.map +1 -0
- package/dist/cjs/ui/components/assessment/types.d.ts +58 -0
- package/dist/cjs/ui/components/assessment/types.d.ts.map +1 -0
- package/dist/cjs/ui/components/assessment/types.js +3 -0
- package/dist/cjs/ui/components/assessment/types.js.map +1 -0
- package/dist/cjs/ui/components/index.d.ts +39 -0
- package/dist/cjs/ui/components/index.d.ts.map +1 -0
- package/dist/cjs/ui/components/index.js +90 -0
- package/dist/cjs/ui/components/index.js.map +1 -0
- package/dist/cjs/ui/components/metrics/AssessmentSection.d.ts +27 -0
- package/dist/cjs/ui/components/metrics/AssessmentSection.d.ts.map +1 -0
- package/dist/cjs/ui/components/metrics/AssessmentSection.js +79 -0
- package/dist/cjs/ui/components/metrics/AssessmentSection.js.map +1 -0
- package/dist/cjs/ui/components/metrics/MetricCard.d.ts +20 -0
- package/dist/cjs/ui/components/metrics/MetricCard.d.ts.map +1 -0
- package/dist/cjs/ui/components/metrics/MetricCard.js +80 -0
- package/dist/cjs/ui/components/metrics/MetricCard.js.map +1 -0
- package/dist/cjs/ui/components/metrics/MetricSection.d.ts +12 -0
- package/dist/cjs/ui/components/metrics/MetricSection.d.ts.map +1 -0
- package/dist/cjs/ui/components/metrics/MetricSection.js +8 -0
- package/dist/cjs/ui/components/metrics/MetricSection.js.map +1 -0
- package/dist/cjs/ui/components/metrics/MetricsOverview.d.ts +89 -0
- package/dist/cjs/ui/components/metrics/MetricsOverview.d.ts.map +1 -0
- package/dist/cjs/ui/components/metrics/MetricsOverview.js +29 -0
- package/dist/cjs/ui/components/metrics/MetricsOverview.js.map +1 -0
- package/dist/cjs/ui/components/metrics/metricThresholds.d.ts +40 -0
- package/dist/cjs/ui/components/metrics/metricThresholds.d.ts.map +1 -0
- package/dist/cjs/ui/components/metrics/metricThresholds.js +208 -0
- package/dist/cjs/ui/components/metrics/metricThresholds.js.map +1 -0
- package/dist/cjs/ui/components/metrics/sections/AIAssessmentSection.d.ts +12 -0
- package/dist/cjs/ui/components/metrics/sections/AIAssessmentSection.d.ts.map +1 -0
- package/dist/cjs/ui/components/metrics/sections/AIAssessmentSection.js +31 -0
- package/dist/cjs/ui/components/metrics/sections/AIAssessmentSection.js.map +1 -0
- package/dist/cjs/ui/components/metrics/sections/ContextMetricsSection.d.ts +10 -0
- package/dist/cjs/ui/components/metrics/sections/ContextMetricsSection.d.ts.map +1 -0
- package/dist/cjs/ui/components/metrics/sections/ContextMetricsSection.js +21 -0
- package/dist/cjs/ui/components/metrics/sections/ContextMetricsSection.js.map +1 -0
- package/dist/cjs/ui/components/metrics/sections/EngagementMetricsSection.d.ts +10 -0
- package/dist/cjs/ui/components/metrics/sections/EngagementMetricsSection.d.ts.map +1 -0
- package/dist/cjs/ui/components/metrics/sections/EngagementMetricsSection.js +21 -0
- package/dist/cjs/ui/components/metrics/sections/EngagementMetricsSection.js.map +1 -0
- package/dist/cjs/ui/components/metrics/sections/ErrorMetricsSection.d.ts +10 -0
- package/dist/cjs/ui/components/metrics/sections/ErrorMetricsSection.d.ts.map +1 -0
- package/dist/cjs/ui/components/metrics/sections/ErrorMetricsSection.js +17 -0
- package/dist/cjs/ui/components/metrics/sections/ErrorMetricsSection.js.map +1 -0
- package/dist/cjs/ui/components/metrics/sections/GitDiffMetricsSection.d.ts +10 -0
- package/dist/cjs/ui/components/metrics/sections/GitDiffMetricsSection.d.ts.map +1 -0
- package/dist/cjs/ui/components/metrics/sections/GitDiffMetricsSection.js +22 -0
- package/dist/cjs/ui/components/metrics/sections/GitDiffMetricsSection.js.map +1 -0
- package/dist/cjs/ui/components/metrics/sections/PerformanceMetricsSection.d.ts +10 -0
- package/dist/cjs/ui/components/metrics/sections/PerformanceMetricsSection.d.ts.map +1 -0
- package/dist/cjs/ui/components/metrics/sections/PerformanceMetricsSection.js +21 -0
- package/dist/cjs/ui/components/metrics/sections/PerformanceMetricsSection.js.map +1 -0
- package/dist/cjs/ui/components/metrics/sections/QualityMetricsSection.d.ts +10 -0
- package/dist/cjs/ui/components/metrics/sections/QualityMetricsSection.d.ts.map +1 -0
- package/dist/cjs/ui/components/metrics/sections/QualityMetricsSection.js +26 -0
- package/dist/cjs/ui/components/metrics/sections/QualityMetricsSection.js.map +1 -0
- package/dist/cjs/ui/components/metrics/sections/UsageMetricsSection.d.ts +10 -0
- package/dist/cjs/ui/components/metrics/sections/UsageMetricsSection.d.ts.map +1 -0
- package/dist/cjs/ui/components/metrics/sections/UsageMetricsSection.js +17 -0
- package/dist/cjs/ui/components/metrics/sections/UsageMetricsSection.js.map +1 -0
- package/dist/cjs/ui/components/phase/PhaseBlock.d.ts +19 -0
- package/dist/cjs/ui/components/phase/PhaseBlock.d.ts.map +1 -0
- package/dist/cjs/ui/components/phase/PhaseBlock.js +16 -0
- package/dist/cjs/ui/components/phase/PhaseBlock.js.map +1 -0
- package/dist/cjs/ui/components/phase/PhaseHeader.d.ts +10 -0
- package/dist/cjs/ui/components/phase/PhaseHeader.d.ts.map +1 -0
- package/dist/cjs/ui/components/phase/PhaseHeader.js +15 -0
- package/dist/cjs/ui/components/phase/PhaseHeader.js.map +1 -0
- package/dist/cjs/ui/components/phase/PhaseIcon.d.ts +25 -0
- package/dist/cjs/ui/components/phase/PhaseIcon.d.ts.map +1 -0
- package/dist/cjs/ui/components/phase/PhaseIcon.js +77 -0
- package/dist/cjs/ui/components/phase/PhaseIcon.js.map +1 -0
- package/dist/cjs/ui/components/phase/PhaseStats.d.ts +13 -0
- package/dist/cjs/ui/components/phase/PhaseStats.d.ts.map +1 -0
- package/dist/cjs/ui/components/phase/PhaseStats.js +27 -0
- package/dist/cjs/ui/components/phase/PhaseStats.js.map +1 -0
- package/dist/cjs/ui/components/phase/PhaseSummary.d.ts +9 -0
- package/dist/cjs/ui/components/phase/PhaseSummary.d.ts.map +1 -0
- package/dist/cjs/ui/components/phase/PhaseSummary.js +8 -0
- package/dist/cjs/ui/components/phase/PhaseSummary.js.map +1 -0
- package/dist/cjs/ui/components/phase/PhaseTimeline.d.ts +17 -0
- package/dist/cjs/ui/components/phase/PhaseTimeline.d.ts.map +1 -0
- package/dist/cjs/ui/components/phase/PhaseTimeline.js +25 -0
- package/dist/cjs/ui/components/phase/PhaseTimeline.js.map +1 -0
- package/dist/cjs/ui/components/phase/index.d.ts +12 -0
- package/dist/cjs/ui/components/phase/index.d.ts.map +1 -0
- package/dist/cjs/ui/components/phase/index.js +22 -0
- package/dist/cjs/ui/components/phase/index.js.map +1 -0
- package/dist/cjs/ui/components/timeline/ContentRenderer.d.ts +10 -0
- package/dist/cjs/ui/components/timeline/ContentRenderer.d.ts.map +1 -0
- package/dist/cjs/ui/components/timeline/ContentRenderer.js +76 -0
- package/dist/cjs/ui/components/timeline/ContentRenderer.js.map +1 -0
- package/dist/cjs/ui/components/timeline/DebugModal.d.ts +14 -0
- package/dist/cjs/ui/components/timeline/DebugModal.d.ts.map +1 -0
- package/dist/cjs/ui/components/timeline/DebugModal.js +30 -0
- package/dist/cjs/ui/components/timeline/DebugModal.js.map +1 -0
- package/dist/cjs/ui/components/timeline/MessageHeader.d.ts +11 -0
- package/dist/cjs/ui/components/timeline/MessageHeader.d.ts.map +1 -0
- package/dist/cjs/ui/components/timeline/MessageHeader.js +10 -0
- package/dist/cjs/ui/components/timeline/MessageHeader.js.map +1 -0
- package/dist/cjs/ui/components/timeline/TimelineGroup.d.ts +10 -0
- package/dist/cjs/ui/components/timeline/TimelineGroup.d.ts.map +1 -0
- package/dist/cjs/ui/components/timeline/TimelineGroup.js +10 -0
- package/dist/cjs/ui/components/timeline/TimelineGroup.js.map +1 -0
- package/dist/cjs/ui/components/timeline/TimelineMessage.d.ts +12 -0
- package/dist/cjs/ui/components/timeline/TimelineMessage.d.ts.map +1 -0
- package/dist/cjs/ui/components/timeline/TimelineMessage.js +26 -0
- package/dist/cjs/ui/components/timeline/TimelineMessage.js.map +1 -0
- package/dist/cjs/ui/components/timeline/VirtualizedMessageList.d.ts +36 -0
- package/dist/cjs/ui/components/timeline/VirtualizedMessageList.d.ts.map +1 -0
- package/dist/cjs/ui/components/timeline/VirtualizedMessageList.js +93 -0
- package/dist/cjs/ui/components/timeline/VirtualizedMessageList.js.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/CodeBlock.d.ts +10 -0
- package/dist/cjs/ui/components/timeline/blocks/CodeBlock.d.ts.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/CodeBlock.js +17 -0
- package/dist/cjs/ui/components/timeline/blocks/CodeBlock.js.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/ImageBlock.d.ts +10 -0
- package/dist/cjs/ui/components/timeline/blocks/ImageBlock.d.ts.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/ImageBlock.js +8 -0
- package/dist/cjs/ui/components/timeline/blocks/ImageBlock.js.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/JsonBlock.d.ts +10 -0
- package/dist/cjs/ui/components/timeline/blocks/JsonBlock.d.ts.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/JsonBlock.js +14 -0
- package/dist/cjs/ui/components/timeline/blocks/JsonBlock.js.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/SystemReminderBlock.d.ts +16 -0
- package/dist/cjs/ui/components/timeline/blocks/SystemReminderBlock.d.ts.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/SystemReminderBlock.js +93 -0
- package/dist/cjs/ui/components/timeline/blocks/SystemReminderBlock.js.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/TextBlock.d.ts +13 -0
- package/dist/cjs/ui/components/timeline/blocks/TextBlock.d.ts.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/TextBlock.js +191 -0
- package/dist/cjs/ui/components/timeline/blocks/TextBlock.js.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/ThinkingBlock.d.ts +15 -0
- package/dist/cjs/ui/components/timeline/blocks/ThinkingBlock.d.ts.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/ThinkingBlock.js +18 -0
- package/dist/cjs/ui/components/timeline/blocks/ThinkingBlock.js.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/ToolBlock.d.ts +13 -0
- package/dist/cjs/ui/components/timeline/blocks/ToolBlock.d.ts.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/ToolBlock.js +54 -0
- package/dist/cjs/ui/components/timeline/blocks/ToolBlock.js.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/ToolResultBlock.d.ts +12 -0
- package/dist/cjs/ui/components/timeline/blocks/ToolResultBlock.d.ts.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/ToolResultBlock.js +84 -0
- package/dist/cjs/ui/components/timeline/blocks/ToolResultBlock.js.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/index.d.ts +11 -0
- package/dist/cjs/ui/components/timeline/blocks/index.d.ts.map +1 -0
- package/dist/cjs/ui/components/timeline/blocks/index.js +21 -0
- package/dist/cjs/ui/components/timeline/blocks/index.js.map +1 -0
- package/dist/cjs/ui/components/timeline/index.d.ts +10 -0
- package/dist/cjs/ui/components/timeline/index.d.ts.map +1 -0
- package/dist/cjs/ui/components/timeline/index.js +32 -0
- package/dist/cjs/ui/components/timeline/index.js.map +1 -0
- package/dist/cjs/ui/index.d.ts +10 -0
- package/dist/cjs/ui/index.d.ts.map +1 -0
- package/dist/cjs/ui/index.js +37 -0
- package/dist/cjs/ui/index.js.map +1 -0
- package/dist/cjs/ui/utils/extractTokens.d.ts +94 -0
- package/dist/cjs/ui/utils/extractTokens.d.ts.map +1 -0
- package/dist/cjs/ui/utils/extractTokens.js +191 -0
- package/dist/cjs/ui/utils/extractTokens.js.map +1 -0
- package/dist/cjs/ui/utils/markdown.d.ts +65 -0
- package/dist/cjs/ui/utils/markdown.d.ts.map +1 -0
- package/dist/cjs/ui/utils/markdown.js +240 -0
- package/dist/cjs/ui/utils/markdown.js.map +1 -0
- package/dist/cjs/ui/utils/processors/BaseMessageProcessor.d.ts +133 -0
- package/dist/cjs/ui/utils/processors/BaseMessageProcessor.d.ts.map +1 -0
- package/dist/cjs/ui/utils/processors/BaseMessageProcessor.js +550 -0
- package/dist/cjs/ui/utils/processors/BaseMessageProcessor.js.map +1 -0
- package/dist/cjs/ui/utils/processors/CanonicalMessageProcessor.d.ts +81 -0
- package/dist/cjs/ui/utils/processors/CanonicalMessageProcessor.d.ts.map +1 -0
- package/dist/cjs/ui/utils/processors/CanonicalMessageProcessor.js +449 -0
- package/dist/cjs/ui/utils/processors/CanonicalMessageProcessor.js.map +1 -0
- package/dist/cjs/ui/utils/processors/GenericMessageProcessor.d.ts +46 -0
- package/dist/cjs/ui/utils/processors/GenericMessageProcessor.d.ts.map +1 -0
- package/dist/cjs/ui/utils/processors/GenericMessageProcessor.js +176 -0
- package/dist/cjs/ui/utils/processors/GenericMessageProcessor.js.map +1 -0
- package/dist/cjs/ui/utils/processors/ProcessorRegistry.d.ts +33 -0
- package/dist/cjs/ui/utils/processors/ProcessorRegistry.d.ts.map +1 -0
- package/dist/cjs/ui/utils/processors/ProcessorRegistry.js +72 -0
- package/dist/cjs/ui/utils/processors/ProcessorRegistry.js.map +1 -0
- package/dist/cjs/ui/utils/processors/index.d.ts +11 -0
- package/dist/cjs/ui/utils/processors/index.d.ts.map +1 -0
- package/dist/cjs/ui/utils/processors/index.js +18 -0
- package/dist/cjs/ui/utils/processors/index.js.map +1 -0
- package/dist/cjs/ui/utils/sessionTypes.d.ts +2 -0
- package/dist/cjs/ui/utils/sessionTypes.d.ts.map +1 -0
- package/dist/cjs/ui/utils/sessionTypes.js +4 -0
- package/dist/cjs/ui/utils/sessionTypes.js.map +1 -0
- package/dist/cjs/ui/utils/systemReminderParser.d.ts +40 -0
- package/dist/cjs/ui/utils/systemReminderParser.d.ts.map +1 -0
- package/dist/cjs/ui/utils/systemReminderParser.js +112 -0
- package/dist/cjs/ui/utils/systemReminderParser.js.map +1 -0
- package/dist/cjs/ui/utils/timelineTypes.d.ts +201 -0
- package/dist/cjs/ui/utils/timelineTypes.d.ts.map +1 -0
- package/dist/cjs/ui/utils/timelineTypes.js +44 -0
- package/dist/cjs/ui/utils/timelineTypes.js.map +1 -0
- package/dist/cjs/ui/utils/todos/extractTodosClaudeCode.d.ts +9 -0
- package/dist/cjs/ui/utils/todos/extractTodosClaudeCode.d.ts.map +1 -0
- package/dist/cjs/ui/utils/todos/extractTodosClaudeCode.js +43 -0
- package/dist/cjs/ui/utils/todos/extractTodosClaudeCode.js.map +1 -0
- package/dist/cjs/ui/utils/todos/extractTodosCodex.d.ts +29 -0
- package/dist/cjs/ui/utils/todos/extractTodosCodex.d.ts.map +1 -0
- package/dist/cjs/ui/utils/todos/extractTodosCodex.js +164 -0
- package/dist/cjs/ui/utils/todos/extractTodosCodex.js.map +1 -0
- package/dist/cjs/ui/utils/todos/index.d.ts +18 -0
- package/dist/cjs/ui/utils/todos/index.d.ts.map +1 -0
- package/dist/cjs/ui/utils/todos/index.js +54 -0
- package/dist/cjs/ui/utils/todos/index.js.map +1 -0
- package/dist/cjs/ui/utils/todos/todoUtils.d.ts +27 -0
- package/dist/cjs/ui/utils/todos/todoUtils.d.ts.map +1 -0
- package/dist/cjs/ui/utils/todos/todoUtils.js +124 -0
- package/dist/cjs/ui/utils/todos/todoUtils.js.map +1 -0
- package/dist/cjs/ui/utils/todos/types.d.ts +41 -0
- package/dist/cjs/ui/utils/todos/types.d.ts.map +1 -0
- package/dist/cjs/ui/utils/todos/types.js +6 -0
- package/dist/cjs/ui/utils/todos/types.js.map +1 -0
- package/dist/cjs/utils/git-url.d.ts +25 -0
- package/dist/cjs/utils/git-url.d.ts.map +1 -0
- package/dist/cjs/utils/git-url.js +60 -0
- package/dist/cjs/utils/git-url.js.map +1 -0
- package/dist/cjs/utils/index.d.ts +7 -0
- package/dist/cjs/utils/index.d.ts.map +1 -0
- package/dist/cjs/utils/index.js +23 -0
- package/dist/cjs/utils/index.js.map +1 -0
- package/dist/cjs/utils/rating.d.ts +61 -0
- package/dist/cjs/utils/rating.d.ts.map +1 -0
- package/dist/cjs/utils/rating.js +96 -0
- package/dist/cjs/utils/rating.js.map +1 -0
- package/dist/cjs/utils/safe-access.d.ts +43 -0
- package/dist/cjs/utils/safe-access.d.ts.map +1 -0
- package/dist/cjs/utils/safe-access.js +89 -0
- package/dist/cjs/utils/safe-access.js.map +1 -0
- package/dist/cjs/utils/user.d.ts +22 -0
- package/dist/cjs/utils/user.d.ts.map +1 -0
- package/dist/cjs/utils/user.js +39 -0
- package/dist/cjs/utils/user.js.map +1 -0
- package/dist/cjs/validation/index.d.ts +8 -0
- package/dist/cjs/validation/index.d.ts.map +1 -0
- package/dist/cjs/validation/index.js +21 -0
- package/dist/cjs/validation/index.js.map +1 -0
- package/dist/cjs/validation/validator.d.ts +48 -0
- package/dist/cjs/validation/validator.d.ts.map +1 -0
- package/dist/cjs/validation/validator.js +207 -0
- package/dist/cjs/validation/validator.js.map +1 -0
- package/dist/esm/ai-models/base/index.d.ts +4 -0
- package/dist/esm/ai-models/base/index.d.ts.map +1 -0
- package/dist/esm/ai-models/base/index.js +3 -0
- package/dist/esm/ai-models/base/index.js.map +1 -0
- package/dist/esm/ai-models/base/model-adapter.d.ts +47 -0
- package/dist/esm/ai-models/base/model-adapter.d.ts.map +1 -0
- package/dist/esm/ai-models/base/model-adapter.js +76 -0
- package/dist/esm/ai-models/base/model-adapter.js.map +1 -0
- package/dist/esm/ai-models/base/model-task.d.ts +35 -0
- package/dist/esm/ai-models/base/model-task.d.ts.map +1 -0
- package/dist/esm/ai-models/base/model-task.js +36 -0
- package/dist/esm/ai-models/base/model-task.js.map +1 -0
- package/dist/esm/ai-models/base/types.d.ts +78 -0
- package/dist/esm/ai-models/base/types.d.ts.map +1 -0
- package/dist/esm/ai-models/base/types.js +2 -0
- package/dist/esm/ai-models/base/types.js.map +1 -0
- package/dist/esm/ai-models/index.d.ts +9 -0
- package/dist/esm/ai-models/index.d.ts.map +1 -0
- package/dist/esm/ai-models/index.js +11 -0
- package/dist/esm/ai-models/index.js.map +1 -0
- package/dist/esm/ai-models/providers/claude/client.d.ts +122 -0
- package/dist/esm/ai-models/providers/claude/client.d.ts.map +1 -0
- package/dist/esm/ai-models/providers/claude/client.js +142 -0
- package/dist/esm/ai-models/providers/claude/client.js.map +1 -0
- package/dist/esm/ai-models/providers/claude/index.d.ts +38 -0
- package/dist/esm/ai-models/providers/claude/index.d.ts.map +1 -0
- package/dist/esm/ai-models/providers/claude/index.js +141 -0
- package/dist/esm/ai-models/providers/claude/index.js.map +1 -0
- package/dist/esm/ai-models/providers/claude/tasks/index.d.ts +5 -0
- package/dist/esm/ai-models/providers/claude/tasks/index.d.ts.map +1 -0
- package/dist/esm/ai-models/providers/claude/tasks/index.js +5 -0
- package/dist/esm/ai-models/providers/claude/tasks/index.js.map +1 -0
- package/dist/esm/ai-models/providers/claude/tasks/intent-extraction.d.ts +27 -0
- package/dist/esm/ai-models/providers/claude/tasks/intent-extraction.d.ts.map +1 -0
- package/dist/esm/ai-models/providers/claude/tasks/intent-extraction.js +138 -0
- package/dist/esm/ai-models/providers/claude/tasks/intent-extraction.js.map +1 -0
- package/dist/esm/ai-models/providers/claude/tasks/quality-assessment.d.ts +31 -0
- package/dist/esm/ai-models/providers/claude/tasks/quality-assessment.d.ts.map +1 -0
- package/dist/esm/ai-models/providers/claude/tasks/quality-assessment.js +153 -0
- package/dist/esm/ai-models/providers/claude/tasks/quality-assessment.js.map +1 -0
- package/dist/esm/ai-models/providers/claude/tasks/session-phase-analysis.d.ts +67 -0
- package/dist/esm/ai-models/providers/claude/tasks/session-phase-analysis.d.ts.map +1 -0
- package/dist/esm/ai-models/providers/claude/tasks/session-phase-analysis.js +272 -0
- package/dist/esm/ai-models/providers/claude/tasks/session-phase-analysis.js.map +1 -0
- package/dist/esm/ai-models/providers/claude/tasks/session-summary.d.ts +26 -0
- package/dist/esm/ai-models/providers/claude/tasks/session-summary.d.ts.map +1 -0
- package/dist/esm/ai-models/providers/claude/tasks/session-summary.js +171 -0
- package/dist/esm/ai-models/providers/claude/tasks/session-summary.js.map +1 -0
- package/dist/esm/ai-models/providers/gemini/client.d.ts +127 -0
- package/dist/esm/ai-models/providers/gemini/client.d.ts.map +1 -0
- package/dist/esm/ai-models/providers/gemini/client.js +213 -0
- package/dist/esm/ai-models/providers/gemini/client.js.map +1 -0
- package/dist/esm/ai-models/providers/gemini/index.d.ts +38 -0
- package/dist/esm/ai-models/providers/gemini/index.d.ts.map +1 -0
- package/dist/esm/ai-models/providers/gemini/index.js +141 -0
- package/dist/esm/ai-models/providers/gemini/index.js.map +1 -0
- package/dist/esm/ai-models/providers/gemini/tasks/index.d.ts +2 -0
- package/dist/esm/ai-models/providers/gemini/tasks/index.d.ts.map +1 -0
- package/dist/esm/ai-models/providers/gemini/tasks/index.js +4 -0
- package/dist/esm/ai-models/providers/gemini/tasks/index.js.map +1 -0
- package/dist/esm/ai-models/providers/index.d.ts +5 -0
- package/dist/esm/ai-models/providers/index.d.ts.map +1 -0
- package/dist/esm/ai-models/providers/index.js +6 -0
- package/dist/esm/ai-models/providers/index.js.map +1 -0
- package/dist/esm/ai-models/providers/openai/client.d.ts +120 -0
- package/dist/esm/ai-models/providers/openai/client.d.ts.map +1 -0
- package/dist/esm/ai-models/providers/openai/client.js +197 -0
- package/dist/esm/ai-models/providers/openai/client.js.map +1 -0
- package/dist/esm/ai-models/providers/openai/index.d.ts +38 -0
- package/dist/esm/ai-models/providers/openai/index.d.ts.map +1 -0
- package/dist/esm/ai-models/providers/openai/index.js +141 -0
- package/dist/esm/ai-models/providers/openai/index.js.map +1 -0
- package/dist/esm/ai-models/providers/openai/tasks/index.d.ts +5 -0
- package/dist/esm/ai-models/providers/openai/tasks/index.d.ts.map +1 -0
- package/dist/esm/ai-models/providers/openai/tasks/index.js +7 -0
- package/dist/esm/ai-models/providers/openai/tasks/index.js.map +1 -0
- package/dist/esm/index.d.ts +7 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +15 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/parsers/base/BaseParser.d.ts +67 -0
- package/dist/esm/parsers/base/BaseParser.d.ts.map +1 -0
- package/dist/esm/parsers/base/BaseParser.js +201 -0
- package/dist/esm/parsers/base/BaseParser.js.map +1 -0
- package/dist/esm/parsers/base/index.d.ts +3 -0
- package/dist/esm/parsers/base/index.d.ts.map +1 -0
- package/dist/esm/parsers/base/index.js +2 -0
- package/dist/esm/parsers/base/index.js.map +1 -0
- package/dist/esm/parsers/base/types.d.ts +112 -0
- package/dist/esm/parsers/base/types.d.ts.map +1 -0
- package/dist/esm/parsers/base/types.js +8 -0
- package/dist/esm/parsers/base/types.js.map +1 -0
- package/dist/esm/parsers/canonical/index.d.ts +8 -0
- package/dist/esm/parsers/canonical/index.d.ts.map +1 -0
- package/dist/esm/parsers/canonical/index.js +7 -0
- package/dist/esm/parsers/canonical/index.js.map +1 -0
- package/dist/esm/parsers/canonical/parser.d.ts +60 -0
- package/dist/esm/parsers/canonical/parser.d.ts.map +1 -0
- package/dist/esm/parsers/canonical/parser.js +416 -0
- package/dist/esm/parsers/canonical/parser.js.map +1 -0
- package/dist/esm/parsers/canonical/types.d.ts +99 -0
- package/dist/esm/parsers/canonical/types.d.ts.map +1 -0
- package/dist/esm/parsers/canonical/types.js +8 -0
- package/dist/esm/parsers/canonical/types.js.map +1 -0
- package/dist/esm/parsers/index.d.ts +13 -0
- package/dist/esm/parsers/index.d.ts.map +1 -0
- package/dist/esm/parsers/index.js +14 -0
- package/dist/esm/parsers/index.js.map +1 -0
- package/dist/esm/parsers/registry.d.ts +34 -0
- package/dist/esm/parsers/registry.d.ts.map +1 -0
- package/dist/esm/parsers/registry.js +85 -0
- package/dist/esm/parsers/registry.js.map +1 -0
- package/dist/esm/processors/base/git-diff-processor.d.ts +38 -0
- package/dist/esm/processors/base/git-diff-processor.d.ts.map +1 -0
- package/dist/esm/processors/base/git-diff-processor.js +124 -0
- package/dist/esm/processors/base/git-diff-processor.js.map +1 -0
- package/dist/esm/processors/base/index.d.ts +5 -0
- package/dist/esm/processors/base/index.d.ts.map +1 -0
- package/dist/esm/processors/base/index.js +4 -0
- package/dist/esm/processors/base/index.js.map +1 -0
- package/dist/esm/processors/base/metric-processor.d.ts +42 -0
- package/dist/esm/processors/base/metric-processor.d.ts.map +1 -0
- package/dist/esm/processors/base/metric-processor.js +79 -0
- package/dist/esm/processors/base/metric-processor.js.map +1 -0
- package/dist/esm/processors/base/provider-processor.d.ts +45 -0
- package/dist/esm/processors/base/provider-processor.d.ts.map +1 -0
- package/dist/esm/processors/base/provider-processor.js +105 -0
- package/dist/esm/processors/base/provider-processor.js.map +1 -0
- package/dist/esm/processors/base/types.d.ts +2 -0
- package/dist/esm/processors/base/types.d.ts.map +1 -0
- package/dist/esm/processors/base/types.js +2 -0
- package/dist/esm/processors/base/types.js.map +1 -0
- package/dist/esm/processors/canonical/index.d.ts +24 -0
- package/dist/esm/processors/canonical/index.d.ts.map +1 -0
- package/dist/esm/processors/canonical/index.js +42 -0
- package/dist/esm/processors/canonical/index.js.map +1 -0
- package/dist/esm/processors/canonical/metrics/context.d.ts +38 -0
- package/dist/esm/processors/canonical/metrics/context.d.ts.map +1 -0
- package/dist/esm/processors/canonical/metrics/context.js +153 -0
- package/dist/esm/processors/canonical/metrics/context.js.map +1 -0
- package/dist/esm/processors/canonical/metrics/engagement.d.ts +32 -0
- package/dist/esm/processors/canonical/metrics/engagement.d.ts.map +1 -0
- package/dist/esm/processors/canonical/metrics/engagement.js +114 -0
- package/dist/esm/processors/canonical/metrics/engagement.js.map +1 -0
- package/dist/esm/processors/canonical/metrics/error.d.ts +48 -0
- package/dist/esm/processors/canonical/metrics/error.d.ts.map +1 -0
- package/dist/esm/processors/canonical/metrics/error.js +199 -0
- package/dist/esm/processors/canonical/metrics/error.js.map +1 -0
- package/dist/esm/processors/canonical/metrics/performance.d.ts +24 -0
- package/dist/esm/processors/canonical/metrics/performance.d.ts.map +1 -0
- package/dist/esm/processors/canonical/metrics/performance.js +67 -0
- package/dist/esm/processors/canonical/metrics/performance.js.map +1 -0
- package/dist/esm/processors/canonical/metrics/quality.d.ts +52 -0
- package/dist/esm/processors/canonical/metrics/quality.d.ts.map +1 -0
- package/dist/esm/processors/canonical/metrics/quality.js +276 -0
- package/dist/esm/processors/canonical/metrics/quality.js.map +1 -0
- package/dist/esm/processors/canonical/metrics/usage.d.ts +64 -0
- package/dist/esm/processors/canonical/metrics/usage.d.ts.map +1 -0
- package/dist/esm/processors/canonical/metrics/usage.js +320 -0
- package/dist/esm/processors/canonical/metrics/usage.js.map +1 -0
- package/dist/esm/processors/index.d.ts +10 -0
- package/dist/esm/processors/index.d.ts.map +1 -0
- package/dist/esm/processors/index.js +14 -0
- package/dist/esm/processors/index.js.map +1 -0
- package/dist/esm/processors/providers/claude-code/index.d.ts +39 -0
- package/dist/esm/processors/providers/claude-code/index.d.ts.map +1 -0
- package/dist/esm/processors/providers/claude-code/index.js +196 -0
- package/dist/esm/processors/providers/claude-code/index.js.map +1 -0
- package/dist/esm/processors/providers/codex/index.d.ts +11 -0
- package/dist/esm/processors/providers/codex/index.d.ts.map +1 -0
- package/dist/esm/processors/providers/codex/index.js +31 -0
- package/dist/esm/processors/providers/codex/index.js.map +1 -0
- package/dist/esm/processors/providers/cursor/index.d.ts +16 -0
- package/dist/esm/processors/providers/cursor/index.d.ts.map +1 -0
- package/dist/esm/processors/providers/cursor/index.js +92 -0
- package/dist/esm/processors/providers/cursor/index.js.map +1 -0
- package/dist/esm/processors/providers/gemini/index.d.ts +16 -0
- package/dist/esm/processors/providers/gemini/index.d.ts.map +1 -0
- package/dist/esm/processors/providers/gemini/index.js +108 -0
- package/dist/esm/processors/providers/gemini/index.js.map +1 -0
- package/dist/esm/processors/providers/github-copilot/index.d.ts +11 -0
- package/dist/esm/processors/providers/github-copilot/index.d.ts.map +1 -0
- package/dist/esm/processors/providers/github-copilot/index.js +31 -0
- package/dist/esm/processors/providers/github-copilot/index.js.map +1 -0
- package/dist/esm/processors/providers/opencode/index.d.ts +11 -0
- package/dist/esm/processors/providers/opencode/index.d.ts.map +1 -0
- package/dist/esm/processors/providers/opencode/index.js +31 -0
- package/dist/esm/processors/providers/opencode/index.js.map +1 -0
- package/dist/esm/processors/registry.d.ts +95 -0
- package/dist/esm/processors/registry.d.ts.map +1 -0
- package/dist/esm/processors/registry.js +210 -0
- package/dist/esm/processors/registry.js.map +1 -0
- package/dist/esm/ui/components/DateFilter.d.ts +19 -0
- package/dist/esm/ui/components/DateFilter.d.ts.map +1 -0
- package/dist/esm/ui/components/DateFilter.js +79 -0
- package/dist/esm/ui/components/DateFilter.js.map +1 -0
- package/dist/esm/ui/components/QuickRatingPopover.d.ts +17 -0
- package/dist/esm/ui/components/QuickRatingPopover.d.ts.map +1 -0
- package/dist/esm/ui/components/QuickRatingPopover.js +55 -0
- package/dist/esm/ui/components/QuickRatingPopover.js.map +1 -0
- package/dist/esm/ui/components/RatingBadge.d.ts +17 -0
- package/dist/esm/ui/components/RatingBadge.d.ts.map +1 -0
- package/dist/esm/ui/components/RatingBadge.js +119 -0
- package/dist/esm/ui/components/RatingBadge.js.map +1 -0
- package/dist/esm/ui/components/ScrollToTopButton.d.ts +17 -0
- package/dist/esm/ui/components/ScrollToTopButton.d.ts.map +1 -0
- package/dist/esm/ui/components/ScrollToTopButton.js +60 -0
- package/dist/esm/ui/components/ScrollToTopButton.js.map +1 -0
- package/dist/esm/ui/components/SessionCard.d.ts +60 -0
- package/dist/esm/ui/components/SessionCard.d.ts.map +1 -0
- package/dist/esm/ui/components/SessionCard.js +250 -0
- package/dist/esm/ui/components/SessionCard.js.map +1 -0
- package/dist/esm/ui/components/SessionDetailHeader.d.ts +57 -0
- package/dist/esm/ui/components/SessionDetailHeader.d.ts.map +1 -0
- package/dist/esm/ui/components/SessionDetailHeader.js +97 -0
- package/dist/esm/ui/components/SessionDetailHeader.js.map +1 -0
- package/dist/esm/ui/components/SessionTodosTab.d.ts +9 -0
- package/dist/esm/ui/components/SessionTodosTab.d.ts.map +1 -0
- package/dist/esm/ui/components/SessionTodosTab.js +66 -0
- package/dist/esm/ui/components/SessionTodosTab.js.map +1 -0
- package/dist/esm/ui/components/TokenUsageChart.d.ts +20 -0
- package/dist/esm/ui/components/TokenUsageChart.d.ts.map +1 -0
- package/dist/esm/ui/components/TokenUsageChart.js +123 -0
- package/dist/esm/ui/components/TokenUsageChart.js.map +1 -0
- package/dist/esm/ui/components/assessment/AssessmentModal.d.ts +3 -0
- package/dist/esm/ui/components/assessment/AssessmentModal.d.ts.map +1 -0
- package/dist/esm/ui/components/assessment/AssessmentModal.js +141 -0
- package/dist/esm/ui/components/assessment/AssessmentModal.js.map +1 -0
- package/dist/esm/ui/components/assessment/ChoiceResponse.d.ts +9 -0
- package/dist/esm/ui/components/assessment/ChoiceResponse.d.ts.map +1 -0
- package/dist/esm/ui/components/assessment/ChoiceResponse.js +27 -0
- package/dist/esm/ui/components/assessment/ChoiceResponse.js.map +1 -0
- package/dist/esm/ui/components/assessment/LikertScale.d.ts +3 -0
- package/dist/esm/ui/components/assessment/LikertScale.d.ts.map +1 -0
- package/dist/esm/ui/components/assessment/LikertScale.js +73 -0
- package/dist/esm/ui/components/assessment/LikertScale.js.map +1 -0
- package/dist/esm/ui/components/assessment/ProgressBar.d.ts +3 -0
- package/dist/esm/ui/components/assessment/ProgressBar.d.ts.map +1 -0
- package/dist/esm/ui/components/assessment/ProgressBar.js +6 -0
- package/dist/esm/ui/components/assessment/ProgressBar.js.map +1 -0
- package/dist/esm/ui/components/assessment/QuestionCard.d.ts +3 -0
- package/dist/esm/ui/components/assessment/QuestionCard.d.ts.map +1 -0
- package/dist/esm/ui/components/assessment/QuestionCard.js +124 -0
- package/dist/esm/ui/components/assessment/QuestionCard.js.map +1 -0
- package/dist/esm/ui/components/assessment/TextResponse.d.ts +3 -0
- package/dist/esm/ui/components/assessment/TextResponse.d.ts.map +1 -0
- package/dist/esm/ui/components/assessment/TextResponse.js +5 -0
- package/dist/esm/ui/components/assessment/TextResponse.js.map +1 -0
- package/dist/esm/ui/components/assessment/VersionSelector.d.ts +7 -0
- package/dist/esm/ui/components/assessment/VersionSelector.d.ts.map +1 -0
- package/dist/esm/ui/components/assessment/VersionSelector.js +68 -0
- package/dist/esm/ui/components/assessment/VersionSelector.js.map +1 -0
- package/dist/esm/ui/components/assessment/index.d.ts +9 -0
- package/dist/esm/ui/components/assessment/index.d.ts.map +1 -0
- package/dist/esm/ui/components/assessment/index.js +9 -0
- package/dist/esm/ui/components/assessment/index.js.map +1 -0
- package/dist/esm/ui/components/assessment/types.d.ts +58 -0
- package/dist/esm/ui/components/assessment/types.d.ts.map +1 -0
- package/dist/esm/ui/components/assessment/types.js +2 -0
- package/dist/esm/ui/components/assessment/types.js.map +1 -0
- package/dist/esm/ui/components/index.d.ts +39 -0
- package/dist/esm/ui/components/index.d.ts.map +1 -0
- package/dist/esm/ui/components/index.js +45 -0
- package/dist/esm/ui/components/index.js.map +1 -0
- package/dist/esm/ui/components/metrics/AssessmentSection.d.ts +27 -0
- package/dist/esm/ui/components/metrics/AssessmentSection.d.ts.map +1 -0
- package/dist/esm/ui/components/metrics/AssessmentSection.js +76 -0
- package/dist/esm/ui/components/metrics/AssessmentSection.js.map +1 -0
- package/dist/esm/ui/components/metrics/MetricCard.d.ts +20 -0
- package/dist/esm/ui/components/metrics/MetricCard.d.ts.map +1 -0
- package/dist/esm/ui/components/metrics/MetricCard.js +77 -0
- package/dist/esm/ui/components/metrics/MetricCard.js.map +1 -0
- package/dist/esm/ui/components/metrics/MetricSection.d.ts +12 -0
- package/dist/esm/ui/components/metrics/MetricSection.d.ts.map +1 -0
- package/dist/esm/ui/components/metrics/MetricSection.js +5 -0
- package/dist/esm/ui/components/metrics/MetricSection.js.map +1 -0
- package/dist/esm/ui/components/metrics/MetricsOverview.d.ts +89 -0
- package/dist/esm/ui/components/metrics/MetricsOverview.d.ts.map +1 -0
- package/dist/esm/ui/components/metrics/MetricsOverview.js +26 -0
- package/dist/esm/ui/components/metrics/MetricsOverview.js.map +1 -0
- package/dist/esm/ui/components/metrics/metricThresholds.d.ts +40 -0
- package/dist/esm/ui/components/metrics/metricThresholds.d.ts.map +1 -0
- package/dist/esm/ui/components/metrics/metricThresholds.js +203 -0
- package/dist/esm/ui/components/metrics/metricThresholds.js.map +1 -0
- package/dist/esm/ui/components/metrics/sections/AIAssessmentSection.d.ts +12 -0
- package/dist/esm/ui/components/metrics/sections/AIAssessmentSection.d.ts.map +1 -0
- package/dist/esm/ui/components/metrics/sections/AIAssessmentSection.js +28 -0
- package/dist/esm/ui/components/metrics/sections/AIAssessmentSection.js.map +1 -0
- package/dist/esm/ui/components/metrics/sections/ContextMetricsSection.d.ts +10 -0
- package/dist/esm/ui/components/metrics/sections/ContextMetricsSection.d.ts.map +1 -0
- package/dist/esm/ui/components/metrics/sections/ContextMetricsSection.js +18 -0
- package/dist/esm/ui/components/metrics/sections/ContextMetricsSection.js.map +1 -0
- package/dist/esm/ui/components/metrics/sections/EngagementMetricsSection.d.ts +10 -0
- package/dist/esm/ui/components/metrics/sections/EngagementMetricsSection.d.ts.map +1 -0
- package/dist/esm/ui/components/metrics/sections/EngagementMetricsSection.js +18 -0
- package/dist/esm/ui/components/metrics/sections/EngagementMetricsSection.js.map +1 -0
- package/dist/esm/ui/components/metrics/sections/ErrorMetricsSection.d.ts +10 -0
- package/dist/esm/ui/components/metrics/sections/ErrorMetricsSection.d.ts.map +1 -0
- package/dist/esm/ui/components/metrics/sections/ErrorMetricsSection.js +14 -0
- package/dist/esm/ui/components/metrics/sections/ErrorMetricsSection.js.map +1 -0
- package/dist/esm/ui/components/metrics/sections/GitDiffMetricsSection.d.ts +10 -0
- package/dist/esm/ui/components/metrics/sections/GitDiffMetricsSection.d.ts.map +1 -0
- package/dist/esm/ui/components/metrics/sections/GitDiffMetricsSection.js +19 -0
- package/dist/esm/ui/components/metrics/sections/GitDiffMetricsSection.js.map +1 -0
- package/dist/esm/ui/components/metrics/sections/PerformanceMetricsSection.d.ts +10 -0
- package/dist/esm/ui/components/metrics/sections/PerformanceMetricsSection.d.ts.map +1 -0
- package/dist/esm/ui/components/metrics/sections/PerformanceMetricsSection.js +18 -0
- package/dist/esm/ui/components/metrics/sections/PerformanceMetricsSection.js.map +1 -0
- package/dist/esm/ui/components/metrics/sections/QualityMetricsSection.d.ts +10 -0
- package/dist/esm/ui/components/metrics/sections/QualityMetricsSection.d.ts.map +1 -0
- package/dist/esm/ui/components/metrics/sections/QualityMetricsSection.js +23 -0
- package/dist/esm/ui/components/metrics/sections/QualityMetricsSection.js.map +1 -0
- package/dist/esm/ui/components/metrics/sections/UsageMetricsSection.d.ts +10 -0
- package/dist/esm/ui/components/metrics/sections/UsageMetricsSection.d.ts.map +1 -0
- package/dist/esm/ui/components/metrics/sections/UsageMetricsSection.js +14 -0
- package/dist/esm/ui/components/metrics/sections/UsageMetricsSection.js.map +1 -0
- package/dist/esm/ui/components/phase/PhaseBlock.d.ts +19 -0
- package/dist/esm/ui/components/phase/PhaseBlock.d.ts.map +1 -0
- package/dist/esm/ui/components/phase/PhaseBlock.js +13 -0
- package/dist/esm/ui/components/phase/PhaseBlock.js.map +1 -0
- package/dist/esm/ui/components/phase/PhaseHeader.d.ts +10 -0
- package/dist/esm/ui/components/phase/PhaseHeader.d.ts.map +1 -0
- package/dist/esm/ui/components/phase/PhaseHeader.js +12 -0
- package/dist/esm/ui/components/phase/PhaseHeader.js.map +1 -0
- package/dist/esm/ui/components/phase/PhaseIcon.d.ts +22 -0
- package/dist/esm/ui/components/phase/PhaseIcon.d.ts.map +1 -0
- package/dist/esm/ui/components/phase/PhaseIcon.js +71 -0
- package/dist/esm/ui/components/phase/PhaseIcon.js.map +1 -0
- package/dist/esm/ui/components/phase/PhaseStats.d.ts +13 -0
- package/dist/esm/ui/components/phase/PhaseStats.d.ts.map +1 -0
- package/dist/esm/ui/components/phase/PhaseStats.js +24 -0
- package/dist/esm/ui/components/phase/PhaseStats.js.map +1 -0
- package/dist/esm/ui/components/phase/PhaseSummary.d.ts +9 -0
- package/dist/esm/ui/components/phase/PhaseSummary.d.ts.map +1 -0
- package/dist/esm/ui/components/phase/PhaseSummary.js +5 -0
- package/dist/esm/ui/components/phase/PhaseSummary.js.map +1 -0
- package/dist/esm/ui/components/phase/PhaseTimeline.d.ts +17 -0
- package/dist/esm/ui/components/phase/PhaseTimeline.d.ts.map +1 -0
- package/dist/esm/ui/components/phase/PhaseTimeline.js +22 -0
- package/dist/esm/ui/components/phase/PhaseTimeline.js.map +1 -0
- package/dist/esm/ui/components/phase/index.d.ts +12 -0
- package/dist/esm/ui/components/phase/index.d.ts.map +1 -0
- package/dist/esm/ui/components/phase/index.js +10 -0
- package/dist/esm/ui/components/phase/index.js.map +1 -0
- package/dist/esm/ui/components/timeline/ContentRenderer.d.ts +10 -0
- package/dist/esm/ui/components/timeline/ContentRenderer.d.ts.map +1 -0
- package/dist/esm/ui/components/timeline/ContentRenderer.js +73 -0
- package/dist/esm/ui/components/timeline/ContentRenderer.js.map +1 -0
- package/dist/esm/ui/components/timeline/DebugModal.d.ts +14 -0
- package/dist/esm/ui/components/timeline/DebugModal.d.ts.map +1 -0
- package/dist/esm/ui/components/timeline/DebugModal.js +27 -0
- package/dist/esm/ui/components/timeline/DebugModal.js.map +1 -0
- package/dist/esm/ui/components/timeline/MessageHeader.d.ts +11 -0
- package/dist/esm/ui/components/timeline/MessageHeader.d.ts.map +1 -0
- package/dist/esm/ui/components/timeline/MessageHeader.js +7 -0
- package/dist/esm/ui/components/timeline/MessageHeader.js.map +1 -0
- package/dist/esm/ui/components/timeline/TimelineGroup.d.ts +10 -0
- package/dist/esm/ui/components/timeline/TimelineGroup.d.ts.map +1 -0
- package/dist/esm/ui/components/timeline/TimelineGroup.js +7 -0
- package/dist/esm/ui/components/timeline/TimelineGroup.js.map +1 -0
- package/dist/esm/ui/components/timeline/TimelineMessage.d.ts +12 -0
- package/dist/esm/ui/components/timeline/TimelineMessage.d.ts.map +1 -0
- package/dist/esm/ui/components/timeline/TimelineMessage.js +23 -0
- package/dist/esm/ui/components/timeline/TimelineMessage.js.map +1 -0
- package/dist/esm/ui/components/timeline/VirtualizedMessageList.d.ts +36 -0
- package/dist/esm/ui/components/timeline/VirtualizedMessageList.d.ts.map +1 -0
- package/dist/esm/ui/components/timeline/VirtualizedMessageList.js +90 -0
- package/dist/esm/ui/components/timeline/VirtualizedMessageList.js.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/CodeBlock.d.ts +10 -0
- package/dist/esm/ui/components/timeline/blocks/CodeBlock.d.ts.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/CodeBlock.js +14 -0
- package/dist/esm/ui/components/timeline/blocks/CodeBlock.js.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/ImageBlock.d.ts +10 -0
- package/dist/esm/ui/components/timeline/blocks/ImageBlock.d.ts.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/ImageBlock.js +5 -0
- package/dist/esm/ui/components/timeline/blocks/ImageBlock.js.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/JsonBlock.d.ts +10 -0
- package/dist/esm/ui/components/timeline/blocks/JsonBlock.d.ts.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/JsonBlock.js +11 -0
- package/dist/esm/ui/components/timeline/blocks/JsonBlock.js.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/SystemReminderBlock.d.ts +16 -0
- package/dist/esm/ui/components/timeline/blocks/SystemReminderBlock.d.ts.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/SystemReminderBlock.js +90 -0
- package/dist/esm/ui/components/timeline/blocks/SystemReminderBlock.js.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/TextBlock.d.ts +13 -0
- package/dist/esm/ui/components/timeline/blocks/TextBlock.d.ts.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/TextBlock.js +188 -0
- package/dist/esm/ui/components/timeline/blocks/TextBlock.js.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/ThinkingBlock.d.ts +15 -0
- package/dist/esm/ui/components/timeline/blocks/ThinkingBlock.d.ts.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/ThinkingBlock.js +15 -0
- package/dist/esm/ui/components/timeline/blocks/ThinkingBlock.js.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/ToolBlock.d.ts +13 -0
- package/dist/esm/ui/components/timeline/blocks/ToolBlock.d.ts.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/ToolBlock.js +51 -0
- package/dist/esm/ui/components/timeline/blocks/ToolBlock.js.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/ToolResultBlock.d.ts +12 -0
- package/dist/esm/ui/components/timeline/blocks/ToolResultBlock.d.ts.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/ToolResultBlock.js +81 -0
- package/dist/esm/ui/components/timeline/blocks/ToolResultBlock.js.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/index.d.ts +11 -0
- package/dist/esm/ui/components/timeline/blocks/index.d.ts.map +1 -0
- package/dist/esm/ui/components/timeline/blocks/index.js +11 -0
- package/dist/esm/ui/components/timeline/blocks/index.js.map +1 -0
- package/dist/esm/ui/components/timeline/index.d.ts +10 -0
- package/dist/esm/ui/components/timeline/index.d.ts.map +1 -0
- package/dist/esm/ui/components/timeline/index.js +10 -0
- package/dist/esm/ui/components/timeline/index.js.map +1 -0
- package/dist/esm/ui/index.d.ts +10 -0
- package/dist/esm/ui/index.d.ts.map +1 -0
- package/dist/esm/ui/index.js +15 -0
- package/dist/esm/ui/index.js.map +1 -0
- package/dist/esm/ui/utils/extractTokens.d.ts +94 -0
- package/dist/esm/ui/utils/extractTokens.d.ts.map +1 -0
- package/dist/esm/ui/utils/extractTokens.js +185 -0
- package/dist/esm/ui/utils/extractTokens.js.map +1 -0
- package/dist/esm/ui/utils/markdown.d.ts +65 -0
- package/dist/esm/ui/utils/markdown.d.ts.map +1 -0
- package/dist/esm/ui/utils/markdown.js +199 -0
- package/dist/esm/ui/utils/markdown.js.map +1 -0
- package/dist/esm/ui/utils/processors/BaseMessageProcessor.d.ts +133 -0
- package/dist/esm/ui/utils/processors/BaseMessageProcessor.d.ts.map +1 -0
- package/dist/esm/ui/utils/processors/BaseMessageProcessor.js +546 -0
- package/dist/esm/ui/utils/processors/BaseMessageProcessor.js.map +1 -0
- package/dist/esm/ui/utils/processors/CanonicalMessageProcessor.d.ts +81 -0
- package/dist/esm/ui/utils/processors/CanonicalMessageProcessor.d.ts.map +1 -0
- package/dist/esm/ui/utils/processors/CanonicalMessageProcessor.js +442 -0
- package/dist/esm/ui/utils/processors/CanonicalMessageProcessor.js.map +1 -0
- package/dist/esm/ui/utils/processors/GenericMessageProcessor.d.ts +46 -0
- package/dist/esm/ui/utils/processors/GenericMessageProcessor.d.ts.map +1 -0
- package/dist/esm/ui/utils/processors/GenericMessageProcessor.js +169 -0
- package/dist/esm/ui/utils/processors/GenericMessageProcessor.js.map +1 -0
- package/dist/esm/ui/utils/processors/ProcessorRegistry.d.ts +33 -0
- package/dist/esm/ui/utils/processors/ProcessorRegistry.d.ts.map +1 -0
- package/dist/esm/ui/utils/processors/ProcessorRegistry.js +71 -0
- package/dist/esm/ui/utils/processors/ProcessorRegistry.js.map +1 -0
- package/dist/esm/ui/utils/processors/index.d.ts +11 -0
- package/dist/esm/ui/utils/processors/index.d.ts.map +1 -0
- package/dist/esm/ui/utils/processors/index.js +11 -0
- package/dist/esm/ui/utils/processors/index.js.map +1 -0
- package/dist/esm/ui/utils/sessionTypes.d.ts +2 -0
- package/dist/esm/ui/utils/sessionTypes.d.ts.map +1 -0
- package/dist/esm/ui/utils/sessionTypes.js +3 -0
- package/dist/esm/ui/utils/sessionTypes.js.map +1 -0
- package/dist/esm/ui/utils/systemReminderParser.d.ts +40 -0
- package/dist/esm/ui/utils/systemReminderParser.d.ts.map +1 -0
- package/dist/esm/ui/utils/systemReminderParser.js +104 -0
- package/dist/esm/ui/utils/systemReminderParser.js.map +1 -0
- package/dist/esm/ui/utils/timelineTypes.d.ts +201 -0
- package/dist/esm/ui/utils/timelineTypes.d.ts.map +1 -0
- package/dist/esm/ui/utils/timelineTypes.js +38 -0
- package/dist/esm/ui/utils/timelineTypes.js.map +1 -0
- package/dist/esm/ui/utils/todos/extractTodosClaudeCode.d.ts +9 -0
- package/dist/esm/ui/utils/todos/extractTodosClaudeCode.d.ts.map +1 -0
- package/dist/esm/ui/utils/todos/extractTodosClaudeCode.js +37 -0
- package/dist/esm/ui/utils/todos/extractTodosClaudeCode.js.map +1 -0
- package/dist/esm/ui/utils/todos/extractTodosCodex.d.ts +29 -0
- package/dist/esm/ui/utils/todos/extractTodosCodex.d.ts.map +1 -0
- package/dist/esm/ui/utils/todos/extractTodosCodex.js +158 -0
- package/dist/esm/ui/utils/todos/extractTodosCodex.js.map +1 -0
- package/dist/esm/ui/utils/todos/index.d.ts +18 -0
- package/dist/esm/ui/utils/todos/index.d.ts.map +1 -0
- package/dist/esm/ui/utils/todos/index.js +36 -0
- package/dist/esm/ui/utils/todos/index.js.map +1 -0
- package/dist/esm/ui/utils/todos/todoUtils.d.ts +27 -0
- package/dist/esm/ui/utils/todos/todoUtils.d.ts.map +1 -0
- package/dist/esm/ui/utils/todos/todoUtils.js +117 -0
- package/dist/esm/ui/utils/todos/todoUtils.js.map +1 -0
- package/dist/esm/ui/utils/todos/types.d.ts +41 -0
- package/dist/esm/ui/utils/todos/types.d.ts.map +1 -0
- package/dist/esm/ui/utils/todos/types.js +5 -0
- package/dist/esm/ui/utils/todos/types.js.map +1 -0
- package/dist/esm/utils/git-url.d.ts +25 -0
- package/dist/esm/utils/git-url.d.ts.map +1 -0
- package/dist/esm/utils/git-url.js +56 -0
- package/dist/esm/utils/git-url.js.map +1 -0
- package/dist/esm/utils/index.d.ts +7 -0
- package/dist/esm/utils/index.d.ts.map +1 -0
- package/dist/esm/utils/index.js +7 -0
- package/dist/esm/utils/index.js.map +1 -0
- package/dist/esm/utils/rating.d.ts +61 -0
- package/dist/esm/utils/rating.d.ts.map +1 -0
- package/dist/esm/utils/rating.js +91 -0
- package/dist/esm/utils/rating.js.map +1 -0
- package/dist/esm/utils/safe-access.d.ts +43 -0
- package/dist/esm/utils/safe-access.d.ts.map +1 -0
- package/dist/esm/utils/safe-access.js +78 -0
- package/dist/esm/utils/safe-access.js.map +1 -0
- package/dist/esm/utils/user.d.ts +22 -0
- package/dist/esm/utils/user.d.ts.map +1 -0
- package/dist/esm/utils/user.js +36 -0
- package/dist/esm/utils/user.js.map +1 -0
- package/dist/esm/validation/index.d.ts +8 -0
- package/dist/esm/validation/index.d.ts.map +1 -0
- package/dist/esm/validation/index.js +10 -0
- package/dist/esm/validation/index.js.map +1 -0
- package/dist/esm/validation/validator.d.ts +48 -0
- package/dist/esm/validation/validator.d.ts.map +1 -0
- package/dist/esm/validation/validator.js +203 -0
- package/dist/esm/validation/validator.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/index.css +31 -0
- package/package.json +144 -0
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Unified Parser Registry
|
|
3
|
+
*
|
|
4
|
+
* Phase 2: Simplified to use only CanonicalParser for all providers.
|
|
5
|
+
* All providers now write canonical JSONL format, eliminating the need
|
|
6
|
+
* for provider-specific parsers.
|
|
7
|
+
*/
|
|
8
|
+
import { CanonicalParser } from './canonical/index.js';
|
|
9
|
+
export class ParserRegistry {
|
|
10
|
+
parsers = new Map();
|
|
11
|
+
constructor() {
|
|
12
|
+
// Register the canonical parser (handles all providers)
|
|
13
|
+
const canonicalParser = new CanonicalParser();
|
|
14
|
+
this.register(canonicalParser);
|
|
15
|
+
// Add aliases for all provider names to use canonical parser
|
|
16
|
+
const providerAliases = [
|
|
17
|
+
'claude-code',
|
|
18
|
+
'claude',
|
|
19
|
+
'gemini-code',
|
|
20
|
+
'gemini',
|
|
21
|
+
'github-copilot',
|
|
22
|
+
'copilot',
|
|
23
|
+
'codex',
|
|
24
|
+
'opencode',
|
|
25
|
+
'cursor',
|
|
26
|
+
];
|
|
27
|
+
for (const alias of providerAliases) {
|
|
28
|
+
this.parsers.set(alias, canonicalParser);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Register a custom parser
|
|
33
|
+
*/
|
|
34
|
+
register(parser) {
|
|
35
|
+
this.parsers.set(parser.name, parser);
|
|
36
|
+
if (parser.providerName !== parser.name) {
|
|
37
|
+
this.parsers.set(parser.providerName, parser);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Get a parser by provider name
|
|
42
|
+
*/
|
|
43
|
+
getParser(provider) {
|
|
44
|
+
// Normalize provider name
|
|
45
|
+
const normalizedProvider = provider.toLowerCase().trim();
|
|
46
|
+
// Try exact match
|
|
47
|
+
const exactMatch = this.parsers.get(normalizedProvider);
|
|
48
|
+
if (exactMatch) {
|
|
49
|
+
return exactMatch;
|
|
50
|
+
}
|
|
51
|
+
// Try partial match
|
|
52
|
+
for (const [name, parser] of this.parsers.entries()) {
|
|
53
|
+
if (name.includes(normalizedProvider) || normalizedProvider.includes(name)) {
|
|
54
|
+
return parser;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
return null;
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Auto-detect the correct parser for JSONL content
|
|
61
|
+
*/
|
|
62
|
+
detectParser(jsonlContent) {
|
|
63
|
+
for (const parser of this.parsers.values()) {
|
|
64
|
+
if (parser.canParse(jsonlContent)) {
|
|
65
|
+
return parser;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
return null;
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Get all registered provider names
|
|
72
|
+
*/
|
|
73
|
+
getRegisteredProviders() {
|
|
74
|
+
return Array.from(new Set(this.parsers.values())).map(parser => parser.providerName);
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Check if a parser exists for a provider
|
|
78
|
+
*/
|
|
79
|
+
hasParser(provider) {
|
|
80
|
+
return this.getParser(provider) !== null;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
// Export singleton instance
|
|
84
|
+
export const parserRegistry = new ParserRegistry();
|
|
85
|
+
//# sourceMappingURL=registry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.js","sourceRoot":"","sources":["../../../src/parsers/registry.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAGH,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAEtD,MAAM,OAAO,cAAc;IACjB,OAAO,GAAG,IAAI,GAAG,EAAyB,CAAA;IAElD;QACE,wDAAwD;QACxD,MAAM,eAAe,GAAG,IAAI,eAAe,EAAE,CAAA;QAC7C,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAA;QAE9B,6DAA6D;QAC7D,MAAM,eAAe,GAAG;YACtB,aAAa;YACb,QAAQ;YACR,aAAa;YACb,QAAQ;YACR,gBAAgB;YAChB,SAAS;YACT,OAAO;YACP,UAAU;YACV,QAAQ;SACT,CAAA;QAED,KAAK,MAAM,KAAK,IAAI,eAAe,EAAE,CAAC;YACpC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,eAAe,CAAC,CAAA;QAC1C,CAAC;IACH,CAAC;IAED;;OAEG;IACH,QAAQ,CAAC,MAAqB;QAC5B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,CAAA;QACrC,IAAI,MAAM,CAAC,YAAY,KAAK,MAAM,CAAC,IAAI,EAAE,CAAC;YACxC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,CAAA;QAC/C,CAAC;IACH,CAAC;IAED;;OAEG;IACH,SAAS,CAAC,QAAgB;QACxB,0BAA0B;QAC1B,MAAM,kBAAkB,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC,IAAI,EAAE,CAAA;QAExD,kBAAkB;QAClB,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAA;QACvD,IAAI,UAAU,EAAE,CAAC;YACf,OAAO,UAAU,CAAA;QACnB,CAAC;QAED,oBAAoB;QACpB,KAAK,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC;YACpD,IAAI,IAAI,CAAC,QAAQ,CAAC,kBAAkB,CAAC,IAAI,kBAAkB,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;gBAC3E,OAAO,MAAM,CAAA;YACf,CAAC;QACH,CAAC;QAED,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;OAEG;IACH,YAAY,CAAC,YAAoB;QAC/B,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC;YAC3C,IAAI,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC;gBAClC,OAAO,MAAM,CAAA;YACf,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;OAEG;IACH,sBAAsB;QACpB,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,CAAA;IACtF,CAAC;IAED;;OAEG;IACH,SAAS,CAAC,QAAgB;QACxB,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,IAAI,CAAA;IAC1C,CAAC;CACF;AAED,4BAA4B;AAC5B,MAAM,CAAC,MAAM,cAAc,GAAG,IAAI,cAAc,EAAE,CAAA"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import type { GitDiffMetrics } from '@guidemode/types';
|
|
2
|
+
import { BaseMetricProcessor } from './metric-processor.js';
|
|
3
|
+
import type { ParsedSession } from './types.js';
|
|
4
|
+
/**
|
|
5
|
+
* Universal git diff metric processor - works with ALL providers
|
|
6
|
+
* Runs LAST to leverage previously calculated metrics
|
|
7
|
+
*
|
|
8
|
+
* Calculates:
|
|
9
|
+
* - Core diff metrics (files, lines added/removed)
|
|
10
|
+
* - Efficiency ratios (lines read per changed, reads per file, etc.)
|
|
11
|
+
*
|
|
12
|
+
* Desktop-only: Returns null if no git diff data available
|
|
13
|
+
*/
|
|
14
|
+
export declare class GitDiffMetricProcessor extends BaseMetricProcessor {
|
|
15
|
+
readonly name = "git-diff";
|
|
16
|
+
readonly metricType: "git-diff";
|
|
17
|
+
readonly description = "Universal git diff analysis with navigation efficiency (all providers)";
|
|
18
|
+
/**
|
|
19
|
+
* Process git diff metrics
|
|
20
|
+
* Standard process() method for base class compatibility
|
|
21
|
+
*/
|
|
22
|
+
process(session: ParsedSession): Promise<GitDiffMetrics>;
|
|
23
|
+
/**
|
|
24
|
+
* Process git diff metrics with access to existing metrics
|
|
25
|
+
* @param session - Parsed session with optional git diff data
|
|
26
|
+
* @param existingMetrics - Previously calculated metrics (for ratios)
|
|
27
|
+
*/
|
|
28
|
+
processWithExistingMetrics(session: ParsedSession, existingMetrics?: Record<string, unknown>): Promise<GitDiffMetrics>;
|
|
29
|
+
/**
|
|
30
|
+
* Count total tool uses across any provider (provider-agnostic)
|
|
31
|
+
*/
|
|
32
|
+
private getTotalToolCount;
|
|
33
|
+
/**
|
|
34
|
+
* Generate improvement tips based on efficiency ratios
|
|
35
|
+
*/
|
|
36
|
+
private generateTips;
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=git-diff-processor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"git-diff-processor.d.ts","sourceRoot":"","sources":["../../../../src/processors/base/git-diff-processor.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAW,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAC/D,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAA;AAC3D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,YAAY,CAAA;AAE/C;;;;;;;;;GASG;AACH,qBAAa,sBAAuB,SAAQ,mBAAmB;IAC7D,QAAQ,CAAC,IAAI,cAAa;IAC1B,QAAQ,CAAC,UAAU,EAAG,UAAU,CAAS;IACzC,QAAQ,CAAC,WAAW,4EAA2E;IAE/F;;;OAGG;IACG,OAAO,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,cAAc,CAAC;IAI9D;;;;OAIG;IACG,0BAA0B,CAC9B,OAAO,EAAE,aAAa,EACtB,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GACxC,OAAO,CAAC,cAAc,CAAC;IAqE1B;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAYzB;;OAEG;IACH,OAAO,CAAC,YAAY;CAkCrB"}
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import { BaseMetricProcessor } from './metric-processor.js';
|
|
2
|
+
/**
|
|
3
|
+
* Universal git diff metric processor - works with ALL providers
|
|
4
|
+
* Runs LAST to leverage previously calculated metrics
|
|
5
|
+
*
|
|
6
|
+
* Calculates:
|
|
7
|
+
* - Core diff metrics (files, lines added/removed)
|
|
8
|
+
* - Efficiency ratios (lines read per changed, reads per file, etc.)
|
|
9
|
+
*
|
|
10
|
+
* Desktop-only: Returns null if no git diff data available
|
|
11
|
+
*/
|
|
12
|
+
export class GitDiffMetricProcessor extends BaseMetricProcessor {
|
|
13
|
+
name = 'git-diff';
|
|
14
|
+
metricType = 'git-diff';
|
|
15
|
+
description = 'Universal git diff analysis with navigation efficiency (all providers)';
|
|
16
|
+
/**
|
|
17
|
+
* Process git diff metrics
|
|
18
|
+
* Standard process() method for base class compatibility
|
|
19
|
+
*/
|
|
20
|
+
async process(session) {
|
|
21
|
+
return this.processWithExistingMetrics(session, {});
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Process git diff metrics with access to existing metrics
|
|
25
|
+
* @param session - Parsed session with optional git diff data
|
|
26
|
+
* @param existingMetrics - Previously calculated metrics (for ratios)
|
|
27
|
+
*/
|
|
28
|
+
async processWithExistingMetrics(session, existingMetrics) {
|
|
29
|
+
// Check if git diff data is available (desktop only)
|
|
30
|
+
const gitDiff = session.metadata?.gitDiff;
|
|
31
|
+
if (!gitDiff || !gitDiff.files) {
|
|
32
|
+
// Return empty metrics if no git data (server sessions)
|
|
33
|
+
return {
|
|
34
|
+
git_total_files_changed: 0,
|
|
35
|
+
git_lines_added: 0,
|
|
36
|
+
git_lines_removed: 0,
|
|
37
|
+
git_lines_modified: 0,
|
|
38
|
+
git_net_lines_changed: 0,
|
|
39
|
+
metadata: {
|
|
40
|
+
calculation_type: 'unstaged',
|
|
41
|
+
improvement_tips: [],
|
|
42
|
+
},
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
// Calculate core diff metrics (provider-agnostic)
|
|
46
|
+
const totalFiles = gitDiff.files.length;
|
|
47
|
+
const linesAdded = gitDiff.files.reduce((sum, file) => sum + (file.stats?.additions || 0), 0);
|
|
48
|
+
const linesRemoved = gitDiff.files.reduce((sum, file) => sum + (file.stats?.deletions || 0), 0);
|
|
49
|
+
const linesModified = linesAdded + linesRemoved;
|
|
50
|
+
const netLines = linesAdded - linesRemoved;
|
|
51
|
+
// Extract total lines read from EXISTING usage metrics (already calculated)
|
|
52
|
+
const usage = existingMetrics?.usage;
|
|
53
|
+
const usageMetadata = usage?.metadata;
|
|
54
|
+
const totalLinesRead = usageMetadata?.total_lines_read || 0;
|
|
55
|
+
const readOperations = usageMetadata?.read_operations || 0;
|
|
56
|
+
// Calculate tool count (provider-agnostic)
|
|
57
|
+
const toolCount = this.getTotalToolCount(session);
|
|
58
|
+
// Calculate efficiency ratios
|
|
59
|
+
const linesReadPerChanged = linesModified > 0 ? Number.parseFloat((totalLinesRead / linesModified).toFixed(2)) : 0;
|
|
60
|
+
const readsPerFile = totalFiles > 0 ? Number.parseFloat((readOperations / totalFiles).toFixed(2)) : 0;
|
|
61
|
+
const linesPerMinute = session.duration > 0
|
|
62
|
+
? Number.parseFloat((linesModified / (session.duration / 60000)).toFixed(2))
|
|
63
|
+
: 0;
|
|
64
|
+
const linesPerTool = toolCount > 0 ? Number.parseFloat((linesModified / toolCount).toFixed(2)) : 0;
|
|
65
|
+
return {
|
|
66
|
+
git_total_files_changed: totalFiles,
|
|
67
|
+
git_lines_added: linesAdded,
|
|
68
|
+
git_lines_removed: linesRemoved,
|
|
69
|
+
git_lines_modified: linesModified,
|
|
70
|
+
git_net_lines_changed: netLines,
|
|
71
|
+
git_lines_read_per_line_changed: linesReadPerChanged > 0 ? linesReadPerChanged : undefined,
|
|
72
|
+
git_reads_per_file_changed: readsPerFile > 0 ? readsPerFile : undefined,
|
|
73
|
+
git_lines_changed_per_minute: linesPerMinute,
|
|
74
|
+
git_lines_changed_per_tool_use: linesPerTool,
|
|
75
|
+
total_lines_read: totalLinesRead > 0 ? totalLinesRead : undefined,
|
|
76
|
+
metadata: {
|
|
77
|
+
calculation_type: gitDiff.isUnstaged ? 'unstaged' : 'committed',
|
|
78
|
+
first_commit: session.metadata?.firstCommitHash,
|
|
79
|
+
latest_commit: session.metadata?.latestCommitHash,
|
|
80
|
+
improvement_tips: this.generateTips(linesReadPerChanged, readsPerFile, linesPerTool),
|
|
81
|
+
},
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Count total tool uses across any provider (provider-agnostic)
|
|
86
|
+
*/
|
|
87
|
+
getTotalToolCount(session) {
|
|
88
|
+
return session.messages
|
|
89
|
+
.filter(m => {
|
|
90
|
+
const toolCount = m.metadata?.toolCount;
|
|
91
|
+
return m.metadata?.hasToolUses || (toolCount && toolCount > 0);
|
|
92
|
+
})
|
|
93
|
+
.reduce((sum, m) => {
|
|
94
|
+
const toolCount = m.metadata?.toolCount || 0;
|
|
95
|
+
return sum + toolCount;
|
|
96
|
+
}, 0);
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* Generate improvement tips based on efficiency ratios
|
|
100
|
+
*/
|
|
101
|
+
generateTips(linesReadPerChanged, readsPerFile, linesPerTool) {
|
|
102
|
+
const tips = [];
|
|
103
|
+
// Lines read per changed analysis
|
|
104
|
+
if (linesReadPerChanged > 10) {
|
|
105
|
+
tips.push('High read-to-change ratio - AI read lots of code for few changes. Be more specific about file locations.');
|
|
106
|
+
}
|
|
107
|
+
else if (linesReadPerChanged > 0 && linesReadPerChanged < 5) {
|
|
108
|
+
tips.push('Excellent navigation efficiency! AI found and modified code quickly.');
|
|
109
|
+
}
|
|
110
|
+
// Reads per file analysis
|
|
111
|
+
if (readsPerFile > 3) {
|
|
112
|
+
tips.push('Multiple reads per file - AI struggled to find right code. Include function/class names.');
|
|
113
|
+
}
|
|
114
|
+
// Lines per tool analysis
|
|
115
|
+
if (linesPerTool > 0 && linesPerTool < 1) {
|
|
116
|
+
tips.push('Low lines per tool - many tools for small changes. Consider consolidating requests.');
|
|
117
|
+
}
|
|
118
|
+
else if (linesPerTool > 5) {
|
|
119
|
+
tips.push('Great tool efficiency - significant changes with minimal tool use.');
|
|
120
|
+
}
|
|
121
|
+
return tips;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
//# sourceMappingURL=git-diff-processor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"git-diff-processor.js","sourceRoot":"","sources":["../../../../src/processors/base/git-diff-processor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export { BaseMetricProcessor } from './metric-processor.js';
|
|
2
|
+
export { BaseProviderProcessor } from './provider-processor.js';
|
|
3
|
+
export { GitDiffMetricProcessor } from './git-diff-processor.js';
|
|
4
|
+
export type { ParsedMessage, ParsedSession, ProcessorResult, ProcessorContext, ProcessingStatus, } from './types.js';
|
|
5
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/processors/base/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAA;AAC3D,OAAO,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAA;AAC/D,OAAO,EAAE,sBAAsB,EAAE,MAAM,yBAAyB,CAAA;AAChE,YAAY,EACV,aAAa,EACb,aAAa,EACb,eAAe,EACf,gBAAgB,EAChB,gBAAgB,GACjB,MAAM,YAAY,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/processors/base/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAA;AAC3D,OAAO,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAA;AAC/D,OAAO,EAAE,sBAAsB,EAAE,MAAM,yBAAyB,CAAA"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import type { MetricType, SessionMetricsData } from '@guidemode/types';
|
|
2
|
+
import type { ParsedSession, ProcessorResult } from './types.js';
|
|
3
|
+
export declare abstract class BaseMetricProcessor {
|
|
4
|
+
abstract readonly name: string;
|
|
5
|
+
abstract readonly metricType: MetricType;
|
|
6
|
+
abstract readonly description: string;
|
|
7
|
+
/**
|
|
8
|
+
* Process a parsed session and extract specific metrics
|
|
9
|
+
* This method should be async to support AI calls and other async operations
|
|
10
|
+
*/
|
|
11
|
+
abstract process(session: ParsedSession): Promise<SessionMetricsData>;
|
|
12
|
+
/**
|
|
13
|
+
* Check if this processor can handle the given session
|
|
14
|
+
* Default implementation checks if the provider is supported
|
|
15
|
+
*/
|
|
16
|
+
canProcess(_session: ParsedSession): boolean;
|
|
17
|
+
/**
|
|
18
|
+
* Validate that the session contains required data for this processor
|
|
19
|
+
*/
|
|
20
|
+
protected validateSession(session: ParsedSession): void;
|
|
21
|
+
/**
|
|
22
|
+
* Public method to process a session and create a result with timing information
|
|
23
|
+
*/
|
|
24
|
+
processToResult(session: ParsedSession): Promise<ProcessorResult>;
|
|
25
|
+
/**
|
|
26
|
+
* Create a processor result with timing information
|
|
27
|
+
*/
|
|
28
|
+
protected createResult(session: ParsedSession): Promise<ProcessorResult>;
|
|
29
|
+
/**
|
|
30
|
+
* Helper method to find messages by type
|
|
31
|
+
*/
|
|
32
|
+
protected findMessagesByType(session: ParsedSession, type: string | string[]): ParsedSession['messages'];
|
|
33
|
+
/**
|
|
34
|
+
* Helper method to calculate time differences between messages
|
|
35
|
+
*/
|
|
36
|
+
protected calculateTimeDifference(startTime: Date, endTime: Date): number;
|
|
37
|
+
/**
|
|
38
|
+
* Helper method to extract content from messages safely
|
|
39
|
+
*/
|
|
40
|
+
protected extractContent(message: ParsedSession['messages'][0]): string;
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=metric-processor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metric-processor.d.ts","sourceRoot":"","sources":["../../../../src/processors/base/metric-processor.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAA;AAEtE,OAAO,KAAK,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAEhE,8BAAsB,mBAAmB;IACvC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IAC9B,QAAQ,CAAC,QAAQ,CAAC,UAAU,EAAE,UAAU,CAAA;IACxC,QAAQ,CAAC,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAA;IAErC;;;OAGG;IACH,QAAQ,CAAC,OAAO,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAErE;;;OAGG;IACH,UAAU,CAAC,QAAQ,EAAE,aAAa,GAAG,OAAO;IAI5C;;OAEG;IACH,SAAS,CAAC,eAAe,CAAC,OAAO,EAAE,aAAa,GAAG,IAAI;IASvD;;OAEG;IACG,eAAe,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,eAAe,CAAC;IAIvE;;OAEG;cACa,YAAY,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,eAAe,CAAC;IA2B9E;;OAEG;IACH,SAAS,CAAC,kBAAkB,CAC1B,OAAO,EAAE,aAAa,EACtB,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,GACtB,aAAa,CAAC,UAAU,CAAC;IAK5B;;OAEG;IACH,SAAS,CAAC,uBAAuB,CAAC,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,GAAG,MAAM;IAIzE;;OAEG;IACH,SAAS,CAAC,cAAc,CAAC,OAAO,EAAE,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,GAAG,MAAM;CASxE"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { isStructuredMessageContent } from '@guidemode/types';
|
|
2
|
+
export class BaseMetricProcessor {
|
|
3
|
+
/**
|
|
4
|
+
* Check if this processor can handle the given session
|
|
5
|
+
* Default implementation checks if the provider is supported
|
|
6
|
+
*/
|
|
7
|
+
canProcess(_session) {
|
|
8
|
+
return true;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Validate that the session contains required data for this processor
|
|
12
|
+
*/
|
|
13
|
+
validateSession(session) {
|
|
14
|
+
if (!session.sessionId) {
|
|
15
|
+
throw new Error('Session ID is required');
|
|
16
|
+
}
|
|
17
|
+
if (!session.messages || session.messages.length === 0) {
|
|
18
|
+
throw new Error('Session must contain messages');
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Public method to process a session and create a result with timing information
|
|
23
|
+
*/
|
|
24
|
+
async processToResult(session) {
|
|
25
|
+
return this.createResult(session);
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Create a processor result with timing information
|
|
29
|
+
*/
|
|
30
|
+
async createResult(session) {
|
|
31
|
+
const startTime = Date.now();
|
|
32
|
+
try {
|
|
33
|
+
this.validateSession(session);
|
|
34
|
+
const metrics = await this.process(session);
|
|
35
|
+
const processingTime = Date.now() - startTime;
|
|
36
|
+
return {
|
|
37
|
+
metricType: this.metricType,
|
|
38
|
+
metrics,
|
|
39
|
+
processingTime,
|
|
40
|
+
metadata: {
|
|
41
|
+
processor: this.name,
|
|
42
|
+
processingTime,
|
|
43
|
+
messageCount: session.messages.length,
|
|
44
|
+
sessionDuration: session.duration,
|
|
45
|
+
},
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
catch (error) {
|
|
49
|
+
const processingTime = Date.now() - startTime;
|
|
50
|
+
throw new Error(`${this.name} processor failed: ${error instanceof Error ? error.message : 'Unknown error'} (processing time: ${processingTime}ms)`);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Helper method to find messages by type
|
|
55
|
+
*/
|
|
56
|
+
findMessagesByType(session, type) {
|
|
57
|
+
const types = Array.isArray(type) ? type : [type];
|
|
58
|
+
return session.messages.filter(msg => types.includes(msg.type));
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Helper method to calculate time differences between messages
|
|
62
|
+
*/
|
|
63
|
+
calculateTimeDifference(startTime, endTime) {
|
|
64
|
+
return endTime.getTime() - startTime.getTime();
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Helper method to extract content from messages safely
|
|
68
|
+
*/
|
|
69
|
+
extractContent(message) {
|
|
70
|
+
if (typeof message.content === 'string') {
|
|
71
|
+
return message.content;
|
|
72
|
+
}
|
|
73
|
+
if (isStructuredMessageContent(message.content)) {
|
|
74
|
+
return message.content.text || '';
|
|
75
|
+
}
|
|
76
|
+
return JSON.stringify(message.content || '');
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
//# sourceMappingURL=metric-processor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metric-processor.js","sourceRoot":"","sources":["../../../../src/processors/base/metric-processor.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,0BAA0B,EAAE,MAAM,kBAAkB,CAAA;AAG7D,MAAM,OAAgB,mBAAmB;IAWvC;;;OAGG;IACH,UAAU,CAAC,QAAuB;QAChC,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;OAEG;IACO,eAAe,CAAC,OAAsB;QAC9C,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC;YACvB,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAA;QAC3C,CAAC;QACD,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,OAAO,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACvD,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAA;QAClD,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,eAAe,CAAC,OAAsB;QAC1C,OAAO,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAA;IACnC,CAAC;IAED;;OAEG;IACO,KAAK,CAAC,YAAY,CAAC,OAAsB;QACjD,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAA;QAE5B,IAAI,CAAC;YACH,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAA;YAC7B,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAA;YAC3C,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAA;YAE7C,OAAO;gBACL,UAAU,EAAE,IAAI,CAAC,UAAU;gBAC3B,OAAO;gBACP,cAAc;gBACd,QAAQ,EAAE;oBACR,SAAS,EAAE,IAAI,CAAC,IAAI;oBACpB,cAAc;oBACd,YAAY,EAAE,OAAO,CAAC,QAAQ,CAAC,MAAM;oBACrC,eAAe,EAAE,OAAO,CAAC,QAAQ;iBAClC;aACF,CAAA;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAA;YAC7C,MAAM,IAAI,KAAK,CACb,GAAG,IAAI,CAAC,IAAI,sBAAsB,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,sBAAsB,cAAc,KAAK,CACpI,CAAA;QACH,CAAC;IACH,CAAC;IAED;;OAEG;IACO,kBAAkB,CAC1B,OAAsB,EACtB,IAAuB;QAEvB,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;QACjD,OAAO,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAA;IACjE,CAAC;IAED;;OAEG;IACO,uBAAuB,CAAC,SAAe,EAAE,OAAa;QAC9D,OAAO,OAAO,CAAC,OAAO,EAAE,GAAG,SAAS,CAAC,OAAO,EAAE,CAAA;IAChD,CAAC;IAED;;OAEG;IACO,cAAc,CAAC,OAAqC;QAC5D,IAAI,OAAO,OAAO,CAAC,OAAO,KAAK,QAAQ,EAAE,CAAC;YACxC,OAAO,OAAO,CAAC,OAAO,CAAA;QACxB,CAAC;QACD,IAAI,0BAA0B,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;YAChD,OAAO,OAAO,CAAC,OAAO,CAAC,IAAI,IAAI,EAAE,CAAA;QACnC,CAAC;QACD,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,IAAI,EAAE,CAAC,CAAA;IAC9C,CAAC;CACF"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import type { BaseMetricProcessor } from './metric-processor.js';
|
|
2
|
+
import type { ParsedSession, ProcessorContext, ProcessorResult } from './types.js';
|
|
3
|
+
export declare abstract class BaseProviderProcessor {
|
|
4
|
+
abstract readonly providerName: string;
|
|
5
|
+
abstract readonly description: string;
|
|
6
|
+
/**
|
|
7
|
+
* Parse the raw JSONL content into a structured session object
|
|
8
|
+
* Each provider implements this differently based on their log format
|
|
9
|
+
*/
|
|
10
|
+
abstract parseSession(jsonlContent: string, provider: string): ParsedSession;
|
|
11
|
+
/**
|
|
12
|
+
* Get all metric processors for this provider
|
|
13
|
+
* Each provider should return the same set of processors for consistency
|
|
14
|
+
*/
|
|
15
|
+
abstract getMetricProcessors(): BaseMetricProcessor[];
|
|
16
|
+
/**
|
|
17
|
+
* Check if this processor can handle the given content
|
|
18
|
+
* Default implementation just checks if content is valid JSON lines
|
|
19
|
+
*/
|
|
20
|
+
canProcess(content: string): boolean;
|
|
21
|
+
/**
|
|
22
|
+
* Process all metrics for a session
|
|
23
|
+
* This orchestrates running all metric processors sequentially to ensure completion
|
|
24
|
+
* Returns array of ProcessorResults - caller is responsible for storage
|
|
25
|
+
*/
|
|
26
|
+
processMetrics(jsonlContent: string, context: ProcessorContext): Promise<ProcessorResult[]>;
|
|
27
|
+
/**
|
|
28
|
+
* Validate JSONL content format
|
|
29
|
+
*/
|
|
30
|
+
protected validateJsonlContent(content: string): void;
|
|
31
|
+
/**
|
|
32
|
+
* Extract timestamps from raw message data
|
|
33
|
+
* Helper method for providers to implement
|
|
34
|
+
*/
|
|
35
|
+
protected parseTimestamp(timestampStr: string | undefined): Date | null;
|
|
36
|
+
/**
|
|
37
|
+
* Calculate session duration from start and end times
|
|
38
|
+
*/
|
|
39
|
+
protected calculateDuration(startTime: Date | null, endTime: Date | null): number;
|
|
40
|
+
/**
|
|
41
|
+
* Generate a unique message ID if not provided
|
|
42
|
+
*/
|
|
43
|
+
protected generateMessageId(index: number, timestamp?: Date): string;
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=provider-processor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider-processor.d.ts","sourceRoot":"","sources":["../../../../src/processors/base/provider-processor.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAA;AAChE,OAAO,KAAK,EAAE,aAAa,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAElF,8BAAsB,qBAAqB;IACzC,QAAQ,CAAC,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAA;IACtC,QAAQ,CAAC,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAA;IAErC;;;OAGG;IACH,QAAQ,CAAC,YAAY,CAAC,YAAY,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,aAAa;IAE5E;;;OAGG;IACH,QAAQ,CAAC,mBAAmB,IAAI,mBAAmB,EAAE;IAErD;;;OAGG;IACH,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAapC;;;;OAIG;IACG,cAAc,CAClB,YAAY,EAAE,MAAM,EACpB,OAAO,EAAE,gBAAgB,GACxB,OAAO,CAAC,eAAe,EAAE,CAAC;IAgC7B;;OAEG;IACH,SAAS,CAAC,oBAAoB,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAqBrD;;;OAGG;IACH,SAAS,CAAC,cAAc,CAAC,YAAY,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI,GAAG,IAAI;IAcvE;;OAEG;IACH,SAAS,CAAC,iBAAiB,CAAC,SAAS,EAAE,IAAI,GAAG,IAAI,EAAE,OAAO,EAAE,IAAI,GAAG,IAAI,GAAG,MAAM;IAKjF;;OAEG;IACH,SAAS,CAAC,iBAAiB,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,IAAI,GAAG,MAAM;CAIrE"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
export class BaseProviderProcessor {
|
|
2
|
+
/**
|
|
3
|
+
* Check if this processor can handle the given content
|
|
4
|
+
* Default implementation just checks if content is valid JSON lines
|
|
5
|
+
*/
|
|
6
|
+
canProcess(content) {
|
|
7
|
+
try {
|
|
8
|
+
const lines = content.split('\n').filter(line => line.trim());
|
|
9
|
+
if (lines.length === 0)
|
|
10
|
+
return false;
|
|
11
|
+
// Try to parse first line as JSON to verify format
|
|
12
|
+
JSON.parse(lines[0]);
|
|
13
|
+
return true;
|
|
14
|
+
}
|
|
15
|
+
catch {
|
|
16
|
+
return false;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Process all metrics for a session
|
|
21
|
+
* This orchestrates running all metric processors sequentially to ensure completion
|
|
22
|
+
* Returns array of ProcessorResults - caller is responsible for storage
|
|
23
|
+
*/
|
|
24
|
+
async processMetrics(jsonlContent, context) {
|
|
25
|
+
const session = this.parseSession(jsonlContent, context.provider);
|
|
26
|
+
const processors = this.getMetricProcessors();
|
|
27
|
+
// Run all processors sequentially to ensure each completes before the next
|
|
28
|
+
const successfulResults = [];
|
|
29
|
+
for (const processor of processors) {
|
|
30
|
+
try {
|
|
31
|
+
if (!processor.canProcess(session)) {
|
|
32
|
+
continue;
|
|
33
|
+
}
|
|
34
|
+
const result = await processor.processToResult(session);
|
|
35
|
+
if (!result || !result.metrics) {
|
|
36
|
+
continue;
|
|
37
|
+
}
|
|
38
|
+
successfulResults.push(result);
|
|
39
|
+
}
|
|
40
|
+
catch (_error) {
|
|
41
|
+
// Silently continue on processor errors
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
if (successfulResults.length === 0) {
|
|
45
|
+
console.error(`⚠ WARNING: NO processors succeeded for session ${context.sessionId}!`);
|
|
46
|
+
}
|
|
47
|
+
return successfulResults;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Validate JSONL content format
|
|
51
|
+
*/
|
|
52
|
+
validateJsonlContent(content) {
|
|
53
|
+
if (!content || content.trim().length === 0) {
|
|
54
|
+
throw new Error('Content is empty');
|
|
55
|
+
}
|
|
56
|
+
const lines = content.split('\n').filter(line => line.trim());
|
|
57
|
+
if (lines.length === 0) {
|
|
58
|
+
throw new Error('No valid lines found in content');
|
|
59
|
+
}
|
|
60
|
+
// Validate first few lines as JSON
|
|
61
|
+
const linesToCheck = Math.min(3, lines.length);
|
|
62
|
+
for (let i = 0; i < linesToCheck; i++) {
|
|
63
|
+
try {
|
|
64
|
+
JSON.parse(lines[i]);
|
|
65
|
+
}
|
|
66
|
+
catch (_error) {
|
|
67
|
+
throw new Error(`Invalid JSON on line ${i + 1}: ${lines[i]}`);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Extract timestamps from raw message data
|
|
73
|
+
* Helper method for providers to implement
|
|
74
|
+
*/
|
|
75
|
+
parseTimestamp(timestampStr) {
|
|
76
|
+
if (!timestampStr)
|
|
77
|
+
return null;
|
|
78
|
+
try {
|
|
79
|
+
const date = new Date(timestampStr);
|
|
80
|
+
if (Number.isNaN(date.getTime())) {
|
|
81
|
+
return null;
|
|
82
|
+
}
|
|
83
|
+
return date;
|
|
84
|
+
}
|
|
85
|
+
catch (_error) {
|
|
86
|
+
return null;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Calculate session duration from start and end times
|
|
91
|
+
*/
|
|
92
|
+
calculateDuration(startTime, endTime) {
|
|
93
|
+
if (!startTime || !endTime)
|
|
94
|
+
return 0;
|
|
95
|
+
return Math.max(0, endTime.getTime() - startTime.getTime());
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Generate a unique message ID if not provided
|
|
99
|
+
*/
|
|
100
|
+
generateMessageId(index, timestamp) {
|
|
101
|
+
const time = timestamp ? timestamp.getTime() : Date.now();
|
|
102
|
+
return `msg_${time}_${index}`;
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
//# sourceMappingURL=provider-processor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider-processor.js","sourceRoot":"","sources":["../../../../src/processors/base/provider-processor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/processors/base/types.ts"],"names":[],"mappings":"AACA,YAAY,EACV,aAAa,EACb,aAAa,EACb,eAAe,EACf,gBAAgB,EAChB,gBAAgB,EAChB,UAAU,EACV,kBAAkB,GACnB,MAAM,kBAAkB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/processors/base/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Unified Canonical Session Processor
|
|
3
|
+
*
|
|
4
|
+
* Single processor that works for all providers using the canonical format.
|
|
5
|
+
* Consolidates 5+ provider-specific processors into one.
|
|
6
|
+
*/
|
|
7
|
+
import { type BaseMetricProcessor, BaseProviderProcessor } from '../base/index.js';
|
|
8
|
+
import { CanonicalContextProcessor } from './metrics/context.js';
|
|
9
|
+
import { CanonicalEngagementProcessor } from './metrics/engagement.js';
|
|
10
|
+
import { CanonicalErrorProcessor } from './metrics/error.js';
|
|
11
|
+
import { CanonicalPerformanceProcessor } from './metrics/performance.js';
|
|
12
|
+
import { CanonicalQualityProcessor } from './metrics/quality.js';
|
|
13
|
+
import { CanonicalUsageProcessor } from './metrics/usage.js';
|
|
14
|
+
export declare class CanonicalSessionProcessor extends BaseProviderProcessor {
|
|
15
|
+
readonly providerName = "canonical";
|
|
16
|
+
readonly description = "Unified session processor for all providers using canonical format";
|
|
17
|
+
private parser;
|
|
18
|
+
private metricProcessors;
|
|
19
|
+
constructor();
|
|
20
|
+
parseSession(jsonlContent: string, _provider: string): import("../../index.js").ParsedSession;
|
|
21
|
+
getMetricProcessors(): BaseMetricProcessor[];
|
|
22
|
+
}
|
|
23
|
+
export { CanonicalEngagementProcessor, CanonicalUsageProcessor, CanonicalQualityProcessor, CanonicalPerformanceProcessor, CanonicalErrorProcessor, CanonicalContextProcessor, };
|
|
24
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/processors/canonical/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,EAAE,KAAK,mBAAmB,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAA;AAClF,OAAO,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAA;AAChE,OAAO,EAAE,4BAA4B,EAAE,MAAM,yBAAyB,CAAA;AACtE,OAAO,EAAE,uBAAuB,EAAE,MAAM,oBAAoB,CAAA;AAC5D,OAAO,EAAE,6BAA6B,EAAE,MAAM,0BAA0B,CAAA;AACxE,OAAO,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAA;AAChE,OAAO,EAAE,uBAAuB,EAAE,MAAM,oBAAoB,CAAA;AAE5D,qBAAa,yBAA0B,SAAQ,qBAAqB;IAClE,QAAQ,CAAC,YAAY,eAAc;IACnC,QAAQ,CAAC,WAAW,wEAAuE;IAE3F,OAAO,CAAC,MAAM,CAAwB;IACtC,OAAO,CAAC,gBAAgB,CAAuB;;IAgB/C,YAAY,CAAC,YAAY,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM;IAKpD,mBAAmB,IAAI,mBAAmB,EAAE;CAG7C;AAGD,OAAO,EACL,4BAA4B,EAC5B,uBAAuB,EACvB,yBAAyB,EACzB,6BAA6B,EAC7B,uBAAuB,EACvB,yBAAyB,GAC1B,CAAA"}
|