2017-01-29 17:36:21 +02:00
|
|
|
/**
|
|
|
|
* A helper wrapper service around window.history
|
|
|
|
*/
|
|
|
|
|
2020-01-17 23:37:52 +03:00
|
|
|
import { createBrowserHistory, History } from 'history';
|
2017-05-25 22:11:57 +03:00
|
|
|
|
|
|
|
export const browserHistory = createBrowserHistory();
|
|
|
|
|
|
|
|
browserHistory.listen(() => {
|
2019-11-27 11:03:32 +02:00
|
|
|
patchHistory(browserHistory);
|
2017-05-25 22:11:57 +03:00
|
|
|
});
|
|
|
|
|
2020-01-17 23:37:52 +03:00
|
|
|
function patchHistory(history: History): void {
|
2019-11-27 11:03:32 +02:00
|
|
|
Object.assign(history.location, {
|
|
|
|
query: new URLSearchParams(history.location.search),
|
|
|
|
});
|
2017-05-25 22:11:57 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
patchHistory(browserHistory);
|
|
|
|
|
2017-01-29 17:36:21 +02:00
|
|
|
export default {
|
2020-01-17 23:37:52 +03:00
|
|
|
initialLength: 0,
|
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
init() {
|
|
|
|
this.initialLength = window.history.length;
|
|
|
|
},
|
2017-01-29 17:36:21 +02:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
/**
|
2019-12-07 13:28:52 +02:00
|
|
|
* @returns {boolean} - whether history.back() can be safetly called
|
2019-11-27 11:03:32 +02:00
|
|
|
*/
|
|
|
|
canGoBack() {
|
|
|
|
return (
|
|
|
|
document.referrer.includes(`${location.protocol}//${location.host}`) ||
|
|
|
|
this.initialLength < window.history.length
|
|
|
|
);
|
|
|
|
},
|
2017-01-31 08:05:36 +02:00
|
|
|
};
|