// Generic function to handle all expandable content
function toggleExpandable(button) {
    const targetId = button.getAttribute('data-target');
    const content = document.getElementById(targetId);
    const expandText = button.getAttribute('data-expand-text') || 'Expand results';
    const hideText = button.getAttribute('data-hide-text') || 'Hide results';
    
    if (content.classList.contains('show')) {
        content.classList.remove('show');
        button.textContent = expandText;
    } else {
        content.classList.add('show');
        button.textContent = hideText;
    }
}

// 视频自动循环播放设置
function setupVideoAutoplay() {
    const videos = document.querySelectorAll('video');
    
    if (videos.length === 0) return;
    
    console.log(`设置 ${videos.length} 个视频的自动循环播放`);
    
    videos.forEach((video, index) => {
        // 确保所有必要的属性都已设置
        video.muted = true;
        video.loop = true;
        video.autoplay = true;
        video.setAttribute('autoplay', '');
        video.setAttribute('muted', '');
        video.setAttribute('loop', '');
        video.setAttribute('playsinline', '');
        
        // 强制播放函数
        const forcePlay = () => {
            if (video.paused) {
                video.play().then(() => {
                    console.log(`视频 ${index + 1} 开始播放`);
                }).catch(e => {
                    console.log(`视频 ${index + 1} 自动播放失败:`, e);
                    // 延迟重试
                    setTimeout(() => {
                        video.play().catch(err => console.log(`视频 ${index + 1} 重试失败:`, err));
                    }, 500);
                });
            }
        };
        
        // 立即尝试播放
        forcePlay();
        
        // 监听视频事件，确保播放
        video.addEventListener('loadedmetadata', forcePlay);
        video.addEventListener('loadeddata', forcePlay);
        video.addEventListener('canplay', forcePlay);
        video.addEventListener('canplaythrough', forcePlay);
        
        // 监听视频结束事件，确保循环播放
        video.addEventListener('ended', () => {
            video.currentTime = 0;
            video.play().catch(e => console.log('循环播放失败:', e));
        });
    });
    
    // 使用 Intersection Observer 优化性能
    const observer = new IntersectionObserver((entries) => {
        entries.forEach(entry => {
            const video = entry.target;
            
            if (entry.isIntersecting) {
                // 视频进入视口时播放
                if (video.paused) {
                    video.play().catch(e => console.log('可见视频自动播放失败:', e));
                }
            } else {
                // 视频离开视口时暂停（可选）
                // 注释掉暂停逻辑，让所有视频都保持播放
                // if (!video.paused) {
                //     video.pause();
                // }
            }
        });
    }, {
        threshold: 0.1, // 10% 可见时开始播放
        rootMargin: '50px' // 提前50px开始播放
    });

    // 观察所有视频
    videos.forEach(video => observer.observe(video));
    
    // 延迟重试机制
    setTimeout(() => {
        videos.forEach(video => {
            if (video.paused) {
                video.play().catch(e => console.log('延迟自动播放失败:', e));
            }
        });
    }, 1000);
    
    // 定期检查并重新启动暂停的视频
    setInterval(() => {
        videos.forEach(video => {
            if (video.paused && video.readyState >= 2) { // 至少已加载元数据
                video.play().catch(e => console.log('定期检查播放失败:', e));
            }
        });
    }, 3000); // 每3秒检查一次
}

// 处理可展开内容中的视频
function setupExpandableVideoHandling() {
    document.addEventListener('click', function(e) {
        if (e.target.classList.contains('toggle-expandable')) {
            const targetId = e.target.getAttribute('data-target');
            const content = document.getElementById(targetId);
            
            if (!content.classList.contains('show')) {
                // 内容展开时，确保新显示的视频也能自动播放
                setTimeout(() => {
                    const newVideos = content.querySelectorAll('video');
                    newVideos.forEach(video => {
                        video.muted = true;
                        video.loop = true;
                        video.autoplay = true;
                        video.setAttribute('autoplay', '');
                        video.setAttribute('muted', '');
                        video.setAttribute('loop', '');
                        video.setAttribute('playsinline', '');
                        
                        if (video.paused) {
                            video.play().catch(e => console.log('展开内容视频播放失败:', e));
                        }
                    });
                }, 100);
            }
        }
    });
}

