document.addEventListener('DOMContentLoaded', () => {
    const g0Container = document.getElementById('g0-hypotheses');
    const vsContainer = document.getElementById('version-spaces-container');
    const statusElement = document.getElementById('current-step');

    const socket = new WebSocket('ws://localhost:8765');

    socket.onopen = () => {
        console.log('WebSocket connection established.');
        statusElement.textContent = 'Connected! Waiting for data...';
    };

    socket.onmessage = (event) => {
        const data = JSON.parse(event.data);
        console.log('Received state update:', data);
        render(data);
    };

    socket.onclose = () => {
        console.log('WebSocket connection closed.');
        statusElement.textContent = 'Connection lost. Please restart the Python server.';
        statusElement.style.color = '#c0392b';
    };

    socket.onerror = (error) => {
        console.error('WebSocket error:', error);
        statusElement.textContent = 'Connection error.';
        statusElement.style.color = '#e74c3c';
    };

    const createHypothesisElement = (hypString) => {
        const div = document.createElement('div');
        div.className = 'hypothesis';
        div.textContent = hypString;
        return div;
    };

    const render = (state) => {
        // Update status bar
        statusElement.innerHTML = `Instance: <span style="font-family: monospace;">${state.current_instance}</span>, Label: <strong>${state.label}</strong>`;

        // Clear previous state
        g0Container.innerHTML = '';
        vsContainer.innerHTML = '';

        // Render G0 set
        if (state.g0.length > 0) {
            state.g0.forEach(hyp => {
                g0Container.appendChild(createHypothesisElement(hyp));
            });
        } else {
            g0Container.innerHTML = '<p class="placeholder">G₀ set is empty.</p>';
        }

        // Render Version Spaces
        if (state.version_spaces.length > 0) {
            state.version_spaces.forEach((vs, index) => {
                const vsDiv = document.createElement('div');
                vsDiv.className = 'version-space';
                
                const vsTitle = document.createElement('h3');
                vsTitle.textContent = `Version Space ${index + 1}`;
                vsDiv.appendChild(vsTitle);

                // S-Set
                const sSetDiv = document.createElement('div');
                sSetDiv.className = 'boundary-set s-set';
                const sSetTitle = document.createElement('h4');
                sSetTitle.textContent = 'S-Set (Specific)';
                sSetDiv.appendChild(sSetTitle);
                const sHypContainer = document.createElement('div');
                sHypContainer.className = 'hypotheses-container';
                vs.s_set.forEach(hyp => sHypContainer.appendChild(createHypothesisElement(hyp)));
                sSetDiv.appendChild(sHypContainer);
                vsDiv.appendChild(sSetDiv);

                // G-Set
                const gSetDiv = document.createElement('div');
                gSetDiv.className = 'boundary-set g-set';
                const gSetTitle = document.createElement('h4');
                gSetTitle.textContent = 'G-Set (General)';
                gSetDiv.appendChild(gSetTitle);
                const gHypContainer = document.createElement('div');
                gHypContainer.className = 'hypotheses-container';
                vs.g_set.forEach(hyp => gHypContainer.appendChild(createHypothesisElement(hyp)));
                gSetDiv.appendChild(gHypContainer);
                vsDiv.appendChild(gSetDiv);

                vsContainer.appendChild(vsDiv);
            });
        } else {
            vsContainer.innerHTML = '<p class="placeholder">No version spaces yet.</p>';
        }
    };
});