-
Notifications
You must be signed in to change notification settings - Fork 78
09 Notifications
As of v2.6.2 Material can send notifications from the LMS side to the web-app.
Notifications are invoked by sending JSONRPC messages to LMS. For example, this can
be accomplished with curl
as follows:
curl 'http://localhost:9000/jsonrpc.js' --data-raw '{"id":0,"method":"slim.request","params":["",["material-skin", "send-notif", "type:alert", "msg:The message"]]}'
- The
type
parameter accepts 5 values:-
type:info
shows a brief message -
type:error
shows a brief error (red background) message -
type:alert
shows the message within a dialog -
type:update
shows an update available icon next to main menu button and info in the 'Information' dialog -
type:notif
adds an 'bell' icon next to the main menu button (unless there are updates, in which case the update icon takes precedence) and adds a 'Notifications' entry to the main menu. This menu entry will then show a 'Notifications' dialog where the notifications are listed.
-
- The message body itself is sent with the
msg
parameter. -
cancelable:1
can be passed withtype:alert
, ortype:notif
, to allow user to cancel these.type:alert
notifications are cancelled via the 'Cancel' button on the dialog, andtype:notif
notifications are cancelled via the cancel icon next to the relevant list entry. -
title:string
needs to be passed withtype:update
to provide the title text shown in the 'Information' dialog, and totype:notif
messages where it is used as the list entry title. -
id:string
needs to be passed withtype:notif
to uniquely identify a notification, as there can be multiple of these. -
client:id
(e.g.client:01:02:03:04:05:06
) may be passed withtype:error
ortype:info
to restrict the display to Material instances that currently have the specified player as the active player.
type:alert
, type:update
, and type:notif
messages are 'remembered' by the
LMS side. When a new instance of the web-app is started, or the page refreshed,
the web-app will query LMS for the last notification and will show these again.
To clear these you need to send a type:alert
, or type:update
, message with
msg:-
as the message parameter.
The message part of a notification can be HTML code, and within this you may insert
links that when clicked will invoke an action from actions.json
. For example, the
following would show "Click me" in a dialog box, and when "Click me" is clicked the
action within the notifications
section of actions.json
that has "id":"xxx"
will be invoked.
curl 'http://localhost:9000/jsonrpc.js' --data-raw '{"id":0,"method":"slim.request","params":["",["material-skin", "send-notif", "type:notif", "msg:A new version of xyz is available. <a href=\"msk:xxx\">Click</a>" to udpdate", "title:XYZ Update", "id:123"]]}'