Apply widget filters during initial load and on-demand in embedding
In JavaScript-based embedding, we have added support for applying filters to specific widgets. This page will explain how to apply filters to multiple widgets based on different formats such as string and date using the following two methods:
- Initial rendering
- On-demand
Steps to follow for applying filters into widgets
- 
Please download the ASP.NET Core sample for a better understanding of the widget filtering support. 
- 
In the Bold BI Server, load the Agent Activity Dashboardfrom the Sample Dashboards.
 
- 
By default, the Agent Activity Dashboardhas one master widget (Date). For demonstration purposes, we need to designate theAvg. Resolution Time by Eventas a master widget by using the ActAsMasterWidget property in the widget settings. Additionally, we need to enable the MultiSelect property in the widget settings to allow for filtering multiple values in a single widget.
- 
In the downloaded application, you can find the EmbedProperties class file in the Models folder. Provide your server details in the EmbedProperties.csfile, where you should set theAgent Activity Dashboardpath to the DashboardPath property as shown in the image below.RootUrl Dashboard Server BI URL (ex: http://localhost:5000/bi, http://demo.boldbi.com/bi). SiteIdentifier For Bold BI Enterprise edition, it should be like site/site1. For Bold BI Cloud, it should be empty string. Environment For Bold BI application environment. (If Cloud, it should be like `cloud`, if Enterprise, it should be like `enterprise`). UserEmail UserEmail of the Admin in your Bold BI, which would be used to get the dashboards list. Password Password of the Admin in your Bold BI, which would be used to get the dashboards list. DashboardPath Dashboard Path which you want to render in the application. EmbedSecret Get your EmbedSecret key from the Embed tab by enabling the Enable embed authenticationin the Administration page.
- 
After running the application, the specific widgets on the dashboard are filtered by default rendering as shown below. 
 
How the sample works
- 
Before rendering the dashboard, we retrieved the widget collection details of that dashboard using REST API in the GetWidgets() method in this application. Please check this link for more details. 
- 
We could retrieve the widget details by conditioning with specific widget names (such as Average Resolution Time by EventandDate) from the widget collections as shown below.function ListWidgets(data) { if (typeof (data) != "undefined" && data != null) { data.forEach(function (element) { if (element.WidgetInfo.DisplayName == "Date") { dateWidgetId = element.WidgetInfo.Id; } if (element.WidgetInfo.DisplayName == "Avg. Resolution Time by Agent") { dimensionWidgetId = element.WidgetInfo.Id; } }); } renderDashboard(dimensionWidgetId, dateWidgetId); }
- 
For the initial rendering, we could pass the specific widget ID in getWidgetInstance() to retrieve the widget instance and the corresponding filter values in setFilterParameters() to filter the widgets with the specified filter values in renderDashboard().
- 
The default string values for Agent_1,Agent_5, andAgent_7, along with the default date range of1/1/2022to6/30/2022, are filtered in theAvg. Resolution Time by AgentandDatewidgets, respectively.function renderDashboard(dimensionWidgetId, dateWidgetId) { this.dashboard = BoldBI.create({ serverUrl: rootUrl + "/" + siteIdentifier, dashboardPath: dashboardPath, embedContainerId: "dashboard", embedType: BoldBI.EmbedType.Component, environment: BoldBI.Environment.Enterprise, expirationTime: 100000, authorizationServer: { url: authorizationServerUrl } }); this.dashboard.loadDashboard(); /*Dimension type widget filter*/ var dimensionFilterValues = ["Agent_1", "Agent_5", "Agent_7"];//values to be filtered in the dimension type widget. this.dashboard.getWidgetInstance(dimensionWidgetId).setFilterParameters(dimensionFilterValues);//filter the values while initial rendering. /*Date type widget filter*/ var dateFilterValues = ["1/1/2022", "6/30/2022"];//date range to be filtered in the date type widget. this.dashboard.getWidgetInstance(dateWidgetId).setFilterParameters(dateFilterValues);//filter the values while initial rendering. };
- 
For the on-demandcase, we could pass the specific widget id in getWidgetInstance() to retrieve the widget instance and pass the respective filter values in setFilterParameters() to set the filter values in the widget instance. Then, call theupdateWidgetFilters()method to reflect the applied filter values in the dashboard using the dashboard instance.
- 
By clicking the Apply Dimension Filtersbutton, the on-demand new filter valuesAgent_4,Agent_6, andAgent_8are applied to theAvg. Resolution Time by Agentwidget. The ondemandDimensionFilters() method below will be triggered to apply the dimension filters.function ondemandDimensionFilters() { var instance = BoldBI.getInstance("dashboard");// "dashboard" -> embed container id. var dimensionValue = ["Agent_4", "Agent_6", "Agent_8"]; // values to be filtered in the widget. instance.getWidgetInstance(dimensionWidgetId).setFilterParameters(dimensionValue); instance.updateWidgetFilters("dashboard"); }
- 
By clicking the Apply Date Filters button, the on-demand date range of 7/1/2022to12/31/2022is applied to theDatewidget. The ondemandDateFilters() method below will be triggered to apply the date filters.function ondemandDateFilters() { var instance = BoldBI.getInstance("dashboard");// "dashboard" -> embed container id. var dateValue = ["7/1/2022", "12/31/2022"];// values to be filtered in the widget. instance.getWidgetInstance(dateWidgetId).setFilterParameters(dateValue); instance.updateWidgetFilters("dashboard"); }
 
                    