<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Rise Simulation Viewer</title>
    <link href="XXXX" rel="stylesheet">
    <link href="XXXX" rel="stylesheet">
    <style>
        body {
            background-color: #1a1a1a;
            color: #f0f0f0;
            padding: 20px;
        }
        .camera-feed {
            margin-bottom: 20px;
            background-color: #222;
            border-radius: 8px;
            overflow: hidden;
            position: relative;
            border: 2px solid transparent;
            transition: all 0.3s ease;
        }
        .camera-feed.active {
            border-color: #28a745;
            box-shadow: 0 0 15px rgba(40, 167, 69, 0.5);
        }
        /* Recording indicator styles */
        .camera-feed.recording-active {
            border-color: #dc3545;
            box-shadow: 0 0 15px rgba(220, 53, 69, 0.5);
        }
        .camera-feed.recording-active .record-button {
            background-color: #dc3545;
            animation: pulse 1.5s infinite;
        }
        @keyframes pulse {
            0% { opacity: 1; }
            50% { opacity: 0.5; }
            100% { opacity: 1; }
        }
        .camera-title {
            padding: 10px;
            background-color: rgba(0,0,0,0.7);
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            z-index: 10;
            display: flex;
            justify-content: space-between;
            align-items: center;
        }
        .camera-title .select-indicator {
            color: #28a745;
            font-size: 1.2rem;
            display: none;
        }
        .camera-feed.active .camera-title .select-indicator {
            display: inline-block;
        }
        .camera-controls {
            padding: 10px;
            background-color: #333;
            border-top: 1px solid #444;
        }
        .camera-image {
            width: 100%;
            height: auto;
            display: block;
            cursor: pointer;
        }
        .camera-feed canvas {
            width: 100%;
            height: auto;
            display: block;
        }
        .control-panel {
            position: absolute;
            bottom: 10px;
            left: 10px;
            background-color: rgba(0,0,0,0.7);
            padding: 8px;
            border-radius: 5px;
            z-index: 100;
            display: none;
            max-width: 160px; /* Limit the width */
        }
        
        .camera-feed:hover .control-panel {
            display: block;
        }
        
        .camera-time {
            position: absolute;
            bottom: 10px;
            right: 10px;
            background-color: rgba(0,0,0,0.5);
            color: white;
            padding: 3px 8px;
            border-radius: 3px;
            font-family: monospace;
            font-size: 14px;
            z-index: 50;
        }
        
        .control-button {
            width: 36px;  /* Smaller button width */
            height: 36px; /* Smaller button height */
            margin: 1px;  /* Smaller margin */
            font-size: 14px; /* Smaller font */
            background-color: #444;
            border: 1px solid #555;
            color: white;
            transition: background-color 0.2s;
            padding: 0;   /* Remove padding */
        }
        
        .control-button.active {
            background-color: #28a745;
        }
        
        /* Record button styles */
        .record-button, .expand-button {
            width: 32px;
            height: 32px;
            border-radius: 50%;
            background-color: #444;
            border: 1px solid #555;
            color: white;
            font-size: 14px;
            display: flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            transition: all 0.3s ease;
            margin-right: 8px;
        }

        .record-button:hover, .expand-button:hover {
            background-color: #555;
        }
        
        .record-button.recording {
            background-color: #dc3545;
        }

        /* Bird view button styles */
        .bird-view-btn, .detailed-bird-view-btn {
            margin-right: 8px;
            font-size: 12px;
            padding: 0.25rem 0.5rem;
            line-height: 1.2;
        }

        .bird-view-btn:hover, .detailed-bird-view-btn:hover {
            background-color: #17a2b8;
            border-color: #17a2b8;
        }
        
        /* Make robot select dropdown smaller */
        .control-panel .form-select {
            font-size: 12px;
            padding: 0.25rem 0.5rem;
            height: auto;
        }
        
        .control-panel .mt-3 {
            margin-top: 0.5rem !important;
        }
        
        .control-panel .mb-2 {
            margin-bottom: 0.25rem !important;
        }
        
        /* Add some transparency to make it less obtrusive */
        .control-panel {
            opacity: 0.85;
            transition: opacity 0.2s;
        }
        
        .control-panel:hover {
            opacity: 1;
        }
        .info-overlay {
            position: absolute;
            top: 60px;
            left: 10px;
            background-color: rgba(0,0,0,0.7);
            padding: 5px;
            border-radius: 3px;
            font-size: 12px;
            color: #ddd;
        }

        .main-camera-view .info-overlay {
            top: 10px; /* This will override the 40px for the detailed view */
        }

        .control-help {
            position: fixed;
            bottom: 20px;
            left: 50%;
            transform: translateX(-50%);
            background-color: rgba(0,0,0,0.7);
            padding: 10px 20px;
            border-radius: 5px;
            font-size: 14px;
            color: #ddd;
        }
        .keyboard-key {
            display: inline-block;
            background: #333;
            border: 1px solid #555;
            border-radius: 3px;
            padding: 2px 8px;
            margin: 0 2px;
            font-family: monospace;
        }
        /* Recording notification style */
        .recording-notification {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            z-index: 1000;
            color: white;
            text-align: center;
        }

        /* Detailed view layout styles */
        .detailed-view-container {
            display: none;
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background-color: #1a1a1a;
            z-index: 2000;
            padding: 20px;
            overflow: hidden;
        }

        .detailed-view-container.active {
            display: flex;
        }

        .main-camera-container {
            flex: 2;
            padding-right: 10px;
            overflow: hidden;
            display: flex;
            flex-direction: column;
        }

        .robot-feeds-container {
            flex: 1;
            max-width: 35%;
            border-left: 1px solid #333;
            padding-left: 10px;
            overflow: hidden;
            display: flex;
            flex-direction: column;
        }

        .robot-feeds-scroll {
            flex: 1;
            overflow-y: auto;
            padding-right: 10px;
        }

        .detailed-view-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 10px;
            background-color: #222;
            border-radius: 8px 8px 0 0;
            margin-bottom: 10px;
        }

        .robot-camera-feed {
            margin-bottom: 15px;
            background-color: #222;
            border-radius: 8px;
            overflow: hidden;
            position: relative;
            display: flex;
            flex-direction: column;
            align-items: center;  /* Center horizontally */
        }

        .robot-camera-title {
            padding: 8px;
            background-color: rgba(0,0,0,0.7);
            font-size: 14px;
            text-align: center;
            width: 100%; /* Make it take up full width */
            display: block; /* Ensure it's a block element */
        }

        .robot-camera-image {
            display: block;
            margin: 0 auto;  /* Center the canvas itself */
            background-color: #000;  /* Dark background to see the canvas boundaries */
        }

        .main-camera-view {
            flex: 1;
            background-color: #222;
            border-radius: 8px;
            position: relative;
            overflow: hidden;
            display: flex;
            flex-direction: column;
        }

        .main-camera-view canvas {
            width: 100%;
            height: 100%;
            object-fit: contain;
        }

        .close-detailed-view {
            position: absolute;
            top: 10px;
            right: 10px;
            z-index: 2100;
            background-color: rgba(0,0,0,0.7);
            color: white;
            border: none;
            border-radius: 50%;
            width: 36px;
            height: 36px;
            display: flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
        }

        .close-detailed-view:hover {
            background-color: rgba(220, 53, 69, 0.7);
        }

        .control-panel-detailed {
            position: absolute;
            bottom: 50px;
            left: 20px;
            background-color: rgba(0,0,0,0.7);
            padding: 10px;
            border-radius: 5px;
            z-index: 2100;
        }

        .robot-camera-title {
            padding: 8px;
            background-color: rgba(0,0,0,0.7);
            font-size: 14px;
            text-align: center;
        }
    </style>
