X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/a9dcb66e7b835a45902e1257f47be3f625389831..4027d0c30abb5c50ac61785a57a8699de000ddd7:/app/assets/javascripts/index/directions/graphhopper.js diff --git a/app/assets/javascripts/index/directions/graphhopper.js b/app/assets/javascripts/index/directions/graphhopper.js index 021fc7b64..191475873 100644 --- a/app/assets/javascripts/index/directions/graphhopper.js +++ b/app/assets/javascripts/index/directions/graphhopper.js @@ -1,6 +1,6 @@ (function () { function GraphHopperEngine(id, vehicleType) { - var GH_INSTR_MAP = { + const GH_INSTR_MAP = { "-3": 7, // sharp left "-2": 6, // left "-1": 5, // slight left @@ -18,65 +18,61 @@ "8": 4 // right u-turn }; + function _processDirections(path) { + const line = L.PolylineUtil.decode(path.points); + + const steps = path.instructions.map(function (instr, i) { + const num = `${i + 1}. `; + const lineseg = line + .slice(instr.interval[0], instr.interval[1] + 1) + .map(([lat, lng]) => ({ lat, lng })); + return [ + lineseg[0], + GH_INSTR_MAP[instr.sign], + num + instr.text, + instr.distance, + lineseg + ]; // TODO does graphhopper map instructions onto line indices? + }); + steps.at(-1)[1] = 14; + + return { + line: line, + steps: steps, + distance: path.distance, + time: path.time / 1000, + ascend: path.ascend, + descend: path.descend + }; + } + return { id: id, creditline: "GraphHopper", draggable: false, getRoute: function (points, callback) { - // GraphHopper Directions API documentation - // https://graphhopper.com/api/1/docs/routing/ + // GraphHopper Directions API documentation + // https://graphhopper.com/api/1/docs/routing/ + const data = { + vehicle: vehicleType, + locale: I18n.currentLocale(), + key: "LijBPDQGfu7Iiq80w3HzwB4RUDJbMbhs6BU0dEnn", + elevation: false, + instructions: true, + turn_costs: vehicleType === "car", + point: points.map(p => p.lat + "," + p.lng) + }; return $.ajax({ url: OSM.GRAPHHOPPER_URL, - data: { - vehicle: vehicleType, - locale: I18n.currentLocale(), - key: "LijBPDQGfu7Iiq80w3HzwB4RUDJbMbhs6BU0dEnn", - elevation: false, - instructions: true, - turn_costs: vehicleType === "car", - point: points.map(function (p) { return p.lat + "," + p.lng; }) - }, + data, traditional: true, dataType: "json", - success: function (data) { - if (!data.paths || data.paths.length === 0) { + success: function ({ paths }) { + if (!paths || paths.length === 0) { return callback(true); } - - var path = data.paths[0]; - var line = L.PolylineUtil.decode(path.points); - - var steps = []; - var len = path.instructions.length; - for (var i = 0; i < len; i++) { - var instr = path.instructions[i]; - var instrCode = (i === len - 1) ? 14 : GH_INSTR_MAP[instr.sign]; - var instrText = "" + (i + 1) + ". "; - instrText += instr.text; - var latLng = line[instr.interval[0]]; - var distInMeter = instr.distance; - var lineseg = []; - for (var j = instr.interval[0]; j <= instr.interval[1]; j++) { - lineseg.push({ lat: line[j][0], lng: line[j][1] }); - } - steps.push([ - { lat: latLng[0], lng: latLng[1] }, - instrCode, - instrText, - distInMeter, - lineseg - ]); // TODO does graphhopper map instructions onto line indices? - } - - callback(false, { - line: line, - steps: steps, - distance: path.distance, - time: path.time / 1000, - ascend: path.ascend, - descend: path.descend - }); + callback(false, _processDirections(paths[0])); }, error: function () { callback(true);