forked from espruino/EspruinoWebIDE
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathembed.js
105 lines (102 loc) · 3.87 KB
/
embed.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
/* Point EspruinoIDE at an iframe with src="https://espruino.com/ide"
to allow that iframe to have transmit/receive access via the returned
structure.
Use for (for example) serving up the IDE directly from an Espruino board.
*/
function EspruinoIDE(ideframe) {
function post(msg) {
msg.for="ide";
ideframe.contentWindow.postMessage(msg,"*");
}
window.addEventListener('message', function(e) {
var event = e.data;
if (typeof event!="object" || event.from!="ide") return;
//console.log("HOST MESSAGE ---------------------------------------");
//console.log(event);
//console.log("-----------------------------------------------");
switch (event.type) {
case "init":
console.log("IDE frame initialised");
if (Espruino.onready)
Espruino.onready();
post({type:"initialised"});
break;
case "getPorts": // get port data
if (Espruino.onportscb) {
Espruino.onportscb(function(ports) {
post({type:"ports", data: ports});
});
} else
post({type:"ports", data: Espruino.onports?Espruino.onports():[]});
break;
case "connect": // request to connect
if (Espruino.onconnect) {
Espruino.onconnect(/*path*/event.data, function() {
post({type:"connected"})
});
} else {
post({type:"connected"}); // let's just say we were connected immediately
}
break;
case "disconnect": // request to disconnect
post({type:"disconnected"}); // let's just say we were disconnected immediately
if (Espruino.ondisconnect)
Espruino.ondisconnect();
break;
case "write": // data to write
if (typeof event.data!="string") throw new Error("write event should have been given a string");
if (Espruino.onwritecb) {
Espruino.onwritecb(event.data, function() {
post({type:"written"});
});
} else {
if (Espruino.onwrite)
Espruino.onwrite(event.data);
// post that we've written, but after a delay
setTimeout(function() {
post({type:"written"});
}, 100);
}
break;
default:
console.error("Unknown event type ",event.type);
break;
}
});
var Espruino = {
// tell the IDE to connect to the given port
connect : function(port) {
post({type:"connect",data:port});
},
// tell the IDE it's disconnected
disconnect : function() {
post({type:"disconnected"});
},
// Data received from device - d should be a string
received : function(d) {
if (typeof d!="string") throw new Error("Espruino.received should be given a string");
post({type:"receive",data:d});
},
// Set the maximum number of bytes that 'onwrite/onwritecb' should be called with
setMaxWriteLength : function(l) {
if (typeof l!="number") throw new Error("Espruino.received should be given a number");
post({type:"setMaxWriteLength",data:l});
},
// ------------------ all the below are optional
// called when the IDE is ready
onready : undefined,
// called with (path, callback) when IDE requests a connection. Should call callback when connected
onconnect : undefined,
// should return a list of available ports. Use this or `onportscb`
onports : undefined,
// called with (callback) - return a list of available ports via callback. Use this or `onports`
onportscb : undefined,
// called with (data) when data should be written to the device. Use this or `onwritecb`
onwrite : undefined,
// called with (data,callback) when data should be written to the device. callback should be called when data has been written. Use this or `onwrite`
onwritecb : undefined,
// called when the user requests a disconnect
ondisconnect : undefined,
};
return Espruino;
}