• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

219
Views
Filtros en el informe de inserción de Power BI

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!

about 3 years ago · Juan Pablo Isaza
2 answers
Answer question

0

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

about 3 years ago · Juan Pablo Isaza Report

0

Sí, funcionará bien con esta solución. Encuentre el código correspondiente a continuación:

  1. Crear un objeto de filtro:
 const filter = { $schema: "http://powerbi.com/product/schema#basic", target: { table: "Geo", column: "Region" }, operator: "In", values: ["West", "Central"] };
  1. Agregue el filtro a los filtros del informe:
 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

about 3 years ago · Juan Pablo Isaza Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error