<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <title>Physics101</title>
    <script src="https://cdn.tailwindcss.com"></script>
    <style>
      button:focus-visible,
      input[type="checkbox"]:focus-visible {
        outline: 2px solid #9ca3af;
        outline-offset: 2px;
      }

      /* Toggle Button Styles */
      .toggle-active {
        color: #60a5fa; /* Blue-400 */
        border-bottom: 2px solid #60a5fa;
      }
      .toggle-inactive {
        color: #9ca3af; /* Gray-400 */
        border-bottom: 2px solid transparent;
      }
      .toggle-inactive:hover {
        color: #e5e7eb;
      }

      /* Strict Dimensions for uniformity */
      .viewport-box {
        width: 448px;
        height: 224px;
      }
    </style>
  </head>

  <body
    class="bg-black text-gray-200 p-4 md:p-8 font-sans min-h-screen flex flex-col items-center"
  >
    <div class="w-full max-w-[1400px] flex items-center gap-x-3 mb-8">
      <a
        href="index.html"
        aria-label="Go to Homepage"
        class="text-blue-400 hover:text-blue-500 text-3xl font-semibold transition-colors duration-150 ease-in-out focus:outline-none focus-visible:ring-2 focus-visible:ring-blue-300 focus-visible:ring-offset-2 focus-visible:ring-offset-black rounded-md"
      >
        &larr;
      </a>

      <h1 class="text-3xl font-bold text-left text-gray-100">Physics101</h1>
      <span
        class="text-gray-500 text-lg mt-1 ml-2 font-mono border-l border-gray-800 pl-4"
        id="sceneNameDisplay"
      >
        Loading...
      </span>
    </div>

    <div class="flex flex-col xl:flex-row gap-8 items-start justify-center">
      <div class="flex flex-col gap-2">
        <div class="flex justify-between items-end px-1 mb-2">
          <h2 class="text-xl font-semibold text-blue-400">Input</h2>
        </div>

        <div
          class="viewport-box relative bg-neutral-900 rounded-lg overflow-hidden shadow-lg border border-neutral-800"
        >
          <img
            id="imgRef"
            src=""
            class="absolute inset-0 w-full h-full object-fill z-0"
            alt="Reference"
          />
        </div>
      </div>

      <div class="flex flex-col gap-2">
        <div class="flex justify-between items-end px-1 mb-2 w-[448px]">
          <h2 class="text-xl font-semibold text-gray-100">Ground Truth</h2>
          <div class="flex gap-4 text-xs font-bold uppercase tracking-wider">
            <button
              id="btnGtTracks"
              onclick="setGtMode('tracks')"
              class="toggle-active pb-1 transition-all"
            >
              Tracks Only
            </button>
            <button
              id="btnGtRgb"
              onclick="setGtMode('rgb')"
              class="toggle-inactive pb-1 transition-all"
            >
              Tracks + RGB
            </button>
          </div>
        </div>

        <div
          class="viewport-box bg-neutral-900 rounded-lg overflow-hidden shadow-lg border border-neutral-800 relative"
        >
          <video
            id="vidGt"
            class="w-full h-full object-fill"
            autoplay
            muted
            loop
            playsinline
          ></video>
        </div>
      </div>

      <div class="flex flex-col gap-2">
        <div class="flex justify-between items-end px-1 mb-2">
          <h2 class="text-xl font-semibold text-gray-100">Ours</h2>
          <span
            class="text-xs font-bold uppercase tracking-wider text-gray-500 pb-1"
            >Tracks</span
          >
        </div>

        <div
          class="viewport-box bg-neutral-900 rounded-lg overflow-hidden shadow-lg border border-neutral-800 relative"
        >
          <video
            id="vidOurs"
            class="w-full h-full object-fill"
            autoplay
            muted
            loop
            playsinline
          ></video>
        </div>
      </div>
    </div>

    <div class="flex justify-center items-center gap-6 mt-12 w-full">
      <button
        id="prevBtn"
        class="bg-blue-700 hover:bg-blue-800 text-white font-semibold py-2 px-6 rounded-lg shadow-md transition-colors duration-150 ease-in-out disabled:opacity-50 disabled:bg-gray-800 disabled:text-gray-500 disabled:cursor-not-allowed"
      >
        &larr; Previous
      </button>
      <span
        id="counterDisplay"
        class="text-lg font-medium text-gray-400 font-mono min-w-[120px] text-center"
      >
        0 / 0
      </span>
      <button
        id="nextBtn"
        class="bg-blue-700 hover:bg-blue-800 text-white font-semibold py-2 px-6 rounded-lg shadow-md transition-colors duration-150 ease-in-out disabled:opacity-50 disabled:bg-gray-800 disabled:text-gray-500 disabled:cursor-not-allowed"
      >
        Next &rarr;
      </button>
    </div>

    <script>
      // --- CONFIG ---
      const BASE_PATH = "samples/physics101";
      const GT_FILES = {
        tracks: "black.mp4",
        rgb: "rgb.mp4",
      };

      // --- DATA ---
      const SCENES = [
        "00001_000_kinect",
        "00014_002_kinect",
        "00038_000_kinect",
        "00257_000_camera",
        "00283_000_kinect",
        "00312_000_kinect",
        "00321_000_camera",
        "00325_000_camera",
        "00014_000_kinect",
        "00038_000_camera",
        "00081_001_camera",
        "00257_001_camera",
        "00283_001_kinect",
        "00312_001_kinect",
        "00321_001_camera",
      ];

      // --- STATE ---
      let currentIndex = 0;
      let gtMode = "tracks";

      // --- DOM ---
      const els = {
        sceneName: document.getElementById("sceneNameDisplay"),
        counter: document.getElementById("counterDisplay"),
        prevBtn: document.getElementById("prevBtn"),
        nextBtn: document.getElementById("nextBtn"),
        imgRef: document.getElementById("imgRef"),
        vidOurs: document.getElementById("vidOurs"),
        vidGt: document.getElementById("vidGt"),
        btnGtTracks: document.getElementById("btnGtTracks"),
        btnGtRgb: document.getElementById("btnGtRgb"),
      };

      // --- FUNCTIONS ---

      function setGtMode(mode) {
        gtMode = mode;
        if (gtMode === "tracks") {
          els.btnGtTracks.className =
            "toggle-active pb-1 transition-all cursor-default";
          els.btnGtRgb.className =
            "toggle-inactive pb-1 transition-all cursor-pointer";
        } else {
          els.btnGtTracks.className =
            "toggle-inactive pb-1 transition-all cursor-pointer";
          els.btnGtRgb.className =
            "toggle-active pb-1 transition-all cursor-default";
        }
        // Refresh just the GT source
        updateGtSource(SCENES[currentIndex]);
      }

      function updateGtSource(scene) {
        const filename = gtMode === "tracks" ? GT_FILES.tracks : GT_FILES.rgb;
        els.vidGt.src = `${BASE_PATH}/${scene}/gt/${filename}`;
      }

      function renderScene(index) {
        const scene = SCENES[index];

        // UI Updates
        els.sceneName.textContent = scene;
        els.counter.textContent = `${index + 1} / ${SCENES.length}`;
        els.prevBtn.disabled = index === 0;
        els.nextBtn.disabled = index === SCENES.length - 1;

        // Save state specifically for Physics101
        localStorage.setItem("compare_physics101_idx", index);

        // 1. Input Image
        els.imgRef.src = `${BASE_PATH}/${scene}/initial_frame.png`;

        // 2. Ours Video
        els.vidOurs.src = `${BASE_PATH}/${scene}/ours/black.mp4`;

        // 3. GT Video
        updateGtSource(scene);
      }

      // --- INIT ---
      document.addEventListener("DOMContentLoaded", () => {
        const savedIndex = localStorage.getItem("compare_physics101_idx");
        if (savedIndex && !isNaN(savedIndex)) {
          currentIndex = Math.max(
            0,
            Math.min(parseInt(savedIndex), SCENES.length - 1)
          );
        }

        if (SCENES.length > 0) renderScene(currentIndex);
        else els.sceneName.textContent = "No Scenes Configured";

        // Navigation Handlers
        const next = () => {
          if (currentIndex < SCENES.length - 1) {
            currentIndex++;
            renderScene(currentIndex);
          }
        };
        const prev = () => {
          if (currentIndex > 0) {
            currentIndex--;
            renderScene(currentIndex);
          }
        };

        els.nextBtn.onclick = next;
        els.prevBtn.onclick = prev;

        document.addEventListener("keydown", (e) => {
          if (e.key === "ArrowRight") next();
          if (e.key === "ArrowLeft") prev();
        });

        // Global exposure
        window.setGtMode = setGtMode;
      });
    </script>
  </body>
</html>
