site/_includes/scripts/settings.js
Ruben 9b38e4bf15
All checks were successful
/ build (push) Successful in 6m53s
clean up styling, redo navbar, redo settings
2025-10-18 03:45:31 -05:00

79 lines
No EOL
3.3 KiB
JavaScript

document.addEventListener("DOMContentLoaded", function() {
// all available settings
const fontInputs = document.querySelectorAll('input[name="font-setting"]');
const themeInputs = document.querySelectorAll('input[name="theme-setting"]');
const uncapitalizationCheckbox = document.getElementById('uncapitalization');
const disableBgCheckbox = document.getElementById('disable-bg');
const disableAnimationsCheckbox = document.getElementById('disable-animations');
const disableAlttextCheckbox = document.getElementById('disable-alttext');
// load saved settings
loadSettings();
// event listeners on all inputs
fontInputs.forEach(input => {
input.addEventListener('change', saveSettings);
});
themeInputs.forEach(input => {
input.addEventListener('change', function() {
saveSettings();
});
});
uncapitalizationCheckbox.addEventListener('change', saveSettings);
disableBgCheckbox.addEventListener('change', saveSettings);
disableAnimationsCheckbox.addEventListener('change', saveSettings);
disableAlttextCheckbox.addEventListener('change', saveSettings);
// settings saving function
function saveSettings() {
// save font setting
const selectedFont = document.querySelector('input[name="font-setting"]:checked').id;
localStorage.setItem('accessibility-font', selectedFont);
// save theme setting
const selectedTheme = document.querySelector('input[name="theme-setting"]:checked').value;
localStorage.setItem('accessibility-theme', selectedTheme);
// save toggle states
localStorage.setItem('accessibility-uncapitalization', uncapitalizationCheckbox.checked);
localStorage.setItem('accessibility-disable-bg', disableBgCheckbox.checked);
localStorage.setItem('accessibility-disable-animations', disableAnimationsCheckbox.checked);
localStorage.setItem('accessibility-disable-alttext', disableAlttextCheckbox.checked);
}
// settings loading function
function loadSettings() {
// load the font setting
const savedFont = localStorage.getItem('accessibility-font');
if (savedFont) {
const fontInput = document.getElementById(savedFont);
if (fontInput) fontInput.checked = true;
}
// load the theme setting
const savedTheme = localStorage.getItem('accessibility-theme');
if (savedTheme) {
const themeInput = document.querySelector(`input[name="theme-setting"][value="${savedTheme}"]`);
if (themeInput) themeInput.checked = true;
}
// load toggle states
if (localStorage.getItem('accessibility-uncapitalization') === 'true') {
uncapitalizationCheckbox.checked = true;
}
if (localStorage.getItem('accessibility-disable-bg') === 'true') {
disableBgCheckbox.checked = true;
}
if (localStorage.getItem('accessibility-disable-animations') === 'true') {
disableAnimationsCheckbox.checked = true;
}
if (localStorage.getItem('accessibility-disable-alttext') === 'true') {
disableAlttextCheckbox.checked = true;
}
}
});