BangleApps/apps/smpltmr/app.js

127 lines
3.0 KiB
JavaScript
Raw Normal View History

2022-02-25 16:14:19 +00:00
/*
* TIMER WIDGET
*
2022-02-25 16:14:19 +00:00
* This is a fork of the Chrono Widget, but implements a
* simpler UI which to be able to set a timer faster with
* less interaction. Additionally, it exposes some functions
* that can be used by other apps or clocks to easily
* implement a timer. It is used e.g. by lcars or notanalog.
*
* Creator: David Peer
* Date: 02/2022
*/
2022-02-23 20:47:22 +00:00
Bangle.loadWidgets();
const storage = require('Storage');
const alarm = require('qalarm');
2022-02-25 16:14:19 +00:00
let settings;
2022-02-23 19:10:09 +00:00
const screenWidth = g.getWidth();
const screenHeight = g.getHeight();
2022-02-23 20:53:27 +00:00
const cx = parseInt(screenWidth/2);
const cy = parseInt(screenHeight/2)-12;
var minutes = 5;
var interval; //used for the 1 second interval timer
2022-02-23 19:10:09 +00:00
function updateSettings() {
2022-02-25 16:14:19 +00:00
storage.writeJSON('widtmr.json', settings);
}
2022-02-23 20:47:22 +00:00
function resetSettings() {
2022-02-25 16:14:19 +00:00
settings = {
alarmIndex: -1
};
updateSettings();
}
2022-02-23 20:47:22 +00:00
2022-02-25 16:14:19 +00:00
settings = storage.readJSON('widtmr.json',1);
if (!settings) resetSettings();
2022-02-23 20:47:22 +00:00
setWatch(_=>load(), BTN1);
2022-02-23 19:10:09 +00:00
function draw(){
g.clear(1);
Bangle.drawWidgets();
if (interval) {
clearInterval(interval);
}
interval = undefined;
// Write time
2022-02-23 19:10:09 +00:00
g.setFontAlign(0, 0, 0);
g.setFont("Vector", 32).setFontAlign(0,-1);
var started = alarm.isTimerStarted(settings.alarmIndex);
var text = minutes + " min.";
if(started){
var min = alarm.getTimerMin(settings.alarmIndex);
text = min + " min.";
}
2022-03-04 16:35:34 +00:00
var rectWidth = parseInt(g.stringWidth(text) / 2);
2022-02-23 19:10:09 +00:00
if(started){
interval = setInterval(draw, 1000);
2022-02-23 19:10:09 +00:00
g.setColor("#ff0000");
} else {
g.setColor(g.theme.fg);
2022-02-23 19:10:09 +00:00
}
g.fillRect(cx-rectWidth-5, cy-5, cx+rectWidth, cy+30);
g.setColor(g.theme.bg);
g.drawString(text, cx, cy);
}
2022-02-23 20:47:22 +00:00
2022-02-23 19:10:09 +00:00
Bangle.on('touch', function(btn, e){
var left = parseInt(g.getWidth() * 0.25);
2022-02-23 19:10:09 +00:00
var right = g.getWidth() - left;
var upper = parseInt(g.getHeight() * 0.25);
2022-02-23 19:10:09 +00:00
var lower = g.getHeight() - upper;
var isLeft = e.x < left;
var isRight = e.x > right;
var isUpper = e.y < upper;
var isLower = e.y > lower;
var isMiddle = !isLeft && !isRight && !isUpper && !isLower;
print(settings.alarmIndex);
var started = alarm.isTimerStarted(settings.alarmIndex);
2022-02-23 19:10:09 +00:00
if(isRight && !started){
minutes += 1;
Bangle.buzz(40, 0.3);
} else if(isLeft && !started){
minutes -= 1;
Bangle.buzz(40, 0.3);
} else if(isUpper && !started){
minutes += 5;
Bangle.buzz(40, 0.3);
} else if(isLower && !started){
minutes -= 5;
Bangle.buzz(40, 0.3);
} else if(isMiddle) {
if(!started){
settings.alarmIndex = alarm.editTimer(settings.alarmIndex, 0, minutes, 0);
print("-----")
print(settings.alarmIndex);
print(alarm.timerExists(settings.alarmIndex))
print(alarm.isTimerStarted(settings.alarmIndex))
print("-----")
} else {
alarm.deleteTimer(settings.alarmIndex);
}
Bangle.buzz(80, 0.6);
2022-02-23 20:53:27 +00:00
}
2022-02-23 19:10:09 +00:00
updateSettings();
draw();
});
g.reset();
draw();