X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/cbea796ef412840af9a3ec2fd26bf08657fc4cd3..00108bc9b7e9e03a47d89343e7f53eb924977ff8:/app/assets/javascripts/router.js diff --git a/app/assets/javascripts/router.js b/app/assets/javascripts/router.js index a2a20b846..2e4b375d7 100644 --- a/app/assets/javascripts/router.js +++ b/app/assets/javascripts/router.js @@ -47,13 +47,13 @@ move the map without the hash changing. */ OSM.Router = function (map, rts) { - var escapeRegExp = /[-{}[\]+?.,\\^$|#\s]/g; - var optionalParam = /\((.*?)\)/g; - var namedParam = /(\(\?)?:\w+/g; - var splatParam = /\*\w+/g; + const escapeRegExp = /[-{}[\]+?.,\\^$|#\s]/g; + const optionalParam = /\((.*?)\)/g; + const namedParam = /(\(\?)?:\w+/g; + const splatParam = /\*\w+/g; function Route(path, controller) { - var regexp = new RegExp("^" + + const regexp = new RegExp("^" + path.replace(escapeRegExp, "\\$&") .replace(optionalParam, "(?:$1)?") .replace(namedParam, function (match, optional) { @@ -61,14 +61,14 @@ OSM.Router = function (map, rts) { }) .replace(splatParam, "(.*?)") + "(?:\\?.*)?$"); - var route = {}; + const route = {}; route.match = function (path) { return regexp.test(path); }; route.run = function (action, path) { - var params = []; + let params = []; if (path) { params = regexp.exec(path).map(function (param, i) { @@ -84,83 +84,80 @@ OSM.Router = function (map, rts) { return route; } - var routes = []; - for (var r in rts) { - routes.push(new Route(r, rts[r])); - } + const routes = Object.entries(rts) + .map(([r, t]) => new Route(r, t)); routes.recognize = function (path) { - for (var i = 0; i < this.length; i++) { - if (this[i].match(path)) return this[i]; + for (const route of this) { + if (route.match(path)) return route; } }; - var currentPath = window.location.pathname.replace(/(.)\/$/, "$1") + window.location.search, - currentRoute = routes.recognize(currentPath), - currentHash = location.hash || OSM.formatHash(map); - - var router = {}; - - if (window.history && window.history.pushState) { - $(window).on("popstate", function (e) { - if (!e.originalEvent.state) return; // Is it a real popstate event or just a hash change? - var path = window.location.pathname + window.location.search, - route = routes.recognize(path); - if (path === currentPath) return; - currentRoute.run("unload", null, route === currentRoute); - currentPath = path; - currentRoute = route; - currentRoute.run("popstate", currentPath); - map.setState(e.originalEvent.state, { animate: false }); - }); + let currentPath = window.location.pathname.replace(/(.)\/$/, "$1") + window.location.search, + currentRoute = routes.recognize(currentPath), + currentHash = location.hash || OSM.formatHash(map); - router.route = function (url) { - var path = url.replace(/#.*/, ""), - route = routes.recognize(path); - if (!route) return false; - currentRoute.run("unload", null, route === currentRoute); - var state = OSM.parseHash(url); - map.setState(state); - window.history.pushState(state, document.title, url); - currentPath = path; - currentRoute = route; - currentRoute.run("pushstate", currentPath); - return true; - }; - - router.replace = function (url) { - window.history.replaceState(OSM.parseHash(url), document.title, url); - }; + const router = {}; - router.stateChange = function (state) { - if (state.center) { - window.history.replaceState(state, document.title, OSM.formatHash(state)); - } else { - window.history.replaceState(state, document.title, window.location); - } - }; - } else { - router.route = router.replace = function (url) { - window.location.assign(url); - }; + function updateSecondaryNav() { + $("header nav.secondary > ul > li > a").each(function () { + const active = $(this).attr("href") === window.location.pathname; - router.stateChange = function (state) { - if (state.center) window.location.replace(OSM.formatHash(state)); - }; + $(this) + .toggleClass("text-secondary", !active) + .toggleClass("text-secondary-emphasis", active); + }); } + $(window).on("popstate", function (e) { + if (!e.originalEvent.state) return; // Is it a real popstate event or just a hash change? + const path = window.location.pathname + window.location.search, + route = routes.recognize(path); + if (path === currentPath) return; + currentRoute.run("unload", null, route === currentRoute); + currentPath = path; + currentRoute = route; + currentRoute.run("popstate", currentPath); + updateSecondaryNav(); + map.setState(e.originalEvent.state, { animate: false }); + }); + + router.route = function (url) { + const path = url.replace(/#.*/, ""), + route = routes.recognize(path); + if (!route) return false; + currentRoute.run("unload", null, route === currentRoute); + const state = OSM.parseHash(url); + map.setState(state); + window.history.pushState(state, document.title, url); + currentPath = path; + currentRoute = route; + currentRoute.run("pushstate", currentPath); + updateSecondaryNav(); + return true; + }; + + router.replace = function (url) { + window.history.replaceState(OSM.parseHash(url), document.title, url); + }; + + router.stateChange = function (state) { + const url = state.center ? OSM.formatHash(state) : window.location; + window.history.replaceState(state, document.title, url); + }; + router.updateHash = function () { - var hash = OSM.formatHash(map); + const hash = OSM.formatHash(map); if (hash === currentHash) return; currentHash = hash; router.stateChange(OSM.parseHash(hash)); }; router.hashUpdated = function () { - var hash = location.hash; + const hash = location.hash; if (hash === currentHash) return; currentHash = hash; - var state = OSM.parseHash(hash); + const state = OSM.parseHash(hash); map.setState(state); router.stateChange(state, hash); }; @@ -179,7 +176,7 @@ OSM.Router = function (map, rts) { }; router.load = function () { - var loadState = currentRoute.run("load", currentPath); + const loadState = currentRoute.run("load", currentPath); router.stateChange(loadState || {}); }; @@ -188,7 +185,7 @@ OSM.Router = function (map, rts) { currentRoute = routes.recognize(currentPath); }; - map.on("moveend baselayerchange overlaylayerchange", router.updateHash); + map.on("moveend baselayerchange overlayadd overlayremove", router.updateHash); $(window).on("hashchange", router.hashUpdated); return router;