Connect to QuickBooks Angular directive
Simple Connect button rendering
I was attempting to answer this SO question which referenced this angular directive for rendering a "Connect to QuickBooks" button. I fired up the gulp-angular generator but couldn't get that directive to work and in the process was was able to come up with a simpler approach.
- Install the gulp-angular Yeoman generator, make a new dir, and run the generator.
- Install no additional items when prompted by the Yeoman wizard.
- Oops. The bower install failed.
- Re-run
bower install
. - Test the generator doing a
gulp serve
. - Let's clean up some of the scaffolding stuff. Remove the
awesomeThings
array insrc/app/main/main.controller.js
- Then remove the corresponding
ng-repeat
insrc/index.html
. - Make a new file
src/app/main/directives.js
and add the following. - Then in
src/index.html
do: - Let's check it out.
$ npm install -g generator-gulp-angular $ cd ~/github/labs $ mkdir connect-intuit-angular && cd $_ $ yo gulp-angular
data:image/s3,"s3://crabby-images/94646/94646ec5021e36b8b8c6ff201f55f9af39f51290" alt=""
data:image/s3,"s3://crabby-images/43c38/43c389be340c7246e63a9b0e3e21e540f78d67de" alt=""
data:image/s3,"s3://crabby-images/53947/5394740cefe8d4dc9ec42f4bf7afc8225d48a337" alt=""
data:image/s3,"s3://crabby-images/50fbe/50fbe0e6dc817a3bdd9e8396651de7afe29368bc" alt=""
data:image/s3,"s3://crabby-images/c3b33/c3b33b5a4a3a09302537c7d1d2587a2d68b6cd71" alt=""
data:image/s3,"s3://crabby-images/d2e32/d2e32841591ea833f255ba5241f8b3ec4c46c211" alt=""
/* src/app/main/directives.js */ angular.module('connectIntuitAngular') .directive('connectToQuickbooks', function($window){ return { restrict: 'E', template: "<ipp:connectToIntuit></ipp:connectToIntuit>", link: function(scope) { var script = $window.document.createElement("script"); script.type = "text/javascript"; script.src = "//js.appcenter.intuit.com/Content/IA/intuit.ipp.anywhere.js"; script.onload = function () { scope.$emit('intuitjs:loaded'); }; $window.document.body.appendChild(script); scope.$on('intuitjs:loaded', function (evt) { $window.intuit.ipp.anywhere.setup({ grantUrl: '/' }); scope.connected = true; scope.$apply(); }); } } });
<!-- index.html --> <div class="jumbotron" ng-init="connected = false"> <div class="control-group"> <div class="controls" ng-show="!connected"> Loading QuickBooks Connect button </div> <div class="controls" ng-show="connected"> <connect-to-quickbooks /> </div> </div> </div>
data:image/s3,"s3://crabby-images/f0e58/f0e583b9e9d05b22b62b54808d34ccd863e12a58" alt=""
Handling external Javascript
There a few other ways to handle external Javascript dependencies in Angular but I like using the onload attribute in combination with Angular events as it is simple and easy to follow. In this refactoring I was able to save quite a few lines of code while improving read-ability.
- Pushed on 11/03/2014 by Christian
- QuickBooks Integration Consulting