forked from robotframework/BeginnersGuide
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnotebook-support.js
112 lines (104 loc) · 7.49 KB
/
notebook-support.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
var getNotebookBaseUrl = function() {
try { return document.cookie.split("notebook=")[1].split(";")[0]; }
catch(e) { return null; }
};
var setNotebookBaseUrl = function(url) {
url = url.split("/notebooks/")[0];
if (!url.match(/\/tree$/)) { url += "/tree"; }
document.cookie = "notebook=" + url + ";max-age=30";
if (typeof console !== "undefined" && console.log) {
console.log("Hearbeat from " + url);
}
return url;
};
var createIframe = function(url, callback) {
var iframe = document.createElement("iframe");
iframe.setAttribute("width", "100%");
iframe.setAttribute("frameBorder", "0");
iframe.setAttribute("src", url);
iframe.setAttribute("style", "display: none;");
iFrameResize({
checkOrigin: false,
log: false,
messageCallback: function(message) {
setNotebookBaseUrl(message.message.window.location.href);
if (callback) {
callback();
callback = null;
iframe.removeAttribute("style");
}
}
}, iframe);
return iframe;
};
var createButton = function(url) {
var button = document.createElement("button");
button.innerHTML = "Try this example in browser";
button.addEventListener("click", function() {
var throbber = document.createElement("img");
var span = document.createElement("span");
span.innerHTML = " "
throbber.setAttribute("height", "18");
throbber.setAttribute("width", "18");
throbber.setAttribute("style", "margin-bottom: -5px;");
throbber.setAttribute("src", THROBBER_GIF);
button.parentElement.appendChild(span);
button.parentElement.appendChild(throbber)
button.parentElement.appendChild(createIframe(url, function() {
button.parentElement.removeChild(throbber)
button.parentElement.removeChild(span);
button.parentElement.removeChild(button);
}));
button.setAttribute("disabled", "disabled");
document.cookie = "notebook=" + url + ";max-age=0";
});
return button;
};
var initNotebookBaseUrl = function(callback) {
var iframe = document.createElement("iframe");
iframe.setAttribute("frameBorder", "nb-init");
iframe.setAttribute("frameBorder", "0");
iframe.setAttribute("height", "0");
iframe.setAttribute("width", "0");
iframe.setAttribute("src",
"https://mybinder.org/v2/gh/robots-from-jupyter/BeginnersGuide/add-binder"
);
iFrameResize({
checkOrigin: false,
log: false,
messageCallback: function(message) {
if (callback !== null) {
callback(setNotebookBaseUrl(message.message.window.location.href));
callback = null;
} else {
setNotebookBaseUrl(message.message.window.location.href);
}
}
}, iframe);
document.body.appendChild(iframe);
};
var embedNotebooks = function(baseUrl) {
var elements = document.getElementsByTagName("div"), i;
for (i = 0; i < elements.length; i++) {
if(elements[i].getAttribute("data-notebook")) {
elements[i].appendChild(
createButton(
baseUrl + "/" + elements[i].getAttribute("data-notebook")
)
);
}
}
};
var init = function() {
if (typeof iFrameResize === "undefined") {
return setTimeout(init, 1000);
} else {
if (getNotebookBaseUrl()) {
embedNotebooks(getNotebookBaseUrl());
} else {
initNotebookBaseUrl(embedNotebooks);
}
}
};
init();
var THROBBER_GIF = "";