diff --git a/app/assets/javascripts/routing_engines/mapquest.js b/app/assets/javascripts/routing_engines/mapquest.js
new file mode 100644
index 000000000..f31a84458
--- /dev/null
+++ b/app/assets/javascripts/routing_engines/mapquest.js
@@ -0,0 +1,81 @@
+// see:
+// http://developer.mapquest.com/web/products/open/directions-service
+// http://open.mapquestapi.com/directions/
+// https://github.com/apmon/openstreetmap-website/blob/21edc353a4558006f0ce23f5ec3930be6a7d4c8b/app/controllers/routing_controller.rb#L153
+
+MapQuestEngine = function(vehicleName, vehicleParam, locale) {
+ this.vehicleName = vehicleName;
+ this.vehicleParam = vehicleParam;
+ this.locale = locale;
+ if (!locale)
+ this.locale = "en";
+};
+
+MapQuestEngine.prototype.createConfig = function() {
+ var that = this;
+ return {
+ name: "javascripts.directions.engines.mapquest_"+this.vehicleName.toLowerCase(),
+ creditline: 'Directions courtesy of MapQuest
',
+ draggable: false,
+ _hints: {},
+ MQ_SPRITE_MAP: {
+ 0: 1, // straight
+ 1: 2, // slight right
+ 2: 3, // right
+ 3: 4, // sharp right
+ 4: 5, // reverse
+ 5: 6, // sharp left
+ 6: 7, // left
+ 7: 8, // slight left
+ 8: 5, // right U-turn
+ 9: 5, // left U-turn
+ 10: 2, // right merge
+ 11: 8, // left merge
+ 12: 2, // right on-ramp
+ 13: 8, // left on-ramp
+ 14: 2, // right off-ramp
+ 15: 8, // left off-ramp
+ 16: 2, // right fork
+ 17: 8, // left fork
+ 18: 1 // straight fork
+ },
+ getRoute: function(isFinal,points) {
+ var url="http://open.mapquestapi.com/directions/v2/route?key=Fmjtd%7Cluur290anu%2Crl%3Do5-908a0y";
+ var from=points[0]; var to=points[points.length-1];
+ url+="&from="+from.join(',');
+ url+="&to="+to.join(',');
+ url+="&"+that.vehicleParam;
+ //url+="&locale=" + I18n.currentLocale(); //Doesn't actually work. MapQuest requires full locale e.g. "de_DE", but I18n only provides language, e.g. "de"
+ url+="&manMaps=false";
+ url+="&shapeFormat=raw&generalize=0";
+ this.requestJSONP(url+"&callback=");
+ },
+ gotRoute: function(router,data) {
+ // *** what if no route?
+
+ var poly=[];
+ var shape=data.route.shape.shapePoints;
+ for (var i=0; iMapQuest
',
- draggable: false,
- _hints: {},
- MQ_SPRITE_MAP: {
- 0: 1, // straight
- 1: 2, // slight right
- 2: 3, // right
- 3: 4, // sharp right
- 4: 5, // reverse
- 5: 6, // sharp left
- 6: 7, // left
- 7: 8, // slight left
- 8: 5, // right U-turn
- 9: 5, // left U-turn
- 10: 2, // right merge
- 11: 8, // left merge
- 12: 2, // right on-ramp
- 13: 8, // left on-ramp
- 14: 2, // right off-ramp
- 15: 8, // left off-ramp
- 16: 2, // right fork
- 17: 8, // left fork
- 18: 1 // straight fork
- },
- getRoute: function(isFinal,points) {
- var url="http://open.mapquestapi.com/directions/v2/route?key=Fmjtd%7Cluur290anu%2Crl%3Do5-908a0y";
- var from=points[0]; var to=points[points.length-1];
- url+="&from="+from.join(',');
- url+="&to="+to.join(',');
- url+="&routeType=bicycle";
- //url+="&locale=" + I18n.currentLocale(); //Doesn't actually work. MapQuest requires full locale e.g. "de_DE", but I18n only provides language, e.g. "de"
- url+="&manMaps=false";
- url+="&shapeFormat=raw&generalize=0";
- this.requestJSONP(url+"&callback=");
- },
- gotRoute: function(router,data) {
- // *** what if no route?
-
- var poly=[];
- var shape=data.route.shape.shapePoints;
- for (var i=0; iOSRM',
+ draggable: true,
+ _hints: {},
+ getRoute: function(isFinal,points) {
+ var url=that.baseURL+"?z=14&output=json";
+ for (var i=0; i ";
+ instText+=TURN_INSTRUCTIONS[instCodes[0]];
+ if (instCodes[1]) { instText+="exit "+instCodes[1]+" "; }
+ if (instCodes[0]!=15) { instText+=s[1] ? ""+s[1]+"" : I18n.t('javascripts.directions.instructions.unnamed'); }
+ steps.push([line[s[3]], s[0].split('-')[0], instText, s[2]]);
+ }
+ if (steps.length) router.setItinerary({ steps: steps });
+ return true;
+ }
+ };
+};
+
+OSM.RoutingEngines.list.push(new OSRMEngine("Car", "http://router.project-osrm.org/viaroute").createConfig());
diff --git a/app/assets/javascripts/routing_engines/osrm_car.js b/app/assets/javascripts/routing_engines/osrm_car.js
deleted file mode 100644
index 8ff6ba482..000000000
--- a/app/assets/javascripts/routing_engines/osrm_car.js
+++ /dev/null
@@ -1,43 +0,0 @@
-// OSRM car engine
-// *** this should all be shared from an OSRM library somewhere
-// *** need to clear hints at some point
-
-OSM.RoutingEngines.list.push({
- name: "javascripts.directions.engines.osrm_car",
- creditline: 'Directions courtesy of OSRM',
- draggable: true,
- _hints: {},
- getRoute: function(isFinal,points) {
- var url="http://router.project-osrm.org/viaroute?z=14&output=json";
- for (var i=0; i ";
- instText+=TURN_INSTRUCTIONS[instCodes[0]];
- if (instCodes[1]) { instText+="exit "+instCodes[1]+" "; }
- if (instCodes[0]!=15) { instText+=s[1] ? ""+s[1]+"" : I18n.t('javascripts.directions.instructions.unnamed'); }
- steps.push([line[s[3]], s[0].split('-')[0], instText, s[2]]);
- }
- if (steps.length) router.setItinerary({ steps: steps });
- return true;
- }
-});
diff --git a/config/locales/en.yml b/config/locales/en.yml
index 8cb9c9674..e5bb7f3f0 100644
--- a/config/locales/en.yml
+++ b/config/locales/en.yml
@@ -2122,9 +2122,10 @@ en:
engines:
graphhopper_bicycle: "Bicycle (GraphHopper)"
graphhopper_foot: "Foot (GraphHopper)"
- mapquest_bike: "Bicycle (MapQuest)"
+ mapquest_bicycle: "Bicycle (MapQuest)"
+ mapquest_car: "Car (MapQuest)"
+ mapquest_foot: "Foot (MapQuest)"
osrm_car: "Car (OSRM)"
- cloudmade_foot: "Foot (Cloudmade)"
directions: "Directions"
errors:
no_route: "Couldn't find a route between those two places."