X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/250bb47cc2723c7af6fac0a6e9e900c1a50f9292..e54eadea95296a68044bd3f2b092b978a808f1b7:/app/assets/javascripts/index/directions/osrm.js
diff --git a/app/assets/javascripts/index/directions/osrm.js b/app/assets/javascripts/index/directions/osrm.js
index 05cb32f20..ab3bcff36 100644
--- a/app/assets/javascripts/index/directions/osrm.js
+++ b/app/assets/javascripts/index/directions/osrm.js
@@ -12,43 +12,49 @@ function OSRMEngine() {
getRoute: function (points, callback) {
var TURN_INSTRUCTIONS = [
"",
- I18n.t('javascripts.directions.instructions.continue_on'), // 1
- I18n.t('javascripts.directions.instructions.slight_right'), // 2
- I18n.t('javascripts.directions.instructions.turn_right'), // 3
- I18n.t('javascripts.directions.instructions.sharp_right'), // 4
- I18n.t('javascripts.directions.instructions.uturn'), // 5
- I18n.t('javascripts.directions.instructions.sharp_left'), // 6
- I18n.t('javascripts.directions.instructions.turn_left'), // 7
- I18n.t('javascripts.directions.instructions.slight_left'), // 8
- I18n.t('javascripts.directions.instructions.via_point'), // 9
- I18n.t('javascripts.directions.instructions.follow'), // 10
- I18n.t('javascripts.directions.instructions.roundabout'), // 11
- I18n.t('javascripts.directions.instructions.leave_roundabout'), // 12
- I18n.t('javascripts.directions.instructions.stay_roundabout'), // 13
- I18n.t('javascripts.directions.instructions.start'), // 14
- I18n.t('javascripts.directions.instructions.destination'), // 15
- I18n.t('javascripts.directions.instructions.against_oneway'), // 16
- I18n.t('javascripts.directions.instructions.end_oneway') // 17
+ 'javascripts.directions.instructions.continue', // 1
+ 'javascripts.directions.instructions.slight_right', // 2
+ 'javascripts.directions.instructions.turn_right', // 3
+ 'javascripts.directions.instructions.sharp_right', // 4
+ 'javascripts.directions.instructions.uturn', // 5
+ 'javascripts.directions.instructions.sharp_left', // 6
+ 'javascripts.directions.instructions.turn_left', // 7
+ 'javascripts.directions.instructions.slight_left', // 8
+ 'javascripts.directions.instructions.via_point', // 9
+ 'javascripts.directions.instructions.follow', // 10
+ 'javascripts.directions.instructions.roundabout', // 11
+ 'javascripts.directions.instructions.leave_roundabout', // 12
+ 'javascripts.directions.instructions.stay_roundabout', // 13
+ 'javascripts.directions.instructions.start', // 14
+ 'javascripts.directions.instructions.destination', // 15
+ 'javascripts.directions.instructions.against_oneway', // 16
+ 'javascripts.directions.instructions.end_oneway' // 17
];
- var url = document.location.protocol + "//router.project-osrm.org/viaroute?z=14&output=json&instructions=true";
+ var params = [
+ { name: "z", value: "14" },
+ { name: "output", value: "json" },
+ { name: "instructions", value: true }
+ ];
for (var i = 0; i < points.length; i++) {
- url += "&loc=" + points[i].lat + ',' + points[i].lng;
+ params.push({ name: "loc", value: points[i].lat + "," + points[i].lng });
+
if (hintData && previousPoints && previousPoints[i].equals(points[i])) {
- url += "&hint=" + hintData.locations[i];
+ params.push({ name: "hint", value: hintData.locations[i] });
}
}
if (hintData && hintData.checksum) {
- url += "&checksum=" + hintData.checksum;
+ params.push({ name: "checksum", value: hintData.checksum });
}
- $.ajax({
- url: url,
- dataType: 'json',
+ return $.ajax({
+ url: document.location.protocol + "//router.project-osrm.org/viaroute",
+ data: params,
+ dataType: "json",
success: function (data) {
- if (data.status == 207)
+ if (data.status === 207)
return callback(true);
previousPoints = points;
@@ -64,12 +70,11 @@ function OSRMEngine() {
var linesegend;
var instCodes = s[0].split('-');
var instText = "" + (i + 1) + ". ";
- 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');
+ var name = s[1] ? "" + s[1] + "" : I18n.t('javascripts.directions.instructions.unnamed');
+ if (instCodes[0] === "11" && instCodes[1]) {
+ instText += I18n.t(TURN_INSTRUCTIONS[instCodes[0]] + '_with_exit', { exit: instCodes[1], name: name } );
+ } else {
+ instText += I18n.t(TURN_INSTRUCTIONS[instCodes[0]] + '_without_exit', { name: name });
}
if ((i + 1) < data.route_instructions.length) {
linesegend = data.route_instructions[i + 1][3] + 1;
@@ -91,4 +96,4 @@ function OSRMEngine() {
};
}
-OSM.Directions.addEngine(OSRMEngine(), true);
+OSM.Directions.addEngine(new OSRMEngine(), true);