<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <title>Cityscapes</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">Cityscapes</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>
          <button
            id="btnToggleSeg"
            onclick="toggleSegmentation()"
            class="text-xs font-bold uppercase tracking-wider text-gray-500 hover:text-white transition-colors pb-1"
          >
            Show Segmentation
          </button>
        </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"
          />
          <img
            id="imgSeg"
            src=""
            class="absolute inset-0 w-full h-full object-fill z-10 opacity-0 transition-opacity duration-200 pointer-events-none"
            alt="Segmentation"
          />
        </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 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">
            WAN (1.3B, fine-tuned)
          </h2>
          <div class="flex gap-4 text-xs font-bold uppercase tracking-wider">
            <button
              id="btnWanTracks"
              onclick="setWanMode('tracks')"
              class="toggle-active pb-1 transition-all"
            >
              Tracks Only
            </button>
            <button
              id="btnWanRGB"
              onclick="setWanMode('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="vidWan"
            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/cityscapes";
      const WAN_FILES = {
        tracks: "tracks.mp4",
        rgb: "tracks+rgb.mp4",
      };

      // Strict single seed configuration
      const SEED = 0;

      // --- DATA ---
      const SCENES = [
        "munster_000033_cont_0359_start_0000",
        "munster_000141_cont_0467_start_0000",
        "munster_000162_cont_0488_start_0000",
        "frankfurt_000001_cont_0110_start_0000",
        "frankfurt_000001_cont_0139_start_0000",
        "frankfurt_000001_cont_0191_start_0000",
        "frankfurt_000001_cont_0270_start_0000",
        "frankfurt_000001_cont_0274_start_0000",
        "lindau_000037_cont_0037_start_0000",
        "lindau_000044_cont_0044_start_0000",
        "lindau_000052_cont_0052_start_0000",
      ];

      // --- STATE ---
      let currentIndex = 0;
      // UPDATED: Default mode set to 'tracks'
      let wanMode = "tracks";
      let showSegmentation = false;

      // --- DOM ---
      const els = {
        sceneName: document.getElementById("sceneNameDisplay"),
        counter: document.getElementById("counterDisplay"),
        prevBtn: document.getElementById("prevBtn"),
        nextBtn: document.getElementById("nextBtn"),
        imgRef: document.getElementById("imgRef"),
        imgSeg: document.getElementById("imgSeg"),
        btnToggleSeg: document.getElementById("btnToggleSeg"),
        vidOurs: document.getElementById("vidOurs"),
        vidWan: document.getElementById("vidWan"),
        btnWanTracks: document.getElementById("btnWanTracks"),
        btnWanRGB: document.getElementById("btnWanRGB"),
      };

      // --- FUNCTIONS ---

      function toggleSegmentation() {
        showSegmentation = !showSegmentation;
        if (showSegmentation) {
          els.imgSeg.classList.remove("opacity-0");
          els.imgSeg.classList.add("opacity-100");
          els.btnToggleSeg.textContent = "Hide Segmentation";
          els.btnToggleSeg.classList.add("text-blue-400");
        } else {
          els.imgSeg.classList.remove("opacity-100");
          els.imgSeg.classList.add("opacity-0");
          els.btnToggleSeg.textContent = "Show Segmentation";
          els.btnToggleSeg.classList.remove("text-blue-400");
        }
      }

      function setWanMode(mode) {
        wanMode = mode;
        if (wanMode === "tracks") {
          els.btnWanTracks.className =
            "toggle-active pb-1 transition-all cursor-default";
          els.btnWanRGB.className =
            "toggle-inactive pb-1 transition-all cursor-pointer";
        } else {
          els.btnWanTracks.className =
            "toggle-inactive pb-1 transition-all cursor-pointer";
          els.btnWanRGB.className =
            "toggle-active pb-1 transition-all cursor-default";
        }
        // Refresh just the WAN source
        updateWanSource(SCENES[currentIndex]);
      }

      function updateWanSource(scene) {
        const filename =
          wanMode === "tracks" ? WAN_FILES.tracks : WAN_FILES.rgb;
        els.vidWan.src = `${BASE_PATH}/wan/${scene}/seed=${SEED}/${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;

        localStorage.setItem("compare_cityscapes_idx", index);

        // 1. Input Images
        const baseRefPath = `${BASE_PATH}/ours/${scene}/seed=${SEED}`;
        els.imgRef.src = `${baseRefPath}/reference_frame.jpg`;
        els.imgSeg.src = `${baseRefPath}/reference_frame_overlayed.jpg`;

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

        // 3. Wan Video
        updateWanSource(scene);
      }

      // --- INIT ---
      document.addEventListener("DOMContentLoaded", () => {
        const savedIndex = localStorage.getItem("compare_cityscapes_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.setWanMode = setWanMode;
        window.toggleSegmentation = toggleSegmentation;
      });
    </script>
  </body>
</html>
