from django.contrib import admin
from .models import (
    Company, ModelTier, Model, ModelAttempt, ModelAnswer,
    ModelSubquestionAnswer, EvaluationQueue, CompanyExecutionLock,
    ModelArg, ReasoningArg
)


@admin.register(Company)
class CompanyAdmin(admin.ModelAdmin):
    """Admin interface for AI companies."""
    list_display = ['id', 'company_name', 'api_key', 'active_models_count']
    search_fields = ['company_name']
    ordering = ['company_name']
    
    def active_models_count(self, obj):
        """Count of active models for this company."""
        return obj.models.filter(is_active=True).count()
    active_models_count.short_description = 'Active Models'


@admin.register(ModelTier)
class ModelTierAdmin(admin.ModelAdmin):
    """Admin interface for model tier management."""
    list_display = ['tier_number', 'tier_name', 'requires_main_grading', 
                   'appears_on_leaderboard', 'is_active']
    list_filter = ['requires_main_grading', 'appears_on_leaderboard', 'is_active']
    ordering = ['tier_number']
    search_fields = ['tier_name', 'description']


# Inline admin for ModelArg
class ModelArgInline(admin.TabularInline):
    model = ModelArg
    extra = 1
    fields = ['arg_name', 'arg_value', 'created_at', 'updated_at']
    readonly_fields = ['created_at', 'updated_at']
    verbose_name = "Model Argument"
    verbose_name_plural = "Model Arguments (Client Initialization)"

# Inline admin for ReasoningArg
class ReasoningArgInline(admin.TabularInline):
    model = ReasoningArg
    extra = 1
    fields = ['arg_name', 'arg_value', 'created_at', 'updated_at']
    readonly_fields = ['created_at', 'updated_at']
    verbose_name = "Reasoning Argument"
    verbose_name_plural = "Reasoning Arguments (Evaluation Parameters)"

@admin.register(Model) 
class ModelAdmin(admin.ModelAdmin):
    """Admin interface for model management."""
    list_display = ['id', 'full_model_name', 'display_name', 'company', 'tier', 'framework_type', 'is_active']
    list_filter = ['company', 'tier', 'framework_type', 'is_active']
    search_fields = ['model_name', 'display_name', 'company__company_name']
    ordering = ['tier__tier_number', 'company__company_name', 'model_name']
    raw_id_fields = ['company', 'tier']
    inlines = [ModelArgInline, ReasoningArgInline]
    
    fieldsets = (
        ('Basic Information', {
            'fields': ('model_name', 'display_name', 'company', 'tier')
        }),
        ('Configuration', {
            'fields': ('framework_type', 'instructions', 'is_active')
        }),
    )
    
    def full_model_name(self, obj):
        """Display the full company/model_name format."""
        return obj.get_full_model_name()
    full_model_name.short_description = 'Full Model Name'


@admin.register(ModelAttempt)
class ModelAttemptAdmin(admin.ModelAdmin):
    """Admin interface for model evaluation attempts."""
    list_display = ['id', 'model', 'question_title', 'attempt_number', 'time']
    list_filter = ['attempt_number', 'time', 'model__tier']
    search_fields = ['model__model_name', 'question__title']
    ordering = ['-time']
    raw_id_fields = ['model', 'question']
    
    def question_title(self, obj):
        return obj.question.title[:50] + "..." if len(obj.question.title) > 50 else obj.question.title
    question_title.short_description = 'Question'


@admin.register(ModelAnswer)
class ModelAnswerAdmin(admin.ModelAdmin):
    """Admin interface for model answers."""
    list_display = ['id', 'model', 'question_title', 'attempt_time', 'has_terminal_log']
    list_filter = ['attempt__time', 'model__tier']
    search_fields = ['model__model_name', 'question__title', 'answer']
    ordering = ['-attempt__time']
    raw_id_fields = ['attempt', 'question', 'model']
    readonly_fields = ['terminal_log_hash']
    
    def question_title(self, obj):
        return obj.question.title[:40] + "..." if len(obj.question.title) > 40 else obj.question.title
    question_title.short_description = 'Question'
    
    def attempt_time(self, obj):
        return obj.attempt.time
    attempt_time.short_description = 'Attempt Time'
    
    def has_terminal_log(self, obj):
        return bool(obj.terminal_log_hash)
    has_terminal_log.boolean = True
    has_terminal_log.short_description = 'Terminal Log'


