'use strict'; define('forum/account/theme', ['forum/account/header', 'storage', 'settings', 'alerts'], function (header, Storage, settings, alerts) { const Theme = {}; Theme.init = () => { header.init(); Theme.setupForm(); }; Theme.setupForm = () => { const saveEl = document.getElementById('save'); const formEl = document.getElementById('theme-settings'); const [sidebarSwapped, autohideNavbarEnvs] = [ !!Storage.getItem('persona:menus:legacy-layout'), Storage.getItem('persona:navbar:autohide'), ]; document.getElementById('persona:menus:legacy-layout').checked = sidebarSwapped; try { const parsed = JSON.parse(autohideNavbarEnvs) || ['xs', 'sm']; parsed.forEach((env) => { const optionEl = document.getElementById('persona:navbar:autohide').querySelector(`option[value="${env}"]`); optionEl.selected = true; }); } catch (e) { console.warn(e); } if (saveEl) { saveEl.addEventListener('click', () => { const themeSettings = settings.helper.serializeForm($(formEl)); Object.keys(themeSettings).forEach((key) => { if (key === 'persona:menus:legacy-layout') { if (themeSettings[key] === 'on') { Storage.setItem('persona:menus:legacy-layout', 'true'); } else { Storage.removeItem('persona:menus:legacy-layout'); } return; } Storage.setItem(key, themeSettings[key]); }); alerts.success('[[success:settings-saved]]'); }); } }; return Theme; });