2022-03-31 09:17:05 +00:00
|
|
|
// adapted from https://github.com/hallettj/Fuzzy-Text-International/
|
2023-01-12 20:46:34 +00:00
|
|
|
{
|
|
|
|
const SETTINGS_FILE = "fuzzyw.settings.json";
|
2022-03-31 11:56:53 +00:00
|
|
|
|
2023-01-12 20:46:34 +00:00
|
|
|
let fuzzy_string = {
|
2022-04-20 21:01:54 +00:00
|
|
|
"hours":[
|
|
|
|
/*LANG*/"twelve",
|
|
|
|
/*LANG*/"one",
|
|
|
|
/*LANG*/"two",
|
|
|
|
/*LANG*/"three",
|
|
|
|
/*LANG*/"four",
|
|
|
|
/*LANG*/"five",
|
|
|
|
/*LANG*/"six",
|
|
|
|
/*LANG*/"seven",
|
|
|
|
/*LANG*/"eight",
|
|
|
|
/*LANG*/"nine",
|
|
|
|
/*LANG*/"ten",
|
|
|
|
/*LANG*/"eleven"
|
|
|
|
],
|
|
|
|
"minutes":[
|
|
|
|
/*LANG*/"*$1 o'clock",
|
|
|
|
/*LANG*/"five past *$1",
|
|
|
|
/*LANG*/"ten past *$1",
|
|
|
|
/*LANG*/"quarter past *$1",
|
|
|
|
/*LANG*/"twenty past *$1",
|
|
|
|
/*LANG*/"twenty five past *$1",
|
|
|
|
/*LANG*/"half past *$1",
|
|
|
|
/*LANG*/"twenty five to *$2",
|
|
|
|
/*LANG*/"twenty to *$2",
|
|
|
|
/*LANG*/"quarter to *$2",
|
|
|
|
/*LANG*/"ten to *$2",
|
|
|
|
/*LANG*/"five to *$2"
|
|
|
|
]
|
2024-05-07 07:52:40 +00:00
|
|
|
};
|
2022-03-31 11:56:53 +00:00
|
|
|
|
2024-05-07 07:52:40 +00:00
|
|
|
let text_scale = 4;
|
|
|
|
let timeout = 2.5*60;
|
|
|
|
let drawTimeout;
|
|
|
|
let animInterval;
|
|
|
|
let time_string = "";
|
|
|
|
let time_string_old = "";
|
|
|
|
let time_string_old_wrapped = "";
|
|
|
|
let settings = {};
|
2022-04-06 11:49:59 +00:00
|
|
|
|
2024-05-07 07:52:40 +00:00
|
|
|
let loadSettings = function() {
|
|
|
|
settings = require("Storage").readJSON(SETTINGS_FILE,1)|| {'showWidgets': false, 'animate': true};
|
|
|
|
};
|
2023-01-12 20:46:34 +00:00
|
|
|
|
2024-05-07 07:52:40 +00:00
|
|
|
let queueDraw = function(seconds) {
|
|
|
|
let millisecs = seconds * 1000;
|
|
|
|
if (drawTimeout) clearTimeout(drawTimeout);
|
|
|
|
drawTimeout = setTimeout(function() {
|
|
|
|
drawTimeout = undefined;
|
|
|
|
draw();
|
|
|
|
}, millisecs - (Date.now() % millisecs));
|
|
|
|
};
|
2022-03-31 11:56:53 +00:00
|
|
|
|
2024-05-07 07:52:40 +00:00
|
|
|
let getTimeString = function(date) {
|
|
|
|
let segment = Math.round((date.getMinutes()*60 + date.getSeconds() + 1)/300);
|
|
|
|
let hour = date.getHours() + Math.floor(segment/12);
|
2024-05-08 08:22:50 +00:00
|
|
|
// add "" to load into RAM due to 2v21 firmware .replace on flashstring issue
|
2024-05-08 21:14:06 +00:00
|
|
|
let f_string = ""+fuzzy_string.minutes[segment % 12];
|
2024-05-07 07:52:40 +00:00
|
|
|
if (f_string.includes('$1')) {
|
2024-05-08 08:22:50 +00:00
|
|
|
f_string = f_string.replace('$1', fuzzy_string.hours[(hour) % 12]);
|
2024-05-07 07:52:40 +00:00
|
|
|
} else {
|
2024-05-08 08:22:50 +00:00
|
|
|
f_string = f_string.replace('$2', fuzzy_string.hours[(hour + 1) % 12]);
|
|
|
|
}
|
|
|
|
return f_string;
|
2024-05-07 07:52:40 +00:00
|
|
|
};
|
2022-03-31 11:56:53 +00:00
|
|
|
|
2024-05-07 07:52:40 +00:00
|
|
|
let draw = function() {
|
|
|
|
time_string = getTimeString(new Date()).replace('*', '');
|
|
|
|
//print(time_string);
|
|
|
|
if (time_string != time_string_old) {
|
|
|
|
g.setFont('Vector', R.h/text_scale).setFontAlign(0, 0);
|
|
|
|
if (settings.animate) {
|
|
|
|
animate(3);
|
|
|
|
} else {
|
|
|
|
quickDraw();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
queueDraw(timeout);
|
|
|
|
};
|
|
|
|
|
|
|
|
let animate = function(step) {
|
|
|
|
if (animInterval) clearInterval(animInterval);
|
|
|
|
let time_string_new_wrapped = g.wrapString(time_string, R.w).join("\n");
|
|
|
|
let slideX = 0;
|
|
|
|
//don't let pulling the drawer change y
|
|
|
|
let text_y = R.y + R.h/2;
|
|
|
|
animInterval = setInterval(function() {
|
|
|
|
//blank old time
|
|
|
|
g.setColor(g.theme.bg);
|
|
|
|
g.drawString(time_string_old_wrapped, R.x + R.w/2 + slideX, text_y);
|
|
|
|
g.drawString(time_string_new_wrapped, R.x - R.w/2 + slideX, text_y);
|
|
|
|
g.setColor(g.theme.fg);
|
|
|
|
slideX += step;
|
|
|
|
let stop = false;
|
|
|
|
if (slideX>=R.w) {
|
|
|
|
slideX=R.w;
|
|
|
|
stop = true;
|
|
|
|
}
|
|
|
|
//draw shifted new time
|
|
|
|
g.drawString(time_string_old_wrapped, R.x + R.w/2 + slideX, text_y);
|
|
|
|
g.drawString(time_string_new_wrapped, R.x - R.w/2 + slideX, text_y);
|
|
|
|
if (stop) {
|
|
|
|
time_string_old = time_string;
|
|
|
|
clearInterval(animInterval);
|
|
|
|
animInterval=undefined;
|
|
|
|
time_string_old_wrapped = time_string_new_wrapped;
|
|
|
|
}
|
|
|
|
//print(Math.round((getTime() - time_start)*1000));
|
|
|
|
}, 30);
|
|
|
|
};
|
2023-01-30 19:46:17 +00:00
|
|
|
|
2024-05-07 07:52:40 +00:00
|
|
|
let quickDraw = function() {
|
|
|
|
let time_string_new_wrapped = g.wrapString(time_string, R.w).join("\n");
|
2023-01-30 19:46:17 +00:00
|
|
|
g.setColor(g.theme.bg);
|
2024-05-07 07:52:40 +00:00
|
|
|
g.drawString(time_string_old_wrapped, R.x + R.w/2, R.y + R.h/2);
|
2023-01-30 19:46:17 +00:00
|
|
|
g.setColor(g.theme.fg);
|
2024-05-07 07:52:40 +00:00
|
|
|
g.drawString(time_string_new_wrapped, R.x + R.w/2, R.y + R.h/2);
|
|
|
|
time_string_old_wrapped = time_string_new_wrapped;
|
|
|
|
};
|
2022-03-31 11:56:53 +00:00
|
|
|
|
2024-05-07 07:52:40 +00:00
|
|
|
g.clear();
|
|
|
|
loadSettings();
|
2022-03-31 11:56:53 +00:00
|
|
|
|
2024-05-07 07:52:40 +00:00
|
|
|
// Stop updates when LCD is off, restart when on
|
|
|
|
Bangle.on('lcdPower',on=>{
|
|
|
|
if (on) {
|
|
|
|
draw(); // draw immediately, queue redraw
|
|
|
|
} else { // stop draw timer
|
|
|
|
if (drawTimeout) clearTimeout(drawTimeout);
|
|
|
|
drawTimeout = undefined;
|
|
|
|
}
|
|
|
|
});
|
2022-03-31 11:56:53 +00:00
|
|
|
|
2024-05-07 07:52:40 +00:00
|
|
|
Bangle.setUI({
|
|
|
|
mode : 'clock',
|
|
|
|
remove : function() {
|
|
|
|
// Called to unload all of the clock app
|
|
|
|
if (drawTimeout) clearTimeout(drawTimeout);
|
|
|
|
drawTimeout = undefined;
|
|
|
|
if (animInterval) clearInterval(animInterval);
|
|
|
|
animInterval = undefined;
|
|
|
|
require('widget_utils').show(); // re-show widgets
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
Bangle.loadWidgets();
|
|
|
|
if (settings.showWidgets) {
|
|
|
|
Bangle.drawWidgets();
|
|
|
|
} else {
|
|
|
|
require("widget_utils").swipeOn(); // hide widgets, make them visible with a swipe
|
2023-01-12 20:46:34 +00:00
|
|
|
}
|
|
|
|
|
2024-05-07 07:52:40 +00:00
|
|
|
let R = Bangle.appRect;
|
|
|
|
draw();
|
2023-01-12 20:46:34 +00:00
|
|
|
}
|