X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/38213ab588ae00af7369252fe4b59ab530a27432..38180c56c9be9d99406c9088b60f5912c2648a04:/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 ab3bcff36..2ee9da12b 100644
--- a/app/assets/javascripts/index/directions/osrm.js
+++ b/app/assets/javascripts/index/directions/osrm.js
@@ -28,7 +28,8 @@ function OSRMEngine() {
'javascripts.directions.instructions.start', // 14
'javascripts.directions.instructions.destination', // 15
'javascripts.directions.instructions.against_oneway', // 16
- 'javascripts.directions.instructions.end_oneway' // 17
+ 'javascripts.directions.instructions.end_oneway', // 17
+ 'javascripts.directions.instructions.ferry' // 18
];
var params = [
@@ -50,7 +51,7 @@ function OSRMEngine() {
}
return $.ajax({
- url: document.location.protocol + "//router.project-osrm.org/viaroute",
+ url: document.location.protocol + OSM.OSRM_URL,
data: params,
dataType: "json",
success: function (data) {
@@ -69,6 +70,10 @@ function OSRMEngine() {
var s = data.route_instructions[i];
var linesegend;
var instCodes = s[0].split('-');
+ if (s[8] === 2) {
+ /* indicates a ferry in car routing mode, see https://github.com/Project-OSRM/osrm-backend/blob/6cbbd1e5a1b441eb27055f56956e1bac14832a58/profiles/car.lua#L151 */
+ instCodes = ["18"];
+ }
var instText = "" + (i + 1) + ". ";
var name = s[1] ? "" + s[1] + "" : I18n.t('javascripts.directions.instructions.unnamed');
if (instCodes[0] === "11" && instCodes[1]) {
@@ -81,15 +86,18 @@ function OSRMEngine() {
} else {
linesegend = s[3] + 1;
}
- steps.push([line[s[3]], s[0].split('-')[0], instText, s[2], line.slice(s[3], linesegend)]);
+ steps.push([line[s[3]], instCodes[0], instText, s[2], line.slice(s[3], linesegend)]);
}
- callback(null, {
+ callback(false, {
line: line,
steps: steps,
distance: data.route_summary.total_distance,
time: data.route_summary.total_time
});
+ },
+ error: function () {
+ callback(true);
}
});
}