import sys
import json
import pandas as pd
from pathlib import Path
import numpy as np
import os

# Add project root to sys.path to ensure imports work if run from different locations
project_root = Path(__file__).parent.parent
if str(project_root) not in sys.path:
    sys.path.append(str(project_root))

# Add experiment dir to sys.path to allow 'mlebench' imports matching internal usage
experiment_dir = project_root / "experiment"
if str(experiment_dir) not in sys.path:
    sys.path.append(str(experiment_dir))

from mlebench.registry import registry
from mlebench.grade import grade_csv

def generate_report(competition_id: str):
    # Paths
    competition_dir = project_root / "experiment" / "mlebench" / "competitions" / competition_id
    submission_path = competition_dir / "submission.csv"
    metrics_path = competition_dir / "execution_metrics.json"
    grading_report_path = competition_dir / "grading_report.json"
    report_path = competition_dir / "report.html"


    # 1. Get Grading Results
    print(f"🔍 Grading submission...")
    grading_data = {}
    
    # Try to load existing grading report first
    if grading_report_path.exists():
        try:
            print(f"📄 Loading existing grading report from {grading_report_path}")
            with open(grading_report_path, "r", encoding="utf-8") as f:
                grading_data = json.load(f)
            print(f"✅ Grading report loaded. Score: {grading_data.get('score')}")
        except Exception as e:
            print(f"⚠️ Failed to load existing grading report: {e}")

    # If no report loaded, try to grade
    if not grading_data:
        try:
            if not submission_path.exists():
                print(f"⚠️ Submission file not found at {submission_path}")
                grading_data = {"error": "Submission file not found"}
            else:
                print(f"⚙️ Running grader...")
                competition = registry.get_competition(competition_id)
                report_obj = grade_csv(submission_path, competition)
                grading_data = report_obj.to_dict()
                
                # Save the generated report
                try:
                    with open(grading_report_path, "w", encoding="utf-8") as f:
                        json.dump(grading_data, f, indent=4)
                    print(f"💾 Saved grading report to {grading_report_path}")
                except Exception as e:
                    print(f"⚠️ Failed to save grading report: {e}")
                    
                print(f"✅ Grading complete. Score: {grading_data.get('score')}")
        except Exception as e:
            print(f"❌ Grading failed: {e}")
            grading_data = {"error": str(e)}

    # 2. Get Execution Metrics
    print(f"📊 Loading execution metrics...")
    metrics_data = {}
    try:
        if not metrics_path.exists():
            print(f"⚠️ Metrics file not found at {metrics_path}")
            metrics_data = {"error": "Metrics file not found"}
        else:
            with open(metrics_path, "r", encoding="utf-8") as f:
                metrics_data = json.load(f)
            print(f"✅ Metrics loaded.")
    except Exception as e:
        print(f"❌ Loading metrics failed: {e}")
        metrics_data = {"error": str(e)}

    # 3. Generate HTML
    print(f"📝 Generating HTML report...")
    
    html_content = f"""
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>MLE-Bench Report: {competition_id}</title>
        <style>
            body {{ font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; margin: 0; padding: 20px; background-color: #f4f4f9; color: #333; }}
            .container {{ max-width: 900px; margin: 0 auto; background-color: #fff; padding: 30px; border-radius: 10px; box-shadow: 0 4px 6px rgba(0,0,0,0.1); }}
            h1 {{ color: #2c3e50; border-bottom: 2px solid #eee; padding-bottom: 10px; }}
            h2 {{ color: #34495e; margin-top: 30px; }}
            .section {{ margin-bottom: 30px; }}
            .metric-grid {{ display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 20px; margin-top: 15px; }}
            .card {{ background-color: #f8f9fa; padding: 15px; border-radius: 8px; border-left: 4px solid #3498db; }}
            .card.success {{ border-left-color: #2ecc71; }}
            .card.warning {{ border-left-color: #f1c40f; }}
            .card.danger {{ border-left-color: #e74c3c; }}
            .label {{ font-size: 0.9em; color: #7f8c8d; display: block; margin-bottom: 5px; }}
            .value {{ font-size: 1.4em; font-weight: bold; color: #2c3e50; }}
            .medal {{ font-size: 1.2em; }}
            table {{ width: 100%; border-collapse: collapse; margin-top: 15px; }}
            th, td {{ padding: 12px; text-align: left; border-bottom: 1px solid #ddd; }}
            th {{ background-color: #f8f9fa; color: #2c3e50; }}
            .footer {{ margin-top: 50px; text-align: center; color: #95a5a6; font-size: 0.9em; }}
            .error-msg {{ color: #e74c3c; background-color: #fadbd8; padding: 10px; border-radius: 5px; }}
        </style>
    </head>
    <body>
        <div class="container">
            <h1>MLE-Bench Report</h1>
            <p><strong>Competition ID:</strong> {competition_id}</p>
            <p><strong>Generated At:</strong> {pd.Timestamp.now().strftime('%Y-%m-%d %H:%M:%S')}</p>
            
            <div class="section">
                <h2>🏆 Grading Results</h2>
                {_format_grading_html(grading_data)}
            </div>

            <div class="section">
                <h2>⚡ Efficiency & Cost Metrics</h2>
                {_format_metrics_html(metrics_data)}
            </div>
            
            <div class="footer">
                <p>Generated by AutoDS Report Generator</p>
            </div>
        </div>
    </body>
    </html>
    """

    with open(report_path, "w", encoding="utf-8") as f:
        f.write(html_content)
    
    print(f"✅ Report generated successfully at:\n{report_path}")

