Update app.js

Cache font size calculations
master
Andrew Gregory 2022-03-08 21:52:57 +08:00 committed by GitHub
parent 915ad63947
commit d7def5d5e1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 22 additions and 23 deletions

View File

@ -18,18 +18,6 @@ var settings = require("Storage").readJSON("authentiwatch.json", true) || {token
if (settings.data ) tokens = settings.data ; /* v0.02 settings */ if (settings.data ) tokens = settings.data ; /* v0.02 settings */
if (settings.tokens) tokens = settings.tokens; /* v0.03+ settings */ if (settings.tokens) tokens = settings.tokens; /* v0.03+ settings */
// QR Code Text
//
// Example:
//
// otpauth://totp/${url}:AA_${algorithm}_${digits}dig_${period}s@${url}?algorithm=${algorithm}&digits=${digits}&issuer=${url}&period=${period}&secret=${secret}
//
// ${algorithm} : one of SHA1 / SHA256 / SHA512
// ${digits} : one of 6 / 8
// ${period} : one of 30 / 60
// ${url} : a domain name "example.com"
// ${secret} : the seed code
function b32decode(seedstr) { function b32decode(seedstr) {
// RFC4648 // RFC4648
var buf = 0, bitcount = 0, retstr = ""; var buf = 0, bitcount = 0, retstr = "";
@ -75,6 +63,10 @@ function do_hmac(key, message, algo) {
var v = new DataView(ret, ret[ret.length - 1] & 0x0F, 4); var v = new DataView(ret, ret[ret.length - 1] & 0x0F, 4);
return v.getUint32(0) & 0x7FFFFFFF; return v.getUint32(0) & 0x7FFFFFFF;
} }
function formatOtp(otp, digits) {
var re = (digits % 3 == 0 || (digits % 3 >= digits % 4 && digits % 4 != 0)) ? "" : ".";
return otp.replace(new RegExp("(..." + re + ")", "g"), "$1 ").trim();
}
function hotp(d, token, dohmac) { function hotp(d, token, dohmac) {
var tick; var tick;
if (token.period > 0) { if (token.period > 0) {
@ -98,8 +90,7 @@ function hotp(d, token, dohmac) {
ret = "0" + ret; ret = "0" + ret;
} }
// add a space after every 3rd or 4th digit // add a space after every 3rd or 4th digit
var re = (token.digits % 3 == 0 || (token.digits % 3 >= token.digits % 4 && token.digits % 4 != 0)) ? "" : "."; ret = formatOtp(ret, token.digits);
ret = ret.replace(new RegExp("(..." + re + ")", "g"), "$1 ").trim();
} catch(err) { } catch(err) {
ret = notsupported; ret = notsupported;
} }
@ -107,6 +98,7 @@ function hotp(d, token, dohmac) {
return {hotp:ret, next:((token.period > 0) ? ((tick + 1) * token.period * 1000) : d.getTime() + 30000)}; return {hotp:ret, next:((token.period > 0) ? ((tick + 1) * token.period * 1000) : d.getTime() + 30000)};
} }
var fontsz_cache = {};
var state = { var state = {
listy: 0, listy: 0,
prevcur:0, prevcur:0,
@ -117,12 +109,25 @@ var state = {
hide:0 hide:0
}; };
function size_font(id, txt, w) {
var sz = fontsz_cache[id];
if (sz) {
g.setFont("Vector", sz);
} else {
sz = tokendigitsheight;
do {
g.setFont("Vector", sz--);
} while (g.stringWidth(txt) > w);
fontsz_cache[id] = sz + 1;
}
}
function drawToken(id, r) { function drawToken(id, r) {
var x1 = r.x; var x1 = r.x;
var y1 = r.y; var y1 = r.y;
var x2 = r.x + r.w - 1; var x2 = r.x + r.w - 1;
var y2 = r.y + r.h - 1; var y2 = r.y + r.h - 1;
var adj, lbl, sz; var adj, lbl;
g.setClipRect(Math.max(x1, Bangle.appRect.x ), Math.max(y1, Bangle.appRect.y ), g.setClipRect(Math.max(x1, Bangle.appRect.x ), Math.max(y1, Bangle.appRect.y ),
Math.min(x2, Bangle.appRect.x2), Math.min(y2, Bangle.appRect.y2)); Math.min(x2, Bangle.appRect.x2), Math.min(y2, Bangle.appRect.y2));
lbl = tokens[id].label.substr(0, 10); lbl = tokens[id].label.substr(0, 10);
@ -137,10 +142,7 @@ function drawToken(id, r) {
} else { } else {
g.setColor(g.theme.fg) g.setColor(g.theme.fg)
.setBgColor(g.theme.bg); .setBgColor(g.theme.bg);
sz = tokendigitsheight; size_font("l" + id, lbl, r.w);
do {
g.setFont("Vector", sz--);
} while (g.stringWidth(lbl) > r.w);
// center in box // center in box
g.setFontAlign(0, 0, 0); g.setFontAlign(0, 0, 0);
adj = (y1 + y2) / 2; adj = (y1 + y2) / 2;
@ -160,10 +162,7 @@ function drawToken(id, r) {
adj = 12; adj = 12;
} }
// digits just below label // digits just below label
sz = tokendigitsheight; size_font("d" + id, state.otp, r.w - adj);
do {
g.setFont("Vector", sz--);
} while (g.stringWidth(state.otp) > (r.w - adj));
g.drawString(state.otp, (x1 + adj + x2) / 2, y1 + tokenextraheight, false); g.drawString(state.otp, (x1 + adj + x2) / 2, y1 + tokenextraheight, false);
} }
g.setClipRect(0, 0, g.getWidth(), g.getHeight()); g.setClipRect(0, 0, g.getWidth(), g.getHeight());