@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,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ScrollToTopButton = ScrollToTopButton;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
/**
|
|
6
|
+
* ScrollToTopButton - Floating button that appears when user scrolls down
|
|
7
|
+
*
|
|
8
|
+
* Features:
|
|
9
|
+
* - Only appears after scrolling down 300px
|
|
10
|
+
* - Positioned at bottom-right with fixed positioning
|
|
11
|
+
* - Smooth scroll animation to top
|
|
12
|
+
* - Fade in/out transition
|
|
13
|
+
*/
|
|
14
|
+
const react_1 = require("react");
|
|
15
|
+
function ScrollToTopButton({ threshold = 300, scrollContainer = 'main', }) {
|
|
16
|
+
const [isVisible, setIsVisible] = (0, react_1.useState)(false);
|
|
17
|
+
(0, react_1.useEffect)(() => {
|
|
18
|
+
const container = document.querySelector(scrollContainer);
|
|
19
|
+
const handleScroll = () => {
|
|
20
|
+
let scrollTop = 0;
|
|
21
|
+
// Try container scroll first
|
|
22
|
+
if (container && container.scrollTop > 0) {
|
|
23
|
+
scrollTop = container.scrollTop;
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
// Fallback to window scroll
|
|
27
|
+
scrollTop = window.pageYOffset || document.documentElement.scrollTop;
|
|
28
|
+
}
|
|
29
|
+
setIsVisible(scrollTop > threshold);
|
|
30
|
+
};
|
|
31
|
+
// Check initial scroll position
|
|
32
|
+
handleScroll();
|
|
33
|
+
// Add scroll listeners to both container (if exists) and window
|
|
34
|
+
if (container) {
|
|
35
|
+
container.addEventListener('scroll', handleScroll);
|
|
36
|
+
}
|
|
37
|
+
window.addEventListener('scroll', handleScroll);
|
|
38
|
+
return () => {
|
|
39
|
+
if (container) {
|
|
40
|
+
container.removeEventListener('scroll', handleScroll);
|
|
41
|
+
}
|
|
42
|
+
window.removeEventListener('scroll', handleScroll);
|
|
43
|
+
};
|
|
44
|
+
}, [scrollContainer, threshold]);
|
|
45
|
+
const scrollToTop = () => {
|
|
46
|
+
const container = document.querySelector(scrollContainer);
|
|
47
|
+
if (container) {
|
|
48
|
+
container.scrollTo({
|
|
49
|
+
top: 0,
|
|
50
|
+
behavior: 'smooth',
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
// Fallback to window scroll
|
|
54
|
+
window.scrollTo({
|
|
55
|
+
top: 0,
|
|
56
|
+
behavior: 'smooth',
|
|
57
|
+
});
|
|
58
|
+
};
|
|
59
|
+
if (!isVisible)
|
|
60
|
+
return null;
|
|
61
|
+
return ((0, jsx_runtime_1.jsx)("button", { type: "button", onClick: scrollToTop, className: "fixed bottom-6 right-6 z-50 btn btn-circle btn-primary shadow-lg hover:shadow-xl transition-all duration-300 animate-fade-in", title: "Scroll to top", "aria-label": "Scroll to top", children: (0, jsx_runtime_1.jsx)("svg", { className: "w-6 h-6", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: (0, jsx_runtime_1.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M5 10l7-7m0 0l7 7m-7-7v18" }) }) }));
|
|
62
|
+
}
|
|
63
|
+
//# sourceMappingURL=ScrollToTopButton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ScrollToTopButton.js","sourceRoot":"","sources":["../../../../src/ui/components/ScrollToTopButton.tsx"],"names":[],"mappings":";;AAoBA,8CA2EC;;AA/FD;;;;;;;;GAQG;AAEH,iCAA2C;AAU3C,SAAgB,iBAAiB,CAAC,EAChC,SAAS,GAAG,GAAG,EACf,eAAe,GAAG,MAAM,GACD;IACvB,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,IAAA,gBAAQ,EAAC,KAAK,CAAC,CAAA;IAEjD,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,MAAM,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,eAAe,CAAC,CAAA;QAEzD,MAAM,YAAY,GAAG,GAAG,EAAE;YACxB,IAAI,SAAS,GAAG,CAAC,CAAA;YAEjB,6BAA6B;YAC7B,IAAI,SAAS,IAAI,SAAS,CAAC,SAAS,GAAG,CAAC,EAAE,CAAC;gBACzC,SAAS,GAAG,SAAS,CAAC,SAAS,CAAA;YACjC,CAAC;iBAAM,CAAC;gBACN,4BAA4B;gBAC5B,SAAS,GAAG,MAAM,CAAC,WAAW,IAAI,QAAQ,CAAC,eAAe,CAAC,SAAS,CAAA;YACtE,CAAC;YAED,YAAY,CAAC,SAAS,GAAG,SAAS,CAAC,CAAA;QACrC,CAAC,CAAA;QAED,gCAAgC;QAChC,YAAY,EAAE,CAAA;QAEd,gEAAgE;QAChE,IAAI,SAAS,EAAE,CAAC;YACd,SAAS,CAAC,gBAAgB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;QACpD,CAAC;QACD,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;QAE/C,OAAO,GAAG,EAAE;YACV,IAAI,SAAS,EAAE,CAAC;gBACd,SAAS,CAAC,mBAAmB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;YACvD,CAAC;YACD,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;QACpD,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,eAAe,EAAE,SAAS,CAAC,CAAC,CAAA;IAEhC,MAAM,WAAW,GAAG,GAAG,EAAE;QACvB,MAAM,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,eAAe,CAAC,CAAA;QACzD,IAAI,SAAS,EAAE,CAAC;YACd,SAAS,CAAC,QAAQ,CAAC;gBACjB,GAAG,EAAE,CAAC;gBACN,QAAQ,EAAE,QAAQ;aACnB,CAAC,CAAA;QACJ,CAAC;QACD,4BAA4B;QAC5B,MAAM,CAAC,QAAQ,CAAC;YACd,GAAG,EAAE,CAAC;YACN,QAAQ,EAAE,QAAQ;SACnB,CAAC,CAAA;IACJ,CAAC,CAAA;IAED,IAAI,CAAC,SAAS;QAAE,OAAO,IAAI,CAAA;IAE3B,OAAO,CACL,mCACE,IAAI,EAAC,QAAQ,EACb,OAAO,EAAE,WAAW,EACpB,SAAS,EAAC,8HAA8H,EACxI,KAAK,EAAC,eAAe,gBACV,eAAe,YAE1B,gCAAK,SAAS,EAAC,SAAS,EAAC,IAAI,EAAC,MAAM,EAAC,MAAM,EAAC,cAAc,EAAC,OAAO,EAAC,WAAW,YAC5E,iCACE,aAAa,EAAC,OAAO,EACrB,cAAc,EAAC,OAAO,EACtB,WAAW,EAAE,CAAC,EACd,CAAC,EAAC,2BAA2B,GAC7B,GACE,GACC,CACV,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SessionCard - Display card for a single session
|
|
3
|
+
*
|
|
4
|
+
* CONVERTED TO PROPS-BASED: This component requires the following to be passed as props:
|
|
5
|
+
* - session data
|
|
6
|
+
* - isActive state (from WebSocket or other real-time source)
|
|
7
|
+
* - ProviderIcon component (for rendering provider icons)
|
|
8
|
+
* - Event handlers for interactions
|
|
9
|
+
*
|
|
10
|
+
* The parent component should handle:
|
|
11
|
+
* - WebSocket connection for live session status
|
|
12
|
+
* - Navigation
|
|
13
|
+
* - Provider icon rendering
|
|
14
|
+
*/
|
|
15
|
+
import type { SessionRating } from '../../utils/rating.js';
|
|
16
|
+
interface AgentSession {
|
|
17
|
+
id: string;
|
|
18
|
+
sessionId: string;
|
|
19
|
+
provider: string;
|
|
20
|
+
username: string;
|
|
21
|
+
repositoryName: string;
|
|
22
|
+
sessionStartTime: string | null;
|
|
23
|
+
sessionEndTime: string | null;
|
|
24
|
+
fileName?: string | null;
|
|
25
|
+
filePath?: string | null;
|
|
26
|
+
fileSize: number | null;
|
|
27
|
+
durationMs: number | null;
|
|
28
|
+
processingStatus: string;
|
|
29
|
+
assessmentStatus: string;
|
|
30
|
+
assessmentRating?: string | null;
|
|
31
|
+
aiModelSummary?: string | null;
|
|
32
|
+
aiModelQualityScore?: number | null;
|
|
33
|
+
createdAt: string;
|
|
34
|
+
syncedToServer?: boolean;
|
|
35
|
+
syncFailedReason?: string | null;
|
|
36
|
+
gitBranch?: string | null;
|
|
37
|
+
firstCommitHash?: string | null;
|
|
38
|
+
latestCommitHash?: string | null;
|
|
39
|
+
}
|
|
40
|
+
interface SessionCardProps {
|
|
41
|
+
session: AgentSession;
|
|
42
|
+
isSelected?: boolean;
|
|
43
|
+
isActive?: boolean;
|
|
44
|
+
onSelect?: (checked: boolean) => void;
|
|
45
|
+
onViewSession?: (sessionId: string) => void;
|
|
46
|
+
onProcessSession?: (sessionId: string) => void;
|
|
47
|
+
onAssessSession?: (sessionId: string) => void;
|
|
48
|
+
onRateSession?: (sessionId: string, rating: SessionRating) => void | Promise<void>;
|
|
49
|
+
onSyncSession?: (sessionId: string) => void;
|
|
50
|
+
onShowSyncError?: (sessionId: string, error: string) => void;
|
|
51
|
+
isProcessing?: boolean;
|
|
52
|
+
ProviderIcon: React.ComponentType<{
|
|
53
|
+
providerId: string;
|
|
54
|
+
size: number;
|
|
55
|
+
className?: string;
|
|
56
|
+
}>;
|
|
57
|
+
}
|
|
58
|
+
declare function SessionCard({ session, isSelected, isActive, onSelect, onViewSession, onProcessSession, onAssessSession, onRateSession, onSyncSession, onShowSyncError, isProcessing, ProviderIcon, }: SessionCardProps): import("react/jsx-runtime.js").JSX.Element;
|
|
59
|
+
export default SessionCard;
|
|
60
|
+
//# sourceMappingURL=SessionCard.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SessionCard.d.ts","sourceRoot":"","sources":["../../../../src/ui/components/SessionCard.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AASH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAA;AAG1D,UAAU,YAAY;IACpB,EAAE,EAAE,MAAM,CAAA;IACV,SAAS,EAAE,MAAM,CAAA;IACjB,QAAQ,EAAE,MAAM,CAAA;IAChB,QAAQ,EAAE,MAAM,CAAA;IAChB,cAAc,EAAE,MAAM,CAAA;IACtB,gBAAgB,EAAE,MAAM,GAAG,IAAI,CAAA;IAC/B,cAAc,EAAE,MAAM,GAAG,IAAI,CAAA;IAC7B,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,UAAU,EAAE,MAAM,GAAG,IAAI,CAAA;IACzB,gBAAgB,EAAE,MAAM,CAAA;IACxB,gBAAgB,EAAE,MAAM,CAAA;IACxB,gBAAgB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IAChC,cAAc,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IAC9B,mBAAmB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACnC,SAAS,EAAE,MAAM,CAAA;IACjB,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,gBAAgB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IAChC,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACzB,eAAe,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IAC/B,gBAAgB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;CACjC;AAED,UAAU,gBAAgB;IACxB,OAAO,EAAE,YAAY,CAAA;IACrB,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,QAAQ,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,CAAA;IACrC,aAAa,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAA;IAC3C,gBAAgB,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAA;IAC9C,eAAe,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAA;IAC7C,aAAa,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,aAAa,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAClF,aAAa,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAA;IAC3C,eAAe,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IAC5D,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,YAAY,EAAE,KAAK,CAAC,aAAa,CAAC;QAAE,UAAU,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,SAAS,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAA;CAC5F;AAED,iBAAS,WAAW,CAAC,EACnB,OAAO,EACP,UAAkB,EAClB,QAAgB,EAChB,QAAQ,EACR,aAAa,EACb,gBAAgB,EAChB,eAAe,EACf,aAAa,EACb,aAAa,EACb,eAAe,EACf,YAAoB,EACpB,YAAY,GACb,EAAE,gBAAgB,8CAialB;AAED,eAAe,WAAW,CAAA"}
|
|
@@ -0,0 +1,252 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
4
|
+
/**
|
|
5
|
+
* SessionCard - Display card for a single session
|
|
6
|
+
*
|
|
7
|
+
* CONVERTED TO PROPS-BASED: This component requires the following to be passed as props:
|
|
8
|
+
* - session data
|
|
9
|
+
* - isActive state (from WebSocket or other real-time source)
|
|
10
|
+
* - ProviderIcon component (for rendering provider icons)
|
|
11
|
+
* - Event handlers for interactions
|
|
12
|
+
*
|
|
13
|
+
* The parent component should handle:
|
|
14
|
+
* - WebSocket connection for live session status
|
|
15
|
+
* - Navigation
|
|
16
|
+
* - Provider icon rendering
|
|
17
|
+
*/
|
|
18
|
+
const outline_1 = require("@heroicons/react/24/outline");
|
|
19
|
+
const RatingBadge_js_1 = require("./RatingBadge.js");
|
|
20
|
+
function SessionCard({ session, isSelected = false, isActive = false, onSelect, onViewSession, onProcessSession, onAssessSession, onRateSession, onSyncSession, onShowSyncError, isProcessing = false, ProviderIcon, }) {
|
|
21
|
+
// Determine if processing from session status if not explicitly provided
|
|
22
|
+
const actuallyProcessing = isProcessing || session.processingStatus === 'processing';
|
|
23
|
+
const _formatDate = (dateString) => {
|
|
24
|
+
if (!dateString)
|
|
25
|
+
return 'N/A';
|
|
26
|
+
return new Date(dateString).toLocaleString();
|
|
27
|
+
};
|
|
28
|
+
const formatTime = (dateString) => {
|
|
29
|
+
if (!dateString)
|
|
30
|
+
return 'N/A';
|
|
31
|
+
return new Date(dateString).toLocaleTimeString();
|
|
32
|
+
};
|
|
33
|
+
const formatShortDate = (dateString) => {
|
|
34
|
+
if (!dateString)
|
|
35
|
+
return 'N/A';
|
|
36
|
+
return new Date(dateString).toLocaleDateString('en-US', {
|
|
37
|
+
month: 'short',
|
|
38
|
+
day: 'numeric',
|
|
39
|
+
});
|
|
40
|
+
};
|
|
41
|
+
const formatFileSize = (bytes) => {
|
|
42
|
+
if (bytes === null || bytes === undefined)
|
|
43
|
+
return null;
|
|
44
|
+
if (bytes === 0)
|
|
45
|
+
return '0 B';
|
|
46
|
+
const k = 1024;
|
|
47
|
+
const sizes = ['B', 'KB', 'MB', 'GB'];
|
|
48
|
+
const i = Math.floor(Math.log(bytes) / Math.log(k));
|
|
49
|
+
return `${Number.parseFloat((bytes / k ** i).toFixed(1))} ${sizes[i]}`;
|
|
50
|
+
};
|
|
51
|
+
const formatDuration = (durationMs) => {
|
|
52
|
+
if (!durationMs)
|
|
53
|
+
return 'N/A';
|
|
54
|
+
const seconds = Math.floor(durationMs / 1000);
|
|
55
|
+
const minutes = Math.floor(seconds / 60);
|
|
56
|
+
const hours = Math.floor(minutes / 60);
|
|
57
|
+
if (hours > 0) {
|
|
58
|
+
return `${hours}h ${minutes % 60}m`;
|
|
59
|
+
}
|
|
60
|
+
if (minutes > 0) {
|
|
61
|
+
return `${minutes}m ${seconds % 60}s`;
|
|
62
|
+
}
|
|
63
|
+
return `${seconds}s`;
|
|
64
|
+
};
|
|
65
|
+
const formatCommitRange = () => {
|
|
66
|
+
const firstCommit = session.firstCommitHash?.substring(0, 7);
|
|
67
|
+
const latestCommit = session.latestCommitHash?.substring(0, 7);
|
|
68
|
+
if (!firstCommit)
|
|
69
|
+
return null;
|
|
70
|
+
// If no latest commit or same as first, show "UNSTAGED" pattern
|
|
71
|
+
if (!latestCommit || firstCommit === latestCommit) {
|
|
72
|
+
return ((0, jsx_runtime_1.jsxs)("span", { className: "font-mono text-xs", title: `Unstaged changes from ${session.firstCommitHash}`, children: [firstCommit, " \u2192 ", (0, jsx_runtime_1.jsx)("span", { className: "text-base-content/60", children: "UNSTAGED" })] }));
|
|
73
|
+
}
|
|
74
|
+
// Show commit range
|
|
75
|
+
return ((0, jsx_runtime_1.jsxs)("span", { className: "font-mono text-xs", title: `Changes from ${session.firstCommitHash} to ${session.latestCommitHash}`, children: [firstCommit, " \u2192 ", latestCommit] }));
|
|
76
|
+
};
|
|
77
|
+
const handleCheckboxChange = (e) => {
|
|
78
|
+
e.stopPropagation(); // Prevent card click when checking checkbox
|
|
79
|
+
if (onSelect) {
|
|
80
|
+
onSelect(e.target.checked);
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
const handleCheckboxClick = (e) => {
|
|
84
|
+
e.stopPropagation(); // Prevent card click when clicking checkbox area
|
|
85
|
+
};
|
|
86
|
+
const handleProcessClick = (e) => {
|
|
87
|
+
e.preventDefault();
|
|
88
|
+
e.stopPropagation();
|
|
89
|
+
if (onProcessSession) {
|
|
90
|
+
onProcessSession(session.sessionId);
|
|
91
|
+
}
|
|
92
|
+
};
|
|
93
|
+
const _handleAssessClick = (e) => {
|
|
94
|
+
e.preventDefault();
|
|
95
|
+
e.stopPropagation();
|
|
96
|
+
if (onAssessSession) {
|
|
97
|
+
onAssessSession(session.sessionId);
|
|
98
|
+
}
|
|
99
|
+
};
|
|
100
|
+
const handleRate = (rating) => {
|
|
101
|
+
if (onRateSession) {
|
|
102
|
+
onRateSession(session.sessionId, rating);
|
|
103
|
+
}
|
|
104
|
+
};
|
|
105
|
+
const handleSyncClick = (e) => {
|
|
106
|
+
e.preventDefault();
|
|
107
|
+
e.stopPropagation();
|
|
108
|
+
// If there's a sync error, show it
|
|
109
|
+
if (session.syncFailedReason && onShowSyncError) {
|
|
110
|
+
onShowSyncError(session.sessionId, session.syncFailedReason);
|
|
111
|
+
}
|
|
112
|
+
// If not synced and no error, trigger sync
|
|
113
|
+
else if (!session.syncedToServer && onSyncSession) {
|
|
114
|
+
onSyncSession(session.sessionId);
|
|
115
|
+
}
|
|
116
|
+
};
|
|
117
|
+
const handleCardClick = () => {
|
|
118
|
+
if (onViewSession) {
|
|
119
|
+
onViewSession(session.sessionId);
|
|
120
|
+
}
|
|
121
|
+
};
|
|
122
|
+
const getProcessingStatusInfo = (status) => {
|
|
123
|
+
// For metrics-only sessions (no transcript file), show as "Metrics Only" with green styling
|
|
124
|
+
// We check filePath instead of fileSize since fileSize is now sent for analytics even in metrics-only mode
|
|
125
|
+
const isMetricsOnly = !session.filePath;
|
|
126
|
+
if (isMetricsOnly) {
|
|
127
|
+
return {
|
|
128
|
+
icon: (0, jsx_runtime_1.jsx)(outline_1.ChartBarIcon, { className: "w-4 h-4", strokeWidth: 2 }),
|
|
129
|
+
color: 'text-success',
|
|
130
|
+
bgColor: 'bg-success/20',
|
|
131
|
+
label: 'Metrics Only - No transcript file to process',
|
|
132
|
+
clickable: false,
|
|
133
|
+
};
|
|
134
|
+
}
|
|
135
|
+
switch (status) {
|
|
136
|
+
case 'pending':
|
|
137
|
+
return {
|
|
138
|
+
icon: (0, jsx_runtime_1.jsx)(outline_1.SparklesIcon, { className: "w-4 h-4", strokeWidth: 2 }),
|
|
139
|
+
color: 'text-base-content/30',
|
|
140
|
+
bgColor: 'bg-base-200',
|
|
141
|
+
label: 'Pending AI Processing',
|
|
142
|
+
clickable: true,
|
|
143
|
+
};
|
|
144
|
+
case 'processing':
|
|
145
|
+
return {
|
|
146
|
+
icon: null, // Will use loading spinner instead
|
|
147
|
+
color: 'text-info',
|
|
148
|
+
bgColor: 'bg-info/20',
|
|
149
|
+
label: 'AI Processing...',
|
|
150
|
+
clickable: false,
|
|
151
|
+
};
|
|
152
|
+
case 'completed':
|
|
153
|
+
return {
|
|
154
|
+
icon: (0, jsx_runtime_1.jsx)(outline_1.SparklesIcon, { className: "w-4 h-4", strokeWidth: 2 }),
|
|
155
|
+
color: 'text-success',
|
|
156
|
+
bgColor: 'bg-success/20',
|
|
157
|
+
label: 'AI Processed',
|
|
158
|
+
clickable: true,
|
|
159
|
+
};
|
|
160
|
+
case 'failed':
|
|
161
|
+
return {
|
|
162
|
+
icon: (0, jsx_runtime_1.jsx)(outline_1.XCircleIcon, { className: "w-4 h-4", strokeWidth: 2 }),
|
|
163
|
+
color: 'text-error',
|
|
164
|
+
bgColor: 'bg-error/20',
|
|
165
|
+
label: 'AI Processing Failed',
|
|
166
|
+
clickable: true,
|
|
167
|
+
};
|
|
168
|
+
default:
|
|
169
|
+
return {
|
|
170
|
+
icon: (0, jsx_runtime_1.jsx)(outline_1.SparklesIcon, { className: "w-4 h-4", strokeWidth: 2 }),
|
|
171
|
+
color: 'text-base-content/30',
|
|
172
|
+
bgColor: 'bg-base-200',
|
|
173
|
+
label: 'Pending AI Processing',
|
|
174
|
+
clickable: true,
|
|
175
|
+
};
|
|
176
|
+
}
|
|
177
|
+
};
|
|
178
|
+
const getAssessmentStatusInfo = (status) => {
|
|
179
|
+
switch (status) {
|
|
180
|
+
case 'completed':
|
|
181
|
+
return {
|
|
182
|
+
icon: '✓',
|
|
183
|
+
color: 'text-success',
|
|
184
|
+
bgColor: 'bg-success/10',
|
|
185
|
+
label: 'Assessment Complete',
|
|
186
|
+
clickable: false,
|
|
187
|
+
};
|
|
188
|
+
case 'in_progress':
|
|
189
|
+
return {
|
|
190
|
+
icon: '📝',
|
|
191
|
+
color: 'text-info',
|
|
192
|
+
bgColor: 'bg-info/10',
|
|
193
|
+
label: 'Assessment In Progress',
|
|
194
|
+
clickable: true,
|
|
195
|
+
};
|
|
196
|
+
default:
|
|
197
|
+
return {
|
|
198
|
+
icon: '📋',
|
|
199
|
+
color: 'text-base-content/40',
|
|
200
|
+
bgColor: 'bg-base-200',
|
|
201
|
+
label: 'Assess Session',
|
|
202
|
+
clickable: true,
|
|
203
|
+
};
|
|
204
|
+
}
|
|
205
|
+
};
|
|
206
|
+
const getSyncStatusInfo = () => {
|
|
207
|
+
// Priority: error > synced > not synced
|
|
208
|
+
if (session.syncFailedReason) {
|
|
209
|
+
return {
|
|
210
|
+
icon: (0, jsx_runtime_1.jsx)(outline_1.ExclamationTriangleIcon, { className: "w-4 h-4", strokeWidth: 2 }),
|
|
211
|
+
color: 'text-error',
|
|
212
|
+
bgColor: 'bg-error/20',
|
|
213
|
+
label: 'Sync Failed - Click to view error',
|
|
214
|
+
clickable: true,
|
|
215
|
+
};
|
|
216
|
+
}
|
|
217
|
+
if (session.syncedToServer) {
|
|
218
|
+
return {
|
|
219
|
+
icon: (0, jsx_runtime_1.jsx)(outline_1.CloudArrowUpIcon, { className: "w-4 h-4", strokeWidth: 2 }),
|
|
220
|
+
color: 'text-success',
|
|
221
|
+
bgColor: 'bg-success/20',
|
|
222
|
+
label: 'Synced to server',
|
|
223
|
+
clickable: false,
|
|
224
|
+
};
|
|
225
|
+
}
|
|
226
|
+
return {
|
|
227
|
+
icon: (0, jsx_runtime_1.jsx)(outline_1.CloudArrowUpIcon, { className: "w-4 h-4", strokeWidth: 2 }),
|
|
228
|
+
color: 'text-base-content/30',
|
|
229
|
+
bgColor: 'bg-base-200',
|
|
230
|
+
label: 'Click to sync to server',
|
|
231
|
+
clickable: true,
|
|
232
|
+
};
|
|
233
|
+
};
|
|
234
|
+
const processingInfo = getProcessingStatusInfo(session.processingStatus);
|
|
235
|
+
const _assessmentInfo = getAssessmentStatusInfo(session.assessmentStatus);
|
|
236
|
+
const syncInfo = getSyncStatusInfo();
|
|
237
|
+
// Render the card content
|
|
238
|
+
const CardContent = ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [isActive && ((0, jsx_runtime_1.jsx)("div", { className: "absolute -top-2 -right-2 z-10", children: (0, jsx_runtime_1.jsx)("div", { className: "relative", children: (0, jsx_runtime_1.jsxs)("span", { className: "flex h-5 w-5", children: [(0, jsx_runtime_1.jsx)("span", { className: "animate-ping absolute inline-flex h-full w-full rounded-full bg-success opacity-75" }), (0, jsx_runtime_1.jsx)("span", { className: "relative inline-flex rounded-full h-5 w-5 bg-success items-center justify-center", children: (0, jsx_runtime_1.jsx)("span", { className: "text-[10px] font-bold text-white", children: "\u25CF" }) })] }) }) })), (0, jsx_runtime_1.jsxs)("div", { className: "flex items-center gap-3 flex-1 min-w-0", children: [onSelect && ((0, jsx_runtime_1.jsx)("div", { className: "shrink-0", onClick: handleCheckboxClick, children: (0, jsx_runtime_1.jsx)("input", { type: "checkbox", className: "checkbox checkbox-sm cursor-pointer", checked: isSelected, onChange: handleCheckboxChange }) })), (0, jsx_runtime_1.jsxs)("div", { className: "flex flex-col md:flex-row md:items-center gap-2 md:gap-3 flex-1 min-w-0", children: [(0, jsx_runtime_1.jsxs)("div", { className: "flex items-center gap-2 shrink-0", children: [(0, jsx_runtime_1.jsx)(ProviderIcon, { providerId: session.provider, size: 16 }), isActive && ((0, jsx_runtime_1.jsxs)("span", { className: "badge badge-success badge-xs gap-1 animate-pulse", children: [(0, jsx_runtime_1.jsx)("span", { className: "w-2 h-2 rounded-full bg-white" }), "LIVE"] })), session.username && session.username.trim() !== '' && ((0, jsx_runtime_1.jsxs)("div", { className: "badge badge-ghost badge-sm", children: ["@", session.username] }))] }), (0, jsx_runtime_1.jsx)("div", { className: "flex-1 min-w-0", children: (0, jsx_runtime_1.jsxs)("div", { className: "flex items-center gap-2 flex-wrap", children: [(0, jsx_runtime_1.jsx)("h3", { className: "text-sm font-medium truncate", children: session.repositoryName }), session.gitBranch && ((0, jsx_runtime_1.jsx)("span", { className: "badge badge-ghost badge-xs font-mono", title: "Git branch", children: session.gitBranch })), formatCommitRange()] }) }), (0, jsx_runtime_1.jsxs)("div", { className: "flex flex-wrap md:flex-nowrap items-center gap-2 md:gap-4 text-xs text-base-content/70", children: [session.aiModelQualityScore !== null && session.aiModelQualityScore !== undefined && ((0, jsx_runtime_1.jsxs)("div", { className: "flex items-center gap-1", children: [(0, jsx_runtime_1.jsx)("span", { className: "hidden md:inline", children: "Quality:" }), (0, jsx_runtime_1.jsxs)("span", { className: `font-medium ${session.aiModelQualityScore >= 80
|
|
239
|
+
? 'text-success'
|
|
240
|
+
: session.aiModelQualityScore >= 60
|
|
241
|
+
? 'text-warning'
|
|
242
|
+
: 'text-error'}`, children: [session.aiModelQualityScore, "%"] })] })), session.filePath && formatFileSize(session.fileSize) ? ((0, jsx_runtime_1.jsxs)("div", { className: "flex items-center gap-1", children: [(0, jsx_runtime_1.jsx)("span", { className: "hidden md:inline", children: "Size:" }), (0, jsx_runtime_1.jsx)("span", { className: "font-medium", children: formatFileSize(session.fileSize) })] })) : ((0, jsx_runtime_1.jsx)("div", { className: "badge badge-ghost badge-xs", children: "Metrics Only" })), (0, jsx_runtime_1.jsxs)("div", { className: "flex items-center gap-1", children: [(0, jsx_runtime_1.jsx)("span", { className: "hidden md:inline", children: "Duration:" }), (0, jsx_runtime_1.jsx)("span", { className: "font-medium", children: formatDuration(session.durationMs) })] }), (0, jsx_runtime_1.jsxs)("div", { className: "hidden sm:flex items-center gap-1", children: [(0, jsx_runtime_1.jsx)("span", { children: formatTime(session.sessionStartTime) }), (0, jsx_runtime_1.jsx)("span", { children: "\u2192" }), (0, jsx_runtime_1.jsx)("span", { children: formatTime(session.sessionEndTime) })] }), (0, jsx_runtime_1.jsx)("div", { className: "font-medium", children: formatShortDate(session.sessionStartTime) })] })] }), (0, jsx_runtime_1.jsxs)("div", { className: "flex items-center gap-2 shrink-0", children: [(0, jsx_runtime_1.jsx)("div", { className: `flex items-center justify-center w-7 h-7 md:w-6 md:h-6 rounded-md ${processingInfo.bgColor} ${processingInfo.clickable && !actuallyProcessing
|
|
243
|
+
? 'cursor-pointer hover:scale-110'
|
|
244
|
+
: 'cursor-default'} transition-all tooltip tooltip-left`, "data-tip": actuallyProcessing ? 'Processing...' : processingInfo.label, onClick: processingInfo.clickable && !actuallyProcessing ? handleProcessClick : undefined, children: actuallyProcessing ? ((0, jsx_runtime_1.jsx)("span", { className: "loading loading-spinner loading-xs text-info" })) : ((0, jsx_runtime_1.jsx)("span", { className: processingInfo.color, children: processingInfo.icon })) }), onRateSession && ((0, jsx_runtime_1.jsx)("div", { onClick: e => e.stopPropagation(), className: "flex items-center justify-center", children: (0, jsx_runtime_1.jsx)(RatingBadge_js_1.RatingBadge, { rating: session.assessmentRating || null, onRate: handleRate, disabled: actuallyProcessing, size: "md", compact: true }) })), (onSyncSession || onShowSyncError) && ((0, jsx_runtime_1.jsx)("div", { className: `flex items-center justify-center w-7 h-7 md:w-6 md:h-6 rounded-md ${syncInfo.bgColor} ${syncInfo.clickable ? 'cursor-pointer hover:scale-110' : 'cursor-default'} transition-all tooltip tooltip-left`, "data-tip": syncInfo.label, onClick: syncInfo.clickable ? handleSyncClick : undefined, children: (0, jsx_runtime_1.jsx)("span", { className: syncInfo.color, children: syncInfo.icon }) }))] })] }), session.aiModelSummary && ((0, jsx_runtime_1.jsx)("div", { className: "text-xs text-base-content/60 pl-8 md:pl-12", children: session.aiModelSummary }))] }));
|
|
245
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: `relative flex flex-col gap-3 p-3 bg-base-100 border rounded transition-all ${isSelected
|
|
246
|
+
? 'border-primary bg-primary/5'
|
|
247
|
+
: isActive
|
|
248
|
+
? 'border-2 border-success shadow-lg shadow-success/30'
|
|
249
|
+
: 'border-base-300 hover:shadow-md hover:border-primary/50'} ${onViewSession ? 'cursor-pointer' : ''}`, onClick: onViewSession ? handleCardClick : undefined, children: CardContent }));
|
|
250
|
+
}
|
|
251
|
+
exports.default = SessionCard;
|
|
252
|
+
//# sourceMappingURL=SessionCard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SessionCard.js","sourceRoot":"","sources":["../../../../src/ui/components/SessionCard.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SessionDetailHeader - Shared session detail header component
|
|
3
|
+
*
|
|
4
|
+
* Displays session metadata, stats, and action buttons for session detail pages.
|
|
5
|
+
* Used by both desktop and server apps for consistent UI.
|
|
6
|
+
*/
|
|
7
|
+
import type { SessionRating } from '../../utils/rating.js';
|
|
8
|
+
export interface SessionDetailHeaderProps {
|
|
9
|
+
session: {
|
|
10
|
+
provider: string;
|
|
11
|
+
repositoryName: string;
|
|
12
|
+
sessionStartTime: string | null;
|
|
13
|
+
durationMs: number | null;
|
|
14
|
+
fileSize?: number;
|
|
15
|
+
username?: string;
|
|
16
|
+
userAvatarUrl?: string;
|
|
17
|
+
repository?: {
|
|
18
|
+
name: string;
|
|
19
|
+
gitRemoteUrl?: string;
|
|
20
|
+
cwd?: string;
|
|
21
|
+
};
|
|
22
|
+
cwd?: string;
|
|
23
|
+
aiModelSummary?: string;
|
|
24
|
+
gitBranch?: string;
|
|
25
|
+
firstCommitHash?: string;
|
|
26
|
+
latestCommitHash?: string;
|
|
27
|
+
};
|
|
28
|
+
messageCount?: number;
|
|
29
|
+
rating?: SessionRating | null;
|
|
30
|
+
onRate?: (rating: SessionRating) => void | Promise<void>;
|
|
31
|
+
onProcessSession?: () => void;
|
|
32
|
+
onAssessSession?: () => void;
|
|
33
|
+
onDeleteSession?: () => void;
|
|
34
|
+
onCwdClick?: (path: string) => void | Promise<void>;
|
|
35
|
+
onViewDiff?: () => void | Promise<void>;
|
|
36
|
+
onRepositoryClick?: () => void | Promise<void>;
|
|
37
|
+
processingStatus?: 'pending' | 'processing' | 'completed' | 'failed';
|
|
38
|
+
isProcessing?: boolean;
|
|
39
|
+
assessmentStatus?: 'not_started' | 'rating_only' | 'in_progress' | 'completed';
|
|
40
|
+
processingProgress?: {
|
|
41
|
+
stepName: string;
|
|
42
|
+
percentage: number;
|
|
43
|
+
} | null;
|
|
44
|
+
syncStatus?: {
|
|
45
|
+
synced: boolean;
|
|
46
|
+
failed: boolean;
|
|
47
|
+
reason?: string;
|
|
48
|
+
onSync?: () => void;
|
|
49
|
+
onShowError?: (error: string) => void;
|
|
50
|
+
};
|
|
51
|
+
ProviderIcon: React.ComponentType<{
|
|
52
|
+
providerId: string;
|
|
53
|
+
size: number;
|
|
54
|
+
}>;
|
|
55
|
+
}
|
|
56
|
+
export declare function SessionDetailHeader({ session, messageCount, rating, onRate, onProcessSession, onAssessSession, onDeleteSession, onCwdClick, onViewDiff, onRepositoryClick, processingStatus, isProcessing, assessmentStatus, processingProgress, syncStatus, ProviderIcon, }: SessionDetailHeaderProps): import("react/jsx-runtime.js").JSX.Element;
|
|
57
|
+
//# sourceMappingURL=SessionDetailHeader.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SessionDetailHeader.d.ts","sourceRoot":"","sources":["../../../../src/ui/components/SessionDetailHeader.tsx"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAA;AAG1D,MAAM,WAAW,wBAAwB;IAEvC,OAAO,EAAE;QACP,QAAQ,EAAE,MAAM,CAAA;QAChB,cAAc,EAAE,MAAM,CAAA;QACtB,gBAAgB,EAAE,MAAM,GAAG,IAAI,CAAA;QAC/B,UAAU,EAAE,MAAM,GAAG,IAAI,CAAA;QACzB,QAAQ,CAAC,EAAE,MAAM,CAAA;QACjB,QAAQ,CAAC,EAAE,MAAM,CAAA;QACjB,aAAa,CAAC,EAAE,MAAM,CAAA;QACtB,UAAU,CAAC,EAAE;YACX,IAAI,EAAE,MAAM,CAAA;YACZ,YAAY,CAAC,EAAE,MAAM,CAAA;YACrB,GAAG,CAAC,EAAE,MAAM,CAAA;SACb,CAAA;QACD,GAAG,CAAC,EAAE,MAAM,CAAA;QACZ,cAAc,CAAC,EAAE,MAAM,CAAA;QACvB,SAAS,CAAC,EAAE,MAAM,CAAA;QAClB,eAAe,CAAC,EAAE,MAAM,CAAA;QACxB,gBAAgB,CAAC,EAAE,MAAM,CAAA;KAC1B,CAAA;IAGD,YAAY,CAAC,EAAE,MAAM,CAAA;IAGrB,MAAM,CAAC,EAAE,aAAa,GAAG,IAAI,CAAA;IAC7B,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,aAAa,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAGxD,gBAAgB,CAAC,EAAE,MAAM,IAAI,CAAA;IAC7B,eAAe,CAAC,EAAE,MAAM,IAAI,CAAA;IAC5B,eAAe,CAAC,EAAE,MAAM,IAAI,CAAA;IAC5B,UAAU,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IACnD,UAAU,CAAC,EAAE,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IACvC,iBAAiB,CAAC,EAAE,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAG9C,gBAAgB,CAAC,EAAE,SAAS,GAAG,YAAY,GAAG,WAAW,GAAG,QAAQ,CAAA;IACpE,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,gBAAgB,CAAC,EAAE,aAAa,GAAG,aAAa,GAAG,aAAa,GAAG,WAAW,CAAA;IAG9E,kBAAkB,CAAC,EAAE;QACnB,QAAQ,EAAE,MAAM,CAAA;QAChB,UAAU,EAAE,MAAM,CAAA;KACnB,GAAG,IAAI,CAAA;IAGR,UAAU,CAAC,EAAE;QACX,MAAM,EAAE,OAAO,CAAA;QACf,MAAM,EAAE,OAAO,CAAA;QACf,MAAM,CAAC,EAAE,MAAM,CAAA;QACf,MAAM,CAAC,EAAE,MAAM,IAAI,CAAA;QACnB,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;KACtC,CAAA;IAGD,YAAY,EAAE,KAAK,CAAC,aAAa,CAAC;QAAE,UAAU,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,CAAA;CACxE;AAED,wBAAgB,mBAAmB,CAAC,EAClC,OAAO,EACP,YAAY,EACZ,MAAM,EACN,MAAM,EACN,gBAAgB,EAChB,eAAe,EACf,eAAe,EACf,UAAU,EACV,UAAU,EACV,iBAAiB,EACjB,gBAA4B,EAC5B,YAAoB,EACpB,gBAAgC,EAChC,kBAAkB,EAClB,UAAU,EACV,YAAY,GACb,EAAE,wBAAwB,8CA6hB1B"}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SessionDetailHeader = SessionDetailHeader;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
/**
|
|
6
|
+
* SessionDetailHeader - Shared session detail header component
|
|
7
|
+
*
|
|
8
|
+
* Displays session metadata, stats, and action buttons for session detail pages.
|
|
9
|
+
* Used by both desktop and server apps for consistent UI.
|
|
10
|
+
*/
|
|
11
|
+
const git_url_js_1 = require("../../utils/git-url.js");
|
|
12
|
+
const RatingBadge_js_1 = require("./RatingBadge.js");
|
|
13
|
+
function SessionDetailHeader({ session, messageCount, rating, onRate, onProcessSession, onAssessSession, onDeleteSession, onCwdClick, onViewDiff, onRepositoryClick, processingStatus = 'pending', isProcessing = false, assessmentStatus = 'not_started', processingProgress, syncStatus, ProviderIcon, }) {
|
|
14
|
+
const formatDate = (dateString) => {
|
|
15
|
+
if (!dateString)
|
|
16
|
+
return 'N/A';
|
|
17
|
+
return new Date(dateString).toLocaleString();
|
|
18
|
+
};
|
|
19
|
+
const formatDuration = (durationMs) => {
|
|
20
|
+
if (!durationMs)
|
|
21
|
+
return 'N/A';
|
|
22
|
+
const seconds = Math.floor(durationMs / 1000);
|
|
23
|
+
const minutes = Math.floor(seconds / 60);
|
|
24
|
+
const hours = Math.floor(minutes / 60);
|
|
25
|
+
if (hours > 0) {
|
|
26
|
+
return `${hours}h ${minutes % 60}m ${seconds % 60}s`;
|
|
27
|
+
}
|
|
28
|
+
if (minutes > 0) {
|
|
29
|
+
return `${minutes}m ${seconds % 60}s`;
|
|
30
|
+
}
|
|
31
|
+
return `${seconds}s`;
|
|
32
|
+
};
|
|
33
|
+
const formatFileSize = (bytes) => {
|
|
34
|
+
if (bytes === 0)
|
|
35
|
+
return '0 B';
|
|
36
|
+
const k = 1024;
|
|
37
|
+
const sizes = ['B', 'KB', 'MB', 'GB'];
|
|
38
|
+
const i = Math.floor(Math.log(bytes) / Math.log(k));
|
|
39
|
+
return `${Number.parseFloat((bytes / k ** i).toFixed(1))} ${sizes[i]}`;
|
|
40
|
+
};
|
|
41
|
+
const actuallyProcessing = isProcessing || processingStatus === 'processing';
|
|
42
|
+
const workingDirectory = session.repository?.cwd || session.cwd;
|
|
43
|
+
// Build GitHub diff URL if we have the required information
|
|
44
|
+
const gitHubDiffUrl = (0, git_url_js_1.buildGitHubDiffUrl)(session.repository?.gitRemoteUrl, session.firstCommitHash, session.latestCommitHash);
|
|
45
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: "card bg-base-100 border border-base-300", children: (0, jsx_runtime_1.jsxs)("div", { className: "card-body p-4", children: [(0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsxs)("div", { className: "flex flex-col md:flex-row md:items-start md:justify-between gap-2", children: [(0, jsx_runtime_1.jsxs)("div", { className: "flex items-center gap-2 flex-wrap flex-1 min-w-0", children: [(0, jsx_runtime_1.jsx)(ProviderIcon, { providerId: session.provider, size: 20 }), session.username && session.userAvatarUrl && ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsxs)("a", { href: `https://github.com/${session.username}`, target: "_blank", rel: "noopener noreferrer", className: "flex items-center gap-2 hover:opacity-80 transition-opacity", title: `View @${session.username} on GitHub`, children: [(0, jsx_runtime_1.jsx)("img", { src: session.userAvatarUrl, alt: session.username, className: "w-8 h-8 rounded-full flex-shrink-0" }), (0, jsx_runtime_1.jsxs)("span", { className: "font-semibold text-lg md:text-xl hover:underline", children: ["@", session.username] })] }), (0, jsx_runtime_1.jsx)("span", { className: "text-base-content/50 text-sm", children: "\u2022" })] })), onRepositoryClick ? ((0, jsx_runtime_1.jsx)("button", { type: "button", onClick: onRepositoryClick, className: "font-medium text-base md:text-lg hover:text-primary hover:underline transition-colors cursor-pointer", children: session.repositoryName })) : ((0, jsx_runtime_1.jsx)("span", { className: "font-medium text-base md:text-lg", children: session.repositoryName })), (0, jsx_runtime_1.jsx)("span", { className: "text-base-content/50 text-sm", children: "\u2022" }), (0, jsx_runtime_1.jsx)("span", { className: "text-sm text-base-content/70", children: formatDate(session.sessionStartTime) }), (0, jsx_runtime_1.jsx)("span", { className: "text-base-content/50 text-sm", children: "\u2022" }), (0, jsx_runtime_1.jsx)("span", { className: "text-sm font-medium", children: session.provider }), (0, jsx_runtime_1.jsx)("span", { className: "text-base-content/50 text-sm", children: "\u2022" }), (0, jsx_runtime_1.jsx)("span", { className: "text-sm", children: formatDuration(session.durationMs) }), messageCount !== undefined && ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)("span", { className: "text-base-content/50 text-sm", children: "\u2022" }), (0, jsx_runtime_1.jsxs)("span", { className: "text-sm", children: [messageCount, " msg"] })] })), (0, jsx_runtime_1.jsx)("span", { className: "text-base-content/50 text-sm", children: "\u2022" }), (0, jsx_runtime_1.jsx)("span", { className: "text-sm", children: session.fileSize !== undefined && session.fileSize !== null ? (formatFileSize(session.fileSize)) : ((0, jsx_runtime_1.jsx)("span", { className: "badge badge-ghost badge-sm", children: "Metrics Only" })) }), syncStatus && ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)("span", { className: "text-base-content/50 text-sm", children: "\u2022" }), syncStatus.failed ? ((0, jsx_runtime_1.jsx)("div", { className: "tooltip tooltip-bottom cursor-pointer hover:scale-110 transition-transform", "data-tip": "Sync failed - Click to view error", onClick: () => syncStatus.onShowError?.(syncStatus.reason || 'Unknown error'), children: (0, jsx_runtime_1.jsx)("svg", { className: "w-4 h-4 text-error", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: (0, jsx_runtime_1.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-3L13.732 4c-.77-1.333-2.694-1.333-3.464 0L3.34 16c-.77 1.333.192 3 1.732 3z" }) }) })) : syncStatus.synced ? ((0, jsx_runtime_1.jsx)("div", { className: "tooltip tooltip-bottom", "data-tip": "Synced to server", children: (0, jsx_runtime_1.jsx)("svg", { className: "w-4 h-4 text-success", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: (0, jsx_runtime_1.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M5 13l4 4L19 7" }) }) })) : ((0, jsx_runtime_1.jsx)("div", { className: "tooltip tooltip-bottom cursor-pointer hover:scale-110 transition-transform", "data-tip": "Click to sync to server", onClick: syncStatus.onSync, children: (0, jsx_runtime_1.jsx)("svg", { className: "w-4 h-4 text-base-content/30", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: (0, jsx_runtime_1.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M7 16a4 4 0 01-.88-7.903A5 5 0 1115.9 6L16 6a5 5 0 011 9.9M15 13l-3-3m0 0l-3 3m3-3v12" }) }) }))] }))] }), (0, jsx_runtime_1.jsxs)("div", { className: "hidden md:flex items-center gap-1.5 flex-shrink-0", children: [onProcessSession && ((0, jsx_runtime_1.jsxs)("button", { onClick: onProcessSession, disabled: actuallyProcessing, className: `btn btn-xs gap-1.5 ${processingStatus === 'completed' ? 'btn-secondary' : 'btn-warning'}`, title: actuallyProcessing
|
|
46
|
+
? 'Processing...'
|
|
47
|
+
: processingStatus === 'completed'
|
|
48
|
+
? 'Metrics already processed'
|
|
49
|
+
: 'Process session with AI', children: [actuallyProcessing ? ((0, jsx_runtime_1.jsx)("span", { className: "loading loading-spinner loading-xs" })) : ((0, jsx_runtime_1.jsx)("svg", { className: "w-3.5 h-3.5", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: (0, jsx_runtime_1.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M13 10V3L4 14h7v7l9-11h-7z" }) })), (0, jsx_runtime_1.jsx)("span", { className: "hidden lg:inline text-xs", children: actuallyProcessing && processingProgress
|
|
50
|
+
? `${processingProgress.stepName} (${processingProgress.percentage}%)`
|
|
51
|
+
: actuallyProcessing
|
|
52
|
+
? 'Processing...'
|
|
53
|
+
: processingStatus === 'completed'
|
|
54
|
+
? 'AI Processed ✓'
|
|
55
|
+
: 'Process Session' })] })), onAssessSession && ((0, jsx_runtime_1.jsxs)("button", { onClick: onAssessSession, className: `btn btn-xs gap-1.5 ${assessmentStatus === 'completed' ? 'btn-secondary' : 'btn-accent'}`, title: assessmentStatus === 'completed'
|
|
56
|
+
? 'Assessment complete'
|
|
57
|
+
: assessmentStatus === 'in_progress'
|
|
58
|
+
? 'Continue assessment'
|
|
59
|
+
: 'Start session assessment', children: [(0, jsx_runtime_1.jsx)("svg", { className: "w-3.5 h-3.5", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: (0, jsx_runtime_1.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M9 12h6m-6 4h6m2 5H7a2 2 0 01-2-2V5a2 2 0 012-2h5.586a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V19a2 2 0 01-2 2z" }) }), (0, jsx_runtime_1.jsx)("span", { className: "hidden lg:inline text-xs", children: assessmentStatus === 'completed'
|
|
60
|
+
? 'Assessed ✓'
|
|
61
|
+
: assessmentStatus === 'in_progress'
|
|
62
|
+
? 'Assessment In Progress'
|
|
63
|
+
: 'Assess Session' })] })), onDeleteSession && ((0, jsx_runtime_1.jsxs)("button", { onClick: onDeleteSession, className: "btn btn-xs btn-error gap-1.5", title: "Delete this session", children: [(0, jsx_runtime_1.jsx)("svg", { className: "w-3.5 h-3.5", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: (0, jsx_runtime_1.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M19 7l-.867 12.142A2 2 0 0116.138 21H7.862a2 2 0 01-1.995-1.858L5 7m5 4v6m4-6v6m1-10V4a1 1 0 00-1-1h-4a1 1 0 00-1 1v3M4 7h16" }) }), (0, jsx_runtime_1.jsx)("span", { className: "hidden lg:inline text-xs", children: "Delete" })] }))] })] }), (onProcessSession || onAssessSession || onDeleteSession) && ((0, jsx_runtime_1.jsxs)("div", { className: "md:hidden mb-2 flex gap-1.5", children: [onProcessSession && ((0, jsx_runtime_1.jsxs)("button", { onClick: onProcessSession, disabled: actuallyProcessing, className: `btn btn-xs gap-1.5 ${processingStatus === 'completed' ? 'btn-secondary' : 'btn-warning'}`, children: [actuallyProcessing ? ((0, jsx_runtime_1.jsx)("span", { className: "loading loading-spinner loading-xs" })) : ((0, jsx_runtime_1.jsx)("svg", { className: "w-3.5 h-3.5", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: (0, jsx_runtime_1.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M13 10V3L4 14h7v7l9-11h-7z" }) })), (0, jsx_runtime_1.jsx)("span", { className: "text-xs", children: actuallyProcessing && processingProgress
|
|
64
|
+
? `${processingProgress.stepName} (${processingProgress.percentage}%)`
|
|
65
|
+
: actuallyProcessing
|
|
66
|
+
? 'Processing...'
|
|
67
|
+
: processingStatus === 'completed'
|
|
68
|
+
? 'Processed ✓'
|
|
69
|
+
: 'Process' })] })), onAssessSession && ((0, jsx_runtime_1.jsxs)("button", { onClick: onAssessSession, className: `btn btn-xs gap-1.5 ${assessmentStatus === 'completed' ? 'btn-secondary' : 'btn-accent'}`, children: [(0, jsx_runtime_1.jsx)("svg", { className: "w-3.5 h-3.5", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: (0, jsx_runtime_1.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M9 12h6m-6 4h6m2 5H7a2 2 0 01-2-2V5a2 2 0 012-2h5.586a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V19a2 2 0 01-2 2z" }) }), (0, jsx_runtime_1.jsx)("span", { className: "text-xs", children: assessmentStatus === 'completed'
|
|
70
|
+
? 'Assessed ✓'
|
|
71
|
+
: assessmentStatus === 'in_progress'
|
|
72
|
+
? 'In Progress'
|
|
73
|
+
: 'Assess' })] })), onDeleteSession && ((0, jsx_runtime_1.jsxs)("button", { onClick: onDeleteSession, className: "btn btn-xs btn-error gap-1.5", children: [(0, jsx_runtime_1.jsx)("svg", { className: "w-3.5 h-3.5", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: (0, jsx_runtime_1.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M19 7l-.867 12.142A2 2 0 0116.138 21H7.862a2 2 0 01-1.995-1.858L5 7m5 4v6m4-6v6m1-10V4a1 1 0 00-1-1h-4a1 1 0 00-1 1v3M4 7h16" }) }), (0, jsx_runtime_1.jsx)("span", { className: "text-xs", children: "Delete" })] }))] }))] }), (session.repository ||
|
|
74
|
+
workingDirectory ||
|
|
75
|
+
session.gitBranch ||
|
|
76
|
+
session.firstCommitHash ||
|
|
77
|
+
session.latestCommitHash ||
|
|
78
|
+
onRate) && ((0, jsx_runtime_1.jsxs)("div", { className: "grid grid-cols-1 lg:grid-cols-4 gap-2", children: [session.repository?.gitRemoteUrl && ((0, jsx_runtime_1.jsx)("div", { className: "stat bg-base-200 rounded-lg p-2.5", children: (0, jsx_runtime_1.jsxs)("div", { className: "flex flex-col gap-1", children: [(0, jsx_runtime_1.jsx)("div", { className: "text-xs text-base-content/60", children: "Repository:" }), (0, jsx_runtime_1.jsxs)("a", { href: session.repository.gitRemoteUrl, target: "_blank", rel: "noopener noreferrer", className: "flex items-center gap-1.5 text-xs text-base-content hover:text-primary transition-colors", title: session.repository.gitRemoteUrl, children: [(0, jsx_runtime_1.jsx)("svg", { className: "w-3 h-3 flex-shrink-0", fill: "currentColor", viewBox: "0 0 24 24", children: (0, jsx_runtime_1.jsx)("path", { fillRule: "evenodd", d: "M12 0C5.374 0 0 5.373 0 12c0 5.302 3.438 9.8 8.207 11.387.599.111.793-.261.793-.577v-2.234c-3.338.726-4.033-1.416-4.033-1.416-.546-1.387-1.333-1.756-1.333-1.756-1.089-.745.083-.729.083-.729 1.205.084 1.839 1.237 1.839 1.237 1.07 1.834 2.807 1.304 3.492.997.107-.775.418-1.305.762-1.604-2.665-.305-5.467-1.334-5.467-5.931 0-1.311.469-2.381 1.236-3.221-.124-.303-.535-1.524.117-3.176 0 0 1.008-.322 3.301 1.23A11.509 11.509 0 0112 5.803c1.02.005 2.047.138 3.006.404 2.291-1.552 3.297-1.23 3.297-1.23.653 1.653.242 2.874.118 3.176.77.84 1.235 1.911 1.235 3.221 0 4.609-2.807 5.624-5.479 5.921.43.372.823 1.102.823 2.222v3.293c0 .319.192.694.801.576C20.566 21.797 24 17.3 24 12c0-6.627-5.373-12-12-12z", clipRule: "evenodd" }) }), (0, jsx_runtime_1.jsx)("span", { className: "truncate", children: session.repository.gitRemoteUrl.replace(/^https?:\/\/(www\.)?/, '') })] })] }) })), (session.gitBranch ||
|
|
79
|
+
session.firstCommitHash ||
|
|
80
|
+
session.latestCommitHash ||
|
|
81
|
+
workingDirectory) && ((0, jsx_runtime_1.jsx)("div", { className: "stat bg-base-200 rounded-lg p-2.5", children: (0, jsx_runtime_1.jsxs)("div", { className: "space-y-1 text-xs", children: [session.gitBranch && ((0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("span", { className: "text-base-content/60", children: "Branch:" }), (0, jsx_runtime_1.jsx)("span", { className: "ml-1.5 font-mono text-base-content", children: session.gitBranch })] })), session.firstCommitHash ? ((0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("span", { className: "text-base-content/60", children: "Commits:" }), session.latestCommitHash &&
|
|
82
|
+
session.latestCommitHash !== session.firstCommitHash ? (
|
|
83
|
+
// Different commits - show commit range
|
|
84
|
+
(0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: onViewDiff ? (
|
|
85
|
+
// Desktop: clickable button that opens Session Changes tab
|
|
86
|
+
(0, jsx_runtime_1.jsxs)("button", { onClick: onViewDiff, className: "ml-1.5 font-mono text-primary hover:text-primary-focus transition-colors hover:underline", title: `View changes: ${session.firstCommitHash} → ${session.latestCommitHash}`, children: [session.firstCommitHash.substring(0, 7), " \u2192", ' ', session.latestCommitHash.substring(0, 7)] })) : gitHubDiffUrl ? (
|
|
87
|
+
// Server: link to GitHub diff
|
|
88
|
+
(0, jsx_runtime_1.jsxs)("a", { href: gitHubDiffUrl, target: "_blank", rel: "noopener noreferrer", className: "ml-1.5 font-mono text-primary hover:text-primary-focus transition-colors hover:underline", title: `View diff: ${session.firstCommitHash} → ${session.latestCommitHash}`, children: [session.firstCommitHash.substring(0, 7), " \u2192", ' ', session.latestCommitHash.substring(0, 7)] })) : (
|
|
89
|
+
// No action available: plain text
|
|
90
|
+
(0, jsx_runtime_1.jsxs)("span", { className: "ml-1.5 font-mono text-base-content", title: `${session.firstCommitHash} → ${session.latestCommitHash}`, children: [session.firstCommitHash.substring(0, 7), " \u2192", ' ', session.latestCommitHash.substring(0, 7)] })) })) : (
|
|
91
|
+
// Same commit or no latest commit - show unstaged changes
|
|
92
|
+
(0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: onViewDiff ? (
|
|
93
|
+
// Desktop: clickable button for unstaged changes
|
|
94
|
+
(0, jsx_runtime_1.jsxs)("button", { onClick: onViewDiff, className: "ml-1.5 font-mono text-primary hover:text-primary-focus transition-colors hover:underline", title: `View unstaged changes from ${session.firstCommitHash}`, children: [session.firstCommitHash.substring(0, 7), " \u2192", ' ', (0, jsx_runtime_1.jsx)("span", { className: "text-base-content/60", children: "UNSTAGED" })] })) : (
|
|
95
|
+
// Plain text (server or no action)
|
|
96
|
+
(0, jsx_runtime_1.jsxs)("span", { className: "ml-1.5 font-mono text-base-content", title: `Unstaged changes from ${session.firstCommitHash}`, children: [session.firstCommitHash.substring(0, 7), " \u2192", ' ', (0, jsx_runtime_1.jsx)("span", { className: "text-base-content/60", children: "UNSTAGED" })] })) }))] })) : (workingDirectory && (
|
|
97
|
+
// Historical session - no git commit data available
|
|
98
|
+
(0, jsx_runtime_1.jsx)("div", { className: "flex items-center h-full text-base-content/60 italic", children: "Git info unavailable (historical session)" })))] }) })), workingDirectory && ((0, jsx_runtime_1.jsx)("div", { className: "stat bg-base-200 rounded-lg p-2.5", children: (0, jsx_runtime_1.jsxs)("div", { className: "flex flex-col gap-1", children: [(0, jsx_runtime_1.jsx)("div", { className: "text-xs text-base-content/60", children: "Working directory:" }), (0, jsx_runtime_1.jsx)("div", { className: "stat-value text-sm", children: onCwdClick ? ((0, jsx_runtime_1.jsx)("button", { onClick: () => onCwdClick(workingDirectory), className: "text-left hover:text-primary transition-colors font-mono break-all text-xs", title: "Click to open in OS", children: workingDirectory })) : ((0, jsx_runtime_1.jsx)("span", { className: "font-mono break-all text-xs", children: workingDirectory })) })] }) })), onRate && ((0, jsx_runtime_1.jsx)("div", { className: "stat bg-base-200 rounded-lg p-2.5", children: (0, jsx_runtime_1.jsx)("div", { className: "flex items-center justify-center h-full", children: (0, jsx_runtime_1.jsx)(RatingBadge_js_1.RatingBadge, { rating: rating || null, onRate: onRate, size: "md" }) }) }))] })), session.aiModelSummary && ((0, jsx_runtime_1.jsx)("div", { className: "mt-2 bg-base-200/50 border border-base-300 rounded-lg p-3", children: (0, jsx_runtime_1.jsx)("p", { className: "text-sm text-base-content", children: session.aiModelSummary }) }))] }) }));
|
|
99
|
+
}
|
|
100
|
+
//# sourceMappingURL=SessionDetailHeader.js.map
|