Cancel any outstanding route when starting a new one
authorTom Hughes <tom@compton.nu>
Thu, 26 Feb 2015 18:39:31 +0000 (18:39 +0000)
committerTom Hughes <tom@compton.nu>
Thu, 26 Feb 2015 18:39:31 +0000 (18:39 +0000)
Fixes #913

app/assets/javascripts/index/directions.js
app/assets/javascripts/index/directions/graphhopper.js
app/assets/javascripts/index/directions/mapquest.js
app/assets/javascripts/index/directions/osrm.js

index 6149228ecb22ad02c79a5b10a5f9e8e33d2479b0..f7ac876369c2f21fb7288c602b28337e6293a4cc 100644 (file)
@@ -145,6 +145,9 @@ OSM.Directions = function (map) {
   }
 
   function getRoute() {
+    // Cancel any route that is already in progress
+    if (awaitingRoute) awaitingRoute.abourt();
+
     // go fetch geocodes for any endpoints which have not already
     // been geocoded.
     for (var ep_i = 0; ep_i < 2; ++ep_i) {
@@ -177,11 +180,10 @@ OSM.Directions = function (map) {
     // just using it in-place and replacing it in case it has to be used
     // again.
     $('#sidebar_content').html($('.directions_form .loader_copy').html());
-    awaitingRoute = true;
     map.setSidebarOverlaid(false);
 
-    chosenEngine.getRoute([o, d], function (err, route) {
-      awaitingRoute = false;
+    awaitingRoute = chosenEngine.getRoute([o, d], function (err, route) {
+      awaitingRoute = null;
 
       if (err) {
         map.removeLayer(polyline);
index deefe151755a89186b8b04e17bb66c23137bb07f..95cb29ab813c0ac61eb265281caf4a49c777b65b 100644 (file)
@@ -32,7 +32,7 @@ function GraphHopperEngine(id, vehicleParam) {
         url += "&point=" + points[i].lat + ',' + points[i].lng;
       }
 
-      $.ajax({
+      return $.ajax({
         url: url,
         dataType: 'jsonp',
         success: function (data) {
index 6b24fb3bc22a426a8091828b2a03d5504a9b82d1..fbbc55a5f660f2c2e89721a4fcaf4b8c85b23725 100644 (file)
@@ -42,7 +42,7 @@ function MapQuestEngine(id, vehicleParam) {
       url += "&manMaps=false";
       url += "&shapeFormat=raw&generalize=0&unit=k";
 
-      $.ajax({
+      return $.ajax({
         url: url,
         success: function (data) {
           if (data.info.statuscode !== 0)
index 842909eabc47cb5e4dc2d920b0013846f4ccae93..b58ba30a28c3dcf347b7b11957338f01ee66afa9 100644 (file)
@@ -44,7 +44,7 @@ function OSRMEngine() {
         url += "&checksum=" + hintData.checksum;
       }
 
-      $.ajax({
+      return $.ajax({
         url: url,
         dataType: 'json',
         success: function (data) {