How to handle events

Tip

Experiment with APIs in real time using your own report or our sample report in the Developer sandbox section of the Power BI Embedded Analytics Playground.

Events are used to communicate between the Power BI component (for example, a report) and the web application code.

An embedded component emits events after an action is executed inside the component. These can be user interactions or an automated action (like a visual being rendered) within the component.

For example, buttonClicked is an event emitted by a Power BI report when a user clicks a button in the report. You can listen to the event by using report.on(...), and then set an event handler.

An example of how to handle an event

This example shows how to handle a report event. To learn about other types of events, see Events and their response values.

Note

Wait for the component to load before using the APIs. Listen to the loaded event and then issue new commands.

report.on('loaded', function(event)
{
    reportPages = await report.getPages();
});

How to remove event handlers

You can use report.off(...) to remove all event handlers for a specific event.

Events and their response values

View a full list of possible events and their response values.

Error events (relevant for all embeds)

An error event is emitted to describe a failed operation.

interface IError {
    message: string // A general message that describes the operation that failed (example: "Could not set page")
    detailedMessage?: string // Detailed message that describes the error
    errorCode?: string  //  Short message that describes the error
    level?: TraceType // The level of the error (example: 'Fatal')
    technicalDetails?: ITechnicalDetails
}

interface ITechnicalDetails {
    requestId?: string // Id for debugging - should be provided when reporting a bug
}

Note

Only the message property is required, and the other properties might be undefined.

Report events

A report event is emitted for an interaction with an embedded report, such as clicking a report button or rendering a visual.

buttonClicked

The buttonClicked event is raised when a user clicks on a Report button.

 id: string
 title?: string
 type?: string (type of button)
 bookmark?: string

commandTriggered

The commandTriggered event is raised when a user clicks on an extension command.

 command: string
 dataPoints?: IIdentityValue[]
 report: models.IReport
 page: models.IPage
 visual: models.IVisual

dataHyperlinkClicked

The dataHyperlinkClicked event is raised when a hyperlink is clicked, and the hyperlink's behavior is set to NavigateAndRaiseEvent or RaiseEvent.

 url: string
 report: models.IReport
 page: models.IPage
 visual: models.IVisual

For more information, see Configure report settings.

dataSelected

The dataSelected event is raised when a specific data point is selected.

 report: models.IReport
 page: models.IPage
 visual: models.IVisual
 filters: IFilter[]
 dataPoints: IIdentityValue[]

loaded

The loaded event is raised when the report initializes. Loading is complete when the Power BI logo disappears.

pageChanged

The pageChanged event is raised whenever a page is changed.

 newPage: Models.IPage

rendered

The rendered event is raised when a report is fully rendered. For example, if all visuals are rendered upon loading a report or after a user interaction.

saveAsTriggered

When useCustomSaveAsDialog: true, the saveAsTriggered event is raised when a user clicks on Save As in the UI. This lets you create your own dialog for the Save As action.

saved

The saved event is raised when a save is triggered by a save or saveAs action in the UI or by using the APIs.

selectionChanged

The selectionChanged event is raised whenever the user is changing the selected visual. selectedItems is a list of all selected visuals when more than one is selected.

 report: models.IReport
 page: models.IPage
 visual?: models.IVisual
 selectedItems?: models.IVisual[]

visualClicked

The visualClicked event is raised every time a visual is clicked.

 report: models.IReport
 page: models.IPage
 visual: models.IVisual

visualRendered

The visualRendered event is raised when a visual is rendered (requires setting visualRenderedEvents to true in the settings object).

Note

Because visuals might render due to user interactions, it's recommended that this event only be turned on when needed.

 name: string

For more information, see Configure report settings.

Report Embed Mobile events

A Report Embed Mobile event is emitted for an interaction with an embedded report in a mobile layout, such as the beginning or end of a swipe.

swipeStart and swipeEnd events

swipeStart or swipeEnd events are raised when a user begins or ends a swipe movement on an embedded report.

interface ISwipeEvent {
    currentPosition: IPosition
    startPosition: IPosition
}

interface IPosition {
    x: number
    y: number
}

Dashboard events

A dashboard event is emitted when the dashboard is loaded and when a user clicks on a tile in the dashboard.

loaded

The loaded event is raised when the dashboard initializes.

tileClicked

The tileClicked event is raised when an end user clicks a tile. It is not raised for pinned live pages.

 tileId: string
 navigationUrl: string
 pageName: string
 reportEmbedUrl: string

Q&A events

A question and answer (Q&A) event is raised when a visual is rendered after entering a question.

visualRendered (Q&A)

The visualRendered event is raised when a visual is rendered after a question is entered and an answer displays.

 question: string
 normalizedQuestion: string

Tile events

A Tile event is raised when a user clicks on a tile.

tileClicked (tile event)

The tileClicked event is raised when an end user clicks a tile. It is not raised for pinned live pages.

 tileId: string
 navigationUrl: string
 pageName: string
 reportEmbedUrl: string

tileLoaded

The tileLoaded event is raised when the tile initializes. Loading is complete when the Power BI logo disappears.