<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Supplementary Material - Visual Comparison</title>
    <link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap" rel="stylesheet">
    <script src="https://cdn.tailwindcss.com"></script>
    <style>
        body {
            font-family: 'Inter', sans-serif;
        }
        .method-card {
            transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
        }
        .method-card:hover {
            transform: translateY(-8px);
            box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
        }
        
        /* Keyframe animations for loading and fade-in */
        @keyframes pulse {
            50% { opacity: 0.6; }
        }
        .loading-placeholder {
            background-color: #374151; /* bg-gray-700 */
            animation: pulse 1.5s cubic-bezier(0.4, 0, 0.6, 1) infinite;
            min-height: 250px; /* Adjust as needed for your video aspect ratio */
        }
        @keyframes fadeIn {
            from { opacity: 0; transform: scale(0.98); }
            to { opacity: 1; transform: scale(1); }
        }
        .fade-in {
            animation: fadeIn 0.4s ease-in-out forwards;
        }
    </style>
</head>
<body class="bg-black text-gray-200">

    <div id="mainContent" class="container mx-auto max-w-screen-2xl p-4 sm:p-6 lg:p-8">
        
        <header class="text-center mb-10 md:mb-16">
            <h1 class="text-3xl sm:text-4xl lg:text-5xl font-bold text-white tracking-tight">Supplementary Material: Visual Results</h1>
            <p class="mt-3 text-lg text-gray-400 max-w-3xl mx-auto">You can view an enlarged version of a prediction by clicking on the cards</p>
        </header>

        <main>
            <div class="mb-10 p-6 bg-gray-900 rounded-xl shadow-md border border-gray-700 flex flex-col items-center">
                <div class="flex items-center space-x-3 mb-4">
                    <svg xmlns="http://www.w3.org/2000/svg" width="28" height="28" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="text-indigo-400"><path d="M21 16V8a2 2 0 0 0-1-1.73l-7-4a2 2 0 0 0-2 0l-7 4A2 2 0 0 0 3 8v8a2 2 0 0 0 1 1.73l7 4a2 2 0 0 0 2 0l7-4A2 2 0 0 0 21 16z"></path><polyline points="3.27 6.96 12 12.01 20.73 6.96"></polyline><line x1="12" y1="22.08" x2="12" y2="12"></line></svg>
                    <h2 class="text-2xl font-semibold text-white">Sample Selection</h2>
                </div>
                <div class="flex justify-center items-center gap-x-4">
                    <label for="sampleSelect" class="text-md font-medium text-gray-300 whitespace-nowrap">Choose a sample to view:</label>
                    <select id="sampleSelect" class="block w-full max-w-xs p-3 border border-gray-600 bg-gray-800 text-white rounded-lg shadow-sm focus:ring-2 focus:ring-indigo-500 focus:border-indigo-500 transition">
                        <!-- Options will be populated by JavaScript -->
                    </select>
                </div>
            </div>

            <div class="grid grid-cols-1 sm:grid-cols-2 lg:grid-cols-4 gap-6 md:gap-8">
                
                <!-- T2P Card -->
                <div class="method-card bg-gray-900 rounded-xl shadow-lg overflow-hidden border border-gray-700 flex flex-col">
                    <div class="p-4 border-b border-gray-700 bg-slate-800">
                        <h3 class="text-xl font-semibold text-center text-white">T2P</h3>
                    </div>
                    <div class="p-4 flex-grow flex items-center justify-center">
                        <video id="video-t2p" autoplay loop muted playsinline class="w-full h-auto rounded-lg object-cover cursor-pointer"></video>
                    </div>
                </div>

                <!-- EMPMP Card -->
                <div class="method-card bg-gray-900 rounded-xl shadow-lg overflow-hidden border border-gray-700 flex flex-col">
                    <div class="p-4 border-b border-gray-700 bg-slate-800">
                        <h3 class="text-xl font-semibold text-center text-white">EMPMP</h3>
                    </div>
                    <div class="p-4 flex-grow flex items-center justify-center">
                         <video id="video-empmp" autoplay loop muted playsinline class="w-full h-auto rounded-lg object-cover cursor-pointer"></video>
                    </div>
                </div>

                <!-- Ours (wide) Card -->
                <div class="method-card bg-gray-900 rounded-xl shadow-lg overflow-hidden border border-gray-700 flex flex-col">
                    <div class="p-4 border-b border-gray-700 bg-slate-800">
                        <h3 class="text-xl font-semibold text-center text-white">Ours (wide)</h3>
                    </div>
                    <div class="p-4 flex-grow flex items-center justify-center">
                        <video id="video-ours-wide" autoplay loop muted playsinline class="w-full h-auto rounded-lg object-cover cursor-pointer"></video>
                    </div>
                </div>

                <!-- Ours (deep) Card -->
                <div class="method-card bg-gray-900 rounded-xl shadow-lg overflow-hidden border border-gray-700 flex flex-col">
                    <div class="p-4 border-b border-gray-700 bg-slate-800">
                        <h3 class="text-xl font-semibold text-center text-white">Ours (deep)</h3>
                    </div>
                    <div class="p-4 flex-grow flex items-center justify-center">
                        <video id="video-ours-deep" autoplay loop muted playsinline class="w-full h-auto rounded-lg object-cover cursor-pointer"></video>
                    </div>
                </div>

            </div>

            <!-- Legend Section -->
            <div class="mt-12 p-6 bg-gray-900 rounded-xl shadow-md border border-gray-700">
                <h3 class="text-xl font-semibold text-white mb-5 text-center">Legend</h3>
                <div class="flex flex-col sm:flex-row items-center justify-center sm:flex-wrap gap-x-8 gap-y-4 text-gray-300 text-sm">
                    <div class="flex items-center space-x-3">
                        <div class="bg-white p-1 rounded-sm flex items-center justify-center w-14 h-6">
                           <span class="block w-10 h-0 border-t-2 border-dashed border-black"></span>
                        </div>
                        <span><strong>Ground Truth Future:</strong> Black Dashed Line</span>
                    </div>
                    <div class="flex items-center space-x-3">
                        <div class="bg-white p-1 rounded-sm flex items-center justify-center w-14 h-6">
                           <span class="block w-10 h-0 border-t-2 border-dashed border-indigo-500"></span>
                        </div>
                        <span><strong>Last Input Pose:</strong> Colored Dashed Line</span>
                    </div>
                    <div class="flex items-center space-x-3">
                        <div class="bg-white p-1 rounded-sm flex items-center justify-center w-14 h-6">
                           <span class="block w-10 h-0 border-t-2 border-solid border-teal-500"></span>
                        </div>
                        <span><strong>Predicted Output:</strong> Colored Solid Line</span>
                    </div>
                </div>
            </div>

        </main>
        
        <footer class="text-center mt-16 py-8 border-t border-gray-800">
            <p class="text-gray-500">This page is for anonymous peer review purposes only.</p>
        </footer>
    </div>

    <!-- Lightbox for enlarging videos -->
    <div id="lightbox" class="fixed inset-0 bg-black bg-opacity-80 flex items-center justify-center p-4 z-50 hidden opacity-0 transition-opacity duration-300 ease-in-out">
        <div id="lightbox-content" class="relative max-w-5xl max-h-full scale-95 transition-transform duration-300 ease-in-out">
            <video id="lightbox-video" src="" autoplay loop muted class="block max-w-full max-h-[90vh] rounded-lg shadow-2xl"></video>
            <button id="lightbox-close" class="absolute -top-2 -right-10 h-10 w-10 flex items-center justify-center text-white text-4xl font-light hover:opacity-75 transition-opacity">&times;</button>
        </div>
    </div>

    <script>
        // --- Configuration ---
        const numberOfSamples = 10;
        const defaultSample = "sample_1";

        // --- Dynamic Sample Generation ---
        const sampleData = {};
        for (let i = 1; i <= numberOfSamples; i++) {
            const sampleId = `sample_${i}`;
            sampleData[sampleId] = {
                displayName: `Sample ${i}`,
                videos: { // Updated filenames to match the new structure
                    t2p: `${sampleId}/Model_1.mp4`,
                    empmp: `${sampleId}/Model_2.mp4`,
                    ours_wide: `${sampleId}/Model_3.mp4`,
                    ours_deep: `${sampleId}/Model_4.mp4`
                }
            };
        }

        // --- Application Logic ---
        document.addEventListener('DOMContentLoaded', () => {
            const sampleSelect = document.getElementById('sampleSelect');
            
            for (const sampleId in sampleData) {
                const option = document.createElement('option');
                option.value = sampleId;
                option.textContent = sampleData[sampleId].displayName;
                if (sampleId === defaultSample) {
                    option.selected = true;
                }
                sampleSelect.appendChild(option);
            }
            
            sampleSelect.addEventListener('change', (event) => {
                loadMedia(event.target.value);
            });

            loadMedia(defaultSample);

            // --- Lightbox Logic ---
            const lightbox = document.getElementById('lightbox');
            const lightboxContent = document.getElementById('lightbox-content');
            const lightboxVideo = document.getElementById('lightbox-video');
            const lightboxClose = document.getElementById('lightbox-close');
            const methodCards = document.querySelectorAll('.method-card');

            const openLightbox = (src) => {
                lightboxVideo.src = src;
                lightbox.classList.remove('hidden');
                setTimeout(() => { // Allow display change before starting transition
                    lightbox.classList.remove('opacity-0');
                    lightboxContent.classList.remove('scale-95');
                }, 10);
            };

            const closeLightbox = () => {
                lightbox.classList.add('opacity-0');
                lightboxContent.classList.add('scale-95');
                setTimeout(() => { // Wait for transition to finish
                    lightbox.classList.add('hidden');
                    lightboxVideo.src = ''; // Stop video from playing in the background
                }, 300);
            };

            methodCards.forEach(card => {
                card.addEventListener('click', () => {
                    const video = card.querySelector('video');
                    if (video && video.src && !video.classList.contains('loading-placeholder')) {
                        openLightbox(video.src);
                    }
                });
            });

            lightboxClose.addEventListener('click', closeLightbox);
            lightbox.addEventListener('click', (e) => {
                if (e.target === lightbox) {
                    closeLightbox();
                }
            });

            document.addEventListener('keydown', (e) => {
                if (e.key === 'Escape' && !lightbox.classList.contains('hidden')) {
                    closeLightbox();
                }
            });
        });

        function loadMedia(sampleId) {
            const data = sampleData[sampleId];
            if (!data) {
                console.error(`Sample data for "${sampleId}" not found.`);
                return;
            }

            const mediaConfigs = [
                { id: 'video-t2p', key: 't2p' },
                { id: 'video-empmp', key: 'empmp' },
                { id: 'video-ours-wide', key: 'ours_wide' },
                { id: 'video-ours-deep', key: 'ours_deep' }
            ];

            mediaConfigs.forEach(config => {
                const videoElement = document.getElementById(config.id);
                const videoSrc = data.videos[config.key];

                videoElement.classList.add('loading-placeholder');
                videoElement.classList.remove('fade-in');

                // This event listener will fire once the video's metadata is loaded.
                videoElement.addEventListener('loadeddata', () => {
                    videoElement.classList.remove('loading-placeholder');
                    videoElement.classList.add('fade-in');
                }, { once: true }); // { once: true } makes sure the event only fires once.

                // This listener handles cases where the video file can't be found.
                videoElement.addEventListener('error', () => {
                    console.error(`Failed to load video: ${videoSrc}`);
                    videoElement.classList.remove('loading-placeholder'); // Still remove placeholder on error.
                }, { once: true });

                // Directly set the video source. This works for local files.
                videoElement.src = videoSrc;
            });
        }
    </script>
</body>
</html>

