2021-02-13 17:42:48 +01:00
|
|
|
var state = {client: null,
|
|
|
|
closure: null,
|
|
|
|
connected: false,
|
|
|
|
};
|
|
|
|
|
|
|
|
function callNewGame() {
|
2021-02-16 15:14:39 +01:00
|
|
|
Module.ccall('newgame', null, ['number'], [state.closure]);
|
2021-02-13 17:42:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
function callButton(obj) {
|
|
|
|
Module.ccall('button', null, ['number', 'string'], [state.closure, obj.id]);
|
|
|
|
}
|
|
|
|
|
|
|
|
function onHaveDevID(closure, devid) {
|
2021-02-13 21:02:26 +01:00
|
|
|
// Set a unique tag so we know if somebody comes along later
|
|
|
|
let tabID = Math.random();
|
|
|
|
localStorage.setItem('tabID', tabID);
|
|
|
|
window.addEventListener('storage', function () {
|
|
|
|
newTabID = localStorage.getItem('tabID');
|
|
|
|
if ( newTabID != tabID ) {
|
|
|
|
state.client.disconnect();
|
|
|
|
Module.ccall('button', null, ['number', 'string'], [state.closure, 'exit']);
|
|
|
|
}
|
|
|
|
} );
|
|
|
|
|
2021-02-13 17:42:48 +01:00
|
|
|
state.closure = closure;
|
|
|
|
document.getElementById("mqtt_span").textContent=devid;
|
|
|
|
|
2021-02-15 23:59:44 +01:00
|
|
|
function tellConnected(isConn) {
|
|
|
|
Module.ccall('MQTTConnectedChanged', null, ['number', 'boolean'], [state.closure, isConn]);
|
|
|
|
}
|
|
|
|
|
2021-02-13 17:42:48 +01:00
|
|
|
state.client = new Paho.MQTT.Client("eehouse.org", 8883, '/wss', devid);
|
|
|
|
|
|
|
|
// set callback handlers
|
|
|
|
state.client.onConnectionLost = function onConnectionLost(responseObject) {
|
|
|
|
state.connected = false;
|
|
|
|
document.getElementById("mqtt_status").textContent="Disconnected";
|
2021-02-15 23:59:44 +01:00
|
|
|
tellConnected(false);
|
2021-02-13 17:42:48 +01:00
|
|
|
if (responseObject.errorCode !== 0) {
|
|
|
|
console.log("onConnectionLost:"+responseObject.errorMessage);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
state.client.onMessageArrived = function onMessageArrived(message) {
|
|
|
|
var payload = message.payloadBytes;
|
|
|
|
var length = payload.length;
|
|
|
|
Module.ccall('gotMQTTMsg', null, ['number', 'number', 'array'],
|
|
|
|
[state.closure, length, payload]);
|
|
|
|
};
|
|
|
|
|
|
|
|
function onConnect() {
|
|
|
|
state.connected = true
|
|
|
|
document.getElementById("mqtt_status").textContent="Connected";
|
2021-02-15 23:59:44 +01:00
|
|
|
tellConnected(true);
|
2021-02-13 17:42:48 +01:00
|
|
|
|
|
|
|
var subscribeOptions = {
|
|
|
|
qos: 2, // QoS
|
|
|
|
// invocationContext: {foo: true}, // Passed to success / failure callback
|
|
|
|
// onSuccess: function() { alert('subscribe succeeded'); },
|
|
|
|
onFailure: function() { alert('subscribe failed'); },
|
|
|
|
timeout: 10,
|
|
|
|
};
|
|
|
|
state.client.subscribe('xw4/device/' + devid, subscribeOptions);
|
|
|
|
}
|
|
|
|
|
|
|
|
state.client.connect({mqttVersion: 3,
|
|
|
|
userName: "xwuser",
|
|
|
|
password: "xw4r0cks",
|
|
|
|
useSSL: true,
|
|
|
|
reconnect: true,
|
|
|
|
onSuccess: onConnect,
|
|
|
|
onFailure: function() { alert('onFailure'); },
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
function mqttSend( topic, ptr ) {
|
|
|
|
let canSend = null != state.client && state.connected;
|
|
|
|
if ( canSend ) {
|
|
|
|
message = new Paho.MQTT.Message(ptr);
|
|
|
|
message.destinationName = topic;
|
|
|
|
message.qos = 2;
|
|
|
|
state.client.send(message);
|
|
|
|
} else {
|
|
|
|
console.log('mqttSend: not connected');
|
|
|
|
}
|
|
|
|
return canSend;
|
|
|
|
}
|
|
|
|
|
2021-02-16 23:25:22 +01:00
|
|
|
function newDlgWMsg(msg) {
|
2021-02-16 22:25:21 +01:00
|
|
|
let container = document.getElementById('nbalert');
|
|
|
|
|
|
|
|
let dlg = document.createElement('div');
|
|
|
|
dlg.classList.add('nbalert');
|
2021-02-16 23:25:22 +01:00
|
|
|
dlg.style.zIndex = 10000 + container.childElementCount;
|
2021-02-16 22:25:21 +01:00
|
|
|
container.appendChild( dlg );
|
2021-02-13 19:37:47 +01:00
|
|
|
|
|
|
|
let txtDiv = document.createElement('div');
|
2021-02-16 22:25:21 +01:00
|
|
|
txtDiv.textContent = msg
|
2021-02-16 23:25:22 +01:00
|
|
|
dlg.appendChild( txtDiv );
|
|
|
|
|
|
|
|
return dlg;
|
|
|
|
}
|
|
|
|
|
2021-02-17 01:03:24 +01:00
|
|
|
function newButtonDiv(buttons, proc) {
|
|
|
|
let div = document.createElement('div');
|
|
|
|
div.classList.add('buttonRow');
|
2021-02-13 19:37:47 +01:00
|
|
|
for ( let buttonTxt of buttons ) {
|
|
|
|
let button = document.createElement('button');
|
|
|
|
button.textContent = buttonTxt;
|
2021-02-17 01:03:24 +01:00
|
|
|
button.onclick = function() { proc(buttonTxt); };
|
|
|
|
div.appendChild( button );
|
2021-02-13 19:37:47 +01:00
|
|
|
}
|
2021-02-17 01:03:24 +01:00
|
|
|
|
|
|
|
return div;
|
|
|
|
}
|
|
|
|
|
|
|
|
function nbDialog(msg, buttons, proc, closure) {
|
|
|
|
let dlg = newDlgWMsg( msg );
|
|
|
|
|
|
|
|
butProc = function(buttonTxt) {
|
|
|
|
Module.ccall('onDlgButton', null, ['number', 'number', 'string'],
|
|
|
|
[proc, closure, buttonTxt]);
|
|
|
|
dlg.parentNode.removeChild(dlg);
|
|
|
|
}
|
|
|
|
dlg.appendChild( newButtonDiv( buttons, butProc ) );
|
2021-02-13 19:37:47 +01:00
|
|
|
}
|
|
|
|
|
2021-02-18 03:58:46 +01:00
|
|
|
function nbBlankPick(title, buttons, proc, closure) {
|
|
|
|
let dlg = newDlgWMsg( title );
|
|
|
|
|
|
|
|
butProc = function(buttonTxt) {
|
|
|
|
Module.ccall('onDlgButton', null, ['number', 'number', 'string'],
|
|
|
|
[proc, closure, buttonTxt]);
|
|
|
|
dlg.parentNode.removeChild(dlg);
|
|
|
|
}
|
|
|
|
|
|
|
|
let ROWLEN = 6;
|
|
|
|
for (ii = 0; ii < buttons.length; ii += ROWLEN) {
|
|
|
|
dlg.appendChild( newButtonDiv( buttons.slice(ii, ii + ROWLEN), butProc ) );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-02-19 20:19:16 +01:00
|
|
|
function nbGamePick(title, gameMap, proc, closure) {
|
|
|
|
let dlg = newDlgWMsg( title );
|
|
|
|
|
|
|
|
buttons = [];
|
|
|
|
revMap = {}
|
|
|
|
Object.keys(gameMap).forEach( function(key) {
|
|
|
|
let val = gameMap[key]
|
|
|
|
buttons.push(val);
|
|
|
|
revMap[val] = key;
|
|
|
|
});
|
|
|
|
|
|
|
|
butProc = function(buttonTxt) {
|
|
|
|
Module.ccall('onDlgButton', null, ['number', 'number', 'string'],
|
|
|
|
[proc, closure, revMap[buttonTxt]]);
|
|
|
|
dlg.parentNode.removeChild(dlg);
|
|
|
|
}
|
|
|
|
|
|
|
|
dlg.appendChild( newButtonDiv( buttons, butProc ) );
|
|
|
|
}
|
|
|
|
|
2021-02-19 04:20:20 +01:00
|
|
|
function setDivButtons(divid, buttons, proc, closure) {
|
|
|
|
let parent = document.getElementById(divid);
|
|
|
|
while ( parent.lastElementChild ) {
|
|
|
|
parent.removeChild(parent.lastElementChild);
|
|
|
|
}
|
|
|
|
|
|
|
|
butProc = function(buttonTxt) {
|
|
|
|
Module.ccall('onDlgButton', null, ['number', 'number', 'string'],
|
|
|
|
[proc, closure, buttonTxt]);
|
|
|
|
}
|
|
|
|
|
|
|
|
parent.appendChild( newButtonDiv( buttons, butProc ) );
|
|
|
|
}
|
|
|
|
|
2021-02-16 23:25:22 +01:00
|
|
|
function nbGetString(msg, dflt, proc, closure) {
|
|
|
|
let dlg = newDlgWMsg( msg );
|
|
|
|
|
|
|
|
let tarea = document.createElement('textarea');
|
|
|
|
tarea.classList.add('stringedit');
|
|
|
|
tarea.value = dflt;
|
|
|
|
dlg.appendChild( tarea );
|
|
|
|
|
|
|
|
dismissed = function(str) {
|
|
|
|
dlg.parentNode.removeChild(dlg);
|
|
|
|
Module.ccall('onDlgButton', null, ['number', 'number', 'string'],
|
|
|
|
[proc, closure, str]);
|
|
|
|
}
|
|
|
|
|
2021-02-17 01:03:24 +01:00
|
|
|
buttons = ["Cancel", "OK"];
|
|
|
|
butProc = function(str) {
|
|
|
|
if ( str == buttons[0] ) {
|
|
|
|
dismissed(null);
|
|
|
|
} else if ( str == buttons[1] ) {
|
|
|
|
dismissed(tarea.value);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
dlg.appendChild( newButtonDiv( buttons, butProc ) );
|
2021-02-16 23:25:22 +01:00
|
|
|
}
|
|
|
|
|
2021-02-13 17:42:48 +01:00
|
|
|
for ( let one of ['paho-mqtt.js'] ) {
|
|
|
|
let script = document.createElement('script');
|
|
|
|
script.src = one
|
|
|
|
document.body.appendChild(script);
|
|
|
|
}
|