diff options
author | (quasar) nebula <qznebula@protonmail.com> | 2024-04-23 16:33:45 -0300 |
---|---|---|
committer | (quasar) nebula <qznebula@protonmail.com> | 2024-05-30 20:48:17 -0300 |
commit | 53483407a9f1f7fe20db6574fd4127d0c875e2ce (patch) | |
tree | 2b564866c638e5f45906a9c92c1ee8e7c15ce5e4 /src/static/js | |
parent | 7fe20d1365068c5da45b7d3123b6cea82300e6e9 (diff) |
content: generateChronologyLinksScopeSwitcher
Diffstat (limited to 'src/static/js')
-rw-r--r-- | src/static/js/client.js | 44 |
1 files changed, 33 insertions, 11 deletions
diff --git a/src/static/js/client.js b/src/static/js/client.js index 5611a349..fe45ba16 100644 --- a/src/static/js/client.js +++ b/src/static/js/client.js @@ -2954,7 +2954,7 @@ clientSteps.addPageListeners.push(addAdditionalNamesBoxListeners); const scopedChronologyLinksInfo = initInfo('scopedChronologyLinksInfo', { containers: null, - switchers: null, + switcherLinks: null, modes: null, session: { @@ -2965,12 +2965,18 @@ const scopedChronologyLinksInfo = initInfo('scopedChronologyLinksInfo', { function getScopedChronologyLinksReferences() { const info = scopedChronologyLinksInfo; + const switcher = + document.querySelector('.scoped-chronology-switcher'); + + if (!switcher) { + return; + } + info.containers = - Array.from(document.querySelectorAll('.scoped-chronology')); + Array.from(switcher.querySelectorAll(':scope > div')); - info.switchers = - info.containers - .map(container => container.querySelector('.scoped-chronology-switcher')); + info.switcherLinks = + Array.from(switcher.querySelectorAll('.switcher-link')); info.modes = info.containers @@ -2984,21 +2990,29 @@ function addScopedChronologyLinksPageHandlers() { const info = scopedChronologyLinksInfo; const {session} = scopedChronologyLinksInfo; - for (const [index, switcher] of info.switchers.entries()) { - const currentContainer = - info.containers[index]; - + for (const [index, { + container: currentContainer, + switcherLink: currentSwitcherLink, + }] of stitchArrays({ + container: info.containers, + switcherLink: info.switcherLinks, + }).entries()) { const nextContainer = atOffset(info.containers, index, +1, {wrap: true}); + const nextSwitcherLink = + atOffset(info.switcherLinks, index, +1, {wrap: true}); + const nextMode = atOffset(info.modes, index, +1, {wrap: true}); - switcher.addEventListener('click', domEvent => { + currentSwitcherLink.addEventListener('click', domEvent => { domEvent.preventDefault(); cssProp(currentContainer, 'display', 'none'); + cssProp(currentSwitcherLink, 'display', 'none'); cssProp(nextContainer, 'display', 'block'); + cssProp(nextSwitcherLink, 'display', 'inline'); session.selectedMode = nextMode; }); @@ -3013,11 +3027,19 @@ function mutateScopedChronologyLinksContent() { if (info.modes.includes(selectedMode)) { const selectedIndex = info.modes.indexOf(selectedMode); - for (const [index, container] of info.containers.entries()) { + for (const [index, { + container, + switcherLink, + }] of stitchArrays({ + container: info.containers, + switcherLink: info.switcherLinks, + }).entries()) { if (index === selectedIndex) { cssProp(container, 'display', 'block'); + cssProp(switcherLink, 'display', 'inline'); } else { cssProp(container, 'display', 'none'); + cssProp(switcherLink, 'display', 'none'); } } } |