2021-01-14 17:38:33 -05:00
|
|
|
// set up javascript listeners
|
2021-01-14 16:02:28 -05:00
|
|
|
window.onload = function() {
|
2021-01-14 17:38:33 -05:00
|
|
|
// let buttons set keyboard focus
|
2021-01-17 11:50:47 -05:00
|
|
|
document.querySelectorAll('[data-controls]')
|
2021-01-14 18:16:18 -05:00
|
|
|
.forEach(t => t.onclick = toggleAction);
|
2021-01-14 17:38:33 -05:00
|
|
|
|
2021-01-14 18:16:18 -05:00
|
|
|
// javascript interactions (boost/fav)
|
2021-01-14 17:38:33 -05:00
|
|
|
Array.from(document.getElementsByClassName('interaction'))
|
|
|
|
.forEach(t => t.onsubmit = interact);
|
2021-01-14 18:16:18 -05:00
|
|
|
|
|
|
|
// select all
|
|
|
|
Array.from(document.getElementsByClassName('select-all'))
|
|
|
|
.forEach(t => t.onclick = selectAll);
|
2021-01-14 18:29:37 -05:00
|
|
|
|
|
|
|
// toggle between tabs
|
|
|
|
Array.from(document.getElementsByClassName('tab-change-nested'))
|
|
|
|
.forEach(t => t.onclick = tabChangeNested);
|
|
|
|
Array.from(document.getElementsByClassName('tab-change'))
|
|
|
|
.forEach(t => t.onclick = tabChange);
|
2021-01-14 18:45:30 -05:00
|
|
|
|
|
|
|
// handle aria settings on menus
|
|
|
|
Array.from(document.getElementsByClassName('pulldown-menu'))
|
|
|
|
.forEach(t => t.onclick = toggleMenu);
|
2021-01-16 12:21:19 -05:00
|
|
|
|
|
|
|
// display based on localstorage vars
|
|
|
|
document.querySelectorAll('[data-hide]')
|
|
|
|
.forEach(t => setDisplay(t));
|
|
|
|
|
|
|
|
// update localstorage
|
|
|
|
Array.from(document.getElementsByClassName('set-display'))
|
|
|
|
.forEach(t => t.onclick = updateDisplay);
|
2021-01-14 16:02:28 -05:00
|
|
|
};
|
|
|
|
|
2021-01-16 12:21:19 -05:00
|
|
|
function updateDisplay(e) {
|
|
|
|
var key = e.target.getAttribute('data-id');
|
|
|
|
var value = e.target.getAttribute('data-value');
|
|
|
|
window.localStorage.setItem(key, value);
|
|
|
|
|
|
|
|
document.querySelectorAll('[data-hide="' + key + '"]')
|
|
|
|
.forEach(t => setDisplay(t));
|
|
|
|
}
|
|
|
|
|
|
|
|
function setDisplay(el) {
|
|
|
|
var key = el.getAttribute('data-hide');
|
|
|
|
var value = window.localStorage.getItem(key)
|
|
|
|
if (!value) {
|
|
|
|
el.className = el.className.replace('hidden', '');
|
|
|
|
} else if (value != null && !!value) {
|
|
|
|
el.className += ' hidden';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-14 18:16:18 -05:00
|
|
|
function toggleAction(e) {
|
2021-01-17 11:26:28 -05:00
|
|
|
var el = e.currentTarget;
|
2021-01-17 11:50:47 -05:00
|
|
|
var pressed = el.getAttribute('aria-pressed') == 'false';
|
2021-01-17 11:26:28 -05:00
|
|
|
|
|
|
|
var targetId = el.getAttribute('data-controls');
|
|
|
|
document.querySelectorAll('[data-controls="' + targetId + '"]')
|
|
|
|
.forEach(t => t.setAttribute('aria-pressed', !!(t.getAttribute('aria-pressed') == 'false')));
|
2021-01-16 22:57:20 -05:00
|
|
|
|
|
|
|
if (targetId) {
|
|
|
|
var target = document.getElementById(targetId);
|
|
|
|
if (pressed) {
|
2021-01-17 11:26:28 -05:00
|
|
|
removeClass(target, 'hidden');
|
|
|
|
addClass(target, 'is-active');
|
2021-01-16 22:57:20 -05:00
|
|
|
} else {
|
2021-01-17 11:26:28 -05:00
|
|
|
addClass(target, 'hidden');
|
|
|
|
removeClass(target, 'is-active');
|
2021-01-16 22:57:20 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// set checkbox, if appropriate
|
2021-01-17 11:26:28 -05:00
|
|
|
var checkbox = el.getAttribute('data-controls-checkbox');
|
2021-01-16 22:57:20 -05:00
|
|
|
if (checkbox) {
|
|
|
|
document.getElementById(checkbox).checked = !!pressed;
|
|
|
|
}
|
2021-01-17 11:50:47 -05:00
|
|
|
|
|
|
|
// set focus, if appropriate
|
|
|
|
var focus = el.getAttribute('data-focus-target');
|
|
|
|
if (focus) {
|
|
|
|
document.getElementById(focus).focus();
|
|
|
|
}
|
2021-01-14 16:02:28 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2021-01-17 11:26:28 -05:00
|
|
|
function addClass(el, classname) {
|
|
|
|
el.className = el.className.split(' ').concat(classname).join(' ');
|
|
|
|
}
|
|
|
|
|
|
|
|
function removeClass(el, className) {
|
|
|
|
var classes = el.className.split(' ');
|
|
|
|
const idx = classes.indexOf(className);
|
|
|
|
if (idx > -1) {
|
|
|
|
classes.splice(idx, 1);
|
|
|
|
}
|
|
|
|
el.className = classes.join(' ');
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-03-15 21:12:45 -04:00
|
|
|
function interact(e) {
|
|
|
|
e.preventDefault();
|
|
|
|
ajaxPost(e.target);
|
2020-03-21 17:29:39 -04:00
|
|
|
var identifier = e.target.getAttribute('data-id');
|
|
|
|
var elements = document.getElementsByClassName(identifier);
|
|
|
|
for (var i = 0; i < elements.length; i++) {
|
|
|
|
if (elements[i].className.includes('hidden')) {
|
|
|
|
elements[i].className = elements[i].className.replace('hidden', '');
|
|
|
|
} else {
|
|
|
|
elements[i].className += ' hidden';
|
|
|
|
}
|
2020-03-15 21:12:45 -04:00
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2021-01-14 18:16:18 -05:00
|
|
|
function selectAll(e) {
|
|
|
|
e.target.parentElement.parentElement.querySelectorAll('[type="checkbox"]')
|
2020-11-13 13:14:24 -05:00
|
|
|
.forEach(t => t.checked=true);
|
|
|
|
}
|
2020-11-11 21:32:52 -05:00
|
|
|
|
2021-01-14 18:29:37 -05:00
|
|
|
function tabChangeNested(e) {
|
|
|
|
var target = e.target.closest('li')
|
|
|
|
var parentElement = target.parentElement.closest('li').parentElement;
|
|
|
|
handleTabChange(target, parentElement)
|
2020-04-03 19:47:47 -04:00
|
|
|
}
|
|
|
|
|
2021-01-14 18:29:37 -05:00
|
|
|
function tabChange(e) {
|
2020-11-08 22:34:41 -05:00
|
|
|
var target = e.target.closest('li')
|
2021-01-14 18:29:37 -05:00
|
|
|
var parentElement = target.parentElement;
|
|
|
|
handleTabChange(target, parentElement)
|
|
|
|
}
|
2020-03-21 19:50:49 -04:00
|
|
|
|
2020-11-08 22:09:29 -05:00
|
|
|
|
2021-01-14 18:29:37 -05:00
|
|
|
function handleTabChange(target, parentElement) {
|
|
|
|
parentElement.querySelectorAll('[aria-selected="true"]')
|
2020-11-08 22:09:29 -05:00
|
|
|
.forEach(t => t.setAttribute("aria-selected", false));
|
2020-11-08 22:34:41 -05:00
|
|
|
target.querySelector('[role="tab"]').setAttribute("aria-selected", true);
|
2020-11-08 22:09:29 -05:00
|
|
|
|
2021-01-14 18:29:37 -05:00
|
|
|
parentElement.querySelectorAll('li')
|
2020-11-08 22:09:29 -05:00
|
|
|
.forEach(t => t.className='');
|
2020-11-08 22:34:41 -05:00
|
|
|
target.className = 'is-active';
|
2020-03-21 19:50:49 -04:00
|
|
|
}
|
|
|
|
|
2021-01-14 18:45:30 -05:00
|
|
|
function toggleMenu(e) {
|
|
|
|
var el = e.target.closest('.pulldown-menu');
|
2020-11-09 14:58:19 -05:00
|
|
|
el.setAttribute('aria-expanded', el.getAttribute('aria-expanded') == 'false');
|
|
|
|
}
|
|
|
|
|
2020-03-21 17:29:39 -04:00
|
|
|
function ajaxPost(form) {
|
|
|
|
fetch(form.action, {
|
|
|
|
method : "POST",
|
|
|
|
body: new FormData(form)
|
|
|
|
});
|
2020-03-15 17:15:36 -04:00
|
|
|
}
|