def _format_grading_html(data):
    if "error" in data:
        return f"<div class='error-msg'>Error: {data['error']}</div>"
    
    score = data.get("score")
    score_display = f"{score:.5f}" if score is not None else "N/A"
    
    medals = []
    if data.get("gold_medal"): medals.append("🥇 Gold")
    elif data.get("silver_medal"): medals.append("🥈 Silver")
    elif data.get("bronze_medal"): medals.append("🥉 Bronze")
    else: medals.append("No Medal")
    
    medal_html = " ".join(medals)
    medal_class = "success" if data.get("any_medal") else "warning"
    
    html = f"""
    <div class="metric-grid">
        <div class="card {medal_class}">
            <span class="label">Score ({'Lower is Better' if data.get('is_lower_better') else 'Higher is Better'})</span>
            <span class="value">{score_display}</span>
        </div>
        <div class="card {medal_class}">
            <span class="label">Medal Status</span>
            <span class="value medal">{medal_html}</span>
        </div>
        <div class="card">
            <span class="label">Above Median</span>
            <span class="value">{'Yes' if data.get('above_median') else 'No'}</span>
        </div>
    </div>
    
    <h3>Medal Thresholds</h3>
    <table>
        <tr><th>Tier</th><th>Threshold</th><th>Achieved</th></tr>
        <tr><td>🥇 Gold</td><td>{data.get('gold_threshold', 'N/A')}</td><td>{'✅' if data.get('gold_medal') else '❌'}</td></tr>
        <tr><td>🥈 Silver</td><td>{data.get('silver_threshold', 'N/A')}</td><td>{'✅' if data.get('silver_medal') else '❌'}</td></tr>
        <tr><td>🥉 Bronze</td><td>{data.get('bronze_threshold', 'N/A')}</td><td>{'✅' if data.get('bronze_medal') else '❌'}</td></tr>
        <tr><td>Median</td><td>{data.get('median_threshold', 'N/A')}</td><td>{'✅' if data.get('above_median') else '❌'}</td></tr>
    </table>

    <p style="margin-top: 20px; font-size: 0.9em; color: #666;">
        <strong>Submission Path:</strong> <code>{data.get('submission_path', 'N/A')}</code>
    </p>
    """
    return html

def _format_metrics_html(data):
    if "error" in data:
        return f"<div class='error-msg'>Error: {data['error']}</div>"
    
    time_min = data.get("execution_time_minutes", 0)
    tokens = data.get("token_stats", {})
    
    html = f"""
    <div class="metric-grid">
        <div class="card">
            <span class="label">Execution Time</span>
            <span class="value">{time_min:.2f} min</span>
        </div>
        <div class="card">
            <span class="label">Total Tokens</span>
            <span class="value">{tokens.get('total_tokens', 0):,}</span>
        </div>
        <div class="card">
            <span class="label">LLM Calls</span>
            <span class="value">{tokens.get('calls', 0)}</span>
        </div>
    </div>
    
    <h3>Token Breakdown</h3>
    <table>
        <tr><th>Type</th><th>Count</th></tr>
        <tr><td>Prompt Tokens</td><td>{tokens.get('prompt_tokens', 0):,}</td></tr>
        <tr><td>Completion Tokens</td><td>{tokens.get('completion_tokens', 0):,}</td></tr>
        <tr><td><strong>Total</strong></td><td><strong>{tokens.get('total_tokens', 0):,}</strong></td></tr>
    </table>
    """
    return html

if __name__ == "__main__":
    if len(sys.argv) < 2:
        print("Usage: python generate_report.py <competition_id>")
        sys.exit(1)
    
    competition_id = sys.argv[1]
    generate_report(competition_id)
