|
30 | 30 | 'use strict'; |
31 | 31 | var NgMap, $timeout, NavigatorGeolocation; |
32 | 32 |
|
| 33 | + var requestTimeout, routeRequest; |
| 34 | + // Delay for each route render to accumulate all requests into a single one |
| 35 | + // This is required for simultaneous origin\waypoints\destination change |
| 36 | + // 20ms should be enough to merge all request data |
| 37 | + var routeRenderDelay = 20; |
| 38 | + |
33 | 39 | var getDirectionsRenderer = function(options, events) { |
34 | 40 | if (options.panel) { |
35 | 41 | options.panel = document.getElementById(options.panel) || |
|
65 | 71 | } |
66 | 72 |
|
67 | 73 | var showDirections = function(request) { |
68 | | - directionsService.route(request, function(response, status) { |
69 | | - if (status == google.maps.DirectionsStatus.OK) { |
70 | | - $timeout(function() { |
71 | | - renderer.setDirections(response); |
72 | | - }); |
| 74 | + if (requestTimeout) { |
| 75 | + for (var attr in request) |
| 76 | + { |
| 77 | + if (request.hasOwnProperty(attr)) |
| 78 | + { |
| 79 | + routeRequest[attr] = request[attr]; |
| 80 | + } |
73 | 81 | } |
74 | | - }); |
| 82 | + } |
| 83 | + else |
| 84 | + { |
| 85 | + requestTimeout = $timeout(function() { |
| 86 | + if (!routeRequest) |
| 87 | + { |
| 88 | + routeRequest = request; |
| 89 | + } |
| 90 | + directionsService.route(routeRequest, function(response, status) { |
| 91 | + if (status == google.maps.DirectionsStatus.OK) { |
| 92 | + renderer.setDirections(response); |
| 93 | + } |
| 94 | + }); |
| 95 | + requestTimeout = undefined; |
| 96 | + }, routeRenderDelay); |
| 97 | + } |
75 | 98 | }; |
76 | 99 |
|
77 | 100 | if (request.origin && request.destination) { |
|
0 commit comments