"""
Views for static pages and the project home page.

Provides:
- Home page with dashboard statistics
- Static content pages (team, guidelines, FAQ, timeline)
"""

from django.views.generic import TemplateView
from django.db.models import Count
from participants.models import Participant
from questions.models import Question, QuestionState
from model_evaluation.models import ModelGradingSession, ModelGrading, Model
from collections import defaultdict


class HomeView(TemplateView):
    """
    Home page with benchmark statistics dashboard.

    Displays:
    - Participant and model counts
    - Question statistics by state
    - Top performing models leaderboard
    """
    template_name = 'home.html'
    
    def get_context_data(self, **kwargs):
        context = super().get_context_data(**kwargs)
        
        # Get participant count
        context['participant_count'] = Participant.objects.count()
        
        # Get model count (only active models)
        context['model_count'] = Model.objects.filter(is_active=True).count()
        
        # Get question counts by state
        # First, get the state IDs (these are defined in the database)
        question_states = QuestionState.objects.all()
        state_map = {state.status.lower().replace(' ', '_'): state.id for state in question_states if state.status}
        
        # Count questions by state
        context['draft_count'] = Question.objects.filter(
            status_id=state_map.get('draft', 1)
        ).count()
        
        context['under_review_count'] = Question.objects.filter(
            status_id=state_map.get('under_review', 2)
        ).count()
        
        # Count both approved and active questions as "accepted"
        context['accepted_count'] = Question.objects.filter(
            status_id__in=[state_map.get('approved', 3), state_map.get('active', 9)]
        ).count()
        
        # Count all submitted questions (under_review, approved, and active)
        context['submitted_count'] = Question.objects.filter(
            status_id__in=[
                state_map.get('under_review', 2),
                state_map.get('approved', 3),
                state_map.get('active', 9)
            ]
        ).count()
        
        # Count active questions that have at least one finalized grading session
        active_questions_with_gradings = Question.objects.filter(
            status_id=state_map.get('active', 9)
        ).filter(
            modelgradingsession__session_status='finalized'
        ).distinct().count()
        
        context['graded_count'] = active_questions_with_gradings
        
        # Get top models based on complete solution percentage
        # Get benchmark questions
        benchmark_questions = Question.objects.filter(
            status_id__in=[state_map.get('approved', 3), state_map.get('active', 9)],
            benchmark_inclusion=True
        )
        benchmark_ids = list(benchmark_questions.values_list('id', flat=True))

        if benchmark_ids:
            # Get all gradings for benchmark questions from finalized sessions
            # Filter by finalized sessions to match scores page logic
            finalized_sessions = ModelGradingSession.objects.filter(
                question_id__in=benchmark_ids,
                session_status='finalized'
            )

            all_gradings = ModelGrading.objects.filter(
                session__in=finalized_sessions,
                grading_status='completed',
                model_answer__question_id__in=benchmark_ids,
                model_answer__released_for_grading=True,
                progress_grade__isnull=False
            ).select_related('model_answer__model').values(
                'model_answer__model_id',
                'model_answer__model__display_name',
                'model_answer__question_id',
                'progress_grade'
            )

            # Calculate complete solution percentages for each model
            model_grades = defaultdict(lambda: defaultdict(list))
            for grading in all_gradings:
                model_id = grading['model_answer__model_id']
                model_name = grading['model_answer__model__display_name']
                if model_name == "Grok 4 Heavy":
                    model_name = "Grok 4"
                question_id = grading['model_answer__question_id']
                model_grades[model_name][question_id].append(grading['progress_grade'])

            # Calculate percentages - ONLY count questions with grades (matching scores page logic)
            model_complete_percentages = []
            for model_name, questions in model_grades.items():
                complete_count = 0
                total_count = 0  # Count only questions with grades

                # Only iterate over questions that have grades for this model
                for question_id, grade_list in questions.items():
                    if grade_list:
                        avg_grade = sum(grade_list) / len(grade_list)
                        total_count += 1
                        # Round to nearest integer (grades >= 2.5 round to 3)
                        if avg_grade >= 2.5:
                            complete_count += 1

                if total_count > 0:
                    percentage = (complete_count / total_count) * 100
                    model_complete_percentages.append({
                        'name': model_name,
                        'percentage': round(percentage, 1)
                    })

            # Sort by percentage and take top 4
            model_complete_percentages.sort(key=lambda x: x['percentage'], reverse=True)
            context['top_models'] = model_complete_percentages[:4]
        else:
            context['top_models'] = []
        
        # Check if user is admin
        user = self.request.user
        if user.is_authenticated and hasattr(user, 'participant'):
            context['is_admin'] = user.participant.role == 'admin'
        else:
            context['is_admin'] = False
        
        return context


class TeamView(TemplateView):
    """Display the team members page."""
    template_name = 'team.html'


class GuidelinesView(TemplateView):
    """Display the question contribution guidelines."""
    template_name = 'guidelines.html'


class FAQView(TemplateView):
    """Display frequently asked questions."""
    template_name = 'faq.html'


class TimelineView(TemplateView):
    """Display the project timeline and milestones."""
    template_name = 'timeline.html'