The app's name is "Owlet", which means baby owl and is chosen because of the Nightscout project logo.
This is the cross-platform application, built with Electron framework, that uses the Nightscout API. The aim is to provide a lightweight interface for your T1D
measurement visualization (blood sugar levels).
The widget will stay on top of your screen, so you don't need to keep your Nightscout site in the browser opened to see your/your relative's or kid's measurements in real-time anymore.
I was inspired by the mlukasek/M5_NightscoutMon solution, built on M5 Stack's hardware platform.
LINUX user, expand it and read..
The widget is packed in an [AppImage](https://appimage.org/) package due to the following reasons:
- It runs on all common Linux distributions
- It supports an auto-update feature (but doesn't support notification about it)
- AppImage usage simplifies the development process and testing on many different Linux distributions
I recommend using AppImageLauncher to properly integrate the AppImage into the OS and create all the necessary .desktop
files to launch it as an installed application. However, this decision is entirely up to you. You can launch the application immediately after downloading from the folder you choose to download and create the .desktop
file manually.
Please install the listed dependencies using the OS package manager:
- wmctrl
- xdg-utils
Without these listed dependencies, the widget will still work, but it might be difficult to manage the window states properly (wmctrl
is used to hide the app from the application panel and tray) and to open other applications (xdg-open
is used to open the browser for redirecting to the Nightscout site and open the file manager to navigate to the logs folder).
Without these packages, the widget will alert you about the missing dependencies once a day on every launch.
Auto-update may cause freezing. The application starts checking for updates right after the launch, but only once a day. If it finds a new version in the latest releases, it will begin downloading and replacing the AppImage on your drive, which usually takes about 1-2 minutes. If the application freezes, you need to wait until it awakens, or alternatively, you can kill the process using the ps
command and restart it.
The issue is related to the lack of usability of the notification-daemon
. Sometimes, the D-Bus service doesn't configure properly, and as a result, the notify-send
command cannot be executed. If the notify-send
command works fine on your distribution, then it is not your issue, and everything should function properly.
Please note that the AppImage doesn't have yet a built-in mechanism to notify about the updates. If you are knowledgeable about how to implement this feature, you are welcome to contribute by submitting a pull request; I would sincerely appreciate it.
‼️ THIS IS VERY IMPORTANT: You have to be sure that all steps are done before you make the first launch!
- Log in to the admin panel of your Nightscout site (e.g. https://some-cgm.site.com/admin/)
- Create a new role with permission to read data using the pattern
*:*:read
- Create a new subject for the application with the role created in step 2, or use an existing role with the pattern to read data
*:*:read
- Copy the access token for this subject to your clipboard or save it
On the first launch, the app will prompt you to fill in the following settings
- NIGHTSCOUT URL - is the address of your nightscout (e.g. https://some-cgm.fly.dev)
- NIGHTSCOUT TOKEN - the access token you've created on the previous steps
- NIGHTSCOUT REQUEST INTERVAL (SEC.) - (default: 60) the interval of the getting information from the Nightscout site to display in the widget
- AGE LIMIT (MIN.) - (default: 20) the timeout of data requesting interval, after that interval widget will change its appearance to a "frozen" state. This typically indicates that the reader is offline, detached from the sensor, or the smartphone's battery is drained. If you prefer the widget not to freeze, you can set this property to 0. The maximum allowable value for this field, as well as the maximum value shown, is 999 minutes.
-
SHOW AGE - (default: enabled) that option displays additional information about how old the shown data is
-
UNITS IN MMOL/L - (default: enabled) that option allows to display sensor glucose values in mmol/l instead of mg/d. If you decide to modify this setting, ensure that you adjust all the blood sugar level preferences based on the selected units of measurement as well. When changing units of measurement, the color display of SGV values will be disabled until the settings are saved.
-
CALC TREND - (default: disabled) This option allows to calculate the direction of the trend using the last six received (for the last half an hour) SGV values. You may find it useful when your sensor doesn't have built-in option (e.g., Dexcom, Medtronic) and the Nightscout API doesn't store this value. In such cases, you will see a
-
symbol in the bottom right corner of the widget all the time instead of a trend arrow.
The app uses the following Abbot™ FreeStyle Libre™ sensors algorithm to recognize the trend pattern.
You can find more information on the approach to using trend arrows to adjust insulin doses in the article of the Journal of the Endocrine Society: Approach to Using Trend Arrows in the FreeStyle Libre Flash Glucose Monitoring Systems in Adults.
PDF version available for downloading.
Set the blood sugar tracking parameters using the following guides:
- Above the HIGH LEVEL TRESHOLD (default: 10) and below th LOW LEVEL THRESHOLD (default: 3.5) the last value will be colored in red
- Above the TARGET TOP LEVEL (default: 8.5) and below the TARGET BOTTOM LEVEL (default: 4) the last value will be colored in orange
- By default, the last value will be colored in green
- You may test the entered connection parameters by clicking the TEST button to verify the Nightscout site is accessible and the token is correct
- If everything is ok, press the SAVE button to save settings and restart the application
- You can choose the settings language by clicking on the top left EN icon and selecting your preferred language.
-
Currently, the application offers the following languages:
- English
- Italian
- Polish
- Russian
-
If you feel confident and have a good grasp of a foreign language, you can contribute to the translation of the application by becoming a project contributor on POEditor.
- After restarting, the widget will always stay on top of the screen until you close it by clicking the top left corner with the X sign.
- If you need to change the settings you can click by the gear symbol in the bottom left corner.
- If you want to fast navigate to the Nightscout site, you can click the middle button with the graph symbol.
- The widget has a built-in implementation of the update system.
- The widget will check for the latest release availability every time it starts, but only once a day.
- If the latest release is available, the widget will automatically download and install it right after exiting.
- On Mac and Windows operating systems, users will receive a notification about the newly downloaded version.
- On Linux, the notification doesn't work properly yet.
- Unit tests coverage using Jest
- Create landing page of the project based on Jekyll
- Replace the Electron engine for the Tauri app
If you feel desire to improve it or help. You can suggest any ideas or detected bugs to the project board.
The current application includes these files:
package.json
- Points to the app's main file and lists its details and dependencies.main.js
- Starts the app and creates a widget. This is the app's main process.widget.html
- An HTML file for the main window. This is the app's renderer process starting point.settings.html
- An HTML file for the settings window. This is the app's settings.styles.css
- Styles for the renderer processjs/widget.js
- The app's core renderer process JS code.js/settings.js
- The settings form renderer process JS code.js/logger.js
- Logger adapter for electron-log library.js/preload.js
- The API interface for IPC messaging between main process and renderer process.js/backend.js
- The code to obtain data from Nightscout API using AJAX.js/util.js
- The JS code to adapt collected data to a human-readable view.js/auto-update.js
- The app's auto-updater JS implementation.js/translator.js
- This file contains the implementation of the localization JS class.js/localization/{lang}.json
- These files contain key sets for localization, with {lang} being a placeholder for the specific language code.js/config-schema.json
- The app's config json schema validation file.js/config-sample.json
- The app's config.json examplejs/config-default.json
- The default values for the config.jsonbuild/
- The build directory contains the necessary files for building the application on your host from the source code.docs/
- Screenshots for this README.
To clone and run this repository, you'll need Git and Node.js (which comes with npm) installed on your computer. From your command line do:
# Clone this repository
git clone https://github.com/kashamalasha/nightscout-widget-electron
# Go into the repository
cd nightscout-widget-electron
# Install dependencies
npm install
# Run the app
npm start
# Or run in developer mode for deeper logging and debugging
npm run dev
Compatible with:
- MacOS,
- MS Windows,
- Linux (tested on Ubuntu, Fedora, CentOS, Alma on GNOME Desktop and XFCE)
You can build a native application for your operating system's preferences from the source code using one of these tools:
- electron-forge
- electron-builder (currently using)
- electronjs.org/docs - all of Electron's documentation
- electron.build - electron-builder documentationn
- Nightscout API v3 - Nightscout API v3 documentation
- Icons8.com - Great icons and assets collection that I used in this project
- POEditor - localization of the application
Feel free to contact me any of these ways:
🙏 I'll appreciate any feedback!