PowerBI-Angular

AngularJS components that allows developers to easily create applications that utilize the Power BI APIs.

  • Owner: microsoft/PowerBI-Angular
  • Platform:
  • License:: MIT License
  • Category::
  • Topic:
  • Like:
    0
      Compare:

Github stars Tracking Chart

Deprecation notice

Power BI Angular is deprecated and is no longer supported.

angular-powerbi

Build Status
npm version
downloads total
downloads monthly
GitHub tag

Angular module which wraps PowerBI-JavaScript as service and adds a collection of components for each embedded type (Currently only Report is supported) which you can use to easily embed Power BI visuals within your Angular applications.

Demo

http://azure-samples.github.io/powerbi-angular-client

Source: https://github.com/Azure-Samples/powerbi-angular-client

Contents

angular-powerbi.js includes the following:

  • Service: PowerBiService

    (Handles messaging communication between host frame/window and embedded powerbi visual iframes/windows)

  • Web Components

    1. Report Specific Component

      <powerbi-report embed-url="vm.report.embedUrl" access-token="vm.report.accessToken"></powerbi-report>
      
    2. Generic Component

      <powerbi-component options="vm.report"></powerbi-component>
      

Getting started

  1. Install:

    npm install -save angular-powerbi
    
  2. Include the powerbi.js and the angular-powerbi.js file within your app:

    Below we're using absolute urls to npmcdn but you could also use relative urls to local files in node_modules or bundle the two scripts with the rest of your vendor scripts.

    <script src="https://npmcdn.com/powerbi-client@2.0.0"></script>
    <script src="https://npmcdn.com/angular-powerbi@1.0.0"></script>
    
  3. Include the 'powerbi' module as a dependency of your app:

    app.module('app', [
      'powerbi'
    ]);
    
  4. Fetch embed data from the server (embedUrl and accessToken) and make it available on controller scope.

    This would likely require using a factory or service to fetch report data from your local server.
    Example where the report is resolved when entering route:

    Route:
    return ReportsService.findById('5dac7a4a-4452-46b3-99f6-a25915e0fe55');

    ReportsService:

    findById(id: string): ng.IPromise<PowerBi.IReport> {
    	return this.$http.get(`${this.baseUrl}/api/reports/${id}`)
    		.then(response => response.data);
    }
    

    If you need a sample server to test you can use the following:

  5. Insert the component in your template where you want to embed the visual:

    <powerbi-report embed-url="vm.report.embedUrl" access-token="vm.report.accessToken" options="vm.reportOptions"></powerbi-report>
    

Main metrics

Overview
Name With Ownermicrosoft/PowerBI-Angular
Primary LanguageTypeScript
Program languageJavaScript (Language Count: 2)
Platform
License:MIT License
所有者活动
Created At2015-09-29 22:46:17
Pushed At2018-01-22 15:33:28
Last Commit At2018-01-22 17:33:28
Release Count8
Last Release Namev1.0.0 (Posted on 2016-09-01 16:26:23)
First Release Namev1.0.0-beta.1 (Posted on 2016-04-25 17:20:43)
用户参与
Stargazers Count82
Watchers Count59
Fork Count47
Commits Count74
Has Issues Enabled
Issues Count26
Issue Open Count18
Pull Requests Count0
Pull Requests Open Count1
Pull Requests Close Count2
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private