<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8" />
  <title>Project Supplementary Page</title>
  <style>
    body {
      font-family: sans-serif;
      margin: 40px;
      background-color: #f7f7f7;
    }
    h1 {
      text-align: center;
      font-size: 2em;
    }
    section {
      margin-bottom: 60px;
    }
    h2 {
      font-size: 1.5em;
      margin-bottom: 10px;
    }
    .description {
      font-style: italic;
      margin-bottom: 10px;
    }
    .carousel {
      display: flex;
      align-items: center;
      justify-content: center;
    }
    .video-container {
      position: relative;
      width: 640px;
    }
    video {
      width: 100%;
      height: auto;
      border-radius: 8px;
    }
    .caption {
      text-align: center;
      margin-top: 5px;
    }
    .nav-button {
      background: none;
      border: none;
      font-size: 2em;
      cursor: pointer;
      margin: 0 10px;
    }
    .hidden {
      visibility: hidden;
    }

    .counter {
  text-align: center;
  font-size: 0.9em;
  color: #555;
  margin-top: 2px;
}
  </style>
</head>
<body>

<h1>CoDA Supplementary Page</h1>

<section>
  <h2>Object Motion Control</h2>
  <div class="description"></div>
  <div class="carousel">
    <button class="nav-button" id="prev1" onclick="prev(1)" type="button">&larr;</button>
    <div class="video-container">
      <video id="video1" src="video/keyframe/093.mp4" autoplay muted loop controls></video>
      <div class="caption" id="caption1">A person uses the waffleiron.</div>
      <div class="counter" id="counter1">(1 / 1)</div>
    </div>
    <button class="nav-button" id="next1" onclick="next(1)" type="button">&rarr;</button>
  </div>
</section>

<section>
  <h2>Generalization to Different Object Geometry</h2>
  <div class="description"></div>
  <div class="carousel">
    <button class="nav-button" id="prev0" onclick="prev(0)" type="button">&larr;</button>
    <div class="video-container">
      <video id="video0" src="video/cams/000.mp4" autoplay muted loop controls></video>
      <div class="caption" id="caption0"></div>
      <div class="counter" id="counter0">(1 / 3)</div>
    </div>
    <button class="nav-button" id="next0" onclick="next(0)" type="button">&rarr;</button>
  </div>
</section>

<section>
    <h2>Simultaneous Locomotion and Manipulation</h2>
    <div class="description"></div>
    <div class="carousel">
      <button class="nav-button" id="prev2" onclick="prev(2)" type="button">&larr;</button>
      <div class="video-container">
        <video id="video2" src="video/walkobj/posz.mp4" autoplay muted loop controls></video>
        <div class="caption" id="caption2">Walk forward</div>
        <div class="counter" id="counter2">(1 / 4)</div>
      </div>
      <button class="nav-button" id="next2" onclick="next(2)" type="button">&rarr;</button>
    </div>
  </section>

  <section>
    <h2>Text-based Control on the ARCTIC Dataset</h2>
    <div class="description"></div>
    <div class="carousel">
      <button class="nav-button" id="prev3" onclick="prev(3)" type="button">&larr;</button>
      <div class="video-container">
        <video id="video3" src="video/text_control/047.mp4" autoplay muted loop controls></video>
        <div class="caption" id="caption3">A person grabs the microwave.</div>
        <div class="counter" id="counter3">(1 / 2)</div>
      </div>
      <button class="nav-button" id="next3" onclick="next(3)" type="button">&rarr;</button>
    </div>
  </section>

  <section>
    <h2>Text-based Control on the GRAB Dataset</h2>
    <div class="description"></div>
    <div class="carousel">
      <button class="nav-button" id="prev4" onclick="prev(4)" type="button">&larr;</button>
      <div class="video-container">
        <video id="video4" src="video/grab/021.mp4" autoplay muted loop controls></video>
        <div class="caption" id="caption4">A person grabs the laptop.</div>
        <div class="counter" id="counter4">(1 / 2)</div>
      </div>
      <button class="nav-button" id="next4" onclick="next(4)" type="button">&rarr;</button>
    </div>
  </section>

  <section>
    <h2>Diverse Results</h2>
    <div class="description"></div>
    <div class="carousel">
      <button class="nav-button" id="prev9" onclick="prev(9)" type="button">&larr;</button>
      <div class="video-container">
        <video id="video9" src="video/diverse/1.mp4" autoplay muted loop controls></video>
        <div class="caption" id="caption9">A person uses the laptop.</div>
        <div class="counter" id="counter9">(1 / 2)</div>
      </div>
      <button class="nav-button" id="next9" onclick="next(9)" type="button">&rarr;</button>
    </div>
  </section>

  <section>
    <h2>Deployment on Simulated Humanoids</h2>
    <div class="description"></div>
    <div class="carousel">
      <button class="nav-button" id="prev5" onclick="prev(5)" type="button">&larr;</button>
      <div class="video-container">
        <video id="video5" src="video/phys.mp4" autoplay muted loop controls></video>
        <div class="caption" id="caption5"></div>
        <div class="counter" id="counter5">(1 / 1)</div>
      </div>
      <button class="nav-button" id="next5" onclick="next(5)" type="button">&rarr;</button>
    </div>
  </section>

  <section>
    <h2>Generating Whole-body Motion from Hand-only Dataset</h2>
    <div class="description"></div>
    <div class="carousel">
      <button class="nav-button" id="prev6" onclick="prev(6)" type="button">&larr;</button>
      <div class="video-container">
        <video id="video6" src="video/hot3d.mp4" autoplay muted loop controls></video>
        <div class="caption" id="caption6"></div>
        <div class="counter" id="counter6">(1 / 1)</div>
      </div>
      <button class="nav-button" id="next6" onclick="next(6)" type="button">&rarr;</button>
    </div>
  </section>

  <section>
    <h2>More Results on the ARCTIC Dataset</h2>
    <div class="description"></div>
    <div class="carousel">
      <button class="nav-button" id="prev7" onclick="prev(7)" type="button">&larr;</button>
      <div class="video-container">
        <video id="video7" src="video/ours/3.mp4" autoplay muted loop controls></video>
        <div class="caption" id="caption7"></div>
        <div class="counter" id="counter7">(1 / 18)</div>
      </div>
      <button class="nav-button" id="next7" onclick="next(7)" type="button">&rarr;</button>
    </div>
  </section>

  <section>
    <h2>More Results on the GRAB Dataset</h2>
    <div class="description"></div>
    <div class="carousel">
      <button class="nav-button" id="prev8" onclick="prev(8)" type="button">&larr;</button>
      <div class="video-container">
        <video id="video8" src="video/grab/34.mp4" autoplay muted loop controls></video>
        <div class="caption" id="caption8"></div>
        <div class="counter" id="counter8">(1 / 8)</div>
      </div>
      <button class="nav-button" id="next8" onclick="next(8)" type="button">&rarr;</button>
    </div>
  </section>

