2024-10-18 18:44:03 +02:00
|
|
|
import { useLayoutStore } from '../stores/layout';
|
|
|
|
|
|
|
|
export function handleReactiveness() {
|
|
|
|
const layoutStore = useLayoutStore();
|
|
|
|
layoutStore.setupResizeListenner();
|
|
|
|
|
2025-01-16 17:32:31 +01:00
|
|
|
// toggle collapse and scroll for etape liste
|
|
|
|
(function setEtapeListe() {
|
2024-10-18 18:44:03 +02:00
|
|
|
const listeEtape = document.querySelector('#etapes-liste');
|
2025-01-16 17:32:31 +01:00
|
|
|
const listeToggleButton = document.querySelector('#retractable-message');
|
|
|
|
const column = document.querySelector('.layout__region--third');
|
|
|
|
const header = document.querySelector('.layout-container > header');
|
2024-10-18 18:44:03 +02:00
|
|
|
|
2024-11-25 23:19:34 +01:00
|
|
|
const animationToggle = document.querySelector('#animation-toggle');
|
|
|
|
|
2025-01-16 17:32:31 +01:00
|
|
|
const EtapeListeScrollElements = {
|
|
|
|
listeEtape,
|
|
|
|
column,
|
|
|
|
listeEtapeContent: listeEtape.querySelector('.item-list'),
|
|
|
|
header,
|
|
|
|
animationToggle: animationToggle.querySelector('.animation-toggle-container')
|
|
|
|
}
|
|
|
|
|
|
|
|
layoutStore.shouldEtapeListeScroll(EtapeListeScrollElements);
|
|
|
|
|
2024-11-25 23:19:34 +01:00
|
|
|
if (!layoutStore.isDesktop) layoutStore.collapseEtapeListe(listeEtape, animationToggle);
|
2024-10-18 18:44:03 +02:00
|
|
|
|
|
|
|
window.addEventListener('resize', () => {
|
2025-01-16 17:32:31 +01:00
|
|
|
layoutStore.shouldEtapeListeScroll(EtapeListeScrollElements);
|
|
|
|
|
2024-10-18 18:44:03 +02:00
|
|
|
if (layoutStore.isDesktop && layoutStore.isEtapeListRetracted) {
|
2024-11-25 23:19:34 +01:00
|
|
|
layoutStore.expandEtapeListe(listeEtape, animationToggle);
|
2024-10-18 18:44:03 +02:00
|
|
|
} else if (!layoutStore.isDesktop && !layoutStore.isEtapeListRetracted) {
|
2024-11-25 23:19:34 +01:00
|
|
|
layoutStore.collapseEtapeListe(listeEtape, animationToggle);
|
2024-10-18 18:44:03 +02:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2024-11-25 23:19:34 +01:00
|
|
|
listeToggleButton.addEventListener('click', () => {
|
2024-10-18 18:44:03 +02:00
|
|
|
if (!layoutStore.isDesktop) {
|
|
|
|
if (!layoutStore.isEtapeListRetracted) {
|
2024-11-25 23:19:34 +01:00
|
|
|
layoutStore.collapseEtapeListe(listeEtape, animationToggle);
|
2024-10-18 18:44:03 +02:00
|
|
|
} else {
|
2024-11-25 23:19:34 +01:00
|
|
|
layoutStore.expandEtapeListe(listeEtape, animationToggle);
|
2025-01-16 17:32:31 +01:00
|
|
|
layoutStore.shouldEtapeListeScroll(EtapeListeScrollElements);
|
2024-10-18 18:44:03 +02:00
|
|
|
}
|
2024-11-25 23:19:34 +01:00
|
|
|
}
|
2024-10-18 18:44:03 +02:00
|
|
|
});
|
|
|
|
})();
|
|
|
|
}
|
|
|
|
|
2024-10-17 02:50:39 +02:00
|
|
|
export function setMenuToggle() {
|
2024-10-22 11:50:33 +02:00
|
|
|
const layoutStore = useLayoutStore();
|
2024-10-17 02:50:39 +02:00
|
|
|
const menuBurger = document.querySelector('#hamburger');
|
2024-10-22 11:50:33 +02:00
|
|
|
const menuContainer = document.querySelector('#block-caravane-mainnavigation > #menu > ul');
|
2024-11-25 23:19:34 +01:00
|
|
|
|
2024-10-22 11:50:33 +02:00
|
|
|
layoutStore.setUpHamburgerToggle(menuBurger, menuContainer);
|
2024-10-17 02:50:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export function setHamburgerWhenLogged(drupalSettings) {
|
|
|
|
if (drupalSettings.user.uid != 0) {
|
|
|
|
const menuBurger = document.querySelector('#hamburger');
|
|
|
|
const menuTitle = document.querySelector('#menu-title');
|
|
|
|
const menuContainer = document.querySelector('#block-caravane-mainnavigation > #menu > ul');
|
|
|
|
const header = document.querySelector('.dialog-off-canvas-main-canvas');
|
|
|
|
const headerTop = header.getBoundingClientRect().top;
|
|
|
|
|
2024-11-25 23:19:34 +01:00
|
|
|
menuTitle.style.top = `${headerTop}px`;
|
2024-10-17 02:50:39 +02:00
|
|
|
menuBurger.style.top = `${headerTop}px`;
|
|
|
|
menuContainer.style.paddingTop = `${headerTop}px`;
|
|
|
|
}
|
2024-11-25 23:19:34 +01:00
|
|
|
}
|