"""
Add Question Versions Table

This migration creates the question_versions table for tracking all changes
to questions and subquestions over time.

Features:
- Full version history with version numbers per question
- Tracks who made each change and when
- Stores complete snapshot of question fields at each version
- Stores subquestions as JSON blob for easy retrieval
- Enables diff comparison between versions
- Supports "modified after evaluation" detection

Design Decisions:
- Using JSON for subquestions (simpler than separate table, atomic versioning)
- Version numbers are per-question (not global)
- Initial version (v1) created when question is first saved
- Subsequent versions created on every save

Reference: https://en.wikipedia.org/wiki/Version_control
"""

from django.db import migrations


def create_question_versions_table(apps, schema_editor):
    """Create the question_versions table."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Creating question_versions table...")

        cursor.execute("""
            CREATE TABLE IF NOT EXISTS question_versions (
                id INTEGER PRIMARY KEY AUTOINCREMENT,
                question_id INTEGER NOT NULL REFERENCES questions(id) ON DELETE CASCADE,
                version_number INTEGER NOT NULL,
                created_at DATETIME NOT NULL DEFAULT(CURRENT_TIMESTAMP),
                created_by_id INTEGER REFERENCES participants(id) ON DELETE SET NULL,

                -- Snapshot of question fields at this version
                title TEXT NOT NULL,
                text TEXT NOT NULL,
                solution TEXT,
                difficulty_background INTEGER,
                difficulty_reasoning INTEGER,
                difficulty_insight INTEGER,
                difficulty_compute INTEGER,
                tags TEXT,

                -- JSON blob storing subquestions at this version
                -- Format: [{"order": "a", "text": "...", "answer": "...", "rationale": "...", "points": 1, "evaluation_type": "..."}]
                subquestions_json TEXT,

                -- Unique constraint: one version number per question
                UNIQUE(question_id, version_number)
            )
        """)
        print("  Created question_versions table")

        # Create indexes for common queries
        cursor.execute("""
            CREATE INDEX IF NOT EXISTS idx_question_versions_question_id
            ON question_versions(question_id)
        """)
        print("  Created index on question_id")

        cursor.execute("""
            CREATE INDEX IF NOT EXISTS idx_question_versions_created_at
            ON question_versions(created_at)
        """)
        print("  Created index on created_at")

        print("question_versions table created successfully!")


def drop_question_versions_table(apps, schema_editor):
    """Drop the question_versions table."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Dropping question_versions table...")
        cursor.execute("DROP TABLE IF EXISTS question_versions")
        print("  Dropped question_versions table")


class Migration(migrations.Migration):

    dependencies = [
        ('questions', '0007_drop_deprecated_tables'),
    ]

    operations = [
        migrations.RunPython(
            create_question_versions_table,
            drop_question_versions_table,
        ),
    ]
