Skip to content

Magic Mirror module - Display public transport in Stockholm/Sweden.

License

Notifications You must be signed in to change notification settings

trafiklab/MMM-SL-PublicTransport

 
 

Repository files navigation

MMM-SL-PublicTransport

Magic Mirror Module - Display public transport in Stockholm/Sweden. This module use the API's provided by Trafiklab.

SL PublicTransport Module

Get API key

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:

Install

  1. Clone repository into ../modules/ inside your MagicMirror folder.
  2. Run npm install inside ../modules/MMM-SL-PublicTransport/ folder
  3. Run node findStation.js apiKey stationName to find out your Station ID.
  4. Add the module to the MagicMirror config

Update

  1. Run git pull inside ../modules/MMM-SL-PublicTransport/ folder.
  2. Run npm install inside ../modules/MMM-SL-PublicTransport/ folder

Configuration

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)

How to use the stations parameter

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.

Examples

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
                }
            ]
        }
    ]
    ...

Frequent update times

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 periods
  • times is an array of time ranges defined by
    • days 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 format
    • stop 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.

Use DisplayTime

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.

SL PublicTransport Module

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.

Find stationid

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"
        },
        ...

Screenshot

SL PublicTransport Module

About

Magic Mirror module - Display public transport in Stockholm/Sweden.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 100.0%