{% load question_extras %}
{% comment %}
    Reusable template for displaying model answer/response with LaTeX rendering.
    
    Context variables:
    - answer_text: The answer text to display (required)
    - show_toggle: Boolean to show rendered/raw toggle button (default: False)
    - title: Title for the section (default: "Model Response")
    - border_style: Optional CSS border style
    - container_class: Additional CSS classes for the container div
{% endcomment %}

<div class="model-answer-display {{ container_class|default:'' }}">
    {% if title %}
    <h5 class="mb-3">{{ title }}</h5>
    {% endif %}
    
    {% if show_toggle|default:False %}
    <div class="d-flex justify-content-end mb-2">
        <div class="btn-group" role="group">
            <button type="button" class="btn btn-sm btn-outline-secondary active" 
                    onclick="showRenderedContent(this)">
                <i class="bi bi-eye"></i> Rendered
            </button>
            <button type="button" class="btn btn-sm btn-outline-secondary" 
                    onclick="showRawContent(this)">
                <i class="bi bi-code-slash"></i> Raw
            </button>
        </div>
    </div>
    {% endif %}
    
    {% if answer_text %}
        <div class="rendered-content mathematical-content p-3 bg-light rounded text-start"
             {% if border_style %}style="{{ border_style }}"{% endif %}>
            {{ answer_text|markdown_latex }}
        </div>
        
        {% if show_toggle|default:False %}
        <div class="raw-content border rounded p-3 bg-light text-start" style="display: none;">
            <pre style="white-space: pre-wrap; word-wrap: break-word; margin: 0;">{{ answer_text }}</pre>
        </div>
        {% endif %}
    {% else %}
        <div class="p-3 bg-light rounded">
            <p class="text-muted fst-italic mb-0">No response available.</p>
        </div>
    {% endif %}
</div>

{% if show_toggle|default:False %}
<script>
function showRenderedContent(button) {
    const container = button.closest('.model-answer-display');
    container.querySelector('.rendered-content').style.display = 'block';
    container.querySelector('.raw-content').style.display = 'none';
    
    // Update button states
    button.classList.add('active');
    button.nextElementSibling?.classList.remove('active');
}

function showRawContent(button) {
    const container = button.closest('.model-answer-display');
    container.querySelector('.rendered-content').style.display = 'none';
    container.querySelector('.raw-content').style.display = 'block';
    
    // Update button states
    button.classList.add('active');
    button.previousElementSibling?.classList.remove('active');
}
</script>
{% endif %}