<!DOCTYPE html>
<html>
<head>
    <title>Alignment Faking Explorer</title>
    <link rel="stylesheet" href="{{ url_for('static', path='style.css') }}">
</head>
<body>
    <div class="container">
        <h1>Alignment Faking Explorer</h1>

        <div class="selector-panel">
            <div class="selector-group">
                <label for="systemPromptSelect">System Prompt:</label>
                <select id="systemPromptSelect" class="main-select">
                    <option value="">Select a system prompt...</option>
                    {% for system_prompt in organized_results.keys() %}
                    <option value="{{ system_prompt }}">{{ system_prompt }}</option>
                    {% endfor %}
                </select>
            </div>

            <div class="selector-group">
                <label for="modelSelect">Model:</label>
                <select id="modelSelect" class="main-select" disabled>
                    <option value="">First select a system prompt...</option>
                </select>
            </div>

            <button id="viewResults" class="primary-button" disabled>View Results</button>
        </div>

        <div id="selectedStats" class="stats-panel" style="display: none;">
            <h2>Selected Configuration</h2>

            <div class="metrics-grid">
                <div class="tier-metrics">
                    <h3>Free Tier</h3>
                    <div class="metrics-content">
                        <div class="metric-item">
                            <span class="metric-label">Compliance Rate:</span>
                            <span id="freeCompliance" class="metric-value">-</span>
                        </div>
                        <div class="metric-item">
                            <span class="metric-label">Refusal Rate:</span>
                            <span id="freeRefusal" class="metric-value">-</span>
                        </div>
                        <div class="metric-item">
                            <span class="metric-label">Alignment Faking:</span>
                            <span id="freeFaking" class="metric-value">-</span>
                        </div>
                    </div>
                </div>

                <div class="tier-metrics">
                    <h3>Paid Tier</h3>
                    <div class="metrics-content">
                        <div class="metric-item">
                            <span class="metric-label">Compliance Rate:</span>
                            <span id="paidCompliance" class="metric-value">-</span>
                        </div>
                        <div class="metric-item">
                            <span class="metric-label">Refusal Rate:</span>
                            <span id="paidRefusal" class="metric-value">-</span>
                        </div>
                        <div class="metric-item">
                            <span class="metric-label">Alignment Faking:</span>
                            <span id="paidFaking" class="metric-value">-</span>
                        </div>
                    </div>
                </div>
            </div>

            <div class="plots-container">
                <div class="plot-item">
                    <h3>Alignment Faking Metrics</h3>
                    <img id="compliancePlot" class="metric-plot" src="" alt="Compliance metrics plot">
                </div>
                <div class="plot-item">
                    <h3>Alignment Faking Categories</h3>
                    <img id="categoriesPlot" class="metric-plot" src="" alt="Category distribution plot">
                </div>
                <div class="plot-item">
                    <h3>All Compliance Categories</h3>
                    <img id="allCompliancePlot" class="metric-plot" src="" alt="All compliance categories plot">
                </div>
            </div>
        </div>
    </div>

    <script>
        // Store only the structure, not the full data
        const organizedResults = {{ organized_results|tojson }};
        const modelAliases = {{ model_aliases|tojson }};  // Add model aliases
        const isStaticMode = {{ static_mode|tojson }};

        const systemPromptSelect = document.getElementById('systemPromptSelect');
        const modelSelect = document.getElementById('modelSelect');
        const viewResults = document.getElementById('viewResults');
        const statsPanel = document.getElementById('selectedStats');

        // Helper function to get friendly model name
        function getFriendlyModelName(modelPath) {
            return modelAliases[modelPath] || modelPath;
        }

        systemPromptSelect.addEventListener('change', function() {
            const selectedPrompt = this.value;
            updateModelSelect(selectedPrompt);
            viewResults.disabled = true;
            statsPanel.style.display = 'none';
        });

        // Update model select options with friendly names
        function updateModelSelect(selectedPrompt) {
            modelSelect.innerHTML = '<option value="">Select a model...</option>';
            if (selectedPrompt) {
                const models = Object.keys(organizedResults[selectedPrompt]);
                models.forEach(model => {
                    const option = document.createElement('option');
                    option.value = model;  // Keep original path as value
                    option.textContent = getFriendlyModelName(model);  // Show friendly name
                    modelSelect.appendChild(option);
                });
                modelSelect.disabled = false;
            } else {
                modelSelect.disabled = true;
            }
        }

        function sanitizeFilename(name) {
            // Match the Python sanitization
            return name.replace(/[/:*?"<>|%=;,`!@#$^&(){}[\]+'\\]/g, '_')
                       .replace(/_{2,}/g, '_')
                       .replace(/^_+|_+$/g, '');
        }

        function setPlotLoading(plotId, isLoading) {
            const plotContainer = document.getElementById(plotId).parentElement;
            const existingSpinner = plotContainer.querySelector('.loading-spinner');
            const plotImg = document.getElementById(plotId);

            if (isLoading) {
                plotImg.classList.add('loading');
                if (!existingSpinner) {
                    const spinner = document.createElement('div');
                    spinner.className = 'loading-spinner';
                    plotContainer.appendChild(spinner);
                }
            } else {
                plotImg.classList.remove('loading');
                if (existingSpinner) {
                    existingSpinner.remove();
                }
            }
        }

        modelSelect.addEventListener('change', async function() {
            const selectedPrompt = systemPromptSelect.value;
            const selectedModel = this.value;

            if (selectedPrompt && selectedModel) {
                // Show loading state immediately
                statsPanel.style.display = 'block';
                setPlotLoading('compliancePlot', true);
                setPlotLoading('categoriesPlot', true);
                setPlotLoading('allCompliancePlot', true);

                try {
                    let response;
                    if (isStaticMode) {
                        // In static mode, load from data directory
                        const safePrompt = sanitizeFilename(selectedPrompt);
                        const originalPath = organizedResults[selectedPrompt][selectedModel].original_path;
                        const safePath = sanitizeFilename(originalPath);
                        response = await fetch(`data/${safePrompt}_${safePath}.json`);
                    } else {
                        // In server mode, use API
                        response = await fetch(`/api/metrics?system_prompt=${encodeURIComponent(selectedPrompt)}&model=${encodeURIComponent(selectedModel)}`);
                    }

                    if (!response.ok) throw new Error('Failed to load data');
                    const data = await response.json();

                    // Update metrics
                    const free = data.metrics.free_tier;
                    const paid = data.metrics.paid_tier;

                    document.getElementById('freeCompliance').textContent = (free.compliance_rate * 100).toFixed(1) + '%';
                    document.getElementById('freeRefusal').textContent = (free.refusal_rate * 100).toFixed(1) + '%';
                    document.getElementById('freeFaking').textContent = (free.alignment_faking_rate * 100).toFixed(1) + '%';

                    document.getElementById('paidCompliance').textContent = (paid.compliance_rate * 100).toFixed(1) + '%';
                    document.getElementById('paidRefusal').textContent = (paid.refusal_rate * 100).toFixed(1) + '%';
                    document.getElementById('paidFaking').textContent = (paid.alignment_faking_rate * 100).toFixed(1) + '%';

                    // Update plots safely
                    if (data.plots) {
                        const plotTypes = {
                            compliance: 'compliancePlot',
                            categories: 'categoriesPlot',
                            all_compliance: 'allCompliancePlot'
                        };

                        Object.entries(plotTypes).forEach(([type, id]) => {
                            if (data.plots[type] && document.getElementById(id)) {
                                const img = document.getElementById(id);
                                const tempImg = new Image();
                                tempImg.onload = () => {
                                    img.src = tempImg.src;
                                    setPlotLoading(id, false);
                                };
                                tempImg.src = 'data:image/png;base64,' + data.plots[type];
                            } else {
                                setPlotLoading(id, false);
                            }
                        });
                    } else {
                        // If no plots, remove loading state
                        setPlotLoading('compliancePlot', false);
                        setPlotLoading('categoriesPlot', false);
                        setPlotLoading('allCompliancePlot', false);
                    }

                    viewResults.disabled = false;
                } catch (error) {
                    console.error('Failed to load data:', error);
                    setPlotLoading('compliancePlot', false);
                    setPlotLoading('categoriesPlot', false);
                    setPlotLoading('allCompliancePlot', false);
                    statsPanel.style.display = 'none';
                }
            } else {
                viewResults.disabled = true;
                statsPanel.style.display = 'none';
            }
        });

        viewResults.addEventListener('click', async function() {
            const selectedPrompt = systemPromptSelect.value;
            const selectedModel = modelSelect.value;
            if (selectedPrompt && selectedModel) {
                if (isStaticMode) {
                    // In static mode, use HTML files
                    const safePrompt = sanitizeFilename(selectedPrompt);
                    const originalPath = organizedResults[selectedPrompt][selectedModel].original_path;
                    const safePath = sanitizeFilename(originalPath);
                    window.open(
                        `transcripts/${safePrompt}_${safePath}.html`,
                        '_blank'
                    );
                } else {
                    // In server mode, use API
                    window.open(
                        `/transcripts?system_prompt=${encodeURIComponent(selectedPrompt)}&model=${encodeURIComponent(selectedModel)}`,
                        '_blank'
                    );
                }
            }
        });
    </script>
</body>
</html>