</head>
<body>
    <div class="container-fluid">
        <h1 class="mb-4" id="pageTitle">{{title}}</h1>
        <div class="row" id="cameraGrid">
            <!-- Camera feeds will be dynamically added here -->
        </div>
    </div>

    <!-- Detailed View Layout -->
    <div class="detailed-view-container" id="detailedViewContainer">
        <button class="close-detailed-view" id="closeDetailedViewBtn">
            <i class="bi bi-x-lg"></i>
        </button>

        <div class="main-camera-container">
            <div class="detailed-view-header">
                <h4 id="mainCameraTitle">Main Camera</h4>
                <div class="d-flex align-items-center">
                    <button class="record-button detailed-record-btn" title="Start Recording">
                        <i class="bi bi-record-circle"></i>
                    </button>
                    <button class="btn btn-sm btn-outline-light detailed-bird-view-btn" title="Bird's Eye View">
                        <i class="bi bi-eye"></i>
                    </button>
                    <button class="btn btn-sm btn-outline-light detailed-tracking-toggle">Free Cam</button>
                </div>
            </div>
            <div class="main-camera-view">
                <canvas id="mainDetailedCanvas"></canvas>
                <div class="info-overlay" id="mainDetailedInfo">Position: [0,0,0]</div>
                <div class="camera-time" id="mainDetailedTime">00:00:000</div>
                <div class="control-panel-detailed">
                    <div class="d-flex justify-content-center mb-2">
                        <button class="control-button" data-action="forward" data-key="w">W</button>
                    </div>
                    <div class="d-flex justify-content-center">
                        <button class="control-button" data-action="left" data-key="a">A</button>
                        <button class="control-button" data-action="backward" data-key="s">S</button>
                        <button class="control-button" data-action="right" data-key="d">D</button>
                    </div>
                    <div class="d-flex justify-content-between mt-2">
                        <button class="control-button" data-action="roll-left" data-key="q">Q</button>
                        <button class="control-button" data-action="roll-right" data-key="e">E</button>
                    </div>
                    <div class="mt-3">
                        <select class="form-select detailed-robot-select">
                            <option value="">Select Robot to Track</option>
                        </select>
                    </div>
                </div>
            </div>
        </div>

        <div class="robot-feeds-container">
            <div class="detailed-view-header">
                <h4>Robot Camera Feeds</h4>
            </div>
            <div class="robot-feeds-scroll" id="robotFeedsContainer">
                <!-- Robot camera feeds will be dynamically added here -->
            </div>
        </div>
    </div>

    <div class="control-help">
    Select a simulation by clicking on it. Then use <span class="keyboard-key">W</span> <span class="keyboard-key">A</span> <span class="keyboard-key">S</span> <span class="keyboard-key">D</span> to move, <span class="keyboard-key">Q</span> <span class="keyboard-key">E</span> to roll. <span class="keyboard-key">Shift</span> + mouse scroll for forward/backward movement. Click the <i class="bi bi-record-circle"></i> button to record.
    </div>

    <!-- Template for camera feed -->
    <template id="camera-template">
        <div class="col-md-4">
            <div class="camera-feed" data-sim-id="">
                <div class="camera-title">
                    <span class="sim-name">Simulation</span>
                    <div class="d-flex align-items-center">
                        <button class="record-button" title="Start Recording">
                            <i class="bi bi-record-circle"></i>
                        </button>
                        <button class="expand-button" title="Expand View">
                            <i class="bi bi-arrows-fullscreen"></i>
                        </button>
                        <button class="btn btn-sm btn-outline-light bird-view-btn" title="Bird's Eye View">
                            <i class="bi bi-eye"></i>
                        </button>
                        <button class="btn btn-sm btn-outline-light tracking-toggle">Free Cam</button>
                        <i class="bi bi-check-circle-fill select-indicator ms-2"></i>
                    </div>
                </div>
                <canvas class="camera-image"></canvas>
                <div class="info-overlay">Position: [0,0,0]</div>
                <div class="camera-time">00:00:000</div>
                
                <div class="control-panel">
                    <div class="d-flex justify-content-center mb-2">
                        <button class="control-button" data-action="forward" data-key="w">W</button>
                    </div>
                    <div class="d-flex justify-content-center">
                        <button class="control-button" data-action="left" data-key="a">A</button>
                        <button class="control-button" data-action="backward" data-key="s">S</button>
                        <button class="control-button" data-action="right" data-key="d">D</button>
                    </div>
                    <div class="d-flex justify-content-between mt-2">
                        <button class="control-button" data-action="roll-left" data-key="q">Q</button>
                        <button class="control-button" data-action="roll-right" data-key="e">E</button>
                    </div>
                    <div class="mt-3">
                        <select class="form-select robot-select">
                            <option value="">Select Robot to Track</option>
                        </select>
                    </div>
                </div>
            </div>
        </div>
    </template>

    <!-- Template for robot camera feed in detailed view -->
    <template id="robot-camera-template">
        <div class="robot-camera-feed" data-camera-name="">
            <div class="robot-camera-title">Robot Camera</div>
            <canvas class="robot-camera-image"></canvas>
        </div>
    </template>

    <script src="XXXX"></script>
    <script src="XXXX"></script>
    <script src="/static/main.js"></script>
</body>
</html>