{% extends 'base.html' %}
{% load static %}
{% load question_extras %}

{% block title %}History: {{ question.title }}{% endblock %}

{% block extra_css %}
<style>
/* Version list styling */
.version-list {
    max-height: 400px;
    overflow-y: auto;
}

.version-item {
    padding: 10px 15px;
    border-bottom: 1px solid #dee2e6;
    cursor: pointer;
    transition: background-color 0.15s;
}

.version-item:hover {
    background-color: #f8f9fa;
}

.version-item.selected {
    background-color: #e7f1ff;
    border-left: 3px solid #0d6efd;
}

.version-number {
    font-weight: 600;
    color: #495057;
}

.version-meta {
    font-size: 0.85rem;
    color: #6c757d;
}

/* Diff styling */
.diff-container {
    font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
    font-size: 0.875rem;
    background-color: #f6f8fa;
    border-radius: 6px;
    overflow-x: auto;
}

.diff-line {
    padding: 2px 10px;
    white-space: pre-wrap;
    word-break: break-all;
}

.diff-added {
    background-color: #d4edda;
    color: #155724;
}

.diff-removed {
    background-color: #f8d7da;
    color: #721c24;
}

.diff-header {
    background-color: #e9ecef;
    color: #495057;
    font-weight: 500;
}

.diff-unchanged {
    color: #6c757d;
}

/* Field comparison cards */
.field-card {
    margin-bottom: 15px;
}

.field-card.changed {
    border-left: 3px solid #ffc107;
}

.field-card.unchanged {
    opacity: 0.7;
}

/* Subquestion diff */
.subquestion-diff {
    background-color: #f8f9fa;
    padding: 10px;
    border-radius: 6px;
    margin-top: 10px;
}

.subquestion-item {
    padding: 8px;
    margin: 5px 0;
    background-color: white;
    border-radius: 4px;
    border: 1px solid #dee2e6;
}

/* Compare controls */
.compare-controls {
    background-color: #f8f9fa;
    padding: 15px;
    border-radius: 6px;
    margin-bottom: 20px;
}
</style>
{% endblock %}

