{% extends 'base.html' %}

{% block title %}Evaluation Results - {{ question.title }} - IMProofBench{% endblock %}

{% block page_header %}
<div class="mb-4">
    <nav aria-label="breadcrumb">
        <ol class="breadcrumb">
            <li class="breadcrumb-item">
                <a href="{% url 'questions:list' %}" class="text-decoration-none">
                    <i class="bi bi-file-earmark-text me-1"></i>
                    Questions
                </a>
            </li>
            <li class="breadcrumb-item">
                <a href="{% url 'questions:detail' question.pk %}" class="text-decoration-none">
                    {{ question.title|default:"Question"|truncatechars:30 }}
                </a>
            </li>
            <li class="breadcrumb-item active">
                Evaluation Results
            </li>
        </ol>
    </nav>
</div>
{% endblock %}

{% block content %}
<div class="container mt-4">
    {% if not question.published and not has_finalized_session %}
    {# User doesn't have a finalized grading session - Tier 1/3 results are hidden to prevent bias (not for published questions) #}
    <div class="alert alert-info">
        <i class="bi bi-info-circle me-2"></i>
        Some models are hidden to prevent bias while grading. Please complete the grading of the model answers to view the results.
        <br>
        (<a href="{% url 'questions:grading_overview' question.pk %}" class="alert-link">Go to grading page</a>)
    </div>
    {% endif %}

    {% if results %}
    <div class="table-responsive">
        <table class="table table-hover" id="resultsTable">
            <thead>
                <tr>
                    <th class="sortable" data-column="0" style="cursor: pointer;">
                        Model
                        <i class="bi bi-arrow-down-up ms-1 text-muted"></i>
                    </th>
                    <th width="150" class="text-center sortable" data-column="1" style="cursor: pointer;">
                        Subquestion Score
                        <i class="bi bi-arrow-down sort-indicator ms-1"></i>
                    </th>
                    <th width="250" class="text-center sortable" data-column="2" style="cursor: pointer;">
                        Grade
                        <i class="bi bi-arrow-down-up ms-1 text-muted"></i>
                    </th>
                </tr>
            </thead>
            <tbody>
                {% for result in results %}
                <tr>
                    <td data-sort-value="{{ result.model.display_name|default:result.model.model_name }}">
                        <strong>{{ result.model.display_name|default:result.model.model_name }}</strong>
                        <br>
                        <small class="text-muted">Tier {{ result.tier }}</small>
                    </td>
                    <td class="text-center" data-sort-value="{% if result.subquestion_score != 'N/A' %}{{ result.subquestion_score|slice:':-1' }}{% else %}-1{% endif %}">
                        {{ result.subquestion_score }}
                    </td>
                    <td class="text-center" data-sort-value="{% if '3 -' in result.grade %}3{% elif '2 -' in result.grade %}2{% elif '1 -' in result.grade %}1{% elif '0 -' in result.grade %}0{% else %}-1{% endif %}">
                        {% if "Not graded" in result.grade %}
                            <span class="text-muted fst-italic">{{ result.grade }}</span>
                        {% elif "N/A" in result.grade %}
                            <span class="text-muted">{{ result.grade }}</span>
                        {% elif "3 -" in result.grade %}
                            <span class="badge bg-success">{{ result.grade }}</span>
                        {% elif "2 -" in result.grade %}
                            <span class="badge bg-info">{{ result.grade }}</span>
                        {% elif "1 -" in result.grade %}
                            <span class="badge bg-warning">{{ result.grade }}</span>
                        {% elif "0 -" in result.grade %}
                            <span class="badge bg-danger">{{ result.grade }}</span>
                        {% else %}
                            {{ result.grade }}
                        {% endif %}
                    </td>
                </tr>
                {% endfor %}
            </tbody>
        </table>
    </div>
    {% else %}
    <div class="alert alert-info">
        <i class="bi bi-info-circle me-2"></i>
        No evaluation results available for this question yet.
    </div>
    {% endif %}

    <div class="mt-3">
        <a href="{% url 'questions:detail' question.pk %}" class="btn btn-outline-secondary">
            <i class="bi bi-arrow-left me-1"></i>
            Back to Question
        </a>
    </div>
</div>

<script>
document.addEventListener('DOMContentLoaded', function() {
    const table = document.getElementById('resultsTable');
    if (!table) return;

    const tbody = table.querySelector('tbody');
    const headers = table.querySelectorAll('th.sortable');

    let currentSort = {
        column: 1, // Subquestion Score column
        ascending: false // Descending by default
    };

    // Sort function
    function sortTable(columnIndex, ascending) {
        const rows = Array.from(tbody.querySelectorAll('tr'));

        rows.sort((a, b) => {
            const aCell = a.children[columnIndex];
            const bCell = b.children[columnIndex];

            const aValue = aCell.getAttribute('data-sort-value') || aCell.textContent.trim();
            const bValue = bCell.getAttribute('data-sort-value') || bCell.textContent.trim();

            // Try to parse as numbers
            const aNum = parseFloat(aValue);
            const bNum = parseFloat(bValue);

            if (!isNaN(aNum) && !isNaN(bNum)) {
                return ascending ? aNum - bNum : bNum - aNum;
            }

            // Fall back to string comparison
            const comparison = aValue.localeCompare(bValue);
            return ascending ? comparison : -comparison;
        });

        // Clear and re-append rows
        rows.forEach(row => tbody.appendChild(row));

        // Update sort indicators
        headers.forEach((header, index) => {
            const indicator = header.querySelector('i');
            if (parseInt(header.getAttribute('data-column')) === columnIndex) {
                indicator.className = ascending ? 'bi bi-arrow-up sort-indicator ms-1' : 'bi bi-arrow-down sort-indicator ms-1';
            } else {
                indicator.className = 'bi bi-arrow-down-up ms-1 text-muted';
            }
        });
    }

    // Add click handlers
    headers.forEach(header => {
        header.addEventListener('click', function() {
            const columnIndex = parseInt(this.getAttribute('data-column'));

            if (currentSort.column === columnIndex) {
                // Toggle direction
                currentSort.ascending = !currentSort.ascending;
            } else {
                // New column - default to descending
                currentSort.column = columnIndex;
                currentSort.ascending = false;
            }

            sortTable(currentSort.column, currentSort.ascending);
        });
    });

    // Apply default sort (Subquestion Score descending)
    sortTable(1, false);
});
</script>
{% endblock %}
