diff options
| author | SimonBrazell <simon@brazell.com.au> | 2020-02-24 19:22:10 +1100 | 
|---|---|---|
| committer | SimonBrazell <simon@brazell.com.au> | 2020-02-24 19:22:10 +1100 | 
| commit | dcef0c8076fbb1edcc4f721e5511f9ee58bcde18 (patch) | |
| tree | 6bc2d4862a0c402bed20ecace484b10061c403ea /background.js | |
| parent | OSM redirects (except embedded maps) (diff) | |
| download | libredirect-dcef0c8076fbb1edcc4f721e5511f9ee58bcde18.zip | |
Fix OSM redirects
Diffstat (limited to '')
| -rw-r--r-- | background.js | 16 | 
1 files changed, 9 insertions, 7 deletions
| diff --git a/background.js b/background.js index dd620d86..b6575f6a 100644 --- a/background.js +++ b/background.js @@ -8,7 +8,7 @@ const bibliogramDefault = 'https://bibliogram.art'; const instagramRegex = /((www|about|help)\.)?instagram\.com/; const instagramPathsRegex = /(\/a|\/admin|\/api|\/favicon.ico|\/static|\/imageproxy|\/p|\/u|\/developer|\/about|\/legal|\/explore|\/director)/; const osmDefault = 'https://openstreetmap.org'; -const googleMapsRegex = /https?:\/\/((www|maps)\.)?(google).*(\/maps)/; +const googleMapsRegex = /https?:\/\/(((www|maps)\.)?(google).*(\/maps)|maps\.(google).*)/; const latLngZoomRegex = /@(-?\d[0-9.]*),(-?\d[0-9.]*),(\d{1,2})[.z]/; const dataLatLngRegex = /(!3d|!4d)(-?[0-9]{1,10}.[0-9]{1,10})/g; @@ -113,18 +113,20 @@ function redirectGoogleMaps(url) { if (url.pathname.includes('/embed')) { return; } - let lat = ''; - let lon = ''; - let zoom = ''; + let mapCentre = ''; if (url.pathname.match(latLngZoomRegex)) { [, lat, lon, zoom] = url.pathname.match(latLngZoomRegex); + mapCentre = `#map=${zoom}/${lat}/${lon}`; } if (url.pathname.includes('data=')) { const [mlat, mlon] = url.pathname.match(dataLatLngRegex); - return `${osmInstance}/?mlat=${mlat.replace('!3d', '')}&mlon=${mlon.replace('!4d', '')}#map=${zoom}/${lat}/${lon}`; + return `${osmInstance}/?mlat=${mlat.replace('!3d', '')}&mlon=${mlon.replace('!4d', '')}${mapCentre}`; + } else if (url.search.includes('ll=')) { + const [mlat, mlon] = url.searchParams.get('ll').split(','); + return `${osmInstance}/?mlat=${mlat}&mlon=${mlon}${mapCentre}`; } else { - const query = encodeURI(url.searchParams.get('q')) || url.pathname.split('/')[3]; - return `${osmInstance}/search?query=${query}#map=${zoom}/${lat}/${lon}`; + const query = url.searchParams.get('q') || url.searchParams.get('query') || url.pathname.split('/')[3]; + return `${osmInstance}/search?query=${encodeURI(query)}${mapCentre}`; } } | 
