{% extends "base.html" %}

{% block title %}Review Invitations Dashboard{% endblock %}

{% block content %}
<div class="container-fluid">
    <h2 class="mb-4">
        <i class="bi bi-speedometer2 me-2"></i>
        Review Invitations Dashboard
    </h2>
    
    <!-- Status Summary Cards -->
    <div class="row mb-4">
        <div class="col">
            <div class="card text-center">
                <div class="card-body">
                    <h5 class="card-title text-warning">Pending</h5>
                    <h3>{{ status_counts.pending }}</h3>
                    <a href="?status=pending" class="btn btn-sm btn-outline-warning">View</a>
                </div>
            </div>
        </div>
        <div class="col">
            <div class="card text-center">
                <div class="card-body">
                    <h5 class="card-title text-success">Accepted</h5>
                    <h3>{{ status_counts.accepted }}</h3>
                    <a href="?status=accepted" class="btn btn-sm btn-outline-success">View</a>
                </div>
            </div>
        </div>
        <div class="col">
            <div class="card text-center">
                <div class="card-body">
                    <h5 class="card-title text-primary">Reviewed</h5>
                    <h3>{{ status_counts.reviewed }}</h3>
                    <a href="?status=reviewed" class="btn btn-sm btn-outline-primary">View</a>
                </div>
            </div>
        </div>
        <div class="col">
            <div class="card text-center">
                <div class="card-body">
                    <h5 class="card-title text-danger">Declined</h5>
                    <h3>{{ status_counts.declined }}</h3>
                    <a href="?status=declined" class="btn btn-sm btn-outline-danger">View</a>
                </div>
            </div>
        </div>
        <div class="col">
            <div class="card text-center">
                <div class="card-body">
                    <h5 class="card-title text-secondary">Expired</h5>
                    <h3>{{ status_counts.expired }}</h3>
                    <a href="?status=expired" class="btn btn-sm btn-outline-secondary">View</a>
                </div>
            </div>
        </div>
        <div class="col">
            <div class="card text-center">
                <div class="card-body">
                    <h5 class="card-title text-dark">Revoked</h5>
                    <h3>{{ status_counts.revoked }}</h3>
                    <a href="?status=revoked" class="btn btn-sm btn-outline-dark">View</a>
                </div>
            </div>
        </div>
        <div class="col">
            <div class="card text-center">
                <div class="card-body">
                    <h5 class="card-title text-info">All</h5>
                    <h3>{{ total_count }}</h3>
                    <a href="{% url 'review_invitations:dashboard' %}" class="btn btn-sm btn-outline-info">View All</a>
                </div>
            </div>
        </div>
    </div>
    
    <!-- Reminders Section -->
    {% if needs_reminder %}
    <div class="alert alert-warning mb-4">
        <h5><i class="bi bi-bell me-2"></i>Invitations Needing Reminders (10+ days old)</h5>
        <ul class="mb-0">
            {% for invitation in needs_reminder %}
            <li>
                <strong>{{ invitation.question.title|truncatechars:50 }}</strong> - 
                {% if invitation.external_first_name %}
                    {{ invitation.external_first_name }} {{ invitation.external_last_name }}
                {% else %}
                    {% if invitation.created_account %}
                        {{ invitation.created_account.participant.name|default:invitation.created_account.email }}
                    {% elif invitation.invited_participant %}
                        {{ invitation.invited_participant.name|default:invitation.invitation.email }}
                    {% elif invitation.invited_user %}
                        {{ invitation.invited_user.get_full_name|default:invitation.invitation.email }}
                    {% else %}
                        {{ invitation.invitation.email }}
                    {% endif %}
                {% endif %}
                (invited {{ invitation.created_at|timesince }} ago)
                <button class="btn btn-sm btn-warning ms-2 send-reminder-btn" 
                        data-invitation-id="{{ invitation.id }}">
                    Send Reminder
                </button>
            </li>
            {% endfor %}
        </ul>
    </div>
    {% endif %}
    
    <!-- Invitations Table -->
    <div class="card">
        <div class="card-header">
            <h5 class="mb-0">Review Invitations</h5>
        </div>
        <div class="card-body">
            <div class="table-responsive">
                <table class="table table-hover">
                    <thead>
                        <tr>
                            <th>Question</th>
                            <th>Reviewer</th>
                            <th>Type</th>
                            <th>Status</th>
                            <th>Invited By</th>
                            <th>Created</th>
                            <th>Last Accessed</th>
                            <th>Actions</th>
                        </tr>
                    </thead>
                    <tbody>
                        {% for invitation in invitations %}
                        <tr>
                            <td>
                                <a href="{{ invitation.question.get_absolute_url }}">
                                    {{ invitation.question.title|truncatechars:40 }}
                                </a>
                            </td>
                            <td>
                                {% if invitation.external_first_name %}
                                    <span class="badge bg-info">External</span>
                                    {{ invitation.external_first_name }} {{ invitation.external_last_name }}
                                    <br><small class="text-muted">{{ invitation.invitation.email }}</small>
                                {% else %}
                                    <span class="badge bg-primary">Internal</span>
                                    {% if invitation.created_account %}
                                        {{ invitation.created_account.participant.name|default:invitation.created_account.email }}
                                    {% elif invitation.invited_participant %}
                                        {{ invitation.invited_participant.name }}
                                    {% elif invitation.invited_user %}
                                        {{ invitation.invited_user.email }}
                                    {% elif invitation.invitation %}
                                        {{ invitation.invitation.email }}
                                    {% else %}
                                        <span class="text-muted">Direct assignment</span>
                                    {% endif %}
                                {% endif %}
                            </td>
                            <td>
                                {% if invitation.external_first_name %}
                                    <span class="badge bg-info">External</span>
                                {% else %}
                                    <span class="badge bg-primary">Internal</span>
                                {% endif %}
                            </td>
                            <td>
                                {% if invitation.status == 'pending' %}
                                    {% if invitation.is_expired %}
                                        <span class="badge bg-secondary">Expired</span>
                                    {% else %}
                                        <span class="badge bg-warning">Pending</span>
                                    {% endif %}
                                {% elif invitation.status == 'accepted' %}
                                    {% if invitation.review_submitted %}
                                        <span class="badge bg-primary">
                                            <i class="bi bi-check-circle-fill me-1"></i>Reviewed
                                        </span>
                                    {% else %}
                                        <span class="badge bg-success">Accepted</span>
                                    {% endif %}
                                {% elif invitation.status == 'declined' %}
                                    <span class="badge bg-danger">Declined</span>
                                {% elif invitation.status == 'revoked' %}
                                    <span class="badge bg-dark">Revoked</span>
                                {% else %}
                                    <span class="badge bg-secondary">{{ invitation.get_status_display }}</span>
                                {% endif %}
                            </td>
                            <td>
                                {% if invitation.inviter_participant %}
                                    {{ invitation.inviter_participant.name }}
                                {% else %}
                                    {{ invitation.invited_by.get_full_name|default:invitation.invited_by.email }}
                                {% endif %}
                            </td>
                            <td>{{ invitation.created_at|date:"M j, Y" }}</td>
                            <td>
                                {% if invitation.last_accessed_at %}
                                    {{ invitation.last_accessed_at|date:"M j, Y" }}
                                {% else %}
                                    <span class="text-muted">Never</span>
                                {% endif %}
                            </td>
                            <td>
                                {% if invitation.status == 'pending' and not invitation.is_expired %}
                                    <button class="btn btn-sm btn-warning revoke-btn" 
                                            data-invitation-id="{{ invitation.id }}">
                                        Revoke
                                    </button>
                                    {% if invitation.needs_reminder %}
                                        <button class="btn btn-sm btn-info send-reminder-btn" 
                                                data-invitation-id="{{ invitation.id }}">
                                            Remind
                                        </button>
                                    {% endif %}
                                {% endif %}
                                
                                {% if invitation.created_account %}
                                    <span class="badge bg-success">Account Created</span>
                                {% endif %}
                            </td>
                        </tr>
                        {% empty %}
                        <tr>
                            <td colspan="8" class="text-center text-muted">No invitations found.</td>
                        </tr>
                        {% endfor %}
                    </tbody>
                </table>
            </div>
            
            <!-- Pagination -->
            {% if is_paginated %}
            <nav aria-label="Page navigation">
                <ul class="pagination justify-content-center">
                    {% if page_obj.has_previous %}
                        <li class="page-item">
                            <a class="page-link" href="?page=1{% if request.GET.status %}&status={{ request.GET.status }}{% endif %}">First</a>
                        </li>
                        <li class="page-item">
                            <a class="page-link" href="?page={{ page_obj.previous_page_number }}{% if request.GET.status %}&status={{ request.GET.status }}{% endif %}">Previous</a>
                        </li>
                    {% endif %}
                    
                    <li class="page-item active">
                        <span class="page-link">
                            Page {{ page_obj.number }} of {{ page_obj.paginator.num_pages }}
                        </span>
                    </li>
                    
                    {% if page_obj.has_next %}
                        <li class="page-item">
                            <a class="page-link" href="?page={{ page_obj.next_page_number }}{% if request.GET.status %}&status={{ request.GET.status }}{% endif %}">Next</a>
                        </li>
                        <li class="page-item">
                            <a class="page-link" href="?page={{ page_obj.paginator.num_pages }}{% if request.GET.status %}&status={{ request.GET.status }}{% endif %}">Last</a>
                        </li>
                    {% endif %}
                </ul>
            </nav>
            {% endif %}
        </div>
    </div>
