<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="utf-8" />
  <title>Video.js Sandbox</title>
  <link href="../dist/video-js.css" rel="stylesheet" type="text/css">
  <script src="../dist/video.js"></script>
  <link rel="icon" href="data:;base64,=">
</head>
<body>
  <div style="background-color:#eee; border: 1px solid #777; padding: 10px; margin-bottom: 20px; font-size: .8em; line-height: 1.5em; font-family: Verdana, sans-serif;">
    <p>You can use /sandbox/ for writing and testing your own code. Nothing in /sandbox/ will get checked into the repo, except files that end in .example (so don't edit or add those files). To get started run `npm start` and open the index.html</p>
    <pre>npm start</pre>
    <pre>open http://localhost:9999/sandbox/index.html</pre>
  </div>

  <p>Tap on video to play/pause</p>

  <test-custom-element id="customElement1"></test-custom-element>

  <script>
    // Custom Element definition
    class TestCustomElement extends HTMLElement {

      constructor() {
        super();

        const shadowRoot = this.attachShadow({ mode: 'closed' });

        const styleLinkElem = document.createElement('link');

        styleLinkElem.setAttribute('rel', 'stylesheet');
        styleLinkElem.setAttribute('href', '../dist/video-js.css')
        shadowRoot.append(styleLinkElem);

        const containerElem = document.createElement('div');

        containerElem.setAttribute('data-vjs-player', '');
        shadowRoot.appendChild(containerElem);

        const videoElem = document.createElement('video');

        videoElem.setAttribute('preload', 'auto');
        videoElem.setAttribute('width', 640);
        videoElem.setAttribute('height', 260);
        containerElem.appendChild(videoElem);

        const sourceElem = document.createElement('source');

        sourceElem.setAttribute('src', 'https://vjs.zencdn.net/v/oceans.mp4');
        sourceElem.setAttribute('type', 'video/mp4');
        videoElem.appendChild(sourceElem);

        this.innerPlayer = videojs(videoElem);

        containerElem.addEventListener('click', () => {
          if (this.innerPlayer.paused()) {
            this.innerPlayer.play();
          }
          else {
            this.innerPlayer.pause();
          }
        });
      }
    }

    window.customElements.define('test-custom-element', TestCustomElement);

    // Main entry point

    document.addEventListener('DOMContentLoaded', () => {
      var customElem = document.getElementById('customElement1');
      var innerPlayer = customElem.innerPlayer;
      innerPlayer.log('Shadow DOM inner player created', innerPlayer);
    });
  </script>

</body>
</html>