Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[widclkinfo] Keeps focus when widget_utils.swipeOn() #3680

Draft
wants to merge 14 commits into
base: master
Choose a base branch
from
Draft
3 changes: 3 additions & 0 deletions apps/clock_info/lib.js
Original file line number Diff line number Diff line change
Expand Up @@ -299,12 +299,15 @@ exports.addInteractive = function(menu, options) {
const blur = () => {
options.focus=false;
Bangle.CLKINFO_FOCUS--;
// if (Bangle.CLKINFO_FOCUS < 0) Bangle.CLKINFO_FOCUS = 0;
const itm = menu[options.menuA].items[options.menuB];
let redraw = true;
if (itm.blur && itm.blur(options) === false)
redraw = false;
if (redraw) options.redraw();
};
// better to only call blur when we know it's focused. Maybe we can rename force_blur to ensure_blur.
options.force_blur = blur;
const focus = () => {
let redraw = true;
Bangle.CLKINFO_FOCUS = (0 | Bangle.CLKINFO_FOCUS) + 1;
Expand Down
135 changes: 93 additions & 42 deletions apps/widclkinfo/widget.js
Original file line number Diff line number Diff line change
@@ -1,50 +1,101 @@
if (!require("clock_info").loadCount) { // don't load if a clock_info was already loaded
// Load the clock infos
let clockInfoItems = require("clock_info").load();
// Add the
let clockInfoMenu = require("clock_info").addInteractive(clockInfoItems, {
app : "widclkinfo",
// Add the dimensions we're rendering to here - these are used to detect taps on the clock info area
x : 0, y: 0, w: 72, h:24,
// You can add other information here you want to be passed into 'options' in 'draw'
// This function draws the info
draw : (itm, info, options) => {
// itm: the item containing name/hasRange/etc
// info: data returned from itm.get() containing text/img/etc
// options: options passed into addInteractive
clockInfoInfo = info;
if (WIDGETS["clkinfo"])
WIDGETS["clkinfo"].draw(WIDGETS["clkinfo"]);
}
});
let clockInfoInfo; // when clockInfoMenu.draw is called we set this up
(() => {

Check failure on line 1 in apps/widclkinfo/widget.js

View workflow job for this annotation

GitHub Actions / build

App widclkinfo widget/clkinfo widclkinfo.wid.js should never totally clear the screen
if (!require("clock_info").loadCount) { // don't load if a clock_info was already loaded
//WIDGETS = {};
const clock_info = require("clock_info");

// The actual widget we're displaying
WIDGETS["clkinfo"] = {
area:"tl",
width: clockInfoMenu.w,
draw:function(e) {
clockInfoMenu.x = e.x;
clockInfoMenu.y = e.y;
var o = clockInfoMenu;
// Clear the background
area: "tl",
width: 0, //this.clockInfoMenu.w,
init: function() {
this.width = this.clockInfoMenu.w;
delete this.init;
return this;
},
clockInfoInfo: undefined, // defined during clockInfoMenu.draw()
clockInfoMenu: clock_info.addInteractive(clock_info.load(), {
app: "widclkinfo",
// Add the dimensions we're rendering to here - these are used to detect taps on the clock info area
x: 0,
y: 0, // TODO how know if offscreen to start?
w: 72,
h: 24,
// You can add other information here you want to be passed into 'options' in 'draw'
// This function draws the info
draw: (itm, info, options) => {
// itm: the item containing name/hasRange/etc
// info: data returned from itm.get() containing text/img/etc
// options: options passed into addInteractive
var wi = WIDGETS["clkinfo"];
wi.clockInfoInfo = info;
wi.clockInfoMenu.y = options.y;
if (WIDGETS["clkinfo"] && wi.clockInfoMenu.y > -24) {
WIDGETS["clkinfo"].draw(WIDGETS["clkinfo"]);
}
}
}),
draw: function(e) {
this.clockInfoMenu.x = e.x;
var o = this.clockInfoMenu;
g.reset();
// indicate focus - make background reddish
//if (clockInfoMenu.focus) g.setBgColor(g.blendColor(g.theme.bg, "#f00", 0.25));
if (clockInfoMenu.focus) g.setColor("#f00");
g.clearRect(o.x, o.y, o.x+o.w-1, o.y+o.h-1);
if (clockInfoInfo) {
// indicate focus
if (this.clockInfoMenu.focus) {
g.setColor("#f00");
}
g.clearRect(o.x, o.y, o.x + o.w - 1, o.y + o.h - 1);
if (this.clockInfoInfo) {
var x = o.x;
if (clockInfoInfo.img) {
g.drawImage(clockInfoInfo.img, x,o.y); // draw the image
x+=24;
if (this.clockInfoInfo.img) {
g.drawImage(this.clockInfoInfo.img, x, o.y); // draw the image
x += 24;
}
var availableWidth = o.x+clockInfoMenu.w - (x+2);
g.setFont("6x8:2").setFontAlign(-1,0);
if (g.stringWidth(clockInfoInfo.text) > availableWidth)
var availableWidth = o.x + this.clockInfoMenu.w - (x + 2);
g.setFont("6x8:2").setFontAlign(-1, 0);
if (g.stringWidth(this.clockInfoInfo.text) > availableWidth)
g.setFont("6x8:1x2");
g.drawString(clockInfoInfo.text, x+2,o.y+12); // draw the text
g.drawString(this.clockInfoInfo.text, x + 2, o.y + 12); // draw the text
}
}
};
}
}.init();

Bangle.on("widgets-start-show", () => {
var wi = WIDGETS["clkinfo"];
if (wi) {
wi.clockInfoMenu.y = 0;
wi.draw(wi);
}
});

Bangle.on("widgets-shown", () => {
var wi = WIDGETS["clkinfo"];
if (wi) {
wi.clockInfoMenu.y = 0;
wi.draw(wi);
}
});

Bangle.on("widgets-start-hide", () => {
var wi = WIDGETS["clkinfo"];
if (wi) {
if (wi.clockInfoMenu.focus) wi.clockInfoMenu.blur();
wi.clockInfoMenu.y = -24;
wi.draw(wi);
}
});

Bangle.on("widgets-hidden", () => {
var wi = WIDGETS["clkinfo"];
if (wi) {
if (wi.clockInfoMenu.focus) wi.clockInfoMenu.blur();
wi.clockInfoMenu.y = -24;
wi.draw(wi);
}
});
}})()

/*
const widget_utils = require("widget_utils");
g.clear();
Bangle.loadWidgets();
widget_utils.swipeOn();
Bangle.drawWidgets();
*/
17 changes: 14 additions & 3 deletions modules/widget_utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ exports.hide = function() {
w.area = "";
if (w.x!=undefined) g.clearRect(w.x,w.y,w.x+w.width-1,w.y+23);
}
Bangle.emit("widgets-hidden");
};

/// Show any hidden widgets
Expand All @@ -25,6 +26,7 @@ exports.show = function() {
delete w._area;
w.draw(w);
}
Bangle.emit("widgets-shown");
};

/// Remove anything not needed if the overlay was removed
Expand Down Expand Up @@ -132,9 +134,11 @@ exports.swipeOn = function(autohide) {
if (dir>0 && exports.offset>=0) { // fully down
stop = true;
exports.offset = 0;
Bangle.emit("widgets-shown");
} else if (dir<0 && exports.offset<-23) { // fully up
stop = true;
exports.offset = -24;
Bangle.emit("widgets-hidden");
}
if (stop) {
clearInterval(exports.animInterval);
Expand All @@ -153,12 +157,19 @@ exports.swipeOn = function(autohide) {
let cb;
if (exports.autohide > 0) cb = function() {
exports.hideTimeout = setTimeout(function() {
Bangle.emit("widgets-start-hide");
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would it work if we moved the widgets-start-show/hide into the start of the anim() function?

anim(-4);
}, exports.autohide);
};
if (ud>0 && exports.offset<0) anim(4, cb);
if (ud<0 && exports.offset>-24) anim(-4);
if (ud>0 && exports.offset<0) {
Bangle.emit("widgets-start-show");
anim(4, cb);
}
if (ud<0 && exports.offset>-24) {
Bangle.emit("widgets-start-hide");
anim(-4);
}
};
Bangle.on("swipe", exports.swipeHandler);
Bangle.drawWidgets();
};
};
Loading