Check your eligibility for this 50% exam voucher offer and join us for free live learning sessions to get prepared for Exam DP-700.
Get StartedDon't miss out! 2025 Microsoft Fabric Community Conference, March 31 - April 2, Las Vegas, Nevada. Use code MSCUST for a $150 discount. Prices go up February 11th. Register now.
I'm trying out AngularJS in a custom visual. I've got the AngularJS modules library in and building and not I'm trying to build a test app.
I've created some html in the constructor:
const ang_app: HTMLElement = document.createElement("div"); ang_app.setAttribute('ng-app',"myapp"); ang_app.setAttribute('ng-controller',"tableController"); const ang_tr: HTMLElement = document.createElement("tr"); ang_tr.setAttribute('ng-repeat',"row in dataSet"); ang_app.appendChild(ang_tr); const ang_td: HTMLElement = document.createElement("td"); ang_td.appendChild(document.createTextNode("{{row[0]}}")); ang_app.appendChild(ang_td); this.target.appendChild(ang_app);
and checked the resulting HTML, which looks OK:
<div ng-app="myapp" ng-controller="tableController"> <tr ng-repeat="row in dataSet"></tr><td>{{row[0]}}</td></div>
I'm using angular in the Update method like this:
var app = ng.module("myapp",[]); app.controller("tableController", ['$scope', function ($scope) { $scope.dataSet = options.dataViews[0]; }], );
So it looks fairly close, but I'm obviously missing something. Does any one have a suggestion or is there sample code I can look at?
I'm getting this error:
SCRIPT5022: SCRIPT5022: [$injector:modulerr] Failed to instantiate module myapp due to: Error: [$injector:nomod] Module 'myapp' is not available! You either misspelled the module name or forgot to load it. If registering a module ensure that you specify the dependencies as the second argument. https://errors.angularjs.org/1.7.4/$injector/modulerr?p0=myapp&p1=Error%3A%20%5B%24injector%3Anomod%...
Solved! Go to Solution.
Your code above is almost correct. You can also learn how to pass props in React Doc.
ReactDOM.render(React.createElement(App, {options}), this.element);
You should also add options as props into App.
Ignat Vilesov,
Software Engineer
Microsoft Power BI Custom Visuals
Have not tried Angular but we have small sample for React.
Ignat Vilesov,
Software Engineer
Microsoft Power BI Custom Visuals
Hey Ignat thanks for that, it's an interesting alternative, I'll let you know how it works out (you might get another question for react 🙂 )
Happy to help.
Current samplkes does not look good since it does not use modern ES2015 features such as modules but we're working on webpack based pbiviz to bring new features to developers.
Ignat Vilesov,
Software Engineer
Microsoft Power BI Custom Visuals
Ignat, I can't figure out how to get the dataView into the React Component.
I'm doing this is in Update:
Your code above is almost correct. You can also learn how to pass props in React Doc.
ReactDOM.render(React.createElement(App, {options}), this.element);
You should also add options as props into App.
Ignat Vilesov,
Software Engineer
Microsoft Power BI Custom Visuals
I'm having some trouble getting that working. I've run out of time to work on it, but I was thinking of getting a programmer to get the example working for me. Is it worth doing that or will there be something else coming along?
We have not plans to implement Angular/React sample for Power BI but it's on our backlog (no ETA).
Ignat Vilesov,
Software Engineer
Microsoft Power BI Custom Visuals
I found using Chrome to debug I culd see inside the object more easily using console.log. The props were being passed just fine, it was a user problem 😞
Awesome.
Ignat Vilesov,
Software Engineer
Microsoft Power BI Custom Visuals