</div>

<script>
document.addEventListener('DOMContentLoaded', function() {
    // Handle revoke buttons
    document.querySelectorAll('.revoke-btn').forEach(btn => {
        btn.addEventListener('click', function() {
            if (confirm('Are you sure you want to revoke this invitation? The reviewer will no longer be able to accept it.')) {
                const invitationId = this.dataset.invitationId;
                
                // Create a form to submit the POST request
                const form = document.createElement('form');
                form.method = 'POST';
                form.action = `/review-invitations/revoke/${invitationId}/`;
                
                // Add CSRF token
                const csrfToken = document.querySelector('[name=csrfmiddlewaretoken]');
                if (csrfToken) {
                    const csrfInput = document.createElement('input');
                    csrfInput.type = 'hidden';
                    csrfInput.name = 'csrfmiddlewaretoken';
                    csrfInput.value = csrfToken.value;
                    form.appendChild(csrfInput);
                } else {
                    // Get CSRF token from cookie if not in page
                    const csrfCookie = document.cookie
                        .split('; ')
                        .find(row => row.startsWith('csrftoken='));
                    if (csrfCookie) {
                        const csrfInput = document.createElement('input');
                        csrfInput.type = 'hidden';
                        csrfInput.name = 'csrfmiddlewaretoken';
                        csrfInput.value = csrfCookie.split('=')[1];
                        form.appendChild(csrfInput);
                    }
                }
                
                document.body.appendChild(form);
                form.submit();
            }
        });
    });
    
    // Handle reminder buttons
    document.querySelectorAll('.send-reminder-btn').forEach(btn => {
        btn.addEventListener('click', function() {
            if (confirm('Send a reminder email for this invitation?')) {
                const invitationId = this.dataset.invitationId;
                // TODO: Implement AJAX call to send reminder
                console.log('Send reminder for invitation:', invitationId);
            }
        });
    });
});
</script>
{% endblock %}