Il nome dell'app è "Owlet", che significa piccolo gufo ed è scelto per via del logo del progetto Nightscout.
Questa è un'applicazione multipiattaforma, creata con framework Electron, che utilizza le API Nightscout. L'obiettivo è fornire un'interfaccia leggera per la visualizzazione della misurazione del livello di zucchero nel sangue per i T1D.
Il widget rimarrà in primo piano sullo schermo, quindi non avrai più bisogno di tenere aperto il tuo sito Nightscout nel browser per vedere le tue misurazioni, di un tuo parente o di un bambino in tempo reale.
Sono stato inspirato dalla soluzione mlukasek/M5_NightscoutMon, creata per l'hardware M5 Stack's.
Utenti LINUX, aprite questa sezione e leggete...
Il widget è incluso in un pacchetto [AppImage](https://appimage.org/) per i seguenti motivi:
- Funziona su tutte le comuni distribuzioni Linux
- Supporta una funzione di aggiornamento automatico (ma non supporta la notifica a riguardo)
- L'utilizzo di AppImage semplifica il processo di sviluppo e test su molte distribuzioni Linux diverse
Consiglio di utilizzare AppImageLauncher per integrare correttamente AppImage nel sistema operativo e creare tutti i file .desktop
necessari per avviarlo come applicazione installata. Tuttavia, questa decisione dipende interamente da te. Puoi avviare l'applicazione subito dopo averla scaricata dalla cartella che hai scelto di scaricare e creare manualmente il file .desktop
.
Installa le dipendenze elencate utilizzando il gestore pacchetti del sistema operativo:
- wmctrl
- xdg-utils
Senza queste dipendenze elencate il widget funzionerà comunque ma potrebbe essere difficile gestire correttamente gli stati della finestra (wmctrl
viene utilizzato per nascondere l'app dal pannello e dalla barra delle applicazioni) e aprire altre applicazioni (xdg-open
viene utilizzato per aprire il browser per reindirizzare al sito Nightscout e aprire il file manager per accedere alla cartella dei registri).
Senza questi pacchetti, il widget ti avviserà delle dipendenze mancanti una volta al giorno ad ogni lancio.
L'aggiornamento automatico può causare il blocco. L'applicazione inizia a verificare la presenza di aggiornamenti subito dopo il lancio, ma solo una volta al giorno. Se trova una nuova versione inizierà a scaricare e a sostituire AppImage sul tuo disco, operazione che in genere richiede circa 1-2 minuti. Se l'applicazione si blocca, devi attendere finché non si riavvia o, in alternativa, puoi terminare il processo utilizzando il comando ps
e riavviarlo.
Il problema è legato alla mancanza di usabilità del daemon di notifica
. A volte, il servizio D-Bus non viene configurato correttamente e, di conseguenza, il comando "notify-send" non può essere eseguito. Se il comando notify-send
funziona bene sulla tua distribuzione, allora non è un tuo problema e tutto dovrebbe funzionare correttamente.
Tieni presente che AppImage non dispone ancora di un meccanismo integrato per notificare gli aggiornamenti. Se sei a conoscenza di come implementare questa funzionalità, puoi contribuire inviando una richiesta pull; Lo apprezzerei sinceramente.
‼️ MOLTO IMPORTANTE: Devi essere sicuro che tutti i passaggi siano stati eseguiti prima di effettuare il primo lancio!
- Autenticati nel pannello di amministrazione del tuo sito Nightscout (es. https://some-cgm.site.com/admin/)
- Crea un nuovo ruolo con i permessi di lettura usando questo pattern
*:*:read
- Crea un nuovo utente per la tua applicazione con il ruolo creato nello step 2, oppure usa un ruolo già esistente con il pattern di sola lettura
*:*:read
- Copia il token di accesso di questo utente negli appunti oppure salvalo
Al primo avvio l'app ti proporrà di compilare le seguenti informazioni
- URL NIGHTSCOUT - è l'indirizzo del tuo sito nightscout (e.g. https://some-cgm.fly.dev)
- TOKEN NIGHTSCOUT - il token di accesso che hai creato nei precedenti step
- INTERVALLO REQUEST NIGHTSCOUT (SEC.) - (default: 60) l'intervalli di tempo per l'aggiornamento dei dati da Nightscout da visualizzare nel widget
- INFO: LIMITE ETÀ (MIN.) - (default: 20) intervallo di timeout della richiesta dati, dopo questo intervallo il widget cambierà e mostrerà uno stato "congelato". Ciò indica in genere che il lettore è offline, staccato dal sensore o che la batteria dello smartphone è scarica. Se preferisci che il widget non si blocchi, puoi impostare questa proprietà su 0. Il valore massimo consentito per questo campo, così come il valore massimo mostrato, è 999 minuti.
-
MOSTRA ETÀ DATI - (default: enabled) questa opzione visualizza informazioni aggiuntive sull'età dei dati mostrati
-
UNITÀ IN MMOL/L - (default: enabled) questa opzione consente di visualizzare i valori glicemici del sensore in mmol/l anziché in mg/dl. Se decidi di modificare questa impostazione assicurati di regolare tutte le preferenze del livello di zucchero nel sangue anche in base alle unità di misura selezionate. Quando si modificano le unità di misura, la visualizzazione a colori dei valori SGV sarà disabilitata finché le impostazioni non verranno salvate.
-
CALCOLA TREND - (default: disabled) Questa opzione consente di calcolare la direzione del trend utilizzando gli ultimi sei valori SGV ricevuti (nell'ultima mezz'ora). Potresti trovarlo utile quando il tuo sensore non dispone di un'opzione integrata (ad esempio, Dexcom, Medtronic) e l'API Nightscout non memorizza questo valore. In questi casi, vedrai sempre un simbolo
-
nell'angolo in basso a destra del widget invece di una freccia di tendenza.
L' app usa il seguente algoritmo dei sensori Abbot™ FreeStyle Libre™ per riconoscere la tendenza.
È possibile trovare ulteriori informazioni sull'approccio all'utilizzo delle frecce di tendenza per regolare le dosi di insulina nell'articolo del Journal of the Endocrine Society: Approach to Using Trend Arrows in the FreeStyle Libre Flash Glucose Monitoring Systems in Adults.
PDF version disponibile per il download.
Imposta i parametri di monitoraggio della glicemia utilizzando le seguenti guide:
- Oltre il SOGLIA ALTO LIVELLO (default: 10) e sotto il SOGLIA BASSO LIVELLO (default: 3.5) l'ultimo valore verrà colorato di rosso
- Oltre il LIVELLO TARGET ALTO (default: 8.5) e sotto il LIVELLO TARGET BASSO (default: 4) l'ultimo valore verrà colorato di arancione
- Di default, l'ultimo valore è colorato di verde
- Puoi testare i parametri di connessione inseriti facendo clic sul pulsante TEST per verificare che il sito Nightscout sia accessibile e che il token sia corretto
- Se tutto è ok, premi il pulsante SALVA per salvare le impostazioni e riavviare l'applicazione
Puoi scegliere la lingua delle impostazioni facendo clic sull'icona EN in alto a sinistra e selezionando la lingua preferita.
-
Attualmente l'applicazione offre le seguenti lingue:
- English
- Italian
- Polish
- Russian
-
Se ti senti sicuro e hai una buona conoscenza di una lingua straniera, puoi contribuire alla traduzione dell'applicazione diventando collaboratore del progetto su POEditor.
- Dopo il riavvio il widget rimarrà sempre in primo piano sullo schermo finché non lo chiuderai facendo clic sull'angolo in alto a sinistra con il segno X.
- Se è necessario modificare le impostazioni è possibile fare clic sul simbolo dell'ingranaggio nell'angolo in basso a sinistra.
- Se vuoi navigare velocemente nel sito Nightscout puoi cliccare il pulsante centrale con il simbolo del grafico.
- Il widget ha un sistema di aggiornamento del sistema integrato.
- Il widget controllerà la disponibilità dell'ultima versione ogni volta che viene avviato, ma solo una volta al giorno.
- Se è disponibile l'ultima versione, il widget verrà scaricato e installato automaticamente subito dopo l'uscita.
- Sui sistemi operativi Mac e Windows, gli utenti riceveranno una notifica sulla versione appena scaricata.
- Su Linux, la notifica non funziona ancora correttamente.
- Unit tests coverage con Jest
- Creazione di una pagina landing del progetto con Jekyll
- Sostituzione di Electron con Tauri app
Se senti il desiderio di migliorarlo o di aiutare puoi suggerire qualsiasi idea o bug rilevato al project board.
La corrente applicazione include questi file:
package.json
: punta al file principale dell'app ed ne elenca i dettagli e le dipendenze.main.js
- Avvia l'app e crea un widget. Questo è il processo principale dell'app.widget.html
- Un file HTML per la finestra principale. Questo è il punto di partenza del processo di rendering dell'app.settings.html
- Un file HTML per la finestra delle impostazioni. Queste sono le impostazioni dell'app.styles.css
- Stili per il processo di renderingjs/widget.js
- Il codice JS principale del processo di rendering dell'app.js/settings.js
- Le impostazioni del modulo processo di rendering codice JS.js/logger.js
- Adattatore logger per libreria di log elettronici.js/preload.js
- L'interfaccia API per la messaggistica IPC tra il processo principale e il processo di rendering.js/backend.js
- Il codice per ottenere dati dall'API Nightscout utilizzando AJAX.js/util.js
- Il codice JS per adattare i dati raccolti a una visualizzazione leggibile dall'uomo.js/auto-update.js
- Implementazione JS dell'aggiornamento automatico dell'app.js/translator.js
- Questo file contiene l'implementazione della classe JS di localizzazione.js/localization/{lang}.json
- Questi file contengono set di chiavi per la localizzazione, dove {lang} è un segnaposto per il codice della lingua specifica.js/config-schema.json
- File di convalida dello schema json di configurazione dell'app.js/config-sample.json
- Esempio di config.json dell'appjs/config-default.json
- I valori predefiniti per config.jsonbuild/
- La directory build contiene i file necessari per creare l'applicazione sul tuo host dal codice sorgente.docs/
- Screenshot per questo README.
Per clonare ed eseguire questo repository, avrai bisogno di Git e Node.js (che viene fornito con npm) installato sul tuo computer. Dalla riga di comando esegui:
# Clona questo repository
git clone https://github.com/kashamalasha/nightscout-widget-electron
# Entra nel repository
cd nightscout-widget-electron
# Installa le dipendenze
npm install
# Avvia l'app
npm start
# Oppure eseguila in developer mode per un maggiore logging e debugging
npm run dev
Compatibile con:
- MacOS,
- MS Windows,
- Linux (testato su Ubuntu, Fedora, CentOS, Alma su GNOME Desktop e XFCE)
Puoi creare un'applicazione nativa per le preferenze del tuo sistema operativo dal codice sorgente utilizzando uno di questi strumenti:
- electron-forge
- electron-builder (attualmente in uso)
- electronjs.org/docs - tutta la documentazione di Electron
- electron.build - documentazione electron-builder
- Nightscout API v3 - documentazione Nightscout API v3
- Icons8.com - Fantastica raccolta di icone e risorse che ho utilizzato in questo progetto
- POEditor - localizzazione dell'applicazione
Sentitevi liberi di contattarmi in uno di questi modi:
🙏 Apprezzerò qualsiasi feedback!