mirror of
https://github.com/philomena-dev/philomena.git
synced 2024-12-18 06:57:59 +01:00
30 lines
748 B
JavaScript
30 lines
748 B
JavaScript
|
/**
|
||
|
* Settings.
|
||
|
*/
|
||
|
|
||
|
import { $, $$ } from './utils/dom';
|
||
|
import store from './utils/store';
|
||
|
|
||
|
export function setupSettings() {
|
||
|
|
||
|
if (!$('#js-setting-table')) return;
|
||
|
|
||
|
const localCheckboxes = $$('[data-tab="local"] input[type="checkbox"]');
|
||
|
const themeSelect = $('#user_theme');
|
||
|
const styleSheet = $('head link[rel="stylesheet"]');
|
||
|
|
||
|
// Local settings
|
||
|
localCheckboxes.forEach(checkbox => {
|
||
|
checkbox.checked = Boolean(store.get(checkbox.id));
|
||
|
checkbox.addEventListener('change', () => {
|
||
|
store.set(checkbox.id, checkbox.checked);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
// Theme preview
|
||
|
themeSelect && themeSelect.addEventListener('change', () => {
|
||
|
styleSheet.href = themeSelect.options[themeSelect.selectedIndex].dataset.themePath;
|
||
|
});
|
||
|
|
||
|
}
|