Desarrollé hace unos meses una API de NodeJS
para obtener informes integrados de Power BI (usando un arrendatario). Consumo esta API desde una aplicación Angular. Ahora quiero filtrar el informe y no sé si esto es posible con mi código real.
Usé la API de descanso de PowerBI para obtener el informe de inserción. Al leer los documentos de Microsoft, veo muchos documentos como este , donde dice que debo crear un objeto con los filtros que quiero. Esto no es un problema, pero no sé si esto es compatible con mi API de Nodo real o si debería desarrollar una nueva solución.
Mi API sigue el ejemplo proporcionado por Microsoft y el código es:
async function getEmbedParamsForSingleReport( workspaceId, reportId, additionalDatasetId ) { const reportInGroupApi = `https://api.powerbi.com/v1.0/myorg/groups/${workspaceId}/reports/${reportId}`; const headers = await getRequestHeader(); // Get report info by calling the PowerBI REST API const result = await axios.get(reportInGroupApi, { headers }); if (result.status !== 200) { throw result; } // Convert result in json to retrieve values const resultJson = result.data; // Add report data for embedding const reportDetails = new PowerBiReportDetails( resultJson.id, resultJson.name, resultJson.embedUrl ); const reportEmbedConfig = new EmbedConfig(); // Create mapping for report and Embed URL reportEmbedConfig.reportsDetail = [reportDetails]; // Create list of datasets let datasetIds = [resultJson.datasetId]; // Append additional dataset to the list to achieve dynamic binding later if (additionalDatasetId) { datasetIds.push(additionalDatasetId); } // Get Embed token multiple resources reportEmbedConfig.embedToken = await getEmbedTokenForSingleReportSingleWorkspace( reportId, datasetIds, workspaceId ); return reportEmbedConfig; }
Con esto obtengo el informe de incrustación y lo envío a mi aplicación. ¿Esta solución es compatible con los filtros?
¡Gracias por adelantado!
Finalmente, encontré una solución. En mi aplicación Angular, uso la biblioteca powerbi-client-angular
. Eso me permite definir alguna configuración en el informe incrustado:
basicFilter: models.IBasicFilter = { $schema: 'http://powerbi.com/product/schema#basic', target: { table: 'items', column: 'id', }, operator: 'In', values: [1,2,3], filterType: models.FilterType.Basic, requireSingleSelection: true, displaySettings: { /** Hiding filter pane */ isLockedInViewMode: true, isHiddenInViewMode: true, }, }; reportConfig: IReportEmbedConfiguration = { type: 'report', id: cuantitativeReportID, embedUrl: undefined, tokenType: models.TokenType.Embed, filters: [this.basicFilter], accessToken: undefined, settings: undefined, };
Con esto puedo evitar pasar información a la API de NodeJS
Sí, funcionará bien con esta solución. Encuentre el código correspondiente a continuación:
const filter = { $schema: "http://powerbi.com/product/schema#basic", target: { table: "Geo", column: "Region" }, operator: "In", values: ["West", "Central"] };
await report.updateFilters(models.FiltersOperations.Add, [filter]);
Puede consultar la aplicación NodeJS de muestra para obtener informes integrados de Power BI. Encuentre la referencia aquí: https://github.com/microsoft/PowerBI-Developer-Samples/tree/master/NodeJS