75 lines
2.3 KiB
JavaScript
75 lines
2.3 KiB
JavaScript
/**
|
|
* Pico's Default Theme - JavaScript helper
|
|
*
|
|
* Pico is a stupidly simple, blazing fast, flat file CMS.
|
|
*
|
|
* @author Daniel Rudolf
|
|
* @link http://picocms.org
|
|
* @license http://opensource.org/licenses/MIT The MIT License
|
|
* @version 2.1
|
|
*/
|
|
|
|
function main()
|
|
{
|
|
// capability CSS classes
|
|
document.documentElement.className = 'js';
|
|
|
|
// wrap tables
|
|
var tables = document.querySelectorAll('#main > .container > table');
|
|
for (var i = 0; i < tables.length; i++) {
|
|
if (!/\btable-responsive\b/.test(tables[i].parentElement.className)) {
|
|
var tableWrapper = document.createElement('div');
|
|
tableWrapper.className = 'table-responsive';
|
|
|
|
tables[i].parentElement.insertBefore(tableWrapper, tables[i]);
|
|
tableWrapper.appendChild(tables[i]);
|
|
}
|
|
}
|
|
|
|
// responsive menu
|
|
var menu = document.getElementById('nav'),
|
|
menuToggle = document.getElementById('nav-toggle');
|
|
|
|
if (menu && menuToggle) {
|
|
function toggleMenuEvent(event) {
|
|
if (event.type === 'keydown') {
|
|
if ((event.keyCode !== 13) && (event.keyCode !== 32)) {
|
|
return;
|
|
}
|
|
}
|
|
|
|
event.preventDefault();
|
|
|
|
if (menuToggle.getAttribute('aria-expanded') === 'false') {
|
|
menuToggle.setAttribute('aria-expanded', 'true');
|
|
utils.slideDown(menu, null, function () {
|
|
if (event.type === 'keydown') {
|
|
menu.focus();
|
|
}
|
|
});
|
|
} else {
|
|
menuToggle.setAttribute('aria-expanded', 'false');
|
|
utils.slideUp(menu);
|
|
}
|
|
}
|
|
|
|
function onResizeEvent() {
|
|
if (utils.isElementVisible(menuToggle)) {
|
|
menu.className = 'hidden';
|
|
menuToggle.addEventListener('click', toggleMenuEvent);
|
|
menuToggle.addEventListener('keydown', toggleMenuEvent);
|
|
} else {
|
|
menu.className = '';
|
|
menu.removeAttribute('data-slide-id');
|
|
menuToggle.removeEventListener('click', toggleMenuEvent);
|
|
menuToggle.removeEventListener('keydown', toggleMenuEvent);
|
|
}
|
|
}
|
|
|
|
window.addEventListener('resize', onResizeEvent);
|
|
onResizeEvent();
|
|
}
|
|
}
|
|
|
|
main();
|