"""
Fix issues from the spring cleaning consolidation.

The consolidation accidentally removed several fields that should have been preserved:
1. grading_status column from model_gradings table
2. is_active column from grading_states table
3. comments and flag_for_organizers columns from model_gradings table

This migration restores all missing fields.
"""

from django.db import migrations


def add_missing_grading_status(apps, schema_editor):
    """Add all missing fields from the consolidation."""
    cursor = schema_editor.connection.cursor()
    
    print("Fixing issues from spring cleaning consolidation...")
    
    # First, check what columns already exist
    cursor.execute("PRAGMA table_info(model_gradings)")
    existing_columns = {col[1] for col in cursor.fetchall()}
    
    # Only recreate table if grading_status is missing
    if 'grading_status' not in existing_columns:
        print("  Adding missing grading_status, comments, and flag_for_organizers to model_gradings...")
        
        # 1. Create new table with ALL original columns
        cursor.execute("""
            CREATE TABLE IF NOT EXISTS model_gradings_new (
                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),
                
                -- Grading status (WAS MISSING!)
                grading_status TEXT DEFAULT 'not_started',
                
                -- 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),
                
                -- Additional fields (WERE MISSING!)
                comments TEXT,
                flag_for_organizers BOOLEAN DEFAULT 0,
                
                -- N/A toggle
                not_applicable BOOLEAN DEFAULT 0,
                
                -- Metadata
                created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
                updated_at DATETIME DEFAULT CURRENT_TIMESTAMP,
                finalized_at DATETIME,
                
                UNIQUE(session_id, model_answer_id)
            )
        """)
    
        # 2. Copy existing data (if any) and infer grading_status based on field completion
        cursor.execute("""
            INSERT INTO model_gradings_new (
                id, session_id, model_answer_id, grader_id,
                grading_status,
                correct_answer, uses_correct_method, logical_reasoning, addresses_question,
                mathematically_sound, clear_communication, uses_appropriate_tools, demonstrates_understanding,
                progress_grade, comments, flag_for_organizers, not_applicable, created_at, updated_at, finalized_at
            )
            SELECT 
                id, session_id, model_answer_id, grader_id,
                CASE 
                    WHEN progress_grade IS NOT NULL 
                        AND correct_answer IS NOT NULL 
                        AND uses_correct_method IS NOT NULL
                        AND logical_reasoning IS NOT NULL
                        AND addresses_question IS NOT NULL
                        AND mathematically_sound IS NOT NULL
                        AND clear_communication IS NOT NULL
                        AND uses_appropriate_tools IS NOT NULL
                        AND demonstrates_understanding IS NOT NULL
                    THEN 'completed'
                    WHEN correct_answer IS NOT NULL 
                        OR uses_correct_method IS NOT NULL
                        OR logical_reasoning IS NOT NULL
                        OR addresses_question IS NOT NULL
                        OR mathematically_sound IS NOT NULL
                        OR clear_communication IS NOT NULL
                        OR uses_appropriate_tools IS NOT NULL
                        OR demonstrates_understanding IS NOT NULL
                        OR progress_grade IS NOT NULL
                    THEN 'in_progress'
                    ELSE 'not_started'
                END as grading_status,
                correct_answer, uses_correct_method, logical_reasoning, addresses_question,
                mathematically_sound, clear_communication, uses_appropriate_tools, demonstrates_understanding,
                progress_grade, 
                NULL as comments,  -- Default to NULL
                0 as flag_for_organizers,  -- Default to false
                not_applicable, created_at, updated_at,
                NULL as finalized_at  -- Default to NULL
            FROM model_gradings
        """)
    
        # 3. Drop old table
        cursor.execute("DROP TABLE model_gradings")
        
        # 4. Rename new table
        cursor.execute("ALTER TABLE model_gradings_new RENAME TO model_gradings")
        
        # 5. Recreate indexes
        cursor.execute("""
            CREATE INDEX IF NOT EXISTS idx_gradings_session 
            ON model_gradings(session_id)
        """)
        cursor.execute("""
            CREATE INDEX IF NOT EXISTS idx_gradings_answer 
            ON model_gradings(model_answer_id)
        """)
        cursor.execute("""
            CREATE INDEX IF NOT EXISTS idx_gradings_grader 
            ON model_gradings(grader_id)
        """)
        
        # 6. Recreate trigger
        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("✅ model_gradings table fixed successfully!")
    else:
        print("  model_gradings table already has grading_status column - skipping")
    
    # Fix grading_states table - add missing is_active column AND fix state_type data
    cursor.execute("PRAGMA table_info(grading_states)")
    grading_states_columns = {col[1] for col in cursor.fetchall()}
    
    # Always recreate to fix the state_type data (was put in description column)
    print("  Fixing grading_states table (is_active and state_type)...")
    
    # Get current data
    cursor.execute("SELECT id, state_name, display_name FROM grading_states")
    current_states = cursor.fetchall()
    
    # Create new table with proper structure
    cursor.execute("""
        CREATE TABLE IF NOT EXISTS grading_states_new (
            id INTEGER PRIMARY KEY AUTOINCREMENT,
            state_name TEXT UNIQUE NOT NULL,
            display_name TEXT NOT NULL,
            state_type TEXT NOT NULL,  -- This should be 'binary' or 'special'
            description TEXT,
            is_active BOOLEAN DEFAULT 1
        )
    """)
    
    # Insert data with correct state_type values
    state_type_mapping = {
        'true': ('binary', 'The statement/calculation is correct'),
        'false': ('binary', 'The statement/calculation is incorrect'),
        'not_sure': ('binary', 'Cannot determine correctness'),
        'not_applicable': ('special', 'Not applicable to this answer')
    }
    
    for state_id, state_name, display_name in current_states:
        state_type, description = state_type_mapping.get(state_name, ('binary', ''))
        cursor.execute("""
            INSERT INTO grading_states_new (id, state_name, display_name, state_type, description, is_active)
            VALUES (%s, %s, %s, %s, %s, 1)
        """, [state_id, state_name, display_name, state_type, description])
    
    # Drop old table and rename new one
    cursor.execute("DROP TABLE grading_states")
    cursor.execute("ALTER TABLE grading_states_new RENAME TO grading_states")
    
    print("✅ grading_states table fixed successfully!")
    
    print("✅ All consolidation issues fixed successfully!")


