});
function formatDistance(m) {
- const unitTemplate = "javascripts.directions.distance_";
- if (m < 1000) return I18n.t(unitTemplate + "m", { distance: Math.round(m) });
- if (m < 10000) return I18n.t(unitTemplate + "km", { distance: (m / 1000.0).toFixed(1) });
- return I18n.t(unitTemplate + "km", { distance: Math.round(m / 1000) });
+ if (m < 1000) {
+ return I18n.t("javascripts.directions.distance_m", { distance: Math.round(m) });
+ } else if (m < 10000) {
+ return I18n.t("javascripts.directions.distance_km", { distance: (m / 1000.0).toFixed(1) });
+ } else {
+ return I18n.t("javascripts.directions.distance_km", { distance: Math.round(m / 1000) });
+ }
}
function formatHeight(m) {
// copy loading item to sidebar and display it. we copy it, rather than
// just using it in-place and replacing it in case it has to be used
// again.
- $("#sidebar_content").html($(".directions_form .loader_copy").html());
+ $("#directions_content").html($(".directions_form .loader_copy").html());
map.setSidebarOverlaid(false);
controller = new AbortController();
chosenEngine.getRoute(points, controller.signal).then(function (route) {
const turnByTurnTable = $("<table class='table table-hover table-sm mb-3'>")
.append($("<tbody>"));
- const directionsCloseButton = $("<button type='button' class='btn-close'>")
- .attr("aria-label", I18n.t("javascripts.close"));
- $("#sidebar_content")
+ $("#directions_content")
.empty()
.append(
- $("<div class='d-flex'>").append(
- $("<h2 class='flex-grow-1 text-break'>")
- .text(I18n.t("javascripts.directions.directions")),
- $("<div>").append(directionsCloseButton)),
distanceText,
turnByTurnTable
);
const [ll, direction, instruction, dist, lineseg] = step;
const row = $("<tr class='turn'/>");
- row.append("<td class='border-0'><div class='direction i" + direction + "'/></td> ");
+ if (direction) {
+ row.append("<td class='border-0'><svg width='20' height='20' class='d-block'><use href='#routing-sprite-" + direction + "' /></svg></td>");
+ } else {
+ row.append("<td class='border-0'>");
+ }
row.append("<td>" + instruction);
row.append("<td class='distance text-body-secondary text-end'>" + getDistText(dist));
URL.revokeObjectURL(downloadURL);
downloadURL = URL.createObjectURL(blob);
- $("#sidebar_content").append(`<p class="text-center"><a href="${downloadURL}" download="${
+ $("#directions_content").append(`<p class="text-center"><a href="${downloadURL}" download="${
I18n.t("javascripts.directions.filename")
}">${
I18n.t("javascripts.directions.download")
}</a></p>`);
- $("#sidebar_content").append("<p class=\"text-center\">" +
+ $("#directions_content").append("<p class=\"text-center\">" +
I18n.t("javascripts.directions.instructions.courtesy", { link: chosenEngine.creditline }) +
"</p>");
-
- directionsCloseButton.on("click", function () {
- map.removeLayer(polyline);
- $("#sidebar_content").html("");
- popup.close();
- map.setSidebarOverlaid(true);
- // TODO: collapse width of sidebar back to previous
- });
}).catch(function () {
map.removeLayer(polyline);
if (reportErrors) {
- $("#sidebar_content").html("<div class=\"alert alert-danger\">" + I18n.t("javascripts.directions.errors.no_route") + "</div>");
+ $("#directions_content").html("<div class=\"alert alert-danger\">" + I18n.t("javascripts.directions.errors.no_route") + "</div>");
}
}).finally(function () {
controller = null;
}
}
+ function hideRoute(e) {
+ e.stopPropagation();
+ map.removeLayer(polyline);
+ $("#directions_content").html("");
+ popup.close();
+ map.setSidebarOverlaid(true);
+ // TODO: collapse width of sidebar back to previous
+ }
+
setEngine("fossgis_osrm_car");
setEngine(Cookies.get("_osm_directions_engine"));
}
function enableListeners() {
+ $("#sidebar .sidebar-close-controls button").on("click", hideRoute);
+
$("#map").on("dragend dragover", function (e) {
e.preventDefault();
});
const page = {};
page.pushstate = page.popstate = function () {
+ if ($("#directions_content").length) {
+ page.load();
+ } else {
+ initializeFromParams();
+
+ $(".search_form").hide();
+ $(".directions_form").show();
+
+ OSM.loadSidebarContent("/directions", enableListeners);
+
+ map.setSidebarOverlaid(!endpoints[0].latlng || !endpoints[1].latlng);
+ }
+ };
+
+ page.load = function () {
initializeFromParams();
$(".search_form").hide();
map.setSidebarOverlaid(!endpoints[0].latlng || !endpoints[1].latlng);
};
- page.load = function () {
- page.pushstate();
- };
-
page.unload = function () {
$(".search_form").show();
$(".directions_form").hide();
+
+ $("#sidebar .sidebar-close-controls button").off("click", hideRoute);
$("#map").off("dragend dragover drop");
map.off("locationfound", sendstartinglocation);