This is a Kodi '2nd screen' project - i.e. for a second screen that runs alongside/below your main Kodi display, and which displays useful/related information about what is playing etc.
(Actually, if you just want a nice clock with some handy key weather data, you can just ignore the Kodi side of this altogether!).
This app provides a simple GUI dashboard which displays the current time, basic current & upcoming weather information, and - if Kodi is playing something - some simple Kodi 'Now Playing' information (Time Remaining and Poster/Thumbnail Artwork).
All of this with an easy to read '10ft' interface size - i.e. you should be able to see & read your screen comfortably, from a normal TV viewing position, some metres away.
The weather data is sourced from either OpenMeteo or, if you're in Australia, from the Australian Bureau of Meteorology.
The idea is that you can use pretty much any old tablet or smartphone for this (most of us have a few of those in the cupboard by now..). You could also use a Raspberry Pi with a screen. Really - just about anything you have really, as long as it can run a browser with some basic, albeit somewhat modern, features, and you can connect it to the same local network on which your Kodi is running).
Here's a few photos / screenshots to give you an idea.
Tablet under a TV, with Kodi playing a movie:
And some screenshots....
(And, remember, you're normally viewing this from 3 to 5 metres away, displayed on a screen maybe 6 to 9 inches in size!).
Above, displaying the weather information:
- Today's forecast High/Low - if before 6pm...
- ...otherwise, the forecast Overnight Low/Tomorrow High
- Rain Chance/Amount
- Actual rain recorded since 9am
- Current Temperature
- (Current 'Feels Like' Temperature)
- Current Time
- Weather Outlook Icon (animated weather icon)
- Weather Outlook Text
Above, displaying Kodi 'Now Playing' information:
- Kodi Artwork - e.g. poster / thumbnail / channel logo / album cover etc
- Time Remaining
- Current Temperature
- (Current 'Feels Like' Temperature)
- Current Time
For my own lounge-room, I am using a Samsung A7 Lite (about $185 from OfficeWorks IIRC) - which is simple but high quality 8-inch tablet, and runs for weeks/months at a time, with complete stability.
(With my mobile Kodi-a-go-go travelling setup, I use a much older Samsung A6 7-inch tablet, and that also works very well).
In practise, I use a Google Play store app called Fully Kiosk to actually load and display the 2nd Screen app URL - but really any tablet and basic browser should work (including iOS devices).
(Fully Kiosk is just a very handy app helps with things like keeping the screen always on, and automatically re-starting the app should there be a network connection issue, and so on. I bought a license for it (AU $15) because I am using it extensively, but the free version is all you actually need to get going with this. If you want more advanced features like on/off schedules for the tablet, you do need the paid version.)
We all stand on the shoulders of giants.
This project uses, and sends thanks to, these particular giants:
- Vite for dev/building/packaging
- Alpine.js for reactivity
- Tailwind CSS for CSS
- (Either) Australian Bureau of Meteorology for weather data
- (Or) OpenMeteo for weather data
- Meteocons for the weather icons
- Kodi - my media player of choice (since 2008!)
Support for this is via this Kodi OzWeather forum thread. Or just open an issue here.
Note, though - support for this will likely be quite limited as this is really just a personal project, and is very much provided 'as-is' - in case it is handy for other people as provided, or they want to use it as a base/starting point for their own similar project.
PRs welcome, of course. See Development below.
There is no 'installation' as such - this is just a basic web app that runs in a browser. To get it, you just go to the app's URL (see below) - and the app should then just come up in your browser.
(If you wish, you can download the app and use it offline and/or install it as a PWA (i.e. Progressive Web App, via 'Add to Home Screen'). If you download/install it, then from them on, the app runs locally and only communicates within your local network. But note PWA support can be a bit hit and miss and you may e.g. struggle to get things working correctly (e.g. in nice clean fullscreen view, without any menu bars)...the best way I have found is to use a Kiosk app, e.g. Fully Kiosk, as described above).
(You can also easily set up your own version to host, locally or otherwise, with any http server, should you wish - either by cloning this repo and building locally or just by downloading my hosted version).
(N.B. if using the default approach, i.e. just visiting the app url, note that this app is deliberately and necessarily served over HTTP, i.e. NOT HTTPS - specifically to avoid 'mixed content' warnings/errors that would otherwise result. This is a Kodi limitation - Kodi provides artwork etc. to this app, without SSL, using its internal webserver - and there is no cross-platform support for SSL with the Kodi internal webserver).
In your Kodi installation's settings, you must enable the Webserver, and JSON-RPC as well as 'allow control from other systems' (which enables the websockets interface which this app uses for communication with Kodi).
All of this is fine and essentially completely safe to do as long as your Kodi player is (as it almost always would be) hidden behind a router's NAT. Do not do this if your Kodi box is corrected directly to the internet (but that would be bad anyway, for a lot of reasons...).
Note, the whole app runs entirely locally in your browser - the app (which is just a web pages and some relatively basic JS code) - is completely downloaded to your browser, and then runs entirely within that.
Of course, it must be able to contact the weather provider you choose to retrieve the weather info, and must also be able to reach your Kodi installation on your local network (via your wi-fi should be more than adequate for this).
This is the basic URL to visit:
(important - must be http
NOT https
or communication with Kodi will not work!)
http://dash.bossanova808.net/
By default you will see a large clock and then some weather info.
Now, you need to provide some configuration. All configuration is done via URL parameters.
To use the default value, just don't supply the parameter. You can supply the parameters in any order.
kodi=
Kodi IP address. Default is 127.0.0.1
(i.e. locahost). Add your auth info if you need to.
.e.g. kodi=192.168.1.53
or kodi=user:password@127.0.0.1
kodi-web=
Kodi webserver port. Default is 8080
.
e.g. kodi-web=8088
kodi-json=
Kodi JSON RPC Port. Default is 9090
.
e.g. kodi-json=9999
If you're not in Australia, then you will need to provide OpenMeteo data - the latitude, longitude and timezone.
You can search for these at the top of this page: https://open-meteo.com/en/docs
And build URL arguments from those values, e.g.:
latitude=-37.814&longitude=144.9633&timezone=Australia%2FSydney
If you ARE in Australia, then definitely use this approach - the BOM weather data is much more accurate, and it's easier to set up.
bom=
BOM location ID. Default is r1r11df
(Ascot Vale, Melbourne).
You get this by querying the BOM localities API - just change the search string on the end of this url: https://api.weather.bom.gov.au/v1/locations/?search=kyneton
You'll get back some JSON, e.g.
{"metadata":{"response_timestamp":"2023-03-27T00:33:04Z"},"data":[{"geohash":"r1qsp5d","id":"Kyneton-r1qsp5d","name":"Kyneton","postcode":"3444","state":"VIC"},{"geohash":"r1qeyek","id":"Kyneton South-r1qeyek","name":"Kyneton South","postcode":"3444","state":"VIC"}]}
...from which you can then find your geohash (r1qsp5d
in the above example).
E.g. bom=r1r11df
size=
UI size. One of small
medium
or large
. Default is large
.
(Large is for tablets in the 7+ inch range, and small is e.g. for phones)
E.g. size=small
Putting it all together...
From the above, you build a full URL for your local deployment.
I.e. you start with the base URL (followed by a question mark to being the parameter list, i.e.:
http://dash.bossanova808.net/?
...and follow that with the rest of your parameters, with each separated by an ampersand (&
).
Of course once everything is working, you will just bookmark this URL (and e.g. set it as the URL in your Kiosk app) - so you don't have to remember all this stuff!
Some full examples:
Supplying your local Kodi machine's IP, the geohash for Kyneton, and setting the UI size to small:
http://dash.bossanova808.net/?kodi=192.168.1.51&bom=r1qsp5d&size=small
Similar, but with auth for the Kodi webserver, and specifying a non-standard port (9999) for the Kodi JSON-rpc, and using OpenMeteo weather information:
http://dash.bossanova808.net/?kodi=kodi:kodi@192.168.1.51&kodi-json=9999&latitude=-37.814&longitude=144.9633&timezone=Australia%2FSydney
(PRs will certainly be looked at but if you're going to add something you think might be generally useful perhaps open an issue here for initial discussion).
To get going for local development/tweaking for your particular need, all you really need to do is:
npm install
(or 'npm update' if you want to update dependencies)
npm run dev
(IMPORTANT: do not use the vite
or vite build
tools directly!)
Click on the URL Vite will then show in your terminal window, and you should have an HMR dev setup up and running (i.e. Hot Module Reload - which will automatically reload whenever you make changes).
To build for deployment if you want to host this yourself somewhere:
npm run build
Note that if you're not deploying to the root of your site, i.e. you're using a sub-folder for you deployment (something like http://your.site/kodidash
), then you will need to modify the vite.config.js
base
property (https://vite.dev/config/shared-options.html#base). See the commented out example.