Search/static/js/minimenu.js
partisan 287c7a7a1d
Some checks failed
Run Integration Tests / test (push) Failing after 36s
added 'mini-menu' to result pages
2024-12-07 23:07:19 +01:00

47 lines
No EOL
2.1 KiB
JavaScript

document.addEventListener('DOMContentLoaded', function () {
// Define the updateSettings function first
function updateSettings(settingKey, settingValue) {
const xhr = new XMLHttpRequest();
xhr.open('POST', '/updateSettings', true);
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
xhr.onload = function () {
if (this.status >= 200 && this.status < 300) {
console.log('Settings updated successfully!');
} else {
console.log('Failed to update settings.');
}
};
xhr.send(encodeURI(settingKey + '=' + settingValue));
}
const settingsIcon = document.querySelector('.settings-icon-link-search');
const searchMenu = document.querySelector('.search-menu');
settingsIcon.addEventListener('click', function () {
searchMenu.classList.toggle('settings-menu-hidden');
searchMenu.classList.toggle('settings-menu-visible');
});
// Theme change event listeners
document.getElementById('dark_theme').addEventListener('click', function () {
const currentUrl = new URL(window.location.href); // Get the current URL
currentUrl.searchParams.set('theme', 'dark'); // Add or update the 'theme' parameter
window.location.href = currentUrl.toString(); // Redirect to the updated URL
});
document.getElementById('light_theme').addEventListener('click', function () {
const currentUrl = new URL(window.location.href); // Get the current URL
currentUrl.searchParams.set('theme', 'light'); // Add or update the 'theme' parameter
window.location.href = currentUrl.toString(); // Redirect to the updated URL
});
// Event listener for Safe Search Selection
document.getElementById('safeSearchSelect').addEventListener('change', function () {
updateSettings('safe', this.value);
});
// Event listener for Language Selection
document.getElementById('languageSelect').addEventListener('change', function () {
updateSettings('lang', this.value);
});
});