X-Git-Url: https://git.openstreetmap.org./nominatim-ui.git/blobdiff_plain/9e8d3367fe08a708b1019ff39ac752e0105be20a..9ad36e2ce2a63535b7071acd26bc819d989b2f17:/src/lib/stores.js?ds=sidebyside diff --git a/src/lib/stores.js b/src/lib/stores.js index a7a524a..5e755c1 100644 --- a/src/lib/stores.js +++ b/src/lib/stores.js @@ -1,8 +1,10 @@ import { writable } from 'svelte/store'; +import { identifyLinkInQuery } from './helpers.js'; export const map_store = writable(); export const results_store = writable(); export const last_api_request_url_store = writable(); +export const error_store = writable(); export const page = writable(); /** @@ -15,16 +17,27 @@ export const page = writable(); * the requested query parameters. It may also be omitted completely for a * link without query parameters. */ +const default_pagename = Nominatim_Config.Reverse_Only ? 'reverse' : 'search'; +const pagenames = [ + default_pagename, + 'reverse', + 'details', + 'deletable', + 'polygons', + 'status', + 'about' +]; + export function refresh_page(pagename, params) { if (typeof pagename === 'undefined') { pagename = window.location.pathname.replace('.html', '').replace(/^.*\//, ''); - if (['search', 'reverse', 'details', 'deletable', 'polygons'].indexOf(pagename) === -1) { - pagename = 'search'; - } + if (!pagenames.includes(pagename)) pagename = default_pagename; params = new URLSearchParams(window.location.search); } else { + if (!pagenames.includes(pagename)) pagename = default_pagename; + if (typeof params === 'undefined') { params = new URLSearchParams(); } @@ -33,8 +46,26 @@ export function refresh_page(pagename, params) { if (param_str) { param_str = '?' + param_str; } - window.history.pushState([], '', pagename + '.html' + param_str); + let new_url = pagename + '.html' + param_str; + + if (window.location.protocol.match(/^http/)) { + window.history.pushState([], '', new_url); + } else { + window.location.href = new_url; + } + } + + if (pagename === 'search' && params.has('q')) { + const arrTypeAndId = identifyLinkInQuery(params.get('q')); + if (arrTypeAndId instanceof Array) { + pagename = 'details'; + params = new URLSearchParams(); + params.set('osmtype', arrTypeAndId[0]); + params.set('osmid', arrTypeAndId[1]); + } } page.set({ tab: pagename, params: params }); + last_api_request_url_store.set(null); + error_store.set(null); }