<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <title>Real examples</title>
    <script src="https://cdn.tailwindcss.com"></script>

    <style>
      button:focus-visible,
      input[type="checkbox"]:focus-visible {
        outline: 2px solid #9ca3af;
        outline-offset: 2px;
      }

      .model-scroll-area {
        max-height: 510px;
        overflow-y: auto; /* This element gets the scrollbar */

        /* Adjusted padding: */
        padding-top: 8px;
        padding-bottom: 8px;
        padding-left: 8px;
        padding-right: 24px; /* Significantly increased: 8px for scrollbar + 16px visual buffer */

        border-radius: 0.375rem; /* rounded-md */
        background-color: black;
        box-sizing: border-box; /* Ensures padding is included in the element's total width/height */
      }

      .model-scroll-area::-webkit-scrollbar {
        width: 8px; /* The scrollbar itself is 8px wide */
      }
      .model-scroll-area::-webkit-scrollbar-track {
        background: #1f2937;
        border-radius: 10px;
      }
      .model-scroll-area::-webkit-scrollbar-thumb {
        background: #6b7280;
        border-radius: 10px;
      }
      .model-scroll-area::-webkit-scrollbar-thumb:hover {
        background: #9ca3af;
      }
    </style>
  </head>

  <body class="bg-black text-gray-200 p-4 md:p-8 font-sans">
    <div class="flex items-center gap-x-3 mb-1">
      <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">
        Some real-world examples
      </h1>
    </div>
    <h2 class="text-2xl mb-4 text-left text-gray-100">Recorded in our lab</h2>
    <div
      class="flex flex-col lg:flex-row justify-center items-start gap-6 md:gap-8 mt-8"
    >
      <div
        class="bg-black rounded-xl shadow-xl p-2 w-full lg:max-w-[320px] flex-shrink-0 mx-auto lg:mx-0"
      >
        <h2 class="text-xl font-semibold mb-4 text-center text-blue-400">
          Initial Condition
        </h2>
        <div class="flex flex-col items-center gap-2">
          <img
            id="initialConditionImage"
            src="https://placehold.co/256x256/000000/D1D5DB?text=Loading..."
            alt="Initial Condition Scene"
            class="w-[256px] h-[256px] object-cover rounded-md shadow-lg"
          />
          <img
            id="initialConditionImageSecondary"
            src="https://placehold.co/256x256/000000/D1D5DB?text=Secondary"
            alt="Secondary Initial Condition"
            class="w-[256px] h-[256px] object-cover rounded-md shadow-lg"
          />
        </div>
      </div>

      <div
        class="flex flex-col md:flex-row justify-center items-start gap-6 md:gap-8"
      >
        <div class="bg-black rounded-xl shadow-xl p-2 w-fit mx-auto md:mx-0">
          <h2 class="text-xl font-semibold mb-2 text-center text-gray-100">
            Ours
          </h2>
          <div id="Ours-scroll-area" class="model-scroll-area mt-2"></div>
        </div>
      </div>
    </div>

    <div class="flex justify-center items-center gap-4 mt-10 pt-4">
      <button
        id="prevSceneBtn"
        class="bg-blue-700 hover:bg-blue-800 text-white font-semibold py-2 px-4 rounded-lg shadow-md transition-colors duration-150 ease-in-out disabled:opacity-50 disabled:bg-gray-700 disabled:cursor-not-allowed"
      >
        &larr; Previous
      </button>
      <span id="sceneIndicator" class="text-lg font-medium text-gray-300"
        >Scene 1 / N</span
      >
      <button
        id="nextSceneBtn"
        class="bg-blue-700 hover:bg-blue-800 text-white font-semibold py-2 px-4 rounded-lg shadow-md transition-colors duration-150 ease-in-out disabled:opacity-50 disabled:bg-gray-700 disabled:cursor-not-allowed"
      >
        Next &rarr;
      </button>
    </div>

    <script>
      document.addEventListener("DOMContentLoaded", () => {
        const SCENE_IDENTIFIERS = [
          "stack-1",
          "stack-2",
          "gravity",
          "gravity2",
          "gravity3",
          "gravity4",
          "complex-1",
          "complex-2",
          "static",
          "static2",
          "static3",
          "balls",
        ];

        const TOTAL_SCENES = SCENE_IDENTIFIERS.length;
        const ITEMS_PER_GROUP = 4;
        const TOTAL_SAMPLES_PER_MODEL = 6;
        const MODEL_ID = "Ours";

        const initialConditionPlaceholderColor = "000000/D1D5DB";
        const LS_KEY_SCENE_INDEX = "realDataCompareSceneIndex";
        let currentSceneIndex;

        const savedSceneIndexStr = localStorage.getItem(LS_KEY_SCENE_INDEX);
        if (savedSceneIndexStr !== null) {
          const savedSceneIndex = parseInt(savedSceneIndexStr, 10);
          if (
            !isNaN(savedSceneIndex) &&
            savedSceneIndex >= 0 &&
            savedSceneIndex < TOTAL_SCENES
          ) {
            currentSceneIndex = savedSceneIndex;
          } else {
            currentSceneIndex = 0;
            localStorage.removeItem(LS_KEY_SCENE_INDEX);
          }
        } else {
          currentSceneIndex = 0;
        }

        const prevSceneBtn = document.getElementById("prevSceneBtn");
        const nextSceneBtn = document.getElementById("nextSceneBtn");
        const sceneIndicator = document.getElementById("sceneIndicator");
        const initialConditionImageEl = document.getElementById(
          "initialConditionImage"
        );
        const initialConditionImageSecondaryEl = document.getElementById(
          "initialConditionImageSecondary"
        );
        const modelScrollArea = document.getElementById("Ours-scroll-area");

        function createErrorPlaceholder(
          modelName,
          sceneIdentifier,
          rolloutIdx,
          messagePrefix = "Error loading video"
        ) {
          const placeholderContainer = document.createElement("div");
          placeholderContainer.className =
            "w-full h-auto aspect-square object-cover rounded shadow-sm media-element flex flex-col items-center justify-center bg-red-900";

          const errorLabel = document.createElement("span");
          errorLabel.textContent = `Sample: ${rolloutIdx}`;
          errorLabel.className = "text-xs text-gray-300 mb-1";
          placeholderContainer.appendChild(errorLabel);

          const errorText = document.createElement("p");
          errorText.textContent = `Error`;
          errorText.className = "text-red-300";
          placeholderContainer.appendChild(errorText);

          placeholderContainer.dataset.rolloutIdx = rolloutIdx;
          return placeholderContainer;
        }

        function getMediaProperties(sceneIdentifier, rolloutIdx) {
          const fileExtension = "mp4";
          const rollout = String(rolloutIdx).padStart(6, "0");
          const src = `./samples/real/${sceneIdentifier}/${rollout}_tab20_without_bg_black.${fileExtension}`;
          const ariaLabel = `Ours Scene ${sceneIdentifier} Sample ${rolloutIdx}`;
          return { src, ariaLabel };
        }

        function populateModelScrollArea(sceneIdentifier) {
          if (!modelScrollArea) {
            console.error(`Scroll area not found: Ours-scroll-area`);
            return;
          }
          modelScrollArea.innerHTML = ""; // Clear previous videos
          const numGroups = Math.ceil(
            TOTAL_SAMPLES_PER_MODEL / ITEMS_PER_GROUP
          );

          for (let groupIndex = 0; groupIndex < numGroups; groupIndex++) {
            const startSampleOffset = groupIndex * ITEMS_PER_GROUP;
            const gridDiv = document.createElement("div");
            const isLastGroup = groupIndex === numGroups - 1;
            gridDiv.className = `grid grid-cols-2 gap-2 ${
              !isLastGroup ? "mb-2" : ""
            }`;
            const itemsInThisGroup =
              isLastGroup && TOTAL_SAMPLES_PER_MODEL % ITEMS_PER_GROUP !== 0
                ? TOTAL_SAMPLES_PER_MODEL % ITEMS_PER_GROUP
                : ITEMS_PER_GROUP;

            for (let i = 0; i < itemsInThisGroup; i++) {
              const rolloutIdx = startSampleOffset + i + 1;
              const props = getMediaProperties(sceneIdentifier, rolloutIdx);

              const itemContainer = document.createElement("div");
              itemContainer.className = "flex flex-col items-center";

              const videoElement = document.createElement("video");
              videoElement.className =
                "w-full h-auto aspect-square object-cover rounded shadow-sm media-element";
              videoElement.autoplay = true;
              videoElement.loop = true;
              videoElement.muted = true;
              videoElement.playsInline = true;
              videoElement.setAttribute("aria-label", props.ariaLabel);
              videoElement.dataset.rolloutIdx = rolloutIdx;
              videoElement.dataset.currentSrc = props.src;

              const source = document.createElement("source");
              source.src = props.src;
              source.type = "video/mp4";
              source.onerror = function (e) {
                console.error(`Error loading video: ${props.src}`, e);
                itemContainer.innerHTML = ""; // Clear existing content (label, video)
                const errorPlaceholder = createErrorPlaceholder(
                  "Ours",
                  sceneIdentifier,
                  rolloutIdx
                );
                itemContainer.appendChild(errorPlaceholder);
              };
              videoElement.appendChild(source);
              itemContainer.appendChild(videoElement);
              gridDiv.appendChild(itemContainer);
            }
            modelScrollArea.appendChild(gridDiv);
          }
        }

        function loadSceneContent(sceneIdx) {
          if (sceneIdx < 0 || sceneIdx >= TOTAL_SCENES) {
            console.error("Invalid scene index:", sceneIdx);
            if (TOTAL_SCENES === 0) {
              sceneIndicator.textContent = "No scenes configured";
              if (initialConditionImageEl)
                initialConditionImageEl.src = `https://placehold.co/256x256/${initialConditionPlaceholderColor}?text=No+Scenes`;
              if (initialConditionImageSecondaryEl)
                initialConditionImageSecondaryEl.src = `https://placehold.co/256x256/${initialConditionPlaceholderColor}?text=No+Scenes`;
              modelScrollArea.innerHTML =
                '<p class="text-center text-gray-400">Please configure scenes in the script.</p>';
            }
            return;
          }
          const currentSceneIdentifier = SCENE_IDENTIFIERS[sceneIdx];

          if (initialConditionImageEl && initialConditionImageSecondaryEl) {
            const basePathForInitial = `./samples/real/${currentSceneIdentifier}`;
            initialConditionImageEl.src = `${basePathForInitial}/initial_frame.jpg`;
            initialConditionImageEl.alt = `Initial Condition Scene ${currentSceneIdentifier} - Frame`;
            initialConditionImageSecondaryEl.src = `${basePathForInitial}/initial_frame_queries.jpg`;
            initialConditionImageSecondaryEl.alt = `Initial Condition Scene ${currentSceneIdentifier} - Frame with Queries`;

            initialConditionImageEl.onerror = function () {
              this.onerror = null;
              this.src = `https://placehold.co/256x256/${initialConditionPlaceholderColor}?text=Error`;
              this.alt = `Error loading Initial Condition Scene ${currentSceneIdentifier} - Frame`;
            };
            initialConditionImageSecondaryEl.onerror = function () {
              this.onerror = null;
              this.src = `https://placehold.co/256x256/${initialConditionPlaceholderColor}?text=Error`;
              this.alt = `Error loading Initial Condition Scene ${currentSceneIdentifier} - Frame with Queries`;
            };
          }
          populateModelScrollArea(currentSceneIdentifier);
        }

        function updateSceneDisplay() {
          if (
            TOTAL_SCENES > 0 &&
            currentSceneIndex >= 0 &&
            currentSceneIndex < TOTAL_SCENES
          ) {
            sceneIndicator.textContent = `Scene ${
              currentSceneIndex + 1
            } / ${TOTAL_SCENES}`;
          } else if (TOTAL_SCENES > 0) {
            sceneIndicator.textContent = `Scene ? / ${TOTAL_SCENES}`;
          } else {
            sceneIndicator.textContent = "Scene 0 / 0";
          }
        }

        function updateButtonStates() {
          if (TOTAL_SCENES === 0) {
            prevSceneBtn.disabled = true;
            nextSceneBtn.disabled = true;
            return;
          }
          prevSceneBtn.disabled = currentSceneIndex === 0;
          nextSceneBtn.disabled = currentSceneIndex === TOTAL_SCENES - 1;
        }

        function goToNextScene() {
          if (currentSceneIndex < TOTAL_SCENES - 1) {
            currentSceneIndex++;
            localStorage.setItem(LS_KEY_SCENE_INDEX, currentSceneIndex);
            loadSceneContent(currentSceneIndex);
            updateSceneDisplay();
            updateButtonStates();
          }
        }

        function goToPrevScene() {
          if (currentSceneIndex > 0) {
            currentSceneIndex--;
            localStorage.setItem(LS_KEY_SCENE_INDEX, currentSceneIndex);
            loadSceneContent(currentSceneIndex);
            updateSceneDisplay();
            updateButtonStates();
          }
        }

        prevSceneBtn.addEventListener("click", goToPrevScene);
        nextSceneBtn.addEventListener("click", goToNextScene);

        if (TOTAL_SCENES > 0) {
          loadSceneContent(currentSceneIndex);
        } else {
          console.warn("No scenes are configured. Update SCENE_IDENTIFIERS.");
          if (initialConditionImageEl)
            initialConditionImageEl.src = `https://placehold.co/256x256/${initialConditionPlaceholderColor}?text=No+Scenes`;
          if (initialConditionImageSecondaryEl)
            initialConditionImageSecondaryEl.src = `https://placehold.co/256x256/${initialConditionPlaceholderColor}?text=No+Scenes`;
          if (modelScrollArea)
            modelScrollArea.innerHTML =
              '<p class="text-center text-gray-400">No scenes configured. Edit script.</p>';
        }
        updateSceneDisplay();
        updateButtonStates();

        document.addEventListener("keydown", (event) => {
          if (
            event.key === "ArrowLeft" &&
            !["INPUT", "TEXTAREA", "BUTTON"].includes(
              document.activeElement.tagName
            )
          ) {
            goToPrevScene();
          } else if (
            event.key === "ArrowRight" &&
            !["INPUT", "TEXTAREA", "BUTTON"].includes(
              document.activeElement.tagName
            )
          ) {
            goToNextScene();
          }
        });
      });
    </script>
  </body>
</html>
