Magic Mirror Module - Display public transport in Stockholm/Sweden. This module use the API's provided by Trafiklab.
You need to obtain your own API key's from TrafikLab in order to use this module. API keys are free and are obtained by creating an account and a so-called project at Trafiklab.se. You need to retrieve keys for the following API's:
- Clone repository into
../modules/
inside your MagicMirror folder. - Run
npm install
inside../modules/MMM-SL-PublicTransport/
folder - Run
node findStation.js apiKey stationName
to find out your Station ID. - Add the module to the MagicMirror config
- Run
git pull
inside../modules/MMM-SL-PublicTransport/
folder. - Run
npm install
inside../modules/MMM-SL-PublicTransport/
folder
Note: In release 1.5 there is a major change of the configuration. Please read through carefully and update your configration appropriately.
All features present in earlier releases are available but you need to redefine your configuration. The new configuration stations
will
allow you to define in more detail what you want to see. For examples see the section How to use the stations parameter below.
Keep in mind that your configuration should not exceed the Trafiklab quota of 10.000 API calls per month. You can find more examples on this below
modules: [
...
{
module: 'MMM-SL-PublicTransport',
position: 'top_right',
header: 'Busses',
config: {
apikey: 'your-api-key', // REQUIRED.
stations: [ // REQUIRED at least one entry.
// Definition of the stations that you would like to see
{
stationId: station-id, // REQUIRED. An id of a station. You need to run the utility
// findStation to get the id(s) of the station(s) you want.
stationName: 'station-name',// Optional. This is the name of the station.
// It's shown in the header if you have set a header on the module
excludeTransportTypes: [], // Optional. This is an array of types of transport that you DONT
// want to see. If not present then all transport types are shown.
// The types are: 'Bus', 'Train', 'Metro', 'Tram' and 'Ship'.
lines: [ // Optional. An array of lines that you want to see departing from
// this station.
{
line: line-id, // The id of the line. If its a line with a letter in the line number
// the line-id has to be a string like "line: '42x'"
direction: dir, // Optional. If present only show departures in this direction
// for this line.
swapDir: false // Optional. If true, change dir 1 to 2 and vice versa.
// Shall be used with the "In to town" feature. Note that
// if direction is defined, that shall be direction swapped to.
}
]
},
],
maxDestinationLength: 999, // Optional, will truncate the destination string to the set length.
displaycount: 10, // Optional, show this number of departures for each direction.
dontDisplayIfAlmostleft: 3*60, // Optional, hides departues with time left less then this value in seconds
// Note that you need to set the omitDeparturesLeft parameter to true for
// this to take effect. Also useDisplayTime has to be set to false.
omitDeparturesLeft: false, // Optional, if set to true departures that have left the station
// is not shown.
showdisturbances: false, // Not implemented yet
fade: true, // Optional. Shall the table of departures be faded or not
fadePoint: 0.2, // Optional. Fraction from end where to start fading
delayThreshhold: 60, // Optional. If a departure is delayed or in advance only
// show this
// if the delay/advance is greater than this number in
// seconds.
updateInterval: 5*60*1000, // Optional. Number of milliseconds between calls to
// Trafiklab's API. This value shall preferably be larger then 1 min
// There are limitations on number of calls per minute and month
highUpdateInterval: {}, // Optional if you dont need it don't define it.
// If defined use higher frequences for updates, see
// "Set what times to update more frequently" below
uiUpdateInterval: 1000, // Optional. Number of milliseconds between updates of the
// departure list. This value shall preferably be less then 10 sec
SSL: false, // Optional. Use https to access the TrafikLab services,
// defaults to false since I have experienced problems
// accessing this service over https. Have an ongoing
// discussion with TrafikLab
debug: false, // Optional. Enable some extra output when debugging
ignoreSanityCheck: false, // Optional. If set to true config sanity checks are not done.
useDisplayTime: false, // Optional. If true use the actual displaytime that is
// received via the API instead of the ExpectedDateTime and
// TimeTabledDateTime. See the DisplayTime section below.
cleanHeader: false, // If set to true the last update time is not shown
// in the header
showIcon: true // Optional. If true show an icon of the type of transport
}
},
...
]
By default the following sanity checks are done on the configuration. The sanity checks can be ignored with the ignoreSanityCheck
parameter.
updateInterval
shall be larger or equal to 1 min (1*60*1000 milliseconds)uiUpdateInterval
shall be smaller or equal to 10 sec (10*1000 milliseconds)
With the stations
configuration parameter you are able to in detail define what you want to see. The basic configuration is that if an optional parameter is not present everything will be shown, i.e. if the lines
parameter is not present for a station all lines will be displayed. However, if it is present you will need to define all lines that you want to see.
Show all departures from one station:
...
stations: [
{
stationId: 2322,
stationName: 'Erikslund'
}
]
...
Show all departures from two station:
...
stations: [
{
stationId: 2322,
stationName: 'Erikslund'
},
{
stationId: 2321,
stationName: 'Täbyvägen'
}
]
...
Please note that having multiple stations will increase the number of API calls made since there's one call per station. You can mitigate this by carefully setting the updateInterval
and highUpdateInterval
configuration parameters.
Also, having multiple stations will increase the space that this module takes on screen so use the displaycount
parameter to limit the number of departures shown.
Show all departures from one station and only line 610 from the other station:
...
stations: [
{
stationId: 2322,
stationName: 'Erikslund'
},
{
stationId: 2321,
stationName: 'Täbyvägen',
lines: [{
line: 610
}]
}
]
...
Show all departures from one station and only line 610 from the other station in one direction:
...
stations: [
{
stationId: 2322,
stationName: 'Erikslund'
},
{
stationId: 2321,
stationName: 'Täbyvägen',
lines: [{
line: 610,
direction: 1
}]
}
]
...
"In To Town" If you only want to see the departures "in to town" and your station has several lines that have different directions "in to town" you can configure the module like this. For one station, show all directions for line 611, for line 616 show only direction 1 (swapDir will change 1->2 and 2->1). Line 616 direction 1 will be shown together with 611 direction 2:
...
stations: [
{
stationId: 2322,
stationName: 'Erikslund'
lines: [
{
line: 611
},
{
line: 616,
direction: 2,
swapDir: true
}
]
}
]
...
If you want the module to update departure times more frequently between certain hours use the highUpdateInterval
config parameter. By using this parameter, you can reduce the refresh rate during 'quiet' hours, for example once every 6 minutes,
but still receive frequent updates (for example, every 2 minutes) when leaving for work of school in the morning.
You can define the updateInterval for these "high-frequency update periads" per period or for all periods. When you
define the updateInterval on a specific period, the general updateInterval will be overwritten.
This parameter is used like this:
...
updateInterval: 5*60*1000,
highUpdateInterval: {
updateInterval: 1*60*1000,
times: [
{days: 'weekdays', start: '07:00', stop: '09:00'},
{days: 'weekends', start: '16:00', stop: '18:00', updateInterval: 2*60*1000}
]
},
...
where
updateInterval
is the frequency to use during the high update periodstimes
is an array of time ranges defined bydays
is one of'weekdays'
meaning Monday to Friday'weekends'
meaning Saturday and Sunday
start
is time of day when the high update should start in hh:mm formatstop
is time of day when the high update should stop in hh:mm format
In the example above the module will update the departures every 5th minute but between 7 and 9 weekdays it will update every minute, and 16 and 18 on weekends the update will be done every 2 minutes. You can have as many entries in the times array as you want.
The Trafiklab API will return a number of different departure times, TimeTabledDateTime, ExpectedDateTime and DisplayTime. Originally this module used the two first to calculate the departure time and display it. However, it has turned out that for some metro lines these are null (do not have a value) due to some infrastructure changes going on.
When that was discovered the useDisplayTime
configuration parameter was introduced. It is false per default but if it's true the DisplayTime value is presented instead of the calculated departure time based on TimeTabledDateTime and ExpectedDateTime.
Also, if the TimeTabledDateTime and ExpectedDateTime do not have a value (are null) the DisplayTime is used instead. The following screenshot shows how it looks when having useDisplayTime
set to false and have a station that returns null for TimeTabledDateTime and ExpectedDateTime.
You see that the station Midsommarkransen uses DisplayTime (it's a dot '.' at the end) but the station Erikslund uses the calculated departure time from TimeTabledDateTime and ExpectedDateTime.
Note that if DisplayTime is used there is (currently) no update of that value between uiUpdateInterval
. So if there is a big difference between uiUpdateInterval
and updateInterval
there will be a discrepancy. This will be handled in future releases.
You need to set a stationid in the configuration and to find that run the following helper
node findStation.js apikey searchstring
where apikey
is your API key for the SL Platsuppslag API and searchstring
is the name of the station.
NOTE: This API key is not the same as the API key for "SL Realtidinformation 4" API that you have to enter in the module configuration.
The output will look something like this (searching for 'Erikslund'). Use the SiteId value as the stationid:
{
"StatusCode": 0,
"Message": null,
"ExecutionTime": 0,
"ResponseData": [
{
"Name": "Erikslund (Täby)",
"SiteId": "2322",
"Type": "Station",
"X": "18044128",
"Y": "59464947"
},
{
"Name": "Erikslundsvägen (Täby)",
"SiteId": "2329",
"Type": "Station",
"X": "18054079",
"Y": "59462808"
},
...