- point: points.map(function (p) { return p.lat + "," + p.lng; })
- },
- traditional: true,
- dataType: "jsonp",
- success: function (data) {
- if (!data.paths || data.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) ? 15 : GH_INSTR_MAP[instr.sign];
- var instrText = "<b>" + (i + 1) + ".</b> ";
- instrText += instr.text;
- var latLng = line[instr.interval[0]];
- var distInMeter = instr.distance;
- steps.push([
- {lat: latLng.lat, lng: latLng.lng},
- instrCode,
- instrText,
- distInMeter,
- []
- ]); // TODO does graphhopper map instructions onto line indices?
- }
-
- callback(false, {
- line: line,
- steps: steps,
- distance: path.distance,
- time: path.time / 1000
+ turn_costs: vehicleType === "car"
+ });
+ points.forEach(p => query.append("point", p.lat + "," + p.lng));
+ return fetch(OSM.GRAPHHOPPER_URL + "?" + query, { signal })
+ .then(response => response.json())
+ .then(({ paths }) => {
+ if (!paths || paths.length === 0) throw new Error();
+ return _processDirections(paths[0]);