bookwyrm/bookwyrm/static/js/shared.js

168 lines
4.9 KiB
JavaScript
Raw Normal View History

// set up javascript listeners
2021-01-14 21:02:28 +00:00
window.onload = function() {
// let buttons set keyboard focus
document.querySelectorAll('[data-controls]')
2021-01-14 23:16:18 +00:00
.forEach(t => t.onclick = toggleAction);
2021-01-14 23:16:18 +00:00
// javascript interactions (boost/fav)
Array.from(document.getElementsByClassName('interaction'))
.forEach(t => t.onsubmit = interact);
2021-01-14 23:16:18 +00:00
// select all
Array.from(document.getElementsByClassName('select-all'))
.forEach(t => t.onclick = selectAll);
2021-01-14 23:29:37 +00: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);
// handle aria settings on menus
Array.from(document.getElementsByClassName('pulldown-menu'))
.forEach(t => t.onclick = toggleMenu);
// 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 21:02:28 +00: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 23:16:18 +00:00
function toggleAction(e) {
var el = e.currentTarget;
var pressed = el.getAttribute('aria-pressed') == 'false';
var targetId = el.getAttribute('data-controls');
document.querySelectorAll('[data-controls="' + targetId + '"]')
.forEach(t => t.setAttribute('aria-pressed', !!(t.getAttribute('aria-pressed') == 'false')));
2021-01-17 03:57:20 +00:00
if (targetId) {
var target = document.getElementById(targetId);
2021-01-17 18:10:59 +00:00
addRemoveClass(target, 'hidden', !pressed);
addRemoveClass(target, 'is-active', pressed);
}
// show/hide container
var container = document.getElementById('hide-' + targetId);
if (!!container) {
addRemoveClass(container, 'hidden', pressed);
2021-01-17 03:57:20 +00:00
}
// set checkbox, if appropriate
var checkbox = el.getAttribute('data-controls-checkbox');
2021-01-17 03:57:20 +00:00
if (checkbox) {
document.getElementById(checkbox).checked = !!pressed;
}
// set focus, if appropriate
var focus = el.getAttribute('data-focus-target');
if (focus) {
document.getElementById(focus).focus();
}
2021-01-14 21:02:28 +00:00
}
2021-01-17 18:10:59 +00:00
function addRemoveClass(el, classname, bool) {
if (bool) {
addClass(el, classname)
} else {
removeClass(el, classname)
}
}
2021-01-14 21:02:28 +00:00
function addClass(el, classname) {
el.className = el.className.split(' ').concat(classname).join(' ');
}
function removeClass(el, className) {
2021-01-17 18:10:59 +00:00
var classes = []
if (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-16 01:12:45 +00:00
function interact(e) {
e.preventDefault();
ajaxPost(e.target);
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-16 01:12:45 +00:00
}
return true;
}
2021-01-14 23:16:18 +00:00
function selectAll(e) {
e.target.parentElement.parentElement.querySelectorAll('[type="checkbox"]')
2020-11-13 18:14:24 +00:00
.forEach(t => t.checked=true);
}
2021-01-14 23:29:37 +00:00
function tabChangeNested(e) {
var target = e.target.closest('li')
var parentElement = target.parentElement.closest('li').parentElement;
handleTabChange(target, parentElement)
2020-04-03 23:47:47 +00:00
}
2021-01-14 23:29:37 +00:00
function tabChange(e) {
var target = e.target.closest('li')
2021-01-14 23:29:37 +00:00
var parentElement = target.parentElement;
handleTabChange(target, parentElement)
}
2020-03-21 23:50:49 +00:00
2021-01-14 23:29:37 +00:00
function handleTabChange(target, parentElement) {
parentElement.querySelectorAll('[aria-selected="true"]')
.forEach(t => t.setAttribute("aria-selected", false));
target.querySelector('[role="tab"]').setAttribute("aria-selected", true);
2021-01-14 23:29:37 +00:00
parentElement.querySelectorAll('li')
.forEach(t => t.className='');
target.className = 'is-active';
2020-03-21 23:50:49 +00:00
}
function toggleMenu(e) {
var el = e.currentTarget;
var expanded = el.getAttribute('aria-expanded') == 'false';
el.setAttribute('aria-expanded', expanded);
var target = document.getElementById(el.getAttribute('data-controls'));
addRemoveClass(target, 'is-active', expanded);
2020-11-09 19:58:19 +00:00
}
function ajaxPost(form) {
fetch(form.action, {
method : "POST",
body: new FormData(form)
});
2020-03-15 21:15:36 +00:00
}