<script>
  const videos = [
    {
      sources: ["video/cams/000.mp4", "video/cams/005.mp4", "video/cams/016.mp4"],
      captions: ["", "", ""],
      index: 0
    },
    {
      sources: ["video/keyframe/093.mp4"],
      captions: [""],
      index: 0
    },
    {
      sources: ["video/walkobj/posz.mp4", "video/walkobj/negz.mp4", "video/walkobj/posx.mp4", "video/walkobj/negx.mp4"],
      captions: ["Walk forward", "Walk backward", "Walk left", "Walk right"],
      index: 0
    },
    {
      sources: ["video/text_control/047.mp4", "video/text_control/099.mp4"],
      captions: ["A person grabs the microwave.", "A person uses the microwave."],
      index: 0
    },
    {
      sources: ["video/grab/021.mp4", "video/grab/024.mp4"],
      captions: ["The person passes the camera.", "The person takes picture with the camera."],
      index: 0
    },
    {
      sources: ["video/phys.mp4"],
      captions: [""],
      index: 0
    },
    {
      sources: ["video/hot3d.mp4"],
      captions: [""],
      index: 0
    },
    {
      sources: ["video/ours/032.mp4", "video/ours/003.mp4", 
      "video/ours/096.mp4", "video/ours/084.mp4", 
      "video/ours/075.mp4", "video/ours/058.mp4", 
      "video/ours/007.mp4", "video/ours/102.mp4", 
      "video/ours/062.mp4", "video/ours/116.mp4", 
      "video/ours/027.mp4", "video/ours/108.mp4",
      "video/ours/112.mp4", 
      "video/ours/061.mp4", "video/ours/070.mp4", 
      "video/ours/024.mp4", 
      "video/ours/122.mp4",],
      captions: ["A person uses the waffleiron.", "A person uses the notebook.",
        "A person uses the laptop.", "A person grabs the mixer.",
        "A person uses the espressomachine.", "A person grabs the espressomachine.",
        "A person grabs the phone.", "A person uses the box.",
        "A person grabs the notebook.", "A person uses the microwave.",
        "A person uses the phone.", "A person uses the scissors.",
        "A person uses the capsulemachine.", 
        "A person grabs the laptop.", "A person grabs the waffleiron.",
        "A person uses the mixer.", 
        "A person uses the ketchup.",
      ],
      index: 0
    },
    {
      sources: ["video/grab/034.mp4", "video/grab/050.mp4", 
      "video/grab/061.mp4", "video/grab/070.mp4",
      "video/grab/143.mp4", "video/grab/026.mp4",
    "video/grab/135.mp4", "video/grab/118.mp4",
    ],
      captions: ["The person lifts the cup.", "The person inspects the elephant.",
        "The person plays the gamecontroller.", "The person shakes the hand.",
        "The person passes the wineglass.", "The person lifts the cubelarge.",
        "The person plays the train", "The person pours from the teapot.",
      ],
      index: 0
    },
    {
      sources: ["video/diverse/1.mp4", "video/diverse/2.mp4"],
      captions: ["A person uses the laptop.", "A person uses the laptop."],
      index: 0
    }
  ];

  function update(sectionId) {
  const vid = document.getElementById("video" + sectionId);
  const cap = document.getElementById("caption" + sectionId);
  const counter = document.getElementById("counter" + sectionId);
  const data = videos[sectionId];

  const newSrc = data.sources[data.index];
  if (vid.getAttribute("src") !== newSrc) {
    vid.setAttribute("src", newSrc);
    vid.load();
    vid.play();
  }

  cap.textContent = data.captions[data.index];
  counter.textContent = `(${data.index + 1} / ${data.sources.length})`;

  const prevBtn = document.getElementById("prev" + sectionId);
  const nextBtn = document.getElementById("next" + sectionId);
  const showNav = data.sources.length > 1;
  prevBtn.style.visibility = showNav ? "visible" : "hidden";
  nextBtn.style.visibility = showNav ? "visible" : "hidden";
}

  function prev(sectionId) {
    const data = videos[sectionId];
    if (data.index > 0) {
      data.index--;
      update(sectionId);
    }
  }

  function next(sectionId) {
    const data = videos[sectionId];
    if (data.index < data.sources.length - 1) {
      data.index++;
      update(sectionId);
    }
  }

  // Initialize all sections
  videos.forEach((_, i) => update(i));
</script>

</body>
</html>