56 lines
2.0 KiB
JavaScript
56 lines
2.0 KiB
JavaScript
import { setActiveNavItem } from "./set-active-nav-item";
|
|
import { useLayoutStore } from '../stores/layout';
|
|
|
|
export async function initFirstLoadRouting(store, router, baseUrl, siteName) {
|
|
const decoupled_origin = JSON.parse(window.localStorage.getItem('decoupled_origin'));
|
|
|
|
if(decoupled_origin) {
|
|
router.push(decoupled_origin.url);
|
|
await store.fetchContentData(baseUrl + decoupled_origin.url);
|
|
window.localStorage.removeItem("decoupled_origin");
|
|
document.title = store.pageTitle;
|
|
setActiveNavItem(store.contentType, decoupled_origin.url);
|
|
useLayoutStore().setHeaderPosition(false);
|
|
} else {
|
|
document.title = siteName;
|
|
useLayoutStore().setHeaderPosition(true);
|
|
}
|
|
}
|
|
|
|
export function handleClickableElements(clickableElements, store, router, baseUrl, siteName, mapStore) {
|
|
for (const link of clickableElements) {
|
|
let href = link.href || link.dataset.href;
|
|
if (href.startsWith(baseUrl)) href = href.replace(baseUrl, '');
|
|
|
|
link.onclick = async function (e) {
|
|
router.push(href);
|
|
if (href !== window.location.pathname) {
|
|
pageChange(href, store, siteName, mapStore, baseUrl);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
export async function handleBrowserNavigation(store, baseUrl, siteName, mapStore) {
|
|
let href = window.location.pathname;
|
|
if (href.startsWith(baseUrl)) href = href.replace(baseUrl, '');
|
|
pageChange(href, store, siteName, mapStore, baseUrl)
|
|
}
|
|
|
|
export async function pageChange(href, store, siteName, mapStore, baseUrl) {
|
|
if (href === '/') {
|
|
store.resetStore(true);
|
|
document.title = siteName;
|
|
mapStore.resetMap();
|
|
useLayoutStore().setHeaderPosition(true);
|
|
} else {
|
|
await store.fetchContentData(baseUrl + href);
|
|
document.title = store.pageTitle;
|
|
useLayoutStore().setHeaderPosition(false);
|
|
}
|
|
setActiveNavItem(store.contentType, href);
|
|
|
|
const listeEtape = document.querySelector('#etapes-liste');
|
|
if (!useLayoutStore().isDesktop) useLayoutStore().collapseEtapeListe(listeEtape);
|
|
}
|