"""
Enhanced Features Migration

This migration consolidates several related feature additions:
1. Adds 'active' question state for evaluation workflow
2. Adds released_for_grading field for grading release management  
3. Creates comprehensive grading system with blind evaluation

Replaces migrations: 0003, 0004, 0005, 0006, 0007, 0008
"""

from django.db import migrations, models
import django.db.models.deletion


def create_enhanced_features(apps, schema_editor):
    """Create enhanced features including question states, grading release, and grading system."""
    db = schema_editor.connection
    cursor = db.cursor()
    
    print("Creating enhanced features...")
    
    # 1. Add 'active' question state (from original 0003)
    print("  Adding 'active' question state...")
    cursor.execute("""
        INSERT OR IGNORE INTO question_states (id, status) 
        VALUES (9, 'active')
    """)
    
    # 2. Add released_for_grading field to model_answers (from original 0004)
    print("  Adding grading release field...")
    cursor.execute("PRAGMA table_info(model_answers)")
    columns = [col[1] for col in cursor.fetchall()]
    
    if 'released_for_grading' not in columns:
        cursor.execute("""
            ALTER TABLE model_answers 
            ADD COLUMN released_for_grading BOOLEAN DEFAULT 0
        """)
    
    # 3. Create comprehensive grading system (from original 0006/0007 consolidated)
    print("  Creating grading system tables...")
    
    # Create grading_states lookup table
    cursor.execute("""
        CREATE TABLE IF NOT EXISTS grading_states (
            id INTEGER PRIMARY KEY AUTOINCREMENT,
            state_name TEXT UNIQUE NOT NULL,
            display_name TEXT NOT NULL,
            description TEXT
        )
    """)
    
    # Populate grading states
    grading_states_data = [
        (1, 'true', 'True', 'The statement/calculation is correct'),
        (2, 'false', 'False', 'The statement/calculation is incorrect'),
        (3, 'not_sure', 'Not Sure', 'Cannot determine correctness'),
        (4, 'not_applicable', 'N/A', 'Not applicable to this answer')
    ]
    
    for state_data in grading_states_data:
        cursor.execute("""
            INSERT OR IGNORE INTO grading_states 
            (id, state_name, display_name, description)
            VALUES (%s, %s, %s, %s)
        """, state_data)
    
    # Create model_grading_sessions table with correct foreign key to accounts_customuser
    cursor.execute("""
        CREATE TABLE IF NOT EXISTS model_grading_sessions (
            id INTEGER PRIMARY KEY AUTOINCREMENT,
            question_id INTEGER NOT NULL REFERENCES questions(id),
            grader_id INTEGER NOT NULL REFERENCES accounts_customuser(id),
            session_status TEXT DEFAULT 'active',
            created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
            finalized_at DATETIME,
            grader_notes TEXT,
            UNIQUE(question_id, grader_id)
        )
    """)
    
    # Create model_grading_aliases table
    cursor.execute("""
        CREATE TABLE IF NOT EXISTS model_grading_aliases (
            id INTEGER PRIMARY KEY AUTOINCREMENT,
            session_id INTEGER NOT NULL REFERENCES model_grading_sessions(id) ON DELETE CASCADE,
            model_answer_id INTEGER NOT NULL REFERENCES model_answers(id),
            alias_name TEXT NOT NULL,
            tier_group INTEGER NOT NULL,
            sort_order INTEGER NOT NULL,
            created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
            UNIQUE(session_id, model_answer_id),
            UNIQUE(session_id, alias_name)
        )
    """)
    
    # Create model_gradings table with correct foreign key to accounts_customuser
    cursor.execute("""
        CREATE TABLE IF NOT EXISTS model_gradings (
            id INTEGER PRIMARY KEY AUTOINCREMENT,
            session_id INTEGER NOT NULL REFERENCES model_grading_sessions(id) ON DELETE CASCADE,
            model_answer_id INTEGER NOT NULL REFERENCES model_answers(id),
            grader_id INTEGER NOT NULL REFERENCES accounts_customuser(id),
            
            -- Binary grading categories
            correct_answer INTEGER REFERENCES grading_states(id),
            uses_correct_method INTEGER REFERENCES grading_states(id),
            logical_reasoning INTEGER REFERENCES grading_states(id),
            addresses_question INTEGER REFERENCES grading_states(id),
            mathematically_sound INTEGER REFERENCES grading_states(id),
            clear_communication INTEGER REFERENCES grading_states(id),
            uses_appropriate_tools INTEGER REFERENCES grading_states(id),
            demonstrates_understanding INTEGER REFERENCES grading_states(id),
            
            -- Progress grade (0-3)
            progress_grade INTEGER CHECK (progress_grade >= 0 AND progress_grade <= 3),
            
            -- N/A toggle
            not_applicable BOOLEAN DEFAULT 0,
            
            -- Metadata
            created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
            updated_at DATETIME DEFAULT CURRENT_TIMESTAMP,
            
            UNIQUE(session_id, model_answer_id)
        )
    """)
    
    # Create indexes for performance
    indexes = [
        "CREATE INDEX IF NOT EXISTS idx_grading_sessions_question ON model_grading_sessions(question_id)",
        "CREATE INDEX IF NOT EXISTS idx_grading_sessions_grader ON model_grading_sessions(grader_id)",
        "CREATE INDEX IF NOT EXISTS idx_grading_aliases_session ON model_grading_aliases(session_id)",
        "CREATE INDEX IF NOT EXISTS idx_grading_aliases_answer ON model_grading_aliases(model_answer_id)",
        "CREATE INDEX IF NOT EXISTS idx_gradings_session ON model_gradings(session_id)",
        "CREATE INDEX IF NOT EXISTS idx_gradings_answer ON model_gradings(model_answer_id)",
        "CREATE INDEX IF NOT EXISTS idx_gradings_grader ON model_gradings(grader_id)",
    ]
    
    for index in indexes:
        try:
            cursor.execute(index)
        except Exception as e:
            print(f"    Note: Index creation skipped: {e}")
    
    # Create trigger to update updated_at timestamp
    cursor.execute("""
        CREATE TRIGGER IF NOT EXISTS update_grading_timestamp 
        AFTER UPDATE ON model_gradings
        BEGIN
            UPDATE model_gradings 
            SET updated_at = CURRENT_TIMESTAMP 
            WHERE id = NEW.id;
        END
    """)
    
    print("✅ Enhanced features created successfully!")


