Merge branch 'master' of github.com:espruino/BangleApps
commit
65d4b410ff
|
|
@ -1,2 +1,3 @@
|
||||||
0.01: Initial Creation
|
0.01: Initial Creation
|
||||||
0.02: Fixed some sleep bugs. Added a sleep mode toggle
|
0.02: Fixed some sleep bugs. Added a sleep mode toggle
|
||||||
|
0.03: Reduce busy-loop and code
|
||||||
|
|
|
||||||
|
|
@ -1,8 +1,8 @@
|
||||||
{
|
{
|
||||||
"id": "chimer",
|
"id": "chimer",
|
||||||
"name": "Chimer",
|
"name": "Chimer",
|
||||||
"version": "0.02",
|
"version": "0.03",
|
||||||
"description": "A fork of Hour Chime that adds extra features such as: \n - Buzz or beep on every 60, 30 or 15 minutes. \n - Reapeat Chime up to 3 times \n - Set hours to disable chime",
|
"description": "A fork of Hour Chime that adds extra features such as: \n - Buzz or beep on every 60, 30 or 15 minutes. \n - Repeat Chime up to 3 times \n - Set hours to disable chime",
|
||||||
"icon": "widget.png",
|
"icon": "widget.png",
|
||||||
"type": "widget",
|
"type": "widget",
|
||||||
"tags": "widget",
|
"tags": "widget",
|
||||||
|
|
|
||||||
|
|
@ -16,16 +16,10 @@
|
||||||
|
|
||||||
var settings = readSettings();
|
var settings = readSettings();
|
||||||
|
|
||||||
function sleep(milliseconds) {
|
|
||||||
const date = Date.now();
|
|
||||||
let currentDate = null;
|
|
||||||
do {
|
|
||||||
currentDate = Date.now();
|
|
||||||
} while (currentDate - date < milliseconds);
|
|
||||||
}
|
|
||||||
|
|
||||||
function chime() {
|
function chime() {
|
||||||
for (var i = 0; i < settings.repeat; i++) {
|
let count = settings.repeat;
|
||||||
|
|
||||||
|
const chime1 = () => {
|
||||||
if (settings.type === 1) {
|
if (settings.type === 1) {
|
||||||
Bangle.buzz(100);
|
Bangle.buzz(100);
|
||||||
} else if (settings.type === 2) {
|
} else if (settings.type === 2) {
|
||||||
|
|
@ -33,8 +27,24 @@
|
||||||
} else {
|
} else {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
sleep(150);
|
if (--count > 0)
|
||||||
|
setTimeout(chime1, 150);
|
||||||
|
};
|
||||||
|
|
||||||
|
chime1();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function queueNextCheckMins(mins) {
|
||||||
|
const now = new Date(),
|
||||||
|
m = now.getMinutes(),
|
||||||
|
s = now.getSeconds(),
|
||||||
|
ms = now.getMilliseconds();
|
||||||
|
|
||||||
|
const mLeft = mins - (m + mins * 2) % mins,
|
||||||
|
sLeft = mLeft * 60 - s,
|
||||||
|
msLeft = sLeft * 1000 - ms;
|
||||||
|
|
||||||
|
setTimeout(check, msLeft);
|
||||||
}
|
}
|
||||||
|
|
||||||
let lastHour = new Date().getHours();
|
let lastHour = new Date().getHours();
|
||||||
|
|
@ -45,88 +55,41 @@
|
||||||
m = now.getMinutes(),
|
m = now.getMinutes(),
|
||||||
s = now.getSeconds(),
|
s = now.getSeconds(),
|
||||||
ms = now.getMilliseconds();
|
ms = now.getMilliseconds();
|
||||||
if (
|
if (settings.sleep && (
|
||||||
(settings.sleep && h > settings.end) ||
|
h > settings.end ||
|
||||||
(settings.sleep && h >= settings.end && m !== 0) ||
|
(h >= settings.end && m !== 0) ||
|
||||||
(settings.sleep && h < settings.start)
|
h < settings.start)
|
||||||
) {
|
) {
|
||||||
var mLeft = 60 - m,
|
queueNextCheckMins(60);
|
||||||
sLeft = mLeft * 60 - s,
|
|
||||||
msLeft = sLeft * 1000 - ms;
|
|
||||||
setTimeout(check, msLeft);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (settings.freq === 1) {
|
switch (settings.freq) {
|
||||||
if ((m !== lastMinute && m === 0) || (m !== lastMinute && m === 30))
|
case 1:
|
||||||
|
if (m !== lastMinute && m % 30 === 0)
|
||||||
chime();
|
chime();
|
||||||
lastHour = h;
|
lastHour = h;
|
||||||
lastMinute = m;
|
lastMinute = m;
|
||||||
// check again in 30 minutes
|
queueNextCheckMins(30);
|
||||||
switch (true) {
|
|
||||||
case m / 30 >= 1:
|
|
||||||
var mLeft = 30 - (m - 30),
|
|
||||||
sLeft = mLeft * 60 - s,
|
|
||||||
msLeft = sLeft * 1000 - ms;
|
|
||||||
break;
|
break;
|
||||||
case m / 30 < 1:
|
case 2:
|
||||||
var mLeft = 30 - m,
|
if (m !== lastMinute && m % 15 === 0)
|
||||||
sLeft = mLeft * 60 - s,
|
|
||||||
msLeft = sLeft * 1000 - ms;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
setTimeout(check, msLeft);
|
|
||||||
} else if (settings.freq === 2) {
|
|
||||||
if (
|
|
||||||
(m !== lastMinute && m === 0) ||
|
|
||||||
(m !== lastMinute && m === 15) ||
|
|
||||||
(m !== lastMinute && m === 30) ||
|
|
||||||
(m !== lastMinute && m === 45)
|
|
||||||
)
|
|
||||||
chime();
|
chime();
|
||||||
lastHour = h;
|
lastHour = h;
|
||||||
lastMinute = m;
|
lastMinute = m;
|
||||||
// check again in 15 minutes
|
queueNextCheckMins(15);
|
||||||
switch (true) {
|
|
||||||
case m / 15 >= 3:
|
|
||||||
var mLeft = 15 - (m - 45),
|
|
||||||
sLeft = mLeft * 60 - s,
|
|
||||||
msLeft = sLeft * 1000 - ms;
|
|
||||||
break;
|
break;
|
||||||
case m / 15 >= 2:
|
case 3:
|
||||||
var mLeft = 15 - (m - 30),
|
// unreachable - not available in settings
|
||||||
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();
|
if (m !== lastMinute) chime();
|
||||||
lastHour = h;
|
lastHour = h;
|
||||||
lastMinute = m;
|
lastMinute = m;
|
||||||
// check again in 1 minute
|
queueNextCheckMins(1);
|
||||||
|
break;
|
||||||
var mLeft = 1,
|
default:
|
||||||
sLeft = mLeft * 60 - s,
|
|
||||||
msLeft = sLeft * 1000 - ms;
|
|
||||||
setTimeout(check, msLeft);
|
|
||||||
} else {
|
|
||||||
if (h !== lastHour && m === 0) chime();
|
if (h !== lastHour && m === 0) chime();
|
||||||
lastHour = h;
|
lastHour = h;
|
||||||
// check again in 60 minutes
|
queueNextCheckMins(60);
|
||||||
var mLeft = 60 - m,
|
break;
|
||||||
sLeft = mLeft * 60 - s,
|
|
||||||
msLeft = sLeft * 1000 - ms;
|
|
||||||
setTimeout(check, msLeft);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue