keep router buffer on tab reload

This commit is contained in:
tophf 2022-01-28 19:08:32 +03:00
parent f9e11f5806
commit ae2160afcd

View File

@ -3,13 +3,17 @@
'use strict'; 'use strict';
const router = { const router = {
buffer: [], buffer: (history.state || {}).buffer || [],
watchers: [], watchers: [],
getSearch(key) { getSearch(key) {
return new URLSearchParams(location.search).get(key); return new URLSearchParams(location.search).get(key);
}, },
push(url, state = history.state) {
history.pushState(Object.assign({buffer: router.buffer}, state), null, url);
},
update(replace) { update(replace) {
const {buffer} = router; const {buffer} = router;
if (!buffer.length) { if (!buffer.length) {
@ -53,7 +57,7 @@ const router = {
if (!hash) { if (!hash) {
hash = ' '; hash = ' ';
} }
history.pushState(history.state, null, hash); router.push(hash);
router.update(); router.update();
}, },
@ -83,7 +87,7 @@ window.on('popstate', () => router.update());
window.on('hashchange', () => router.update()); window.on('hashchange', () => router.update());
msg.on(e => { msg.on(e => {
if (e.method === 'pushState' && e.url !== location.href) { if (e.method === 'pushState' && e.url !== location.href) {
history.pushState(history.state, null, e.url); router.push(e.url);
router.update(); router.update();
return true; return true;
} }