Updated formatting
parent
04819fcfe1
commit
86b5c10937
|
|
@ -6,10 +6,10 @@
|
||||||
"icon": "widget.png",
|
"icon": "widget.png",
|
||||||
"type": "widget",
|
"type": "widget",
|
||||||
"tags": "widget",
|
"tags": "widget",
|
||||||
"supports": ["BANGLEJS","BANGLEJS2"],
|
"supports": ["BANGLEJS", "BANGLEJS2"],
|
||||||
"storage": [
|
"storage": [
|
||||||
{"name":"chimer.wid.js","url":"widget.js"},
|
{ "name": "chimer.wid.js", "url": "widget.js" },
|
||||||
{"name":"chimer.settings.js","url":"settings.js"}
|
{ "name": "chimer.settings.js", "url": "settings.js" }
|
||||||
],
|
],
|
||||||
"data": [{"name":"chimer.json"}]
|
"data": [{ "name": "chimer.json" }]
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,68 +2,69 @@
|
||||||
* @param {function} back Use back() to return to settings menu
|
* @param {function} back Use back() to return to settings menu
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
(function (back) {
|
||||||
|
|
||||||
(function(back) {
|
|
||||||
// default to buzzing
|
// default to buzzing
|
||||||
var FILE = "chimer.json";
|
var FILE = "chimer.json";
|
||||||
var settings = {};
|
var settings = {};
|
||||||
const chimes = ["Off", "Buzz", "Beep", "Both"];
|
const chimes = ["Off", "Buzz", "Beep", "Both"];
|
||||||
const frequency = ["60 min", "30 min", "15 min", "1 min"];
|
const frequency = ["60 min", "30 min", "15 min", "1 min"];
|
||||||
|
|
||||||
|
var showMainMenu = () => {
|
||||||
var showMainMenu = () => {
|
E.showMenu({
|
||||||
E.showMenu({
|
"": { title: "Chimer" },
|
||||||
"": {"title": "Chimer"},
|
"< Back": () => back(),
|
||||||
"< Back": () => back(),
|
"Chime Type": {
|
||||||
"Chime Type": {
|
value: settings.type,
|
||||||
value: settings.type,
|
min: 0,
|
||||||
min: 0, max: 2, // both is just silly
|
max: 2, // both is just silly
|
||||||
format: v => chimes[v],
|
format: (v) => chimes[v],
|
||||||
onchange: v => {
|
onchange: (v) => {
|
||||||
settings.type = v;
|
settings.type = v;
|
||||||
writeSettings(settings);
|
writeSettings(settings);
|
||||||
|
},
|
||||||
},
|
},
|
||||||
},
|
Frequency: {
|
||||||
"Frequency": {
|
value: settings.freq,
|
||||||
value: settings.freq,
|
min: 0,
|
||||||
min: 0, max: 2,
|
max: 2,
|
||||||
format: v => frequency[v],
|
format: (v) => frequency[v],
|
||||||
onchange: v => {
|
onchange: (v) => {
|
||||||
settings.freq = v;
|
settings.freq = v;
|
||||||
writeSettings(settings);
|
writeSettings(settings);
|
||||||
}
|
},
|
||||||
},
|
},
|
||||||
"Repetition": {
|
Repetition: {
|
||||||
value: settings.repeat,
|
value: settings.repeat,
|
||||||
min: 1, max: 3,
|
min: 1,
|
||||||
format: v => v,
|
max: 3,
|
||||||
onchange: v => {
|
format: (v) => v,
|
||||||
settings.repeat = v;
|
onchange: (v) => {
|
||||||
writeSettings(settings);
|
settings.repeat = v;
|
||||||
}
|
writeSettings(settings);
|
||||||
},
|
},
|
||||||
"Start Hour": {
|
},
|
||||||
value: settings.start,
|
"Start Hour": {
|
||||||
min: 1, max: 24,
|
value: settings.start,
|
||||||
format: v => v,
|
min: 1,
|
||||||
onchange: v => {
|
max: 24,
|
||||||
settings.start = v;
|
format: (v) => v,
|
||||||
writeSettings(settings);
|
onchange: (v) => {
|
||||||
}
|
settings.start = v;
|
||||||
},
|
writeSettings(settings);
|
||||||
"End Hour": {
|
},
|
||||||
value: settings.end,
|
},
|
||||||
min: 1, max: 24,
|
"End Hour": {
|
||||||
format: v => v,
|
value: settings.end,
|
||||||
onchange: v => {
|
min: 1,
|
||||||
settings.end = v;
|
max: 24,
|
||||||
writeSettings(settings);
|
format: (v) => v,
|
||||||
}
|
onchange: (v) => {
|
||||||
}
|
settings.end = v;
|
||||||
});
|
writeSettings(settings);
|
||||||
};
|
},
|
||||||
|
},
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
var readSettings = () => {
|
var readSettings = () => {
|
||||||
var settings = require("Storage").readJSON(FILE, 1) || {
|
var settings = require("Storage").readJSON(FILE, 1) || {
|
||||||
|
|
@ -82,5 +83,4 @@ var showMainMenu = () => {
|
||||||
|
|
||||||
settings = readSettings();
|
settings = readSettings();
|
||||||
showMainMenu();
|
showMainMenu();
|
||||||
})
|
});
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
(function() {
|
(function () {
|
||||||
// 0: off, 1: buzz, 2: beep, 3: both
|
// 0: off, 1: buzz, 2: beep, 3: both
|
||||||
var FILE = "chimer.json";
|
var FILE = "chimer.json";
|
||||||
|
|
||||||
|
|
@ -15,7 +15,7 @@
|
||||||
|
|
||||||
var settings = readSettings();
|
var settings = readSettings();
|
||||||
|
|
||||||
function sleep(milliseconds) {
|
function sleep(milliseconds) {
|
||||||
const date = Date.now();
|
const date = Date.now();
|
||||||
let currentDate = null;
|
let currentDate = null;
|
||||||
do {
|
do {
|
||||||
|
|
@ -24,86 +24,100 @@ function sleep(milliseconds) {
|
||||||
}
|
}
|
||||||
|
|
||||||
function chime() {
|
function chime() {
|
||||||
for(var i = 0; i < settings.repeat; i++){
|
for (var i = 0; i < settings.repeat; i++) {
|
||||||
if (settings.type === 1){
|
if (settings.type === 1) {
|
||||||
Bangle.buzz(100);
|
Bangle.buzz(100);
|
||||||
} else if(settings.type === 2){
|
} else if (settings.type === 2) {
|
||||||
Bangle.beep();
|
Bangle.beep();
|
||||||
} else {
|
} else {
|
||||||
return;
|
|
||||||
}
|
|
||||||
sleep(100);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
let lastHour = (new Date()).getHours();
|
|
||||||
let lastMinute = (new Date()).getMinutes(); // don't chime when (re)loaded at a whole hour
|
|
||||||
function check() {
|
|
||||||
const now = new Date(),
|
|
||||||
h = now.getHours(), m = now.getMinutes(),
|
|
||||||
s = now.getSeconds(), ms = now.getMilliseconds();
|
|
||||||
if (h > settings.end || h < settings.start){
|
|
||||||
var mLeft = 60-m, sLeft = (mLeft*60)-s, msLeft = (sLeft*1000)-ms;
|
|
||||||
setTimeout(check, msLeft);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (settings.freq === 1){
|
sleep(100);
|
||||||
if (m !== lastMinute && m===0 || m===30) chime();
|
|
||||||
lastHour = h;
|
|
||||||
lastMinute = m;
|
|
||||||
// check again in 30 minutes
|
|
||||||
switch (true){
|
|
||||||
case (m/30 >= 1):
|
|
||||||
var mLeft = 30-(m-30), sLeft = (mLeft*60)-s, msLeft = (sLeft*1000)-ms;
|
|
||||||
break;
|
|
||||||
case (m/30 < 1):
|
|
||||||
var mLeft = 30-m, sLeft = (mLeft*60)-s, msLeft = (sLeft*1000)-ms;
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
setTimeout(check, msLeft);
|
|
||||||
|
|
||||||
}else if (settings.freq === 2){
|
|
||||||
if (m !== lastMinute && m===0 || m===15 || m===30 || m===45) chime();
|
|
||||||
lastHour = h;
|
|
||||||
lastMinute = m;
|
|
||||||
// check again in 15 minutes
|
|
||||||
switch (true){
|
|
||||||
case (m/15 >= 3):
|
|
||||||
var mLeft = 15-(m-45), sLeft = (mLeft*60)-s, msLeft = (sLeft*1000)-ms;
|
|
||||||
break;
|
|
||||||
case (m/15 >= 2):
|
|
||||||
var mLeft = 15-(m-30), sLeft = (mLeft*60)-s, msLeft = (sLeft*1000)-ms;
|
|
||||||
break;
|
|
||||||
case (m/15 >= 1):
|
|
||||||
var mLeft = 15-(m-15), sLeft = (mLeft*60)-s, msLeft = (sLeft*1000)-ms;
|
|
||||||
break;
|
|
||||||
case (m/15 < 1):
|
|
||||||
var mLeft = 15-m, sLeft = (mLeft*60)-s, msLeft = (sLeft*1000)-ms;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
setTimeout(check, msLeft);
|
|
||||||
}else if (settings.freq === 3){
|
|
||||||
if (m !== lastMinute) chime();
|
|
||||||
lastHour = h;
|
|
||||||
lastMinute = m;
|
|
||||||
// check again in 1 minute
|
|
||||||
|
|
||||||
var mLeft = 1, sLeft = (mLeft*60)-s, msLeft = (sLeft*1000)-ms;
|
|
||||||
setTimeout(check, msLeft);
|
|
||||||
|
|
||||||
}else{
|
|
||||||
if (h!==lastHour && m===0) chime();
|
|
||||||
lastHour = h;
|
|
||||||
// check again in 60 minutes
|
|
||||||
var mLeft = 60-m, sLeft = (mLeft*60)-s, msLeft = (sLeft*1000)-ms;
|
|
||||||
setTimeout(check, msLeft);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let lastHour = new Date().getHours();
|
||||||
|
let lastMinute = new Date().getMinutes(); // don't chime when (re)loaded at a whole hour
|
||||||
|
function check() {
|
||||||
|
const now = new Date(),
|
||||||
|
h = now.getHours(),
|
||||||
|
m = now.getMinutes(),
|
||||||
|
s = now.getSeconds(),
|
||||||
|
ms = now.getMilliseconds();
|
||||||
|
if (h > settings.end || h < settings.start) {
|
||||||
|
var mLeft = 60 - m,
|
||||||
|
sLeft = mLeft * 60 - s,
|
||||||
|
msLeft = sLeft * 1000 - ms;
|
||||||
|
setTimeout(check, msLeft);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (settings.freq === 1) {
|
||||||
|
if ((m !== lastMinute && m === 0) || m === 30) chime();
|
||||||
|
lastHour = h;
|
||||||
|
lastMinute = m;
|
||||||
|
// check again in 30 minutes
|
||||||
|
switch (true) {
|
||||||
|
case m / 30 >= 1:
|
||||||
|
var mLeft = 30 - (m - 30),
|
||||||
|
sLeft = mLeft * 60 - s,
|
||||||
|
msLeft = sLeft * 1000 - ms;
|
||||||
|
break;
|
||||||
|
case m / 30 < 1:
|
||||||
|
var mLeft = 30 - m,
|
||||||
|
sLeft = mLeft * 60 - s,
|
||||||
|
msLeft = sLeft * 1000 - ms;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
setTimeout(check, msLeft);
|
||||||
|
} else if (settings.freq === 2) {
|
||||||
|
if ((m !== lastMinute && m === 0) || m === 15 || m === 30 || m === 45)
|
||||||
|
chime();
|
||||||
|
lastHour = h;
|
||||||
|
lastMinute = m;
|
||||||
|
// check again in 15 minutes
|
||||||
|
switch (true) {
|
||||||
|
case m / 15 >= 3:
|
||||||
|
var mLeft = 15 - (m - 45),
|
||||||
|
sLeft = mLeft * 60 - s,
|
||||||
|
msLeft = sLeft * 1000 - ms;
|
||||||
|
break;
|
||||||
|
case m / 15 >= 2:
|
||||||
|
var mLeft = 15 - (m - 30),
|
||||||
|
sLeft = mLeft * 60 - s,
|
||||||
|
msLeft = sLeft * 1000 - ms;
|
||||||
|
break;
|
||||||
|
case m / 15 >= 1:
|
||||||
|
var mLeft = 15 - (m - 15),
|
||||||
|
sLeft = mLeft * 60 - s,
|
||||||
|
msLeft = sLeft * 1000 - ms;
|
||||||
|
break;
|
||||||
|
case m / 15 < 1:
|
||||||
|
var mLeft = 15 - m,
|
||||||
|
sLeft = mLeft * 60 - s,
|
||||||
|
msLeft = sLeft * 1000 - ms;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
setTimeout(check, msLeft);
|
||||||
|
} else if (settings.freq === 3) {
|
||||||
|
if (m !== lastMinute) chime();
|
||||||
|
lastHour = h;
|
||||||
|
lastMinute = m;
|
||||||
|
// check again in 1 minute
|
||||||
|
|
||||||
|
var mLeft = 1,
|
||||||
};
|
sLeft = mLeft * 60 - s,
|
||||||
|
msLeft = sLeft * 1000 - ms;
|
||||||
|
setTimeout(check, msLeft);
|
||||||
|
} else {
|
||||||
|
if (h !== lastHour && m === 0) chime();
|
||||||
|
lastHour = h;
|
||||||
|
// check again in 60 minutes
|
||||||
|
var mLeft = 60 - m,
|
||||||
|
sLeft = mLeft * 60 - s,
|
||||||
|
msLeft = sLeft * 1000 - ms;
|
||||||
|
setTimeout(check, msLeft);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
check();
|
check();
|
||||||
})
|
})();
|
||||||
();
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue