2020-02-12 10:48:14 +00:00
|
|
|
Bangle.loadWidgets();
|
|
|
|
Bangle.drawWidgets();
|
|
|
|
|
2019-11-06 22:12:54 +00:00
|
|
|
const storage = require('Storage');
|
|
|
|
let settings;
|
|
|
|
|
|
|
|
function updateSettings() {
|
2020-02-28 11:44:25 +00:00
|
|
|
//storage.erase('setting.json'); // - not needed, just causes extra writes if settings were the same
|
|
|
|
storage.write('setting.json', settings);
|
2019-11-06 22:12:54 +00:00
|
|
|
}
|
|
|
|
|
2020-04-03 20:43:38 +00:00
|
|
|
function updateOptions() {
|
|
|
|
updateSettings();
|
|
|
|
Bangle.setOptions(settings.options)
|
|
|
|
}
|
|
|
|
|
|
|
|
function gToInternal(g) {
|
|
|
|
// converts g to Espruino internal unit
|
|
|
|
return g * 8192;
|
|
|
|
}
|
|
|
|
|
|
|
|
function internalToG(u) {
|
|
|
|
// converts Espruino internal unit to g
|
|
|
|
return u / 8192
|
|
|
|
}
|
|
|
|
|
2019-11-06 22:12:54 +00:00
|
|
|
function resetSettings() {
|
|
|
|
settings = {
|
2020-02-25 13:34:06 +00:00
|
|
|
ble: true, // Bluetooth enabled by default
|
|
|
|
blerepl: true, // Is REPL on Bluetooth - can Espruino IDE be used?
|
|
|
|
log: false, // Do log messages appear on screen?
|
|
|
|
timeout: 10, // Default LCD timeout in seconds
|
|
|
|
vibrate: true, // Vibration enabled by default. App must support
|
2020-03-25 11:05:33 +00:00
|
|
|
beep: "vib", // Beep enabled by default. App must support
|
2020-02-25 13:34:06 +00:00
|
|
|
timezone: 0, // Set the timezone for the device
|
2020-04-03 20:43:38 +00:00
|
|
|
HID: false, // BLE HID mode, off by default
|
2020-02-25 13:34:06 +00:00
|
|
|
clock: null, // a string for the default clock's name
|
2020-04-03 20:43:38 +00:00
|
|
|
"12hour": false, // 12 or 24 hour clock?
|
2020-02-13 08:18:32 +00:00
|
|
|
// welcomed : undefined/true (whether welcome app should show)
|
2020-04-03 20:43:38 +00:00
|
|
|
options: {
|
|
|
|
wakeOnBTN1: true,
|
|
|
|
wakeOnBTN2: true,
|
|
|
|
wakeOnBTN3: true,
|
|
|
|
wakeOnFaceUp: false,
|
|
|
|
wakeOnTouch: false,
|
|
|
|
wakeOnTwist: true,
|
|
|
|
twistThreshold: 819.2,
|
|
|
|
twistMaxY: -800,
|
|
|
|
twistTimeout: 1000
|
|
|
|
}
|
2019-11-06 22:12:54 +00:00
|
|
|
};
|
|
|
|
updateSettings();
|
|
|
|
}
|
|
|
|
|
2020-04-03 20:43:38 +00:00
|
|
|
settings = storage.readJSON('setting.json', 1);
|
2019-11-06 22:12:54 +00:00
|
|
|
if (!settings) resetSettings();
|
|
|
|
|
2020-02-25 13:34:06 +00:00
|
|
|
const boolFormat = v => v ? "On" : "Off";
|
2019-11-06 22:12:54 +00:00
|
|
|
|
|
|
|
function showMainMenu() {
|
2020-04-03 20:43:38 +00:00
|
|
|
var beepV = [false, true, "vib"];
|
|
|
|
var beepN = ["Off", "Piezo", "Vibrate"];
|
2019-11-06 22:12:54 +00:00
|
|
|
const mainmenu = {
|
|
|
|
'': { 'title': 'Settings' },
|
2020-02-04 16:17:23 +00:00
|
|
|
'Make Connectable': makeConnectable,
|
2019-11-08 17:52:37 +00:00
|
|
|
'BLE': {
|
|
|
|
value: settings.ble,
|
|
|
|
format: boolFormat,
|
|
|
|
onchange: () => {
|
|
|
|
settings.ble = !settings.ble;
|
|
|
|
updateSettings();
|
|
|
|
}
|
|
|
|
},
|
2019-11-10 11:46:05 +00:00
|
|
|
'Programmable': {
|
2020-02-25 13:34:06 +00:00
|
|
|
value: settings.blerepl,
|
2019-11-09 01:30:11 +00:00
|
|
|
format: boolFormat,
|
2019-11-08 23:59:37 +00:00
|
|
|
onchange: () => {
|
2020-02-25 13:34:06 +00:00
|
|
|
settings.blerepl = !settings.blerepl;
|
|
|
|
updateSettings();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'Debug info': {
|
|
|
|
value: settings.log,
|
|
|
|
format: v => v ? "Show" : "Hide",
|
|
|
|
onchange: () => {
|
|
|
|
settings.log = !settings.log;
|
2019-11-08 23:59:37 +00:00
|
|
|
updateSettings();
|
|
|
|
}
|
|
|
|
},
|
2019-11-06 22:12:54 +00:00
|
|
|
'LCD Timeout': {
|
|
|
|
value: settings.timeout,
|
|
|
|
min: 0,
|
|
|
|
max: 60,
|
|
|
|
step: 5,
|
|
|
|
onchange: v => {
|
|
|
|
settings.timeout = 0 | v;
|
|
|
|
updateSettings();
|
|
|
|
Bangle.setLCDTimeout(settings.timeout);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'Beep': {
|
2020-04-03 20:43:38 +00:00
|
|
|
value: 0 | beepV.indexOf(settings.beep),
|
|
|
|
min: 0, max: 2,
|
|
|
|
format: v => beepN[v],
|
2020-03-25 11:05:33 +00:00
|
|
|
onchange: v => {
|
|
|
|
settings.beep = beepV[v];
|
2020-04-03 20:43:38 +00:00
|
|
|
if (v == 1) { analogWrite(D18, 0.5, { freq: 2000 }); setTimeout(() => D18.reset(), 200) } // piezo
|
|
|
|
else if (v == 2) { analogWrite(D13, 0.1, { freq: 2000 }); setTimeout(() => D13.reset(), 200) } // vibrate
|
2019-11-06 22:12:54 +00:00
|
|
|
updateSettings();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'Vibration': {
|
|
|
|
value: settings.vibrate,
|
|
|
|
format: boolFormat,
|
|
|
|
onchange: () => {
|
|
|
|
settings.vibrate = !settings.vibrate;
|
|
|
|
updateSettings();
|
|
|
|
if (settings.vibrate) {
|
|
|
|
VIBRATE.write(1);
|
2020-04-03 20:43:38 +00:00
|
|
|
setTimeout(() => VIBRATE.write(0), 10);
|
2019-11-06 22:12:54 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
2020-02-13 08:18:32 +00:00
|
|
|
'Welcome App': {
|
|
|
|
value: !settings.welcomed,
|
|
|
|
format: boolFormat,
|
|
|
|
onchange: v => {
|
2020-04-03 20:43:38 +00:00
|
|
|
settings.welcomed = v ? undefined : true;
|
2020-02-13 08:18:32 +00:00
|
|
|
updateSettings();
|
|
|
|
}
|
|
|
|
},
|
2020-02-04 16:17:23 +00:00
|
|
|
'Locale': showLocaleMenu,
|
2019-11-16 22:13:49 +00:00
|
|
|
'Select Clock': showClockMenu,
|
2020-02-04 16:17:23 +00:00
|
|
|
'HID': {
|
|
|
|
value: settings.HID,
|
|
|
|
format: boolFormat,
|
|
|
|
onchange: () => {
|
|
|
|
settings.HID = !settings.HID;
|
|
|
|
updateSettings();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'Set Time': showSetTimeMenu,
|
2020-04-04 15:50:23 +00:00
|
|
|
'LCD Wake-Up': showWakeUpMenu,
|
2020-02-04 16:17:23 +00:00
|
|
|
'Reset Settings': showResetMenu,
|
|
|
|
'Turn Off': Bangle.off,
|
2020-04-03 20:43:38 +00:00
|
|
|
'< Back': () => { load(); }
|
2020-02-04 16:17:23 +00:00
|
|
|
};
|
|
|
|
return E.showMenu(mainmenu);
|
|
|
|
}
|
|
|
|
|
2020-04-04 15:50:23 +00:00
|
|
|
function showWakeUpMenu() {
|
|
|
|
const wakeUpMenu = {
|
|
|
|
'': { 'title': 'LCD Wake-Up' },
|
2020-04-03 20:43:38 +00:00
|
|
|
'< Back': showMainMenu,
|
|
|
|
'Wake On BTN1': {
|
|
|
|
value: settings.options.wakeOnBTN1,
|
|
|
|
format: boolFormat,
|
|
|
|
onchange: () => {
|
|
|
|
settings.options.wakeOnBTN1 = !settings.options.wakeOnBTN1;
|
|
|
|
updateOptions();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'Wake On BTN2': {
|
|
|
|
value: settings.options.wakeOnBTN2,
|
|
|
|
format: boolFormat,
|
|
|
|
onchange: () => {
|
|
|
|
settings.options.wakeOnBTN2 = !settings.options.wakeOnBTN2;
|
|
|
|
updateOptions();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'Wake On BTN3': {
|
|
|
|
value: settings.options.wakeOnBTN3,
|
|
|
|
format: boolFormat,
|
|
|
|
onchange: () => {
|
|
|
|
settings.options.wakeOnBTN3 = !settings.options.wakeOnBTN3;
|
|
|
|
updateOptions();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'Wake on FaceUp': {
|
|
|
|
value: settings.options.wakeOnFaceUp,
|
|
|
|
format: boolFormat,
|
|
|
|
onchange: () => {
|
|
|
|
settings.options.wakeOnFaceUp = !settings.options.wakeOnFaceUp;
|
|
|
|
updateOptions();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'Wake on Touch': {
|
|
|
|
value: settings.options.wakeOnTouch,
|
|
|
|
format: boolFormat,
|
|
|
|
onchange: () => {
|
|
|
|
settings.options.wakeOnTouch = !settings.options.wakeOnTouch;
|
|
|
|
updateOptions();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'Wake On Twist': {
|
|
|
|
value: settings.options.wakeOnTwist,
|
|
|
|
format: boolFormat,
|
|
|
|
onchange: () => {
|
|
|
|
settings.options.wakeOnTwist = !settings.options.wakeOnTwist;
|
|
|
|
updateOptions();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'Twist Threshold': {
|
|
|
|
value: internalToG(settings.options.twistThreshold),
|
|
|
|
min: -0.5,
|
|
|
|
max: 0.5,
|
|
|
|
step: 0.01,
|
|
|
|
onchange: v => {
|
|
|
|
settings.options.twistThreshold = gToInternal(v || 0.1);
|
|
|
|
updateOptions();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'Twist Max Y': {
|
|
|
|
value: settings.options.twistMaxY,
|
|
|
|
min: -1500,
|
|
|
|
max: 1500,
|
|
|
|
step: 100,
|
|
|
|
onchange: v => {
|
|
|
|
settings.options.twistMaxY = v || -800;
|
|
|
|
updateOptions();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'Twist Timeout': {
|
|
|
|
value: settings.options.twistTimeout,
|
|
|
|
min: 0,
|
|
|
|
max: 2000,
|
|
|
|
step: 100,
|
|
|
|
onchange: v => {
|
|
|
|
settings.options.twistTimeout = v || 1000;
|
|
|
|
updateOptions();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-04-04 15:50:23 +00:00
|
|
|
return E.showMenu(wakeUpMenu)
|
2020-04-03 20:43:38 +00:00
|
|
|
}
|
|
|
|
|
2020-02-04 16:17:23 +00:00
|
|
|
function showLocaleMenu() {
|
|
|
|
const localemenu = {
|
|
|
|
'': { 'title': 'Locale' },
|
|
|
|
'< Back': showMainMenu,
|
2019-11-06 22:12:54 +00:00
|
|
|
'Time Zone': {
|
|
|
|
value: settings.timezone,
|
|
|
|
min: -11,
|
|
|
|
max: 12,
|
2019-12-18 21:23:35 +00:00
|
|
|
step: 0.5,
|
2019-11-06 22:12:54 +00:00
|
|
|
onchange: v => {
|
2019-12-19 14:23:53 +00:00
|
|
|
settings.timezone = v || 0;
|
2019-11-06 22:12:54 +00:00
|
|
|
updateSettings();
|
|
|
|
}
|
|
|
|
},
|
2020-02-04 16:17:23 +00:00
|
|
|
'Clock Style': {
|
|
|
|
value: !!settings["12hour"],
|
2020-04-03 20:43:38 +00:00
|
|
|
format: v => v ? "12hr" : "24hr",
|
2020-02-04 16:17:23 +00:00
|
|
|
onchange: v => {
|
|
|
|
settings["12hour"] = v;
|
2019-11-08 15:54:57 +00:00
|
|
|
updateSettings();
|
|
|
|
}
|
2020-03-10 12:35:45 +00:00
|
|
|
}
|
2019-11-06 22:12:54 +00:00
|
|
|
};
|
2020-02-04 16:17:23 +00:00
|
|
|
return E.showMenu(localemenu);
|
2019-11-06 22:12:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function showResetMenu() {
|
|
|
|
const resetmenu = {
|
|
|
|
'': { 'title': 'Reset' },
|
|
|
|
'< Back': showMainMenu,
|
|
|
|
'Reset Settings': () => {
|
|
|
|
E.showPrompt('Reset Settings?').then((v) => {
|
|
|
|
if (v) {
|
|
|
|
E.showMessage('Resetting');
|
|
|
|
resetSettings();
|
|
|
|
}
|
|
|
|
setTimeout(showMainMenu, 50);
|
|
|
|
});
|
2020-02-04 16:17:23 +00:00
|
|
|
}
|
2019-11-06 22:12:54 +00:00
|
|
|
};
|
2020-01-17 11:32:32 +00:00
|
|
|
return E.showMenu(resetmenu);
|
2019-11-06 22:12:54 +00:00
|
|
|
}
|
|
|
|
|
2019-11-09 20:01:36 +00:00
|
|
|
function makeConnectable() {
|
2020-04-03 20:43:38 +00:00
|
|
|
try { NRF.wake(); } catch (e) { }
|
2019-11-10 11:46:05 +00:00
|
|
|
Bluetooth.setConsole(1);
|
2020-04-03 20:43:38 +00:00
|
|
|
var name = "Bangle.js " + NRF.getAddress().substr(-5).replace(":", "");
|
|
|
|
E.showPrompt(name + "\nStay Connectable?", { title: "Connectable" }).then(r => {
|
|
|
|
if (settings.ble != r) {
|
2019-11-09 20:01:36 +00:00
|
|
|
settings.ble = r;
|
|
|
|
updateSettings();
|
|
|
|
}
|
2020-04-03 20:43:38 +00:00
|
|
|
if (!r) try { NRF.sleep(); } catch (e) { }
|
2019-11-09 20:01:36 +00:00
|
|
|
showMainMenu();
|
|
|
|
});
|
|
|
|
}
|
2019-11-16 22:13:49 +00:00
|
|
|
function showClockMenu() {
|
2020-04-03 20:43:38 +00:00
|
|
|
var clockApps = require("Storage").list(/\.info$/).map(app => {
|
2019-11-16 22:13:49 +00:00
|
|
|
try { return require("Storage").readJSON(app); }
|
2020-04-03 20:43:38 +00:00
|
|
|
catch (e) { }
|
|
|
|
}).filter(app => app.type == "clock").sort((a, b) => a.sortorder - b.sortorder);
|
2019-11-16 22:13:49 +00:00
|
|
|
const clockMenu = {
|
|
|
|
'': {
|
|
|
|
'title': 'Select Clock',
|
|
|
|
},
|
|
|
|
'< Back': showMainMenu,
|
|
|
|
};
|
2020-04-03 20:43:38 +00:00
|
|
|
clockApps.forEach((app, index) => {
|
2019-11-16 22:13:49 +00:00
|
|
|
var label = app.name;
|
2019-11-16 22:36:43 +00:00
|
|
|
if ((!settings.clock && index === 0) || (settings.clock === app.src)) {
|
2020-04-03 20:43:38 +00:00
|
|
|
label = "* " + label;
|
2019-11-16 22:13:49 +00:00
|
|
|
}
|
|
|
|
clockMenu[label] = () => {
|
|
|
|
if (settings.clock !== app.src) {
|
|
|
|
settings.clock = app.src;
|
|
|
|
updateSettings();
|
|
|
|
showMainMenu();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
});
|
|
|
|
if (clockApps.length === 0) {
|
2020-04-03 20:43:38 +00:00
|
|
|
clockMenu["No Clocks Found"] = () => { };
|
2019-11-16 22:13:49 +00:00
|
|
|
}
|
2020-01-17 11:32:32 +00:00
|
|
|
return E.showMenu(clockMenu);
|
2019-11-16 22:13:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-11-09 20:01:36 +00:00
|
|
|
|
2019-11-07 23:28:07 +00:00
|
|
|
function showSetTimeMenu() {
|
|
|
|
d = new Date();
|
|
|
|
const timemenu = {
|
|
|
|
'': {
|
|
|
|
'title': 'Set Time',
|
2020-04-03 20:43:38 +00:00
|
|
|
'predraw': function () {
|
2019-11-07 23:28:07 +00:00
|
|
|
d = new Date();
|
|
|
|
timemenu.Hour.value = d.getHours();
|
|
|
|
timemenu.Minute.value = d.getMinutes();
|
|
|
|
timemenu.Second.value = d.getSeconds();
|
|
|
|
timemenu.Date.value = d.getDate();
|
|
|
|
timemenu.Month.value = d.getMonth() + 1;
|
|
|
|
timemenu.Year.value = d.getFullYear();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'< Back': showMainMenu,
|
|
|
|
'Hour': {
|
|
|
|
value: d.getHours(),
|
|
|
|
min: 0,
|
|
|
|
max: 23,
|
|
|
|
step: 1,
|
|
|
|
onchange: v => {
|
|
|
|
d = new Date();
|
|
|
|
d.setHours(v);
|
2020-04-03 20:43:38 +00:00
|
|
|
setTime(d.getTime() / 1000);
|
2019-11-07 23:28:07 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
'Minute': {
|
|
|
|
value: d.getMinutes(),
|
|
|
|
min: 0,
|
|
|
|
max: 59,
|
|
|
|
step: 1,
|
|
|
|
onchange: v => {
|
|
|
|
d = new Date();
|
|
|
|
d.setMinutes(v);
|
2020-04-03 20:43:38 +00:00
|
|
|
setTime(d.getTime() / 1000);
|
2019-11-07 23:28:07 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
'Second': {
|
|
|
|
value: d.getSeconds(),
|
|
|
|
min: 0,
|
|
|
|
max: 59,
|
|
|
|
step: 1,
|
|
|
|
onchange: v => {
|
|
|
|
d = new Date();
|
|
|
|
d.setSeconds(v);
|
2020-04-03 20:43:38 +00:00
|
|
|
setTime(d.getTime() / 1000);
|
2019-11-07 23:28:07 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
'Date': {
|
|
|
|
value: d.getDate(),
|
|
|
|
min: 1,
|
|
|
|
max: 31,
|
|
|
|
step: 1,
|
|
|
|
onchange: v => {
|
|
|
|
d = new Date();
|
|
|
|
d.setDate(v);
|
2020-04-03 20:43:38 +00:00
|
|
|
setTime(d.getTime() / 1000);
|
2019-11-07 23:28:07 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
'Month': {
|
|
|
|
value: d.getMonth() + 1,
|
|
|
|
min: 1,
|
|
|
|
max: 12,
|
|
|
|
step: 1,
|
|
|
|
onchange: v => {
|
|
|
|
d = new Date();
|
|
|
|
d.setMonth(v - 1);
|
2020-04-03 20:43:38 +00:00
|
|
|
setTime(d.getTime() / 1000);
|
2019-11-07 23:28:07 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
'Year': {
|
|
|
|
value: d.getFullYear(),
|
2019-11-20 08:19:56 +00:00
|
|
|
min: 2019,
|
|
|
|
max: 2100,
|
2019-11-07 23:28:07 +00:00
|
|
|
step: 1,
|
|
|
|
onchange: v => {
|
|
|
|
d = new Date();
|
|
|
|
d.setFullYear(v);
|
2020-04-03 20:43:38 +00:00
|
|
|
setTime(d.getTime() / 1000);
|
2019-11-07 23:28:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
2020-01-17 11:32:32 +00:00
|
|
|
return E.showMenu(timemenu);
|
2019-11-07 23:28:07 +00:00
|
|
|
}
|
|
|
|
|
2019-11-06 22:12:54 +00:00
|
|
|
showMainMenu();
|