Don't show supervised user as "already on this device" while they're being imported.
[chromium-blink-merge.git] / native_client_sdk / src / resources / index.js
blob6c0c1cf39670a663526c88c92915bef2d2059677
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 var iframeUpdateIntervalID;
6 var queryParams = '';
8 function selectConfig(el) {
9   deselectAllItems('.config-item');
10   selectItem(el);
11   updateIframe();
14 function selectExample(el) {
15   deselectAllItems('.nav-item');
16   selectItem(el);
17   updateIframe();
20 function updateIframe() {
21   var exampleEl = document.querySelector('.nav-item.selected');
22   var configEl = document.querySelector('.config-item.selected');
23   var url = exampleEl.dataset.href + '?config=' + configEl.textContent;
24   setIframeSrc(url);
27 function selectItem(el) {
28   el.classList.add('selected');
31 function deselectAllItems(selector) {
32   var navItemEls = document.querySelectorAll(selector);
33   for (var i = 0; i < navItemEls.length; ++i) {
34     navItemEls[i].classList.remove('selected');
35   }
38 function setIframeSrc(src) {
39   var iframeEl = document.querySelector('iframe');
41   window.clearInterval(iframeUpdateIntervalID);
42   iframeEl.style.height = '';
43   iframeEl.src = src;
46 document.addEventListener('DOMContentLoaded', function () {
47   var iframeEl = document.querySelector('iframe');
48   var iframeWrapperEl = document.querySelector('.iframe-wrapper');
50   var configItemEls = document.querySelectorAll('.config-item');
51   for (var i = 0; i < configItemEls.length; ++i) {
52     configItemEls[i].addEventListener('click', function (e) {
53       selectConfig(this);
54     });
55   }
57   var navItemEls = document.querySelectorAll('.nav-item');
58   for (var i = 0; i < navItemEls.length; ++i) {
59     navItemEls[i].addEventListener('click', function (e) {
60       selectExample(this);
61     });
62   }
64   iframeEl.addEventListener('load', function () {
65     var iframeDocument = this.contentWindow.document;
66     var iframeBodyEl = iframeDocument.body;
67     iframeEl.style.height = iframeBodyEl.scrollHeight + 'px';
69     // HACK: polling the body height to update the iframe. There's got to be a
70     // better way to do this...
71     var prevBodyHeight;
72     var prevWrapperHeight;
73     iframeUpdateIntervalID = window.setInterval(function () {
74       var bodyHeight = iframeBodyEl.getBoundingClientRect().height;
75       var wrapperHeight = iframeWrapperEl.clientHeight;
76       if (bodyHeight != prevBodyHeight || wrapperHeight != prevWrapperHeight) {
77         // HACK: magic 4... without it, the scrollbar is always visible. :(
78         var newHeight = Math.max(wrapperHeight - 4, bodyHeight);
79         iframeEl.style.height = newHeight + 'px';
80         prevBodyHeight = bodyHeight;
81         prevWrapperHeight = wrapperHeight;
82       }
83     }, 100);  // .1s
84   }, false);
86   var closeButtonEl = document.querySelector('.close-button');
87   closeButtonEl.addEventListener('click', function () {
88     window.close();
89   });
91   // select the first example.
92   selectExample(document.querySelector('.nav-item'));
93 });