75 lines
2.2 KiB
JavaScript
75 lines
2.2 KiB
JavaScript
---
|
|
---
|
|
|
|
/*!
|
|
* Basically Basic Jekyll Theme 1.3.1
|
|
* Copyright 2017-2018 Michael Rose - mademistakes | @mmistakes
|
|
* Free for personal and commercial use under the MIT license
|
|
* https://github.com/mmistakes/jekyll-basically-theme/blob/master/LICENSE.md
|
|
*/
|
|
|
|
var menuItems = document.querySelectorAll('#sidebar li');
|
|
|
|
// Get vendor transition property
|
|
var docElemStyle = document.documentElement.style;
|
|
var transitionProp = typeof docElemStyle.transition == 'string' ?
|
|
'transition' : 'WebkitTransition';
|
|
|
|
// Animate sidebar menu items
|
|
function animateMenuItems() {
|
|
for ( var i=0; i < menuItems.length; i++ ) {
|
|
var item = menuItems[i];
|
|
// Stagger transition with transitionDelay
|
|
item.style[ transitionProp + 'Delay' ] = ( i * 75 ) + 'ms';
|
|
item.classList.toggle('is--moved');
|
|
}
|
|
};
|
|
|
|
var myWrapper = document.querySelector('.wrapper');
|
|
var myMenu = document.querySelector('.sidebar');
|
|
var myToggle = document.querySelector('.toggle');
|
|
var myInitialContent = document.querySelector('.initial-content');
|
|
var mySearchContent = document.querySelector('.search-content');
|
|
var mySearchToggle = document.querySelector('.search-toggle');
|
|
|
|
// Toggle sidebar visibility
|
|
function toggleClassMenu() {
|
|
myMenu.classList.add('is--animatable');
|
|
if(!myMenu.classList.contains('is--visible')) {
|
|
myMenu.classList.add('is--visible');
|
|
myToggle.classList.add('open');
|
|
myWrapper.classList.add('is--pushed');
|
|
} else {
|
|
myMenu.classList.remove('is--visible');
|
|
myToggle.classList.remove('open');
|
|
myWrapper.classList.remove('is--pushed');
|
|
}
|
|
}
|
|
|
|
// Animation smoother
|
|
function OnTransitionEnd() {
|
|
myMenu.classList.remove('is--animatable');
|
|
}
|
|
|
|
myMenu.addEventListener('transitionend', OnTransitionEnd, false);
|
|
myToggle.addEventListener('click', function() {
|
|
toggleClassMenu();
|
|
animateMenuItems();
|
|
}, false);
|
|
myMenu.addEventListener('click', function() {
|
|
toggleClassMenu();
|
|
animateMenuItems();
|
|
}, false);
|
|
mySearchToggle.addEventListener('click', function() {
|
|
toggleClassSearch();
|
|
}, false);
|
|
|
|
// Toggle search input and content visibility
|
|
function toggleClassSearch() {
|
|
mySearchContent.classList.toggle("is--visible");
|
|
myInitialContent.classList.toggle("is--hidden");
|
|
setTimeout(function() {
|
|
document.querySelector(".search-content input").focus();
|
|
}, 400);
|
|
}
|