123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 |
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>JSDoc: Source: directives/custom-control.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/custom-control.js</h1>
-
-
- <section>
- <article>
- <pre class="prettyprint source linenums"><code>/*jshint -W030*/
- /**
- * @ngdoc directive
- * @name custom-control
- * @requires Attr2Options
- * @requires $compile
- * @description
- * Build custom control and set to the map with position
- *
- * Requires: map directive
- *
- * Restrict To: Element
- *
- * @param {String} position position of this control
- * i.e. TOP_RIGHT
- * @param {Number} index index of the control
- * @example
- *
- * Example:
- * <map center="41.850033,-87.6500523" zoom="3">
- * <custom-control id="home" position="TOP_LEFT" index="1">
- * <div style="background-color: white;">
- * <b>Home</b>
- * </div>
- * </custom-control>
- * </map>
- *
- */
- /*jshint -W089*/
- ngMap.directive('customControl', ['Attr2Options', '$compile', function(Attr2Options, $compile) {
- var parser = Attr2Options;
- 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("custom-control options", options, "events", events);
- /**
- * build a custom control element
- */
- var compiled = $compile(element.html().trim())(scope);
- var customControlEl = compiled[0];
- /**
- * set events
- */
- for (var eventName in events) {
- google.maps.event.addDomListener(customControlEl, eventName, events[eventName]);
- }
- mapController.addObject('customControls', customControlEl);
- scope.$on('mapInitialized', function(evt, map) {
- var position = options.position;
- map.controls[google.maps.ControlPosition[position]].push(customControlEl);
- });
- } //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>
|