Weather module for Fitbit OS
This library permits to retrieve weather information from the device.
You can choose your favourite weather provider between OpenWeatherMap, DarkSky and Weatherbit
Installation
npm i fitbit-weather
Companion
Create an index.js file in the companion folder if you don't already have one.
Add the following code in this file :
import * as weather from 'fitbit-weather/companion'
weather.setup({ provider : weather.Providers.openweathermap, apiKey : 'YOUR_KEY' })
App
Add the following code in your app/index.js file
import * as weather from 'fitbit-weather/app'
weather.fetch(30 * 60 * 1000) // return the cached value if it is less than 30 minutes old
.then(weather => console.log(JSON.stringify(weather)))
.catch(error => console.log(JSON.stringify(error)))
API
- companion.setup({ provider, apiKey}) : configure the provider / apiKey used to fetch the weather
-
app.fetch(maximumAge = 0) : retrieve the weather, if given the parameter is the maximum age in milliseconds of a possible cached weather data that is acceptable to return. Default is
0
-
app.get() : returns immediately the last cached weather data (the value can be
undefined
when no data has been received)
Example of result
{
"temperatureC":15,
"temperatureF":59,
"location":"Castelnau-D'Estretefonds",
"description":"Mostly Clear",
"isDay":false,
"conditionCode":0,
"realConditionCode":"this is the real conditioncode returned by the provider",
"sunrise":1507442496594,
"sunset":1507483356594,
"timestamp":1507496916594
}
Condition codes
const Conditions = {
ClearSky : 0,
FewClouds : 1,
ScatteredClouds : 2,
BrokenClouds : 3,
ShowerRain : 4,
Rain : 5,
Thunderstorm : 6,
Snow : 7,
Mist : 8,
Unknown : 1000,
}
Providers codes
const Providers = {
openweathermap : "owm",
darksky : "darksky",
weatherbit : "weatherbit"
}
TypeScript
Developer who are using TypeScript could include type definitions from or fitbit-weather-types.
npm i @types/fitbit-weather
Contribution
I'm not a javascript expert so every comment/code reactoring/best practice is appreciated. Don't hesitate to make PR and tell me what's wrong.