123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234 |
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>JSDoc: Source: directives/info-window.js</title>
- <script src="scripts/prettify/prettify.js"> </script>
- <script src="scripts/prettify/lang-css.js"> </script>
- <!--[if lt IE 9]>
- <script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
- <![endif]-->
- <link type="text/css" rel="stylesheet" href="styles/prettify-tomorrow.css">
- <link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css">
- </head>
- <body>
- <div id="main">
- <h1 class="page-title">Source: directives/info-window.js</h1>
-
-
- <section>
- <article>
- <pre class="prettyprint source linenums"><code>/*jshint -W030*/
- /**
- * @ngdoc directive
- * @name info-window
- * @requires Attr2Options
- * @requires $compile
- * @description
- * Defines infoWindow and provides compile method
- *
- * Requires: map directive
- *
- * Restrict To: Element
- *
- * @param {Boolean} visible Indicates to show it when map is initialized
- * @param {Boolean} visible-on-marker Indicates to show it on a marker when map is initialized
- * @param {String} &lt;InfoWindowOption> Any InfoWindow options,
- * https://developers.google.com/maps/documentation/javascript/reference?csw=1#InfoWindowOptions
- * @param {String} &lt;InfoWindowEvent> Any InfoWindow events, https://developers.google.com/maps/documentation/javascript/reference
- * @example
- * Usage:
- * <map MAP_ATTRIBUTES>
- * <info-window id="foo" ANY_OPTIONS ANY_EVENTS"></info-window>
- * </map>
- *
- * Example:
- * <map center="41.850033,-87.6500523" zoom="3">
- * <info-window id="1" position="41.850033,-87.6500523" >
- * <div ng-non-bindable>
- * Chicago, IL<br/>
- * LatLng: {{chicago.lat()}}, {{chicago.lng()}}, <br/>
- * World Coordinate: {{worldCoordinate.x}}, {{worldCoordinate.y}}, <br/>
- * Pixel Coordinate: {{pixelCoordinate.x}}, {{pixelCoordinate.y}}, <br/>
- * Tile Coordinate: {{tileCoordinate.x}}, {{tileCoordinate.y}} at Zoom Level {{map.getZoom()}}
- * </div>
- * </info-window>
- * </map>
- */
- ngMap.directive('infoWindow', ['Attr2Options', '$compile', '$timeout', function(Attr2Options, $compile, $timeout) {
- var parser = Attr2Options;
- var getInfoWindow = function(options, events, element) {
- var infoWindow;
- /**
- * set options
- */
- if (options.position &&
- !(options.position instanceof google.maps.LatLng)) {
- var address = options.position;
- delete options.position;
- infoWindow = new google.maps.InfoWindow(options);
- var callback = function() {
- infoWindow.open(infoWindow.map);
- }
- parser.setDelayedGeoLocation(infoWindow, 'setPosition', address, {callback: callback});
- } else {
- infoWindow = new google.maps.InfoWindow(options);
- }
- /**
- * set events
- */
- if (Object.keys(events).length > 0) {
- console.log("infoWindow events", events);
- }
- for (var eventName in events) {
- if (eventName) {
- google.maps.event.addListener(infoWindow, eventName, events[eventName]);
- }
- }
- /**
- * set template ane template-relate functions
- * it must have a container element with ng-non-bindable
- */
- var template = element.html().trim();
- if (angular.element(template).length != 1) {
- throw "info-window working as a template must have a container";
- }
- infoWindow.__template = template.replace(/\s?ng-non-bindable[='"]+/,"");
- infoWindow.__compile = function(scope) {
- var el = $compile(infoWindow.__template)(scope);
- scope.$apply();
- infoWindow.setContent(el[0]);
- };
- infoWindow.__eval = function(event) {
- var template = infoWindow.__template;
- var _this = this;
- template = template.replace(/{{(event|this)[^;\}]+}}/g, function(match) {
- var expression = match.replace(/[{}]/g, "").replace("this.", "_this.");
- return eval(expression);
- });
- return template;
- };
- return infoWindow;
- };
- return {
- restrict: 'E',
- require: '^map',
- link: function(scope, element, attrs, mapController) {
- element.css('display','none');
- var orgAttrs = parser.orgAttributes(element);
- var filtered = parser.filter(attrs);
- var options = parser.getOptions(filtered, scope);
- var events = parser.getEvents(scope, filtered);
- console.log('infoWindow', 'options', options, 'events', events);
- var infoWindow = getInfoWindow(options, events, element);
- mapController.addObject('infoWindows', infoWindow);
- parser.observeAttrSetObj(orgAttrs, attrs, infoWindow); /* observers */
- // show InfoWindow when initialized
- if (infoWindow.visible) {
- //if (!infoWindow.position) { throw "Invalid position"; }
- scope.$on('mapInitialized', function(evt, map) {
- $timeout(function() {
- infoWindow.__template = infoWindow.__eval.apply(this, [evt]);
- infoWindow.__compile(scope);
- infoWindow.map = map;
- infoWindow.position && infoWindow.open(map);
- });
- });
- }
- // show InfoWindow on a marker when initialized
- if (infoWindow.visibleOnMarker) {
- scope.$on('mapInitialized', function(evt, map) {
- $timeout(function() {
- var markerId = infoWindow.visibleOnMarker;
- var marker = map.markers[markerId];
- if (!marker) throw "Invalid marker id";
- infoWindow.__template = infoWindow.__eval.apply(this, [evt]);
- infoWindow.__compile(scope);
- infoWindow.open(map, marker);
- });
- });
- }
- /**
- * provide showInfoWindow method to scope
- */
- scope.showInfoWindow = scope.showInfoWindow ||
- function(event, id, anchor) {
- var infoWindow = mapController.map.infoWindows[id],
- tempTemplate = infoWindow.__template; // set template in a temporary variable
- infoWindow.__template = infoWindow.__eval.apply(this, [event]);
- infoWindow.__compile(scope);
- if (anchor) {
- infoWindow.open(mapController.map, anchor);
- } else if (this.getPosition) {
- infoWindow.open(mapController.map, this);
- } else {
- infoWindow.open(mapController.map);
- }
- infoWindow.__template = tempTemplate; // reset template to the object
- };
- /**
- * provide hideInfoWindow method to scope
- */
- scope.hideInfoWindow = scope.hideInfoWindow ||
- function(event, id, anchor) {
- var infoWindow = mapController.map.infoWindows[id];
- infoWindow.__template = infoWindow.__eval.apply(this, [event]);
- infoWindow.__compile(scope);
- infoWindow.close();
- };
- } //link
- }; // return
- }]);// function
- </code></pre>
- </article>
- </section>
- </div>
- <nav>
- <h2><a href="index.html">Index</a></h2><h3>service</h3><ul><li><a href="Attr2Options.html">Attr2Options</a></li><li><a href="GeoCoder.html">GeoCoder</a></li><li><a href="NavigatorGeolocation.html">NavigatorGeolocation</a></li><li><a href="StreetView.html">StreetView</a></li></ul><h3>directive</h3><ul><li><a href="bicycling-layer.html">bicycling-layer</a></li><li><a href="cloud-layer.html">cloud-layer</a></li><li><a href="custom-control.html">custom-control</a></li><li><a href="drawing-manager.html">drawing-manager</a></li><li><a href="dynamic-maps-engine-layer.html">dynamic-maps-engine-layer</a></li><li><a href="fusion-tables-layer.html">fusion-tables-layer</a></li><li><a href="heatmap-layer.html">heatmap-layer</a></li><li><a href="info-window.html">info-window</a></li><li><a href="kml-layer.html">kml-layer</a></li><li><a href="lazy-load.html">lazy-load</a></li><li><a href="map.html">map</a></li><li><a href="map-data.html">map-data</a></li><li><a href="map-type.html">map-type</a></li><li><a href="MapController.html">MapController</a></li><li><a href="maps-engine-layer.html">maps-engine-layer</a></li><li><a href="marker.html">marker</a></li><li><a href="overlay-map-type.html">overlay-map-type</a></li><li><a href="shape.html">shape</a></li><li><a href="traffic-layer.html">traffic-layer</a></li><li><a href="transit-layer.html">transit-layer</a></li><li><a href="weather-layer.html">weather-layer</a></li></ul>
- </nav>
- <br clear="both">
- <footer>
- Documentation generated by <a href="https://github.com/jsdoc3/jsdoc">JSDoc 3.3.0-alpha9</a>
- and <a href="https://github.com/allenhwkim/angular-jsdoc">angular-jsdoc</a>
- </footer>
- <script> prettyPrint(); </script>
- <script src="scripts/linenumber.js"> </script>
- <script>
- var href=window.location.href.match(/\/([^\/]+$)/)[1];
- document.querySelector("nav a[href='"+href+"']").scrollIntoView(true);
- if (window.location.hash == "")
- document.querySelector("body").scrollIntoView(true);
- </script>
- </body>
- </html>
|