-
Notifications
You must be signed in to change notification settings - Fork 10
Web Messaging API
🧪 The Web Messaging API is experimental. We advise the customers to use the JavaScript API.
Spreadsheet Viewer is designed to be used in an iframe or a window and be controlled from the outside code. For that, it implements a low-level Web Messaging API (see the MSN docs about postMessage
). This is a cross-document messaging defined in the HTML standard. However, this API is stateless and asynchronous, which may be confusing when integrating with your app. For that reason, we have created a high-level JavaScript API with a simpler, Promise-driven interface.
The messaging is bidirectional. One direction is referred to as "request messages" (from host to SV), the second direction is referred to as "callback messages" (from SV to host).
Every message is implemented as a postMessage
call in which the message is encoded as a JavaScript object. There are two mandatory properties in the object: name
and svId
. Other properties are used to carry the details of the message.
This low-level API must be used directly when integrating SV with a native app or any other non-JavaScript app.
The documentation for the low-level API is considered private, however, it can be made available to customers upon request.
The below sequence diagram illustrates the main intended correspondence between the request messages, the callback messages and the views (🏗 this is still work in progress):
Request messages are emitted from the parent frame and are listened to in the iframe. They are used to steer the UI of Spreadsheet Viewer from the host app.
Request message that reconfigures up the internal state of the Spreadsheet Viewer iframe in the runtime.
Properties:
-
name
:configure
-
themeStylesheet
: Optional. A string representing the name of the built-in theme (color scheme) which can be eitherlight
ordark
. Default value:dark
-
licenseKey
: Optional. A string representing Spreadsheet Viewer license key. Default value: empty string (meaning: unlicensed)
Request message to Spreadsheet Viewer to render a file. Provided a URL, Spreadsheet Viewer will download and render the file. Provided a Data URL, Spreadsheet Viewer will render the file contents without additional downloading. See MDN for guidelines about Data URL: https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs.
While loading and parsing the workbook file, Spreadsheet Viewer displays an animated loading screen.
Properties:
-
name
:loadWorkbook
-
workbook
: Required. A URL to a workbook file, or a base64-encoded string (Data URL) representing the file contents or anArrayBuffer
with the file contents. -
sheet
: Required. A number, starting from 0, representing the index of the sheet within the document that will be open after the file loads. -
fileName
: Required ifworkbook
is anArrayBuffer
, otherwise optional. A string representing a file name of the current workbook. If the file name is not provided andworkbook
is an HTTP(S) URL, the app considers the last segment of the URL as the file name (after the last/
). Otherwise, if the file name cannot be determined, the app will show "Unnamed file" as the file name.
Example:
// send message to contentWindow
document.querySelector('iframe#spreadsheet-viewer').contentWindow.postMessage({
'name': 'loadWorkbook',
'workbook': url,
'sheet': sheet
}, '*');
Request message to Spreadsheet Viewer to select cells in a loaded spreadsheet.
Properties:
-
name
:selectCells
-
range
: Required. An array of four numbers. Each number, starting from 0, represents in order: starting row, starting column, ending row, ending column.
document.querySelector('iframe#spreadsheet-viewer').contentWindow.postMessage({
'name': 'selectCells',
'range': [0, 0, 1, 1] // select 4 cells: A1, A2, B1, B2
}, '*');
Callback messages are emitted from the iframe and can be listened to in the parent frame. They allow the host app to observe UI interactions (screen changed e.g. name: screenLoaded, screen: crash
, button clicked e.g. name: actionPerformed, action: close
, ...) performed by the end-user in Spreadsheet Viewer.
Callback messages are emitted also if they are the result of a request message.
The callback from Spreadsheet Viewer emitted when a sheet is changed by the end-user. The message includes the index of the new active sheet.
Properties:
-
name
:activeSheetChanged
-
sheet
: a number, starting from 0, representing the index of the sheet within the document
Example:
// get a message from SpreadsheetViewer iframe
window.addEventListener('message', function(e) {
if (e.data.name === 'activeSheetChanged') {
var sheet = e.data.sheet
}
});
The callback from Spreadsheet Viewer emitted when cells are selected by the end-user. The message includes the range of the selected cells.
Properties:
-
name
:cellSelectionChanged
-
range
: an array of four numbers. Each number, starting from 0, represents in order: starting row, starting column, ending row, ending column.
window.addEventListener('message', function(e) {
if (e.data.name === 'cellSelectionChanged') {
var range = e.data.range
console.log(range) // example output of cells A1, A2, B1, B2: [0, 0, 1, 1]
}
});
- Installation
- API guides
- Advanced topics
- Features and known limitations
- Open-source licenses