-
• #2
Nice! The routing idea seems like it might be quite helpful.
My only concern with this is obviously there are pretty limited resources on the Bangle, and things like wrapper functions can end up chewing through them quite quickly.
If you haven't already it'd be well worth checking out https://www.espruino.com/Code+Style#other-suggestions and trying to make your library such that it can run without using too much memory. The more stuff you can keep in flash (which is really pretty big) the better!
-
• #3
Hey @Gordon - thanks for the feedback.
The final idea would be to have something that is zero dependencies and fully tree-shakable, but for now, it's just a concept idea - I've got some kind of pipeline compiling the library to a IIFE version and appending it with the app code, which is also IIFE and it works fine - but yes it's pulling 10K for that file.
I'm trying for the library being ESM/UMD which means it's importable and tree-shakable, and the output code being UMD with bundled dependencies but it seems a pain right now. It's something I might come back to.
(As it is if I made that select component more compact would it be useful in the core? It's an alternative to a menu but allowing a user prompt)
Hey everyone. So I've had my Bangle for a few days and I've been diving into discovering what it takes to make an app for the device.
My output so far is WatchmakerJS - https://github.com/tanepiper/watchmaker-js (with demo "Moods" app)
This is very very alpha - there are two parts included in it:
The library itself - https://github.com/tanepiper/watchmaker-js/tree/main/packages/watchmaker/watchmaker/src/lib
A basic app using it: https://github.com/tanepiper/watchmaker-js/blob/main/packages/apps/wmaker/src/main.ts
The library includes a few wrapper functions around
E
methods, using some additional library code to take strings and turn them into pages of content. There is also a new UI component I called a "Scroll Prompt" that is a cross between a Prompt and a Menu: https://github.com/tanepiper/watchmaker-js/blob/main/packages/watchmaker/watchmaker/src/lib/ui.ts#L117Here is only shows two options - but like a menu it supports as many options as provided
The biggest part of the library is
lug
- A small application framework that allows routable applications to be created and handles some additional stuff:.goTo
method that allows you to define your application flowinit
for setting app state,first
for the first transition after app state loaded andonChange
when each route change happens.So far these are the things I've found I needed to make a fast, memory-efficient app. Since implementing these new techniques my initial app - which ran out of memory - now barely pushes total memory usage over 60%
I've written an initial app for it - The Moods App - https://github.com/tanepiper/watchmaker-js/blob/main/packages/apps/wmaker/src/main.ts
Data is saved each time a new mood is added - which can include HRM and Geolocation data - it's also saved by reading the current file, appending the new record to the beginning and resaving - this means re-reading data the latest is always at the top. This makes re-reading data much more efficient than having to read the whole file to get the latest data.
There are instructions to build the library and the app - currently, the app requires the library and I'm still figuring out the tooling to bundle correctly - otherwise, the library needs to be included in the BangleApps module folder and as it's still early release I'd prefer not to add the app just now.
The overall size of apps is still on the large size - there's also an issue with the Terser plugin causing code to fail when uploaded to the Bangle, but that works perfectly fine unminified. However once on the device the app is quick and efficient with data.
Would love to get some feedback on this in terms of usefulness and also potential features (also on anything anyone sees as a nono!)