UNPKG

ngmap

Version:
57 lines (50 loc) 1.64 kB
/** * @ngdoc directive * @name bicycling-layer * @param Attr2Options {service} * convert html attribute to Google map api options * @description * Requires: map directive * Restrict To: Element * * @example * * <map zoom="13" center="34.04924594193164, -118.24104309082031"> * <bicycling-layer></bicycling-layer> * </map> */ (function() { 'use strict'; var parser; var linkFunc = function(scope, element, attrs, mapController) { mapController = mapController[0]||mapController[1]; var orgAttrs = parser.orgAttributes(element); var filtered = parser.filter(attrs); var options = parser.getOptions(filtered, {scope: scope}); var events = parser.getEvents(scope, filtered); console.log('bicycling-layer options', options, 'events', events); var layer = getLayer(options, events); mapController.addObject('bicyclingLayers', layer); mapController.observeAttrSetObj(orgAttrs, attrs, layer); //observers element.bind('$destroy', function() { mapController.deleteObject('bicyclingLayers', layer); }); }; var getLayer = function(options, events) { var layer = new google.maps.BicyclingLayer(options); for (var eventName in events) { google.maps.event.addListener(layer, eventName, events[eventName]); } return layer; }; var bicyclingLayer= function(Attr2MapOptions) { parser = Attr2MapOptions; return { restrict: 'E', require: ['?^map','?^ngMap'], link: linkFunc }; }; bicyclingLayer.$inject = ['Attr2MapOptions']; angular.module('ngMap').directive('bicyclingLayer', bicyclingLayer); })();