Enable persistent filters
In reports you embed for your organization, when the persistent filters feature is enabled, reports retain their state, including filters, slicers, and other data view changes. When your user opens a report, the saved user state loads into the report. Also, the user gets the same user state in the different scenarios if persistent filters is enabled.
To reset the persistent filters in an embed scenario, you'll need to implement a button and use the resetPersistentFilters
API, or show the action bar to get the Power BI Reset to default button on the action bar.
How to enable persistent filters
Persistent filters are disabled by default. To enable persistent filters, follow the steps in this section.
Verify that persistent filters are enabled in the report settings in the Power BI service or desktop.
Verify that your Azure Active Directory (Azure AD) app has
UserState.ReadWrite.All
permissions.Set the
persistentFiltersEnabled
property totrue
.
let config = {
type: 'report',
...
settings: {
persistentFiltersEnabled: true
}
};
The report is loaded with the latest user's report state, if the state exists. The user's report state is automatically saved after 60 seconds, without any change.
Note
- Only updates to existing filters are saved. New filters are added by the
setFilters
API aren't saved. - Persistent filters can't be changed after the report is loaded. To change the persistent filters state, reset the iframe by calling
powerbi.reset(element)
, and then embed the report again.
Persistent filters APIs
Reset persistent filters
Reset a user's filters, slicers, and other data view changes to the report's default state.
resetPersistentFilters(): Promise<void>
Save persistent filters
Save the user's report filters, slicers, and other data view changes.
savePersistentFilters(): Promise<void>
Persistent filters applied
Returns a user's filters, slicers, or other data view changes applied on the report, if they exist. If persistent filters are disabled, this returns false.
You can use this API to determine the reset button state.
arePersistentFiltersApplied(): Promise<boolean>
Considerations and limitations
Persistent filters are supported only for the embed for your organization (user owns data) solution.