Add settings and cleanup
parent
b1e4b82ecc
commit
fa66b67816
|
|
@ -4970,6 +4970,7 @@
|
||||||
"storage": [
|
"storage": [
|
||||||
{"name":"coretemp.boot.js","url":"boot.js"},
|
{"name":"coretemp.boot.js","url":"boot.js"},
|
||||||
{"name":"coretemp.app.js","url":"coretemp.js"},
|
{"name":"coretemp.app.js","url":"coretemp.js"},
|
||||||
|
{"name":"coretemp.settings.js","url":"settings.js"},
|
||||||
{"name":"coretemp.img","url":"coretemp-icon.js","evaluate":true}
|
{"name":"coretemp.img","url":"coretemp-icon.js","evaluate":true}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
|
|
||||||
|
|
@ -1,47 +1,100 @@
|
||||||
(function() {
|
(function() {
|
||||||
|
|
||||||
var state = {gatt : null, primary : null, temp : null, data : null};
|
var device;
|
||||||
// Would it be better to scan by uuid rather than name?
|
var gatt;
|
||||||
NRF.requestDevice({timeout : 20000, filters : [ {namePrefix : 'CORE'} ]})
|
var service;
|
||||||
// NRF.requestDevice({timeout : 20000, filters : [ {services :
|
var characteristic;
|
||||||
// '1809','2100'} ]})
|
|
||||||
.then(function(device) {
|
|
||||||
return device.gatt.connect();
|
|
||||||
})
|
|
||||||
.then(function(g) {
|
|
||||||
state.gatt = g;
|
|
||||||
return state.gatt
|
|
||||||
.getPrimaryService('00002100-5b1e-4347-b07c-97b514dae121')
|
|
||||||
.then(function(service) {
|
|
||||||
state.primary = service;
|
|
||||||
return state.primary.getCharacteristic(
|
|
||||||
'00002101-5b1e-4347-b07c-97b514dae121');
|
|
||||||
})
|
|
||||||
.then(function(c) {
|
|
||||||
state.data = c;
|
|
||||||
state.data.on('characteristicvaluechanged', function(event) {
|
|
||||||
var dv = event.target.value;
|
|
||||||
var flags = dv.buffer[0];
|
|
||||||
var unit, core = -1, skin = -1;
|
|
||||||
|
|
||||||
if (flags & 8) {
|
class CoreSensor {
|
||||||
unit = "F";
|
constructor() {
|
||||||
} else {
|
this.unit = "";
|
||||||
unit = "C";
|
this.core = -1;
|
||||||
}
|
this.skin = -1;
|
||||||
|
this.battery = 0;
|
||||||
|
}
|
||||||
|
|
||||||
if (flags & 1)
|
updateSensor(event) {
|
||||||
skin = (dv.buffer[4] * 256 + dv.buffer[3]) / 100;
|
if (event.target.uuid == "00002101-5b1e-4347-b07c-97b514dae121") {
|
||||||
if (flags & 2)
|
var dv = event.target.value;
|
||||||
core = (dv.buffer[2] * 256 + dv.buffer[1]) / 100;
|
var flags = dv.buffer[0];
|
||||||
|
|
||||||
Bangle.emit('CoreTemp', {core : core, skin : skin, unit : unit});
|
if (flags & 8) {
|
||||||
});
|
this.unit = "F";
|
||||||
return c.startNotifications();
|
} else {
|
||||||
})
|
this.unit = "C";
|
||||||
.catch(function(e) {
|
}
|
||||||
E.showMessage(e.toString(), "ERROR");
|
|
||||||
console.log(e);
|
if (flags & 1) this.skin = (dv.buffer[4] * 256 + dv.buffer[3]) / 100;
|
||||||
});
|
if (flags & 2) this.core = (dv.buffer[2] * 256 + dv.buffer[1]) / 100;
|
||||||
});
|
|
||||||
|
Bangle.emit('CoreTemp',
|
||||||
|
{core : this.core, skin : this.skin, unit : this.unit});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
updateBatteryLevel(event) {
|
||||||
|
if (event.target.uuid == "0x2a19")
|
||||||
|
this.battery = event.target.value.getUint8(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var mySensor = new CoreSensor();
|
||||||
|
|
||||||
|
function getSensorBatteryLevel(gatt) {
|
||||||
|
gatt.getPrimaryService("180f")
|
||||||
|
.then(function(s) { return s.getCharacteristic("2a19"); })
|
||||||
|
.then(function(c) {
|
||||||
|
c.on('characteristicvaluechanged',
|
||||||
|
(event) => mySensor.updateBatteryLevel(event));
|
||||||
|
return c.startNotifications();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function connection_setup() {
|
||||||
|
E.showMessage("Scanning for CoreTemp sensor...");
|
||||||
|
NRF.requestDevice({timeout : 20000, filters : [ {namePrefix : 'CORE'} ]})
|
||||||
|
.then(function(d) {
|
||||||
|
device = d;
|
||||||
|
E.showMessage("Found device");
|
||||||
|
return device.gatt.connect();
|
||||||
|
})
|
||||||
|
.then(function(g) {
|
||||||
|
gatt = g;
|
||||||
|
return gatt.getPrimaryService('00002100-5b1e-4347-b07c-97b514dae121');
|
||||||
|
})
|
||||||
|
.then(function(s) {
|
||||||
|
service = s;
|
||||||
|
return service.getCharacteristic(
|
||||||
|
'00002101-5b1e-4347-b07c-97b514dae121');
|
||||||
|
})
|
||||||
|
.then(function(c) {
|
||||||
|
characteristic = c;
|
||||||
|
characteristic.on('characteristicvaluechanged',
|
||||||
|
(event) => mySensor.updateSensor(event));
|
||||||
|
return characteristic.startNotifications();
|
||||||
|
})
|
||||||
|
.then(function() {
|
||||||
|
console.log("Done!");
|
||||||
|
// getSensorBatteryLevel(gatt);
|
||||||
|
g.reset().clearRect(Bangle.appRect).flip();
|
||||||
|
})
|
||||||
|
.catch(function(e) {
|
||||||
|
E.showMessage(e.toString(), "ERROR");
|
||||||
|
console.log(e);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function connection_end() {
|
||||||
|
if (gatt != undefined) gatt.disconnect();
|
||||||
|
}
|
||||||
|
|
||||||
|
connection_setup();
|
||||||
|
|
||||||
|
E.on('kill', () => { connection_end(); });
|
||||||
|
|
||||||
|
// move into setup
|
||||||
|
NRF.on('disconnect', connection_setup); // restart if disconnected
|
||||||
|
|
||||||
|
// Bangle.loadWidgets();
|
||||||
|
// Bangle.drawWidgets();
|
||||||
})();
|
})();
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
|
// Simply listen for core events and show
|
||||||
|
|
||||||
Bangle.setLCDPower(1);
|
Bangle.setLCDPower(1);
|
||||||
Bangle.setLCDTimeout(0);
|
Bangle.setLCDTimeout(0);
|
||||||
|
|
@ -23,3 +23,4 @@ Bangle.drawWidgets();
|
||||||
|
|
||||||
g.reset().setFont("6x8", 2).setFontAlign(0, 0);
|
g.reset().setFont("6x8", 2).setFontAlign(0, 0);
|
||||||
g.drawString("Please wait...", g.getWidth() / 2, g.getHeight() / 2 - 16);
|
g.drawString("Please wait...", g.getWidth() / 2, g.getHeight() / 2 - 16);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,40 @@
|
||||||
|
// This file should contain exactly one function, which shows the app's settings
|
||||||
|
/**
|
||||||
|
* @param {function} back Use back() to return to settings menu
|
||||||
|
*/
|
||||||
|
(function(back) {
|
||||||
|
const SETTINGS_FILE = 'coretemp.json'
|
||||||
|
// initialize with default settings...
|
||||||
|
let s = {
|
||||||
|
'enabled': true,
|
||||||
|
}
|
||||||
|
// ...and overwrite them with any saved values
|
||||||
|
// This way saved values are preserved if a new version adds more settings
|
||||||
|
const storage = require('Storage')
|
||||||
|
const saved = storage.readJSON(SETTINGS_FILE, 1) || {}
|
||||||
|
for (const key in saved) {
|
||||||
|
s[key] = saved[key];
|
||||||
|
}
|
||||||
|
// creates a function to safe a specific setting, e.g. save('color')(1)
|
||||||
|
function save(key) {
|
||||||
|
return function (value) {
|
||||||
|
s[key] = value;
|
||||||
|
storage.write(SETTINGS_FILE, s);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const menu = {
|
||||||
|
'' : {'title' : 'CoreTemp sensor'},
|
||||||
|
'< Back' : back,
|
||||||
|
'Enabled' : {
|
||||||
|
value : !!settings.enabled,
|
||||||
|
format : v => v ? "Yes" : "No",
|
||||||
|
onchange : v => {
|
||||||
|
settings.enabled = v;
|
||||||
|
updateSettings();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
E.showMenu(menu);
|
||||||
|
})
|
||||||
Loading…
Reference in New Issue