<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>DriveGuard Ground Truth Annotation Tool</title>
    
    <!-- Styles -->
    <link rel="stylesheet" href="/static/css/main.css">
    <link rel="stylesheet" href="/static/css/components.css">
    <link rel="stylesheet" href="/static/css/video-player.css">
    
    <!-- Video.js CSS -->
    <link href="https://vjs.zencdn.net/8.0.4/video-js.css" rel="stylesheet">
    
    <!-- Font Awesome for icons -->
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css">
</head>
<body>
    <div id="app">
        <!-- Header -->
        <header class="app-header">
            <div class="header-content">
                <h1><i class="fas fa-video"></i> DriveGuard Ground Truth Annotation</h1>
                <div class="header-controls">
                    <div class="clip-navigation">
                        <button id="prev-clip-btn" class="btn btn-secondary">
                            <i class="fas fa-chevron-left"></i> Previous Clip
                        </button>
                        <span id="clip-counter">-- / --</span>
                        <button id="next-clip-btn" class="btn btn-secondary">
                            Next Clip <i class="fas fa-chevron-right"></i>
                        </button>
                        <button id="mark-complete-btn" class="btn btn-success" disabled>
                            <i class="fas fa-check-circle"></i> Mark Complete
                        </button>
                    </div>
                    <button id="refresh-btn" class="btn btn-secondary">
                        <i class="fas fa-sync-alt"></i> Refresh
                    </button>
                </div>
            </div>
        </header>

        <!-- Main Content -->
        <main class="app-main">

            <!-- Content Area -->
            <div class="app-content">
                <!-- Current Clip Info -->
                <section class="clip-info-section">
                    <div class="clip-header">
                        <h2 id="current-clip-title">Select a video clip to begin</h2>
                        <div class="clip-metadata" id="clip-metadata">
                            <!-- Clip metadata will be shown here -->
                        </div>
                    </div>
                </section>

                <!-- Video Player -->
                <section class="video-section">
                    <div class="video-container">
                        <video
                            id="main-video-player"
                            class="video-js vjs-default-skin"
                            controls
                            preload="auto"
                            width="800"
                            height="450"
                            data-setup="{}">
                            <p class="vjs-no-js">
                                To view this video please enable JavaScript, and consider upgrading to a web browser that
                                <a href="https://videojs.com/html5-video-support/" target="_blank">supports HTML5 video</a>.
                            </p>
                        </video>
                        <div class="video-placeholder" id="video-placeholder">
                            <i class="fas fa-video"></i>
                            <p>Select a video clip to view</p>
                        </div>
                    </div>
                </section>

                <!-- Pipeline Steps -->
                <section class="pipeline-section">
                    <div class="pipeline-header">
                        <h3>Annotation Pipeline</h3>
                        <p class="pipeline-description">Complete all steps sequentially. Each step builds on the previous results.</p>
                    </div>

                    <div class="pipeline-steps">
                        <!-- Step 1: Annotation -->
                        <div class="step-container" id="step-1" data-step="1">
                            <div class="step-header">
                                <h4>
                                    <span class="step-number">1</span>
                                    <span class="step-title">Generate Annotation</span>
                                    <span class="step-status" id="step-1-status">pending</span>
                                </h4>
                                <div class="step-actions">
                                    <button class="btn btn-primary" id="generate-annotation-btn">
                                        <i class="fas fa-brain"></i> Generate with AI
                                    </button>
                                </div>
                            </div>
                            <div class="step-content">
                                <div class="step-description">
                                    <p>Generate a narrative description of the driving scenario using the DriveGuard VideoAnnotator AI agent. The system will analyze video frames and create a comprehensive traffic safety annotation.</p>
                                </div>
                                <div class="annotation-editor" id="annotation-editor">
                                    <textarea 
                                        id="annotation-text" 
                                        class="form-control annotation-textarea" 
                                        placeholder="Click 'Generate with AI' to create an annotation using the DriveGuard VideoAnnotator agent. The AI will analyze video frames at 2 FPS and generate a comprehensive narrative description..."
                                        rows="8">
                                    </textarea>
                                    <div class="editor-actions">
                                        <button class="btn btn-success" id="save-annotation-btn">
                                            <i class="fas fa-save"></i> Save
                                        </button>
                                        <button class="btn btn-secondary" id="reset-annotation-btn">
                                            <i class="fas fa-undo"></i> Reset
                                        </button>
                                    </div>
                                    
                                    <!-- Feedback/Optimization Section -->
                                    <div class="optimization-section" id="optimization-section" style="display: none;">
                                        <div class="optimization-header">
                                            <label for="optimization-feedback" class="feedback-label">
                                                <i class="fas fa-comment-dots"></i> Optimization Instructions
                                            </label>
                                        </div>
                                        <textarea 
                                            id="optimization-feedback" 
                                            class="form-control feedback-textarea" 
                                            placeholder="Enter your optimization instructions here (e.g., 'Add more details about vehicle speeds', 'Describe weather conditions', 'Focus more on the ego vehicle behavior')"
                                            rows="3">
                                        </textarea>
                                        <div class="optimization-actions">
                                            <button class="btn btn-primary" id="optimize-annotation-btn">
                                                <i class="fas fa-magic"></i> Optimize with AI
                                            </button>
                                        </div>
                                    </div>
                                </div>
                            </div>
                        </div>

                        <!-- Step 2: Scene Extraction -->
                        <div class="step-container" id="step-2" data-step="2">
                            <div class="step-header">
                                <h4>
                                    <span class="step-number">2</span>
                                    <span class="step-title">Extract Scenes</span>
                                    <span class="step-status" id="step-2-status">pending</span>
                                </h4>
                                <div class="step-actions">
                                    <button class="btn btn-primary" id="extract-scenes-btn">
                                        <i class="fas fa-scissors"></i> Extract
                                    </button>
                                </div>
                            </div>
                            <div class="step-content">
                                <div class="step-description">
                                    <p>Break down the annotation into atomic scene descriptions.</p>
                                </div>
                                <div class="scenes-editor" id="scenes-editor">
                                    <div class="scenes-list" id="scenes-list">
                                        <!-- Scenes will be populated here -->
                                    </div>
                                    <div class="editor-actions">
                                        <button class="btn btn-secondary" id="add-scene-btn">
                                            <i class="fas fa-plus"></i> Add Scene
                                        </button>
                                        <button class="btn btn-danger" id="reset-scenes-btn">
                                            <i class="fas fa-trash-alt"></i> Delete All Scenes
                                        </button>
                                        <button class="btn btn-success" id="save-scenes-btn">
                                            <i class="fas fa-save"></i> Save
                                        </button>
                                    </div>
                                </div>
                            </div>
                        </div>

                        <!-- Step 3: Violations -->
                        <div class="step-container" id="step-3" data-step="3">
                            <div class="step-header">
                                <h4>
                                    <span class="step-number">3</span>
                                    <span class="step-title">Analyze Violations</span>
                                    <span class="step-status" id="step-3-status">pending</span>
                                </h4>
                                <div class="step-actions">
                                    <button class="btn btn-primary" id="analyze-violations-btn">
                                        <i class="fas fa-search"></i> Analyze
                                    </button>
                                </div>
                            </div>
                            <div class="step-content">
                                <div class="step-description">
                                    <p>Identify traffic violations in each scene.</p>
                                </div>
                                <div class="violations-editor" id="violations-editor">
                                    <div class="violations-list" id="violations-list">
                                        <!-- Violations will be populated here -->
                                    </div>
                                    <div class="editor-actions">
                                        <button class="btn btn-success" id="save-violations-btn">
                                            <i class="fas fa-save"></i> Save
                                        </button>
                                        <button class="btn btn-secondary" id="reset-violations-btn">
                                            <i class="fas fa-undo"></i> Reset
                                        </button>
                                        <small class="text-muted">Note: Scenes are managed in Step 2. Only violation status and reasons can be edited here.</small>
                                    </div>
                                </div>
                            </div>
                        </div>

                        <!-- Step 4: Accidents -->
                        <div class="step-container" id="step-4" data-step="4">
                            <div class="step-header">
                                <h4>
                                    <span class="step-number">4</span>
                                    <span class="step-title">Analyze Accidents</span>
                                    <span class="step-status" id="step-4-status">pending</span>
                                </h4>
                                <div class="step-actions">
                                    <button class="btn btn-primary" id="analyze-accidents-btn">
                                        <i class="fas fa-exclamation-triangle"></i> Analyze
                                    </button>
                                </div>
                            </div>
                            <div class="step-content">
                                <div class="step-description">
                                    <p>Identify accident risks and potential consequences in each scene.</p>
                                </div>
                                <div class="accidents-editor" id="accidents-editor">
                                    <div class="accidents-list" id="accidents-list">
                                        <!-- Accidents will be populated here -->
                                    </div>
                                    <div class="editor-actions">
                                        <button class="btn btn-success" id="save-accidents-btn">
                                            <i class="fas fa-save"></i> Save
                                        </button>
                                        <button class="btn btn-secondary" id="reset-accidents-btn">
                                            <i class="fas fa-undo"></i> Reset
                                        </button>
                                        <small class="text-muted">Note: Scenes are managed in Step 2. Only accident status and consequences can be edited here.</small>
                                    </div>
                                </div>
                            </div>
                        </div>

                        <!-- Step 5: Assessment -->
                        <div class="step-container" id="step-5" data-step="5">
                            <div class="step-header">
                                <h4>
                                    <span class="step-number">5</span>
                                    <span class="step-title">Generate Assessment</span>
                                    <span class="step-status" id="step-5-status">pending</span>
                                </h4>
                                <div class="step-actions">
                                    <button class="btn btn-primary" id="generate-assessment-btn">
                                        <i class="fas fa-chart-line"></i> Generate
                                    </button>
                                </div>
                            </div>
                            <div class="step-content">
                                <!-- Safety Scoring Reference -->
                                <div class="scoring-reference-section">
                                    <div class="reference-header">
                                        <h4>
                                            <i class="fas fa-graduation-cap"></i> Safety Scoring Reference
                                            <button type="button" id="scoring-reference-toggle" class="btn-link reference-toggle" title="Toggle Scoring Criteria">
                                                <i class="fas fa-chevron-down"></i>
                                            </button>
                                        </h4>
                                        <p class="reference-description">Reference guide for consistent safety scoring. Click to expand criteria.</p>
                                    </div>
                                    
                                    <!-- Safety Score Criteria Panel -->
                                    <div id="scoring-reference-panel" class="reference-panel" style="display: none;">
                                        <div class="reference-content">
                                            <!-- Critical Risk Levels (1-4) -->
                                            <div class="criteria-section critical-risk">
                                                <h6 class="risk-level-header">
                                                    <span class="risk-badge critical">Critical Risk</span>
                                                    <span class="score-range">(Scores 1-4)</span>
                                                </h6>
                                                <div class="criteria-list">
                                                    <div class="criteria-item" data-score="1">
                                                        <span class="score-number">1</span>
                                                        <span class="score-description">Accident caused by ego vehicle's traffic rule violation</span>
                                                    </div>
                                                    <div class="criteria-item" data-score="2">
                                                        <span class="score-number">2</span>
                                                        <span class="score-description">Accident caused by ego vehicle's fault/risky behavior (non-violation)</span>
                                                    </div>
                                                    <div class="criteria-item" data-score="3">
                                                        <span class="score-number">3</span>
                                                        <span class="score-description">Accident caused by others, but ego vehicle did not react properly or failed to mitigate</span>
                                                    </div>
                                                    <div class="criteria-item" data-score="4">
                                                        <span class="score-number">4</span>
                                                        <span class="score-description">Accident caused by others, ego vehicle tried best to mitigate damages/loss</span>
                                                    </div>
                                                </div>
                                            </div>
                                            
                                            <!-- High Risk Levels (5-7) -->
                                            <div class="criteria-section high-risk">
                                                <h6 class="risk-level-header">
                                                    <span class="risk-badge high">High Risk</span>
                                                    <span class="score-range">(Scores 5-7)</span>
                                                </h6>
                                                <div class="criteria-list">
                                                    <div class="criteria-item" data-score="5">
                                                        <span class="score-number">5</span>
                                                        <span class="score-description">Near miss caused by ego vehicle's traffic rule violation</span>
                                                    </div>
                                                    <div class="criteria-item" data-score="6">
                                                        <span class="score-number">6</span>
                                                        <span class="score-description">Near miss caused by ego vehicle's risky behavior (non-violation)</span>
                                                    </div>
                                                    <div class="criteria-item" data-score="7">
                                                        <span class="score-number">7</span>
                                                        <span class="score-description">Near miss caused by other traffic participants, ego vehicle involved but not at fault</span>
                                                    </div>
                                                </div>
                                            </div>
                                            
                                            <!-- Medium Risk Level (8) -->
                                            <div class="criteria-section medium-risk">
                                                <h6 class="risk-level-header">
                                                    <span class="risk-badge medium">Medium Risk</span>
                                                    <span class="score-range">(Score 8)</span>
                                                </h6>
                                                <div class="criteria-list">
                                                    <div class="criteria-item" data-score="8">
                                                        <span class="score-number">8</span>
                                                        <span class="score-description">No accident or near miss, but ego vehicle violates traffic rules or exhibits risky behaviors</span>
                                                    </div>
                                                </div>
                                            </div>
                                            
                                            <!-- Low Risk Levels (9-10) -->
                                            <div class="criteria-section low-risk">
                                                <h6 class="risk-level-header">
                                                    <span class="risk-badge low">Low Risk</span>
                                                    <span class="score-range">(Scores 9-10)</span>
                                                </h6>
                                                <div class="criteria-list">
                                                    <div class="criteria-item" data-score="9">
                                                        <span class="score-number">9</span>
                                                        <span class="score-description">No accident or near miss, other traffic participants violate rules or exhibit risky behaviors, ego vehicle takes defensive actions</span>
                                                    </div>
                                                    <div class="criteria-item" data-score="10">
                                                        <span class="score-number">10</span>
                                                        <span class="score-description">Safe driving with good behavior, defensive driving, correct response to emergencies</span>
                                                    </div>
                                                </div>
                                            </div>
                                        </div>
                                        
                                        <div class="reference-footer">
                                            <div class="reference-note">
                                                <strong>Scoring Guidelines:</strong> Accidents take precedence over other factors. Consider who caused the incident and how well ego vehicle responded. Risk levels automatically map to scores: Critical (1-4), High (5-7), Medium (8), Low (9-10).
                                            </div>
                                        </div>
                                    </div>
                                </div>
                                
                                <div class="step-description">
                                    <p>Generate comprehensive safety assessment with scores and recommendations.</p>
                                </div>
                                <div class="assessment-editor" id="assessment-editor">
                                    <div class="assessment-form" id="assessment-form" style="display: none;">
                                        <!-- Safety Score -->
                                        <div class="assessment-item-compact">
                                            <div class="assessment-field">
                                                <label for="safety-score" class="field-label">
                                                    Safety Score: 
                                                    <button type="button" id="score-criteria-toggle" class="btn-link criteria-toggle" title="View Scoring Reference">
                                                        <i class="fas fa-info-circle"></i>
                                                    </button>
                                                </label>
                                                <div class="score-input-group">
                                                    <input type="range" id="safety-score" class="form-control-compact score-slider" 
                                                           min="1" max="10" value="5" step="1">
                                                    <span class="score-display" id="score-display">5/10</span>
                                                </div>
                                            </div>
                                        </div>

                                        <!-- Risk Level -->
                                        <div class="assessment-item-compact">
                                            <div class="assessment-field">
                                                <label for="risk-level" class="field-label">Risk Level:</label>
                                                <select id="risk-level" class="form-control-compact">
                                                    <option value="low">Low Risk</option>
                                                    <option value="medium" selected>Medium Risk</option>
                                                    <option value="high">High Risk</option>
                                                    <option value="critical">Critical Risk</option>
                                                </select>
                                            </div>
                                        </div>

                                        <!-- Overall Evaluation -->
                                        <div class="assessment-item-compact">
                                            <div class="assessment-field">
                                                <label for="overall-evaluation" class="field-label">Overall Evaluation:</label>
                                                <textarea id="overall-evaluation" class="form-control-compact" rows="3" 
                                                          placeholder="Comprehensive evaluation of the driving behavior and safety assessment..."></textarea>
                                            </div>
                                        </div>

                                        <!-- Strengths -->
                                        <div class="assessment-item-compact">
                                            <div class="assessment-field">
                                                <label for="strengths" class="field-label">Strengths:</label>
                                                <textarea id="strengths" class="form-control-compact" rows="4" 
                                                          placeholder="List positive driving behaviors (one per line or separated by periods)..."></textarea>
                                            </div>
                                        </div>

                                        <!-- Weaknesses -->
                                        <div class="assessment-item-compact">
                                            <div class="assessment-field">
                                                <label for="weaknesses" class="field-label">Weaknesses:</label>
                                                <textarea id="weaknesses" class="form-control-compact" rows="4" 
                                                          placeholder="List identified weaknesses or risky behaviors (one per line or separated by periods)..."></textarea>
                                            </div>
                                        </div>

                                        <!-- Improvement Advice -->
                                        <div class="assessment-item-compact">
                                            <div class="assessment-field">
                                                <label for="improvement-advice" class="field-label">Improvement Advice:</label>
                                                <textarea id="improvement-advice" class="form-control-compact" rows="4" 
                                                          placeholder="Specific actionable recommendations for improving driving safety (one per line or separated by periods)..."></textarea>
                                            </div>
                                        </div>

                                        <!-- Assessment Optimization Section -->
                                        <div class="optimization-section" id="assessment-optimization-section" style="display: none;">
                                            <div class="optimization-header">
                                                <label for="assessment-optimization-feedback" class="feedback-label">
                                                    <i class="fas fa-comment-dots"></i> Assessment Optimization Instructions
                                                </label>
                                            </div>
                                            <textarea 
                                                id="assessment-optimization-feedback" 
                                                class="form-control feedback-textarea" 
                                                placeholder="Enter your optimization instructions here (e.g., 'Increase safety score to 6', 'Add more strengths', 'Focus more on defensive driving advice', 'Adjust risk level assessment')"
                                                rows="3">
                                            </textarea>
                                            <div class="optimization-actions">
                                                <button class="btn btn-primary" id="optimize-assessment-btn">
                                                    <i class="fas fa-magic"></i> Optimize with AI
                                                </button>
                                            </div>
                                        </div>

                                        <!-- Action Buttons -->
                                        <div class="editor-actions">
                                            <button class="btn btn-success" id="save-assessment-btn">
                                                <i class="fas fa-save"></i> Save Assessment
                                            </button>
                                            <button class="btn btn-secondary" id="reset-assessment-btn">
                                                <i class="fas fa-undo"></i> Reset
                                            </button>
                                        </div>
                                    </div>
                                    
                                    <div class="assessment-placeholder" id="assessment-placeholder">
                                        <p class="text-muted">Click "Generate" to create a comprehensive driving safety assessment using the DriveGuard DrivingMentor agent.</p>
                                    </div>
                                </div>
                            </div>
                        </div>
                    </div>
                </section>
            </div>
        </main>

        <!-- Footer -->
        <footer class="app-footer">
            <div class="footer-content">
                <span>DriveGuard Ground Truth Annotation Tool v1.0</span>
                <span>Generated with Claude Code</span>
            </div>
        </footer>
    </div>

    <!-- Loading Overlay -->
    <div id="loading-overlay" class="loading-overlay" style="display: none;">
        <div class="loading-spinner">
            <i class="fas fa-spinner fa-spin"></i>
            <p>Processing...</p>
        </div>
    </div>

    <!-- Scripts -->
    <script src="https://vjs.zencdn.net/8.0.4/video.min.js"></script>
    <script src="/static/js/utils/api-client.js"></script>
    <script src="/static/js/utils/progress-tracker.js"></script>
    <script src="/static/js/components/video-player.js"></script>
    <script src="/static/js/components/scoring-reference.js"></script>
    <script src="/static/js/components/step-annotation.js"></script>
    <script src="/static/js/components/step-scenes.js"></script>
    <script src="/static/js/components/step-violations.js"></script>
    <script src="/static/js/components/step-accidents.js"></script>
    <script src="/static/js/components/step-assessment.js"></script>
    <script src="/static/js/app.js"></script>
</body>
</html>