def reverse_enhanced_features(apps, schema_editor):
    """Reverse the enhanced features migration."""
    db = schema_editor.connection
    cursor = db.cursor()
    
    # Drop grading system tables
    grading_tables = [
        'model_gradings',
        'model_grading_aliases', 
        'model_grading_sessions',
        'grading_states'
    ]
    
    for table in grading_tables:
        cursor.execute(f"DROP TABLE IF EXISTS {table}")
    
    # Remove released_for_grading column (SQLite doesn't support DROP COLUMN easily)
    # This would require table recreation - left as manual operation if needed
    
    # Remove active question state
    cursor.execute("DELETE FROM question_states WHERE id = 9")
    
    print("Enhanced features reversed.")


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0002_complete_evaluation_setup'),
    ]

    operations = [
        # Remove obsolete model that's not used in new system
        migrations.DeleteModel(
            name='ModelAnswerGrading',
        ),
        
        # Create the enhanced features
        migrations.RunPython(
            create_enhanced_features,
            reverse_enhanced_features,
        ),
        
        # Create Django model definitions for the grading system
        migrations.CreateModel(
            name='GradingState',
            fields=[
                ('id', models.AutoField(primary_key=True, serialize=False)),
                ('state_name', models.TextField(unique=True)),
                ('display_name', models.TextField()),
                ('description', models.TextField(blank=True, null=True)),
            ],
            options={
                'db_table': 'grading_states',
                'ordering': ['id'],
                'managed': False,
            },
        ),
        migrations.CreateModel(
            name='ModelGrading',
            fields=[
                ('id', models.AutoField(primary_key=True, serialize=False)),
                ('correct_answer', models.IntegerField(blank=True, null=True)),
                ('uses_correct_method', models.IntegerField(blank=True, null=True)),
                ('logical_reasoning', models.IntegerField(blank=True, null=True)),
                ('addresses_question', models.IntegerField(blank=True, null=True)),
                ('mathematically_sound', models.IntegerField(blank=True, null=True)),
                ('clear_communication', models.IntegerField(blank=True, null=True)),
                ('uses_appropriate_tools', models.IntegerField(blank=True, null=True)),
                ('demonstrates_understanding', models.IntegerField(blank=True, null=True)),
                ('progress_grade', models.IntegerField(blank=True, null=True)),
                ('not_applicable', models.BooleanField(default=False)),
                ('created_at', models.DateTimeField()),
                ('updated_at', models.DateTimeField()),
            ],
            options={
                'db_table': 'model_gradings',
                'ordering': ['-updated_at'],
                'managed': False,
            },
        ),
        migrations.CreateModel(
            name='ModelGradingAlias',
            fields=[
                ('id', models.AutoField(primary_key=True, serialize=False)),
                ('alias_name', models.TextField()),
                ('tier_group', models.IntegerField()),
                ('sort_order', models.IntegerField()),
                ('created_at', models.DateTimeField()),
            ],
            options={
                'db_table': 'model_grading_aliases',
                'ordering': ['alias_order'],
                'managed': False,
            },
        ),
        migrations.CreateModel(
            name='ModelGradingSession',
            fields=[
                ('id', models.AutoField(primary_key=True, serialize=False)),
                ('session_status', models.TextField(default='active')),
                ('created_at', models.DateTimeField()),
                ('finalized_at', models.DateTimeField(blank=True, null=True)),
                ('grader_notes', models.TextField(blank=True, null=True)),
            ],
            options={
                'db_table': 'model_grading_sessions',
                'ordering': ['-created_at'],
                'managed': False,
            },
        ),
    ]