<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Navigating Through Crowds Survey</title>
    <link rel="stylesheet" href=href="styles.css?v=1" type="text/css">
    <style>
        body {
            margin: 0;
            padding: 0;
            font-family: Arial, sans-serif;
            background-color: #f0f0f0;
            display: flex;
            flex-direction: column;
            min-height: 100vh;
        }
    
        .sticky-image {
            position: fixed; /* Position the image fixed on the screen */
            top: 0; /* Align at the top of the viewport */
            left: 10%; /* Align at the left side of the viewport */
            width: 35%; /* Adjust width as needed */
            height: 100vh; /* Cover full height of the viewport */
            background-color: #fff;
            display: flex;
            align-items: center;
            justify-content: center;
            overflow: hidden;
            flex-direction: column;
        }
    
        .sticky-image img {
            width: 100%;
            height: auto; /* Keep the aspect ratio */
            max-height: 100%;
            object-fit: cover;
            display: block; /* Ensure the image is visible */
        }

        .slider-container {
            margin-top: -40px; /* Move slider up */
            width: 80%; /* Adjust width to fit container */
            text-align: center; /* Center the slider within the container */
        }
    
        .main-content {
            display: flex;
            flex: 1;
            min-height: 100vh;
            margin-left: 50%; /* Add margin to avoid being covered by the sticky image */
            justify-content: center;
            align-items: center;
            overflow: hidden;
        }
    
        .form-container {
            width: 100%;
            max-width: 40rem;
            padding: 2rem;
            background-color: white;
            border-radius: 0.625rem;
            box-shadow: 0 0.25rem 0.5rem rgba(0, 0, 0, 0.1);
            overflow-y: auto;
            display: flex;
            flex-direction: column;
        }

        .header {
            font-size: 2rem; /* Responsive font size */
            font-weight: bold;
            margin-bottom: 1.25rem; /* 1.25rem for consistent margin */
            text-align: center;
        }
    
        .pages-left {
            font-size: 1rem; /* Responsive font size */
            font-weight: bold;
            margin-bottom: 1.25rem; /* 1.25rem for consistent margin */
            text-align: center;
            color: #555;
        }
    
        .instructions {
            font-size: 1.2rem; /* Responsive font size */
            margin-bottom: 1.25rem; /* 1.25rem for consistent margin */
            text-align: left;
        }
    
        .questions {
            flex: 1;
            overflow-y: auto;
            text-align: center; /* Center the questions section */
        }
    
        .question-group {
            margin-bottom: 1.25rem; /* 1.25rem for consistent margin */
            text-align: left;
            padding-left: 1.25rem; /* Padding to move content slightly to the right */
        }
    
        .question-group p {
            text-align: center;
            margin: 0 auto;
        }
    
        .question-group input[type="radio"],
        .question-group input[type="checkbox"] {
            margin-left: 1.25rem; /* Adjusted for consistency */
        }
    
        .question-group label {
            margin-left: 0.625rem; /* Adjusted for consistency */
        }
        previous_answers
        .question-matrix {
            width: 100%;
            border-collapse: collapse;
            margin-bottom: 1.25rem; /* Adjusted for consistency */
        }
    
        .question-matrix th,
        .question-matrix td {
            border: 0.0625rem solid #ddd; /* 1px is 0.0625rem */
            padding: 0.5rem; /* Adjusted for consistency */
            text-align: center;
        }
    
        .question-matrix th {
            background-color: #f2f2f2;
            font-weight: bold;
        }
    
        .button-container {
            text-align: center;
            padding: 0.5rem 0; /* Adjusted for consistency */
            background-color: white;
            margin-bottom: 0.5rem; /* Adjusted for consistency */
        }
    
        .button, .button-back {
            display: inline-block;
            margin-top: 0.5rem; /* Adjusted for consistency */
            padding: 0.625rem 1.25rem; /* Adjusted for consistency */
            background-color: #007BFF;
            color: white;
            text-decoration: none;
            border-radius: 0.3125rem; /* 5px is 0.3125rem */
            border: none;
            cursor: pointer;
            font-size: 1rem; /* Responsive font size */
        }
    
        .button-back {
            background-color: #6c757d;
            margin-right: 0.625rem; /* Adjusted for consistency */
        }
    
        .button:hover {
            background-color: #0056b3;
        }
    
        .button-back:hover {
            background-color: #5a6268;
        }
    
        @media (max-width: 48rem) { /* Adjust for smaller screens */
            .main-content {
                flex-direction: column;
                height: auto;
                padding: 1.25rem;
            }
    
            .sticky-image, .form-container {
                width: 100%;
            }
    
            .sticky-image {
                height: 30vh;
            }
        }
    
        @media (max-width: 30rem) { /* Further adjustments for very small screens */
            .header {
                font-size: 1.5rem;
            }
    
            .pages-left {
                font-size: 0.9rem;
            }
    
            .instructions {
                font-size: 1rem;
            }
    
            .button, .button-back {
                font-size: 0.9rem;
            }
    
            .sticky-image {
                height: 25vh;
            }

            .play-button {
                margin-right: 10px; /* Add margin to separate the button from the slider */
                padding: 0.625rem 1.25rem; /* Adjusted for consistency */
                background-color: #28a745;
                color: white;
                border: none;
                border-radius: 0.3125rem;
                cursor: pointer;
                font-size: 1.5rem; /* Increased font size for icon visibility */
            }
    
            .play-button:hover {
                background-color: #218838;
            }
        }
    </style>
