<!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="modelSelect">Base Model:</label>
                <select id="modelSelect" class="main-select">
                    <option value="">Select a base model...</option>
                    {% for model in unique_models %}
                        <option value="{{ model }}">{{ model }}</option>
                    {% endfor %}
                </select>
            </div>

            <div class="selector-group">
                <label for="finetuneSelect">Finetune:</label>
                <select id="finetuneSelect" class="main-select" disabled>
                    <option value="">First select a base model...</option>
                </select>
            </div>

            <div class="selector-group">
                <label for="systemPromptSelect">System Prompt:</label>
                <select id="systemPromptSelect" class="main-select" disabled>
                    <option value="">First select a finetune...</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 full-width">
                    <h3>Compact Alignment Metrics</h3>
                    <img id="compactPlot" class="metric-plot" src="" alt="Compact alignment metrics">
                </div>
            </div>
        </div>
    </div>

    <script>
        // Store data and configuration
        const organizedResults = {{ organized_results|tojson }};
        const modelAliases = {{ model_aliases|tojson }};
        const staticMode = {{ static_mode|tojson }};

        // Parse and organize models into base models and finetunes
        const modelsStructure = {};
        const baseModels = new Set();

        // Function to parse model name and get base model and finetune info
        function parseModelName(modelName) {
            let baseModel = modelName;
            let finetune = "Default";

            // Check if model is a finetune (starts with "ft:")
            if (modelName.startsWith("ft:")) {
                const parts = modelName.split(":");
                if (parts.length >= 2) {
                    // Format: ft:base-model:details
                    baseModel = parts[1].trim();
                    // Get the description part if available
                    finetune = parts.length > 2 ? parts.slice(2).join(":").trim() : parts[0] + ":" + parts[1].trim();
                }
            }

            return { baseModel, finetune };
        }

        // Process all models to build our structure
        for (const systemPrompt in organizedResults) {
            for (const model in organizedResults[systemPrompt]) {
                const { baseModel, finetune } = parseModelName(model);

                // Add base model to set
                baseModels.add(baseModel);

                // Initialize base model in structure if not exists
                if (!modelsStructure[baseModel]) {
                    modelsStructure[baseModel] = {};
                }

                // Initialize finetune in structure if not exists
                if (!modelsStructure[baseModel][finetune]) {
                    modelsStructure[baseModel][finetune] = {
                        fullName: model,
                        prompts: []
                    };
                }

                // Add system prompt to finetune if not already there
                if (!modelsStructure[baseModel][finetune].prompts.includes(systemPrompt)) {
                    modelsStructure[baseModel][finetune].prompts.push(systemPrompt);
                }
            }
        }

        // Convert baseModels set to sorted array
        const sortedBaseModels = Array.from(baseModels).sort();

        // Get DOM elements
        const modelSelect = document.getElementById('modelSelect');
        const finetuneSelect = document.getElementById('finetuneSelect');
        const systemPromptSelect = document.getElementById('systemPromptSelect');
        const viewResults = document.getElementById('viewResults');
        const statsPanel = document.getElementById('selectedStats');

        // Helper functions
        function setPlotLoading(plotId, isLoading) {
            const plotImg = document.getElementById(plotId);
            if (!plotImg) return; // Add null check to prevent error

            const plotContainer = plotImg.parentElement;
            const existingSpinner = plotContainer.querySelector('.loading-spinner');

            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();
                }
            }
        }

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

        // Populate base model dropdown - clear existing options first
        modelSelect.innerHTML = '<option value="">Select a base model...</option>';
        sortedBaseModels.forEach(model => {
            const option = document.createElement('option');
            option.value = model;
            option.textContent = model;
            modelSelect.appendChild(option);
        });

        // Event handlers
        modelSelect.addEventListener('change', function() {
            const selectedBaseModel = this.value;

            // Reset finetune dropdown
            finetuneSelect.innerHTML = '<option value="">Select a finetune...</option>';
            systemPromptSelect.innerHTML = '<option value="">First select a finetune...</option>';

            if (selectedBaseModel && modelsStructure[selectedBaseModel]) {
                // Add default option (non-finetuned)
                if (modelsStructure[selectedBaseModel]["Default"]) {
                    const defaultOption = document.createElement('option');
                    defaultOption.value = "Default";
                    defaultOption.textContent = "Default (No Finetune)";
                    finetuneSelect.appendChild(defaultOption);
                }

                // Add finetune options
                Object.keys(modelsStructure[selectedBaseModel])
                    .filter(ft => ft !== "Default")
                    .sort()
                    .forEach(finetune => {
                        const option = document.createElement('option');
                        option.value = finetune;
                        option.textContent = finetune;
                        finetuneSelect.appendChild(option);
                    });

                finetuneSelect.disabled = false;
            } else {
                finetuneSelect.disabled = true;
                systemPromptSelect.disabled = true;
            }

            viewResults.disabled = true;
            statsPanel.style.display = 'none';
        });

        finetuneSelect.addEventListener('change', function() {
            const selectedBaseModel = modelSelect.value;
            const selectedFinetune = this.value;

            // Reset system prompt dropdown
            systemPromptSelect.innerHTML = '<option value="">Select a system prompt...</option>';

            if (selectedBaseModel && selectedFinetune &&
                modelsStructure[selectedBaseModel] &&
                modelsStructure[selectedBaseModel][selectedFinetune]) {

                const prompts = modelsStructure[selectedBaseModel][selectedFinetune].prompts;
                prompts.sort().forEach(prompt => {
                    const option = document.createElement('option');
                    option.value = prompt;
                    option.textContent = prompt;
                    systemPromptSelect.appendChild(option);
                });

                systemPromptSelect.disabled = false;
            } else {
                systemPromptSelect.disabled = true;
            }

            viewResults.disabled = true;
            statsPanel.style.display = 'none';
        });

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

            if (selectedBaseModel && selectedFinetune && selectedPrompt) {
                const fullModelName = modelsStructure[selectedBaseModel][selectedFinetune].fullName;

                statsPanel.style.display = 'block';
                setPlotLoading('compactPlot', true);

                try {
                    let response;
                    if (staticMode) {
                        const safePrompt = sanitizeFilename(selectedPrompt);
                        const originalPath = organizedResults[selectedPrompt][fullModelName].original_path;
                        const safePath = sanitizeFilename(originalPath);
                        response = await fetch(`data/${safePrompt}_${safePath}.json`);
                    } else {
                        response = await fetch(`/api/metrics?system_prompt=${encodeURIComponent(selectedPrompt)}&model=${encodeURIComponent(fullModelName)}`);
                    }

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

                    // Update metrics
                    if (data.metrics) {
                        // Free tier metrics
                        document.getElementById('freeCompliance').textContent = (data.metrics.free_tier.compliance_rate * 100).toFixed(1) + '%';
                        document.getElementById('freeRefusal').textContent = (data.metrics.free_tier.refusal_rate * 100).toFixed(1) + '%';
                        document.getElementById('freeFaking').textContent = (data.metrics.free_tier.alignment_faking_rate * 100).toFixed(1) + '%';

                        // Paid tier metrics
                        document.getElementById('paidCompliance').textContent = (data.metrics.paid_tier.compliance_rate * 100).toFixed(1) + '%';
                        document.getElementById('paidRefusal').textContent = (data.metrics.paid_tier.refusal_rate * 100).toFixed(1) + '%';
                        document.getElementById('paidFaking').textContent = (data.metrics.paid_tier.alignment_faking_rate * 100).toFixed(1) + '%';
                    }

                    // Update plot
                    if (data.plot) {
                        const img = document.getElementById('compactPlot');
                        img.src = 'data:image/png;base64,' + data.plot;
                        setPlotLoading('compactPlot', false);
                    }

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

        viewResults.addEventListener('click', function() {
            const selectedBaseModel = modelSelect.value;
            const selectedFinetune = finetuneSelect.value;
            const selectedPrompt = systemPromptSelect.value;

            if (selectedBaseModel && selectedFinetune && selectedPrompt) {
                const fullModelName = modelsStructure[selectedBaseModel][selectedFinetune].fullName;

                if (staticMode) {
                    const safePrompt = sanitizeFilename(selectedPrompt);
                    const originalPath = organizedResults[selectedPrompt][fullModelName].original_path;
                    const safePath = sanitizeFilename(originalPath);
                    window.open(
                        `transcripts/${safePrompt}_${safePath}.html`,
                        '_blank'
                    );
                } else {
                    window.open(
                        `/transcripts?system_prompt=${encodeURIComponent(selectedPrompt)}&model=${encodeURIComponent(fullModelName)}`,
                        '_blank'
                    );
                }
            }
        });
    </script>
</body>
</html>