'use strict'; /*global define, socket, app, ajaxify, config*/ define('forum/account/settings', ['forum/account/header', 'components', 'sounds'], function (header, components, sounds) { var AccountSettings = {}; AccountSettings.init = function () { header.init(); $('#submitBtn').on('click', function () { var settings = loadSettings(); if (settings.homePageRoute === 'custom' && settings.homePageCustom) { $.get(config.relative_path + '/' + settings.homePageCustom, function () { saveSettings(settings); }).fail(function () { app.alertError('[[error:invalid-home-page-route]]'); }); } else { saveSettings(settings); } return false; }); $('#bootswatchSkin').on('change', function () { var css = $('#bootswatchCSS'); var val = $(this).val() === 'default' ? config['theme:src'] : '//maxcdn.bootstrapcdn.com/bootswatch/latest/' + $(this).val() + '/bootstrap.min.css'; css.attr('href', val); }); $('[data-property="homePageRoute"]').on('change', toggleCustomRoute); $('.account').find('button[data-action="play"]').on('click', function (e) { e.preventDefault(); var soundName = $(this).parent().parent().find('select').val(); sounds.playSound(soundName); }); toggleCustomRoute(); components.get('user/sessions').find('.timeago').timeago(); }; function loadSettings() { var settings = {}; $('.account').find('input, textarea, select').each(function (id, input) { input = $(input); var setting = input.attr('data-property'); if (input.is('select')) { settings[setting] = input.val(); return; } switch (input.attr('type')) { case 'text': case 'textarea': settings[setting] = input.val(); break; case 'checkbox': settings[setting] = input.is(':checked') ? 1 : 0; break; } }); return settings; } function saveSettings(settings) { socket.emit('user.saveSettings', {uid: ajaxify.data.theirid, settings: settings}, function (err, newSettings) { if (err) { return app.alertError(err.message); } app.alertSuccess('[[success:settings-saved]]'); var requireReload = false; for (var key in newSettings) { if (newSettings.hasOwnProperty(key)) { if (key === 'userLang' && config.userLang !== newSettings.userLang) { requireReload = true; } if (config.hasOwnProperty(key)) { config[key] = newSettings[key]; } } } sounds.loadMap(); if (requireReload && parseInt(app.user.uid, 10) === parseInt(ajaxify.data.theirid, 10)) { app.alert({ id: 'setting-change', message: '[[user:settings-require-reload]]', type: 'warning', timeout: 5000, clickfn: function () { ajaxify.refresh(); } }); } }); } function toggleCustomRoute() { if ($('[data-property="homePageRoute"]').val() === 'custom') { $('#homePageCustom').show(); } else { $('#homePageCustom').hide(); $('[data-property="homePageCustom"]').val(''); } } return AccountSettings; });