set sophia_after_dark_enable_top_header always to false, as it would a a bar to the top of the page below the admin bar also did some general fixing on php :)
88 lines
2.7 KiB
JavaScript
88 lines
2.7 KiB
JavaScript
/**
|
|
* File navigation.js.
|
|
*
|
|
* Handles toggling the navigation menu for small screens and enables TAB key
|
|
* navigation support for dropdown menus.
|
|
*/
|
|
(function() {
|
|
var container, button, menu, links, i, len;
|
|
|
|
container = document.getElementById('site-navigation');
|
|
if (!container) {
|
|
return;
|
|
}
|
|
|
|
menu = container.getElementsByTagName('ul')[0];
|
|
if (!menu) {
|
|
return;
|
|
}
|
|
|
|
menu.setAttribute('aria-expanded', 'false');
|
|
|
|
if (-1 === menu.className.indexOf('nav-menu')) {
|
|
menu.className += ' nav-menu';
|
|
}
|
|
|
|
// Get all the link elements within the menu.
|
|
links = menu.getElementsByTagName('a');
|
|
|
|
// Each time a menu link is focused or blurred, toggle focus.
|
|
for (i = 0, len = links.length; i < len; i++) {
|
|
links[i].addEventListener('focus', toggleFocus, true);
|
|
links[i].addEventListener('blur', toggleFocus, true);
|
|
}
|
|
|
|
/**
|
|
* Sets or removes .focus class on an element.
|
|
*/
|
|
function toggleFocus() {
|
|
var self = this;
|
|
|
|
// Move up through the ancestors of the current link until we hit .nav-menu.
|
|
while (self && -1 === self.className.indexOf('nav-menu')) {
|
|
|
|
// On li elements toggle the class .focus.
|
|
if ('li' === self.tagName.toLowerCase()) {
|
|
if (-1 !== self.className.indexOf('focus')) {
|
|
self.className = self.className.replace(' focus', '');
|
|
} else {
|
|
self.className += ' focus';
|
|
}
|
|
}
|
|
|
|
self = self.parentElement;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Toggles `focus` class to allow submenu access on tablets.
|
|
*/
|
|
(function(container) {
|
|
var touchStartFn, i,
|
|
parentLink = container.querySelectorAll('.menu-item-has-children > a, .page_item_has_children > a');
|
|
|
|
if ('ontouchstart' in window) {
|
|
touchStartFn = function(e) {
|
|
var menuItem = this.parentNode,
|
|
j;
|
|
|
|
if (!menuItem.classList.contains('focus')) {
|
|
e.preventDefault();
|
|
for (j = 0; j < menuItem.parentNode.children.length; ++j) {
|
|
if (menuItem === menuItem.parentNode.children[j]) {
|
|
continue;
|
|
}
|
|
menuItem.parentNode.children[j].classList.remove('focus');
|
|
}
|
|
menuItem.classList.add('focus');
|
|
} else {
|
|
menuItem.classList.remove('focus');
|
|
}
|
|
};
|
|
|
|
for (i = 0; i < parentLink.length; ++i) {
|
|
parentLink[i].addEventListener('touchstart', touchStartFn, false);
|
|
}
|
|
}
|
|
}(container));
|
|
})(); |