Menu improvements

* Menus are now expanded when javascript is disabled/not working.
* Menu for the current page now expands upon load.
This commit is contained in:
Dustin Wilson 2019-08-11 08:15:11 -05:00 committed by Stéphane Goetz
parent 47db2e4cba
commit 9d37044303
12 changed files with 45 additions and 23 deletions

View File

@ -26,6 +26,9 @@
<meta name="apple-mobile-web-app-capable" content="yes" /> <meta name="apple-mobile-web-app-capable" content="yes" />
<meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<!-- JS -->
<script>document.documentElement.classList.remove('no-js');</script>
<!-- Font --> <!-- Font -->
<?php foreach ($params['theme']['fonts'] as $font) { <?php foreach ($params['theme']['fonts'] as $font) {
echo "<link href='$font' rel='stylesheet' type='text/css'>"; echo "<link href='$font' rel='stylesheet' type='text/css'>";

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@ -107,21 +107,31 @@ if (hljs) {
}; };
}; };
var navItemsWithChildren = document.querySelectorAll('.Nav__item.has-children > a'); var navItems = document.querySelectorAll('.Nav__item.has-children > a');
function _toggleSubMenu(ev) { function _toggleSubMenu(ev) {
if (ev.preventDefault !== undefined) {
ev.preventDefault(); ev.preventDefault();
}
var parent = ev.target.parentNode; var parent = ev.target.parentNode;
var subNav = parent.querySelector('ul.Nav'); var subNav = parent.querySelector('ul.Nav');
if (parent.classList.contains('Nav__item--open')) { if (ev.preventDefault !== undefined && parent.classList.contains('Nav__item--open')) {
subNav.style.height = 0; subNav.style.height = 0;
parent.classList.remove('Nav__item--open'); parent.classList.remove('Nav__item--open');
} else { } else {
subNav.style.transitionDuration = Math.max(subNav.scrollHeight * 1.5, 150) + 'ms'; if (ev.preventDefault !== undefined) {
subNav.style.transitionDuration = Math.max(subNav.scrollHeight, 150) + 'ms';
subNav.style.height = subNav.scrollHeight + 'px'; subNav.style.height = subNav.scrollHeight + 'px';
parent.classList.add('Nav__item--open'); parent.classList.add('Nav__item--open');
} else {
// When running at page load the transitions don't need to fire and
// the classList doesn't need to be altered.
subNav.style.transitionDuration = '0ms';
subNav.style.height = subNav.scrollHeight + 'px';
subNav.style.transitionDuration = Math.max(subNav.scrollHeight, 150) + 'ms';
}
} }
} }
@ -134,21 +144,27 @@ if (hljs) {
cur = subNav[i]; cur = subNav[i];
height = parseFloat(cur.style.height, 10); height = parseFloat(cur.style.height, 10);
if (height > 0 && cur.scrollHeight !== height) { if (height > 0 && cur.scrollHeight !== height) {
// Disable the height transition, change it, and // Transitions don't need to fire when resizing the window.
// re-establish the transition that's in the stylesheet. cur.style.transitionDuration = '0ms';
cur.style.transitionDuration = 0;
cur.style.height = cur.scrollHeight + 'px'; cur.style.height = cur.scrollHeight + 'px';
cur.style.transitionDuration = Math.max(cur.scrollHeight, 150) + 'ms'; cur.style.transitionDuration = Math.max(cur.scrollHeight, 150) + 'ms';
} }
} }
} }
for (var i = 0; i < navItemsWithChildren.length; i++) { for (var i = 0, cur; i < navItems.length; i++) {
navItemsWithChildren[i].addEventListener('click', _toggleSubMenu); cur = navItems[i];
cur.addEventListener('click', _toggleSubMenu);
if (cur.parentNode.classList.contains('Nav__item--open')) {
_toggleSubMenu({ target: cur });
}
} }
window.addEventListener('resize', debounce(_resize, 150)); window.addEventListener('resize', debounce(_resize, 150));
window.addEventListener('orientationchange', _resize); window.addEventListener('orientationchange', _resize);
})(); })();
(function() { (function() {

View File

@ -199,10 +199,13 @@ Components
} }
.Nav .Nav { .Nav .Nav {
margin-left: 15px;
html:not(.no-js) & {
height: 0; height: 0;
transition: height 400ms ease-in-out; transition: height 400ms ease-in-out;
overflow: hidden; overflow: hidden;
margin-left: 15px; }
.Nav__item a { .Nav__item a {
margin: 0; margin: 0;

View File

@ -43,7 +43,7 @@ body {
@media (max-width: 768px) { @media (max-width: 768px) {
// mobile friendly sub-nav // mobile friendly sub-nav
.Collapsible__content { html:not(.no-js) .Collapsible__content {
height: 0; height: 0;
overflow: hidden; overflow: hidden;
transition: height 400ms ease-in-out; transition: height 400ms ease-in-out;