Files
NodeBB/public/src/client/account/settings.js
2021-12-06 14:31:35 -05:00

148 lines
4.0 KiB
JavaScript

'use strict';
define('forum/account/settings', [
'forum/account/header', 'components', 'translator', 'api', 'alerts',
], function (header, components, translator, api, alerts) {
const AccountSettings = {};
// If page skin is changed but not saved, switch the skin back
$(window).on('action:ajaxify.start', function () {
if (ajaxify.data.template.name === 'account/settings' && $('#bootswatchSkin').val() !== config.bootswatchSkin) {
reskin(config.bootswatchSkin);
}
});
AccountSettings.init = function () {
header.init();
$('#submitBtn').on('click', function () {
const settings = loadSettings();
if (settings.homePageRoute === 'custom' && settings.homePageCustom) {
$.get(config.relative_path + '/' + settings.homePageCustom, function () {
saveSettings(settings);
}).fail(function () {
alerts.error('[[error:invalid-home-page-route]]');
});
} else {
saveSettings(settings);
}
return false;
});
$('#bootswatchSkin').on('change', function () {
reskin($(this).val());
});
$('[data-property="homePageRoute"]').on('change', toggleCustomRoute);
toggleCustomRoute();
components.get('user/sessions').find('.timeago').timeago();
};
function loadSettings() {
const settings = {};
$('.account').find('input, textarea, select').each(function (id, input) {
input = $(input);
const setting = input.attr('data-property');
if (input.is('select')) {
settings[setting] = input.val();
return;
}
switch (input.attr('type')) {
case 'checkbox':
settings[setting] = input.is(':checked') ? 1 : 0;
break;
default:
settings[setting] = input.val();
break;
}
});
return settings;
}
function saveSettings(settings) {
api.put(`/users/${ajaxify.data.uid}/settings`, { settings }).then((newSettings) => {
alerts.success('[[success:settings-saved]]');
let languageChanged = false;
for (const key in newSettings) {
if (newSettings.hasOwnProperty(key)) {
if (key === 'userLang' && config.userLang !== newSettings.userLang) {
languageChanged = true;
}
if (config.hasOwnProperty(key)) {
config[key] = newSettings[key];
}
}
}
if (languageChanged && parseInt(app.user.uid, 10) === parseInt(ajaxify.data.theirid, 10)) {
translator.translate('[[language:dir]]', config.userLang, function (translated) {
const htmlEl = $('html');
htmlEl.attr('data-dir', translated);
htmlEl.css('direction', translated);
});
translator.switchTimeagoLanguage(utils.userLangToTimeagoCode(config.userLang), function () {
overrides.overrideTimeago();
ajaxify.refresh();
});
}
});
}
function toggleCustomRoute() {
if ($('[data-property="homePageRoute"]').val() === 'custom') {
$('#homePageCustom').show();
} else {
$('#homePageCustom').hide();
$('[data-property="homePageCustom"]').val('');
}
}
function reskin(skinName) {
const clientEl = Array.prototype.filter.call(document.querySelectorAll('link[rel="stylesheet"]'), function (el) {
return el.href.indexOf(config.relative_path + '/assets/client') !== -1;
})[0] || null;
if (!clientEl) {
return;
}
const currentSkinClassName = $('body').attr('class').split(/\s+/).filter(function (className) {
return className.startsWith('skin-');
});
if (!currentSkinClassName[0]) {
return;
}
let currentSkin = currentSkinClassName[0].slice(5);
currentSkin = currentSkin !== 'noskin' ? currentSkin : '';
// Stop execution if skin didn't change
if (skinName === currentSkin) {
return;
}
const linkEl = document.createElement('link');
linkEl.rel = 'stylesheet';
linkEl.type = 'text/css';
linkEl.href = config.relative_path + '/assets/client' + (skinName ? '-' + skinName : '') + '.css';
linkEl.onload = function () {
clientEl.parentNode.removeChild(clientEl);
// Update body class with proper skin name
$('body').removeClass(currentSkinClassName.join(' '));
$('body').addClass('skin-' + (skinName || 'noskin'));
};
document.head.appendChild(linkEl);
}
return AccountSettings;
});