This directive allows you to add Google Maps Javascript API elements.
- AngularJS
- UI.Event
- Google Maps Javascript API 3.x
You can get it from Bower
bower install angular-ui-map
This will copy the UI.Map files into a bower_components
folder, along with its dependencies. Load the script files in your application:
<script type="text/javascript" src="bower_components/angular/angular.js"></script>
<script type="text/javascript" src="bower_components/angular-ui-utils/modules/event/event.js "></script>
<script type="text/javascript" src="bower_components/angular-ui-map/src/map.js"></script>
<script type="text/javascript" src="https://maps.googleapis.com/maps/api/js?v=3.exp&sensor=false&callback=onGoogleReady"></script>
Make sure to listen to the callback parameter when loading the Google Maps API !
The API must be fully loaded before this module !
Here we name this callback onGoogleReady
. To load your angular app after the Google Maps API you can start it with angular.bootstrap.
function onGoogleReady() {
angular.bootstrap(document.getElementById("map"), ['app.ui-map']);
}
Add the UI.Map module as a dependency to your application module :
var myAppModule = angular.module('app.ui-map', ['ui.map']);
Finally, add the directive to your html:
<section id="map" ng-controller="MapCtrl" >
<div ui-map="myMap" ui-options="mapOptions" class="map-canvas"></div>
</section>
Note that myMap
will be a google.maps.Map class, and mapOptions
a google.maps.MapOptions object (see below).
To see something it's better to add some CSS, like
.map-canvas { height: 400px; }
google.maps.MapOptions object can be passed through the main directive attributeui-map
.
myAppModule.controller('MapCtrl', ['$scope', function ($scope) {
$scope.mapOptions = {
center: new google.maps.LatLng(35.784, -78.670),
zoom: 15,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
}]);
UI.Event allows you to specify custom behavior over user events. You just need to prefix the official event by map- to bind a callback to it.
For example, the click or zoom_changed event of the google.maps.Map class can be used through the UI.Event object keys map-click and map-zoom_changed :
<section id="map" ng-controller="MapCtrl" >
<div ui-map="myMap"ui-options="mapOptions" class="map-canvas"
ui-event="{'map-click': 'addMarker($event, $params)', 'map-zoom_changed': 'setZoomMessage(myMap.getZoom())' }"
></div>
</section>
We use Karma and jshint to ensure the quality of the code. The easiest way to run these checks is to use grunt:
npm install -g grunt-cli
npm install && bower install
grunt
The karma task will try to open Firefox and Chrome as browser in which to run the tests. Make sure this is available or change the configuration in test\karma.conf.js
You can watch files change for your tests with
grunt watch
Make sure to have a Karma server available with it.
grunt server
(you can force a test on this server with grunt karma:unit:run
)
The documentation is generated by bower and grunt. To build it run :
grunt build-doc
And then, launch a built-in web server on the angular-ui-docs bower module
cd bower_components/angular-ui-docs/
php -S localhost:8000
or
python -m SimpleHTTPServer
Then check your http://localhost:8000/
Tips for fast development : Inline everything
grunt build-doc && cd bower_components/angular-ui-docs/ && php -S localhost:8000 && cd ../..