@admin.register(ModelSubquestionAnswer)
class ModelSubquestionAnswerAdmin(admin.ModelAdmin):
    """Admin interface for subquestion answers."""
    list_display = ['id', 'model', 'subquestion_text', 'answer_preview', 'is_correct']
    list_filter = ['is_correct', 'attempt__time', 'model__tier']
    search_fields = ['model__model_name', 'subquestion__text', 'answer']
    ordering = ['-attempt__time', 'subquestion__subquestion_order']
    raw_id_fields = ['attempt', 'subquestion', 'model']
    
    def subquestion_text(self, obj):
        return obj.subquestion.text[:30] + "..." if len(obj.subquestion.text) > 30 else obj.subquestion.text
    subquestion_text.short_description = 'Subquestion'
    
    def answer_preview(self, obj):
        if not obj.answer:
            return "(No answer)"
        return obj.answer[:40] + "..." if len(obj.answer) > 40 else obj.answer
    answer_preview.short_description = 'Answer Preview'


@admin.register(EvaluationQueue)
class EvaluationQueueAdmin(admin.ModelAdmin):
    """Admin interface for evaluation queue management."""
    list_display = ['id', 'attempt_info', 'tier_priority', 'status', 
                   'submitted_at']
    list_filter = ['status', 'submitted_at', 'attempt__model__tier']
    search_fields = ['attempt__model__model_name', 'attempt__question__title']
    ordering = ['-submitted_at']  # Show newest submissions first
    raw_id_fields = ['attempt']
    readonly_fields = ['submitted_at', 'started_at', 'completed_at']
    
    def attempt_info(self, obj):
        model = obj.attempt.model.model_name
        question = obj.attempt.question.title[:40]
        attempt_num = obj.attempt.attempt_number
        return f"{model} - {question}... (Attempt {attempt_num})"
    attempt_info.short_description = 'Attempt Details'
    
    actions = ['cancel_evaluations', 'reset_failed_evaluations']
    
    def cancel_evaluations(self, request, queryset):
        """Cancel selected pending evaluations."""
        updated = queryset.filter(status='pending').update(status='cancelled')
        self.message_user(request, f"{updated} evaluations cancelled.")
    cancel_evaluations.short_description = "Cancel selected pending evaluations"
    
    def reset_failed_evaluations(self, request, queryset):
        """Reset failed evaluations to pending for retry."""
        updated = queryset.filter(status='failed').update(
            status='pending', 
            error_message=None,
            started_at=None
        )
        self.message_user(request, f"{updated} failed evaluations reset to pending.")
    reset_failed_evaluations.short_description = "Reset failed evaluations to pending"


@admin.register(CompanyExecutionLock)
class CompanyExecutionLockAdmin(admin.ModelAdmin):
    """Admin interface for company execution locks."""
    list_display = ['id', 'company', 'locked_at', 'locked_by_queue']
    list_filter = ['locked_at', 'company']
    ordering = ['-locked_at']
    raw_id_fields = ['company', 'locked_by_queue']
    readonly_fields = ['locked_at']


class BaseArgAdmin(admin.ModelAdmin):
    """Base admin class for ModelArg and ReasoningArg with shared functionality."""
    list_display = ['id', 'model_display', 'arg_name', 'arg_value_preview', 'created_at', 'updated_at']
    list_filter = ['arg_name', 'model__company', 'model__tier']
    search_fields = ['model__model_name', 'model__display_name', 'arg_name', 'arg_value']
    ordering = ['model__company__company_name', 'model__model_name', 'arg_name']
    raw_id_fields = ['model']
    readonly_fields = ['created_at', 'updated_at']

    def model_display(self, obj):
        """Display model with company prefix."""
        return obj.model.get_full_model_name() if obj.model else "-"
    model_display.short_description = 'Model'

    def arg_value_preview(self, obj):
        """Preview of argument value (truncated if long)."""
        if not obj.arg_value:
            return "(empty)"
        value = str(obj.arg_value)
        return value[:50] + "..." if len(value) > 50 else value
    arg_value_preview.short_description = 'Value'


@admin.register(ModelArg)
class ModelArgAdmin(BaseArgAdmin):
    """Admin interface for model arguments (client initialization parameters)."""
    pass


@admin.register(ReasoningArg)
class ReasoningArgAdmin(BaseArgAdmin):
    """Admin interface for reasoning arguments (evaluation parameters)."""
    pass