{% extends "base.html" %}
{% load crispy_forms_tags %}

{% block title %}Assign Reviewer - {{ question.title|truncatechars:50 }}{% endblock %}

{% block content %}
<div class="container">
    <div class="row justify-content-center">
        <div class="col-md-8">
            <div class="card shadow">
                <div class="card-header bg-info text-white">
                    <h4 class="mb-0">
                        <i class="bi bi-person-plus me-2"></i>
                        Assign Reviewer
                    </h4>
                </div>
                <div class="card-body">
                    {% crispy form %}
                </div>
            </div>
        </div>
    </div>
</div>

<script>
document.addEventListener('DOMContentLoaded', function() {
    const invitationType = document.querySelectorAll('input[name="invitation_type"]');
    const existingSection = document.getElementById('existing-user-section');
    const externalSection = document.getElementById('external-reviewer-section');
    const sendEmailCheckbox = document.querySelector('input[name="send_email"]');
    const emailMessageSection = document.getElementById('email-message-section');
    const customMessage = document.querySelector('textarea[name="custom_message"]');
    const externalEmail = document.querySelector('input[name="external_email"]');
    const emailWarning = document.getElementById('email-collision-warning');
    
    // Handle invitation type toggle
    invitationType.forEach(radio => {
        radio.addEventListener('change', function() {
            if (this.value === 'existing') {
                existingSection.classList.remove('d-none');
                externalSection.classList.add('d-none');
                sendEmailCheckbox.disabled = false;
                
                // Update email template for existing user
                updateEmailTemplate(false);
            } else {
                existingSection.classList.add('d-none');
                externalSection.classList.remove('d-none');
                sendEmailCheckbox.checked = true;
                sendEmailCheckbox.disabled = true;
                emailMessageSection.classList.remove('d-none');
                
                // Update email template for external reviewer
                updateEmailTemplate(true);
            }
        });
    });
    
    // Handle send email checkbox
    sendEmailCheckbox.addEventListener('change', function() {
        if (this.checked) {
            emailMessageSection.classList.remove('d-none');
        } else {
            emailMessageSection.classList.add('d-none');
        }
    });
    
    // Check for email collision on external email input
    if (externalEmail) {
        let checkTimeout;
        externalEmail.addEventListener('input', function() {
            clearTimeout(checkTimeout);
            const email = this.value.trim();
            
            if (email && email.includes('@')) {
                checkTimeout = setTimeout(() => {
                    // Check if email exists via AJAX
                    fetch(`/participants/check-email/?email=${encodeURIComponent(email)}`)
                        .then(response => response.json())
                        .then(data => {
                            if (data.exists) {
                                emailWarning.innerHTML = `
                                    <i class="bi bi-exclamation-triangle me-2"></i>
                                    This email already exists in the system for user: 
                                    <strong>${data.name}</strong> (ID: ${data.id}). 
                                    Please use "Existing User" option instead.
                                `;
                                emailWarning.classList.remove('d-none');
                            } else {
                                emailWarning.classList.add('d-none');
                            }
                        })
                        .catch(() => {
                            // Silently fail if endpoint doesn't exist yet
                            emailWarning.classList.add('d-none');
                        });
                }, 500);
            } else {
                emailWarning.classList.add('d-none');
            }
        });
    }
    
    // Function to update email template
    function updateEmailTemplate(isExternal) {
        const firstName = document.querySelector('input[name="external_first_name"]');
        const lastName = document.querySelector('input[name="external_last_name"]');
        const existingUser = document.querySelector('select[name="existing_user"]');
        
        let reviewerName = "{{reviewer_first_name}}";
        
        if (isExternal && firstName && firstName.value) {
            reviewerName = firstName.value + (lastName.value ? ' ' + lastName.value : '');
        } else if (!isExternal && existingUser && existingUser.selectedOptions[0]) {
            // Extract name from "Name (email)" format
            const fullText = existingUser.selectedOptions[0].text.trim();
            const nameMatch = fullText.match(/^([^(]+)\s*\(/);
            reviewerName = nameMatch ? nameMatch[1].trim() : fullText;
        }
        
        const questionTitle = "{{ question.title|escapejs }}";
        const authorName = "{{ question.author.name|default:'Unknown'|escapejs }}";
        const inviterName = "{{ inviter_name|escapejs }}";
        
        let template = `Dear ${reviewerName},

`;
        
        if (isExternal) {
			template += `My name is ${inviterName} and I am part of a small team of mathematicians at <redacted> and <redacted>, studying the question of how good today's AI models are at solving research-level math questions. As part of this IMProofBench project, we are building a collection of challenging mathematical problems to use for testing the AI performance. 

We would like to ask for your help in verifying the mathematical correctness of one such question. If you are interested to learn more about the project, further information is available at https://improofbench.math.ethz.ch/faq/

`;
        }
        
        template += `The following question was submitted for inclusion in the IMProofBench dataset:

Title: ${questionTitle}
Author: ${authorName}

Would you be willing to review this question and:
- Verify that the phrasing is well-defined and unambiguous
- Confirm the provided solution is mathematically correct
- Make any suggestions for improvements (e.g., additional unique-answer subquestions)

We estimate that for most problems this should take between 10 and 30 minutes.

You can view the full submitted problem and write a review at:
[ACCEPT_URL]

There you will also have the option to decline this review request after viewing the question.
Alternatively, you can decline immediately by clicking:
[DECLINE_URL]

If you provide a review, the question's author will be notified and have the chance to revise the question and compose a response. After seeing the response, you have the option to submit a further review or recommend the question for acceptance in the benchmark.

Thank you for considering this request!

Best regards,
${inviterName}`;
        
        if (isExternal) {
            template += `

Note: To track your review and allow you to see the author's replies, accepting the review request will create a user account for you on our website. You can optionally set a password after submitting your review to log back in and e.g. contribute a question to the benchmark yourself.`;
        }
        
        if (customMessage) {
            customMessage.value = template;
        }
    }
    
    // Check if form has errors (preserved data from failed submission)
    const hasFormErrors = document.querySelector('.invalid-feedback') || 
                         document.querySelector('.alert-danger') ||
                         document.querySelector('.is-invalid');
    
    // Update template when external name fields change
    const externalFirstName = document.querySelector('input[name="external_first_name"]');
    const externalLastName = document.querySelector('input[name="external_last_name"]');
    
    if (externalFirstName) {
        externalFirstName.addEventListener('input', function() {
            const checkedType = document.querySelector('input[name="invitation_type"]:checked');
            if (checkedType && checkedType.value === 'external') {
                updateEmailTemplate(true);
            }
        });
    }
    
    if (externalLastName) {
        externalLastName.addEventListener('input', function() {
            const checkedType = document.querySelector('input[name="invitation_type"]:checked');
            if (checkedType && checkedType.value === 'external') {
                updateEmailTemplate(true);
            }
        });
    }
    
    // Update template when existing user selection changes
    const existingUserSelect = document.querySelector('select[name="existing_user"]');
    if (existingUserSelect) {
        existingUserSelect.addEventListener('change', function() {
            const checkedType = document.querySelector('input[name="invitation_type"]:checked');
            if (checkedType && checkedType.value === 'existing') {
                updateEmailTemplate(false);
            }
        });
    }
    
    // Initialize based on current selection
    const checkedType = document.querySelector('input[name="invitation_type"]:checked');
    if (checkedType) {
        // If form has errors, just ensure visibility without updating templates
        if (hasFormErrors) {
            if (checkedType.value === 'existing') {
                existingSection.classList.remove('d-none');
                externalSection.classList.add('d-none');
                sendEmailCheckbox.disabled = false;
            } else {
                existingSection.classList.add('d-none');
                externalSection.classList.remove('d-none');
                sendEmailCheckbox.checked = true;
                sendEmailCheckbox.disabled = true;
                emailMessageSection.classList.remove('d-none');
            }
            // Ensure email message section visibility based on checkbox
            if (sendEmailCheckbox.checked) {
                emailMessageSection.classList.remove('d-none');
            }
        } else {
            // No errors, trigger normal initialization including template update
            checkedType.dispatchEvent(new Event('change'));
        }
    }
});
</script>
{% endblock %}
