"""
Update Grok 4 Display Name

Changes the display name for grok-4-0709 model from "Grok 4 Heavy" to "Grok 4"
to maintain consistency with how it's referenced elsewhere in the system.
"""

from django.db import migrations


def update_grok4_display_name(apps, schema_editor):
    """Change Grok 4 display name from 'Grok 4 Heavy' to 'Grok 4'."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Updating Grok 4 display name...")

        # Find model with display_name 'Grok 4 Heavy'
        cursor.execute("SELECT id, model_name FROM models WHERE display_name = 'Grok 4 Heavy'")
        result = cursor.fetchone()

        if result:
            model_id, model_name = result
            print(f"  Found model ID {model_id} ({model_name}) with display name 'Grok 4 Heavy'")

            # Update display name
            cursor.execute("""
                UPDATE models
                SET display_name = 'Grok 4'
                WHERE display_name = 'Grok 4 Heavy'
            """)
            print(f"  ✅ Updated display name to 'Grok 4'")
        else:
            print("  ⚠️  Model with display name 'Grok 4 Heavy' not found, skipping")

        print("✅ Grok 4 display name updated!")


def reverse_grok4_display_name(apps, schema_editor):
    """Revert Grok 4 display name back to 'Grok 4 Heavy'."""
    from django.db import connection

    with connection.cursor() as cursor:
        print("Reverting Grok 4 display name...")

        # Find model with display_name 'Grok 4'
        cursor.execute("SELECT id, model_name FROM models WHERE display_name = 'Grok 4' AND model_name = 'grok-4-0709'")
        result = cursor.fetchone()

        if result:
            model_id, model_name = result
            print(f"  Found model ID {model_id} ({model_name})")

            cursor.execute("""
                UPDATE models
                SET display_name = 'Grok 4 Heavy'
                WHERE display_name = 'Grok 4' AND model_name = 'grok-4-0709'
            """)
            print(f"  ✅ Reverted to 'Grok 4 Heavy'")
        else:
            print("  ⚠️  Model not found, skipping")

        print("✅ Revert complete!")


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0027_add_published_and_release_date'),
    ]

    operations = [
        migrations.RunPython(
            update_grok4_display_name,
            reverse_grok4_display_name,
        ),
    ]
