<link href="//netdna.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap.min.css" rel="stylesheet" id="bootstrap-css">
<script src="//netdna.bootstrapcdn.com/bootstrap/3.0.0/js/bootstrap.min.js"></script>
<script src="//code.jquery.com/jquery-1.11.1.min.js"></script>
<!------ Include the above in your HEAD tag ---------->
<!DOCTYPE html><html class=''>
<head><script src='//production-assets.codepen.io/assets/editor/live/console_runner-079c09a0e3b9ff743e39ee2d5637b9216b3545af0de366d4b9aad9dc87e26bfd.js'></script><script src='//production-assets.codepen.io/assets/editor/live/events_runner-73716630c22bbc8cff4bd0f07b135f00a0bdc5d14629260c3ec49e5606f98fdd.js'></script><script src='//production-assets.codepen.io/assets/editor/live/css_live_reload_init-2c0dc5167d60a5af3ee189d570b1835129687ea2a61bee3513dee3a50c115a77.js'></script><meta charset='UTF-8'><meta name="robots" content="noindex"><link rel="shortcut icon" type="image/x-icon" href="//production-assets.codepen.io/assets/favicon/favicon-8ea04875e70c4b0bb41da869e81236e54394d63638a1ef12fa558a4a835f1164.ico" /><link rel="mask-icon" type="" href="//production-assets.codepen.io/assets/favicon/logo-pin-f2d2b6d2c61838f7e76325261b7195c27224080bc099486ddd6dccb469b8e8e6.svg" color="#111" /><link rel="canonical" href="https://codepen.io/jsphstls/pen/aOOqzg?depth=everything&order=popularity&page=6&q=iframe&show_forks=false" />
<style class="cp-pen-styles">html {
  padding-top: 30px;
  background: #000;
}
body {
  width: 700px;
  margin: 0 auto;
}
button {
  text-transform: uppercase;
letter-spacing: 1px;
color: #fff;
background: #cc181e;
border: 0;
  border-radius: 2px;
padding: 1em 2em;
  cursor: pointer;
}
button:hover {
  background: #A52A2A;
}
#ypt_wrapper {
  width: 100%;
  background: #000;
  color: #fff;
  overflow: hidden;
  max-width: 100%;
   box-shadow: 0px 8px 13px rgba(0,0,0,0.5);
  margin-bottom: 1em;
}
#ypt_thumbs {
  overflow-y: scroll;
  overflow-x: hidden;
  width: 20%;
  background: #000;
  margin: 0;
  padding: 0;
  height: 0;
}
#ypt_thumbs li {
  list-style: none;
  margin: 0;
  position: relative;
  font-size: 0;
}
#ypt_thumbs li img{
  width: 100%;
}
#ypt_thumbs li p {
  font-family: arial;
  font-size: 10px;
  background: rgba(0, 0, 0, 0.7);
  display: none;
  position: absolute;
  width: 100%;
  height: 100%;
  color: #fff;
  padding: 5%;
  margin: 0;
}
#ypt_thumbs li:hover p {
  display: block;
  cursor: pointer;
}
#ypt_thumbs .ypt-now-playing p {
  display: block;
}
#ypt_thumbs .ypt-now-playing > span::after {
  content: "\25b6  Now playing"; /* A traingle pointing right */
  margin-top: -1em;
  display: block;
  width: 100%;
  padding: 5%;
  background: rgba(0, 0, 0, 0.6);
  color: #fff;
  position: absolute;
  bottom: 0;
  font-size: 10px;
}
#ypt_wrapper .video {
  position: relative;
  width: 80%;
  /*height: 0;*/
  padding-bottom: 48.4%;
  float: left;
}
#ypt_wrapper .video iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  float:left;
}
@media only screen and (max-width : 400px) {
  #ypt_thumbs {
    display: none;
  }
  #ypt_wrapper .video {
    width: 100%;
    padding-bottom: 56.25%;
  }
}</style></head><body>
<div id="ypt_wrapper">
     <div class="video">
      <div id="player" data-pl="PLb0IAmt7-GS0M8Q95RIc2lOM6nc77q1IY"></div>
    </div>
    <ul id="ypt_thumbs"></ul>
</div>
  
  <button data-ypt-index="1">Play the 2nd video</button>