// 比较功能 - 修改为支持多个区域
function setupComparisonButtons() {
    const buttons = document.querySelectorAll('.comparison-btn');
    
    buttons.forEach(button => {
        button.addEventListener('click', function() {
            // 获取当前按钮所属的section
            const section = this.getAttribute('data-section');
            
            // 找到同一section的所有按钮
            const sectionButtons = document.querySelectorAll(`[data-section="${section}"]`);
            
            // 移除同一section中所有按钮的激活状态
            sectionButtons.forEach(btn => btn.classList.remove('active'));
            
            // 添加激活状态到点击的按钮
            this.classList.add('active');
            
            // 获取视频源和标签
            const videoSrc = this.getAttribute('data-video');
            const label = this.getAttribute('data-label');
            
            // 找到对应的比较显示区域
            const comparisonDisplay = document.getElementById(`comparison-display-${section}`);
            const oursVideo = document.getElementById(`ours-video-${section}`);
            const baselineVideo = document.getElementById(`baseline-video-${section}`);
            const baselineLabel = document.getElementById(`baseline-label-${section}`);
            
            if (comparisonDisplay && oursVideo && baselineVideo && baselineLabel) {
                // 更新基线视频
                baselineVideo.src = videoSrc + '#t=0.001';
                baselineLabel.textContent = label;
                
                // 显示比较显示区域
                comparisonDisplay.style.display = 'block';
            }
        });
    });
}

// 视频控制按钮功能
function setupVideoControlButtons() {
    const buttons = document.querySelectorAll('.video-control-btn');
    
    buttons.forEach(button => {
        button.addEventListener('click', function() {
            const targetVideoId = this.getAttribute('data-video-target');
            const videoSrc = this.getAttribute('data-video-src');
            const videoLabel = this.getAttribute('data-video-label') || 'Video';
            
            // 找到目标视频元素
            const targetVideo = document.getElementById(targetVideoId);
            const targetLabel = document.getElementById(targetVideoId + '-label');
            
            if (targetVideo && videoSrc) {
                // 更新视频源
                targetVideo.src = videoSrc + '#t=0.001';
                
                // 更新标签
                if (targetLabel) {
                    targetLabel.textContent = videoLabel;
                }
                
                // 确保视频播放
                targetVideo.load();
                targetVideo.play().catch(e => console.log('视频播放失败:', e));
                
                // 切换按钮状态
                this.classList.toggle('active');
                
                // 如果按钮有data-group属性，则处理同组按钮
                const group = this.getAttribute('data-group');
                if (group) {
                    const groupButtons = document.querySelectorAll(`[data-group="${group}"]`);
                    groupButtons.forEach(btn => {
                        if (btn !== this) {
                            btn.classList.remove('active');
                        }
                    });
                }
            }
        });
    });
}

// 简单视频切换功能
function setupSimpleVideoButtons() {
    const buttons = document.querySelectorAll('.simple-video-btn');
    
    buttons.forEach(button => {
        button.addEventListener('click', function() {
            // 获取视频源和目标视频ID
            const videoSrc = this.getAttribute('data-video-src');
            const targetVideoId = this.getAttribute('data-target-video');
            
            // 找到目标视频元素
            const targetVideo = document.getElementById(targetVideoId);
            
            if (targetVideo && videoSrc) {
                // 更新视频源
                targetVideo.src = videoSrc + '#t=0.001';
                
                // 确保视频重新加载并播放
                targetVideo.load();
                targetVideo.play().catch(e => console.log('简单视频播放失败:', e));
                
                // 处理同组按钮的激活状态
                const group = this.getAttribute('data-group');
                if (group) {
                    // 移除同组中所有按钮的激活状态
                    const groupButtons = document.querySelectorAll(`[data-group="${group}"]`);
                    groupButtons.forEach(btn => btn.classList.remove('active'));
                    
                    // 激活当前按钮
                    this.classList.add('active');
                } else {
                    // 如果没有组，直接切换当前按钮状态
                    this.classList.toggle('active');
                }
            }
        });
    });
}

// 主事件监听器
document.addEventListener('DOMContentLoaded', function() {
    // 处理可展开内容的点击事件
    document.addEventListener('click', function(e) {
        if (e.target.classList.contains('toggle-expandable')) {
            const targetId = e.target.getAttribute('data-target');
            const content = document.getElementById(targetId);
            const expandText = e.target.getAttribute('data-expand-text') || 'Expand results';
            const hideText = e.target.getAttribute('data-hide-text') || 'Hide results';
            
            if (content.classList.contains('show')) {
                content.classList.remove('show');
                e.target.textContent = expandText;
            } else {
                content.classList.add('show');
                e.target.textContent = hideText;
            }
        }
    });

    // 设置视频自动播放
    setupVideoAutoplay();
    
    // 设置可展开内容中的视频处理
    setupExpandableVideoHandling();
    
    // 设置比较按钮
    setupComparisonButtons();

    // 设置视频控制按钮
    setupVideoControlButtons();

    // 设置简单视频切换按钮
    setupSimpleVideoButtons();
}); 