def reverse_fix_grading(apps, schema_editor):
    """Reverses all the fixes - removes added fields."""
    cursor = schema_editor.connection.cursor()
    
    print("Reversing consolidation fixes...")
    
    # Reverse model_gradings changes
    cursor.execute("""
        CREATE TABLE IF NOT EXISTS model_gradings_new (
            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)
        )
    """)
    
    cursor.execute("""
        INSERT INTO model_gradings_new 
        SELECT id, session_id, model_answer_id, grader_id,
            correct_answer, uses_correct_method, logical_reasoning, addresses_question,
            mathematically_sound, clear_communication, uses_appropriate_tools, demonstrates_understanding,
            progress_grade, not_applicable, created_at, updated_at
        FROM model_gradings
    """)
    
    cursor.execute("DROP TABLE model_gradings")
    cursor.execute("ALTER TABLE model_gradings_new RENAME TO model_gradings")
    
    # Recreate indexes
    cursor.execute("CREATE INDEX IF NOT EXISTS idx_gradings_session ON model_gradings(session_id)")
    cursor.execute("CREATE INDEX IF NOT EXISTS idx_gradings_answer ON model_gradings(model_answer_id)")
    cursor.execute("CREATE INDEX IF NOT EXISTS idx_gradings_grader ON model_gradings(grader_id)")
    
    # Recreate trigger
    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
    """)
    
    # Reverse grading_states changes (back to consolidated version)
    cursor.execute("""
        CREATE TABLE IF NOT EXISTS grading_states_new (
            id INTEGER PRIMARY KEY AUTOINCREMENT,
            state_name TEXT UNIQUE NOT NULL,
            display_name TEXT NOT NULL,
            description TEXT
        )
    """)
    
    # Put state_type data back into description column (as consolidation did)
    cursor.execute("""
        INSERT INTO grading_states_new (id, state_name, display_name, description)
        SELECT id, state_name, display_name, description  -- Use actual description not state_type
        FROM grading_states
    """)
    
    cursor.execute("DROP TABLE grading_states")
    cursor.execute("ALTER TABLE grading_states_new RENAME TO grading_states")
    
    print("Consolidation fixes reversed.")


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0004_model_configuration'),
    ]

    operations = [
        migrations.RunPython(
            add_missing_grading_status,
            reverse_fix_grading,
        ),
    ]