<script src='//production-assets.codepen.io/assets/common/stopExecutionOnTimeout-b2a7b3fe212eaa732349046d8416e00a9dec26eb7fd347590fbced3ab38af52e.js'></script><script src='//cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js'></script>
<script >// Load Youtube IFrame Player API code asynchronously. This boat is going nowhere without it.
var tag = document.createElement('script'); //Add a script tag
tag.src = "https://www.youtube.com/iframe_api"; //Set the SRC to get the API
var firstScriptTag = document.getElementsByTagName('script')[0]; //Find the first script tag in the html
firstScriptTag.parentNode.insertBefore(tag, firstScriptTag); //Put this script tag before the first one
var player; //The Youtube API player
var ypt_player = document.getElementById('player');
var playlistID = ypt_player.getAttribute('data-pl');
var ypt_thumbs = document.getElementById('ypt_thumbs');
var nowPlaying = "ypt-now-playing"; //For marking the current thumb
var nowPlayingClass = "." + nowPlaying;
var ypt_index = 0; //Playlists begin at the first video by default
function getPlaylistData(playlistID, video_list, page_token) { //Makes a single request to Youtube Data API
  var apiKey = 'AIzaSyArQNfmJDkjxP_ZyZIocbyuDeyTanf4Rl8';
  var theUrl =
  'https://www.googleapis.com/youtube/v3/playlistItems?part=snippet' +
  '&maxResults='+ 50 + //Can be anything from 1-50
  '&playlistId=' + playlistID +
  '&key=' + apiKey
  ;
  if(page_token){ theUrl +=('&pageToken=' + page_token );} //If there is page token, start there
  var xmlHttp = null;
  xmlHttp = new XMLHttpRequest();
  xmlHttp.open( "GET", theUrl, true);
  xmlHttp.send( null );
  xmlHttp.onload = function (e) { //when the request comes back
    buildJSON(xmlHttp.responseText, video_list, playlistID); //send the data to buildJSON
  };
}
function buildJSON(response, list, playlistID){ //Takes the text response and adds it to any existing JSON data
  var results = JSON.parse(response); //Parse it
  if(!list){ list = []; } //If there is no list to add to, make one
  list.push.apply(list,results.items); //Add JSON data to the list
  if(results.nextPageToken){ //If the results included a page token
    getPlaylistData(playlistID, list, results.nextPageToken); //Create another data API request including the current list and page token
  } else { //If there is not a next-page token
    buildHTML(list); //Send the JSON data to buildHTML
  }
}
function buildHTML(data){ //Turns JSON data into HTML elements
  var list_data = ''; //A string container
  for(i = 0; i < data.length; i++){if (window.CP.shouldStopExecution(1)){break;} //Do this to each item in the JSON list
    var item = data[i].snippet; //Each Youtube playlist item snippet
    if(!item.thumbnails){continue;} //private videos do no reveal thumbs, so skip them
    list_data += '<li data-ypt-index="'+ i +'"><p>' + item.title + '</p><span><img alt="'+ item.title +'" src="'+ item.thumbnails.medium.url +'"/></span></li>'; //create an element and add it to the list
  }
window.CP.exitedLoop(1);
  ypt_thumbs.innerHTML = list_data; //After the for loop, insert that list of links into the html
}
function yptThumbHeight(){
  ypt_thumbs.style.height = document.getElementById('player').clientHeight + 'px'; //change the height of the thumb list
  //breaks if ypt_player.clientHeight + 'px';
}
function onPlayerReady(event) { //Once the player is ready...
  yptThumbHeight(); //Set the thumb containter height
}
getPlaylistData(playlistID);
//Once the Youtube Iframe API is ready...
window.onYouTubeIframeAPIReady = function() { // Creates an <iframe> (and YouTube player) after the API code downloads. must be globally available
  player = new YT.Player('player', {
    height: '360',
    width: '640',
    playerVars:
    {
      listType:'playlist',
      list: playlistID
    },
    events: {
      'onReady': onPlayerReady,
      'onStateChange': onPlayerStateChange
    }
  });
  // When the player does something...
  function onPlayerStateChange(event) {
    //Let's check on what video is playing
    var currentIndex = player.getPlaylistIndex();
    var the_thumbs = ypt_thumbs.getElementsByTagName('li');
    var currentThumb = the_thumbs[currentIndex];
    if (event.data == YT.PlayerState.PLAYING) { //A video is playing
      for (var i = 0; i < the_thumbs.length; i++) {if (window.CP.shouldStopExecution(2)){break;} //Loop through the thumbs
        the_thumbs[i].className = ""; //Remove nowplaying from each thumb
      }
window.CP.exitedLoop(2);
      currentThumb.className = nowPlaying; //this will also erase any other class belonging to the li
      //need to do a match looking for now playing
    }
    //if a video has finished, and the current index is the last video, and that thumb already has the nowplaying class
    if (event.data == YT.PlayerState.ENDED && currentIndex == the_thumbs.length - 1 && the_thumbs[currentIndex].className == nowPlaying){
      jQuery.event.trigger('playlistEnd'); //Trigger a global event
    }
  } //function onPlayerStateChange(event)
  //When the user changes the window size...
  window.addEventListener('resize', function(event){
    yptThumbHeight(); //change the height of the thumblist
  });
  //When the user clicks an element with a playlist index...
  jQuery(document).on('click','[data-ypt-index]:not(".ypt-now-playing")',function(e){ //click on a thumb that is not currently playing
    ypt_index = Number(jQuery(this).attr('data-ypt-index')); //Get the ypt_index of the clicked item
    if(navigator.userAgent.match(/(iPad|iPhone|iPod)/g)){ //if IOS
      player.cuePlaylist({ //cue is required for IOS 7
        listType: 'playlist',
        list: playlistID,
        index: ypt_index,
        suggestedQuality: 'hd720' //quality is required for cue to work, for now
        // https://code.google.com/p/gdata-issues/issues/detail?id=5411
      }); //player.cuePlaylist
    } else { //yay it's not IOS!
    player.playVideoAt(ypt_index); //Play the new video, does not work for IOS 7
  }
  jQuery(nowPlayingClass).removeClass(nowPlaying); //Remove "now playing" from the thumb that is no longer playing
  //When the new video starts playing, its thumb will get the now playing class
}); //jQuery(document).on('click','#ypt_thumbs...
};
//# sourceURL=pen.js
</script>
</body></html>