</head>
<body>
    <div class="main-content">
        <div class="sticky-image">
            {% for filepath in image_data['image_filepaths'] %}
            <img src="{{ url_for('static', filename=filepath) }}" id="frame-{{ loop.index0 }}" alt="image">
            {% endfor %}
            <div class="slider-container">
                <button id="play-button" class="play-button">►</button>
                <input type="range" id="frame-slider" min="0" max="{{ 10 - 1 }}" value="0" step="1">
            </div>
        </div>

        <div class="form-container">
            <div class="header">
                {{ image_data['header'] }}
            </div>
            <div class="pages-left">
                Pages left: {{ pages_left }}
            </div>
            <div class="instructions">
                {{ image_data['instructions']|safe }}
            </div>
            <div class="questions">
                <form method="POST" action="{{ url_for('questions_callback', page_id=page_id) }}" id="question-form">
                    {% for question_group in image_data['questions'] %}
                    <div class="question-group">
                        <div class="question-group-title">{{ question_group.title }}</div>
                        <p>{{ question_group[0]['question'] }}</p>

                        {% if question_group[0]['type'] == 'multiple_choice' %}
                            {% for choice in question_group[0]['choices'] %}
                            <label>
                                <input type="radio" name="{{ question_group[0]['id'] }}" value="{{ choice }}" required {% if previous_answers.get(question_group[0]['id']) == choice %}checked{% endif %}>
                                {{ choice }}
                            </label><br>
                            {% endfor %}
                        {% elif question_group[0]['type'] == 'multiple_select' %}
                            {% for choice in question_group[0]['choices'] %}
                            <label>
                                <input type="checkbox" name="{{ question_group[0]['id'] }}[]" value="{{ choice }}" {% if choice in previous_answers.get(question_group[0]['id'], []) %}checked{% endif %}>
                                {{ choice }}
                            </label><br>
                            {% endfor %}                        
                        {% elif question_group[0]['type'] == 'multiple_choice_matrix' %}
                            <table class="question-matrix">
                                <thead>
                                    <tr>
                                        <th></th>
                                        {% for choice in question_group[0]['choices'] %}
                                        <th>{{ choice }}</th>
                                        {% endfor %}
                                    </tr>
                                </thead>
                                <tbody>
                                    {% for question in question_group %}
                                    <tr>
                                        <td>{{ question['row'] }}</td>
                                        {% for choice in question['choices'] %}
                                        <td>
                                            <label style="display: block; width: 100%; height: 100%;">
                                                <input type="radio" name="{{ question['id'] }}" value="{{ choice }}" required {% if previous_answers.get(question['id']) == choice %}checked{% endif %}>
                                            </label>
                                        </td>
                                        {% endfor %}
                                    </tr>
                                    {% endfor %}
                                </tbody>
                            </table>
                        {% endif %}
                    </div>
                    {% endfor %}
                    <div class="button-container">
                        {% if page_id > 0 %}
                            <button type="submit" name="action" value="back" class="button-back" onclick="removeRequired()">Back</button>
                        {% endif %}
                        <button type="submit" name="action" value="next" class="button" onclick="addRequired()">Next</button>
                    </div>
                </form>
            </div>
        </div>
    </div>

    <script>
        const numFrames = 10;
        const slider = document.getElementById('frame-slider');
        const playButton = document.getElementById('play-button');
        const images = [];

        // Declare variables
        let isPlaying = sessionStorage.getItem('isPlaying') === 'true';
        let intervalId = null;

        for (let i = 0; i < numFrames; i++) {
            images.push(document.getElementById('frame-' + i));
            images[i].style.display = 'none';
        }

        images[0].style.display = 'block';

        slider.addEventListener('input', function() {
            const frameIndex = slider.value;
            images.forEach((img, index) => {
                img.style.display = index == frameIndex ? 'block' : 'none';
            });
        });

        function addRequired() {
            const form = document.getElementById('question-form');
            const inputs = form.querySelectorAll('input[type="radio"]');
            inputs.forEach(input => {
                input.setAttribute('required', 'required');
            });
        }

        function removeRequired() {
            const form = document.getElementById('question-form');
            const inputs = form.querySelectorAll('input[type="radio"]');
            inputs.forEach(input => {
                input.removeAttribute('required');
            });
        }

        // Function to start playing the images
        function startPlaying() {
            let currentIndex = parseInt(slider.value);
            const interval = 400; // Time in milliseconds between each frame

            intervalId = setInterval(() => {
                currentIndex = (currentIndex + 1) % numFrames;
                images.forEach((img, index) => {
                    img.style.display = index === currentIndex ? 'block' : 'none';
                });
                slider.value = currentIndex;
            }, interval);
        }

        // Function to stop playing the images
        function stopPlaying() {
            clearInterval(intervalId);
            intervalId = null;
        }

        // Toggle play/stop button functionality
        playButton.addEventListener('click', function() {
            if (isPlaying) {
                stopPlaying();
                playButton.textContent = '►';
            } else {
                startPlaying();
                playButton.textContent = '■';
            }
            isPlaying = !isPlaying;
            sessionStorage.setItem('isPlaying', isPlaying);
        });

        // Function to play the sequence slider once on page load and return to frame 0
        function playSequenceOnce() {
            let currentIndex = 0;
            const interval = 400; // Time in milliseconds between each frame
            const maxIndex = numFrames - 1;

            const intervalId = setInterval(() => {
                images.forEach((img, index) => {
                    img.style.display = index === currentIndex ? 'block' : 'none';
                });
                slider.value = currentIndex;
                currentIndex++;

                if (currentIndex > maxIndex) {
                    clearInterval(intervalId);
                    // Return to the first frame after the sequence ends
                    images.forEach((img, index) => {
                        img.style.display = index === 0 ? 'block' : 'none';
                    });
                    slider.value = 0;
                }
            }, interval);
        }

        // Trigger the sequence playback on page load
        // On page load, check if isPlaying is true
        window.onload = function() {
            isPlaying = true; // Set default to playing
            playButton.textContent = '■';
            startPlaying();
        };
    </script>
</body>
</html>