{% block content %}
<div class="container-fluid py-4">
    <!-- Header -->
    <div class="d-flex justify-content-between align-items-center mb-4">
        <div>
            <h1 class="h3 mb-1">
                <i class="bi bi-clock-history me-2"></i>
                Edit History
            </h1>
            <p class="text-muted mb-0">
                <a href="{% url 'questions:detail' question.id %}">Q{{ question.id }}: {{ question.title }}</a>
            </p>
        </div>
        <div>
            <a href="{% url 'questions:detail' question.id %}" class="btn btn-outline-secondary">
                <i class="bi bi-arrow-left me-1"></i> Back to Question
            </a>
            <a href="{% url 'questions:edit' question.id %}" class="btn btn-outline-primary">
                <i class="bi bi-pencil me-1"></i> Edit Question
            </a>
        </div>
    </div>

    {% if versions %}
    <div class="row">
        <!-- Version List -->
        <div class="col-md-4">
            <div class="card">
                <div class="card-header">
                    <h5 class="mb-0">
                        <i class="bi bi-list-ol me-2"></i>
                        Versions ({{ versions|length }})
                    </h5>
                </div>
                <div class="card-body p-0 version-list">
                    {% for version in versions %}
                    <div class="version-item {% if comparing and version1.version_number == version.version_number or version2.version_number == version.version_number %}selected{% endif %}"
                         data-version="{{ version.version_number }}">
                        <div class="d-flex justify-content-between align-items-start">
                            <div>
                                <span class="version-number">Version {{ version.version_number }}</span>
                                {% if forloop.first %}
                                    <span class="badge bg-primary ms-2">Current</span>
                                {% endif %}
                            </div>
                            <small class="text-muted">
                                {{ version.created_at|date:"M d, Y" }}
                            </small>
                        </div>
                        <div class="version-meta mt-1">
                            <i class="bi bi-clock me-1"></i>
                            {{ version.created_at|time:"H:i" }}
                            {% if version.created_by %}
                                <span class="ms-2">
                                    <i class="bi bi-person me-1"></i>
                                    {{ version.created_by.name }}
                                </span>
                            {% endif %}
                        </div>
                    </div>
                    {% endfor %}
                </div>
            </div>

            <!-- Compare Controls -->
            <div class="card mt-3">
                <div class="card-header">
                    <h6 class="mb-0">
                        <i class="bi bi-arrows-angle-expand me-2"></i>
                        Compare Versions
                    </h6>
                </div>
                <div class="card-body">
                    <form method="get" action="">
                        <div class="row g-2">
                            <div class="col-6">
                                <label class="form-label small">From:</label>
                                <select name="v1" class="form-select form-select-sm">
                                    {% for version in versions reversed %}
                                    <option value="{{ version.version_number }}"
                                            {% if request.GET.v1 == version.version_number|stringformat:"d" %}selected{% endif %}>
                                        v{{ version.version_number }}
                                    </option>
                                    {% endfor %}
                                </select>
                            </div>
                            <div class="col-6">
                                <label class="form-label small">To:</label>
                                <select name="v2" class="form-select form-select-sm">
                                    {% for version in versions %}
                                    <option value="{{ version.version_number }}"
                                            {% if request.GET.v2 == version.version_number|stringformat:"d" %}selected{% elif forloop.first and not request.GET.v2 %}selected{% endif %}>
                                        v{{ version.version_number }}
                                    </option>
                                    {% endfor %}
                                </select>
                            </div>
                        </div>
                        <button type="submit" class="btn btn-primary btn-sm w-100 mt-2">
                            <i class="bi bi-arrow-left-right me-1"></i> Compare
                        </button>
                    </form>
                </div>
            </div>
        </div>

        <!-- Diff Display -->
        <div class="col-md-8">
            {% if comparing %}
            <div class="card">
                <div class="card-header d-flex justify-content-between align-items-center">
                    <h5 class="mb-0">
                        <i class="bi bi-file-diff me-2"></i>
                        Comparing Version {{ version1.version_number }} &rarr; Version {{ version2.version_number }}
                    </h5>
                    <a href="{% url 'questions:history' question.id %}" class="btn btn-sm btn-outline-secondary">
                        <i class="bi bi-x me-1"></i> Clear
                    </a>
                </div>
                <div class="card-body">
                    <!-- Title -->
                    <div class="field-card card {% if diff_data.title.changed %}changed{% else %}unchanged{% endif %}">
                        <div class="card-header py-2 d-flex justify-content-between align-items-center">
                            <span><strong>{{ diff_data.title.display_name }}</strong></span>
                            {% if diff_data.title.changed %}
                                <span class="badge bg-warning text-dark">Changed</span>
                            {% else %}
                                <span class="badge bg-secondary">Unchanged</span>
                            {% endif %}
                        </div>
                        {% if diff_data.title.changed %}
                        <div class="card-body">
                            <div class="row">
                                <div class="col-6">
                                    <small class="text-muted">Version {{ version1.version_number }}:</small>
                                    <div class="p-2 bg-light rounded mt-1">{{ diff_data.title.old_value }}</div>
                                </div>
                                <div class="col-6">
                                    <small class="text-muted">Version {{ version2.version_number }}:</small>
                                    <div class="p-2 bg-light rounded mt-1">{{ diff_data.title.new_value }}</div>
                                </div>
                            </div>
                        </div>
                        {% endif %}
                    </div>

                    <!-- Question Text -->
                    <div class="field-card card {% if diff_data.text.changed %}changed{% else %}unchanged{% endif %}">
                        <div class="card-header py-2 d-flex justify-content-between align-items-center">
                            <span><strong>{{ diff_data.text.display_name }}</strong></span>
                            {% if diff_data.text.changed %}
                                <span class="badge bg-warning text-dark">Changed</span>
                            {% else %}
                                <span class="badge bg-secondary">Unchanged</span>
                            {% endif %}
                        </div>
                        {% if diff_data.text.changed %}
                        <div class="card-body p-0">
                            <div class="diff-container">
                                {% for line in diff_data.text.diff_lines %}
                                    {% if line|slice:":3" == "---" or line|slice:":3" == "+++" %}
                                        <div class="diff-line diff-header">{{ line }}</div>
                                    {% elif line|slice:":2" == "@@" %}
                                        <div class="diff-line diff-header">{{ line }}</div>
                                    {% elif line|first == "+" %}
                                        <div class="diff-line diff-added">{{ line }}</div>
                                    {% elif line|first == "-" %}
                                        <div class="diff-line diff-removed">{{ line }}</div>
                                    {% else %}
                                        <div class="diff-line diff-unchanged">{{ line }}</div>
                                    {% endif %}
                                {% endfor %}
                            </div>
                        </div>
                        {% endif %}
                    </div>

                    <!-- Solution -->
                    <div class="field-card card {% if diff_data.solution.changed %}changed{% else %}unchanged{% endif %}">
                        <div class="card-header py-2 d-flex justify-content-between align-items-center">
                            <span><strong>{{ diff_data.solution.display_name }}</strong></span>
                            {% if diff_data.solution.changed %}
                                <span class="badge bg-warning text-dark">Changed</span>
                            {% else %}
                                <span class="badge bg-secondary">Unchanged</span>
                            {% endif %}
                        </div>
                        {% if diff_data.solution.changed %}
                        <div class="card-body p-0">
                            <div class="diff-container">
                                {% for line in diff_data.solution.diff_lines %}
                                    {% if line|slice:":3" == "---" or line|slice:":3" == "+++" %}
                                        <div class="diff-line diff-header">{{ line }}</div>
                                    {% elif line|slice:":2" == "@@" %}
                                        <div class="diff-line diff-header">{{ line }}</div>
                                    {% elif line|first == "+" %}
                                        <div class="diff-line diff-added">{{ line }}</div>
                                    {% elif line|first == "-" %}
                                        <div class="diff-line diff-removed">{{ line }}</div>
                                    {% else %}
                                        <div class="diff-line diff-unchanged">{{ line }}</div>
                                    {% endif %}
                                {% endfor %}
                            </div>
                        </div>
                        {% endif %}
                    </div>

                    <!-- Difficulty -->
                    <div class="field-card card">
                        <div class="card-header py-2">
                            <strong>Difficulty Ratings</strong>
                        </div>
                        <div class="card-body">
                            <div class="row">
                                {% for field in "difficulty_background,difficulty_reasoning,difficulty_insight,difficulty_compute"|split:"," %}
                                <div class="col-3 text-center">
                                    <small class="text-muted">{{ diff_data|get_item:field|get_item:"display_name" }}</small>
                                    <div class="{% if diff_data|get_item:field|get_item:'changed' %}text-warning fw-bold{% endif %}">
                                        {{ diff_data|get_item:field|get_item:"old_value"|default:"-" }}
                                        {% if diff_data|get_item:field|get_item:"changed" %}
                                            &rarr; {{ diff_data|get_item:field|get_item:"new_value"|default:"-" }}
                                        {% endif %}
                                    </div>
                                </div>
                                {% endfor %}
                            </div>
                        </div>
                    </div>

                    <!-- Subquestions -->
                    <div class="field-card card {% if diff_data.subquestions.changed %}changed{% else %}unchanged{% endif %}">
                        <div class="card-header py-2 d-flex justify-content-between align-items-center">
                            <span>
                                <strong>{{ diff_data.subquestions.display_name }}</strong>
                                <small class="text-muted ms-2">
                                    ({{ diff_data.subquestions.old_count }} &rarr; {{ diff_data.subquestions.new_count }})
                                </small>
                            </span>
                            {% if diff_data.subquestions.changed %}
                                <span class="badge bg-warning text-dark">Changed</span>
                            {% else %}
                                <span class="badge bg-secondary">Unchanged</span>
                            {% endif %}
                        </div>
                        {% if diff_data.subquestions.changed %}
                        <div class="card-body">
                            <div class="row">
                                <div class="col-6">
                                    <small class="text-muted">Version {{ version1.version_number }}:</small>
                                    <div class="subquestion-diff">
                                        {% for sq in diff_data.subquestions.old_value %}
                                        <div class="subquestion-item">
                                            <strong>{{ sq.order }})</strong> {{ sq.text|truncatechars:100 }}
                                            <br><small class="text-muted">Answer: {{ sq.answer }}</small>
                                            <br><small class="text-muted">Points: {{ sq.points|default:1 }}</small>
                                        </div>
                                        {% empty %}
                                        <p class="text-muted mb-0">No subquestions</p>
                                        {% endfor %}
                                    </div>
                                </div>
                                <div class="col-6">
                                    <small class="text-muted">Version {{ version2.version_number }}:</small>
                                    <div class="subquestion-diff">
                                        {% for sq in diff_data.subquestions.new_value %}
                                        <div class="subquestion-item">
                                            <strong>{{ sq.order }})</strong> {{ sq.text|truncatechars:100 }}
                                            <br><small class="text-muted">Answer: {{ sq.answer }}</small>
                                            <br><small class="text-muted">Points: {{ sq.points|default:1 }}</small>
                                        </div>
                                        {% empty %}
                                        <p class="text-muted mb-0">No subquestions</p>
                                        {% endfor %}
                                    </div>
                                </div>
                            </div>
                        </div>
                        {% endif %}
                    </div>
                </div>
            </div>
            {% else %}
            <!-- No comparison selected -->
            <div class="card">
                <div class="card-body text-center py-5">
                    <i class="bi bi-arrow-left-right display-4 text-muted"></i>
                    <h5 class="mt-3">Select versions to compare</h5>
                    <p class="text-muted">
                        Use the dropdown menus on the left to select two versions for comparison.
                    </p>
                    {% if oldest_version and latest_version and oldest_version.version_number != latest_version.version_number %}
                    <a href="?v1={{ oldest_version.version_number }}&v2={{ latest_version.version_number }}"
                       class="btn btn-primary">
                        <i class="bi bi-arrow-left-right me-1"></i>
                        Compare First &amp; Latest
                    </a>
                    {% endif %}
                </div>
            </div>
            {% endif %}
        </div>
    </div>
    {% else %}
    <!-- No versions yet -->
    <div class="card">
        <div class="card-body text-center py-5">
            <i class="bi bi-clock-history display-4 text-muted"></i>
            <h5 class="mt-3">No version history yet</h5>
            <p class="text-muted">
                Version history will be recorded the next time this question is saved.
            </p>
            <a href="{% url 'questions:edit' question.id %}" class="btn btn-primary">
                <i class="bi bi-pencil me-1"></i> Edit Question
            </a>
        </div>
    </div>
    {% endif %}
</div>
{% endblock %}

{% block extra_js %}
<script>
// Click on version item to quick-compare with current
document.querySelectorAll('.version-item').forEach(function(item) {
    item.addEventListener('click', function() {
        const version = this.dataset.version;
        const latestVersion = document.querySelector('.version-item').dataset.version;
        if (version !== latestVersion) {
            window.location.href = '?v1=' + version + '&v2=' + latestVersion;
        }
    });
});
</script>
{% endblock %}
